/* Homepage editorial refresh based on the supplied premium references. */
@media (max-width: 767px) {
  body.home video[data-mobile-autoplay] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
}

body.home .destination-stories {
  position: relative !important;
  padding: clamp(72px, 8vw, 112px) 0 !important;
  background: radial-gradient(circle at 88% 8%, rgba(59,130,246,.1), transparent 28%), #0b1114 !important;
  color: #f8fafc !important;
}

body.home .destination-stories .container { position: relative !important; }
body.home .destination-transition-heading { max-width: 620px !important; margin: 0 0 32px !important; text-align: left !important; }
body.home .destination-transition-heading .eyebrow { color: #72a8ff !important; -webkit-text-fill-color: #72a8ff !important; }
body.home .destination-transition-heading h2 {
  margin: .45rem 0 .6rem !important;
  color: #f8fafc !important;
  -webkit-text-fill-color: #f8fafc !important;
  font-size: clamp(2rem, 4vw, 3.6rem) !important;
  line-height: 1 !important;
  letter-spacing: -.055em !important;
}
body.home .destination-transition-heading p { max-width: 540px !important; margin: 0 !important; color: #aab7c7 !important; -webkit-text-fill-color: #aab7c7 !important; }

body.home .destination-selection-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr) !important;
  grid-template-rows: repeat(2, minmax(230px, 1fr)) !important;
  gap: 16px !important;
}

