/* ==========================================================================
   Local Morocco Tours — Editorial Design System
   Fonts: Fraunces + Inter + JetBrains Mono loaded via <link> in <head>
   ========================================================================== */

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- 1. Tokens ---------- */
:root{
  /* Palette — drawn from the Local Morocco Tours logo: atlas green, zellige blue, saffron */
  --c-bg:#fbf8f1;
  --c-bg-soft:#f5efe0;
  --c-bg-sand:#ebe2c9;
  --c-paper:#fcf8ed;
  --c-ink:#14110d;
  --c-ink-soft:#2e342f;
  --c-mute:#6f766d;
  --c-line:#e2dccb;
  --c-line-dark:#0a2a1a;
  --c-primary:#0f5132;       /* atlas green (logo) */
  --c-primary-dk:#0a3a23;
  --c-accent:#e8a63b;        /* saffron (logo) */
  --c-accent-dk:#c48820;
  --c-deep:#2e5aa8;          /* zellige blue (logo) */
  --c-deep-dk:#1f3f7a;
  --c-sand:#d9b66a;
  --c-star:#e8a63b;
  --c-success:#2d6a54;

  /* Type — editorial serif + neutral sans + display numerals */
  --ff-head:"Fraunces","Playfair Display",Georgia,serif;
  --ff-body:"Inter","Helvetica Neue",Arial,sans-serif;
  --ff-mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,Menlo,monospace;

  --fs-xs:.72rem;
  --fs-sm:.8125rem;
  --fs-md:.9375rem;
  --fs-lg:1.0625rem;
  --fs-xl:1.25rem;
  --fs-2xl:1.625rem;
  --fs-3xl:2.125rem;
  --fs-4xl:2.875rem;
  --fs-5xl:4.25rem;
  --fs-display:clamp(2.75rem,7vw,6.5rem);

  /* Rhythm */
  --sp-1:.25rem;
  --sp-2:.5rem;
  --sp-3:.75rem;
  --sp-4:1rem;
  --sp-5:1.5rem;
  --sp-6:2rem;
  --sp-7:2.5rem;
  --sp-8:3rem;
  --sp-10:4.5rem;
  --sp-12:6.5rem;
  --sp-16:9rem;

  /* Radii — restrained */
  --r-sm:3px;
  --r-md:6px;
  --r-lg:10px;
  --r-pill:999px;

  /* Shadows — subtle, layered */
  --sh-xs:0 1px 2px rgba(20,17,13,.04);
  --sh-sm:0 1px 3px rgba(20,17,13,.05),0 2px 10px rgba(20,17,13,.03);
  --sh-md:0 4px 16px rgba(20,17,13,.06),0 10px 30px rgba(20,17,13,.04);
  --sh-lg:0 10px 40px rgba(20,17,13,.1),0 30px 80px rgba(20,17,13,.06);
  --sh-inset:inset 0 -1px 0 var(--c-line);

  /* Layout */
  --container:1240px;
  --container-wide:1440px;
  --container-narrow:780px;
  --header-h:76px;

  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-in-out:cubic-bezier(.65,.05,.36,1);
}

/* ---------- 2. Reset + base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-feature-settings:"ss01","ss02","kern";}
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:var(--fs-md);
  line-height:1.7;
  color:var(--c-ink);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern","liga","calt";
}
/* subtle paper grain (fixed behind all content) */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .02 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.4;
}
img,video{max-width:100%;height:auto;display:block}
svg{max-width:100%;vertical-align:middle}
img{font-style:italic;color:var(--c-mute)}  /* alt-text styling while loading */
a{color:var(--c-ink);text-decoration:none;transition:color .18s var(--ease)}
a:hover{color:var(--c-primary)}
p{margin:0 0 1em}
ul{padding:0;margin:0;list-style:none}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
::selection{background:var(--c-primary);color:#fff}

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4,h5{
  font-family:var(--ff-head);font-weight:500;
  line-height:1.08;letter-spacing:-.015em;
  color:var(--c-ink);margin:0 0 .55em;
  font-feature-settings:"ss01","ss02","kern";
}
h1{font-size:clamp(2rem,4.4vw,var(--fs-5xl));font-weight:400;letter-spacing:-.02em}
h2{font-size:clamp(1.65rem,3.4vw,var(--fs-4xl));font-weight:400;letter-spacing:-.018em}
h3{font-size:var(--fs-2xl);letter-spacing:-.012em}
h4{font-size:var(--fs-xl);font-weight:500}
h5{font-size:var(--fs-lg);font-weight:500}

.display{font-size:var(--fs-display);line-height:.96;letter-spacing:-.03em;font-weight:300;font-style:italic}
.display em{font-style:normal}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--ff-mono);
  font-size:.72rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--c-primary);margin-bottom:var(--sp-3);
}
.eyebrow::before{content:"";width:28px;height:1px;background:currentColor;opacity:.7}
.eyebrow.no-rule::before{display:none}

.lead{
  font-size:var(--fs-lg);color:var(--c-ink-soft);
  max-width:58ch;line-height:1.6;margin:0 0 var(--sp-6);
}
.lead-center{margin:0 auto var(--sp-6);text-align:center}

.drop-cap::first-letter{
  font-family:var(--ff-head);font-size:4.4em;line-height:.85;
  float:left;margin:.08em .12em -.04em 0;color:var(--c-primary);
  font-weight:400;
}

.meta-line{
  font-family:var(--ff-mono);font-size:.72rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--c-mute);
}

