/* =========================================================================
   VILLA PELAGE - Salon de toilettage premium
   Design system : palette eucalyptus/pin · Bricolage Grotesque + Hanken Grotesk
   Dials : VARIANCE 7 · MOTION 6 · DENSITY 3
   ========================================================================= */

/* ---- Fonts (self-hosted, latin) --------------------------------------- */
@font-face{
  font-family:'Bricolage Grotesque';
  src:url('../fonts/bricolage.woff2') format('woff2');
  font-weight:400 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Hanken Grotesk';
  src:url('../fonts/hanken.woff2') format('woff2');
  font-weight:400 700; font-style:normal; font-display:swap;
}

/* ---- Tokens ------------------------------------------------------------ */
:root{
  --canvas:#F1F3EC;       /* fond principal, off-white eucalyptus froid */
  --canvas-2:#E7EBDE;     /* sections alternées */
  --surface:#FBFCF9;     /* cartes, champs */
  --ink:#1B2620;         /* pin profond, presque noir */
  --ink-2:#3F4A43;       /* texte secondaire */
  --ink-3:#5C6760;       /* assombri → AA sur fonds clairs */
  --line:#D7DCCC;        /* filets */
  --sage:#6E8466;        /* accent unique */
  --sage-deep:#4B5C44;   /* accent sur fond clair (contraste) */
  --sage-soft:#DDE4D1;   /* tuiles, fonds d'accent */

  --btn-bg:var(--ink);
  --btn-fg:var(--canvas);

  --r:20px;              /* cartes, images */
  --r-sm:12px;           /* champs, petits */
  --r-pill:999px;        /* boutons, puces */

  --sh-1:0 1px 2px rgba(27,38,32,.04), 0 4px 14px rgba(27,38,32,.05);
  --sh-2:0 14px 34px -12px rgba(27,38,32,.16);
  --sh-lift:0 20px 46px -14px rgba(27,38,32,.24);

  --ease:cubic-bezier(.16,1,.3,1);
  --nav-h:70px;
}

/* Bloc sombre délibéré (réservation + footer) : tokens locaux,
   valables en clair comme en sombre. */
.panel-dark{
  --canvas:#19221C;
  --canvas-2:#1E2922;
  --surface:#27332B;
  --ink:#EDF0E7;
  --ink-2:#B7C1B2;
  --ink-3:#9AA497;
  --line:#33403A;
  --sage:#A9BE9E;
  --sage-deep:#C4D3B9;
  --sage-soft:#26332A;
  --btn-bg:var(--ink);
  --btn-fg:#19221C;
  --sh-2:0 18px 40px -14px rgba(0,0,0,.5);
  --sh-lift:0 22px 50px -16px rgba(0,0,0,.6);
  background:var(--canvas);
  color:var(--ink);
}

/* Dark mode système : bascule globale de la page */
@media (prefers-color-scheme:dark){
  :root{
    --canvas:#141B16;
    --canvas-2:#19221C;
    --surface:#1F2922;
    --ink:#ECEFE6;
    --ink-2:#B5BFB0;
    --ink-3:#9AA396;
    --line:#2C3833;
    --sage:#A4BA98;
    --sage-deep:#BFD0B4;
    --sage-soft:#222E26;
    --btn-fg:#141B16;
    --sh-1:0 1px 2px rgba(0,0,0,.3), 0 4px 14px rgba(0,0,0,.3);
    --sh-2:0 16px 36px -12px rgba(0,0,0,.55);
    --sh-lift:0 22px 48px -14px rgba(0,0,0,.6);
  }
  .panel-dark{
    --canvas:#10160F; --canvas-2:#141B14; --surface:#1A231B;
  }
}

