﻿/* ===== LOADING SCREEN STYLES ===== */
#loading-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #F2F7F5;
  z-index: 99999;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: opacity 1.2s ease, visibility 1.2s;
}
#loading-screen.fade-out {
  opacity: 0;
  visibility: hidden;
}
.loader-container {
  position: relative;
  padding: 3rem;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  border: 1px solid rgba(26, 122, 110, 0.18);
  border-radius: 24px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.5rem;
  width: 380px;
  text-align: center;
}
.visual-wrapper {
  position: relative;
  width: 180px;
  height: 180px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.central-logo {
  width: 110px;
  height: 110px;
  object-fit: contain;
  z-index: 2;
  animation: logoPulse 4s ease-in-out infinite;
}
.orbit {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1px dashed rgba(200, 119, 58, 0.3);
  animation: rotate 6s linear infinite;
}
.plane {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%) rotate(90deg);
  font-size: 24px;
  color: #C8773A;
}
@keyframes rotate { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes logoPulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.05); } }
.loading-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.5rem;
  color: #1A3530;
  margin-bottom: 0.5rem;
}
.loading-subtitle {
  font-family: 'Poppins', sans-serif;
  font-size: 0.9rem;
  color: rgba(42, 80, 72, 0.62);
  letter-spacing: 0.05em;
}
.progress-bar-bg {
  width: 100%;
  height: 4px;
  background: rgba(200, 119, 58, 0.1);
  border-radius: 10px;
  overflow: hidden;
  margin-top: 1rem;
}
.progress-bar-fill {
  height: 100%;
  width: 40%;
  background: linear-gradient(90deg, #1A7A6E, #C8773A, #1A7A6E);
  background-size: 200% 100%;
  animation: progressMove 2s infinite linear;
}
@keyframes progressMove { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }

/* ===== CSS VARIABLES ===== */
:root {
  --jungle:#1A7A6E; --jungle-light:#2A9A8C; --jungle-mid:#157060;
  --ocean:#1A7A6E; --ocean-light:#2A9A8C;
  --sunset:#C8773A; --sunset-light:#E8A96A; --sunset-text:#ffffff;
  --gold:#C8773A; --gold-light:#E8A96A;
  --sand:#F0E8DC; --cream:#F8F4EE;
  --coral:#E8A96A; --white:#ffffff;
  --bg:#0F0F0E; --bg-card:#1C1A17; --bg-glass:rgba(42,37,32,0.65);
  --text:#F0E8DC; --text-muted:rgba(200,180,155,0.65);
  --border:rgba(200,119,58,0.18); --nav-bg:rgba(15,15,14,0.93);
  --surface:#2A2520; --surface-hover:#342F28;
  --font-head:'Oswald',sans-serif;
  --font-body:'Poppins',sans-serif;
  --radius:16px; --shadow:0 20px 60px rgba(0,0,0,0.4);
  --transition:all 0.4s cubic-bezier(0.25,0.8,0.25,1);
}
[data-theme="light"] {
  --bg:#F2F7F5; --bg-card:#FFFFFF; --bg-glass:rgba(255,255,255,0.82);
  --text:#1A3530; --text-muted:rgba(42,80,72,0.62);
  --border:rgba(26,122,110,0.18); --nav-bg:rgba(242,247,245,0.96);
  --sunset:#1A7A6E; --sunset-light:#2AA898; --sunset-text:#1A7A6E;
  --gold:#1A7A6E; --gold-light:#2AA898;
  --jungle:#1A7A6E; --jungle-light:#2AA898;
  --surface:#E7F0ED; --surface-hover:#D8EAE5;
}

/* â”€â”€ Tropical Mist light-mode component overrides â”€â”€ */
[data-theme="light"] .form-group input,
[data-theme="light"] .form-group select,
[data-theme="light"] .form-group textarea {
  background:#E7F0ED;
  border-color:rgba(26,122,110,0.18);
  color:#1A3530;
}
[data-theme="light"] .form-group input:focus,
[data-theme="light"] .form-group select:focus,
[data-theme="light"] .form-group textarea:focus {
  border-color:#1A7A6E;
  box-shadow:0 0 0 3px rgba(26,122,110,.12);
}
[data-theme="light"] .custom-select-trigger,
[data-theme="light"] .date-range-input,
[data-theme="light"] .visitors-trigger {
  background:#E7F0ED;
  border-color:rgba(26,122,110,0.18);
  color:#1A3530;
}
[data-theme="light"] .custom-select-dropdown,
[data-theme="light"] .date-picker-popup,
[data-theme="light"] .visitors-popup {
  background:#FFFFFF;
  border-color:rgba(26,122,110,0.18);
}
[data-theme="light"] .country-search-wrap input {
  background:#F2F7F5;
  border-color:rgba(26,122,110,0.18);
  color:#1A3530;
}
[data-theme="light"] .country-item:hover {
  background:rgba(26,122,110,.10);
  color:#1A7A6E;
}
[data-theme="light"] .meal-option:hover { background:rgba(26,122,110,.10); }
[data-theme="light"] .meal-option.selected { background:rgba(26,122,110,.08); }
[data-theme="light"] .vctr-btn {
  background:#E7F0ED;
  border-color:rgba(26,122,110,0.25);
  color:#1A3530;
}
[data-theme="light"] .vctr-btn:hover {
  background:#1A7A6E;
  border-color:#1A7A6E;
  color:#ffffff;
}
[data-theme="light"] .budget-slider { background:#E7F0ED; }
[data-theme="light"] .budget-slider::-webkit-slider-thumb {
  background:#1A7A6E;
  box-shadow:0 2px 10px rgba(26,122,110,.35);
}
[data-theme="light"] .dp-day:hover:not(.dp-empty):not(.dp-disabled) {
  background:rgba(26,122,110,.15);
  color:#1A7A6E;
}
[data-theme="light"] .dp-day.dp-from,
[data-theme="light"] .dp-day.dp-to { background:#1A7A6E; color:#fff; }
[data-theme="light"] .dp-day.dp-in-range { background:rgba(26,122,110,.12); }
[data-theme="light"] .dp-leg-from::before,
[data-theme="light"] .dp-leg-to::before { background:#1A7A6E; }
[data-theme="light"] .dp-leg-range::before { background:rgba(26,122,110,.15); }
[data-theme="light"] .dp-done-btn { background:#1A7A6E; }
[data-theme="light"] .dp-done-btn:hover { background:#2AA898; }
[data-theme="light"] .cal-nav-btn:hover { background:#1A7A6E; border-color:#1A7A6E; }
[data-theme="light"] .visitor-total-num { color:#1A7A6E; }
[data-theme="light"] .btn-primary { background:#1A7A6E; box-shadow:0 6px 25px rgba(26,122,110,.28); }
[data-theme="light"] .btn-primary:hover { background:#2AA898; box-shadow:0 12px 40px rgba(26,122,110,.42); }
[data-theme="light"] .btn-outline { border-color:#1A7A6E; color:#1A7A6E; }
[data-theme="light"] .btn-outline:hover { background:#1A7A6E; color:#ffffff; }
[data-theme="light"] .nav-cta { background:#1A7A6E; box-shadow:0 4px 20px rgba(26,122,110,.28); }
[data-theme="light"] .nav-cta:hover { box-shadow:0 8px 30px rgba(26,122,110,.45); }
[data-theme="light"] .section-label { color:#1A7A6E; }
[data-theme="light"] .section-title em { color:#1A7A6E; }
[data-theme="light"] .filter-btn:hover,
[data-theme="light"] .filter-btn.active { background:#1A7A6E; border-color:#1A7A6E; }
[data-theme="light"] .social-btn:hover { background:#1A7A6E; border-color:#1A7A6E; }
[data-theme="light"] .info-icon { background:linear-gradient(135deg,#1A7A6E,#2AA898); }
[data-theme="light"] .pkg-highlight { background:rgba(26,122,110,.08); border-color:rgba(26,122,110,.2); color:#1A7A6E; }
[data-theme="light"] .day-tag { background:rgba(26,122,110,.1); color:#1A7A6E; }
[data-theme="light"] .booking-submit { background:#1A7A6E; }
[data-theme="light"] .booking-submit:hover { background:#2AA898; box-shadow:0 10px 35px rgba(26,122,110,.4); }
[data-theme="light"] .dest-overlay { background:linear-gradient(to top,rgba(16,50,44,.94) 0%,rgba(16,50,44,.48) 60%,rgba(0,0,0,0) 100%); }
[data-theme="light"] .why-icon { color:#1A7A6E; }
[data-theme="light"] #whatsapp-btn ~ .wa-tooltip { color:#1A3530; }
[data-theme="light"] .footer-col a:hover { color:#1A7A6E; }
[data-theme="light"] .nav-links a:hover,
[data-theme="light"] .nav-links a.active { color:#1A7A6E; }
[data-theme="light"] .nav-links a::after { background:#1A7A6E; }
[data-theme="light"] .contact-form { background:#FFFFFF; }
[data-theme="light"] .testi-name { color:#1A3530; }
[data-theme="light"] .loc-stars { color:#1A7A6E; }
[data-theme="light"] .cta-section { background:linear-gradient(rgba(215,236,230,.88),rgba(215,236,230,.94)),url('https://images.unsplash.com/photo-1770374441638-6608acfcfe21?q=80&w=1170&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover; }
[data-theme="light"] .cta-title{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,3.5rem);color:#008080;font-weight:700;line-height:1.2;margin-bottom:1rem}
[data-theme="light"] .cta-sub{color:#008080;margin-bottom:2.5rem;font-size:1.05rem}


/* ===== RESET ===== */
	*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
	:focus-visible {
	  outline: 3px solid var(--sunset);
	  outline-offset: 4px;
	}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family: 'Oswald', system-ui, -apple-system, sans-serif;font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.7;transition:background 0.4s,color 0.4s;overflow-x:hidden}
a{text-decoration:none;color:inherit} img{max-width:100%} ul{list-style:none} button{border:none;background:none;font-family:var(--font-body)}



/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 4%;display:flex;align-items:center;justify-content:space-between;background:transparent;transition:var(--transition)}
nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(20px);padding:.8rem 4%;box-shadow:0 4px 30px rgba(0,0,0,.3);border-bottom:1px solid var(--border)}
.nav-logo{font-family:var(--font-head);font-size:1.4rem;font-weight:700;color:var(--cyan);display:flex;align-items:center;gap:.6rem;cursor:pointer}
.nav-logo-icon{width:34px;height:34px;background:transparent;border-radius:0;display:flex;align-items:center;justify-content:center;font-size:1rem}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{font-size:.85rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text);opacity:.85;position:relative;transition:var(--transition)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--sunset);transform:scaleX(0);transition:transform .3s}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--sunset-text)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{padding:.5rem 1.4rem;background:var(--sunset);color:#fff !important;border-radius:50px;font-weight:600 !important;opacity:1 !important;transition:var(--transition) !important;box-shadow:0 4px 20px rgba(200,119,58,.35)}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(200,119,58,.55)}
.nav-cta::after{display:none !important}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;z-index:1001}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);transition:var(--transition);border-radius:2px}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  z-index:999;
  flex-direction:column;
  background:var(--bg-card);
  border-top:1px solid var(--border);
  border-radius:24px 24px 0 0;
  padding:1rem 2rem 2.5rem;
  transform:translateY(100%);
  transition:transform .38s cubic-bezier(.32,0,.67,0);
  box-shadow:0 -20px 60px rgba(0,0,0,.35);
  backdrop-filter:blur(20px);
}
.mobile-menu.open{transform:translateY(0);transition:transform .42s cubic-bezier(.33,1,.68,1)}
/* drag handle */
.mobile-menu::before{
  content:'';display:block;width:40px;height:4px;
  background:var(--border);border-radius:4px;
  margin:0 auto 1.5rem;
}
.mobile-menu a{
  font-family:var(--font-body);
  font-size:1.1rem;font-weight:600;
  color:var(--text);
  padding:.85rem 0;
  border-bottom:1px solid var(--border);
  transition:color .25s,padding-left .25s;
  letter-spacing:.02em;
}
.mobile-menu a:last-child{border-bottom:none}
.mobile-menu a:hover{color:var(--jungle);padding-left:.5rem}
/* Overlay backdrop for mobile */
.mobile-overlay{
  display:none;position:fixed;inset:0;
  z-index:998;background:rgba(0,0,0,.55);
  backdrop-filter:blur(2px);
  opacity:0;transition:opacity .3s ease;
}
.mobile-overlay.open{opacity:1}

/* ===== THEME TOGGLE - MOVED TO TOP RIGHT ===== */
#theme-toggle{position:fixed;top:0.88rem;right:0.8rem;z-index:1001;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--jungle-light),var(--ocean));color:#fff;font-size:1.3rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.4);transition:var(--transition);border:1px solid var(--border)}
#theme-toggle:hover{transform:scale(1.1) rotate(20deg)}

/* ===== WHATSAPP BUTTON ===== */
#whatsapp-btn{
  position:fixed;bottom:2rem;right:2rem;z-index:998;
  width:56px;height:56px;border-radius:50%;
  background:#25d366;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.5);
  transition:var(--transition);
  animation:waPulse 2.5s ease-in-out infinite;
}
#whatsapp-btn:hover{transform:scale(1.12);box-shadow:0 8px 35px rgba(37,211,102,.7)}
#whatsapp-btn svg{width:30px;height:30px;fill:#fff}
@keyframes waPulse{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,.5)}50%{box-shadow:0 4px 35px rgba(37,211,102,.9),0 0 0 8px rgba(37,211,102,.15)}}
.wa-tooltip{
  position:fixed;bottom:2.6rem;right:5rem;z-index:997;
  background:#fff;color:#1a1a1a;font-size:.8rem;font-weight:600;
  padding:.5rem 1rem;border-radius:8px;white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
#whatsapp-btn:hover ~ .wa-tooltip{opacity:1}

/* ===== PAGE SYSTEM ===== */
.page{display:none;opacity:0;transition:opacity .4s ease}
.page.active{display:block;opacity:1}

/* ===== SCROLL REVEAL â€” staggered ===== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* Stagger children inside grid containers */
.stagger-children > *{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.stagger-children.visible > *:nth-child(1){opacity:1;transform:translateY(0);transition-delay:.05s}
.stagger-children.visible > *:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.15s}
.stagger-children.visible > *:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.25s}
.stagger-children.visible > *:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.35s}
.stagger-children.visible > *:nth-child(5){opacity:1;transform:translateY(0);transition-delay:.45s}
.stagger-children.visible > *:nth-child(6){opacity:1;transform:translateY(0);transition-delay:.55s}

/* Button ripple */
.btn{position:relative;overflow:hidden}
.btn-ripple{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.35);
  transform:scale(0);animation:ripple .55s linear;
  pointer-events:none;
}
@keyframes ripple{to{transform:scale(4);opacity:0}}

/* Stat counters */
.stat-num{font-family:var(--font-head);font-size:2.3rem;font-weight:700;color:var(--gold-light);line-height:1;display:inline-block}

/* Focus-visible improvements (accessibility) */
:focus-visible{outline:3px solid var(--jungle);outline-offset:4px;border-radius:4px}

/* ===== UTILS ===== */
.section-label{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sunset-text);font-weight:600;margin-bottom:.75rem}
.section-title{font-family:var(--font-head);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;line-height:1.2;color:var(--text)}
.section-title em{color:var(--sunset-text);font-style:italic}
.section-subtitle{font-size:1rem;color:var(--text-muted);max-width:540px;line-height:1.8;margin-top:1rem}
.container{max-width:1200px;margin:0 auto;padding:0 4%}
section{padding:100px 4%}
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:.85rem 2.2rem;border-radius:50px;font-size:.9rem;font-weight:600;letter-spacing:.05em;transition:var(--transition)}
.btn-primary{background:var(--sunset);color:#fff;box-shadow:0 6px 25px rgba(200,119,58,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(200,119,58,.55);background:var(--sunset-light)}
.btn-outline{border:1.5px solid var(--gold);color:var(--gold);background:transparent}
.btn-outline:hover{background:var(--gold);color:var(--bg)}
.btn-white{background:#fff;color:var(--jungle)}
.btn-white:hover{background:var(--cream);transform:translateY(-3px)}
.btn-dark{background:rgba(0,0,0,.45);backdrop-filter:blur(8px);color:#fff;border:1px solid rgba(255,255,255,.25)}
.btn-dark:hover{background:rgba(0,0,0,.7)}

.popup-overlay{
    position:fixed;
    top:0;
    left:0;
    width:100vw;
    height:100vh;
    background:rgba(0,0,0,0.6);

    display:none; /* hidden by default */
    justify-content:center;
    align-items:center;

    z-index:99999;
}

.popup-box{
    background:#0f172a;
    color:#fff;
    padding:25px;
    border-radius:12px;
    text-align:center;
    width:300px;
    box-shadow:0 10px 40px rgba(0,0,0,0.5);
}

.popup-box h3{
    margin-bottom:10px;
}

.popup-box button{
    margin-top:15px;
    padding:8px 15px;
    border:none;
    background:#3b82f6;
    color:white;
    border-radius:6px;
    cursor:pointer;
}
/* =====================================================
   HOME PAGE
===================================================== */

/* HERO */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}

/* Slideshow layers */
.hero-slide{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:0;
  animation:kenBurns 10s ease-in-out forwards;
  will-change:transform,opacity;
}
.hero-slide.active{opacity:1}
.hero-slide.fade-out{opacity:0;transition:opacity 1.4s ease}

/* Hero overlay â€” gradient + subtle noise */
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(8,20,14,.25) 0%,rgba(8,20,14,.50) 50%,rgba(8,20,14,.92) 100%);
  z-index:1;
}
.hero-bg::after{
  content:'';position:absolute;inset:0;z-index:2;
  background-image:radial-gradient(circle,rgba(255, 255, 255, 0.30) 1px,transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}

/* Slide dots indicator */
.hero-dots{
  position:absolute;bottom:5.5rem;left:50%;transform:translateX(-50%);
  z-index:4;display:flex;gap:.5rem;
}
.hero-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.35);
  border:none;padding:0;cursor:pointer;
  transition:all .3s ease;
}
.hero-dot.active{
  width:22px;border-radius:4px;
  background:#E8A96A;
}

/* Light mode hero overlay */
[data-theme="light"] .hero-dot.active{background:var(--jungle)}

@keyframes kenBurns{
  0%{transform:scale(1.08) translate(1%,0.5%)}
  100%{transform:scale(1) translate(0,0)}
}
.hero-content{position:relative;z-index:3;max-width:900px;padding:0 2rem}.glass-block{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:100%;height:58%;background:rgba(255,255,255,0.2);backdrop-filter:blur(2.5px);-webkit-backdrop-filter:blur(2.5px);border:1px solid rgba(255,255,255,0.1);border-radius:24px;z-index:-1;box-shadow:0 8px 32px 0 rgba(31,38,135,0.37);overflow:hidden}.glass-block::before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,rgba(255,255,255,0) 0%,rgba(255,255,255,0.1) 45%,rgba(255,255,255,0.5) 50%,rgba(255,255,255,0.1) 55%,rgba(255,255,255,0) 100%);transform:rotate(30deg);animation:glass-shine 6s infinite linear}@keyframes glass-shine{0%{transform:translateX(-100%) rotate(30deg)}100%{transform:translateX(100%) rotate(30deg)}}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem 1.3rem;
  border:1px solid rgba(255,255,255,.28);
  border-radius:50px;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:#fff;margin-bottom:2rem;
  background:rgba(0,0,0,.22);backdrop-filter:blur(12px);
  font-family:var(--font-body);font-weight:500;
  opacity:0;animation:heroFadeUp .8s .3s ease forwards;
}
[data-theme="light"] .hero-badge{
  border-color:rgba(26,122,110,.22);color:rgba(20,70,62,.88);background:rgba(232,244,240,.55);
}
.hero-title {
  font-family: 'Oswald', sans-serif;
  font-size: clamp(5rem, 11vw, 9rem);
  font-weight: 700;
  line-height: 0.88;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  /* Adds a global shadow to all lines */
  text-shadow: 3px 6px 15px rgba(0, 0, 0, 0.4); 
}

.hero-title .line1 {
  display: block;
  color: #E8A96A;
  letter-spacing: .01em;
  opacity: 0;
  animation: heroSlideRight .9s .5s cubic-bezier(.16,1,.3,1) forwards;
}

.hero-title .line2 {
  display: block;
  color: #FFFFFF;
  letter-spacing: -.03em;
  opacity: 0;
  animation: heroSlideRight .9s .65s cubic-bezier(.16,1,.3,1) forwards;
}

[data-theme="light"] .hero-title .line1{color:#2A9A8C}
[data-theme="light"] .hero-title .line2{color:rgba(255, 255, 255, 1)}
.hero-sub{
  font-size:1rem;letter-spacing:.03em;
  color:rgba(255,255,255,.90);
  max-width:480px;margin:0 auto 2.8rem;line-height:1.85;
  font-weight:400;
  opacity:0;animation:heroFadeUp .8s .85s ease forwards;
}
[data-theme="light"] .hero-sub{color:rgba(255, 255, 255, .90)}
.hero-btns{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:heroFadeUp .8s 1s ease forwards;
}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroSlideRight{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.5);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;animation:bounce 2.5s ease-in-out infinite}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* STATS */
.stats-bar{background:linear-gradient(135deg,#1f4a30,#0e3a52);padding:2rem 4%}
.stats-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat-num{font-family:var(--font-head);font-size:2.3rem;font-weight:700;color:var(--gold-light);line-height:1}
.stat-label{font-size:.72rem;color:rgba(255,255,255,.65);margin-top:.3rem;letter-spacing:.1em;text-transform:uppercase}

/* DESTINATIONS PREVIEW */
.destinations-preview{background:var(--bg)}

/* Filter Nav Tabs */
.dest-filter-nav{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin-top:2.5rem;border-bottom:1px solid var(--border);padding-bottom:0}
.dest-filter-btn{
  font-family:var(--font-body);font-size:.82rem;font-weight:500;
  color:var(--text-muted);background:none;border:none;
  padding:.6rem 1.3rem;cursor:pointer;
  position:relative;transition:color .25s;
  letter-spacing:.03em;white-space:nowrap;
}
.dest-filter-btn::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;
  background:var(--jungle);transform:scaleX(0);transition:transform .3s ease;
}
.dest-filter-btn.active{color:var(--jungle);font-weight:600}
.dest-filter-btn.active::after{transform:scaleX(1)}
.dest-filter-btn:hover{color:var(--jungle)}
.dest-filter-search{margin-left:auto;background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:.4rem .6rem;transition:color .2s}
.dest-filter-search:hover{color:var(--jungle)}

/* Mosaic Grid â€” named-area layout for true varied sizes */
.dest-mosaic{
  display:grid;
  grid-template-columns: 1.6fr 1fr 1.2fr;
  grid-template-rows: 260px 200px 230px;
  gap:6px;
  margin-top:1rem;
}

/* Named grid areas */
.dest-mosaic .dest-card:nth-child(1){ grid-area:1/1/3/2; }  /* Sigiriya â€” tall left, rows 1-2 */
.dest-mosaic .dest-card:nth-child(2){ grid-area:1/2/2/3; }  /* Yala â€” top center, normal */
.dest-mosaic .dest-card:nth-child(3){ grid-area:1/3/2/4; }  /* Kandy â€” top right, normal */
.dest-mosaic .dest-card:nth-child(4){ grid-area:2/2/3/4; }  /* Ella â€” wide middle, spans 2 cols */
.dest-mosaic .dest-card:nth-child(5){ grid-area:3/1/4/2; }  /* Bentota â€” bottom left, narrow */
.dest-mosaic .dest-card:nth-child(6){ grid-area:3/2/4/3; }  /* Mirissa â€” bottom center */
.dest-mosaic .dest-card:nth-child(7){ grid-area:3/3/4/4; }  /* Galle â€” bottom right */
.dest-mosaic .dest-card:nth-child(8){ display:none; }        /* Udawalawe hidden in this layout */

/* Card base */
.dest-card{position:relative;overflow:hidden;cursor:pointer}
.dest-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.8,.25,1),filter .55s ease;display:block}
.dest-card:hover img{transform:scale(1.09);filter:brightness(.5)}

/* Overlay */
.dest-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.84) 0%,rgba(0,0,0,.12) 55%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.4rem 1.6rem;
  transition:background .4s;
}
[data-theme="light"] .dest-overlay{background:linear-gradient(to top,rgba(16,50,44,.9) 0%,rgba(16,50,44,.28) 60%,transparent 100%)}
.dest-card:hover .dest-overlay{background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.5) 65%,rgba(0,0,0,.12) 100%)}

.dest-tag{
  display:inline-block;padding:.22rem .7rem;
  background:var(--gold);color:#fff;
  border-radius:3px;font-size:.62rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:.55rem;width:fit-content;
  opacity:0;transform:translateY(8px);transition:opacity .35s .05s,transform .35s .05s;
}
.dest-card:hover .dest-tag{opacity:1;transform:translateY(0)}

.dest-name{
  font-family:var(--font-head);font-size:1.45rem;font-weight:700;
  color:#fff;line-height:1.1;text-transform:uppercase;letter-spacing:.06em;
}
/* Bigger name on tall/wide cards */
.dest-mosaic .dest-card:nth-child(1) .dest-name{ font-size:2.1rem; }
.dest-mosaic .dest-card:nth-child(4) .dest-name{ font-size:1.9rem; }

.dest-count{
  font-size:.75rem;color:rgba(255,255,255,.65);
  margin-top:.3rem;letter-spacing:.04em;
  opacity:0;transform:translateY(6px);transition:opacity .35s .1s,transform .35s .1s;
}
.dest-card:hover .dest-count{opacity:1;transform:translateY(0)}

/* Hidden card state for filter animation */
.dest-card.hidden{display:none}

/* Responsive */
@media(max-width:900px){
  .dest-mosaic{
    grid-template-columns:1fr 1fr;
    grid-template-rows:220px 180px 180px 180px;
  }
  .dest-mosaic .dest-card:nth-child(1){grid-area:1/1/2/2}
  .dest-mosaic .dest-card:nth-child(2){grid-area:1/2/2/3}
  .dest-mosaic .dest-card:nth-child(3){grid-area:2/1/3/3}
  .dest-mosaic .dest-card:nth-child(4){grid-area:3/1/4/2}
  .dest-mosaic .dest-card:nth-child(5){grid-area:3/2/4/3}
  .dest-mosaic .dest-card:nth-child(6){grid-area:4/1/5/2}
  .dest-mosaic .dest-card:nth-child(7){grid-area:4/2/5/3}
  .dest-mosaic .dest-card:nth-child(8){display:none}
  .dest-filter-nav{gap:.2rem}
}

/* WHY SRI LANKA */
.why-section{
  background:linear-gradient(rgba(15,15,14,.88),rgba(15,15,14,.88)),
  url('https://images.unsplash.com/photo-1559038331-02f4bae92a3d?q=80&w=1170&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover fixed;
  padding:100px 4%;
}
[data-theme="light"] .why-section{background:linear-gradient(rgba(226,240,236,.94),rgba(226,240,236,.94)),url('https://images.unsplash.com/photo-1566766189268-ecac9118f2b7?q=80&w=1170&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover fixed}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.why-card{background:var(--bg-glass);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:var(--transition)}
.why-card:hover{transform:translateY(-8px);border-color:var(--sunset);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.why-icon{font-size:2.5rem;margin-bottom:1rem}
.why-title{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:.6rem}
.why-desc{font-size:.87rem;color:var(--text-muted);line-height:1.7}

/* PACKAGES â€” Zigzag stagger: cards 1&3 lower, cards 2&4 higher */
.packages-preview{
  background: var(--bg);
  padding: 100px 0 0 !important;
  margin: 0;
  max-width: 100% !important;
  overflow: hidden;
}

/* Section header â€” inherits global section-label/title/subtitle styles */

.pkg-strip-wrapper{
  padding: 0 4% 0;
  background: var(--bg);
}

/* Flex row â€” align-items: flex-start so margin-top offsets are respected */
.pkg-strip{
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 10px;
  max-width: 1280px;
  margin: 0 auto;
  padding-top: 20px;
  padding-bottom: 60px;   /* space below for lower cards */
}

/* All cards: equal width, equal height */
.pkg-strip-card{
  flex: 1 1 0;
  min-width: 0;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  border-radius: 6px;
  height: 400px;
  /* NO transform here â€” use margin-top instead so JS animations don't reset it */
}

/* Cards 1 & 3 â€” pushed DOWN */
.pkg-strip-card:nth-child(1),
.pkg-strip-card:nth-child(3){
  margin-top: 70px;
}

/* Cards 2 & 4 â€” stay at top (margin-top: 0) */
.pkg-strip-card:nth-child(2),
.pkg-strip-card:nth-child(4){
  margin-top: 0;
}

/* Override any reveal/stagger animation transforms that fight with our layout */
.pkg-strip .pkg-strip-card.reveal,
.pkg-strip .pkg-strip-card{
  opacity: 1 !important;
  transform: none !important;
}

/* Image */
.pkg-strip-card img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .7s cubic-bezier(.25,.8,.25,1), filter .5s ease;
  filter: brightness(.70);
}
.pkg-strip-card:hover img{
  transform: scale(1.07) !important;
  filter: brightness(.38);
}

/* Gradient overlay */
.pkg-strip-overlay{
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,45,40,.88) 0%, rgba(15,60,52,.2) 55%, transparent 100%);
  transition: background .45s ease;
}
.pkg-strip-card:hover .pkg-strip-overlay{
  background: rgba(26,122,110,.62);
}

/* Label */
.pkg-strip-label{
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.6rem 1.8rem;
  transition: bottom .4s cubic-bezier(.25,.8,.25,1), transform .4s cubic-bezier(.25,.8,.25,1);
}
.pkg-strip-name{
  font-family: var(--font-head);
  font-size: 1.2rem; font-weight: 700;
  color: #fff; text-transform: uppercase;
  letter-spacing: .12em; line-height: 1.15;
  text-shadow: 0 2px 14px rgba(0,0,0,.5);
}
.pkg-strip-sub{
  font-size: .72rem; color: rgba(255,255,255,.75);
  letter-spacing: .07em; margin-top: .4rem;
  opacity: 0; transform: translateY(8px);
  transition: opacity .35s .08s, transform .35s .08s;
}
.pkg-strip-card:hover .pkg-strip-sub{ opacity: 1; transform: translateY(0); }
.pkg-strip-card:hover .pkg-strip-label{ bottom: 50%; transform: translateY(50%); text-align: center; }
.pkg-strip-card:hover .pkg-strip-name{ font-size: 1.4rem; }

/* CTA */
.pkg-strip-cta{
  text-align: center;
  padding: 2.5rem 4% 80px;
  background: var(--bg);
}

[data-theme="light"] .pkg-strip-card:hover .pkg-strip-overlay{
  background: rgba(26,122,110,.62);
}

/* Responsive */
@media(max-width:900px){
  .pkg-strip{ flex-wrap: wrap; padding-bottom: 20px; }
  .pkg-strip-card{ flex: 1 1 calc(50% - 5px); height: 260px; }
  .pkg-strip-card:nth-child(1),
  .pkg-strip-card:nth-child(3){ margin-top: 0; }
}
@media(max-width:520px){
  .pkg-strip-card{ flex: 1 1 100%; height: 240px; }
}

/* ===== TESTIMONIALS ===== */
.testimonials-section{
  background:linear-gradient(rgba(15,15,14,.9),rgba(15,15,14,.9)),
  url('https://images.unsplash.com/photo-1579989197355-c2c5ff50a3f3?q=80&w=1074&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover fixed;
  padding:100px 4%;
}
[data-theme="light"] .testimonials-section{background:linear-gradient(rgba(232,244,240,.96),rgba(232,244,240,.96)),url('https://images.unsplash.com/photo-1732234009486-e3d318c8d176?q=80&w=1170&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover fixed}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem;margin-top:3rem}
.testi-card{
  background:var(--bg-glass);backdrop-filter:blur(20px);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:2rem;position:relative;transition:var(--transition);
}
.testi-card:hover{transform:translateY(-6px);border-color:var(--sunset);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.testi-quote{font-size:3rem;color:var(--sunset-text);line-height:1;margin-bottom:.5rem;font-family:Georgia,serif;opacity:.7}
.testi-text{font-size:.9rem;color:var(--text);line-height:1.8;font-style:italic;margin-bottom:1.5rem}
.testi-stars{color:var(--gold);font-size:1rem;letter-spacing:.1em;margin-bottom:1rem}
.testi-author{display:flex;align-items:center;gap:.9rem;border-top:1px solid var(--border);padding-top:1rem}
.testi-avatar{width:70px;height:70px;border-radius:50%;object-fit:cover;border:2px solid var(--sunset)}
.testi-name{font-weight:600;font-size:.9rem;color:var(--text)}
.testi-origin{font-size:.75rem;color:var(--text-muted)}
.testi-pkg{font-size:.7rem;color:var(--sunset-text);font-weight:600;margin-top:.15rem}

/* CTA */
.cta-section{
 min-height:500px;background:linear-gradient(rgba(15,15,14,.6),rgba(15,15,14,.75)),url('https://images.unsplash.com/photo-1507296993015-167a20c29988?q=80&w=1633&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover;display:flex;align-items:center;justify-content:center;text-align:center;padding:100px 4%}

.cta-inner{max-width:700px}
.cta-title{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,3.5rem);color:#ffff;font-weight:700;line-height:1.2;margin-bottom:1rem}
.cta-sub{color:rgba(255,255,255,.75);margin-bottom:2.5rem;font-size:1.05rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* =====================================================
   LOCATIONS PAGE
===================================================== */
.page-hero{height:50vh;min-height:400px;background:linear-gradient(rgba(15,15,14,.6),rgba(15,15,14,.9)),url('../images/destinations.jpg') center/cover;display:flex;align-items:flex-end;padding:4rem 4%}
.page-hero-content{max-width:600px}
.page-hero-title{font-family:var(--font-head);font-size:clamp(2.5rem,5vw,4rem);font-weight:700;color:#fff;margin-bottom:.5rem}
.page-hero-sub{color:rgba(255,255,255,.7);font-size:1rem}

.filter-bar{display:flex;gap:.75rem;flex-wrap:wrap;padding:1.5rem 4%;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:72px;z-index:50;backdrop-filter:blur(10px)}
.filter-btn{padding:.45rem 1.2rem;border-radius:50px;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:1.5px solid var(--border);color:var(--text-muted);transition:var(--transition);cursor:pointer}
.filter-btn:hover,.filter-btn.active{background:var(--sunset);color:#fff;border-color:var(--sunset)}

.locations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding:3rem 4%}
.loc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.loc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--sunset)}
.loc-img{height:240px;overflow:hidden;position:relative}
.loc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.loc-card:hover .loc-img img{transform:scale(1.1)}
.loc-badge{position:absolute;top:1rem;left:1rem;padding:.3rem .8rem;background:var(--sunset);color:#fff;border-radius:50px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.loc-body{padding:1.5rem}
.loc-name{font-family:var(--font-head);font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:.5rem}
.loc-desc{font-size:.85rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem}
.loc-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.78rem;color:var(--text-muted);border-top:1px solid var(--border);padding-top:1rem}
.loc-stars{color:var(--gold);font-size:.9rem}

/* ===== SEASONAL CALENDAR ===== */
.seasonal-section{background:var(--bg);padding:80px 4%}
.calendar-wrapper{margin-top:2.5rem;overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}
.calendar-table{width:100%;min-width:900px;border-collapse:collapse}
.calendar-table th{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-weight:600;padding:.9rem .5rem;border-bottom:1px solid var(--border);background:var(--bg-card);text-align:center}
.calendar-table th:first-child{text-align:left;padding-left:1.2rem;width:160px}
.calendar-table td{padding:0;text-align:center;border-bottom:1px solid var(--border);vertical-align:middle}
.calendar-table td:first-child{padding:.9rem 1.2rem;text-align:left;font-size:.82rem;font-weight:600;color:var(--text);background:var(--bg-card);border-right:1px solid var(--border);white-space:nowrap}
.calendar-table td:first-child:hover{color:var(--sunset-text)}
.cal-cell{display:block;width:100%;padding:.8rem .3rem;font-size:.68rem;font-weight:600;transition:opacity .2s;position:relative}
.cal-cell:hover{opacity:.8;filter:brightness(1.1)}
.cal-excellent{background:#0d3530;color:#4dd9b8}
.cal-good{background:#3a3000;color:#d4aa00}
.cal-mixed{background:#3a1510;color:#e8856a}
.cal-avoid{background:#1c1c1c;color:#666}
[data-theme="light"] .cal-excellent{background:#c8f0e8;color:#0f5048}
[data-theme="light"] .cal-good{background:#fff3c4;color:#7a5c00}
[data-theme="light"] .cal-mixed{background:#fde8df;color:#a04020}
[data-theme="light"] .cal-avoid{background:#f0f0f0;color:#888}
.cal-current-marker::after{content:'â—';position:absolute;top:2px;right:4px;font-size:.5rem;color:var(--sunset-text)}
.month-panel{display:none;margin:0;background:var(--bg-glass);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;animation:slideDown .35s ease}
.month-panel.visible{display:block}
@keyframes slideDown{from{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}
.month-panel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.month-panel-item h4{font-family:var(--font-head);color:var(--sunset-text);margin-bottom:.25rem}
.month-panel-item p{font-size:.85rem;color:var(--text-muted)}
.region-tip{display:none;background:var(--bg-glass);backdrop-filter:blur(20px);border:1px solid var(--border);border-left:3px solid var(--sunset);border-radius:var(--radius);padding:1.5rem;margin:.25rem 0;animation:slideDown .3s ease}
.region-tip.visible{display:block}
.region-tip h4{font-family:var(--font-head);color:var(--text);font-size:1.1rem;margin-bottom:.5rem}
.region-tip p{font-size:.85rem;color:var(--text-muted);line-height:1.7}
.cal-legend{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1.5rem;align-items:center}
.cal-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--text-muted)}
.cal-legend-dot{width:14px;height:14px;border-radius:3px}
.leg-excellent{background:#0d3530;border:1px solid #4dd9b8}
.leg-good{background:#3a3000;border:1px solid #d4aa00}
.leg-mixed{background:#3a1510;border:1px solid #e8856a}
.leg-avoid{background:#1c1c1c;border:1px solid #444}
[data-theme="light"] .leg-excellent{background:#c8f0e8}
[data-theme="light"] .leg-good{background:#fff3c4}
[data-theme="light"] .leg-mixed{background:#fde8df}
[data-theme="light"] .leg-avoid{background:#f0f0f0}
.season-tips{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.season-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.8rem}
.season-card h3{font-family:var(--font-head);font-size:1.1rem;font-weight:700;margin-bottom:.75rem}
.season-card.peak h3{color:var(--gold)}
.season-card.shoulder h3{color:var(--ocean-light)}
.season-card.monsoon h3{color:var(--coral)}
.season-card p{font-size:.85rem;color:var(--text-muted);line-height:1.7}

/* =====================================================
   PACKAGES PAGE
===================================================== */
.packages-hero{height:40vh;min-height:320px;background:linear-gradient(rgba(15,15,14,.65),rgba(15,15,14,.9)),url('../images/pacakges.jpg') center/cover;display:flex;align-items:flex-end;padding:4rem 4%}
.pkg-section{padding:80px 4%;background:var(--bg)}
.pkg-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:3rem}
.pkg-full-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition);position:relative;cursor:pointer}
.pkg-full-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.pkg-full-card{border-color:var(--sunset);box-shadow:0 0 0 1px var(--sunset),var(--shadow)}
.pkg-featured-label{position:absolute;top:1.2rem;right:1.2rem;background:var(--sunset);color:#fff;padding:.3rem .9rem;border-radius:50px;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.pkg-img{height:200px;overflow:hidden}
.pkg-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pkg-full-card:hover .pkg-img img{transform:scale(1.06)}
.pkg-body{padding:2rem}
.pkg-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.pkg-full-name{font-family:var(--font-head);font-size:1.4rem;font-weight:700;color:var(--text)}
.pkg-full-price{text-align:right}
.pkg-full-price .price-num{font-family:var(--font-head);font-size:1.8rem;font-weight:700;color:var(--sunset-text)}
.pkg-full-price .price-per{font-size:.75rem;color:var(--text-muted)}
.pkg-highlights{margin:1rem 0;display:flex;flex-wrap:wrap;gap:.5rem}
.pkg-highlight{padding:.3rem .8rem;background:rgba(200,119,58,.1);border:1px solid rgba(200,119,58,.25);border-radius:50px;font-size:.75rem;color:var(--sunset-text)}
.pkg-includes{margin:1rem 0}
.pkg-include-item{display:flex;align-items:center;gap:.5rem;font-size:.83rem;color:var(--text-muted);margin-bottom:.4rem}
.pkg-include-item::before{content:'âœ“';color:var(--sunset-text);font-weight:700}
.trust-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;padding:2.5rem 4%;background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-top:60px}
.trust-badge{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-muted)}
.trust-badge-icon{font-size:1.5rem}
.trust-badge strong{display:block;color:var(--text);font-size:.88rem}

/* ===== TAILOR MADE SECTION ===== */
.tailor-section{background:linear-gradient(rgba(15,15,14,.75),rgba(15,15,14,.85)),url('../images/tailor%20made.jpg') center/cover;padding:100px 4%;text-align:center}
.tailor-content{max-width:700px;margin:0 auto}
.tailor-title{font-family:var(--font-head);font-size:clamp(2rem,5vw,3rem);color:#fff;font-weight:700;margin-bottom:1rem}
.tailor-sub{color:rgba(255,255,255,.8);font-size:1.1rem;margin-bottom:2.5rem;line-height:1.8}

/* =====================================================
   PACKAGE DETAIL PAGE
===================================================== */
.pkg-detail-hero{
  height:55vh;min-height:450px;position:relative;
  display:flex;align-items:flex-end;padding:4rem 4%;overflow:hidden;
}
.pkg-detail-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.pkg-detail-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 60%,transparent 100%);z-index:1}
.pkg-detail-hero-content{position:relative;z-index:2;max-width:750px}
.pkg-detail-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;color:rgba(255,255,255,.7);margin-bottom:1rem;transition:color .3s}
.pkg-detail-back:hover{color:#fff}
.pkg-detail-title{font-family:var(--font-head);font-size:clamp(2rem,5vw,3.5rem);font-weight:700;color:#fff;margin-bottom:.5rem}
.pkg-detail-meta{display:flex;flex-wrap:wrap;gap:1.2rem;font-size:.85rem;color:rgba(255,255,255,.75);margin-top:.75rem}
.pkg-detail-meta span{display:flex;align-items:center;gap:.35rem}

.pkg-detail-body{padding:60px 4%;background:var(--bg)}
.pkg-detail-grid{display:grid;grid-template-columns:1fr 380px;gap:3rem;max-width:1200px;margin:0 auto}

.pkg-detail-main{}
.pkg-section-title{font-family:var(--font-head);font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}

/* Route Map Section */
.route-map-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;margin-bottom:2rem}
.route-map-title{font-family:var(--font-head);font-size:1.2rem;color:var(--text);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}
.route-map-container{position:relative;max-width:500px;margin:0 auto}
.route-map-svg{width:100%;height:auto}
.route-map-svg .land{fill:#1e4d32;stroke:#2a6642;stroke-width:1.5}
[data-theme="light"] .route-map-svg .land{fill:#8FBFB8;stroke:#2A9A8C}
.route-pin{fill:var(--sunset);stroke:#fff;stroke-width:2;transition:r .25s}
.route-pin:hover{r:10}
.route-line{fill:none;stroke:var(--sunset);stroke-width:2;stroke-dasharray:5,5;opacity:.7}
.route-label{font-family:var(--font-body);font-size:10px;fill:var(--text);font-weight:600}
.route-legend{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1.5rem;justify-content:center;font-size:.8rem;color:var(--text-muted)}
.route-legend-item{display:flex;align-items:center;gap:.4rem}
.route-dot{width:10px;height:10px;border-radius:50%;background:var(--sunset)}
.route-line-legend{width:20px;height:2px;background:var(--sunset);opacity:.7}

/* Itinerary */
.itinerary-day{
  display:flex;gap:1.5rem;margin-bottom:1.5rem;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;
  transition:var(--transition);
}
.itinerary-day:hover{border-color:var(--sunset);transform:translateX(4px)}
.day-num{
  width:48px;height:48px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--sunset),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:.9rem;font-weight:700;color:#fff;
}
.day-content h4{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:.4rem}
.day-content p{font-size:.85rem;color:var(--text-muted);line-height:1.7}
.day-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}
.day-tag{padding:.2rem .65rem;background:rgba(200,119,58,.1);border-radius:50px;font-size:.7rem;color:var(--sunset-text);font-weight:600}

/* Timeline */
.timeline-section{margin-bottom:2rem}
.timeline-container{position:relative;padding-left:2rem}
.timeline-container::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--sunset),var(--gold))}
.timeline-item{position:relative;padding-bottom:1.5rem}
.timeline-item::before{content:'';position:absolute;left:-2rem;top:.5rem;width:12px;height:12px;border-radius:50%;background:var(--sunset);border:3px solid var(--bg);transform:translateX(-5px)}
.timeline-item:last-child{padding-bottom:0}
.timeline-time{font-family:var(--font-head);font-size:.85rem;color:var(--sunset-text);font-weight:700;margin-bottom:.25rem}
.timeline-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:.25rem}
.timeline-desc{font-size:.8rem;color:var(--text-muted)}

/* Travel Specialist Section */
.specialist-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem;margin-top:2rem;text-align:center}
.specialist-title{font-family:var(--font-head);font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem}
.specialist-sub{font-size:1rem;color:var(--text-muted);margin-bottom:2rem}
.specialist-card{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}
.specialist-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--sunset),var(--gold));display:flex;align-items:center;justify-content:center;font-size:2.5rem;border:4px solid var(--border)}
.specialist-info{text-align:left}
.specialist-label{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--sunset-text);margin-bottom:.25rem}
.specialist-name{font-size:1.1rem;font-weight:600;color:var(--text)}
.specialist-role{font-size:.85rem;color:var(--text-muted)}
.specialist-contact-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg);border-radius:12px;border:0px solid var(--border)}
.specialist-icon{width:44px;height:44px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.specialist-contact-label{font-size:1.1rem;color:var(--text-muted);letter-spacing:.15em;text-align:center;text-transform:uppercase;letter-spacing:.1em}
.specialist-contact-value{font-size:.8rem;color:var(--sunset-text);text-align:center;font-weight:600;margin-bottom:.5rem}

/* Highlights gallery */
.highlights-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:2rem}
.gallery-thumb{border-radius:10px;overflow:hidden;height:110px;cursor:pointer}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-thumb:hover img{transform:scale(1.08)}

/* Booking sidebar */
.booking-sidebar{position:relative;top:0}
.booking-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:2rem;
  box-shadow:var(--shadow);
}
.booking-form-label{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem;display:block}
.booking-form-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:.8rem 1rem;color:var(--text);font-family:var(--font-body);font-size:.88rem;outline:none;transition:border-color .3s;margin-bottom:1rem}
.booking-form-input:focus{border-color:var(--sunset)}
.booking-submit{width:100%;padding:1rem;background:var(--sunset);color:#fff;border-radius:50px;font-size:1rem;font-weight:700;transition:var(--transition);box-shadow:0 6px 25px rgba(200,119,58,.35)}
.booking-submit:hover{background:var(--sunset-light);transform:translateY(-2px);box-shadow:0 10px 35px rgba(200,119,58,.55)}
.booking-guarantees{margin-top:1.2rem;display:flex;flex-direction:column;gap:.5rem}
.booking-guarantee{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--text-muted)}
.booking-guarantee::before{content:'âœ“';color:var(--sunset-text);font-weight:700}
.booking-success{display:none;text-align:center;padding:1rem}
.booking-success .check{font-size:2.5rem}
.booking-success h4{font-family:var(--font-head);color:var(--sunset-text);margin:.5rem 0 .25rem}
.booking-success p{font-size:.82rem;color:var(--text-muted)}

/* =====================================================
   CONTACT PAGE
===================================================== */
.contact-hero{height:40vh;min-height:320px;background:linear-gradient(rgba(15,15,14,.65),rgba(15,15,14,.9)),url('../images/BEAUTY.jpeg') center/cover;display:flex;align-items:flex-end;padding:4rem 4%}
.contact-section{padding:80px 4%;background:var(--bg)}
.contact-grid{display:block;max-width:1180px;margin:3rem auto 0}
.contact-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem}
.form-parts{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.form-part{min-width:0}
.form-part-title{font-family:var(--font-head);font-size:1.1rem;color:var(--sunset-text);margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1.5rem;position:relative}
.form-group label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}
.form-group input,.form-group select,.form-group textarea{width:100%;background:#2A2520;border:1px solid var(--border);border-radius:10px;padding:.9rem 1.1rem;color:var(--text);font-family:var(--font-body);font-size:.9rem;transition:var(--transition);outline:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--sunset);box-shadow:0 0 0 3px rgba(200,119,58,.12)}
.form-group textarea{height:140px;resize:vertical}
.form-success{display:none;text-align:center;padding:2rem}
.form-success .check{font-size:3rem;margin-bottom:1rem}
.form-success h3{font-family:var(--font-head);color:var(--sunset-text);font-size:1.4rem;margin-bottom:.5rem}
.form-success p{color:var(--text-muted);font-size:.9rem}
/* CONTACT INFO SECTION */
/* =========================
   CONTACT MAIN LAYOUT
========================= */
.contact-info{
    display:grid;
    grid-template-columns:2fr 1fr; /* details wider than map */
    gap:2rem;
    margin-top:3rem;
    align-items:stretch;
}

/* =========================
   OFFICE DETAILS CARD
========================= */
.office-details{
    background:#fff;
    padding:2rem;
    border-radius:18px;
    box-shadow:0 10px 30px rgba(0,0,0,0.08);
}

.office-details h3{
    font-size:1.8rem;
    margin-bottom:1.5rem;
    color:#222;
}

/* =========================
   INFO GRID (Address, Phone, Email, Hours)
========================= */
.office-info-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1rem;
    margin-bottom:2rem;
}

/* INFO BOX */
.info-item{
    display:flex;
    align-items:flex-start;
    gap:0.8rem;
    padding:1rem;
    background:#f7f7f7;
    border-radius:12px;
}

/* ICON */
.info-icon{
    font-size:1.6rem;
    flex-shrink:0;
}

/* TEXT */
.info-label{
    font-weight:700;
    margin-bottom:0.3rem;
    color:#222;
}

.info-value{
    font-size:0.95rem;
    color:#666;
    line-height:1.5;
}

.info-value a{
    color:#666;
    text-decoration:none;
}

.info-value a:hover{
    color:#0077ff;
}

/* =========================
   SOCIAL ICONS ROW
========================= */
.social-row{
    display:flex;
    flex-wrap:wrap;
    gap:1rem;
    justify-content:center;
    margin-top:1rem;
}

.social-btn{
    width:70px;
    height:70px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:#fff;
    box-shadow:0 5px 15px rgba(0,0,0,0.08);
    transition:0.3s ease;
}

.social-btn:hover{
    transform:translateY(-5px);
    box-shadow:0 10px 25px rgba(0,0,0,0.15);
}

/* =========================
   MAP SECTION
========================= */
.map-container{
    border-radius:18px;
    overflow:hidden;
    min-height:500px;
    box-shadow:0 10px 30px rgba(0,0,0,0.08);
}

.map-container iframe{
    width:100%;
    height:100%;
    border:0;
}

/* =========================
   RESPONSIVE DESIGN
========================= */


.custom-select-wrapper,.multiselect-wrapper{position:relative}
.custom-select-trigger,.date-range-input,.visitors-trigger{width:100%;background:#2A2520;border:1px solid var(--border);border-radius:10px;padding:.9rem 1.1rem;color:var(--text);font-size:.9rem;cursor:pointer;display:flex;align-items:center;gap:.6rem;transition:var(--transition);user-select:none}
.custom-select-trigger:hover,.date-range-input:hover,.visitors-trigger:hover{border-color:var(--sunset);box-shadow:0 0 0 3px rgba(200,119,58,.12)}
.custom-select-trigger.open,.date-range-input.open,.visitors-trigger.open{border-color:var(--sunset);box-shadow:0 0 0 3px rgba(200,119,58,.12)}
.select-arrow{margin-left:auto;opacity:.5;font-size:.75rem;transition:transform .25s}
.custom-select-trigger.open .select-arrow,.visitors-trigger.open .select-arrow,.date-range-input.open .select-arrow{transform:rotate(180deg)}
.custom-select-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:500;background:#1C1A17;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.4);display:none;overflow:hidden}
.custom-select-dropdown.open{display:block}
.country-search-wrap{padding:.75rem .75rem .5rem}
.country-search-wrap input{width:100%;background:#0F0F0E;border:1px solid var(--border);border-radius:8px;padding:.6rem .9rem;color:var(--text);font-size:.85rem;outline:none;cursor:text}
.country-search-wrap input:focus{border-color:var(--sunset)}
.country-list{max-height:220px;overflow-y:auto;padding:.25rem 0}
.country-list::-webkit-scrollbar{width:4px}
.country-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.country-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;cursor:pointer;transition:background .15s;font-size:.88rem;line-height:1.4}
.country-item:hover{background:rgba(200,119,58,.12);color:var(--sunset-text)}
.country-flag{display:flex;align-items:center;flex-shrink:0}
.meal-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .15s;font-size:.88rem}
.meal-option:hover{background:rgba(200,119,58,.12)}
.meal-option.selected{background:rgba(200,119,58,.1)}
.meal-check{font-size:1rem;color:var(--text)}
.budget-slider-wrap{padding:.5rem 0 .25rem}
.budget-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}
.budget-slider{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:5px;outline:none;cursor:pointer;background:#2A2520}
.budget-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--sunset);box-shadow:0 2px 10px rgba(200,119,58,.5);cursor:pointer;transition:transform .15s}
.budget-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}
.budget-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--sunset);border:none;cursor:pointer}
.date-icon{font-size:1rem}
.date-picker-popup,.visitors-popup{position:absolute;left:0;right:0;z-index:600;margin-top:6px;background:#1C1A17;border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 50px rgba(0,0,0,.45);display:none;padding:1.25rem}
.date-picker-popup.open,.visitors-popup.open{display:block}
.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.cal-nav-btn{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;width:32px;height:32px;font-size:1.1rem;cursor:pointer;transition:var(--transition)}
.cal-nav-btn:hover{background:var(--sunset);color:#fff;border-color:var(--sunset)}
#cal-month-label{font-family:var(--font-head);font-size:1rem;font-weight:600;color:var(--text)}
.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:.75rem}
.dp-weekday{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-muted);padding:.3rem 0}
.dp-day{text-align:center;padding:.45rem .25rem;border-radius:8px;font-size:.82rem;cursor:pointer;transition:background .15s,color .15s;color:var(--text);user-select:none}
.dp-day:hover:not(.dp-empty):not(.dp-disabled){background:rgba(200,119,58,.2);color:var(--sunset-text)}
.dp-day.dp-from{background:var(--sunset);color:#fff;border-radius:8px 0 0 8px}
.dp-day.dp-to{background:var(--sunset);color:#fff;border-radius:0 8px 8px 0}
.dp-day.dp-from.dp-to{border-radius:8px}
.dp-day.dp-in-range{background:rgba(200,119,58,.15);border-radius:0}
.dp-day.dp-disabled{opacity:.3;cursor:default}
.dp-day.dp-empty{cursor:default}
.dp-today{font-weight:700;color:var(--sunset-text)}
.date-picker-legend{display:flex;gap:1rem;margin-bottom:.75rem}
.dp-leg{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--text-muted)}
.dp-leg::before{content:'';width:12px;height:12px;border-radius:3px;flex-shrink:0}
.dp-leg-from::before,.dp-leg-to::before{background:var(--sunset)}
.dp-leg-range::before{background:rgba(200,119,58,.2)}
.date-picker-actions{display:flex;gap:.75rem;justify-content:flex-end}
.dp-clear-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:.45rem 1rem;font-size:.82rem;cursor:pointer;transition:var(--transition)}
.dp-clear-btn:hover{border-color:var(--text-muted);color:var(--text)}
.dp-done-btn{background:var(--sunset);color:#fff;border:none;border-radius:8px;padding:.45rem 1.2rem;font-size:.82rem;cursor:pointer;font-weight:600;transition:var(--transition)}
.dp-done-btn:hover{background:var(--sunset-light)}
.visitor-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border)}
.visitor-title{font-size:.9rem;font-weight:600;color:var(--text)}
.visitor-sub{font-size:.75rem;color:var(--text-muted);margin-top:.1rem}
.visitor-counter{display:flex;align-items:center;gap:.75rem}
.vctr-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:#2A2520;color:var(--text);font-size:1.1rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.vctr-btn:hover{background:var(--sunset);border-color:var(--sunset);color:#fff}
.vctr-val{width:24px;text-align:center;font-size:.95rem;font-weight:600;color:var(--text)}
.visitor-total-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;margin-top:.25rem;border-top:2px solid var(--border);font-weight:600;font-size:.9rem;color:var(--text-muted)}
.visitor-total-num{font-size:1.2rem;font-weight:700;color:var(--sunset-text)}

/* ===== CUSTOM SELECT / COUNTRY DROPDOWN ===== */
.custom-select-wrapper,.multiselect-wrapper{position:relative}
.custom-select-trigger,.date-range-input,.visitors-trigger{
  width:100%;background:var(--bg);border:1px solid var(--border);border-radius:10px;
  padding:.9rem 1.1rem;color:var(--text);font-size:.9rem;
  display:flex;align-items:center;gap:.6rem;transition:var(--transition);user-select:none
}
.custom-select-trigger:hover,.date-range-input:hover,.visitors-trigger:hover{border-color:var(--sunset);box-shadow:0 0 0 3px rgba(200,119,58,.12)}
.custom-select-trigger.open,.date-range-input.open,.visitors-trigger.open{border-color:var(--sunset);box-shadow:0 0 0 3px rgba(200,119,58,.12)}
.select-arrow{margin-left:auto;opacity:.5;font-size:.75rem;transition:transform .25s}
.custom-select-trigger.open .select-arrow,.visitors-trigger.open .select-arrow,.date-range-input.open .select-arrow{transform:rotate(180deg)}
.custom-select-dropdown{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:500;
  background:var(--bg-card);border:1px solid var(--border);border-radius:12px;
  box-shadow:0 12px 40px rgba(0,0,0,.4);display:none;overflow:hidden
}
.custom-select-dropdown.open{display:block}
.country-search-wrap{padding:.75rem .75rem .5rem}
.country-search-wrap input{width:100%;background:#0F0F0E;border:1px solid var(--border);border-radius:8px;padding:.6rem .9rem;color:var(--text);font-size:.85rem;outline:none;cursor:pointer}
.country-search-wrap input:focus{border-color:var(--sunset)}
.country-list{max-height:220px;overflow-y:auto;padding:.25rem 0}
.country-list::-webkit-scrollbar{width:4px}
.country-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.country-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;transition:background .15s;font-size:.88rem}
.country-item:hover{background:rgba(200,119,58,.12);color:var(--sunset-text)}
.country-flag{display:flex;align-items:center;flex-shrink:0}
.meal-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:background .15s;font-size:.88rem}
.meal-option:hover{background:rgba(200,119,58,.12)}
.meal-check{font-size:1rem}
.meal-option.selected{background:rgba(200,119,58,.1)}
.budget-slider-wrap{padding:.5rem 0 .25rem}
.budget-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}
.budget-slider{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:5px;outline:none;background:#2A2520}
.budget-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--sunset);box-shadow:0 2px 10px rgba(200,119,58,.5);transition:transform .15s}
.budget-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}
.budget-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--sunset);border:none;cursor:pointer}
.date-range-input{cursor:pointer}
.date-icon{font-size:1rem}
.date-picker-popup,.visitors-popup{
  position:absolute;left:0;right:0;z-index:600;margin-top:6px;
  background:var(--bg-card);border:1px solid var(--border);border-radius:14px;
  box-shadow:0 16px 50px rgba(0,0,0,.45);display:none;padding:1.25rem
}
.date-picker-popup.open,.visitors-popup.open{display:block}
.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.cal-nav-btn{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;width:32px;height:32px;font-size:1.1rem;transition:var(--transition)}
.cal-nav-btn:hover{background:var(--sunset);color:#fff;border-color:var(--sunset)}
#cal-month-label{font-family:var(--font-head);font-size:1rem;font-weight:600;color:var(--text)}
.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:.75rem}
.dp-weekday{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-muted);padding:.3rem 0}
.dp-day{text-align:center;padding:.45rem .25rem;border-radius:8px;font-size:.82rem;transition:background .15s,color .15s;color:var(--text);user-select:none}
.dp-day:hover:not(.dp-empty):not(.dp-disabled){background:rgba(200,119,58,.2);color:var(--sunset-text)}
.dp-day.dp-from{background:var(--sunset);color:#fff;border-radius:8px 0 0 8px}
.dp-day.dp-to{background:var(--sunset);color:#fff;border-radius:0 8px 8px 0}
.dp-day.dp-from.dp-to{border-radius:8px}
.dp-day.dp-in-range{background:rgba(200,119,58,.15);border-radius:0}
.dp-day.dp-disabled{opacity:.3;cursor:default}
.dp-day.dp-empty{cursor:default}
.dp-today{font-weight:700;color:var(--sunset-text)}
.date-picker-legend{display:flex;gap:1rem;margin-bottom:.75rem}
.dp-leg{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--text-muted)}
.dp-leg::before{content:'';width:12px;height:12px;border-radius:3px;flex-shrink:0}
.dp-leg-from::before,.dp-leg-to::before{background:var(--sunset)}
.dp-leg-range::before{background:rgba(200,119,58,.2)}
.date-picker-actions{display:flex;gap:.75rem;justify-content:flex-end}
.dp-clear-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:.45rem 1rem;font-size:.82rem;transition:var(--transition)}
.dp-clear-btn:hover{border-color:var(--text-muted);color:var(--text)}
.dp-done-btn{background:var(--sunset);color:#fff;border:none;border-radius:8px;padding:.45rem 1.2rem;font-size:.82rem;font-weight:600;transition:var(--transition)}
.dp-done-btn:hover{background:var(--sunset-light)}
.visitor-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border)}
.visitor-row:last-of-type{border-bottom:none}
.visitor-title{font-size:.9rem;font-weight:600;color:var(--text)}
.visitor-sub{font-size:.75rem;color:var(--text-muted);margin-top:.1rem}
.visitor-counter{display:flex;align-items:center;gap:.75rem}
.vctr-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:#2A2520;color:var(--text);font-size:1.1rem;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.vctr-btn:hover{background:var(--sunset);border-color:var(--sunset);color:#fff}
.vctr-val{width:24px;text-align:center;font-size:.95rem;font-weight:600;color:var(--text)}
.visitor-total-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;margin-top:.25rem;border-top:2px solid var(--border);font-weight:600;font-size:.9rem;color:var(--text-muted)}
.visitor-total-num{font-size:1.2rem;font-weight:700;color:var(--sunset-text)}

