@charset "UTF-8";

@font-face {
    font-family: 'gyre';
    src: url('/img/fonts/texgyreheros-regular-webfont.woff')format('woff');
    font-weight: 100;
    font-style: normal;
}


/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
html {
    margin: 0%;
    margin-bottom: 0%;
    height: 100%;

    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
} 


body {
  margin: 0%;
  margin-top: 0%;
  margin-bottom: 0%;
  width: 100%;
  text-rendering: optimizeLegibility;
  overflow:auto;
  position: relative;
    
    
}


main {
    padding: 0%;
    padding-bottom: 0%;
    height: 100%;
    margin-bottom: 0%;
    left:0;
    justify-content: center;
    align-items: center;
    
}
  

  
article,
aside,
footer,
header,
nav,
section, main {
    display: block
    
}

h1 {
    font-size: 1.2em;
    font-family: 'gyre';
    letter-spacing: 0.05rem;
}

h2{
    font-size: 1em;
    font-family: 'gyre';
    letter-spacing: 0.05em;
    text-transform: uppercase;
}
.background_a_color{

    background-color:rgb(255, 255, 255);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow:hidden;
  }
  
  .svg-container {
    position: fixed;
    bottom: 0;
    width: calc(100% + 0px);
    text-align: center;
    height: calc(100% - 84px - 15px);
    transform: translateY(0);
    animation: animationlogo 4.5s ease;

  }
  @keyframes animationlogo {
    0% {
      bottom: calc(-100% - 84px - 10px);
    }
    15% {
      bottom: calc(-100% - 84px - 10px);
    }
    75% {
      bottom: 0;  
    }
    100% {
      bottom: 0;}
  }
  
 /* iPhone XR */
@media only screen and (min-device-width: 375px) and (max-device-width: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait) {
  .animated-svg {
    position: fixed;
    top: 50%;
    right: -17%;
    width: 100vh;
    height: 100vw;
    transform: scale(250%);
  }
}

/* iPhone SE */
@media only screen and (min-device-width: 320px) and (max-device-width: 568px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait) {
  .animated-svg {
    position: fixed;
    top: 50%;
    right: -25%;
    width: 100vh;
    transform: scale(200%);
  }
}




/* iPad Mini */
@media (min-width: 768px) and (max-width: 1024px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait) {
  .animated-svg {
    position: fixed;
    top: 70%;
    right: 12%;
    width: 100vh;
    height: 100vw;
    transform: scale(280%);}}

/* iPad Pro and iPad Air */
@media (min-width: 1024px) and (max-width: 1366px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait) {
  .animated-svg {
    position: fixed;
    top: 50%;
    right: 11%;
    width: 100vh;
    height: 100vw;
    transform: scale(250%);
  }
}

/* Additional iPad Pro and iPad Air */
@media (min-width: 1024px) and (max-width: 1366px) and (-webkit-device-pixel-ratio: 2) and (orientation: landscape) {
  .animated-svg {
    right: 5.5%;

  }
}



/*dropdown menubar*/

.hover-image {
  display: none;
  position: absolute;
  top: 30%;
  left:38%;
  width: 30vw;
  height: 30vw;
  overflow: hidden;
  }
  
  
.hover-link:hover + .hover-image {
  display: block;
  transform: translateX(-10%);
  overflow: hidden;
  }
.hover-link{
  font-size: 18px;
}

nav {
  display: flex;
  justify-content: space-between;
  height: 100%;
  color: #000000;
  background-color: transparent;

  
    
}
nav a:first-child {
	text-decoration: none;
	color: #000000;
  letter-spacing: 0.03em;
  
  }
  
  nav a:first-child:hover {
	color: #c2c2c2;
  }
  
  
span {
  font-size: 18px;
  font-family: 'gyre';
  padding: 10px;
  position: left;
  cursor: pointer;
  letter-spacing: 0.05em;

}

  
.overlay {
  height: 0;
  bottom: 0px;
  position: fixed;
  z-index: 1;
  width: 100%;
  left: 0;
  transform: translateX(0);
  text-align: center;
  background-color:rgb(255, 255, 255);
  overflow-y: auto; 
  transition:0.9s cubic-bezier(0.075, 0.82, 0.165, 1);
    
}
.overlay-grid {
  display: grid;
  grid-template-columns: 1fr 2fr ;
  grid-gap: 30px;
  margin-top: 30px;
  margin-left:15px;

  
}

