

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

html {
  background: var(--bg-app);
  color: var(--fg-1);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  background: var(--bg-app);
  color: var(--fg-1);
  font-family: var(--font-sans);

  
  --viz-focus-fg:     rgb(120, 8, 48);
  --viz-focus-bg:     rgba(120, 8, 48, 0.14);
  --viz-focus-border: rgba(120, 8, 48, 0.45);
  --viz-focus-ring:   rgba(120, 8, 48, 0.30);
  --viz-focus-bar:    rgba(120, 8, 48, 0.38);

  --viz-trip-fg:      rgb(191, 30, 48);
  --viz-trip-bg:      rgba(191, 30, 48, 0.10);
  --viz-trip-border:  rgba(191, 30, 48, 0.50);
  --viz-trip-ring:    rgba(191, 30, 48, 0.32);
}

.container {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 32px;
}
.container--narrow {
  max-width: 760px;
}

section {
  padding: 96px 0;
  border-top: 1px solid var(--border-1);
}
section:first-of-type { border-top: none; }

.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 16px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
}

h1, h2, h3, h4 {
  font-family: var(--font-sans);
  letter-spacing: -0.01em;
  text-wrap: balance;
  margin: 0;
  font-weight: 500;
}

p { margin: 0; }
p + p { margin-top: 16px; }

a { color: var(--brand-5); text-decoration: none; }
a:hover { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }

.topnav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(250, 250, 250, 0.82);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--border-1);
}
.topnav__inner {
  display: flex;
  align-items: center;
  gap: 24px;
  height: 60px;
}
.topnav__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--fg-1);
}
.topnav__brand svg { height: 18px; width: auto; color: var(--fg-1); }
.topnav__brand-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
  border-left: 1px solid var(--border-2);
  padding-left: 12px;
  margin-left: 4px;
}
.topnav__links {
  display: flex;
  gap: 4px;
  margin-left: auto;
  align-items: center;
}
.topnav__links a {
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-2);
  padding: 6px 10px;
  border-radius: 6px;
  transition: background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard);
}
.topnav__links a:hover {
  background: var(--bg-hover);
  color: var(--fg-1);
  text-decoration: none;
}
.topnav__cta {
  background: var(--brand-5);
  color: white !important;
  padding: 8px 14px !important;
  margin-left: 8px;
  font-weight: 500;
}
.topnav__cta:hover {
  background: var(--brand-deep) !important;
  text-decoration: none !important;
}

.hero {
  padding: 120px 0 80px;
  border-top: none !important;
}
.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 28px;
}
.hero__eyebrow .dot {
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--brand-5);
  box-shadow: 0 0 0 4px var(--brand-1);
}
.hero h1 {
  font-size: clamp(40px, 5.6vw, 72px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-weight: 500;
  max-width: 16ch;
  margin-bottom: 28px;
  color: var(--fg-1);
}
.hero h1 em {
  font-style: normal;
  color: var(--brand-5);
}
.hero__lede {
  font-size: 19px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 62ch;
  margin-bottom: 40px;
}
.hero__lede b { font-weight: 500; color: var(--fg-1); }
.hero__meta {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 56px;
}
.hero__meta span:not(:last-child)::after {
  content: "·";
  margin-left: 16px;
  color: var(--fg-muted);
}
.hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
  padding-top: 40px;
  border-top: 1px solid var(--border-1);
}
.stat-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.stat-card__label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
}
.stat-card__big {
  font-family: var(--font-mono);
  font-size: 44px;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--fg-1);
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.stat-card__big .unit {
  font-size: 22px;
  color: var(--fg-3);
  font-weight: 400;
}
.stat-card__big .delta-from {
  color: var(--fg-3);
  text-decoration: line-through;
  text-decoration-color: var(--fg-muted);
  font-weight: 400;
  margin-right: 6px;
}
.stat-card__sub {
  font-size: 13px;
  color: var(--fg-3);
  line-height: 1.5;
  max-width: 28ch;
}

.hero__visual {
  margin-top: 48px;
  padding: 20px;
  border-radius: 10px;
  border: 1px solid var(--border-1);
  background: var(--bg-panel);
}

/* Hero 2×2 conditions matrix — desktop only (see min-width rule below) */
.hero__aside { display: none; }

@media (min-width: 981px) {
  .hero__top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 480px;
    gap: 56px;
    align-items: start;
  }
  .hero__aside { display: block; }
  .matrix--hero {
    position: static;
    top: auto;
    grid-template-columns: 16px 62px 1fr 1fr;
    margin-top: 4px;
  }
  .matrix--hero .matrix__cell { min-height: 0; padding: 13px; gap: 5px; }
  .matrix--hero .matrix__cell-desc { font-size: 11.5px; line-height: 1.45; }
}

