/**
 * KALONGO FARM — Premium Luxury Eco-Resort UI (moodboard-aligned)
 * Loads after style.css — UI only
 */

:root {
  --eco-bg-deep: #07140D;
  --eco-bg-mid: #0D1F17;
  --eco-bg-card: #123524;
  --eco-green: #67C15E;
  --eco-green-bright: #A3FF9D;
  --eco-green-dark: #4d9a46;
  --eco-text: #FFFFFF;
  --eco-muted: rgba(255, 255, 255, 0.75);
  --eco-glass: rgba(255, 255, 255, 0.06);
  --eco-glass-hover: rgba(255, 255, 255, 0.08);
  --eco-border: rgba(255, 255, 255, 0.08);
  --eco-glow: rgba(103, 193, 94, 0.35);
  --eco-radius: 24px;
  --eco-radius-lg: 32px;
  --eco-nav-h: 76px;
  --eco-font-display: 'Cormorant Garamond', Georgia, serif;
  --eco-font-body: 'Outfit', system-ui, sans-serif;
  --eco-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --eco-section: clamp(3.5rem, 8vw, 6rem);
  --eco-container: min(1200px, 92vw);
}

html.eco-luxury-scroll { scroll-behavior: smooth; }

.eco-luxury {
  font-family: var(--eco-font-body);
  color: var(--eco-text);
  background:
    radial-gradient(circle at 12% 8%, rgba(103, 193, 94, 0.15), transparent 32%),
    radial-gradient(circle at 88% 20%, rgba(18, 53, 36, 0.5), transparent 40%),
    linear-gradient(to bottom, var(--eco-bg-deep), var(--eco-bg-mid));
  min-height: 100vh;
  padding-bottom: env(safe-area-inset-bottom, 0);
}

.eco-luxury::selection {
  background: rgba(103, 193, 94, 0.35);
  color: #fff;
}

/* Kill white surfaces from legacy style.css */
.eco-luxury .room-card,
.eco-luxury .review-slide .review-content,
.eco-luxury .facility-item,
.eco-luxury .activity-card-modern,
.eco-luxury .accommodation-card-modern,
.eco-luxury .food-card-modern,
.eco-luxury .menu-category-modern,
.eco-luxury .menu-item-modern,
.eco-luxury .other-charges-card-modern,
.eco-luxury .packages-cta-modern,
.eco-luxury .booking-form-container,
.eco-luxury .booking-summary {
  background: var(--eco-glass) !important;
  color: var(--eco-text) !important;
  border: 1px solid var(--eco-border) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.28) !important;
}

.eco-luxury,
.eco-luxury section,
.eco-luxury .packages-page,
.eco-luxury .packages-section-modern,
.eco-luxury .reviews,
.eco-luxury .activities-page {
  background: transparent !important;
}

.eco-luxury > header,
.eco-luxury > section,
.eco-luxury > footer { position: relative; z-index: 1; }

/* Ambient */
.eco-ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
.eco-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  animation: eco-float 20s ease-in-out infinite;
}
.eco-orb--1 { width: 360px; height: 360px; background: rgba(103, 193, 94, 0.12); top: 5%; left: -12%; }
.eco-orb--2 { width: 300px; height: 300px; background: rgba(18, 53, 36, 0.55); top: 50%; right: -15%; animation-delay: -7s; }
.eco-orb--3 { width: 220px; height: 220px; background: rgba(163, 255, 157, 0.06); bottom: 10%; left: 35%; animation-delay: -14s; }
@keyframes eco-float {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(16px, -20px); }
}

/* Reveal */
.eco-reveal {
  opacity: 0;
  transform: translateY(32px);
  filter: blur(8px);
  transition: opacity 0.85s var(--eco-ease), transform 0.85s var(--eco-ease), filter 0.85s;
}
.eco-reveal.is-visible { opacity: 1; transform: none; filter: none; }
.eco-reveal-delay-1 { transition-delay: 0.12s; }
.eco-reveal-delay-2 { transition-delay: 0.24s; }

