/* ================================================================
   GODANDELI v5 — Bold Adventure Style (Zostel-inspired)
   Fonts: Space Grotesk + Inter
   Palette: White · Forest Green · Vivid Orange
================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --white:      #ffffff;
  --off:        #f6f8f6;
  --light:      #eaf0eb;
  --border:     #dde6de;
  --green:      #1b7a45;
  --green-d:    #135733;
  --green-l:    #2aaa63;
  --green-bg:   #e9f5ee;
  --ink:        #0c180e;
  --text:       #1c2b1f;
  --mid:        #4a5e4d;
  --soft:       #7d9080;
  --orange:     #ff5a1f;
  --orange-l:   #ff7640;
  --yellow:     #ffc107;
  --shadow:     0 2px 12px rgba(0,0,0,.07);
  --shadow-md:  0 6px 28px rgba(0,0,0,.11);
  --shadow-lg:  0 16px 48px rgba(0,0,0,.14);

  --head:   'Space Grotesk', sans-serif;
  --body:   'Inter', sans-serif;

  --r-sm: 8px;
  --r:    14px;
  --r-lg: 20px;
  --r-xl: 28px;

  --ease: cubic-bezier(.16,1,.3,1);
  --nav-h: 68px;
  --max:   min(1240px, 92vw);
  --pad:   clamp(56px,8vw,96px);

  /* ── legacy aliases (inner pages) ── */
  --cream:       #f6f8f6;
  --radius:      14px;
  --radius-lg:   20px;
  --radius-xl:   28px;
  --transition:  all .3s cubic-bezier(.16,1,.3,1);
  --text-light:  #7d9080;
  --text-mid:    #4a5e4d;
  --text-dark:   #0c180e;
  --shadow-deep: 0 16px 48px rgba(0,0,0,.18);
  --green-main:  #1b7a45;
  --green-dark:  #135733;
  --cream-dark:  #dde6de;
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--white);color:var(--text);line-height:1.6;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{cursor:pointer;border:none;background:none;font-family:var(--body)}

/* ── LOADER ─────────────────────────────────────────────────── */
#loader{
  position:fixed;inset:0;z-index:10000;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  transition:opacity .6s var(--ease),visibility .6s;
}
#loader.hide{opacity:0;visibility:hidden;pointer-events:none}
.loader-wordmark{
  font-family:var(--head);font-size:clamp(2rem,5vw,3rem);font-weight:700;
  color:var(--white);letter-spacing:-.02em;
}
.loader-wordmark em{font-style:normal;color:var(--green-l)}
.loader-sub{font-family:var(--body);font-size:.65rem;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:32px}
.loader-line{width:140px;height:3px;background:rgba(255,255,255,.1);border-radius:99px;overflow:hidden}
.loader-fill{height:3px;width:0;background:var(--green-l);border-radius:99px;animation:lFill 2.4s var(--ease) forwards}
@keyframes lFill{to{width:100%}}

/* ── NAV ────────────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(16px,4vw,48px);
  transition:background .35s,box-shadow .35s,backdrop-filter .35s;
}
nav.transparent{background:transparent}
nav.solid{background:rgba(12,24,14,.95);backdrop-filter:blur(16px);box-shadow:0 1px 0 rgba(255,255,255,.07)}

.nav-logo{
  font-family:var(--head);font-size:1.4rem;font-weight:700;
  letter-spacing:-.03em;color:var(--white);z-index:1;
}
.nav-logo em{font-style:normal;color:var(--green-l)}

.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{
  font-size:.78rem;font-weight:600;letter-spacing:.3px;
  color:rgba(255,255,255,.7);transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links .nav-cta{
  background:var(--orange);color:var(--white)!important;
  padding:10px 24px;border-radius:var(--r-sm);font-weight:700;
  transition:background .2s,transform .15s;
}
.nav-links .nav-cta:hover{background:var(--orange-l);transform:translateY(-1px)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;z-index:2}
.hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:880;
  background:var(--ink);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .4s,visibility .4s;
}
.mobile-menu.open{opacity:1;visibility:visible;pointer-events:all}
.mobile-menu a{font-family:var(--head);font-size:clamp(1.6rem,5vw,2.2rem);font-weight:700;color:rgba(255,255,255,.6);transition:color .2s;letter-spacing:-.02em}
.mobile-menu a:hover{color:var(--white)}
.mobile-menu .nav-cta{background:var(--orange);color:var(--white)!important;padding:14px 40px;border-radius:var(--r-sm);font-size:.85rem}

/* ── HERO ───────────────────────────────────────────────────── */
.hero{
  position:relative;height:100dvh;min-height:600px;
  display:flex;align-items:center;justify-content:flex-start;
  overflow:hidden;
}
.hero-video-wrap{position:absolute;inset:0;z-index:0}
.hero-video-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,rgba(12,24,14,.78) 0%,rgba(12,24,14,.45) 50%,rgba(12,24,14,.2) 100%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:var(--max);width:100%;margin:0 auto;
  padding:0 clamp(20px,5vw,56px);
}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:99px;padding:7px 16px;
  font-size:.68rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,.85);margin-bottom:24px;
}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--green-l);flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