body.home .destination-priority-card {
  min-height: 0 !important;
  height: 100% !important;
  border: 1px solid rgba(255,255,255,.11) !important;
  border-radius: 22px !important;
  background: #07101d !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
body.home .destination-priority-card.priority-1 { grid-column: 1 !important; grid-row: 1 / span 2 !important; min-height: 520px !important; }
body.home .destination-priority-card:not(.priority-1) { grid-column: 2 !important; min-height: 250px !important; }
body.home .destination-priority-card .story-media,
body.home .destination-priority-card .story-media img { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; object-fit: cover !important; }
body.home .destination-priority-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background: linear-gradient(180deg, transparent 34%, rgba(2,8,23,.22) 55%, rgba(2,8,23,.94) 100%) !important;
  pointer-events: none !important;
}
body.home .destination-choice-badge { z-index: 3 !important; top: 18px !important; left: 18px !important; color: #07101d !important; -webkit-text-fill-color: #07101d !important; background: #bfdbfe !important; border: 0 !important; }
body.home .destination-priority-card .story-copy { position: absolute !important; inset: auto 0 0 !important; z-index: 2 !important; padding: clamp(20px, 3vw, 34px) !important; background: transparent !important; color: #fff !important; }
body.home .destination-priority-card .story-copy h3 { margin: 0 !important; color: #fff !important; -webkit-text-fill-color: #fff !important; font-size: clamp(1.35rem, 2.6vw, 2.75rem) !important; line-height: 1 !important; }
body.home .destination-priority-card:not(.priority-1) .story-copy h3 { font-size: clamp(1.2rem, 2vw, 1.85rem) !important; }
body.home .destination-priority-card .story-copy p { max-width: 540px !important; margin: .65rem 0 0 !important; color: #d7e0eb !important; -webkit-text-fill-color: #d7e0eb !important; }
body.home .destination-priority-card .story-copy small,
body.home .destination-priority-card .destination-card-foot { display: none !important; }
body.home .destination-stories > .container > .text-link { position: absolute !important; top: 24px !important; right: 0 !important; color: #7db4ff !important; -webkit-text-fill-color: #7db4ff !important; }
body.home .destination-cta-mobile { display: none !important; }

body.home section#reviews { padding: clamp(72px, 8vw, 112px) 0 !important; background: #141a1c !important; }
body.home #reviews .testimonial-layout.review-compact-layout {
  display: grid !important;
  grid-template-columns: minmax(300px, .78fr) minmax(0, 1.22fr) !important;
  grid-template-areas: "summary testimonials" "stats testimonials" "crew testimonials" "write testimonials" !important;
  gap: 22px 42px !important;
  align-items: start !important;
}
body.home #reviews .review-summary { grid-area: summary !important; max-width: none !important; text-align: left !important; }
body.home #reviews .review-summary .eyebrow { padding: 0 !important; border: 0 !important; background: transparent !important; color: #72a8ff !important; -webkit-text-fill-color: #72a8ff !important; }
body.home #reviews .review-summary h2,
body.home #reviews .review-summary h2 span { margin: .55rem 0 0 !important; color: #f8fafc !important; -webkit-text-fill-color: #f8fafc !important; font-size: clamp(2.2rem, 4vw, 4rem) !important; line-height: 1.03 !important; text-align: left !important; }
body.home #reviews .review-summary h2 span { color: #72a8ff !important; -webkit-text-fill-color: #72a8ff !important; font-style: normal !important; }
body.home #reviews .review-summary > p { display: block !important; margin: 1.2rem 0 0 !important; padding-left: 18px !important; border-left: 2px solid #72a8ff !important; color: #d6dee8 !important; -webkit-text-fill-color: #d6dee8 !important; font-size: 1rem !important; font-style: italic !important; line-height: 1.75 !important; }
body.home #reviews .review-rating-band,
body.home #reviews .reviews-feature-grid,
body.home #reviews .review-trust-points { display: none !important; }
body.home #reviews .reviews-stat-grid { grid-area: stats !important; display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 14px !important; }
body.home #reviews .reviews-stat-card { padding: 0 !important; border: 0 !important; background: transparent !important; box-shadow: none !important; }
body.home #reviews .reviews-stat-card strong { color: #78aaff !important; -webkit-text-fill-color: #78aaff !important; font-size: 1.65rem !important; }
body.home #reviews .reviews-stat-card span { display: block !important; margin-top: 4px !important; color: #8593a4 !important; -webkit-text-fill-color: #8593a4 !important; font-size: .62rem !important; font-weight: 800 !important; letter-spacing: .08em !important; text-transform: uppercase !important; }
body.home #reviews .testimonial-rail-wrap { grid-area: testimonials !important; width: 100% !important; }
body.home #reviews .testimonial-rail.compact-rail { display: grid !important; grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 14px !important; }
body.home #reviews .testimonial-card { min-height: 190px !important; padding: 22px !important; border: 1px solid rgba(255,255,255,.09) !important; border-radius: 16px !important; background: #303638 !important; box-shadow: none !important; }
body.home #reviews .testimonial-card blockquote { color: #f1f5f9 !important; -webkit-text-fill-color: #f1f5f9 !important; font-size: .92rem !important; line-height: 1.65 !important; }
body.home #reviews .testimonial-card h4 { color: #fff !important; -webkit-text-fill-color: #fff !important; }
body.home #reviews .review-crew-row { grid-area: crew !important; }
body.home #reviews .review-write-row { grid-area: write !important; padding: 0 !important; border: 0 !important; background: transparent !important; box-shadow: none !important; }

@media (max-width: 900px) {
  body.home .destination-selection-grid { grid-template-columns: 1fr 1fr !important; grid-template-rows: auto !important; }
  body.home .destination-priority-card.priority-1 { grid-column: 1 / -1 !important; grid-row: auto !important; min-height: 440px !important; }
  body.home .destination-priority-card:not(.priority-1) { grid-column: auto !important; min-height: 280px !important; }
  body.home #reviews .testimonial-layout.review-compact-layout { grid-template-columns: 1fr !important; grid-template-areas: "summary" "stats" "testimonials" "crew" "write" !important; }
}

@media (max-width: 620px) {
  body.home .destination-stories {
    padding: 64px 0 72px !important;
    overflow: hidden !important;
    background: #0b1114 !important;
  }

  body.home .destination-stories .container {
    width: 100% !important;
    padding-left: 16px !important;
    overflow: visible !important;
  }

  body.home .destination-transition-heading {
    width: calc(100% - 32px) !important;
    margin: 0 0 26px !important;
    padding-right: 120px !important;
    text-align: left !important;
  }

  body.home .destination-transition-heading .eyebrow {
    display: block !important;
    margin: 0 0 6px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    text-align: left !important;
    font-size: .72rem !important;
    letter-spacing: .08em !important;
  }

  body.home .destination-transition-heading h2 {
    margin: 0 !important;
    font-size: clamp(1.72rem, 8vw, 2.15rem) !important;
    line-height: 1.06 !important;
    text-align: left !important;
  }

  body.home .destination-transition-heading p {
    display: none !important;
  }

  body.home .destination-stories > .container > .text-link {
    position: absolute !important;
    top: 32px !important;
    right: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    padding-bottom: 4px !important;
    border-bottom: 1px solid rgba(125,180,255,.45) !important;
    font-size: .7rem !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
  }

  body.home .destination-cta-desktop { display: none !important; }
  body.home .destination-cta-mobile { display: inline !important; }
  body.home .destination-cta-arrow { display: none !important; }

  body.home .destination-selection-grid {
    width: 100% !important;
    display: flex !important;
    grid-template-columns: none !important;
    gap: 14px !important;
    padding: 0 24px 14px 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory !important;
    scroll-padding-left: 16px !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.home .destination-selection-grid::-webkit-scrollbar {
    display: none !important;
  }

  body.home .destination-priority-card,
  body.home .destination-priority-card.priority-1,
  body.home .destination-priority-card:not(.priority-1) {
    flex: 0 0 min(80vw, 300px) !important;
    grid-column: auto !important;
    grid-row: auto !important;
    min-height: 430px !important;
    height: 430px !important;
    scroll-snap-align: start !important;
    border-radius: 18px !important;
  }

  body.home .destination-priority-card .story-copy {
    padding: 20px !important;
  }

  body.home .destination-priority-card .story-copy h3,
  body.home .destination-priority-card:not(.priority-1) .story-copy h3 {
    font-size: 1.5rem !important;
  }

  body.home .destination-priority-card .story-copy p {
    display: none !important;
  }

  body.home #reviews .testimonial-rail.compact-rail {
    width: calc(100vw - 16px) !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 14px !important;
    padding: 0 24px 12px 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
  }

  body.home #reviews .testimonial-rail.compact-rail::-webkit-scrollbar {
    display: none !important;
  }

  body.home #reviews .testimonial-rail.compact-rail .testimonial-card {
    flex: 0 0 min(82vw, 310px) !important;
    width: min(82vw, 310px) !important;
    min-width: min(82vw, 310px) !important;
    min-height: 280px !important;
    scroll-snap-align: start !important;
  }
}

/* High-specificity mobile override for legacy destination rules. */
@media (max-width: 620px) {
  body.home section.destination-stories.cinematic-section {
    background: #0b1114 !important;
    color: #f8fafc !important;
  }

  body.home section.destination-stories .container .destination-transition-heading {
    align-items: flex-start !important;
    text-align: left !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  body.home section.destination-stories .container .destination-transition-heading h2 {
    color: #f8fafc !important;
    -webkit-text-fill-color: #f8fafc !important;
    text-align: left !important;
  }

  body.home section.destination-stories .container .destination-transition-heading .eyebrow {
    color: #78aaff !important;
    -webkit-text-fill-color: #78aaff !important;
  }

  body.home section.destination-stories .container .destination-selection-grid.destination-transition-cards {
    width: 100% !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    justify-items: initial !important;
    margin: 0 !important;
    padding: 0 24px 14px 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card.priority-1,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card.priority-2,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card.priority-3,
  body.home section.destination-stories .destination-selection-grid .destination-choice-card,
  body.home section.destination-stories .destination-selection-grid .destination-choice-card.is-featured {
    flex: 0 0 min(80vw, 300px) !important;
    width: min(80vw, 300px) !important;
    min-width: min(80vw, 300px) !important;
    max-width: min(80vw, 300px) !important;
    height: 430px !important;
    min-height: 430px !important;
    margin: 0 !important;
    scroll-snap-align: start !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy {
    padding: 20px !important;
    text-align: left !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy h3 {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: 0 2px 16px rgba(0,0,0,.55) !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy p,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy small,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card .destination-card-foot {
    display: none !important;
  }

  body.home section.destination-stories .destination-selection-grid + .text-link {
    position: absolute !important;
    top: 29px !important;
    right: 18px !important;
    width: auto !important;
    margin: 0 !important;
    justify-content: flex-start !important;
  }
}

/* High-specificity mobile carousel for legacy testimonial rules. */
@media (max-width: 620px) {
  body.home section#reviews .container .testimonial-layout .testimonial-rail-wrap {
    width: calc(100vw - 16px) !important;
    overflow: visible !important;
  }

  body.home section#reviews .container .testimonial-rail.compact-rail {
    display: flex !important;
    grid-template-columns: none !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
  }

  body.home section#reviews .container .testimonial-rail.compact-rail .testimonial-card {
    flex: 0 0 min(82vw, 310px) !important;
    width: min(82vw, 310px) !important;
    min-width: min(82vw, 310px) !important;
    max-width: min(82vw, 310px) !important;
    margin: 0 !important;
  }
}

/* Final desktop editorial alignment for the destination heading and cards. */
@media (min-width: 901px) {
  body.home section.destination-stories .container {
    display: block !important;
    text-align: left !important;
  }

  body.home section.destination-stories .container .destination-transition-heading,
  body.home section.destination-stories .container .cinematic-heading.destination-transition-heading {
    width: min(68%, 760px) !important;
    max-width: 760px !important;
    margin: 0 0 36px !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 0 !important;
    text-align: left !important;
  }

  body.home section.destination-stories .container .destination-transition-heading .eyebrow {
    margin: 0 0 12px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }

  body.home section.destination-stories .container .destination-transition-heading h2 {
    width: 100% !important;
    max-width: 720px !important;
    margin: 0 !important;
    font-size: clamp(3rem, 5vw, 5.25rem) !important;
    line-height: .96 !important;
    text-align: left !important;
  }

  body.home section.destination-stories .container .destination-transition-heading p {
    max-width: 590px !important;
    margin: 22px 0 0 !important;
    text-align: left !important;
  }

  body.home section.destination-stories .container > .text-link {
    top: 62px !important;
    right: 0 !important;
    width: auto !important;
    margin: 0 !important;
    justify-content: flex-end !important;
    text-align: right !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy {
    align-items: flex-start !important;
    text-align: left !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy h3 {
    width: auto !important;
    margin: 0 !important;
    text-align: left !important;
  }

  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy p,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card .story-copy small,
  body.home section.destination-stories .destination-selection-grid .destination-priority-card .destination-card-foot {
    display: none !important;
  }
}

@media (max-width: 767px) {
  body.home #hero {
    min-height: 100svh !important;
    height: 100svh !important;
    align-items: center !important;
  }

  body.home #hero .container.hero-grid {
    width: 100% !important;
    padding: 0 16px !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content.hero-content-centered {
    max-width: none !important;
    width: 100% !important;
    min-height: 100svh !important;
    padding: 74px 0 20px !important;
    text-align: center !important;
    align-items: center !important;
    justify-content: center !important;
  }

  body.home #hero .hero-content .eyebrow {
    margin: 0 0 8px !important;
    font-size: .62rem !important;
    letter-spacing: .14em !important;
  }

  body.home #hero .hero-content h1,
  body.home #hero .hero-content h1 span {
    margin: 0 !important;
    font-size: clamp(1.8rem, 8.9vw, 2.7rem) !important;
    line-height: .9 !important;
    letter-spacing: -.06em !important;
    text-align: center !important;
  }

  body.home #hero .hero-text,
  body.home #hero .hero-subtext {
    max-width: 100% !important;
    text-align: center !important;
  }

  body.home #hero .hero-text {
    margin-top: 8px !important;
    font-size: .79rem !important;
    line-height: 1.36 !important;
  }

  body.home #hero .hero-subtext {
    margin-top: 4px !important;
    font-size: .64rem !important;
    line-height: 1.3 !important;
    color: rgba(255,255,255,.78) !important;
  }

  body.home #hero .hero-actions {
    width: 100% !important;
    margin-top: 12px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    align-items: center !important;
  }

  body.home #hero .hero-actions .btn,
  body.home #hero .hero-actions .btn.btn-large {
    width: 100% !important;
    max-width: 292px !important;
    min-width: 0 !important;
    min-height: 44px !important;
    padding: 10px 14px !important;
    font-size: .88rem !important;
  }

  body.home #hero .hero-stats,
  body.home #hero .premium-trust-strip {
    width: 100% !important;
    max-width: 338px !important;
    margin-top: 12px !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    justify-content: stretch !important;
    align-items: stretch !important;
  }

  body.home #hero .hero-stats > div,
  body.home #hero .premium-trust-strip > div {
    min-width: 0 !important;
    width: 100% !important;
    min-height: 58px !important;
    padding: 8px 6px !important;
    border-radius: 12px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
  }

  body.home #hero .hero-stats strong,
  body.home #hero .premium-trust-strip strong {
    font-size: .82rem !important;
    line-height: 1.1 !important;
  }

  body.home #hero .hero-stats span,
  body.home #hero .premium-trust-strip span {
    margin-top: 1px !important;
    font-size: .46rem !important;
    line-height: 1.2 !important;
  }

  body.home #hero .hero-scroll {
    margin-top: 8px !important;
    font-size: .56rem !important;
    letter-spacing: .14em !important;
  }

  body.home .whatsapp-float {
    right: 16px !important;
    bottom: 10px !important;
    left: 16px !important;
    width: auto !important;
    min-height: 46px !important;
    padding: 12px 16px !important;
    border-radius: 16px !important;
    text-align: center !important;
  }
}

