/* ============================================================
   HAKOE — la charette du vignoble
   Design system: cinematic + rustic chic
   ============================================================ */

:root{
  /* Palette (from brief) */
  --leather:#3F220F;
  --leather-2:#2a1608;
  --leather-3:#1c0e04;
  --tan:#BA5C12;
  --tan-2:#9c4a0c;
  --cream:#FFFCE8;
  --cream-2:#F6F0D6;
  --cream-3:#EDE5C5;
  --sky:#90E1FF;
  --sky-deep:#5cc2e6;

  /* Roles */
  --accent:var(--tan);
  --accent-ink:#fff8ee;
  --ink:var(--leather);
  --ink-soft:rgba(63,34,15,.72);
  --ink-faint:rgba(63,34,15,.52);
  --line:rgba(63,34,15,.16);
  --line-strong:rgba(63,34,15,.28);
  --bg:var(--cream);

  /* Type */
  --font-display:"Bitter",Georgia,serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-script:"Caveat",cursive;
  --display-weight:800;

  /* Metrics */
  --maxw:1240px;
  --gutter:clamp(20px,5vw,64px);
  --section-y:clamp(72px,11vw,140px);
  --radius:6px;
  --radius-lg:12px;
  --shadow-sm:0 2px 10px rgba(40,18,4,.08);
  --shadow:0 18px 50px -18px rgba(40,18,4,.38);
  --shadow-lg:0 40px 90px -30px rgba(40,18,4,.55);
  --nav-h:74px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.62;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}

body.no-grain::before{display:none}

/* Paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:var(--display-weight);line-height:1.05;letter-spacing:-.015em;color:var(--ink)}
.display{font-size:clamp(2.6rem,7.5vw,6rem)}
.h-sec{font-size:clamp(2rem,4.6vw,3.6rem);line-height:1.04}
.h-3{font-size:clamp(1.3rem,2.3vw,1.7rem);font-weight:700;letter-spacing:-.01em}
.lead{font-size:clamp(1.08rem,1.5vw,1.35rem);line-height:1.55;color:var(--ink-soft);max-width:60ch}
p{text-wrap:pretty}

.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.26em;color:var(--accent);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.75}
.eyebrow.center::after{content:"";width:26px;height:1px;background:var(--accent);opacity:.75}
.eyebrow.center{justify-content:center}
.script{font-family:var(--font-script);font-weight:600;color:var(--accent);
  font-size:1.5em;line-height:1}
.italic-note{font-family:var(--font-script);font-size:1.7rem;color:var(--ink-soft);line-height:1.3}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1440px;margin:0 auto;padding-inline:var(--gutter)}
section{position:relative}
.section{padding-block:var(--section-y)}
.sec-head{max-width:62ch}
.sec-head .h-sec{margin-top:.5rem}
.sec-head .lead{margin-top:1.1rem}
.center{text-align:center}
.center .lead{margin-inline:auto}

.dark{background:var(--leather);color:var(--cream)}
.dark h1,.dark h2,.dark h3,.dark h4{color:var(--cream)}
.dark .lead{color:rgba(255,252,232,.78)}
.dark .eyebrow{color:var(--sky)}
.dark .eyebrow::before,.dark .eyebrow.center::after{background:var(--sky)}

/* diamond divider */
.diamond{display:flex;align-items:center;gap:14px;color:var(--accent)}
.diamond::before,.diamond::after{content:"";height:1px;flex:1;background:var(--line)}
.diamond i{width:7px;height:7px;background:var(--accent);transform:rotate(45deg);display:block}
.dark .diamond::before,.dark .diamond::after{background:rgba(255,252,232,.2)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--font-body);font-weight:700;font-size:.98rem;letter-spacing:.01em;
  padding:1.02em 1.8em;border-radius:var(--radius);
  transition:transform .25s cubic-bezier(.2,.7,.3,1),background .25s,color .25s,box-shadow .25s;
  white-space:nowrap;line-height:1;
}
.btn svg{width:1.05em;height:1.05em;flex:none}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--tan-2);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(186,92,18,.55)}
.btn-ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--ink);transform:translateY(-2px)}
.dark .btn-ghost{color:var(--cream);box-shadow:inset 0 0 0 1.5px rgba(255,252,232,.4)}
.dark .btn-ghost:hover{box-shadow:inset 0 0 0 1.5px var(--cream)}
.btn-light{background:var(--cream);color:var(--leather)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-sm{padding:.7em 1.15em;font-size:.86rem}
.link-arrow{display:inline-flex;align-items:center;gap:.5em;font-weight:700;color:var(--accent);
  letter-spacing:.01em}
.link-arrow svg{width:1.1em;transition:transform .25s}
.link-arrow:hover svg{transform:translateX(4px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);
  display:flex;align-items:center;transition:background .4s,box-shadow .4s,color .4s;color:var(--cream)}
.nav .wrap-wide{display:flex;align-items:center;gap:24px;width:100%}
.nav.scrolled{background:rgba(255,252,232,.94);backdrop-filter:blur(10px);
  box-shadow:0 1px 0 var(--line),0 10px 30px -20px rgba(40,18,4,.4);color:var(--leather)}
.brand{display:flex;flex-direction:column;line-height:1;margin-right:auto}
.brand .mark{font-family:var(--font-display);font-weight:800;font-size:1.45rem;letter-spacing:.14em}
.brand .sub{font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;opacity:.8;margin-top:4px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:.9rem;font-weight:600;letter-spacing:.01em;opacity:.9;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--accent);transition:right .3s}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{right:0}
.nav-right{display:flex;align-items:center;gap:14px}

