/* Vellum Editorial — Shared Design System */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root {
  /* Severity tiers */
  --dealbreaker: oklch(0.50 0.16 25);
  --dealbreaker-bg: oklch(0.50 0.16 25 / 0.06);
  --dealbreaker-border: oklch(0.50 0.16 25 / 0.28);
  --high: oklch(0.44 0.14 55);
  --high-bg: oklch(0.44 0.14 55 / 0.06);
  --high-border: oklch(0.44 0.14 55 / 0.28);
  --moderate: oklch(0.45 0.02 240);
  --moderate-bg: oklch(0.45 0.02 240 / 0.06);
  --moderate-border: oklch(0.45 0.02 240 / 0.22);
  /* Platform colors */
  --subq: oklch(0.38 0.12 160);
  --subq-bg: oklch(0.38 0.12 160 / 0.06);
  --subq-border: oklch(0.38 0.12 160 / 0.22);
  --claude: oklch(0.40 0.10 245);
  --claude-bg: oklch(0.40 0.10 245 / 0.06);
  --claude-border: oklch(0.40 0.10 245 / 0.22);
  --cursor: oklch(0.42 0.11 295);
  --cursor-bg: oklch(0.42 0.11 295 / 0.06);
  --cursor-border: oklch(0.42 0.11 295 / 0.22);
  --codex: oklch(0.42 0.14 145);
  --codex-bg: oklch(0.42 0.14 145 / 0.06);
  --codex-border: oklch(0.42 0.14 145 / 0.22);
  /* Entity dossier backgrounds */
  --dossier-bg: oklch(0.16 0.02 260 / 0.9);
  --dossier-bg-secondary: oklch(0.14 0.025 260 / 0.85);
  /* Core palette — Star Wars dark space */
  --copper: oklch(0.72 0.14 85);
  --ink: oklch(0.92 0.01 80);
  --bg: oklch(0.10 0.03 265);
  --bg-warm: oklch(0.12 0.025 265);
  --bg-card: oklch(0.15 0.02 265 / 0.85);
  --border: oklch(0.30 0.03 270 / 0.5);
  --border-strong: oklch(0.40 0.04 270 / 0.6);
  --text: oklch(0.90 0.01 80);
  --text-body: oklch(0.82 0.01 80);
  --text-dim: oklch(0.60 0.015 260);
  --text-muted: oklch(0.58 0.02 260);
  --text-label: oklch(0.63 0.015 260);
  --nav-active: oklch(0.72 0.12 160);
  --nav-active-bg: oklch(0.72 0.12 160 / 0.06);
  --nav-active-border: oklch(0.72 0.12 160 / 0.25);
  --ghost: oklch(0.30 0.02 270 / 0.4);
  /* Era accent colors — brightened for dark space background */
  --era-jk2: oklch(0.65 0.14 195);
  --era-jk2-bg: oklch(0.65 0.14 195 / 0.15);
  --era-jk2-border: oklch(0.65 0.14 195 / 0.25);
  --era-jka: oklch(0.68 0.16 85);
  --era-jka-bg: oklch(0.68 0.16 85 / 0.15);
  --era-jka-border: oklch(0.68 0.16 85 / 0.25);
  --era-aim: oklch(0.63 0.12 210);
  --era-aim-bg: oklch(0.63 0.12 210 / 0.15);
  --era-aim-border: oklch(0.63 0.12 210 / 0.25);
  --era-swg: oklch(0.62 0.14 290);
  --era-swg-bg: oklch(0.62 0.14 290 / 0.15);
  --era-swg-border: oklch(0.62 0.14 290 / 0.25);
  --era-joc: oklch(0.60 0.16 15);
  --era-joc-bg: oklch(0.60 0.16 15 / 0.15);
  --era-joc-border: oklch(0.60 0.16 15 / 0.25);
  --era-aj: oklch(0.62 0.16 155);
  --era-aj-bg: oklch(0.62 0.16 155 / 0.18);
  --era-aj-border: oklch(0.62 0.16 155 / 0.25);
  /* Typography */
  --display: 'Bodoni Moda', serif;
  --mono: 'Inconsolata', monospace;
  --body: 'Source Serif 4', serif;
}

html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; background: var(--bg); }

