/* ============================================================
   GENSHI v4 — modules additionnels (par-dessus genshi-v3.css)
   Thème clair · atome 3D · « la pile » · workflow automatisation
   ============================================================ */

/* hero : le canvas 3D occupe tout le hero (réutilise .v3hero/.veil de v3) */
.v3hero .gcanvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; display:block; }

/* ============ LA PILE GENSHI (deux couches) ============ */
.stack{ display:flex; flex-direction:column; gap:16px; margin-top:clamp(36px,5vw,56px); }
.layer{ position:relative; border:1px solid var(--line); border-radius:20px; background:var(--bg-2);
  padding:clamp(26px,3.2vw,40px); display:grid; grid-template-columns:200px 1fr; gap:clamp(22px,3vw,48px);
  align-items:center; overflow:hidden; transition:transform .5s var(--ease-out), box-shadow .5s; }
@media (max-width:780px){ .layer{ grid-template-columns:1fr; gap:18px; } }
.layer:hover{ transform:translateY(-3px); box-shadow:0 24px 50px -28px rgba(20,20,20,.35); }
.layer-side{ display:flex; flex-direction:column; gap:8px; }
.layer-side .lk{ font-family:var(--f-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); }
.layer-side .lt{ font-family:var(--f-display); font-weight:600; font-size:clamp(22px,2.4vw,30px); letter-spacing:-.02em; }
.layer-main h3{ font-size:clamp(19px,1.9vw,24px); }
.layer-main p{ color:var(--dim); margin-top:10px; font-size:15px; max-width:60ch; }
.layer-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.lchip{ font-family:var(--f-mono); font-size:12px; color:var(--dim); border:1px solid var(--line); border-radius:100px; padding:6px 13px; }
.layer--engine{ border-color:color-mix(in srgb,var(--accent) 55%, var(--line)); background:color-mix(in srgb,var(--accent) 7%, var(--bg-2)); }
.layer--engine .lt{ color:var(--accent); }
/* couche présence en ocre — duo chromatique avec le moteur indigo */
.layer:not(.layer--engine){ border-color:color-mix(in srgb,var(--accent2) 40%, var(--line)); background:color-mix(in srgb,var(--accent2) 5%, var(--bg-2)); }
.layer:not(.layer--engine) .lt{ color:var(--accent2); }
.layer:not(.layer--engine) .lchip{ border-color:color-mix(in srgb,var(--accent2) 30%, var(--line)); }
.layer--engine .lchip{ border-color:color-mix(in srgb,var(--accent) 35%, var(--line)); color:var(--fg); }
.lbadge{ display:inline-flex; align-items:center; gap:7px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent-ink); background:var(--accent2); border-radius:100px; padding:4px 11px; width:max-content; }
.layer-main .lhead{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }

/* ============ WORKFLOW AUTOMATISATION ============ */
.flow{ display:flex; align-items:stretch; gap:0; margin-top:clamp(34px,4vw,52px); }
@media (max-width:820px){ .flow{ flex-direction:column; } }
.flow-node{ flex:1; min-width:0; border:1px solid var(--line); border-radius:16px; background:var(--bg-2);
  padding:20px 18px; display:flex; flex-direction:column; gap:9px; position:relative;
  transition:border-color .45s var(--ease), box-shadow .45s, transform .45s var(--ease); }
.flow-node.active{ border-color:var(--accent); box-shadow:0 14px 36px -16px var(--glow); transform:translateY(-4px); }
.flow-node .fn-ic{ width:30px; height:30px; border-radius:9px; display:grid; place-items:center; background:var(--bg-3); color:var(--dim); transition:background .45s, color .45s; }
.flow-node.active .fn-ic{ background:var(--accent); color:var(--accent-ink); }
.flow-node .fn-ic svg{ width:17px; height:17px; }
.flow-node .fn-t{ font-family:var(--f-display); font-weight:600; font-size:15px; }
.flow-node .fn-d{ color:var(--dim); font-size:12.5px; line-height:1.45; }
.flow-arrow{ flex:0 0 30px; display:grid; place-items:center; color:var(--dim-2); }
.flow-arrow svg{ width:18px; height:18px; transition:color .4s; }
.flow-arrow.lit{ color:var(--accent); }
@media (max-width:820px){ .flow-arrow{ height:26px; } .flow-arrow svg{ transform:rotate(90deg); } }

