/*
Theme Name:  Explore Kerala
Theme URI:   https://explorekeralatours.in
Author:      Explore Kerala
Author URI:  https://explorekeralatours.in
Description: Premium Kerala Tourism WordPress theme. God's Own Country — backwaters, hills, beaches and Ayurveda.
Version:     1.0.0
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: explore-kerala
Tags:        travel, tourism, kerala, one-page, responsive
*/

/* ── RESET & ROOT ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',sans-serif;background:#FAFDF8;color:#1A2A1A;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:'DM Sans',sans-serif;cursor:pointer;border:none;background:none}

/* ── CSS VARIABLES ── */
:root{
  --forest:#1A3A1A;
  --forest2:#244224;
  --leaf:#2E7D32;
  --leaf-light:#4CAF50;
  --sage:#7BAE7F;
  --mint:#E8F5E9;
  --cream:#FAFDF8;
  --cream2:#F0F7EE;
  --white:#ffffff;
  --gold:#B8860B;
  --gold-light:#D4A017;
  --water:#0D7377;
  --water-light:#14A3A8;
  --text-muted:#5A7A5A;
  --radius:1rem;
  --radius-sm:0.5rem;
  --radius-lg:2rem;
  --shadow:0 4px 32px rgba(26,58,26,0.10);
  --shadow-lg:0 12px 60px rgba(26,58,26,0.16);
  --transition:0.35s cubic-bezier(0.4,0,0.2,1);
}

/* ── UTILITIES ── */
.container{max-width:1220px;margin:0 auto;padding:0 1.5rem}
.serif{font-family:'Cormorant Garamond',serif}
.gold{color:var(--gold)}
.leaf{color:var(--leaf)}

/* ── FADE-UP ANIMATION ── */
.fu{opacity:0;transform:translateY(28px);transition:opacity 0.75s ease,transform 0.75s ease}
.fu.on{opacity:1;transform:translateY(0)}
.fu.d1{transition-delay:0.1s}
.fu.d2{transition-delay:0.2s}
.fu.d3{transition-delay:0.3s}
.fu.d4{transition-delay:0.4s}
.fu.d5{transition-delay:0.5s}

/* ════════ HEADER ════════ */
#header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(46,125,50,0.12);
  transition:box-shadow var(--transition),background var(--transition);
}
#header.scrolled{box-shadow:0 2px 32px rgba(26,58,26,0.12);background:rgba(255,255,255,0.98)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:76px;padding:0 2rem;max-width:1300px;margin:0 auto}
.logo{display:flex;align-items:center;gap:0.75rem}
.logo-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--leaf),var(--water));display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;box-shadow:0 2px 12px rgba(46,125,50,0.3)}
.logo-text{display:flex;flex-direction:column;line-height:1.15}
.logo-name{font-family:'Cormorant Garamond',serif;font-size:1.35rem;font-weight:600;color:var(--forest);letter-spacing:0.02em}
.logo-tag{font-size:0.58rem;color:var(--leaf);letter-spacing:0.2em;text-transform:uppercase;font-weight:500}
.desktop-nav{display:none;align-items:center;gap:0.5rem}
.desktop-nav a{font-size:0.85rem;font-weight:500;color:var(--forest);padding:0.5rem 0.9rem;border-radius:2rem;letter-spacing:0.02em;transition:color var(--transition),background var(--transition)}
.desktop-nav a:hover{color:var(--leaf);background:var(--mint)}
.nav-item{position:relative}
.btn-hdr-book{display:none;background:var(--forest);color:var(--white);font-weight:600;font-size:0.82rem;padding:0.65rem 1.4rem;border-radius:3rem;letter-spacing:0.04em;transition:background var(--transition),transform var(--transition),box-shadow var(--transition);white-space:nowrap;margin-left:0.5rem}
.btn-hdr-book:hover{background:var(--leaf);transform:translateY(-1px);box-shadow:0 4px 20px rgba(46,125,50,0.35)}
.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;cursor:pointer}
.hamburger span{display:block;height:2px;width:100%;background:var(--forest);border-radius:2px;transition:all 0.3s ease}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-drawer{position:fixed;top:0;right:-100%;width:min(340px,100vw);height:100vh;background:var(--white);z-index:999;padding:100px 2rem 2rem;border-left:1px solid var(--mint);transition:right 0.35s cubic-bezier(0.4,0,0.2,1);box-shadow:-8px 0 40px rgba(26,58,26,0.15);overflow-y:auto}
.mobile-drawer.open{right:0}
.drawer-header{position:absolute;top:0;left:0;right:0;height:80px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;border-bottom:1px solid var(--mint)}
.drawer-close{width:36px;height:36px;border-radius:50%;background:var(--mint);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--forest);cursor:pointer}
.drawer-close:hover{background:var(--leaf);color:white}
.drawer-nav{display:flex;flex-direction:column;gap:0.25rem}
.drawer-nav-item{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 0;border-bottom:1px solid rgba(46,125,50,0.08);font-size:1rem;font-weight:500;color:var(--forest)}
.drawer-nav-item:hover{color:var(--leaf)}
.drawer-cta{display:block;margin-top:1.5rem;padding:1rem;background:var(--forest);color:white;text-align:center;border-radius:var(--radius);font-weight:600;font-size:0.95rem;letter-spacing:0.04em}
.overlay{position:fixed;inset:0;background:rgba(26,58,26,0.4);z-index:998;opacity:0;visibility:hidden;transition:all var(--transition);backdrop-filter:blur(3px)}
.overlay.open{opacity:1;visibility:visible}
/* Mega dropdown */
.has-mega{position:relative}
.mega-dropdown{position:absolute;top:calc(100% + 12px);left:-120px;background:white;border:1px solid rgba(46,125,50,0.12);border-radius:var(--radius);min-width:620px;padding:1.5rem;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition);box-shadow:var(--shadow-lg);display:grid;grid-template-columns:repeat(3,1fr);gap:0.4rem;z-index:100}
.has-mega:hover .mega-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.mega-item{display:block;padding:0.55rem 0.75rem;border-radius:var(--radius-sm);font-size:0.82rem;color:var(--forest);transition:all var(--transition)}
.mega-item:hover{background:var(--mint);color:var(--leaf)}

