/* ============================================================
   PATRIMO — REFONTE « BRAISE »
   Noir charbon · braise incandescente · serif éditorial · grain
   ============================================================ */
:root{
  /* fonds — DA bleu & blanc : surfaces claires bleutées */
  --noir:#F6F8FC;
  --noir-2:#EEF2F9;
  --noir-3:#E4EAF5;
  --papier:#FFFFFF;
  --papier-2:#F2F5FA;

  /* encres — marine sur fond clair */
  --blanc:#101C3D;
  --blanc-doux:#3D4A6B;
  --muet:#6F7A99;
  --encre:#101C3D;
  --encre-douce:#46506E;

  /* bleu Klein (accent, piloté par les Tweaks) */
  --acc-h:224; --acc-s:80%; --acc-l:56%;
  --acc:hsl(var(--acc-h) var(--acc-s) var(--acc-l));
  --acc-vive:hsl(var(--acc-h) 92% 66%);
  --acc-pale:hsl(var(--acc-h) 85% 80%);
  --acc-sombre:hsl(var(--acc-h) 72% 26%);
  --acc-braise:hsl(var(--acc-h) 65% 14%);

  --ligne:rgba(16,28,61,.10);
  --ligne-forte:rgba(16,28,61,.2);
  --ligne-encre:rgba(16,28,61,.12);

  /* grain (intensité pilotée par les Tweaks) */
  --grain:1;

  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;
  --s7:32px;--s8:40px;--s9:48px;--s10:64px;--s11:80px;--s12:96px;--s13:128px;

  --r-l:28px;--r-m:14px;--r-pill:999px;

  --serif:-apple-system,BlinkMacSystemFont,'SF Pro Display','Segoe UI',Roboto,'Helvetica Neue',sans-serif;
  --serif-produit:'Instrument Serif',Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,'SF Pro Text','Segoe UI',Roboto,'Helvetica Neue',sans-serif;
  --mono:'IBM Plex Mono',monospace;

  --t-display:clamp(2.75rem, 1.2rem + 6.4vw, 6rem);
  --t-headline:clamp(2rem, 1.4rem + 2.4vw, 3.25rem);
  --t-title:clamp(1.125rem, 1.05rem + .3vw, 1.3125rem);
  --t-body:0.9375rem;
  --t-body-lg:1.0625rem;
  --t-label:0.6875rem;

  --ease:cubic-bezier(.2,.8,.2,1);
  --max:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--noir);color:var(--blanc);
  font-family:var(--sans);font-size:var(--t-body-lg);line-height:26px;
  font-weight:300;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:var(--acc);color:#fff}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--acc-vive);outline-offset:3px;border-radius:4px}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--s6)}
@media(min-width:768px){.wrap{padding:0 var(--s9)}}
@media(min-width:1024px){.wrap{padding:0 var(--s10)}}

/* ---------- GRAIN GLOBAL (feTurbulence en data-URI) ---------- */
.grain-veil{
  position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:2000;
  opacity:calc(var(--grain) * .12);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain-shift 1.1s steps(3) infinite;
}
@keyframes grain-shift{
  0%{transform:translate(0,0)}33%{transform:translate(-2.5%,1.5%)}66%{transform:translate(1.5%,-2%)}100%{transform:translate(0,0)}
}

/* typographies utilitaires */
.kicker{font-family:var(--mono);font-size:var(--t-label);letter-spacing:.22em;text-transform:uppercase;color:var(--muet)}
.kicker .pt{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--acc);margin-right:10px;vertical-align:1px;box-shadow:0 0 12px var(--acc)}
h1,h2,.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.025em}
h2{font-size:var(--t-headline);line-height:1.02;text-wrap:balance}
h2 em{font-style:normal;color:hsl(var(--acc-h) 72% 46%)}
h1 em{font-style:normal;color:inherit}
.sur-papier h2 em{color:hsl(var(--acc-h) 70% 42%)}

/* ---------- NAV (centrée, transparente — sur le hero uniquement) ---------- */
.navbar{
  position:absolute;top:var(--s6);left:50%;transform:translateX(-50%);z-index:100;
  display:flex;align-items:center;gap:var(--s7);
  padding:var(--s2) var(--s2) var(--s2) var(--s5);
  border-radius:var(--r-pill);
  background:transparent;border:none;box-shadow:none;
}
.logo{font-family:var(--sans);font-weight:500;font-size:18px;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:10px;white-space:nowrap;flex:none}
.logo .braise-pt{width:13px;height:13px;border-radius:50%;flex:none;
  background:radial-gradient(circle at 35% 30%, var(--acc-pale), var(--acc) 55%, var(--acc-sombre));
  box-shadow:0 0 14px var(--acc), 0 0 34px hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .45);}
.nav-links{display:none;gap:var(--s5);font-family:var(--sans);font-size:14px;letter-spacing:.01em;white-space:nowrap}
@media(min-width:1080px){.nav-links{gap:var(--s6)}}
@media(min-width:900px){.nav-links{display:flex}}
.nav-links a{color:rgba(242,237,230,.72);transition:color .2s}
.nav-links a:hover{color:var(--blanc)}
.btn-nav{
  font-family:var(--sans);font-size:13.5px;font-weight:400;letter-spacing:.01em;white-space:nowrap;
  background:rgba(242,237,230,.12);color:var(--blanc);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(242,237,230,.08);
  padding:9px var(--s5);border-radius:var(--r-pill);
  transition:transform .2s var(--ease), background .2s;
}
.btn-nav:hover{background:rgba(242,237,230,.22);transform:translateY(-1px)}

