/* iampoom HTML System V0
   Source: current iampoom.com visual DNA, adapted for local static readers.
   Boundary: internal design artifact, not a public site route. */

:root {
  /* Light C "Cool" — synced from iampoom.com globals.css 2026-05-30 */
  --accent: #2563eb;
  --accent-soft: rgba(37, 99, 235, 0.07);
  --accent-glow: rgba(37, 99, 235, 0.18);
  --ink: #14171c;
  --ink-2: #222730;
  --ink-3: #4d5663;
  --ink-4: #6b7382;
  --line: #e2e7ee;
  --line-strong: #cdd5e0;
  --bg: #f6f8fa;
  --bg-soft: #eef1f5;
  --highlight: rgba(250, 204, 21, 0.25);
  --green: #10b981;
  --green-soft: rgba(16, 185, 129, 0.10);
  --amber: #b7791f;
  --amber-soft: rgba(250, 204, 21, 0.16);
  --red: #b42318;
  --red-soft: rgba(180, 35, 24, 0.08);
  --shadow: 0 1px 2px rgba(0,0,0,0.04), 0 12px 24px -8px rgba(0,0,0,0.08);
  --font-sans: "Geist", "Geist Sans", "IBM Plex Sans Thai", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-thai: "IBM Plex Sans Thai", var(--font-sans);
  --font-mono: "Geist Mono", "SFMono-Regular", Consolas, Menlo, monospace;
  --font-serif: "Instrument Serif", Georgia, serif;
  --reader-scale: 1;
  --shell-max: 1200px;
  --page-title-max: 860px;
  --shell-gutter: 24px;

  /* Print tokens (V0.2) — referenced only inside @media print rules.
     Provide a consistent paper-friendly grayscale palette so Track R / T / P
     print rules do not hardcode colour literals. */
  --print-ink:           #000000;
  --print-ink-2:         #333333;
  --print-ink-3:         #444444;
  --print-ink-4:         #555555;
  --print-bg:            #ffffff;
  --print-bg-soft:       #fafafa;
  --print-bg-softer:     #f8f8f8;
  --print-bg-softest:    #f5f5f5;
  --print-bg-accent:     #f0f4ff;
  --print-line:          #cccccc;
  --print-line-soft:     #eeeeee;
}

html[data-reader-width="readable"] {
  --shell-max: 760px;
  --page-title-max: 760px;
}

html[data-reader-width="wide"] {
  --shell-max: 1200px;
  --page-title-max: 860px;
}

html[data-reader-width="full"] {
  --shell-max: none;
  --page-title-max: 1100px;
}

.dark {
  /* Dark A "Zinc" — synced from iampoom.com globals.css 2026-05-30 */
  --accent: #60a5fa;
  --accent-soft: rgba(96, 165, 250, 0.14);
  --accent-glow: rgba(96, 165, 250, 0.22);
  --ink: #ededed;
  --ink-2: #d6d6d8;
  --ink-3: #a1a1aa;
  --ink-4: #7c7c85;
  --line: #2e2e33;
  --line-strong: #45454c;
  --bg: #18181b;
  --bg-soft: #212124;
  --highlight: rgba(250, 204, 21, 0.22);
  --shadow: 0 1px 2px rgba(0,0,0,0.4), 0 12px 24px -8px rgba(0,0,0,0.6);
}

html[data-reader-size="compact"] { --reader-scale: 0.94; }
html[data-reader-size="comfortable"] { --reader-scale: 1; }
html[data-reader-size="large"] { --reader-scale: 1.12; }

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: 72px;
  background: var(--bg);
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-thai);
  font-feature-settings: "cv11", "ss01", "ss03";
  line-height: 1.75;
  letter-spacing: 0;
  transition: background-color 240ms ease, color 240ms ease;
}

a { color: inherit; }

code {
  overflow-wrap: anywhere;
  word-break: break-word;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

*:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 2px;
}

.skip-link {
  position: absolute;
  left: 12px;
  top: 12px;
  transform: translateY(-160%);
  z-index: 100;
  padding: 8px 10px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 12px;
}

.skip-link:focus { transform: translateY(0); }

.topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  border-bottom: 1px solid var(--line);
  backdrop-filter: saturate(140%) blur(10px);
}

.topbar__inner {
  width: 100%;
  max-width: var(--shell-max, 1200px);
  min-height: 56px;
  margin: 0 auto;
  padding: 10px var(--shell-gutter, 24px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.brand {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  gap: 10px;
  color: var(--ink);
  text-decoration: none;
}

.brand__mark {
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
  display: block;
}

.brand__text {
  display: grid;
  gap: 1px;
  min-width: 0;
}

.brand__name {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  white-space: nowrap;
}

.brand__sub {
  font-family: var(--font-mono);
  font-size: 10px;
  line-height: 1.2;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink-4);
  white-space: nowrap;
}

.topbar__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}

.reader-size,
.reader-width,
.theme-toggle {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--ink);
}

.reader-size,
.reader-width {
  border-radius: 999px;
  padding: 3px;
  gap: 2px;
}

.reader-size__label,
.reader-width__label {
  padding: 0 7px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 10px;
}

.reader-size button,
.reader-width button,
.theme-toggle {
  min-width: 30px;
  height: 28px;
  padding: 0 8px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
}

.reader-size button[aria-pressed="true"],
.reader-width button[aria-pressed="true"] {
  color: #ffffff;
  background: var(--accent);
}

.theme-toggle {
  justify-content: center;
  padding: 0 9px;
  border-radius: 999px;
}

.theme-toggle[aria-pressed="true"] {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-soft);
}

.shell {
  width: 100%;
  max-width: var(--shell-max, 1200px);
  margin: 0 auto;
  padding: 48px var(--shell-gutter) 80px;
}

.page-head {
  position: relative;
  overflow: hidden;
  padding: 38px 0 32px;
  border-bottom: 1px solid var(--line);
}

.page-head::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(ellipse 80% 50% at 85% 0%, var(--accent-soft), transparent 60%),
    linear-gradient(135deg, var(--bg) 0%, color-mix(in oklab, var(--bg) 98%, var(--ink)) 42%, var(--bg) 100%);
}