.eco-glass {
  background: var(--eco-glass);
  border: 1px solid var(--eco-border);
  border-radius: var(--eco-radius);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

/* Typography */
.eco-luxury .section-title-modern,
.eco-luxury .pricing-hero-title,
.eco-luxury .activities-hero-title,
.eco-luxury .booking-hero-title {
  font-family: var(--eco-font-display) !important;
  font-weight: 600 !important;
  font-size: clamp(1.85rem, 4.5vw, 2.75rem) !important;
  color: var(--eco-text) !important;
  -webkit-text-fill-color: var(--eco-text) !important;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.eco-luxury .section-description-modern,
.eco-luxury .section-description,
.eco-luxury .about-description-modern p,
.eco-luxury .hero-subtitle,
.eco-luxury .pricing-hero-subtitle,
.eco-luxury .activities-hero-subtitle,
.eco-luxury .room-description {
  color: var(--eco-muted) !important;
  line-height: 1.75 !important;
}

.eco-luxury .hero-title {
  font-family: var(--eco-font-display) !important;
  font-size: clamp(2.5rem, 8vw, 4.25rem) !important;
  font-weight: 600 !important;
  color: #fff !important;
  line-height: 1.08 !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  text-shadow: 0 4px 40px rgba(0, 0, 0, 0.5);
}
.eco-hero-accent {
  color: var(--eco-green-bright);
  display: inline;
}

/* Buttons */
.eco-luxury .btn-primary,
.eco-luxury .btn-submit-modern,
.eco-luxury .nav-link.btn-booking {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.9rem 1.85rem !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  font-size: 0.92rem !important;
  color: var(--eco-bg-deep) !important;
  background: linear-gradient(135deg, var(--eco-green), var(--eco-green-dark)) !important;
  border: none !important;
  box-shadow: 0 6px 28px var(--eco-glow) !important;
  transition: transform 0.35s var(--eco-ease), box-shadow 0.35s !important;
}
.eco-luxury .btn-primary:hover { transform: translateY(-3px); box-shadow: 0 12px 40px var(--eco-glow) !important; }
.eco-luxury .nav-link.btn-booking::after { display: none !important; }

.eco-luxury .eco-btn-ghost {
  color: var(--eco-text) !important;
  background: var(--eco-glass) !important;
  border: 1px solid var(--eco-border) !important;
  box-shadow: none !important;
}
.eco-luxury .eco-btn-ghost:hover {
  border-color: rgba(103, 193, 94, 0.45) !important;
  background: rgba(103, 193, 94, 0.1) !important;
}

/* Navbar + logo fix */
.eco-luxury .header {
  position: fixed !important;
  inset: 0 0 auto 0;
  z-index: 1000;
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0.85rem 1rem !important;
}
.eco-luxury .header > .container {
  max-width: var(--eco-container);
  margin: 0 auto;
  padding: 0.55rem 1.15rem;
  background: rgba(7, 20, 13, 0.55);
  border: 1px solid var(--eco-border);
  border-radius: 999px;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
}
/* Navbar brand: see eco-brand-logo.css */
.eco-luxury .nav-link {
  color: var(--eco-muted) !important;
  font-weight: 500;
  font-size: 0.88rem;
  position: relative;
}
.eco-luxury .nav-link:hover,
.eco-luxury .nav-link.is-active {
  color: var(--eco-green-bright) !important;
}
.eco-luxury .nav-link.is-active {
  text-shadow: 0 0 24px var(--eco-glow);
}
.eco-luxury .nav-link:not(.btn-booking)::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -3px;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--eco-green), var(--eco-green-bright));
  transition: width 0.3s var(--eco-ease);
}
.eco-luxury .nav-link:not(.btn-booking):hover::after,
.eco-luxury .nav-link.is-active::after { width: 100%; }

/* Hero */
.eco-luxury .hero {
  min-height: 100vh;
  min-height: 100dvh;
  margin-top: 0 !important;
  padding-top: 0 !important;
  position: relative;
  overflow: hidden;
}
/* Hero overlay tuned in eco-moodboard.css for moodboard left-dark gradient */
.eco-luxury .hero-slider {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1;
}
.eco-luxury .hero-slide {
  background-size: cover !important;
  background-position: center !important;
  animation: eco-hero-zoom 18s ease-in-out infinite alternate;
}
@keyframes eco-hero-zoom {
  from { transform: scale(1); }
  to { transform: scale(1.06); }
}
.eco-luxury .hero-content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  min-height: 100vh;
  min-height: 100dvh;
  padding: calc(var(--eco-nav-h) + 1.5rem) clamp(1.25rem, 5vw, 3rem) clamp(2rem, 6vw, 4rem);
  max-width: var(--eco-container);
  margin: 0 auto;
  width: 100%;
  animation: eco-hero-in 1.1s var(--eco-ease) both;
}
@keyframes eco-hero-in {
  from { opacity: 0; transform: translateY(28px); }
  to { opacity: 1; transform: none; }
}