/* Text link underline — fine, offset */
.t-link{color:var(--c-ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:4px;text-decoration-color:var(--c-line);transition:text-decoration-color .2s,color .2s}
.t-link:hover{color:var(--c-primary);text-decoration-color:currentColor}

/* ---------- 4. Layout primitives ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(1rem,3vw,2rem);position:relative}
.container-wide{max-width:var(--container-wide)}
.container-narrow{max-width:var(--container-narrow)}
.section{padding:clamp(3.5rem,7vw,var(--sp-12)) 0;position:relative}
.section-sm{padding:clamp(2rem,5vw,var(--sp-8)) 0}
.section-tight{padding:var(--sp-6) 0}
.section-divide{border-top:1px solid var(--c-line)}

.grid{display:grid;gap:var(--sp-5)}
/* Stack multi-column .grid layouts on tablet/mobile — overrides inline grid-template-columns */
@media (max-width:860px){
  .grid[style*="grid-template-columns"]{grid-template-columns:1fr !important;gap:var(--sp-6) !important}
}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.row{display:flex;gap:var(--sp-4);flex-wrap:wrap}
.center{text-align:center}

/* Section header (editorial) */
.s-head{display:grid;grid-template-columns:auto 1fr;gap:var(--sp-6);align-items:end;margin-bottom:clamp(2rem,4vw,var(--sp-8));padding-bottom:var(--sp-5);border-bottom:1px solid var(--c-line)}
.s-head .s-num{font-family:var(--ff-mono);font-size:.75rem;color:var(--c-mute);letter-spacing:.14em}
.s-head h2{margin:0;max-width:20ch}
.s-head .s-tail{color:var(--c-ink-soft);max-width:44ch;justify-self:end;text-align:right;font-size:var(--fs-md);line-height:1.55}
@media (max-width:760px){.s-head{grid-template-columns:1fr;gap:var(--sp-3)}.s-head .s-tail{text-align:left;justify-self:start}}

/* ---------- 5. Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.8rem 1.35rem;font-weight:500;font-size:var(--fs-sm);
  letter-spacing:.02em;
  border-radius:var(--r-sm);
  border:1px solid transparent;
  transition:transform .25s var(--ease),background .2s,border-color .2s,color .2s;
  white-space:nowrap;cursor:pointer;position:relative;overflow:hidden;
}
.btn::after{content:"→";transition:transform .3s var(--ease)}
.btn.no-arrow::after{display:none}
.btn:hover::after{transform:translateX(4px)}
.btn-primary{background:var(--c-ink);color:var(--c-bg);border-color:var(--c-ink)}
.btn-primary:hover{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.btn-accent{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.btn-accent:hover{background:var(--c-primary-dk);border-color:var(--c-primary-dk);color:#fff}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:#fff;color:var(--c-ink);border-color:#fff}
.btn-outline{background:transparent;color:var(--c-ink);border-color:var(--c-ink)}
.btn-outline:hover{background:var(--c-ink);color:var(--c-bg)}
.btn-sm{padding:.55rem 1rem;font-size:.78rem}
.btn-lg{padding:.95rem 1.75rem;font-size:var(--fs-md)}
.btn-link{padding:0;background:transparent;border:0;color:var(--c-ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:5px;text-decoration-color:var(--c-primary)}
.btn-link:hover{color:var(--c-primary)}
.btn-link::after{margin-left:.3rem}
.btn-whatsapp{
  background:rgba(20,14,10,.45);color:#fff;border-color:rgba(255,255,255,.35);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.btn-whatsapp:hover{background:rgba(20,14,10,.65);border-color:#fff;color:#fff}
.btn-whatsapp svg{display:none !important}
.btn-whatsapp::before{
  content:"";
  width:22px;height:22px;flex-shrink:0;
  background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M17.5 14.4c-.3-.2-1.8-.9-2.1-1-.3-.1-.5-.2-.7.2s-.8 1-1 1.2c-.2.2-.4.2-.7 0-.3-.2-1.3-.5-2.5-1.5-.9-.8-1.5-1.8-1.7-2.1-.2-.3 0-.5.1-.7.1-.1.3-.4.5-.6.2-.2.2-.3.3-.6.1-.2 0-.5 0-.6-.1-.2-.7-1.6-.9-2.2-.2-.6-.5-.5-.7-.5h-.6c-.2 0-.5.1-.8.4-.3.3-1.1 1-1.1 2.5s1.1 2.9 1.3 3.1c.2.2 2.2 3.4 5.4 4.7.8.3 1.4.5 1.8.7.8.2 1.5.2 2 .1.6-.1 1.8-.7 2-1.5.3-.7.3-1.4.2-1.5-.1-.1-.3-.2-.6-.4zM12 2C6.5 2 2 6.5 2 12c0 1.7.4 3.4 1.3 4.8L2 22l5.4-1.3c1.4.8 3 1.2 4.6 1.2 5.5 0 10-4.5 10-10S17.5 2 12 2zm0 18.3c-1.5 0-2.9-.4-4.1-1.1l-.3-.2-3 .8.8-2.9-.2-.3A8.3 8.3 0 0 1 3.7 12 8.3 8.3 0 0 1 12 3.7a8.3 8.3 0 0 1 8.3 8.3 8.3 8.3 0 0 1-8.3 8.3z'/></svg>") no-repeat center/contain;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M17.5 14.4c-.3-.2-1.8-.9-2.1-1-.3-.1-.5-.2-.7.2s-.8 1-1 1.2c-.2.2-.4.2-.7 0-.3-.2-1.3-.5-2.5-1.5-.9-.8-1.5-1.8-1.7-2.1-.2-.3 0-.5.1-.7.1-.1.3-.4.5-.6.2-.2.2-.3.3-.6.1-.2 0-.5 0-.6-.1-.2-.7-1.6-.9-2.2-.2-.6-.5-.5-.7-.5h-.6c-.2 0-.5.1-.8.4-.3.3-1.1 1-1.1 2.5s1.1 2.9 1.3 3.1c.2.2 2.2 3.4 5.4 4.7.8.3 1.4.5 1.8.7.8.2 1.5.2 2 .1.6-.1 1.8-.7 2-1.5.3-.7.3-1.4.2-1.5-.1-.1-.3-.2-.6-.4zM12 2C6.5 2 2 6.5 2 12c0 1.7.4 3.4 1.3 4.8L2 22l5.4-1.3c1.4.8 3 1.2 4.6 1.2 5.5 0 10-4.5 10-10S17.5 2 12 2zm0 18.3c-1.5 0-2.9-.4-4.1-1.1l-.3-.2-3 .8.8-2.9-.2-.3A8.3 8.3 0 0 1 3.7 12 8.3 8.3 0 0 1 12 3.7a8.3 8.3 0 0 1 8.3 8.3 8.3 8.3 0 0 1-8.3 8.3z'/></svg>") no-repeat center/contain;
}

/* ---------- 6. Topbar / Header ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:95;
  background:var(--c-ink);color:rgba(255,255,255,.78);
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.08em;
  padding:.45rem 0;height:32px;
  transition:transform .35s var(--ease),opacity .35s var(--ease);
}
.topbar .container{max-width:var(--container-wide);display:flex;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;align-items:center;padding:0 clamp(1rem,3vw,2rem)}
.topbar a{color:rgba(255,255,255,.78);white-space:nowrap;text-transform:uppercase}
.topbar a:hover{color:var(--c-accent)}
.topbar .row-l{display:flex;gap:var(--sp-5);flex-wrap:wrap}
body.scrolled .topbar{transform:translateY(-100%);opacity:0;pointer-events:none}

.site-header{
  position:fixed;top:32px;left:0;right:0;z-index:100;
  background:rgba(253,251,247,.88);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:top .35s var(--ease),background .25s,border-color .25s,box-shadow .25s;
}
body:not(.has-topbar) .site-header{top:0}
body.scrolled .site-header{
  top:0;
  background:rgba(253,251,247,.96);
  border-bottom-color:var(--c-line);
  box-shadow:0 6px 24px rgba(20,17,13,.05);
}
.site-header .container{max-width:var(--container-wide);padding:0 clamp(1rem,3vw,2.25rem)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:var(--sp-5);flex-wrap:nowrap}

.brand{display:flex;align-items:center;gap:.55rem;color:var(--c-ink);flex-shrink:0;min-width:0}
.brand img{height:40px;width:auto;flex-shrink:0}
.brand-text{font-family:var(--ff-head);font-size:1.05rem;font-weight:500;line-height:1.02;letter-spacing:-.015em;white-space:nowrap}
.brand-text small{display:block;font-family:var(--ff-mono);font-size:.62rem;color:var(--c-mute);font-weight:400;letter-spacing:.18em;text-transform:uppercase;white-space:nowrap;margin-top:3px}
@media (max-width:560px){.brand-text{display:none}}

.nav{display:flex;align-items:center;gap:2px;flex-wrap:nowrap;min-width:0}
.nav > li{position:relative;flex-shrink:0}
.nav a{
  display:inline-block;padding:.6rem .75rem;position:relative;
  color:var(--c-ink);font-weight:500;font-size:.82rem;
  letter-spacing:.005em;white-space:nowrap;
}
.nav a::before{
  content:"";position:absolute;left:.75rem;right:.75rem;bottom:6px;height:1px;
  background:var(--c-primary);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav a:hover::before,.nav a.active::before{transform:scaleX(1)}
.nav a:hover,.nav a.active{color:var(--c-primary)}
.nav .has-sub > a::after{content:"";display:inline-block;width:6px;height:6px;margin-left:.4rem;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.5}
.sub{
  position:absolute;top:calc(100% - 4px);left:-8px;
  min-width:240px;background:var(--c-bg);
  border:1px solid var(--c-line);border-radius:var(--r-md);
  padding:.5rem;box-shadow:var(--sh-lg);
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:all .22s var(--ease);z-index:200;
}
.has-sub:hover > .sub,.has-sub:focus-within > .sub{opacity:1;visibility:visible;transform:translateY(0)}
.sub li{position:relative}
.sub a{display:block;font-size:.82rem;padding:.55rem .75rem;white-space:normal;border-radius:var(--r-sm);color:var(--c-ink)}
.sub a::before{display:none}
.sub a:hover{background:var(--c-bg-soft);color:var(--c-ink)}
/* Submenu indicator arrow */
.sub .has-sub > a{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.sub .has-sub > a::after{
  content:"";width:6px;height:6px;margin:0;flex-shrink:0;
  border-right:1px solid currentColor;border-bottom:1px solid currentColor;
  transform:rotate(-45deg);opacity:.5;
}
/* Nested submenu — opens to the right of its parent */
.sub .sub{
  top:-6px;left:calc(100% + 4px);transform:translateX(6px);
  min-width:280px;max-height:70vh;overflow-y:auto;
}
.sub .has-sub:hover > .sub,.sub .has-sub:focus-within > .sub{transform:translateX(0)}
/* Flip to left when near viewport right edge */
.sub .has-sub.flip-left > .sub{left:auto;right:calc(100% + 4px);transform:translateX(-6px)}
.sub .has-sub.flip-left:hover > .sub,.sub .has-sub.flip-left:focus-within > .sub{transform:translateX(0)}
/* Mobile: nested subs flow naturally */
@media (max-width:1023px){
  .sub .sub{position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:0;padding:0 0 .4rem 1rem;background:transparent;max-height:none}
}

.nav-cta{display:flex;align-items:center;gap:var(--sp-4);flex-shrink:0}
.nav-phone{
  font-family:var(--ff-mono);font-size:.7rem;color:var(--c-mute);
  font-weight:400;line-height:1.2;letter-spacing:.08em;text-align:right;
  white-space:nowrap;text-transform:uppercase;padding-right:var(--sp-2);
  border-right:1px solid var(--c-line);
}
.nav-phone strong{font-family:var(--ff-body);color:var(--c-ink);display:block;font-size:.88rem;letter-spacing:.01em;text-transform:none;font-weight:500;margin-top:2px}
.burger{display:none;width:40px;height:40px;border-radius:var(--r-sm);border:1px solid var(--c-line);background:transparent;position:relative;flex-shrink:0;cursor:pointer}
.burger span{position:absolute;left:10px;right:10px;height:1px;background:var(--c-ink);transition:.25s}
.burger span:nth-child(1){top:14px}
.burger span:nth-child(2){top:19px}
.burger span:nth-child(3){top:24px}
.burger.open span:nth-child(1){top:19px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:19px;transform:rotate(-45deg)}

@media (max-width:1279px){.nav-phone{display:none}}
@media (max-width:1199px){.nav a{padding:.55rem .55rem;font-size:.78rem}.brand img{height:36px}}
@media (max-width:1023px){
  .nav{display:none}
  .burger{display:flex;align-items:center;justify-content:center}
  /* When mobile menu is open, drop header's backdrop-filter — it creates a containing block
     that traps the fixed .nav.mobile-open inside the 76px header box. */
  body.nav-open .site-header{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav.mobile-open{
    display:flex;position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
    flex-direction:column;align-items:stretch;gap:0;z-index:99;
    background:var(--c-bg);padding:var(--sp-5) clamp(1rem,3vw,2rem);overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  body.scrolled .nav.mobile-open,
  body:not(.has-topbar) .nav.mobile-open{top:var(--header-h)}
  .nav.mobile-open > li{border-bottom:1px solid var(--c-line);flex-shrink:0}
  .nav.mobile-open a{padding:1.1rem 0;font-size:var(--fs-lg);font-family:var(--ff-head);font-weight:400;white-space:normal}
  .nav.mobile-open a::before{display:none}
  .nav.mobile-open .sub{
    position:static;opacity:1;visibility:visible;transform:none;
    box-shadow:none;border:0;background:transparent;
    display:none;padding:0;
  }
  .nav.mobile-open .has-sub.open-sub > .sub{
    display:block;padding:.2rem 0 .8rem 1rem;
  }
  .nav.mobile-open .sub a{font-size:.95rem;font-family:var(--ff-body);padding:.55rem 0}
  /* Caret indicator rotates when submenu is open */
  .nav.mobile-open .has-sub > a::after{transition:transform .2s}
  .nav.mobile-open .has-sub.open-sub > a::after{transform:rotate(225deg) translateY(-2px)}
}

body{padding-top:calc(var(--header-h) + 32px)}
body:not(.has-topbar){padding-top:var(--header-h)}
@media (max-width:640px){
  .topbar{display:none}
  body.has-topbar{padding-top:var(--header-h)}
  body.has-topbar .site-header{top:0}
  .hero{padding-top:var(--header-h);margin-top:calc(-1 * var(--header-h))}
  .page-hero{padding-top:calc(var(--header-h) + 2rem);margin-top:calc(-1 * var(--header-h))}
}

/* ---------- 7. Hero — editorial, asymmetric ---------- */
.hero{
  position:relative;min-height:calc(100vh - 32px);
  display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;
  margin-top:calc(-1 * (var(--header-h) + 32px));
  padding:calc(var(--header-h) + 32px) 0 clamp(3rem,6vw,5rem);
  isolation:isolate;
}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg .slide{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 1.6s var(--ease-in-out);
  transform:scale(1.05);animation:none;
  contain:paint;
}
.hero-bg .slide.active{opacity:1;animation:kenburns 9s var(--ease-in-out) forwards}
/* On first paint (before JS runs) make sure the active slide is visible
   so Lighthouse can detect the LCP element. */
.hero-bg .slide.active{will-change:opacity}
.hero-bg::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(10,8,5,.45) 0%,rgba(10,8,5,.15) 40%,rgba(10,8,5,.82) 100%),
    linear-gradient(90deg,rgba(10,8,5,.5) 0%,transparent 60%);
}
@keyframes kenburns{from{transform:scale(1.05) translate(0,0)}to{transform:scale(1.14) translate(-1.5%,-1.2%)}}

.slide-dots{
  position:absolute;right:clamp(1.25rem,2.5vw,2rem);top:50%;transform:translateY(-50%);
  z-index:3;display:flex;flex-direction:column;gap:12px;padding:14px 10px;
  background:rgba(10,8,5,.3);backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.14);
}
.slide-dots .dot{
  width:8px;height:8px;border-radius:50%;padding:0;
  background:rgba(255,255,255,.4);border:0;cursor:pointer;
  transition:height .4s var(--ease),background .25s,transform .25s;
  flex-shrink:0;
}
.slide-dots .dot:hover{background:rgba(255,255,255,.8);transform:scale(1.2)}
.slide-dots .dot.active{background:var(--c-accent);height:28px;border-radius:var(--r-pill);transform:none}
@media (max-width:768px){.slide-dots{right:.8rem;padding:10px 8px}}
.hero-inner{position:relative;z-index:1;width:100%;display:grid;grid-template-columns:1fr;gap:var(--sp-6);align-items:end;padding-top:var(--sp-8);padding-bottom:var(--sp-10)}
.hero-l{max-width:760px}
.hero h1,.hero .display{color:#fff;margin-bottom:var(--sp-4);letter-spacing:-.025em;text-shadow:0 2px 40px rgba(0,0,0,.3)}
.hero .eyebrow{color:var(--c-accent);margin-top:var(--sp-6);margin-bottom:var(--sp-5)}
.hero .eyebrow::before{background:var(--c-accent)}
.hero p{font-size:var(--fs-lg);max-width:540px;color:rgba(255,255,255,.92);margin-bottom:var(--sp-6)}
.hero-actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;align-items:center}
.hero-actions .btn-ghost{background:rgba(255,255,255,.08);backdrop-filter:blur(6px)}

/* Hero meta badges (inline under hero-actions) */
.hero-meta{
  margin-top:var(--sp-8);padding-top:var(--sp-5);
  border-top:1px solid rgba(255,255,255,.2);
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.7);display:flex;gap:var(--sp-8);flex-wrap:wrap;
}
.hero-meta span strong{display:block;font-family:var(--ff-head);font-size:1.6rem;color:#fff;font-weight:400;letter-spacing:-.01em;margin-top:6px;text-transform:none;letter-spacing:-.02em}

.hero-scroll{
  position:absolute;right:clamp(1.1rem,2.3vw,1.8rem);bottom:clamp(1.5rem,3vw,2.5rem);
  z-index:2;color:rgba(255,255,255,.72);
  font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  writing-mode:vertical-rl;transform:rotate(180deg);
  display:flex;align-items:center;gap:.75rem;padding:.5rem 0;
}
.hero-scroll::after{
  content:"";width:1px;height:40px;background:rgba(255,255,255,.5);
  animation:line-pulse-v 2.4s infinite;
}
@keyframes line-pulse-v{0%,100%{transform:scaleY(1);opacity:.5}50%{transform:scaleY(1.5);opacity:1}}
@media (max-width:768px){.hero-scroll{display:none}}

/* ---------- 8. Search bar — floating booking card ---------- */
.search-wrap{
  position:relative;z-index:10;
  margin-top:-64px;margin-bottom:var(--sp-8);
}
.search-bar{
  background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--r-pill);
  padding:10px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:0;
  box-shadow:0 20px 60px rgba(20,17,13,.12),0 6px 20px rgba(20,17,13,.06);
  align-items:stretch;
}
.search-bar .field{
  padding:.85rem 1.2rem;position:relative;
  display:flex;align-items:center;gap:.9rem;min-width:0;
}
.search-bar .field + .field::before{
  content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:var(--c-line);
}
.search-bar .f-icon{
  width:34px;height:34px;border-radius:50%;flex-shrink:0;
  background:var(--c-bg-soft);color:var(--c-primary);
  display:inline-flex;align-items:center;justify-content:center;
}
.search-bar .f-icon svg{width:16px;height:16px}
.search-bar .f-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.search-bar label{
  display:block;font-family:var(--ff-mono);font-size:.64rem;
  color:var(--c-mute);text-transform:uppercase;letter-spacing:.14em;
  margin-bottom:3px;font-weight:500;
}
.search-bar select,.search-bar input{
  width:100%;border:0;font-family:inherit;font-weight:500;
  font-size:.92rem;color:var(--c-ink);background:transparent;outline:none;
  padding:0;line-height:1.3;cursor:pointer;
  text-overflow:ellipsis;
}
.search-bar select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  padding-right:16px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1l4 4 4-4' stroke='%2314110d' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right center;background-size:10px 6px;
}
.search-bar input[type=number]{cursor:text}
.search-bar .btn{
  margin:0;border-radius:var(--r-pill);padding:0 1.8rem;
  font-size:.92rem;font-weight:600;letter-spacing:.01em;min-width:150px;
  display:inline-flex;align-items:center;justify-content:center;
}
.search-bar .btn::after{display:none}
@media (max-width:1100px){
  .search-bar{grid-template-columns:1fr 1fr;border-radius:var(--r-lg);padding:8px}
  .search-bar .field{padding:.75rem 1rem}
  .search-bar .field + .field::before{display:none}
  .search-bar .field:nth-child(2)::before,.search-bar .field:nth-child(4)::before{display:block}
  .search-bar .btn{grid-column:span 2;margin-top:4px;padding:.9rem 1.5rem}
}
@media (max-width:540px){
  .search-wrap{margin-top:-40px;padding:0 1rem}
  .search-bar{grid-template-columns:1fr}
  .search-bar .field + .field::before{display:none!important;}
  .search-bar .field{border-bottom:1px solid var(--c-line)}
  .search-bar .btn{grid-column:1}
}

