/* ════════════════════════════════════════════════════════════════════
   DAVID CAM — "Le Dossier" : le site comme pièce justificative.
   Sérénité Qualiopi · cachet CONFORME tamponné au scroll · finale noire.
   Fraunces (display) × Host Grotesk (corps) × IBM Plex Mono (réfs dossier)
   ════════════════════════════════════════════════════════════════════ */
:root{
  --creme:#F6F1E7;        /* fond principal — papier chaud */
  --velin:#FBF8F1;        /* fiches / attestation */
  --marge:#EFE9DC;        /* respirations, sections alternées */
  --encre:#15120D;        /* texte principal (noir chaud) */
  --solennel:#0C0A07;     /* UNIQUE aplat noir — finale */
  --or:#C8A24B;           /* cachet, CTA, accents */
  --or-clair:#E3C77F;     /* halo de cachet, surlignage */
  --ocre:#B5762E;         /* rappel veste — liens, accents chauds */
  --sepia:#5B5142;        /* corps secondaire, mono, mentions */
  --filet:#E4DBC8;        /* hairlines 1px */
  --rouge:#9E3B2E;        /* filigrane "non conforme ?" — §02 only */
  --vert:#5E7A52;         /* coche conforme */
  --on-dark:#F3ECDC;
  --on-dark-mut:rgba(243,236,220,.58);
  --line-dark:rgba(243,236,220,.14);
  --max:1080px;
  --disp:"Newsreader",Georgia,"Times New Roman",serif;
  --sans:"Host Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--creme);color:var(--encre);font-family:var(--sans);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3{margin:0;font-weight:400}
.disp{font-family:var(--disp);font-weight:380;letter-spacing:-.01em;line-height:1.04;
  font-optical-sizing:auto}
.mono{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sepia)}
.ital{font-family:var(--disp);font-style:italic;color:var(--ocre)}
em.sigword{font-style:normal;position:relative;white-space:nowrap}
.sig-stroke{position:absolute;left:-1%;right:-1%;bottom:-.18em;width:102%;height:.42em;overflow:visible;pointer-events:none}
.sig-stroke path{fill:none;stroke:var(--or);stroke-width:7;stroke-linecap:round;stroke-dasharray:340;stroke-dashoffset:340}
html.js .in .sig-stroke path,html.js .sig-stroke.draw path{animation:draw 1.1s cubic-bezier(.6,.05,.2,1) .3s forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ── Cachet CONFORME (signature système) ─────────────────────────── */
.stamp{display:inline-block;color:var(--or);transform:rotate(-5deg)}
.stamp svg{display:block;width:100%;height:100%;overflow:visible}
.stamp .ring{fill:none;stroke:currentColor;stroke-width:2.4}
.stamp .ring2{fill:none;stroke:currentColor;stroke-width:1;opacity:.7}
.stamp .ctext{fill:currentColor;font-family:var(--mono);font-weight:500;letter-spacing:1.5px}
.stamp .mono-dc{fill:currentColor;font-family:var(--disp);font-weight:600;font-style:italic}

/* ── Boutons ─────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;padding:.92em 1.7em;border-radius:6px;
  font-weight:600;font-size:.96rem;border:1px solid transparent;cursor:pointer;transition:.22s ease;white-space:nowrap;font-family:var(--sans)}
.btn-or{background:var(--or);color:#241902;box-shadow:0 12px 26px -14px rgba(200,162,75,.85)}
.btn-or:hover{background:#D2AE57;transform:translateY(-1px)}
.btn-ghost{color:var(--encre);border-color:var(--filet);background:transparent}
.btn-ghost:hover{border-color:var(--or);color:var(--ocre)}
.link-down{font-size:.92rem;color:var(--sepia);border-bottom:1px solid var(--filet);padding-bottom:2px;transition:.2s}
.link-down:hover{color:var(--ocre);border-color:var(--ocre)}
.btn .arw{transition:transform .25s}.btn:hover .arw{transform:translateX(3px)}

/* ── 00 · Bandeau-dossier (header) ───────────────────────────────── */
.dossier-bar{position:sticky;top:0;z-index:70;background:rgba(246,241,231,.88);backdrop-filter:blur(12px) saturate(1.3);
  border-bottom:1px solid var(--filet)}
.dossier-prog{position:absolute;left:0;bottom:-1px;height:2px;width:0;background:linear-gradient(90deg,var(--ocre),var(--or));transition:width .15s linear}
.dossier-inner{display:flex;align-items:center;gap:24px;height:66px}
.dossier-id{display:flex;align-items:center;gap:11px;flex:none}
.dossier-seal{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--or);display:grid;place-items:center;color:var(--ocre);font-family:var(--disp);font-weight:600;font-style:italic;font-size:.85rem}
.dossier-ref{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sepia)}
.dossier-nav{display:flex;gap:26px;margin:0 auto;font-size:.88rem;color:var(--sepia)}
.dossier-nav a{position:relative;padding:4px 0;transition:color .2s}
.dossier-nav a:hover,.dossier-nav a.active{color:var(--encre)}
.dossier-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--or)}
.dossier-cta{flex:none;padding:.6em 1.25em;font-size:.86rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.burger span{width:22px;height:2px;background:var(--encre);transition:.25s}

/* ── 01 · Hero ───────────────────────────────────────────────────── */
.hero{position:relative;overflow:hidden;padding:84px 0 92px}
.hero::before{content:"";position:absolute;top:-20%;right:-10%;width:55vw;height:55vw;max-width:680px;max-height:680px;
  background:radial-gradient(circle,rgba(181,118,46,.10),transparent 62%);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.32fr 1fr;gap:56px;align-items:center}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sepia);margin:0 0 26px;display:flex;align-items:center;gap:11px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--ocre)}
