/* Shared stylesheet for generated pages. */
/* Rules are scoped by body class so index and article layouts can share one file. */

/* Index page */
:root {
  --bg: #ffffff;
  --surface: #f2f2f2;
  --surface-warm: #ffffff;
  --fg: #000000;
  --fg-2: #333333;
  --muted: #666666;
  --meta: #057dbc;
  --border: #d0d0d0;
  --border-soft: #e8e8e8;
  --accent: #057dbc;
  --accent-on: #ffffff;
  --accent-hover: color-mix(in oklab, var(--accent), black 8%);
  --accent-active: color-mix(in oklab, var(--accent), black 14%);
  --success: #0f8a3b;
  --warn: #f5a400;
  --danger: #c40000;
  --font-display: "Druk Wide", "Arial Black", Impact, sans-serif;
  --font-body: "Exchange", Georgia, serif;
  --font-mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;
  --text-xs: 12px;
  --text-sm: 14px;
  --text-base: 17px;
  --text-lg: 20px;
  --text-xl: 28px;
  --text-2xl: 44px;
  --text-3xl: 68px;
  --text-4xl: 96px;
  --leading-body: 1.55;
  --leading-tight: 0.92;
  --tracking-display: -0.02em;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-12: 48px;
  --section-y-desktop: 88px;
  --section-y-tablet: 64px;
  --section-y-phone: 44px;
  --radius-sm: 0px;
  --radius-md: 0px;
  --radius-lg: 0px;
  --radius-pill: 9999px;
  --elev-flat: none;
  --elev-ring: 0 0 0 1px var(--border);
  --elev-raised: 0 16px 40px rgba(0, 0, 0, 0.14);
  --focus-ring: 0 0 0 4px rgba(5, 125, 188, 0.24);
  --motion-fast: 120ms;
  --motion-base: 200ms;
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);
  --container-max: 1180px;
  --container-gutter-desktop: 34px;
  --container-gutter-tablet: 26px;
  --container-gutter-phone: 18px;

}
* {box-sizing: border-box;}
html {scroll-behavior: smooth;}
body.output-index {
  margin: 0;
  min-height: 100vh;
  color: var(--fg);
  background: var(--bg);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-body);

}
body.output-index a {color: inherit; text-decoration-thickness: 0.12em; text-underline-offset: 0.18em;}
body.output-index a:hover {color: var(--accent);}
body.output-index a:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;

}
body.output-index .skip-link {
  position: absolute;
  left: var(--space-4);
  top: var(--space-4);
  transform: translateY(-180%);
  z-index: 20;
  padding: var(--space-2) var(--space-3);
  border: 2px solid var(--fg);
  background: var(--bg);
  font: 700 var(--text-sm)/1.2 var(--font-mono);
  letter-spacing: 0;
  text-transform: uppercase;

}
body.output-index .skip-link:focus {transform: translateY(0);}
body.output-index .site-header {
  background: var(--bg);
  border-bottom: 1px solid var(--border);

}
body.output-index .masthead {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: var(--space-12) var(--container-gutter-desktop) var(--space-8);

}
body.output-index .kicker {
  margin: 0 0 var(--space-3);
  color: var(--accent);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0;
  text-transform: uppercase;

}
body.output-index h1 {
  margin: 0;
  max-width: 14ch;
  font-family: var(--font-display);
  font-size: clamp(40px, 7vw, 76px);
  line-height: 1.02;
  letter-spacing: 0;

}
body.output-index .lede {
  max-width: 60ch;
  margin: var(--space-5) 0 0;
  color: var(--fg-2);
  font-size: var(--text-lg);

}
body.output-index main {
  max-width: var(--container-max);
  margin: 0 auto;
  min-width: 0;

}
body.output-index .section {
  padding: var(--space-8) var(--container-gutter-desktop) var(--space-12);

}
body.output-index .section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);

}
body.output-index h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1.08;
  letter-spacing: 0;

}
body.output-index .count {
  color: var(--muted);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0;

}
body.output-index .article-list {
  display: grid;
  gap: var(--space-4);
  border-top: 1px solid var(--border);

}
body.output-index .empty-state {
  margin: 0;
  padding: var(--space-8) 0;
  color: var(--fg-2);
  font-size: var(--text-lg);

}
body.output-index .article-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--border);
  text-decoration: none;

}
body.output-index .article-card:hover h3 {color: var(--accent);}
body.output-index .article-card h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(24px, 3vw, var(--text-2xl));
  line-height: 1.08;
  letter-spacing: 0;
}
body.output-index .article-card p {
  max-width: 64ch;
  margin: 0;
  color: var(--fg-2);
}
body.output-index .tag-line {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  color: var(--muted);
  font: 700 var(--text-xs)/1.3 var(--font-mono);
  letter-spacing: 0;
}
@media (max-width: 860px) {
  body.output-index .masthead, body.output-index .section {padding-left: var(--container-gutter-tablet); padding-right: var(--container-gutter-tablet);}
}
@media (max-width: 560px) {
  body.output-index .masthead, body.output-index .section {padding-left: var(--container-gutter-phone); padding-right: var(--container-gutter-phone);}
  body.output-index .masthead {padding-top: var(--space-8);}
  body.output-index .section-title {align-items: flex-start; flex-direction: column; gap: var(--space-2);}
}
@media (prefers-reduced-motion: reduce) {
  html {scroll-behavior: auto;}
}

