/* ============================================================
   estimer.eu — "Mecanisme expose" (direction Cowork, integree sur le vrai moteur).
   L'honnetete EST le luxe : calcul in-browser expose, sources visibles.
   Palette : Encre / Bone / Signal-clay (anti navy+or).
   Polices AUTO-HEBERGEES (woff2) : Instrument Serif (display) + IBM Plex Mono (data/corps).
   Motion : transform/opacity uniquement. Coupe si prefers-reduced-motion.
   ============================================================ */

@font-face{font-family:"Instrument Serif";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/instrument-serif-400.woff2") format("woff2")}
@font-face{font-family:"Instrument Serif";font-style:italic;font-weight:400;font-display:swap;src:url("fonts/instrument-serif-400-italic.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:400;font-display:swap;src:url("fonts/ibm-plex-mono-400.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:500;font-display:swap;src:url("fonts/ibm-plex-mono-500.woff2") format("woff2")}
@font-face{font-family:"IBM Plex Mono";font-style:normal;font-weight:600;font-display:swap;src:url("fonts/ibm-plex-mono-600.woff2") format("woff2")}

:root{
  --display: clamp(2.7rem, 7vw, 5.6rem);
  --h2: clamp(1.5rem, 3.4vw, 2.3rem);
  --h3: 1.1rem;
  --body: 0.95rem;
  --small: 0.8rem;
  --micro: 0.7rem;
  --s1:8px; --s2:16px; --s3:24px; --s4:40px; --s5:64px; --s6:96px; --s7:128px;
  --r1:3px; --r2:6px; --r3:10px;
  --maxw: 1180px;
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- NUIT (defaut) ---------- */
html[data-theme="nuit"]{
  /* contraste relevé (founder 2026-06-30 "trop sombre, aucun contraste") : surfaces+bordures+texte
     secondaire plus clairs -> les cartes ressortent, la structure se voit. Identité encre gardée. */
  --bg:#121210; --bg2:#1A1914; --surface:#221F18; --surface2:#2B2920;
  --ink:#F2EFE5; --ink-soft:#D8D5C9; --muted:#ABA796;
  --line:rgba(236,233,222,.20); --line-strong:rgba(236,233,222,.40);
  --accent:#E2683C;        /* signal clay (surfaces/CTA) */
  --accent-text:#EF7E54;   /* clay TEXTE éclairci -> lisible sur fond sombre (AA) */
  --accent-ink:#16140F; --good:#9DBE7B; --grain:.05;
}
/* ---------- JOUR ---------- */
html[data-theme="jour"]{
  --bg:#F3EFE4; --bg2:#EDE8DA; --surface:#FBF9F2; --surface2:#FFFFFF;
  --ink:#16150E; --ink-soft:#3A382E; --muted:#6E6A5C;
  --line:rgba(20,19,12,.13); --line-strong:rgba(20,19,12,.24);
  --accent:#C24A28;        /* clay clair : surfaces/CTA/gros texte (>=3:1) */
  --accent-text:#B5421F;   /* clay FONCE : petit texte accentue sur papier -> AA 4.5:1 (must-verify #1) */
  --accent-ink:#FBF9F2; --good:#5E7A3C; --grain:.035;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:"IBM Plex Mono",ui-monospace,Menlo,Consolas,monospace;
  font-size:var(--body);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  position:relative;overflow-x:hidden;
}
/* (grain feTurbulence retiré : rendait un aplat bleu géant sur iOS Safari — bug de rendu SVG
   en background fixed. La profondeur vient des ombres/filets, pas d'un calque plein écran.) */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--s3);position:relative;z-index:1}

.serif{font-family:"Instrument Serif",Georgia,serif;font-weight:400}
h1,h2{font-family:"Instrument Serif",Georgia,serif;font-weight:400;line-height:1.02;letter-spacing:-.01em}
h1{font-size:var(--display)}
h2{font-size:var(--h2)}
.eyebrow{font-size:var(--micro);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--accent);display:inline-block}
.mono-num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
a{color:inherit}