/* ─── STARFIELD + NEBULA ─── */
body {
  position: relative;
  background:
    radial-gradient(ellipse 900px 450px at 15% 25%, oklch(0.30 0.10 290 / 0.28) 0%, transparent 70%),
    radial-gradient(ellipse 700px 350px at 80% 55%, oklch(0.25 0.08 260 / 0.35) 0%, transparent 65%),
    radial-gradient(ellipse 500px 600px at 45% 85%, oklch(0.28 0.06 210 / 0.18) 0%, transparent 60%),
    var(--bg);
  background-attachment: fixed;
}
@keyframes twinkle {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}
body::before, body::after {
  content: '';
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 0;
}
body::before {
  width: 1px; height: 1px;
  box-shadow:
    /* Dense field — small crisp dots across the viewport */
    72px 44px 0 0 rgba(255,255,255,0.7),
    183px 112px 0 0 rgba(255,255,255,0.5),
    291px 203px 0 0 rgba(255,255,255,0.6),
    410px 87px 0 0 rgba(255,255,255,0.45),
    528px 341px 0 0 rgba(255,255,255,0.7),
    635px 156px 0 0 rgba(255,255,255,0.5),
    744px 428px 0 0 rgba(255,255,255,0.65),
    852px 72px 0 0 rgba(255,255,255,0.55),
    961px 319px 0 0 rgba(255,255,255,0.7),
    1073px 193px 0 0 rgba(255,255,255,0.5),
    1185px 461px 0 0 rgba(255,255,255,0.6),
    1298px 38px 0 0 rgba(255,255,255,0.7),
    1407px 285px 0 0 rgba(255,255,255,0.5),
    120px 512px 0 0 rgba(255,255,255,0.55),
    248px 634px 0 0 rgba(255,255,255,0.7),
    365px 573px 0 0 rgba(255,255,255,0.45),
    487px 710px 0 0 rgba(255,255,255,0.6),
    603px 548px 0 0 rgba(255,255,255,0.7),
    715px 682px 0 0 rgba(255,255,255,0.5),
    834px 615px 0 0 rgba(255,255,255,0.65),
    948px 740px 0 0 rgba(255,255,255,0.55),
    1060px 580px 0 0 rgba(255,255,255,0.7),
    1172px 700px 0 0 rgba(255,255,255,0.5),
    1290px 520px 0 0 rgba(255,255,255,0.6),
    1400px 650px 0 0 rgba(255,255,255,0.45),
    55px 830px 0 0 rgba(255,255,255,0.6),
    170px 925px 0 0 rgba(255,255,255,0.5),
    295px 1045px 0 0 rgba(255,255,255,0.7),
    418px 870px 0 0 rgba(255,255,255,0.55),
    540px 960px 0 0 rgba(255,255,255,0.6),
    660px 1100px 0 0 rgba(255,255,255,0.45),
    780px 850px 0 0 rgba(255,255,255,0.7),
    895px 1020px 0 0 rgba(255,255,255,0.5),
    1010px 900px 0 0 rgba(255,255,255,0.65),
    1135px 1080px 0 0 rgba(255,255,255,0.55),
    1255px 830px 0 0 rgba(255,255,255,0.7),
    1370px 950px 0 0 rgba(255,255,255,0.5),
    88px 1190px 0 0 rgba(255,255,255,0.55),
    215px 1310px 0 0 rgba(255,255,255,0.7),
    340px 1240px 0 0 rgba(255,255,255,0.5),
    465px 1380px 0 0 rgba(255,255,255,0.6),
    590px 1270px 0 0 rgba(255,255,255,0.45),
    720px 1410px 0 0 rgba(255,255,255,0.7),
    840px 1310px 0 0 rgba(255,255,255,0.55),
    960px 1450px 0 0 rgba(255,255,255,0.5),
    1085px 1345px 0 0 rgba(255,255,255,0.65),
    1210px 1500px 0 0 rgba(255,255,255,0.5),
    1330px 1250px 0 0 rgba(255,255,255,0.7),
    1420px 1420px 0 0 rgba(255,255,255,0.55),
    145px 1550px 0 0 rgba(255,255,255,0.6),
    310px 1680px 0 0 rgba(255,255,255,0.5),
    480px 1600px 0 0 rgba(255,255,255,0.7),
    650px 1740px 0 0 rgba(255,255,255,0.55),
    820px 1650px 0 0 rgba(255,255,255,0.6),
    990px 1780px 0 0 rgba(255,255,255,0.5),
    1160px 1660px 0 0 rgba(255,255,255,0.7),
    1335px 1800px 0 0 rgba(255,255,255,0.55),
    1430px 1580px 0 0 rgba(255,255,255,0.6);
}
body::after {
  width: 2px; height: 2px;
  border-radius: 50%;
  box-shadow:
    /* Bright feature stars — larger, with soft glow */
    240px 160px 1px 1px rgba(255,255,255,0.9),
    670px 236px 1px 1px rgba(200,220,255,0.85),
    1078px 95px 2px 1px rgba(255,255,255,0.95),
    454px 405px 1px 1px rgba(200,210,255,0.8),
    860px 310px 1px 0 rgba(255,255,255,0.85),
    1305px 280px 2px 1px rgba(220,200,255,0.9),
    336px 528px 1px 1px rgba(200,220,255,0.85),
    595px 660px 1px 0 rgba(255,255,255,0.8),
    931px 555px 2px 1px rgba(255,255,255,0.95),
    1200px 480px 1px 1px rgba(200,210,255,0.85),
    150px 720px 1px 0 rgba(255,255,255,0.85),
    468px 810px 1px 1px rgba(220,200,255,0.9),
    771px 690px 2px 1px rgba(255,255,255,0.95),
    1100px 750px 1px 0 rgba(200,220,255,0.8),
    1380px 680px 1px 1px rgba(255,255,255,0.85),
    303px 940px 1px 0 rgba(255,255,255,0.85),
    669px 1050px 1px 1px rgba(200,210,255,0.9),
    980px 920px 2px 1px rgba(255,255,255,0.95),
    1250px 1010px 1px 0 rgba(220,200,255,0.8),
    120px 1150px 1px 1px rgba(255,255,255,0.85),
    500px 1200px 1px 0 rgba(200,220,255,0.85),
    830px 1300px 2px 1px rgba(255,255,255,0.95),
    1150px 1180px 1px 1px rgba(255,255,255,0.9),
    1400px 1100px 1px 0 rgba(200,210,255,0.8),
    250px 1420px 1px 1px rgba(255,255,255,0.85),
    600px 1500px 1px 0 rgba(220,200,255,0.85),
    950px 1450px 2px 1px rgba(255,255,255,0.95),
    1300px 1380px 1px 1px rgba(200,220,255,0.9),
    380px 1650px 1px 0 rgba(255,255,255,0.85),
    750px 1750px 1px 1px rgba(255,255,255,0.9);
  animation: twinkle 8s ease-in-out infinite;
}
body > * { position: relative; z-index: 1; }

