@import 'reset.css';
@import 'fonts.css';
@import 'layout.css';
@import 'adaptive.css';
@import 'animation.css';


body{
  font-family: 'Helvetica Neue', Arial, sans-serif;
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: none;
  height: 90px;
  border: none;
  padding: 0 30px;
  position: relative;
  z-index: 2;
}

.nav {
  display: flex;
  font-size: 16px;
  width: 50%;
  justify-content: space-between;
}
.nav__link {
  color: #000;
  text-decoration: none;
  font-weight: 400;
  letter-spacing: 0.02em;
  transition: color 0.2s;
}

.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  width: 70px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 3;
}
.hamburger span {
  display: block;
  height: 7px;
  width: 65px;
  background: #000;
  margin: 5px 0;
  transition: 0.3s;
}
.nav-overlay {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  z-index: 10;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 20px;
  font-size: 2rem;
  transition: opacity 0.3s;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.nav-overlay.active {
  display: flex;
}
.nav-overlay-header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 24px 0 24px;
  box-sizing: border-box;
}
.nav-overlay-logo svg {
  display: block;
  width: 46px;
  height: 52px;
}
.close-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 11;

}
.footer-popup__content{
  padding: 30px;
  border: 2px solid black;
}

.close-hamburger span {
  display: block;
  height: 4px;
  width: 30px;
  background: #000;
  margin: 5px 0;
  border-radius: 2px;
  transition: 0.3s;
}
.nav-overlay .nav__link {
  font-size: 2rem;
  color: #000;
  margin: 0.5em 0;
  text-align: center;
}
.footer-mobile {
  font-size: 1.1rem;
  width: 100%;
  margin-bottom: 15px;
  position: absolute;
  bottom: 0px;
}
.footer-popup{
  padding: 0 30px;
  
}

.footer-popup__content-wrap {
width: calc(100% + 65px);
background-color: #fff;
position: relative;
left: -33px;
padding: 0 30px;
}





.main {
  flex: 1 1 auto;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: none;
  border: none;
}
.main__container {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box;
}
.main__info {

  margin-top: 50px;
  width: 50%;
}
.main__title {
  font-size: 110px;
  font-weight: 400;
  margin-bottom: 32px;
  line-height: 1;
}
.main__desc {
  font-size: 38px;
  line-height: 1.2;
  font-weight: 400;
  text-align: left;
}
.main__visual {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  width: 50%;
}
.main__visual-border {
  border: 2px solid #000;
  position: relative;
  width: 300px;
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

.main__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(0) brightness(0.8) sepia(0.2) hue-rotate(190deg) saturate(2);
}



.footer-container {
    margin: 0 auto;
    border: 2px solid #333;
    background-color: white;
    padding: 20px;
    margin: 40px 0;
    
}
.footer{
  padding: 0 30px;
}

.footer-content {
display: flex;
justify-content: space-between;
align-items: center;
gap: 40px;
width: calc(100% + 4px);
left: -30px;
position: relative;
background: white;
padding: 0 30px;
}

.footer-section {
    flex: 1;
}

.footer-section h4 {
    font-size: 14px;
    font-weight: normal;
    color: #333;
    margin-bottom: 10px;
    text-transform: lowercase;
}

.newsletter-section {
    display: flex;
    flex-direction: column;
}

/* .newsletter-input-container {
    display: flex;
    align-items: center;
    gap: 10px;
} */

.newsletter-input {
    border: 2px dashed #333;
    background: transparent;
    padding: 8px 12px;
    font-size: 14px;
    outline: none;
}

.newsletter-input::placeholder {
    color: #999;
}

.newsletter-button {
    background: transparent;
    border: none;
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    margin-left: 10px;
}


.social-section {
    text-align: center;
}

