/* ============================================================================
   PILOTIS — Template « Le Dossier de Preuve »
   Éditorial institutionnel santé. La preuve datée est le matériau de design.
   Grille à filets, zéro ombre flottante. Premium parce que rigoureux.

   Identité = squelette (Pilotis, non surchargeable par le client) :
     grille à filets · sur-titres numérotés · proof-stamps datés · pas d'ombres.
   Épiderme = tokens surchargés par client (couleurs, police de marque, formes).
   Valeurs par défaut ci-dessous = preset "praticien-moderne".
   ========================================================================== */

/* ---- Polices self-hostées (RGPD santé : aucun CDN tiers) ---- */
@font-face{font-family:'Space Grotesk';src:url('/fonts/space-grotesk-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('/fonts/space-grotesk-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Space Grotesk';src:url('/fonts/space-grotesk-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'InterP';src:url('/fonts/inter-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'InterP';src:url('/fonts/inter-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'InterP';src:url('/fonts/inter-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'PlexMono';src:url('/fonts/ibm-plex-mono-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'PlexMono';src:url('/fonts/ibm-plex-mono-500.woff2') format('woff2');font-weight:500;font-display:swap}

:root{
  /* — Typographie (3 rôles) — */
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-text:'InterP',system-ui,-apple-system,sans-serif;
  --font-mono:'PlexMono',ui-monospace,'SFMono-Regular',monospace;
  --weight-display:600;
  --tracking-display:-0.01em;
  --tracking-kicker:0.16em;
  --scale-ratio:1.25;
  --step-0:1.0625rem;
  --step--1:calc(var(--step-0)/1.125);
  --step-1:calc(var(--step-0)*var(--scale-ratio));
  --step-2:calc(var(--step-1)*var(--scale-ratio));
  --step-3:calc(var(--step-2)*var(--scale-ratio));
  --step-4:calc(var(--step-3)*var(--scale-ratio));
  --step-5:calc(var(--step-4)*var(--scale-ratio));

  /* — Couleur (split sémantique) — */
  --ink:#181d23;
  --pri:#1f5fa6;
  --pri-strong:#163f6f;
  --pri-soft:#6f9bc7;
  --pri-pale:#eef3f9;
  --accent:#b1492c;
  --surface:#ffffff;
  --surface-2:#f5f6f7;
  --rule:#d9dde2;
  --proof:#5d6772;
  --text:#2c343d;
  --muted:#69727c;

  /* — Verrouillé Pilotis (états, non surchargeable côté marque) — */
  --state-ok:#2e7d50;
  --state-few:#bf7211;
  --state-full:#c0392b;
  --focus:#1f5fa6;

  /* — Forme & densité — */
  --radius:6px;
  --radius-card:8px;
  --radius-pill:999px;
  --rule-weight:1px;
  --shadow-strength:0;
  --space:1rem;
  --maxw:1140px;

  /* — Imagerie — */
  --img-ratio:4/3;
  --hero-overlay:0.55;

  /* — Motion — */
  --ease:cubic-bezier(.22,.61,.36,1);
  --reveal-dist:8px;
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-text);
  font-size:var(--step-0);
  line-height:1.6;
  color:var(--text);
  background:var(--surface);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:var(--weight-display);color:var(--ink);line-height:1.1;letter-spacing:var(--tracking-display)}
a{color:var(--pri);text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.container-narrow{max-width:760px}
.mono{font-family:var(--font-mono)}

/* ---------- Sur-titre numéroté (signature) ---------- */
.kicker{
  font-family:var(--font-mono);
  font-size:.72rem;
  font-weight:500;
  letter-spacing:var(--tracking-kicker);
  text-transform:uppercase;
  color:var(--proof);
  display:flex;align-items:center;gap:10px;
}
.kicker .num{color:var(--pri)}
.kicker::after{content:"";flex:1;height:var(--rule-weight);background:var(--rule)}
.section-num h2{font-size:var(--step-3);margin-top:14px}
.section-num .lead{color:var(--muted);max-width:60ch;margin-top:8px}

/* ---------- Filet (séparateur) ---------- */
.rule{height:var(--rule-weight);background:var(--rule);border:0}

/* ---------- Proof-stamp (signature : la donnée n'est jamais nue) ---------- */
.proof{
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.02em;
  color:var(--proof);
  display:inline-flex;align-items:center;gap:7px;
  margin-top:8px;
}
.proof::before{content:"";width:14px;height:var(--rule-weight);background:var(--proof);display:inline-block}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:.95rem;
  padding:13px 22px;border-radius:var(--radius);cursor:pointer;border:var(--rule-weight) solid transparent;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
  letter-spacing:0;line-height:1;
}
.btn-primary{background:var(--pri);color:#fff}
.btn-primary:hover{background:var(--pri-strong)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-lg{padding:16px 28px;font-size:1rem}
.btn-block{width:100%}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(8px);border-bottom:var(--rule-weight) solid var(--rule)}
.nav-inner{display:flex;align-items:center;gap:24px;height:64px}
.nav-brand{display:flex;align-items:center;gap:12px;color:var(--ink);font-family:var(--font-display);font-weight:600;font-size:1.05rem}
.nav-logo{width:34px;height:34px;border-radius:var(--radius);background:var(--pri);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700}
.nav-logo-img{background:transparent}
.nav-links{display:flex;gap:24px;margin-left:auto}
.nav-links a{color:var(--text);font-size:.92rem}
.nav-links a:hover{color:var(--pri)}
.nav-cta{margin-left:0}

/* ---------- Hero preuve (asymétrique 7/5) ---------- */
.hero{border-bottom:var(--rule-weight) solid var(--rule);background:var(--surface)}
.hero-grid{display:grid;grid-template-columns:7fr 5fr;gap:48px;padding:64px 0 56px;align-items:center}
.hero-main h1{font-size:var(--step-5);letter-spacing:-0.02em;margin:18px 0 18px}
.hero-sub{font-size:var(--step-1);color:var(--muted);max-width:34ch;margin-bottom:22px}
.hero-proof{font-family:var(--font-mono);font-size:.86rem;color:var(--ink);display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center;margin-bottom:28px}
.hero-proof b{color:var(--pri);font-weight:500}
.hero-proof .sep{color:var(--rule)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* carte identité OF */
.idcard{border:var(--rule-weight) solid var(--rule);border-radius:var(--radius-card);padding:24px;background:var(--surface-2)}
.idcard-top{display:flex;align-items:center;gap:14px;padding-bottom:16px;border-bottom:var(--rule-weight) solid var(--rule)}
.idcard-logo{width:46px;height:46px;border-radius:var(--radius);background:var(--pri);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:1.3rem;flex:0 0 auto}
.idcard-logo img{width:100%;height:100%;object-fit:contain}
.idcard-of{font-family:var(--font-display);font-weight:600;color:var(--ink);line-height:1.2}
.idcard-da{font-family:var(--font-mono);font-size:.7rem;color:var(--proof);margin-top:3px}
.idcard-pills{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0}
.pill{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border:var(--rule-weight) solid var(--rule);border-radius:var(--radius-pill);color:var(--ink)}
.idcard-founder{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:var(--rule-weight) solid var(--rule)}
.idcard-founder img{width:48px;height:48px;border-radius:var(--radius-pill);object-fit:cover}
.idcard-founder-ph{width:48px;height:48px;border-radius:var(--radius-pill);background:var(--pri-pale);color:var(--pri);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700}
.idcard-founder b{color:var(--ink);font-size:.92rem;display:block}
.idcard-founder span{font-size:.8rem;color:var(--muted)}

/* hero variante image */
.hero-img-col{align-self:stretch;border-radius:var(--radius-card);overflow:hidden;border:var(--rule-weight) solid var(--rule);position:relative;min-height:340px;background-size:cover;background-position:center}

/* ---------- Bande certifs ---------- */
.certs{border-bottom:var(--rule-weight) solid var(--rule);background:var(--surface)}
.certs-inner{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:16px 0}
.certs-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:var(--tracking-kicker);text-transform:uppercase;color:var(--proof)}
.certs-pills{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Sections génériques ---------- */
.section{padding:72px 0;border-bottom:var(--rule-weight) solid var(--rule)}
.section-alt{background:var(--surface-2)}

/* ---------- Tableau de bord qualité ---------- */
.quality-grid{display:grid;grid-template-columns:repeat(4,1fr);margin-top:36px;border:var(--rule-weight) solid var(--rule);border-radius:var(--radius-card);overflow:hidden}
.qblock{padding:28px 24px;border-right:var(--rule-weight) solid var(--rule)}
.qblock:last-child{border-right:0}
.qblock-val{font-family:var(--font-display);font-weight:700;font-size:var(--step-4);color:var(--ink);line-height:1;letter-spacing:-0.02em}
.qblock-val small{font-size:.45em;font-weight:500;color:var(--muted);margin-left:2px}
.qblock-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--proof);margin-top:10px}
.qgauge{margin-top:14px}
.qgauge-track{height:8px;border-radius:var(--radius-pill);background:var(--pri-pale);overflow:hidden}
.qgauge-fill{height:100%;background:var(--pri);width:0;transition:width 1.1s var(--ease)}
.qgauge-cap{font-family:var(--font-mono);font-size:.72rem;color:var(--ink);margin-top:8px}
.quality-note{font-size:.8rem;color:var(--muted);margin-top:14px;max-width:70ch}

/* ---------- Formations (cartes éditoriales, zéro ombre) ---------- */
.formations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:36px;border-top:var(--rule-weight) solid var(--rule)}
.fcard{display:flex;flex-direction:column;padding:28px 26px;border-bottom:var(--rule-weight) solid var(--rule);border-right:var(--rule-weight) solid var(--rule);background:var(--surface);transition:background .2s var(--ease)}
.fcard:hover{background:var(--surface-2)}
.formations-grid .fcard:nth-child(3n){border-right:0}
.fcard-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.fcard-num{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--rule)}
.fcard-code{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;color:var(--proof)}
.fcard h3{font-size:var(--step-1);margin:14px 0 8px}
.fcard-desc{font-size:.92rem;color:var(--muted);flex:1}
.fcard-meta{display:flex;gap:14px;font-family:var(--font-mono);font-size:.74rem;color:var(--ink);margin-top:18px;padding-top:14px;border-top:var(--rule-weight) solid var(--rule)}
.fcard-meta .price{color:var(--pri);font-weight:500}
.fcard-hook{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);margin-top:10px}
.fcard-link{font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--ink);margin-top:16px;display:inline-flex;gap:6px;border-bottom:2px solid transparent;align-self:flex-start;transition:border-color .2s var(--ease)}
.fcard:hover .fcard-link{border-color:var(--pri)}