/* ---------- 9. Tour card — premium, rounded ---------- */
.tour-card{
  position:relative;
  background:var(--c-bg);border:1px solid var(--c-line);border-radius:16px;
  overflow:hidden;transition:transform .4s var(--ease),border-color .3s,box-shadow .3s;
  display:flex;flex-direction:column;
}
.tour-card:hover{transform:translateY(-4px);border-color:transparent;box-shadow:0 12px 36px rgba(20,17,13,.1),0 30px 70px rgba(20,17,13,.06)}
.tour-card .media{
  position:relative;aspect-ratio:3/2;overflow:hidden;background:var(--c-bg-sand);
  border-radius:14px;margin:10px 10px 0;
}
.tour-card .media > a{position:absolute;inset:0;display:block}
.tour-card .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:filter .4s,opacity .5s var(--ease),transform .8s var(--ease);filter:saturate(.98)}
.tour-card:hover .media img{filter:saturate(1.05)}
/* Dual image hover-swap — primary fades out, secondary fades in */
.tour-card .media img.img-alt,
.blog-card .media img.img-alt{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;z-index:1;transition:opacity .5s var(--ease),transform .8s var(--ease);
}
.tour-card:hover .media img.img-alt,
.blog-card:hover .media img.img-alt{opacity:1;transform:scale(1.03)}
.tour-card:hover .media img:not(.img-alt),
.blog-card:hover .media img:not(.img-alt){opacity:0}
/* .dest cards keep a single static image — no hover-swap (matches editorial feel of destinations grids) */
/* Badges — pill style */
.tour-card .badge{
  position:absolute;top:12px;left:12px;z-index:3;
  background:var(--c-primary);color:#fff;
  font-family:var(--ff-body);font-size:.72rem;font-weight:600;
  letter-spacing:.02em;
  padding:.4rem .75rem;border-radius:var(--r-pill);
  box-shadow:0 4px 12px rgba(184,74,30,.25);
}
.tour-card .badge.accent{background:var(--c-ink);color:#fff;box-shadow:0 4px 12px rgba(20,17,13,.18)}
.tour-card .tag-num{display:none}
/* Heart favorite */
.tour-card .fav{
  position:absolute;top:12px;right:12px;z-index:3;
  width:38px;height:38px;border-radius:50%;padding:0;
  background:rgba(253,251,247,.95);display:flex;align-items:center;justify-content:center;
  color:var(--c-ink);box-shadow:0 2px 10px rgba(20,17,13,.12);
  transition:background .25s,color .25s,transform .25s var(--ease);cursor:pointer;border:0;
  backdrop-filter:blur(4px);
}
.tour-card .fav:hover{background:var(--c-primary);color:#fff;transform:scale(1.08)}
.tour-card .fav.active,.tour-card .fav.saved,.dest .fav.active,.dest .fav.saved,article .fav.active,article .fav.saved{background:var(--c-primary);color:#fff}
.tour-card .fav.active svg,.tour-card .fav.saved svg,.dest .fav.active svg,.dest .fav.saved svg,article .fav.active svg,article .fav.saved svg{fill:currentColor}
.tour-card .fav svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:fill .2s}
/* Media quick-action icons */
.media-actions{
  position:absolute;right:12px;bottom:12px;z-index:3;
  display:flex;gap:5px;
  opacity:0;transform:translateY(6px);transition:all .3s var(--ease);
}
.tour-card:hover .media-actions,.dest:hover .media-actions{opacity:1;transform:translateY(0)}
.media-actions a{
  width:30px;height:30px;border-radius:50%;
  background:var(--c-bg);color:var(--c-ink);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(20,17,13,.1);
  transition:background .2s,color .2s,transform .2s var(--ease);border:0;
}
.media-actions a:hover{background:var(--c-primary);color:#fff;transform:translateY(-2px)}
.media-actions a.primary{background:var(--c-primary);color:#fff}
.media-actions a.primary:hover{background:var(--c-primary-dk)}
.media-actions svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.8}
.tour-card .tag-num{
  position:absolute;bottom:var(--sp-4);left:var(--sp-4);
  color:#fff;font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.14em;
}
.tour-card .body{padding:18px 22px 22px;display:flex;flex-direction:column;flex:1;gap:var(--sp-2)}
.tour-card .meta{
  display:flex;gap:var(--sp-4);color:var(--c-mute);
  font-size:.78rem;font-weight:500;align-items:center;flex-wrap:wrap;
}
.tour-card .meta span{display:inline-flex;align-items:center;gap:.35rem}
.tour-card .meta span.m-loc::before,
.tour-card .meta span.m-days::before,
.tour-card .meta span.m-pax::before{
  content:"";display:inline-block;width:14px;height:14px;
  background:var(--c-primary);mask-position:center;mask-repeat:no-repeat;mask-size:contain;
  -webkit-mask-position:center;-webkit-mask-repeat:no-repeat;-webkit-mask-size:contain;
  opacity:.85;
}
.tour-card .meta .m-loc::before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>")}
.tour-card .meta .m-days::before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><polyline points='12 6 12 12 16 14'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><polyline points='12 6 12 12 16 14'/></svg>")}
.tour-card .meta .m-pax::before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/><circle cx='9' cy='7' r='4'/><path d='M23 21v-2a4 4 0 0 0-3-3.87'/><path d='M16 3.13a4 4 0 0 1 0 7.75'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/><circle cx='9' cy='7' r='4'/><path d='M23 21v-2a4 4 0 0 0-3-3.87'/><path d='M16 3.13a4 4 0 0 1 0 7.75'/></svg>")}
.tour-card h3{
  font-family:var(--ff-head);font-size:var(--fs-xl);margin:2px 0 4px;font-weight:500;
  letter-spacing:-.012em;line-height:1.25;
}
.tour-card h3 a{color:var(--c-ink);background-image:linear-gradient(var(--c-primary),var(--c-primary));background-repeat:no-repeat;background-size:0 1px;background-position:0 100%;transition:background-size .4s var(--ease)}
.tour-card:hover h3 a{background-size:100% 1px}
.tour-card p{color:var(--c-ink-soft);font-size:.88rem;line-height:1.55;margin:0 0 var(--sp-2)}
.tour-card .foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:var(--sp-4);margin-top:auto;
  border-top:1px solid var(--c-line);gap:var(--sp-3);
}
.tour-card .price{
  font-family:var(--ff-head);font-size:1.6rem;color:var(--c-primary);
  font-weight:500;line-height:1;letter-spacing:-.02em;
}
.tour-card .price .old{
  display:inline-block;font-family:var(--ff-body);font-size:.8rem;color:var(--c-mute);
  font-weight:400;text-decoration:line-through;margin-right:6px;letter-spacing:0;
}
.tour-card .price small{display:block;font-family:var(--ff-body);font-size:.72rem;color:var(--c-mute);font-weight:400;margin-top:4px;letter-spacing:0;text-transform:none}
.tour-card .book-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.6rem 1.15rem;border:1.5px solid var(--c-primary);color:var(--c-primary);
  border-radius:var(--r-pill);font-size:.82rem;font-weight:600;letter-spacing:.01em;
  background:transparent;transition:all .25s var(--ease);white-space:nowrap;
}
.tour-card .book-btn:hover{background:var(--c-primary);color:#fff}
.rating{color:var(--c-star);font-size:.88rem;font-weight:500;letter-spacing:.02em;display:inline-flex;align-items:center;gap:.45rem}
.rating small{color:var(--c-mute);font-weight:500;font-family:var(--ff-body);font-size:.78rem;letter-spacing:0}

/* ---------- 10. Destinations grid (bento) ---------- */
.dest-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:minmax(280px,1fr) minmax(280px,1fr);gap:var(--sp-4);min-height:600px}
.dest{
  position:relative;border-radius:var(--r-md);overflow:hidden;
  display:flex;align-items:flex-end;padding:var(--sp-6);
  color:#fff;isolation:isolate;
  border:1px solid var(--c-line);
}
.dest:first-child{grid-row:span 2}
.dest img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:filter .6s,transform .6s;filter:saturate(.9) brightness(.85)}
.dest:hover img{filter:saturate(1.05) brightness(.9);transform:scale(1.04)}
.dest::after{content:"";position:absolute;inset:0;background:linear-gradient(175deg,rgba(10,8,5,.05) 25%,rgba(10,8,5,.75));z-index:-1}
.dest .dest-body{position:relative;color:#fff;width:100%}
.dest .num{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.16em;opacity:.8;display:block;margin-bottom:var(--sp-3)}
.dest h3{color:#fff;margin-bottom:.2em;font-size:clamp(1.5rem,2.5vw,var(--fs-3xl));font-weight:400;letter-spacing:-.015em}
.dest span.cap{font-size:.78rem;opacity:.85;font-family:var(--ff-mono);letter-spacing:.12em;text-transform:uppercase;display:block}
.dest .go{display:flex;align-items:center;gap:.4rem;margin-top:var(--sp-4);font-size:.8rem;opacity:0;transform:translateY(4px);transition:.3s var(--ease);letter-spacing:.05em}
.dest:hover .go{opacity:1;transform:translateY(0)}
@media (max-width:768px){.dest-grid{grid-template-columns:1fr;grid-template-rows:none}.dest:first-child{grid-row:auto}}

/* ============================================================
   DESTINATIONS PAGE — magazine-style editorial layout
   Three rhythms: (1) Feature spread, (2) Cinematic strip, (3) Numbered index
   ============================================================ */

/* (1) Feature spread — Sahara portrait + 2 landscapes stacked beside it */
.dest-feature{
  display:grid;grid-template-columns:1.2fr 1fr;gap:var(--sp-4);
  margin-top:var(--sp-6);align-items:stretch;
}
.dest-feature .d-portrait{min-height:720px;height:100%}
.dest-feature .d-portrait h3{font-size:clamp(2.4rem,4vw,3.8rem);line-height:.95}
.dest-feature .d-landscape{min-height:0;height:100%}
.dest-feature .d-landscape h3{font-size:clamp(1.8rem,2.6vw,2.4rem)}
.dest-feature .d-right-stack{display:grid;grid-template-rows:1fr 1fr;gap:var(--sp-4);min-height:720px;height:100%}
@media (max-width:900px){
  .dest-feature{grid-template-columns:1fr;gap:var(--sp-3)}
  .dest-feature .d-portrait,.dest-feature .d-right-stack{min-height:0}
  .dest-feature .d-portrait{min-height:54vh}
  .dest-feature .d-right-stack{gap:var(--sp-3)}
  .dest-feature .d-landscape{min-height:240px}
  .dest-feature .d-portrait h3{font-size:clamp(2rem,8vw,2.8rem)}
  .dest-feature .d-landscape h3{font-size:clamp(1.5rem,5.5vw,1.9rem)}
}
@media (max-width:560px){
  .dest-feature .d-portrait{min-height:58vh;padding:var(--sp-4)}
  .dest-feature .d-landscape{min-height:220px;padding:var(--sp-4)}
  .dest-feature .d-portrait h3 br{display:none}
}

/* (2) Cinematic strip — desktop staggered grid / mobile snap carousel */
.dest-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4);
  margin-top:var(--sp-8);
}
.dest-strip{align-items:stretch}
.dest-strip .dest{min-height:460px;height:100%;padding:var(--sp-5)}
.dest-strip .dest h3{font-size:clamp(1.3rem,2vw,1.7rem)}
@media (max-width:900px){
  /* Become a horizontal snap carousel on tablet/mobile */
  .dest-strip{
    display:flex;grid-template-columns:none;gap:var(--sp-3);
    overflow-x:auto;scroll-snap-type:x mandatory;
    scroll-padding-inline:var(--sp-4);
    padding:0 var(--sp-4) var(--sp-3);
    margin-inline:calc(-1 * var(--sp-4));
    -webkit-overflow-scrolling:touch;scrollbar-width:thin;
  }
  .dest-strip::-webkit-scrollbar{height:4px}
  .dest-strip::-webkit-scrollbar-thumb{background:var(--c-line-dark);border-radius:4px}
  .dest-strip .dest{
    flex:0 0 66%;min-width:240px;min-height:340px;
    scroll-snap-align:start;margin-top:0!important;padding:var(--sp-4);
  }
}
@media (max-width:560px){
  .dest-strip .dest{flex:0 0 78%;min-height:320px}
  .dest-strip .dest h3{font-size:1.35rem}
}

/* (3) Numbered editorial index — magazine TOC with thumbs */
.dest-index{
  margin-top:var(--sp-10);
  border-top:1px solid var(--c-line-dark);
  padding-top:var(--sp-8);
}
.dest-index-head{
  display:grid;grid-template-columns:auto 1fr;gap:var(--sp-6);align-items:baseline;
  margin-bottom:var(--sp-6);
}
.dest-index-head .kicker{font-family:var(--ff-mono);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-mute)}
.dest-index-head h3{font-family:var(--ff-head);font-weight:300;font-size:clamp(1.6rem,2.4vw,2.2rem);letter-spacing:-.015em;margin:0;max-width:28ch}
.dest-list{display:grid;grid-template-columns:1fr 1fr;gap:0 var(--sp-10)}
@media (max-width:800px){.dest-list{grid-template-columns:1fr;gap:0}}
.dest-list a{
  display:grid;grid-template-columns:56px 64px 1fr auto;gap:var(--sp-4);
  align-items:center;padding:var(--sp-5) 0;
  border-bottom:1px solid var(--c-line);
  transition:background .2s,padding .2s;
  color:var(--c-ink);
}
.dest-list a:hover{background:var(--c-bg-soft);padding-inline:var(--sp-3);color:var(--c-primary)}
.dest-list .d-num{font-family:var(--ff-mono);font-size:.85rem;color:var(--c-mute);letter-spacing:.12em}
.dest-list .d-thumb{
  width:64px;height:64px;object-fit:cover;border-radius:var(--r-sm);
  filter:saturate(.95) brightness(.95);transition:filter .3s;
}
.dest-list a:hover .d-thumb{filter:saturate(1.1) brightness(1)}
.dest-list .d-meta h4{
  font-family:var(--ff-head);font-weight:400;font-size:1.15rem;
  margin:0 0 .2rem;letter-spacing:-.01em;color:inherit;
}
.dest-list .d-meta span{
  font-family:var(--ff-mono);font-size:.68rem;color:var(--c-mute);
  text-transform:uppercase;letter-spacing:.1em;
}
.dest-list .d-arrow{
  font-family:var(--ff-mono);color:var(--c-mute);opacity:0;transition:opacity .2s,transform .2s;
}
.dest-list a:hover .d-arrow{opacity:1;transform:translateX(4px);color:var(--c-primary)}
@media (max-width:640px){
  .dest-index{margin-top:var(--sp-7);padding-top:var(--sp-6)}
  .dest-index-head{grid-template-columns:1fr;gap:var(--sp-2);margin-bottom:var(--sp-5)}
  .dest-index-head h3{font-size:1.4rem}
  .dest-list a{
    grid-template-columns:36px 48px 1fr;gap:var(--sp-3);
    padding:var(--sp-4) 0;
  }
  .dest-list a:hover{padding-inline:0;background:transparent}
  .dest-list .d-thumb{width:48px;height:48px}
  .dest-list .d-num{font-size:.72rem}
  .dest-list .d-meta h4{font-size:1rem}
  .dest-list .d-meta span{font-size:.62rem}
  .dest-list .d-arrow{display:none}
}

/* ---------- 11. Feature / icon block ---------- */
.feature{
  padding:var(--sp-6) var(--sp-5);border-top:1px solid var(--c-line);
  transition:background .2s;
}
.feature:hover{background:var(--c-bg-soft)}
.feature .num{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.14em;color:var(--c-mute);margin-bottom:var(--sp-4);display:block}
.feature h4,.feature .feature-title{font-family:var(--ff-head);font-weight:400;font-size:var(--fs-xl);margin-bottom:var(--sp-2);letter-spacing:-.012em}
.feature p{color:var(--c-ink-soft);font-size:.88rem;margin:0;max-width:32ch}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--c-line)}
.feature-grid .feature + .feature{border-left:1px solid var(--c-line)}
@media (max-width:900px){.feature-grid{grid-template-columns:1fr 1fr}.feature-grid .feature:nth-child(odd){border-left:0}.feature-grid .feature:nth-child(even){border-left:1px solid var(--c-line)}}
@media (max-width:540px){.feature-grid{grid-template-columns:1fr}.feature-grid .feature{border-left:0!important}}

/* ---------- 12. Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line)}
.stat{padding:var(--sp-6) var(--sp-5);text-align:left;border-left:1px solid var(--c-line)}
.stat:first-child{border-left:0}
.stat .num{font-family:var(--ff-head);font-size:clamp(2.25rem,4vw,var(--fs-5xl));color:var(--c-ink);font-weight:300;line-height:1;letter-spacing:-.03em}
.stat .lbl{color:var(--c-mute);font-family:var(--ff-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;margin-top:var(--sp-3);display:block}
@media (max-width:720px){.stats{grid-template-columns:1fr 1fr}.stat:nth-child(3){border-left:0}.stat:nth-child(odd){border-left:0}.stat:nth-child(even){border-left:1px solid var(--c-line)}}

/* ---------- 13. Testimonials ---------- */
.testimonial{
  padding:var(--sp-6);position:relative;border-top:1px solid var(--c-line);
  display:flex;flex-direction:column;gap:var(--sp-4);
}
.testimonial .stars{color:var(--c-star);letter-spacing:.2em;font-size:.9rem}
.testimonial blockquote{
  margin:0;font-family:var(--ff-head);font-size:clamp(1.15rem,1.5vw,1.45rem);
  font-weight:400;line-height:1.4;letter-spacing:-.012em;color:var(--c-ink);
  font-style:italic;
}
.testimonial blockquote::before{content:"\201C";font-family:var(--ff-head);font-size:1em;color:var(--c-primary);margin-right:.1em}
.testimonial blockquote::after{content:"\201D";font-family:var(--ff-head);color:var(--c-primary);margin-left:.05em}
.testimonial .who{display:flex;align-items:center;gap:.75rem;margin-top:auto;padding-top:var(--sp-3);border-top:1px solid var(--c-line)}
.testimonial .who strong{display:block;color:var(--c-ink);font-weight:500;font-size:.92rem}
.testimonial .who span{font-family:var(--ff-mono);font-size:.7rem;color:var(--c-mute);text-transform:uppercase;letter-spacing:.1em;margin-top:2px;display:block}

