/* ============================================================
   IA pour le Retail — moteur de deck partagé · Metagora × RMS
   ============================================================ */
:root{
  --bg:#F8F8F6; --ink:#0A0A0F; --ink-soft:#4A4A55; --ink-faint:#8A8A95;
  --line:#E5E5E0; --line-strong:#1A1A1F;
  --accent:#00D4AA; --accent-soft:#E6FAF4; --accent-deep:#007D66;
  --alert:#FF6B6B; --alert-deep:#C73E3E; --alert-soft:#FFE8E8;
  --warm:#FFB94F; --warm-soft:#FFF4E0; --warm-deep:#B07000;
  --sig-yellow:#F2C200; --sig-orange:#FF7A3D; --sig-red:#FF5A5A;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono','SF Mono',Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:#08080B;color:var(--ink);font-family:var(--sans);
  overflow:hidden;-webkit-font-smoothing:antialiased}
body.idle{cursor:none}

/* ---------- STAGE ---------- */
#deckView{position:fixed;inset:0;background:#08080B;overflow:hidden}
.stage{position:absolute;top:50%;left:50%;width:1280px;height:720px;
  transform:translate(-50%,-50%) scale(1)}
.slide{position:absolute;inset:0;width:1280px;height:720px;background:var(--bg);
  opacity:0;transition:opacity .34s ease;padding:60px 84px;
  display:flex;flex-direction:column}
.slide.active{opacity:1;z-index:2}
.slide.dark{background:var(--ink);color:#fff}

.kicker{font:600 13px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-deep);display:flex;align-items:center;gap:12px;flex:none}
.kicker .k-sep{width:26px;height:1px;background:var(--accent);flex:none}
.slide.dark .kicker{color:var(--accent)}

h1.s-title{font-family:var(--serif);font-weight:800;letter-spacing:-.022em;
  line-height:1.04;font-size:49px;margin-top:16px;flex:none}
h2.s-title{font-family:var(--serif);font-weight:600;letter-spacing:-.018em;
  line-height:1.1;font-size:40px;margin-top:14px;flex:none}
.s-title em{font-style:italic;color:var(--accent-deep);font-weight:600}
.slide.dark .s-title em{color:var(--accent)}
.s-lead{font-size:19px;line-height:1.5;color:var(--ink-soft);max-width:840px;
  margin-top:13px;flex:none}
.slide.dark .s-lead{color:rgba(255,255,255,.72)}
.s-body{flex:1;display:flex;flex-direction:column;justify-content:center;min-height:0}

/* ---------- LAYOUT UTILITIES ---------- */
.grid{display:grid;gap:16px}
.g2{grid-template-columns:1fr 1fr}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.cols{display:grid;grid-template-columns:0.92fr 1.08fr;gap:36px;align-items:center}
.card{background:#fff;border:1px solid var(--line-strong);padding:22px;
  display:flex;flex-direction:column}
.slide.dark .card{background:#15151c;border-color:#2a2a33}

/* ---------- TITLE SLIDE ---------- */
.title-num{font-family:var(--serif);font-weight:800;font-size:142px;line-height:.9;
  letter-spacing:-.04em;color:var(--accent)}
.title-main{font-family:var(--serif);font-weight:800;font-size:60px;line-height:1.03;
  letter-spacing:-.025em;margin-top:6px;max-width:940px}
.title-main em{font-style:italic;color:var(--accent-deep);font-weight:600}
.phasestrip{display:flex;gap:10px;margin-top:32px}
.phase-chip{font:600 13px/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;
  padding:9px 15px;border:1px solid var(--line-strong);color:var(--ink-faint)}
.phase-chip.on{background:var(--accent);border-color:var(--accent);color:var(--ink);font-weight:700}
.phase-chip .pc-time{display:block;font-size:10px;letter-spacing:.08em;margin-top:3px;opacity:.7}
.title-foot{font:500 13px/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:auto}

/* ---------- CONCLUSION / TRANSITION ---------- */
.concl{flex:1;display:flex;flex-direction:column;justify-content:center}
.concl-q{font-family:var(--serif);font-weight:600;font-size:52px;line-height:1.2;
  letter-spacing:-.022em;max-width:1040px}
.concl-q em{font-style:italic;color:var(--accent);font-weight:700}
.slide:not(.dark) .concl-q em{color:var(--accent-deep)}
.concl-attr{margin-top:28px;font:600 13px/1 var(--mono);letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-faint)}
.end-next{display:flex;align-items:center;gap:26px;margin-top:26px;text-decoration:none;
  padding:24px 30px;border:1px solid var(--line-strong);background:#fff;align-self:flex-start;
  transition:background .2s,transform .2s}
.end-next:hover{background:var(--accent);transform:translateY(-2px)}
.end-num{font-family:var(--serif);font-weight:800;font-size:62px;line-height:1;
  color:var(--accent);letter-spacing:-.03em}