@media (max-width: 420px) {
  body.home #hero .container.hero-grid {
    padding: 0 14px !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content.hero-content-centered {
    min-height: 100svh !important;
    padding: 68px 0 18px !important;
  }

  body.home #hero .hero-content h1,
  body.home #hero .hero-content h1 span {
    font-size: clamp(1.6rem, 8.9vw, 2.3rem) !important;
  }

  body.home #hero .hero-text {
    font-size: .72rem !important;
    line-height: 1.32 !important;
  }

  body.home #hero .hero-subtext {
    font-size: .58rem !important;
  }

  body.home #hero .hero-stats,
  body.home #hero .premium-trust-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    max-width: 100% !important;
    gap: 6px !important;
  }

  body.home #hero .hero-stats > div,
  body.home #hero .premium-trust-strip > div {
    min-height: 52px !important;
    padding: 7px 5px !important;
    border-radius: 11px !important;
  }

  body.home #hero .hero-stats strong,
  body.home #hero .premium-trust-strip strong {
    font-size: .74rem !important;
  }

  body.home #hero .hero-stats span,
  body.home #hero .premium-trust-strip span {
    font-size: .42rem !important;
  }

  body.home #hero .hero-actions .btn,
  body.home #hero .hero-actions .btn.btn-large {
    min-height: 42px !important;
    font-size: .82rem !important;
  }

  body.home #hero .hero-scroll {
    display: none !important;
  }
}

@media (max-width: 430px) {
  body.home #hero .hero-subtext,
  body.home #hero .hero-scroll,
  body.home #hero .hero-actions .btn-secondary {
    display: none !important;
  }

  body.home #hero .hero-actions {
    margin-top: 6px !important;
    gap: 0 !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content.hero-content-centered {
    transform: translateY(24px) !important;
  }
}

/* Keep the shared header attached to the top on the home page. */
body.home .site-header.glass-site-header,
body.home .site-header.glass-site-header.solid {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: auto !important;
  min-width: 100% !important;
  max-width: none !important;
  height: 64px !important;
  min-height: 64px !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: #08101d !important;
  background-image: none !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 14px 32px rgba(2, 8, 18, 0.18) !important;
  transform: none !important;
  overflow: visible !important;
}