.eco-hero-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.1rem; }
.eco-badge {
  padding: 0.45rem 0.95rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--eco-text);
  background: var(--eco-glass);
  border: 1px solid var(--eco-border);
  border-radius: 999px;
  backdrop-filter: blur(12px);
}
.eco-hero-actions { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1.35rem; }

.eco-hero-trust {
  position: absolute;
  right: clamp(1rem, 4vw, 2.5rem);
  bottom: clamp(2rem, 6vw, 4rem);
  z-index: 4;
  width: min(280px, 90vw);
  padding: 1.35rem;
  display: none;
}
@media (min-width: 960px) { .eco-hero-trust { display: block; } }
.eco-hero-trust h4 {
  font-family: var(--eco-font-display);
  font-size: 1.15rem;
  margin: 0 0 0.85rem;
  color: var(--eco-green-bright);
}
.eco-hero-trust-stats { list-style: none; margin: 0 0 1rem; padding: 0; display: grid; gap: 0.55rem; }
.eco-hero-trust-stats li { font-size: 0.78rem; color: var(--eco-muted); }
.eco-hero-trust-stats strong { display: block; font-size: 1.3rem; color: var(--eco-text); }
.eco-hero-trust .eco-btn-sm {
  display: inline-flex;
  padding: 0.55rem 1.1rem;
  font-size: 0.8rem;
  border-radius: 999px;
  color: var(--eco-bg-deep);
  background: linear-gradient(135deg, var(--eco-green), var(--eco-green-dark));
  text-decoration: none;
  font-weight: 600;
}

/* Sections */
.eco-luxury .packages-page,
.eco-luxury .reviews { padding: var(--eco-section) 0 !important; }
.eco-luxury .container { max-width: var(--eco-container); }
.eco-luxury .packages-page + .packages-page::before,
.eco-luxury .packages-page + .reviews::before {
  content: '';
  display: block;
  width: min(65%, 420px);
  height: 1px;
  margin: 0 auto var(--eco-section);
  background: linear-gradient(90deg, transparent, var(--eco-border), transparent);
}
.eco-luxury .section-header-modern { text-align: center; margin-bottom: 2.25rem; }

/* About — text left, image right */
.eco-about-grid {
  display: grid;
  gap: 2rem;
  align-items: stretch;
}
@media (min-width: 900px) {
  .eco-about-grid {
    grid-template-columns: 1.05fr 0.95fr;
  }
  .eco-about-copy { order: 1; }
  .eco-about-visual { order: 2; }
  .eco-about-copy .section-header-modern { text-align: left; }
}
.eco-about-copy.eco-glass {
  padding: clamp(1.75rem, 4vw, 2.75rem);
}
.eco-about-copy .about-description-modern p {
  color: var(--eco-muted) !important;
  font-size: 1rem;
}
.eco-about-visual {
  border-radius: var(--eco-radius-lg);
  overflow: hidden;
  aspect-ratio: 4/5;
  max-height: 520px;
  border: 1px solid var(--eco-border);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45);
}
.eco-about-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 10s var(--eco-ease);
}
.eco-about-visual:hover img { transform: scale(1.05); }