.section-head {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 40px;
}
.section-head__num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--brand-5);
  letter-spacing: 0.08em;
}
.section-head__kicker {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-3);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.section-head h2 {
  font-size: 36px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 500;
  max-width: 22ch;
  color: var(--fg-1);
}
.section-intro {
  font-size: 17px;
  line-height: 1.6;
  color: var(--fg-2);
  max-width: 62ch;
  margin-bottom: 40px;
}

.findings {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 48px;
}
.finding {
  display: grid;
  grid-template-columns: 80px 1fr 320px;
  gap: 32px;
  padding: 36px 0;
  border-top: 1px solid var(--border-1);
  align-items: flex-start;
}
.finding:last-child { border-bottom: 1px solid var(--border-1); }
.finding__num {
  font-family: var(--font-mono);
  font-size: 28px;
  color: var(--brand-5);
  font-weight: 500;
  letter-spacing: -0.02em;
}
.finding__body h3 {
  font-size: 22px;
  line-height: 1.25;
  letter-spacing: -0.01em;
  font-weight: 500;
  margin-bottom: 12px;
  color: var(--fg-1);
  max-width: 28ch;
}
.finding__body p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-2);
  max-width: 56ch;
}
.finding__viz {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 16px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
}

.replay {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 12px;
  overflow: hidden;
}

.results-mount {
  margin-top: 8px;
}

.methodology__grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px;
  align-items: start;
}
.methodology__left { align-self: stretch; }
.matrix {
  display: grid;
  grid-template-columns: 18px 100px 1fr 1fr;
  grid-template-rows: 18px 36px 1fr 1fr;
  gap: 8px;
  padding: 20px;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 10px;
  position: sticky;
  top: 76px;
}
.matrix__label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  display: flex;
  align-items: center;
  justify-content: center;
}
.matrix__cell {
  background: var(--bg-app);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 110px;
}
.matrix__cell-name {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--brand-5);
}
.matrix__cell-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--fg-1);
}
.matrix__cell-desc {
  font-size: 12px;
  line-height: 1.5;
  color: var(--fg-3);
}
.matrix__cell--baseline { background: rgba(0,0,0,0.02); }
.matrix__cell--treatment { background: var(--brand-1); border-color: var(--brand-3); }

.matrix-axis {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-2);
  display: flex; align-items: center; justify-content: center;
}
.matrix-axis--y { writing-mode: vertical-rl; transform: rotate(180deg); }

.method-list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.method-item dt {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  margin-bottom: 6px;
}
.method-item dd {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--fg-2);
}
.method-item dd b { font-weight: 500; color: var(--fg-1); }

.faq-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--border-1);
}
.faq-item {
  border-bottom: 1px solid var(--border-1);
  scroll-margin-top: 80px;
}
.faq-item > summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 0;
  display: flex;
  align-items: baseline;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-2);
  transition: color 0.15s ease;
}
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary:hover { color: var(--fg-1); }
.faq-item > summary::after {
  content: "+";
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 18px;
  line-height: 1;
  color: var(--fg-3);
  transition: transform 0.15s ease;
}
.faq-item[open] > summary { color: var(--fg-1); }
.faq-item[open] > summary::after { content: "−"; }
.faq-item__body {
  padding: 4px 0 22px 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--fg-2);
}
.faq-item__body b { font-weight: 500; color: var(--fg-1); }

.methodology__detail {
  margin-top: 44px;
  padding-top: 36px;
  border-top: 1px solid var(--border-1);
}
.method-detail__head { margin-bottom: 18px; }
.method-detail__head .section-head__kicker { display: block; margin-bottom: 8px; }
.method-detail__intro { font-size: 14px; line-height: 1.6; color: var(--fg-2); max-width: 720px; }
.method-detail__intro b { font-weight: 500; color: var(--fg-1); }

.detail-2col {
  display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto 1fr;
  position: relative;
}
.detail-2col::before {
  content: ""; position: absolute; top: 0; bottom: 0; left: 50%; width: 1px;
  background: var(--border-1);
}
.detail-2col .col-l { padding-right: 28px; }
.detail-2col .col-r { padding-left: 28px; }
@media (max-width: 760px) {
  .detail-2col { display: block; }
  .detail-2col::before { display: none; }
  .detail-2col .col-l, .detail-2col .col-r { padding: 0; }
  .detail-2col .method-detail__head.col-r { margin-top: 28px; }
}