/* ---------- 14. CTA band ---------- */
.cta-band{
  position:relative;padding:clamp(3.5rem,7vw,5.5rem) 0;color:#fff;text-align:center;
  background:#1a1510 url("../images/static/Luxury+Riads+in+Marrakech.avif") center/cover no-repeat;
  overflow:hidden;isolation:isolate;
}
.cta-band::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(20,14,10,.78) 0%,rgba(20,14,10,.62) 45%,rgba(20,14,10,.82) 100%),
    radial-gradient(ellipse at 15% 20%,rgba(200,120,80,.22) 0%,transparent 55%),
    radial-gradient(ellipse at 85% 80%,rgba(200,120,80,.16) 0%,transparent 55%);
}
.cta-band::after{
  content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(1100px,90%);height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
  z-index:-1;
}
.cta-band .container{display:flex;flex-direction:column;align-items:center;gap:1.25rem;max-width:780px}
.cta-band .container > div:first-child{display:flex;flex-direction:column;align-items:center;gap:.85rem}
.cta-band .eyebrow{color:var(--c-accent);margin-bottom:0;justify-content:center;display:inline-flex}
.cta-band .eyebrow::before{background:var(--c-accent)}
.cta-band h2{color:#fff;margin:0;max-width:22ch;font-weight:300;line-height:1.12;font-size:clamp(1.9rem,3.8vw,2.8rem)}
.cta-band p{color:rgba(255,255,255,.72);font-size:var(--fs-lg);max-width:58ch;margin:.15rem 0 0;line-height:1.5}
.cta-band .hero-actions{margin-top:.5rem;justify-content:center}
.cta-band .cta-actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;justify-content:center;margin-top:var(--sp-4)}
.cta-band .btn{min-width:180px}
.cta-band .btn-primary{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.cta-band .btn-ghost,.cta-band .btn-outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
.cta-band .btn-ghost:hover,.cta-band .btn-outline:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
.cta-band .cta-trust{display:flex;gap:var(--sp-5);flex-wrap:wrap;justify-content:center;margin-top:var(--sp-5);color:rgba(255,255,255,.55);font-size:.85rem}
.cta-band .cta-trust span{display:inline-flex;align-items:center;gap:.4em}
.cta-band .cta-trust svg{width:14px;height:14px;stroke:var(--c-accent);stroke-width:2;fill:none}
@media (max-width:720px){.cta-band .container{padding:0 var(--sp-4)}.cta-band .btn{width:100%;min-width:0}}

/* ---------- 15. Forms ---------- */
.form{display:grid;gap:var(--sp-5)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5) var(--sp-5);align-items:start}
@media (max-width:640px){.form-row{grid-template-columns:1fr;gap:var(--sp-4)}}
.field-l{display:block;min-width:0}
.field-l label{display:block;font-family:var(--ff-mono);font-size:.7rem;font-weight:500;margin-bottom:.5rem;color:var(--c-mute);text-transform:uppercase;letter-spacing:.12em}
.form input,.form select,.form textarea{
  width:100%;padding:.75rem 0;
  border:0;border-bottom:1px solid var(--c-line);
  background:transparent;font:inherit;color:var(--c-ink);
  transition:border-color .2s;border-radius:0;font-size:.95rem;
  line-height:1.35;
}
.form select{padding-right:1.5rem;background-image:linear-gradient(45deg,transparent 50%,var(--c-mute) 50%),linear-gradient(135deg,var(--c-mute) 50%,transparent 50%);background-position:calc(100% - 12px) 55%,calc(100% - 6px) 55%;background-size:6px 6px,6px 6px;background-repeat:no-repeat;appearance:none;-webkit-appearance:none}
.form input:focus,.form select:focus,.form textarea:focus{outline:0;border-bottom-color:var(--c-primary)}
.form textarea{min-height:120px;resize:vertical;padding-top:.5rem}
.form .hint{font-family:var(--ff-mono);font-size:.68rem;color:var(--c-mute);letter-spacing:.08em;text-transform:uppercase}

/* Chip multi-select (replaces native multi select for interests etc.) */
.chip-group{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}
.chip-group input[type="checkbox"]{position:absolute;opacity:0;pointer-events:none}
.chip-group label{
  display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;
  padding:.55rem .9rem;border:1px solid var(--c-line);border-radius:999px;
  font-family:var(--ff-body);font-size:.82rem;letter-spacing:0;text-transform:none;color:var(--c-ink-soft);
  background:transparent;transition:all .18s var(--ease);margin:0;
}
.chip-group label:hover{border-color:var(--c-primary);color:var(--c-primary)}
.chip-group input[type="checkbox"]:checked + label{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.chip-group input[type="checkbox"]:focus-visible + label{outline:2px solid var(--c-accent);outline-offset:2px}

.form-card{
  background:var(--c-bg);padding:clamp(1.75rem,4vw,var(--sp-8));border:1px solid var(--c-line);border-radius:var(--r-md);
  box-shadow:var(--sh-sm);max-width:720px;margin:0 auto;
}
.form-card .form-section-title{font-family:var(--ff-mono);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--c-mute);margin:0 0 var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--c-line)}
.form-card .form-section-title:not(:first-child){margin-top:var(--sp-6)}

/* Contact list used in sidebars (phone / email / address) */
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:var(--sp-3)}
.contact-list li{display:flex;align-items:center;gap:.65rem;font-size:.95rem;color:var(--c-ink-soft)}
.contact-list li svg{flex-shrink:0;color:var(--c-primary)}
.contact-list a{color:var(--c-ink);font-weight:500;word-break:break-all}
.contact-list a:hover{color:var(--c-primary)}
/* Stacked variant: each row has icon + (label stacked above value) */
.contact-list--stacked{gap:var(--sp-4)}
.contact-list--stacked li{align-items:flex-start;gap:.75rem}
.contact-list--stacked li svg{margin-top:.15rem}
.contact-list--stacked li > div{display:flex;flex-direction:column;gap:.15rem;min-width:0;flex:1}
.contact-list--stacked strong{
  font-family:var(--ff-mono);font-size:.66rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.12em;color:var(--c-mute);
}
.contact-list--stacked a,.contact-list--stacked span{
  font-family:var(--ff-body);font-size:.95rem;color:var(--c-ink);font-weight:500;
}

/* ---------- 16. Breadcrumb ---------- */
.breadcrumb{font-family:var(--ff-mono);font-size:.72rem;color:var(--c-mute);padding:var(--sp-4) 0;letter-spacing:.1em;text-transform:uppercase}
.breadcrumb a{color:var(--c-mute)}
.breadcrumb a:hover{color:var(--c-primary)}
.breadcrumb .sep{margin:0 .55rem;opacity:.5}

/* ---------- 17. Page hero ---------- */
.page-hero{
  position:relative;color:#fff;padding:calc(var(--header-h) + 32px + 5rem) 0 var(--sp-10);
  background:linear-gradient(rgba(10,8,5,.55),rgba(10,8,5,.65)),url('../images/hero/02.jpg') center/cover;
  margin-top:calc(-1 * (var(--header-h) + 32px));
  text-align:left;
}
.page-hero .container{max-width:var(--container);padding-inline:clamp(1rem,4vw,2rem)}
.page-hero h1{color:#fff;margin:0;max-width:22ch;font-weight:300;letter-spacing:-.025em;font-size:clamp(2.25rem,5vw,4.5rem)}
.page-hero p{color:rgba(255,255,255,.82);max-width:58ch;margin:var(--sp-4) 0 0;font-size:var(--fs-lg)}
.page-hero .eyebrow{color:var(--c-accent);display:block;margin-bottom:var(--sp-4)}
.page-hero .eyebrow::before{background:var(--c-accent)}
.page-hero .breadcrumb{color:rgba(255,255,255,.7);padding:0;margin-bottom:var(--sp-4)}
.page-hero .breadcrumb a{color:rgba(255,255,255,.7)}
.page-hero .breadcrumb a:hover{color:var(--c-accent)}
/* Two-column hero variant (when a page explicitly opts in) */
.page-hero--split .container{display:grid;grid-template-columns:1fr auto;gap:var(--sp-6);align-items:end}
@media (max-width:800px){.page-hero--split .container{grid-template-columns:1fr}}

/* ---------- 18. Footer ---------- */
.site-footer{background:var(--c-ink);color:rgba(255,255,255,.6);padding:var(--sp-12) 0 var(--sp-5);margin-top:var(--sp-12);position:relative}
.site-footer h4,.site-footer .footer-h{color:#fff;font-family:var(--ff-mono);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em;margin-bottom:var(--sp-5)}
.site-footer a{color:rgba(255,255,255,.6);font-size:.88rem}
.site-footer a:hover{color:var(--c-accent)}
.site-footer ul li{margin-bottom:.6rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:var(--sp-8);padding-bottom:var(--sp-8);border-bottom:1px solid rgba(255,255,255,.08)}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:500px){.footer-grid{grid-template-columns:1fr}}
.footer-about img{height:44px;margin-bottom:var(--sp-4);}
.footer-about p{max-width:38ch;line-height:1.7;font-size:.88rem}
.social{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:var(--sp-5);max-width:100%}
.social a{
  width:38px;height:38px;min-width:38px;min-height:38px;
  aspect-ratio:1 / 1;border-radius:50%;box-sizing:border-box;
  border:1px solid rgba(255,255,255,.15);
  display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);
  transition:all .25s var(--ease);
  flex:0 0 auto;
}
.social a svg{width:16px;height:16px;flex-shrink:0}
.social a:hover{background:var(--c-accent);color:var(--c-ink);border-color:var(--c-accent);transform:translateY(-2px)}
/* TripAdvisor — transparent circle, white owl, centered */
.social a.ta{background:transparent;border-color:rgba(255,255,255,.15)}
.social a.ta:hover{background:var(--c-accent);border-color:var(--c-accent);transform:translateY(-2px)}
.social a.ta img{width:20px;height:20px;display:block;flex-shrink:0;object-fit:contain;margin:auto;transition:opacity .25s var(--ease)}
.social a.ta:hover img{filter:brightness(0);opacity:1}
/* Tripadvisor Travellers' Choice badge — standalone award mark in footer-about */
.footer-about .ta-badge{display:inline-block;margin-top:var(--sp-5);opacity:.9;transition:opacity .25s var(--ease),transform .25s var(--ease)}
.footer-about .ta-badge:hover{opacity:1;transform:translateY(-2px)}
.footer-about .ta-badge img{display:block;width:120px;height:auto}
@media (max-width:500px){.footer-about .ta-badge img{width:104px}}
.legal{margin-top:var(--sp-6);padding-top:var(--sp-5);display:flex;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;font-family:var(--ff-mono);font-size:.7rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em}
.footer-legal-links a{color:rgba(255,255,255,.7);text-decoration:none;transition:color .2s}
.footer-legal-links a:hover{color:#fff}
.legal .codesommet-link{color:rgba(255,255,255,.7);text-decoration:none;transition:color .2s;font-size:.85em;letter-spacing:.08em}
.legal .codesommet-link:hover{color:var(--c-accent)}

/* ---------- 19. Floating WhatsApp ---------- */
.wa-float{
  position:fixed;right:20px;bottom:20px;z-index:9998;
  width:54px;height:54px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,.3);transition:transform .25s var(--ease);
}
.wa-float:hover{color:#fff;transform:scale(1.06)}
.wa-float svg{width:26px;height:26px}

/* ---------- 20. Utility ---------- */
.hide-md{display:initial}
@media (max-width:768px){.hide-md{display:none}}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.text-center{text-align:center}
.divider{height:1px;background:var(--c-line);margin:var(--sp-6) 0;border:0}
.divider-thick{height:1px;background:var(--c-ink);margin:var(--sp-8) 0;border:0;width:48px}
.num-chip{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.18em;color:var(--c-mute);text-transform:uppercase}

/* ---------- 21. Reveal (disabled — no scroll-triggered motion) ---------- */
/* Elements are always visible. Hover + click interactions still animate. */

/* ---------- 22. Detail page (booking) extras ---------- */
.detail-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:var(--sp-10);align-items:start}
@media (max-width:900px){.detail-grid{grid-template-columns:1fr}}
.booking-card{position:sticky;top:calc(var(--header-h) + 48px);background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--r-md);padding:var(--sp-6);box-shadow:var(--sh-sm)}
.booking-card .price{font-family:var(--ff-head);font-size:clamp(2rem,3vw,2.75rem);color:var(--c-ink);font-weight:400;line-height:1;letter-spacing:-.02em}
.booking-card .price small{display:block;font-family:var(--ff-mono);font-size:.7rem;color:var(--c-mute);font-weight:400;letter-spacing:.1em;text-transform:uppercase;margin-top:6px}
.itinerary{border-left:1px solid var(--c-line);padding-left:var(--sp-5);margin-left:var(--sp-3)}
.itinerary .day{position:relative;padding:var(--sp-4) 0;border-bottom:1px solid var(--c-line)}
.itinerary .day:last-child{border-bottom:0}
.itinerary .day::before{content:"";position:absolute;left:calc(-1 * var(--sp-5) - 5px);top:calc(var(--sp-4) + .6rem);width:9px;height:9px;border-radius:50%;background:var(--c-bg);border:2px solid var(--c-primary)}
.itinerary .day h4{margin:0 0 .3rem;color:var(--c-mute);font-family:var(--ff-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;font-weight:500}
.itinerary .day h3{font-family:var(--ff-head);font-weight:400;font-size:var(--fs-xl);margin-bottom:.4em}
.pill{display:inline-block;padding:.35rem .8rem;border:1px solid var(--c-line);background:var(--c-bg);color:var(--c-ink);font-size:.78rem;margin:0 .3rem .3rem 0;font-family:var(--ff-mono);letter-spacing:.06em}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:6px;border-radius:var(--r-md);overflow:hidden;max-height:560px}
.gallery img{width:100%;height:100%;object-fit:cover;min-height:160px;transition:transform .6s var(--ease)}
.gallery img:hover{transform:scale(1.02)}
.gallery img:first-child{grid-row:span 2}
.include-list,.exclude-list{list-style:none;padding:0;margin:0}
.include-list li,.exclude-list li{display:flex;align-items:flex-start;gap:.7rem;padding:.7rem 0;border-bottom:1px solid var(--c-line);font-size:.9rem;line-height:1.5}
.include-list li::before,.exclude-list li::before{flex:0 0 auto;display:inline-block;width:1.1rem;text-align:center;font-weight:700;line-height:1.5}
.include-list li::before{content:"\2713";color:var(--c-success)}
.exclude-list li::before{content:"\2715";color:#b00}

/* ---------- 23. Blog / Journal cards — GSAP-style glass hover ---------- */
.blog-card{
  background:var(--c-bg);border-top:1px solid var(--c-line);
  display:flex;flex-direction:column;gap:var(--sp-4);
  padding:var(--sp-5) 0;transition:transform .5s var(--ease);
}
.blog-card:hover{transform:translateY(-4px)}
.blog-card .media{
  aspect-ratio:16/10;overflow:hidden;background:var(--c-bg-sand);
  position:relative;border-radius:14px;isolation:isolate;
  cursor:pointer;
}
.blog-card .media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease),filter .6s;filter:saturate(.95) brightness(.96);
}
.blog-card:hover .media img{filter:saturate(1.05) brightness(1.02)}
/* Glass overlay that reveals on hover */
.blog-card .media::before{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,transparent 30%,rgba(184,74,30,.65) 100%);
  opacity:0;transition:opacity .5s var(--ease);pointer-events:none;
}
.blog-card .media::after{
  content:"Read the story →";position:absolute;inset:auto 0 0 0;z-index:3;
  padding:1rem 1.25rem;
  background:rgba(253,251,247,.15);backdrop-filter:blur(14px) saturate(160%);
  -webkit-backdrop-filter:blur(14px) saturate(160%);
  color:#fff;font-family:var(--ff-mono);font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  border-top:1px solid rgba(255,255,255,.3);
  transform:translateY(110%);transition:transform .55s var(--ease);
  pointer-events:none;
}
.blog-card:hover .media::before{opacity:1}
.blog-card:hover .media::after{transform:translateY(0)}
.blog-card .cat{
  position:absolute;top:var(--sp-3);left:var(--sp-3);z-index:4;
  background:var(--c-bg);color:var(--c-ink);
  font-family:var(--ff-mono);font-size:.62rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  padding:.35rem .7rem;border-radius:var(--r-pill);
  box-shadow:0 2px 8px rgba(20,17,13,.1);
}
.blog-card .meta{
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--c-mute);
  display:flex;gap:var(--sp-4);align-items:center;
}
.blog-card .meta span + span::before{content:"·";margin-right:var(--sp-4);opacity:.6}
.blog-card h3{
  font-family:var(--ff-head);font-weight:400;
  font-size:clamp(1.15rem,1.6vw,1.45rem);
  line-height:1.25;letter-spacing:-.012em;margin:0;
}
.blog-card h3 a{color:var(--c-ink);background-image:linear-gradient(var(--c-primary),var(--c-primary));background-repeat:no-repeat;background-size:0 1px;background-position:0 100%;transition:background-size .4s var(--ease)}
.blog-card:hover h3 a{background-size:100% 1px}
.blog-card p{color:var(--c-ink-soft);font-size:.9rem;line-height:1.6;margin:0}
.blog-card .read{
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-ink);margin-top:auto;display:inline-flex;align-items:center;gap:.5rem;
}
.blog-card .read::after{content:"→";transition:transform .3s var(--ease)}
.blog-card:hover .read::after{transform:translateX(4px)}
.blog-card .read:hover{color:var(--c-primary)}