@media(min-width:960px){.desktop-nav{display:flex!important}.btn-hdr-book{display:inline-block!important}.hamburger{display:none!important}}

/* ════════ HERO ════════ */
#hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-top:76px;padding-bottom:5rem;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.5s ease;background-size:cover;background-position:center}
.hero-slide.active{opacity:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.18) 0%,rgba(0,20,0,0.2) 40%,rgba(0,30,10,0.75) 100%);z-index:1}
.hero-content{position:relative;z-index:2;text-align:center;padding:2rem 1.25rem;max-width:900px;width:100%}
.hero-eyebrow{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.75rem;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.75);font-weight:500;margin-bottom:1.25rem}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:32px;height:1px;background:rgba(255,255,255,0.4)}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,8vw,6.5rem);font-weight:300;line-height:1.05;color:#ffffff;letter-spacing:-0.01em;margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:#A8D8A8}
.hero-sub{font-size:clamp(1rem,2.5vw,1.2rem);color:rgba(255,255,255,0.82);max-width:580px;margin:0 auto 2.5rem;line-height:1.65;font-weight:300}
.hero-btns{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem;margin-bottom:3.5rem}
.btn-primary{background:var(--leaf);color:white;font-weight:600;font-size:0.9rem;padding:1rem 2.2rem;border-radius:3rem;letter-spacing:0.04em;transition:all var(--transition);box-shadow:0 4px 24px rgba(46,125,50,0.4);display:inline-block}
.btn-primary:hover{background:var(--forest);transform:translateY(-2px);box-shadow:0 8px 32px rgba(46,125,50,0.45)}
.btn-outline-white{background:transparent;color:white;font-weight:500;font-size:0.9rem;padding:1rem 2.2rem;border-radius:3rem;letter-spacing:0.04em;border:1.5px solid rgba(255,255,255,0.5);transition:all var(--transition);display:inline-block}
.btn-outline-white:hover{background:rgba(255,255,255,0.12);border-color:white}
.hero-stats{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:2rem}
.hero-stat{text-align:center}
.hero-stat-num{display:block;font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:600;color:#A8D8A8;line-height:1}
.hero-stat-label{display:block;font-size:0.72rem;color:rgba(255,255,255,0.65);letter-spacing:0.1em;text-transform:uppercase;margin-top:0.3rem}
.hero-stat-div{width:1px;height:40px;background:rgba(255,255,255,0.2)}
.hero-dots{display:flex;gap:0.4rem;justify-content:center;position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:3}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.35);cursor:pointer;transition:all var(--transition)}
.hero-dot.active{background:#A8D8A8;width:24px;border-radius:3px}
.scroll-hint{position:absolute;bottom:2rem;right:2rem;z-index:3;display:flex;flex-direction:column;align-items:center;gap:0.4rem;opacity:0.6}
.scroll-hint span{font-size:0.65rem;letter-spacing:0.15em;color:white;text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,0.6),transparent);animation:scrollLine 1.5s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(0.5);opacity:0.4}50%{transform:scaleY(1);opacity:1}}

