@import url("https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600&family=Montserrat:wght@300;400;600&family=Roboto:wght@100;300&display=swap");
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.2/font/bootstrap-icons.min.css");

:root {
  --general-font: "Roboto", sans-serif;
  --cinzel: "Cinzel", serif;
  --dark-color: #2a2a2a;
}

.main-menu {
  font-family: var(--general-font);
  color: #ffffff;
  text-decoration: none;
  text-transform: uppercase;
  font-size: 14px;
  padding-bottom: 3px;
  font-weight: 300;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  border: #2098d1;
}

.lang-button {
  display: block;
  position: fixed !important;
  top: 0px;
  right: 30px;
  z-index: 10;
  width: auto !important;
  line-height: 30px !important;
  padding-left: 10px;
  padding-right: 7px;
  content: 'Español';
  text-transform: lowercase;
}

.eng span::after {
  content: 'English';
}

.spa span::after {
  content: 'Español';
}

.txt-general {
  font-family: var(--general-font);
  font-size: 25px;
  font-weight: 400;
  font-size: 13px;
  line-height: 20px;
  letter-spacing: 3px;

}

.txt-general-form {
  font-family: var(--general-font);
  font-size: 25px;
  font-weight: 400;
  font-size: 13px;
  line-height: 25px;
  letter-spacing: 3px;

}

.txt-general-numbers {
  font-family: var(--general-font);
  font-size: 25px;
  font-weight: 400;
  font-size: 13px;
  line-height: 20px;
}

.txt-general-table-tittle {
  font-family: var(--general-font);
  font-size: 25px;
  font-weight: 400;
  font-size: 12px;
  line-height: 20px;
  letter-spacing: 3px;

}

.invalid-feedback {
  font-family: var(--general-font);
  font-size: 12px;
  letter-spacing: 2px;
}

.txt-gray {
  color: #808080 !important;
}

.txt-red {
  color: #e13108 !important;
}

.txt-blue {
  color: #29ABE2 !important;
}

.small-map {
  margin-top: -35%;
  z-index: 5;
  position: relative;
}

.buttons-total-box {
  -webkit-transform: translate(0px, 70%);
  transform: translate(0px, 70%);
  z-index: 10;
  height: 50px;
}

.button-building-box {
  width: 250px;
}

.button-building {
  font-family: var(--cinzel);
  color: #e9e3dd;
  font-weight: 400;
  font-size: 20px;
  background-color: #4C392F;
  width: 100%;
  text-transform: lowercase;
  letter-spacing: 4px;
  border: none;
  line-height: 45px;
  -webkit-transition: all 500ms;
  transition: all 500ms;
}

.button-building:hover {
  background-color: #9b694e;
}

.side-button {
  border: none;
  width: calc(100%/3);
  font-size: 13px;
  font-family: var(--general-font);
  line-height: 35px;
  background-color: #5E2D17;
  -webkit-transition: all 500ms;
  transition: all 500ms;
  color: #ffffff;
  font-weight: 300;
  text-align: center;
  margin-top: 2px;
}

.side-button:hover {
  background-color: #a04b24;
}

.sides-box {
  font-size: 0px;
}

.c2 {
  background-color: #492315;
}

.c3 {
  background-color: #2D140A;
}

.gold {
  background-color: #C09859;
}

.gold:hover {
  background-color: #937950;
}

.gold-1 {
  background-color: #AA834F;
}

.gold-1:hover {
  background-color: #8f6f46;
}

.gold-2 {
  background-color: #916D3F;
}

.gold-2:hover {
  background-color: #5e4729;
}

.orange-1 {
  background-color: #DD912C;
}

.orange-1:hover {
  background-color: #af7324;
}

.orange-2 {
  background-color: #B27124;
}

.orange-2:hover {
  background-color: #623f14;
}

.pic-overlay {
  width: 100%;
  height: calc(100% + 100px);
  position: absolute;
  top: 0px;
  left: 0px;
  -o-object-fit: cover;
  object-fit: cover;
  z-index: 10;
}

.txt-general-md {
  font-family: var(--general-font);
  font-size: 17px;
  font-weight: 300;
  letter-spacing: 2px;
}