.page-head::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(0,0,0,0.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0,0,0,0.025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: linear-gradient(to bottom, #000 60%, transparent 100%);
}

.dark .page-head::after {
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

.page-head__terminal {
  margin: 24px 0 16px;
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-3);
}

.cursor-blink {
  display: inline-block;
  width: 0.5em;
  height: 0.9em;
  margin-left: 4px;
  vertical-align: -0.05em;
  border-radius: 1px;
  background: var(--accent);
  animation: blink 1.1s steps(1) infinite;
}

@keyframes blink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } }

.page-title {
  max-width: var(--page-title-max, 860px);
  margin: 0;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: clamp(38px, 7vw, 76px);
  line-height: 0.98;
  font-weight: 650;
  letter-spacing: -0.04em;
}

.page-title .accent { color: var(--accent); }

.page-lede {
  max-width: 760px;
  margin: 22px 0 0;
  color: var(--ink-2);
  font-size: calc(17px * var(--reader-scale));
  line-height: 1.75;
}

.meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.tag,
.status {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  gap: 6px;
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--bg);
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  line-height: 1.25;
  text-transform: none;
}

.status::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}

.status--ok { color: var(--green); background: var(--green-soft); border-color: transparent; }
.status--warn { color: var(--amber); background: var(--amber-soft); border-color: transparent; }
.status--bad { color: var(--red); background: var(--red-soft); border-color: transparent; }
.status--info { color: var(--accent); background: var(--accent-soft); border-color: transparent; }
.status--mute { color: var(--ink-4); background: var(--bg-soft); }

.reader-layout {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 40px;
  align-items: start;
  margin-top: 42px;
}

.toc {
  position: sticky;
  top: 86px;
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--line);
  background: var(--bg);
}

.toc__label {
  margin: 0 0 5px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.toc__link {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 8px;
  border-left: 2px solid transparent;
  color: var(--ink-3);
  font-size: 13px;
  line-height: 1.35;
  text-decoration: none;
}

.toc__link:hover,
.toc__link[aria-current="true"] {
  color: var(--ink);
  border-left-color: var(--accent);
  background: var(--accent-soft);
}

.toc__num {
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
}

.content {
  min-width: 0;
  display: grid;
  gap: 22px;
}

.section,
.card,
.note {
  border: 1px solid var(--line);
  background: var(--bg);
}

.section {
  min-width: 0;
  padding: 28px;
  scroll-margin-top: 72px;
}

.section__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}

.section__num {
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
}

h2,
h3,
p {
  margin-top: 0;
}

h2 {
  margin-bottom: 0;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: calc(25px * var(--reader-scale));
  line-height: 1.22;
  font-weight: 620;
  letter-spacing: -0.025em;
}

h3 {
  margin-bottom: 8px;
  color: var(--ink);
  font-size: calc(18px * var(--reader-scale));
  line-height: 1.32;
  font-weight: 620;
  letter-spacing: -0.01em;
}

p,
li {
  color: var(--ink-2);
  font-size: calc(16px * var(--reader-scale));
}

p:last-child { margin-bottom: 0; }

mark,
.mark {
  padding: 0 3px;
  background: linear-gradient(180deg, transparent 58%, var(--highlight) 58%);
  color: inherit;
}

.grid {
  display: grid;
  gap: 14px;
}