/* ════════ TICKER ════════ */
#ticker{background:var(--forest);padding:0.85rem 0;overflow:hidden;border-bottom:1px solid rgba(255,255,255,0.05)}
.ticker-track{display:flex;gap:0;white-space:nowrap;animation:ticker 35s linear infinite}
.ticker-item{display:inline-flex;align-items:center;gap:1rem;font-size:0.75rem;color:rgba(255,255,255,0.7);letter-spacing:0.12em;text-transform:uppercase;padding:0 2rem}
.ticker-dot{width:4px;height:4px;border-radius:50%;background:var(--sage)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ════════ SECTIONS ════════ */
section{padding:5.5rem 0}
.section-label{display:inline-block;font-size:0.72rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--leaf);margin-bottom:0.85rem}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:400;line-height:1.12;color:var(--forest);letter-spacing:-0.01em}
.section-sub{font-size:1.05rem;color:var(--text-muted);line-height:1.7;font-weight:300;max-width:560px;margin-top:0.75rem}
.section-head{margin-bottom:3.5rem}

/* ════════ POSTER RAIL ════════ */
#destinations-rail{background:var(--cream2);padding:5rem 0;overflow:hidden}
.poster-head{text-align:center;margin-bottom:3rem}
.poster-head .section-sub{margin:0.75rem auto 0;text-align:center}
.poster-rail-wrap{overflow:hidden;position:relative}
.poster-rail-wrap::before,.poster-rail-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.poster-rail-wrap::before{left:0;background:linear-gradient(to right,var(--cream2),transparent)}
.poster-rail-wrap::after{right:0;background:linear-gradient(to left,var(--cream2),transparent)}
.poster-rail{display:flex;gap:1.25rem;padding:1rem 2rem 2rem;cursor:grab;user-select:none;animation:rail-scroll 40s linear infinite}
.poster-rail:hover{animation-play-state:paused}
.poster-rail.dragging{animation-play-state:paused;cursor:grabbing}
@keyframes rail-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.poster-card{flex-shrink:0;width:220px;height:300px;border-radius:var(--radius);position:relative;overflow:hidden;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition);box-shadow:var(--shadow)}
.poster-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-lg)}
.poster-card--drop{margin-top:40px}
.poster-card img{transition:transform 0.6s ease;width:100%;height:100%;object-fit:cover}
.poster-card:hover img{transform:scale(1.08)}
.poster-card-shade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,20,0,0.82) 100%)}
.poster-card-num{position:absolute;top:1rem;left:1rem;font-size:0.65rem;letter-spacing:0.15em;color:rgba(255,255,255,0.6);font-weight:500}
.poster-card-body{position:absolute;bottom:0;left:0;right:0;padding:1.25rem}
.poster-card-tag{display:block;font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;color:#A8D8A8;margin-bottom:0.3rem}
.poster-card-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:white;line-height:1.1}

/* ════════ PLACES GRID ════════ */
#kerala-places{background:var(--white)}
.places-head{margin-bottom:3.5rem}
.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.75rem}
.place-card{border-radius:var(--radius);overflow:hidden;background:var(--white);box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition);cursor:pointer}
.place-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.place-card-img{height:240px;position:relative;overflow:hidden}
.place-card-img img{transition:transform 0.6s ease;width:100%;height:100%;object-fit:cover}
.place-card:hover .place-card-img img{transform:scale(1.07)}
.place-card-badge{position:absolute;top:1rem;left:1rem;background:rgba(255,255,255,0.92);color:var(--forest);font-size:0.68rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:0.3rem 0.8rem;border-radius:2rem}
.place-card-body{padding:1.5rem}
.place-card-flag{font-size:1.5rem;margin-bottom:0.5rem;display:block}
.place-card-name{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--forest);margin-bottom:0.4rem}
.place-card-tagline{font-size:0.8rem;color:var(--leaf);font-weight:500;letter-spacing:0.06em;margin-bottom:0.75rem}
.place-card-desc{font-size:0.9rem;color:var(--text-muted);line-height:1.6;font-weight:300}
.place-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--mint)}
.place-card-meta{font-size:0.75rem;color:var(--text-muted)}
.place-card-arrow{width:36px;height:36px;border-radius:50%;background:var(--mint);color:var(--leaf);display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all var(--transition)}
.place-card:hover .place-card-arrow{background:var(--leaf);color:white}