.overlay-grid ul {
  list-style: none;
  font-family: 'gyre';
  padding: 0;
  line-height: 1.1em;
  letter-spacing: 0.05rem;
  font-family: 'gyre';
  font-size: 18px;
}

.overlay-grid h2 {
  margin-top: 30px;
  text-align: left;  
}

.overlay-grid ul li {
  margin-bottom: 10px;
  text-align: left;
  list-style: none;

}
.overlay-grid li a{
  text-decoration: none;
  font-size: 18px;
  display: inline;
}

.overlay-content {

  display: flex;
	flex-direction: column;
	justify-content: space-between;
	text-align: left;
  margin-left: 15px;
 ;
}
.overlay-onecol{
  padding-right:15vw;

}
.overlay p {
  letter-spacing: 0.05rem;
  font-family: 'gyre';
  font-size: 18px;
  line-height: 1.1em;
  margin-left: 15px
}

.overlay a {

  font-family: 'gyre';
  display: inline;
  letter-spacing: 0.05em;
  text-decoration: none;
  color:black;
}
.overlay .overlay-content a:first-child:hover,
.overlay .overlay-content a:first-child:focus {
    color: #c2c2c2 !important;
}

.overlay a:hover,
.overlay a:focus {
    color: #c2c2c2;
}

#about-text-trigger {
  margin-top: 15px;
  cursor: pointer;
}
    

.overlay #about-text-trigger:hover,
.overlay #about-text-trigger:focus {
    color:#c2c2c2;
}
@media (min-width: 1024px) and (max-width: 1200px){
  .overlay-grid{
    display: grid;
    grid-template-columns: 1fr 2fr;
    grid-gap: 30px;
    margin-top: 30px;
    margin-left: 15px;
  }
}

/* Mobile devices */
@media (max-width: 767px) {
  .overlay-grid {
    display: block; /* Apply for mobile devices */
  }
}

/* iPad and Desktop */
@media (min-width: 768px) and (max-width: 1023px) {
  .overlay a {
    line-height: 1em; /* Apply for iPad */
  }
}

/* iPhone X, iPhone SE, and similar devices */
@media (min-width: 360px) and (max-width: 812px) {
  .overlay a {
    line-height: 1em; /* Apply for iPhone X, iPhone SE, etc. */
  }
  .overlay-grid {
    display: block; /* Apply for iPhone X, iPhone SE, etc. */
    margin-top: 0px; /* Apply for iPhone X, iPhone SE, etc. */
  }
  .overlay ul {
    margin: 0 auto; /* Apply for iPhone X, iPhone SE, etc. */
  }
  .overlay-grid h2 {
    text-align: left; /* Apply for iPhone X, iPhone SE, etc. */
    padding-top: 15px; /* Apply for iPhone X, iPhone SE, etc. */
    margin-bottom: 15px; /* Apply for iPhone X, iPhone SE, etc. */
  }
}

/* iPad, iPad Mini, iPad Air, and similar devices */
@media (min-width: 360px) and (max-width: 1024px) {
  .overlay-grid {
    display: block; /* Apply for iPad, iPad Mini, iPad Air, etc. */
    padding-right:10px;
  }
 
  .overlay-content {
    font-size: 1.2em; /* Apply for iPad, iPad Mini, iPad Air, etc. */
    line-height: 1; /* Apply for iPad, iPad Mini, iPad Air, etc. */
    max-width: 100%; /* Apply for iPad, iPad Mini, iPad Air, etc. */
    padding-top: 10px; /* Apply for iPad, iPad Mini, iPad Air, etc. */
    margin-left: 10px;
  }
  .overlay-onecol {
    padding-right:20px;
  }
  .hover-link{
    margin-left: 10px;
  }
}

/* iPhone XR, iPhone 12 Pro, and similar devices */
@media (min-width: 414px) and (max-width: 768px) {
  .overlay a {
    line-height: 1em; /* Apply for iPhone XR, iPhone 12 Pro, etc. */
  }
}

/*Mac Book Pro late 2014*/
@media (min-width:1025px) and (max-width:1440px) {
.overlay-grid{
display: grid;
} 
}

