/*
Theme Name: Tangonale
Version: 1.0
Author: Ewald Natter
Author URI: http://www.freelenz.at
Description: WordPress Theme für die Tangonale
*/

::selection {
  background: #000;
  color: #fff;
  }
  
::-moz-selection {
  background: #333;
  color: #fff;
  }  

* {
	border: none;
	margin: 0;
	padding: 0;
	outline: none;
	box-sizing: border-box;
	-webkit-appearance: none;
  
  --wp--preset--font-size--large: 22px;
  --scale: calc(100vw / 1728);
  --footer-text-color: #E5E7EB;
  }
  
HTML {
  height: 100%;
  }  
  
BODY {
  height: 100%;
  background: var(--darker);  
  }
  
UL, LI {
  list-style-type: none;
  }  
  
A {
  transition: 0.2s;
  text-decoration: none;
  }  
  
P {
  margin-bottom: 1.5em;
  }
  
MAIN P:last-child {
  margin-bottom: 0em;
  }      
  
P A,
A.active,
.project A,
.email A,
.phone A {
  text-decoration: underline;
  text-underline-offset: 2px;
  }
  
IMG {
  vertical-align: baseline;
  }  
  
INPUT {
  font: inherit;
  }  
  
INPUT::-webkit-input-placeholder {
  color: #999;
  }

INPUT::-moz-placeholder {  
  color: #999;  
  }

INPUT:-ms-input-placeholder {  
  color: #999;  
  }
  
/* HEADER
------------------------------------------------------------------------- */   

HEADER {
  width: 100%;
  z-index: 21;
  position: relative;
  }
  
HEADER #logo {
  position: absolute;
  z-index: 21;
  top: calc(16vw / 1728 * 100);
  right: calc(16vw / 1728 * 100);
  }  
  
HEADER #logo IMG {  
  width: calc(500vw / 1728 * 100);
  height: auto;
  }
  
/* LAYOUT
------------------------------------------------------------------------- */  
  
#page {
  background: #fff;
  }  
  
/* MOBILE MENU
------------------------------------------------------------------------- */    
  
#burger {
  position: fixed;
  top: 0px;
  left: 0;
  display: block;
  z-index: 10000;  
  width: 86px;
  height: 76px;
  
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  transition: position 0s;
  cursor: pointer;
  transform: scale(var(--scale)) !important;
  transform-origin: 0 0;
  }

#burger span {
  display: block;
  position: absolute;
  height: 4px;
  width: calc(56vw / 1728 * 100);
  background: #000;
  opacity: 1;
  left: calc(16vw / 1728 * 100);
  
  
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out;
  }

#burger span:nth-child(1) {
  top: calc(15vw / 1728 * 100);
  }

#burger span:nth-child(2),#burger span:nth-child(3) {
  top: calc(35vw / 1728 * 100);
  }

#burger span:nth-child(4) {
  top: calc(55vw / 1728 * 100);
  }

#burger.open span:nth-child(1) {
  top: calc(20vw / 1728 * 100);
  width: 0%;
  left: 50%;
  }

#burger.open span:nth-child(2) {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  }

#burger.open span:nth-child(3) {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
  }

#burger.open span:nth-child(4) {
  top: 20px;
  width: 0%;
  left: 50%;
  } 
  
/* MENU
------------------------------------------------------------------------- */     

#menu {
  position: fixed;
  top: 0;
  width: 88vw;
  height: 100%;
  left: 12%;
  right: 0;
  background: rgba(255,255,255,0.9);
  display: flex;
  align-items: center;
  padding-left: calc(190vw / 1728 * 100);
  z-index: 20;
  transform: translateX(100vw);
  transition: 0.5s;
  }
  
BODY.menu #menu {
  transform: none;
  }  
  
#menu NAV.main {
  margin-bottom: calc(100vw / 1728 * 100);
  }  
  