.hero-title{
  font-family:var(--head);
  font-size:clamp(2.8rem,6.5vw,5.5rem);
  font-weight:700;line-height:1.05;color:var(--white);
  letter-spacing:-.03em;margin-bottom:20px;
}
.hero-title span{color:var(--green-l)}

.hero-sub{
  font-size:1rem;font-weight:400;color:rgba(255,255,255,.65);
  max-width:480px;line-height:1.7;margin-bottom:36px;
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px}

/* Hero floating cards */
.hero-cards{
  display:flex;gap:12px;flex-wrap:wrap;
}
.hero-card{
  background:rgba(255,255,255,.1);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.15);border-radius:var(--r);
  padding:14px 20px;display:flex;align-items:center;gap:12px;
}
.hero-card-icon{font-size:1.3rem}
.hero-card-num{font-family:var(--head);font-size:1.2rem;font-weight:700;color:var(--white);line-height:1}
.hero-card-lbl{font-size:.6rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:2px}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:.85rem;font-weight:700;
  background:var(--orange);color:var(--white);
  padding:14px 32px;border-radius:var(--r-sm);
  transition:background .2s,transform .15s,box-shadow .2s;
}
.btn-primary:hover{background:var(--orange-l);transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,90,31,.35)}

.btn-green{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:.85rem;font-weight:700;
  background:var(--green);color:var(--white);
  padding:14px 32px;border-radius:var(--r-sm);
  transition:background .2s,transform .15s,box-shadow .2s;
}
.btn-green:hover{background:var(--green-d);transform:translateY(-2px);box-shadow:0 8px 20px rgba(27,122,69,.3)}

.btn-white{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:.85rem;font-weight:700;
  background:var(--white);color:var(--ink);
  padding:14px 32px;border-radius:var(--r-sm);
  transition:background .2s,transform .15s;
}
.btn-white:hover{background:#f0f0f0;transform:translateY(-2px)}

.btn-outline-green{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:.85rem;font-weight:700;
  color:var(--green);padding:13px 30px;border-radius:var(--r-sm);
  border:2px solid var(--green);
  transition:background .2s,color .2s;
}
.btn-outline-green:hover{background:var(--green);color:var(--white)}

.btn-outline-white{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:.85rem;font-weight:700;
  color:var(--white);padding:13px 30px;border-radius:var(--r-sm);
  border:2px solid rgba(255,255,255,.5);
  transition:border-color .2s,background .2s;
}
.btn-outline-white:hover{border-color:var(--white);background:rgba(255,255,255,.1)}

.btn-arrow{display:inline-block;transition:transform .2s var(--ease)}
*:hover>.btn-arrow{transform:translateX(4px)}

/* ── MARQUEE STRIP ──────────────────────────────────────────── */
.marquee-strip{background:var(--green);overflow:hidden;padding:13px 0}
.marquee-track{display:flex;width:max-content;animation:marquee 26s linear infinite}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{
  display:flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:rgba(255,255,255,.8);padding:0 28px;white-space:nowrap;
}
.marquee-item:hover{color:var(--white)}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--green-l);flex-shrink:0}

/* ── STATS STRIP ────────────────────────────────────────────── */
.stats-strip{
  background:var(--white);border-bottom:1px solid var(--border);
  display:grid;grid-template-columns:repeat(4,1fr);
}
.stat-item{
  padding:28px 20px;text-align:center;border-right:1px solid var(--border);
  transition:background .2s;
}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:var(--off)}
.stat-num{
  display:block;font-family:var(--head);
  font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:700;
  color:var(--green);line-height:1;
}
.stat-lbl{display:block;font-size:.72rem;font-weight:500;color:var(--soft);margin-top:5px}

/* ── SECTIONS ───────────────────────────────────────────────── */
section{padding:var(--pad) clamp(20px,5vw,56px)}