/* nav opaque (PAS de backdrop-filter : iOS Safari le mal-rend en aplat diagonal dans les captures full-page) */
nav{position:sticky;top:0;z-index:30;background:var(--bg);border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{display:flex;align-items:baseline;gap:.5ch;font-weight:600;letter-spacing:-.02em}
.brand b{font-weight:600}
.brand .dot{color:var(--accent-text)}
.brand small{font-size:var(--micro);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-weight:400}
.nav-right{display:flex;align-items:center;gap:var(--s2)}
.nav-link{font-size:var(--small);color:var(--muted);text-decoration:none}
.nav-link:hover{color:var(--ink)}
.toggle{border:1px solid var(--line-strong);background:transparent;color:var(--ink);font:inherit;font-size:var(--micro);letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:999px;cursor:pointer;display:flex;align-items:center;gap:.5em;transition:border-color .2s var(--ease),color .2s var(--ease)}
.toggle:hover{border-color:var(--accent);color:var(--accent-text)}
.toggle:focus-visible,a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r1)}

.hero{padding:var(--s6) 0 var(--s5)}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:var(--s5);align-items:start}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:var(--s4)}}
.hero h1 .accent{color:var(--accent);font-style:italic}
.hero .lede{margin-top:var(--s3);max-width:46ch;color:var(--ink-soft);font-size:1rem}
.honest-line{margin-top:var(--s3);display:flex;flex-wrap:wrap;gap:.5ch var(--s2);font-size:var(--small);color:var(--muted)}
.honest-line span{display:inline-flex;align-items:center;gap:.55ch}
.honest-line span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.8}

.instrument{background:linear-gradient(180deg,var(--surface),var(--bg2));border:1px solid var(--line-strong);border-radius:var(--r3);padding:var(--s3);position:relative;box-shadow:0 1px 0 rgba(255,255,255,.03) inset, 0 30px 60px -40px rgba(0,0,0,.6)}
.instrument::before,.instrument::after{content:"";position:absolute;width:12px;height:12px;border:1px solid var(--accent);opacity:.5}
.instrument::before{top:10px;left:10px;border-right:none;border-bottom:none}
.instrument::after{bottom:10px;right:10px;border-left:none;border-top:none}
.inst-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s2);padding-bottom:var(--s2);border-bottom:1px solid var(--line)}
.inst-title{font-size:var(--micro);letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.live{display:inline-flex;align-items:center;gap:.5ch;font-size:var(--micro);letter-spacing:.12em;text-transform:uppercase;color:var(--good)}
.live .pulse{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 0 var(--good);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:1}70%{transform:scale(2.4);opacity:0}100%{opacity:0}}

.steps{display:grid;gap:var(--s2)}
.step{display:grid;gap:6px}
.step-label{display:flex;align-items:center;gap:.6ch;font-size:var(--micro);letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.step-num{display:inline-grid;place-items:center;width:18px;height:18px;border:1px solid var(--line-strong);border-radius:50%;font-size:10px;color:var(--accent-text)}
select,input[type=number],input[type=text]{width:100%;font:inherit;color:var(--ink);background:var(--surface2);border:1px solid var(--line-strong);border-radius:var(--r2);padding:12px 14px;appearance:none;transition:border-color .2s var(--ease)}
select:hover,input:hover{border-color:var(--accent)}
.field-select{position:relative}
.field-select::after{content:"\25BE";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.seg{display:flex;border:1px solid var(--line-strong);border-radius:var(--r2);overflow:hidden}
.seg button{flex:1;font:inherit;font-size:var(--small);background:transparent;color:var(--muted);border:none;padding:11px 8px;cursor:pointer;transition:color .2s,background .2s}
.seg button[aria-pressed=true]{background:var(--accent);color:var(--accent-ink);font-weight:500}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s2)}
input[type=range]{width:100%;accent-color:var(--accent);background:transparent}
.unit{position:relative}
.unit input{padding-right:42px}
.unit .u{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:var(--small)}
.hint{font-size:var(--micro);color:var(--muted);margin-top:2px;line-height:1.5}

.result{margin-top:var(--s3);padding-top:var(--s3);border-top:1px dashed var(--line-strong)}
.result-top{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s2);flex-wrap:wrap}
.big{font-family:"Instrument Serif",Georgia,serif;font-size:clamp(2.2rem,5vw,3.4rem);line-height:1;letter-spacing:-.01em}
.big .cur{font-size:.5em;color:var(--muted);margin-left:.15em}
.permsq{text-align:right;color:var(--muted);font-size:var(--small)}
.permsq b{color:var(--ink);font-weight:500}

