/* =========================================================================
   Citoyen · SIEF — thème moderne (inspiration Geist / Vercel : blanc pur,
   hairlines, typographie nette) avec accents bleu-blanc-rouge discrets.
   ========================================================================= */
:root{
  --bg:#ffffff; --bg-2:#fafafa; --bg-3:#f5f6f8;
  --ink:#0a0a0a; --ink-2:#3d3d3d; --muted:#737373; --faint:#a3a3a3;
  --line:#ececec; --line-2:#e2e2e2; --line-3:#d4d4d4;
  --blue:#1b3df5; --blue-ink:#0f2bb5; --blue-soft:#eef1ff;
  --red:#e4313f; --red-soft:#fdecec;
  --card:#ffffff; --shadow-sm:0 1px 2px rgba(10,10,12,.05);
  --shadow:0 6px 24px -8px rgba(16,24,60,.14);
  --r:10px; --r-lg:16px; --maxw:1120px; --maxw-read:740px;
  --sans:"Geist","Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:"Geist Mono","SF Mono",ui-monospace,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16.5px;line-height:1.6;
  -webkit-font-smoothing:antialiased;letter-spacing:-.005em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wrap-wide{max-width:1240px;margin:0 auto;padding:0 24px}
a{color:var(--ink);text-decoration:none}
a:hover{color:var(--blue)}
h1{font-size:clamp(2rem,4.5vw,3rem);line-height:1.05;font-weight:600;letter-spacing:-.03em;margin:.2em 0 .4em}
h2{font-size:clamp(1.4rem,3vw,1.9rem);font-weight:600;letter-spacing:-.02em;margin:1.6em 0 .5em}
h3{font-size:1.12rem;font-weight:600;letter-spacing:-.01em;margin:.2em 0}
p{margin:.7em 0}
.muted{color:var(--muted);font-size:.9rem}
.lead{font-size:1.2rem;line-height:1.5;color:var(--ink-2);max-width:60ch;font-weight:400;letter-spacing:-.01em}
.kick{font-family:var(--mono);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--blue)}
.crumb{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:.2em 0}
.crumb a{color:var(--muted)} .crumb a:hover{color:var(--blue)}
.nowrap{white-space:nowrap}
.count{display:inline-block;font-family:var(--mono);font-size:.72rem;color:var(--blue-ink);background:var(--blue-soft);
  padding:.15em .5em;border-radius:6px;vertical-align:middle;margin-left:.35em}
.tag{display:inline-block;font-size:.78rem;color:var(--ink-2);background:var(--bg-3);border:1px solid var(--line);
  padding:.18em .6em;border-radius:6px;margin-top:.4em}