.hero-title{font-family:var(--disp);font-weight:360;font-size:clamp(2.5rem,5.7vw,4.4rem);letter-spacing:-.018em;line-height:1.02;font-optical-sizing:auto}
.hero-prom{font-family:var(--disp);font-weight:340;font-size:clamp(1.4rem,2.5vw,2rem);color:var(--sepia);margin:18px 0 0;line-height:1.16}
.hero-sub{font-size:1.12rem;color:var(--encre);max-width:42ch;margin:26px 0 32px;line-height:1.55}
.hero-sub b{font-weight:600}
.hero-cta{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
/* portrait de confiance */
.hero-portrait{position:relative;justify-self:center}
.portrait-frame{position:relative;border:1px solid var(--or);border-radius:2px;padding:9px;background:var(--velin);
  box-shadow:0 40px 80px -44px rgba(21,18,13,.4)}
.portrait-frame::after{content:"";position:absolute;inset:9px;border:1px solid rgba(200,162,75,.35);pointer-events:none}
.portrait-frame img{display:block;width:300px;max-width:62vw;aspect-ratio:4/5;object-fit:cover;border-radius:1px}
.portrait-cap{margin:12px 2px 0;font-family:var(--mono);font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;color:var(--sepia);display:flex;justify-content:space-between;gap:8px}
.portrait-stamp{position:absolute;right:-26px;bottom:14px;width:96px;height:96px;filter:drop-shadow(0 8px 16px rgba(21,18,13,.18))}
.hero-reass{margin:22px 0 0;font-family:var(--mono);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--sepia);text-align:center}

/* ── Sections génériques ─────────────────────────────────────────── */
.section{position:relative;padding:clamp(64px,9vw,118px) 0}
.piece-no{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ocre);display:flex;align-items:center;gap:10px;margin:0 0 18px}
.piece-no::before{content:"";width:22px;height:1px;background:var(--or)}
.sec-title{font-family:var(--disp);font-weight:360;font-size:clamp(1.9rem,3.6vw,2.9rem);letter-spacing:-.015em;line-height:1.06;max-width:20ch}
.sec-intro{color:var(--sepia);font-size:1.12rem;margin:18px 0 0;max-width:54ch;line-height:1.55}
.alt{background:var(--marge)}