.section-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-bg);color:var(--green);
  font-size:.68rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  padding:6px 14px;border-radius:99px;margin-bottom:14px;
}
.section-tag::before{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}
.section-tag.orange{background:#fff2ed;color:var(--orange)}
.section-tag.orange::before{background:var(--orange)}

.section-title{
  font-family:var(--head);
  font-size:clamp(1.9rem,3.8vw,2.9rem);
  font-weight:700;color:var(--text);
  line-height:1.1;letter-spacing:-.02em;margin-bottom:10px;
}
.section-title span{color:var(--green)}
.section-sub{font-size:.9rem;color:var(--soft);line-height:1.75;max-width:520px;margin-bottom:0}
.section-sub.center{margin-left:auto;margin-right:auto;text-align:center}

/* ── PACKAGES ───────────────────────────────────────────────── */
.pkg-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.pkg-card{
  background:var(--white);border-radius:var(--r-xl);
  overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--border);
  transition:transform .35s var(--ease),box-shadow .35s;
  display:flex;flex-direction:column;
}
.pkg-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.pkg-card.featured{border-color:var(--green);outline:2px solid var(--green)}
.pkg-img-wrap{height:210px;position:relative;overflow:hidden}
.pkg-img-wrap img{transition:transform .6s var(--ease)}
.pkg-card:hover .pkg-img-wrap img{transform:scale(1.06)}
.pkg-badge{
  position:absolute;top:14px;left:14px;z-index:1;
  font-family:var(--head);font-size:.62rem;font-weight:700;letter-spacing:.5px;
  background:var(--orange);color:var(--white);
  padding:5px 12px;border-radius:99px;
}
.pkg-badge.green{background:var(--green)}
.pkg-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.pkg-name{font-family:var(--head);font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:4px;letter-spacing:-.02em}
.pkg-share{font-size:.75rem;color:var(--soft);margin-bottom:14px}
.pkg-price{display:flex;align-items:baseline;gap:4px;margin-bottom:14px}
.pkg-amount{font-family:var(--head);font-size:1.9rem;font-weight:700;color:var(--green);line-height:1}
.pkg-unit{font-size:.75rem;color:var(--soft)}
.pkg-ac{
  font-size:.62rem;font-weight:700;background:var(--green-bg);color:var(--green);
  padding:3px 9px;border-radius:99px;margin-left:6px;align-self:center;
}
.pkg-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.pkg-tag{
  font-size:.65rem;font-weight:600;background:var(--off);color:var(--mid);
  padding:4px 11px;border-radius:99px;border:1px solid var(--border);
}
.pkg-hr{height:1px;background:var(--border);margin:4px 0 16px}
.pkg-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--head);font-size:.82rem;font-weight:700;
  background:var(--green);color:var(--white);
  padding:12px;border-radius:var(--r);
  transition:background .2s;
}
.pkg-cta:hover{background:var(--green-d)}

/* Extra packages strip */
.pkg-strip{
  max-width:var(--max);margin:24px auto 0;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;
}
.pkg-strip-item{
  padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:var(--white);border-right:1px solid var(--border);
  transition:background .2s;
}
.pkg-strip-item:last-child{border-right:none}
.pkg-strip-item:hover{background:var(--off)}
.pkg-strip-name{font-family:var(--head);font-size:.95rem;font-weight:700;color:var(--text)}
.pkg-strip-share{font-size:.72rem;color:var(--soft);margin-top:3px}
.pkg-strip-price{font-family:var(--head);font-size:1.3rem;font-weight:700;color:var(--green);white-space:nowrap;text-align:right}
.pkg-strip-unit{font-size:.65rem;color:var(--soft);text-align:right;margin-top:2px}

/* ── ACTIVITIES ─────────────────────────────────────────────── */
.act-section{background:var(--ink)}
.act-header-row{
  max-width:var(--max);margin:0 auto 40px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.act-title{
  font-family:var(--head);
  font-size:clamp(1.9rem,3.5vw,2.8rem);font-weight:700;
  color:var(--white);letter-spacing:-.02em;line-height:1.1;
}
.act-title span{color:var(--green-l)}
.act-sub{font-size:.85rem;color:rgba(255,255,255,.45);margin-top:8px;line-height:1.6}
.act-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:260px 260px;
  gap:10px;
}
.act-card{position:relative;overflow:hidden;border-radius:var(--r-lg);cursor:pointer}
.act-card:first-child{grid-column:span 2;grid-row:span 2}
.act-card img{transition:transform .5s var(--ease)}
.act-card:hover img{transform:scale(1.06)}
.act-info{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(12,24,14,.85) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:18px;
}
.act-num{
  font-size:.6rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;
  color:var(--green-l);margin-bottom:4px;
}
.act-name{font-family:var(--head);font-size:1.05rem;font-weight:700;color:var(--white);line-height:1.1}
.act-card:first-child .act-name{font-size:1.7rem}
.act-free-badge{
  display:inline-block;font-size:.58rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  background:var(--green-l);color:var(--white);
  padding:3px 9px;border-radius:99px;margin-top:6px;width:fit-content;
}
.act-desc{font-size:.75rem;color:rgba(255,255,255,.55);line-height:1.5;margin-top:6px;max-height:0;overflow:hidden;opacity:0;transition:max-height .4s var(--ease),opacity .3s}
.act-card:hover .act-desc{max-height:60px;opacity:1}

/* ── ABOUT ──────────────────────────────────────────────────── */
.about-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.about-img-wrap{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  height:500px;box-shadow:var(--shadow-lg);
}
.about-img-wrap img{position:absolute;inset:0;transition:transform .8s var(--ease)}
.about-img-wrap:hover img{transform:scale(1.04)}
.about-badge{
  position:absolute;bottom:24px;left:24px;z-index:2;
  background:var(--white);border-radius:var(--r-lg);padding:16px 20px;
  box-shadow:var(--shadow-md);display:flex;align-items:center;gap:14px;
}
.about-badge-icon{font-size:1.8rem}
.about-badge-num{font-family:var(--head);font-size:1.5rem;font-weight:700;color:var(--green);line-height:1}
.about-badge-lbl{font-size:.65rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.about-checklist{margin:28px 0 36px;display:flex;flex-direction:column;gap:12px}
.about-check{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--mid)}
.check-icon{
  width:24px;height:24px;border-radius:50%;background:var(--green-bg);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--green);font-size:.75rem;font-weight:800;
}