/* ─── SKIP LINK ─── */
.skip-link {
  position: absolute; left: -9999px; top: auto;
  width: 1px; height: 1px; overflow: hidden;
  font-family: var(--mono); font-size: 0.82rem; font-weight: 700;
  color: var(--bg); background: var(--ink);
  padding: 0.6rem 1.2rem; border-radius: 0 0 8px 0;
  z-index: 1000; text-decoration: none;
}
.skip-link:focus {
  position: fixed; left: 0; top: 0;
  width: auto; height: auto;
}

/* ─── INLINE CODE ─── */
code {
  font-family: var(--mono);
  font-size: 0.82rem;
}
code.code--copper { color: var(--copper); }
code.code--critical { color: var(--critical); }
code.code--omp { color: var(--omp); }

/* ─── SECTION ANCHORS ─── */
section[id] { scroll-margin-top: 2rem; }
body {
  color: var(--text);
  font-family: var(--body); line-height: 1.65;
  overflow-x: hidden;
}

/* ─── BREADCRUMB ─── */
.breadcrumb {
  position: relative; z-index: 1;
  padding: 1.5rem 2rem 0; max-width: 960px; margin: 0 auto;
  font-family: var(--mono); font-size: 0.75rem;
  color: var(--text-label); letter-spacing: 0.1em;
}
.breadcrumb a {
  color: var(--copper); text-decoration: none;
  border-bottom: 1px solid transparent; transition: border-color 0.2s;
}
.breadcrumb a:hover { border-bottom-color: var(--copper); }
.breadcrumb a:focus-visible { outline: 2px solid var(--copper); outline-offset: 2px; border-radius: 2px; }

/* ─── HEADER ─── */
header {
  position: relative; z-index: 1;
  padding: 4.5rem 2rem 2.5rem;
  max-width: 960px; margin: 0 auto;
}
.breadcrumb + header { padding-top: 3rem; }
.header__logo {
  width: 120px; height: 120px; border-radius: 50%; object-fit: cover;
  display: block; margin: 0 auto 1.25rem;
  border: 2.5px solid var(--border);
  box-shadow: 0 4px 16px oklch(0 0 0 / 0.4);
}
.header__tag {
  font-family: var(--mono); font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--copper); margin-bottom: 1rem;
}
header h1 {
  font-family: var(--display); font-size: 3.5rem; font-weight: 400; font-style: italic;
  line-height: 1.08; color: var(--ink); margin-bottom: 0.75rem;
  text-wrap: balance;
}
header p {
  font-family: var(--body); font-size: 1.05rem; color: var(--text-body);
  font-style: italic; line-height: 1.65;
  text-wrap: pretty;
}

/* ─── MAIN ─── */
main {
  position: relative; z-index: 1;
  max-width: 960px; margin: 0 auto;
  padding: 0 2rem 3rem;
}

/* ─── SECTIONS ─── */
section { position: relative; margin-bottom: 3.5rem; padding-top: 0.5rem; }
.section-num {
  font-family: var(--display); font-size: 3.2rem; font-weight: 400;
  color: var(--ghost); line-height: 1;
  position: absolute; left: -0.5rem; top: -0.2rem; pointer-events: none;
  z-index: 0;
}
section h2 {
  font-family: var(--mono); font-size: 0.78rem; font-weight: 700;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-label); margin-bottom: 1.25rem;
  padding-left: 4rem;
  display: flex; align-items: center; gap: 0.6rem;
  position: relative; z-index: 1;
}
section h2 i { font-size: 1.15rem; color: var(--copper); }
section h2 a.deep-link {
  display: inline-flex; align-items: center; gap: 0.5rem;
  color: inherit; text-decoration: none; transition: color 0.2s;
}
section h2 a.deep-link:hover { color: var(--copper); }
section h2 a.deep-link::after {
  content: '\2192'; font-family: var(--mono); font-size: 0.85em;
  color: var(--copper); opacity: 0;
  transition: opacity 0.2s, transform 0.2s;
  transform: translateX(-4px); margin-left: 0.25rem;
}
section h2 a.deep-link:hover::after { opacity: 1; transform: translateX(0); }

/* ─── RINGS ─── */
.ring {
  border: 1.5px solid var(--border); border-radius: 14px;
  padding: 1.5rem; margin-bottom: 1rem; position: relative;
}
.ring--claude { background: var(--claude-bg); border-color: var(--claude-border); }
.ring--dealbreaker { background: var(--dealbreaker-bg); margin: 0 1.25rem 1rem; border-color: var(--dealbreaker-border); }
.ring--subq { background: var(--subq-bg); margin: 0 2.5rem 1rem; border-color: var(--subq-border); }
.ring--core { margin: 0 3.75rem; border-style: dashed; border-color: var(--border); background: var(--bg-card); }
.ring h3 {
  font-family: var(--mono); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 0.75rem;
}
.ring--claude h3 { color: var(--claude); }
.ring--dealbreaker h3 { color: var(--dealbreaker); }
.ring--subq h3 { color: var(--subq); }
.ring--core h3 { color: var(--text-muted); }
.ring p {
  font-family: var(--body); font-size: 0.88rem;
  color: var(--text-body); line-height: 1.55; text-wrap: pretty;
}

.flow-caption {
  text-align: center; font-family: var(--display); font-size: 0.9rem;
  color: var(--copper); padding: 0.6rem 0; font-style: italic;
}