/* ===== FOOTER ===== */
footer{background:var(--bg-card);padding:60px 4% 30px;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand p{font-size:.85rem;color:var(--text-muted);line-height:1.8;margin-top:.75rem;max-width:280px}
.footer-col h4{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:1.2rem}
.footer-col a{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:.6rem;transition:color .3s;cursor:pointer}
.footer-col a:hover{color:var(--sunset-text)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:var(--text-muted)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .dest-mosaic,.why-grid,.pkg-cards-grid{grid-template-columns:repeat(2,1fr)}
  .locations-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-detail-grid{grid-template-columns:1fr}
  .booking-sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .form-parts,.contact-info{grid-template-columns:1fr}
  .map-container{min-height:340px}
}
@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:flex;flex-direction:column}
  .mobile-overlay{display:block}
  .dest-mosaic,.why-grid,.pkg-grid,.pkg-cards-grid,.season-tips,.month-panel-grid,.testimonials-grid{grid-template-columns:1fr}
  .locations-grid{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .contact-form,.office-details{padding:1.5rem}
  .office-info-grid{grid-template-columns:1fr}
  .pkg-strip{grid-template-columns:1fr}
  .pkg-strip-card{height:260px}
  .included-grid{grid-template-columns:1fr}
  .highlights-gallery{grid-template-columns:repeat(2,1fr)}
  .specialist-contact{grid-template-columns:1fr}
  .pkg-detail-grid{grid-template-columns:1fr}
  #theme-toggle{top:1rem;right:1rem;width:40px;height:40px;font-size:1rem}
}
@media(max-width:480px){
  .hero-title{font-size:3rem}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  #whatsapp-btn{bottom:1rem;right:1rem}
}
/* ===== SKIP LINK (accessibility) ===== */
.skip-link{
  position:fixed;top:-100px;left:1rem;z-index:99999;
  background:var(--jungle);color:#fff;
  padding:.6rem 1.2rem;border-radius:8px;
  font-size:.85rem;font-weight:600;
  transition:top .2s ease;
}
.skip-link:focus{top:1rem}