/* ── SIGHTSEEING ────────────────────────────────────────────── */
.sight-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.sight-card{
  background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow);border:1px solid var(--border);
  transition:transform .35s var(--ease),box-shadow .35s;
}
.sight-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.sight-img{height:180px;overflow:hidden}
.sight-img img{transition:transform .5s var(--ease)}
.sight-card:hover .sight-img img{transform:scale(1.07)}
.sight-body{padding:16px 18px 20px}
.sight-name{font-family:var(--head);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:6px}
.sight-desc{font-size:.78rem;color:var(--soft);line-height:1.6;margin-bottom:10px}
.sight-dist{
  display:inline-flex;align-items:center;gap:5px;
  font-size:.65rem;font-weight:700;background:var(--green-bg);color:var(--green);
  padding:4px 10px;border-radius:99px;
}

/* ── GALLERY ────────────────────────────────────────────────── */
.gal-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:10px;
}
.gal-grid .gal-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gal-grid .gal-item:nth-child(5){grid-column:span 2}
.gal-item{border-radius:var(--r-lg);overflow:hidden;cursor:zoom-in;position:relative}
.gal-item img{transition:transform .5s var(--ease)}
.gal-item:hover img{transform:scale(1.06)}
.gal-overlay{
  position:absolute;inset:0;
  background:rgba(12,24,14,.4);opacity:0;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .3s;
}
.gal-item:hover .gal-overlay{opacity:1}
.gal-zoom{
  width:48px;height:48px;border:2px solid var(--white);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;color:var(--white);
  transform:scale(.7);transition:transform .3s var(--ease);
}
.gal-item:hover .gal-zoom{transform:scale(1)}

/* ── TESTIMONIALS ───────────────────────────────────────────── */
/* ── TESTIMONIALS MARQUEE ── */
.testi-grid{
  overflow:hidden;
  position:relative;
  width:100%;
  /* fade edges */
}
.testi-grid::before,.testi-grid::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none;
}
.testi-grid::before{left:0;background:linear-gradient(to right,var(--off) 10%,transparent)}
.testi-grid::after{right:0;background:linear-gradient(to left,var(--off) 10%,transparent)}
.testi-track{
  display:flex;gap:20px;
  width:max-content;
  animation:testiScroll 40s linear infinite;
}
.testi-track:hover{animation-play-state:paused}
@keyframes testiScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.testi-card{
  width:320px;flex-shrink:0;
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:28px;
  transition:border-color .3s,box-shadow .3s,transform .3s var(--ease);
}
.testi-card:hover{border-color:var(--green);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.testi-stars{margin-bottom:14px}
.testi-stars span{color:var(--yellow);font-size:.95rem}
.testi-text{font-size:.85rem;color:var(--mid);line-height:1.75;margin-bottom:20px}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-av{
  width:38px;height:38px;border-radius:50%;
  background:var(--green);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--head);font-size:.85rem;font-weight:700;flex-shrink:0;
}
.testi-name{font-size:.82rem;font-weight:700;color:var(--text)}
.testi-loc{font-size:.7rem;color:var(--soft);margin-top:2px}

/* ── BLOG ───────────────────────────────────────────────────── */
.blog-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.blog-card{
  background:var(--white);border-radius:var(--r-xl);
  overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);
  transition:transform .35s var(--ease),box-shadow .35s;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.blog-img-link{display:block}
.blog-card-img{height:190px;overflow:hidden}
.blog-card-img img{transition:transform .5s var(--ease)}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-body{padding:20px}
.blog-meta{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.blog-cat{
  font-size:.62rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  background:var(--green-bg);color:var(--green);
  padding:4px 10px;border-radius:99px;
}
.blog-date{font-size:.7rem;color:var(--soft)}
.blog-title{
  font-family:var(--head);font-size:1rem;font-weight:700;
  color:var(--text);line-height:1.35;display:block;margin-bottom:8px;
  transition:color .2s;letter-spacing:-.01em;
}
.blog-title:hover{color:var(--green)}
.blog-excerpt{font-size:.78rem;color:var(--soft);line-height:1.65;margin-bottom:14px}
.blog-more{
  font-size:.72rem;font-weight:700;color:var(--green);
  display:flex;align-items:center;gap:6px;transition:gap .2s;
}
.blog-more:hover{gap:10px}

/* ── CTA BAND ───────────────────────────────────────────────── */
.cta-band{
  background:var(--green-d);
  padding:var(--pad) clamp(20px,5vw,56px);
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;right:-80px;top:-80px;
  width:400px;height:400px;border-radius:50%;
  background:rgba(255,255,255,.03);
}
.cta-band::after{
  content:'';position:absolute;left:-60px;bottom:-60px;
  width:300px;height:300px;border-radius:50%;
  background:rgba(255,255,255,.03);
}
.cta-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;
  position:relative;z-index:1;
}
.cta-text h2{
  font-family:var(--head);
  font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;
  color:var(--white);letter-spacing:-.02em;line-height:1.1;margin-bottom:10px;
}
.cta-text h2 span{color:var(--green-l)}
.cta-text p{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.65;max-width:480px}
.cta-actions{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}