/* language switcher */
.lang{position:relative}
.lang-btn{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:8px 10px;border-radius:var(--radius)}
.lang-btn svg{width:12px;transition:transform .25s}
.lang.open .lang-btn svg{transform:rotate(180deg)}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--cream);color:var(--leather);
  border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;min-width:140px;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.2s;border:1px solid var(--line)}
.lang.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:11px 14px;font-size:.9rem;font-weight:600;text-align:left}
.lang-menu button:hover{background:var(--cream-3)}
.lang-menu button.active{color:var(--accent)}
.lang-menu .flag{font-size:1.1rem}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:currentColor;transition:.3s;border-radius:2px}
.mobile-menu{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden;isolation:isolate}
.hero h1,.hero h2{color:var(--cream)}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 42%}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(28,14,4,.55) 0%,rgba(28,14,4,.12) 32%,rgba(28,14,4,.28) 62%,rgba(28,14,4,.86) 100%)}
.hero-inner{padding-bottom:clamp(48px,8vh,110px);padding-top:calc(var(--nav-h) + 40px);width:100%}
.hero .kicker{font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--sky);display:flex;align-items:center;gap:.8em}
.hero .kicker::before{content:"";width:34px;height:1px;background:var(--sky)}
.hero h1{margin:.32em 0 0;max-width:16ch;text-shadow:0 2px 40px rgba(20,10,2,.5)}
.hero .tagline{font-size:clamp(1.1rem,1.8vw,1.5rem);max-width:34ch;margin-top:1.1rem;color:rgba(255,252,232,.92);font-weight:400}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:2rem}
.hero-meta{display:flex;flex-wrap:wrap;gap:26px;margin-top:2.6rem;padding-top:1.8rem;border-top:1px solid rgba(255,252,232,.2);max-width:640px}
.hero-meta div{display:flex;flex-direction:column;gap:3px}
.hero-meta .k{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sky)}
.hero-meta .v{font-family:var(--font-display);font-weight:700;font-size:1.18rem}

