/* ============================================================
   DOMROC - feuille de styles commune (phase 2 factorisation, v2.1)
   Architecture :
   1. tokens :root   2. regles de base   3. refonte header/footer v2
   4. blocs @media EN FIN DE FICHIER, avec specificite renforcee
      (.nav ... / footer.site ...) : ce fichier se charge AVANT le
      <style> de chaque page, les media doivent donc battre les
      regles de base restees inline dans les pages.
   Breakpoint nav unifie : 920px.
   ============================================================ */

:root{
  --avenir:#7C97AE;
  --bp-lg:1024px;
  --bp-md:768px;
  --bp-sm:480px;
  --bp-xl:1280px;
  --dispo:var(--laterite);
  --ease-dom:cubic-bezier(.2,.6,.2,1);
  --eff:var(--laterite);
  --encre:#15191C;
  --nav-h:64px;
  --gris:#62676C;
  --gris-fin:#615E54;
  --ivoire:#EFEEE9;
  --laiton:#B08A4A;
  --laiton-soft:#C29A57;
  --laterite:#9E4A2B;
  --laterite-soft:#B5673F;
  --maxw:1180px;
  --mono:'IBM Plex Mono','SFMono-Regular',Menlo,monospace;
  --motion:280ms;
  --motion-fast:160ms;
  --motion-slow:520ms;
  --mx:clamp(20px,5vw,80px);
  --none:#b7b3a8;
  --opt:#9aa0a4;
  --pierre:#E2E0D8;
  --pierre-2:#D6D3C8;
  --prevu:#6E7378;
  --rac:var(--laiton);
  --read:720px;
  --reserve:var(--laiton);
  --reveal-y:16px;
  --roc:#0F1E2A;
  --roc-700:#162C3C;
  --sans:'Archivo',system-ui,-apple-system,sans-serif;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --stagger:80ms;
  --vendu:#8a8f93;
  --wa:#1f6f5c;
  --wa-soft:#2a8a72;
}