/* ─── CHIP GRID ─── */
.chip-grid { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.chip {
  font-family: var(--mono); font-size: 0.8rem; font-weight: 500;
  padding: 0.3rem 0.65rem; border: 1px solid var(--border);
  border-radius: 5px; color: var(--text-dim); background: var(--bg-card);
}
.chip--dealbreaker { border-color: var(--dealbreaker-border); color: var(--dealbreaker); background: var(--dealbreaker-bg); }
.chip--high { border-color: var(--high-border); color: var(--high); background: var(--high-bg); }
.chip--moderate { border-color: var(--moderate-border); color: var(--moderate); background: var(--moderate-bg); }
.chip--subq { border-color: var(--subq-border); color: var(--subq); background: var(--subq-bg); font-weight: 600; }
.chip--claude { border-color: var(--claude-border); color: var(--claude); background: var(--claude-bg); }
.chip--cursor { border-color: var(--cursor-border); color: var(--cursor); background: var(--cursor-bg); }
.chip--codex { border-color: var(--codex-border); color: var(--codex); background: var(--codex-bg); }

/* ─── STATE CARDS ─── */
.states-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem;
}
.states-grid--3col { grid-template-columns: repeat(3, 1fr); }

.state-card {
  border: 1.5px solid var(--border); border-radius: 12px; padding: 1.5rem;
  background: var(--bg-card); position: relative; overflow: hidden;
  transition: box-shadow 0.25s cubic-bezier(0.25,1,0.5,1), border-color 0.25s cubic-bezier(0.25,1,0.5,1);
  text-decoration: none; color: inherit; display: block;
}
.state-card::before {
  content: ''; position: absolute; top: -1.5px; left: -1.5px; right: -1.5px;
  height: 4px; border-radius: 12px 12px 0 0;
}
.state-card--dealbreaker::before { background: var(--dealbreaker); }
.state-card--dealbreaker:hover { border-color: var(--dealbreaker-border); box-shadow: 0 4px 20px var(--dealbreaker-bg); }
.state-card--high::before { background: var(--high); }
.state-card--high:hover { border-color: var(--high-border); box-shadow: 0 4px 20px var(--high-bg); }
.state-card--moderate::before { background: var(--moderate); }
.state-card--moderate:hover { border-color: var(--moderate-border); box-shadow: 0 4px 20px var(--moderate-bg); }
.state-card--subq::before { background: var(--subq); }
.state-card--subq:hover { border-color: var(--subq-border); box-shadow: 0 4px 20px var(--subq-bg); }
.state-card--claude::before { background: var(--claude); }
.state-card--claude:hover { border-color: var(--claude-border); box-shadow: 0 4px 20px var(--claude-bg); }
.state-card--cursor::before { background: var(--cursor); }
.state-card--cursor:hover { border-color: var(--cursor-border); box-shadow: 0 4px 20px var(--cursor-bg); }
.state-card--codex::before { background: var(--codex); }
.state-card--codex:hover { border-color: var(--codex-border); box-shadow: 0 4px 20px var(--codex-bg); }
.state-card:focus-visible { outline: 2px solid var(--copper); outline-offset: 2px; }
.state-card:active { transform: scale(0.96); }

.state-card h4 {
  font-family: var(--mono); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 0.25rem;
}
.state-card--dealbreaker h4 { color: var(--dealbreaker); }
.state-card--high h4 { color: var(--high); }
.state-card--moderate h4 { color: var(--moderate); }
.state-card--subq h4 { color: var(--subq); }
.state-card--claude h4 { color: var(--claude); }
.state-card--cursor h4 { color: var(--cursor); }
.state-card--codex h4 { color: var(--codex); }

.state-card h5 {
  font-family: var(--display); font-size: 1.5rem; font-weight: 500; font-style: italic;
  color: var(--ink); margin-bottom: 0.5rem; line-height: 1.15;
}
.state-card h5 i { font-style: normal; font-size: 1.1rem; color: var(--copper); margin-right: 0.15rem; }
.state-card p {
  font-family: var(--body); font-size: 0.88rem; color: var(--text-body);
  line-height: 1.6; margin-bottom: 0.75rem; text-wrap: pretty;
}
.state-card__verbs { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.verb-chip {
  font-family: var(--mono); font-size: 0.70rem; font-weight: 600;
  padding: 0.2rem 0.55rem; border-radius: 100px; border: 1px solid var(--border);
  color: var(--text-dim);
}
.state-card--dealbreaker .verb-chip { border-color: var(--dealbreaker-border); color: var(--dealbreaker); }
.state-card--high .verb-chip { border-color: var(--high-border); color: var(--high); }
.state-card--moderate .verb-chip { border-color: var(--moderate-border); color: var(--moderate); }
.state-card--subq .verb-chip { border-color: var(--subq-border); color: var(--subq); }
.state-card--claude .verb-chip { border-color: var(--claude-border); color: var(--claude); }
.state-card--cursor .verb-chip { border-color: var(--cursor-border); color: var(--cursor); }
.state-card--codex .verb-chip { border-color: var(--codex-border); color: var(--codex); }

/* ─── HOOK CARDS ─── */
.hook-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 0.75rem;
}
.hook-card {
  border: 1px solid var(--border); border-radius: 10px;
  padding: 1rem 1.1rem; background: var(--bg-card);
}
.hook-card h4 {
  font-family: var(--mono); font-size: 0.8rem; font-weight: 700;
  color: var(--copper); margin-bottom: 0.3rem;
}
.hook-card p {
  font-family: var(--body); font-size: 0.85rem; color: var(--text-body); line-height: 1.55;
}
.hook-card__verb {
  font-family: var(--display); font-size: 0.85rem;
  color: var(--text-dim); margin-top: 0.5rem; padding-top: 0.45rem;
  border-top: 1px solid var(--border); font-style: italic;
}
.hook-card--dealbreaker h4 { color: var(--dealbreaker); }
.hook-card--high { background: var(--high-bg); border-color: var(--high-border, var(--high)); }
.hook-card--high h4 { color: var(--high); }