/* ── 02 · La pile (Avant) ────────────────────────────────────────── */
.pile-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:14px}
.pile-text .sec-title{max-width:16ch}
.pile-stage{position:relative;height:360px}
.pile-stage::before{content:"NON CONFORME ?";position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--disp);font-weight:600;font-size:2.4rem;color:var(--rouge);opacity:.07;transform:rotate(-8deg);letter-spacing:.04em;pointer-events:none}
.paper{position:absolute;left:50%;top:50%;width:260px;background:var(--velin);border:1px solid var(--filet);border-radius:3px;
  padding:15px 18px;box-shadow:0 14px 30px -16px rgba(21,18,13,.25);transition:transform .35s ease}
.paper .mono{display:block;color:var(--ocre);margin-bottom:6px}
.paper b{font-weight:600;font-size:1.02rem}
.paper .src{font-size:.86rem;color:var(--sepia)}
.paper:nth-child(1){transform:translate(-58%,-128px) rotate(-5deg)}
.paper:nth-child(2){transform:translate(-42%,-72px) rotate(3deg)}
.paper:nth-child(3){transform:translate(-56%,-14px) rotate(-2.5deg)}
.paper:nth-child(4){transform:translate(-40%,46px) rotate(4deg)}
.paper:nth-child(5){transform:translate(-54%,104px) rotate(-3.5deg)}
.pile-stage:hover .paper:nth-child(odd){transform-origin:center}
.pile-stage.shiver .paper{animation:shiver .4s ease}
@keyframes shiver{0%,100%{}25%{margin-left:-2px}75%{margin-left:2px}}

/* ── 03 · Le Parcours (signature, scroll-tampon) ─────────────────── */
.parcours{position:relative}
.jalons{position:relative;margin-top:40px;padding-left:34px}
.jalons::before{content:"";position:absolute;left:9px;top:8px;bottom:8px;width:2px;background:var(--filet)}
.jalons-fill{position:absolute;left:9px;top:8px;width:2px;background:linear-gradient(180deg,var(--ocre),var(--or));height:0;transition:height .2s linear}
.jalon{position:relative;padding:26px 0 26px 0;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;border-bottom:1px solid var(--filet)}
.jalon:last-child{border-bottom:0}
.jalon::before{content:"";position:absolute;left:-34px;top:34px;width:20px;height:20px;border-radius:50%;background:var(--creme);border:2px solid var(--filet);transition:.3s}
.jalon.stamped::before{border-color:var(--or);background:var(--or-clair)}
.jalon-ref{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ocre);margin:0 0 6px}
.jalon-t{font-family:var(--disp);font-weight:380;font-size:clamp(1.3rem,2.4vw,1.85rem);letter-spacing:-.01em;line-height:1.12}
.jalon-stamp{width:104px;height:104px;flex:none;opacity:0;transform:scale(1.5) rotate(0deg);justify-self:end}
html.js .jalon.stamped .jalon-stamp{animation:thunk .5s cubic-bezier(.3,1.5,.5,1) forwards}
@keyframes thunk{0%{opacity:0;transform:scale(1.6) rotate(2deg)}60%{opacity:1;transform:scale(.92) rotate(-6deg)}100%{opacity:1;transform:scale(1) rotate(-5deg)}}
.jalon-check{margin-top:8px;display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--vert);font-weight:600;opacity:0;transition:opacity .4s .2s}
.jalon.stamped .jalon-check{opacity:1}
.jalon-check svg{width:15px;height:15px;fill:none;stroke:var(--vert);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:20;stroke-dashoffset:20}
html.js .jalon.stamped .jalon-check svg{animation:draw2 .5s ease .25s forwards}
@keyframes draw2{to{stroke-dashoffset:0}}
@media(prefers-reduced-motion:reduce){
  html.js .jalon-stamp{animation:none;opacity:1;transform:scale(1) rotate(-5deg)}
  html.js .jalon-check svg{animation:none;stroke-dashoffset:0}
}