/* ---- header ---- */
.hd{background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:40}
.hd::before{content:"";display:block;height:3px;background:linear-gradient(90deg,var(--blue) 0 33%,#fff 33% 66%,var(--red) 66% 100%)}
.hd .wrap{display:flex;align-items:center;gap:22px;min-height:62px;flex-wrap:wrap}
.brand{color:var(--ink);font-size:1rem;font-weight:600;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
.brand::before{content:"";width:18px;height:18px;border-radius:5px;flex:0 0 auto;
  background:conic-gradient(from 220deg,var(--blue),#fff 50%,var(--red));box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.brand b{font-weight:700}
.hd nav{margin-left:auto;display:flex;gap:1px;flex-wrap:wrap}
.hd nav a{color:var(--ink-2);padding:.5em .7em;font-size:.9rem;font-weight:450;border-radius:7px;letter-spacing:-.01em}
.hd nav a:hover{color:var(--ink);background:var(--bg-3)}
.hd nav a.active{color:var(--blue);font-weight:550}
.navtog{display:none;margin-left:auto;background:none;border:1px solid var(--line-2);color:var(--ink);
  font-size:1.1rem;border-radius:8px;padding:.15em .55em;cursor:pointer}

main{padding:40px 0 72px;min-height:62vh}

/* ---- accueil : métriques ---- */
.home-metrics{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;margin:8px 0 6px;background:var(--card)}
.hm-item{flex:1 1 140px;padding:18px 18px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:3px}
.hm-item:last-child{border-right:0}
.hm-item b{font-size:1.7rem;font-weight:650;letter-spacing:-.03em;line-height:1}
.hm-item span{font-size:.8rem;color:var(--muted)}
.hm-hi b{color:var(--blue)}

/* ---- accueil : constellation orbitale ---- */
.orbit-full{padding:14px 4% 0}
.orbit-intro{text-align:center;max-width:680px;margin:30px auto 0}
.orbit-intro .ia-line{font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:var(--muted);
  max-width:600px;margin:12px auto 14px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.orbit-intro p{font-size:1.05rem;color:var(--ink-2);line-height:1.5}
.orbit-intro b{font-weight:600;color:var(--ink)}
.orbit-stage{position:relative;max-width:1120px;height:clamp(520px,54vw,760px);margin:74px auto 66px;overflow:visible}
.orbit-stage::before{content:"";position:absolute;left:50%;top:50%;width:52%;height:58%;transform:translate(-50%,-50%);
  border-radius:50%;background:radial-gradient(ellipse at center,var(--blue-soft),transparent 70%);pointer-events:none}
.oring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid var(--line-2);border-radius:50%;pointer-events:none}
.or-in{width:54%;height:62%}
.or-out{width:92%;height:96%}
.ocore{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:clamp(240px,30%,312px);
  background:var(--card);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:20px 22px 18px;text-align:center;
  z-index:5;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;transition:.18s}
.ocore::before{content:"";position:absolute;top:0;left:24px;right:24px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--blue) 0 40%,#fff 40% 60%,var(--red) 60% 100%)}
.ocore .ot{font-size:1.12rem;font-weight:600;line-height:1.14;letter-spacing:-.02em;color:var(--ink);margin-top:6px}
.ocore .od{font-size:.84rem;line-height:1.42;color:var(--ink-2);margin-top:9px}
.ocore .octa{font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin-top:16px}
.ocore:hover{border-color:var(--blue);box-shadow:0 22px 60px -18px rgba(16,24,60,.28)}
.onode{position:absolute;display:flex;align-items:center;gap:10px;width:max-content;max-width:196px;z-index:3}
.onode .bubble{position:absolute;left:7px;top:50%;width:46px;height:46px;transform:translate(-50%,-50%);border-radius:50%;
  background:radial-gradient(circle,rgba(27,61,245,.10),transparent 70%);pointer-events:none;z-index:-1;transition:.18s}
.onode:hover .bubble{background:radial-gradient(circle,rgba(27,61,245,.22),transparent 72%)}
.onode .dot{width:11px;height:11px;border-radius:50%;background:var(--blue);flex-shrink:0;box-shadow:0 0 0 4px var(--bg);transition:transform .18s}
.onode .lbl{display:flex;flex-direction:column;max-width:158px}
.onode .nt{font-size:.95rem;font-weight:550;line-height:1.14;color:var(--ink);letter-spacing:-.01em}
.onode .nm{font-family:var(--mono);font-size:.66rem;letter-spacing:.04em;color:var(--muted);margin-top:3px}
.onode:hover .nt{color:var(--blue)}
.onode:hover .dot{transform:scale(1.35)}
.ring-out .dot{background:var(--ink-2)}
.ring-in .dot{width:13px;height:13px}
.side-r{flex-direction:row;text-align:left;transform:translateY(-50%)}
.side-l{flex-direction:row-reverse;text-align:right;transform:translate(-100%,-50%)}
.side-t{flex-direction:column-reverse;text-align:center;transform:translate(-50%,-100%)}
.side-b{flex-direction:column;text-align:center;transform:translate(-50%,0)}
.side-t .lbl,.side-b .lbl{align-items:center}
.orbit-fallback{display:none}

/* ---- sections accueil ---- */
.section{padding:14px 0}
.section .head{max-width:var(--maxw-read);margin-bottom:14px}
.qa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}

/* ---- tuiles ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;margin:18px 0}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;color:var(--ink);
  display:block;transition:.15s;box-shadow:var(--shadow-sm)}
.card:hover{border-color:var(--line-3);box-shadow:var(--shadow);transform:translateY(-2px)}
.card h3{color:var(--ink)} .card:hover h3{color:var(--blue)}
.card .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:var(--blue);margin:.3em 0}
.card .muted{margin-top:.5em}
.card.big{padding:22px 24px}
.card .tag{margin-top:.7em}

/* ---- listes / tableaux ---- */
.list{list-style:none;padding:0;margin:.5em 0;columns:2;column-gap:40px}
.list li{margin:.34em 0;break-inside:avoid;padding-left:16px;position:relative}
.list li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;background:var(--blue);border-radius:50%}
@media(max-width:640px){.list{columns:1}}
.tbl{width:100%;border-collapse:collapse;font-size:.93rem;margin:1em 0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line)}
.tbl thead th{background:var(--bg-3);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-2)}
.tbl tbody tr:hover{background:var(--bg-2)}
.tbl tr:last-child td{border-bottom:0}

/* ---- document (synthèses, fiches) ---- */
.doc{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px 44px;margin:18px 0}
.doc.small{font-size:.95rem;background:var(--bg-2)}
.doc>*{max-width:var(--maxw-read)}
.doc h1{margin-top:0;font-size:2rem}
.doc h2{font-size:1.4rem;margin-top:1.5em}
.doc h3{font-size:1.12rem;margin:1.4em 0 .3em;color:var(--ink)}
.doc p{margin:.75em 0;color:var(--ink-2)}
.doc blockquote{border-left:2px solid var(--blue);margin:1em 0;padding:.3em 0 .3em 18px;color:var(--ink);font-size:1.02em}
.doc blockquote p{margin:.3em 0;color:var(--ink)}
.doc code{font-family:var(--mono);background:var(--bg-3);padding:.08em .4em;border-radius:5px;font-size:.85em}
.doc ul,.doc ol{padding-left:1.4em}.doc li{margin:.3em 0;color:var(--ink-2)}
.doc table{border-collapse:collapse;width:100%;font-size:.88rem;margin:1.2em 0;border:1px solid var(--line)}
.doc table th,.doc table td{border:1px solid var(--line);padding:8px 11px;text-align:left;vertical-align:top}
.doc table th{background:var(--bg-3);font-weight:600}
.doc hr{border:none;border-top:1px solid var(--line);margin:1.8em 0}
.links{margin:16px 0 0;display:flex;flex-wrap:wrap;gap:10px}
.links a{display:inline-flex;align-items:center;padding:.5em 1em;border:1px solid var(--line-2);color:var(--ink);
  border-radius:8px;font-size:.88rem;font-weight:500;box-shadow:var(--shadow-sm)}
.links a:hover{border-color:var(--blue);color:var(--blue)}
.meta{color:var(--muted);font-size:.9rem}
details.more{margin:18px 0;border:1px solid var(--line);border-radius:var(--r);background:var(--bg-2)}
details.more>summary{cursor:pointer;font-weight:600;color:var(--ink);padding:13px 18px;list-style:none}
details.more>summary::-webkit-details-marker{display:none}
details.more>summary::before{content:"→ ";color:var(--blue);font-family:var(--mono)}
details.more[open]>summary::before{content:"↓ "}
details.more .doc{margin:0;border:0;border-top:1px solid var(--line);border-radius:0}

/* ---- vidéo ---- */
.video{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;margin:16px 0;background:#000;border-radius:var(--r);border:1px solid var(--line)}
.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- recherche ---- */
.search{width:100%;font-size:1.05rem;padding:15px 17px;border:1px solid var(--line-2);border-radius:var(--r);
  margin:12px 0 22px;background:var(--bg-2);font-family:inherit}
.search:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px var(--blue-soft)}
.results .r{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:12px 16px;margin:8px 0;box-shadow:var(--shadow-sm)}
.results .r:hover{border-color:var(--line-3);box-shadow:var(--shadow)}
.results .k{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;
  background:var(--blue);padding:.16em .5em;border-radius:5px;margin-right:8px}

/* ---- explorateur à facettes ---- */
.expo-top{border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:6px}
.expo-controls{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.expo-controls input{flex:1;min-width:240px;font-size:1.05rem;padding:13px 16px;border:1px solid var(--line-2);
  border-radius:var(--r);background:var(--bg-2);font-family:inherit}
.expo-controls input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px var(--blue-soft)}
.surprise{background:var(--ink);border:1px solid var(--ink);color:#fff;font-weight:500;border-radius:var(--r);padding:0 18px;cursor:pointer;font-size:.92rem}
.surprise:hover{background:var(--blue);border-color:var(--blue)}
.expo-body{display:grid;grid-template-columns:240px 1fr;gap:30px;margin-top:22px}
.expo-rail{align-self:start;position:sticky;top:84px}
.rail-t{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}
.fgroup{margin-bottom:18px}
.fglabel{display:block;font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:9px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chips-scroll{max-height:240px;overflow:auto;padding-right:4px}
.chip{font:inherit;font-size:.82rem;background:var(--card);border:1px solid var(--line-2);color:var(--ink-2);
  padding:.32em .72em;border-radius:20px;cursor:pointer;transition:.12s;letter-spacing:-.01em}
.chip:hover{border-color:var(--blue);color:var(--blue)}
.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}
.expo-bar{display:flex;align-items:center;gap:14px;margin-bottom:16px;font-weight:600}
.reset{background:none;border:0;color:var(--blue);cursor:pointer;text-decoration:underline;font:inherit;font-weight:500}
.expo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(282px,1fr));gap:14px}
.ecard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:17px 19px;transition:.15s;box-shadow:var(--shadow-sm)}
.ecard:hover{border-color:var(--line-3);box-shadow:var(--shadow);transform:translateY(-2px)}
.ecard.flash{animation:flash 1.2s ease}
@keyframes flash{0%,100%{box-shadow:var(--shadow-sm)}30%{box-shadow:0 0 0 2px var(--blue)}}
.ec-top{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:7px}
.ec-dom{font-family:var(--mono);font-size:.68rem;font-weight:500;color:var(--blue);text-transform:uppercase;letter-spacing:.05em}
.ec-niv{font-family:var(--mono);font-size:.68rem;color:var(--muted)}
.ecard h3{margin:.1em 0 .35em;font-size:1.04rem}
.ecard h3 a{color:var(--ink)} .ecard:hover h3 a{color:var(--blue)}
.ec-resume{font-size:.9rem;color:var(--ink-2);margin:.3em 0;line-height:1.5}
.ec-meta{font-size:.78rem;color:var(--muted);margin-top:.55em}
.ec-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:.65em}
.ec-tags .tag{margin:0;cursor:pointer}.ec-tags .tag:hover{border-color:var(--blue);color:var(--blue)}
.expo-empty{padding:46px;text-align:center;color:var(--muted);background:var(--bg-2);border:1px dashed var(--line-2);border-radius:var(--r)}