/* ---------- HERO : L'ÉCLIPSE ---------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
  padding:calc(var(--s10) + var(--s8)) var(--s5) var(--s9);
}
.hero .fond-hero{position:absolute;inset:0;width:100%;height:100%;z-index:0;object-fit:cover;object-position:50% 30%}
.hero-voile{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:var(--voile-hero,.4);
  background:
    linear-gradient(rgba(11,10,9,.22), rgba(11,10,9,.22)),
    radial-gradient(120% 90% at 50% 42%, transparent 30%, rgba(11,10,9,.72) 100%),
    linear-gradient(180deg, rgba(11,10,9,.42), rgba(11,10,9,.08) 26%, rgba(11,10,9,.38) 55%, rgba(11,10,9,.9) 85%, rgba(11,10,9,1))}
.orbe-scene{position:relative;z-index:2;width:min(48vw,42svh,360px);aspect-ratio:1;margin-bottom:calc(-1 * min(14vw,110px))}
.orbe-halo-fond{
  position:absolute;inset:-46%;border-radius:50%;
  background:radial-gradient(closest-side circle, hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .22) 0%, hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .07) 55%, transparent 96%);
  animation:respire 7s ease-in-out infinite;
}
.orbe-eclipse{
  position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(circle at 50% 30%, hsl(var(--acc-h) 70% 24%) 0%, hsl(var(--acc-h) 60% 11%) 46%, #0D0C0A 72%);
  box-shadow:
    inset 0 22px 36px -10px hsl(var(--acc-h) 90% 62% / .85),
    inset 0 60px 80px -30px hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .5),
    inset 0 -60px 90px rgba(0,0,0,.85),
    0 -10px 60px -8px hsl(var(--acc-h) 88% 58% / .5),
    0 0 140px 6px hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .28);
  animation:respire-ombre 7s ease-in-out infinite;
}
.orbe-eclipse::before{ /* liseré incandescent supérieur */
  content:'';position:absolute;inset:-1.5px;border-radius:50%;
  background:radial-gradient(circle at 50% -30%, hsl(var(--acc-h) 100% 88%) 30%, hsl(var(--acc-h) 96% 66% / .9) 48%, transparent 72%);
  -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 4px), #000 calc(100% - 2.2px));
  mask:radial-gradient(farthest-side, transparent calc(100% - 4px), #000 calc(100% - 2.2px));
}
.orbe-eclipse::after{ /* reflet bas discret */
  content:'';position:absolute;left:18%;right:18%;bottom:6%;height:22%;border-radius:50%;
  background:radial-gradient(ellipse at 50% 100%, hsl(var(--acc-h) 80% 45% / .25), transparent 70%);
  filter:blur(8px);
}
@keyframes respire{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.85}}
@keyframes respire-ombre{0%,100%{filter:brightness(1)}50%{filter:brightness(1.12)}}

.hero-texte{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center}
.hero-texte::before{ /* écran sombre qui suit le bloc de texte, quel que soit l'écran */
  content:'';position:absolute;inset:-22% -26%;z-index:-1;pointer-events:none;
  opacity:calc(.42 + var(--voile-hero,.4) * .55); /* plancher de lisibilité du texte */
  background:radial-gradient(ellipse 62% 58% at 50% 46%, rgba(11,10,9,.72) 0%, rgba(11,10,9,.42) 52%, transparent 76%);
}
.hero-eyebrow{position:relative;z-index:3;margin-bottom:var(--s5)}
.hero h1{
  position:relative;z-index:3;
  font-weight:400;color:#EDEAE6;
  font-size:min(var(--t-display), 7.4svh);line-height:.99;letter-spacing:-.022em;
  max-width:16ch;text-wrap:balance;
  text-shadow:0 2px 18px rgba(11,10,9,.85), 0 8px 60px rgba(11,10,9,.95);
}
.hero h1 .mot{display:inline-block;opacity:0;transform:translateY(26px);filter:blur(6px);
  transition:opacity .9s var(--ease),transform .9s var(--ease),filter .9s var(--ease)}
.hero h1 .mot.on{opacity:1;transform:none;filter:blur(0)}
.hero .sous{
  position:relative;z-index:3;color:var(--blanc-doux);max-width:640px;
  font-size:var(--t-body-lg);line-height:25px;margin-top:var(--s5);
  text-shadow:0 1px 12px rgba(11,10,9,.9);text-wrap:balance;
}
.hero-btns{position:relative;z-index:3;display:flex;flex-wrap:wrap;gap:var(--s4);justify-content:center;margin-top:var(--s6)}
.btn{display:inline-flex;align-items:center;gap:12px;padding:var(--s3) var(--s7);border-radius:var(--r-pill);
  font-size:15.5px;font-weight:400;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s}
.btn:active{transform:scale(.97)}
.btn.plein{background:var(--blanc);color:var(--noir)}
.btn.plein:hover{background:#fff;transform:translateY(-2px)}
.btn.plein .fl{width:24px;height:24px;border-radius:50%;background:var(--acc);display:inline-flex;align-items:center;justify-content:center;flex:none}
.btn.plein .fl svg{width:11px;height:11px;stroke:#fff;stroke-width:2.2;fill:none}
.btn.blanc-simple{background:var(--blanc);color:var(--noir);gap:10px}
.btn.blanc-simple:hover{background:#fff;transform:translateY(-2px)}
.btn.blanc-simple svg{width:13px;height:13px;stroke:var(--noir);stroke-width:2;fill:none}
.btn.fantome{border:1px solid var(--ligne-forte);color:var(--blanc);
  background:rgba(242,237,230,.03);backdrop-filter:blur(6px)}
.btn.fantome:hover{background:var(--blanc);color:var(--noir);border-color:var(--blanc)}
.hero-pied{
  position:absolute;bottom:var(--s6);left:0;right:0;z-index:3;
  display:flex;justify-content:center;gap:var(--s7);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muet);
}
.hero-pied span b{color:var(--blanc-doux);font-weight:500}
@media(max-height:620px){.hero-pied{display:none}}
.fondu{opacity:0;transition:opacity 1.2s ease}
.fondu.on{opacity:1}

/* ---------- TICKER ---------- */
.ticker{
  border-top:1px solid var(--ligne);border-bottom:1px solid var(--ligne);
  background:var(--noir-2);
  overflow:hidden;white-space:nowrap;padding:var(--s4) 0;position:relative;
}
.ticker::before,.ticker::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:1;pointer-events:none;
}
.ticker::before{left:0;background:linear-gradient(90deg,var(--noir-2),transparent)}
.ticker::after{right:0;background:linear-gradient(-90deg,var(--noir-2),transparent)}
.ticker-piste{display:inline-block;animation:defile 44s linear infinite}
.ticker:hover .ticker-piste{animation-play-state:paused}
.ticker span.q{font-family:var(--serif-produit);font-style:italic;font-size:21px;color:var(--blanc-doux);margin-right:var(--s6)}
.ticker .sep{color:var(--acc);font-family:var(--mono);font-size:12px;margin-right:var(--s6);vertical-align:3px}
@keyframes defile{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- SECTIONS ---------- */
section{padding:var(--s13) 0;position:relative}
.sec-tete{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--s6);margin-bottom:var(--s9);flex-wrap:wrap}
.sec-tete .sous{color:var(--muet);font-size:var(--t-body);line-height:24px;margin-top:var(--s4);max-width:480px}
.lien-mono{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blanc-doux);white-space:nowrap;border-bottom:1px solid var(--ligne-forte);padding-bottom:4px;
  transition:color .2s,border-color .2s}