/* ─── MATRIX ─── */
.matrix {
  border: 1.5px solid var(--border-strong); border-radius: 12px;
  overflow: hidden; background: var(--bg-card); font-family: var(--mono);
}
.matrix__row {
  display: grid; align-items: center; border-bottom: 1px solid var(--border);
}
.matrix__row:last-child { border-bottom: none; }
.matrix__row--head { background: var(--bg-warm); }
.matrix__cell {
  padding: 0.8rem 0.9rem; font-size: 0.82rem; color: var(--text-body);
  min-width: 0; word-break: break-word; overflow-wrap: anywhere;
}
.matrix__cell--center { text-align: center; }
.matrix__th {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--text-muted); display: flex; align-items: center; gap: 0.5rem;
}
.matrix__th--center { justify-content: center; }
.matrix__th i { font-size: 1.05rem; color: var(--copper); flex-shrink: 0; }
.matrix__tool {
  font-weight: 700; color: var(--ink); display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.85rem; line-height: 1.3;
}
.matrix__effect {
  font-family: var(--body); font-size: 0.88rem; color: var(--text-body); line-height: 1.45;
}
.matrix__effect strong { font-family: var(--mono); font-weight: 700; color: var(--ink); }

/* Verdict badges */
.matrix__verdict {
  display: inline-flex; align-items: center; gap: 0.3rem;
  font-size: 0.70rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.25rem 0.55rem; border-radius: 100px; white-space: nowrap; line-height: 1.2;
  font-variant-numeric: tabular-nums;
}
.matrix__verdict--dealbreaker { background: var(--dealbreaker-bg); color: var(--dealbreaker); border: 1px solid var(--dealbreaker-border); }
.matrix__verdict--high { background: var(--high-bg); color: var(--high); border: 1px solid var(--high-border); }
.matrix__verdict--moderate { background: var(--moderate-bg); color: var(--moderate); border: 1px solid var(--moderate-border); }
.matrix__verdict--subq { background: var(--subq-bg); color: var(--subq); border: 1px solid var(--subq-border); }
.matrix__verdict--claude { background: var(--claude-bg); color: var(--claude); border: 1px solid var(--claude-border); }
.matrix__verdict--cursor { background: var(--cursor-bg); color: var(--cursor); border: 1px solid var(--cursor-border); }
.matrix__verdict--codex { background: var(--codex-bg); color: var(--codex); border: 1px solid var(--codex-border); }
.matrix__verdict--yes { background: var(--subq-bg); color: var(--subq); border: 1px solid var(--subq-border); }
.matrix__verdict--partial { background: oklch(0.50 0.12 75 / 0.08); color: oklch(0.42 0.12 75); border: 1px solid oklch(0.50 0.12 75 / 0.25); }

/* Matrix note callout */
.matrix-note {
  margin-top: 1rem; padding: 0.75rem 1rem;
  border: 1px solid var(--high-border, var(--border)); background: var(--high-bg);
  font-family: var(--body); font-size: 0.9rem; color: var(--text-body);
  line-height: 1.55; border-radius: 8px;
}
.matrix-note strong {
  font-family: var(--mono); font-weight: 700; color: var(--high);
  text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.78rem;
}
.matrix-note--dealbreaker { border-color: var(--dealbreaker-border, var(--dealbreaker)); background: var(--dealbreaker-bg); }
.matrix-note--dealbreaker strong { color: var(--dealbreaker); }
.matrix-note--subq { border-color: var(--subq-border, var(--subq)); background: var(--subq-bg); }
.matrix-note--subq strong { color: var(--subq); }
.matrix-note--copper { border-color: oklch(0.45 0.12 55 / 0.3); background: oklch(0.45 0.12 55 / 0.06); }
.matrix-note--copper strong { color: var(--copper); }
.matrix-note--neutral { border-color: var(--border); background: var(--bg-warm); }
.matrix-note--neutral strong { color: var(--text-dim); }

/* ─── CAPABILITY PANELS ─── */
.caps-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 1.25rem;
}
.cap-panel {
  border: 1.5px solid var(--border); border-radius: 12px; padding: 1.5rem;
  background: var(--bg-card);
}
.cap-panel h4 {
  font-family: var(--mono); font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 0.35rem;
  color: var(--subq);
}
.cap-panel h5 {
  font-family: var(--display); font-size: 1.35rem; font-weight: 500; font-style: italic;
  color: var(--ink); margin-bottom: 0.5rem;
}
.cap-panel p {
  font-family: var(--body); font-size: 0.88rem; color: var(--text-body); line-height: 1.55;
  margin-bottom: 0.75rem;
}
.cap-panel--primary { border-color: var(--subq-border); background: var(--subq-bg); }
.cap-panel--dealbreaker h4 { color: var(--dealbreaker); }
.cap-panel--claude h4 { color: var(--claude); }

/* ─── DEBUGGER PANEL ─── */
.debugger-panel {
  border: 1.5px solid var(--border-strong); border-radius: 12px;
  overflow: hidden; background: var(--bg-card);
}
.console-line {
  font-family: var(--mono); font-size: 0.8rem; line-height: 2;
  display: flex; gap: 0.6rem; align-items: baseline;
  animation: consoleSlideIn 0.3s cubic-bezier(0.25,1,0.5,1) both;
}
.console-line:nth-child(1) { animation-delay: 0.15s; }
.console-line:nth-child(2) { animation-delay: 0.4s; }
.console-line:nth-child(3) { animation-delay: 0.65s; }
.console-line:nth-child(4) { animation-delay: 0.95s; }
.console-line:nth-child(5) { animation-delay: 1.25s; }
.console-line:nth-child(6) { animation-delay: 1.55s; }
.console-line:nth-child(7) { animation-delay: 1.9s; }
.console-line:nth-child(8) { animation-delay: 2.25s; }
.console-line:nth-child(9) { animation-delay: 2.6s; }
.console-line:nth-child(10) { animation-delay: 2.95s; }
.console-line:nth-child(11) { animation-delay: 3.3s; }
.console-line:nth-child(12) { animation-delay: 3.65s; }
@keyframes consoleSlideIn {
  from { transform: translateY(4px); opacity: 0.4; }
  to { transform: translateY(0); opacity: 1; }
}
.console-verb { min-width: 110px; font-weight: 700; flex-shrink: 0; }
.console-verb--claude { color: var(--claude); }
.console-verb--codex { color: var(--codex); }
.console-verb--subq { color: var(--subq); }
.console-verb--dealbreaker { color: var(--dealbreaker); }
.console-verb--high { color: var(--high); }
.console-verb--copper { color: var(--copper); }
.console-verb--market { color: var(--text-muted); font-style: italic; }
.console-msg { color: var(--text-body); flex: 1; min-width: 0; }
.console-state {
  font-size: 0.7rem; font-weight: 600; padding: 0.15rem 0.5rem;
  border-radius: 3px; border: 1px solid var(--border);
  color: var(--text-muted); white-space: nowrap; flex-shrink: 0;
}