.range{margin-top:var(--s3)}
.range-track{position:relative;height:8px;border-radius:999px;background:var(--surface2);border:1px solid var(--line);overflow:hidden}
.range-fill{position:absolute;top:0;bottom:0;left:0;width:100%;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.55;transform-origin:left;transform:scaleX(1);transition:transform .5s var(--ease)}
.range-mid{position:absolute;top:-3px;width:2px;height:14px;background:var(--accent);left:50%;transition:left .5s var(--ease)}
.range-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:var(--small);color:var(--muted)}
.range-labels b{color:var(--ink);font-weight:500}

.src{margin-top:6px;font-size:var(--micro);color:var(--muted);display:flex;align-items:flex-start;gap:.6ch;line-height:1.5}
.src::before{content:"\2514";color:var(--accent-text);opacity:.8}
.src b{color:var(--ink-soft);font-weight:500}
.src em{font-style:normal;color:var(--accent-text)}
.src.missing{color:#ff6b6b}
.src.missing::before{content:"\26A0"}
.insufficient{margin-top:var(--s2);font-size:var(--small);color:var(--ink-soft);border:1px dashed var(--line-strong);border-radius:var(--r2);padding:12px 14px}

.chips{display:flex;flex-wrap:wrap;gap:.5ch var(--s1);margin-top:var(--s3)}
.chip{font-size:var(--micro);letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:5px 10px;background:var(--surface2)}
.chip b{color:var(--ink-soft);font-weight:500}
.demo-flag{position:absolute;top:-1px;right:-1px;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent);padding:4px 9px;border-radius:0 var(--r3) 0 var(--r2);font-weight:600}

.deepen{margin-top:var(--s3);text-align:center}
.btn-ghost{font:inherit;font-size:var(--small);background:transparent;color:var(--ink);border:1px solid var(--line-strong);border-radius:999px;padding:10px 18px;cursor:pointer;display:inline-flex;align-items:center;gap:.6ch;transition:border-color .2s,color .2s}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-text)}
.deep{display:none;margin-top:var(--s3);padding-top:var(--s3);border-top:1px solid var(--line)}
.deep.open{display:block;animation:reveal .45s var(--ease)}
@keyframes reveal{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.deep h3{font-size:var(--micro);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--s2)}
.cascade{display:grid;gap:8px}
.casc-row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--s2);padding-bottom:8px;border-bottom:1px solid var(--line)}
.casc-row .lab{color:var(--ink-soft);font-size:var(--small)}
.casc-row .lab small{display:block;color:var(--muted);font-size:var(--micro)}
.casc-row .val{font-variant-numeric:tabular-nums;white-space:nowrap}
.casc-row.minus .val{color:var(--muted)}
.casc-row.total{border-bottom:none;border-top:1px solid var(--line-strong);padding-top:10px;margin-top:2px}
.casc-row.total .val{font-family:"Instrument Serif",serif;font-size:1.5rem}
.field-inline{display:flex;align-items:center;gap:var(--s1);margin-bottom:var(--s2);font-size:var(--small);color:var(--muted)}
.field-inline input{width:150px;padding:8px 10px}

section{padding:var(--s6) 0;position:relative;z-index:1}
.section-head{max-width:60ch;margin-bottom:var(--s4)}
.section-head .eyebrow{margin-bottom:var(--s2)}
.lead-p{font-size:1.05rem;color:var(--ink-soft);max-width:54ch}
.mech{border-top:1px solid var(--line)}
.mech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3)}
@media(max-width:820px){.mech-grid{grid-template-columns:1fr}}
.mech-card{border:1px solid var(--line);border-radius:var(--r2);padding:var(--s3);background:var(--surface)}
.mech-card .k{font-size:var(--micro);letter-spacing:.16em;text-transform:uppercase;color:var(--accent-text);margin-bottom:var(--s2)}
.mech-card h3{font-family:"Instrument Serif",serif;font-size:1.5rem;margin-bottom:8px;font-weight:400}
.mech-card p{font-size:var(--small);color:var(--muted)}
.sources{border-top:1px solid var(--line);background:var(--bg2)}
.src-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:var(--s4)}
@media(max-width:820px){.src-grid{grid-template-columns:1fr;gap:var(--s3)}}
.src-grid h3{font-size:var(--micro);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--s2)}
.src-grid p{font-size:var(--small);color:var(--ink-soft)}
.src-grid a{color:var(--accent-text);text-decoration:none;border-bottom:1px solid var(--line-strong)}
footer{border-top:1px solid var(--line);padding:var(--s4) 0}
footer .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s2);align-items:center;color:var(--muted);font-size:var(--small)}