/* ── FOOTER ─────────────────────────────────────────────────── */
footer{background:var(--ink);padding:clamp(56px,7vw,88px) clamp(20px,5vw,56px) 0}
.footer-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:48px;
  padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-logo{
  font-family:var(--head);font-size:1.6rem;font-weight:700;letter-spacing:-.03em;
  color:var(--white);display:block;margin-bottom:14px;line-height:1;
}
.footer-logo em{font-style:normal;color:var(--green-l)}
.footer-wordmark{
  font-family:var(--head);font-size:1.6rem;font-weight:700;letter-spacing:-.03em;
  color:var(--white);display:block;margin-bottom:14px;line-height:1;
}
.footer-wordmark em{font-style:normal;color:var(--green-l)}
.footer-about{font-size:.8rem;line-height:1.75;color:rgba(255,255,255,.35);max-width:280px;margin-bottom:22px}
.socials{display:flex;gap:8px}
.social-btn{
  width:36px;height:36px;border-radius:var(--r-sm);
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:rgba(255,255,255,.4);
  transition:background .2s,border-color .2s,color .2s;
}
.social-btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:var(--white)}
.footer-col h5{
  font-family:var(--head);font-size:.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.25);margin-bottom:18px;
}
.footer-col ul li{margin-bottom:10px}
.footer-col a{font-size:.8rem;color:rgba(255,255,255,.4);transition:color .2s}
.footer-col a:hover{color:rgba(255,255,255,.85)}
.footer-col p{font-size:.8rem;color:rgba(255,255,255,.35);line-height:1.7;margin-bottom:6px}
.newsletter-form{display:flex;gap:6px;margin-top:8px}
.newsletter-form input{
  flex:1;padding:10px 14px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-sm);
  font-family:var(--body);font-size:.78rem;color:var(--white);outline:none;
  transition:border-color .2s;
}
.newsletter-form input::placeholder{color:rgba(255,255,255,.2)}
.newsletter-form input:focus{border-color:var(--green-l)}
.newsletter-form button{
  padding:10px 16px;background:var(--green);color:var(--white);
  font-family:var(--head);font-size:.7rem;font-weight:700;
  border-radius:var(--r-sm);transition:background .2s;
}
.newsletter-form button:hover{background:var(--green-l)}
.footer-bottom{
  max-width:var(--max);margin:0 auto;padding:20px 0;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
}
.footer-copy{font-size:.68rem;color:rgba(255,255,255,.2)}
.footer-legal{display:flex;gap:18px}
.footer-legal a{font-size:.68rem;color:rgba(255,255,255,.25);transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.6)}

/* ── FLOATERS ───────────────────────────────────────────────── */
.whatsapp-float{
  position:fixed;bottom:28px;right:28px;z-index:800;
  width:52px;height:52px;border-radius:50%;background:#25d366;
  box-shadow:0 4px 16px rgba(37,211,102,.35);
  display:flex;align-items:center;justify-content:center;
  transition:transform .3s var(--ease),box-shadow .3s;
}
.whatsapp-float:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,.45)}
.whatsapp-float svg{width:26px;height:26px;fill:white}
.back-to-top{
  position:fixed;bottom:90px;right:28px;z-index:800;
  width:42px;height:42px;border-radius:50%;
  background:var(--ink);color:var(--white);border:1px solid rgba(255,255,255,.12);
  font-size:.9rem;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transform:translateY(8px);
  transition:opacity .3s,transform .3s;
}
.back-to-top.show{opacity:1;pointer-events:all;transform:translateY(0)}

/* ── TOAST ──────────────────────────────────────────────────── */
.success-toast{
  position:fixed;bottom:40px;left:50%;transform:translateX(-50%) translateY(14px);
  background:var(--ink);color:var(--white);border:1px solid rgba(255,255,255,.1);
  padding:13px 24px;border-radius:var(--r);font-size:.8rem;
  z-index:9000;opacity:0;transition:opacity .3s,transform .3s;
  pointer-events:none;white-space:nowrap;
}
.success-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── LIGHTBOX ───────────────────────────────────────────────── */
.lightbox{
  position:fixed;inset:0;z-index:9990;
  background:rgba(12,24,14,.96);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s,visibility .3s;
}
.lightbox.open{opacity:1;visibility:visible;pointer-events:all}
.lightbox img{max-width:90vw;max-height:88vh;width:auto;height:auto;object-fit:contain;border-radius:var(--r-lg)}
.lightbox-close{
  position:absolute;top:22px;right:26px;font-size:1.2rem;
  color:rgba(255,255,255,.4);cursor:pointer;transition:color .2s;padding:8px;
}
.lightbox-close:hover{color:var(--white)}

/* ── SCROLL REVEAL ──────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .45s var(--ease),transform .45s var(--ease)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal.visible,.reveal-left.visible,.reveal-right.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.08s!important}
.reveal-delay-2{transition-delay:.16s!important}
.reveal-delay-3{transition-delay:.24s!important}
.reveal-delay-4{transition-delay:.32s!important}
/* Mobile: snappier animations */
@media(max-width:768px){.reveal,.reveal-left,.reveal-right{transition-duration:.25s!important;transition-delay:0s!important}}
/* Respect user motion preference */
@media(prefers-reduced-motion:reduce){.reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important;transition:none!important}}