.social-links {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.social-links a {
    color: #333;
    text-decoration: none;
    font-size: 14px;
    text-transform: lowercase;
}



.email-section {
    text-align: right;
}

.email-address {
    color: #333;
    text-decoration: none;
    font-size: 14px;
}






.image-wrapper {
  position: relative;
  display: inline-block;
  padding: 32px; 
}
.image-wrapper__events{
  position: relative;
  display: inline-block;
  padding: 0;
  width: 100%;
  margin-top: 40px;
}
.image-wrapper img {
  display: block;
  width: 100%;
  height: auto;
}

.corner {
  position: absolute;
  width: 20px;
  height: 20px;
  border-color: black;
  border-style: solid;
}

.top-left {
  top: 0;
  left: 0;
  border-width: 2px 0 0 2px;
}

.top-right {
  top: 0;
  right: 0;
  border-width: 2px 2px 0 0;
}

.bottom-left {
  bottom: 0;
  left: 0;
  border-width: 0 0 2px 2px;
}

.bottom-right {
  bottom: 0;
  right: 0;
  border-width: 0 2px 2px 0;
}







.card-wrapper{
  display: grid;
  grid-template-columns: repeat(3, 1fr);  
  justify-items: center;
  text-align: center;
  gap: 30px;
  padding: 15px 30px;
}

.card{
  width: 100%;
  height: 100%;
}

img.card-img {
  width: 100%;
}
.card-descr-text__title{
  font-size: 2rem;
  margin-top: 15px;
  line-height: 1.2;
font-weight: 300;
text-align: left;
width: 100%;
}
.card-descr-text {
display: flex
;
align-items: end;
}
.cart {
padding: 15px 25px;
border: 2px dashed #333;
display: block;
text-decoration: none;
color: #000;
text-align: center;
width: -webkit-fill-available;
}
   



      .header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        height: 90px;
        padding: 0 30px;
        position: relative;
        top: 0;
        left: 0;
        right: 0;
        z-index: 100;
        background-color: white;
        
      }
      .nav {
        display: flex;
        gap: 32px;
        font-size: 16px;
      }
      .nav__link {
        color: #000;
        text-decoration: none;
      }
      .hamburger {
        display: none;
        cursor: pointer;
 
      }
      .hamburger span {
        display: block;
        height: 7px;
        width: 65px;
        background: #000;
        margin: 5px 0;
        
      }
      .nav-overlay {
        display: none;
        position: fixed;
        top: 0; left: 0; right: 0; bottom: 0;
        width: 100%;
        height: 100%;
        
        background: #fff;
        z-index: 1000;
        flex-direction: column;
        align-items: center;
        overflow-y: auto;
      }
      .nav-overlay.active {
        display: flex;
      }
      .nav-overlay-header {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0 30px;
        height: 90px;
        position: absolute;
      }
      .nav-overlay__wrap {
        display: flex
    ;
        flex-direction: column;
        height: 100%;
        justify-content: center;
    }
      .nav-overlay .nav__link {
        font-size: 2rem;
        margin: 1rem 0;
      }



      .footer-mobile-adaptive{
        display: none;
        
      }
      
    
      .footer-mobile-adaptive__border{
        padding: 0 30px;
        width: 100%;
      }
      .footer-mobile-adaptive__wrapper{
        border: 2px solid black;
        padding: 30px;
      }
      .footer-mobile-adaptive__content {
        width: calc(100% + 6px);
        background-color: #fff;
        position: relative;
        left: -33px;
        padding: 0 30px;
    }
    .footer-mobile-adaptive__content-text{
      margin-bottom: 10px;
    }


    .social-wrapper{
      display: flex;
      justify-content: end;
      position: absolute;
      width: 100%;
      bottom: 15px;
  }
  .social-link{
      display: flex;
      
      justify-content: space-between;
      width: 48%;
      text-align: right;
      padding-right: 30px;
  }
  
  .social-link a{
      text-decoration: none;
      color: #000;
  }








.select-nav{
  
  color: #000;
  text-decoration: none;
  border-bottom: 2px solid black;
  opacity: 0.8;
}



  
.subevents-img img{
  width: 80%;
}
.w100{
  width: 100%;
  padding: 15px 0;
  
}
.cart-wrap{
  width: 100%;}

.subevents-text__wrap{
padding: 32px;
}
.subevents-block-data{
  width: 100%;
}
.subevents-text__descr{
  font-size: 20px;

}
.subevents-wrapper {
  display: flex;
  padding: 0 30px;
  height: 100%;
}
.subevents-img, .subevents-text {
flex: 1 1 0;
height: 100%;
}
.subevents-text {
display: flex;
flex-direction: column;
justify-content: space-between;
align-items: center;
height: auto;
}
.subevents-text__data {
  display: flex
;
  justify-content: space-between;
  width: 100%;
}




.dome-page {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
  padding: 0 30px;
  color: #fff;
}
.dome-page__video-bg {
  position: fixed;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  object-fit: cover;
  transform: translate(-50%, -50%);
  z-index: 0;
  filter: brightness(0.6);
}