/* ════════ PACKAGES ════════ */
#packages{background:var(--cream2)}
.pkg-head{text-align:center;margin-bottom:3.5rem}
.pkg-head .section-sub{margin:0.75rem auto 0}
.pkg-grid{display:grid;gap:1.75rem;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}
.pkg-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition);display:flex;flex-direction:column}
.pkg-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.pkg-img{height:220px;position:relative;overflow:hidden}
.pkg-img img{transition:transform 0.65s ease;width:100%;height:100%;object-fit:cover}
.pkg-card:hover .pkg-img img{transform:scale(1.06)}
.pkg-badge{position:absolute;top:1rem;right:1rem;background:var(--forest);color:white;font-size:0.68rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;padding:0.3rem 0.85rem;border-radius:2rem}
.pkg-badge.gold-badge{background:var(--gold)}
.pkg-body{padding:1.6rem;flex:1;display:flex;flex-direction:column}
.pkg-meta{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:0.75rem}
.pkg-meta span{font-size:0.75rem;color:var(--text-muted);background:var(--mint);padding:0.2rem 0.65rem;border-radius:2rem}
.pkg-title{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:600;color:var(--forest);margin-bottom:0.5rem;line-height:1.2}
.pkg-desc{font-size:0.88rem;color:var(--text-muted);line-height:1.6;margin-bottom:1rem;flex:1}
.pkg-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-bottom:1.25rem}
.pkg-tag{font-size:0.72rem;color:var(--leaf);background:var(--mint);padding:0.25rem 0.7rem;border-radius:2rem;font-weight:500}
.pkg-footer{display:flex;align-items:flex-end;justify-content:space-between;margin-top:auto}
.pkg-price-label{font-size:0.7rem;color:var(--text-muted);letter-spacing:0.06em;text-transform:uppercase;display:block}
.pkg-price-val{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:600;color:var(--forest)}
.pkg-price-val span{font-size:0.85rem;font-family:'DM Sans',sans-serif;color:var(--text-muted)}
.pkg-price-orig{font-size:0.8rem;color:var(--text-muted);text-decoration:line-through}
.pkg-btn{background:var(--leaf);color:white;font-size:0.82rem;font-weight:600;padding:0.75rem 1.4rem;border-radius:2rem;letter-spacing:0.04em;transition:all var(--transition);white-space:nowrap;box-shadow:0 2px 12px rgba(46,125,50,0.3);display:inline-block}
.pkg-btn:hover{background:var(--forest);box-shadow:0 4px 20px rgba(46,125,50,0.4)}

/* ════════ COUNTERS ════════ */
#counters{background:var(--forest);padding:5rem 0;position:relative;overflow:hidden}
#counters::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1602216056096-3b40cc0c9944?w=1600&auto=format&fit=crop&q=30') center/cover;opacity:0.12}
.counters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;position:relative}
.counter-item{text-align:center}
.counter-num{display:block;font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:300;color:#A8D8A8;line-height:1}
.counter-label{display:block;font-size:0.75rem;color:rgba(255,255,255,0.65);letter-spacing:0.14em;text-transform:uppercase;margin-top:0.5rem}

/* ════════ WHY US ════════ */
#whyus{background:var(--white)}
.whyus-inner{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:900px){.whyus-inner{grid-template-columns:1fr 1fr;gap:5rem}}
.whyus-img-wrap{border-radius:var(--radius-lg);overflow:hidden;height:480px;position:relative}
.whyus-img-wrap img{width:100%;height:100%;object-fit:cover}
.whyus-img-badge{position:absolute;bottom:2rem;left:2rem;background:white;border-radius:var(--radius);padding:1rem 1.5rem;box-shadow:var(--shadow-lg)}
.whyus-img-badge-num{font-family:'Cormorant Garamond',serif;font-size:2.5rem;font-weight:600;color:var(--leaf);line-height:1}
.whyus-img-badge-label{font-size:0.75rem;color:var(--text-muted)}
.features-list{display:flex;flex-direction:column;gap:1.5rem;margin-top:2rem}
.feature-item{display:flex;gap:1.25rem;align-items:flex-start}
.feature-icon-wrap{width:48px;height:48px;border-radius:var(--radius-sm);flex-shrink:0;background:var(--mint);display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.feature-title{font-size:1rem;font-weight:600;color:var(--forest);margin-bottom:0.25rem}
.feature-desc{font-size:0.88rem;color:var(--text-muted);line-height:1.6;font-weight:300}

/* ════════ HOW IT WORKS ════════ */
#howitworks{background:var(--cream2)}
.hiw-head{text-align:center;margin-bottom:4rem}
.steps-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.step-item{background:white;padding:2.25rem 2rem;border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform var(--transition),box-shadow var(--transition)}
.step-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.step-num{font-family:'Cormorant Garamond',serif;font-size:5rem;font-weight:300;color:var(--mint);line-height:1;position:absolute;top:0.75rem;right:1rem}
.step-icon{font-size:2rem;margin-bottom:1rem}
.step-title{font-size:1.1rem;font-weight:600;color:var(--forest);margin-bottom:0.6rem}
.step-desc{font-size:0.88rem;color:var(--text-muted);line-height:1.65;font-weight:300}

/* ════════ TESTIMONIALS ════════ */
#testimonials{background:var(--white)}
.testi-head{text-align:center;margin-bottom:3.5rem}
.testi-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.testi-card{background:var(--cream2);border-radius:var(--radius);padding:2rem;border:1px solid rgba(46,125,50,0.08);transition:transform var(--transition),box-shadow var(--transition)}
.testi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.testi-stars{color:var(--gold);font-size:0.85rem;letter-spacing:0.1em;margin-bottom:1rem}
.testi-quote{font-family:'Cormorant Garamond',serif;font-size:1.05rem;line-height:1.7;color:var(--forest);font-weight:300;margin-bottom:1.5rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:0.85rem}
.testi-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--leaf),var(--water));display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:700;color:white;flex-shrink:0}
.testi-name{font-size:0.9rem;font-weight:600;color:var(--forest)}
.testi-trip{font-size:0.75rem;color:var(--text-muted);margin-top:0.1rem}