/* ---- Reset ------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 8px)}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--canvas);
  color:var(--ink-2);
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-optical-sizing:auto;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
ul{list-style:none}
::selection{background:var(--sage);color:var(--canvas)}

/* Focus clavier visible (WCAG 2.4.7) + skip-link */
:focus-visible{outline:2px solid var(--sage-deep);outline-offset:3px;border-radius:4px}
.hero :focus-visible,.nav:not(.scrolled) :focus-visible,.panel-dark :focus-visible{outline-color:#FCFDF9}
.skip{position:absolute;left:-9999px;top:auto;z-index:100}
.skip:focus{left:1rem;top:1rem;background:var(--ink);color:var(--canvas);padding:.7rem 1.2rem;border-radius:10px}

/* ---- Typo -------------------------------------------------------------- */
h1,h2,h3,h4{
  font-family:'Bricolage Grotesque',sans-serif;
  color:var(--ink);
  font-weight:600;
  line-height:1.06;
  letter-spacing:-.02em;
  text-wrap:balance;
}
.display{
  font-size:clamp(2.6rem,1.7rem + 3.9vw,4.35rem);
  font-weight:640;
  letter-spacing:-.032em;
  line-height:1.02;
}
h2{font-size:clamp(2rem,1.45rem + 2.3vw,3.05rem)}
h3{font-size:clamp(1.2rem,1.05rem + .6vw,1.5rem);letter-spacing:-.015em}
p{text-wrap:pretty}
.lead{font-size:clamp(1.1rem,1.02rem + .35vw,1.3rem);line-height:1.55;color:var(--ink-2)}
strong{color:var(--ink);font-weight:600}
.accent{color:var(--sage-deep)}

/* ---- Layout ------------------------------------------------------------ */
.wrap{width:100%;max-width:1180px;margin-inline:auto;padding-inline:clamp(1.25rem,5vw,2.5rem)}
.wrap--narrow{max-width:880px}
section{padding-block:clamp(4.5rem,3.5rem + 5vw,8rem)}
.bg-2{background:var(--canvas-2)}

.section-head{max-width:42rem;margin-bottom:clamp(2.5rem,2rem + 2vw,4rem)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head p{margin-top:1rem;color:var(--ink-2)}

/* Eyebrow : label discret, PAS le tell uppercase-mono */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-weight:600;font-size:.82rem;letter-spacing:.01em;
  color:var(--sage-deep);margin-bottom:1.1rem;
}
.eyebrow::before{
  content:"";width:18px;height:1.5px;background:var(--sage);border-radius:2px;
}

/* ---- Boutons ----------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.975rem;
  line-height:1;white-space:nowrap;padding:.95rem 1.6rem;border-radius:var(--r-pill);
  transition:transform .25s var(--ease),background .25s var(--ease),
             box-shadow .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);
}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn--primary{background:var(--btn-bg);color:var(--btn-fg);box-shadow:var(--sh-1)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--sh-lift)}
.btn--primary:active{transform:translateY(0) scale(.985)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--canvas);transform:translateY(-2px)}
.btn--ghost:active{transform:translateY(0) scale(.985)}
.btn--lg{padding:1.1rem 2rem;font-size:1.05rem}
.btn--block{width:100%}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}

.link-arrow{
  display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--sage-deep);
  border-bottom:1.5px solid transparent;transition:border-color .25s var(--ease),gap .25s var(--ease);
  padding-bottom:1px;
}
.link-arrow svg{width:1.05em;height:1.05em;transition:transform .25s var(--ease)}
.link-arrow:hover{border-color:var(--sage)}
.link-arrow:hover svg{transform:translate(2px,-2px)}

/* ---- Icône en pastille ------------------------------------------------- */
.ico{
  display:grid;place-items:center;width:3rem;height:3rem;flex:none;
  border-radius:14px;background:var(--sage-soft);color:var(--sage-deep);
}
.ico svg{width:1.5rem;height:1.5rem}

/* ---- Navigation -------------------------------------------------------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),backdrop-filter .35s var(--ease);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.nav.scrolled{
  background:var(--canvas); /* repli si color-mix non supporté */
  background:color-mix(in srgb,var(--canvas) 80%,transparent);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 var(--line);
}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:'Bricolage Grotesque',sans-serif;
  font-weight:600;font-size:1.18rem;letter-spacing:-.02em;color:var(--ink)}
.brand__mark{width:34px;height:34px;flex:none}
.nav__links{display:flex;align-items:center;gap:2rem}
.nav__links a{font-weight:500;font-size:.95rem;color:var(--ink-2);position:relative;transition:color .2s var(--ease)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--sage);transition:width .28s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:1rem}
.nav__burger{display:none;width:44px;height:44px;border-radius:12px;align-items:center;justify-content:center}
.nav__burger span{position:relative;width:20px;height:1.6px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
.nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:20px;height:1.6px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease)}
.nav__burger span::before{top:-6px}.nav__burger span::after{top:6px}
.nav.open .nav__burger span{background:transparent}
.nav.open .nav__burger span::before{transform:translateY(6px) rotate(45deg)}
.nav.open .nav__burger span::after{transform:translateY(-6px) rotate(-45deg)}
.nav__menu{display:none}  /* visible uniquement en mobile, voir media query */