.auto-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:18px; }
@media (max-width:820px){ .auto-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .auto-grid{ grid-template-columns:1fr; } }
.auto-card{ border:1px solid var(--line); border-radius:14px; background:var(--bg-2); padding:18px; display:flex; gap:13px; align-items:flex-start; }
.auto-card .ico{ width:22px; height:22px; color:var(--accent); flex:none; margin-top:2px; }
.auto-card h4{ font-family:var(--f-display); font-weight:600; font-size:14.5px; }
.auto-card p{ color:var(--dim); font-size:12.5px; margin-top:4px; line-height:1.45; }

/* bandeau gain de temps */
.flow-note{ margin-top:22px; display:flex; gap:14px; align-items:center; padding:18px 22px; border-radius:14px;
  border:1px solid color-mix(in srgb,var(--accent) 40%, var(--line)); background:color-mix(in srgb,var(--accent) 6%, transparent); }
.flow-note .ico{ width:24px; height:24px; color:var(--accent); flex:none; }
.flow-note p{ font-size:15px; } .flow-note b{ color:var(--accent); }

/* ============================================================
   GABARIT PAGE SERVICE (langage v4)
   ============================================================ */
.crumb{ padding:104px var(--pad) 0; max-width:var(--maxw); margin-inline:auto; }
.crumb .row{ display:flex; gap:9px; align-items:center; font-family:var(--f-mono); font-size:12px; color:var(--dim-2); flex-wrap:wrap; }
.crumb a{ color:var(--dim); } .crumb a:hover{ color:var(--accent); }
.crumb .sep{ opacity:.5; } .crumb [aria-current]{ color:var(--fg); }

.phero{ padding:32px var(--pad) clamp(40px,6vh,72px); max-width:var(--maxw); margin-inline:auto; position:relative; }
.phero-grid{ display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(32px,5vw,72px); align-items:center; }
@media (max-width:860px){ .phero-grid{ grid-template-columns:1fr; } }
.phero h1{ font-family:var(--f-display); font-weight:600; font-size:clamp(38px,5.4vw,72px); letter-spacing:-.03em; line-height:1.03; margin-top:18px; }
.phero h1 .accent{ color:var(--accent); }
.phero .lead{ color:var(--dim); font-size:clamp(17px,1.5vw,20px); margin-top:22px; max-width:54ch; }
.phero-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.phero-side{ display:flex; flex-direction:column; }
.spec{ display:flex; justify-content:space-between; gap:16px; padding:15px 0; border-bottom:1px solid var(--line); font-family:var(--f-mono); font-size:13px; }
.spec:first-child{ border-top:1px solid var(--line); }
.spec .v{ color:var(--accent); white-space:nowrap; }

/* cas d'usage / offres */
.offers{ border-top:1px solid var(--line); margin-top:clamp(34px,4vw,50px); }
.offer{ display:grid; grid-template-columns:auto 1fr auto; gap:clamp(18px,3vw,44px); padding:clamp(24px,3vw,34px) 0; border-bottom:1px solid var(--line); align-items:start; }
.offer-ix{ font-family:var(--f-mono); font-size:13px; color:var(--accent2); padding-top:5px; }
.offer-main h3{ font-family:var(--f-display); font-weight:600; font-size:clamp(19px,1.9vw,24px); }
.offer-main p{ color:var(--dim); font-size:15px; margin-top:10px; max-width:62ch; }
.offer-tags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:14px; }
.otag{ font-family:var(--f-mono); font-size:11.5px; color:var(--dim); border:1px solid var(--line); border-radius:100px; padding:5px 11px; }
.offer-price{ text-align:right; display:flex; flex-direction:column; gap:6px; align-items:flex-end; min-width:130px; }
.offer-price .from{ font-family:var(--f-mono); font-size:12px; color:var(--dim-2); }
.offer-price .amt{ font-family:var(--f-display); font-size:clamp(19px,2.1vw,26px); font-weight:600; }
.offer-price .amt b{ color:var(--accent); }
@media (max-width:680px){ .offer{ grid-template-columns:auto 1fr; } .offer-price{ grid-column:2; align-items:flex-start; text-align:left; margin-top:4px; } }