/* ---------- Sessions (registre à filets) ---------- */
.sessions{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.sessions-list{margin-top:0;border-top:var(--rule-weight) solid var(--rule)}
.srow{display:grid;grid-template-columns:auto 1fr auto auto;gap:20px;align-items:center;padding:20px 0;border-bottom:var(--rule-weight) solid var(--rule)}
.sdate{text-align:center;min-width:54px}
.sdate-day{font-family:var(--font-display);font-weight:700;font-size:1.7rem;color:var(--ink);line-height:1}
.sdate-month{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;color:var(--proof);text-transform:uppercase}
.sinfo-title{font-family:var(--font-display);font-weight:600;color:var(--ink)}
.sinfo-title a{color:inherit}
.sinfo-title a:hover{color:var(--pri)}
.sinfo-meta{font-family:var(--font-mono);font-size:.74rem;color:var(--muted);margin-top:3px}
.splaces{font-family:var(--font-mono);font-size:.76rem;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.splaces .dot{width:8px;height:8px;border-radius:50%;background:var(--state-ok);flex:0 0 auto}
.splaces.few .dot{background:var(--state-few)}
.splaces.full .dot{background:var(--state-full)}
.splaces.full{color:var(--state-full)}

/* rail sticky */
.rail{position:sticky;top:88px;border:var(--rule-weight) solid var(--rule);border-radius:var(--radius-card);padding:22px;background:var(--surface)}
.rail-kicker{font-family:var(--font-mono);font-size:.68rem;letter-spacing:var(--tracking-kicker);text-transform:uppercase;color:var(--proof)}
.rail-date{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--ink);margin:10px 0 4px}
.rail-meta{font-family:var(--font-mono);font-size:.78rem;color:var(--muted);margin-bottom:18px}
.rail .btn{width:100%}

/* barre mobile */
.mobar{display:none}

/* ---------- Parcours (frise reliée par filet) ---------- */
.parcours{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:40px;position:relative}
.pstep{padding:0 22px;position:relative}
.pstep:not(:last-child)::after{content:"";position:absolute;top:18px;right:0;width:100%;height:var(--rule-weight);background:var(--rule);z-index:0}
.pnum{width:38px;height:38px;border-radius:var(--radius-pill);background:var(--surface);border:var(--rule-weight) solid var(--ink);color:var(--ink);font-family:var(--font-display);font-weight:700;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}
.pstep.key .pnum{background:var(--pri);border-color:var(--pri);color:#fff}
.pstep h3{font-size:1.05rem;margin:16px 0 6px}
.pstep p{font-size:.88rem;color:var(--muted)}

/* ---------- Avis vérifiés ---------- */
.avis-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:36px;border-top:var(--rule-weight) solid var(--rule)}
.avis{padding:26px;border-bottom:var(--rule-weight) solid var(--rule);border-right:var(--rule-weight) solid var(--rule)}
.avis-grid .avis:nth-child(2n){border-right:0}
.avis-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.avis-note{font-family:var(--font-display);font-weight:700;font-size:1.7rem;color:var(--pri);line-height:1}
.avis-note small{font-size:.42em;color:var(--muted);font-weight:500}
.avis-meta b{color:var(--ink);font-size:.92rem;display:block;font-family:var(--font-display)}
.avis-tag{font-family:var(--font-mono);font-size:.7rem;color:var(--proof)}
.avis-text{color:var(--text);font-size:.95rem}

/* ---------- Fondateur ---------- */
.founder{display:grid;grid-template-columns:200px 1fr;gap:40px;align-items:center;margin-top:36px}
.founder-photo img{width:100%;border-radius:var(--radius-card);object-fit:cover;aspect-ratio:3/4}
.founder-photo-ph{width:100%;aspect-ratio:3/4;border-radius:var(--radius-card);background:var(--pri-pale);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:3rem;color:var(--pri)}
.founder-body h3{font-size:var(--step-1)}
.founder-role{font-family:var(--font-mono);font-size:.78rem;color:var(--proof);margin:6px 0 14px}
.founder-body p{color:var(--text)}

/* ---------- FAQ ---------- */
.faq-list{margin-top:28px;border-top:var(--rule-weight) solid var(--rule)}
.faq-item{border-bottom:var(--rule-weight) solid var(--rule)}
.faq-item summary{font-family:var(--font-display);font-weight:600;color:var(--ink);padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--pri);font-weight:700}
.faq-item[open] summary::after{content:"–"}
.faq-a{padding:0 0 20px;color:var(--text);max-width:75ch}