body.home .site-header.glass-site-header .container.header-inner {
  width: 100% !important;
  min-width: 100% !important;
  max-width: none !important;
  height: 64px !important;
  min-height: 64px !important;
  max-height: 64px !important;
  margin: 0 !important;
  padding: 8px clamp(16px, 7vw, 112px) !important;
  border-radius: 0 !important;
  background: #08101d !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

@media (max-width: 1024px) {
  body.home .site-header.glass-site-header .container.header-inner {
    padding: 8px 12px 8px 16px !important;
  }

  body.home .site-header.glass-site-header .header-actions {
    top: 8px !important;
    right: 12px !important;
  }
}

/* Final mobile/tablet typography pass: most visitors open from phones. */
body.home {
  text-wrap: pretty;
}

body.home h1,
body.home h2,
body.home h3,
body.home p,
body.home a,
body.home button,
body.home small,
body.home span {
  overflow-wrap: anywhere;
}

body.home .hero-content h1,
body.home .cinematic-heading h2,
body.home .section-heading h2,
body.home .section-header h2,
body.home .private-experience-copy h2,
body.home .review-summary h2,
body.home .journey-copy h2,
body.home #faq h2 {
  text-wrap: balance;
}

body.home .hero-text,
body.home .hero-subtext,
body.home .cinematic-heading p,
body.home .section-heading p,
body.home .section-header p,
body.home .private-experience-copy > p,
body.home .experience-checklist p,
body.home .tour-card-content p,
body.home .review-summary > p,
body.home .testimonial-card blockquote,
body.home .booking-experience p,
body.home .faq-card p,
body.home .site-footer p {
  text-wrap: pretty;
}

@media (max-width: 1024px) {
  body.home .container {
    width: min(100% - 32px, 1120px) !important;
  }

  body.home .cinematic-section,
  body.home .section,
  body.home .destination-stories,
  body.home section#reviews {
    padding-top: 64px !important;
    padding-bottom: 64px !important;
  }

  body.home .cinematic-heading,
  body.home .section-heading,
  body.home .section-header,
  body.home .review-summary,
  body.home .journey-copy {
    max-width: 720px !important;
  }

  body.home .cinematic-heading h2,
  body.home .section-heading h2,
  body.home .section-header h2,
  body.home .private-experience-copy h2,
  body.home .review-summary h2,
  body.home .journey-copy h2,
  body.home #faq h2 {
    font-size: clamp(2rem, 6vw, 3.25rem) !important;
    line-height: 1.06 !important;
    letter-spacing: 0 !important;
  }

  body.home .cinematic-heading p,
  body.home .section-heading p,
  body.home .section-header p,
  body.home .private-experience-copy > p,
  body.home .review-summary > p,
  body.home .booking-experience p,
  body.home #faq p {
    font-size: clamp(.95rem, 2.1vw, 1.05rem) !important;
    line-height: 1.65 !important;
  }

  body.home .private-experience-grid,
  body.home .booking-experience-grid,
  body.home .testimonial-layout {
    gap: 28px !important;
  }
}

@media (max-width: 767px) {
  body.home .container {
    width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  body.home .cinematic-section,
  body.home .section,
  body.home .destination-stories,
  body.home section#reviews {
    padding-top: 44px !important;
    padding-bottom: 48px !important;
  }

  body.home .home-cta-band {
    padding: 24px 0 !important;
  }

  body.home .home-cta-inner,
  body.home .private-experience-grid,
  body.home .booking-experience-grid,
  body.home .testimonial-layout,
  body.home .review-compact-layout {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  body.home .cinematic-heading,
  body.home .section-heading,
  body.home .section-header,
  body.home .private-experience-copy,
  body.home .review-summary,
  body.home .journey-copy {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    text-align: left !important;
  }

  body.home .eyebrow,
  body.home .section-heading span,
  body.home .cinematic-heading .eyebrow {
    font-size: .68rem !important;
    line-height: 1.25 !important;
    letter-spacing: .1em !important;
  }

  body.home .hero-content h1,
  body.home .hero-content h1 span {
    max-width: 11ch !important;
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: clamp(2.15rem, 10.4vw, 3.1rem) !important;
    line-height: .98 !important;
    letter-spacing: 0 !important;
  }

  body.home .hero-text {
    max-width: 34ch !important;
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: .9rem !important;
    line-height: 1.48 !important;
  }

  body.home .cinematic-heading h2,
  body.home .section-heading h2,
  body.home .section-header h2,
  body.home .private-experience-copy h2,
  body.home .review-summary h2,
  body.home .review-summary h2 span,
  body.home .journey-copy h2,
  body.home #faq h2,
  body.home .home-cta-inner h2 {
    font-size: clamp(1.75rem, 7.6vw, 2.35rem) !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
    text-align: left !important;
  }

  body.home .cinematic-heading p,
  body.home .section-heading p,
  body.home .section-header p,
  body.home .private-experience-copy > p,
  body.home .experience-checklist p,
  body.home .tour-card-content p,
  body.home .review-summary > p,
  body.home .testimonial-card blockquote,
  body.home .booking-experience p,
  body.home .faq-card p,
  body.home .home-cta-inner p {
    font-size: .94rem !important;
    line-height: 1.58 !important;
    text-align: left !important;
  }

  body.home .experience-checklist h3,
  body.home .tour-card-content h3,
  body.home .reviews-feature-card h3,
  body.home .faq-card h3 {
    font-size: 1rem !important;
    line-height: 1.28 !important;
    letter-spacing: 0 !important;
  }

  body.home .btn,
  body.home .btn.btn-large,
  body.home .home-cta-inner .btn {
    width: 100% !important;
    max-width: 340px !important;
    min-height: 46px !important;
    padding: 12px 16px !important;
    font-size: .92rem !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  body.home .home-cta-inner .btn,
  body.home .private-experience-copy .btn,
  body.home .booking-experience .btn {
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  body.home .tour-grid,
  body.home .reviews-stat-grid,
  body.home .reviews-feature-grid,
  body.home .faq-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  body.home .tour-card-content,
  body.home .reviews-stat-card,
  body.home .reviews-feature-card,
  body.home .faq-card,
  body.home .testimonial-card {
    padding: 18px !important;
  }

  body.home #reviews .review-summary > p {
    padding-left: 12px !important;
    margin-top: .85rem !important;
  }
}

@media (min-width: 768px) and (max-width: 1180px) {
  body.home .hero-content h1,
  body.home .hero-content h1 span {
    font-size: clamp(3.4rem, 8.4vw, 5.6rem) !important;
    line-height: .98 !important;
    letter-spacing: 0 !important;
  }

  body.home .hero-text {
    max-width: 620px !important;
    font-size: 1rem !important;
    line-height: 1.62 !important;
  }

  body.home .destination-transition-heading,
  body.home .cinematic-heading,
  body.home .section-heading,
  body.home .section-header {
    max-width: 680px !important;
  }
}

@media (max-width: 430px) {
  body.home .cinematic-section,
  body.home .section,
  body.home .destination-stories,
  body.home section#reviews {
    padding-top: 36px !important;
    padding-bottom: 40px !important;
  }

  body.home .hero-content h1,
  body.home .hero-content h1 span {
    max-width: 10ch !important;
    font-size: clamp(1.75rem, 9.2vw, 2.35rem) !important;
    line-height: 1 !important;
  }

  body.home .hero-text {
    max-width: 31ch !important;
    font-size: .78rem !important;
    line-height: 1.4 !important;
  }

  body.home .cinematic-heading h2,
  body.home .section-heading h2,
  body.home .section-header h2,
  body.home .private-experience-copy h2,
  body.home .review-summary h2,
  body.home .journey-copy h2,
  body.home #faq h2,
  body.home .home-cta-inner h2 {
    font-size: clamp(1.48rem, 7.2vw, 1.95rem) !important;
    line-height: 1.1 !important;
  }

  body.home .cinematic-heading p,
  body.home .section-heading p,
  body.home .section-header p,
  body.home .private-experience-copy > p,
  body.home .experience-checklist p,
  body.home .tour-card-content p,
  body.home .review-summary > p,
  body.home .testimonial-card blockquote,
  body.home .booking-experience p,
  body.home .faq-card p,
  body.home .home-cta-inner p {
    font-size: .86rem !important;
    line-height: 1.52 !important;
  }

  body.home .destination-transition-heading {
    padding-right: 86px !important;
  }
}

/* Final detail cleanup: remove pale blue pills and cramped uppercase microcopy. */
body.home .private-experience-copy .eyebrow,
body.home .review-summary .eyebrow,
body.home section#reviews .review-summary .eyebrow,
body.home .destination-transition-heading .eyebrow,
body.home .booking-story-copy .route-label {
  display: inline-flex !important;
  width: auto !important;
  max-width: 100% !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #2563EB !important;
  -webkit-text-fill-color: #2563EB !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  letter-spacing: .035em !important;
  text-transform: none !important;
  white-space: normal !important;
}

body.home #reviews .review-write-row,
body.home section#reviews .review-write-row {
  width: fit-content !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.home #reviews .review-write-row .btn,
body.home section#reviews .review-write-row .btn {
  margin: 0 !important;
}