.lien-mono:hover{color:var(--acc);border-color:var(--acc)}

/* ---------- RÉPLIQUE PRODUIT ---------- */
.scene-produit{position:relative}
.scene-produit::before{ /* nappe de braise sous la fenêtre */
  content:'';position:absolute;left:50%;bottom:-8%;transform:translateX(-50%);
  width:80%;height:50%;border-radius:50%;pointer-events:none;
  background:radial-gradient(ellipse, hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .2), transparent 70%);
  filter:blur(30px);
}
.fenetre{
  position:relative;border-radius:var(--r-l);overflow:hidden;
  background:#FFFFFF;color:var(--encre);
  border:1px solid rgba(16,28,61,.08);
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 60px 120px -40px rgba(16,28,61,.28), 0 30px 60px -30px hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .2);
}
.nav-fenetre{display:none}
.produit{padding:var(--s11) var(--s7) var(--s10);display:flex;flex-direction:column;align-items:center}
@media(max-width:600px){.produit{padding:var(--s9) var(--s5) var(--s8)}}

/* ---------- DÉMO CONVERSATIONNELLE — minimale ---------- */
.chat{width:100%;max-width:560px;display:flex;flex-direction:column;gap:0;
  margin:var(--s7) 0 var(--s6);max-height:460px;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:rgba(15,27,60,.18) transparent}
.msg{display:flex;flex-direction:column;max-width:100%}
.msg.patrimo{align-items:flex-start;text-align:left}
.msg.user{align-items:center;text-align:center;margin:var(--s7) 0 var(--s5);padding-top:var(--s7);
  border-top:1px solid rgba(15,27,60,.1);width:100%}
.msg .bulle{font-size:14.5px;line-height:24px;text-align:left}
.msg.patrimo .bulle{background:none;border:none;border-radius:0;padding:0;box-shadow:none;color:var(--encre-douce)}
.msg.patrimo .bulle strong{color:var(--encre);font-weight:600}
.msg.patrimo .bulle em{font-style:italic}
.msg.user .bulle{background:none;color:var(--encre);border-radius:0;padding:0;
  font-family:var(--serif-produit);font-style:italic;font-size:clamp(1.25rem,1.05rem+.8vw,1.625rem);line-height:1.3;text-align:center;text-wrap:balance}