/* ════════ GALLERY ════════ */
#gallery{background:var(--cream2);padding:5rem 0}
.gallery-head{text-align:center;margin-bottom:3rem}
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:240px 240px;gap:1rem}
.gal-item{border-radius:var(--radius);overflow:hidden;position:relative}
.gal-item:nth-child(1){grid-column:1/6;grid-row:1/2}
.gal-item:nth-child(2){grid-column:6/9;grid-row:1/2}
.gal-item:nth-child(3){grid-column:9/13;grid-row:1/3}
.gal-item:nth-child(4){grid-column:1/4;grid-row:2/3}
.gal-item:nth-child(5){grid-column:4/9;grid-row:2/3}
.gal-overlay{position:absolute;inset:0;background:rgba(26,58,26,0);display:flex;align-items:center;justify-content:center;transition:background var(--transition)}
.gal-item:hover .gal-overlay{background:rgba(26,58,26,0.35)}
.gal-icon{font-size:2rem;color:white;opacity:0;transition:all var(--transition);transform:scale(0.8)}
.gal-item:hover .gal-icon{opacity:1;transform:scale(1)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.gal-item:hover img{transform:scale(1.05)}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}.gal-item{grid-column:auto!important;grid-row:auto!important;height:180px}}

/* ════════ BOOKING ════════ */
#booking{background:var(--white)}
.booking-inner{display:grid;grid-template-columns:1fr;gap:3.5rem;align-items:flex-start}
@media(min-width:900px){.booking-inner{grid-template-columns:1fr 1.3fr;gap:5rem}}
.contact-cards{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.contact-card{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.3rem;border-radius:var(--radius-sm);background:var(--mint);border:1px solid rgba(46,125,50,0.15)}
.contact-card-icon{font-size:1.5rem}
.contact-card-label{font-size:0.7rem;color:var(--leaf);letter-spacing:0.1em;text-transform:uppercase;font-weight:600}
.contact-card-val{font-size:0.95rem;color:var(--forest);font-weight:500}
.form-card{background:var(--cream2);padding:2.5rem;border-radius:var(--radius-lg);border:1px solid rgba(46,125,50,0.1);box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-bottom:1.25rem}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:0.4rem}
.form-group.full{grid-column:1/-1}
.form-group label{font-size:0.78rem;font-weight:600;color:var(--forest);letter-spacing:0.05em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{padding:0.8rem 1rem;border:1.5px solid rgba(46,125,50,0.2);border-radius:var(--radius-sm);font-size:0.9rem;font-family:'DM Sans',sans-serif;color:var(--forest);background:white;transition:border-color var(--transition),box-shadow var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--leaf);box-shadow:0 0 0 3px rgba(46,125,50,0.12)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;padding:1.1rem;border-radius:var(--radius);background:var(--forest);color:white;font-size:0.95rem;font-weight:600;letter-spacing:0.06em;transition:all var(--transition);box-shadow:0 4px 20px rgba(26,58,26,0.3);cursor:pointer;border:none;font-family:'DM Sans',sans-serif}
.form-submit:hover{background:var(--leaf);box-shadow:0 6px 28px rgba(46,125,50,0.4);transform:translateY(-1px)}
.form-success{display:none;text-align:center;padding:3rem}
.form-success.show{display:block}
.success-check{font-size:3rem;margin-bottom:1rem}
.form-success h3{font-family:'Cormorant Garamond',serif;font-size:2rem;color:var(--forest);margin-bottom:0.5rem}
.form-success p{color:var(--text-muted)}