@media (max-width: 767px) {
  body.home .private-experience-copy .eyebrow,
  body.home .review-summary .eyebrow,
  body.home section#reviews .review-summary .eyebrow,
  body.home .destination-transition-heading .eyebrow,
  body.home .booking-story-copy .route-label {
    font-size: .74rem !important;
    letter-spacing: .02em !important;
  }

  body.home #reviews .review-write-row,
  body.home section#reviews .review-write-row {
    width: 100% !important;
  }
}

/* iPad/tablet header: avoid desktop nav + hamburger overlap. */
@media (min-width: 768px) and (max-width: 1024px) {
  body.home .site-header.glass-site-header .container.header-inner,
  body.home .site-header.glass-site-header .header-inner {
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    gap: 12px !important;
    width: min(100%, calc(100vw - 28px)) !important;
    min-height: 58px !important;
    padding: 8px 12px !important;
    overflow: visible !important;
  }

  body.home .site-header.glass-site-header .nav-links {
    display: none !important;
  }

  body.home .site-header.glass-site-header .header-actions {
    display: flex !important;
    justify-content: flex-end !important;
    grid-column: 3 !important;
    min-width: 48px !important;
  }

  body.home .site-header.glass-site-header .menu-toggle {
    display: inline-flex !important;
    width: 48px !important;
    height: 44px !important;
    padding: 0 !important;
    border-radius: 16px !important;
    background: rgba(15, 23, 42, .62) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    color: #F8FAFC !important;
    -webkit-text-fill-color: #F8FAFC !important;
  }

  body.home .site-header.glass-site-header .menu-toggle .menu-toggle-icon {
    display: block !important;
  }
}

/* Detail micro-label cleanup: use soft oval pills, never square boxes. */
body.home .eyebrow,
body.home .route-label,
body.home .destination-choice-badge,
body.home .destination-transition-heading .eyebrow,
body.home .private-experience-copy .eyebrow,
body.home .booking-story-copy .route-label,
body.home .review-summary .eyebrow,
body.home section#reviews .review-summary .eyebrow {
  width: auto !important;
  max-width: 100% !important;
  padding: .38rem .72rem !important;
  border: 1px solid rgba(96, 165, 250, .24) !important;
  border-radius: 999px !important;
  background: rgba(239, 246, 255, .12) !important;
  background-image: none !important;
  box-shadow: none !important;
  outline: 0 !important;
  line-height: 1.2 !important;
  white-space: normal !important;
}

body.home .destination-choice-badge {
  background: rgba(15, 23, 42, .42) !important;
  border-color: rgba(255, 255, 255, .22) !important;
  color: #DBEAFE !important;
  -webkit-text-fill-color: #DBEAFE !important;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .36) !important;
}

/* Match destination page reveal animation across home sections. */
body.home [data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
  will-change: auto;
}