.bulle-suite{margin-top:var(--s3);color:#8B93AE}
.msg-meta{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:#A9B1C7;margin-top:var(--s3);white-space:nowrap}
.msg-sources{display:flex;flex-wrap:wrap;column-gap:var(--s4);row-gap:var(--s1);margin-top:var(--s3)}
.source-chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;
  color:#8B93AE;background:none;border:none;border-radius:0;padding:0}
.source-chip svg{width:11px;height:11px;stroke:hsl(var(--acc-h) 60% 45%);fill:none;stroke-width:1.5;flex:none}
.msg.pense .bulle{color:#8B93AE;display:flex;align-items:center;gap:10px}
.pense-pts{display:inline-flex;gap:4px}
.pense-pts i{width:5px;height:5px;border-radius:50%;background:hsl(var(--acc-h) 70% 55%);animation:pense 1.1s ease-in-out infinite}
.pense-pts i:nth-child(2){animation-delay:.18s}
.pense-pts i:nth-child(3){animation-delay:.36s}
@keyframes pense{0%,100%{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}
.lien-braise{font:inherit;background:none;border:none;cursor:pointer;padding:0 0 1px}
.lien-braise:hover{color:hsl(var(--acc-h) 80% 30%)}
.pilules{display:flex;flex-wrap:wrap;column-gap:var(--s6);row-gap:var(--s2);justify-content:center;margin-bottom:var(--s7);max-width:640px}
.pilule{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:#8B93AE;
  background:none;border:none;border-radius:0;padding:0 0 3px;white-space:nowrap;cursor:pointer;
  border-bottom:1px solid rgba(15,27,60,.16);transition:color .2s,border-color .2s}
.pilule:hover{color:var(--encre);border-color:var(--encre);transform:none}
.champ-input{width:100%;border:none;background:transparent;font:inherit;font-size:15px;line-height:26px;
  color:var(--encre);padding:var(--s3) 0 var(--s2);outline:none;text-align:left}
.champ-input::placeholder{color:#A9B1C7}
.saisie .barre{display:flex;justify-content:space-between;align-items:center;padding:var(--s2) 0 0}
.saisie .micro{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:7px;color:#8B93AE;
  background:none;border:none;padding:0;cursor:pointer;transition:color .2s}
.saisie .micro svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2}
.saisie .micro:hover{color:var(--encre)}
.saisie .micro.ecoute-active{color:hsl(var(--acc-h) 70% 40%)}
.saisie .envoi{width:30px;height:30px;border-radius:50%;border:1px solid rgba(15,27,60,.2);background:none;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .25s,border-color .25s}
.saisie .envoi svg{width:13px;height:13px;stroke:var(--encre);stroke-width:2;fill:none;transition:stroke .25s}
.saisie .envoi.actif{background:var(--encre);border-color:var(--encre)}
.saisie .envoi.actif svg{stroke:#FFFFFF}
#demo-orbe.actif{animation:respire 1.2s ease-in-out infinite}
/* widgets de réponse — minimaux */
.widget-barres{display:flex;flex-direction:column;gap:var(--s3);margin-top:var(--s4)}
.barre-ligne{display:grid;grid-template-columns:96px 1fr 64px;align-items:center;gap:var(--s4);font-size:12.5px}
.bl-nom{color:var(--encre);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}
.bl-piste{height:2px;border-radius:0;background:rgba(15,27,60,.1);overflow:hidden;display:block}
.bl-rempli{display:block;height:100%;border-radius:0;
  background:hsl(var(--acc-h) 75% 48%);
  transition:width 1s var(--ease)}
.bl-val{font-family:var(--mono);font-size:10.5px;color:var(--encre);text-align:right;white-space:nowrap}
.widget-dossiers{display:flex;flex-direction:column;margin-top:var(--s3)}
.wd-ligne{display:flex;align-items:center;justify-content:space-between;gap:var(--s4);
  background:none;border:none;border-radius:0;border-bottom:1px solid rgba(15,27,60,.1);padding:var(--s3) 0}
.wd-ligne:last-child{border-bottom:none}
.wd-nom{font-size:13.5px;color:var(--encre);line-height:20px}
.wd-det{font-size:11.5px;color:#8B93AE;line-height:17px}
.wd-pill{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;
  padding:0;border-radius:0;color:hsl(var(--acc-h) 70% 38%);background:none;border:none}
.wd-pill.ok{color:#7E879F;background:none;border:none}
.widget-coches{display:flex;flex-direction:column;gap:var(--s3);margin-top:var(--s4)}
.wc-ligne{display:flex;gap:var(--s3);align-items:flex-start;font-size:13px;line-height:20px;color:var(--encre-douce);text-align:left}
.wc-ligne svg{width:14px;height:14px;flex:none;margin-top:3px;stroke:hsl(var(--acc-h) 70% 45%);stroke-width:2;fill:none}
.produit .orbe-mini-halo{width:76px;height:76px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  background:radial-gradient(circle, hsl(var(--acc-h) 70% 55% / .14), transparent 70%)}
.produit .orbe-mini{width:46px;height:46px;border-radius:50%;
  background:radial-gradient(circle at 50% 40%, hsl(var(--acc-h) 60% 30%) 0%, hsl(var(--acc-h) 55% 14%) 52%, #060D1A 78%);
  box-shadow:
    inset 0 6px 9px -2px hsl(var(--acc-h) 100% 85% / 1),
    inset 0 14px 20px -6px hsl(var(--acc-h) 92% 60% / .75),
    inset 0 -10px 16px rgba(3,6,14,.9),
    0 0 0 1px hsl(var(--acc-h) 80% 55% / .25),
    0 0 22px hsl(var(--acc-h) 90% 60% / .55),
    0 14px 30px -10px hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .65);
  animation:respire 5s ease-in-out infinite;
}
.produit .ecoute{font-family:var(--serif-produit);font-style:italic;font-size:15px;color:#8B93AE;margin:var(--s3) 0 0}
.produit .salut{font-family:var(--serif-produit);font-size:clamp(1.875rem,1.5rem+1.3vw,2.375rem);line-height:1.12}
.produit .question{font-size:15px;color:var(--encre-douce);margin:var(--s1) 0 var(--s6)}
.brief{max-width:560px;background:#fff;border:1px solid rgba(15,27,60,.1);border-radius:var(--r-m);
  padding:var(--s4) var(--s5);font-size:13.5px;line-height:22px;color:var(--encre-douce);text-align:left;
  margin-bottom:var(--s5);box-shadow:0 10px 30px -18px rgba(15,27,60,.25)}
.brief strong{color:var(--encre);font-weight:600}
.lien-braise{color:hsl(var(--acc-h) 75% 36%);font-weight:500;
  border-bottom:1px solid hsl(var(--acc-h) 70% 45% / .4);padding-bottom:1px}
.saisie{width:100%;max-width:560px;background:none;border:none;border-radius:0;box-shadow:none;text-align:left;
  border-top:1px solid rgba(15,27,60,.22);transition:border-color .25s}
.saisie:focus-within{border-top-color:var(--encre)}
.curseur{display:inline-block;width:1.5px;height:1em;background:var(--encre);vertical-align:-2px;animation:clip 1s steps(1) infinite}
@keyframes clip{50%{opacity:0}}
.mini-stats{display:none}
.etage{opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease}
.on-scene .etage{opacity:1;transform:none}
.on-scene .e1{transition-delay:.1s}.on-scene .e2{transition-delay:.32s}
.on-scene .e3{transition-delay:.55s}.on-scene .e4{transition-delay:.8s}
.on-scene .e5{transition-delay:1s}.on-scene .e6{transition-delay:1.2s}

/* ---------- CAS D'USAGE : VERRE SUR PHOTO ---------- */
.verre-scene{
  position:relative;border-radius:32px;overflow:hidden;
  min-height:640px;display:flex;align-items:stretch;
  border:1px solid var(--ligne);
  background:
    radial-gradient(900px 600px at 70% 10%, hsl(var(--acc-h) 60% 30% / .55), transparent 60%),
    radial-gradient(700px 500px at 15% 90%, hsl(var(--acc-h) 70% 22% / .5), transparent 60%),
    linear-gradient(180deg,#191512,#0D0C0A);
}
.verre-scene image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.92}
.verre-voile{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, rgba(11,10,9,.25), rgba(11,10,9,.05) 40%, rgba(11,10,9,.45))}
.verre-grille{
  position:relative;z-index:2;width:100%;
  display:grid;gap:var(--s5);grid-template-columns:1fr;
  padding:var(--s7);align-content:end;
}
@media(min-width:980px){
  .verre-grille{grid-template-columns:repeat(3,1fr);padding:var(--s8)}
  .verre-carte.basse{grid-column:1/4}
}
.verre-carte{
  position:relative;border-radius:20px;padding:var(--s6);
  background:rgba(20,16,12,.32);
  backdrop-filter:blur(16px) saturate(1.15);-webkit-backdrop-filter:blur(16px) saturate(1.15);
  box-shadow:inset 0 1px 1px rgba(255,255,255,.12);
  display:flex;flex-direction:column;min-height:300px;
  transition:transform .4s var(--ease),background .4s;
}
.verre-carte:hover{transform:translateY(-5px);background:rgba(20,16,12,.45)}
.verre-carte::before{ /* liseré dégradé façon liquid glass */
  content:'';position:absolute;inset:0;border-radius:inherit;padding:1.2px;
  background:linear-gradient(180deg, rgba(255,255,255,.35) 0%, rgba(255,255,255,.08) 24%,
    rgba(255,255,255,0) 45%, rgba(255,255,255,0) 60%, rgba(255,255,255,.08) 82%, rgba(255,255,255,.3) 100%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.verre-carte .ki{font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--blanc-doux);margin-bottom:auto;display:flex;justify-content:space-between;gap:10px}
.verre-carte .ki .num{color:var(--muet)}
.verre-carte h3{font-family:var(--serif);font-weight:400;font-size:var(--t-title);font-size:clamp(1.25rem,1.1rem+.6vw,1.5rem);line-height:1.15;margin:var(--s6) 0 var(--s2);letter-spacing:-.01em}
.verre-carte p{color:var(--blanc-doux);font-size:14px;line-height:23px}
.verre-carte p .dim{color:var(--muet)}
.compteur{font-family:var(--serif);font-size:clamp(3.25rem,2.4rem+2.6vw,4.5rem);line-height:1;letter-spacing:-.02em;
  color:var(--blanc);font-variant-numeric:tabular-nums;white-space:nowrap;margin:var(--s5) 0 var(--s2)}
.compteur small{font-size:.38em;color:var(--blanc-doux);font-style:italic}
.compteur-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muet)}

.graphe{margin:var(--s5) 0 var(--s2)}
.graphe svg{width:100%;height:auto;display:block}
.legende{display:flex;gap:var(--s4);margin-top:var(--s3);font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muet)}
.legende .cle{display:flex;align-items:center;gap:7px}
.cle .trait{width:18px;height:0;border-top:2px solid var(--acc-vive)}
.cle .trait.pointille{border-top:2px dashed rgba(242,237,230,.35)}
.trace{stroke-dasharray:420;stroke-dashoffset:420;transition:stroke-dashoffset 1.8s ease .4s}
.on-scene .trace{stroke-dashoffset:0}

.lignes-scan{margin-top:var(--s5);display:flex;flex-direction:column;gap:var(--s2)}
.ligne-scan{display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:rgba(11,10,9,.4);border:1px solid rgba(242,237,230,.1);
  border-radius:12px;padding:10px var(--s4);font-size:13px;
  opacity:0;transform:translateY(8px);transition:opacity .5s ease,transform .5s ease}
.on-scene .ligne-scan{opacity:1;transform:none}
.on-scene .ligne-scan:nth-child(1){transition-delay:.3s}
.on-scene .ligne-scan:nth-child(2){transition-delay:.55s}
.on-scene .ligne-scan:nth-child(3){transition-delay:.8s}
.ligne-scan .dossier{font-weight:400;color:var(--blanc);line-height:20px}
.ligne-scan .detail{color:var(--muet);font-size:11.5px;line-height:16px}
.pill{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;padding:4px 11px;border-radius:var(--r-pill);white-space:nowrap}
.pill.alerte{color:var(--acc-pale);background:hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .14);border:1px solid hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .4)}
.pill.ok{color:var(--blanc-doux);background:rgba(242,237,230,.07);border:1px solid rgba(242,237,230,.25)}

.verre-carte.basse{flex-direction:row;align-items:center;gap:var(--s5);flex-wrap:wrap;min-height:0}
.faux-champ{flex:1;min-width:240px;display:flex;align-items:center;gap:var(--s3);
  background:rgba(11,10,9,.45);border:1px solid rgba(242,237,230,.14);border-radius:var(--r-pill);
  padding:var(--s3) var(--s5);font-size:14.5px;line-height:24px;color:var(--blanc)}
.faux-champ .loupe{width:15px;height:15px;flex:none;stroke:var(--muet);fill:none;stroke-width:2}
.resultat{display:flex;align-items:center;gap:var(--s4);
  border:1px solid hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .45);
  background:hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .1);
  border-radius:12px;padding:var(--s3) var(--s4);
  opacity:0;transform:translateX(12px);transition:opacity .6s ease .5s,transform .6s ease .5s}
.on-scene .resultat{opacity:1;transform:none}
.resultat .fichier{font-weight:400;font-size:13.5px;line-height:20px;color:var(--blanc)}
.resultat .fichier .plus{color:var(--muet)}
.resultat .chemin{font-family:var(--mono);font-size:10px;line-height:16px;color:var(--muet)}
.resultat .temps{font-family:var(--mono);font-size:10.5px;color:var(--acc-vive);white-space:nowrap}

/* ---------- POSITIONNEMENT : PAGE PAPIER ---------- */
.sur-papier{
  background:var(--papier);color:var(--encre);
  border-radius:0;position:relative;
}
body[data-claire="off"] .sur-papier{background:var(--noir-2);color:var(--blanc)}
.sur-papier .kicker{color:hsl(var(--acc-h) 50% 35%)}
body[data-claire="off"] .sur-papier .kicker{color:var(--muet)}
.sur-papier .filet{position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .6), transparent)}
.manif-grille{display:grid;gap:var(--s9);grid-template-columns:1fr}
@media(min-width:1024px){.manif-grille{grid-template-columns:1fr 1.1fr;gap:var(--s11)}.manif-colle{position:sticky;top:var(--s12);align-self:start}}
.sur-papier .manif-intro{color:var(--encre-douce);font-size:var(--t-body);line-height:25px;margin-top:var(--s5);max-width:440px}
body[data-claire="off"] .sur-papier .manif-intro{color:var(--blanc-doux)}
.anti{padding:var(--s6) 0;border-top:1px solid var(--ligne-encre);display:grid;grid-template-columns:64px 1fr;gap:var(--s2)}
.anti:last-child{border-bottom:1px solid var(--ligne-encre)}
body[data-claire="off"] .anti{border-color:var(--ligne)}
.anti .no{font-family:var(--mono);font-size:11px;color:hsl(var(--acc-h) 55% 38%);padding-top:6px}
body[data-claire="off"] .anti .no{color:var(--acc-vive)}
.anti h4{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,1.1rem+.5vw,1.4375rem);line-height:1.2;margin-bottom:var(--s2);letter-spacing:-.01em}
.anti p{color:var(--encre-douce);font-size:var(--t-body);line-height:24px}
body[data-claire="off"] .anti p{color:var(--blanc-doux)}