/* ---------- 28. Carousel (responsive cards/slide) ---------- */
.carousel{
  position:relative;
  --cards:4;
  --gap:var(--sp-5);
}
@media (max-width:1200px){.carousel{--cards:3}}
@media (max-width:800px){.carousel{--cards:2}}
@media (max-width:520px){.carousel{--cards:1}}
/* Detail-page "Related tours" carousel: 2 cards desktop, 1 on mobile, with dots */
.carousel[data-per-lg="3"]{--cards:2}
@media (max-width:560px){.carousel[data-per-lg="3"]{--cards:1}}

.carousel-track{
  display:grid;grid-auto-flow:column;
  grid-auto-columns:calc((100% - (var(--cards) - 1) * var(--gap)) / var(--cards));
  gap:var(--gap);
  overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:4px 4px 24px;
  scrollbar-width:none;-ms-overflow-style:none;
}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-track > *{scroll-snap-align:start;min-width:0}

/* Prev/Next buttons */
.carousel-btn{
  position:absolute;top:40%;transform:translateY(-50%);z-index:5;
  width:46px;height:46px;border-radius:50%;
  background:var(--c-bg);color:var(--c-ink);border:1px solid var(--c-line);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(20,17,13,.1);cursor:pointer;
  transition:background .25s,color .25s,transform .25s var(--ease),opacity .3s;
  opacity:.95;
}
.carousel-btn:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary);transform:translateY(-50%) scale(1.06)}
.carousel-btn.prev{left:-22px}
.carousel-btn.next{right:-22px}
.carousel-btn svg{width:20px;height:20px}
.carousel-btn[disabled]{opacity:.35;cursor:default;pointer-events:none}
@media (max-width:900px){
  .carousel-btn.prev{left:6px}
  .carousel-btn.next{right:6px}
  .carousel-btn{width:40px;height:40px}
}
@media (max-width:520px){
  .carousel-btn{display:none}
}

/* Dots */
.carousel-dots{
  display:flex;gap:8px;justify-content:center;align-items:center;
  margin-top:var(--sp-5);
}
.carousel-dots button{
  width:8px;height:8px;border-radius:50%;padding:0;
  background:var(--c-line);border:0;cursor:pointer;
  transition:width .3s var(--ease),background .25s;
}
.carousel-dots button:hover{background:var(--c-mute)}
.carousel-dots button.active{background:var(--c-primary);width:26px;border-radius:var(--r-pill)}

/* ---------- 24. Manifesto / editorial 2-col ---------- */
.manifesto{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2.5rem,6vw,var(--sp-10));align-items:center}
.manifesto-txt h2{margin-bottom:var(--sp-5)}
.manifesto-txt h2 em{font-style:italic;color:var(--c-primary);font-weight:400}
.manifesto-txt .drop-cap{font-size:var(--fs-lg);color:var(--c-ink-soft);line-height:1.65}
.manifesto-img{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:var(--r-md);margin:0}
.manifesto-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.95);transition:transform 1.2s var(--ease)}
.manifesto:hover .manifesto-img img{transform:scale(1.03)}
.manifesto-img figcaption{
  position:absolute;left:var(--sp-4);bottom:var(--sp-4);
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;background:rgba(20,17,13,.55);padding:.4rem .7rem;backdrop-filter:blur(6px);
}
@media (max-width:860px){.manifesto{grid-template-columns:1fr}.manifesto-img{aspect-ratio:16/10}}

/* ---------- 25. Testimonial avatars ---------- */
.testimonial .who .avatar{
  width:48px;height:48px;border-radius:50%;object-fit:cover;
  border:1px solid var(--c-line);flex-shrink:0;
}

/* ---------- 26. Team / Agency section ---------- */
.agency-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5)}
@media (max-width:1024px){.agency-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.agency-grid{grid-template-columns:1fr}}
.team-card{margin:0;display:flex;flex-direction:column;gap:var(--sp-4)}
.team-card .media{aspect-ratio:4/5;overflow:hidden;border-radius:var(--r-md);background:var(--c-bg-sand)}
.team-card .media img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.03);transition:transform .8s var(--ease),filter .4s}
.team-card:hover .media img{transform:scale(1.04);filter:saturate(1.05) contrast(1.05)}
.team-card figcaption{display:flex;flex-direction:column;gap:var(--sp-2)}
.team-card .role{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-primary)}
.team-card h3{font-family:var(--ff-head);font-weight:400;font-size:var(--fs-xl);margin:0;letter-spacing:-.012em}
.team-card p{color:var(--c-ink-soft);font-size:.88rem;line-height:1.55;margin:0}

.agency-strip{
  margin-top:var(--sp-10);padding:var(--sp-6) 0;
  border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5);
}
@media (max-width:900px){.agency-strip{grid-template-columns:repeat(2,1fr);gap:var(--sp-6)}}
@media (max-width:500px){.agency-strip{grid-template-columns:1fr}}
.agency-strip > div{display:flex;flex-direction:column;gap:.4rem}
.agency-strip strong{font-family:var(--ff-head);font-weight:400;color:var(--c-ink);font-size:var(--fs-md);letter-spacing:-.008em}

/* ---------- 27. (Scroll reveals removed — content always visible) ---------- */

/* ---------- 28. Tour detail page ---------- */
.tour-head{padding:var(--sp-6) 0 var(--sp-5) !important}
.tour-crumb{display:flex;align-items:center;gap:.5rem;color:var(--c-mute);font-size:var(--fs-sm);margin-bottom:var(--sp-3);flex-wrap:wrap}
.tour-crumb a{color:var(--c-primary);text-decoration:none}
.tour-crumb a:hover{text-decoration:underline}
.tour-crumb .chev{color:var(--c-mute);opacity:.6}
.tour-crumb .current{color:var(--c-ink-soft,#555)}
.tour-title{font-size:clamp(1.8rem,3.2vw,2.6rem);line-height:1.15;margin:0 0 var(--sp-3);letter-spacing:-.01em}
.tour-tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:var(--sp-3)}
.tag-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border:1px solid var(--c-line);border-radius:var(--r-pill);background:#fff;font-size:.82rem;color:var(--c-ink);font-weight:500;white-space:nowrap}
.tour-meta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-3);margin-bottom:var(--sp-4);padding-bottom:var(--sp-4);border-bottom:1px solid var(--c-line)}
.tour-meta-left{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;color:var(--c-ink);font-size:.9rem}
.tour-meta-left .loc{display:inline-flex;align-items:center;gap:.35rem;color:var(--c-primary);font-weight:600}
.tour-meta-left .stars{color:#f5a524;letter-spacing:1px}
.tour-meta-left .rev{color:var(--c-mute);font-size:.82rem;margin-left:.25rem}
.tour-actions{display:flex;align-items:center;gap:var(--sp-4)}
.tour-action{display:inline-flex;align-items:center;gap:.45rem;background:none;border:0;padding:.4rem .2rem;cursor:pointer;color:var(--c-ink);font:inherit;font-size:.88rem;font-weight:500;transition:color .2s}
.tour-action:hover{color:var(--c-primary)}
.tour-action svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.tour-action.active,.tour-action.saved{color:#e63946}
.tour-action.saved svg{fill:#e63946}
.tour-actions{position:relative}
.share-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);box-shadow:var(--sh-md);padding:.45rem;display:flex;gap:.35rem;z-index:50;animation:shareIn .15s ease-out}
.share-menu a,.share-menu button{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--c-ink);background:transparent;border:0;cursor:pointer;text-decoration:none;transition:background .15s,color .15s}
.share-menu a:hover,.share-menu button:hover{background:var(--c-bg-soft);color:var(--c-primary)}
.share-menu a svg,.share-menu button svg{display:block}
@keyframes shareIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:480px){.share-menu{right:auto;left:0}}

.share-inline{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.share-inline .share-label{font-size:.85rem;color:var(--c-ink-soft);margin-right:.25rem}
.share-inline a,.share-inline button{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--c-line);background:#fff;color:var(--c-ink);cursor:pointer;text-decoration:none;transition:background .15s,color .15s,border-color .15s,transform .15s}
.share-inline a:hover,.share-inline button:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary);transform:translateY(-1px)}
.share-inline svg{width:17px;height:17px;display:block}
.share-inline .copied{position:absolute;background:var(--c-ink);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:var(--r-sm);margin-top:-2.5rem;opacity:0;pointer-events:none;transition:opacity .2s}
.share-inline .copied.show{opacity:1}

/* Pill icons — replace emoji with SVG */
.pill{display:inline-flex;align-items:center;gap:.45rem;line-height:1.2;vertical-align:middle}
.pill svg{width:15px;height:15px;flex:0 0 auto;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;opacity:.85;display:inline-block;vertical-align:middle}

/* Generic inline SVG alignment for icons injected into text (labels, meta rows,
   strong/em/span wrappers, buttons, list markers). Keeps them inline with the
   adjacent text baseline and prevents them from wrapping onto their own line. */
strong > svg:first-child,
em > svg:first-child,
label > svg:first-child,
h1 > svg:first-child,h2 > svg:first-child,h3 > svg:first-child,h4 > svg:first-child,h5 > svg:first-child,h6 > svg:first-child,
.meta svg,
.stat svg,
.btn svg,
.book-btn svg,
.brand svg,
.rating svg,
.social svg,
a.tag svg,.tag svg,
li > svg:first-child,
p > svg:first-child{
  display:inline-block;
  vertical-align:-0.18em;
  flex:0 0 auto;
}

/* Feature-card icon boxes: make the SVG fill the block nicely */
.feature > .icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:50%;
  background:var(--c-bg-soft);color:var(--c-primary);
  margin-bottom:var(--sp-3);
}
.feature > .icon svg{display:block;width:24px;height:24px;margin:0}

/* Numeric "step" icon boxes (same shell, but show the number centered) */
.feature > .icon:not(:has(svg)){
  font-family:var(--ff-head);font-size:1.2rem;font-weight:600;
}

/* Multiple stars in a row should butt together, not have per-star margin */
.stars svg,.rating svg{margin-right:2px !important;vertical-align:-2px}
.stars svg:last-child,.rating svg:last-child{margin-right:0 !important}

/* Stats blocks — SVG shouldn't block-stack inside .num */
.stat .num svg{display:inline-block;vertical-align:-3px;margin-right:.2em}

/* Meta rows (.meta span) — icons inline with text */
.meta span{display:inline-flex;align-items:center;gap:.25rem}
.meta svg{margin-right:0 !important;vertical-align:middle}

/* Book-btn arrow / button SVGs */
.btn svg,.book-btn svg,.btn-link svg{vertical-align:-2px}