body.home [data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

html {
  scroll-padding-top: 96px;
}

body.home {
  overscroll-behavior-y: contain;
}

@media (prefers-reduced-motion: reduce) {
  body.home [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Absolute final home header: remove the dark pasted strip and let hero sit behind it. */
body.home main {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

body.home #hero.hero {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

body.home #hero .hero-grid {
  padding-top: clamp(82px, 9vh, 116px) !important;
}

body.home .site-header.glass-site-header,
body.home .site-header.glass-site-header.solid {
  height: 76px !important;
  min-height: 76px !important;
  padding: 14px clamp(18px, 3vw, 42px) 0 !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  pointer-events: none !important;
}

body.home .site-header.glass-site-header .container.header-inner,
body.home .site-header.glass-site-header .header-inner {
  width: min(1220px, 100%) !important;
  max-width: 1220px !important;
  min-width: 0 !important;
  height: 52px !important;
  min-height: 52px !important;
  max-height: 52px !important;
  padding: 0 !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  align-items: center !important;
  gap: 18px !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  pointer-events: auto !important;
}

body.home .site-header.glass-site-header .brand-logo {
  height: 52px !important;
  min-width: 112px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  background: rgba(8, 16, 29, .34) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: none !important;
  backdrop-filter: blur(14px) saturate(130%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(130%) !important;
}

body.home .site-header.glass-site-header .nav-links {
  justify-self: end !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  width: auto !important;
  padding: 4px !important;
  border-radius: 999px !important;
  background: rgba(8, 16, 29, .34) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  box-shadow: 0 16px 44px rgba(2, 8, 18, .14) !important;
  backdrop-filter: blur(14px) saturate(130%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(130%) !important;
}

body.home .site-header.glass-site-header .nav-links > a,
body.home .site-header.glass-site-header .nav-language-trigger {
  height: 42px !important;
  min-height: 42px !important;
  border-radius: 999px !important;
}

body.home .site-header.glass-site-header .nav-links > a {
  padding: 0 16px !important;
  background: transparent !important;
  border-color: transparent !important;
}

body.home .site-header.glass-site-header .nav-links > a:hover,
body.home .site-header.glass-site-header .nav-links > a.is-active {
  background: rgba(255,255,255,.12) !important;
  border-color: rgba(255,255,255,.10) !important;
}

body.home .site-header.glass-site-header .nav-language-trigger {
  margin-left: 10px !important;
  padding: 0 16px !important;
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.12) !important;
}

body.home .site-header.glass-site-header .nav-links > .nav-contact-cta,
body.home .site-header.glass-site-header .nav-links > .nav-contact-cta.is-active {
  padding: 0 24px !important;
  background: #3B82F6 !important;
  border-color: rgba(255,255,255,.12) !important;
  box-shadow: 0 12px 28px rgba(59,130,246,.30) !important;
}

@media (max-width: 1024px) {
  body.home .site-header.glass-site-header,
  body.home .site-header.glass-site-header.solid {
    height: 74px !important;
    min-height: 74px !important;
    padding: 10px 12px 0 !important;
  }

  body.home .site-header.glass-site-header .container.header-inner,
  body.home .site-header.glass-site-header .header-inner {
    height: 54px !important;
    min-height: 54px !important;
    max-height: 54px !important;
    grid-template-columns: auto 1fr auto !important;
    padding: 7px 8px 7px 12px !important;
    border-radius: 999px !important;
    background: rgba(8, 16, 29, .58) !important;
    border: 1px solid rgba(255,255,255,.13) !important;
    box-shadow: 0 14px 36px rgba(2, 8, 18, .18) !important;
    backdrop-filter: blur(14px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(14px) saturate(130%) !important;
  }

  body.home .site-header.glass-site-header .nav-links {
    display: none !important;
  }

  body.home #hero .hero-grid {
    padding-top: calc(env(safe-area-inset-top, 0px) + 78px) !important;
  }
}

/* Final mobile home hero: compact, readable, and thumb-friendly. */
@media (max-width: 767px) {
  body.home #hero.hero {
    min-height: 100svh !important;
    overflow: hidden !important;
  }

  body.home #hero .hero-overlay {
    background:
      linear-gradient(180deg, rgba(2, 6, 23, .22) 0%, rgba(2, 6, 23, .48) 46%, rgba(2, 6, 23, .74) 100%),
      radial-gradient(circle at 50% 20%, rgba(59, 130, 246, .12), transparent 45%) !important;
  }

  body.home #hero .hero-grid {
    min-height: 100svh !important;
    padding: calc(env(safe-area-inset-top, 0px) + 86px) 18px 92px !important;
    align-items: center !important;
    justify-items: center !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content-centered {
    width: 100% !important;
    max-width: 360px !important;
    margin: 0 auto !important;
    gap: 10px !important;
    text-align: center !important;
  }

  body.home #hero .eyebrow {
    max-width: 100% !important;
    min-height: 28px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    font-size: 9px !important;
    line-height: 1 !important;
    letter-spacing: .12em !important;
    white-space: nowrap !important;
    color: #fff !important;
    background: rgba(15, 23, 42, .32) !important;
    border-color: rgba(255, 255, 255, .18) !important;
  }

  body.home #hero h1 {
    max-width: 100% !important;
    margin: 4px auto 0 !important;
    font-size: clamp(28px, 8.8vw, 36px) !important;
    line-height: .96 !important;
    letter-spacing: -.055em !important;
    text-wrap: balance !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    text-shadow: 0 8px 28px rgba(0, 0, 0, .28) !important;
  }

  body.home #hero .hero-text,
  body.home #hero .hero-subtext {
    max-width: 310px !important;
    margin: 0 auto !important;
    font-size: 12.5px !important;
    line-height: 1.45 !important;
    letter-spacing: -.01em !important;
    color: rgba(255, 255, 255, .92) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, .92) !important;
    text-shadow: 0 4px 16px rgba(0, 0, 0, .28) !important;
  }

  body.home #hero .hero-subtext {
    font-size: 12px !important;
    color: rgba(255, 255, 255, .86) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, .86) !important;
  }

  body.home #hero .hero-actions {
    width: 100% !important;
    margin-top: 6px !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  body.home #hero .hero-actions .btn,
  body.home #hero .hero-actions .btn.btn-large {
    width: 100% !important;
    min-height: 44px !important;
    height: 44px !important;
    padding: 0 18px !important;
    border-radius: 999px !important;
    font-size: 13.5px !important;
    font-weight: 800 !important;
  }

  body.home #hero .hero-actions .btn-secondary {
    display: none !important;
  }

  body.home #hero .premium-trust-strip {
    width: 100% !important;
    margin-top: 4px !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  body.home #hero .premium-trust-strip div {
    min-width: 0 !important;
    min-height: 54px !important;
    padding: 8px 6px !important;
    border-radius: 12px !important;
    background: rgba(15, 23, 42, .42) !important;
    border: 1px solid rgba(255, 255, 255, .14) !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, .14) !important;
  }

  body.home #hero .premium-trust-strip strong {
    display: block !important;
    font-size: 12px !important;
    line-height: 1.05 !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
  }

  body.home #hero .premium-trust-strip span {
    display: block !important;
    margin-top: 3px !important;
    font-size: 9px !important;
    line-height: 1.15 !important;
    color: rgba(255, 255, 255, .82) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, .82) !important;
  }

  body.home #hero .hero-scroll {
    display: none !important;
  }

  body.home .whatsapp-float {
    right: 14px !important;
    bottom: 16px !important;
    min-height: 42px !important;
    padding: 0 16px !important;
    font-size: 12px !important;
  }

  body.home #hero .hero-grid {
    min-height: calc(100svh - 16px) !important;
    padding-top: calc(env(safe-area-inset-top, 0px) + 24px) !important;
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 24px) !important;
    align-items: center !important;
    justify-items: center !important;
    align-content: center !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content-centered {
    padding: 0 0 24px !important;
    margin: 0 auto !important;
    align-self: center !important;
    justify-self: center !important;
  }
}

