.mt-n1 {
  margin-top: -10px;
}

@keyframes slideInItem {
  0% {
    opacity: 0;
    transform: translateY(10px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}



.hero-layered {
  height: 100vh;
  position: relative;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}

.hero-content {
  min-height: calc(100vh - var(--nav-h, 72px));
  padding-top: var(--nav-h, 72px);
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: white;
}

.hero-front {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 112vh;
  object-fit: cover;
  z-index: 3;
  pointer-events: none;
}

.hero-content--merida {
  padding-bottom: 20vh;
  transform: translateY(-50px);
}

.hero-content--merida h3 {
  color: #1E1E1E;
  font-size: 47px;
}

.hero-content--merida h2 {
  font-size: 40px;
  text-shadow: 0 4px 35px rgba(0, 0, 0, 0.25);
  font-family: Montserrat-SemiBold, sans-serif;
}

.hero-content--merida h5 {
  color: #1E1E1E;
  font-size: 25px;
}

.monument {
  height: 100vh;
}

.house {
  height: 100vh;
}

.ground {
  height: 112vh;
}

#home h1,
#home h4 {
  font-family: Montserrat-Bold, sans-serif;
}

#home h1 {
  font-size: 232px;
  position: relative;
  transform: translateY(-40px);
  text-shadow: 0 4px 35px rgba(0, 0, 0, 0.50);
}

.hero-content--cancun {
  padding-bottom: 50vh !important;
}

.hero-content--cancun h3 {
  font-size: 46px;
  text-shadow: 0 4px 35px rgba(0, 0, 0, 0.25);
  font-family: Montserrat-Thin, sans-serif;
}

.hero-content--cancun h3 span {
  font-family: Montserrat-Regular, sans-serif;
}

.hero-content--home {
  padding-bottom: 50vh;
  transform: translateY(-130px);
}

.hero-content--home h2 {
  font-family: Montserrat-Bold, sans-serif;
  font-size: 60px;
}

.hero-content--home h3 {
  font-family: Montserrat-Thin, sans-serif;
  font-size: 50px;
}

#home .home-footer {
  width: 100%;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 4;
  color: white;
  height: 22vh;
  pointer-events: none;
}

.home-footer__inner {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  height: 100%;
  padding: 0 24px;
}

.home-footer button,
.home-footer a,
.home-footer input,
.home-footer select {
  pointer-events: auto;
}

.home-footer button,
.home-footer a {
  background: linear-gradient(90deg, var(--main-blue) 0%, var(--second-blue) 100%);
  color: white;
  border-radius: 80px;
  border: none;
  padding: 8px 20px;
  font-size: 26px;
  text-decoration: none;
}

.home-footer button:hover,
.home-footer a:hover {
  background: white;
  color: var(--main-blue);
}

.home-footer .prices-info {
  position: absolute;
  right: 24px;
  bottom: 100%;
  transform: translateY(-24px);
  pointer-events: none;
}

.home-footer .prices-info h6 {
  writing-mode: sideways-lr;
  font-size: 16px;
  font-family: Montserrat-Thin, sans-serif;
}

.home-footer .prices-info h5 {
  font-size: 19px;
  line-height: 18px;
}

.home-footer .prices-info h4 {
  font-size: 61px;
  text-shadow: 0 4px 35px rgba(0, 0, 0, 0.50);
}

/* Input de lada con banderas */

.iti {
  display: block;
}

.iti__dial-code {
  display: inline;
  color: #333;
  font-weight: 500;
}

.iti__country {
  color: #1a1a1a;
}

.iti__dropdown-content {
  height: 50vh;
  margin-top: 20%;
}

.iti__selected-dial-code {
  color: black !important;
}

.iti__selected-flag {
  background-color: transparent !important;
  border-right: 1px solid white;
}

/* fin select lada */

.home-footer .payments {
  background-color: rgba(255, 255, 255, 0.4);
  width: fit-content;
  backdrop-filter: blur(38.8px);
  border-radius: 147px;
  color: var(--main-blue);
  pointer-events: none;
  gap: 2rem;
  padding-inline: 1rem;
}

#homeCarousel .carousel-control-prev,
#homeCarousel .carousel-control-next {
  width: 64px;
  z-index: 4;
  opacity: 1;
}

#homeCarousel .carousel-control-prev {
  left: 16px;
}

#homeCarousel .carousel-control-next {
  right: 16px;
}

#home .anim-title,
#home .anim-subtitle,
#home .anim-caption,
#home .anim-city {
  opacity: 1;
}

#home .first-load.is-animating .anim-title,
#home .first-load.is-animating .anim-subtitle,
#home .first-load.is-animating .anim-caption,
#home .first-load.is-animating .anim-city {
  opacity: 0;
  will-change: transform, opacity;
}

#home .first-load.is-animating .anim-title {
  animation: slideDownFade 900ms ease-out 120ms forwards;
}

#home .first-load.is-animating .anim-subtitle {
  animation: fadeIn 700ms ease-out 250ms forwards;
}

#home .first-load.is-animating .anim-caption,
#home .first-load.is-animating .anim-city {
  animation: slideUpFade 900ms ease-out 220ms forwards;
}

#home .first-load.is-animating .anim-city {
  animation: fadeIn 900ms ease-out 380ms forwards;
}

#home .anim-cancun-title,
#home .anim-price {
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#home .anim-cancun-city {
  font-size: clamp(56px, 12vw, 180px);
  line-height: 0.9;
  letter-spacing: 0.02em;
  margin: 0;
  max-width: 95vw;
}

#homeCarousel .carousel-item[data-slide="cancun"].is-animating .anim-cancun-title,
#homeCarousel .carousel-item[data-slide="cancun"].is-animating .anim-cancun-city,
#homeCarousel .carousel-item[data-slide="cancun"].is-animating .anim-price {
  opacity: 0;
  will-change: transform, opacity;
}