/* FAQ */
.faq{ border-top:1px solid var(--line); margin-top:clamp(30px,4vw,46px); }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{ list-style:none; cursor:pointer; padding:22px 0; display:flex; align-items:center; justify-content:space-between; gap:24px; font-family:var(--f-display); font-weight:600; font-size:clamp(17px,1.6vw,20px); color:var(--fg); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ position:relative; width:18px; height:18px; flex:none; }
.faq summary .pm::before,.faq summary .pm::after{ content:""; position:absolute; background:var(--accent); border-radius:2px; transition:transform .3s var(--ease); }
.faq summary .pm::before{ inset:8px 0; height:2px; } .faq summary .pm::after{ inset:0 8px; width:2px; }
.faq details[open] summary .pm::after{ transform:scaleY(0); }
.faq-a{ padding:0 0 24px; color:var(--dim); font-size:15.5px; line-height:1.65; max-width:74ch; }
.faq-a a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; }

/* cross-sell */
.xgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:clamp(30px,4vw,44px); }
@media (max-width:820px){ .xgrid{ grid-template-columns:1fr; } }
.xcard{ border:1px solid var(--line); border-radius:14px; background:var(--bg-2); padding:22px; display:flex; flex-direction:column; gap:11px; transition:transform .4s var(--ease-out), box-shadow .4s; }
.xcard:hover{ transform:translateY(-4px); box-shadow:0 22px 44px -26px rgba(20,20,20,.4); }
.xcard .ico{ width:24px; height:24px; color:var(--accent); }
.xcard h3{ font-family:var(--f-display); font-weight:600; font-size:18px; }
.xcard p{ color:var(--dim); font-size:14px; }
.xcard .lk{ font-family:var(--f-mono); font-size:12.5px; color:var(--accent); margin-top:auto; }

/* CTA band */
.cta-band{ background:var(--bg-3); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cta-band .sec{ display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.cta-band h2{ font-family:var(--f-display); font-weight:600; font-size:clamp(28px,4vw,48px); letter-spacing:-.025em; max-width:18ch; }
.cta-band p{ color:var(--dim); margin-top:12px; max-width:46ch; }

/* ============================================================
   PREUVE SOCIALE
   ============================================================ */
.proof-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:clamp(34px,4vw,52px); }
@media (max-width:820px){ .proof-grid{ grid-template-columns:1fr; } }
.proof-card{ border:1px solid var(--line); border-radius:18px; background:var(--bg-2); padding:clamp(24px,2.8vw,32px); display:flex; flex-direction:column; gap:14px; }
.proof-metric{ font-family:var(--f-display); font-weight:600; font-size:clamp(30px,3.6vw,44px); letter-spacing:-.02em; color:var(--accent); line-height:1; }
.proof-metric .u{ font-size:.45em; color:var(--dim); font-weight:500; letter-spacing:0; }
.proof-quote{ font-size:15px; color:var(--dim); line-height:1.6; }
.proof-quote::before{ content:"« "; color:var(--accent2); }
.proof-quote::after{ content:" »"; color:var(--accent2); }
.proof-who{ margin-top:auto; padding-top:14px; border-top:1px solid var(--line-2); font-family:var(--f-mono); font-size:12px; color:var(--dim-2); }
.proof-who b{ color:var(--accent2); font-weight:500; display:block; margin-bottom:2px; font-size:12.5px; }
.proof-note{ margin-top:18px; font-family:var(--f-mono); font-size:11.5px; color:var(--dim-2); }

/* ============================================================
   FORMULAIRE COMPLET (clair)
   ============================================================ */
.gform{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:30px; max-width:780px; }
@media (max-width:640px){ .gform{ grid-template-columns:1fr; } }
.gfield{ display:flex; flex-direction:column; gap:7px; }
.gfield.full{ grid-column:1 / -1; }
.gfield label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--dim); }
.gfield label .req{ color:var(--accent); }
.gfield input, .gfield select, .gfield textarea{
  background:var(--bg-2); border:1px solid var(--line); border-radius:12px; color:var(--fg);
  font-family:var(--f-body); font-size:15.5px; padding:13px 16px; outline:none; transition:border-color .25s, box-shadow .25s; width:100%;
}
.gfield textarea{ resize:vertical; min-height:96px; }
.gfield input:focus, .gfield select:focus, .gfield textarea:focus{ border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 14%, transparent); }
.gfield.invalid input, .gfield.invalid textarea{ border-color:var(--accent); }
.gfield .err{ display:none; font-family:var(--f-mono); font-size:11px; color:var(--accent); }
.gfield.invalid .err{ display:block; }
.gform .btn{ grid-column:1 / -1; justify-self:start; margin-top:4px; }
.gform-ok{ display:none; grid-column:1 / -1; align-items:center; gap:12px; padding:18px 20px; border:1px solid color-mix(in srgb,var(--accent) 40%, var(--line)); background:color-mix(in srgb,var(--accent) 7%, transparent); border-radius:14px; font-size:15px; }
.gform-ok svg{ width:22px; height:22px; color:var(--accent); flex:none; }
.gform.sent .gfield, .gform.sent .btn{ display:none; }
.gform.sent .gform-ok{ display:flex; }

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:clamp(34px,4vw,52px); }
@media (max-width:820px){ .blog-grid{ grid-template-columns:1fr; } }
.bcard{ border:1px solid var(--line); border-radius:18px; background:var(--bg-2); overflow:hidden; display:flex; flex-direction:column; transition:transform .4s var(--ease-out), box-shadow .4s; }
a.bcard:hover{ transform:translateY(-4px); box-shadow:0 24px 48px -28px rgba(20,20,20,.4); }
.bimg{ aspect-ratio:16/9; display:grid; place-items:center; background:linear-gradient(135deg, color-mix(in srgb,var(--accent) 14%, var(--bg-3)), color-mix(in srgb,var(--accent2) 16%, var(--bg-3))); border-bottom:1px solid var(--line); }
.bimg span{ font-family:var(--f-display); font-weight:700; font-size:clamp(28px,3vw,40px); color:var(--accent); letter-spacing:-.02em; }
.bbody{ padding:22px; display:flex; flex-direction:column; gap:11px; flex:1; }
.bcat{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent2); }
.bcard h3{ font-family:var(--f-display); font-weight:600; font-size:19px; line-height:1.25; }
.bcard p{ color:var(--dim); font-size:14px; line-height:1.55; }
.bmeta{ margin-top:auto; padding-top:12px; font-family:var(--f-mono); font-size:11.5px; color:var(--dim-2); display:flex; justify-content:space-between; gap:10px; }
.bmeta .lk{ color:var(--accent); }
.bcard.soon{ opacity:.62; }
.bcard.soon .bimg span{ color:var(--dim-2); }
.bsoon{ font-family:var(--f-mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-ink); background:var(--accent2); border-radius:100px; padding:3px 9px; width:max-content; }