/* ─── FURTHER READING ─── */
.further {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 0.75rem;
}
.further-card {
  display: block; text-decoration: none; color: inherit;
  border: 1.5px solid var(--border); border-radius: 12px; padding: 1.1rem 1.3rem;
  background: var(--bg-card); transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}
.further-card:hover {
  border-color: var(--copper); box-shadow: 0 4px 14px rgba(0,0,0,0.05);
  transform: translateY(-2px);
}
.further-card:focus-visible { outline: 2px solid var(--copper); outline-offset: 2px; }
.further-card:active { transform: scale(0.96); }
.further-card__logo {
  width: 96px; height: 96px; border-radius: 50%; object-fit: cover;
  margin: 0 auto 0.75rem; display: block;
  border: 2px solid var(--border); box-shadow: 0 2px 8px oklch(0 0 0 / 0.3);
}
.further-card__head {
  display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.4rem;
  justify-content: center;
}
.further-card__head i { font-size: 1.3rem; color: var(--copper); }
.further-card__name {
  font-family: var(--mono); font-size: 0.88rem; font-weight: 700; color: var(--ink);
}
.further-card__desc {
  font-family: var(--body); font-size: 0.85rem; color: var(--text-body); line-height: 1.5;
  text-align: center;
}

/* ─── QUOTE CARDS ─── */
.quote-card {
  border: 1px solid var(--border); border-radius: 10px;
  padding: 1.15rem 1.25rem; background: var(--bg-card);
}
.quote-card blockquote {
  font-family: var(--body); font-size: 0.92rem; font-style: italic;
  color: var(--text-body); line-height: 1.6; margin-bottom: 0.6rem;
}
.quote-card cite {
  font-family: var(--mono); font-size: 0.72rem; font-style: normal;
  color: var(--text-muted); letter-spacing: 0.05em;
}

/* ─── FOOTER ─── */
footer {
  text-align: center; padding: 2.5rem 2rem;
  font-family: var(--display); font-size: 0.9rem;
  color: var(--text-dim); font-style: italic;
  border-top: 1px solid var(--border); position: relative; z-index: 1;
}
footer a {
  color: var(--copper); text-decoration: none; border-bottom: 1px solid transparent;
}
footer a:hover { border-bottom-color: var(--copper); }
footer a:focus-visible { outline: 2px solid var(--copper); outline-offset: 2px; border-radius: 2px; }
.footer__nav {
  display: flex; justify-content: center; gap: 1.5rem; margin-bottom: 1rem;
  font-family: var(--mono); font-size: 0.78rem; font-style: normal;
}

/* ─── TIER SUBHEADINGS ─── */
.tier-label {
  font-family: var(--mono); font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  margin-bottom: 0.75rem;
}
.tier-label--dealbreaker { color: var(--dealbreaker); }
.tier-label--high { color: var(--high); }
.tier-label--moderate { color: var(--moderate); }
.tier-label--copper { color: var(--copper); }
.tier-label--1 { color: var(--tier1); }
.tier-label--2 { color: var(--tier2); }
.tier-label--3 { color: var(--tier3); }
.tier-label--4 { color: var(--tier4); }

/* ─── CAPABILITY PANEL VARIANTS ─── */
.cap-panel--neutral h4 { color: var(--ink); }

/* ─── LEAD TEXT ─── */
.lead {
  font-family: var(--body); font-size: 0.98rem;
  color: var(--text-body); line-height: 1.65;
}
.lead + .lead { margin-top: 0.75rem; }
.lead strong {
  font-family: var(--display); font-style: italic; font-weight: 500; color: var(--ink);
}
.lead code {
  font-family: var(--mono); font-size: 0.88rem;
  background: var(--bg-warm); color: var(--copper);
  padding: 0.1rem 0.4rem; border-radius: 4px;
}

/* ─── SPACING UTILITIES ─── */
.spaced { margin-top: 1.25rem; }
.spaced-sm { margin-top: 1rem; }
.gap-below { margin-bottom: 1.5rem; }
.gap-below-md { margin-bottom: 1.25rem; }
.gap-below-sm { margin-bottom: 1rem; }
.flush { margin-bottom: 0; }

/* ─── HEADER ICON (landing page) ─── */
.header__icon {
  width: 80px; height: 80px; display: block;
  margin: 0 auto 1.25rem;
}

/* ─── CONSOLE LINE DIVIDER ─── */
.console-line--divider { color: var(--text-dim); font-style: italic; }

/* ─── PHASE BLOCK BADGE WRAPPER ─── */
.phase-block__badges { margin-top: 0.5rem; }