/* ════════ CTA BAND ════════ */
#ctaband{background:var(--forest);padding:5rem 0;text-align:center;position:relative;overflow:hidden}
#ctaband::before{content:'';position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1508009603885-50cf7c579365?w=1600&auto=format&fit=crop&q=30') center/cover;opacity:0.08}
.ctaband-inner{position:relative}
#ctaband .section-label{color:#A8D8A8}
#ctaband .section-title{color:white;margin:0.75rem auto 1.25rem}
#ctaband .section-sub{color:rgba(255,255,255,0.7);margin:0 auto 2.5rem}
.cta-btns{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.btn-ghost{background:transparent;color:white;font-weight:500;font-size:0.9rem;padding:1rem 2rem;border-radius:3rem;border:1.5px solid rgba(255,255,255,0.35);transition:all var(--transition);display:inline-block}
.btn-ghost:hover{background:rgba(255,255,255,0.1);border-color:white}
.btn-wa{background:#25D366;color:white;font-weight:600;font-size:0.9rem;padding:1rem 2rem;border-radius:3rem;transition:all var(--transition);display:inline-flex;align-items:center;gap:0.5rem}
.btn-wa:hover{background:#1da851;transform:translateY(-2px)}

/* ════════ FOOTER ════════ */
#footer{background:#0F1F0F;padding:4rem 0 0}
.footer-grid{display:grid;gap:2.5rem;grid-template-columns:1.5fr 1fr 1fr 1fr}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .logo-name{color:white}
.footer-brand .logo-tag{color:var(--sage)}
.footer-brand-desc{font-size:0.85rem;color:rgba(255,255,255,0.5);line-height:1.65;margin-top:1rem;max-width:260px}
.footer-social{display:flex;gap:0.75rem;margin-top:1.25rem}
.social-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.6);display:flex;align-items:center;justify-content:center;font-size:0.75rem;transition:all var(--transition)}
.social-btn:hover{background:var(--leaf);color:white}
.footer-col h4{font-size:0.72rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:1.25rem}
.footer-col ul{display:flex;flex-direction:column;gap:0.6rem}
.footer-col ul li a{font-size:0.88rem;color:rgba(255,255,255,0.6);transition:color var(--transition)}
.footer-col ul li a:hover{color:#A8D8A8}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:1.5rem 0;margin-top:3.5rem;border-top:1px solid rgba(255,255,255,0.07)}
.footer-copy{font-size:0.8rem;color:rgba(255,255,255,0.35)}
.footer-legal{display:flex;gap:1.25rem}
.footer-legal a{font-size:0.78rem;color:rgba(255,255,255,0.4);transition:color var(--transition)}
.footer-legal a:hover{color:rgba(255,255,255,0.7)}

/* ════════ FLOATING BUTTONS ════════ */
#float-actions{position:fixed;bottom:2rem;right:1.5rem;z-index:990;display:flex;flex-direction:column;gap:0.75rem}
.float-btn{display:flex;align-items:center;gap:0.6rem;padding:0.75rem 1.2rem;border-radius:3rem;font-size:0.82rem;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 20px rgba(0,0,0,0.2);white-space:nowrap;text-decoration:none}
.float-wa{background:#25D366;color:white}
.float-wa:hover{background:#1da851;transform:translateY(-2px) scale(1.03)}
.float-call{background:var(--forest);color:white}
.float-call:hover{background:var(--leaf);transform:translateY(-2px) scale(1.03)}
@media(max-width:480px){.float-btn{padding:0.75rem;border-radius:50%;width:52px;height:52px;justify-content:center}.float-label{display:none}}

/* ════════ COUNTRY PAGE (Destination Detail) ════════ */
.country-hero{min-height:70vh;display:flex;align-items:flex-end;background-size:cover;background-position:center;position:relative;padding:2rem 0 4rem}
.country-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.25) 0%,rgba(0,30,10,0.80) 100%)}
.country-hero-inner{position:relative;z-index:2}
.breadcrumbs{display:flex;align-items:center;gap:0.5rem;font-size:0.8rem;color:rgba(255,255,255,0.7);margin-bottom:1.5rem;flex-wrap:wrap}
.breadcrumbs a{color:rgba(255,255,255,0.7);transition:color var(--transition)}
.breadcrumbs a:hover{color:#A8D8A8}
.bc-sep{color:rgba(255,255,255,0.4)}
.bc-current{color:white}
.country-flag{font-size:3rem;display:block;margin-bottom:0.75rem}
.country-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,7vw,5.5rem);font-weight:300;color:white;line-height:1.05;margin-bottom:0.5rem}
.country-tagline{font-size:1.1rem;color:#A8D8A8;font-weight:300;letter-spacing:0.05em;margin-bottom:1.5rem}
.country-meta{display:flex;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}
.country-meta-item{display:flex;flex-direction:column;gap:0.25rem}
.country-meta-label{font-size:0.7rem;color:rgba(255,255,255,0.55);letter-spacing:0.14em;text-transform:uppercase}
.country-meta-value{font-size:0.95rem;color:white;font-weight:500}
.country-hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.btn-outline{background:transparent;color:white;font-weight:500;font-size:0.9rem;padding:0.9rem 2rem;border-radius:3rem;border:1.5px solid rgba(255,255,255,0.5);transition:all var(--transition);display:inline-block}
.btn-outline:hover{background:rgba(255,255,255,0.12);border-color:white}
.country-intro{background:var(--cream2);padding:4rem 0}
.country-intro-inner{max-width:760px}
.country-intro-text{font-family:'Cormorant Garamond',serif;font-size:1.2rem;line-height:1.8;color:var(--forest);margin-top:1rem;font-style:italic;font-weight:300}
.country-places{background:var(--white);padding:5rem 0}
.places-grid--float{display:flex;flex-direction:column;gap:4rem}
.place-card--visual{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.place-card--visual.swing-right{direction:rtl}
.place-card--visual.swing-right .place-info{direction:ltr}
.place-card--visual.swing-right .place-photo-wrap{direction:ltr}
.place-photo-wrap{border-radius:var(--radius-lg);overflow:hidden;height:340px;box-shadow:var(--shadow-lg)}
.place-photo-frame{width:100%;height:100%}
.place-photo{width:100%;height:100%;object-fit:cover}
.place-info{direction:ltr}
.place-num{font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:300;color:var(--mint);line-height:1;margin-bottom:0.5rem}
.place-name{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;color:var(--forest);margin-bottom:0.75rem;line-height:1.1}
.place-desc{font-size:1rem;color:var(--text-muted);line-height:1.7;font-weight:300;margin-bottom:1.5rem}
.place-enquire{display:inline-flex;align-items:center;gap:0.5rem;background:#25D366;color:white;font-weight:600;font-size:0.85rem;padding:0.75rem 1.5rem;border-radius:2rem;transition:all var(--transition)}
.place-enquire:hover{background:#1da851;transform:translateY(-1px)}
@media(max-width:768px){.place-card--visual{grid-template-columns:1fr}.place-card--visual.swing-right{direction:ltr}.place-photo-wrap{height:240px}}
.country-cta{background:var(--forest);padding:4rem 0}
.country-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.country-cta-title{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:400;color:white;margin-bottom:0.5rem}
.country-cta-sub{font-size:1rem;color:rgba(255,255,255,0.7);max-width:480px}
.country-cta-btns{display:flex;gap:1rem;flex-wrap:wrap;flex-shrink:0}
.btn-whatsapp{background:#25D366;color:white;font-weight:600;font-size:0.88rem;padding:0.9rem 1.8rem;border-radius:2rem;transition:all var(--transition);display:inline-flex;align-items:center;gap:0.5rem}
.btn-whatsapp:hover{background:#1da851;transform:translateY(-1px)}
.country-nav{background:var(--cream2);padding:3rem 0}
.country-nav-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.country-nav-card{display:flex;flex-direction:column;gap:0.4rem;padding:1.5rem 2rem;border-radius:var(--radius);background:white;border:1px solid rgba(46,125,50,0.12);transition:all var(--transition)}
.country-nav-card:hover{box-shadow:var(--shadow);background:var(--mint)}
.country-nav-card.next{text-align:right}
.country-nav-dir{font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--leaf);font-weight:600}
.country-nav-name{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;color:var(--forest)}
.country-others{background:var(--white);padding:5rem 0}
.others-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2.5rem}
.other-card{border-radius:var(--radius);overflow:hidden;height:180px;position:relative;display:block}
.other-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease}
.other-card:hover img{transform:scale(1.06)}
.other-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,20,0,0.75) 100%)}
.other-info{position:absolute;bottom:0;left:0;right:0;padding:1rem;display:flex;align-items:center;gap:0.5rem}
.other-flag{font-size:1.2rem}
.other-name{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:white}
.country-others-cta{text-align:center}

