/* ============================================================
   PLAN MARKETING — FARO CREAFORM
   MBA-8416 · UQAR · Hiver 2026
   Système de design : éditorial académique
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter+Tight:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  /* couleurs — palette « bordeaux & olive » sur crème */
  --bg: #f3ecdc;
  --bg-soft: #e8dfca;
  --surface: #fbf7ec;
  --ink: #1a1410;
  --ink-2: #3d362e;
  --ink-3: #7c7264;
  --ink-4: #b1a692;
  --rule: rgba(26, 20, 16, 0.10);
  --rule-soft: rgba(26, 20, 16, 0.05);
  --accent: #6e2530;          /* bordeaux profond */
  --accent-soft: #f0e0e3;
  --accent-glow: rgba(110, 37, 48, 0.14);
  --on-dark-accent: #e6d4a8;
  --warm: #6b6936;            /* olive chaud, parcimonieux */
  --warm-soft: #e9e6cf;
  --positive: #3a6b2f;
  --negative: #9c2a2a;
  --neutral: #6a6760;

  /* type */
  --serif: 'Instrument Serif', 'Times New Roman', serif;
  --sans: 'Inter Tight', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: #0a0a08;
  font-family: var(--sans);
  color: var(--ink);
  font-feature-settings: 'ss01', 'cv11';
  -webkit-font-smoothing: antialiased;
}

deck-stage { background: #0a0a08; }

/* ===== SLIDE ROOT ===== */
section {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 24px;
  line-height: 1.45;
  letter-spacing: -0.005em;
  position: relative;
  overflow: hidden;
  padding: 64px 88px 84px;
  display: flex;
  flex-direction: column;
}

/* ============================================================
   HEADER + FOOTER
   ============================================================ */
.slide-head {
  display: flex;
  align-items: baseline;
  gap: 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 36px;
}
.slide-head .num {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--ink-3);
}
.slide-head .sect {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--ink);
  text-transform: uppercase;
}
.slide-head .spacer { flex: 1; }
.slide-head .meta {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.16em;
  color: var(--ink-4);
  text-transform: uppercase;
}

.slide-foot {
  position: absolute;
  left: 88px;
  right: 88px;
  bottom: 32px;
  display: flex;
  align-items: center;
  gap: 18px;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.16em;
  color: var(--ink-4);
  text-transform: uppercase;
}
.slide-foot .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--ink-4); display: inline-block; }
.slide-foot .page { margin-left: auto; color: var(--ink-3); font-weight: 500; }

/* ============================================================
   TYPO HELPERS
   ============================================================ */