.grid--two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--three { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.card {
  padding: 16px;
  transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.card:hover {
  border-color: var(--line-strong);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}

.metric__label,
.card__label {
  margin-bottom: 6px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
}

.metric__value {
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: calc(26px * var(--reader-scale));
  line-height: 1.15;
  font-weight: 650;
  letter-spacing: -0.03em;
}

.metric__sub,
.card__sub {
  margin-top: 6px;
  color: var(--ink-3);
  font-size: calc(13px * var(--reader-scale));
  line-height: 1.55;
}

.timeline,
.checklist,
.source-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.timeline__item {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.timeline__date {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.45;
}

.timeline__body {
  min-width: 0;
}

.timeline__body h3,
.timeline__body h4 {
  overflow-wrap: anywhere; /* prevent long machine tokens (e.g. ALL_CAPS_STATUS_CODES) from overflowing at mobile */
}

.timeline__body p {
  margin: 4px 0 0;
  color: var(--ink-3);
  font-size: calc(14px * var(--reader-scale));
}

.check {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.check__box {
  width: 14px;
  height: 14px;
  margin-top: 5px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
}

.check--done .check__box {
  border-color: var(--accent);
  background: var(--accent);
  box-shadow: inset 0 0 0 3px var(--bg);
}

.check__title {
  color: var(--ink);
  font-weight: 620;
  overflow-wrap: anywhere;
}

.check__note {
  margin-top: 2px;
  color: var(--ink-3);
  font-size: calc(13px * var(--reader-scale));
  overflow-wrap: anywhere;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--line);
}

table {
  width: 100%;
  min-width: 680px;
  border-collapse: collapse;
}

th,
td {
  padding: 12px 13px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
  font-size: calc(14px * var(--reader-scale));
}

th {
  color: var(--ink-4);
  background: var(--bg-soft);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

tr:last-child td { border-bottom: 0; }

.note {
  padding: 16px;
  border-left: 3px solid var(--accent);
  background: var(--accent-soft);
}

.note--warn {
  border-left-color: var(--amber);
  background: var(--amber-soft);
}

.source {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.source__kind {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
}

.source__path {
  min-width: 0;
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: calc(12px * var(--reader-scale));
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.source__copy {
  align-self: start;
  padding: 3px 9px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--bg);
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  cursor: pointer;
  transition: color 150ms ease, border-color 150ms ease, background 150ms ease;
}

.source__copy:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.source__copy[data-state="copied"] {
  color: var(--green);
  border-color: var(--green);
  background: var(--green-soft);
}

.footer {
  margin-top: 42px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
}

.template-note {
  margin-top: 12px;
  color: var(--ink-4);
  font-size: 12px;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

@media (max-width: 860px) {
  .topbar__inner {
    flex-wrap: wrap;
    align-items: flex-start;
    padding: 10px 16px;
  }

  .brand {
    flex: 1 1 100%;
  }

  .topbar__actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .shell {
    padding: 30px 14px 60px;
  }

  .page-head {
    padding: 28px 0 26px;
  }

  .reader-layout {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .toc {
    position: relative;
    top: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .toc__label {
    grid-column: 1 / -1;
  }

  .grid--two,
  .grid--three {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 560px) {
  .brand__sub {
    white-space: normal;
  }

  .page-title {
    font-size: 42px;
  }

  .page-lede {
    font-size: calc(15px * var(--reader-scale));
  }

  .section {
    padding: 18px;
  }

  .section__head {
    display: grid;
    gap: 6px;
  }

  .toc {
    grid-template-columns: 1fr;
  }

  .timeline__item,
  .source {
    grid-template-columns: 1fr;
  }

  .source__copy {
    justify-self: start;
  }

  .table-wrap {
    overflow-x: visible;
    border: 0;
  }

  table {
    width: 100%;
    min-width: 0;
    table-layout: auto;
    border: 0;
  }

  thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  table tr {
    display: block;
    margin-bottom: 10px;
    padding: 4px 0;
    border: 1px solid var(--line);
    background: var(--bg-soft);
  }

  table tr:last-child {
    margin-bottom: 0;
  }

  table td {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 8px;
    align-items: baseline;
    padding: 8px 12px;
    border-bottom: 0;
    word-break: break-word;
  }

  table td::before {
    content: attr(data-label);
    color: var(--ink-4);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
  }

  table td[data-label=""]::before,
  table td:not([data-label])::before {
    content: "";
  }

  .status,
  .tag {
    white-space: normal;
  }
}

@media print {
  html {
    scroll-padding-top: 0;
    background: #ffffff !important;
  }

  body {
    background: #ffffff !important;
    color: #000000 !important;
    font-family: var(--font-thai);
    line-height: 1.55;
  }

  .skip-link,
  .topbar,
  .reader-size,
  .reader-width,
  .theme-toggle,
  .cursor-blink,
  .page-head__terminal,
  .source__copy {
    display: none !important;
  }

  .page-head {
    padding-top: 0;
    border-bottom: 1px solid #cccccc;
  }

  .page-head::before,
  .page-head::after {
    display: none !important;
  }

  .shell {
    max-width: none !important;
    padding: 16px 0 24px !important;
  }

  .reader-layout {
    display: block !important;
    margin-top: 18px;
  }

  .toc {
    position: static !important;
    grid-template-columns: none !important;
    display: block !important;
    margin-bottom: 16px;
    padding: 0 0 10px;
    border: 0;
    border-bottom: 1px solid #cccccc;
    background: transparent !important;
  }

  .toc__label {
    display: block;
    margin-bottom: 4px;
  }

  .toc__link {
    display: inline-block;
    margin: 0 14px 4px 0;
    padding: 0;
    border-left: 0 !important;
    background: transparent !important;
    color: #000000 !important;
  }

  .toc__num {
    color: #555555 !important;
  }

  .content {
    display: block !important;
  }

  .section,
  .card,
  .timeline__item,
  .check,
  .source,
  .note {
    page-break-inside: avoid;
    break-inside: avoid;
    background: #ffffff !important;
    border: 1px solid #cccccc !important;
    box-shadow: none !important;
  }

  .section {
    margin-bottom: 14px;
  }

  .section__head,
  th {
    background: transparent !important;
  }

  h2,
  h3,
  p,
  li,
  td,
  .source__path {
    color: #000000 !important;
  }

  a {
    color: #000000 !important;
    text-decoration: underline;
  }

  a[href^="http"]::after,
  a[href^="/"]::after {
    content: " (" attr(href) ")";
    font-size: 0.85em;
    color: #555555 !important;
  }

  .table-wrap {
    overflow: visible !important;
    border: 1px solid #cccccc;
  }

  table {
    min-width: 0 !important;
    table-layout: auto !important;
  }

  th {
    color: #333333 !important;
    background: #f5f5f5 !important;
  }

  thead {
    position: static !important;
    width: auto;
    height: auto;
    clip: auto;
    overflow: visible;
  }

  table tr {
    display: table-row !important;
    border: 0 !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  table td {
    display: table-cell !important;
    grid-template-columns: none !important;
    border-bottom: 1px solid #eeeeee !important;
    padding: 8px 10px !important;
  }

  table td::before {
    content: "" !important;
  }

  .status,
  .tag {
    background: #ffffff !important;
    color: #000000 !important;
    border: 1px solid #000000 !important;
  }

  .note {
    border-left: 3px solid #000000 !important;
  }

  .footer {
    border-top: 1px solid #cccccc;
    color: #555555 !important;
  }
}

/* ============================================================
   Track T · Transcript Summary (promoted from lab in V0.2)
   ------------------------------------------------------------
   Visual identity: transcript-review surface.
   - .transcript-block · verbatim/near-verbatim excerpt with timestamp +
     speaker label (mono, sober, scrollable as needed).
   - .confidence-badge · explicit uncertainty signal on summary blocks.
   - .action-row · extends shared .check with a third auto column for
     a per-row status pill (pending / open / done).
   All values reference shared tokens only; no new colour literals.
   ============================================================ */

.transcript-block {
  padding: 16px 18px 16px 20px;
  border: 1px solid var(--line);
  border-left: 3px solid var(--ink-4);
  background: var(--bg-soft);
  font-family: var(--font-mono);
  font-size: calc(13px * var(--reader-scale));
  line-height: 1.9;
  color: var(--ink-2);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.transcript-block .ts {
  color: var(--ink-4);
  font-size: 11px;
  margin-right: 6px;
  user-select: none;
}

.transcript-block .speaker-label {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  margin-right: 8px;
}

.confidence-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.confidence-badge::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
}

.confidence-badge--high   { color: var(--green); background: var(--green-soft); }
.confidence-badge--medium { color: var(--amber); background: var(--amber-soft); }
.confidence-badge--low    { color: var(--red);   background: var(--red-soft);   }

.action-row {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr) auto;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  align-items: start;
}

.action-row--done .check__box {
  border-color: var(--accent);
  background: var(--accent);
  box-shadow: inset 0 0 0 3px var(--bg);
}

.action-row__title {
  display: block;
  color: var(--ink);
  font-weight: 620;
  font-size: calc(15px * var(--reader-scale));
}

.action-row--done .action-row__title {
  color: var(--ink-3);
  text-decoration: line-through;
}

.action-row__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.action-row__owner,
.action-row__due {
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
}

.action-row__owner::before { content: "owner: "; }
.action-row__due::before   { content: "due: "; }

@media (max-width: 560px) {
  .action-row {
    grid-template-columns: 18px minmax(0, 1fr);
  }

  .action-row > .status,
  .action-row > .tag {
    grid-column: 2 / -1;
    justify-self: start;
  }
}

/* ============================================================
   Track P · Presentation Brief (promoted from lab in V0.2)
   ------------------------------------------------------------
   Visual identity: briefing deck reader.
   - .brief-cover · replaces .page-head; serif title + metadata grid
     (date / presenter / audience / classification / version / status).
   - .frame · slide-like content block with header (num + title + status)
     and body with bullet points.
   - .ask-box · accent-bordered emphasis box for the decision/ask.
   - .talking-points / .speaker-note · structured speaker notes for
     live delivery; printable as briefing prep material.
   Print colors use --print-* tokens (defined in :root) — no hardcoded
   colour literals in the print block.
   ============================================================ */

.brief-cover {
  position: relative;
  overflow: hidden;
  padding: 48px 0 40px;
  border-bottom: 1px solid var(--line);
}

.brief-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: radial-gradient(ellipse 60% 70% at 92% -5%, var(--accent-soft), transparent 58%);
}

.brief-cover__type {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.brief-cover__type::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  flex: 0 0 auto;
}

.brief-title {
  max-width: 820px;
  margin: 0 0 14px;
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: clamp(36px, 6.5vw, 68px);
  line-height: 1.04;
  font-weight: 400;
  letter-spacing: -0.02em;
}

.brief-title .accent { color: var(--accent); }

.brief-subject {
  max-width: 700px;
  margin: 0 0 28px;
  color: var(--ink-3);
  font-family: var(--font-sans);
  font-size: calc(17px * var(--reader-scale));
  line-height: 1.65;
}

.brief-meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 10px;
  max-width: 760px;
  margin-top: 6px;
}

.brief-meta-cell {
  padding: 10px 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.brief-meta-cell__label {
  margin-bottom: 3px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.brief-meta-cell__value {
  color: var(--ink-2);
  font-size: calc(14px * var(--reader-scale));
  line-height: 1.4;
}

.frames {
  display: grid;
  gap: 14px;
}

.frame {
  border: 1px solid var(--line);
  background: var(--bg);
  overflow: hidden;
}

.frame__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 11px 18px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-soft);
}

.frame__num {
  flex: 0 0 auto;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.frame__title {
  flex: 1 1 auto;
  margin: 0;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: calc(16px * var(--reader-scale));
  font-weight: 620;
  line-height: 1.3;
  letter-spacing: -0.01em;
}

.frame__status { flex: 0 0 auto; }

.frame__body {
  padding: 18px 20px;
}

.frame__body > p:last-child { margin-bottom: 0; }

.frame__points {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.frame__point {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 11px 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.frame__point::before {
  content: "→";
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.55;
  margin-top: 1px;
}

.frame__point-body { min-width: 0; }

.frame__point-title {
  color: var(--ink);
  font-weight: 620;
  font-size: calc(15px * var(--reader-scale));
  line-height: 1.4;
}

.frame__point-note {
  margin-top: 3px;
  color: var(--ink-3);
  font-size: calc(13px * var(--reader-scale));
  line-height: 1.55;
}

.ask-box {
  padding: 22px 26px;
  border: 2px solid var(--accent);
  background: var(--accent-soft);
}

.ask-box__label {
  margin-bottom: 10px;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.ask-box h3 {
  margin-bottom: 8px;
  font-size: calc(20px * var(--reader-scale));
}

.ask-box p { font-size: calc(16px * var(--reader-scale)); }
.ask-box p:last-child { margin-bottom: 0; }

.speaker-note {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-left: 3px solid var(--ink-4);
  background: var(--bg-soft);
}

.speaker-note__label {
  margin-bottom: 6px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.speaker-note p {
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: calc(13px * var(--reader-scale));
  line-height: 1.7;
}

.speaker-note p:last-child { margin-bottom: 0; }

.talking-points {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.talking-point {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.talking-point__num {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.6;
}

.talking-point__body {
  min-width: 0;
  color: var(--ink-2);
  font-size: calc(15px * var(--reader-scale));
  line-height: 1.65;
}

@media (max-width: 560px) {
  .brief-meta-grid {
    grid-template-columns: 1fr 1fr;
  }

  .brief-title {
    font-size: 34px;
  }

  .brief-subject {
    font-size: calc(15px * var(--reader-scale));
  }

  .frame__header {
    flex-wrap: wrap;
    gap: 8px;
  }

  .frame__body {
    padding: 14px 16px;
  }

  .ask-box {
    padding: 16px 18px;
  }
}

@media print {
  .brief-cover::before { display: none !important; }

  .brief-title {
    font-size: 38px !important;
    color: var(--print-ink) !important;
  }

  .brief-subject { color: var(--print-ink-3) !important; }

  .brief-meta-grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }

  .brief-meta-cell {
    background: var(--print-bg-softer) !important;
    border-color: var(--print-line) !important;
  }

  .brief-meta-cell__label,
  .brief-meta-cell__value { color: var(--print-ink-2) !important; }

  .frames { display: block !important; }

  .frame {
    page-break-inside: avoid;
    break-inside: avoid;
    margin-bottom: 12px;
    border: 1px solid var(--print-line) !important;
  }

  .frame__header {
    background: var(--print-bg-softest) !important;
    border-bottom-color: var(--print-line) !important;
  }

  .frame__num   { color: var(--print-ink-3) !important; }
  .frame__title { color: var(--print-ink) !important; }

  .frame__point {
    page-break-inside: avoid;
    break-inside: avoid;
    background: var(--print-bg-soft) !important;
    border-color: var(--print-line) !important;
  }

  .frame__point::before  { color: var(--print-ink-4) !important; }
  .frame__point-title    { color: var(--print-ink) !important; }
  .frame__point-note     { color: var(--print-ink-4) !important; }

  .ask-box {
    page-break-inside: avoid;
    break-inside: avoid;
    border: 2px solid var(--print-ink) !important;
    background: var(--print-bg-accent) !important;
  }

  .ask-box__label  { color: var(--print-ink-2) !important; }
  .ask-box h3      { color: var(--print-ink) !important; }
  .ask-box p       { color: var(--print-ink-2) !important; }

  .speaker-note {
    page-break-inside: avoid;
    break-inside: avoid;
    border-left-color: var(--print-ink-4) !important;
    background: var(--print-bg-softer) !important;
  }

  .speaker-note__label,
  .speaker-note p { color: var(--print-ink-3) !important; }

  .talking-point {
    page-break-inside: avoid;
    break-inside: avoid;
    background: var(--print-bg-soft) !important;
    border-color: var(--print-line) !important;
  }

  .talking-point__num   { color: var(--print-ink-3) !important; }
  .talking-point__body  { color: var(--print-ink-2) !important; }
}

/* ============================================================
   Track P2 · Controlled 16:9 HTML Slide Deck (V0.2 add-on)
   ------------------------------------------------------------
   Distinct from Track P1 (which is a long-form briefing reader).
   P2 is a real slide stage:
     - .deck                  · max-width wrapper centred under .shell
     - .deck__stage           · 16:9 aspect-ratio frame · positioning context
     - .slide                 · absolute-positioned · only .is-active shows
     - .slide__inner          · padded content region · container-query scaled
     - .slide__kicker / __title / __body / __bullets · slide vocabulary
     - .deck-controls         · prev/next/counter/notes-toggle bar below stage
     - .deck-notes            · presenter notes panel (toggleable)
   Mobile fallback (<860px):
     - Stage drops position:absolute and becomes a vertical stack of 16:9 frames
     - Prev/next/counter chrome hides; notes panel inlines per slide
   Print:
     - Each slide becomes its own 16:9 page via page-break-after
     - Chrome and counter hidden; presenter notes flow after each slide
   ============================================================ */

.shell--deck {
  --shell-max: 1240px;
}

.deck {
  --deck-max: 1180px;
  max-width: var(--deck-max);
  margin: 16px auto 0;
}

.deck__stage {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  border: 1px solid var(--line);
  background: var(--bg);
  overflow: hidden;
  /* Container query unit base — slide text scales with stage width */
  container-type: inline-size;
  /* Subtle elevation so the stage reads as a controlled surface */
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
}

.slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 4.2cqi 5.2cqi 4.4cqi;
  background: var(--bg);
  color: var(--ink);
  visibility: hidden;
  opacity: 0;
  transition: opacity 180ms ease;
}

.slide.is-active {
  visibility: visible;
  opacity: 1;
}

.slide__kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  margin-bottom: 2cqi;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 1.2cqi;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.slide__kicker::before {
  content: "";
  width: 0.5em;
  height: 0.5em;
  border-radius: 50%;
  background: var(--accent);
  flex: 0 0 auto;
}

.slide__title {
  margin: 0 0 2.5cqi;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 4.4cqi;
  line-height: 1.06;
  font-weight: 650;
  letter-spacing: -0.025em;
  max-width: 28em;
}

.slide__title .accent { color: var(--accent); }

.slide__lede {
  margin: 0 0 2.5cqi;
  color: var(--ink-3);
  font-family: var(--font-sans);
  font-size: 1.9cqi;
  line-height: 1.45;
  max-width: 40em;
}

.slide__body {
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: 1.7cqi;
  line-height: 1.55;
  max-width: 50em;
}

.slide__body p { margin: 0 0 1.6cqi; }
.slide__body p:last-child { margin-bottom: 0; }

.slide__bullets {
  display: grid;
  gap: 1.2cqi;
  margin: 0;
  padding: 0;
  list-style: none;
}

.slide__bullet {
  display: grid;
  grid-template-columns: 1.6cqi minmax(0, 1fr);
  gap: 1.4cqi;
  align-items: baseline;
  font-size: 1.7cqi;
  color: var(--ink-2);
  line-height: 1.5;
}

.slide__bullet::before {
  content: "→";
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 1.5cqi;
  font-weight: 600;
}

.slide__bullet strong { color: var(--ink); }

.slide__footer {
  margin-top: auto;
  padding-top: 2cqi;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2cqi;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 1.1cqi;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.slide__footer-mark {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
}

.slide__footer-mark::before {
  content: "";
  width: 1.6cqi;
  height: 1.6cqi;
  background: url("../brand/logo-mark.svg") center / contain no-repeat;
  flex: 0 0 auto;
}

.slide__footer-mark:has(.slide__footer-logo)::before {
  display: none;
}

.slide__footer-logo {
  width: 1.6cqi;
  height: 1.6cqi;
  display: block;
  flex: 0 0 auto;
}

/* Presenter notes are part of the slide markup but hidden inside the stage.
   The deck-notes panel below the stage reads from the active slide's notes. */
.slide__notes {
  display: none;
}

/* Cover-style slide: centred, larger title. */
.slide--cover {
  justify-content: center;
}

.slide--cover .slide__title {
  font-size: 5.6cqi;
  max-width: 18em;
}

.slide--cover .slide__lede {
  font-size: 2.2cqi;
  max-width: 32em;
}

/* Closing-style slide variant. */
.slide--closing .slide__title {
  font-size: 4.2cqi;
  max-width: 22em;
}

/* ── Controls ─────────────────────────────────────────────────────────── */

.deck-controls {
  max-width: var(--deck-max, 1180px);
  margin: 14px auto 0;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.deck-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: border-color 150ms ease, color 150ms ease, background 150ms ease;
}

.deck-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.deck-btn[aria-pressed="true"] {
  border-color: var(--accent);
  background: var(--accent);
  color: #ffffff;
}

.deck-btn:disabled {
  color: var(--ink-4);
  cursor: not-allowed;
  border-color: var(--line);
}

.deck-btn:disabled:hover {
  color: var(--ink-4);
}

.deck-counter {
  margin: 0 auto;
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
}

.deck-counter b {
  color: var(--ink);
  font-weight: 600;
}

.deck-btn--toggle[aria-pressed="true"] {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-soft);
}

/* ── Notes panel ──────────────────────────────────────────────────────── */

.deck-notes {
  max-width: var(--deck-max, 1180px);
  margin: 14px auto 0;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  background: var(--bg-soft);
}

.deck-notes[hidden] { display: none; }

.deck-notes__label {
  margin-bottom: 6px;
  color: var(--ink-4);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.deck-notes__body {
  color: var(--ink-2);
  font-size: calc(15px * var(--reader-scale));
  line-height: 1.65;
}

.deck-notes__body p { margin: 0 0 0.7em; }
.deck-notes__body p:last-child { margin-bottom: 0; }
.deck-notes__body em { color: var(--ink-3); font-style: normal; }

/* ── Mobile fallback (<860px): stack slides vertically ───────────────── */

@media (max-width: 860px) {
  .deck {
    margin-top: 8px;
  }

  .deck__stage {
    aspect-ratio: auto;
    height: auto;
    overflow: visible;
    border: 0;
    background: transparent;
    box-shadow: none;
    container-type: normal;
  }

  .slide {
    position: static;
    visibility: visible;
    opacity: 1;
    transition: none;
    aspect-ratio: 16 / 9;
    margin-bottom: 12px;
    border: 1px solid var(--line);
    background: var(--bg);
    padding: 18px 20px;
    container-type: inline-size;
  }

  .slide:last-child { margin-bottom: 0; }

  .slide__kicker { font-size: 1.6cqi; margin-bottom: 1.5cqi; }
  .slide__title  { font-size: 4.6cqi; margin-bottom: 1.8cqi; max-width: none; }
  .slide__lede   { font-size: 2.2cqi; margin-bottom: 1.8cqi; max-width: none; }
  .slide__body   { font-size: 2.0cqi; max-width: none; }
  .slide__bullets { gap: 1.6cqi; }
  .slide__bullet { font-size: 1.9cqi; grid-template-columns: 2cqi minmax(0, 1fr); }
  .slide__footer { font-size: 1.5cqi; }

  .slide--cover .slide__title { font-size: 5.6cqi; max-width: none; }
  .slide--cover .slide__lede  { font-size: 2.4cqi; max-width: none; }

  .deck-controls {
    display: none;
  }

  /* Per-slide notes shown inline below each slide on mobile */
  .slide__notes {
    display: block;
    margin-top: -4px;
    margin-bottom: 16px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-left: 3px solid var(--ink-4);
    background: var(--bg-soft);
    color: var(--ink-3);
    font-family: var(--font-mono);
    font-size: 12px;
    line-height: 1.65;
  }

  .slide__notes::before {
    content: "Notes";
    display: block;
    margin-bottom: 4px;
    color: var(--ink-4);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .deck-notes {
    display: none;
  }
}

/* ── Presentation mode: one 16:9 slide fitted to the viewport ───────────── */

html[data-deck-presenting="true"],
html[data-deck-presenting="true"] body {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--bg);
}

html[data-deck-presenting="true"] .skip-link,
html[data-deck-presenting="true"] .topbar,
html[data-deck-presenting="true"] .page-head,
html[data-deck-presenting="true"] .deck-controls,
html[data-deck-presenting="true"] .deck-notes,
html[data-deck-presenting="true"] .footer {
  display: none !important;
}

html[data-deck-presenting="true"] .shell--deck {
  width: 100vw;
  max-width: none;
  min-height: 100dvh;
  margin: 0;
  padding: 0;
  display: grid;
  place-items: center;
}

html[data-deck-presenting="true"] .deck {
  width: 100vw;
  max-width: none;
  height: 100dvh;
  margin: 0;
  display: grid;
  place-items: center;
  background: var(--bg);
}

html[data-deck-presenting="true"] .deck__stage {
  width: min(100vw, calc(100dvh * 16 / 9));
  height: min(100dvh, calc(100vw * 9 / 16));
  aspect-ratio: 16 / 9;
  border: 0;
  box-shadow: none;
  overflow: hidden;
  container-type: inline-size;
}

html[data-deck-presenting="true"] .slide {
  position: absolute;
  inset: 0;
  display: flex;
  visibility: hidden;
  opacity: 0;
  margin: 0;
  border: 0;
  aspect-ratio: auto;
  padding: 4.2cqi 5.2cqi 4.4cqi;
}

html[data-deck-presenting="true"] .slide.is-active {
  visibility: visible;
  opacity: 1;
}

/* ── Print: each slide its own page ──────────────────────────────────── */

@media print {
  .deck-controls,
  .deck-notes {
    display: none !important;
  }

  .deck {
    max-width: none !important;
    margin: 0 !important;
  }

  .deck__stage {
    aspect-ratio: auto !important;
    height: auto !important;
    overflow: visible !important;
    border: 0 !important;
    background: var(--print-bg) !important;
    box-shadow: none !important;
    container-type: normal !important;
  }

  .slide {
    position: static !important;
    visibility: visible !important;
    opacity: 1 !important;
    transition: none !important;
    page-break-after: always;
    break-after: page;
    page-break-inside: avoid;
    break-inside: avoid;
    aspect-ratio: 16 / 9;
    width: 100%;
    margin: 0 !important;
    border: 1px solid var(--print-line) !important;
    background: var(--print-bg) !important;
    color: var(--print-ink) !important;
    padding: 4cqi 5cqi !important;
    container-type: inline-size !important;
  }

  .slide:last-child {
    page-break-after: auto;
    break-after: auto;
  }

  .slide__kicker { color: var(--print-ink-3) !important; }
  .slide__title  { color: var(--print-ink) !important; }
  .slide__lede   { color: var(--print-ink-2) !important; }
  .slide__body   { color: var(--print-ink-2) !important; }
  .slide__bullet { color: var(--print-ink-2) !important; }
  .slide__bullet::before { color: var(--print-ink-3) !important; }
  .slide__footer { color: var(--print-ink-3) !important; }

  /* Inline notes per slide on print */
  .slide__notes {
    display: block;
    margin-top: 6mm;
    padding: 6mm;
    border: 1px solid var(--print-line) !important;
    border-left: 2px solid var(--print-ink-4) !important;
    background: var(--print-bg-softer) !important;
    color: var(--print-ink-3) !important;
    font-family: var(--font-mono);
    font-size: 10pt;
    page-break-inside: avoid;
    break-inside: avoid;
  }

  .slide__notes::before {
    content: "Presenter notes";
    display: block;
    margin-bottom: 2mm;
    color: var(--print-ink-4) !important;
    font-size: 9pt;
    letter-spacing: 0.06em;
    text-transform: uppercase;
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   Track P2 V0.4 — Slide Variant Extensions
   Added: 2026-05-27
   Variants  : .slide--agenda · .slide--section-divider · .slide--exec-summary
               .slide--cards  · .slide--compare         · .slide--ask
   Primitives: .slide__messages · .slide__cards · .slide__compare · .slide__ask
   These classes are additive. They do not modify any existing selector.
   ═══════════════════════════════════════════════════════════════════════ */

/* ── .slide--agenda ───────────────────────────────────────────────────── */
/* Numbered agenda list. Uses existing .slide__bullets + .slide__bullet
   structure. The variant resets the bullet marker to a mono counter. */

.slide--agenda .slide__bullets {
  counter-reset: agenda-item;
  gap: 0;
}

.slide--agenda .slide__bullet {
  counter-increment: agenda-item;
  grid-template-columns: 5cqi minmax(0, 1fr);
  gap: 1.6cqi;
  font-size: 2.1cqi;
  font-weight: 500;
  color: var(--ink-2);
  align-items: center;
  padding-bottom: 1.4cqi;
  border-bottom: 1px solid var(--line);
}

.slide--agenda .slide__bullet:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.slide--agenda .slide__bullet::before {
  content: counter(agenda-item, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 1.5cqi;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--accent);
}

.slide--agenda .slide__bullet strong {
  color: var(--ink);
  font-weight: 650;
}

/* ── .slide--section-divider ──────────────────────────────────────────── */
/* Full-height centred slide. Large title + one-line purpose.
   Add .slide__section-num before the title for a mono "Section 01" label. */

.slide--section-divider {
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 2cqi;
}

.slide--section-divider .slide__kicker {
  justify-content: center;
}

.slide--section-divider .slide__title {
  font-size: 5.4cqi;
  max-width: 22em;
  text-align: center;
}

.slide--section-divider .slide__lede {
  font-size: 1.9cqi;
  max-width: 40em;
  text-align: center;
}

/* Helper element for the "Section 01" numeric above the title. */
.slide__section-num {
  display: block;
  font-family: var(--font-mono);
  font-size: 1.4cqi;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}

/* ── .slide--exec-summary ─────────────────────────────────────────────── */
/* Three-message grid filling remaining space + "so what" conclusion bar.
   Markup: .slide__title → .slide__messages → .slide__so-what */

.slide__messages {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.8cqi;
  flex: 1 1 0;
  min-height: 0;
}

.slide__message {
  display: flex;
  flex-direction: column;
  gap: 0.8cqi;
  padding: 1.8cqi 1.8cqi;
  border: 1px solid var(--line);
  border-top: 2px solid var(--accent);
  background: var(--bg-soft);
}

.slide__message-label {
  font-family: var(--font-mono);
  font-size: 1.1cqi;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}

.slide__message-title {
  font-family: var(--font-sans);
  font-size: 1.8cqi;
  font-weight: 650;
  line-height: 1.2;
  color: var(--ink);
}

.slide__message-body {
  font-family: var(--font-sans);
  font-size: 1.4cqi;
  line-height: 1.5;
  color: var(--ink-3);
  margin-top: auto;
}

.slide__so-what {
  padding: 1.4cqi 1.8cqi;
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  background: var(--bg-soft);
  font-family: var(--font-sans);
  font-size: 1.6cqi;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
}

.slide__so-what::before {
  content: "So what";
  display: block;
  font-family: var(--font-mono);
  font-size: 1cqi;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 0.5cqi;
}

/* ── .slide--cards ────────────────────────────────────────────────────── */
/* Multi-card grid. Default: 3 columns. Add .slide__cards--2col for 2.
   Markup: .slide__title → .slide__cards > .slide__card (× n) */

.slide__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.8cqi;
  flex: 1 1 0;
  min-height: 0;
}

.slide__cards--2col {
  grid-template-columns: repeat(2, 1fr);
}

.slide__card {
  display: flex;
  flex-direction: column;
  gap: 0.9cqi;
  padding: 1.8cqi 2cqi;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  border-radius: 3px;
}

.slide__card-icon {
  font-family: var(--font-mono);
  font-size: 1.1cqi;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-4);
}

.slide__card-title {
  font-family: var(--font-sans);
  font-size: 1.7cqi;
  font-weight: 650;
  line-height: 1.25;
  color: var(--ink);
}

.slide__card-body {
  font-family: var(--font-sans);
  font-size: 1.4cqi;
  line-height: 1.55;
  color: var(--ink-3);
  margin-top: auto;
}

/* ── .slide--compare ──────────────────────────────────────────────────── */
/* Two-column A vs B comparison. Column A = dimmed "before"; B = accented "after/now".
   Markup: .slide__compare > .slide__compare-col.slide__compare-col--a
                             .slide__compare-col.slide__compare-col--b */

.slide__compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2cqi;
  flex: 1 1 0;
  min-height: 0;
}

.slide__compare-col {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 1.8cqi 2cqi;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  border-top-width: 2px;
}

.slide__compare-col--a {
  border-top-color: var(--line);
  opacity: 0.75;
}

.slide__compare-col--b {
  border-top-color: var(--accent);
  opacity: 1;
}

.slide__compare-head {
  display: flex;
  align-items: center;
  gap: 0.8cqi;
  font-family: var(--font-mono);
  font-size: 1.2cqi;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding-bottom: 1.2cqi;
  margin-bottom: 1.2cqi;
  border-bottom: 1px solid var(--line);
}

.slide__compare-col--b .slide__compare-head {
  color: var(--accent);
}

.slide__compare-items {
  display: grid;
  gap: 0.9cqi;
  margin: 0;
  padding: 0;
  list-style: none;
}

.slide__compare-item {
  display: grid;
  grid-template-columns: 1.4cqi minmax(0, 1fr);
  gap: 1cqi;
  font-size: 1.55cqi;
  line-height: 1.45;
  color: var(--ink-2);
  align-items: baseline;
}

.slide__compare-item::before {
  content: "·";
  font-family: var(--font-mono);
  color: var(--ink-4);
}

.slide__compare-col--b .slide__compare-item {
  color: var(--ink);
}

.slide__compare-col--b .slide__compare-item::before {
  content: "→";
  color: var(--accent);
  font-size: 1.3cqi;
}

/* ── .slide--ask ──────────────────────────────────────────────────────── */
/* Slide-scale ask / decision / recommendation block. Centred layout.
   Markup: .slide__ask > .slide__ask-label
                         .slide__ask-question
                         .slide__ask-body (optional)
                         .slide__ask-options > .slide__ask-option (× n) */

.slide--ask {
  justify-content: center;
}

.slide__ask {
  display: flex;
  flex-direction: column;
  gap: 2.2cqi;
  max-width: 52em;
}

.slide__ask-label {
  font-family: var(--font-mono);
  font-size: 1.1cqi;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
}

.slide__ask-question {
  font-family: var(--font-sans);
  font-size: 3.4cqi;
  font-weight: 650;
  line-height: 1.12;
  color: var(--ink);
  letter-spacing: -0.02em;
}

.slide__ask-body {
  font-family: var(--font-sans);
  font-size: 1.6cqi;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 48em;
}

.slide__ask-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16em, 1fr));
  gap: 1.4cqi;
  margin: 0;
  padding: 0;
  list-style: none;
}

.slide__ask-option {
  padding: 1.4cqi 1.6cqi;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  font-family: var(--font-sans);
  font-size: 1.4cqi;
  line-height: 1.45;
  color: var(--ink-2);
}

.slide__ask-option strong {
  display: block;
  font-size: 1.5cqi;
  font-weight: 650;
  color: var(--ink);
  margin-bottom: 0.4cqi;
}

.slide__ask-option--recommended {
  border-color: var(--accent);
  border-top: 2px solid var(--accent);
}

.slide__ask-option--recommended strong {
  color: var(--accent);
}

/* ── V0.4 mobile overrides (<860px) ──────────────────────────────────── */

@media (max-width: 860px) {
  /* Agenda */
  .slide--agenda .slide__bullet { font-size: 2.3cqi; grid-template-columns: 6cqi minmax(0, 1fr); }
  .slide--agenda .slide__bullet::before { font-size: 1.8cqi; }

  /* Section divider */
  .slide--section-divider .slide__title { font-size: 5.6cqi; }
  .slide--section-divider .slide__lede  { font-size: 2.2cqi; }
  .slide__section-num { font-size: 1.6cqi; }

  /* Exec summary */
  .slide__messages {
    grid-template-columns: 1fr;
    gap: 1.2cqi;
    flex: none;
  }
  .slide__message { padding: 1.4cqi; flex-direction: row; gap: 1.2cqi; align-items: flex-start; }
  .slide__message-label  { font-size: 1.4cqi; flex: 0 0 auto; padding-top: 0.2cqi; }
  .slide__message-title  { font-size: 2.0cqi; }
  .slide__message-body   { font-size: 1.6cqi; }
  .slide__so-what        { font-size: 1.9cqi; }
  .slide__so-what::before { font-size: 1.2cqi; }

  /* Cards */
  .slide__cards { grid-template-columns: repeat(2, 1fr); gap: 1.4cqi; flex: none; }
  .slide__cards--2col { grid-template-columns: 1fr; }
  .slide__card-icon  { font-size: 1.4cqi; }
  .slide__card-title { font-size: 2.0cqi; }
  .slide__card-body  { font-size: 1.7cqi; }

  /* Compare */
  .slide__compare { grid-template-columns: 1fr; gap: 1.4cqi; flex: none; }
  .slide__compare-head { font-size: 1.5cqi; }
  .slide__compare-item { font-size: 1.8cqi; grid-template-columns: 1.8cqi minmax(0, 1fr); }

  /* Ask */
  .slide__ask-label    { font-size: 1.4cqi; }
  .slide__ask-question { font-size: 4.0cqi; }
  .slide__ask-body     { font-size: 1.9cqi; }
  .slide__ask-options  { grid-template-columns: 1fr; gap: 1.2cqi; }
  .slide__ask-option   { font-size: 1.7cqi; }
  .slide__ask-option strong { font-size: 1.8cqi; }
}

/* ── V0.4 print overrides ─────────────────────────────────────────────── */

@media print {
  /* Exec summary */
  .slide__message       { border-top-color: var(--print-ink-3) !important; }
  .slide__message-label { color: var(--print-ink-4) !important; }
  .slide__message-title { color: var(--print-ink) !important; }
  .slide__message-body  { color: var(--print-ink-3) !important; }
  .slide__so-what {
    border-left-color: var(--print-ink-3) !important;
    color: var(--print-ink) !important;
  }
  .slide__so-what::before { color: var(--print-ink-4) !important; }

  /* Cards */
  .slide__card-icon  { color: var(--print-ink-4) !important; }
  .slide__card-title { color: var(--print-ink) !important; }
  .slide__card-body  { color: var(--print-ink-3) !important; }

  /* Compare */
  .slide__compare-col--a,
  .slide__compare-col--b { opacity: 1 !important; }
  .slide__compare-head   { color: var(--print-ink-3) !important; }
  .slide__compare-col--b .slide__compare-head { color: var(--print-ink) !important; }
  .slide__compare-item   { color: var(--print-ink-2) !important; }
  .slide__compare-col--b .slide__compare-item::before { color: var(--print-ink-3) !important; }

  /* Ask */
  .slide__ask-label    { color: var(--print-ink-3) !important; }
  .slide__ask-question { color: var(--print-ink) !important; }
  .slide__ask-body     { color: var(--print-ink-2) !important; }
  .slide__ask-option   { color: var(--print-ink-2) !important; }
  .slide__ask-option strong { color: var(--print-ink) !important; }
}