.button-form {
  width: 100%;
  color: #ffffff;
  font-family: var(--cinzel);
}

.txt-white {
  color: #e9e3dd;
}

.txt-gold {
  color: #A38A7C !important;
}

.txt-link {
  color: #A38A7C !important;
  text-decoration: none;
}

.main-menu:hover {
  color: #dda54c;
}

.active-section {
  color: #dda54c;

}

.main-menu-box {
  width: 100px;
  text-align: center;
}

.main-logo {
  width: 75%;
  max-width: 350px;
}

.pre-sale-content {
  background-color: rgb(23 68 76 / 35%);
  padding-top: 19%;
  padding-bottom: 2%;
}

.pre-sale-content-light {
  background-color: #E9E3DD;
  padding-top: 2%;
  padding-bottom: 2%;
  -webkit-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15)
}

.anchor-presale {
  position: relative;
  height: 2px;
  background-color: #ffffff;
}

.over-dwn-up {
  --spacing: 100px;
  margin-top: calc(-1*var(--spacing));
  padding-top: var(--spacing);
}

.tittle-presale {
  font-family: var(--cinzel);
  color: #e9e3dd;
  font-weight: 400;
  margin-bottom: 0px;
  letter-spacing: 12px;
  font-size: clamp(20px, 3.8vw, 40px);
}

.tittle-section {
  font-family: var(--cinzel);
  color: var(--dark-color);
  font-size: 23px;
  letter-spacing: 4px;
  text-transform: lowercase;
  margin-bottom: 40px;
}

.form-label {
  font-family: var(--cinzel);
  font-size: 15px;
  color: var(--dark-color);
  letter-spacing: 2px;
  text-transform: lowercase;
}

.tittle-box {
  font-family: var(--cinzel);
  font-size: 23px;
  color: var(--dark-color);
  font-size: 23px;
  letter-spacing: 4px;
  text-transform: lowercase;
  line-height: 30px;
  margin-bottom: 0px;
}

.unique-video-box {
  padding-top: 15%;
  padding-bottom: 15%;
}

.video-header {
  height: 25vh;
  min-height: 300px;
}

.sub-presale {
  color: #e9e3dd;
  font-family: var(--general-font);
  font-size: clamp(15px, 2vw, 19px);
  font-weight: 300;
  letter-spacing: 1px;
}

.commercial-index {
  position: absolute;
  z-index: 1;
  bottom: 0px;
  width: 100%;
  padding-bottom: 4%;
  padding-top: 10%;
  background-image: -webkit-gradient(linear,
      left bottom, left top,
      from(rgba(0, 0, 0, 0.53)),
      to(rgba(255, 255, 255, 0)));
  background-image: linear-gradient(0deg,
      rgba(0, 0, 0, 0.53) 0%,
      rgba(255, 255, 255, 0) 100%);
  font-family: var(--general-font);
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 2px;
  color: #e9e3dd;
  text-transform: uppercase;
}

.menu-shadow {
  background-image: repeating-linear-gradient(180deg,
      rgba(0, 0, 0, 0.62) 0%,
      rgba(255, 255, 255, 0) 100%);
}

.solana-footer {
  max-width: 200px;
}

.border-side {
  border-left: 1px solid #c1995a;
  border-right: 1px solid #c1995a;
}

.footer-logo {
  width: 40%;
}

.hable {
  color: #c1995a;
  font-size: 15px;
  line-height: 15px;
  font-family: var(--general-font);
}

.phone-box {
  font-family: "Montserrat", sans-serif;
  color: #ffffff;
  font-weight: 300;
  font-size: 25px;
  line-height: 17px;
}