/* ============================================================
   HERO 3D TILT — perspective follows cursor (clickable preserved)
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .hero{perspective:1800px}
  .hero-bg,
  .hero-inner,
  .hero::after{
    transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
    transition:transform .65s cubic-bezier(.22,.61,.36,1);
    will-change:transform;
  }
  .hero-inner{transform-style:preserve-3d}
  .hero .scroll-cue{
    transform:translateX(-50%) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
    transition:transform .65s cubic-bezier(.22,.61,.36,1);
    will-change:transform;
  }
  /* Quick follow while moving the cursor */
  .hero.is-tilting .hero-bg{
    transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) scale(1.045);
    transition:transform .12s ease-out;
  }
  .hero.is-tilting .hero-inner,
  .hero.is-tilting::after,
  .hero.is-tilting .scroll-cue{transition:transform .12s ease-out}
  /* Floating depth on the inner content */
  .hero-inner .kicker,
  .hero-inner h1,
  .hero-inner .tagline,
  .hero-inner .hero-cta,
  .hero-inner .hero-meta{
    transition:transform .45s cubic-bezier(.22,.61,.36,1);
    will-change:transform;
  }
  .hero.is-tilting .hero-inner .kicker{transform:translateZ(22px)}
  .hero.is-tilting .hero-inner h1{transform:translateZ(55px)}
  .hero.is-tilting .hero-inner .tagline{transform:translateZ(32px)}
  .hero.is-tilting .hero-inner .hero-cta{transform:translateZ(75px)}
  .hero.is-tilting .hero-inner .hero-meta{transform:translateZ(18px)}
}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.66rem;letter-spacing:.24em;
  text-transform:uppercase;opacity:.8}
.scroll-cue .mouse{width:22px;height:34px;border:1.5px solid currentColor;border-radius:12px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;top:6px;left:50%;width:3px;height:6px;background:currentColor;
  border-radius:2px;transform:translateX(-50%);animation:scroll 1.7s infinite}
@keyframes scroll{0%{opacity:1;top:6px}70%{opacity:0;top:16px}100%{opacity:0}}

/* ============================================================
   CONCEPT (3 layers / anti-positioning)
   ============================================================ */
.concept-statement{font-family:var(--font-display);font-weight:var(--display-weight);
  font-size:clamp(1.9rem,4.4vw,3.3rem);line-height:1.12;letter-spacing:-.015em;max-width:20ch}
.concept-statement .strike{position:relative;color:rgba(255,252,232,.42);white-space:nowrap}
/* Typewriter: blinking caret on the currently-typing span. Removes the orange strike lines. */
.concept-statement [data-tw].tw-active::after{
  content:"|";
  display:inline-block;
  margin-left:.04em;
  color:currentColor;
  font-weight:400;
  animation:tw-blink 1s infinite step-end;
}
@keyframes tw-blink{0%,49%{opacity:1}50%,100%{opacity:0}}
.concept-statement .hl{color:var(--sky)}
.layers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin-top:clamp(48px,6vw,80px)}
.layer{padding-top:26px;border-top:1px solid rgba(255,252,232,.2)}
.layer .num{font-family:var(--font-display);font-weight:800;font-size:.95rem;color:var(--sky);letter-spacing:.1em}
.layer h3{margin:1.2rem 0 .6rem;font-size:clamp(1.25rem,1.9vw,1.6rem)}
.layer p{color:rgba(255,252,232,.74);font-size:1rem}