#homeCarousel .carousel-item[data-slide="cancun"].is-animating .anim-cancun-title {
  animation: slideDownFade 900ms ease-out 120ms forwards;
}

#homeCarousel .carousel-item[data-slide="cancun"].is-animating .anim-cancun-city {
  animation: slideUpFade 900ms ease-out 220ms forwards;
}

#homeCarousel .carousel-item[data-slide="cancun"].is-animating .anim-price {
  animation: slideInRightFade 900ms ease-out 320ms forwards;
}

#homeCarousel .carousel-item[data-slide="experiencias"] .anim-exp-legend {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#homeCarousel .carousel-item[data-slide="experiencias"].is-animating .anim-exp-legend {
  opacity: 0;
  will-change: transform, opacity;
  animation: slideUpFade 900ms ease-out 140ms forwards;
}

#home .anim-home-title,
#home .anim-home-subtitle {
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#homeCarousel .carousel-item[data-slide="your_home"].is-animating .anim-home-title,
#homeCarousel .carousel-item[data-slide="your_home"].is-animating .anim-home-subtitle {
  opacity: 0;
  will-change: transform, opacity;
}

#homeCarousel .carousel-item[data-slide="your_home"].is-animating .anim-home-title {
  animation: slideInLeftFade 900ms ease-out 120ms forwards;
}

#homeCarousel .carousel-item[data-slide="your_home"].is-animating .anim-home-subtitle {
  animation: slideInRightFade 900ms ease-out 220ms forwards;
}


/* animaciones para slick */
#homeCarouselMobile .slide-card-mobile .anim-city,
#homeCarouselMobile .slide-card-mobile .anim-caption,
#homeCarouselMobile .slide-card-mobile .anim-price,
#homeCarouselMobile .slide-card-mobile .anim-cancun-title,
#homeCarouselMobile .slide-card-mobile .anim-cancun-city,
#homeCarouselMobile .slide-card-mobile .anim-exp-legend,
#homeCarouselMobile .slide-card-mobile .anim-home-title,
#homeCarouselMobile .slide-card-mobile .anim-home-subtitle {
  opacity: 0;
}

/* merida */

#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .anim-city,
#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .anim-caption,
#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .anim-price {
  opacity: 0;
  will-change: transform, opacity;
}

#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .anim-city {
  animation: slideDownFade 900ms ease-out 380ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .anim-caption {
  animation: slideDownFade 900ms ease-out 220ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .anim-price {
  animation: slideUpFade 900ms ease-out 380ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="merida"].is-animating .merida-birds-image {
  animation: slideInTopRightFade 900ms ease-out 320ms forwards;
}



/* cancun */
#homeCarouselMobile .slide-card-mobile[data-slide="cancun"].is-animating .anim-cancun-title,
#homeCarouselMobile .slide-card-mobile[data-slide="cancun"].is-animating .anim-cancun-city,
#homeCarouselMobile .slide-card-mobile[data-slide="cancun"].is-animating .anim-price {
  opacity: 0;
  will-change: transform, opacity;
}

#homeCarouselMobile .slide-card-mobile[data-slide="cancun"].is-animating .anim-cancun-title {
  animation: slideUpFade 900ms ease-out 220ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="cancun"].is-animating .anim-cancun-city {
  animation: slideUpFade 900ms ease-out 220ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="cancun"].is-animating .anim-price {
  animation: slideUpFade 900ms ease-out 320ms forwards;
}

/* Experiencias */

#homeCarouselMobile .slide-card-mobile[data-slide="experiencias"].is-animating .anim-exp-legend {
  opacity: 0;
  will-change: transform, opacity;
  animation: slideUpFade 900ms ease-out 140ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="experiencias"].is-animating .anim-price {
  animation: slideInRightFade 900ms ease-out 320ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="experiencias"].is-animating .fire-right-image {
  animation: scaleFromCenterToRight 900ms ease-out 320ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="experiencias"].is-animating .fire-left-image {
  animation: scaleFromCenterToLeft 900ms ease-out 320ms forwards;
}

/* your home */
#homeCarouselMobile .slide-card-mobile[data-slide="your_home"].is-animating .anim-home-title,
#homeCarouselMobile .slide-card-mobile[data-slide="your_home"].is-animating .anim-home-subtitle {
  opacity: 0;
  will-change: transform, opacity;
}

#homeCarouselMobile .slide-card-mobile[data-slide="your_home"].is-animating .anim-home-title {
  animation: slideDownFade 900ms ease-out 220ms forwards;
}

#homeCarouselMobile .slide-card-mobile[data-slide="your_home"].is-animating .anim-home-subtitle {
  animation: slideDownFade 900ms ease-out 220ms forwards;
}





/* fin de animaciones para slick */
#mapa .map-area {
  position: relative;
}

#mapa .map-wrap {
  position: relative;
  overflow: hidden;
}

#mapa .map-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
}

#mapa .map-wrap svg {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: auto;
}

#zona-florida,
#zona-chicago,
#zona-california,
#zona-texas {
  pointer-events: all;
  cursor: pointer;
  transition: fill .15s ease, stroke .15s ease, opacity .15s ease;
}

#zona-florida:hover,
#zona-chicago:hover,
#zona-california:hover,
#zona-texas:hover {
  fill: #122e53 !important;
  opacity: 1;
  stroke: none !important;
}

#mapa .map-tooltip {
  position: absolute;
  display: none;
  width: max-content;
  max-width: 260px;
  z-index: 999;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.40);
  backdrop-filter: blur(14px);
  color: #666;
  font-size: 15px;
  line-height: 1.2;
  white-space: normal;
  word-break: break-word;
  pointer-events: none;
  transform: translate(-50%, -120%);
  box-shadow:
    0 18px 45px rgba(0, 0, 0, 0.18),
    0 2px 10px rgba(0, 0, 0, 0.10);
}