.eyebrow {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.title-xl {
  font-family: var(--serif);
  font-size: 132px;
  line-height: 0.96;
  letter-spacing: -0.025em;
  font-weight: 400;
  color: var(--ink);
  text-wrap: balance;
}
.title-l {
  font-family: var(--serif);
  font-size: 104px;
  line-height: 0.98;
  letter-spacing: -0.022em;
  font-weight: 400;
  text-wrap: balance;
}
.title-m {
  font-family: var(--serif);
  font-size: 76px;
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-weight: 400;
  text-wrap: balance;
}
.subtitle {
  font-family: var(--serif);
  font-style: italic;
  font-size: 36px;
  line-height: 1.2;
  color: var(--ink-3);
  font-weight: 400;
}
.kicker {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}
.lead {
  font-size: 28px;
  line-height: 1.4;
  color: var(--ink-2);
  font-weight: 400;
  text-wrap: pretty;
}
.body { font-size: 22px; line-height: 1.5; color: var(--ink-2); }
.small { font-size: 16px; line-height: 1.45; color: var(--ink-3); }
.mono { font-family: var(--mono); }
.serif { font-family: var(--serif); }

em.serif { font-family: var(--serif); font-style: italic; color: var(--ink); }
strong { font-weight: 600; color: var(--ink); }

/* ============================================================
   COMPOSANTS GÉNÉRIQUES
   ============================================================ */
.card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 28px;
}
.card-flat {
  background: transparent;
  border-top: 1px solid var(--rule);
  padding: 24px 0;
}
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-2);
  background: var(--surface);
}
.tag.accent { background: var(--accent); color: #fff; border-color: var(--accent); }
.tag.warm { background: var(--warm); color: #fff; border-color: var(--warm); }
.tag.positive { color: var(--positive); border-color: rgba(47,107,60,.3); background: rgba(47,107,60,.06); }
.tag.negative { color: var(--negative); border-color: rgba(156,42,42,.3); background: rgba(156,42,42,.06); }

.divider { height: 1px; background: var(--rule); width: 100%; }
.divider-thick { height: 2px; background: var(--ink); width: 100%; }

.stat .num {
  font-family: var(--serif);
  font-size: 88px;
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-weight: 400;
}
.stat .num.accent { color: var(--accent); }
.stat .num.warm { color: var(--warm); }
.stat .lbl {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 8px;
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
section[data-active="true"] .anim-in {
  animation: fadeUp 0.7s cubic-bezier(.2,.7,.25,1) both;
}
section[data-active="true"] .anim-in.d1 { animation-delay: 0.08s; }
section[data-active="true"] .anim-in.d2 { animation-delay: 0.16s; }
section[data-active="true"] .anim-in.d3 { animation-delay: 0.24s; }
section[data-active="true"] .anim-in.d4 { animation-delay: 0.32s; }
section[data-active="true"] .anim-in.d5 { animation-delay: 0.40s; }
section[data-active="true"] .anim-in.d6 { animation-delay: 0.48s; }
section[data-active="true"] .anim-in.d7 { animation-delay: 0.56s; }
section[data-active="true"] .anim-in.d8 { animation-delay: 0.64s; }

.anim-in { opacity: 0; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

section[data-active="true"] .anim-line {
  animation: lineGrow 0.9s cubic-bezier(.2,.7,.25,1) 0.2s both;
  transform-origin: left center;
}
.anim-line { transform: scaleX(0); }
@keyframes lineGrow { to { transform: scaleX(1); } }

section[data-active="true"] .anim-bar {
  animation: barGrow 0.9s cubic-bezier(.2,.7,.25,1) 0.3s both;
}
.anim-bar { width: 0 !important; }
@keyframes barGrow { /* width set inline; we override via class removal */ }

/* ============================================================
   BOUTON PLEIN ÉCRAN
   ============================================================ */
.fs-btn {
  position: fixed;
  bottom: 18px;
  right: 18px;
  z-index: 9999;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: rgba(20,20,15,0.72);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background .18s ease, transform .18s ease;
}
.fs-btn:hover { background: rgba(20,20,15,0.95); transform: scale(1.05); }
.fs-btn svg { width: 16px; height: 16px; stroke: #fff; }

/* ============================================================
   SLIDE 1 — COVER
   ============================================================ */
.cover {
  padding: 0;
  background: var(--bg);
}
.cover-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: 100%;
  position: relative;
}
.cover-left {
  padding: 88px 72px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-right: 1px solid var(--rule);
}
.cover-right {
  padding: 88px 72px;
  background: var(--ink);
  color: var(--bg);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.cover-right::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at top right, rgba(230,212,168,0.16), transparent 60%);
  pointer-events: none;
}
.cover-mark {
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.cover-title {
  font-family: var(--serif);
  font-size: 168px;
  line-height: 0.94;
  letter-spacing: -0.03em;
}
.cover-title em { font-style: italic; }
.cover-sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 40px;
  line-height: 1.2;
  margin-top: 22px;
  color: var(--ink-2);
}
.cover-right .cover-sub { color: rgba(244,237,224,0.78); }

.cover-credit-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}
.cover-credit .label {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  color: rgba(244,237,224,0.5);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.cover-credit .name { font-family: var(--serif); font-size: 34px; line-height: 1.15; }

/* ============================================================
   SLIDE 2 — AGENDA
   ============================================================ */
.agenda-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 18px;
  border-top: 1px solid var(--rule);
}
.agenda-item {
  padding: 26px 28px 26px 0;
  border-bottom: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  display: flex;
  align-items: baseline;
  gap: 22px;
  min-height: 120px;
  padding-left: 28px;
}
.agenda-item:nth-child(3n) { border-right: none; }
.agenda-item .n {
  font-family: var(--mono);
  font-size: 15px;
  color: var(--ink-3);
  letter-spacing: 0.16em;
  width: 30px;
}
.agenda-item .t {
  font-family: var(--serif);
  font-size: 34px;
  line-height: 1.1;
  letter-spacing: -0.01em;
}
.agenda-item:hover .t { color: var(--accent); }

/* ============================================================
   SLIDE 3 — ENTREPRISE
   ============================================================ */
.entreprise-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 56px;
  flex: 1;
}
.entreprise-left .scian {
  display: flex;
  align-items: baseline;
  gap: 18px;
  padding: 20px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  margin-bottom: 28px;
}
.scian .code {
  font-family: var(--serif);
  font-size: 96px;
  line-height: 0.95;
  letter-spacing: -0.02em;
}
.scian .lbl { font-size: 16px; color: var(--ink-3); flex: 1; line-height: 1.4; }

.mvv { display: grid; gap: 26px; }
.mvv-item .l {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  color: var(--ink-3);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.mvv-item .v { font-family: var(--serif); font-size: 28px; line-height: 1.25; color: var(--ink); }

.enjeu {
  background: var(--ink);
  color: var(--bg);
  padding: 36px;
  margin-top: auto;
  border-radius: 4px;
}
.enjeu .l {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(244,237,224,0.55);
  margin-bottom: 14px;
}
.enjeu .v { font-family: var(--serif); font-size: 38px; line-height: 1.15; }

/* ============================================================
   SLIDE 4 — ANSOFF
   ============================================================ */
.ansoff {
  display: grid;
  grid-template-columns: 100px 1fr 1fr;
  grid-template-rows: 56px 1fr 1fr;
  flex: 1;
  gap: 0;
}
.ansoff > .axis-x-l, .ansoff > .axis-x-r, .ansoff > .corner, .ansoff > .axis-y-t, .ansoff > .axis-y-b {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 8px;
}
.ansoff .corner { }
.ansoff .axis-x-l, .ansoff .axis-x-r { border-bottom: 1px solid var(--rule); }
.ansoff .axis-y-t, .ansoff .axis-y-b { border-right: 1px solid var(--rule); writing-mode: vertical-rl; transform: rotate(180deg); }
.ansoff .quad {
  border: 1px solid var(--rule);
  padding: 44px 26px 26px;
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  margin: -1px 0 0 -1px;
}
.ansoff .quad .t { font-family: var(--serif); font-size: 38px; line-height: 1.05; letter-spacing: -0.015em; }
.ansoff .quad .d { font-size: 18px; color: var(--ink-3); line-height: 1.4; }
.ansoff .quad.picked {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
  z-index: 2;
}
.ansoff .quad.picked .d { color: rgba(246,243,236,0.7); }
.ansoff .quad .star {
  position: absolute;
  top: 16px; left: 26px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--warm);
}

.ansoff-why {
  margin-top: 28px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 28px;
  align-items: start;
}
.ansoff-why .l {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  white-space: nowrap;
}
.ansoff-why .v { font-family: var(--serif); font-size: 28px; line-height: 1.28; color: var(--ink); }

/* ============================================================
   SLIDE 5 — OBJECTIFS
   ============================================================ */
.obj-block { margin-bottom: 28px; }
.obj-block .head {
  display: flex;
  align-items: baseline;
  gap: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 22px;
}
.obj-block .head .l {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
}
.obj-block .head .h { font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--ink-3); flex: 1; }
.obj-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.obj-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.obj-cell {
  padding: 0 28px;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.obj-cell:first-child { padding-left: 0; }
.obj-cell:last-child { border-right: none; }
.obj-cell .v {
  font-family: var(--serif);
  font-size: 84px;
  line-height: 1;
  letter-spacing: -0.025em;
}
.obj-cell .v.accent { color: var(--accent); }
.obj-cell .v.warm { color: var(--warm); }
.obj-cell .l {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
}
.obj-cell .d { font-size: 16px; color: var(--ink-3); }

/* ============================================================
   SLIDE 6 — CONTEXTE US (3 grands chiffres)
   ============================================================ */
.bignums {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  flex: 1;
  margin-top: 30px;
}
.bignums .cell {
  padding: 36px 36px 28px;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}
.bignums .cell:first-child { padding-left: 0; }
.bignums .cell:last-child { border-right: none; }
.bignums .v {
  font-family: var(--serif);
  font-size: 180px;
  line-height: 0.9;
  letter-spacing: -0.04em;
}
.bignums .v.accent { color: var(--accent); }
.bignums .label { font-family: var(--serif); font-size: 36px; line-height: 1.1; }
.bignums .desc { font-size: 17px; color: var(--ink-3); line-height: 1.45; }
.bignums .src {
  margin-top: auto;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-4);
}