/* ============================================================
   CHARETTE — gallery + equipment
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:clamp(32px,4vw,52px)}
.gphoto{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;background:var(--cream-3)}
.gphoto img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.3,1)}
.gphoto:hover img{transform:scale(1.06)}
.gphoto::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(28,14,4,.5));opacity:0;transition:.4s}
.gphoto:hover::after{opacity:1}
.gphoto .cap{position:absolute;left:16px;bottom:14px;color:#fff;font-size:.82rem;font-weight:600;
  letter-spacing:.04em;opacity:0;transform:translateY(8px);transition:.4s;z-index:2;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.gphoto:hover .cap{opacity:1;transform:none}
.gphoto .zoom{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,252,232,.92);display:grid;place-items:center;opacity:0;transform:scale(.7);transition:.35s;z-index:2}
.gphoto:hover .zoom{opacity:1;transform:none}
.gphoto .zoom svg{width:15px;color:var(--leather)}
.g-a{grid-column:span 7;aspect-ratio:16/11}
.g-b{grid-column:span 5;aspect-ratio:4/5}
.g-c{grid-column:span 4;aspect-ratio:1}
.g-d{grid-column:span 4;aspect-ratio:1}
.g-e{grid-column:span 4;aspect-ratio:1}

.equip{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:start;margin-top:clamp(56px,7vw,96px)}
.equip-list{columns:2;column-gap:30px}
.equip-list li{break-inside:avoid;display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--line);font-size:.98rem;align-items:flex-start}
.equip-list li svg{width:17px;flex:none;color:var(--accent);margin-top:3px}
.equip-list li .premium{display:inline-block;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--accent);border-radius:3px;padding:1px 5px;margin-left:6px;vertical-align:middle}
.equip-aside{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,38px);position:sticky;top:100px}
.equip-aside h3{margin-bottom:6px}
.spec-row{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line);font-size:.96rem}
.spec-row:last-of-type{border-bottom:none}
.spec-row .k{color:var(--ink-soft)}
.spec-row .v{font-weight:700;text-align:right}
.spec-row .v.yes{color:#3c7a3c}
.spec-row .v.no{color:var(--ink-faint)}
.badge-off{display:inline-flex;align-items:center;gap:7px;margin-top:18px;background:var(--leather);color:var(--cream);
  font-size:.78rem;font-weight:600;padding:9px 14px;border-radius:var(--radius);letter-spacing:.02em}
.badge-off svg{width:15px;color:var(--sky)}

/* ============================================================
   HOSTS
   ============================================================ */
.hosts{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(36px,5vw,80px);align-items:center}
.polaroid{background:#fff;padding:16px 16px 58px;box-shadow:var(--shadow);border-radius:3px;
  transform:rotate(-2.4deg);max-width:430px;position:relative}
.polaroid .ph{aspect-ratio:4/5;background:repeating-linear-gradient(45deg,var(--cream-3),var(--cream-3) 11px,var(--cream-2) 11px,var(--cream-2) 22px);
  border-radius:2px;display:grid;place-items:center;text-align:center;padding:20px}
.polaroid .ph span{font-family:monospace;font-size:.78rem;color:var(--ink-faint);letter-spacing:.04em;line-height:1.6}
.polaroid .cap{position:absolute;bottom:16px;left:0;right:0;text-align:center;font-family:var(--font-script);font-size:1.7rem;color:var(--leather)}

/* Hosts polaroid — interactive 3D tilt (matches React TiltCard exactly).
   Selector is bumped (.hosts .polaroid.reveal) to win over `.reveal.in { transform:none }`. */
@media (prefers-reduced-motion:no-preference){
  .hosts .polaroid.reveal,
  .hosts .polaroid.reveal.in{
    transform:perspective(1000px) rotateX(var(--prx,0deg)) rotateY(var(--pry,0deg)) scale3d(1.02,1.02,1.02);
    transition:transform .2s ease-out;
    cursor:pointer;
    will-change:transform;
  }
}
.hosts-text .h-sec{margin:.5rem 0 1.4rem}
.hosts-text .bio{font-size:1.12rem;line-height:1.72;color:var(--ink-soft);max-width:56ch}
.hosts-text .bio + .bio{margin-top:1rem}
.host-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:1.8rem}
.host-tags span{font-size:.82rem;font-weight:600;background:var(--cream-2);border:1px solid var(--line);
  padding:7px 13px;border-radius:100px;color:var(--ink-soft)}

/* ============================================================
   LE CADRE — full bleed
   ============================================================ */