#mapa .map-tooltip::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: rgba(255, 255, 255, 0.40);
  filter: drop-shadow(0 6px 10px rgba(0, 0, 0, 0.12));
}

#mapa .hero-map h4 {
  font-family: Montserrat-Medium, sans-serif;
  color: var(--main-blue);
  font-size: 2rem;
}

#mapa .hero-map h3 {
  font-family: Montserrat-Bold, sans-serif;
  color: var(--gold-maderas);
  font-size: 2rem;
}

#mapa .hero-map h6 {
  font-family: Montserrat-Light, sans-serif;
  color: var(--main-blue);
  font-size: 20px;
  letter-spacing: 2px;
}

.stat-rotator {
  position: relative;
  display: flex;
  justify-content: center;
  width: 100%;
}

.stat-rotator__inner {
  position: relative;
  width: 100%;
  min-height: 92px;
}

.stat-rotator__item {
  position: absolute;
  left: 50%;
  top: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 18px);
}

.stat-rotator__item.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.stat-rotator__item.is-enter {
  animation: statEnter 700ms ease forwards;
}

.stat-rotator__item.is-leave {
  animation: statLeave 650ms ease forwards;
}

.stat-rotator__num {
  font-family: Montserrat-SemiBold, sans-serif;
  font-size: 4rem;
  line-height: 1;
  color: var(--main-blue);
}

.stat-rotator__text {
  font-family: Montserrat-SemiBold, sans-serif;
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--main-blue);
  transform: translateY(-2px);
}

.stat-rotator__text_main {
  font-family: Montserrat-Bold, sans-serif;
  color: var(--gold-maderas);
  font-size: 25px;
}

.stat-rotator__text_submain {
  font-family: Montserrat-Light, sans-serif;
  font-size: 25px;
  color: var(--main-blue);
}

#mapa .mapa-dollar,
#payment-facilities .mapa-dollar {
  position: absolute;
  z-index: 2;
  height: auto;
  pointer-events: none;
  user-select: none;
}

#mapa .mapa-dollar-1 {
  left: 0;
  bottom: 0;
}

#mapa .mapa-dollar-2 {
  right: 0;
  bottom: 0;
}

#mapa.map-anim-on .map-wrap,
#mapa.map-anim-on .hero-map,
#mapa.map-anim-on .mapa-dollar-1,
#mapa.map-anim-on .mapa-dollar-2 {
  opacity: 0;
  will-change: transform, opacity;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#mapa.map-anim-on.is-inview .map-wrap {
  animation: mapEnterRightToLeft 900ms ease-out 120ms forwards;
}

#mapa.map-anim-on.is-inview .hero-map {
  animation: mapEnterLeftToRight 900ms ease-out 220ms forwards;
}

#mapa.map-anim-on.is-inview .mapa-dollar-1 {
  animation: mapEnterLeftToRight 850ms ease-out 180ms forwards;
}

#mapa.map-anim-on.is-inview .mapa-dollar-2 {
  animation: mapEnterRightToLeft 850ms ease-out 260ms forwards;
}

#payment-facilities {
  min-height: 100vh;
}

#payment-facilities h1 {
  font-family: Montserrat-Bold, sans-serif;
  font-size: 40px;
  color: var(--gold-maderas);
}

#payment-facilities h5 {
  font-family: Montserrat-Light, sans-serif;
  color: var(--main-blue);
  font-size: 22px;
  letter-spacing: 2px;
}

#payment-facilities ul li,
#payment-facilities ul li .custom {
  font-family: Montserrat-Light, sans-serif;
  color: var(--main-blue);
  font-size: 18px;
}

#payment-facilities ul li .custom .text-1 {
  font-family: Montserrat-Medium, sans-serif !important;
}

#payment-facilities .pf-visual {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  min-height: 520px;
  overflow: visible;
  isolation: isolate;
}

#payment-facilities .payments {
  position: relative;
  background: rgba(255, 255, 255, 0.40);
  backdrop-filter: blur(14px);
  border-radius: 50px;
  color: var(--main-blue);
  font-size: 14px;
  white-space: nowrap;
  z-index: 5;
}

#payment-facilities .payments img {
  max-height: 25px;
  width: auto;
}

#payment-facilities .pf-visual__img {
  display: block;
  height: auto;
  max-width: none;
}

#payment-facilities .pf-visual__img--hero {
  position: relative;
  width: clamp(340px, 20vw, 570px);
  z-index: 1;
}

#payment-facilities .mapa-dollar-3 {
  top: 50%;
  left: 0;
  z-index: 0;
  width: clamp(140px, 10vw, 570px);
}

#payment-facilities .pf-visual .mapa-dollar-4 {
  position: absolute;
  right: -15%;
  bottom: -10%;
  z-index: 2;
  pointer-events: none;
  width: clamp(250px, 10vw, 570px);
}

#payment-facilities .mapa-dollar-5 {
  left: calc(-1 * (3rem));
  bottom: 0;
}

#payment-facilities .pf-anim-left,
#payment-facilities .pf-anim-right {
  opacity: 0;
  will-change: transform, opacity;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#payment-facilities .pf-anim-left {
  transform: translateX(-40px);
}

#payment-facilities .pf-anim-right {
  transform: translateX(40px);
}

#payment-facilities.is-inview .pf-anim-left {
  animation: pfEnterLeft 900ms ease-out 120ms forwards;
}

#payment-facilities.is-inview .pf-anim-right {
  animation: pfEnterRight 900ms ease-out 220ms forwards;
}

#amenities {
  height: 100vh;
  position: relative;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
  display: flex;
  align-items: center;
}