/* ---------- Footer colophon ---------- */
.footer{background:var(--ink);color:#cfd6dd;padding:56px 0 0}
.footer a{color:#fff}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer-brand{display:flex;align-items:center;gap:12px;color:#fff;font-family:var(--font-display);font-weight:600;font-size:1.1rem;margin-bottom:14px}
.footer-brand .nav-logo{background:rgba(255,255,255,.12)}
.footer h4{color:#fff;font-size:.78rem;font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.footer p,.footer a{font-size:.9rem;line-height:1.9}
.footer-legal{border-top:var(--rule-weight) solid rgba(255,255,255,.15);padding:18px 0;font-size:.78rem;color:#9aa4ad}
.colophon{border-top:var(--rule-weight) solid rgba(255,255,255,.15);padding:18px 0;font-family:var(--font-mono);font-size:.78rem;color:#9aa4ad;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.colophon .strates{display:inline-flex;gap:3px;align-items:center;vertical-align:middle;margin-right:6px}

/* ---------- Pages secondaires ---------- */
.page-hero{border-bottom:var(--rule-weight) solid var(--rule);padding:56px 0}
.breadcrumb{font-family:var(--font-mono);font-size:.74rem;color:var(--proof);margin-bottom:14px}
.breadcrumb a{color:var(--proof)}
.legal-content h2{font-size:1.2rem;margin:28px 0 10px}
.legal-content p,.legal-content li{color:var(--text);margin-bottom:10px}
.legal-content ul{padding-left:20px}
.fpage-meta{display:flex;gap:18px;font-family:var(--font-mono);font-size:.82rem;margin:18px 0 24px;flex-wrap:wrap}
.fpage-objectifs{padding-left:18px}
.fpage-objectifs li{margin-bottom:8px}
.fpage-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:10px}
.fpage-block{margin-bottom:28px}
.fpage-block h2{font-size:1.25rem;margin-bottom:12px}
.empty-msg{color:var(--muted);font-style:italic}
.apropos-text{font-size:1.05rem;color:var(--text)}

/* ---------- Modal inscription ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(20,25,30,.6);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}
.modal-overlay[hidden]{display:none}
.modal{background:var(--surface);border-radius:var(--radius-card);max-width:560px;width:100%;padding:32px;max-height:90vh;overflow:auto;border:var(--rule-weight) solid var(--rule)}
.modal h3{font-size:1.4rem;margin-bottom:6px}
.modal-session{font-family:var(--font-mono);font-size:.82rem;color:var(--pri);margin-bottom:18px}
.modal-close{float:right;background:none;border:0;font-size:1.3rem;cursor:pointer;color:var(--muted)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-field{margin-bottom:14px;display:flex;flex-direction:column}
.form-field label{font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:5px}
.form-field input,.form-field select,.form-field textarea{font-family:var(--font-text);font-size:.95rem;padding:11px 13px;border:var(--rule-weight) solid var(--rule);border-radius:var(--radius);background:var(--surface);color:var(--text)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:2px solid var(--focus);outline-offset:1px;border-color:var(--focus)}
.hp-field{position:absolute;left:-9999px}
.form-error{background:#fdecea;color:var(--state-full);padding:10px 14px;border-radius:var(--radius);font-size:.88rem;margin-bottom:12px}
.form-rgpd{font-size:.76rem;color:var(--muted);margin-top:12px}
.form-success{text-align:center;padding:20px 0}
.success-icon{width:60px;height:60px;border-radius:50%;background:var(--state-ok);color:#fff;font-size:1.8rem;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}

/* ---------- Motion (signature : filet qui se trace + reveal) ---------- */
[data-reveal]{opacity:0;transform:translateY(var(--reveal-dist));transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
.rule-draw{transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease)}
.rule-draw.in{transform:scaleX(1)}
@media (prefers-reduced-motion:reduce){
  [data-reveal],[data-reveal].in,.rule-draw,.rule-draw.in{opacity:1!important;transform:none!important;transition:none!important}
  .qgauge-fill{transition:none!important}
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:32px;padding:44px 0}
  .quality-grid{grid-template-columns:repeat(2,1fr)}
  .qblock:nth-child(2n){border-right:0}
  .formations-grid{grid-template-columns:1fr}
  .fcard{border-right:0}
  .sessions{grid-template-columns:1fr}
  .rail{display:none}
  .founder{grid-template-columns:1fr}
  .founder-photo{max-width:200px}
  .avis-grid{grid-template-columns:1fr}
  .avis{border-right:0}
  .parcours{grid-template-columns:1fr 1fr;gap:28px 0}
  .pstep:not(:last-child)::after{display:none}
  .footer-inner{grid-template-columns:1fr}
  .nav-links{display:none}
  .mobar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--surface);border-top:var(--rule-weight) solid var(--rule);padding:12px 16px;gap:12px;align-items:center;justify-content:space-between}
  .mobar-info{font-family:var(--font-mono);font-size:.74rem;color:var(--ink)}
  .mobar .btn{padding:11px 18px}
}
@media (max-width:560px){
  .form-row{grid-template-columns:1fr}
  .quality-grid{grid-template-columns:1fr}
  .qblock{border-right:0}
  :root{--step-5:2.4rem}
}

/* ============================================================================
   MULTI-PAGES — layouts additionnels (tokens only, même langage : filets, plat)
   ========================================================================== */

/* tuiles réassurance / valeurs (réutilise .quality-grid) */
.quality-grid.tiles{grid-template-columns:repeat(4,1fr)}
.tile{display:flex;flex-direction:column;text-decoration:none;transition:background .2s var(--ease)}
a.tile:hover{background:var(--surface-2)}
.tile-text{font-size:.9rem;color:var(--muted);margin:8px 0 12px;flex:1}

/* teaser (home : bloc + CTA aligné à droite) */
.fin-teaser{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.fin-teaser .section-num{margin-bottom:0}

/* financement */
.fin-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:36px;border-top:var(--rule-weight) solid var(--rule)}
.fin-block{padding:28px 26px;border-bottom:var(--rule-weight) solid var(--rule);border-right:var(--rule-weight) solid var(--rule)}
.fin-grid .fin-block:nth-child(2n){border-right:0}
.fin-block-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.fin-block-head h3{font-size:var(--step-1)}
.fin-steps{margin:14px 0 0;padding-left:20px;color:var(--text)}
.fin-steps li{margin-bottom:8px}
.fin-note{margin-top:12px;font-size:.85rem;color:var(--proof);font-family:var(--font-mono)}

/* catalogue : filtres + bloc CTA */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 24px}
.filter-chip{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;padding:8px 16px;border:var(--rule-weight) solid var(--rule);border-radius:var(--radius-pill);background:var(--surface);color:var(--ink);cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease)}
.filter-chip.active,.filter-chip:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.fcard.is-hidden{display:none}
.catalogue-cta,.contact-cta-box{margin-top:36px;border:var(--rule-weight) solid var(--rule);border-radius:var(--radius-card);padding:28px;background:var(--surface-2)}
.catalogue-cta{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.catalogue-cta h3{font-size:var(--step-1);margin-bottom:6px}

/* programme détaillé */
.prog-list{margin-top:8px;border-top:var(--rule-weight) solid var(--rule)}
.prog-step{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:start;padding:18px 0;border-bottom:var(--rule-weight) solid var(--rule)}
.prog-num{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--rule)}
.prog-step h4{font-family:var(--font-display);color:var(--ink);font-size:1.02rem;margin-bottom:4px}
.prog-step p{color:var(--muted);font-size:.92rem}
.prog-dur{font-family:var(--font-mono);font-size:.74rem;color:var(--proof);white-space:nowrap}