/* ============================================================
   ARTICLE
   ============================================================ */
.article{ max-width:1080px; }
.art-body{ max-width:76ch; }
.article .art-meta, .phero .art-meta{ display:flex; gap:18px; flex-wrap:wrap; font-family:var(--f-mono); font-size:12px; color:var(--dim-2); margin-top:20px; }
.article h1{ font-family:var(--f-display); font-weight:600; font-size:clamp(32px,4.6vw,54px); letter-spacing:-.03em; line-height:1.06; margin-top:18px; }
.art-body{ margin-top:clamp(30px,4vw,44px); }
.art-body h2{ font-size:clamp(22px,2.4vw,30px); margin:1.8em 0 .6em; }
.art-body h3{ font-size:clamp(17px,1.8vw,21px); margin:1.5em 0 .5em; }
.art-body p{ color:var(--dim); line-height:1.75; margin:0 0 1.1em; font-size:16px; }
.art-body strong{ color:var(--fg); }
.art-body ul{ color:var(--dim); line-height:1.7; margin:0 0 1.2em; padding-left:1.2em; }
.art-body li{ margin-bottom:.45em; }
.art-body li::marker{ color:var(--accent2); }
.art-body blockquote{ margin:1.6em 0; padding:18px 22px; border-left:3px solid var(--accent2); background:var(--bg-2); border-radius:0 14px 14px 0; color:var(--fg); font-size:16.5px; }
.art-body a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; }
.art-cta{ margin-top:clamp(36px,5vw,56px); border:1px solid color-mix(in srgb,var(--accent) 40%, var(--line)); background:color-mix(in srgb,var(--accent) 6%, transparent); border-radius:18px; padding:clamp(24px,3vw,36px); display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.art-cta h3{ font-size:clamp(19px,2vw,24px); max-width:24ch; }
.art-cta p{ color:var(--dim); font-size:14.5px; margin-top:8px; max-width:44ch; }

/* ---- modules visuels d'article ---- */
.art-pull{ position:relative; margin:clamp(36px,5vw,56px) 0; padding:clamp(26px,3.4vw,42px) clamp(24px,3vw,40px) clamp(26px,3.4vw,42px) clamp(30px,4vw,52px); border:1px solid var(--line); border-radius:20px; background:var(--bg-2); overflow:hidden; }
.art-pull::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:linear-gradient(var(--accent), var(--accent2)); }
.art-pull .enso-bg{ position:absolute; right:-30px; bottom:-46px; width:170px; height:170px; opacity:.08; pointer-events:none; }
.art-pull p{ font-family:var(--f-display); font-weight:600; font-size:clamp(19px,2.2vw,26px); line-height:1.35; letter-spacing:-.015em; color:var(--fg); max-width:34ch; position:relative; }
.art-pull .who{ display:block; margin-top:14px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent2); }