#menu NAV.main UL LI {
  overflow: hidden;
  }  
  
#menu NAV.main > DIV > UL > LI > A {
  font-family: "EK Roumald";
  font-size: calc(48vw / 1728 * 100);
  line-height: 1.5;
  text-transform: uppercase;
  color: var(--darker);
  float: left;
  position: relative;
  overflow: hidden;
  }
  
#menu NAV.main > DIV > UL > LI > A:before {  
  content: "→ ";
  margin-left: calc(50vw / 1728 * -100);
  transition: 0.2s;  
  opacity: 0;
  }
  
#menu NAV.main > DIV > UL > LI:hover > A:before {  
  opacity: 1;
  margin-left: 0;
  }  
  
#menu NAV.main > DIV > UL > LI > A:after {  
  content: " ";
  position: absolute;
  height: 2px;
  background: var(--darker);
  bottom: calc(3vw / 1728 * 100);
  left: calc(50vw / 1728 * 100);
  right: auto;
  transition: 0.4s;
  width: 0;
  }
  
#menu NAV.main UL LI:hover A:after { 
  left: calc(52vw / 1728 * 100);  
  right: 0;
  opacity: 1;
  width: 100%;
  }
  
#menu NAV.main UL UL {
  float: left;
  margin-left: calc(25vw / 1728 * 100);
  opacity: 0;
  transition: 0.2s;
  }
  
#menu NAV.main UL LI:hover UL {
  opacity: 1;
  }  
  
#menu NAV.main UL UL LI {
  float: left;
  margin-left: 0;
  } 
  
#menu NAV.main UL UL LI.mobile {
  display: none;
  }     
  
#menu NAV.main UL UL LI A {
  display: block;
  font-family: "ABC Favorit";
  font-size: calc(16vw / 1728 * 100);
  color: var(--darker);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: calc(15vw / 1728 * 100) calc(20vw / 1728 * 100);
  }
  
#menu NAV.main UL UL LI A:hover {   
  color: var(--red);
  }
  
#menu NAV.main UL UL LI A:before {  
  content: "(";
  opacity: 1;
  margin-left: 0;
  }
  
#menu NAV.main UL UL LI A:after {  
  content: ")";
  }  
  
#menu .bottom {  
  position: absolute;
  left: calc(190vw / 1728 * 100);
  right: calc(55vw / 1728 * 100);
  bottom: calc(90vw / 1728 * 100);
  display: flex;
  justify-content: space-between;
  align-items: center;
  }
  
#menu .bottom NAV LI {
  float: left;
  }  
  
#menu .bottom NAV A {
  color: var(--darker);
  } 
  
#menu .bottom NAV A:hover {  
  color: var(--red);
  }
  
#menu .bottom NAV.social-media {
  display: flex;
  align-items: center;
  }  
  
#menu .bottom NAV.social-media .hashtag,
#menu .bottom NAV LI {
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-size: calc(18vw / 1728 * 100);
  }
  
#menu .bottom NAV.social-media LI A:after {
  content: " →";
  }   
  
#menu .bottom NAV LI.menu-item-type-custom A:after {
  content: " ↗";
  }   
  
#menu .bottom NAV.social-media .hashtag {
  margin-left: 10px;
  }  
  
#menu .bottom NAV.legal LI:after {
  content: " / ";
  margin-right: 0.25em;
  }  
  
#menu .bottom NAV.legal LI:last-child:after {
  display: none;
  }
  
/* A ANIMATED
------------------------------------------------------------------------- */     
  
.logo svg {
  width: calc(60vw / 1728 * 100);
  height: auto;
  float: right;
  }
  
#menu .logo svg .a {  
  opacity: 0;
  transition: 1s;
  }
  
#menu .logo svg #a1.visible {    
  opacity: 0.05;
  }
  
#menu .logo svg #a2.visible {    
  opacity: 0.2;
  }
  