.gallery{position:relative;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:12px;height:clamp(380px,46vw,560px)}
.gallery .g-item{position:relative;overflow:hidden;background:var(--c-bg-sand);border-radius:var(--r-md)}
.gallery .g-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.gallery .g-item:hover img{transform:scale(1.04)}
/* Figure wrapper — figcaption overlays bottom of main gallery image */
.gallery .g-item figure{margin:0;padding:0;position:relative;width:100%;height:100%;overflow:hidden;border-radius:inherit}
.gallery .g-item figure img{border-radius:inherit}
.gallery .g-item figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:var(--sp-6) var(--sp-5) var(--sp-4);
  background:linear-gradient(180deg,transparent 0%,rgba(10,8,5,.72) 100%);
  color:rgba(255,255,255,.92);
  font-family:var(--ff-head);font-weight:400;font-size:clamp(.88rem,1.2vw,1.05rem);
  letter-spacing:-.005em;line-height:1.35;
  pointer-events:none;
}
@media (max-width:640px){
  .gallery .g-item figcaption{padding:var(--sp-5) var(--sp-4) var(--sp-3);font-size:.82rem}
}
.gallery .g-main{grid-column:1 / span 2;grid-row:1 / span 2;border-radius:var(--r-lg)}
/* Adaptive layouts when fewer images are provided */
.gallery.g-count-1{grid-template-columns:1fr;grid-template-rows:1fr;height:clamp(320px,42vw,520px)}
.gallery.g-count-1 .g-main{grid-column:1;grid-row:1}
.gallery.g-count-2{grid-template-columns:1.6fr 1fr;grid-template-rows:1fr;height:clamp(320px,42vw,520px)}
.gallery.g-count-2 .g-main{grid-column:1;grid-row:1}
.gallery.g-count-2 .g-item:not(.g-main){grid-column:2;grid-row:1}
.gallery.g-count-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;height:clamp(360px,44vw,540px)}
.gallery.g-count-3 .g-main{grid-column:1;grid-row:1 / span 2}
.gallery.g-count-3 .g-item:nth-of-type(2){grid-column:2;grid-row:1}
.gallery.g-count-3 .g-item:nth-of-type(3){grid-column:2;grid-row:2}
.gallery.g-count-4{grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr}
.gallery.g-count-4 .g-main{grid-column:1;grid-row:1 / span 2}
.gallery.g-count-4 .g-item:nth-of-type(2){grid-column:2;grid-row:1}
.gallery.g-count-4 .g-item:nth-of-type(3){grid-column:3;grid-row:1}
.gallery.g-count-4 .g-item:nth-of-type(4){grid-column:2 / span 2;grid-row:2}
/* Detail-page galleries: cap at 2 images, regardless of how many are in markup */
.gallery .g-item:nth-of-type(n+3){display:none}
.gallery{grid-template-columns:1.6fr 1fr!important;grid-template-rows:1fr!important;height:clamp(320px,42vw,520px)!important}
.gallery .g-main{grid-column:1!important;grid-row:1!important}
.gallery .g-item:not(.g-main){grid-column:2!important;grid-row:1!important}
@media (max-width:900px){
  .gallery{grid-template-columns:1fr!important;grid-template-rows:auto auto!important;height:auto!important}
  .gallery .g-main{grid-column:1!important;aspect-ratio:16/10}
  .gallery .g-item:not(.g-main){grid-column:1!important;grid-row:2!important;aspect-ratio:16/10}
}
.gallery .g-fab{position:absolute;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);border:0;cursor:pointer;color:var(--c-ink);box-shadow:0 2px 6px rgba(0,0,0,.18);transition:transform .2s,background .2s}
.gallery .g-fab:hover{background:#fff;transform:scale(1.06)}
.gallery .g-fab svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.gallery .g-fab.fab-1{left:14px;bottom:14px}
.gallery .g-fab.fab-2{left:62px;bottom:14px}
.gallery .g-viewall{position:absolute;right:14px;bottom:14px;display:inline-flex;align-items:center;gap:.45rem;padding:.55rem 1rem;border-radius:var(--r-pill);background:#fff;border:1px solid rgba(0,0,0,.08);color:var(--c-ink);font-size:.85rem;font-weight:600;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.18);text-decoration:none;transition:transform .2s}
.gallery .g-viewall:hover{transform:scale(1.04)}
.gallery .g-viewall svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
@media (max-width:900px){
  .tour-title{font-size:clamp(1.5rem,6vw,2rem)}
  .tour-meta-row{flex-direction:column;align-items:flex-start;gap:var(--sp-2);padding-bottom:var(--sp-3)}
  .tour-actions{width:100%;justify-content:flex-start;gap:var(--sp-3)}
  .gallery{height:auto;gap:8px;grid-template-columns:repeat(2,1fr);grid-template-rows:auto auto auto}
  .gallery .g-main{grid-column:1 / span 2;grid-row:1;aspect-ratio:16/10}
  .gallery .g-item:not(.g-main){aspect-ratio:1/1}
  .gallery.g-count-1,
  .gallery.g-count-2{grid-template-columns:1fr;grid-template-rows:auto}
  .gallery.g-count-1 .g-main,
  .gallery.g-count-2 .g-main{grid-column:1;aspect-ratio:16/10}
  .gallery.g-count-2 .g-item:not(.g-main){grid-column:1;grid-row:2;aspect-ratio:16/10}
  .gallery .g-fab{width:36px;height:36px}
  .gallery .g-fab.fab-1{left:10px;bottom:10px}
  .gallery .g-fab.fab-2{left:54px;bottom:10px}
  .gallery .g-viewall{right:10px;bottom:10px;padding:.45rem .8rem;font-size:.8rem}
}
@media (max-width:480px){
  .tour-tags{gap:.4rem}
  .tag-pill{padding:.32rem .7rem;font-size:.75rem}
  .tour-meta-left{font-size:.85rem;gap:var(--sp-2)}
}

/* ==========================================================================
   Scroll Animations — editorial / cinematic
   Tasteful fade + lift + image zoom. Triggers once via IntersectionObserver.
   Respects prefers-reduced-motion.
   ========================================================================== */

/* Default easing & duration tokens */
:root{
  --anim-dur: 900ms;
  --anim-dur-fast: 600ms;
  --anim-ease: cubic-bezier(.2,.7,0,1);       /* gentle, editorial */
  --anim-ease-image: cubic-bezier(.25,.46,.45,.94);
}

/* Mark elements with .scroll-anim (JS adds .is-visible when in view).
   Default to visible — only the reveal variants (.anim-rise etc.) start hidden,
   so if the IntersectionObserver fails or never fires, content is never stuck. */
.scroll-anim{
  opacity:1;
  transform:none;
  transition:opacity var(--anim-dur) var(--anim-ease),
             transform var(--anim-dur) var(--anim-ease);
}
.scroll-anim.is-visible{
  opacity:1;
  transform:translate3d(0,0,0);
}

/* Variant: fade only (no translate) — for overlays, backgrounds */
.scroll-anim.anim-fade{transform:none}

/* Variant: rise from further down — for headlines/hero lines */
.scroll-anim.anim-rise{transform:translate3d(0,40px,0)}

/* Variant: from left / from right — editorial side-panels */
.scroll-anim.anim-left{transform:translate3d(-32px,0,0)}
.scroll-anim.anim-right{transform:translate3d(32px,0,0)}

/* Variant: soft scale + fade — used for framed images / cards */
.scroll-anim.anim-zoom{transform:scale(.96);opacity:0}
.scroll-anim.anim-zoom.is-visible{transform:scale(1);opacity:1}

/* Variant: Ken-Burns image reveal inside a figure/.media container.
   The IMG zooms from 1.08 → 1.00 while the container fades in.
   Perfect for tour hero photos, cards, destination tiles. */
.media-reveal,.figure-reveal{overflow:hidden;position:relative}
.media-reveal > img,.figure-reveal > img{
  transform:none;
  opacity:1;
  transition:transform 1600ms var(--anim-ease-image),
             opacity 900ms var(--anim-ease-image);
}
.media-reveal.is-visible > img,.figure-reveal.is-visible > img{
  transform:scale(1);
  opacity:1;
}

/* Staggered children — JS adds delays via --i custom prop */
.scroll-anim{transition-delay:calc(var(--i,0) * 80ms)}

/* Word-level fade for H1/H2 (JS splits headings into .anim-word spans).
   Default visible so headings never get stuck if the parent's .is-visible
   class is never added. The reveal still plays when the parent enters the
   viewport via IntersectionObserver. */
.anim-word{
  display:inline-block;
  opacity:1;
  transform:none;
  transition:opacity 700ms var(--anim-ease),
             transform 700ms var(--anim-ease);
  transition-delay:calc(var(--w,0) * 70ms);
}
.is-visible .anim-word{opacity:1;transform:translate3d(0,0,0)}

/* Page-hero images get Ken-Burns automatically (no opt-in needed) */
.page-hero{background-attachment:scroll !important}
.hero-img,.page-hero-img,
.g-item > img{
  transition:transform 800ms var(--anim-ease-image);
}

/* Small utility: make sure animations don't fire for users who prefer less motion */
@media (prefers-reduced-motion: reduce){
  .scroll-anim,
  .scroll-anim.anim-zoom,
  .scroll-anim.anim-rise,
  .scroll-anim.anim-left,
  .scroll-anim.anim-right,
  .media-reveal > img,
  .figure-reveal > img,
  .anim-word{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
  .tour-card:hover .media img,
  .blog-card:hover .media img,
  .dest:hover .media img{transform:none}
}


/* ---------- Toast ---------- */
.lmt-toast{position:fixed;left:50%;bottom:32px;transform:translate(-50%,20px);background:#111;color:#fff;padding:.75rem 1.25rem;border-radius:999px;font-size:.9rem;font-weight:500;box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:0;transition:opacity .25s,transform .25s;z-index:9999;pointer-events:none}
.lmt-toast.show{opacity:1;transform:translate(-50%,0)}

/* ---------- Gallery lightbox ---------- */
.lmt-lightbox{position:fixed;inset:0;background:rgba(10,10,10,.92);display:none;align-items:center;justify-content:center;z-index:10000;padding:20px}
.lmt-lightbox.open{display:flex}
.lmt-lightbox .lb-stage{margin:0;max-width:min(1200px,92vw);max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:12px}
.lmt-lightbox .lb-stage img{max-width:100%;max-height:82vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5);background:#000}
.lmt-lightbox .lb-stage figcaption{color:rgba(255,255,255,.75);font-size:.9rem;text-align:center;max-width:80ch}
.lmt-lightbox .lb-close{position:absolute;top:18px;right:20px;width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lmt-lightbox .lb-close:hover{background:rgba(255,255,255,.22)}
.lmt-lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lmt-lightbox .lb-nav:hover{background:rgba(255,255,255,.22)}
.lmt-lightbox .lb-prev{left:20px}
.lmt-lightbox .lb-next{right:20px}
.lmt-lightbox .lb-counter{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:.85rem;font-family:var(--ff-mono);letter-spacing:.05em;background:rgba(0,0,0,.3);padding:.3rem .8rem;border-radius:999px}
@media (max-width:600px){
  .lmt-lightbox .lb-nav{width:40px;height:40px}
  .lmt-lightbox .lb-prev{left:8px}
  .lmt-lightbox .lb-next{right:8px}
  .lmt-lightbox .lb-close{top:10px;right:10px;width:38px;height:38px}
}

/* ---------- Wishlist page ---------- */
.wishlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-5)}
.wishlist-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-sm);display:flex;flex-direction:column}
.wishlist-card .media{aspect-ratio:4/3;background:var(--c-bg-sand);overflow:hidden}
.wishlist-card .media img{width:100%;height:100%;object-fit:cover;display:block}
.wishlist-card .body{padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3);flex:1}
.wishlist-card h3{font-size:var(--fs-lg);margin:0;line-height:1.3}
.wishlist-card h3 a{color:var(--c-ink);text-decoration:none}
.wishlist-card h3 a:hover{color:var(--c-primary)}
.wishlist-card .card-actions{display:flex;gap:var(--sp-3);margin-top:auto;align-items:center;justify-content:space-between}
.wishlist-card .remove-btn{background:none;border:0;color:var(--c-mute);cursor:pointer;font:inherit;font-size:.85rem;padding:0}
.wishlist-card .remove-btn:hover{color:#e63946}
.wishlist-empty{text-align:center;padding:var(--sp-10) var(--sp-5);color:var(--c-mute)}

/* Header wishlist badge */
[data-wishlist-count]{display:none;background:var(--c-primary);color:#fff;border-radius:999px;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;align-items:center;justify-content:center;margin-left:4px}

/* ---------- Floating wishlist FAB + panel ---------- */
.wishlist-fab{position:fixed;right:20px;bottom:92px;z-index:9998;width:52px;height:52px;border-radius:50%;border:0;background:#fff;box-shadow:0 6px 20px rgba(0,0,0,.18);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#e63946;transition:transform .2s,box-shadow .2s}
.wishlist-fab:hover{transform:scale(1.06);box-shadow:0 10px 28px rgba(0,0,0,.22)}
.wishlist-fab svg{width:22px;height:22px;fill:currentColor;stroke:#e63946;stroke-width:1.5;transition:fill .2s}
.wishlist-fab.active svg,.wishlist-fab svg{fill:#e63946}
.wishlist-fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#e63946;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
@media (max-width:600px){
  .wishlist-fab{right:14px;bottom:84px;width:48px;height:48px}
  .wishlist-fab svg{width:20px;height:20px}
}

.wishlist-panel{position:fixed;right:20px;bottom:156px;z-index:9999;width:min(360px,calc(100vw - 40px));max-height:min(520px,calc(100vh - 200px));background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.25);display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(10px) scale(.98);pointer-events:none;transition:opacity .2s,transform .2s}
.wishlist-panel.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.wl-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--c-line)}
.wl-panel-head h3{margin:0;font-size:var(--fs-lg);font-family:var(--ff-head)}
.wl-close{background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--c-mute);padding:0 4px}
.wl-close:hover{color:var(--c-ink)}
.wl-panel-body{flex:1;overflow-y:auto;padding:8px}
.wl-empty{padding:32px 20px;text-align:center;color:var(--c-mute)}
.wl-empty p{margin:0 0 6px}
.wl-empty-sub{font-size:.85rem}
.wl-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:10px;text-decoration:none;color:var(--c-ink);transition:background .15s}
.wl-item:hover{background:var(--c-bg-sand)}
.wl-item img{width:56px;height:56px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--c-bg-sand)}
.wl-item-title{flex:1;font-size:.9rem;line-height:1.3;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.wl-item-remove{background:none;border:0;font-size:20px;color:var(--c-mute);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}
.wl-item-remove:hover{background:rgba(230,57,70,.1);color:#e63946}
.wl-panel-foot{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--c-line);background:var(--c-bg-sand)}
.wl-panel-foot .btn{flex:1;text-align:center;justify-content:center}
@media (max-width:600px){
  .wishlist-panel{right:10px;left:10px;bottom:140px;width:auto;max-width:none}
}

/* ---------- Red heart for wishlist buttons ---------- */
.tour-action[data-wishlist] svg{transition:fill .2s,stroke .2s,color .2s}
.tour-action[data-wishlist]:hover{color:#e63946}
.tour-action[data-wishlist]:hover svg{stroke:#e63946}
.tour-action[data-wishlist].saved,
.tour-action[data-wishlist].active{color:#e63946}
.tour-action[data-wishlist].saved svg,
.tour-action[data-wishlist].active svg{fill:#e63946;stroke:#e63946}

/* ---------- Tours listing: sidebar + grid ---------- */
.tours-listing{display:grid;grid-template-columns:280px 1fr;gap:var(--sp-7);align-items:start}
@media (max-width:900px){.tours-listing{grid-template-columns:1fr;gap:var(--sp-5)}}

.tours-sidebar{position:sticky;top:calc(var(--header-h) + 32px);background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:var(--sp-5);box-shadow:var(--sh-sm)}
@media (max-width:900px){
  .tours-sidebar{position:static;display:none;border-radius:var(--r-md)}
  .tours-sidebar.open{display:block}
}
.ts-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}
.ts-head h3{margin:0;font-family:var(--ff-head);font-size:var(--fs-xl)}
.ts-clear{background:none;border:0;color:var(--c-primary);cursor:pointer;font:inherit;font-size:.85rem;padding:0;text-decoration:underline}
.ts-clear:hover{color:var(--c-ink)}
.ts-group{margin-bottom:var(--sp-5);padding-bottom:var(--sp-4);border-bottom:1px solid var(--c-line)}
.ts-group:last-child{border-bottom:0;padding-bottom:0}
.ts-group h4{margin:0 0 var(--sp-3);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--c-mute)}
.ts-group label{display:flex;align-items:center;gap:.55rem;padding:.3rem 0;font-size:.9rem;cursor:pointer;color:var(--c-ink)}
.ts-group label:hover{color:var(--c-primary)}
.ts-group input[type="checkbox"]{accent-color:var(--c-primary);width:15px;height:15px}
.ts-group select{width:100%;padding:.55rem .7rem;border:1px solid var(--c-line);border-radius:var(--r-sm,6px);background:#fff;font:inherit;font-size:.9rem;cursor:pointer}
.ts-group input[type="range"]{width:100%;accent-color:var(--c-primary)}
.ts-price-val{font-size:.85rem;color:var(--c-mute);text-align:right;margin-top:.3rem;font-family:var(--ff-mono)}
.ts-help p{margin:0;font-size:.85rem;color:var(--c-mute)}
.ts-help a{color:var(--c-primary);text-decoration:underline}

.tours-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4);flex-wrap:wrap;gap:var(--sp-3)}
.ts-count{font-size:.9rem;color:var(--c-mute)}
.ts-count strong{color:var(--c-ink);font-weight:700}
.ts-filter-toggle{display:none;background:var(--c-ink);color:#fff;border:0;padding:.55rem 1.2rem;border-radius:999px;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer}
@media (max-width:900px){.ts-filter-toggle{display:inline-block}}

.ts-empty{text-align:center;padding:var(--sp-10) var(--sp-4);color:var(--c-mute)}
.ts-empty h3{color:var(--c-ink);font-family:var(--ff-head)}
.ts-empty a{color:var(--c-primary)}

.tour-card[hidden]{display:none}

/* ---------- Custom dropdown (replaces native <select> chrome) ---------- */
/* Z-index strategy: parent field-l gets position:relative + z-index:auto, opened dropdown rises */
.field-l:has(.lmt-select[aria-expanded="true"]){position:relative;z-index:50}
.form-row:has(.lmt-select[aria-expanded="true"]){position:relative;z-index:50}
.lmt-select{position:relative;width:100%;font-family:inherit;z-index:1}
.lmt-select[aria-expanded="true"]{z-index:60}
.lmt-select__native{position:absolute;inset:0;width:100%;height:100%;opacity:0;pointer-events:none;appearance:none;-webkit-appearance:none}
.lmt-select__btn{
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;width:100%;
  background:transparent;border:0;padding:0;margin:0;cursor:pointer;
  font:inherit;font-weight:500;font-size:.92rem;color:var(--c-ink);
  line-height:1.3;text-align:left;outline:none;
}
.lmt-select__btn:focus-visible{outline:2px solid var(--c-primary);outline-offset:3px;border-radius:4px}
.lmt-select__value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lmt-select__chev{flex-shrink:0;width:12px;height:12px;color:var(--c-ink);transition:transform .2s var(--ease)}
.lmt-select[aria-expanded="true"] .lmt-select__chev{transform:rotate(180deg)}
.lmt-select__menu{
  position:absolute;top:calc(100% + 10px);left:-14px;right:-14px;z-index:1000;
  background:#fff;border:1px solid var(--c-line);border-radius:14px;
  box-shadow:0 20px 50px rgba(20,17,13,.14),0 6px 18px rgba(20,17,13,.06);
  padding:6px;max-height:280px;overflow-y:auto;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s var(--ease),transform .18s var(--ease),visibility .18s;
}
.lmt-select[aria-expanded="true"] .lmt-select__menu{opacity:1;visibility:visible;transform:translateY(0)}
.lmt-select__opt{
  display:flex;align-items:center;gap:.6rem;
  padding:.6rem .85rem;border-radius:10px;cursor:pointer;
  font-size:.9rem;color:var(--c-ink);line-height:1.3;
  transition:background-color .15s var(--ease),color .15s var(--ease);
  user-select:none;
}
.lmt-select__opt:hover{background:var(--c-bg-soft)}
.lmt-select__opt[aria-selected="true"]{
  background:var(--c-bg-soft);color:var(--c-primary);font-weight:600;
}
.lmt-select__opt[aria-selected="true"]::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--c-primary);flex-shrink:0;
}
.lmt-select__opt.is-focused{background:var(--c-bg-soft)}

/* Hide native arrow on enhanced selects inside search-bar (we draw our own chevron) */
.search-bar .lmt-select .lmt-select__btn{background-image:none;padding-right:0}

.lmt-select__menu::-webkit-scrollbar{width:8px}
.lmt-select__menu::-webkit-scrollbar-thumb{background:var(--c-line);border-radius:8px}
.lmt-select__menu::-webkit-scrollbar-thumb:hover{background:var(--c-mute)}

/* Standalone (outside search-bar) — give it a visible field chrome */
.lmt-select.is-standalone .lmt-select__btn{
  border:1px solid var(--c-line);border-radius:10px;
  padding:.6rem .85rem;background:#fff;
}
.lmt-select.is-standalone .lmt-select__btn:hover{border-color:var(--c-ink)}
.lmt-select.is-standalone[aria-expanded="true"] .lmt-select__btn{border-color:var(--c-primary)}
.lmt-select.is-standalone .lmt-select__menu{left:0;right:0}

@media (max-width:540px){
  .lmt-select__menu{left:0;right:0}
}

/* ---------- Custom date picker ---------- */
/* Date picker z-index strategy mirrors .lmt-select */
.field-l:has(.lmt-date[aria-expanded="true"]){position:relative;z-index:50}
.form-row:has(.lmt-date[aria-expanded="true"]){position:relative;z-index:50}
.lmt-date{position:relative;width:100%;font-family:inherit;z-index:1}
.lmt-date[aria-expanded="true"]{z-index:60}
.lmt-date__native{position:absolute;inset:0;width:100%;height:100%;opacity:0;pointer-events:none;appearance:none;-webkit-appearance:none}
.lmt-date__btn{
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;width:100%;
  background:#fff;border:1px solid var(--c-line);border-radius:10px;
  padding:.65rem .9rem;cursor:pointer;
  font:inherit;font-weight:500;font-size:.95rem;color:var(--c-ink);
  line-height:1.3;text-align:left;outline:none;
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease);
}
.lmt-date__btn:hover{border-color:var(--c-ink)}
.lmt-date__btn:focus-visible{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(193,86,47,.15)}
.lmt-date[aria-expanded="true"] .lmt-date__btn{border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(193,86,47,.15)}
.lmt-date__value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lmt-date__value.is-placeholder{color:var(--c-mute);font-weight:400}
.lmt-date__ico{flex-shrink:0;width:18px;height:18px;color:var(--c-mute)}
.lmt-date[aria-expanded="true"] .lmt-date__ico{color:var(--c-primary)}