.link-email {
  font-family: "Montserrat", sans-serif;
  color: #ffffff;
  font-weight: 300;
  font-size: 19px;
  text-decoration: none;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.link-email:hover {
  color: #c1995a;
}

.dot-color {
  margin-left: 6px;
  margin-right: 6px;
  color: #c1995a;
}

.separator {
  background-color: #c1995a;
  padding-top: 15px;
  border-top: 2px solid #ffffff;
}

footer {
  background-color: #373127;
  padding-bottom: 8%;
}

.social-button {
  display: inline-block;
  color: #ffffff;
  background-color: #c1995a;
  text-align: center;
  border-radius: 50px;
  width: 40px;
  height: 40px;
  line-height: 40px;
  font-size: 20px;
  margin: 5px;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}

.social-button:hover {
  background-color: #dda54c;
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
}

.menu-container {
  position: relative;
}

.img-resp {
  width: 100%;
}

.img-box {
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.header-index {
  position: relative;
  background-color: #373127;
}

.pre-sale-container {
  position: absolute;
  top: 0px;
  width: 100%;
  z-index: 1;
}

.menu-content {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 4;
}

.plane-box {
  padding-top: 10%;
}

.plane1-3 {
  position: absolute;
  bottom: 0px;
  right: 0px;
  z-index: 8;
  -webkit-transform: translate(calc(100% + 15px), -15px);
  transform: translate(calc(100% + 15px), -15px);
  width: 40%;

}

.menu-resposive-box {
  position: fixed;
  background-color: rgba(0, 0, 0, 0.9);
  width: 100%;
  height: 100%;
  z-index: 15;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.sun-back {
  background-image: url("../assets/images/index/sun.svg");
  background-position: top center;
  background-size: 100% auto;
  background-color: #cfbaa3;
  background-repeat: no-repeat;
}

.sun-back-light {
  background-image: url("../assets/images/sun-light.svg");
  background-position: top center;
  background-size: 100% auto;
  background-color: #E9E3DD;
  background-repeat: no-repeat;
}

.menu-resposive-box-show {
  visibility: visible;
  --speed-menu: 0.5s;
  -webkit-animation: menu-box-animation var(--speed-menu) ease-in forwards;
  animation: menu-box-animation var(--speed-menu) ease-in forwards;
}

.tittle-center {
  background-color: #e9e3dd;
  padding: 7% 5%;
  text-align: center;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.overlay-top {
  margin-top: -40px;
}

@-webkit-keyframes menu-box-animation {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.resp-button {
  color: #e9e3dd;
  font-family: var(--general-font);
  text-transform: uppercase;
  text-decoration: none;
  font-size: 8vw;
  display: block;
  width: 10px;
  overflow: hidden;
  text-align: center;
  font-weight: 100;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.resp-button:hover,
.resp-button:active {
  color: #ffffff;
  background-color: #c1995a;
}

.resp-button-reveal {
  -webkit-animation: resp-animation 1s ease-in;
  animation: resp-animation 1s ease-in;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-delay: calc(var(--speed-menu) + (0.2s * var(--rb)));
  animation-delay: calc(var(--speed-menu) + (0.2s * var(--rb)));
}

@-webkit-keyframes resp-animation {
  from {
    width: 0px;
    opacity: 0.3;
  }

  to {
    width: 100%;
    opacity: 1;
  }
}

.close-responsive {
  position: absolute;
  z-index: 12;
  right: 15px;
  top: 15px;
  background-color: transparent;
  border: 1px solid #ffffff;
  color: #ffffff;
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.close-responsive:hover,
.close-responsive:active {
  background-color: #bd955c;
}

.open-responsive {
  position: fixed;
  z-index: 200;
  background-color: transparent;
  border: 1px solid #ffffff;
  color: #ffffff;
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  background-color: rgb(195 174 159 / 77%);
}

.open-responsive:hover,
.open-responsive:active {
  background-color: #bd955c;
}

#buttonResp {
  position: fixed;
  z-index: 11;
  right: 15px;
  top: 35px;
  width: 50px;
  height: 50px;
  z-index: 101;
}

.header-back {
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  width: 100%;
  height: 100vh;
  background-image: url("../assets/images/index/header.jpg");
}

.brown-header {
  background-image: url("../assets/images/back_brown2.svg");
  height: 25vh;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  border-bottom: 2px solid #ffffff;
  min-height: 330px;

}

.coastal-logo {
  max-width: 250px;
  width: 70%;
}

.tittle-overlay {
  -webkit-transform: translate(0px, -50%);
  transform: translate(0px, -50%);
}

.unique-box {
  border-top: 5px solid white;
}

.content-cols {
  max-width: 600px;
}

.content-cols-large {
  max-width: 500px;
}

.content-cols-xlarge {
  max-width: 600px;
}

.bars-deco {
  position: absolute;
  width: 5%;
  top: 65%;
  right: -2.5%;
  height: auto;
  z-index: 20;
}

.presale-tag-box {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 10;
  -webkit-transform: translate(0px, -50%);
  transform: translate(0px, -50%);
}

.float-box {
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 11;
  -webkit-transform: translate(0px, -50%);
  transform: translate(0px, -50%);
}

.parallax-back {
  background-size: cover;
  background-attachment: fixed;
  background-position: center center;

}

.parallax-back img {
  opacity: 0.0;
}

.activities-intro-box {
  height: auto;

}

.map-box {
  display: grid;
  grid-template-rows: 1fr;
  -webkit-transition: grid-template-rows 2000ms;
  transition: grid-template-rows 2000ms;
  transition: grid-template-rows 2000ms, -ms-grid-rows 2000ms;
}

.map-content {
  overflow: hidden;
}

.map-close {
  grid-template-rows: 0fr;
}

/* Underline Reveal */
.hvr-underline-reveal {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  position: relative;
  overflow: hidden;
}

.hvr-underline-reveal:before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  right: 0;
  bottom: 0;
  background: #fcc56d;
  height: 2px;
  -webkit-transform: translateY(4px);
  transform: translateY(4px);
  -webkit-transition-property: transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-duration: 0.7s;
  transition-duration: 0.7s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}

.hvr-underline-reveal:hover:before,
.hvr-underline-reveal:focus:before,
.hvr-underline-reveal:active:before {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.learn-dark {
  width: 270px;
  line-height: 55px;
  text-align: center;
  font-family: var(--cinzel);
  background-color: #4c3930;
  color: #ffffff;
  text-decoration: none;
  font-size: 15px;
  letter-spacing: 3px;
  display: block !important;
}

.learn-dark.hvr-bounce-to-bottom:before {
  background: #c0985e !important;
}

.learn-light {
  width: 270px;
  line-height: 55px;
  text-align: center;
  font-family: var(--cinzel);
  background-color: #c0985e;
  color: #ffffff;
  text-decoration: none;
  font-size: 15px;
  letter-spacing: 3px;
  display: block !important;
}

.learn-light.hvr-bounce-to-bottom:before {
  background: #4c3930 !important;
}

.tittle-building {
  position: absolute;
  top: 17%;
  width: 100%;
}

.unit-sign {
  position: absolute;
  top: 0px;
  left: 0px;
  z-index: 5;
  text-decoration: none;
  -webkit-transition: all .5s;
  transition: all .5s;
  pointer-events: none;
  cursor: default;
}

.unit-sign:hover .unit-number {
  background-color: #618236;
}

.unit-sign:hover .status-label {
  background-color: #2680a7;
}

.unit-number {
  display: inline-block;
  font-family: var(--general-font);
  background-color: #8CC63F;
  color: #ffffff;
  padding-left: 10px;
  padding-right: 10px;
  font-size: 1.3vw;
  padding-top: 2px;
  padding-bottom: 2px;
  font-weight: 300;
  text-decoration: none;
  -webkit-transition: all .5s;
  transition: all .5s;
  line-height: 2vw;
}

.status-label {
  background-color: #29ABE2;
  font-family: var(--general-font);
  color: #ffffff;
  font-weight: 300;
  font-size: 1.3vw;
  padding-top: 2px;
  padding-bottom: 2px;
  padding-left: 10px;
  padding-right: 10px;
  text-transform: uppercase;
  -webkit-transition: all .5s;
  transition: all .5s;


}

.table-unit {
  display: inline-block;
  color: #ffffff;
  width: 50px;
  background-color: #8CC63F;
  text-align: center;
  line-height: 25px;
}

.download-pdf {
  display: inline-block;
  color: #ffffff;
  background-color: #C7B299;
  text-decoration: none;
  line-height: 25px;
  padding-left: 10px;
  padding-right: 10px;

}

.download-pdf.hvr-bounce-to-bottom:before {
  background: #827668 !important;
}

.color-3 {
  background-color: #BF6D00;
}

.color-3:hover {
  background-color: #754404 !important;
}

.color-2 {
  background-color: #FBB03B;
}

.sold {
  background-color: #ED1E79;
}

.sold:hover {
  background-color: #9d1650 !important;
}

.color-2:hover {
  background-color: #815611 !important;
}

.gallery-img {
  -webkit-transition: all ease 500ms;
  transition: all ease 500ms;

}

.gallery-img:hover {
  scale: 0.95;
  cursor: pointer;

}

.price-table {
  --bs-table-color-type: initial;
  --bs-table-bg-type: initial;
  --bs-table-color-state: initial;
  --bs-table-bg-state: initial;
  --bs-table-color: var(--bs-emphasis-color);
  --bs-table-bg: transparent;
  --bs-table-border-color: var(--bs-border-color);
  --bs-table-accent-bg: transparent;
  --bs-table-striped-color: var(--bs-emphasis-color);
  --bs-table-striped-bg: rgba(var(--bs-emphasis-color-rgb), 0.05);
  --bs-table-active-color: var(--bs-emphasis-color);
  --bs-table-active-bg: rgba(var(--bs-emphasis-color-rgb), 0.1);
  --bs-table-hover-color: var(--bs-emphasis-color);
  --bs-table-hover-bg: rgba(var(--bs-emphasis-color-rgb), 0.075);
  width: 100%;
  margin-bottom: 1rem;
  vertical-align: top;
  border-color: var(--bs-table-border-color);
}

/* Bounce To Bottom */
.hvr-bounce-to-bottom {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
}

.hvr-bounce-to-bottom:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #2098d1;
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50% 0;
  transform-origin: 50% 0;
  -webkit-transition-property: transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}

.hvr-bounce-to-bottom:hover,
.hvr-bounce-to-bottom:focus,
.hvr-bounce-to-bottom:active {
  color: white;
}

.hvr-bounce-to-bottom:hover:before,
.hvr-bounce-to-bottom:focus:before,
.hvr-bounce-to-bottom:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
  -webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
  transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}

@media (max-width: 767.98px) {
  .pre-sale-container {
    position: relative;
  }

  .pre-sale-content {
    padding-top: 5%;
    background-color: transparent;
  }

  .commercial-index {
    position: relative;
    padding-top: 0px;
  }

  .tittle-presale {
    font-size: clamp(25px, 5vw, 40px);
  }

  .header-back {
    height: 90vh;
  }

  .overlay-top {
    margin-top: 10%;
  }

  .tittle-overlay {
    -webkit-transform: translate(0px, 0%);
    transform: translate(0px, 0%);
    margin-top: 10%;
  }

  .float-box {
    position: relative;
    top: 0px;
    left: 0px;
    width: 100%;
    z-index: 11;
    -webkit-transform: translate(0px, 0%);
    transform: translate(0px, 0%);
    padding-top: 5%;
    padding-bottom: 5%;
    background-color: #E9E3DD;
  }

  .activities-intro-box {
    padding-top: 5%;
  }

  .buttons-total-box {
    -webkit-transform: translate(0px, 0%);
    transform: translate(0px, 0%);
    height: auto;

  }

  .button-building-box {
    width: 100%;
  }

  .small-map {
    margin-top: 20px;
    z-index: 5;
    position: relative;
    max-width: 300px;
    margin-bottom: 20px;
    margin-left: auto;
    margin-right: auto;
    display: block;
  }

  .little-map-box {
    background-color: #efeff0;
  }

  .lang-button {
    right: 15px;
    width: 50px !important;
    padding-left: 7px;
  }

  .eng span::after {
    content: 'Eng';
  }

  .spa span::after {
    content: 'Esp';
  }

}

@media (max-width: 991.98px) {
  .border-side {
    border-top: 1px solid #c1995a;
    border-left: none;
    border-right: none;
  }
}