/* ---------------- base ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
::selection{background:var(--laterite);color:var(--ivoire)}
a{color:inherit}
img,svg{display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--mx)}
.mono{font-family:var(--mono)}
.eyebrow::before{content:"+";color:var(--laterite);font-weight:500}
.eyebrow.light{color:var(--laterite-soft)}
.eyebrow.light::before{color:var(--laterite-soft)}
.corner-marks{position:absolute;inset:0;pointer-events:none}
.corner-marks span::before,.corner-marks span::after{content:"";position:absolute;background:var(--laterite)}
.cm-tl{top:0;left:0}
.cm-tr{top:0;right:0;transform:scaleX(-1)}
.cm-bl{bottom:0;left:0;transform:scaleY(-1)}
.cm-br{bottom:0;right:0;transform:scale(-1)}
.skip:focus{left:8px;top:8px}
.wm{font-family:var(--sans);font-weight:600;letter-spacing:.30em;font-size:18px;color:var(--roc);padding-left:.30em;line-height:1}
.wm .roc{color:var(--laterite)}
.wm-desc{font-family:var(--mono);font-size:8px;letter-spacing:.42em;color:var(--gris);padding-left:.42em}
.lang{display:flex;align-items:center;font-family:var(--mono);font-size:12px;letter-spacing:.08em;border:1px solid var(--pierre-2);border-radius:2px;overflow:hidden}
.lang button[aria-pressed="true"]{background:var(--roc);color:var(--ivoire)}
.btn-roc{background:var(--roc);color:var(--ivoire);padding:9px 16px}
.btn-roc:hover{background:var(--roc-700)}
.btn-lat{background:var(--laterite);color:var(--ivoire);padding:14px 22px;font-size:15px}
.btn-lat:hover{background:var(--laterite-soft)}
.nav-cta{flex:none}
.nav-cta .cta-full{display:none}
.nav-cta .cta-min{display:inline}
.nav-cta::after{content:"\2192";display:inline-block;margin-left:7px;transition:transform var(--motion) var(--ease-dom)}
.nav-cta:hover::after,.nav-cta:focus-visible::after{transform:translateX(4px)}
.nav-cta:hover{transform:translateY(-1px)}
.burger span{display:block;width:18px;height:1.6px;background:var(--roc);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:1.6px;background:var(--roc)}
.burger span::before{top:-6px}
.burger span::after{top:6px}
.nav-links.open li{border-top:1px solid var(--pierre)}
.nav-links.open a{display:block;padding:14px 0}
.nav-links a:hover::after,.nav-links a:focus-visible::after{transform:scaleX(1)}
.nav-links a.active::after{transform:scaleX(1);background:var(--laiton)}
.emplacement .gridline{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(255,255,255,.12) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.12) 1px,transparent 1px);background-size:33.33% 33.33%}
.fiche-data .k{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gris)}
.fiche-data .v.ok{color:var(--laterite)}
.gabarit-ribbon{position:absolute;top:-1px;right:-1px;background:var(--pierre);color:var(--gris);font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;padding:5px 10px;z-index:3}
.foot-brand .logo{height:34px;width:auto;display:block;margin-bottom:8px}
.cap-form .form-row{display:flex;gap:8px;flex-wrap:wrap}
.cap-form input[type=email]:focus{outline:2px solid var(--laterite);outline-offset:1px}
.cap-thanks{display:none}
.foot-brand .wm{color:var(--ivoire);font-size:20px}
.foot-brand .wm .roc{color:var(--laterite-soft)}
.foot-base{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--laiton-soft);margin-top:16px}
.foot-brand p{font-size:13.5px;color:#8A95A0;margin-top:14px;max-width:34ch;line-height:1.55}
.foot-col h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#7C8794;margin-bottom:16px;font-weight:500}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a{font-size:14px;text-decoration:none;color:#B9C2CB;transition:color .2s}
.foot-col a:hover{color:var(--ivoire)}
.foot-col .sub{font-size:11.5px;color:#6E7B86;display:block;margin-top:2px;line-height:1.4}
.wa:hover{transform:scale(1.06)}
.wa svg{width:28px;height:28px}
.reveal.in{opacity:1;transform:none}
.anim-title.in{opacity:1;transform:none}
.fiche-stamp.in{opacity:1;transform:none;transition:opacity var(--motion-slow) var(--ease-dom),transform var(--motion-slow) var(--ease-dom)}
:focus-visible{outline:2px solid var(--laterite);outline-offset:3px;border-radius:2px}
.dom-cursor{ --reticule: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%3E%3Cg%20stroke='%230F1E2A'%20stroke-width='2'%3E%3Cline%20x1='12'%20y1='1'%20x2='12'%20y2='8'/%3E%3Cline%20x1='12'%20y1='16'%20x2='12'%20y2='23'/%3E%3Cline%20x1='1'%20y1='12'%20x2='8'%20y2='12'/%3E%3Cline%20x1='16'%20y1='12'%20x2='23'%20y2='12'/%3E%3C/g%3E%3Crect%20x='9.5'%20y='9.5'%20width='5'%20height='5'%20fill='%239E4A2B'%20stroke='%230F1E2A'%20stroke-width='1'/%3E%3C/svg%3E") 12 12, crosshair; --reticule-hover: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%3E%3Crect%20x='4.5'%20y='4.5'%20width='15'%20height='15'%20fill='none'%20stroke='%230F1E2A'%20stroke-width='1.5'/%3E%3Cg%20stroke='%230F1E2A'%20stroke-width='2'%3E%3Cline%20x1='12'%20y1='1'%20x2='12'%20y2='6'/%3E%3Cline%20x1='12'%20y1='18'%20x2='12'%20y2='23'/%3E%3Cline%20x1='1'%20y1='12'%20x2='6'%20y2='12'/%3E%3Cline%20x1='18'%20y1='12'%20x2='23'%20y2='12'/%3E%3C/g%3E%3Crect%20x='9'%20y='9'%20width='6'%20height='6'%20fill='%239E4A2B'%20stroke='%230F1E2A'%20stroke-width='1'/%3E%3C/svg%3E") 12 12, pointer; }
.dom-cursor,.dom-cursor *{cursor:var(--reticule)}
.dom-cursor a,.dom-cursor button,.dom-cursor [role="button"],.dom-cursor .btn,.dom-cursor label,.dom-cursor summary{cursor:var(--reticule-hover)}
.dom-cursor input,.dom-cursor textarea,.dom-cursor select,.dom-cursor [contenteditable="true"]{cursor:text}
#dom-preloader{position:fixed;inset:0;z-index:9999;background:#0F1E2A;display:flex;align-items:center;justify-content:center;transition:opacity .6s cubic-bezier(.2,.6,.2,1),visibility .6s}
#dom-preloader.is-done{opacity:0;visibility:hidden;pointer-events:none}
#dom-preloader .pl-stage{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}
#dom-preloader .pl-ring{position:absolute;inset:0;width:120px;height:120px;animation:domPlSpin 1.4s linear infinite}
#dom-preloader .pl-seal{width:52px;height:52px}
@keyframes domPlSpin{to{transform:rotate(360deg)}}
.crumb a{text-decoration:none;color:#9fb0bd}
@keyframes heroFade{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.pagehead .crumb{animation:heroFade .7s var(--ease-dom) both .05s}
.pay-track{display:flex;gap:2px;margin-bottom:8px}
.pay-track .seg{height:8px;flex:1;background:var(--pierre)}
.pay-track .seg.done{background:var(--laterite)}
.pay-stages b{display:block;color:var(--roc);font-weight:500;font-size:11px;margin-bottom:3px;letter-spacing:.02em}
.pay-note{margin-top:22px;font-size:14.5px;color:var(--encre);line-height:1.55;border-top:1px solid var(--pierre);padding-top:18px}
.pay-note b{font-weight:500;color:var(--roc)}
.aside-piece .pg{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(15,30,42,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(15,30,42,.045) 1px,transparent 1px);background-size:26px 26px}
.aside-ribbon{position:absolute;top:-1px;right:-1px;background:var(--pierre);color:var(--gris);font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;padding:5px 9px;z-index:3}
.aside-piece .ah{position:relative;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--laterite);border-bottom:1px solid var(--pierre);padding-bottom:14px}
.aside-piece .af{padding:12px 0;border-bottom:1px solid var(--pierre)}
.aside-piece .ak{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gris)}
.aside-piece .av{font-family:var(--mono);font-size:14px;color:var(--roc);margin-top:5px}
.aside-piece .av.ok{color:var(--laterite)}
.aside-cap{position:relative;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--gris);margin-top:14px;line-height:1.5}
.retenir .grid-bg{mask-image:radial-gradient(ellipse 80% 100% at 90% 10%,#000 20%,transparent 75%)}
.retenir .lbl{position:relative;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--laterite-soft);margin-bottom:10px}
.retenir p{position:relative;font-family:var(--serif);font-size:clamp(18px,2.3vw,23px);line-height:1.35;margin:0;color:var(--ivoire)}
.retenir p .em{color:var(--laterite-soft);font-style:italic}

/* ============================================================
   Refonte header / footer — design v2 (validée sur maquette)
   ============================================================ */