/* ---- embed avatar ---- */
.avatar-embed{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;height:74vh;min-height:520px;background:#fff;box-shadow:var(--shadow-sm)}
.avatar-embed iframe{width:100%;height:100%;border:0;display:block}

/* ---- bandeau consentement ---- */
/* consentement mesure d'audience : dans le pied de page (aucun flottant => aucun overlap) */
.fconsent{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-size:.84rem;color:var(--muted);
  display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fconsent button{background:var(--card);border:1px solid var(--line-2);color:var(--ink);border-radius:7px;
  padding:.3em .8em;cursor:pointer;font:inherit;font-size:.82rem}
.fconsent button:hover{border-color:var(--blue);color:var(--blue)}

/* ---- pied de page ---- */
footer{background:var(--bg-2);border-top:1px solid var(--line);padding:34px 0;font-size:.86rem;color:var(--ink-2);margin-top:60px}
footer::before{content:"";display:block;height:2px;width:60px;margin:0 auto 22px;
  background:linear-gradient(90deg,var(--blue) 0 33%,#fff 33% 66%,var(--red) 66% 100%)}
footer p{margin:.4em 0;max-width:84ch}
footer .muted{color:var(--muted)}

@media(max-width:880px){
  .expo-body{grid-template-columns:1fr}
  .expo-rail{position:static}.chips-scroll{max-height:none}
  .orbit-stage{display:none}
  .orbit-fallback{display:block;max-width:620px;margin:18px auto 0}
  .of-flag{display:block;border:1px solid var(--line-2);border-radius:var(--r);padding:18px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
  .of-flag .t{font-size:1.15rem;font-weight:600;display:block;margin-top:4px}
  .of-grp{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:16px 0 8px}
  .of-list{list-style:none;padding:0;margin:0}
  .of-list li{border-bottom:1px solid var(--line)}
  .of-list a{display:flex;justify-content:space-between;gap:10px;padding:11px 2px;align-items:baseline}
  .of-list em{font-family:var(--mono);font-size:.7rem;color:var(--muted);font-style:normal}
}
@media(max-width:760px){
  .navtog{display:block}
  .hd nav{display:none;width:100%;flex-direction:column;margin:6px 0}
  body.navopen .hd nav{display:flex}
  .hd nav a{padding:.6em .5em;border-bottom:1px solid var(--line)}
  .doc{padding:24px 22px}
  .home-metrics{border-radius:var(--r)}
  .hm-item{flex-basis:50%;border-bottom:1px solid var(--line)}
}

/* explorer fusionné (sujets + facettes domaine + cross-corpus) */
.fbar{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0 4px}
.dom-group{margin:26px 0}
.dom-group h2{font-size:1.25rem;margin:0 0 .45em;border-bottom:1px solid var(--line);padding-bottom:.3em}
.dom-group h2 a{color:var(--ink)} .dom-group h2 a:hover{color:var(--blue)}
.other{margin:14px 0 10px;padding:16px 18px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r)}
.other h2{margin:0 0 .5em;font-size:1.05rem}

/* nav : l'agent en bouton d'appel (CTA) */
.hd nav a.nav-cta{background:var(--blue);color:#fff;border-radius:8px;padding:.5em .95em;margin-left:6px;font-weight:550}
.hd nav a.nav-cta:hover{background:var(--blue-ink);color:#fff}
.hd nav a.nav-cta.active{background:var(--blue-ink)}

/* hero de l'agent — le clou du site */
.ask-hero{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:44px 48px;margin:46px 0;position:relative;overflow:hidden}
.ask-hero::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(27,61,245,.55),transparent 70%);pointer-events:none}
.ask-hero .inner{position:relative;z-index:1;max-width:680px}
.ask-hero .kick{color:#9db0ff}
.ask-hero h2{color:#fff;font-size:clamp(1.55rem,3.2vw,2.3rem);line-height:1.08;letter-spacing:-.025em;margin:.35em 0 .3em;max-width:20ch}
.ask-hero p{color:rgba(255,255,255,.8);max-width:56ch;margin:.5em 0 0;font-size:1.05rem}
.askbtn{display:inline-flex;align-items:center;gap:9px;margin-top:24px;background:#fff;color:var(--ink);font-weight:650;
  padding:.78em 1.5em;border-radius:11px;font-size:1.05rem;box-shadow:0 8px 24px -8px rgba(0,0,0,.5);transition:.15s}
.askbtn:hover{background:var(--blue);color:#fff;transform:translateY(-1px)}
.ask-tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.ask-tags span{font-size:.84rem;color:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:.28em .8em}
@media(max-width:600px){.ask-hero{padding:30px 24px}}

/* avatars acteurs */
.avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:0 0 auto;background:var(--bg-3);border:1px solid var(--line)}
.avatar-ph{display:inline-flex;align-items:center;justify-content:center;font-weight:600;color:var(--ink-2);font-size:.92rem;letter-spacing:.02em}
.avatar-lg{width:108px;height:108px;font-size:2rem;border:1px solid var(--line-2)}
.actor-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2px;padding:22px 16px 18px}
.actor-card .avatar{width:66px;height:66px;margin-bottom:9px}
.actor-card .avatar-ph{font-size:1.25rem}
.actor-card .ac-body{min-width:0;width:100%}
.actor-card h3{margin:0 0 .12em;font-size:1rem;line-height:1.2}
.actor-card .meta{margin:.1em 0}
.actor-card .muted{margin:.15em 0}
.fiche-top{display:flex;justify-content:center;margin:4px 0 -6px}
.fiche-top .avatar-lg{box-shadow:var(--shadow-sm)}

/* chat plein écran : l'iframe remplit le viewport, l'input reste visible en bas */
.chat-wrap{display:flex;flex-direction:column;height:calc(100dvh - 116px);min-height:520px}
.chat-head{flex:0 0 auto;margin-bottom:12px}
.chat-head h1{margin:.05em 0 .1em}
.chat-head .muted{max-width:74ch}
.chat-wrap .avatar-embed{flex:1 1 auto;min-height:0;height:auto;margin:0}

/* fix recadrage photos : garder le visage (biais vers le haut) */
.avatar{object-position:center 24%}

/* chat plein écran « clean » (mode bare : pas de footer) — tout en flex pour que l'iframe remplisse */
body.bare{display:flex;flex-direction:column;height:100dvh;overflow:hidden}
body.bare .hd{position:static;flex:0 0 auto}
body.bare main{flex:1 1 auto;min-height:0;padding:0;max-width:none;display:flex}
.chat-full{flex:1 1 auto;min-height:0;display:flex;justify-content:center;background:#fff}
.chat-full iframe{flex:1 1 auto;width:100%;max-width:840px;min-height:0;border:0;display:block;background:#fff}

/* ===== chat maison façon Gemini ===== */
.gchat{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;width:100%;background:#fff}
.gchat-log{flex:1 1 auto;min-height:0;overflow-y:auto;padding:28px 20px 8px}
.gchat-empty{max-width:680px;margin:5vh auto 0;text-align:center;padding:0 12px}
.gc-spark{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#1b3df5,#6a3df5 55%,#d6357a);color:#fff;box-shadow:0 10px 28px -10px rgba(70,40,210,.55)}
.gc-hello{font-size:clamp(1.9rem,4.2vw,2.6rem);font-weight:600;letter-spacing:-.03em;margin:.45em 0 .15em;
  background:linear-gradient(100deg,#1b3df5,#6a3df5 50%,#d6357a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.gc-sub{color:var(--ink-2);font-size:1.06rem;line-height:1.5;max-width:56ch;margin:.4em auto 0}
.gc-suggs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:620px;margin:32px auto 0}
.sugg{text-align:left;background:var(--card);border:1px solid var(--line-2);border-radius:14px;padding:14px 16px;
  cursor:pointer;font:inherit;font-size:.93rem;color:var(--ink);transition:.14s;line-height:1.35}
.sugg:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px);color:var(--blue)}
@media(max-width:560px){.gc-suggs{grid-template-columns:1fr}}
.msg{max-width:760px;margin:22px auto;display:flex;gap:13px;align-items:flex-start}
.msg.user{flex-direction:row-reverse}
.msg.user .bubble{background:var(--blue-soft);color:var(--ink);border-radius:18px 18px 4px 18px;padding:11px 16px;max-width:78%;line-height:1.5}
.msg.bot .bubble{flex:1;min-width:0;line-height:1.65;color:var(--ink)}
.msg.bot .bubble p{margin:.55em 0}.msg.bot .bubble p:first-child{margin-top:0}
.msg.bot .bubble h4{font-size:1.02rem;font-weight:650;margin:1em 0 .25em}
.msg.bot .bubble ul,.msg.bot .bubble ol{padding-left:1.3em;margin:.45em 0}
.msg.bot .bubble li{margin:.25em 0}
.msg.bot .bubble code{font-family:var(--mono);background:var(--bg-3);padding:.06em .35em;border-radius:5px;font-size:.86em}
.msg.bot .bubble .q{font-style:italic;color:#33373c}
.msg-ic{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1b3df5,#6a3df5 55%,#d6357a);color:#fff;margin-top:1px}
.typing{display:inline-flex;gap:5px;padding:7px 0}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--faint);animation:tp 1.1s infinite ease-in-out}
.typing i:nth-child(2){animation-delay:.15s}.typing i:nth-child(3){animation-delay:.3s}
@keyframes tp{0%,80%,100%{opacity:.25;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}
.gchat-bar{flex:0 0 auto;padding:10px 20px 18px;background:linear-gradient(to top,#fff 72%,rgba(255,255,255,0))}
.gchat-inputwrap{max-width:760px;margin:0 auto;display:flex;align-items:flex-end;gap:8px;background:var(--card);
  border:1px solid var(--line-2);border-radius:26px;padding:7px 7px 7px 20px;box-shadow:0 4px 24px -10px rgba(16,24,60,.18);transition:.15s}
.gchat-inputwrap:focus-within{border-color:var(--blue);box-shadow:0 6px 30px -8px rgba(27,61,245,.30)}
.gchat-inputwrap textarea{flex:1;border:0;outline:0;resize:none;font:inherit;font-size:1.02rem;line-height:1.5;background:transparent;color:var(--ink);max-height:180px;padding:9px 0}
.gchat-send{flex:0 0 auto;width:40px;height:40px;border:0;border-radius:50%;cursor:pointer;color:#fff;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1b3df5,#6a3df5);transition:.15s}
.gchat-send:hover{transform:scale(1.06);box-shadow:0 6px 18px -6px rgba(27,61,245,.5)}
.gchat-foot{max-width:760px;margin:9px auto 0;text-align:center;font-size:.76rem;color:var(--faint)}
.msg.bot .bubble table{border-collapse:collapse;width:100%;font-size:.88rem;margin:.7em 0;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.msg.bot .bubble th,.msg.bot .bubble td{border:1px solid var(--line);padding:7px 11px;text-align:left;vertical-align:top}
.msg.bot .bubble th{background:var(--bg-3);font-weight:600}
.msg.bot .bubble hr{border:0;border-top:1px solid var(--line);margin:1.1em 0}
.msg.bot .bubble a{color:var(--blue);text-decoration:underline}

/* hero d'accueil — la plateforme « La part du citoyen » */
.hero{text-align:center;max-width:760px;margin:38px auto 30px;padding:0 4px}
/* splash (accueil sans menu) : contenu remonté tout en haut, plus grand, plus large */
body.splash main{padding-top:0}
body.splash .hero{margin:28px auto 26px;max-width:920px}
body.splash .hero-sub{font-size:clamp(1.12rem,1.7vw,1.4rem);line-height:1.55;max-width:66ch;color:var(--ink-2)}
body.splash .section{padding:36px 0}
body.splash .head.wide{max-width:none;margin-bottom:22px}
body.splash .head.wide h2{font-size:clamp(1.7rem,3.2vw,2.45rem);letter-spacing:-.03em;line-height:1.08}
body.splash .steps{gap:20px}
body.splash .step{padding:28px 30px 26px}
body.splash .step-no{width:36px;height:36px;font-size:1.1rem;border-radius:11px;margin-bottom:13px}
body.splash .step h3{font-size:1.28rem;margin-bottom:.45em}
body.splash .step p{font-size:1.07rem;line-height:1.62;color:var(--ink-2)}
.head.wide{max-width:none}
.hero-title{font-size:clamp(2.3rem,6vw,3.4rem);line-height:1.04;letter-spacing:-.035em;margin:.18em 0 .12em}
.hero-base{font-size:clamp(1.05rem,2.4vw,1.32rem);color:var(--blue);font-weight:500;margin:.2em auto .7em;max-width:34ch;line-height:1.32}
.hero-sub{color:var(--muted);font-size:1.02rem;line-height:1.6;max-width:62ch;margin:0 auto}
.hero-doss{display:inline-flex;align-items:center;gap:10px;margin:22px 0 0;padding:8px 16px 8px 12px;
  background:var(--card);border:1px solid var(--line);border-radius:999px;font-weight:600;font-size:.98rem}
.hero-doss .kick{margin:0;color:var(--blue)}
.hero-cta{display:inline-block;margin-top:24px;background:var(--blue);color:#fff;font-weight:600;
  padding:.72em 1.5em;border-radius:11px;text-decoration:none;box-shadow:var(--shadow-sm);transition:.14s}
.hero-cta:hover{background:#1530d8;transform:translateY(-1px)}
@media(max-width:600px){.hero{margin-top:22px}.hero-doss{flex-direction:column;gap:3px;border-radius:14px}}

/* la démarche (3 étapes) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:6px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 22px 20px}
.step-no{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;
  background:var(--blue-soft);color:var(--blue);font-family:var(--mono);font-weight:600;font-size:.95rem;margin-bottom:11px}
.step h3{margin:.1em 0 .35em;font-size:1.08rem;letter-spacing:-.01em}
.step p{color:var(--muted);font-size:.96rem;line-height:1.55;margin:0}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* vitrine des analyses (dossiers) */
.doss-list{display:grid;grid-template-columns:1.55fr 1fr;gap:16px}
@media(max-width:760px){.doss-list{grid-template-columns:1fr}}
.doss-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:26px 28px;color:var(--ink);text-decoration:none;transition:.15s}
.doss-card .kick{display:block;margin-bottom:4px}
.doss-card h3{margin:.25em 0 .25em;font-size:clamp(1.3rem,2.4vw,1.62rem);letter-spacing:-.025em;line-height:1.12}
.doss-card p{color:var(--muted);line-height:1.55;margin:.2em 0 0;max-width:56ch}
.doss-card.feat{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.doss-card.feat:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px)}
.doss-card.feat:hover h3{color:var(--blue)}
.dc-kpis{display:flex;flex-wrap:wrap;gap:18px 22px;margin:18px 0 2px}
.dc-kpis span{font-size:.85rem;color:var(--muted)}
.dc-kpis b{font-size:1.18rem;color:var(--ink);font-weight:650;letter-spacing:-.02em;margin-right:.28em}
.dc-go{display:inline-block;margin-top:15px;color:var(--blue);font-weight:600}
.doss-card.soon{background:var(--bg-3);border-style:dashed}
.doss-card.soon h3{color:var(--ink-2)}
.doss-card.soon .kick{color:var(--muted)}

/* note « pourquoi / par qui » */
.ia-note{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 24px;margin:6px 0 0}
.ia-note p{margin:0;color:var(--ink-2);line-height:1.65;font-size:.98rem}
.ia-note b{color:var(--ink)}

/* hero d'accueil = le dossier (souveraineté énergétique) */
.comm-hero{max-width:760px;margin:26px 0 20px}
.comm-hero h1{font-size:clamp(2.1rem,4.8vw,3rem);letter-spacing:-.035em;line-height:1.05;margin:.16em 0 .3em}
.baselines{margin:16px 0 2px}
.baselines p{font-size:clamp(1.12rem,1.9vw,1.4rem);line-height:1.45;color:var(--ink-2);margin:.5em 0;max-width:62ch}
.baselines b{color:var(--ink)}
.baselines p:last-child{color:var(--blue);font-weight:500}
.baselines p:last-child b{color:var(--blue)}

/* enjeux + sources (2 colonnes) */
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:34px}
@media(max-width:760px){.cols2{grid-template-columns:1fr;gap:26px}}
.col h2{font-size:1.32rem;margin:.3em 0 .55em;letter-spacing:-.02em}
.vlist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.vlist li{position:relative;padding-left:20px;color:var(--ink-2);line-height:1.5;font-size:.97rem}
.vlist li::before{content:"";position:absolute;left:2px;top:.58em;width:7px;height:7px;border-radius:50%;background:var(--blue);opacity:.5}
.vlist b{color:var(--ink)}

/* références d'audition cliquables : nom de l'audité, lien vers l'audition (vidéo + verbatim) */
.ref{color:var(--blue);font-weight:500;text-decoration:none;background:var(--blue-soft);
  padding:.02em .34em;border-radius:5px;box-decoration-break:clone;-webkit-box-decoration-break:clone;
  transition:.13s}
.ref::before{content:"▸";font-size:.7em;opacity:.6;margin-right:.18em;vertical-align:.06em}
.ref:hover{background:var(--blue);color:#fff}
.ref:hover::before{opacity:.85}

/* frise chronologique des auditions */
.frise{position:relative;max-width:780px;margin:28px 0 8px}
.frise::before{content:"";position:absolute;left:118px;top:8px;bottom:8px;width:2px;background:var(--line);border-radius:2px}
.frise-month{position:relative;font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.09em;
  color:var(--blue);font-weight:600;margin:30px 0 6px;padding-left:148px}
.frise-month:first-child{margin-top:6px}
.frise-item{position:relative;display:block;padding:7px 0 7px 148px;color:var(--ink);text-decoration:none}
.frise-date{position:absolute;left:0;width:100px;text-align:right;top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-size:.78rem;color:var(--muted)}
.frise-dot{position:absolute;left:112px;top:50%;transform:translateY(-50%);width:13px;height:13px;border-radius:50%;
  background:#fff;border:2px solid var(--line-3);z-index:1;transition:.14s}
.frise-item:hover .frise-dot{border-color:var(--blue);background:var(--blue)}
.frise-card{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:9px 15px 9px 9px;font-size:.96rem;line-height:1.3;transition:.14s}
.frise-nom{min-width:0}
.avatar.frise-av{width:36px;height:36px}
.avatar-ph.frise-av{font-size:.82rem}
.frise-item:hover .frise-card{border-color:var(--blue);box-shadow:var(--shadow-sm);transform:translateX(2px);color:var(--blue)}
@media(max-width:620px){
  .frise::before{left:7px}
  .frise-month{padding-left:30px}
  .frise-item{padding:6px 0 6px 30px}
  .frise-date{position:static;display:block;width:auto;text-align:left;transform:none;margin:0 0 3px;
    font-size:.72rem;color:var(--blue)}
  .frise-dot{left:1px;top:30px}
}

/* ============================================================
   LE DOSSIER CITOYEN — scrollytelling (pièces du rapport)
   ============================================================ */
/* bannière d'accueil */
.dossier-banner{display:block;background:linear-gradient(135deg,var(--blue),#3346ec 55%,#5a3df5);color:#fff;
  border-radius:var(--r-lg);padding:30px 34px;margin:30px 0 8px;box-shadow:var(--shadow);transition:.16s;position:relative;overflow:hidden}
.dossier-banner::after{content:"";position:absolute;right:-50px;bottom:-80px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);pointer-events:none}
.dossier-banner:hover{transform:translateY(-2px);box-shadow:0 24px 64px -18px rgba(27,61,245,.5)}
.db-txt{position:relative;z-index:1;max-width:700px}
.dossier-banner .kick{color:#cdd6ff}
.dossier-banner h2{color:#fff;margin:.25em 0 .2em;font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:-.025em}
.dossier-banner p{color:rgba(255,255,255,.88);margin:.3em 0 0;max-width:62ch}
.db-go{display:inline-block;margin-top:16px;font-weight:650;background:#fff;color:var(--blue);padding:.55em 1.15em;border-radius:10px;font-size:.95rem}

/* index du dossier */
.dossier-hero{max-width:var(--maxw-read);margin:4px 0 22px}
.dossier-hero h1{font-size:clamp(2.1rem,5vw,3rem);margin:.1em 0 .3em}
.dossier-claim{font-size:1.02rem;color:var(--ink-2);border-left:3px solid var(--blue);padding-left:14px;margin-top:16px}
.dossier-claim b{color:var(--ink)}
.dossier-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin:8px 0 26px}
.dpiece{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:20px 22px;box-shadow:var(--shadow-sm);transition:.15s}
.dpiece:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px)}
.dp-no{font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);font-weight:600}
.dpiece h3{margin:.4em 0 .35em;font-size:1.12rem;line-height:1.2;color:var(--ink)}
.dpiece:hover h3{color:var(--blue)}
.dpiece p{font-size:.9rem;color:var(--ink-2);line-height:1.5;margin:0 0 .9em;flex:1}
.dp-go{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.dpiece:hover .dp-go{color:var(--blue)}

/* page d'une pièce — colonne de lecture centrée */
.piece-head,.doc.piece,.piece-ask,.piece-nav{max-width:800px;margin-left:auto;margin-right:auto}
.piece-head{margin-top:2px;margin-bottom:4px}
.piece-title{font-size:clamp(1.9rem,4vw,2.7rem);line-height:1.06;margin:.12em 0 .2em;letter-spacing:-.03em}
.doc.piece{margin-top:14px;margin-bottom:26px;padding:40px 48px;font-size:1.06rem;line-height:1.72}
.doc.piece>*{max-width:none}
.doc.piece h2{font-size:1.45rem;margin:1.7em 0 .45em;letter-spacing:-.02em;color:var(--ink)}
.doc.piece p{color:var(--ink);margin:.95em 0}

/* accroche (hook) */
.doc.piece blockquote.hook{border-left:0;background:var(--blue-soft);border-radius:var(--r);padding:20px 24px;margin:2px 0 24px}
.doc.piece blockquote.hook p{font-size:1.18rem;line-height:1.42;font-weight:600;color:var(--blue-ink);margin:0;letter-spacing:-.01em}

/* pièce dépliable (citation verbatim sourcée) */
.doc.piece blockquote.piece{border-left:3px solid var(--blue);background:var(--bg-2);border-radius:0 var(--r) var(--r) 0;
  padding:15px 22px;margin:1.3em 0}
.doc.piece blockquote.piece p{margin:.2em 0;color:var(--ink)}
.doc.piece blockquote.piece p:first-child{font-size:1.04em;line-height:1.5}
.doc.piece blockquote.piece p:last-child{font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-top:.55em;line-height:1.4}
.doc.piece blockquote.piece strong{font-weight:600;color:var(--ink)}

/* encarts comparaison / sortie */
.enc{border:1px solid var(--line-2);border-radius:var(--r);padding:18px 22px;margin:1.7em 0;background:var(--bg-2)}
.enc .enc-lbl{display:inline-block;font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-bottom:9px}
.enc p{margin:.5em 0}
.enc-cmp{background:var(--blue-soft);border-color:#cdd6ff}
.enc-cmp .enc-lbl,.enc-cmp strong{color:var(--blue-ink)}
.enc-out{background:#fbfbf6;border-color:var(--line-2);border-left:3px solid var(--ink)}
.enc-out .enc-lbl{color:var(--ink)}

/* badges fait/disputé */
.badge{display:inline-block;font-family:var(--mono);font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  padding:.2em .55em;border-radius:5px;vertical-align:.1em;margin-right:.35em}
.b-etabli{background:#e7f6ec;color:#1a7f37}
.b-dispute{background:var(--red-soft);color:#c0271f}

/* micro-fiche acteur (appositif) */
.who{color:var(--muted);font-size:.93em}

/* appel à l'agent en bas de pièce */
.piece-ask{display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;
  background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:24px 28px;margin-top:28px;margin-bottom:6px}
.piece-ask .kick{color:#9db0ff}
.piece-ask p{color:rgba(255,255,255,.82);margin:.4em 0 0;max-width:46ch;font-size:.96rem}
.piece-ask .askbtn{margin-top:0;white-space:nowrap}

/* navigation pièce précédente / suivante */
.piece-nav{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}
.pnav{display:flex;flex-direction:column;gap:3px;border:1px solid var(--line);border-radius:var(--r);padding:14px 18px;
  background:var(--card);box-shadow:var(--shadow-sm);transition:.15s}
.pnav:hover{border-color:var(--blue);box-shadow:var(--shadow)}
.pnav span{font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.pnav b{font-weight:600;color:var(--ink);font-size:.96rem;line-height:1.25}
.pnav:hover b{color:var(--blue)}
.pnav.next{text-align:right;align-items:flex-end}
@media(max-width:680px){
  .doc.piece{padding:26px 22px;font-size:1.02rem}
  .piece-ask{flex-direction:column;align-items:flex-start}
  .piece-nav{grid-template-columns:1fr}
  .pnav.next{text-align:left;align-items:flex-start}
}

/* avatars dans les auditions : puces d'intervenants (fiche d'audition) */
.aud-persons{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 4px}
.aud-person{display:inline-flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);
  border-radius:999px;padding:4px 15px 4px 4px;font-size:.92rem;color:var(--ink);box-shadow:var(--shadow-sm);transition:.14s}
a.aud-person:hover{border-color:var(--blue);color:var(--blue)}
.aud-av.avatar{width:32px;height:32px}
.aud-av.avatar-ph{font-size:.76rem}