.ladder { display: flex; flex-direction: column; gap: 8px; }
.ladder__row {
  flex: 1;
  display: flex; gap: 12px; align-items: flex-start;
  background: rgba(0,0,0,0.02);
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 11px 12px;
}
.ladder__tier {
  font-family: var(--font-mono); font-size: 13px; font-weight: 600;
  color: #fff; border-radius: 6px; padding: 3px 9px; min-width: 34px;
  text-align: center; flex-shrink: 0;
}
.ladder__tier--t1 { background: #c41e3a; }
.ladder__tier--t2 { background: #e85a3d; }
.ladder__tier--t3 { background: #f59e0b; }
.ladder__tier--t4 { background: #fbbf24; color: #3a2a00; }
.ladder__tier--t5 { background: #fde68a; color: #3a2a00; }
.ladder__name { display: block; font-size: 14px; font-weight: 500; color: var(--fg-1); }
.ladder__desc { display: block; font-size: 13px; line-height: 1.5; color: var(--fg-3); margin-top: 3px; }

.paths { display: flex; flex-direction: column; gap: 8px; }
.path {
  flex: 1;
  display: flex; gap: 10px; align-items: flex-start;
  background: rgba(0,0,0,0.02);
  border: 1px solid var(--border-1);
  border-radius: 8px; padding: 10px 12px;
}
.path__id {
  font-family: var(--font-mono); font-size: 13px; font-weight: 600;
  color: var(--fg-1); border: 1px solid var(--border-1);
  border-radius: 6px; padding: 2px 8px; min-width: 26px; text-align: center; flex-shrink: 0;
}
.path__name { display: block; font-size: 13px; font-weight: 500; color: var(--fg-1); }
.path__desc { display: block; font-size: 12px; line-height: 1.45; color: var(--fg-3); margin-top: 3px; }

.model-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.model-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,0.04);
  border: 1px solid var(--border-1);
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-2);
}
.model-chip__dot {
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--brand-5);
  opacity: 0.7;
}

.transcripts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.transcript {
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 10px;
  overflow: hidden;
}
.transcript__head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-1);
  background: rgba(0,0,0,0.02);
  flex-wrap: wrap;
}
.transcript__model {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-1);
}
.transcript__condition {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.transcript__verdict {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 8px;
  border-radius: 4px;
}
.transcript__verdict--tripped {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid var(--danger-border);
}
.transcript__verdict--success {
  background: var(--success-bg);
  color: var(--success-deep);
  border: 1px solid rgba(129,190,76,0.4);
}
.transcript__body {
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.tr-row {
  display: grid;
  grid-template-columns: 56px 80px 1fr;
  gap: 12px;
  font-size: 13px;
  line-height: 1.5;
  align-items: flex-start;
}
.tr-row__t {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-4);
}
.tr-row__role {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
}
.tr-row__role--act { color: var(--brand-5); }
.tr-row__role--obs { color: var(--fg-2); }
.tr-row__role--canary { color: var(--danger); }
.tr-row__txt {
  font-family: var(--font-mono);
  color: var(--fg-1);
  font-size: 12px;
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}
.tr-row__txt em {
  font-style: normal;
  color: var(--fg-2);
}
.tr-row--canary .tr-row__txt {
  color: var(--danger);
}

.cta {
  background: var(--gray-1);
  color: rgba(255,255,255,0.92);
  border-top: none !important;
  position: relative;
  overflow: hidden;
}
.cta__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  align-items: center;
}
.cta h2 {
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 500;
  color: white;
  max-width: 16ch;
  margin-bottom: 20px;
}
.cta p {
  font-size: 17px;
  line-height: 1.55;
  color: rgba(255,255,255,0.65);
  max-width: 48ch;
}
.cta__actions {
  display: flex;
  gap: 12px;
  margin-top: 32px;
  flex-wrap: wrap;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 500;
  font-family: var(--font-sans);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-standard);
  text-decoration: none;
}
.btn--primary {
  background: var(--brand-5);
  color: white;
}
.btn--primary:hover { background: var(--brand-deep); text-decoration: none; }
.btn--ghost-dark {
  background: transparent;
  color: white;
  border-color: rgba(255,255,255,0.2);
}
.btn--ghost-dark:hover {
  background: rgba(255,255,255,0.06);
  text-decoration: none;
}
.cta__panel {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 24px;
}
.cta__panel-title {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.5);
  margin-bottom: 14px;
}
.cta__panel ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cta__panel li {
  font-size: 14px;
  color: rgba(255,255,255,0.85);
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.cta__panel li::before {
  content: "→";
  color: var(--brand-6);
  font-family: var(--font-mono);
  font-size: 13px;
  margin-top: 1px;
}

.footer {
  border-top: 1px solid var(--border-1);
  padding: 32px 0;
  background: var(--bg-app);
}
.footer__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
}
.footer__brand {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--fg-2);
}
.footer__brand svg { height: 14px; color: var(--fg-2); }
.footer__copy {
  font-size: 12px;
  color: var(--fg-3);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}