header.site .nav{height:var(--nav-h)}
header.site .brand .logo{height:38px;margin-bottom:0}
.nav .nav-links a::after{height:2px}

/* sélecteur de langue : toggle texte discret FR · EN */
.nav .lang{border:0;border-radius:0;background:none}
.nav .lang button{padding:0 7px}
.nav .lang button+button::before{content:"·";color:var(--pierre-2);margin-right:12px}
.nav .lang button[aria-pressed="true"]{background:none;color:var(--roc);font-weight:600}

/* CTA header : latérite, seul point chaud de la barre */
.nav a.nav-cta{background:var(--laterite);border-color:var(--laterite);color:var(--ivoire);padding:11px 20px}
.nav a.nav-cta:hover,.nav a.nav-cta:focus-visible{background:var(--laterite-soft);border-color:var(--laterite-soft)}

/* bandeau d'engagement en tête de footer */
footer.site .foot-pledge{position:relative;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;border:1px solid rgba(239,238,233,.16);padding:clamp(22px,3.5vw,36px) clamp(18px,2.5vw,30px);margin-bottom:clamp(36px,5vw,56px)}
footer.site .fp-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--laiton-soft);display:flex;align-items:center;gap:12px;margin-bottom:10px}
footer.site .fp-eyebrow::before{content:"+";color:var(--laiton-soft);font-weight:500}
footer.site .fp-line{font-family:var(--serif);font-size:clamp(19px,2.4vw,26px);line-height:1.35;color:var(--ivoire);max-width:44ch;margin:0}
footer.site .fp-line em{color:var(--laiton-soft)}
footer.site .fp-cta{flex:none;display:inline-flex;align-items:center;background:var(--laterite);border:1px solid var(--laterite);color:var(--ivoire);padding:13px 22px;font-size:14px;font-weight:500;text-decoration:none;transition:background .2s,border-color .2s}
footer.site .fp-cta:hover,footer.site .fp-cta:focus-visible{background:var(--laterite-soft);border-color:var(--laterite-soft)}