/* Nav au-dessus de la vidéo héro : texte clair tant qu'on n'a pas scrollé */
.nav:not(.scrolled) .brand{color:#FCFDF9}
.nav:not(.scrolled) .nav__links a{color:rgba(252,253,249,.82)}
.nav:not(.scrolled) .nav__links a:hover{color:#fff}
.nav:not(.scrolled) .nav__burger span,
.nav:not(.scrolled) .nav__burger span::before,
.nav:not(.scrolled) .nav__burger span::after{background:#FCFDF9}
.nav:not(.scrolled) .nav__cta .btn--primary{background:#FCFDF9;color:#16201A}
.nav.open .brand{color:var(--ink)}
.nav.open .nav__burger span::before,
.nav.open .nav__burger span::after{background:var(--ink)}

/* ---- Hero (vidéo plein cadre) ----------------------------------------- */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;overflow:hidden;color:#FCFDF9;padding-top:var(--nav-h)}
.hero__bg{position:absolute;inset:0;z-index:0;background:#16201A url('../img/hero-poster.webp') center/cover no-repeat}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0}
.hero__scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(100deg,rgba(15,21,17,.92) 0%,rgba(15,21,17,.78) 26%,rgba(15,21,17,.5) 46%,rgba(15,21,17,.16) 72%,transparent 92%),
  linear-gradient(to bottom,rgba(15,21,17,.5) 0%,transparent 22%,transparent 64%,rgba(15,21,17,.46) 100%)}
.hero__inner{position:relative;z-index:2;width:100%}
.hero__copy{max-width:37rem}
.hero h1{margin:.5rem 0 1.4rem;color:#FCFDF9}
.hero .lead{max-width:33rem;color:rgba(252,253,249,.85)}
.hero .eyebrow{color:rgba(252,253,249,.9)}
.hero .eyebrow::before{background:#B9CDAE}
.hero h1,.hero .lead,.hero .eyebrow{text-shadow:0 1px 16px rgba(8,12,10,.55)} /* plancher de lisibilité quelle que soit l'image vidéo */
.hero__actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2.3rem}
.hero .btn--primary{background:#FCFDF9;color:#16201A;box-shadow:0 14px 36px -12px rgba(0,0,0,.55)}
.hero .btn--primary:hover{background:#fff;box-shadow:0 20px 46px -12px rgba(0,0,0,.6)}
.hero .btn--ghost{border-color:rgba(252,253,249,.5);color:#FCFDF9;background:rgba(252,253,249,.08)}
.hero .btn--ghost:hover{background:#FCFDF9;color:#16201A;border-color:#FCFDF9}
@media (prefers-reduced-motion:reduce){.hero__video{display:none}}

/* ---- Trust strip ------------------------------------------------------- */
.trust{border-block:1px solid var(--line)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,3vw,2.5rem);padding-block:2.2rem}
.trust__item{display:flex;align-items:center;gap:.85rem}
.trust__item svg{width:1.6rem;height:1.6rem;color:var(--sage-deep);flex:none}
.trust__item b{display:block;font-family:'Bricolage Grotesque',sans-serif;color:var(--ink);font-weight:600;font-size:1.02rem;line-height:1.15}
.trust__item span{font-size:.86rem;color:var(--ink-3)}

/* ---- Feature rows (prestations vedettes) ------------------------------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.feature + .feature{margin-top:clamp(3rem,4vw,5.5rem)}
.feature__media img{width:100%;aspect-ratio:1024/1216;object-fit:cover;border-radius:var(--r);box-shadow:var(--sh-2)}
.feature--rev .feature__media{order:2}
.feature__body{max-width:30rem}
.feature__body h3{font-size:clamp(1.5rem,1.2rem + 1.2vw,2.1rem);margin-bottom:1rem}
.feature__list{margin-top:1.5rem;display:grid;gap:.7rem}
.feature__list li{display:flex;align-items:flex-start;gap:.65rem;color:var(--ink-2)}
.feature__list svg{width:1.15rem;height:1.15rem;color:var(--sage-deep);flex:none;margin-top:.35rem}

/* ---- Tuiles de soins (grille) ----------------------------------------- */
.tiles{margin-top:clamp(3rem,4vw,5rem);display:grid;grid-template-columns:repeat(6,1fr);gap:1.1rem}
.tile{
  grid-column:span 2;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:1.7rem 1.5rem;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.tile:hover{transform:translateY(-4px);box-shadow:var(--sh-2);border-color:transparent}
.tile .ico{margin-bottom:1.1rem}
.tile h3{font-size:1.15rem;margin-bottom:.45rem}
.tile p{font-size:.94rem;color:var(--ink-2)}
.tile--accent{background:var(--sage-soft);border-color:transparent}
.tile--accent .ico{background:color-mix(in srgb,var(--sage) 22%,transparent)}
/* Tuile large « Première visite » : casse la grille de 4, layout horizontal */
.tile--wide{grid-column:span 6;display:flex;align-items:center;gap:1.6rem}
.tile--wide .ico{margin-bottom:0}
.tile--wide h3{font-size:1.3rem}
.tile--wide p{max-width:48ch}

/* ---- Le salon (collage éditorial) ------------------------------------- */
.about{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2.5rem,5vw,5rem);align-items:center}
.about__media{position:relative;min-height:380px}
.about__media .a-main{width:84%;border-radius:var(--r);box-shadow:var(--sh-2);aspect-ratio:1216/832;object-fit:cover}
.about__media .a-sub{position:absolute;right:0;bottom:-1.5rem;width:46%;border-radius:var(--r);
  border:5px solid var(--canvas);box-shadow:var(--sh-2);aspect-ratio:1/1;object-fit:cover}
.about__body h2{margin-bottom:1.3rem}
.about__body p + p{margin-top:1.1em}
.about__stats{display:flex;gap:clamp(1.5rem,4vw,3rem);margin-top:2.2rem;flex-wrap:wrap}
.about__stats .n{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:2.2rem;color:var(--ink);line-height:1;letter-spacing:-.02em}
.about__stats .l{font-size:.88rem;color:var(--ink-3);margin-top:.35rem;max-width:9rem}

/* ---- Déroulé (timeline) ------------------------------------------------ */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;counter-reset:step}
.flow__step{position:relative;padding-top:2.6rem}
.flow__step::before{counter-increment:step;content:"0" counter(step);
  font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1rem;color:var(--sage-deep);
  position:absolute;top:0;left:0}
.flow__step::after{content:"";position:absolute;top:.55rem;left:2.6rem;right:-.75rem;height:1.5px;background:var(--line)}
.flow__step:last-child::after{display:none}
.flow__step h3{font-size:1.2rem;margin-bottom:.5rem}
.flow__step p{font-size:.94rem;color:var(--ink-2)}
.flow__dot{position:absolute;top:.05rem;left:2.1rem;width:8px;height:8px;border-radius:50%;background:var(--sage)}

/* ---- Tarifs ------------------------------------------------------------ */
.pricing{display:grid;grid-template-columns:1.35fr .85fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.price-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:.6rem clamp(1.4rem,3vw,2.2rem);box-shadow:var(--sh-1)}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.35rem 0}
.price-row + .price-row{border-top:1px solid var(--line)}
.price-row__info{display:flex;align-items:center;gap:1rem}
.price-row .ico{width:2.6rem;height:2.6rem;border-radius:12px}
.price-row .ico svg{width:1.3rem;height:1.3rem}
.price-row h3{font-size:1.12rem;margin-bottom:.1rem}
.price-row small{color:var(--ink-3);font-size:.85rem}
.price-row__amt{text-align:right;flex:none}
.price-row__amt b{font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:1.4rem;color:var(--ink);letter-spacing:-.02em}
.price-row__amt span{display:block;font-size:.78rem;color:var(--ink-3)}
.price-aside{background:var(--sage-soft);border-radius:var(--r);padding:clamp(1.6rem,3vw,2.2rem);position:sticky;top:calc(var(--nav-h) + 1.5rem)}
.price-aside h3{font-size:1.3rem;margin-bottom:.7rem}
.price-aside p{font-size:.96rem;color:var(--ink-2);margin-bottom:1.5rem}
.price-aside .btn{margin-top:.3rem}
.price-note{font-size:.82rem;color:var(--ink-3);margin-top:1.5rem;display:flex;gap:.5rem;align-items:flex-start}
.price-note svg{width:1rem;height:1rem;flex:none;margin-top:.2rem;color:var(--sage-deep)}

/* ---- Avis -------------------------------------------------------------- */
.reviews{display:grid;grid-template-columns:1.2fr 1fr;gap:1.3rem;align-items:stretch}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.6rem,3vw,2.4rem);display:flex;flex-direction:column;gap:1.1rem}
.review--feat{justify-content:space-between}
.review__col{display:grid;gap:1.3rem}
.review .quo{width:2rem;height:2rem;color:var(--sage)}
.review .quo--sm{width:1.5rem;height:1.5rem}
.review__stars{display:flex;gap:.15rem;color:var(--sage)}
.review__stars svg{width:1.05rem;height:1.05rem}
.review p{color:var(--ink);font-size:1.02rem;line-height:1.55}
.review--feat p{font-size:clamp(1.15rem,1rem + .7vw,1.5rem);font-family:'Bricolage Grotesque',sans-serif;font-weight:500;letter-spacing:-.01em;line-height:1.32}
.review__by{display:flex;align-items:center;gap:.75rem;margin-top:auto}
.review__by .av{width:2.6rem;height:2.6rem;border-radius:50%;object-fit:cover;flex:none}
.review__by b{display:block;color:var(--ink);font-weight:600;font-size:.96rem}
.review__by span{font-size:.84rem;color:var(--ink-3)}

/* ---- Réservation (bloc sombre) ----------------------------------------- */
.book{position:relative}
.book__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:start}
.book__intro h2{margin-bottom:1.2rem}
.book__intro .lead{color:var(--ink-2)}
.book__contact{margin-top:2.4rem;display:grid;gap:1.3rem}
.book__contact li{display:flex;align-items:flex-start;gap:.95rem}
.book__contact .ico{background:var(--sage-soft);color:var(--sage-deep);width:2.7rem;height:2.7rem;border-radius:12px}
.book__contact .ico svg{width:1.3rem;height:1.3rem}
.book__contact b{display:block;color:var(--ink);font-weight:600;font-size:.97rem;margin-bottom:.1rem}
.book__contact span,.book__contact a{color:var(--ink-2);font-size:.94rem}
.book__contact a:hover{color:var(--sage-deep)}
.book__embed{background:var(--surface);border-radius:var(--r);padding:.5rem;box-shadow:var(--sh-2);min-height:560px;overflow:hidden}
.cal-loading{display:grid;place-items:center;min-height:540px;gap:1rem;text-align:center;padding:2rem;color:var(--ink-3)}
.cal-loading .spin{width:30px;height:30px;border-radius:50%;border:2.5px solid var(--line);border-top-color:var(--sage);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.cal-fallback{display:none;text-align:center;padding:2.5rem 1.5rem}
.cal-fallback.show{display:block}

/* ---- Footer ------------------------------------------------------------ */
.foot{padding-block:clamp(3.5rem,4vw,5rem) 2rem}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem clamp(1.5rem,3vw,3rem)}
.foot__brand .brand{color:var(--ink);margin-bottom:1rem}
.foot__brand p{font-size:.92rem;color:var(--ink-3);max-width:22rem}
.foot__social{display:flex;gap:.6rem;margin-top:1.4rem}
.foot__social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);color:var(--ink-2);transition:all .25s var(--ease)}
.foot__social a:hover{background:var(--sage);border-color:var(--sage);color:var(--canvas);transform:translateY(-2px)}
.foot__social svg{width:1.2rem;height:1.2rem}
.foot__col h4{font-family:'Hanken Grotesk',sans-serif;font-size:.95rem;font-weight:600;letter-spacing:0;color:var(--ink);margin-bottom:1.1rem}
.foot__col ul{display:grid;gap:.7rem}
.foot__col a{display:inline-block;padding-block:.25rem}
.foot__col a,.foot__col li{font-size:.93rem;color:var(--ink-2);transition:color .2s}
.foot__col a:hover{color:var(--sage-deep)}
.foot__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-top:clamp(2.5rem,4vw,3.5rem);padding-top:1.6rem;border-top:1px solid var(--line);
  font-size:.84rem;color:var(--ink-3)}