.cadre-hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden;isolation:isolate}
.cadre-hero h2{color:var(--cream)}
.cadre-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.cadre-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(28,14,4,.3),rgba(28,14,4,.05) 40%,rgba(28,14,4,.8))}
.cadre-hero .inner{padding-block:clamp(48px,8vw,96px);max-width:680px}
.cadre-hero h2{margin:.4em 0 0}
.cadre-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:2.4rem}
.cadre-feats .f .v{font-family:var(--font-display);font-weight:800;font-size:clamp(1.4rem,2.4vw,2rem);color:var(--sky)}
.cadre-feats .f .k{font-size:.92rem;color:rgba(255,252,232,.8);margin-top:4px}

.cadre-split{display:grid;grid-template-columns:1fr 1fr}
.cadre-split .txt{padding:var(--section-y) var(--gutter);display:flex;flex-direction:column;justify-content:center}
.cadre-split .txt .inner{max-width:48ch}
.cadre-split figure{position:relative;min-height:420px}
.cadre-split figure img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ============================================================
   ACTIVITES — map
   ============================================================ */
.map-wrap{display:grid;grid-template-columns:1.25fr .75fr;gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;margin-top:clamp(32px,4vw,52px);box-shadow:var(--shadow);background:var(--cream-2)}
.map-stage{position:relative;min-height:560px;height:560px;overflow:hidden;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}
.map-stage .topo{position:absolute;inset:0;opacity:.5;mix-blend-mode:multiply}
.map-stage .grain{position:absolute;inset:0;opacity:.5;mix-blend-mode:multiply;pointer-events:none}
.map-marker{position:absolute;transform:translate(-50%,-100%);z-index:3;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:0}
.map-marker .pin{width:30px;height:30px;border-radius:50% 50% 50% 2px;background:var(--tan);transform:rotate(45deg);
  box-shadow:0 6px 14px -4px rgba(40,18,4,.5);display:grid;place-items:center;transition:.25s;border:2px solid var(--cream)}
.map-marker .pin svg{transform:rotate(-45deg);width:14px;color:var(--cream)}
.map-marker.home .pin{background:var(--leather)}
.map-marker:hover .pin,.map-marker.active .pin{transform:rotate(45deg) scale(1.18)}
.map-marker .lbl{font-size:.7rem;font-weight:700;letter-spacing:.02em;background:rgba(255,252,232,.92);
  padding:2px 7px;border-radius:3px;margin-top:6px;white-space:nowrap;color:var(--leather);transform:translateY(-2px);
  box-shadow:0 2px 6px rgba(40,18,4,.18);opacity:0;transition:.25s}
.map-marker:hover .lbl,.map-marker.active .lbl{opacity:1}
.map-legend{position:absolute;left:16px;bottom:16px;background:rgba(255,252,232,.9);border:1px solid var(--line);
  border-radius:var(--radius);padding:10px 13px;font-size:.72rem;font-weight:600;color:var(--ink-soft);
  display:flex;flex-direction:column;gap:6px;backdrop-filter:blur(4px)}
.map-legend .row{display:flex;align-items:center;gap:8px}
.map-legend i{width:11px;height:11px;border-radius:50% 50% 50% 1px;transform:rotate(45deg);display:block}
.map-side{padding:clamp(20px,2.4vw,30px);display:flex;flex-direction:column;max-height:560px;overflow-y:auto}
.cat-filter{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.cat-filter button{font-size:.76rem;font-weight:700;letter-spacing:.02em;padding:7px 12px;border-radius:100px;
  border:1px solid var(--line);color:var(--ink-soft);transition:.2s}
.cat-filter button.active{background:var(--leather);color:var(--cream);border-color:var(--leather)}
.act-item{padding:15px 0;border-bottom:1px solid var(--line);cursor:pointer;transition:.2s}
.act-item:hover,.act-item.active{padding-left:8px}
.act-item .top{display:flex;justify-content:space-between;gap:12px;align-items:baseline}
.act-item h4{font-family:var(--font-display);font-size:1.08rem;font-weight:700}
.act-item .dist{font-size:.76rem;font-weight:700;color:var(--accent);white-space:nowrap}
.act-item p{font-size:.88rem;color:var(--ink-soft);margin-top:4px}
.act-item .tag{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);margin-top:6px;display:inline-block}