#amenities::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  z-index: 1;
}

#amenities::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 180px;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(to top,
      rgba(255, 255, 255, 1) 0%,
      rgba(255, 255, 255, 0) 100%);
}

#amenities>.container-fluid {
  position: relative;
  z-index: 4;
}

.amenities-desk-box {
  color: var(--main-blue);
}

.amenities-words__title {
  font-family: Montserrat-Light, sans-serif;
  font-size: 28px;
}

.amenities-words__word {
  margin: 0;
  line-height: 1;
}

#amenitiesWord {
  display: inline-block;
  background: linear-gradient(90deg, var(--main-blue) 0%, var(--second-blue) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-size: 85px;
}

.word-enter {
  animation: wordEnter 520ms ease forwards;
}

.word-leave {
  animation: wordLeave 420ms ease forwards;
}

#amenities .amenity-card {
  position: relative;
  width: 100%;
  border-radius: 18px;
  overflow: hidden;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 500px;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .40);
  cursor: pointer;
  transition: transform 450ms ease, box-shadow 450ms ease;
}

@media (hover: hover) and (pointer: fine) {
  #amenities .amenity-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 24px 60px rgba(0, 0, 0, .18);
  }
}

@media (hover: none) and (pointer: coarse) {
  #amenities .amenity-card:hover {
    transform: none;
    box-shadow: 0 18px 45px rgba(0, 0, 0, .40);
  }
}

#amenities .amenity-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  background: linear-gradient(to top, rgba(0, 0, 0, .35), rgba(0, 0, 0, 0));
  z-index: 2;
}

#amenities .amenity-card__title {
  color: white;
  letter-spacing: .8px;
  width: 100%;
  border-radius: 0 0 18px 18px;
  background: linear-gradient(90deg, var(--main-blue) 0%, var(--second-blue) 100%);
  text-align: center;
  padding: 8px 0;
}

#amenities .amenity-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 650ms ease;
  z-index: 1;
}

#amenities #amenitiesCards .amenity-col {
  transition:
    flex-basis 650ms cubic-bezier(.2, .8, .2, 1),
    max-width 650ms cubic-bezier(.2, .8, .2, 1),
    opacity 450ms ease,
    transform 650ms cubic-bezier(.2, .8, .2, 1);
  will-change: flex-basis, max-width, opacity, transform;
}

#amenities #amenitiesCards.is-expanding .amenity-col.is-expanded {
  flex: 0 0 100%;
  max-width: 100%;
  opacity: 1;
  transform: translateX(0);
}

#amenities #amenitiesCards.is-expanding .amenity-col.is-collapsing {
  flex: 0 0 0%;
  max-width: 0%;
  opacity: 0;
  transform: translateX(20px);
  overflow: hidden;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#amenities #amenitiesCards.is-expanding .amenity-col.is-collapsing>* {
  opacity: 0;
}

#amenities .amenity-video {
  opacity: 0;
  transition: opacity 650ms ease;
}

#amenities #amenitiesCards.is-expanding .amenity-col.is-expanded .amenity-video {
  opacity: 1;
}

#amenities #amenitiesCards:not(.is-expanding) .amenity-col {
  opacity: 1;
  transform: translateX(0);
}

#amenities .amenity-card-footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  background: linear-gradient(90deg, var(--main-blue) 0%, var(--second-blue) 100%);
  color: white;
  text-align: center;
  padding: 6px 0;
  border-radius: 0 0 10px 10px;
}

#amenities h6 {
  font-size: 20px;
}

#amenities h4 {
  font-size: 36px;
}

#amenities button {
  font-family: Montserrat-Light, sans-serif;
  padding: 8px 20px;
  border: none;
  background-color: transparent;
  margin: auto;
  font-size: 22px;
  color: var(--main-blue);
  box-shadow: 0 17px 20px rgba(0, 0, 0, 0.20);
  border-radius: 20px;
  background-color: white;
}

#contact {
  position: relative;
  background-image: var(--bg);
  background-size: contain;
  background-position: bottom;
  background-repeat: no-repeat;
  overflow: hidden;
  height: 135vh;
}

#clouds {
  padding: 0px 0 195px 0;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 0) 100%);
  color: var(--main-blue);
}

#clouds h1 {
  font-family: Montserrat-Medium, sans-serif;
  font-size: 42px;
}

#clouds h3 {
  font-size: 25px;
}

#clouds h1,
#clouds h3 {
  position: relative;
  z-index: 2;
}

#contact .clouds-divider {
  position: absolute;
  left: 0;
  top: -120px;
  height: clamp(34px, 64vw, 560px);
  object-fit: contain;
  display: block;
  pointer-events: none;
  user-select: none;
  z-index: 1;
}

#contact>.container {
  position: relative;
  z-index: 2;
}

#hero-form h2 {
  color: white;
  font-size: 35px;
  text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

#hero-form h5 {
  color: white;
  font-size: 20px;
  text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

#contactForm {
  color: white;
  font-size: 14px;
  margin-top: 5px !important;
}

#contactForm label {
  text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

#contactForm input {
  border: none;
  border-radius: 20px;
  box-shadow: 0px 4px 8.7px 0px #00000080;
  padding: .0 .75rem;
}

#contactForm button {
  width: 80%;
  border: none;
  border-radius: 20px;
  background-color: var(--main-blue);
  color: white;
  font-size: 15px;
}

.checkbox__container {
  display: block;
  position: relative;
  padding-left: 35px;
  margin-bottom: 12px;
  cursor: pointer;
  font-size: 22px;
  user-select: none;
}

.checkbox__container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}

.checkbox__checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  background-color: transparent;
  border: 2px var(--main-blue) solid;
}

.checkbox__container:hover input~.checkbox__checkmark {
  background-color: rgba(255, 255, 255, 0.250);
}