.lmt-date__pop{
  position:absolute;top:calc(100% + 10px);left:0;z-index:1000;
  width:300px;max-width:calc(100vw - 24px);
  background:#fff;border:1px solid var(--c-line);border-radius:16px;
  box-shadow:0 24px 60px rgba(20,17,13,.16),0 8px 24px rgba(20,17,13,.08);
  padding:14px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s var(--ease),transform .18s var(--ease),visibility .18s;
}
.lmt-date[aria-expanded="true"] .lmt-date__pop{opacity:1;visibility:visible;transform:translateY(0)}

.lmt-date__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:.5rem}
.lmt-date__title{
  font-family:var(--ff-head);font-size:1rem;font-weight:600;color:var(--c-ink);
  background:transparent;border:0;padding:.3rem .5rem;margin:0;cursor:pointer;border-radius:8px;
  display:inline-flex;align-items:center;gap:.35rem;
  transition:background-color .15s var(--ease);
}
.lmt-date__title:hover{background:var(--c-bg-soft)}
.lmt-date__title svg{width:10px;height:10px}
.lmt-date__nav{display:inline-flex;gap:4px}
.lmt-date__navbtn{
  width:30px;height:30px;border-radius:8px;border:0;background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;color:var(--c-ink);
  transition:background-color .15s var(--ease);
}
.lmt-date__navbtn:hover{background:var(--c-bg-soft)}
.lmt-date__navbtn svg{width:14px;height:14px}

.lmt-date__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.lmt-date__dow{
  font-family:var(--ff-mono);font-size:.7rem;color:var(--c-mute);
  text-transform:uppercase;letter-spacing:.08em;text-align:center;padding:6px 0;
}
.lmt-date__cell{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:.88rem;color:var(--c-ink);border-radius:8px;cursor:pointer;
  border:0;background:transparent;font-family:inherit;padding:0;
  transition:background-color .15s var(--ease),color .15s var(--ease);
}
.lmt-date__cell:hover:not(:disabled){background:var(--c-bg-soft)}
.lmt-date__cell.is-outside{color:var(--c-mute);opacity:.45}
.lmt-date__cell.is-today{font-weight:700;color:var(--c-primary)}
.lmt-date__cell.is-selected{
  background:var(--c-primary);color:#fff;font-weight:600;
}
.lmt-date__cell.is-selected:hover{background:var(--c-primary)}
.lmt-date__cell:disabled{cursor:not-allowed;opacity:.3}

.lmt-date__foot{display:flex;justify-content:space-between;gap:.5rem;margin-top:10px;padding-top:10px;border-top:1px solid var(--c-line)}
.lmt-date__footbtn{
  background:transparent;border:0;cursor:pointer;padding:.35rem .6rem;border-radius:8px;
  font:inherit;font-size:.85rem;font-weight:500;color:var(--c-primary);
  transition:background-color .15s var(--ease);
}
.lmt-date__footbtn:hover{background:var(--c-bg-soft)}

/* Month/Year pickers */
.lmt-date__pick{
  display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px 0;
}
.lmt-date__pickcell{
  padding:.7rem .4rem;border-radius:8px;border:0;background:transparent;cursor:pointer;
  font:inherit;font-size:.88rem;color:var(--c-ink);
  transition:background-color .15s var(--ease),color .15s var(--ease);
}
.lmt-date__pickcell:hover{background:var(--c-bg-soft)}
.lmt-date__pickcell.is-selected{background:var(--c-primary);color:#fff;font-weight:600}

@media (max-width:540px){
  .lmt-date__pop{left:0;right:0;width:auto}
}

/* ==========================================================================
   Responsive Refinement — Tablet + Mobile polish (v2)
   Consolidated mobile/tablet improvements layered on top of earlier rules.
   Breakpoints: 1024 (tablet L) · 900 (tablet) · 768 (tablet P) · 640 (large mobile)
                540 (mobile) · 420 (small mobile)
   ========================================================================== */

/* Global: prevent horizontal overflow on any viewport */
html,body{overflow-x:hidden;max-width:100%}
img,video,iframe{max-width:100%}

/* Containers: tighter gutters on mobile */
@media (max-width:640px){
  .container,.container-wide,.container-narrow{padding-left:1rem;padding-right:1rem}
  .section{padding:clamp(2.25rem,8vw,3.5rem) 0}
  .section-sm{padding:clamp(1.5rem,5vw,2rem) 0}
}

/* ---------- Topbar / Header on tablet + mobile ---------- */
@media (max-width:1023px){
  .topbar{font-size:.62rem;padding:.35rem 0;height:auto;min-height:28px}
  .topbar .container{gap:.75rem;justify-content:center;padding:0 .9rem}
  .topbar .row-l{gap:.9rem;justify-content:center}
  body{padding-top:calc(var(--header-h) + 32px)}
  :root{--header-h:64px}
  .site-header .container{padding:0 1rem}
  .site-header .bar{height:var(--header-h);gap:.6rem}
  .brand img{height:34px}
  .brand-text{display:none}
  .nav-cta{gap:.5rem}
  .nav-cta .btn{padding:.5rem .9rem;font-size:.72rem}
}
@media (max-width:640px){
  :root{--header-h:60px}
  .topbar{display:none}
  body.has-topbar{padding-top:var(--header-h)}
  body{padding-top:var(--header-h)}
  .site-header{top:0!important}
  body.scrolled .site-header{top:0}
  .nav.mobile-open,
  body.scrolled .nav.mobile-open{top:var(--header-h)!important}
  .brand img{height:32px}
  .nav-cta .btn{padding:.45rem .75rem;font-size:.7rem}
  .burger{width:38px;height:38px}
}
@media (max-width:420px){
  :root{--header-h:56px}
  .nav-cta .btn-primary{display:none}
  .nav-cta{gap:.4rem}
}

/* Mobile nav drawer polish */
@media (max-width:1023px){
  .nav.mobile-open{
    padding:.75rem clamp(1rem,4vw,1.5rem) 2.5rem;
    background:var(--c-bg);
  }
  .nav.mobile-open > li{border-bottom:1px solid var(--c-line)}
  .nav.mobile-open > li:last-child{border-bottom:0}
  .nav.mobile-open a{padding:.95rem .25rem;font-size:1.05rem}
  .nav.mobile-open .has-sub > a{
    display:flex;align-items:center;justify-content:space-between;width:100%;
  }
  .nav.mobile-open .has-sub > a::after{
    width:7px;height:7px;border-width:1.5px;margin-left:auto;opacity:.55;
  }
  body.nav-open{overflow:hidden}
}

/* ---------- Hero: tame height + type on small screens ---------- */
@media (max-width:900px){
  .hero{min-height:auto;padding:calc(var(--header-h) + 32px + 3rem) 0 clamp(2.5rem,6vw,4rem)}
  .hero-inner{padding-bottom:var(--sp-6)}
  .hero .display{font-size:clamp(2.1rem,7.5vw,3.6rem);line-height:1.02}
  .hero p{font-size:var(--fs-md)}
  .hero-meta{gap:var(--sp-5);margin-top:var(--sp-6);padding-top:var(--sp-4)}
  .hero-meta span strong{font-size:1.3rem}
}
@media (max-width:640px){
  .hero{min-height:78vh;padding-top:calc(var(--header-h) + 2rem)}
  .hero .display{font-size:clamp(1.9rem,9vw,2.8rem)}
  .hero p{font-size:.95rem;max-width:100%}
  .hero-actions{gap:.5rem;width:100%}
  .hero-actions .btn{flex:1 1 auto;min-width:140px;justify-content:center;padding:.8rem 1rem}
  .hero-meta{gap:var(--sp-4) var(--sp-5);font-size:.62rem}
  .hero-meta span strong{font-size:1.15rem;margin-top:2px}
  .slide-dots{right:.6rem;padding:6px 5px;gap:6px;border-radius:999px}
  .slide-dots .dot{width:6px;height:6px}
  .slide-dots .dot.active{height:14px}
}
@media (max-width:480px){
  .slide-dots{right:.5rem;padding:5px 4px;gap:5px}
  .slide-dots .dot{width:5px;height:5px}
  .slide-dots .dot.active{height:12px}
}
@media (max-width:420px){
  .hero .eyebrow{font-size:.65rem;letter-spacing:.12em}
  .hero-actions .btn{min-width:0;width:100%}
}

/* ---------- Floating search bar — clean stacking on mobile ---------- */
@media (max-width:1100px){
  .search-wrap{margin-top:-40px;padding:0 1rem}
  .search-bar{border-radius:var(--r-lg);box-shadow:0 12px 40px rgba(20,17,13,.12)}
}
@media (max-width:768px){
  .search-wrap{margin-top:-32px}
  .search-bar{grid-template-columns:1fr 1fr;gap:0;padding:6px}
  .search-bar .field{padding:.7rem .85rem;gap:.6rem}
  .search-bar .f-icon{width:30px;height:30px}
  .search-bar label{font-size:.58rem}
  .search-bar select,.search-bar input{font-size:.85rem}
  .search-bar .btn{padding:.85rem 1rem;font-size:.85rem;min-width:0}
}
@media (max-width:540px){
  .search-wrap{margin-top:-28px;margin-bottom:var(--sp-5)}
  .search-bar{grid-template-columns:1fr;padding:8px}
  .search-bar .field{border-bottom:1px solid var(--c-line);padding:.7rem .5rem}
  .search-bar .field:last-of-type{border-bottom:0}
  .search-bar .field + .field::before{display:none!important}
  .search-bar .btn{grid-column:1;width:100%;margin-top:6px;border-radius:var(--r-md)}
}

/* ---------- Section headers ---------- */
@media (max-width:760px){
  .s-head{padding-bottom:var(--sp-4);margin-bottom:var(--sp-6)}
  .s-head h2{font-size:clamp(1.5rem,6vw,2.1rem)}
  .s-head .s-tail{font-size:.9rem}
}

/* ---------- Destinations mosaic — 2-col on tablet, 1 on phone ---------- */
@media (max-width:1024px) and (min-width:769px){
  .dest-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:minmax(220px,1fr) minmax(220px,1fr) minmax(220px,1fr);
    min-height:auto;
  }
  .dest:first-child{grid-column:1 / -1;grid-row:auto}
}
@media (max-width:768px){
  .dest-grid{gap:var(--sp-3)}
  .dest{padding:var(--sp-5);min-height:220px}
  .dest h3{font-size:1.4rem}
  .dest .go{opacity:1;transform:none;font-size:.72rem}
}

/* ---------- Features ---------- */
@media (max-width:900px){
  .feature{padding:var(--sp-5) var(--sp-4)}
  .feature h4,.feature .feature-title{font-size:var(--fs-lg)}
}