#menu .logo svg #a3.visible {    
  opacity: 0.4;
  }
  
#menu .logo svg #a4.visible {    
  opacity: 0.6;
  }
  
#menu .logo svg #a5.visible {    
  opacity: 0.8;
  }
  
#menu .logo svg path {
  fill: #1d1d1b;
  }   
  
FOOTER .logo svg { 
  height: calc(69vw / 1728 * 100);  
  width: auto;
  }
  
FOOTER .logo svg .a { 
  opacity: 0;
  transition: 1s;
  }
  
FOOTER .logo svg path {
  fill: var(--footer-text-color);
  }
  
FOOTER .logo svg #fa1.visible {    
  opacity: 0.05;
  }
  
FOOTER .logo svg #fa2.visible {    
  opacity: 0.2;
  }
  
FOOTER .logo svg #fa3.visible {    
  opacity: 0.4;
  }
  
FOOTER .logo svg #fa4.visible {    
  opacity: 0.6;
  }
  
FOOTER .logo svg #fa5.visible {    
  opacity: 0.8;
  }  
  
/* HOME
------------------------------------------------------------------------- */   

BODY.home #page {
  min-height: 100%;
  }
  
BODY.home #title {
  display: none;
  }  
  
BODY.home MAIN {
  position: absolute;
  top: calc(76vw / 1728 * 100);
  bottom: 0;
  left: 0;
  right: 0;
  }  
  
BODY.home FOOTER {
  display: none;
  }  
  
/* SLIDEDECK
------------------------------------------------------------------------- */   
  
#slidedeck {
  display: flex;
  width: 100%;
  height: 100%;
  overflow: hidden;
  }

#slidedeck .panel {
  position: relative;
  flex: 0 0 4%;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  z-index: 1;
  transition: flex-basis 0.5s cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  }
  
#slidedeck #idee.panel {
  background: var(--wp--preset--color--lighter);
  }
  
#slidedeck #idee.panel .content {  
  padding-left: calc(40vw / 1728 * 100);
  }
  
#slidedeck #raum.panel {
  background: var(--wp--preset--color--light);
  }
  
#slidedeck #raum.panel .content {  
  padding-left: calc(20vw / 1728 * 100);
  }  
  
#slidedeck #musik.panel {
  background: var(--wp--preset--color--red);
  } 
  
#slidedeck .panel:not(.active) {
  flex: 0 0 4%;
  }
  
#slidedeck .panel.active {
  flex-basis: 88%; /* 100% - (4 panels - 1) * 4% */
  }
  
#slidedeck .panel::after {
  content: "";
  position: absolute;
  inset: 0;
  }

#slidedeck .label {
  display: block;
  position: absolute;
  text-transform: uppercase;
  font-family: "EK Roumald";
  font-size: calc(48vw / 1728 * 100);
  line-height: calc(33vw / 1728 * 100);
  letter-spacing: 0.03em;
  left: 4vw;
  top: calc(360vw / 1728 * 100);
  color: var(--darker);
  transform: rotate(-90deg);
  transform-origin: 0 100%;
  opacity: 1;
  transition: 0.2s ease;
  white-space: nowrap;
  }
  
#slidedeck .panel.active .label {
  color: #fff;
  font-family: "ABC Favorit";
  font-size: calc(22vw / 1728 * 100);
  margin-top: calc(5vw / 1728 * -100);
  }  
  
#slidedeck .label SPAN {
  position: absolute;
  left: calc(50vw / 1728 * 100);
  transition: 0.2s;
  }  
  
#slidedeck .label .hover {  
  opacity: 0;
  }
  
#slidedeck .label:before {
  content: "→ ";
  opacity: 0;
  transition: 0.2s;
  }
  
#slidedeck .panel:not(.active):hover .label {
  margin-top: calc(60vw / 1728 * -100);
  }
  
#slidedeck .panel:not(.active):hover .label:before {  
  opacity: 1;
  }
  