.checkbox__container input:checked~.checkbox__checkmark {
  background-color: white;
}

.checkbox__checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

.checkbox__container input:checked~.checkbox__checkmark:after {
  display: block;
}

.checkbox__container .checkbox__checkmark:after {
  left: 9px;
  top: 5px;
  width: 5px;
  height: 10px;
  border: solid var(--main-blue);
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}

#contactForm p {
  color: var(--main-blue);
  font-size: 10px;
}

#info h6 {
  font-size: 18px;
}

#info h3 {
  font-size: 32px;
}

#contact #info {
  text-align: center;
  color: white;
}

#info h1 {
  font-family: Montserrat-SemiBold, sans-serif;
  font-size: 46px;
}

#copyright {
  position: absolute;
  top: 95%;
  width: 100%;
}

#copyright p {
  color: rgba(255, 255, 255, 0.8);
  text-align: center;
  font-weight: 200;
  font-size: 12px;
}

#contact .anim-in-left,
#contact .anim-in-right {
  opacity: 0;
  will-change: transform, opacity;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
}

#contact .anim-in-left {
  transform: translateX(-40px);
}

#contact .anim-in-right {
  transform: translateX(40px);
}

#contact.is-inview .anim-in-left,
#contact.is-inview .anim-in-right {
  animation-duration: 1400ms;
  animation-timing-function: ease-out;
  animation-delay: 140ms;
  animation-fill-mode: forwards;
}

#contact.is-inview .anim-in-left {
  animation-name: contactEnterLeft;
}

#contact.is-inview .anim-in-right {
  animation-name: contactEnterRight;
}