/* barre basse du footer : liens rapides */
footer.site .foot-bot .fb-links a{color:#B9C2CB;text-decoration:none;transition:color .2s}
footer.site .foot-bot .fb-links a:hover{color:var(--ivoire)}

/* ============================================================
   Blocs @media — toujours en fin de fichier, spécificité renforcée
   pour battre les règles de base inline des pages (chargées après).
   ============================================================ */

/* footer : 1 colonne mobile (base pages), 2 colonnes dès 560px, 4 dès 920px */
@media (min-width:560px){
  footer.site .foot-top{grid-template-columns:1fr 1fr}
}
@media (min-width:920px){
  footer.site .foot-top{grid-template-columns:1.6fr 1fr 1fr 1fr}
}

/* nav : mobile < 920px */
@media (max-width:919.98px){
  .nav .nav-links{display:none}
  .nav .nav-links.open{display:flex;position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;gap:0;background:var(--ivoire);border-bottom:1px solid var(--pierre);padding:8px var(--mx) 16px}
  .nav .nav-links.open li{border-top:1px solid var(--pierre)}
  .nav .nav-links.open a{display:block;padding:14px 0}
  .nav .burger{display:flex}
  .nav .nav-cta{display:none}
}

/* nav : desktop >= 920px */
@media (min-width:920px){
  :root{--nav-h:76px}
  .nav .nav-links{display:flex}
  .nav .nav-links.open{position:static;flex-direction:row;background:none;border:0;padding:0}
  .nav .nav-links.open li{border-top:0}
  .nav .nav-links.open a{display:inline;padding:6px 0}
  .nav .burger{display:none}
  .nav .nav-cta .cta-full{display:inline}
  .nav .nav-cta .cta-min{display:none}
  header.site .nav{gap:20px}
  .nav .nav-right{gap:14px}
}

@media (pointer:coarse){
  .nav .nav-links a{padding:12px 0}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  #dom-preloader .pl-ring{animation:none}
  .reveal{opacity:1;transform:none;transition:none}
}

/* petits ecrans : force 1 colonne aussi pour les pages ecrites desktop-first */
@media (max-width:559.98px){
  footer.site .foot-top{grid-template-columns:1fr}
}

/* en-têtes des pages dossier : eyebrow persona (continuité avec la carte cliquée) */
.bien-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--laiton-soft);display:flex;align-items:center;gap:12px;margin-bottom:14px}
.bien-eyebrow::before{content:"+";color:var(--laiton-soft);font-weight:500}