/* formateurs */
.formateur-card{display:grid;grid-template-columns:120px 1fr;gap:24px;align-items:start}
.formateur-card .formateur-photo img,.formateur-card .formateur-ph{width:120px;height:120px}
.formateurs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:36px}
.formateur-grid-card .formateur-photo{margin-bottom:14px}
.formateur-photo img{width:100%;border-radius:var(--radius-card);object-fit:cover;aspect-ratio:1/1}
.formateur-ph{width:100%;aspect-ratio:1/1;border-radius:var(--radius-card);background:var(--pri-pale);color:var(--pri);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:2rem}
.formateur-grid-card h3{font-size:1.1rem;margin-bottom:4px}
.formateur-spec{font-family:var(--font-mono);font-size:.74rem;color:var(--pri);margin-top:4px}

/* tableau résultats par formation */
.res-table{margin-top:36px;border-top:var(--rule-weight) solid var(--rule)}
.res-row{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:16px;align-items:center;padding:16px 0;border-bottom:var(--rule-weight) solid var(--rule)}
.res-head{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--proof)}
.res-name{font-family:var(--font-display);font-weight:600;color:var(--ink)}
.res-cell{font-family:var(--font-mono);color:var(--text)}
.res-cell b{font-family:var(--font-display);font-size:1.2rem;color:var(--ink)}
.res-cell small{color:var(--muted)}

@media (max-width:900px){
  .quality-grid.tiles{grid-template-columns:repeat(2,1fr)}
  .fin-grid{grid-template-columns:1fr}
  .fin-block{border-right:0}
  .formateurs-grid{grid-template-columns:1fr 1fr}
  .formateur-card{grid-template-columns:90px 1fr}
  .formateur-card .formateur-photo img,.formateur-card .formateur-ph{width:90px;height:90px}
  .res-row{grid-template-columns:1.5fr 1fr 1fr;font-size:.85rem}
  .res-row .res-cell:last-child,.res-head div:last-child{display:none}
}
@media (max-width:560px){
  .quality-grid.tiles{grid-template-columns:1fr}
  .formateurs-grid{grid-template-columns:1fr}
  .fin-teaser,.catalogue-cta{flex-direction:column;align-items:flex-start}
}