/* ─── MATRIX TIER DIVIDER ROW ─── */
.matrix__row--divider {
  display: grid; grid-template-columns: 1fr;
}
.matrix__row--divider .matrix__cell {
  background: var(--bg-warm); padding: 0.4rem 0.9rem;
}

/* ─── LEGEND BADGE SIZE ─── */
.matrix__verdict--legend { font-size: 0.6rem; }

/* ─── MATRIX TOTAL ROW ─── */
.matrix__row--total { background: var(--bg-warm); }
.matrix__row--total .matrix__tool { font-weight: 700; }
.matrix__verdict--total { font-size: 0.8rem; padding: 0.3rem 0.7rem; }

/* ─── STICKY LEGEND ─── */
.matrix-legend {
  position: sticky; top: 0; z-index: 10;
  background: var(--bg); padding: 0.75rem 0; margin-bottom: 1rem;
  display: flex; gap: 0.75rem; flex-wrap: wrap;
  font-family: var(--mono); font-size: 0.7rem;
}

/* ─── STATUS CHIP SEVERITY VARIANTS ─── */
.status-chip--critical { color: var(--critical); border-color: var(--critical-border); background: var(--critical-bg); }
.status-chip--high { color: var(--blocked); border-color: oklch(0.50 0.16 25 / 0.3); }

/* ─── VERB CHIP SIZE ─── */
.verb-chip--sm { font-size: 0.68rem; }

/* ─── LINK VARIANTS ─── */
a.link--copper { color: var(--copper); }

/* ─── STAT BAR ─── */
.stat-bar {
  display: flex; flex-wrap: wrap; gap: 0;
  border: 1px solid var(--border); border-radius: 6px;
  overflow: hidden;
}
.stat-bar__item {
  flex: 1; min-width: 100px;
  padding: 0.75rem 1rem; text-align: center;
  border-right: 1px solid var(--border);
}
.stat-bar__item:last-child { border-right: none; }
.stat-bar__val {
  font-family: var(--display); font-size: 1.4rem; font-weight: 500;
  color: var(--copper); font-variant-numeric: tabular-nums;
}
.stat-bar__label {
  font-family: var(--mono); font-size: 0.62rem;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text-label);
}

/* ─── HERO IMAGE ─── */
section h2 + .hero-image { margin-top: 1rem; }
.hero-image {
  width: 100%; border-radius: 6px;
  border: 1px solid var(--border);
  margin-top: 1.75rem; margin-bottom: 2rem;
  object-fit: cover; max-height: 320px;
  cursor: pointer;
}
.hero-lightbox {
  display: flex; position: fixed; inset: 0; z-index: 200;
  background: oklch(0.15 0.02 270 / 0.92);
  align-items: center; justify-content: center; padding: 2rem;
  opacity: 0; pointer-events: none;
  transition: opacity 300ms cubic-bezier(0.25, 1, 0.5, 1);
}
.hero-lightbox.open { opacity: 1; pointer-events: auto; }
.hero-lightbox img {
  max-width: 92vw; max-height: 90vh;
  object-fit: contain; border-radius: 6px;
  box-shadow: 0 8px 40px oklch(0 0 0 / 0.4);
  transform: scale(0.95);
  transition: transform 300ms cubic-bezier(0.25, 1, 0.5, 1);
}
.hero-lightbox.open img { transform: scale(1); }
.hero-lightbox__close {
  position: absolute; top: 1.5rem; right: 1.5rem;
  font-size: 2rem; color: oklch(0.9 0 0);
  background: none; border: none; cursor: pointer; line-height: 1;
}
@media (prefers-reduced-motion: reduce) {
  .hero-lightbox { transition: none; }
  .hero-lightbox img { transition: none; transform: none; }
}

/* ─── ERA TOP-BAR ─── */
.era-bar { position: relative; overflow: hidden; }
.era-bar::before {
  content: ''; display: block;
  height: 3px; border-radius: 3px 3px 0 0;
  background: var(--era-accent, var(--copper));
}

/* ─── AIM WINDOW CHROME ─── */
.aim-window {
  border: 1px solid var(--border); border-radius: 8px;
  overflow: hidden;
}
.aim-window__titlebar {
  background: oklch(0.30 0.02 270);
  padding: 0.5rem 0.75rem;
  display: flex; align-items: center; gap: 0.5rem;
}
.aim-window__dots { display: flex; gap: 6px; }
.aim-window__dot {
  width: 10px; height: 10px; border-radius: 50%;
}
.aim-window__dot--red { background: oklch(0.55 0.2 25); }
.aim-window__dot--yellow { background: oklch(0.75 0.15 85); }
.aim-window__dot--green { background: oklch(0.60 0.15 145); }
.aim-window__title {
  font-family: var(--mono); font-size: 0.72rem;
  color: oklch(0.85 0.01 80); letter-spacing: 0.04em;
}