@keyframes slideInRightFade {
  from {
    transform: translateX(28px);
    opacity: 0;
  }

  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes slideInLeftFade {
  from {
    transform: translateX(-28px);
    opacity: 0;
  }

  to {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes zoomOutBg {
  from {
    transform: scale(1.12);
  }

  to {
    transform: scale(1);
  }
}

@keyframes mapEnterRightToLeft {
  from {
    opacity: 0;
    transform: translateX(40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes mapEnterLeftToRight {
  from {
    opacity: 0;
    transform: translateX(-40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes wordEnter {
  from {
    opacity: 0;
    transform: translateY(16px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes wordLeave {
  from {
    opacity: 1;
    transform: translateY(0);
  }

  to {
    opacity: 0;
    transform: translateY(-16px);
  }
}

@keyframes statEnter {
  from {
    opacity: 0;
    transform: translate(-50%, 18px);
  }

  to {
    opacity: 1;
    transform: translate(-50%, 0);
  }
}

@keyframes statLeave {
  from {
    opacity: 1;
    transform: translate(-50%, 0);
  }

  to {
    opacity: 0;
    transform: translate(-50%, -18px);
  }
}

@keyframes slideDownFade {
  from {
    transform: translateY(-28px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes slideUpFade {
  from {
    transform: translateY(28px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes pfEnterLeft {
  from {
    opacity: 0;
    transform: translateX(-40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes pfEnterRight {
  from {
    opacity: 0;
    transform: translateX(40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes contactEnterLeft {
  from {
    opacity: 0;
    transform: translateX(-40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes contactEnterRight {
  from {
    opacity: 0;
    transform: translateX(40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideInTopRightFade {
  from {
    transform: translate3d(40px, -40px, 0) scale(0.95);
    opacity: 0;
  }

  to {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 1;
  }
}

@keyframes scaleFromCenterToLeft {
  from {
    transform: translate3d(0, 0, 0) scale(0.85);
    opacity: 0;
  }

  to {
    transform: translate3d(-30px, 0, 0) scale(1);
    opacity: 1;
  }
}

@keyframes scaleFromCenterToRight {
  from {
    transform: translate3d(0, 0, 0) scale(0.85);
    opacity: 0;
  }

  to {
    transform: translate3d(30px, 0, 0) scale(1);
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {

  .word-enter,
  .word-leave {
    animation: none !important;
  }

  .stat-rotator__item.is-enter,
  .stat-rotator__item.is-leave {
    animation: none !important;
  }

  #home .anim-title,
  #home .anim-subtitle,
  #home .anim-caption,
  #home .anim-city,
  #home .anim-cancun-title,
  #home .anim-cancun-city,
  #home .anim-price,
  #home .anim-exp-legend,
  #home .anim-home-title,
  #home .anim-home-subtitle {
    opacity: 1 !important;
    animation: none !important;
    transform: none !important;
  }

  #mapa.map-anim-on .map-wrap,
  #mapa.map-anim-on .hero-map,
  #mapa.map-anim-on .mapa-dollar-1,
  #mapa.map-anim-on .mapa-dollar-2 {
    opacity: 1 !important;
    animation: none !important;
    transform: none !important;
  }

  #payment-facilities .pf-anim-left,
  #payment-facilities .pf-anim-right {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }

  #contact .anim-in-left,
  #contact .anim-in-right {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }
}

.hero-mobile-content h1 {
  font-size: 30px;
  font-weight: bold;
  font-family: Montserrat-Bold, sans-serif;
}

.hero-mobile-content h5 {
  font-size: 8px;
  font-weight: bold;
  font-family: Montserrat-Bold, sans-serif;
  color: white;
}

.home-footer-experiencia {
  width: 100%;
}

.home-footer-experiencia .hero-mobile-btn {
  width: fit-content;
}

.experiencia-top h5 {
  font-family: Montserrat-Bold, sans-serif;
  font-size: 13px !important;
}

.experiencia-top p {
  font-size: 13px !important;
}

.payment-type-icons {
  width: 60px !important;
}


.experiencia-bottom {
  font-size: 8px !important;
}


.hero-mobile-btn a {
  display: block;
  background: #FFFFFF !important;
  box-shadow: -2.6129px 4.35484px 4.18065px -1.74194px rgba(0, 0, 0, 0.23) !important;
  backdrop-filter: blur(5.09516px) !important;
  /* Nota: El filtro de fondo es mínimamente compatible con el navegador */
  border-radius: 69.0869px !important;
  font-size: 5px !important;
  font-weight: 400 !important;
  margin: 0 !important;
  color: black !important;
  width: 100%;

}

@media (min-width: 390px) {
  .hero-mobile-content h1 {
    font-size: 50px;
  }

  .hero-mobile-content h5 {
    font-size: 13px;
  }

  .experiencia-top p,
  .experiencia-top h5 {
    font-size: 16px !important;
  }

  .experiencia-bottom {
    font-size: 13px !important;
  }

  .hero-mobile-btn a {
    font-size: 10px !important;

  }

  .payment-type-icons {
    width: 80px !important;
  }

}

@media (min-width: 420px) {
  .buscador {
    width: 100% !important
  }

  .stat-item-mobile .big-number {
    font-size: 25px !important;
  }

  .clouds-transition-up {
    top: -50px !important;
  }
}

@media (max-width: 576px) {

  #mapa .mapa-dollar-1,
  #mapa .mapa-dollar-2 {
    width: 30vw;
    bottom: -100px;
  }

  #amenities {
    height: 250vh;
  }

  #contact {
    height: 2500px;
  }

  .hero-content--merida {
    transform: translateY(-80px);
  }




  #home .payments {
    display: none !important;
  }

  .home-footer .prices-info {
    right: 50%;
    transform: translateX(50%) !important;
  }

  .home-footer .prices-info h4 {
    font-size: 40px;
  }

  .home-footer .prices-info h6,
  .home-footer .prices-info h4,
  .home-footer .prices-info h5 {
    text-shadow: 1px 7px 12px rgba(0, 0, 0, 0.95);
  }

  .home-footer button {
    font-size: 20px;
  }

  .hero-content--cancun {
    padding-bottom: 40vh;
  }

  .w-sm-75 {
    width: 75% !important;
  }

  .hero-content--cancun h3 {
    font-size: 42px;
  }

  #home .anim-cancun-city h1 {
    margin-top: 10px;
  }

  .hero-content--home {
    padding-bottom: 45vh;
  }

  .hero-content--home h2,
  .hero-content--home h3 {
    font-size: 32px;
  }

  #mapa {
    height: fit-content !important;
    padding-top: 20px;
  }

  #mapa .hero-map h4,
  #mapa .hero-map h3,
  #mapa .hero-map h6 {
    font-size: 1rem !important;
  }

  #mapa .hero-map h6 {
    font-size: 10px !important;
  }

  .stat-rotator__num {
    font-size: 1.2rem !important;
  }

  .stat-rotator__text_submain,
  .stat-rotator__text_main {
    font-size: 16px !important;
  }

  #payment-facilities h1 {
    font-size: 25px;
  }

  #payment-facilities h5 {
    font-size: 15px;
  }

  #payment-facilities ul li,
  #payment-facilities ul li p {
    font-size: 14px;
  }

  #payment-facilities ul li img {
    margin-right: 10px;
  }

  #payment-facilities .pf-visual__img--hero {
    width: 100% !important;
  }

  .mapa-dollar-5,
  .mapa-dollar-4 {
    display: none !important;
  }

  #amenitiesWord {
    font-size: 50px !important;
  }

  #amenities h6,
  #amenities h4 {
    text-align: center;
  }

  #clouds h1 {
    font-size: 25px !important;
  }

  #clouds h3 {
    font-size: 18px !important;
  }

  #clouds {
    padding: 0px 0 100px 0 !important;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%) !important;
  }



  #hero-form {
    padding-top: 0px !important;
    margin-top: -15%;
  }

  .row {
    margin-top: 25%;
  }



  .facilities-payment-title {
    display: flex;
    flex-direction: column;

  }

  .yourbank-title {
    gap: 0.5rem;
    font-size: 21px !important;
  }

  .second-line-payment {
    font-size: 8px !important;
    display: flex;
    justify-content: end;
  }

  .payment-type-box {
    gap: 1rem !important;
  }

  #hero-form h2 {
    font-size: 19px !important;
  }

  #hero-form h5 {
    font-size: 12px !important;

  }



  .content-facility {
    font-size: 10px !important;
  }

}

@media (min-width: 576px) {
  #home h1 {
    font-size: 90px;
    transform: translateY(-20px);
  }

  .home-footer .prices-info {
    right: 18px;
    transform: translateY(-70px);
  }

  .home-footer .prices-info h4 {
    font-size: 44px;
  }

  .home-footer button {
    font-size: 18px;
    padding: 8px 16px;
  }

  .payment-type-icons {
    width: 150px !important;
  }


}

@media(max-width: 992px) {
  /* Ajuste de secciones en main */

  .mapa-desk-box,
  .payment-desk-box,
  .amenities-desk-box,
  .carrousel-desk {
    display: none !important;
  }

  .payment-mobile-box {
    color: var(--main-blue);
  }

  .city-builders {
    background-color: var(--city-builders-Color);
    font-size: 22px;
    font-weight: 600;
  }

  .we-are-text {
    font-weight: 800;
    font-family: 'Montserrat-Bold', sans-serif;
  }

  .second-line-city-builders {
    font-size: 15px;
    margin-bottom: 0 !important;
  }

  .yourbank-title {
    gap: 0.5rem;
    font-size: 31px;
  }

  .second-line-payment {
    font-size: 14px;
    display: flex;
    justify-content: end;
  }

  .facilities-payment-title {
    display: flex;
    flex-direction: column;

  }

  .facility-box {
    display: flex;
    align-items: center;
    max-width: 600px;
    width: 75%;
  }

  .facility-box>div:last-child {
    flex: 1;
    min-width: 0;
  }

  .dollar-top-left {
    position: absolute;
    width: 80px;
    left: -35px;
    top: 30.44px;
    filter: blur(0.402778px);
    transform: rotate(35deg);

  }

  .dollar-top-right {
    position: absolute;
    height: 88.03px;
    right: -45px;

    top: -2.39px;

    transform: rotate(30deg);

  }

  .dollar-bottom-left {
    position: absolute;
    width: 79.33px;
    height: 69.7px;
    left: -24px;
    /* top: 227px; */

    filter: blur(0.402778px);
    transform: rotate(0deg);
  }

  .dollar-bottom-right {
    position: absolute;
    height: 88.03px;
    right: -15px;
    top: 223.03px;
    transform: rotate(160deg);
  }

  .left-facility {
    display: flex;
    justify-content: center;
    align-items: center;

    flex-shrink: 0;

    box-shadow: 1px 4px 4.2px 1px rgba(0, 0, 0, 0.25);
    border-radius: 50% !important;
    padding: 15px;
    width: 73px;
    height: 73px;
  }

  .left-facility img {
    width: 43px;
    /* Ajusta según qué tan grande quieras el icono */
    height: 43px;
    object-fit: contain;
  }

  .title-facility {
    align-self: flex-start;
    background-color: var(--main-blue);
    color: white;
    font-weight: 700;
    font-size: 9px;
    margin-bottom: 0 !important;
    padding: 3px 5px;
    padding-right: 15px;
    box-shadow: 1px 4px 4.2px 1px rgba(0, 0, 0, 0.25);
  }

  .content-facility {
    display: flex;
    flex-direction: column;
    align-items: start;
    box-shadow: 1px 4px 4.2px 1px rgba(0, 0, 0, 0.25);
    color: black;
    font-size: 13px;
    padding: 10px 5px !important;
    width: 100%;
    min-height: 47px;

  }

  .nearest-office {
    font-size: 8px;
  }

  .payment-type-box {
    gap: 3rem;
  }



  #clouds {
    padding: 0px 0 110px 0;
  }

  #clouds h1,
  #clouds h3 {
    display: none;
  }

  #hero-form h2 {
    font-size: 22px;
    color: var(--main-blue);
  }

  #hero-form h5 {
    font-size: 15px;
    color: var(--main-blue);

  }

  #contactForm input {
    background: rgba(255, 255, 255, 0.16);
    border-radius: 16px;
    backdrop-filter: blur(9.6px);
    -webkit-backdrop-filter: blur(9.6px);
    border: 1px solid rgba(255, 255, 255, 0.95);

    border-radius: 5px;
    box-shadow: 1px 4px 4.2px 1px rgba(0, 0, 0, 0.15);

  }

  #contact {
    position: relative;
    background-image: url(../img/sunset_mobile.webp) !important;
    height: fit-content !important;
    background-size: cover;
  }

  #contact .clouds-divider {
    top: -5% !important;
    height: clamp(0px, 50vw, 500px) !important;
  }

  #contact .w-sm-100 {
    width: 100% !important;
  }

  #contactForm {
    margin-bottom: 210px !important;
  }

  #contactForm button {
    width: 100%;
    margin-top: 25px;
    max-width: 500px;
  }

  #contact #info {
    margin-top: 100px;
    display: none !important;
  }








  .checkbox__checkmark {
    background: rgba(255, 255, 255, 0.16);
    border-radius: 16px;
    backdrop-filter: blur(9.6px);
    -webkit-backdrop-filter: blur(9.6px);
    border: 1px solid rgba(255, 255, 255, 0.95);

    border-radius: 5px;
    box-shadow: 1px 4px 4.2px 1px rgba(0, 0, 0, 0.15);
  }

  .additional-text-igree {
    display: none;
  }

  #check-info {
    display: none !important;
  }

  /* Carrusel */

  .slick-slide {
    opacity: 0.6;
    transition: transform 0.3s ease, opacity 0.3s ease;
  }

  .slick-center {
    opacity: 1;
    transform: scale(1.03);
  }

  .slick-prev {
    left: 0 !important;
    z-index: 10;
    width: 80px !important;
    height: 80px !important;
  }

  .slick-next {
    right: 0 !important;
    z-index: 10;
    width: 80px !important;
    height: 80px !important;
  }

  .slick-prev:before,
  .slick-next:before {
    font-size: 40px !important;
  }

  .slide-card-mobile {
    height: 80vh !important;

    padding: 0 10px;
  }

  .hero-layered {
    height: 100%;
    position: relative;
  }

  .back_mobile_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .back_mobile_image {
    inset: 0;
  }

  .slick-dots {
    bottom: -50px !important;
  }

  .slick-dots li button:before {
    font-size: 18px !important;
    color: var(--gold-maderas) !important;
    opacity: 1;
  }

  /* estilos de slides */


  .hero-content--merida h1 {
    margin: 0 !important;

  }

  .hero-content--merida {
    position: absolute;
    top: 70px;
  }

  .hero-content--cancun {
    position: absolute;
    top: 38px;
  }

  .hero-content--home {
    position: absolute;
    top: 50px;

    display: flex;
    flex-direction: column;

    align-items: flex-start;

    left: 50%;
    transform: translateX(-50%);

    width: max-content;
    /* 🔥 clave */
  }

  .hero-content--home h1 {
    line-height: 40px;
    margin-bottom: 0;
  }

  .home-footer {
    position: absolute;
    bottom: 7%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;

  }



  .home-footer .prices-info h6 {
    font-size: 6px;
    margin: 0 !important;
    text-shadow: 0px 0.571607px 1.56258px rgba(0, 0, 0, 0.8);
  }

  .home-footer .prices-info h4 {
    font-size: 21px;
    margin: 0 !important;
    text-shadow: 0px 2.1206px 5.79702px rgba(0, 0, 0, 0.8) !important;
    font-family: Montserrat-Bold, sans-serif;
  }

  .home-footer .custom-legend h5 {
    font-size: 7px;
    margin: 0 !important;
    line-height: 8px;
    text-shadow: 0px 0.657563px 1.2px #000000 !important;
    font-family: Montserrat-Bold, sans-serif;
  }

  .custom-legend {
    display: flex;
    flex-direction: column;
    margin-left: 2px;
    align-items: end;
  }

  .custom-legend h5 {
    text-shadow: 0px 0.657563px 1.79755px rgba(0, 0, 0, 0.8) !important;
  }

  .home-footer .custom-legend p {
    font-size: 2px;
    margin-bottom: 0 !important;
    text-shadow: 0px 0.190264px 0.520119px rgba(0, 0, 0, 0.8) !important;
  }

  .home-footer__inner {
    padding-inline: 0 !important;
  }

  .hero-mobile-btn {
    padding-inline: 5px;
  }

  .merida-birds-image {
    top: 50px !important;
    z-index: 500;
  }

  .fire-left-image {
    left: 0;
    top: 0;
    z-index: 500;
  }

  .fire-right-image {
    right: 0;
    bottom: 0;
    z-index: 500;
  }

  .country-city-box {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
  }

  .country-city-box .country {
    width: 37%;
  }

  .country-city-box .city {
    width: 57%;
  }



}