.footer__links {
  display: flex;
  gap: 18px;
  font-size: 13px;
}
.footer__links a {
  color: var(--fg-3);
}
.footer__links a:hover { color: var(--fg-1); text-decoration: none; }

.replay-mobile-notice {
  display: none;
  background: var(--bg-panel);
  border: 1px solid var(--border-1);
  border-radius: 10px;
  padding: 22px;
  text-align: center;
}
.replay-mobile-notice__kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brand-5);
  margin-bottom: 10px;
}
.replay-mobile-notice__title {
  font-size: 17px;
  font-weight: 500;
  color: var(--fg-1);
  margin-bottom: 8px;
}
.replay-mobile-notice__body {
  font-size: 14px;
  line-height: 1.55;
  color: var(--fg-2);
}

@media (max-width: 980px) {
  section { padding: 64px 0; }
  .hero { padding: 80px 0 56px; }
  .hero__stats { grid-template-columns: 1fr; }
  .finding { grid-template-columns: 60px 1fr; }
  .finding__viz { grid-column: 2; max-width: none; }
  .methodology__grid { grid-template-columns: 1fr; gap: 40px; }
  .matrix { position: static; top: auto; }
  .cta__inner { grid-template-columns: 1fr; gap: 32px; }
  .topnav__links a { display: none; }
  .topnav__links a.topnav__cta { display: inline-flex; }
}

@media (max-width: 640px) {
  .container { padding: 0 20px; }
  section { padding: 56px 0; }

  
  .hero { padding: 56px 0 36px; }
  .hero h1 { font-size: clamp(30px, 9vw, 40px); margin-bottom: 22px; }
  .hero__lede { font-size: 16px; margin-bottom: 28px; }
  .hero__meta { font-size: 11px; margin-bottom: 36px; gap: 10px; }
  .hero__meta span:not(:last-child)::after { margin-left: 10px; }
  .hero__stats { gap: 22px; padding-top: 28px; margin-top: 32px; }
  .stat-card__big { font-size: 34px; }
  .stat-card__big .unit { font-size: 18px; }

  
  .section-head { gap: 10px; margin-bottom: 28px; }
  .section-head h2 { font-size: 28px; max-width: none; }
  .section-intro { font-size: 15px; margin-bottom: 28px; }

  
  .finding { grid-template-columns: 1fr; gap: 10px; padding: 28px 0; }
  .finding__num { font-size: 20px; }
  .finding__body { grid-column: 1; }
  .finding__body h3 { font-size: 20px; max-width: none; }
  .finding__body p { font-size: 14px; }
  .finding__viz { grid-column: 1; margin-top: 8px; }

  
  #replay-mount { display: none; }
  .replay-mobile-notice { display: block; }

  
  .matrix {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 14px;
  }
  .matrix-axis,
  .matrix__label { display: none; }
  .matrix__cell { min-height: 0; padding: 14px; }

  
  .ladder__row, .path { padding: 10px 12px; }
  .path__name { font-size: 12px; }
  .path__desc { font-size: 11.5px; }

  
  .methodology__detail { margin-top: 32px; padding-top: 24px; }

  
  .transcript__head { padding: 12px 14px; gap: 8px; flex-wrap: wrap; }
  .transcript__body { padding: 14px; }
  .tr-row { grid-template-columns: 40px 54px 1fr; gap: 8px; }
  .tr-row__t, .tr-row__role { font-size: 10.5px; }
  .tr-row__txt { font-size: 11.5px; }

  
  .cta__panel { padding: 22px; }

  
  .faq-item > summary { padding: 16px 0; font-size: 11px; gap: 12px; }
  .faq-item > summary::after { font-size: 20px; }

  
  .footer__inner { flex-direction: column; align-items: flex-start; gap: 14px; }


  #tweaks-mount { display: none; }
}

/* ============================================================
   Export PDF button + print utilities
   ============================================================ */