/* ─── EDITORIAL PULLQUOTE ─── */
aside.pullquote {
  margin: 2.5rem 0; padding: 1.5rem 2rem;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
aside.pullquote blockquote {
  font-family: var(--display); font-size: 1.35rem;
  font-style: italic; font-weight: 400;
  color: var(--ink); line-height: 1.45;
  text-wrap: balance;
}
aside.pullquote cite {
  display: block; margin-top: 0.75rem;
  font-family: var(--mono); font-size: 0.72rem;
  font-style: normal; color: var(--text-muted);
  letter-spacing: 0.05em;
}
aside.pullquote .pullquote__accent {
  width: 2rem; height: 3px; border-radius: 2px;
  background: var(--era-accent, var(--copper));
  margin-bottom: 1rem;
}

/* ─── MASONRY GALLERY ─── */
.masonry-grid {
  columns: 3 220px; column-gap: 1rem;
}
.masonry-grid__item {
  break-inside: avoid; margin-bottom: 1rem;
  border-radius: 4px; overflow: hidden;
  cursor: pointer; position: relative;
}
.masonry-grid__item img {
  width: 100%; display: block;
  transition: transform 300ms cubic-bezier(0.25, 1, 0.5, 1);
}
.masonry-grid__item:hover img { transform: scale(1.03); }

/* ─── STAGGERED LOAD-IN ─── */
@keyframes stagger-in {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.stagger-in {
  animation: stagger-in 300ms cubic-bezier(0.25, 1, 0.5, 1) both;
  animation-delay: calc(var(--stagger-index, 0) * 80ms);
}

/* ─── HIGHLIGHT DENSITY BAR ─── */
.density-bar {
  height: 3px; border-radius: 2px; margin-top: 0.5rem;
  background: var(--era-accent, var(--copper));
  opacity: 0.6;
}

/* ─── REDUCED MOTION ─── */
@media (prefers-reduced-motion: reduce) {
  .console-line { animation: none; }
  .status-dot--building { animation: none; }
  .stagger-in { animation: none; opacity: 1; }
  .masonry-grid__item img { transition: none; }
  .state-card, .further-card, .phase-block, .page-nav a { transition: none; }
  html { scroll-behavior: auto; }
}

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  header h1 { font-size: 2.8rem; }
  .states-grid { grid-template-columns: 1fr 1fr; }
  .states-grid--3col { grid-template-columns: 1fr 1fr; }
  .ring--dealbreaker { margin: 0 0.75rem 1rem; }
  .ring--subq { margin: 0 1.5rem 1rem; }
  .ring--core { margin: 0 2.25rem; }
}
@media (max-width: 640px) {
  header { padding: 3rem 1.25rem 2rem; }
  header h1 { font-size: 2.2rem; }
  main { padding: 0 1.25rem 2rem; }
  .states-grid, .states-grid--3col { grid-template-columns: 1fr; }
  .ring--dealbreaker { margin: 0 0.25rem 1rem; }
  .ring--subq { margin: 0 0.5rem 1rem; }
  .ring--core { margin: 0 0.75rem; }
  .ring { padding: 1rem; }
  section h2 { padding-left: 3rem; }
  .section-num { font-size: 2.4rem; }
  .console-state { display: none; }
  .console-verb { min-width: 80px; }
  .hide-mobile { display: none; }
  .matrix__cell { padding: 0.55rem 0.6rem; font-size: 0.76rem; }
  .matrix__verdict { font-size: 0.62rem; padding: 0.2rem 0.5rem; }
  .stat-bar { flex-direction: column; }
  .stat-bar__item { border-right: none; border-bottom: 1px solid var(--border); }
  .stat-bar__item:last-child { border-bottom: none; }
  .masonry-grid { columns: 2 160px; }
  aside.pullquote { margin: 1.5rem 0; padding: 1rem; }
  aside.pullquote blockquote { font-size: 1.05rem; }
  .hero-image { max-height: 200px; }
  .audio-player { bottom: 0.75rem; top: auto; right: 0.75rem; }
  .audio-player__volume { width: 60px; }
}

/* ═══════════════════════════════════════════════════
   Audio Player — Fixed ambient controls
   ═══════════════════════════════════════════════════ */
.audio-player {
  position: fixed;
  top: 1rem;
  right: 1.5rem;
  z-index: 900;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 0.75rem;
  background: oklch(0.14 0.02 265 / 0.85);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 2px 12px oklch(0 0 0 / 0.3);
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}
.audio-player:hover {
  border-color: var(--copper);
  box-shadow: 0 2px 18px oklch(0.72 0.14 85 / 0.15);
}
.audio-player__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--copper);
  font-size: 1.15rem;
  border-radius: 50%;
  position: relative;
  transition: color 0.2s ease;
}
.audio-player__btn:hover { color: var(--ink); }
.audio-player__btn i { position: relative; z-index: 1; }
.audio-player__pulse {
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: oklch(0.72 0.14 85 / 0.15);
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.audio-player--playing .audio-player__pulse {
  opacity: 1;
  transform: scale(1);
  animation: audio-pulse 2s ease-in-out infinite;
}
@keyframes audio-pulse {
  0%, 100% { transform: scale(1); opacity: 0.4; }
  50% { transform: scale(1.25); opacity: 0; }
}
.audio-player__bars {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 14px;
  margin: 0 0.15rem;
}
.audio-player__bar {
  width: 2.5px;
  height: 3px;
  background: var(--copper);
  border-radius: 1px;
  transition: height 60ms linear;
}
.audio-player__volume {
  -webkit-appearance: none;
  appearance: none;
  width: 70px;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
  transition: opacity 0.2s ease;
}
.audio-player__volume::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 10px;
  height: 10px;
  background: var(--copper);
  border-radius: 50%;
  cursor: pointer;
  transition: transform 0.15s ease;
}
.audio-player__volume::-webkit-slider-thumb:hover {
  transform: scale(1.3);
}
.audio-player__volume::-moz-range-thumb {
  width: 10px;
  height: 10px;
  background: var(--copper);
  border-radius: 50%;
  border: none;
  cursor: pointer;
}
.audio-player__label {
  font-family: var(--mono);
  font-size: 0.6rem;
  color: var(--text-muted);
  letter-spacing: 0.04em;
  white-space: nowrap;
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-width 0.4s ease, opacity 0.3s ease;
}
.audio-player:hover .audio-player__label,
.audio-player--playing .audio-player__label {
  max-width: 200px;
  opacity: 1;
}
@media (prefers-reduced-motion: reduce) {
  .audio-player--playing .audio-player__pulse { animation: none; opacity: 0.3; transform: scale(1); }
  .audio-player__bar { transition: none; }
}