/* footer */

footer {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: transparent;
    animation: animationlogo 4.5s ease;
  }
  
  
  
  .accordion-header {
    overflow: hidden;
    cursor: pointer;
    color: #000000;
    bottom: 0px;
    font-family: 'gyre';
    font-size: 18px;
  }
  
  .accordion-header-title {
    font-size: 18px;
    padding-left: 10px;
    padding-bottom: 0%;
    letter-spacing: 0.05em;
    font-family: 'gyre';
  }
  
  footer .accordion-content {
    height: 0;
    display: flex;
    justify-content: space-between;
    transition:0.9s cubic-bezier(0.075, 0.82, 0.165, 1);
    letter-spacing: 0.05em;
  }
  
  #contact-left {
   
    width: 50%;
    text-align: left;
    padding-left: 10px;
  }
  
  #contact-right {
    

    text-align: right;
    padding-right: 10px;
  }

  #contact-left:hover{
    color: #c2c2c2;
  }
  #contact-right:hover{
    color: 	#c2c2c2;
  }
 

 /* Media Queries for Mobile Devices */
@media (min-width: 375px) and (max-width: 767px) {
  footer{
    height:0;
    position: fixed;
  }
  .accordion-header {
    font-size: 18px;
    background-color: rgb(255, 255, 255);
    position: absolute;
    width:100%;
  }

  .accordion-header-title {
    font-size: 18px;
  }


}

/* Media Queries for Tablets */
@media (min-width: 768px) and (max-width: 1023px) {
  footer{
    height:0;
    position: fixed;
  }
  .accordion-header {
    font-size: 1.3em;
    line-height: 28px;
    background-color: rgb(255, 255, 255);
    position: absolute;
    width:100%;
  }

  .accordion-header-title {
    font-size: 17px;
  }
  

  /* Adjust other styles as needed */
}

  /*main*/
  
#content{
  margin: 34px 0px 20px;
}

.background_project1{
  background-color: white;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    }
    
.background_project2{
  background-color: rgb(255, 255, 255);
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  }
.background_project3{
  background-color: white;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.project__text{
  font-family: 'gyre';
  line-height: 1.1;
  color:#000000;
  letter-spacing: 0.2em;
  position: relative;
  text-align: left;
  max-width: 80%;
  margin-bottom:25px;
}
.project__text h1{
  padding-top: 1%;
  padding-bottom:1px;
  display:inline-block;
  text-transform: uppercase;
}
.titel-text {
  font-size: 16px;
  letter-spacing: 0.02em;
}
.project__text h2{
  text-align: left;

}
#specs-container {
  line-height: 1;
  display: grid;
  grid-template-columns: repeat(2,1fr);
  text-align: left;
  column-gap: 15px;
  row-gap: 5px;
  margin: 10px 0px 200px;

}
#specs-element {
  font-family: 'gyre';
  position: relative;
  line-height: 0.8rem;
  letter-spacing: 0.04em;
  font-size: 18px;
}
a{
    text-decoration: none;
    color:#000000;
}
a:hover{
    color: #c2c2c2;
}
.project__text:first-child{
    margin-top:0;
    margin-left:10px;
}

.single__gallery{
  height:calc(100vw / 7 * 5 - 10px);
  width:100vw;
  margin-left:auto;
  margin-right:auto;
  position:relative;
  margin-bottom:40px;
  position:relative
}
.single__gallery.right{
  cursor:e-resize
}
.single__gallery.left{
  cursor:w-resize
}

.single__img{
  display:none;
  position:absolute;
  height:100%;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  margin-bottom:5px;

}
.single__img img{
  width:auto;
  height:100%
  
}
.single__img.active{
  display:block
}
.single__img-caption{
  margin-top:5px;
  padding-left:20px;
  font-family: 'gyre';
  color:#000000;
  font-size: 13px;
  letter-spacing: 0.03em;
}
@media (min-width:375px) {
  .single__gallery{
    height:calc(100vw / 12 * 10 / 7 * 5 - 15 px);
  }
  .project__text{
    padding: 10px 10px;
    max-width: 90%;
    
  }
  .project__text h1{
    font-size: 1em;
  }
  
  #specs-container{
    display:block;
  }
  #specs-element{
    padding-left: 20px;
  }
}