.eco-stats-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.85rem;
  margin-top: 1.75rem;
  list-style: none;
  padding: 0;
}
@media (min-width: 600px) { .eco-stats-row { grid-template-columns: repeat(4, 1fr); } }
.eco-stat-card {
  text-align: center;
  padding: 1rem 0.65rem;
  border-radius: var(--eco-radius);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--eco-border);
  transition: transform 0.35s, box-shadow 0.35s;
}
.eco-stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 28px rgba(103, 193, 94, 0.15);
}
.eco-stat-num {
  display: block;
  font-family: var(--eco-font-display);
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  font-weight: 600;
  color: var(--eco-green-bright);
}
.eco-stat-label {
  font-size: 0.68rem;
  color: var(--eco-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* Rooms — uniform 4:5 cards */
.eco-luxury .rooms-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 1.5rem !important;
  align-items: stretch;
}
.eco-luxury .eco-room-card {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  padding: 0 !important;
  border-radius: var(--eco-radius-lg) !important;
  overflow: hidden !important;
  transition: transform 0.45s var(--eco-ease), box-shadow 0.45s !important;
}
.eco-luxury .eco-room-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 56px rgba(103, 193, 94, 0.18) !important;
}
.eco-luxury .eco-room-media {
  position: relative;
  aspect-ratio: 4/5;
  flex-shrink: 0;
  overflow: hidden;
}
.eco-luxury .eco-room-media .room-slider-container {
  position: absolute !important;
  inset: 0 !important;
  height: 100% !important;
  aspect-ratio: unset !important;
}
.eco-luxury .eco-room-media .room-slider,
.eco-luxury .eco-room-media .room-slide {
  height: 100% !important;
}
.eco-luxury .eco-room-media .room-slide-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.65s var(--eco-ease);
}
.eco-luxury .eco-room-card:hover .room-slide-image { transform: scale(1.07); }
.eco-room-media-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,20,13,0.15) 0%, rgba(7,20,13,0.35) 40%, rgba(7,20,13,0.92) 100%);
  pointer-events: none;
  z-index: 2;
}
.eco-luxury .eco-room-media .eco-room-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 3;
}
.eco-room-badge {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  background: var(--eco-glass);
  border: 1px solid var(--eco-border);
  color: var(--eco-green-bright);
}
.eco-room-media-bottom {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 3;
  padding: 1.25rem;
}
.eco-luxury .eco-room-media-bottom .room-name {
  font-family: var(--eco-font-display) !important;
  font-size: 1.5rem !important;
  color: #fff !important;
  margin: 0 0 0.25rem !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.eco-luxury .eco-room-media-bottom .room-capacity {
  color: var(--eco-green-bright) !important;
  font-size: 0.8rem !important;
  margin: 0 !important;
}
.eco-luxury .eco-room-body {
  padding: 1.15rem 1.25rem 1.35rem !important;
  flex: 1;
  display: flex;
  flex-direction: column;
  background: rgba(18, 53, 36, 0.55) !important;
}
.eco-luxury .eco-room-features {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 1rem !important;
  display: grid;
  gap: 0.45rem;
}
.eco-luxury .eco-room-features li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--eco-muted) !important;
  font-size: 0.82rem !important;
}
.eco-feat-icon {
  color: var(--eco-green);
  font-size: 0.75rem;
  width: 1.1rem;
  text-align: center;
}
.eco-room-footer {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.eco-room-from {
  font-size: 0.75rem;
  color: var(--eco-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.eco-luxury .eco-room-book {
  padding: 0.65rem 1.25rem !important;
  font-size: 0.82rem !important;
  flex-shrink: 0;
}
.eco-luxury .eco-room-slide--empty {
  background: var(--eco-bg-card) !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.eco-luxury .eco-room-slide--empty p { color: var(--eco-muted) !important; }

/* Facilities — 16:9 overlay cards */
.eco-luxury .facilities-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 1.35rem !important;
}
.eco-luxury .eco-facility-card {
  padding: 0 !important;
  border-radius: var(--eco-radius) !important;
  overflow: hidden !important;
  min-height: 220px;
  transition: transform 0.4s var(--eco-ease), box-shadow 0.4s !important;
}
.eco-luxury .eco-facility-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 0 36px var(--eco-glow) !important;
}
.eco-facility-inner {
  position: relative;
  aspect-ratio: 16/9;
  min-height: 220px;
}
.eco-facility-media {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.55s var(--eco-ease);
}
.eco-facility-media--empty {
  background: linear-gradient(135deg, var(--eco-bg-card), var(--eco-bg-mid));
}
.eco-luxury .eco-facility-card:hover .eco-facility-media { transform: scale(1.08); }
.eco-facility-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(7, 20, 13, 0.92) 0%, rgba(7, 20, 13, 0.2) 55%, transparent 100%);
  z-index: 1;
}
.eco-facility-copy {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  padding: 1.15rem 1.25rem;
}
.eco-facility-icon {
  color: var(--eco-green-bright);
  font-size: 1rem;
  display: block;
  margin-bottom: 0.35rem;
}
.eco-luxury .eco-facility-copy h3 {
  font-family: var(--eco-font-display) !important;
  color: #fff !important;
  margin: 0 0 0.35rem !important;
  font-size: 1.2rem !important;
  padding: 0 !important;
}
.eco-luxury .eco-facility-copy p {
  color: var(--eco-muted) !important;
  margin: 0 !important;
  font-size: 0.85rem !important;
  padding: 0 !important;
  line-height: 1.5 !important;
}