.dome-page__center {
  background-color: #061335;
  padding: 40px;
  max-width: 900px;
  width: 100%;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  border-radius: 0;
}
.dome-page__content {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.dome-page__images {
  display: flex;
  justify-content: center;
}
.dome-page__images-left {
  display: flex;
  flex-direction: column;
}
.dome-page__images img {
  width: 100%;
  height: auto;
  display: block;
}
.dome-page__text-content h1 {
  font-size: 3rem;
  margin: 0 0 30px 0;
  font-weight: 400;
  letter-spacing: 0.02em;
}
.dome-page__text-content p {
  font-size: 1.5rem;
  line-height: 1.6;
  margin: 0;
  font-weight: 300;
}


.notfound{
  width: 100%;
  height: 90vh;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.notfound__title {
  font-size: 20rem;
  line-height: 1;
  z-index: 10;
}
@media (max-width: 700px) {
  .notfound__title {
    font-size: 12rem;
    line-height: 1;
    z-index: 10;
  }
}
.notfound__subtitle {
  font-size: 1.5rem;
  margin-top: 1rem;
  margin-bottom: 2rem;
  z-index: 10;
}
.cart--dashed {
  border: 2px dashed black;
  padding: 10px 20px;
  z-index: 10;
}

.cart--dashed__404{
  border: 2px dashed black;
  padding: 10px;
  z-index: 10;
  margin-top: 80px;
  width: 29%;
}

.notfound__img-container {
  position: absolute;
  padding: 15px;
}
.notfound__img-container img {
  display: block;
  max-width: 100%;
}

.notfound__img-container--1 { top: 7%; left: 1%; width: 300px; }
.notfound__img-container--2 { bottom: 15%; left: 10%; width: 200px; }
.notfound__img-container--3 { top: 30%; right: 1%; width: 300px; }

.corner {
  position: absolute;
  width: 20px;
  height: 20px;
}
.corner--tl { top: 0; left: 0; border-top: 2px solid black; border-left: 2px solid black; }
.corner--tr { top: 0; right: 0; border-top: 2px solid black; border-right: 2px solid black; }
.corner--bl { bottom: 0; left: 0; border-bottom: 2px solid black; border-left: 2px solid black; }
.corner--br { bottom: 0; right: 0; border-bottom: 2px solid black; border-right: 2px solid black; }



    
.footer-mobile {
  margin-top: auto;
  padding: 20px;
  width: 100%;
  text-align: center;
}
.domes {
  padding-top: 0;
  height: auto;
}
.domes__container {
  display: flex;
  height: 90vh;
}
.domes__block {
  flex: 1;
  position: relative;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  text-decoration: none;
  cursor: pointer;
}
.domes__block--1 { background-image: url('../image/1.png'); }
.domes__block--2 { background-image: url('../image/2.png'); }
.domes__block--3 { background-image: url('../image/3.png'); }
.domes__block--4 { background-image: url('../image/4.png'); }
.domes__caption {
  position: absolute;
  left: 24px;
  bottom: 24px;
  font-size: 24px;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,0.3);
  opacity: 1;
  display: flex;
  flex-direction: column;
}

.events-card img{
  width: 100%;
  }
  .events-text{
  display: none;
  }
  .events-card__text{
    width: 98%;
  }
  .events-card__data{
    display: flex;
    justify-content: space-between;
    margin-top: 15px;
  }
  
    .event-link {
      display: block;
      position: relative;
      height: 100%;
      width: 100%;
      overflow: hidden;
    }
    .event-link .event-img-hover {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
      transition: opacity 0.3s ease-in-out;
    }
    .event-link:hover .event-img-hover {
      opacity: 1;
    }
  
   
    .footer-mobile {
      display: none;
    }
    .nav-overlay.active .footer-mobile {
      display: block;
      width: 100%;
      margin-top: 2rem;
    }


  
    .dome-page {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      height: 100%;
      position: relative;
      overflow: hidden;
      box-sizing: border-box;
      padding: 0 30px;
      color: #fff;
    }
   
    .dome-page__video-bg {
      position: fixed;
      top: 50%;
      left: 50%;
      min-width: 100%;
      min-height: 100%;
      width: auto;
      height: auto;
      object-fit: cover;
      transform: translate(-50%, -50%);
      z-index: 0;
      filter: brightness(0.6);
    }
    .dome-page__back-btn {
      position: absolute;
      top: 110px;
      right: 30px;
      background: #061335;
      color: #fff;
      padding: 8px 24px;
      text-decoration: none;
      font-weight: 300;
      z-index: 10;
      transition: background-color 0.2s;
    }
    

    .dome-page__center {
      background-color: #061335;
      padding: 40px;
      max-width: 900px;
      width: 100%;
      box-shadow: 0 10px 40px rgba(0,0,0,0.5);
      box-sizing: border-box;
      position: relative;
      z-index: 1;
      border-radius: 0;
    }
    .dome-page__content {
      display: flex;
      flex-direction: column;
      gap: 30px;
    }
    .dome-page__images {
      display: flex;
      justify-content: center;
    }
    .dome-page__images-left {
      display: flex;
      flex-direction: column;
      width: 100%;
    }
    .dome-page__images img {
      width: 100%;
      height: auto;
      display: block;
    }
    .dome-page__text-content h1 {
      font-size: 3rem;
      margin: 0 0 30px 0;
      font-weight: 300;
      letter-spacing: 0.02em;
    }
    .dome-page__text-content p {
      font-size: 1.5rem;
      line-height: 1.6;
      margin: 0;
      font-weight: 300;
    }

    
    .form-container {
      width: 100%;
      text-align: center;
      padding: 0 30px;
      box-sizing: border-box;
    }

   

    .submit-btn {
      margin-top: 30px;
      padding: 10px;
      width: 100%;
      border: 2px dashed black;
      background: white;
      font-size: 14px;
      cursor: pointer;
      text-align: center;
      box-sizing: border-box;
    }



 
 .main__desc-mobile{
  display: none;
 }


  .bordered {
    display: inline-block;
    border-style: dashed;
    border-image-source: url("https://i.sstatic.net/wLdVc.png");
    border-image-slice: 2;
    border-image-repeat: round;
  
    border-image: url("https://i.sstatic.net/wLdVc.png") 1.3 round;
  }
  
  
  
  .largeGaps {
    border-image-source: url("https://i.sstatic.net/LKclP.png");
  }



  .newsletter-input-container {
    display: flex
;
}
.nav-overlay__wrap{
  gap: 40px;
}


     
.events-card img{
  width: 100%;
  }
  .events-text{
  display: none;
  }
  .events-card__text{
    width: 98%;
  }
  .events-card__data{
    display: flex;
    justify-content: space-between;
    margin-top: 15px;
  }
 
    .events-card-wrap{
      display: flex;
      gap: 30px;
      padding-right: 30px;
    }
    .events-wrapper{
      width: 100%;
      display: flex;
      justify-content: center;
      gap: 30px;
      height: 100%;

      flex-wrap: nowrap;
    }
   
    .full-img{
      
      width: 100%;
     
    }
    .event-link {
      display: block;
      position: relative;
      height: 100%;
      width: 100%;
      overflow: hidden;
    }
    .event-link .event-img-hover {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
      transition: opacity 0.3s ease-in-out;
    }
    .event-link:hover .event-img-hover {
      opacity: 1;
    }
  
  
    .footer-mobile {
      display: none;
    }
    .nav-overlay.active .footer-mobile {
      display: block;
      width: 100%;
      margin-top: 2rem;
    }


    .domes__label {
      font-size: 2.2rem;
  }

  .top{
    margin-top: 15px;
  }
 
  .footer-mobile-adaptive__wrapper{
    padding: 20px 30px;
  }

.pc{
  display: block;
  
  }
  .mobile{
  display: none;
  }



  .form-container {
    width: 100%;
    text-align: center;
    padding: 0 30px;
    box-sizing: border-box;
  }
  .record-input{
    width: 100%;
    padding: 10px;
    margin-bottom: 20px;
    border: 1px solid #aaa;
    border-radius: 0;
    text-align: center;
    font-size: 14px;
    box-sizing: border-box;
    }

    .record-form{
      max-width: 400px;
      margin: 25px auto;
    }
    .record-content {
        min-height: 80vh;
        display: flex;
        align-items: center;
        justify-content: center;
      }


      
      .d-0{
        display: none;
      }
     
    
            .o-0{
        opacity: 0;
      }
     
      .support-location{
          display: flex;
        
        }
        .support-info__second-block-text {
          margin-right: 50px;
        }
    
    
      .support-wrapper{
          display: flex;
          justify-content: space-between;
          padding: 0 30px;
          align-items: center;
          height: 550px;
      }
      .support-content{
          display: flex;
          flex-direction: column;
          width: 50%;
    
      }
      .support-info__block{
          display: flex;
          align-items: flex-start;
          margin-bottom: 40px;
          width: 100%;
          justify-content: space-between;
          height: 178px;
      }
      
      .support-info__block__left{
    
          display: flex;
          flex-direction: column;
          align-items: flex-start;
        justify-content: space-between;
        height: 100%;
      }
      
      .support-info__block__right{
          display: flex;
          flex-direction: column;
          gap: 40px;
          position: relative;
        left: 3.6rem;
    
      }
      
      .support-info__block-text,
      .support-info__second-block-text{
          display: flex;
          flex-direction: column;
          gap: 8px;
      }
      .support-title{
          font-size: 3rem;
          line-height: 1.1;
          font-weight: normal;
      }
    
      .support-subtitle{
          font-size: 1.1rem;
          color: #555;
      }
      .support-info {
          width: 100%;
      }
    
      
      .support-info__block__d0{
        opacity: 0;
      }
      .mobile{
        display: none;
      }
      .pc{
        display: block;
      }
     


      .body-domes{
        height: 120vh;
      }


      @import 'reset.css';
      @import 'fonts.css';
      @import 'layout.css';
      @import 'adaptive.css';
      @import 'animation.css';
      
      