/* ============================================================
   TARIFS + calendar
   ============================================================ */
.tarifs-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:start;margin-top:clamp(32px,4vw,52px)}
.price-card{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.price-card .ph{background:var(--leather);color:var(--cream);padding:22px 26px}
.price-card .ph .label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sky)}
.price-rows{padding:8px 26px 26px}
.price-rows .r{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0;border-bottom:1px solid var(--line)}
.price-rows .r:last-child{border-bottom:none}
.price-rows .r .n{font-weight:600;color:var(--leather)}
.price-rows .r .n small{display:block;font-weight:400;font-size:.8rem;color:var(--ink-faint)}
.price-rows .r .p{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--tan)}
.price-rows .r .p small{font-size:.8rem;font-weight:600;color:var(--ink-faint)}
.price-rows .r .p.is-text{font-size:1.1rem}
.incl{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.incl .i{display:flex;gap:10px;font-size:.95rem;align-items:center}
.incl .i svg{width:18px;color:var(--accent);flex:none}
.policy{margin-top:18px;background:rgba(144,225,255,.16);border:1px solid rgba(92,194,230,.4);border-radius:var(--radius);
  padding:14px 16px;font-size:.9rem;display:flex;gap:10px;align-items:flex-start}
.policy svg{width:18px;color:var(--sky-deep);flex:none;margin-top:2px}

/* calendar */
.cal{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(20px,2.6vw,30px)}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;color:var(--tan-2)}
.cal-head h4{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:inherit}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:34px;height:34px;border-radius:var(--radius);border:1px solid var(--line);display:grid;place-items:center}
.cal-nav button:hover{background:var(--cream-3)}
.cal-nav button svg{width:14px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-grid .dow{text-align:center;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);padding-bottom:6px}
.cal-day{aspect-ratio:1;display:grid;place-items:center;font-size:.86rem;font-weight:600;border-radius:5px;position:relative}
.cal-day.empty{visibility:hidden}
.cal-day.free{background:rgba(144,225,255,.18);color:var(--leather);cursor:pointer}
.cal-day.free:hover{background:var(--sky);transform:scale(1.05)}
.cal-day.booked{color:var(--ink-faint);text-decoration:line-through;opacity:.5}
.cal-day.past{color:var(--ink-faint);opacity:.35}
.cal-legend{display:flex;gap:18px;margin-top:16px;font-size:.78rem;color:var(--ink-soft);flex-wrap:wrap}
.cal-legend span{display:flex;align-items:center;gap:6px}
.cal-legend i{width:12px;height:12px;border-radius:3px;display:block}
.cal-note{font-size:.8rem;color:var(--ink-faint);margin-top:14px;font-style:italic}

/* ============================================================
   TÉMOIGNAGES
   ============================================================ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:clamp(32px,4vw,52px)}
.testi{background:#fff;padding:14px 14px 22px;box-shadow:var(--shadow-sm);border-radius:3px;
  transform:rotate(var(--rot,0deg));transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .3s}
.testi:hover{transform:rotate(0deg) translateY(-4px);box-shadow:var(--shadow)}
/* Fan-out reveal: cards FULLY stack at center column, then deploy to their grid slots with rotation (staggered spring) */
.testi-grid.reveal .testi{
  position:relative;
  z-index:calc(30 - var(--i) * 10); /* left on top (30), middle (20), right (10) — matches ImageReveal stacking */
  opacity:0;
  transform:translateX(calc((1 - var(--i)) * 110%)) translateY(30px) rotate(0deg) scale(.82);
  transition:opacity .8s ease, transform 1.15s cubic-bezier(.34,1.7,.5,1);
  transition-delay:calc(var(--i) * .22s);
}
.testi-grid.reveal.in .testi{
  opacity:1;
  transform:translate(0,0) rotate(var(--rot,0deg)) scale(1);
}
.testi-grid.reveal.in .testi:hover{transform:rotate(0deg) translateY(-4px) scale(1);transition:transform .3s ease,box-shadow .3s}
.testi .ph{aspect-ratio:5/4;background:var(--cream-3);
  border-radius:2px;overflow:hidden;position:relative}