/* Package / service grids */
.eco-luxury .accommodation-grid-modern,
.eco-luxury .food-grid-modern,
.eco-luxury .activities-grid-modern,
.eco-luxury .other-charges-grid-modern {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 1.25rem !important;
}
.eco-luxury .activity-card-modern,
.eco-luxury .accommodation-card-modern,
.eco-luxury .food-card-modern {
  border-radius: var(--eco-radius) !important;
  padding: 1.35rem !important;
  min-height: 160px;
  transition: transform 0.35s var(--eco-ease) !important;
}
.eco-luxury .activity-card-modern:hover,
.eco-luxury .accommodation-card-modern:hover,
.eco-luxury .food-card-modern:hover { transform: translateY(-5px); }
.eco-luxury .activity-name-modern,
.eco-luxury .accommodation-name-modern,
.eco-luxury .food-name-modern,
.eco-luxury .menu-category-title-modern {
  font-family: var(--eco-font-display) !important;
  color: var(--eco-text) !important;
}
.eco-luxury .activity-price-modern,
.eco-luxury .price-value-modern,
.eco-luxury .food-price-modern,
.eco-luxury .menu-item-price-modern {
  color: var(--eco-green-bright) !important;
  font-weight: 600;
}
.eco-luxury .featured-badge-modern {
  background: linear-gradient(135deg, var(--eco-green), var(--eco-green-dark)) !important;
  color: var(--eco-bg-deep) !important;
}
.eco-luxury .menu-grid-modern {
  display: grid;
  gap: 0.5rem;
}
.eco-luxury .menu-item-modern {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 1rem !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.03) !important;
}
.eco-luxury .menu-item-name-modern { color: var(--eco-muted) !important; }

/* Activities page — horizontal luxury cards */
.eco-luxury .activities-list-container {
  display: grid;
  gap: 1.25rem;
}
.eco-luxury .eco-activity-block {
  padding: 0 !important;
  overflow: hidden;
  border-radius: var(--eco-radius) !important;
}
.eco-activity-layout {
  display: grid;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .eco-activity-layout { grid-template-columns: minmax(200px, 38%) 1fr; }
}
.eco-luxury .eco-activity-media {
  position: relative;
  min-height: 200px;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.eco-luxury .eco-activity-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--eco-ease);
}
.eco-luxury .eco-activity-block:hover .eco-activity-media img { transform: scale(1.06); }
.eco-activity-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(7, 20, 13, 0.5));
}
.eco-luxury .eco-activity-text {
  padding: 1.35rem 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.eco-luxury .activities-group-title {
  color: var(--eco-text) !important;
  font-family: var(--eco-font-display) !important;
  margin-bottom: 0.5rem !important;
}
.eco-luxury .eco-activity-desc { color: var(--eco-muted) !important; margin: 0 !important; }

/* Sub-page heroes */
.eco-luxury .pricing-hero,
.eco-luxury .activities-hero,
.eco-luxury .booking-hero {
  min-height: 48vh;
  margin-top: 0;
  padding-top: var(--eco-nav-h);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-size: cover !important;
  background-position: center !important;
}
.eco-luxury .pricing-hero::before,
.eco-luxury .activities-hero::before,
.eco-luxury .booking-hero::before,
.eco-luxury .booking-hero-overlay {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7,20,13,0.45), rgba(13,31,23,0.88));
  z-index: 1;
}
.eco-luxury .pricing-hero-content,
.eco-luxury .activities-hero-content,
.eco-luxury .booking-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 2rem;
}