.reveal{opacity:0;transform:translateY(16px)}
.reveal.in{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}

/* ============ HERO BARRE UNIQUE (le smart bot = l'entree) ============ */
.hero-center{max-width:720px;margin:0 auto;text-align:center}
.hero-center .eyebrow{justify-content:center}
.hero-center h1{margin-top:var(--s3)}
.hero-center .lede{margin:var(--s3) auto 0;max-width:52ch;color:var(--ink-soft);font-size:1rem}
.askbar{display:flex;align-items:center;gap:8px;margin:var(--s4) auto 0;max-width:600px;background:var(--surface);border:1px solid var(--line-strong);border-radius:16px;padding:7px 7px 7px 16px;box-shadow:0 30px 60px -38px rgba(0,0,0,.7);transition:border-color .2s var(--ease)}
.askbar:focus-within{border-color:var(--accent)}
.askbar-ic{color:var(--accent);font-size:1.15rem;line-height:1;flex:none}
.askbar input{flex:1;min-width:0;border:0;background:transparent;color:var(--ink);font-family:inherit;font-size:16px;padding:11px 2px;outline:none}
.askbar input::placeholder{color:var(--muted)}
.askbar-go{flex:none;border:0;background:var(--accent);color:var(--accent-ink);font-family:inherit;font-weight:600;font-size:.95rem;border-radius:11px;padding:12px 22px;cursor:pointer;transition:transform .15s var(--ease)}
.askbar-go:hover{transform:translateY(-1px)}
.askbar-hint{margin-top:12px;color:var(--muted);font-size:var(--small)}
.askbar-msg{max-width:560px;margin:16px auto 0;text-align:left;color:var(--ink);background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent) 38%,transparent);border-radius:var(--r3);padding:12px 15px;font-size:.9rem;line-height:1.5}
.result-card{max-width:600px;margin:var(--s4) auto 0;text-align:left;background:linear-gradient(180deg,var(--surface),var(--bg2));border:1px solid var(--line-strong);border-radius:var(--r3);padding:var(--s3);box-shadow:0 30px 60px -40px rgba(0,0,0,.6)}
.refine{margin-top:var(--s3);border-top:1px dashed var(--line-strong);padding-top:var(--s2)}
.refine>summary{cursor:pointer;color:var(--muted);font-size:var(--small);list-style:none;user-select:none}
.refine>summary:hover{color:var(--ink)}
.refine>summary::-webkit-details-marker{display:none}
.refine>summary::before{content:"+ ";color:var(--accent)}
.refine[open]>summary::before{content:"\2212 "}
.refine-body{margin-top:var(--s2);display:flex;flex-direction:column;gap:12px}
.proof{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg2)}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3);padding:var(--s4) 0;text-align:center}
.proof-grid b{display:block;font-family:"Instrument Serif",Georgia,serif;font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1;color:var(--ink)}
.proof-grid span{display:block;margin-top:8px;color:var(--muted);font-size:var(--micro);letter-spacing:.04em}
@media(max-width:600px){.proof-grid{grid-template-columns:repeat(2,1fr);gap:var(--s3) var(--s2)}.askbar{flex-wrap:wrap}.askbar input{width:100%;order:1}.askbar-go{width:100%;order:2}.askbar-ic{display:none}}
/* Mobile : moins d'air vertical (96px en haut = trop sur petit écran) */
@media(max-width:600px){
  .hero{padding:var(--s4) 0 var(--s3)}
  section{padding:var(--s4) 0}
  .wrap{padding:0 var(--s2)}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .live .pulse{box-shadow:none}
}

/* ---------- ENVIRONNEMENT (contexte gratuit de commune ; jamais un prix) ---------- */
.env-band{margin-top:var(--s3);padding-top:var(--s3);border-top:1px solid var(--line)}
.env-head{font-size:var(--small);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--s2)}
.env-head small{text-transform:none;letter-spacing:0;color:var(--muted);font-size:var(--micro)}
.env-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s2)}
@media (max-width:560px){.env-grid{grid-template-columns:repeat(2,1fr)}}
.env-cell{background:var(--surface2);border:1px solid var(--line);border-radius:var(--r2);padding:var(--s2);text-align:center}
.env-cell b{display:block;font-size:1.05rem;color:var(--ink);line-height:1.2}
.env-cell span{font-size:var(--micro);color:var(--muted)}
.env-src{margin-top:var(--s2)}