/* Article pages */
:root {
  --bg: #ffffff;
  --surface: #f2f2f2;
  --surface-warm: #ffffff;
  --fg: #000000;
  --fg-2: #333333;
  --muted: #666666;
  --meta: #057dbc;
  --border: #d0d0d0;
  --border-soft: #e8e8e8;
  --accent: #057dbc;
  --accent-on: #ffffff;
  --accent-hover: color-mix(in oklab, var(--accent), black 8%);
  --accent-active: color-mix(in oklab, var(--accent), black 14%);
  --success: #0f8a3b;
  --warn: #f5a400;
  --danger: #c40000;
  --font-display: "Druk Wide", "Arial Black", Impact, sans-serif;
  --font-body: "Exchange", Georgia, serif;
  --font-mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;
  --text-xs: 12px;
  --text-sm: 14px;
  --text-base: 17px;
  --text-lg: 20px;
  --text-xl: 28px;
  --text-2xl: 44px;
  --text-3xl: 68px;
  --text-4xl: 96px;
  --leading-body: 1.55;
  --leading-tight: 0.92;
  --tracking-display: -0.02em;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-12: 48px;
  --section-y-desktop: 88px;
  --section-y-tablet: 64px;
  --section-y-phone: 44px;
  --radius-sm: 0px;
  --radius-md: 0px;
  --radius-lg: 0px;
  --radius-pill: 9999px;
  --elev-flat: none;
  --elev-ring: 0 0 0 1px var(--border);
  --elev-raised: 0 16px 40px rgba(0, 0, 0, 0.14);
  --focus-ring: 0 0 0 4px rgba(5, 125, 188, 0.24);
  --motion-fast: 120ms;
  --motion-base: 200ms;
  --ease-standard: cubic-bezier(0.2, 0, 0, 1);
  --container-max: 1180px;
  --container-gutter-desktop: 34px;
  --container-gutter-tablet: 26px;
  --container-gutter-phone: 18px;

}
* {box-sizing: border-box;}
html {scroll-behavior: smooth;}
body.article-page {
  margin: 0;
  color: var(--fg);
  background: var(--bg);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-body);

}
body.article-page a {color: inherit; text-decoration-thickness: 0.12em; text-underline-offset: 0.18em;}
body.article-page a:hover {color: var(--accent);}
body.article-page a:focus-visible, body.article-page button:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;

}
body.article-page .skip-link {
  position: absolute;
  left: var(--space-4);
  top: var(--space-4);
  z-index: 20;
  transform: translateY(-180%);
  padding: var(--space-2) var(--space-3);
  border: 2px solid var(--fg);
  background: var(--bg);
  font: 700 var(--text-sm)/1.2 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;

}
body.article-page .skip-link:focus {transform: translateY(0);}
body.article-page .utility {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-2) var(--container-gutter-desktop);
  border-bottom: 1px solid var(--fg);
  background: var(--fg);
  color: var(--bg);
  font: 700 var(--text-xs)/1.4 var(--font-mono);
  letter-spacing: 0.09em;
  text-transform: uppercase;

}
body.article-page .utility a:hover {color: var(--bg);}
body.article-page article {
  max-width: var(--container-max);
  margin: 0 auto;
  border-right: 1px solid var(--fg);
  border-left: 1px solid var(--fg);
  overflow-wrap: break-word;

}
body.article-page .hero {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 0;
  border-bottom: 2px solid var(--fg);

}
body.article-page .hero-main {
  padding: var(--space-12) var(--container-gutter-desktop);
  border-right: 1px solid var(--fg);

}
body.article-page .kicker {
  margin: 0 0 var(--space-3);
  color: var(--accent);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0.09em;
  text-transform: uppercase;

}
body.article-page h1 {
  margin: 0;
  max-width: 11ch;
  font-family: var(--font-display);
  font-size: clamp(48px, 8vw, var(--text-4xl));
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-display);
  text-transform: uppercase;
  overflow-wrap: anywhere;

}
body.article-page .dek {
  max-width: 62ch;
  margin: var(--space-5) 0 0;
  color: var(--fg-2);
  font-size: var(--text-lg);

}
body.article-page .thesis {
  display: grid;
  align-content: end;
  padding: var(--space-6);
  background: var(--surface);

}
body.article-page .thesis h2 {
  margin: 0 0 var(--space-4);
  color: var(--accent);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0.09em;
  text-transform: uppercase;

}
body.article-page .thesis p {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 1.45;

}
body.article-page .body-grid {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);

}
body.article-page nav {
  position: sticky;
  top: 0;
  align-self: start;
  min-height: 100vh;
  padding: var(--space-6) var(--space-5);
  border-right: 1px solid var(--fg);
  background: var(--bg);

}
body.article-page nav p {
  margin: 0 0 var(--space-3);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0.09em;
  text-transform: uppercase;

}
body.article-page nav a {
  display: block;
  padding: var(--space-3) 0;
  border-top: 1px solid var(--border);
  text-decoration: none;
  font: 700 var(--text-sm)/1.4 var(--font-mono);

}
body.article-page nav a.is-current {color: var(--accent);}
body.article-page .content {
  min-width: 0;
  padding: 0 var(--container-gutter-desktop) var(--space-8);

}
body.article-page section {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: var(--space-8);
  padding: var(--space-8) 0;
  border-top: 1px solid var(--fg);

}
body.article-page section:first-child {border-top: 0;}
body.article-page .mark {
  color: var(--muted);
  font: 700 var(--text-xs)/1.4 var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;

}
body.article-page h2.section-heading {
  margin: 0 0 var(--space-4);
  max-width: 13ch;
  font-family: var(--font-display);
  font-size: clamp(34px, 5vw, var(--text-3xl));
  line-height: 0.98;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  overflow-wrap: anywhere;

}
body.article-page h3 {
  margin: 0 0 var(--space-2);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: 1;
  letter-spacing: -0.02em;
  text-transform: uppercase;

}
body.article-page p, body.article-page li {color: var(--fg-2);}
body.article-page p {margin: 0 0 var(--space-4);}
body.article-page strong {color: var(--fg);}
body.article-page .lead {
  color: var(--fg);
  font-size: var(--text-lg);
  line-height: 1.5;

}
body.article-page .proof-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: var(--space-5);
  border-top: 2px solid var(--fg);
  border-left: 2px solid var(--fg);

}
body.article-page .proof {
  min-height: 150px;
  padding: var(--space-5);
  border-right: 2px solid var(--fg);
  border-bottom: 2px solid var(--fg);
  background: var(--bg);

}
body.article-page .proof p {margin: 0;}
body.article-page .source-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--space-5);
  border-top: 2px solid var(--fg);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.45;
  max-width: 100%;

}
body.article-page .source-table th,
body.article-page .source-table td {
  padding: var(--space-3);
  border-bottom: 1px solid var(--fg);
  text-align: left;
  vertical-align: top;

}
body.article-page .source-table th {
  color: var(--fg);
  letter-spacing: 0.08em;
  text-transform: uppercase;

}
body.article-page ul {
  margin: var(--space-4) 0 0;
  padding-left: 1.2rem;

}
body.article-page li + li {margin-top: var(--space-3);}
body.article-page .flow {
  display: grid;
  grid-template-columns: 1fr 76px 1fr;
  margin-top: var(--space-5);
  border: 2px solid var(--fg);

}
body.article-page .flow-card {padding: var(--space-5);}
body.article-page .flow-card h3 {
  color: var(--accent);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0.09em;

}
body.article-page .arrow {
  display: grid;
  place-items: center;
  border-right: 2px solid var(--fg);
  border-left: 2px solid var(--fg);
  background: var(--fg);
  color: var(--bg);
  font: 700 var(--text-xl)/1 var(--font-mono);

}
body.article-page .prompt-box {
  margin-top: var(--space-5);
  border: 2px solid var(--fg);
  background: var(--fg);
  color: var(--bg);

}
body.article-page .prompt-box header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  font: 700 var(--text-xs)/1.2 var(--font-mono);
  letter-spacing: 0.09em;
  text-transform: uppercase;

}
body.article-page .copy-button {
  min-height: 38px;
  padding: 0 var(--space-4);
  border-color: var(--bg);
  background: var(--fg);
  color: var(--bg);

}
body.article-page .copy-button:hover {
  background: var(--bg);
  color: var(--fg);

}
body.article-page pre {
  margin: 0;
  padding: var(--space-5);
  overflow: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  color: var(--bg);
  font: 500 var(--text-sm)/1.8 var(--font-mono);

}
body.article-page .takeaway {
  margin: 0;
  padding: var(--space-5);
  border: 2px solid var(--fg);
  border-left: 12px solid var(--accent);
  color: var(--fg);
  font-size: var(--text-lg);

}
body.article-page .source-figure {
  margin: var(--space-5) 0 0;
  border-top: 2px solid var(--fg);
  padding-top: var(--space-4);

}
body.article-page .source-figure img {
  display: block;
  width: 100%;
  border: 1px solid var(--fg);
  border-radius: 0;

}
body.article-page .source-figure figcaption {
  margin-top: var(--space-2);
  color: var(--muted);
  font: 700 var(--text-xs)/1.6 var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;

}
body.article-page .footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-6) 0 0;
  border-top: 2px solid var(--fg);
  color: var(--muted);
  font: 700 var(--text-xs)/1.5 var(--font-mono);
  letter-spacing: 0.06em;

}
@media (max-width: 900px) {
  body.article-page .utility, body.article-page .hero-main, body.article-page .content {padding-left: var(--container-gutter-tablet); padding-right: var(--container-gutter-tablet);}
  body.article-page .hero, body.article-page .body-grid, body.article-page section {grid-template-columns: 1fr;}
  body.article-page .hero-main, body.article-page nav {border-right: 0;}
  body.article-page .thesis {border-top: 1px solid var(--fg);}
  body.article-page nav {
    position: static;
    min-height: 0;
    border-bottom: 1px solid var(--fg);

  }
  body.article-page nav a {
    display: inline-block;
    margin-right: var(--space-4);
    border-top: 0;
    border-bottom: 1px solid var(--border);

  }
}
@media (max-width: 560px) {
  body.article-page .utility {display: none;}
  body.article-page article {
    border-right: 0;
    border-left: 0;
  }
  body.article-page .hero-main,
  body.article-page .thesis,
  body.article-page nav,
  body.article-page .content {
    padding-left: var(--container-gutter-phone);
    padding-right: var(--container-gutter-phone);
  }
  body.article-page h1 {
    max-width: 100%;
    font-size: clamp(34px, 11vw, 44px);
    line-height: 1.02;
  }
  body.article-page h2.section-heading {
    max-width: 100%;
    font-size: clamp(28px, 10vw, 40px);
    line-height: 1.04;
  }
  body.article-page h3 {
    font-size: 24px;
    line-height: 1.08;
  }
  body.article-page nav a {
    display: block;
    margin-right: 0;
  }
  body.article-page .source-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  body.article-page .prompt-box header,
  body.article-page pre,
  body.article-page .takeaway,
  body.article-page .proof,
  body.article-page .flow-card {
    padding: var(--space-4);
  }
  body.article-page .proof-grid, body.article-page .flow {grid-template-columns: 1fr;}
  body.article-page .arrow {
    min-height: 58px;
    border: 0;
    border-top: 2px solid var(--fg);
    border-bottom: 2px solid var(--fg);

  }
}
@media (prefers-reduced-motion: reduce) {
  html {scroll-behavior: auto;}
}