/* Videos */
.eco-luxury .gallery-grid-modern:not(.eco-gallery-masonry) {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 1.25rem !important;
}
.eco-luxury .eco-video-card {
  position: relative;
  aspect-ratio: 16/10;
  border-radius: var(--eco-radius);
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--eco-border);
  background: var(--eco-bg-card);
  transition: transform 0.4s, box-shadow 0.4s;
}
.eco-luxury .eco-video-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
}
.eco-luxury .eco-video-thumb {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.55s, filter 0.55s;
}
.eco-luxury .eco-video-card:hover .eco-video-thumb {
  transform: scale(1.08);
  filter: brightness(1.08);
}
.eco-luxury .eco-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 68px;
  height: 68px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.35);
  background: var(--eco-glass);
  backdrop-filter: blur(14px);
  color: #fff;
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: transform 0.35s, box-shadow 0.35s;
  pointer-events: none;
}
.eco-luxury .eco-video-card:hover .eco-play-btn {
  transform: translate(-50%, -50%) scale(1.08);
  box-shadow: 0 0 40px var(--eco-glow);
}
.eco-luxury .eco-video-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(7,20,13,0.85), transparent 55%);
  display: flex;
  align-items: flex-end;
  padding: 1rem;
  z-index: 1;
  pointer-events: none;
}
.eco-luxury .eco-video-caption { color: var(--eco-text); margin: 0; font-size: 0.88rem; }