/* ── 04 · L'attestation modèle (Après) ───────────────────────────── */
.attest-wrap{display:flex;justify-content:center;margin-top:10px}
.attest{position:relative;width:100%;max-width:680px;background:var(--velin);border:1px solid var(--filet);border-radius:4px;
  padding:48px clamp(28px,5vw,56px) 52px;box-shadow:0 50px 90px -50px rgba(21,18,13,.35)}
.attest::before{content:"";position:absolute;inset:14px;border:1px solid var(--or);opacity:.3;border-radius:2px;pointer-events:none}
.attest-head{text-align:center;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ocre);margin-bottom:8px}
.attest-title{text-align:center;font-family:var(--disp);font-weight:360;font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:30px}
.attest-list{list-style:none;margin:0 auto;padding:0;max-width:440px;display:grid;gap:15px}
.attest-list li{display:flex;gap:13px;align-items:flex-start;font-size:1.04rem;padding-bottom:14px;border-bottom:1px solid var(--filet)}
.attest-list li:last-child{border-bottom:0}
.attest-list i{flex:none;width:22px;height:22px;border-radius:50%;background:var(--or);color:#fff;display:grid;place-items:center;font-size:.66rem;font-style:normal;margin-top:1px}
.attest-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-top:34px}
.attest-sign svg{width:150px;height:42px;overflow:visible}
.attest-sign path{fill:none;stroke:var(--encre);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:520;stroke-dashoffset:520}
html.js .in .attest-sign path{animation:draw3 1.4s ease .3s forwards}
@keyframes draw3{to{stroke-dashoffset:0}}
.attest-sign .cap{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sepia);margin-top:4px}
.attest-stamp{width:96px;height:96px;opacity:0;transform:scale(1.5)}
html.js .in .attest-stamp{animation:thunk .55s cubic-bezier(.3,1.5,.5,1) .35s forwards}

/* ── 05 · L'Interview ────────────────────────────────────────────── */
.interview{max-width:780px;margin:34px auto 0}
.qa{padding:30px 0;border-top:1px solid var(--filet)}
.qa:first-child{border-top:0}
.qa-q{font-family:var(--disp);font-style:italic;font-weight:400;font-size:clamp(1.25rem,2.3vw,1.7rem);color:var(--ocre);line-height:1.18;margin:0 0 12px}
.qa-a{font-size:1.06rem;color:var(--encre);margin:0;max-width:62ch;line-height:1.6}
.qa-a b{font-weight:600}

/* ── 06 · Ce que je mets en ordre (verbes) ───────────────────────── */
.verbs{margin-top:24px;border-top:1px solid var(--filet)}
.verb{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.4fr);gap:24px;align-items:baseline;
  padding:26px 0;border-bottom:1px solid var(--filet);transition:.25s}
.verb:hover{padding-left:10px}
.verb h3{font-family:var(--disp);font-weight:360;font-size:clamp(1.7rem,3.2vw,2.5rem);letter-spacing:-.01em}
.verb:hover h3{color:var(--ocre)}
.verb p{margin:0;color:var(--sepia);font-size:1rem;line-height:1.5}
.verb .vmono{font-family:var(--mono);font-size:.64rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ocre);display:block;margin-bottom:6px}

/* ── 07 · Preuves de terrain (réalisations) ──────────────────────── */
.fiches{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.fiche{background:var(--velin);border:1px solid var(--filet);border-radius:4px;padding:26px 24px;display:flex;flex-direction:column;gap:12px;transition:.25s;position:relative}
.fiche:hover{border-color:var(--or);transform:translateY(-3px)}
.fiche-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.fiche-sec{font-family:var(--mono);font-size:.62rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ocre)}
.fiche-soon{color:var(--sepia)}
.fiche h3{font-family:var(--disp);font-weight:400;font-size:1.5rem}
.fiche-res{font-size:.96rem;color:var(--encre);line-height:1.5;margin:0}
.fiche-res b{font-weight:600}
.fiche-link{margin-top:auto;font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ocre)}
.fiche-also{margin:28px 0 0;text-align:center;color:var(--sepia);font-size:.96rem}
.fiche-also b{color:var(--encre);font-weight:600}