.foot__bar a:hover{color:var(--sage-deep)}
.foot__legal{display:flex;gap:1.4rem;flex-wrap:wrap}

/* ---- Pages légales (prose) --------------------------------------------- */
.legal{max-width:760px;margin-inline:auto;padding:calc(var(--nav-h) + 3rem) clamp(1.25rem,5vw,2.5rem) 5rem}
.legal .back{display:inline-flex;align-items:center;gap:.45rem;color:var(--sage-deep);font-weight:600;margin-bottom:2.2rem}
.legal .back svg{width:1.05em;height:1.05em;transform:rotate(180deg)}
.legal h1{font-size:clamp(2rem,1.5rem + 2vw,2.8rem);margin-bottom:1.4rem}
.legal h2{font-size:1.3rem;margin:2.4rem 0 .7rem}
.legal p,.legal li{color:var(--ink-2);margin-bottom:1rem;line-height:1.7}
.legal ul{padding-left:1.2rem;list-style:disc;margin-bottom:1rem}
.legal li{margin-bottom:.45rem}
.legal a:not(.back){color:var(--sage-deep);border-bottom:1px solid var(--line)}
.legal strong{color:var(--ink)}
.legal .muted{color:var(--ink-3);font-size:.9rem;margin-top:2.5rem}

/* ---- Reveal (motion) --------------------------------------------------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-d="1"]{transition-delay:.08s}
[data-reveal][data-d="2"]{transition-delay:.16s}
[data-reveal][data-d="3"]{transition-delay:.24s}
[data-reveal][data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
  .btn,.tile,.foot__social a{transition:none!important}
}

/* ---- Responsive -------------------------------------------------------- */
@media (max-width:980px){
  .hero__copy{max-width:none}
  .about{grid-template-columns:1fr}
  .about__media{max-width:480px}
  .pricing{grid-template-columns:1fr}
  .price-aside{position:static}
  .book__grid{grid-template-columns:1fr;gap:2.5rem}
  .reviews{grid-template-columns:1fr}
  .flow{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}
  .flow__step::after{display:none}
  .flow__dot{display:none}
  .tiles{grid-template-columns:repeat(2,1fr)}
  .tile{grid-column:auto}
  .tile--wide{grid-column:1/-1}
  .foot__top{grid-template-columns:1fr 1fr}
  .foot__brand{grid-column:1/-1}
}
@media (max-width:760px){
  .nav__links,.nav__cta .btn{display:none}
  .nav__burger{display:flex}
  .nav.open{background:var(--canvas);backdrop-filter:none;box-shadow:0 1px 0 var(--line)}
  .nav__menu{
    position:fixed;inset:var(--nav-h) 0 auto 0;background:var(--canvas);
    border-bottom:1px solid var(--line);padding:1.5rem clamp(1.25rem,5vw,2.5rem) 2rem;
    display:none;flex-direction:column;gap:.3rem;box-shadow:var(--sh-2);
  }
  .nav.open .nav__menu{display:flex}
  .nav__menu a:not(.btn){padding:.85rem 0;font-size:1.05rem;border-bottom:1px solid var(--line);color:var(--ink)}
  .nav__menu .btn{display:inline-flex;margin-top:1rem;justify-content:center}
  .hero{align-items:flex-end;padding-bottom:3.4rem}
  .hero__scrim{background:linear-gradient(to bottom,rgba(16,22,18,.5) 0%,rgba(16,22,18,.12) 30%,rgba(16,22,18,.5) 70%,rgba(16,22,18,.85) 100%)}
  .feature,.feature--rev .feature__media{grid-template-columns:1fr;order:0}
  .feature__media{order:-1}
  .trust .wrap{grid-template-columns:1fr 1fr;gap:1.5rem}
  .about__stats{gap:2rem}
  .foot__top{grid-template-columns:1fr}
  .foot__bar{flex-direction:column;align-items:flex-start;gap:1rem}
}
@media (max-width:460px){
  .tiles{grid-template-columns:1fr}
  .tile--wide{grid-column:auto;flex-direction:column;align-items:flex-start;gap:1.1rem}
  .flow{grid-template-columns:1fr}
  .trust .wrap{grid-template-columns:1fr}
  .hero__actions .btn{flex:1 1 auto}
  .about__media .a-sub{width:50%}
}