/* ---------- SÉCURITÉ : LA CHAMBRE FORTE (trame) ---------- */
.tramee{position:relative}
.trame-fond{ /* touche dither : trame de points fondue dans le noir */
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle, rgba(16,28,61,.3) 1px, transparent 1.4px);
  background-size:9px 9px;
  -webkit-mask-image:radial-gradient(640px 420px at 85% 0%, #000, transparent 75%);
  mask-image:radial-gradient(640px 420px at 85% 0%, #000, transparent 75%);
  opacity:.5;
}
.badge-fr{display:inline-flex;align-items:center;gap:10px;border:1px solid hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .5);
  border-radius:var(--r-pill);background:hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .08);white-space:nowrap;
  padding:var(--s2) var(--s5);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:hsl(var(--acc-h) 70% 40%)}
.badge-fr .pt{width:7px;height:7px;border-radius:50%;background:var(--acc-vive);box-shadow:0 0 10px var(--acc);animation:clignote 2.4s ease-in-out infinite}
.secu-grille{display:grid;gap:1px;grid-template-columns:1fr;background:var(--ligne);
  border:1px solid var(--ligne);border-radius:var(--r-l);overflow:hidden}
@media(min-width:720px){.secu-grille{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.secu-grille{grid-template-columns:repeat(4,1fr)}}
.secu-carte{position:relative;background:var(--noir-2);padding:var(--s7) var(--s6);min-height:320px;display:flex;flex-direction:column;overflow:hidden;transition:background .35s}
.secu-carte:hover{background:var(--noir-3)}
.secu-carte .trame-coin{position:absolute;right:0;top:0;width:170px;height:140px;pointer-events:none;
  background-image:radial-gradient(circle, rgba(16,28,61,.28) 1px, transparent 1.3px);
  background-size:7px 7px;opacity:0;transition:opacity .4s;
  -webkit-mask-image:radial-gradient(circle at 100% 0, #000, transparent 75%);
  mask-image:radial-gradient(circle at 100% 0, #000, transparent 75%)}
.secu-carte:hover .trame-coin{opacity:.55}
.secu-carte .ki{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muet);display:flex;justify-content:space-between;margin-bottom:var(--s7)}
.secu-carte .picto{width:42px;height:42px;margin-bottom:auto}
.secu-carte .picto svg{width:100%;height:100%;stroke:var(--acc);fill:none;stroke-width:1.2}
.secu-carte h4{font-size:16px;line-height:24px;font-weight:400;color:var(--blanc);margin:var(--s7) 0 var(--s2);letter-spacing:.01em;
  min-height:48px;display:flex;align-items:flex-end} /* 2 lignes réservées — têtes de cartes alignées */
.secu-carte p{color:var(--muet);font-size:13.5px;line-height:22px;min-height:88px} /* 4 lignes réservées */

/* ---------- DÉMARCHE ---------- */
.frise{position:relative;display:grid;gap:var(--s8);grid-template-columns:1fr;margin-top:var(--s4);counter-reset:jalon}
@media(min-width:900px){
  .frise{grid-template-columns:repeat(3,1fr);gap:var(--s8)}
  .frise::before{content:'';position:absolute;top:7px;left:4%;right:4%;height:1px;
    background:linear-gradient(90deg,var(--acc), hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .12))}
}
.jalon{position:relative;padding-top:var(--s7)}
.jalon::before{content:'';position:absolute;top:0;left:0;width:15px;height:15px;border-radius:50%;
  background:var(--noir);border:1.5px solid var(--acc)}
.jalon:first-child::before{background:var(--acc);box-shadow:0 0 16px hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .8)}
.jalon .num{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--acc);margin-bottom:var(--s3)}
.jalon h4{font-family:var(--serif);font-weight:400;font-size:clamp(1.25rem,1.1rem+.5vw,1.4375rem);line-height:1.2;margin-bottom:var(--s2);min-height:calc(2em * 1.2);display:flex;align-items:flex-end} /* 2 lignes réservées — jalons alignés */
.jalon p{color:var(--muet);font-size:var(--t-body);line-height:24px}
.jalon .duree{font-family:var(--serif-produit);font-style:italic;color:var(--blanc-doux);font-size:16px;margin-top:var(--s3)}