.bignums-synth {
  margin-top: 36px;
  padding: 28px 32px;
  background: var(--accent);
  color: #fff;
  border-radius: 4px;
  font-family: var(--serif);
  font-size: 28px;
  line-height: 1.3;
}

/* ============================================================
   SLIDE 7 — PESTEL
   ============================================================ */
.pestel { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; flex: 1; }
.pestel .row {
  display: grid;
  grid-template-columns: 56px 160px 1fr 36px;
  align-items: center;
  padding: 22px 28px 22px 0;
  border-bottom: 1px solid var(--rule);
  gap: 18px;
}
.pestel .row:nth-child(odd) { padding-right: 36px; }
.pestel .row:nth-child(even) { padding-left: 36px; padding-right: 0; }
.pestel .row:nth-last-child(-n+2) { border-bottom: none; }
.pestel .letter {
  font-family: var(--serif);
  font-size: 72px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.pestel .name {
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.pestel .desc { font-size: 19px; color: var(--ink); line-height: 1.4; }
.pestel .sign {
  font-family: var(--serif);
  font-size: 40px;
  line-height: 1;
  text-align: center;
}
.pestel .sign.pos { color: var(--positive); }
.pestel .sign.neg { color: var(--negative); }

/* ============================================================
   SLIDE 8 — PORTER
   ============================================================ */
.porter { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; flex: 1; margin-top: 12px; }
.porter .col {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--rule);
  padding: 24px 22px;
  gap: 14px;
}
.porter .score {
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.porter .score .n { font-family: var(--serif); font-size: 76px; line-height: 0.9; letter-spacing: -0.02em; }
.porter .score .d { font-family: var(--mono); font-size: 15px; color: var(--ink-3); }
.porter .bar {
  height: 6px;
  background: var(--rule-soft);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 4px;
}
.porter .bar > span {
  display: block;
  height: 100%;
  background: var(--ink);
  border-radius: 999px;
}
.porter .col.weak .bar > span { background: var(--positive); }
.porter .col.strong .bar > span { background: var(--warm); }
.porter .name {
  font-family: var(--serif);
  font-size: 30px;
  line-height: 1.1;
  margin-top: 4px;
}
.porter .desc { font-size: 15px; color: var(--ink-3); line-height: 1.4; }

.porter-synth {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  font-family: var(--serif);
  font-size: 28px;
  line-height: 1.3;
  color: var(--ink);
}
.porter-synth em { font-style: italic; color: var(--accent); }

/* ============================================================
   SLIDE 9 — VRIO
   ============================================================ */
.vrio { width: 100%; border-collapse: collapse; flex: 1; }
.vrio th {
  text-align: left;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: 14px 14px;
  border-bottom: 1.5px solid var(--ink);
  font-weight: 500;
}
.vrio th.c { text-align: center; width: 60px; }
.vrio td {
  padding: 20px 14px;
  border-bottom: 1px solid var(--rule);
  vertical-align: middle;
  font-size: 18px;
}
.vrio td.r { font-family: var(--serif); font-size: 24px; letter-spacing: -0.01em; }
.vrio td.c {
  text-align: center;
  font-family: var(--mono);
  font-size: 15px;
  color: var(--ink-2);
}
.vrio td.c.yes { color: var(--positive); font-weight: 600; }
.vrio td.c.no { color: var(--negative); }
.vrio td.diag { font-family: var(--mono); font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink); }
.vrio tr.dur td.diag { color: var(--positive); }
.vrio tr.temp td.diag { color: var(--warm); }
.vrio tr.par td.diag { color: var(--ink-3); }
.vrio-synth {
  margin-top: 22px;
  padding: 22px 26px;
  background: var(--surface);
  border-left: 3px solid var(--accent);
  font-family: var(--serif);
  font-size: 26px;
  line-height: 1.35;
}

/* ============================================================
   SLIDE 10 — FFOM (SWOT)
   ============================================================ */
.ffom { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 0; flex: 1; }
.ffom .q {
  padding: 32px 36px;
  border: 1px solid var(--rule);
  margin: -1px 0 0 -1px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: var(--surface);
}
.ffom .q.f { background: #f3f6ef; border-color: rgba(47,107,60,.2); }
.ffom .q.fa { background: #fbf2ec; border-color: rgba(182,83,52,.22); }
.ffom .q.o { background: #eef1f7; border-color: rgba(27,58,107,.2); }
.ffom .q.m { background: #f6ecec; border-color: rgba(156,42,42,.18); }
.ffom .q .h {
  display: flex;
  align-items: baseline;
  gap: 12px;
}
.ffom .q .l {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.ffom .q .t { font-family: var(--serif); font-size: 50px; letter-spacing: -0.018em; }
.ffom .q.f .t { color: var(--positive); }
.ffom .q.fa .t { color: var(--warm); }
.ffom .q.o .t { color: var(--accent); }
.ffom .q.m .t { color: var(--negative); }
.ffom .q ul { list-style: none; display: grid; gap: 10px; margin-top: 4px; }
.ffom .q li {
  font-size: 18px;
  line-height: 1.4;
  padding-left: 20px;
  position: relative;
  color: var(--ink-2);
}
.ffom .q li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.55em;
  width: 8px; height: 1px;
  background: currentColor;
  opacity: 0.5;
}

.ffom-options {
  display: grid;
  grid-template-columns: 220px repeat(3, 1fr);
  gap: 14px;
  margin-top: 20px;
  align-items: stretch;
}
.ffom-options .label {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 4px;
}
.ffom-options .label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--ink);
  display: block;
}
.ffom-opt {
  background: var(--ink);
  color: var(--bg);
  padding: 18px 22px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  gap: 18px;
}
.ffom-opt:nth-child(2) { background: var(--accent); }
.ffom-opt .n { font-family: var(--mono); font-size: 14px; color: rgba(244,237,224,0.55); letter-spacing: 0.18em; }
.ffom-opt .t { font-family: var(--serif); font-size: 24px; line-height: 1.1; letter-spacing: -0.01em; flex: 1; }

/* ============================================================
   SLIDE 11 — TOWS
   ============================================================ */
.tows-top { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; margin-bottom: 28px; }
.tows-cell {
  padding: 22px 22px 22px 0;
  border-right: 1px solid var(--rule);
}
.tows-cell:first-child { padding-left: 0; }
.tows-cell:not(:first-child) { padding-left: 22px; }
.tows-cell:last-child { border-right: none; }
.tows-cell .l {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 8px;
}
.tows-cell .t { font-family: var(--serif); font-size: 28px; line-height: 1.1; margin-bottom: 10px; }
.tows-cell .d { font-size: 16px; color: var(--ink-3); line-height: 1.4; }

.tows-options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.tows-opt {
  background: var(--ink);
  color: var(--bg);
  padding: 28px 26px;
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.tows-opt .n { font-family: var(--mono); font-size: 14px; letter-spacing: 0.2em; color: rgba(244,237,224,0.55); }
.tows-opt .t { font-family: var(--serif); font-size: 34px; line-height: 1.05; }
.tows-opt .d { font-size: 16px; color: rgba(244,237,224,0.72); line-height: 1.4; }
.tows-opt:first-child { background: var(--accent); }

/* ============================================================
   SLIDE 12 — SEGMENTATION
   ============================================================ */
.seg-intro {
  display: flex;
  align-items: baseline;
  gap: 28px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 18px;
}
.seg-intro .t { font-family: var(--serif); font-style: italic; font-size: 30px; color: var(--ink-3); flex: 1; }
.segs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; flex: 1; }
.seg {
  padding: 28px 24px 28px 0;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.seg:first-child { padding-left: 0; }
.seg:not(:first-child) { padding-left: 24px; }
.seg:last-child { border-right: none; }
.seg .top { display: flex; align-items: baseline; gap: 10px; }
.seg .code { font-family: var(--mono); font-size: 16px; color: var(--ink); letter-spacing: 0.1em; font-weight: 600; }
.seg .pri { margin-left: auto; }
.seg .name { font-family: var(--serif); font-size: 38px; line-height: 1.05; letter-spacing: -0.015em; }
.seg .share {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
}
.seg .share .v { font-family: var(--serif); font-size: 54px; line-height: 1; letter-spacing: -0.02em; color: var(--accent); }
.seg .share .l { font-family: var(--mono); font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); }
.seg .desc { font-size: 16px; color: var(--ink-3); line-height: 1.45; }

/* ============================================================
   SLIDE 13 — PERSONAS
   ============================================================ */
.personas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; flex: 1; }
.persona {
  background: var(--surface);
  border: 1px solid var(--rule);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.persona .avatar-row { display: flex; align-items: center; gap: 16px; }
.persona .avatar {
  width: 64px; height: 64px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--bg);
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-size: 26px;
  letter-spacing: -0.01em;
}
.persona .who .name { font-family: var(--serif); font-size: 32px; line-height: 1.1; }
.persona .who .role { font-size: 15px; color: var(--ink-3); margin-top: 2px; }
.persona .seg-tag {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  padding: 5px 10px;
  background: var(--accent-soft);
  border-radius: 999px;
  display: inline-block;
  align-self: flex-start;
}
.persona .block .l {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 6px;
}
.persona .block .v { font-size: 16px; color: var(--ink-2); line-height: 1.45; }

/* ============================================================
   SLIDE 14 — POSITIONNEMENT (énoncé + 3 axes)
   ============================================================ */
.positioning-quote {
  background: var(--ink);
  color: var(--bg);
  padding: 36px 40px;
  border-radius: 4px;
  font-family: var(--serif);
  font-size: 38px;
  line-height: 1.22;
  letter-spacing: -0.012em;
  margin-bottom: 28px;
}
.positioning-quote em { font-style: italic; color: var(--on-dark-accent); }
.axes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.axis {
  border-top: 2px solid var(--ink);
  padding-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.axis .n { font-family: var(--mono); font-size: 13px; letter-spacing: 0.2em; color: var(--ink-3); }
.axis .t { font-family: var(--serif); font-size: 32px; line-height: 1.08; }
.axis .d { font-size: 16px; color: var(--ink-3); line-height: 1.45; }

/* ============================================================
   SLIDE 15 — CARTE PERCEPTUELLE
   ============================================================ */
.map-wrap { display: grid; grid-template-columns: 1.4fr 1fr; gap: 36px; flex: 1; align-items: stretch; min-height: 0; }
.map {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--rule);
  aspect-ratio: 1.4 / 1;
  max-height: 100%;
  overflow: hidden;
}
.map .axis-x, .map .axis-y { position: absolute; background: var(--ink-4); }
.map .axis-x { left: 6%; right: 6%; bottom: 50%; height: 1px; }
.map .axis-y { top: 6%; bottom: 6%; left: 50%; width: 1px; }
.map .axis-lbl {
  position: absolute;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.map .ax-x-lbl { bottom: 12px; right: 18px; background: var(--surface); padding: 2px 6px; }
.map .ax-y-lbl { top: 18px; left: 14px; writing-mode: vertical-rl; transform: rotate(180deg); background: var(--surface); padding: 6px 2px; }
.map .pt {
  position: absolute;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  gap: 8px;
}
.map .pt .dot {
  width: 12px; height: 12px;
  border-radius: 999px;
  background: var(--ink-3);
  border: 2px solid var(--bg);
  box-shadow: 0 0 0 1px var(--ink-3);
}
.map .pt .lbl { font-family: var(--mono); font-size: 13px; letter-spacing: 0.06em; color: var(--ink-2); }
.map .pt.hero .dot { width: 20px; height: 20px; background: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 0 10px var(--accent-glow); }
.map .pt.hero .lbl { font-family: var(--serif); font-size: 22px; color: var(--accent); letter-spacing: -0.01em; }
.map .pt.lbl-left { flex-direction: row-reverse; }
.map .zone {
  position: absolute;
  top: 6%; right: 6%;
  bottom: 50%; left: 50%;
  background: rgba(27,58,107,.05);
  border: 1px dashed rgba(27,58,107,.3);
}

.map-read .l { font-family: var(--mono); font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 12px; }
.map-read p { font-family: var(--serif); font-size: 24px; line-height: 1.32; margin-bottom: 14px; color: var(--ink); }
.map-read p em { color: var(--accent); font-style: italic; }

/* ============================================================
   SLIDE 16 — PRODUIT (4 couches)
   ============================================================ */
.layers { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; flex: 1; }
.layer {
  padding: 28px 24px;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.layer:first-child { padding-left: 0; }
.layer:not(:first-child) { padding-left: 24px; }
.layer:last-child { border-right: none; }
.layer .n {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--ink-3);
}
.layer .l {
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink);
}
.layer .t { font-family: var(--serif); font-size: 36px; line-height: 1.05; letter-spacing: -0.015em; }
.layer .d { font-size: 16px; color: var(--ink-3); line-height: 1.45; }
.layer .ring {
  width: 72px; height: 72px;
  border-radius: 999px;
  border: 1.5px solid var(--ink);
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-size: 26px;
  margin-bottom: 4px;
}
.layer:nth-child(1) .ring { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.layer:nth-child(2) .ring { background: var(--accent); color: #fff; border-color: var(--accent); }
.layer:nth-child(3) .ring { background: var(--warm); color: #fff; border-color: var(--warm); }
.layer:nth-child(4) .ring { background: var(--surface); color: var(--ink); }

/* ============================================================
   SLIDE 17 — PRIX
   ============================================================ */
.prix { display: grid; grid-template-columns: 1fr 1.2fr; gap: 40px; flex: 1; }
.calc { display: flex; flex-direction: column; gap: 0; }
.calc h3 {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 16px;
}
.calc .row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 16px 0;
  border-bottom: 1px solid var(--rule);
}
.calc .row .k { font-size: 17px; color: var(--ink-2); }
.calc .row .v { font-family: var(--mono); font-size: 20px; color: var(--ink); font-weight: 500; }
.calc .row.sum { border-bottom: 1.5px solid var(--ink); }
.calc .row.sum .k { font-weight: 600; }
.calc .row.final { border-bottom: none; padding-top: 22px; }
.calc .row.final .k { font-family: var(--serif); font-size: 26px; }
.calc .row.final .v { font-family: var(--serif); font-size: 52px; color: var(--accent); letter-spacing: -0.02em; }

.valeur h3 {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 16px;
}
.valeur table { width: 100%; border-collapse: collapse; }
.valeur th {
  text-align: left;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: 12px 8px;
  border-bottom: 1.5px solid var(--ink);
  font-weight: 500;
}
.valeur th.r { text-align: right; }
.valeur td {
  padding: 14px 8px;
  border-bottom: 1px solid var(--rule);
  font-size: 17px;
}
.valeur td.r { text-align: right; font-family: var(--mono); font-size: 18px; }
.valeur tr.us td { background: var(--accent-soft); }
.valeur tr.us td.name { font-weight: 600; color: var(--accent); }
.valeur tr.us td.r { color: var(--accent); font-weight: 600; }

.prix-foot {
  grid-column: 1 / -1;
  margin-top: 20px;
  padding: 22px 28px;
  background: var(--warm-soft);
  border-radius: 4px;
  font-family: var(--serif);
  font-size: 26px;
  line-height: 1.3;
  color: var(--ink);
}
.prix-foot em { color: var(--warm); font-style: italic; }

/* ============================================================
   SLIDE 18 — DISTRIBUTION
   ============================================================ */
.dist { width: 100%; border-collapse: collapse; flex: 1; }
.dist th {
  text-align: left;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: 14px 16px 14px 0;
  border-bottom: 1.5px solid var(--ink);
  font-weight: 500;
}
.dist td {
  padding: 26px 16px 26px 0;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
  font-size: 17px;
  line-height: 1.4;
}
.dist td.type { font-family: var(--mono); font-size: 13px; letter-spacing: 0.2em; }
.dist td.type.direct { color: var(--accent); }
.dist td.type.indirect { color: var(--warm); }
.dist td.canal { font-family: var(--serif); font-size: 28px; letter-spacing: -0.01em; color: var(--ink); }
.dist td.obj { color: var(--ink-2); }
.dist td.seg { font-family: var(--mono); font-size: 15px; color: var(--ink-2); }
.dist-logique {
  margin-top: 22px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  font-family: var(--serif);
  font-size: 26px;
  line-height: 1.32;
}
.dist-logique em { color: var(--accent); font-style: italic; }

/* ============================================================
   SLIDE 19 — COMMUNICATION
   ============================================================ */
.com-quote {
  background: var(--ink);
  color: var(--bg);
  padding: 32px 36px;
  border-radius: 4px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 32px;
  line-height: 1.28;
  margin-bottom: 24px;
}
.com-quote::before { content: '«'; font-size: 64px; color: var(--warm); display: inline-block; margin-right: 6px; line-height: 0; vertical-align: -10px; }
.com-quote::after  { content: ' »'; color: var(--warm); }

.com-table { display: flex; flex-direction: column; gap: 0; }
.com-row {
  display: grid;
  grid-template-columns: 110px 1.4fr 1.4fr 130px 60px;
  align-items: center;
  gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule);
}
.com-row.head {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  border-bottom: 1.5px solid var(--ink);
  padding: 10px 0;
}
.com-row .type {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.com-row .type.push { color: var(--warm); }
.com-row .type.pull { color: var(--accent); }
.com-row .type.both { color: var(--ink); }
.com-row .what { font-family: var(--serif); font-size: 28px; line-height: 1.15; letter-spacing: -0.01em; }
.com-row .why { font-size: 16px; color: var(--ink-3); line-height: 1.4; }
.com-row .budget { font-family: var(--mono); font-size: 24px; text-align: right; font-weight: 500; }
.com-row .pct {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--ink-3);
  text-align: right;
}
.com-row.total {
  border-bottom: none;
  margin-top: 8px;
  padding-top: 18px;
  border-top: 1.5px solid var(--ink);
}
.com-row.total .what { font-family: var(--serif); font-size: 28px; }
.com-row.total .budget { font-family: var(--serif); font-size: 42px; color: var(--accent); letter-spacing: -0.02em; }

/* ============================================================
   SLIDE 20 — PERFORMANCE
   ============================================================ */
.perf { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; flex: 1; }
.perf-cell {
  padding: 30px 28px 30px 0;
  border-right: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.perf-cell:first-child { padding-left: 0; }
.perf-cell:not(:first-child) { padding-left: 28px; }
.perf-cell:last-child { border-right: none; }
.perf-cell .l { font-family: var(--mono); font-size: 14px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink); }
.perf-cell .v { font-family: var(--serif); font-size: 112px; line-height: 0.95; letter-spacing: -0.03em; }
.perf-cell .v.pos { color: var(--positive); }
.perf-cell .v.neg { color: var(--negative); }
.perf-cell .v.warm { color: var(--accent); }
.perf-cell .vs { display: flex; align-items: baseline; gap: 8px; font-size: 16px; color: var(--ink-3); border-top: 1px solid var(--rule); padding-top: 10px; }
.perf-cell .vs .ind { font-family: var(--mono); color: var(--ink-2); }
.perf-cell .verdict {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.perf-cell .verdict.pos { color: var(--positive); }
.perf-cell .verdict.neg { color: var(--negative); }
.perf-cell .verdict.warm { color: var(--accent); }
.perf-cell .desc { font-size: 16px; color: var(--ink-3); line-height: 1.4; }
.perf-sensi {
  margin-top: 26px;
  padding: 24px 28px;
  background: var(--warm-soft);
  border-left: 3px solid var(--warm);
  font-family: var(--serif);
  font-size: 26px;
  line-height: 1.32;
}
.perf-sensi em { color: var(--warm); font-style: italic; }

/* ============================================================
   SLIDE 21 — CONCLUSION
   ============================================================ */
.concl { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; flex: 1; align-content: start; }
.concl-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-top: 2px solid var(--ink);
  padding-top: 24px;
}
.concl-card .n { font-family: var(--mono); font-size: 14px; letter-spacing: 0.2em; color: var(--accent); }
.concl-card .t { font-family: var(--serif); font-size: 42px; line-height: 1.1; letter-spacing: -0.015em; }
.concl-card .d { font-size: 17px; color: var(--ink-3); line-height: 1.5; }

/* ============================================================
   SLIDE 22 — MERCI
   ============================================================ */
.merci {
  padding: 0;
  background: var(--ink);
  color: var(--bg);
}
.merci-grid {
  display: grid;
  grid-template-columns: 1fr;
  height: 100%;
  padding: 96px 120px;
  position: relative;
}
.merci .top { font-family: var(--mono); font-size: 15px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(244,237,224,0.5); }
.merci .big {
  font-family: var(--serif);
  font-size: 280px;
  line-height: 0.94;
  letter-spacing: -0.035em;
  margin-top: auto;
  margin-bottom: 20px;
}
.merci .big em { font-style: italic; color: var(--on-dark-accent); }
.merci .qst { font-family: var(--serif); font-style: italic; font-size: 56px; color: rgba(244,237,224,0.7); line-height: 1.15; margin-bottom: 64px; }
.merci .ret {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 32px;
  align-items: baseline;
  padding-top: 28px;
  border-top: 1px solid rgba(244,237,224,0.18);
}
.merci .ret .l { font-family: var(--mono); font-size: 13px; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(244,237,224,0.5); }
.merci .ret .v { font-family: var(--serif); font-size: 36px; line-height: 1.2; color: var(--bg); }
.merci .ret .v em { color: var(--on-dark-accent); font-style: italic; }
.merci .credits {
  position: absolute;
  bottom: 50px;
  right: 120px;
  text-align: right;
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.2em;
  color: rgba(244,237,224,0.5);
  text-transform: uppercase;
}

/* ============================================================
   PRINT
   ============================================================ */
/* ============================================================
   PALETTE FLOTTANTE
   ============================================================ */
.palette-toggle {
  position: fixed;
  bottom: 18px;
  right: 66px;
  z-index: 9999;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: rgba(20,20,15,0.72);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background .18s ease, transform .18s ease;
}
.palette-toggle:hover { background: rgba(20,20,15,0.95); transform: scale(1.05); }
.palette-toggle svg { width: 18px; height: 18px; stroke: #fff; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.palette-panel {
  position: fixed;
  bottom: 70px;
  right: 18px;
  z-index: 9999;
  width: 296px;
  background: rgba(252, 250, 244, 0.97);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 14px;
  padding: 18px;
  box-shadow: 0 24px 64px rgba(0,0,0,0.20), 0 4px 12px rgba(0,0,0,0.08);
  font-family: var(--sans);
  color: var(--ink);
  transform-origin: bottom right;
  animation: paletteIn 0.22s cubic-bezier(.2,.7,.25,1.2);
}
.palette-panel[hidden] { display: none; }

@keyframes paletteIn {
  from { opacity: 0; transform: scale(0.92) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.palette-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.palette-head .ttl {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
  font-weight: 500;
}
.palette-close {
  width: 26px; height: 26px;
  border: none;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  color: var(--ink-3);
  display: grid;
  place-items: center;
  border-radius: 999px;
  padding: 0;
  font-family: var(--sans);
}
.palette-close:hover { background: rgba(0,0,0,0.06); color: var(--ink); }

.palette-group { margin-bottom: 16px; }
.palette-group:last-child { margin-bottom: 0; }
.palette-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 10px;
}
.swatches {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.swatch {
  width: 32px; height: 32px;
  border-radius: 999px;
  border: 1.5px solid rgba(0,0,0,0.10);
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
  padding: 0;
  position: relative;
}
.swatch:hover { transform: scale(1.10); }
.swatch.active {
  box-shadow: 0 0 0 2px rgba(255,255,255,0.95), 0 0 0 4px var(--ink);
  transform: scale(1.05);
}
.swatch[title]:hover::after {
  content: attr(title);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink);
  color: #fff;
  padding: 4px 8px;
  border-radius: 4px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  white-space: nowrap;
  pointer-events: none;
}

@media print {
  .palette-toggle, .palette-panel { display: none !important; }
  .fs-btn { display: none !important; }
}