.pillars{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:clamp(26px,3vw,38px) 0; }
@media (max-width:680px){ .pillars{ grid-template-columns:1fr; } }
.pillar{ border:1px solid var(--line); border-radius:16px; background:var(--bg-2); padding:clamp(20px,2.4vw,28px); display:flex; flex-direction:column; gap:10px; }
.pillar .pn{ font-family:var(--f-mono); font-size:12px; color:var(--accent2); letter-spacing:.1em; }
.pillar h3{ font-size:clamp(16.5px,1.7vw,19px); margin:0; }
.pillar p{ color:var(--dim); font-size:14px; line-height:1.6; margin:0; }

.ex-pair{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:clamp(26px,3vw,38px) 0; }
@media (max-width:680px){ .ex-pair{ grid-template-columns:1fr; } }
.ex{ border-radius:16px; padding:20px 22px; font-size:15px; line-height:1.55; position:relative; }
.ex .xk{ display:flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; margin-bottom:10px; }
.ex .xk i{ width:18px; height:18px; border-radius:50%; display:grid; place-items:center; font-style:normal; font-size:11px; }
.ex--good{ border:1px solid color-mix(in srgb,var(--accent) 45%, var(--line)); background:color-mix(in srgb,var(--accent) 7%, transparent); }
.ex--good .xk{ color:var(--accent); } .ex--good .xk i{ background:var(--accent); color:#fff; }
.ex--bad{ border:1px dashed var(--line); background:var(--bg-2); color:var(--dim); }
.ex--bad .xk{ color:var(--dim-2); } .ex--bad .xk i{ background:var(--bg-3); color:var(--dim-2); }
.ex q{ quotes:"« " " »"; }

.art-steps{ margin:clamp(26px,3vw,38px) 0; }

/* ---- 13 · bandeau de chiffres-clés ---- */
.statband{ display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--line); border-radius:18px; background:var(--bg-2); overflow:hidden; }
@media (max-width:680px){ .statband{ grid-template-columns:1fr; } }
.statband .stat{ padding:clamp(22px,2.6vw,32px); border-left:1px solid var(--line); display:flex; flex-direction:column; gap:6px; }
.statband .stat:first-child{ border-left:0; }
@media (max-width:680px){ .statband .stat{ border-left:0; border-top:1px solid var(--line); } .statband .stat:first-child{ border-top:0; } }
.statband .sv{ font-family:var(--f-display); font-weight:600; font-size:clamp(28px,3.2vw,40px); letter-spacing:-.02em; color:var(--accent); line-height:1; }
.statband .stat:nth-child(2) .sv{ color:var(--accent2); }
.statband .sl{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--dim); }
.statband .ss{ font-size:13px; color:var(--dim-2); }

/* ---- 14 · timeline ---- */
.gtimeline{ position:relative; padding-left:26px; display:flex; flex-direction:column; gap:clamp(18px,2.4vw,26px); }
.gtimeline::before{ content:""; position:absolute; left:7px; top:8px; bottom:8px; width:2px; background:linear-gradient(var(--accent), var(--accent2)); border-radius:2px; }
.gt-item{ position:relative; }
.gt-item::before{ content:""; position:absolute; left:-26px; top:5px; width:16px; height:16px; border-radius:50%; background:var(--bg); border:3px solid var(--accent); }
.gt-item:nth-child(even)::before{ border-color:var(--accent2); }
.gt-item .gtd{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent2); }
.gt-item h3{ font-size:clamp(16.5px,1.7vw,19px); margin:4px 0 0; }
.gt-item p{ color:var(--dim); font-size:14.5px; line-height:1.6; margin:6px 0 0; max-width:64ch; }