/* ---------- Stats ---------- */
@media (max-width:720px){
  .stats{gap:0}
  .stat{padding:var(--sp-5) var(--sp-4);text-align:center}
  .stat .num{font-size:clamp(1.9rem,7vw,2.6rem)}
  .stat .lbl{margin-top:var(--sp-2)}
}
@media (max-width:420px){
  .stats{grid-template-columns:1fr}
  .stat,.stat:nth-child(n){border-left:0!important;border-top:1px solid var(--c-line);text-align:center}
  .stat:first-child{border-top:0}
  .stat{padding:var(--sp-4) var(--sp-4)}
}

/* ---------- Testimonials ---------- */
@media (max-width:640px){
  .testimonial{padding:var(--sp-5) var(--sp-4)}
  .testimonial blockquote{font-size:1.05rem;line-height:1.45}
}

/* ---------- CTA Band ---------- */
@media (max-width:720px){
  .cta-band{
    padding:clamp(2.75rem,9vw,4rem) 0;
    background-position:center 35%;
  }
  .cta-band::before{
    background:
      linear-gradient(180deg,rgba(20,14,10,.82) 0%,rgba(20,14,10,.70) 45%,rgba(20,14,10,.88) 100%),
      radial-gradient(ellipse at 50% 100%,rgba(200,120,80,.20) 0%,transparent 60%);
  }
  .cta-band .container{gap:var(--sp-5);padding:0 var(--sp-5)}
  .cta-band h2{font-size:clamp(1.6rem,5.8vw,2.2rem);max-width:100%;line-height:1.15}
  .cta-band p{font-size:.92rem;line-height:1.55;max-width:42ch}
  .cta-band .hero-actions{
    width:100%;max-width:340px;margin:0 auto;
    gap:.55rem;flex-direction:column;align-items:stretch;
  }
  .cta-band .hero-actions .btn{
    width:100%;min-width:0;
    padding:.78rem 1.1rem;
    font-size:.9rem;
    border-radius:var(--r-sm);
  }
}

/* ---------- Manifesto ---------- */
@media (max-width:860px){
  .manifesto{gap:var(--sp-6)}
  .manifesto-img{aspect-ratio:16/10}
  .manifesto-txt h2{font-size:clamp(1.6rem,6vw,2.3rem);line-height:1.1}
}
@media (max-width:640px){
  .manifesto-img{aspect-ratio:3/2;border-radius:var(--r-sm);max-height:280px}
  .manifesto-img img{height:100%}
}
@media (max-width:480px){
  .manifesto-img{aspect-ratio:4/3;max-height:240px}
}

/* ---------- Page hero (non-home pages) ---------- */
@media (max-width:900px){
  .page-hero{padding:calc(var(--header-h) + 32px + 2.5rem) 0 var(--sp-7)}
  .page-hero h1{font-size:clamp(1.75rem,6.5vw,2.6rem)}
  .page-hero p{font-size:.95rem}
}
@media (max-width:640px){
  .page-hero{padding:calc(var(--header-h) + 1.5rem) 0 var(--sp-6);margin-top:calc(-1 * var(--header-h))}
  .page-hero .breadcrumb{font-size:.62rem}
}

/* ---------- Footer ---------- */
@media (max-width:900px){
  .site-footer{padding:var(--sp-8) 0 var(--sp-5);margin-top:var(--sp-8)}
  .footer-grid{gap:var(--sp-6) var(--sp-5)}
  .footer-about{grid-column:1 / -1}
  .footer-about p{max-width:100%}
  .footer-about img{height:40px}
}
@media (max-width:640px){
  .site-footer{padding:var(--sp-7) 0 var(--sp-4)}
  .site-footer .container{padding-left:var(--sp-4);padding-right:var(--sp-4)}
  .footer-grid{gap:var(--sp-5);padding-bottom:var(--sp-6)}
  .footer-about p{font-size:.85rem;line-height:1.6}
  .site-footer h4,.site-footer .footer-h{margin-bottom:var(--sp-3);font-size:.68rem}
  .site-footer ul li{margin-bottom:.5rem}
  .site-footer a{font-size:.85rem}
}
@media (max-width:500px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--sp-5) var(--sp-4)}
  .footer-about{grid-column:1 / -1}
  .legal{flex-direction:column;gap:.6rem;text-align:center;font-size:.6rem}
  .footer-legal-links{order:3}
  .social{gap:.35rem;margin-top:var(--sp-4)}
  .social a{width:34px;height:34px;min-width:34px;min-height:34px}
  .social a svg{width:14px;height:14px}
  .social a.ta img{width:19px;height:19px}
}
@media (max-width:380px){
  .footer-grid{grid-template-columns:1fr}
  .social{gap:.3rem;justify-content:flex-start}
  .social a{width:32px;height:32px;min-width:32px;min-height:32px}
  .social a svg{width:13px;height:13px}
  .social a.ta img{width:18px;height:18px}
}

/* ---------- Floating WhatsApp ---------- */
@media (max-width:640px){
  .wa-float{right:14px;bottom:14px;width:48px;height:48px}
  .wa-float svg{width:22px;height:22px}
}

/* ---------- Tour cards — tighter on mobile ---------- */
@media (max-width:640px){
  .tour-card .body{padding:14px 16px 18px}
  .tour-card h3{font-size:1.05rem}
  .tour-card p{font-size:.85rem}
  .tour-card .meta{font-size:.72rem;gap:var(--sp-3) var(--sp-4)}
  .tour-card .price{font-size:1.35rem}
  .tour-card .foot{padding-top:var(--sp-3);gap:.5rem;flex-wrap:wrap}
  .tour-card .book-btn{padding:.5rem .9rem;font-size:.75rem}
  .tour-card .badge{font-size:.65rem;padding:.32rem .6rem;top:10px;left:10px}
  .tour-card .fav{width:34px;height:34px;top:10px;right:10px}
  .tour-card .fav svg{width:15px;height:15px}
}

/* ---------- Carousel nav on medium screens ---------- */
@media (max-width:1100px) and (min-width:901px){
  .carousel-btn.prev{left:-6px}
  .carousel-btn.next{right:-6px}
}

/* ---------- Tour detail — booking card unsticks on mobile ---------- */
@media (max-width:900px){
  .booking-card{position:static;top:auto}
  .detail-grid{gap:var(--sp-6)}
}

/* ---------- Tours listing ---------- */
@media (max-width:900px){
  .tours-listing{gap:var(--sp-4)}
  .tours-sidebar{padding:var(--sp-4);border-radius:var(--r-md)}
  .tours-toolbar{gap:var(--sp-2);margin-bottom:var(--sp-3)}
  .ts-filter-toggle{padding:.55rem 1rem;font-size:.8rem}
}

/* ---------- Typography — consistent vertical rhythm ---------- */
@media (max-width:640px){
  h1{font-size:clamp(1.75rem,7vw,2.4rem)}
  h2{font-size:clamp(1.55rem,6vw,2.1rem)}
  h3{font-size:1.3rem}
  .lead{font-size:var(--fs-md)}
  .display{font-size:clamp(2rem,9vw,3rem);line-height:1.02}
}

/* ---------- Touch targets: generous tap areas on touch devices ---------- */
@media (hover:none) and (pointer:coarse){
  .btn,.book-btn,.nav a,.sub a,.carousel-btn,.tour-action,
  .site-footer a,.share-menu a,.share-menu button,.fav{
    min-height:40px;
  }
  .tour-card:hover,.blog-card:hover{transform:none}
  .tour-card:hover .media-actions,.dest:hover .media-actions{opacity:1;transform:none}
}

/* ---------- Gallery / Detail page fine tuning ---------- */
@media (max-width:640px){
  .gallery{gap:6px}
  .gallery .g-fab{width:34px;height:34px}
  .gallery .g-viewall{font-size:.75rem;padding:.4rem .7rem}
  .itinerary{padding-left:var(--sp-4);margin-left:var(--sp-2)}
  .itinerary .day::before{left:calc(-1 * var(--sp-4) - 5px)}
}

/* ---------- Forms ---------- */
@media (max-width:860px){
  /* Contact / Request-a-quote aside: compact on tablet/mobile */
  .grid[style*="grid-template-columns"] > aside .feature{padding:var(--sp-5)}
  .grid[style*="grid-template-columns"] > aside .feature + .feature{margin-top:var(--sp-4) !important}
}
@media (max-width:640px){
  .form-card{padding:var(--sp-5) var(--sp-4);border-radius:var(--r-sm);max-width:100%}
  .form-card h2{font-size:clamp(1.4rem,5.5vw,1.8rem)}
  .form-card .lead{font-size:.95rem}
  .form input,.form select,.form textarea{font-size:16px} /* prevent iOS zoom */
  /* Keep submit button + hint readable when stacked */
  .form-row:has(button[type="submit"]){grid-template-columns:1fr;gap:var(--sp-3)}
  .form-row:has(button[type="submit"]) .btn{width:100%}
  .form-row:has(button[type="submit"]) .hint{text-align:center;font-size:.62rem}
  /* Chip group stays tappable on small screens */
  .chip-group{gap:.4rem}
  .chip-group label{padding:.5rem .75rem;font-size:.78rem}
  /* Form-card section title has less margin */
  .form-card .form-section-title{margin:0 0 var(--sp-3);padding-bottom:var(--sp-2)}
  .form-card .form-section-title:not(:first-child){margin-top:var(--sp-5)}
  /* Aside becomes more compact and matches card style */
  .grid[style*="grid-template-columns"] > aside .feature{padding:var(--sp-4);border-radius:var(--r-sm)}
  .grid[style*="grid-template-columns"] > aside h3{font-size:1.1rem !important}
}

/* ---------- Wishlist page ---------- */
@media (max-width:500px){
  .wishlist-grid{grid-template-columns:1fr;gap:var(--sp-4)}
}

/* ---------- Tablet landscape polish ---------- */
@media (min-width:641px) and (max-width:1023px) and (orientation:landscape){
  .hero{min-height:auto;padding-top:calc(var(--header-h) + 2.5rem)}
}

/* ---------- Hide decorative elements on small screens ---------- */
@media (max-width:768px){
  .hero-scroll{display:none}
  .nav-phone{display:none}
}

/* ---------- Custom date picker (replaces native <input type=date> chrome) ---------- */
.lmt-date{position:relative;width:100%;font-family:inherit;z-index:1}
.lmt-date[aria-expanded="true"]{z-index:60}
.lmt-date__btn{
  display:flex;align-items:center;gap:.6rem;width:100%;
  background:transparent;border:0;padding:.8rem 0;margin:0;cursor:pointer;
  font:inherit;font-weight:500;font-size:.95rem;color:var(--c-ink);
  line-height:1.3;text-align:left;outline:none;
  border-bottom:1px solid var(--c-line);border-radius:0;
  transition:border-color .2s;
}
.lmt-date[aria-expanded="true"] .lmt-date__btn{border-bottom-color:var(--c-primary)}
.lmt-date__btn:focus-visible{outline:2px solid var(--c-primary);outline-offset:3px;border-radius:4px}
.lmt-date__value{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lmt-date__value.is-placeholder{color:var(--c-mute);font-weight:400}
.lmt-date__ico{flex-shrink:0;width:17px;height:17px;color:var(--c-mute)}
.lmt-date[aria-expanded="true"] .lmt-date__ico{color:var(--c-primary)}

.lmt-date__pop{
  position:absolute;top:calc(100% + 10px);left:0;z-index:1000;
  width:304px;max-width:calc(100vw - 32px);
  background:#fff;border:1px solid var(--c-line);border-radius:14px;
  box-shadow:0 24px 60px rgba(20,17,13,.16),0 8px 22px rgba(20,17,13,.06);
  padding:14px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .18s var(--ease),transform .18s var(--ease),visibility .18s;
}
.lmt-date[aria-expanded="true"] .lmt-date__pop{opacity:1;visibility:visible;transform:translateY(0)}

.lmt-date__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.lmt-date__title{
  font-family:var(--ff-head);font-size:.95rem;font-weight:600;color:var(--c-ink);
  display:inline-flex;align-items:center;gap:.4rem;
  background:transparent;border:0;cursor:pointer;padding:.35rem .5rem;border-radius:6px;
}
.lmt-date__title:hover{background:var(--c-bg-soft)}
.lmt-date__title svg{width:10px;height:10px;color:var(--c-mute)}
.lmt-date__nav{display:inline-flex;gap:2px}
.lmt-date__navbtn{
  width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;
  background:transparent;border:0;border-radius:8px;cursor:pointer;color:var(--c-ink);
  transition:background-color .15s var(--ease);padding:0;
}
.lmt-date__navbtn:hover{background:var(--c-bg-soft)}
.lmt-date__navbtn svg{width:14px;height:14px}

.lmt-date__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.lmt-date__dow{
  text-align:center;font-family:var(--ff-mono);font-size:.6rem;font-weight:500;
  color:var(--c-mute);text-transform:uppercase;letter-spacing:.1em;padding:6px 0 4px;
}
.lmt-date__cell{
  aspect-ratio:1;display:inline-flex;align-items:center;justify-content:center;
  background:transparent;border:0;border-radius:8px;cursor:pointer;
  font:inherit;font-size:.85rem;color:var(--c-ink);padding:0;
  transition:background-color .15s var(--ease),color .15s var(--ease);
}
.lmt-date__cell:hover:not([disabled]){background:var(--c-bg-soft)}
.lmt-date__cell.is-outside{color:var(--c-mute);opacity:.45}
.lmt-date__cell.is-today{font-weight:700;color:var(--c-primary);box-shadow:inset 0 0 0 1px var(--c-line)}
.lmt-date__cell.is-selected{background:var(--c-primary);color:#fff;font-weight:600;box-shadow:none}
.lmt-date__cell.is-selected:hover{background:var(--c-primary);filter:brightness(1.08)}
.lmt-date__cell[disabled]{opacity:.3;cursor:not-allowed}

.lmt-date__foot{
  display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  margin-top:10px;padding-top:10px;border-top:1px solid var(--c-line);
}
.lmt-date__footbtn{
  background:transparent;border:0;cursor:pointer;font:inherit;font-size:.82rem;font-weight:500;
  color:var(--c-primary);padding:.4rem .7rem;border-radius:6px;
}
.lmt-date__footbtn:hover{background:var(--c-bg-soft)}

.lmt-date__pick{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:4px 0}
.lmt-date__pickcell{
  padding:.75rem .4rem;background:transparent;border:0;border-radius:8px;cursor:pointer;
  font:inherit;font-size:.85rem;color:var(--c-ink);
  transition:background-color .15s var(--ease);
}
.lmt-date__pickcell:hover{background:var(--c-bg-soft)}
.lmt-date__pickcell.is-selected{background:var(--c-primary);color:#fff;font-weight:600}

/* Search-bar / inline usage — no bottom border, follows search-bar field chrome */
.search-bar .lmt-date .lmt-date__btn{border-bottom:0;padding:0}
.search-bar .lmt-date[aria-expanded="true"] .lmt-date__btn{border-bottom:0}

/* Standalone (outside search-bar & field-l) */
.lmt-date.is-standalone .lmt-date__btn{
  border:1px solid var(--c-line);border-radius:10px;
  padding:.7rem .95rem;background:#fff;
}
.lmt-date.is-standalone .lmt-date__btn:hover{border-color:var(--c-ink)}
.lmt-date.is-standalone[aria-expanded="true"] .lmt-date__btn{border-color:var(--c-primary);border-bottom-color:var(--c-primary)}

@media (max-width:540px){
  .lmt-date__pop{width:calc(100vw - 32px);left:0;right:auto}
}