@media (max-width: 380px) {
  body.home #hero .hero-grid {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  body.home #hero h1 {
    font-size: clamp(27px, 8.2vw, 32px) !important;
  }

  body.home #hero .hero-text,
  body.home #hero .hero-subtext {
    font-size: 12px !important;
  }

  body.home #hero .premium-trust-strip div {
    min-height: 52px !important;
    padding: 7px 4px !important;
  }
}

/* Reference-style mobile home: airy nav + centered selling block. */
@media (max-width: 767px) {
  body.home header.site-header.glass-site-header .container.header-inner,
  body.home .site-header.glass-site-header .container.header-inner,
  body.home .site-header.glass-site-header .header-inner {
    width: calc(100% - 28px) !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
    padding: 0 !important;
    grid-template-columns: auto 1fr auto !important;
    gap: 12px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body.home header.site-header.glass-site-header .brand-logo,
  body.home .site-header.glass-site-header .brand-logo {
    width: 92px !important;
    min-width: 92px !important;
    height: 42px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body.home header.site-header.glass-site-header .brand-logo img,
  body.home .site-header.glass-site-header .brand-logo img {
    width: 78px !important;
    min-width: 78px !important;
    max-width: 78px !important;
    max-height: 36px !important;
  }

  body.home header.site-header.glass-site-header .nav-links,
  body.home .site-header.glass-site-header .nav-links {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    justify-self: end !important;
    width: auto !important;
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    gap: 14px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body.home header.site-header.glass-site-header .nav-links > a,
  body.home .site-header.glass-site-header .nav-links > a {
    display: none !important;
  }

  body.home header.site-header.glass-site-header .nav-links > a[href="tour.php"],
  body.home header.site-header.glass-site-header .nav-links > a[href="gallery.php"],
  body.home header.site-header.glass-site-header .nav-links > a[href="index.php#reviews"],
  body.home .site-header.glass-site-header .nav-links > a[href="tour.php"],
  body.home .site-header.glass-site-header .nav-links > a[href="gallery.php"],
  body.home .site-header.glass-site-header .nav-links > a[href="index.php#reviews"] {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: auto !important;
    min-width: auto !important;
    height: 42px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    letter-spacing: .045em !important;
    text-transform: uppercase !important;
    text-shadow: 0 2px 10px rgba(0, 0, 0, .3) !important;
  }

  body.home header.site-header.glass-site-header .nav-language-trigger,
  body.home header.site-header.glass-site-header .nav-contact-cta,
  body.home .site-header.glass-site-header .nav-language-trigger,
  body.home .site-header.glass-site-header .nav-contact-cta {
    display: none !important;
  }

  body.home header.site-header.glass-site-header .header-actions,
  body.home .site-header.glass-site-header .header-actions {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    min-width: 42px !important;
  }

  body.home header.site-header.glass-site-header .menu-toggle,
  body.home .site-header.glass-site-header .menu-toggle {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    background: rgba(255, 255, 255, .12) !important;
    border: 1px solid rgba(255, 255, 255, .2) !important;
    box-shadow: none !important;
  }

  body.home #hero .hero-grid {
    padding-top: calc(env(safe-area-inset-top, 0px) + 150px) !important;
    padding-bottom: 78px !important;
    align-items: center !important;
    justify-items: center !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content-centered {
    max-width: 340px !important;
    gap: 12px !important;
    margin: 0 auto !important;
    align-items: center !important;
    justify-self: center !important;
  }

  body.home #hero .eyebrow {
    margin-bottom: 2px !important;
    background: rgba(20, 184, 166, .24) !important;
    border-color: rgba(94, 234, 212, .34) !important;
  }

  body.home #hero h1 {
    font-size: clamp(29px, 8.4vw, 34px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.055em !important;
  }

  body.home #hero h1 em,
  body.home #hero h1 span {
    color: #60A5FA !important;
    -webkit-text-fill-color: #60A5FA !important;
  }

  body.home #hero .hero-text {
    max-width: 300px !important;
    font-size: 12.5px !important;
    line-height: 1.42 !important;
  }

  body.home #hero .hero-subtext {
    max-width: 310px !important;
    margin-top: 2px !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
  }

  body.home #hero .premium-trust-strip {
    margin-top: 8px !important;
    gap: 10px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  body.home #hero .premium-trust-strip div {
    min-height: 48px !important;
    padding: 2px 4px !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  body.home #hero .premium-trust-strip div + div {
    border-left: 1px solid rgba(255, 255, 255, .22) !important;
  }

  body.home #hero .premium-trust-strip strong {
    font-size: 19px !important;
    line-height: 1 !important;
  }

  body.home #hero .premium-trust-strip span {
    margin-top: 6px !important;
    font-size: 8px !important;
    line-height: 1 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
  }

  body.home #hero .hero-scroll {
    display: inline-flex !important;
    left: 50% !important;
    bottom: 36px !important;
    transform: translateX(-50%) !important;
    color: rgba(255,255,255,.78) !important;
    -webkit-text-fill-color: rgba(255,255,255,.78) !important;
    font-size: 11px !important;
    letter-spacing: .32em !important;
  }

  body.home .whatsapp-float {
    width: 54px !important;
    min-width: 54px !important;
    height: 54px !important;
    min-height: 54px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    right: 18px !important;
    bottom: 28px !important;
    font-size: 0 !important;
  }

  body.home .whatsapp-float::before {
    content: "☎" !important;
    font-size: 24px !important;
    line-height: 1 !important;
  }
}