@media (min-width: 768px) {
  #contact {
    height: 100vh !important;
    background-size: cover;
  }

  #contact #info {
    display: none !important;
  }

  #amenities {
    padding-bottom: 100px;
  }

  #amenities h6,
  #amenities h4 {
    text-align: center;
  }

  .map-container {
    width: 50% !important;
  }

  .panelIzq {
    left: 50% !important;
    transform: translateX(-25%) !important;
  }

  #contact .clouds-divider {
    top: -5% !important;
    height: clamp(0px, 30vw, 500px) !important;
  }

  #clouds {
    padding: 0px 0 150px 0;
  }
}

@media (min-width: 992px) {
  .payment-mobile-box {
    display: none;
  }

  #check-info-mobile {
    display: none !important;
  }

  .carousel-control-prev,
  .carousel-control-next {
    display: block;
  }

  .carrousel-mobile {
    display: none;
  }
}

@media (min-width: 1024px) {
  #clouds {
    padding: 0px 0 210px 0;
  }

  #contact {
    height: 120vh;
    background-size: cover;
  }

  #contact #info {
    display: flex !important;
  }

  .map-container {
    width: 100% !important;
  }

  .panelIzq {
    left: 0px !important;
    transform: none !important;
  }

  .cantidades {
    margin-top: 170px !important;
  }

  .panelDer {
    padding-top: 280px !important;
  }

  .subtitulo {
    font-size: 35px !important;
  }
}