/* ════════ RESPONSIVE ════════ */
@media(max-width:900px){section{padding:4rem 0}.pkg-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
@media(max-width:600px){.hero-stats{gap:1.25rem}.hero-stat-div{display:none}.places-grid{grid-template-columns:1fr}.testi-grid{grid-template-columns:1fr}}

/* ════════════════════════════════════════
   ROUND CIRCLE DESTINATION SLIDER
════════════════════════════════════════ */


/* ══ DESTINATIONS SECTION ══ */
#dest-circles { background: var(--cream2); padding: 5.5rem 0 4rem; }

/* feature card */
.dest-feature-wrap {
  position: relative;
  max-width: 940px;
  margin: 0 auto 3.5rem;
}
.dest-feature-img-wrap { position: relative; height: 460px; overflow: hidden; }
@media (max-width: 640px) { .dest-feature-img-wrap { height: 300px; } }
#destFeatureImg { transition: opacity .4s ease, transform .8s ease; }
.dest-feature-img-wrap.switching #destFeatureImg { opacity: 0; transform: scale(1.05); }

/* prev/next */
.dest-slider-prev, .dest-slider-next {
  position: absolute; top: 46%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: #fff; color: var(--forest);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
  cursor: pointer; z-index: 5; border: none;
  transition: all var(--transition);
}
.dest-slider-prev { left: -24px; }
.dest-slider-next { right: -24px; }
.dest-slider-prev:hover, .dest-slider-next:hover {
  background: var(--leaf); color: #fff;
  box-shadow: 0 6px 24px rgba(46,125,50,0.35);
}
@media (max-width: 768px) { .dest-slider-prev { left: 8px; } .dest-slider-next { right: 8px; } }

/* dots */
.dest-slider-dots { display: flex; justify-content: center; gap: .5rem; margin-top: 1.25rem; }
.dest-slider-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(46,125,50,.25); cursor: pointer; border: none;
  transition: all var(--transition); padding: 0;
}
.dest-slider-dot.active { background: var(--leaf); width: 28px; border-radius: 4px; }