/* ── PAGE HERO ──────────────────────────────────────────────── */
.page-hero{position:relative;height:400px;overflow:hidden;display:flex;align-items:flex-end}
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg img{position:absolute;inset:0}
.page-hero-bg::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(12,24,14,.2),rgba(12,24,14,.7))}
.page-hero-content{position:relative;z-index:2;padding:0 clamp(20px,5vw,56px) 48px;width:100%;max-width:var(--max);margin:0 auto}
.page-hero-content h1{font-family:var(--head);font-size:clamp(2rem,5vw,3.2rem);font-weight:700;color:var(--white);line-height:1.05;margin-bottom:12px;letter-spacing:-.03em}

/* ── BREADCRUMB ─────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.7rem;color:rgba(255,255,255,.4)}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .2s}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb .sep{color:rgba(255,255,255,.2)}
.breadcrumb span:last-child{color:rgba(255,255,255,.75)}

/* ── SECTION HEADER ─────────────────────────────────────────── */
.section-header{max-width:var(--max);margin:0 auto 48px}
.section-header.center{text-align:center}
.section-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.65rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  background:var(--green-bg);color:var(--green);
  padding:6px 14px;border-radius:99px;margin-bottom:14px;
}
.section-label::before{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}

/* ── CONTACT ────────────────────────────────────────────────── */
.contact-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--soft);margin-bottom:7px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px 16px;
  border:2px solid var(--border);border-radius:var(--r);
  font-family:var(--body);font-size:.88rem;color:var(--text);
  background:var(--white);outline:none;transition:border-color .2s,box-shadow .2s;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(27,122,69,.1)}
.form-group textarea{resize:vertical;min-height:130px}

/* ── FAQ ────────────────────────────────────────────────────── */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;padding:18px 0;font-family:var(--head);font-size:.9rem;font-weight:700;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:16px;cursor:pointer;transition:color .2s}
.faq-q:hover{color:var(--green)}
.faq-icon{width:24px;height:24px;border-radius:50%;background:var(--off);display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0;transition:all .3s;color:var(--mid);font-weight:700}
.faq-item.open .faq-icon{background:var(--green);color:var(--white);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s;font-size:.83rem;color:var(--soft);line-height:1.75}
.faq-item.open .faq-a{max-height:300px;padding-bottom:18px}

/* ── ADDONS ─────────────────────────────────────────────────── */
.addon-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.addon-card{background:var(--white);border:2px solid var(--border);border-radius:var(--r-lg);padding:24px;text-align:center;transition:border-color .25s,transform .25s,box-shadow .25s}
.addon-card:hover{border-color:var(--green);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.addon-icon{font-size:1.8rem;display:block;margin-bottom:10px}
.addon-name{font-family:var(--head);font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:5px}
.addon-price{font-family:var(--head);font-size:1.4rem;font-weight:700;color:var(--green);line-height:1;margin-bottom:3px}
.addon-note{font-size:.68rem;color:var(--soft)}

/* ── LEGAL ──────────────────────────────────────────────────── */
.legal-content{max-width:840px;margin:0 auto}
.legal-content h2{font-family:var(--head);font-size:1.2rem;font-weight:700;color:var(--text);margin:36px 0 12px;padding-top:22px;border-top:1px solid var(--border)}
.legal-content h2:first-of-type{border-top:none;padding-top:0;margin-top:0}
.legal-content p{color:var(--mid);line-height:1.8;margin-bottom:12px;font-size:.88rem}
.legal-content ul{padding-left:20px;margin-bottom:16px}
.legal-content ul li{color:var(--mid);line-height:1.8;margin-bottom:6px;font-size:.88rem}
.legal-updated{font-size:.75rem;color:var(--soft);margin-bottom:32px}

/* ── BLOG POST ──────────────────────────────────────────────── */
.blog-post-hero{height:400px;background-size:cover;background-position:center;border-radius:var(--r-xl);margin-bottom:36px}
.blog-post-meta-bar{display:flex;gap:12px;margin-bottom:12px;align-items:center;flex-wrap:wrap}
.blog-post-meta{font-size:.72rem;color:var(--soft)}
.blog-post-heading{font-family:var(--head);font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:700;color:var(--text);line-height:1.15;margin-bottom:14px;letter-spacing:-.02em}
#blogPostContent h3{font-family:var(--head);font-size:1.1rem;font-weight:700;color:var(--text);margin:26px 0 10px}
#blogPostContent p{color:var(--mid);line-height:1.85;margin-bottom:16px;font-size:.88rem}
.blog-sidebar{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:20px}
.sidebar-title{font-family:var(--head);font-size:.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--soft);margin-bottom:16px}