/* Mobile perfection pass: stable 360-430px layout. */
@media (max-width: 430px) {
  body.home header.site-header.glass-site-header .container.header-inner,
  body.home .site-header.glass-site-header .container.header-inner,
  body.home .site-header.glass-site-header .header-inner {
    width: calc(100% - 28px) !important;
    height: 54px !important;
    min-height: 54px !important;
    max-height: 54px !important;
    left: 50% !important;
    top: calc(env(safe-area-inset-top, 0px) + 10px) !important;
    transform: translateX(-50%) !important;
    display: grid !important;
    grid-template-columns: 78px minmax(0, 1fr) 38px !important;
    gap: 8px !important;
    align-items: center !important;
    padding: 0 !important;
    background: rgba(8, 16, 29, .62) !important;
    border: 1px solid rgba(255, 255, 255, .12) !important;
    border-radius: 999px !important;
    box-shadow: 0 12px 34px rgba(2, 6, 23, .18) !important;
    backdrop-filter: blur(14px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(14px) saturate(130%) !important;
  }

  body.home header.site-header.glass-site-header .brand-logo,
  body.home .site-header.glass-site-header .brand-logo {
    grid-column: 1 !important;
    width: 78px !important;
    min-width: 78px !important;
    height: 42px !important;
    justify-self: start !important;
    padding-left: 12px !important;
  }

  body.home header.site-header.glass-site-header .brand-logo img,
  body.home .site-header.glass-site-header .brand-logo img {
    width: 54px !important;
    min-width: 54px !important;
    max-width: 54px !important;
    max-height: 30px !important;
  }

  body.home header.site-header.glass-site-header .nav-links,
  body.home .site-header.glass-site-header .nav-links {
    grid-column: 2 !important;
    justify-self: center !important;
    width: 100% !important;
    min-width: 0 !important;
    height: 42px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    overflow: hidden !important;
  }

  body.home header.site-header.glass-site-header .nav-links > a[href="tour.php"],
  body.home header.site-header.glass-site-header .nav-links > a[href="gallery.php"],
  body.home header.site-header.glass-site-header .nav-links > a[href="index.php#reviews"],
  body.home .site-header.glass-site-header .nav-links > a[href="tour.php"],
  body.home .site-header.glass-site-header .nav-links > a[href="gallery.php"],
  body.home .site-header.glass-site-header .nav-links > a[href="index.php#reviews"] {
    flex: 0 1 auto !important;
    min-width: 0 !important;
    height: 42px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    letter-spacing: .035em !important;
    text-align: center !important;
  }

  body.home header.site-header.glass-site-header .header-actions,
  body.home .site-header.glass-site-header .header-actions {
    grid-column: 3 !important;
    width: 38px !important;
    min-width: 38px !important;
    justify-self: end !important;
    padding-right: 2px !important;
  }

  body.home header.site-header.glass-site-header .menu-toggle,
  body.home .site-header.glass-site-header .menu-toggle {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
  }

  body.home #hero .hero-grid {
    padding: calc(env(safe-area-inset-top, 0px) + 92px) 16px 92px !important;
    align-items: center !important;
    justify-items: center !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content-centered {
    max-width: 330px !important;
    gap: 8px !important;
    margin: 0 auto !important;
    align-items: center !important;
    justify-self: center !important;
  }

  body.home #hero .eyebrow {
    min-height: 26px !important;
    padding: 0 10px !important;
    font-size: 8.5px !important;
    letter-spacing: .11em !important;
  }

  body.home #hero h1 {
    margin-top: 2px !important;
    font-size: clamp(28px, 8.2vw, 32px) !important;
    line-height: .98 !important;
  }

  body.home #hero .hero-text,
  body.home #hero .hero-subtext {
    max-width: 295px !important;
    font-size: 12px !important;
    line-height: 1.38 !important;
  }

  body.home #hero .hero-actions {
    margin-top: 5px !important;
  }

  body.home #hero .hero-actions .btn,
  body.home #hero .hero-actions .btn.btn-large {
    height: 42px !important;
    min-height: 42px !important;
    font-size: 13px !important;
  }

  body.home #hero .premium-trust-strip {
    margin-top: 8px !important;
    gap: 0 !important;
  }

  body.home #hero .premium-trust-strip div {
    min-height: 46px !important;
    padding: 4px 6px !important;
  }

  body.home #hero .premium-trust-strip strong {
    font-size: 17px !important;
  }

  body.home #hero .premium-trust-strip span {
    margin-top: 5px !important;
    font-size: 7.5px !important;
  }

  body.home #hero .hero-scroll {
    bottom: 28px !important;
    z-index: 4 !important;
  }

  body.home .whatsapp-float {
    right: 14px !important;
    bottom: 20px !important;
    width: 48px !important;
    min-width: 48px !important;
    height: 48px !important;
    min-height: 48px !important;
    z-index: 8 !important;
  }
}

@media (max-width: 360px) {
  body.home header.site-header.glass-site-header .nav-links > a[href="index.php#reviews"],
  body.home .site-header.glass-site-header .nav-links > a[href="index.php#reviews"] {
    display: none !important;
  }

  body.home #hero .hero-grid {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

/* Final hamburger alignment on mobile home. */
@media (max-width: 767px) {
  body.home header.site-header.glass-site-header .header-actions,
  body.home .site-header.glass-site-header .header-actions {
    width: 40px !important;
    min-width: 40px !important;
    height: 44px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    justify-self: end !important;
  }

  body.home header.site-header.glass-site-header .menu-toggle,
  body.home .site-header.glass-site-header .menu-toggle {
    position: relative !important;
    inset: auto !important;
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
    min-height: 38px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    background: rgba(15, 23, 42, .52) !important;
    border: 1px solid rgba(255,255,255,.28) !important;
    box-shadow: 0 10px 24px rgba(2,6,23,.2) !important;
    transform: none !important;
  }

  body.home header.site-header.glass-site-header .menu-toggle svg,
  body.home .site-header.glass-site-header .menu-toggle svg,
  body.home header.site-header.glass-site-header .menu-toggle .menu-toggle-icon,
  body.home .site-header.glass-site-header .menu-toggle .menu-toggle-icon {
    width: 20px !important;
    height: 20px !important;
    display: block !important;
    margin: 0 !important;
    color: #fff !important;
    stroke: currentColor !important;
  }

  body.home header.site-header.glass-site-header .menu-toggle span:not(.menu-toggle-fallback),
  body.home .site-header.glass-site-header .menu-toggle span:not(.menu-toggle-fallback),
  body.home header.site-header.glass-site-header .menu-toggle .menu-toggle-fallback,
  body.home .site-header.glass-site-header .menu-toggle .menu-toggle-fallback {
    display: none !important;
  }
}

/* Final override: center home hero content vertically on small mobile devices */
@media (max-width: 480px) {
  body.home #hero {
    min-height: 100svh !important;
    min-height: 100dvh !important;
  }

  body.home #hero .hero-grid {
    padding-top: calc(env(safe-area-inset-top, 0px) + 340px) !important;
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 40px) !important;
    align-items: flex-start !important;
    align-content: start !important;
    justify-items: center !important;
    min-height: calc(100% - 380px) !important;
  }

  body.home #hero .hero-content,
  body.home #hero .hero-content.hero-content-centered {
    position: relative !important;
    top: 260px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin: 0 auto !important;
    align-self: start !important;
    justify-self: center !important;
    max-width: 100% !important;
    transform: none !important;
  }

  body.home #hero .hero-content h1 {
    margin-top: 0 !important;
  }

  body.home #hero .hero-scroll {
    margin-top: 24px !important;
    position: relative !important;
    top: 0 !important;
  }
}