/* ── 08 · Le concepteur (à propos) ───────────────────────────────── */
.about-grid{display:grid;grid-template-columns:.74fr 1.26fr;gap:54px;align-items:center}
.about-photo{position:relative;border:1px solid var(--filet);border-radius:3px;padding:8px;background:var(--velin)}
.about-photo img{display:block;width:100%;aspect-ratio:1/1;object-fit:cover;object-position:50% 22%;border-radius:1px}
.about-copy p{color:var(--encre);margin:16px 0 0;max-width:54ch;font-size:1.06rem;line-height:1.6}
.about-copy p.muted{color:var(--sepia)}
.about-copy strong{font-weight:600}
.about-sign{margin-top:26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.about-sign svg{width:140px;height:40px;overflow:visible}
.about-sign path{fill:none;stroke:var(--encre);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:520;stroke-dashoffset:520}
html.js .in .about-sign path{animation:draw3 1.4s ease .2s forwards}
.about-sign a{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ocre);border-bottom:1px solid var(--filet);padding-bottom:3px;transition:.2s}
.about-sign a:hover{border-color:var(--ocre)}

/* ── 09 · Pour qui (intercalaires) ───────────────────────────────── */
.tabs{display:flex;flex-wrap:wrap;gap:0;margin-top:18px;border-top:1px solid var(--filet)}
.tab{flex:1 1 30%;min-width:200px;padding:22px 22px;border-bottom:1px solid var(--filet);border-right:1px solid var(--filet);
  font-family:var(--disp);font-weight:400;font-size:1.3rem;display:flex;align-items:center;gap:12px;transition:.22s;position:relative}
.tab::before{content:"";width:8px;height:22px;background:var(--marge);border-radius:0 3px 3px 0;transition:.22s}
.tab:hover{background:var(--velin)}
.tab:hover::before{background:var(--or)}
.who-note{margin:30px 0 0;color:var(--sepia);font-size:1.12rem;max-width:54ch;line-height:1.55}

/* ── 10 · L'appel à signer (finale noire) ────────────────────────── */
.appel{background:var(--solennel);color:var(--on-dark);position:relative;overflow:hidden}
.appel-mono{position:absolute;right:-50px;top:-40px;width:320px;opacity:.05;pointer-events:none}
.appel .piece-no{color:var(--or-clair)}.appel .piece-no::before{background:var(--or)}
.appel-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start;position:relative}
.appel-title{font-family:var(--disp);font-weight:340;font-size:clamp(2rem,4vw,3rem);color:var(--on-dark);line-height:1.05}
.appel-sub{color:var(--on-dark-mut);margin:20px 0 26px;font-size:1.08rem;max-width:42ch}
.appel-reass{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:11px}
.appel-reass li{display:flex;gap:11px;align-items:center;font-size:.96rem;color:var(--on-dark-mut)}
.appel-reass i{flex:none;width:18px;height:18px;border-radius:50%;background:rgba(200,162,75,.18);color:var(--or-clair);display:grid;place-items:center;font-size:.6rem;font-style:normal}
.appel-sign{margin-top:30px;display:flex;align-items:center;gap:16px}
.appel-sign svg{width:140px;height:40px;overflow:visible}
.appel-sign path{fill:none;stroke:var(--or-clair);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:520;stroke-dashoffset:520}
html.js .in .appel-sign path{animation:draw3 1.5s ease .2s forwards}
.appel-stamp{width:60px;height:60px}
/* form */
.dform{position:relative}
.field{display:block;margin-bottom:16px}
.field>span{display:block;font-size:.8rem;color:var(--on-dark-mut);margin-bottom:8px;letter-spacing:.02em}
.field input,.field textarea{width:100%;background:rgba(243,236,220,.04);border:1px solid var(--line-dark);border-radius:4px;
  padding:13px 15px;color:var(--on-dark);font-family:inherit;font-size:1rem;transition:.2s}