.testi .ph img{width:100%;height:100%;object-fit:cover;display:block}
.testi .stars{display:flex;gap:2px;margin:14px 4px 8px}
.testi .stars svg{width:15px;color:var(--accent)}
.testi blockquote{font-size:.95rem;line-height:1.55;color:var(--ink-soft);padding:0 4px;font-style:italic}
.testi .who{display:flex;justify-content:space-between;align-items:baseline;margin:14px 4px 0;padding-top:12px;border-top:1px solid var(--line)}
.testi .who .name{font-family:var(--font-display);font-weight:700;font-size:1rem}
.testi .who .meta{font-size:.74rem;color:var(--ink-faint)}
.testi-note{text-align:center;margin-top:30px;font-size:.9rem;color:var(--ink-faint);font-style:italic}

/* ============================================================
   FAQ
   ============================================================ */
.faq-wrap{max-width:820px;margin:clamp(32px,4vw,52px) auto 0}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 4px;text-align:left;font-family:var(--font-display);font-weight:700;font-size:clamp(1.05rem,1.7vw,1.3rem)}
.faq-q .ic{width:30px;height:30px;flex:none;border-radius:50%;border:1.5px solid var(--line-strong);
  display:grid;place-items:center;transition:.3s;position:relative}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;background:var(--ink);border-radius:2px;transition:.3s}
.faq-q .ic::before{width:12px;height:2px}
.faq-q .ic::after{width:2px;height:12px}
.faq-item.open .faq-q .ic{background:var(--accent);border-color:var(--accent)}
.faq-item.open .faq-q .ic::before,.faq-item.open .faq-q .ic::after{background:#fff}
.faq-item.open .faq-q .ic::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a .inner{padding:0 4px 26px;color:var(--ink-soft);max-width:64ch;font-size:1.02rem}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.news{background:var(--leather);color:var(--cream);position:relative;overflow:hidden}
.news .blob{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(144,225,255,.22),transparent 70%);
  width:520px;height:520px;right:-120px;top:-160px;pointer-events:none}
.news-inner{max-width:720px;margin:0 auto;text-align:center;position:relative}
.news form{display:flex;gap:12px;margin-top:2rem;max-width:520px;margin-inline:auto}
.news input{flex:1;padding:1.05em 1.3em;border-radius:var(--radius);border:1.5px solid rgba(255,252,232,.28);
  background:rgba(255,252,232,.06);color:var(--cream);font:inherit;font-size:1rem}
.news input::placeholder{color:rgba(255,252,232,.55)}
.news input:focus{outline:none;border-color:var(--sky)}
.news .consent{font-size:.78rem;color:rgba(255,252,232,.6);margin-top:1rem}
.news-ok{display:none;margin-top:1.4rem;font-family:var(--font-script);font-size:1.8rem;color:var(--sky)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--leather-2);color:rgba(255,252,232,.74);padding-block:clamp(56px,7vw,90px) 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px}
.footer .brand .mark{color:var(--cream);font-size:1.7rem}
.footer .brand .sub{color:var(--sky)}
.footer .tagfoot{margin-top:1rem;max-width:30ch;font-size:.92rem;line-height:1.6}
.footer h5{font-family:var(--font-body);color:var(--cream);font-size:.76rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px}
.footer ul li{margin-bottom:10px}
.footer ul a{font-size:.92rem;transition:.2s}
.footer ul a:hover{color:var(--sky);padding-left:3px}
.footer .contact a{display:flex;align-items:center;gap:10px;font-size:.92rem;margin-bottom:11px}
.footer .contact svg{width:16px;color:var(--sky);flex:none}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,252,232,.2);
  display:grid;place-items:center;transition:.25s}