@media (min-width: 1366px) {

  .hero-content--merida h3,
  .hero-content--merida h2 {
    font-size: 35px;
  }

  .hero-content--merida h1,
  .hero-content--cancun h1 {
    font-size: 200px !important;
  }

  .home-footer .prices-info {
    right: 50%;
    transform: translateX(50%) !important;
  }

  /* .hero-content--home{
    padding-top: 1vh !important;
  } */

  .hero-content--home h2 {
    font-family: Montserrat-Bold, sans-serif;
    font-size: 60px;
    line-height: 1;
  }

  .hero-content--home h3 {
    font-size: 30px;
    line-height: 1;
  }

  .home-footer .prices-info h6,
  .home-footer .prices-info h4,
  .home-footer .prices-info h5 {
    text-shadow: 1px 7px 12px rgba(0, 0, 0, 0.95);
  }

  #homeCarousel .carousel-control-next {
    right: 45px;
  }

  .payments p {
    font-size: 14px
  }

  #payment-facilities .mapa-dollar-3 {
    left: 10%;
  }

  #payment-facilities .pf-visual__img--hero {
    width: clamp(525px, 20vw, 570px);
  }

  #payment-facilities h1 {
    font-size: 60px;
  }

  #payment-facilities .pf-visual .mapa-dollar-4 {
    right: -10%;
    bottom: -15%;
    width: clamp(375px, 10vw, 570px);
  }

  #payment-facilities h5 {
    font-size: 38px;
  }

  #payment-facilities ul li,
  #payment-facilities ul li .custom {
    font-size: 25px;
  }

  .hero-content--cancun {
    padding-bottom: 38vh;
  }

  .w-tb-50 {
    width: 25% !important;
  }

  #mapa .mapa-dollar-1 {
    bottom: 25%;
  }

  #amenities {
    padding: 150px 50px;
    height: fit-content !important;
  }

  #amenities h6,
  #amenities h4 {
    text-align: center;
  }

  #clouds {
    padding: 0px 0 250px 0;
  }

  #contact {
    height: 120vh;
  }

  #contact .clouds-divider {
    top: -130px;
    height: clamp(48px, 73vw, 600px);
  }

  #contact .w-sm-100 {
    width: 100% !important;
  }

  #hero-form h2 {
    font-size: 35px !important;
  }

  #contactForm button {
    width: 95%;
  }
}


@media (min-width: 1920px) {
  .mobile-nav-overlay {
    display: none !important;
  }

  .desktop-nav {
    display: block;
  }

  #mapa {
    height: auto !important;
  }

  #amenities {
    height: 100vh;
  }

  #contact {
    height: 115vh;
    background-size: cover;
  }

  #hero-form h2 {
    font-size: 45px !important;
  }

  #contact #info {
    display: block !important;
  }
}