/* ---- 15 · tableau comparatif ---- */
.cmp{ border:1px solid var(--line); border-radius:18px; overflow:hidden; background:var(--bg-2); }
.cmp-row{ display:grid; grid-template-columns:1.1fr 1fr 1fr; border-top:1px solid var(--line-2); }
.cmp-row:first-child{ border-top:0; }
.cmp-row > div{ padding:14px 18px; font-size:14.5px; border-left:1px solid var(--line-2); }
.cmp-row > div:first-child{ border-left:0; color:var(--dim); font-family:var(--f-mono); font-size:12.5px; display:flex; align-items:center; }
.cmp-head > div{ font-family:var(--f-display); font-weight:600; font-size:15.5px; display:flex; align-items:center; gap:8px; }
.cmp-head .ca{ color:var(--accent2); background:color-mix(in srgb,var(--accent2) 8%, transparent); }
.cmp-head .cb{ color:var(--accent); background:color-mix(in srgb,var(--accent) 8%, transparent); }
.cmp .ok{ color:var(--accent); font-weight:600; }
.cmp .ok2{ color:var(--accent2); font-weight:600; }
.cmp .no{ color:var(--dim-2); }
@media (max-width:680px){ .cmp-row{ grid-template-columns:1fr; } .cmp-row > div{ border-left:0; border-top:1px dashed var(--line-2); } .cmp-row > div:first-child{ border-top:0; background:var(--bg-3); } }

/* ---- 16 · définition glossaire ---- */
.gdef{ position:relative; border:1px solid var(--line); border-radius:18px; background:var(--bg-2); padding:clamp(24px,3vw,36px); overflow:hidden; }
.gdef .kanji{ position:absolute; right:14px; top:-14px; font-size:120px; line-height:1; color:var(--line-2); font-weight:700; pointer-events:none; user-select:none; }
.gdef .gw{ display:flex; align-items:baseline; gap:12px; flex-wrap:wrap; position:relative; }
.gdef .gw h3{ font-size:clamp(24px,2.6vw,32px); margin:0; }
.gdef .gnat{ font-family:var(--f-mono); font-size:12px; color:var(--accent2); font-style:italic; }
.gdef .gph{ font-family:var(--f-mono); font-size:13px; color:var(--dim-2); }
.gdef .gd{ margin-top:14px; color:var(--dim); font-size:15.5px; line-height:1.65; max-width:66ch; position:relative; }
.gdef .gd b{ color:var(--fg); }
.gdef .gex{ margin-top:14px; padding-top:14px; border-top:1px dashed var(--line); font-size:14px; color:var(--dim-2); font-style:italic; position:relative; }
.gdef .gex::before{ content:"ex. "; font-family:var(--f-mono); font-style:normal; color:var(--accent2); }

/* ---- 17 · à retenir (TL;DR) ---- */
.tldr{ border:1.5px solid color-mix(in srgb,var(--accent2) 55%, var(--line)); border-radius:18px; padding:clamp(22px,2.8vw,32px); background:color-mix(in srgb,var(--accent2) 5%, transparent); }
.tldr .tk{ display:flex; align-items:center; gap:10px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent2); }
.tldr .tk svg{ width:18px; height:18px; }
.tldr ul{ list-style:none; margin:16px 0 0; padding:0; display:flex; flex-direction:column; gap:10px; }
.tldr li{ display:flex; gap:11px; font-size:15px; line-height:1.55; color:var(--fg); }
.tldr li::before{ content:""; width:8px; height:8px; border-radius:50%; border:2px solid var(--accent2); margin-top:7px; flex:none; }
.tldr li b{ color:var(--accent); }

/* ---- 18 · barres de données ---- */
.databars{ display:flex; flex-direction:column; gap:16px; }
.dbar .dl{ display:flex; justify-content:space-between; gap:14px; font-size:14px; margin-bottom:7px; }
.dbar .dl span:last-child{ font-family:var(--f-mono); font-size:12.5px; color:var(--accent2); }
.dbar .track{ height:10px; border-radius:100px; background:var(--bg-3); overflow:hidden; }
.dbar .fill{ height:100%; border-radius:100px; background:linear-gradient(90deg, var(--accent-deep), var(--accent)); width:var(--w,50%); }
.dbar.alt .fill{ background:linear-gradient(90deg, color-mix(in srgb,var(--accent2) 80%, #000 5%), var(--accent2)); }
.dbar.alt .dl span:last-child{ color:var(--accent); }
@media (prefers-reduced-motion: no-preference){
  .dbar .fill{ transform-origin:left; animation:dbargrow 1s var(--ease-out) both; }
}
@keyframes dbargrow{ from{ transform:scaleX(0); } }
.no-anim .dbar .fill{ animation:none !important; }

/* page courante du fil d'ariane en ocre */
.crumb span[aria-current]{ color:var(--accent2); }