.field input::placeholder,.field textarea::placeholder{color:rgba(243,236,220,.26)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--or);background:rgba(243,236,220,.07)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pref{border:0;padding:0;margin:0 0 16px}.pref>span{display:block;font-size:.8rem;color:var(--on-dark-mut);margin-bottom:8px}
.pref-opts{display:flex;gap:10px;flex-wrap:wrap}
.radio{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--line-dark);border-radius:4px;cursor:pointer;font-size:.92rem;transition:.2s}
.radio input{accent-color:var(--or)}
.radio:has(input:checked){border-color:var(--or);background:rgba(200,162,75,.14)}
.btn-block{width:100%;padding:1.05em;margin-top:4px}
.appel-alt{text-align:center;margin-top:16px;font-size:.88rem;color:var(--on-dark-mut)}
.appel-alt a{color:var(--or-clair);border-bottom:1px solid rgba(227,199,127,.35)}

/* ── Colophon ────────────────────────────────────────────────────── */
.colophon{background:#100D08;color:var(--on-dark-mut);padding:40px 0;border-top:1px solid var(--line-dark)}
.colo-inner{display:flex;align-items:center;gap:22px;flex-wrap:wrap;font-size:.88rem}
.colo-inner .mono{color:var(--on-dark-mut)}
.colo-links{display:flex;gap:22px;margin-left:auto}
.colo-links a:hover{color:var(--or-clair)}
.colo-fine{flex-basis:100%;font-size:.74rem;color:rgba(243,236,220,.36);margin:6px 0 0}

/* ── Motion (reveal — jamais de masquage dépendant du scroll) ─────── */
.rv{opacity:1;transform:none}
html.js .rv{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
html.js .rv.in{opacity:1;transform:none}
html.js .rv.d1{transition-delay:.08s}html.js .rv.d2{transition-delay:.16s}html.js .rv.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){html.js .rv{opacity:1;transform:none;transition:none}}

/* ── Responsive ──────────────────────────────────────────────────── */
@media(max-width:900px){
  .hero{padding:48px 0 70px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-portrait{order:-1}
  .pile-grid,.about-grid,.appel-grid{grid-template-columns:1fr;gap:36px}
  .pile-stage{height:330px;max-width:340px;margin:0 auto}
  .fiches{grid-template-columns:1fr}
  .verb{grid-template-columns:1fr;gap:8px}
}
@media(max-width:760px){
  .dossier-nav{display:none}
  .dossier-cta{display:none}
  .burger{display:flex}
  .dossier-bar.open .dossier-nav{display:flex;position:absolute;top:66px;left:0;right:0;background:var(--creme);flex-direction:column;gap:14px;padding:18px 28px;margin:0;border-bottom:1px solid var(--filet)}
  .jalon{grid-template-columns:1fr;gap:14px}
  .jalon-stamp{width:84px;height:84px;justify-self:start}
  .field-row{grid-template-columns:1fr}
  .tab{flex-basis:100%}
}

/* ════════════════ PILOTIS — styles produit (ajouts) ════════════════ */
/* Fenêtre d'application (cadre autour des captures de l'outil) */
.appwin{border-radius:10px;overflow:hidden;background:#fff;border:1px solid var(--filet);
  box-shadow:0 40px 80px -46px rgba(21,18,13,.42)}
.appwin-bar{display:flex;align-items:center;gap:7px;padding:10px 14px;background:#F1ECE0;border-bottom:1px solid var(--filet)}
.appwin-bar i{width:10px;height:10px;border-radius:50%;background:#D6CDB8;display:inline-block}
.appwin-bar em{margin-left:10px;font-style:normal;font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sepia)}
.appwin img{display:block;width:100%}
/* hero : visuel = l'outil */
.hero-tool{position:relative}
.hero-tool .stamp{position:absolute;right:-22px;bottom:-26px;width:104px;height:104px;filter:drop-shadow(0 10px 18px rgba(21,18,13,.2))}

/* Piliers : texte + capture, alternés */
.pilier{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,5vw,64px);align-items:center;
  padding:clamp(40px,6vw,72px) 0;border-top:1px solid var(--filet)}
.pilier:first-of-type{border-top:0}
.pilier:nth-child(even) .pilier-media{order:2}
.pilier-k{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ocre);margin:0 0 14px;display:flex;align-items:center;gap:9px}
.pilier-k::before{content:"";width:18px;height:1px;background:var(--or)}
.pilier h3{font-family:var(--disp);font-weight:380;font-size:clamp(1.6rem,3vw,2.3rem);letter-spacing:-.015em;line-height:1.08;margin:0 0 12px}
.pilier p{margin:0;color:var(--sepia);font-size:1.06rem;line-height:1.58;max-width:46ch}
.pilier-tag{display:inline-block;margin-top:16px;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--vert);border:1px solid var(--filet);border-radius:3px;padding:5px 11px}