.socials a:hover{background:var(--tan);border-color:var(--tan);transform:translateY(-3px)}
.socials a svg{width:18px}
.footer-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,252,232,.14);font-size:.82rem}
.footer-bot a:hover{color:var(--sky)}

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:900;display:none;
  background:rgba(255,252,232,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);
  padding:11px var(--gutter);box-shadow:0 -8px 30px -16px rgba(40,18,4,.4);
  transform:translateY(120%);transition:transform .4s}
.sticky-cta.show{transform:none}
.sticky-cta .row{display:flex;gap:10px;align-items:center}
.sticky-cta .price{flex:1;line-height:1.1}
.sticky-cta .price .a{font-family:var(--font-display);font-weight:800;font-size:1.15rem}
.sticky-cta .price .b{font-size:.72rem;color:var(--ink-faint)}
.sticky-cta .btn{flex:none}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(20,10,2,.94);display:none;
  align-items:center;justify-content:center;padding:30px;opacity:0;transition:opacity .3s}
.lightbox.show{display:flex;opacity:1}
.lightbox img{max-width:92vw;max-height:84vh;object-fit:contain;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.lb-cap{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:var(--cream);font-size:.92rem;letter-spacing:.02em}
.lb-close,.lb-prev,.lb-next{position:absolute;color:var(--cream);width:50px;height:50px;border-radius:50%;
  display:grid;place-items:center;background:rgba(255,252,232,.1);transition:.25s}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,252,232,.25)}
.lb-close{top:24px;right:24px}
.lb-close svg,.lb-prev svg,.lb-next svg{width:22px}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
/* MapLibre popup */
.maplibregl-popup-content{font-family:var(--font-body);font-size:.9rem;padding:10px 14px;border-radius:var(--radius);box-shadow:var(--shadow)}
.maplibregl-popup-content strong{font-family:var(--font-display);color:var(--leather)}
.maplibregl-ctrl-group{border:1px solid var(--line)!important;box-shadow:none!important}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.scroll-cue .mouse::after{animation:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .layers{grid-template-columns:1fr;gap:0}
  .layer{padding-block:24px}
  .equip,.hosts,.tarifs-grid,.map-wrap,.cadre-split{grid-template-columns:1fr}
  .equip-aside{position:static}
  .map-stage{min-height:420px;order:-1}
  .map-side{max-height:none}
  .cadre-split figure{min-height:340px}
  .testi-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  :root{--nav-h:64px}
  .nav-links{display:none}
  .nav-toggle{display:flex}
  .nav.scrolled .nav-toggle{color:var(--leather)}
  .mobile-menu{position:fixed;inset:var(--nav-h) 0 0;background:var(--cream);z-index:999;
    display:flex;flex-direction:column;padding:30px var(--gutter);gap:6px;transform:translateX(100%);transition:transform .35s;overflow-y:auto}
  .mobile-menu.open{transform:none}
  .mobile-menu a{font-family:var(--font-display);font-size:1.5rem;font-weight:700;padding:14px 0;border-bottom:1px solid var(--line)}
  .mobile-menu .btn{margin-top:20px}
  .gallery{grid-template-columns:1fr 1fr}
  .g-a,.g-b,.g-c,.g-d,.g-e{grid-column:span 1;aspect-ratio:4/3}
  .g-a{grid-column:span 2;aspect-ratio:16/11}
  .equip-list{columns:1}
  .news form{flex-direction:column}
  .testi-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .sticky-cta{display:block}
  .hero-meta{gap:18px}
  .cadre-feats{grid-template-columns:1fr 1fr}
  .lb-prev{left:10px}.lb-next{right:10px}
}
@media (max-width:420px){
  .gallery{grid-template-columns:1fr}
  .g-a{grid-column:span 1}
}