.btn-pdf {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-2);
  background: transparent;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  padding: 6px 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--duration-fast) var(--ease-standard),
              color var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.btn-pdf:hover {
  background: var(--bg-hover);
  color: var(--fg-1);
  border-color: var(--border-strong);
}
.btn-pdf svg { display: block; flex-shrink: 0; }

/* Icon-only on small screens to keep the nav uncluttered */
@media (max-width: 640px) {
  .btn-pdf span { display: none; }
  .btn-pdf { padding: 6px 9px; }
}

.print-only { display: none; }

/* ============================================================
   Print / "Save as PDF" layout
   ============================================================ */

@media print {
  /* Keep brand colours, tier chips and viz bars in the PDF */
  *,
  *::before,
  *::after {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  @page {
    margin: 16mm 14mm;
  }

  html {
    font-size: 15px;
    scroll-behavior: auto;
  }
  html, body {
    background: #fff !important;
    color: #000 !important;
  }

  /* Hide screen-only chrome */
  .topnav,
  .btn-pdf,
  .no-print,
  #replay-mount,
  .hero__aside,
  .cta__actions {
    display: none !important;
  }

  /* Show print-only blocks (e.g. the replay note) */
  .print-only { display: block !important; }
  .replay-print-note {
    background: var(--bg-panel);
    border: 1px solid var(--border-1);
    border-radius: 10px;
    padding: 20px;
    text-align: center;
  }

  /* Full-width content within the page margins */
  .container { max-width: none; padding: 0; }
  section {
    padding: 22px 0 !important;
    border-top: 1px solid #ddd !important;
  }
  section:first-of-type { border-top: none; }

  /* Hero scaled down for paper */
  .hero { padding: 0 0 18px !important; }
  .hero h1 {
    font-size: 30px !important;
    line-height: 1.1 !important;
    max-width: none;
    margin-bottom: 18px;
  }
  .hero__lede { font-size: 13.5px; max-width: none; margin-bottom: 24px; }
  .hero__meta { margin-bottom: 28px; }
  .hero__stats {
    margin-top: 28px;
    padding-top: 24px;
    break-inside: avoid;
  }

  /* Headings stay attached to the content that follows them */
  h1, h2, h3 { break-after: avoid; }
  .section-head { margin-bottom: 26px; break-after: avoid; }
  .section-head h2 { font-size: 26px; }
  .section-intro { font-size: 14px; }

  /* Keep self-contained blocks from splitting across pages */
  .stat-card,
  .finding,
  .matrix,
  .matrix__cell,
  .method-item,
  .ladder__row,
  .path,
  .transcript,
  .tr-row,
  .faq-item,
  .cta__panel { break-inside: avoid; }

  /* Findings: drop the third column, stack the viz under the text */
  .finding {
    grid-template-columns: 44px 1fr !important;
    gap: 8px 24px !important;
    padding: 22px 0 !important;
  }
  .finding__num { font-size: 22px; }
  .finding__body h3 { font-size: 19px; max-width: none; }
  .finding__viz { grid-column: 2 !important; max-width: none; margin-top: 12px; }

  /* Methodology: single column, matrix no longer sticky */
  .methodology__grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .matrix { position: static !important; top: auto !important; }

  /* Lighten the dark CTA so it reads on white paper without flooding ink */
  .cta { background: #fff !important; color: #000 !important; }
  .cta h2 { color: #000 !important; }
  .cta p { color: var(--fg-2) !important; }
  .cta__panel {
    background: #fff !important;
    border: 1px solid #ddd !important;
  }
  .cta__panel-title { color: var(--fg-3) !important; }
  .cta__panel li { color: var(--fg-1) !important; }

  /* Expand FAQ answers (also forced open via beforeprint) */
  .faq-item__body { display: block !important; }

  /* Results table: the on-screen layout scrolls horizontally inside an
     overflow wrapper, which a printer would clip. Release the wrapper and
     fit the table to the page width so every condition column prints. */
  #results-mount div[style*="overflow"] { overflow: visible !important; }
  #results-mount table {
    table-layout: fixed !important;
    width: 100% !important;
    font-size: 10px !important;
  }
  #results-mount th,
  #results-mount td {
    padding: 6px 6px !important;
    white-space: normal !important;
    overflow-wrap: anywhere;
  }
  #results-mount td div,
  #results-mount th div,
  #results-mount td span { min-width: 0 !important; }

  /* Avoid stranded section headings at the foot of a page */
  #findings, #methodology, #results, #transcripts, #conclusions, #faq {
    break-before: auto;
  }

  a { color: #000; text-decoration: none; }
}