/* ── INNER PAGES: PACKAGES ─────────────────────────────────── */
.packages-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.package-card{background:var(--white);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow);transition:transform .3s var(--ease),box-shadow .3s;position:relative}
.package-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.package-card.featured{border:2px solid var(--green)}
.featured-badge{position:absolute;top:16px;left:16px;z-index:3;background:var(--green);color:var(--white);font-family:var(--head);font-size:.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:99px}
.package-img{height:200px;position:relative;overflow:hidden}
.package-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.package-card:hover .package-img img{transform:scale(1.06)}
.package-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(12,24,14,.4))}
.package-body{padding:20px}
.package-name{font-family:var(--head);font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:4px}
.package-sharing{font-size:.75rem;color:var(--soft);margin-bottom:14px}
.package-price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.price-amount{font-family:var(--head);font-size:1.6rem;font-weight:700;color:var(--green)}
.price-unit{font-size:.72rem;color:var(--soft)}
.price-ac-badge{font-size:.6rem;background:var(--green-bg);color:var(--green);padding:3px 8px;border-radius:4px;font-weight:600}
.package-includes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.include-tag{font-size:.68rem;font-weight:600;background:var(--off);color:var(--mid);padding:5px 10px;border-radius:6px}
.package-divider{height:1px;background:var(--border);margin-bottom:14px}
.package-book{display:flex;align-items:center;justify-content:space-between;font-family:var(--head);font-size:.82rem;font-weight:700;color:var(--green);transition:color .2s}
.package-book:hover{color:var(--green-d)}
.package-book .arrow{transition:transform .2s}
.package-card:hover .package-book .arrow{transform:translateX(4px)}

/* ── INNER PAGES: GALLERY GRID ──────────────────────────────── */
.gallery-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:10px}
.gallery-grid .gallery-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.gallery-item{border-radius:var(--r-lg);overflow:hidden;cursor:zoom-in;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery-item:hover img{transform:scale(1.06)}

/* ── INNER PAGES: MEALS ─────────────────────────────────────── */
.meals-card{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:var(--off);border-radius:var(--r-xl);padding:40px;box-shadow:var(--shadow)}
.meals-info h3{font-family:var(--head);font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:12px}
.meals-info p{font-size:.88rem;color:var(--mid);line-height:1.7;margin-bottom:20px}
.meal-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.meal-list li{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text)}
.meal-check{width:18px;height:18px;border-radius:50%;background:var(--green);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0}
.meals-img{border-radius:var(--r-lg);overflow:hidden;height:280px}

/* ── INNER PAGES: SIGHTSEEING ──────────────────────────────── */
.sightseeing-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sight-img{height:200px;border-radius:var(--r-lg) var(--r-lg) 0 0;overflow:hidden;background-size:cover;background-position:center}
.sight-tag{display:inline-block;font-size:.65rem;font-weight:600;background:var(--off);color:var(--mid);padding:5px 12px;border-radius:99px;margin-top:8px}

/* ── INNER PAGES: CTA BANNER ────────────────────────────────── */
.cta-banner{background:var(--ink);padding:var(--pad);text-align:center}
.cta-banner h2{font-family:var(--head);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;color:var(--white);margin-bottom:12px;letter-spacing:-.02em}
.cta-banner p{color:rgba(255,255,255,.55);font-size:.95rem;max-width:500px;margin:0 auto 28px;line-height:1.7}
.cta-banner .btn-primary{display:inline-flex}

/* ── INNER PAGES: STATS BAR ─────────────────────────────────── */
.stats-bar{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);background:var(--ink)}
.stats-bar .stat-item{padding:28px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.stats-bar .stat-item:last-child{border-right:none}
.stats-bar .stat-number{display:block;font-family:var(--head);font-size:1.8rem;font-weight:700;color:var(--green-l);margin-bottom:4px}
.stats-bar .stat-label{font-size:.68rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* ── INNER PAGES: CONTACT ───────────────────────────────────── */
.contact-info-card{background:var(--white);border-radius:var(--r-xl);padding:32px;box-shadow:var(--shadow)}
.contact-info-card h3{font-family:var(--head);font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:8px}
.contact-info-card>p{font-size:.85rem;color:var(--mid);line-height:1.7;margin-bottom:24px}
.contact-detail{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.contact-icon{width:40px;height:40px;border-radius:50%;background:var(--green-bg);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.contact-detail-text span{display:block;font-size:.68rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--soft);margin-bottom:2px}
.contact-detail-text p{font-size:.88rem;color:var(--text);line-height:1.5;margin:0}
.contact-form-card{background:var(--white);border-radius:var(--r-xl);padding:32px;box-shadow:var(--shadow)}
.contact-form-card h3{font-family:var(--head);font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;background:var(--green);color:var(--white);font-family:var(--head);font-size:.9rem;font-weight:700;padding:14px 24px;border:none;border-radius:var(--r-lg);cursor:pointer;transition:background .2s,transform .2s;margin-top:8px}
.form-submit:hover{background:var(--green-d);transform:translateY(-1px)}

/* ── INNER PAGES: RESPONSIVE ────────────────────────────────── */
@media(max-width:1100px){.packages-grid{grid-template-columns:repeat(2,1fr)}.gallery-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:160px}.meals-card{grid-template-columns:1fr}.sightseeing-grid{grid-template-columns:repeat(2,1fr)}.stats-bar{grid-template-columns:repeat(2,1fr)}.stats-bar .stat-item:nth-child(2){border-right:none}}
@media(max-width:600px){.packages-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:130px}.gallery-grid .gallery-item:nth-child(1){grid-column:span 2}.sightseeing-grid{grid-template-columns:1fr 1fr}.stats-bar{grid-template-columns:1fr 1fr}}

/* ── PHOTO SLIDER ───────────────────────────────────────────── */
.ps-section{background:var(--ink);padding:var(--pad) 0 0}
.ps-section .section-tag{color:var(--green-l)}
.ps-section .section-title{color:var(--white)}
.ps-section .section-sub{color:rgba(255,255,255,.5)}
.ps-header{max-width:var(--max);margin:0 auto 36px;padding:0 clamp(16px,4vw,0px)}

.ps-wrap{position:relative;width:100%;overflow:hidden;background:var(--ink);line-height:0}
.ps-track{display:flex;transition:transform .65s cubic-bezier(.16,1,.3,1);will-change:transform}
.ps-slide{min-width:100%;position:relative;height:580px;line-height:1}
.ps-slide img{width:100%;height:100%;object-fit:cover;display:block}

.ps-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:100px 48px 36px;
  background:linear-gradient(to top,rgba(12,24,14,.8) 0%,transparent 100%);
}
.ps-cap-tag{font-size:.6rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--green-l);margin-bottom:8px}
.ps-cap-title{font-family:var(--head);font-size:clamp(1.1rem,2.5vw,1.7rem);font-weight:700;color:var(--white);letter-spacing:-.02em;line-height:1.15}