#slidedeck .panel:not(.active):hover .label .default {    
  opacity: 0;
  }
  
#slidedeck .panel:not(.active):hover .label .hover {    
  opacity: 1;
  }  

#slidedeck .content {
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(4vw);
  width: calc(84vw);
  opacity: 0;
  transition: opacity 0.2s ease 0.2s, transform 0.2s ease 0.2s;
  z-index: 1;
  transition-delay: 0.25s;
  cursor: auto;
  }

#slidedeck .panel.active .content {
  opacity: 1;
  }  
  
#slidedeck #intro.panel {
  background-size: cover;
  background-position: center center;
  }    
  
#slidedeck #intro.panel .label {
  display: none;
  }
  
#slidedeck #intro .content {
  left: 0;
  width: 88vw;
  display: flex;
  align-items: center;
  opacity: 1 !important;
  }
  
#slidedeck #intro .background FIGURE {  
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  }
  
#slidedeck #intro .background FIGURE IMG {     
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  }
  
#slidedeck #intro .background .mobile {    
  display: none;
  }
  
#slidedeck #intro .content VIDEO {  
  width: 100%;
  height: auto;
  position: relative;
  z-index: 1;
  background: transparent !important;
  background-color: transparent !important;
  /*margin-top: calc(180vw / 1728 * 100);*/
  }
  
/* LINK HOVER EFFECT
------------------------------------------------------------------------- */   

.wp-block-button .wp-block-button__link,
.more A,
FOOTER LI A {
  position: relative;
  }
  
.wp-block-button .wp-block-button__link:before,
.more A:before, 
FOOTER LI A:before {
  content: " ";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1.5px;
  background: var(--red);
  transition: 0.2s;
  }
  
FOOTER LI A:before {
  background: var(--footer-text-color);
  }
  
#slidedeck .panel .wp-block-button__link:before {
  background: #fff;
  }

.wp-block-button .wp-block-button__link:hover:before,
.more A:hover:before,
FOOTER LI A:hover:before {
  width: 100%;
  }

/* FOOTER
------------------------------------------------------------------------- */  

FOOTER {
  color: var(--footer-text-color);
  background: #fff;
  position: relative;
  z-index: 2;
  }

BODY.home FOOTER {  
  margin-top: calc(-46vw / 1728 * 100);  
  background: none;
  }

FOOTER .stripe {  
  height: calc(23vw / 1728 * 100);
  background: #FF4043;
  }
  
FOOTER .stripe.o60 {
  opacity: 0.6;
  }  
  
FOOTER .stripe.o30 {
  opacity: 0.3;
  }
  
FOOTER .content {
  padding: calc(16vw / 1728 * 100);
  padding-top: calc(36vw / 1728 * 100);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;  
  background: var(--red);
  }  
  
FOOTER A {  
  color: var(--footer-text-color);
  }
  
FOOTER .left {
  display: flex;
  align-items: flex-end;
  gap: calc(125vw / 1728 * 100);
  }  
  
FOOTER ADDRESS,
FOOTER .email {
  font-size: calc(16vw / 1728 * 100);
  font-style: normal;
  letter-spacing: 0.04em;
  } 
  
FOOTER ADDRESS P {
  margin-bottom: 0;
  }  
  
FOOTER .email:hover {
  color: var(--darker);
  }
  
FOOTER NAV {
  display: flex;
  gap: calc(150vw / 1728 * 100);
  } 
  
FOOTER NAV A {
  display: inline-block;
  font-size: calc(22vw / 1728 * 100);
  padding-top: calc(7vw / 1728 * 100);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  }
  
FOOTER NAV A:after {  
  content: " →";
  }
  
FOOTER NAV LI.menu-item-type-custom A:after {
  content: " ↗";
  }  
  
FOOTER .right .logo {
  height: calc(69vw / 1728 * 100);
  }  
  

  