/* Comment ça marche : 3 temps */
.etapes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:18px}
.etape{background:var(--velin);border:1px solid var(--filet);border-radius:6px;padding:30px 28px}
.etape-no{font-family:var(--disp);font-style:italic;font-weight:600;color:var(--ocre);font-size:1.1rem}
.etape h3{font-family:var(--disp);font-weight:400;font-size:1.5rem;margin:10px 0 8px}
.etape p{margin:0;color:var(--sepia);font-size:1rem;line-height:1.55}

/* Tarifs */
.pack{background:var(--velin);border:1px solid var(--or);border-radius:8px;padding:30px clamp(26px,4vw,42px);
  display:flex;flex-wrap:wrap;align-items:center;gap:18px 32px;margin-top:14px;box-shadow:0 30px 60px -42px rgba(200,162,75,.5)}
.pack-l{flex:1 1 320px}
.pack-l .mono{color:var(--ocre)}
.pack-l h3{font-family:var(--disp);font-weight:400;font-size:1.7rem;margin:6px 0 6px}
.pack-l p{margin:0;color:var(--sepia);font-size:1rem;line-height:1.5;max-width:52ch}
.pack-price{font-family:var(--disp);font-size:2.1rem;color:var(--encre);white-space:nowrap}
.pack-price small{font-family:var(--sans);font-size:.8rem;color:var(--sepia);display:block;letter-spacing:.02em}
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
.price-card{background:var(--velin);border:1px solid var(--filet);border-radius:8px;padding:30px 26px;display:flex;flex-direction:column}
.price-card.featured{border-color:var(--or);box-shadow:0 30px 60px -42px rgba(200,162,75,.5)}
.price-badge{align-self:flex-start;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:#241902;background:var(--or);border-radius:3px;padding:4px 9px;margin-bottom:14px}
.price-name{font-family:var(--disp);font-weight:400;font-size:1.5rem}
.price-amt{font-family:var(--disp);font-size:2.4rem;color:var(--encre);margin:6px 0 2px}
.price-amt small{font-family:var(--sans);font-size:.9rem;color:var(--sepia)}
.price-tag{color:var(--sepia);font-size:.95rem;font-style:italic;margin:0 0 18px;min-height:2.6em}
.price-feats{list-style:none;margin:0 0 22px;padding:0;display:grid;gap:10px}
.price-feats li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem;color:var(--encre);line-height:1.4}
.price-feats i{flex:none;width:18px;height:18px;border-radius:50%;background:var(--or);color:#fff;display:grid;place-items:center;font-size:.58rem;font-style:normal;margin-top:2px}
.price-card .btn{margin-top:auto}
.price-note{margin:22px 0 0;text-align:center;color:var(--sepia);font-size:.92rem}

/* Preuves produit */
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:14px}
.proof{background:var(--velin);border:1px solid var(--filet);border-radius:6px;padding:28px 26px}
.proof-big{font-family:var(--disp);font-size:2.4rem;color:var(--ocre);line-height:1}
.proof h3{font-family:var(--disp);font-weight:400;font-size:1.35rem;margin:0 0 8px}
.proof p{margin:0;color:var(--sepia);font-size:.97rem;line-height:1.55}