@media (min-width:500px){
  .single__gallery{
      height:calc(100vw / 7 * 5 - 25px)
  }
  .project__text{
    padding: 20px 10px;
  }
}
@media (min-width:768px){
  .single__gallery{
      height:calc(100vw / 12 * 10 / 7 * 5 - 50px);
      width:calc(100vw / 12 * 10);
      margin-bottom:40px
  }
  .single__img-caption{
    padding-left:0
}
  .project__text{
    padding: 10px 115px;


  }
  #specs-container{
    display:grid;
    grid-template-columns: 1fr 1fr;
    row-gap: 0.7pt;
  }
}
@media (min-width:1024px){
  .single__gallery{
      height:calc(100vw / 12 * 8 / 7 * 5 - 50px);
      width:calc(100vw / 12 * 8)
  }
}


.single__credits{
  font-size:11px;
  letter-spacing:.03em;
  margin:40px 0
}

span.arrow{
    position:relative;
    display:inline-block
}

.arrow-link {
  position: absolute;
  transform: rotate(-45deg);
  top: 50%;
  left: 50%;
  margin: -8px 0 0 -8px; 
}

.arrow-link:after,
.arrow-link:before {
  content: '';
  position: absolute;
  background: #c2c2c2;
  height: 1px;
  width: 4px;
  right: -12px;
  top: -2px;
}

.arrow-link:before {
  transform: rotate(45deg);
}

.arrow-link:after {
  transform: rotate(-45deg);
  top: 2px;
}

.arrow-link__stem{
    background:#c2c2c2;
    height:1px;
    width:12px;
    position:absolute
}
img,video{
    width:100%;
    height:100%;
}

/*Cookie Bar*/

.cookie-bar {
    font-family: 'gyre';
    letter-spacing: 0.03rem;
    color:black;
    text-transform: uppercase;
    background-color: rgb(255, 255, 255);
    display: none;
    font-size: 16px;
    padding: 15px;
    position: fixed;
    bottom: 0;
    width:100vw;
    left: 0;
    z-index: 999;
  }
  
  .cookie-bar p {
    margin: 0;
  }

  
  .cookie-btn {
    background-color: transparent;
    border: none;
    border-radius: 4px;    
    color: black;
    cursor: pointer;
    font-size: 16px;
    padding: 15px;
    position: fixed;
    right:10px;
    bottom: 0;
  }
  .cookie-btn:hover{
    color:#c2c2c2;
  }
  .cookie-bar a{
    text-decoration: none;
    color:black;
  }
  .cookie-bar a:hover{
    color:#c2c2c2;
  }
  @media (min-width:375px ) and (max-width: 768px) {
    .cookie-btn{
      display: block;

    }
    .cookie-bar a{
      
      display: block;
    }
    .cookie-bar {
    width:fit-content;
    }
  }
  @media (min-width: 768px) and (max-width: 1023px) {
    .cookie-bar{
      width: fit-content;
    }
  }
  /* Imprint*/
  .background_imprint{
    background-color:white;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    }

  .imprint-container{
    padding-left: 30px;
    padding-right: 30px;

  }
  @media (min-width: 768px){
  .low {
    margin-left:-15px;
    margin-right:-15px;
  }
}
  @media (min-width: 576px){
  .imprint-container{
      padding-left: 30px;
      padding-right: 30px;
  }
}
  .imprinttext1{
    font-family: 'gyre';
    margin-top:0;
    margin-bottom: 1rem;
    display: block;
    letter-spacing: 0.02em;
    line-height: 1.3em;
    font-size: 0.8em;
    padding:50px 10px;
    height: 100vh;
    color:black;
    text-align: left;
   

  }
  @media (min-width: 960px){
  .imprinttext1{
    width: 58.3333333333%;
}
  }

  .imprintlist ul{
    line-height: 1.3em;
    padding-right: 0%;
    padding-left: 5%;
    margin-bottom: 10px;

  }

  .imprinttext1 h1{
    font-size: 1.2em;
    text-transform: uppercase;
  }
  .imprinttext1 h2{
    font-size: 1em;
  }
  .adress{
    text-align: left;
    padding-left:0%
  }