/* ---------- TURING LABS : L'ATELIER ---------- */
.turing{background:var(--noir-2);border-top:1px solid var(--ligne)}
.turing .anti{border-color:var(--ligne)}
.turing .anti:last-child{border-bottom:1px solid var(--ligne)}
.turing .anti .no{color:var(--acc)}
.turing .anti p{color:var(--blanc-doux)}
.turing .manif-intro{color:var(--blanc-doux);font-size:var(--t-body);line-height:25px;margin-top:var(--s5);max-width:440px}
.citation{margin-top:var(--s8);max-width:400px;font-size:18px;line-height:29px;font-style:italic;color:var(--blanc)}
.citation footer{margin-top:var(--s4);font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muet);font-style:normal;
  background:none;border:none;padding:0}

/* ---------- BANNIÈRE FINALE : LA BRAISE ---------- */
.banniere-wrap{padding:var(--s8) 0 var(--s10)}
.banniere{
  position:relative;border-radius:36px;overflow:hidden;
  min-height:520px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:var(--s11) var(--s6);
  background:
    radial-gradient(720px 480px at 22% 8%, hsl(var(--acc-h) 92% 70% / .85), transparent 58%),
    radial-gradient(900px 640px at 78% 95%, hsl(var(--acc-h) 80% 28%), transparent 65%),
    radial-gradient(1200px 800px at 50% 50%, hsl(var(--acc-h) 78% 46%), hsl(var(--acc-h) 70% 20%)),
    var(--noir);
}
.banniere .grain-local{position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;opacity:calc(var(--grain)*.9);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.banniere .voile-sombre{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 120%, rgba(11,10,9,.55), transparent 60%)}
.banniere .dedans{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:var(--s6);max-width:760px}
.banniere h2{font-size:clamp(2.375rem,1.5rem+3.6vw,4rem);line-height:1;letter-spacing:-.025em;color:#F2F6FF;text-wrap:balance}
.banniere h2 em{font-style:normal;color:#D8E4FF}
.banniere .ss{color:rgba(242,246,255,.85);font-size:var(--t-body-lg);line-height:27px;max-width:480px}
.banniere .btn.plein{box-shadow:0 24px 48px -16px rgba(11,10,9,.5)}
.banniere .mention{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,246,255,.6);margin-top:var(--s2)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--ligne);padding:var(--s10) 0 var(--s8);background:var(--noir)}
.foot-grille{display:grid;gap:var(--s8);grid-template-columns:1fr}
@media(min-width:900px){.foot-grille{grid-template-columns:1.5fr 1fr 1fr 1fr}}
.foot-marque .logo{font-size:17px}
.foot-marque p{color:var(--muet);font-size:13px;line-height:21px;margin-top:var(--s4);max-width:280px}
.foot-col .titre{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muet);margin-bottom:var(--s4)}
.foot-col a{display:block;font-size:14px;line-height:20px;color:var(--blanc-doux);padding:var(--s1) 0;transition:color .2s}
.foot-col a:hover{color:var(--acc)}
.foot-bas{display:flex;justify-content:space-between;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s9);padding-top:var(--s6);border-top:1px solid var(--ligne)}
.foot-bas p{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muet)}