@media(max-width:900px){
  .pilier,.pilier:nth-child(even){grid-template-columns:1fr;gap:26px}
  .pilier:nth-child(even) .pilier-media{order:0}
  .etapes,.pricing,.proof-grid{grid-template-columns:1fr}
}

/* ════════════════ PILOTIS — POLISH (contraste + micro-interactions) ════════════════ */
/* Fonds blancs en alternance avec le crème (plus de contraste, moins plat) */
.white{background:#fff}
.white .paper{box-shadow:0 18px 38px -16px rgba(21,18,13,.32)}

/* Micro-interactions au survol */
.appwin{transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease}
.pilier:hover .appwin,.hero-tool:hover .appwin{transform:translateY(-6px);box-shadow:0 56px 100px -44px rgba(21,18,13,.5)}
.price-card{transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s ease,border-color .3s}
.price-card:hover{transform:translateY(-6px);box-shadow:0 40px 72px -40px rgba(21,18,13,.3)}
.proof{transition:transform .3s cubic-bezier(.2,.7,.2,1),border-color .3s}
.proof:hover{transform:translateY(-5px);border-color:var(--or)}
.pack{transition:box-shadow .3s,transform .3s}
.pack:hover{transform:translateY(-3px);box-shadow:0 40px 70px -40px rgba(200,162,75,.6)}
.pilier-tag{transition:.25s}
.pilier:hover .pilier-tag{border-color:var(--or);color:var(--ocre)}
/* accent doré dans les titres */
.sec-title .ital,.hero-title .ital,.pilier h3 .ital,.attest-title .ital{font-style:italic;color:var(--ocre)}

/* Captures "ambiance" : 2 écrans forts pleins (hero + Conformité), le reste suggéré (moins copiable) */
.appwin.amb{position:relative;transform:rotate(-1deg)}
.appwin.amb img{height:300px;object-fit:cover;object-position:top center}
.appwin.amb::after{content:"";position:absolute;left:0;right:0;bottom:0;height:130px;background:linear-gradient(to top,var(--creme),transparent);pointer-events:none;border-radius:0 0 10px 10px}
@media(max-width:900px){.appwin.amb img{height:210px}}

/* Cadrage ROI (parler en valeur connue du client) + sous-titre tarifs */
.roi{display:flex;gap:14px;align-items:center;background:var(--velin);border:1px solid var(--or-clair);border-left:4px solid var(--or);border-radius:6px;padding:20px 26px;margin:26px 0 6px;font-size:1.08rem;line-height:1.45;color:var(--encre)}
.roi b{font-weight:600;color:var(--ocre)}
.roi-ic{font-size:1.5rem;color:var(--or);flex:none;line-height:1}
.tarifs-sub{font-weight:380;font-size:clamp(1.4rem,2.4vw,1.8rem);margin:48px 0 6px;letter-spacing:-.01em}
.price-amt small{display:inline}
.price-note b{color:var(--encre);font-weight:600}

/* ── Pages légales ───────────────────────────────────────────────── */
.legal-bar{border-bottom:1px solid var(--filet)}
.legal-bar .dossier-inner{justify-content:space-between}
.legal-back{font-size:.9rem;color:var(--sepia);font-weight:500}
.legal-back:hover{color:var(--ocre)}
.legal{max-width:740px;margin:0 auto;padding:clamp(48px,7vw,88px) 28px}
.legal h1{font-family:var(--disp);font-weight:380;font-size:clamp(2rem,4vw,2.9rem);letter-spacing:-.01em;margin:0 0 8px}
.legal .updated{font-family:var(--mono);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--sepia);margin:0 0 40px}
.legal h2{font-family:var(--disp);font-weight:400;font-size:1.35rem;margin:40px 0 12px}
.legal p,.legal li{color:var(--sepia);line-height:1.65;margin:0 0 12px}
.legal ul{padding-left:20px}
.legal strong{color:var(--encre);font-weight:600}
.legal a{color:var(--ocre);border-bottom:1px solid var(--filet);padding-bottom:1px}