.end-next:hover .end-num{color:var(--ink)}
.end-t .et-meta{font:600 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:6px}
.end-t .et-title{font-family:var(--serif);font-weight:700;font-size:23px;
  letter-spacing:-.015em;color:var(--ink)}

/* ---------- TOOLS / TAGS ---------- */
.tools{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.tool{font:500 13px/1 var(--mono);padding:7px 11px;border:1px solid var(--line-strong);
  color:var(--ink);white-space:nowrap}
.tool.acc{background:var(--accent);border-color:var(--accent);font-weight:600}
.tool.alr{background:var(--alert);border-color:var(--alert);color:#fff;font-weight:600}
.slide.dark .tool{color:#fff;border-color:rgba(255,255,255,.3)}

/* ---------- MOCKUP ---------- */
.mock{background:#fff;border:1px solid var(--line-strong)}
.mock-bar{display:flex;align-items:center;gap:6px;padding:9px 14px;
  background:var(--bg);border-bottom:1px solid var(--line)}
.mock-dot{width:9px;height:9px;border-radius:50%;background:var(--ink-faint)}
.mock-dot.r{background:var(--alert)}.mock-dot.y{background:#FFC107}.mock-dot.g{background:var(--accent)}
.mock-title{margin-left:8px;font:600 11px/1 var(--mono);letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint)}
.mock-body{padding:17px 19px}
.mock-prompt{background:var(--bg);border-left:3px solid var(--accent);padding:11px 13px;
  font:500 13px/1.5 var(--mono);color:var(--ink);margin-bottom:13px}
.mock-prompt::before{content:"PROMPT → ";color:var(--accent-deep);font-weight:700}
.mock-out{font-size:14px;line-height:1.55;color:var(--ink)}
.mock-out::before{content:"SORTIE ↓";display:block;font:600 10px/1 var(--mono);
  letter-spacing:.12em;color:var(--ink-faint);margin-bottom:8px}
.mock-out b{font-weight:700}
.mock-out ul{margin:7px 0 0 18px}.mock-out li{margin-bottom:4px}
.anom{padding:7px 10px;margin-bottom:5px;border-left:3px solid var(--alert);
  background:var(--alert-soft);font-size:12.5px;list-style:none}

/* ---------- LEVEL / LEVIER DETAIL ---------- */
.lvl{display:grid;grid-template-columns:0.92fr 1.08fr;gap:36px;flex:1;align-items:center}
.lvl-left{display:flex;flex-direction:column}
.lvl-tag{font:600 12px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  padding:6px 11px;border:1px solid var(--line-strong);align-self:flex-start}
.lvl-tag.ok{background:var(--accent);border-color:var(--accent)}
.lvl-tag.warn{background:var(--alert);border-color:var(--alert);color:#fff}
.lvl-h{font-family:var(--serif);font-weight:700;font-size:33px;line-height:1.12;
  letter-spacing:-.018em;margin-top:15px}
.lvl-tagline{font-family:var(--serif);font-weight:500;font-size:19px;line-height:1.4;
  color:var(--ink-soft);margin-top:11px}

/* ---------- STATS ---------- */
.stat4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line-strong);border:1px solid var(--line-strong)}
.stat4 .cell{background:#fff;padding:24px 20px}
.stat-n{font-family:var(--serif);font-weight:800;font-size:48px;line-height:1;letter-spacing:-.03em}
.stat-n .u{font-size:.5em;color:var(--ink-faint);font-weight:600}
.stat-l{font-size:14.5px;line-height:1.45;color:var(--ink-soft);margin-top:11px}
.stat-l b{color:var(--ink);font-weight:600}
.stat-src{font:500 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:11px}
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  background:var(--ink);padding:28px 30px}
.sb-n{font-family:var(--serif);font-weight:700;font-size:50px;line-height:1;
  color:var(--alert);letter-spacing:-.03em}
.sb-l{font-size:13.5px;line-height:1.45;color:rgba(255,255,255,.82);margin-top:9px}
.sb-l b{color:#fff;font-weight:600}

/* ---------- VS COMPARE ---------- */
.vs{display:flex;flex-direction:column;gap:20px}
.vs-row{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.vs-cell{display:flex;align-items:baseline;gap:16px}
.vs-n{font-family:var(--serif);font-weight:800;font-size:80px;line-height:.85;letter-spacing:-.04em}
.vs-cell.muted .vs-n{color:var(--ink-faint)}
.vs-cell.hot .vs-n{color:var(--accent-deep)}
.vs-l{font-size:16px;line-height:1.4}.vs-l b{font-weight:700}
.vs-bar{height:13px;background:var(--line);position:relative;margin-top:9px}
.vs-bar i{position:absolute;left:0;top:0;bottom:0;background:var(--ink-faint)}
.vs-bar.acc i{background:var(--accent)}
.takeaway{margin-top:22px;padding:20px 24px;border-left:3px solid var(--accent);
  background:var(--accent-soft);font-family:var(--serif);font-weight:500;font-size:20px;
  line-height:1.42;letter-spacing:-.01em}
.takeaway em{color:var(--accent-deep);font-style:italic;font-weight:600}

/* ---------- CASE STUDY ---------- */
.casewrap{flex:1;display:flex;flex-direction:column;justify-content:center}
.case-meta{font:600 12px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--alert);display:flex;align-items:center;gap:12px}
.case-meta .k-sep{width:26px;height:1px;background:var(--alert)}
.case-h{font-family:var(--serif);font-weight:700;font-size:31px;line-height:1.16;
  letter-spacing:-.018em;margin:15px 0 15px;color:#fff}
.case-p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.82);max-width:1000px}
.case-p b{color:#fff;font-weight:700}
.case-p .hot{color:var(--alert);font-weight:700}
.case-quote{margin-top:18px;padding:15px 19px;border-left:3px solid var(--alert);
  background:rgba(255,255,255,.05);font-family:var(--serif);font-style:italic;
  font-size:16px;line-height:1.5;color:rgba(255,255,255,.9)}

/* ---------- DECK 01 : MUR / ACCROCHE / STAIR ---------- */
.mur{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-top:22px;flex:1}
.mur-col{border:1px solid var(--line-strong);background:#fff;display:flex;flex-direction:column}
.mur-head{padding:13px 17px;color:var(--ink);display:flex;align-items:center;gap:10px}
.mur-col.y .mur-head{background:var(--sig-yellow)}
.mur-col.o .mur-head{background:var(--sig-orange)}
.mur-col.r .mur-head{background:var(--sig-red)}
.mur-dot{width:13px;height:13px;border-radius:50%;background:var(--ink)}
.mur-name{font:700 14px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase}
.mur-prompt{padding:17px;font-family:var(--serif);font-weight:600;font-size:19px;
  line-height:1.32;flex:1}
.mur-zone{margin:0 17px 13px;border:1.5px dashed var(--line-strong);padding:13px;
  text-align:center;font:600 12px/1 var(--mono);letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-faint)}
.mur-reveal{padding:12px 17px;border-top:1px solid var(--line);
  font:600 12px/1.4 var(--mono);letter-spacing:.04em;text-transform:uppercase}
.mur-reveal b{color:var(--accent-deep)}
.mur-foot{margin-top:15px;font-size:15px;color:var(--ink-soft);flex:none}
.accroche-q{font-family:var(--serif);font-weight:600;font-size:56px;line-height:1.12;
  letter-spacing:-.022em;max-width:1000px}
.accroche-q em{font-style:italic;color:var(--accent);font-weight:700}
.accroche-b{font-size:20px;line-height:1.6;color:rgba(255,255,255,.78);
  max-width:780px;margin-top:26px}
.accroche-b b{color:#fff;font-weight:600}
.stair{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:16px;
  align-items:end;flex:1}
.stair-card{background:#fff;border:1px solid var(--line-strong);border-top-width:5px;
  padding:21px;display:flex;flex-direction:column;height:100%}
.stair-card.l1{border-top-color:var(--accent);margin-top:114px}
.stair-card.l2{border-top-color:var(--line-strong);margin-top:57px}
.stair-card.l3{border-top-color:var(--alert);margin-top:0}
.stair-n{font-family:var(--serif);font-weight:800;font-size:44px;line-height:1;letter-spacing:-.03em}
.stair-card.l1 .stair-n{color:var(--accent-deep)}
.stair-card.l3 .stair-n{color:var(--alert-deep)}
.stair-name{font:600 12px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-faint);margin:8px 0 9px}
.stair-phrase{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.3;
  letter-spacing:-.01em;flex:1}
.stair-tags{display:flex;flex-direction:column;gap:6px;margin-top:13px;
  border-top:1px solid var(--line);padding-top:12px}
.stair-tag{font:500 12px/1.3 var(--mono);letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-soft);display:flex;justify-content:space-between}
.stair-tag b{color:var(--ink);font-weight:700}
.axis-bar{margin-top:18px;display:flex;align-items:center;gap:16px;flex:none}
.axis-grad{flex:1;height:9px;border-radius:5px;
  background:linear-gradient(90deg,var(--accent),var(--warm),var(--alert))}
.axis-label{font:600 12px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);white-space:nowrap}
.subc{border-left:5px solid var(--ink)}
.subc.s3a{border-left-color:var(--warm)}.subc.s3b{border-left-color:var(--accent)}
.subc.s3c{border-left-color:var(--alert)}
.subc-l{font:700 12px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.subc-h{font-family:var(--serif);font-weight:600;font-size:21px;line-height:1.22;
  margin:9px 0;letter-spacing:-.01em}
.subc-p{font-size:14.5px;line-height:1.5;color:var(--ink-soft);flex:1}
.subc-risk{margin-top:13px;font:600 11px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase}

/* ---------- TIER MAP (deck 01 — mapping outils par niveau) ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px;flex:1}
.tier-card{background:#fff;border:1px solid var(--line-strong);border-top-width:5px;
  padding:22px 21px;display:flex;flex-direction:column}
.tier-card.t1{border-top-color:var(--accent)}
.tier-card.t2{border-top-color:var(--line-strong)}
.tier-card.t3{border-top-color:var(--alert)}
.tier-top{display:flex;align-items:baseline;gap:11px}
.tier-n{font-family:var(--serif);font-weight:800;font-size:40px;line-height:1;
  letter-spacing:-.03em;color:var(--ink-faint)}
.tier-card.t1 .tier-n{color:var(--accent-deep)}
.tier-card.t3 .tier-n{color:var(--alert-deep)}
.tier-name{font:600 12px/1.3 var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint)}
.tier-verb{font-family:var(--serif);font-weight:700;font-size:21px;line-height:1.26;
  letter-spacing:-.015em;margin:14px 0;padding-bottom:15px;border-bottom:1px solid var(--line)}
.tier-verb em{font-style:italic;color:var(--accent-deep);font-weight:700}
.tier-card.t3 .tier-verb em{color:var(--alert-deep)}
.tier-lab{font:600 10px/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:10px}
.tier-card .tools{margin-top:0}
.tier-cap{margin-top:auto;padding-top:14px;font-size:12.5px;line-height:1.45;color:var(--ink-soft)}

/* ---------- OUTPUT PALETTE (deck 01 — sorties N1 / rendus N2) ---------- */
.outs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
.outs .outcard{background:#fff;border:1px solid var(--line-strong);
  border-top:4px solid var(--accent);padding:19px 17px;display:flex;flex-direction:column}
.outs.r2 .outcard{border-top-color:var(--line-strong)}
.out-io{font:700 11px/1 var(--mono);letter-spacing:.09em;text-transform:uppercase;
  color:var(--accent-deep)}
.outs.r2 .out-io{color:var(--ink)}
.out-h{font-family:var(--serif);font-weight:700;font-size:20px;letter-spacing:-.015em;
  margin:10px 0 8px}
.out-p{font-size:13px;line-height:1.5;color:var(--ink-soft);flex:1}
.out-ex{font-family:var(--serif);font-style:italic;font-size:13.5px;line-height:1.42;
  color:var(--ink);margin-top:12px;padding-top:11px;border-top:1px solid var(--line)}
.out-ai{margin-top:10px;font:600 11.5px/1.55 var(--mono);color:var(--ink-soft)}
.out-ai b{font-weight:700;font-size:9px;letter-spacing:.13em;color:var(--accent-deep);
  margin-right:6px}
.outs.r2 .out-ai b{color:var(--ink)}

/* ---------- CAS D'USAGE + MINI-CAS (deck 01 — slides agents) ---------- */
.uses-lab{font:600 10px/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;
  color:var(--accent-deep);margin:18px 0 2px}
.uses{list-style:none}
.uses li{font-size:15px;line-height:1.4;padding:9px 0;border-top:1px solid var(--line);
  display:flex;gap:10px}
.uses li::before{content:"→";color:var(--accent-deep);font-weight:700;flex:none}
.minicase-h{font-family:var(--serif);font-weight:700;font-size:18px;line-height:1.22;
  letter-spacing:-.01em;color:#fff;margin:10px 0 7px}
.minicase-p{font-size:13px;line-height:1.5;color:rgba(255,255,255,.8)}
.minicase-p b{color:#fff;font-weight:700}
.minicase-p .hot{color:var(--alert);font-weight:700}

/* ---------- ROW LISTS (leviers overview, ownership, segments) ---------- */
.rows{border-top:1px solid var(--line-strong)}
.row{display:grid;gap:22px;padding:16px 4px;border-bottom:1px solid var(--line);align-items:center}
.row .r-num{font-family:var(--serif);font-weight:800;font-size:34px;line-height:1;
  color:var(--accent-deep);letter-spacing:-.03em}
.row .r-h{font-weight:700;font-size:16px;margin-bottom:3px}
.row .r-p{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft);line-height:1.35}
.row .r-tag{font:600 11px/1.3 var(--mono);letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-faint);text-align:right}

/* ---------- NUMBERED STEPS ---------- */
.steps{counter-reset:st;list-style:none}
.steps li{counter-increment:st;padding:9px 0 9px 38px;position:relative;
  border-top:1px solid var(--line);line-height:1.45;font-size:15.5px}
.steps li:first-child{border-top:none}
.steps li::before{content:counter(st);position:absolute;left:0;top:9px;width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;background:var(--accent);
  color:var(--ink);font:700 13px/1 var(--mono);border-radius:50%}
.steps li b{font-weight:700}

/* ---------- KPI / LIMITS ---------- */
.kpilim{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:16px;
  padding-top:15px;border-top:1px solid var(--line)}
.kl-label{font:600 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:6px;display:block}
.kl-label.k{color:var(--accent-deep)}.kl-label.l{color:var(--alert-deep)}
.kl-box p{font-size:14px;line-height:1.5;color:var(--ink)}

/* ---------- BADGES ---------- */
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.badge{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;
  font:600 11px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;
  border:1px solid var(--line-strong);background:#fff}
.badge .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.badge.med .dot{background:var(--warm)}.badge.hard .dot{background:var(--alert)}

.reference{margin-top:14px;padding:13px 16px;background:var(--accent-soft);
  border-left:3px solid var(--accent);font-size:14px;line-height:1.5}
.reference b{font:700 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-deep);display:block;margin-bottom:4px}

/* ---------- MATRIX 2×2 (graphe valeur × faisabilité) ---------- */
.matrix{display:grid;grid-template-columns:26px 1fr;grid-template-rows:1fr 30px;
  grid-template-areas:"yaxis grid" ". xaxis";column-gap:14px;row-gap:9px;
  width:100%;max-width:840px;height:400px;margin:0 auto}
.mx-grid{grid-area:grid;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
  gap:1px;background:var(--line-strong);border:1px solid var(--line-strong)}
.mx-quad{background:#fff;padding:15px 22px;display:flex;flex-direction:column;justify-content:center}
.mx-quad.win{background:var(--accent-soft);box-shadow:inset 0 0 0 2px var(--accent)}
.mx-quad.no{background:#F0F0EE}
.mx-pos{font:600 9px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:9px}
.mx-quad.win .mx-pos{color:var(--accent-deep)}
.mx-tag{font:700 13px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.mx-quad.win .mx-tag{color:var(--accent-deep)}
.mx-quad.no .mx-tag{color:var(--ink-faint)}
.mx-d{font-family:var(--serif);font-weight:600;font-size:15.5px;line-height:1.3;letter-spacing:-.01em}
.mx-yaxis{grid-area:yaxis;position:relative;display:flex;flex-direction:column;
  align-items:center;justify-content:space-between;padding:4px 0;
  border-right:2px solid var(--line-strong)}
.mx-yaxis::after{content:"";position:absolute;top:-8px;right:-7px;width:0;height:0;
  border-left:6px solid transparent;border-right:6px solid transparent;
  border-bottom:8px solid var(--line-strong)}
.mx-xaxis{grid-area:xaxis;position:relative;display:flex;align-items:center;
  justify-content:space-between;padding-top:7px;border-top:2px solid var(--line-strong)}
.mx-xaxis::after{content:"";position:absolute;top:-7px;right:-8px;width:0;height:0;
  border-top:6px solid transparent;border-bottom:6px solid transparent;
  border-left:8px solid var(--line-strong)}
.mx-end{font:600 10px/1 var(--mono);letter-spacing:.09em;text-transform:uppercase;color:var(--ink-faint)}
.mx-axttl{font:700 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}
.mx-yaxis .mx-end,.mx-yaxis .mx-axttl{writing-mode:vertical-rl;transform:rotate(180deg)}

/* ---------- DECK 02 — 5 PILIERS (slide intro) ---------- */
.pillars{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:34px}
.pillar{background:#fff;border:1px solid var(--line-strong);border-top:4px solid var(--accent);
  padding:17px 18px;display:flex;flex-direction:column;gap:9px}
.pillar-n{font-family:var(--serif);font-weight:800;font-size:30px;line-height:1;
  letter-spacing:-.03em;color:var(--accent-deep)}
.pillar-v{font:700 13px/1.25 var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}

/* ---------- DECK 02 — VUE D'ENSEMBLE (pilier · levier · objectif) ---------- */
.lev-pill{font:700 12px/1.25 var(--mono);letter-spacing:.09em;text-transform:uppercase;
  color:var(--accent-deep);margin-top:6px}
.lev-name{font-family:var(--serif);font-weight:700;font-size:18px;line-height:1.2;letter-spacing:-.015em}
.lev-job{font:600 11px/1 var(--mono);letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:8px;display:flex;align-items:center;gap:7px}
.lev-job::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--ink-faint);flex:none}
.lev-obj{border-left:2px solid var(--accent);padding-left:15px}
.lev-obj-l{font:700 9px/1 var(--mono);letter-spacing:.13em;text-transform:uppercase;
  color:var(--accent-deep);display:block;margin-bottom:6px}
.lev-obj-t{font-family:var(--serif);font-style:italic;font-weight:500;font-size:15px;
  line-height:1.32;color:var(--ink)}

/* ---------- DECK 02 — CYCLE AVANT / APRÈS IA (leviers) ---------- */
.cyc-cap{font:600 11px/1.4 var(--mono);letter-spacing:.03em;color:var(--ink-faint);margin-bottom:15px}
.cyc-cap b{color:var(--ink);font-weight:700}
.cycle{display:grid;grid-template-columns:78px repeat(5,1fr) 104px;column-gap:8px}
.cyc-head{display:flex;flex-direction:column;gap:5px;padding:10px 10px 13px;
  border-bottom:2px solid var(--line-strong)}
.cyc-head.ia{background:var(--accent-soft)}
.cyc-hn{font:800 13px/1 var(--mono);letter-spacing:.03em;color:var(--ink-faint)}
.cyc-head.ia .cyc-hn{color:var(--accent-deep)}
.cyc-ht{font-family:var(--serif);font-weight:700;font-size:14px;line-height:1.16;
  letter-spacing:-.01em;color:var(--ink)}
.cyc-hmeta{margin-top:auto;display:flex;flex-direction:column;align-items:flex-start;
  gap:5px;padding-top:10px}
.cyc-role{font:700 8px/1 var(--mono);letter-spacing:.05em;text-transform:uppercase;
  padding:3px 5px;border:1px solid var(--ink-faint);color:var(--ink-faint)}
.cyc-head.ia .cyc-role{border-color:var(--accent-deep);color:var(--accent-deep);background:#fff}
.cyc-tool{font:600 10px/1.3 var(--mono);color:var(--accent-deep)}
.cyc-rl{display:flex;align-items:center;font:700 9.5px/1.3 var(--mono);letter-spacing:.07em;
  text-transform:uppercase;color:var(--ink-faint)}
.cyc-rl.ap{color:var(--accent-deep)}
.cyc-cell{display:flex;align-items:center;padding:12px 10px}
.cyc-track{width:100%;height:14px;background:var(--line)}
.cyc-track i{display:block;height:100%}
.cyc-track i.f-av{background:var(--ink-soft)}
.cyc-track i.f-ap{background:var(--accent)}
.cyc-sum{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;text-align:right}
.cyc-sum b{font-family:var(--serif);font-weight:800;font-size:19px;line-height:1.05;
  letter-spacing:-.02em;color:var(--ink-soft)}
.cyc-sum.ap b{color:var(--accent-deep)}
.cyc-sum span{font:600 8px/1.3 var(--mono);letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:5px}
.cyc-kpi{display:flex;align-items:center;gap:21px;margin-top:22px;padding:17px 24px;background:var(--ink)}
.cyc-kpi-l{font:700 10px/1.4 var(--mono);letter-spacing:.13em;text-transform:uppercase;
  color:var(--accent);flex:none}
.cyc-kpi-v{font-family:var(--serif);font-weight:800;font-size:38px;line-height:1;
  letter-spacing:-.03em;color:var(--accent);flex:none}
.cyc-kpi-d{font-family:var(--serif);font-weight:500;font-size:17px;line-height:1.32;color:#fff}
.cyc-kpi-d b{font-weight:700;color:#fff}

/* ---------- RISK ROWS (AI Act) ---------- */
.riskrows{border:1px solid var(--line-strong);background:#fff}
.riskrow{display:grid;grid-template-columns:230px 1fr 270px;gap:22px;
  padding:16px 22px;border-bottom:1px solid var(--line);align-items:center;
  border-left:6px solid var(--line)}
.riskrow:last-child{border-bottom:none}
.riskrow.r1{border-left-color:var(--alert-deep);background:var(--alert-soft)}
.riskrow.r2{border-left-color:var(--alert)}
.riskrow.r3{border-left-color:var(--warm)}
.riskrow.r4{border-left-color:var(--accent)}
.rr-lvl{font:600 10px/1.4 var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}
.rr-name{font-family:var(--serif);font-weight:700;font-size:19px;line-height:1.15;
  letter-spacing:-.01em;margin-top:3px}
.rr-ex{font-size:13.5px;line-height:1.45;color:var(--ink-soft)}
.rr-ex b{color:var(--ink);font-weight:600}
.rr-imp{font:500 12px/1.45 var(--mono);color:var(--ink)}
.rr-imp b{display:block;color:var(--accent-deep);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:3px}

/* ---------- HORIZONTAL FLOW (cycle / timeline) ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line-strong);background:#fff}
.flow-step{padding:18px 18px;border-right:1px solid var(--line);position:relative}
.flow-step:last-child{border-right:none}
.flow-step::after{content:"→";position:absolute;right:-9px;top:18px;color:var(--accent);
  font-size:1.1rem;background:var(--bg);padding:0 2px;z-index:1}
.flow-step:last-child::after{display:none}
.fs-tempo{font:700 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-deep);display:block;margin-bottom:7px}
.fs-h{font-family:var(--serif);font-weight:600;font-size:17px;line-height:1.25;
  letter-spacing:-.01em;margin-bottom:6px}
.fs-p{font-size:13px;line-height:1.45;color:var(--ink-soft)}
.slide.dark .flow{background:#15151c;border-color:#2a2a33}
.slide.dark .flow-step{border-color:#2a2a33}
.slide.dark .flow-step::after{background:var(--ink)}
.slide.dark .fs-h{color:#fff}.slide.dark .fs-p{color:rgba(255,255,255,.7)}
.slide.dark .fs-tempo{color:var(--accent)}

/* ---------- DATE ROWS (AI Act timeline) ---------- */
.daterows{display:flex;flex-direction:column}
.daterow{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:11px 0;
  border-top:1px solid rgba(255,255,255,.14);align-items:center}
.daterow:first-child{border-top:1px solid rgba(255,255,255,.32)}
.dr-date{font:700 14px/1 var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.dr-ev{font-size:15px;line-height:1.4;color:rgba(255,255,255,.86)}
.dr-ev b{color:#fff;font-weight:700}

/* ---------- VERTICALE (deck 04) ---------- */
.vert{border:1px solid var(--line-strong);background:#fff;display:grid;
  grid-template-columns:188px 1fr;overflow:hidden}
.vert-side{background:var(--ink);color:#fff;padding:22px 20px;
  display:flex;flex-direction:column;justify-content:space-between}
.vert-side.meta{background:linear-gradient(165deg,var(--ink),#1c1c30)}
.v-letter{font-family:var(--serif);font-weight:800;font-size:62px;line-height:1;
  color:var(--accent);letter-spacing:-.04em}
.v-label{font:600 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.6);margin-top:5px;display:block}
.v-meta{font:500 11px/1.7 var(--mono);letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.82);margin-top:14px}
.v-meta b{color:var(--accent);font-weight:700}
.vert-body{padding:22px 24px}
.vert-h{font-family:var(--serif);font-weight:700;font-size:24px;line-height:1.18;
  letter-spacing:-.015em}
.vert-tag{font-family:var(--serif);font-weight:500;font-size:16px;line-height:1.35;
  color:var(--ink-soft);margin:8px 0 13px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.vrow{display:grid;grid-template-columns:96px 1fr;gap:14px;padding:7px 0;font-size:14px;line-height:1.45}
.vrow+.vrow{border-top:1px solid var(--line)}
.vrow .vr-l{font:600 10px/1.3 var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent-deep);padding-top:2px}
.vrow b{font-weight:700}

/* ---------- FICHE (deck 05) ---------- */
.zones{display:flex;flex-direction:column;gap:9px}
.zone-row{display:grid;grid-template-columns:150px 1fr 130px;gap:18px;align-items:center;
  background:#fff;border:1px solid var(--line-strong);padding:14px 18px}
.zone-row.new{background:var(--accent-soft);border-color:var(--accent)}
.zr-z{font-family:var(--serif);font-weight:700;font-size:17px;letter-spacing:-.01em}
.zr-d{font-size:14px;color:var(--ink-soft);line-height:1.4}
.zr-c{font:600 11px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-faint);text-align:right}
.zone-row.new .zr-c{color:var(--accent-deep);font-weight:700}
.fields{display:grid;gap:14px}
.field{background:#fff;border:1px solid var(--line-strong);padding:16px 18px}
.field.new{border-left:4px solid var(--accent)}
.fld-n{font:700 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-deep);display:block;margin-bottom:6px}
.fld-q{font-family:var(--serif);font-weight:600;font-size:16px;line-height:1.3;
  letter-spacing:-.01em;margin-bottom:5px}
.fld-h{font-size:13px;line-height:1.45;color:var(--ink-soft);font-style:italic}
.fld-in{margin-top:9px;border:1px dashed var(--line-strong);padding:9px 11px;
  font-size:12.5px;color:var(--ink-faint);font-style:italic}

/* ---------- EMAIL (deck 06) ---------- */
.email{max-width:660px;margin:0 auto;background:#fff;border:1px solid var(--line-strong)}
.email-hd{padding:13px 18px;background:var(--bg);border-bottom:1px solid var(--line);
  font:500 12px/1.7 var(--mono);color:var(--ink-soft)}
.email-hd b{color:var(--ink)}
.email-bd{padding:20px 22px}
.email-subj{font-family:var(--serif);font-weight:700;font-size:23px;line-height:1.2;
  letter-spacing:-.015em;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.email-bd p{font-size:14px;line-height:1.55;margin-bottom:10px}
.email-blk{padding:12px 14px;background:var(--bg);border-left:3px solid var(--accent);margin:10px 0}
.email-blk .eb-l{font:700 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-deep);display:block;margin-bottom:6px}
.email-blk .eb-c{font-size:13px;line-height:1.5}
.email-blk ul{margin:5px 0 0 16px}.email-blk li{margin-bottom:3px}

/* ---------- ACTS (deck 06) ---------- */
.acts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;flex:1}
.act{background:#fff;border:1px solid var(--line-strong);border-top:5px solid var(--accent);
  padding:20px;display:flex;flex-direction:column}
.act-n{font-family:var(--serif);font-weight:800;font-size:40px;line-height:1;
  color:var(--accent-deep);letter-spacing:-.03em}
.act-t{font:600 11px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);margin:7px 0 9px}
.act-h{font-family:var(--serif);font-weight:600;font-size:18px;line-height:1.22;
  letter-spacing:-.01em;margin-bottom:8px}
.act-p{font-size:13px;line-height:1.45;color:var(--ink-soft);flex:1}

/* ---------- SEGMENTS (deck 06) ---------- */
.segs{display:flex;flex-direction:column}
.seg{display:grid;grid-template-columns:200px 1fr 230px;gap:22px;padding:15px 0;
  border-top:1px solid rgba(255,255,255,.14);align-items:start}
.seg:first-child{border-top:1px solid rgba(255,255,255,.32)}
.seg-n{font-family:var(--serif);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.01em}
.seg-a{font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.82)}
.seg-a b{color:#fff;font-weight:600}
.seg-c{font:600 12px/1.45 var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}

/* ---------- NOTES (hidden — read by presenter) ---------- */
.notes{display:none}

/* ---------- DECK UI ---------- */
.progress{position:fixed;top:0;left:0;height:3px;background:var(--accent);width:0;
  z-index:50;transition:width .34s ease}
.deck-ui{position:fixed;bottom:18px;right:22px;display:flex;align-items:center;gap:4px;
  z-index:50;transition:opacity .3s}
body.idle .deck-ui{opacity:0}
.ui-btn{height:34px;min-width:34px;padding:0 9px;display:flex;align-items:center;
  justify-content:center;background:rgba(255,255,255,.08);color:#fff;
  border:1px solid rgba(255,255,255,.16);font:600 14px/1 var(--mono);cursor:pointer;border-radius:5px}
.ui-btn:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
.ui-count{font:600 12px/1 var(--mono);color:rgba(255,255,255,.6);padding:0 11px;letter-spacing:.06em}
.hint{position:fixed;bottom:18px;left:22px;z-index:50;font:500 12px/1.6 var(--mono);
  color:rgba(255,255,255,.55);background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);padding:10px 14px;border-radius:6px;transition:opacity .5s}
.hint b{color:var(--accent)}
.hint.gone{opacity:0;pointer-events:none}

/* ---------- PRESENTER MODE ---------- */
#pTop,#pSide{display:none}
body.mode-presenter{display:grid;background:#0E0E13;padding:12px;gap:12px;
  grid-template-columns:1fr 428px;grid-template-rows:56px 1fr}
body.mode-presenter #deckView{position:relative;inset:auto;grid-column:1;grid-row:2;
  border-radius:8px;background:#000}
body.mode-presenter .progress,body.mode-presenter .deck-ui,body.mode-presenter .hint{display:none}
body.mode-presenter #pTop{display:flex;grid-column:1/-1;grid-row:1;align-items:center;
  gap:16px;background:#16161D;border-radius:8px;padding:0 18px;color:#fff}
body.mode-presenter #pSide{display:flex;grid-column:2;grid-row:2;
  flex-direction:column;gap:12px;min-height:0}
.pt-badge{font:700 11px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);padding:6px 10px;border:1px solid rgba(0,212,170,.4);border-radius:4px}
.pt-count{font:700 19px/1 var(--mono);letter-spacing:.04em}
.pt-count span{color:var(--ink-faint);font-weight:500;font-size:14px}
.pt-nav{display:flex;gap:6px}
.pt-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.16);
  border-radius:6px;cursor:pointer;font-size:17px}
.pt-btn:hover{background:var(--accent);color:#000}
.pt-spacer{flex:1}
.pt-block{text-align:right}
.pt-k{font:500 9px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.pt-timer{font:700 21px/1 var(--mono);color:var(--accent)}
.pt-clock{font:600 15px/1.1 var(--mono);color:rgba(255,255,255,.7)}
#pNext{flex:none;background:#000;border-radius:8px;overflow:hidden;position:relative;height:240px}
#pNextHost{position:absolute;inset:0}
.p-caplabel{position:absolute;top:8px;left:10px;z-index:3;font:700 9px/1 var(--mono);
  letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.55);
  padding:5px 8px;border-radius:3px}
#pNotes{flex:1;background:#F8F8F6;border-radius:8px;padding:17px 19px;overflow-y:auto;min-height:0}
#pNotes .pn-head{font:700 10px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:11px;padding-bottom:9px;border-bottom:1px solid var(--line)}
#pNotesBody p{font-size:14.5px;line-height:1.55;color:var(--ink);margin-bottom:9px}
#pNotesBody .scr{background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent);
  padding:9px 12px;margin-bottom:7px;font-size:13px;line-height:1.5}
#pNotesBody .scr b{color:var(--accent-deep);font-family:var(--mono);font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:3px}
#pNotesBody .pn-key{font-family:var(--serif);font-weight:600;font-size:16px;
  color:var(--accent-deep);margin:2px 0 10px}
.pv-end{display:flex;align-items:center;justify-content:center;height:100%;
  color:rgba(255,255,255,.4);font:600 13px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase}