/* ---------- DÉMARCATIONS ---------- */
#securite,#demarche{border-top:1px solid var(--ligne)}
#usages .verre-scene{margin-top:var(--s4)}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.on{opacity:1;transform:none}
.reveal.r2{transition-delay:.12s}.reveal.r3{transition-delay:.24s}.reveal.r4{transition-delay:.36s}

@media (prefers-reduced-motion: reduce){
  .reveal,.fondu,.hero h1 .mot,.etage,.ligne-scan,.resultat{opacity:1 !important;transform:none !important;filter:none !important;transition:none !important}
  .trace{stroke-dashoffset:0 !important;transition:none !important}
  .orbe-eclipse,.orbe-halo-fond,.orbe-mini,.grain-veil,.ticker-piste{animation:none !important}
  .curseur{animation:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   DA BLEU & BLANC — overrides pour les éléments restant
   sur surface sombre (nav/hero sur image, scène photo, bannière)
   ============================================================ */
.navbar{color:#F2F5FA}
.nav-links a:hover{color:#fff}
.btn-nav{color:#F2F5FA}
.hero .sous{color:#C9CFDD}
.hero-pied{color:#97A1B8}
.hero-pied span b{color:#D8DDE9}
.btn.plein,.btn.blanc-simple{background:#fff;color:#101C3D}
.btn.plein:hover,.btn.blanc-simple:hover{background:#fff}
.btn.blanc-simple svg{stroke:#101C3D}
.btn.fantome{color:#F2F5FA;border-color:rgba(242,245,250,.35);background:rgba(242,245,250,.05)}
.btn.fantome:hover{background:#fff;color:#101C3D;border-color:#fff}
.verre-scene{color:#F0F3F9}
.verre-carte .ki{color:#D5DBE8}
.verre-carte .ki .num,.verre-carte p .dim,.compteur-sub,.verre-scene .legende,
.ligne-scan .detail,.resultat .chemin,.resultat .fichier .plus{color:#97A1B8}
.verre-carte p{color:#C9D0DF}
.compteur{color:#F4F7FC}
.compteur small{color:#C9D0DF}
.ligne-scan .dossier,.faux-champ,.resultat .fichier{color:#EFF2F8}
.pill.ok{color:#C9D0DF}

/* ============================================================
   RESPONSIVE MOBILE
   ============================================================ */
@media(max-width:640px){
  section{padding:var(--s11) 0}

  /* nav : logo à gauche, CTA à droite, pleine largeur */
  .navbar{width:calc(100% - var(--s6));justify-content:space-between;gap:var(--s3);padding:var(--s2) 0;top:var(--s4)}
  .logo{font-size:16px}
  .btn-nav{padding:8px 14px;font-size:12.5px}

  /* hero compact */
  .hero{padding:calc(var(--s10) + var(--s6)) var(--s4) var(--s8)}
  .hero h1{font-size:min(11.5vw,7svh)}
  .hero .sous{font-size:15px;line-height:23px;max-width:90%}
  .hero-btns{margin-top:var(--s5);gap:var(--s3)}
  .btn{padding:var(--s3) var(--s6);font-size:14.5px}
  .hero-pied{display:none}
  .orbe-scene{margin-bottom:calc(-1 * min(18vw,80px))}

  .ticker span.q{font-size:17px}
  .sec-tete{margin-bottom:var(--s7)}

  /* démo */
  .produit{padding:var(--s8) var(--s4) var(--s7)}
  .chat{max-height:380px}
  .pilules{column-gap:var(--s4)}
  .msg.user .bulle{font-size:1.125rem}

  /* cas d'usage : cartes fluides, plus de hauteurs réservées */
  .verre-scene{min-height:0;border-radius:20px}
  .verre-grille{padding:var(--s4);gap:var(--s3)}
  .verre-carte{min-height:0;padding:var(--s5);border-radius:14px}
  .verre-carte h3{margin-top:var(--s4)}
  .compteur{font-size:2.75rem}

  /* sécurité / démarche : hauteurs réservées inutiles en 1 colonne */
  .secu-carte{min-height:0;padding:var(--s6) var(--s5)}
  .secu-carte h4{min-height:0}
  .secu-carte p{min-height:0}
  .jalon h4{min-height:0}

  .citation{font-size:16px;line-height:26px}

  /* bannière */
  .banniere-wrap{padding:var(--s6) 0 var(--s8)}
  .banniere{min-height:0;padding:var(--s10) var(--s5);border-radius:22px}

  footer{padding:var(--s9) 0 var(--s7)}
  .foot-bas{margin-top:var(--s7)}
}

/* ============================================================
   SECTION DÉMO — habillage bleu & blanc
   ============================================================ */
@keyframes clignote{0%,100%{opacity:1}50%{opacity:.35}}

/* décor derrière la fenêtre : trame de points + nappe renforcée */
.scene-produit::after{
  content:'';position:absolute;inset:-48px -64px;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle, rgba(16,28,61,.2) 1px, transparent 1.3px);
  background-size:11px 11px;
  -webkit-mask-image:radial-gradient(62% 72% at 50% 38%, #000, transparent 76%);
  mask-image:radial-gradient(62% 72% at 50% 38%, #000, transparent 76%);
}
.scene-produit::before{opacity:1;background:radial-gradient(ellipse, hsl(var(--acc-h) var(--acc-s) var(--acc-l) / .3), transparent 70%)}
.fenetre{z-index:1;background:linear-gradient(180deg,#FFFFFF,#FAFBFE)}
.fenetre::after{ /* filet lumineux supérieur */
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg, transparent, hsl(var(--acc-h) 80% 56% / .55), transparent);
}

/* bandeau du produit */
.fenetre-tete{display:flex;justify-content:space-between;align-items:center;gap:var(--s4);
  padding:var(--s4) var(--s6);border-bottom:1px solid rgba(16,28,61,.07);
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#8B93AE}
.fenetre-tete .pt-live{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--acc);
  box-shadow:0 0 10px var(--acc);margin-right:10px;vertical-align:1px;animation:clignote 2.4s ease-in-out infinite}
@media(max-width:640px){.fenetre-tete .ft-droite{display:none}}

/* halo + anneaux autour de l'orbe */
.produit{position:relative}
.produit::before{content:'';position:absolute;top:-110px;left:50%;transform:translateX(-50%);
  width:580px;height:400px;pointer-events:none;
  background:radial-gradient(closest-side, hsl(var(--acc-h) 80% 56% / .1), transparent 72%)}
.produit .orbe-mini-halo{position:relative;width:96px;height:96px}
.produit .orbe-mini{width:56px;height:56px}
.orbe-mini-halo::before,.orbe-mini-halo::after{content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);border-radius:50%;pointer-events:none;
  border:1px solid hsl(var(--acc-h) 70% 50% / .16)}
.orbe-mini-halo::before{width:160px;height:160px}
.orbe-mini-halo::after{width:250px;height:250px;border-color:hsl(var(--acc-h) 70% 50% / .08)}

/* suggestions : pilules fines */
.pilules{column-gap:var(--s3);row-gap:var(--s3)}
.pilule{background:#fff;border:1px solid rgba(16,28,61,.14);border-radius:var(--r-pill);
  padding:9px 16px;color:#46506E;letter-spacing:.04em;
  transition:color .2s,border-color .2s,background .2s,transform .2s var(--ease)}
.pilule:hover{color:var(--acc);border-color:hsl(var(--acc-h) 80% 56% / .55);
  background:hsl(var(--acc-h) 80% 56% / .04);transform:translateY(-1px)}

/* saisie : vrai champ */
.saisie{background:#fff;border:1px solid rgba(16,28,61,.13);border-radius:20px;
  padding:var(--s2) var(--s3) var(--s2) var(--s5);
  box-shadow:0 18px 40px -26px rgba(16,28,61,.35);
  transition:border-color .25s,box-shadow .25s}
.saisie:focus-within{border-color:hsl(var(--acc-h) 80% 56% / .6);
  box-shadow:0 0 0 4px hsl(var(--acc-h) 80% 56% / .08), 0 18px 40px -26px rgba(16,28,61,.35)}
.saisie .barre{padding:0 0 var(--s1)}
.saisie .envoi{border-color:hsl(var(--acc-h) 80% 56% / .4)}
.saisie .envoi svg{stroke:var(--acc)}
.saisie .envoi.actif{background:var(--acc);border-color:var(--acc)}
.saisie .envoi.actif svg{stroke:#fff}

/* ---------- carte Pilotage : barres de répartition ---------- */
.verre-barres{display:flex;flex-direction:column;gap:var(--s3);margin:var(--s5) 0 var(--s2)}
.vb{display:grid;grid-template-columns:74px 1fr 52px;align-items:center;gap:var(--s3);font-size:12px}
.vb-nom{color:#C9D0DF;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vb-piste{display:block;height:2px;background:rgba(242,245,250,.18);overflow:hidden}
.vb-rempli{display:block;height:100%;background:var(--acc-vive);width:0;transition:width 1.2s var(--ease) .35s}
.on-scene .vb-rempli{width:var(--w,0%)}
.vb-val{font-family:var(--mono);font-size:10px;color:#97A1B8;text-align:right;white-space:nowrap}

/* démo : moins d'air vertical en tête de fenêtre */
.produit{padding:var(--s8) var(--s7) var(--s8)}
.produit::before{top:-150px}
.orbe-mini-halo::after{width:210px;height:210px}
.chat{margin:var(--s6) 0 var(--s5)}
.produit .ecoute{margin-top:var(--s2)}
/* citation sur fond papier */
.sur-papier .citation{color:var(--encre);font-size:17px;line-height:27px}