/* Gallery masonry */
.eco-luxury .eco-gallery-masonry { columns: 1; column-gap: 1rem; }
@media (min-width: 560px) { .eco-luxury .eco-gallery-masonry { columns: 2; } }
@media (min-width: 960px) { .eco-luxury .eco-gallery-masonry { columns: 3; } }
.eco-luxury .gallery-item-modern {
  break-inside: avoid;
  margin-bottom: 1rem;
  border-radius: var(--eco-radius);
  overflow: hidden;
  border: 1px solid var(--eco-border);
  position: relative;
  cursor: pointer;
}
.eco-luxury .gallery-media-modern {
  width: 100%;
  display: block;
  object-fit: cover;
  min-height: 200px;
  max-height: 420px;
  transition: transform 0.55s var(--eco-ease);
}
.eco-luxury .gallery-item-modern:hover .gallery-media-modern { transform: scale(1.05); }
.eco-luxury .gallery-overlay-modern {
  background: linear-gradient(0deg, rgba(7,20,13,0.9), transparent) !important;
}
.eco-luxury .gallery-caption-modern { color: #fff !important; }

/* Reviews */
.eco-luxury .reviews { text-align: center; }
.eco-luxury .reviews-slider-container {
  max-width: 920px;
  margin: 0 auto;
  border-radius: var(--eco-radius-lg) !important;
  padding: 0.75rem !important;
  backdrop-filter: blur(18px);
}
.eco-luxury .review-slide .review-content {
  background: transparent !important;
  padding: 1.75rem !important;
  align-items: center !important;
}
.eco-luxury .review-image-container {
  width: 96px !important;
  height: 96px !important;
  border-radius: 50% !important;
  border: 2px solid var(--eco-green) !important;
  overflow: hidden;
}
.eco-luxury .review-quote {
  color: var(--eco-muted) !important;
  font-family: var(--eco-font-display);
  font-size: 1.15rem !important;
  font-style: italic;
}
.eco-luxury .review-name { color: var(--eco-green-bright) !important; }
.eco-luxury .review-stars { color: #f0d78c; }

/* Footer */
.eco-luxury .footer {
  background: linear-gradient(180deg, transparent, rgba(7, 20, 13, 0.95)) !important;
  border-top: 1px solid var(--eco-border) !important;
  padding: 3.5rem 0 calc(5.5rem + env(safe-area-inset-bottom)) !important;
}
.eco-luxury .footer-content {
  display: grid;
  gap: 2rem;
}
@media (min-width: 768px) {
  .eco-luxury .footer-content { grid-template-columns: repeat(3, 1fr); }
}
.eco-luxury .footer-brand h3 {
  font-family: var(--eco-font-display) !important;
  color: var(--eco-green-bright) !important;
  font-size: 1.5rem !important;
}
.eco-luxury .footer-section h4 { color: var(--eco-text) !important; }
.eco-luxury .footer-section p,
.eco-luxury .quick-link-item { color: var(--eco-muted) !important; }
.eco-luxury .quick-link-item:hover { color: var(--eco-green-bright) !important; }
.eco-luxury .btn-visit-footer {
  background: var(--eco-glass) !important;
  border: 1px solid var(--eco-border) !important;
  border-radius: 999px !important;
  color: var(--eco-text) !important;
}
.eco-luxury .footer-bottom {
  border-top: 1px solid var(--eco-border);
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  text-align: center;
  color: var(--eco-muted);
  font-size: 0.85rem;
}

/* Modals */
.eco-lightbox, .eco-video-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(7, 20, 13, 0.94);
  backdrop-filter: blur(16px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.35s, visibility 0.35s;
}
.eco-lightbox.is-open, .eco-video-modal.is-open { opacity: 1; visibility: visible; }
.eco-lightbox img, .eco-video-modal video {
  max-width: 95vw;
  max-height: 88vh;
  border-radius: var(--eco-radius);
  object-fit: contain;
}
.eco-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 48px;
  height: 48px;
  border: 1px solid var(--eco-border);
  border-radius: 50%;
  background: var(--eco-glass);
  color: #fff;
  font-size: 1.5rem;
  cursor: pointer;
}

/* Shimmer */
.eco-shimmer {
  background: linear-gradient(90deg, rgba(255,255,255,0.03) 25%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0.03) 75%);
  background-size: 200% 100%;
  animation: eco-shimmer 1.4s infinite;
}
@keyframes eco-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Mobile chrome */
.eco-fab-book {
  display: none;
  position: fixed;
  right: 1rem;
  bottom: calc(5.75rem + env(safe-area-inset-bottom));
  z-index: 999;
  padding: 0.85rem 1.35rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--eco-bg-deep);
  background: linear-gradient(135deg, var(--eco-green), var(--eco-green-dark));
  box-shadow: 0 8px 32px var(--eco-glow);
  text-decoration: none;
}
@media (max-width: 768px) {
  .eco-fab-book { display: inline-flex; align-items: center; gap: 0.35rem; }
  .eco-luxury { padding-bottom: calc(5rem + env(safe-area-inset-bottom)); }
}
.eco-mobile-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 998;
  padding: 0.55rem 0.85rem calc(0.55rem + env(safe-area-inset-bottom));
  background: rgba(7, 20, 13, 0.94);
  border-top: 1px solid var(--eco-border);
  backdrop-filter: blur(18px);
}
@media (max-width: 768px) {
  .eco-mobile-nav { display: flex; justify-content: space-around; align-items: center; }
}
.eco-mobile-nav a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  color: var(--eco-muted);
  text-decoration: none;
  font-size: 0.62rem;
  font-weight: 500;
  padding: 0.35rem;
}
.eco-mobile-nav a svg { width: 22px; height: 22px; }
.eco-mobile-nav a.is-active, .eco-mobile-nav a:hover { color: var(--eco-green-bright); }
.eco-mobile-nav a.eco-nav-book {
  color: var(--eco-bg-deep);
  background: linear-gradient(135deg, var(--eco-green), var(--eco-green-dark));
  border-radius: 14px;
  padding: 0.4rem 0.7rem;
  font-weight: 600;
}

.eco-luxury .nav-menu.active {
  background: rgba(7, 20, 13, 0.97) !important;
  backdrop-filter: blur(18px);
  border: 1px solid var(--eco-border);
  border-radius: var(--eco-radius);
}
.eco-luxury .nav-menu-overlay.active {
  background: rgba(7, 20, 13, 0.75) !important;
}

/* Forms */
.eco-luxury input, .eco-luxury select, .eco-luxury textarea {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid var(--eco-border) !important;
  color: var(--eco-text) !important;
}
.eco-luxury label { color: var(--eco-muted) !important; }

.eco-luxury .packages-cta-modern h3 { color: var(--eco-text) !important; }
.eco-luxury .packages-cta-modern p { color: var(--eco-muted) !important; }
.eco-luxury.prices-hidden .price-display { filter: blur(6px); user-select: none; }

/* Responsive hero */
@media (max-width: 768px) {
  .eco-luxury .hero-content { padding-bottom: 5rem; }
  .eco-luxury .nav-menu { color: var(--eco-text); }
}