.ps-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.9);border:none;
  font-size:1.5rem;font-weight:700;color:var(--ink);
  cursor:pointer;z-index:10;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s,box-shadow .2s;
  box-shadow:0 4px 20px rgba(0,0,0,.25);
}
.ps-btn:hover{background:var(--white);transform:translateY(-50%) scale(1.08);box-shadow:0 6px 24px rgba(0,0,0,.3)}
.ps-prev{left:24px}
.ps-next{right:24px}

.ps-dots{
  position:absolute;bottom:24px;right:40px;
  display:flex;gap:8px;align-items:center;z-index:10;
}
.ps-dot{
  width:7px;height:7px;border-radius:99px;
  background:rgba(255,255,255,.4);border:none;cursor:pointer;
  transition:all .3s var(--ease);padding:0;
}
.ps-dot.active{background:var(--white);width:24px}

.ps-counter{
  position:absolute;top:20px;right:20px;
  background:rgba(0,0,0,.5);backdrop-filter:blur(10px);
  color:var(--white);font-family:var(--head);font-size:.68rem;font-weight:700;letter-spacing:1px;
  padding:7px 14px;border-radius:99px;z-index:10;
}

.ps-thumbs{
  display:flex;gap:5px;overflow-x:auto;
  padding:8px 0;background:rgba(0,0,0,.6);
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.ps-thumbs::-webkit-scrollbar{display:none}
.ps-thumb{
  min-width:90px;height:62px;border-radius:var(--r-sm);overflow:hidden;
  cursor:pointer;opacity:.45;flex-shrink:0;
  border:2.5px solid transparent;
  transition:opacity .3s,border-color .3s,transform .2s;
}
.ps-thumb.active{opacity:1;border-color:var(--green-l)}
.ps-thumb:hover{opacity:.8;transform:scale(1.04)}
.ps-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1100px){
  .pkg-grid{grid-template-columns:repeat(2,1fr)}
  .pkg-strip{grid-template-columns:repeat(2,1fr)}
  .pkg-strip-item:nth-child(2){border-right:none}
  .about-grid{grid-template-columns:1fr}
  .about-img-wrap{height:360px}
  .sight-grid{grid-template-columns:repeat(2,1fr)}
  .act-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
  .act-card:first-child{grid-column:span 2;height:280px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:860px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .blog-grid{grid-template-columns:1fr 1fr}
  .testi-track{animation-duration:28s}
  .contact-grid{grid-template-columns:1fr}
  .hero-cards{display:none}
}
@media(max-width:600px){
  :root{--pad:52px}
  .hero-title{font-size:clamp(2.4rem,8vw,3rem)}
  .hero-btns{flex-direction:column;width:100%}
  .hero-btns a{justify-content:center}
  .blog-grid{grid-template-columns:1fr}
  .pkg-grid{grid-template-columns:1fr}
  .pkg-strip{grid-template-columns:1fr}
  .pkg-strip-item{border-right:none!important;border-bottom:1px solid var(--border)}
  .sight-grid{display:flex;flex-direction:row;overflow-x:auto;gap:14px;padding:4px 20px 16px;margin:0 calc(-1 * var(--pad));scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .sight-grid::-webkit-scrollbar{display:none}
  .sight-card{min-width:72vw;max-width:72vw;flex-shrink:0;scroll-snap-align:start}
  .act-grid{grid-template-columns:1fr}
  .act-card:first-child{grid-column:span 1;height:220px}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .footer-grid{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;text-align:center}
  .cta-actions{justify-content:center}
  .ps-slide{height:260px}
  .ps-btn{width:38px;height:38px;font-size:1.1rem}
  .ps-prev{left:10px}.ps-next{right:10px}
  .ps-caption{padding:60px 20px 20px}
  .ps-thumbs{display:none}
  .ps-dots{bottom:14px;right:20px}
  .form-row{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .meals-card img{height:200px}
  .stats-bar{grid-template-columns:1fr 1fr}
}