/* ── CIRCLE THUMBNAIL INFINITE SLIDE ── */
.ek-thumbs-outer {
  position: relative;
  overflow: hidden;
  padding: .5rem 0 1rem;
}
.ek-thumbs-outer::before,
.ek-thumbs-outer::after {
  content: ''; position: absolute; top: 0; bottom: 0; width: 80px; z-index: 2; pointer-events: none;
}
.ek-thumbs-outer::before { left: 0; background: linear-gradient(to right, var(--cream2) 30%, transparent); }
.ek-thumbs-outer::after  { right: 0; background: linear-gradient(to left,  var(--cream2) 30%, transparent); }

@keyframes ek-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-33.333%); }
}

.ek-thumbs-track {
  display: flex;
  gap: 1.8rem;
  padding: 1rem 1.5rem .5rem;
  width: max-content;
  animation: ek-scroll 30s linear infinite;
  will-change: transform;
}
.ek-thumbs-outer:hover .ek-thumbs-track { animation-play-state: paused; }

/* each circle item */
.dest-circle-btn {
  display: flex; flex-direction: column; align-items: center; gap: .55rem;
  cursor: pointer; border: none; background: none;
  flex-shrink: 0; padding: .4rem .5rem;
  transition: transform .3s ease;
  outline: none;
}
.dest-circle-btn:hover { transform: translateY(-6px); }

.ek-thumb-circle {
  width: 100px; height: 100px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid rgba(255,255,255,.9);
  box-shadow: 0 4px 18px rgba(0,0,0,.15);
  transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
  background: var(--mint);
  flex-shrink: 0;
}
.ek-thumb-circle img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .5s ease;
}
.dest-circle-btn:hover .ek-thumb-circle img { transform: scale(1.1); }

.dest-circle-btn.active .ek-thumb-circle {
  border-color: var(--leaf);
  box-shadow: 0 0 0 4px rgba(46,125,50,.25), 0 8px 28px rgba(46,125,50,.3);
  transform: scale(1.1);
}
.dest-circle-btn.active .ek-thumb-name { color: var(--leaf); font-weight: 700; }

.ek-thumb-flag {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 50%;
  background: #fff; box-shadow: 0 2px 8px rgba(0,0,0,.15);
  font-size: .95rem;
  margin-top: -1.6rem; margin-left: 3.8rem;
  position: relative; z-index: 2; flex-shrink: 0;
}
.ek-thumb-name {
  font-size: .8rem; font-weight: 500; color: var(--forest);
  text-align: center; white-space: nowrap;
  transition: color .3s ease;
}

@media (max-width: 640px) {
  .ek-thumb-circle { width: 80px; height: 80px; }
  .ek-thumbs-track { gap: 1.2rem; animation-duration: 22s; }
  .dest-feature-wrap { margin-bottom: 2.5rem; }
}
