/*
Theme Name: Marjorie System
Theme URI: https://marjoriegabriel.com
Author: Marjorie Gabriel
Author URI: https://marjoriegabriel.com
Description: Custom editorial system theme for Marjorie Gabriel
Version: 1.0
Text Domain: marjorie-system
*/

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

/* --------------------------------------------------------------------------
   Custom Properties
   -------------------------------------------------------------------------- */
:root {
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', monospace;

  /* Color */
  --c-bg:       #FAFAF8;
  --c-surface:  #F4F3F0;
  --c-text:     #0C0C0B;
  --c-muted:    #5A5A56;
  --c-faint:    #A0A09A;
  --c-border:   #E2E1DC;
  --c-accent:   #1B3A5C;
  --c-accent-dim: rgba(27, 58, 92, 0.08);

  /* Type scale */
  --mono-xs:    0.625rem;   /* 10px */
  --mono-sm:    0.6875rem;  /* 11px */
  --body-sm:    0.8125rem;  /* 13px */
  --body-base:  1rem;       /* 16px */
  --body-lg:    1.125rem;   /* 18px */
  --display-sm: 2rem;       /* 32px */
  --display-md: 3rem;       /* 48px */
  --display-lg: clamp(3.25rem, 6.5vw, 5.5rem);

  /* Spacing */
  --sp-1:  0.5rem;
  --sp-2:  1rem;
  --sp-3:  1.5rem;
  --sp-4:  2rem;
  --sp-6:  3rem;
  --sp-8:  4rem;
  --sp-10: 5rem;
  --sp-12: 6rem;
  --sp-16: 8rem;
  --sp-20: 10rem;

  /* Layout */
  --max-w:       1280px;
  --rail-w:      72px;
  --gutter:      clamp(1.5rem, 3.5vw, 2.5rem);
  --header-h:    56px;
  --context-h:   26px;

  /* Motion — minimal, precise */
  --ease:     cubic-bezier(0.16, 1, 0.3, 1);
  --dur:      0.25s;
}

/* --------------------------------------------------------------------------
   Reset
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  background-color: var(--c-bg);
  color: var(--c-text);
  font-family: var(--font-body);
  font-size: var(--body-base);
  font-weight: 400;
  line-height: 1.6;
  min-height: 100vh;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
ul, ol { list-style: none; }

/* --------------------------------------------------------------------------
   Container
   -------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

/* --------------------------------------------------------------------------
   Context Bar — top micro-line, anchors the identity immediately
   -------------------------------------------------------------------------- */
.context-bar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--context-h);
  background-color: var(--c-bg);
  border-bottom: 1px solid var(--c-border);
  z-index: 210;
  overflow: hidden;
}

.context-bar__inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  white-space: nowrap;
}

.context-bar__label {
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 400;
  color: var(--c-text);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.context-bar__sep {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--c-border);
  user-select: none;
}

.context-bar__item {
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 300;
  color: var(--c-faint);
  letter-spacing: 0.07em;
}

/* --------------------------------------------------------------------------
   Header
   -------------------------------------------------------------------------- */
.site-header {
  position: fixed;
  top: var(--context-h); left: 0; right: 0;
  z-index: 200;
  height: var(--header-h);
  background-color: var(--c-bg);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--ease);
}

.site-header.is-scrolled {
  border-bottom-color: var(--c-border);
}

.site-header__inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Wordmark: monospace, tracked, restrained */
.site-header__wordmark {
  font-family: var(--font-mono);
  font-size: var(--mono-sm);
  font-weight: 400;
  letter-spacing: 0.12em;
  color: var(--c-text);
  text-transform: uppercase;
  transition: color var(--dur) var(--ease);
}

.site-header__wordmark:hover { color: var(--c-accent); }

/* Nav */
.site-header__nav {
  display: flex;
  align-items: center;
  gap: var(--sp-6);
}

.site-header__nav a {
  font-family: var(--font-mono);
  font-size: var(--mono-sm);
  font-weight: 300;
  letter-spacing: 0.06em;
  color: var(--c-faint);
  transition: color var(--dur) var(--ease);
}

.site-header__nav a:hover,
.site-header__nav a.is-active { color: var(--c-text); }

/* --------------------------------------------------------------------------
   Page body offset
   -------------------------------------------------------------------------- */
.page-body { padding-top: calc(var(--header-h) + var(--context-h)); }

/* --------------------------------------------------------------------------
   LAYER SYSTEM
   The core structural pattern: numeric module IDs in a left rail,
   content offset to the right. No conventional section headers.
   -------------------------------------------------------------------------- */

.layer {
  padding-block: var(--sp-10);
  border-top: 1px solid var(--c-border);
}

.layer:first-child { border-top: none; }

/* The two-column layer layout: rail + content */
.layer__row {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr;
  gap: 0 var(--sp-4);
  align-items: start;
}

/* The monospace module ID in the left rail */
.module-id {
  font-family: var(--font-mono);
  font-size: 8px;
  font-weight: 300;
  color: var(--c-faint);
  letter-spacing: 0.04em;
  padding-top: 0.25em;
  user-select: none;
}

/* --------------------------------------------------------------------------
   Layer 01 — Statement (Hero)
   Full viewport presence, asymmetric grid, system manifest
   -------------------------------------------------------------------------- */
.layer--statement {
  padding-top: var(--sp-16);
  padding-bottom: var(--sp-16);
  min-height: calc(96vh - var(--header-h));
  display: flex;
  align-items: flex-end;
  border-top: none;
}

.statement__grid {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr 280px;
  gap: 0 var(--sp-4);
  align-items: end;
  width: 100%;
}

.statement__id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  padding-bottom: 0.25em;
  align-self: end;
}

/* The main statement — Cormorant Garamond, controlled, severe */
.statement__text {
  font-family: var(--font-display);
  font-size: var(--display-lg);
  font-weight: 300;
  line-height: 0.97;
  letter-spacing: -0.03em;
  color: var(--c-text);
}

/* The system manifest block — right column, monospace dot-fill */
.manifest {
  padding-bottom: 0.3em;
  border-left: 1px solid var(--c-border);
  padding-left: var(--sp-4);
}

.manifest__row {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 0;
  line-height: 2.0;
}

.manifest__key {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 300;
  color: var(--c-faint);
  white-space: nowrap;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Dots element retained in HTML but hidden — clean grid replaces it */
.manifest__dots { display: none; }

.manifest__val {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 400;
  color: var(--c-text);
  white-space: nowrap;
  letter-spacing: 0.06em;
}

.manifest__val--accent {
  color: var(--c-accent);
  opacity: 0.8;
}

/* --------------------------------------------------------------------------
   Layer 02 — Signal (Introduction paragraph)
   -------------------------------------------------------------------------- */
.layer--signal .layer__row {
  align-items: start;
}

.signal__content {
  max-width: 640px;
}

.signal__content p {
  font-size: var(--body-lg);
  font-weight: 300;
  line-height: 1.8;
  color: var(--c-text);
}

.signal__content p + p {
  margin-top: 1.4em;
  color: var(--c-muted);
}

/* --------------------------------------------------------------------------
   Layer 03 — Publications (Writing index)
   -------------------------------------------------------------------------- */
.pub-list {
  width: 100%;
}

.pub-list__item {
  display: grid;
  grid-template-columns: 32px 80px 1fr auto;
  gap: 0 var(--sp-3);
  align-items: baseline;
  padding-block: var(--sp-2);
  border-top: 1px solid var(--c-border);
  text-decoration: none;
  color: inherit;
  transition: background-color var(--dur) var(--ease);
}

.pub-list__item:last-child {
  border-bottom: 1px solid var(--c-border);
}

.pub-list__index {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.pub-list__date {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.pub-list__title {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: -0.01em;
  transition: color var(--dur) var(--ease);
}

.pub-list__item:hover .pub-list__title {
  color: var(--c-accent);
}

.pub-list__tag {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  font-weight: 300;
  transition: color var(--dur) var(--ease);
}

.pub-list__item:hover .pub-list__tag {
  color: var(--c-accent);
}

.pub-list__more {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--sp-4);
}

.pub-list__more a {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color var(--dur) var(--ease);
}

.pub-list__more a:hover { color: var(--c-accent); }

/* --------------------------------------------------------------------------
   Layer 04 — Domain (Areas of operation)
   -------------------------------------------------------------------------- */
.domain__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}

.domain__item {
  padding: var(--sp-4) var(--sp-4) var(--sp-4) 0;
  border-top: 1px solid var(--c-border);
}

.domain__item:nth-child(odd) { padding-right: var(--sp-6); }
.domain__item:nth-child(even) {
  padding-left: var(--sp-6);
  border-left: 1px solid var(--c-border);
}

/* Remove border-top for first two items since they're flush with the header rule */
.domain__item:nth-child(1),
.domain__item:nth-child(2) { border-top: none; }

.domain__item-id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  letter-spacing: 0.06em;
  font-weight: 300;
  margin-bottom: var(--sp-3);
  display: block;
}

.domain__item-title {
  font-family: var(--font-display);
  font-size: var(--display-sm);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin-bottom: var(--sp-2);
}

.domain__item-desc {
  font-size: var(--body-sm);
  color: var(--c-muted);
  line-height: 1.65;
  font-weight: 300;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.site-footer {
  padding-block: var(--sp-6);
  border-top: 1px solid var(--c-border);
  margin-top: var(--sp-4);
}

.site-footer__inner {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr auto;
  gap: 0 var(--sp-4);
  align-items: center;
}

.site-footer__id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
}

.site-footer__copy {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  letter-spacing: 0.04em;
}

.site-footer__links {
  display: flex;
  gap: var(--sp-4);
}

.site-footer__links a {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color var(--dur) var(--ease);
}

.site-footer__links a:hover { color: var(--c-text); }

/* ==========================================================================
   ARTICLE SINGLE PAGE
   ========================================================================== */

/* ==========================================================================
   SYSTEM RAIL — fixed left-side structural marker (article pages only)
   Appears only when outer margin is wide enough to hold it (~1380px+)
   ========================================================================== */

.system-rail {
  display: none;
  position: fixed;
  top: calc(var(--header-h) + var(--context-h));
  bottom: 0;
  /* Sits in the outer margin, left of the container */
  left: calc((100vw - 1280px) / 2 - 28px);
  width: 1px;
  pointer-events: none;
  z-index: 50;
}

.system-rail__line {
  position: absolute;
  top: 0; bottom: 0; left: 0;
  width: 1px;
  background-color: rgba(0,0,0,0.09);
}

.system-rail__markers {
  position: absolute;
  top: var(--sp-10);
  left: 10px;
  display: flex;
  flex-direction: column;
  gap: var(--sp-8);
}

.system-rail__marker {
  font-family: var(--font-mono);
  font-size: 7px;
  font-weight: 300;
  color: var(--c-faint);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  writing-mode: vertical-lr;
  white-space: nowrap;
  line-height: 1;
  opacity: 0.7;
}

.system-rail__marker--status {
  color: var(--c-accent);
  opacity: 0.45;
}

@media (min-width: 1380px) {
  .system-rail { display: block; }
}

/* Reading progress — 2px, accent, at top below header */
.reading-progress {
  position: fixed;
  top: calc(var(--header-h) + var(--context-h));
  left: 0; right: 0;
  height: 2px;
  z-index: 199;
  background: transparent;
}

.reading-progress__bar {
  height: 100%;
  width: 0%;
  background-color: var(--c-accent);
  transition: width 0.08s linear;
}

/* Article page layers */
.article-page { padding-top: var(--sp-16); }

/* Article Header Layer */
.article-header__layer {
  padding-bottom: var(--sp-8);
  border-bottom: 1px solid var(--c-border);
}

.article-header__grid {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr 240px;
  gap: 0 var(--sp-4);
  align-items: start;
}

.article-header__id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  padding-top: 0.3em;
}

.article-header__main {
  /* spans the center column */
}

.article-header__meta {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--c-border);
}

.article-header__topic {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-accent);
}

.article-header__date {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
}

.article-header__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4.5vw, 3.75rem);
  font-weight: 500;
  line-height: 0.97;
  letter-spacing: -0.03em;
}

.article-header__lede {
  margin-top: var(--sp-2);
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 300;
  font-style: italic;
  line-height: 1.35;
  color: var(--c-faint);
  max-width: 480px;
}

/* Article manifest (right column) — structured data table */
.article-manifest {
  border-left: 1px solid var(--c-border);
  border-top: 1px solid var(--c-border);
  padding-left: var(--sp-3);
  padding-top: 0;
}

.article-manifest__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-2);
  padding-block: 7px;
  border-bottom: 1px solid var(--c-border);
}

.article-manifest__key {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--c-faint);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 400;
  white-space: nowrap;
  flex-shrink: 0;
}

.article-manifest__val {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--c-text);
  letter-spacing: 0.05em;
  font-weight: 400;
  text-align: right;
}

/* Article body */
.article-body__layer {
  padding-block: var(--sp-8);
}

.article-body__grid {
  display: grid;
  grid-template-columns: var(--rail-w) 4fr 2fr;
  gap: 0 var(--sp-4);
}

.article-body__rail {
  /* empty — maintains grid rhythm */
}

.article-body__content {
  max-width: 640px;
  border-left: 1px solid rgba(0,0,0,0.08);
  padding-left: var(--sp-6);
}

.article-body__content p {
  font-size: var(--body-lg);
  line-height: 1.85;
  color: var(--c-text);
  font-weight: 300;
  margin-bottom: 1.6em;
}

.article-body__content p:last-child { margin-bottom: 0; }

.article-body__content h2 {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-top: 2.5em;
  margin-bottom: 0.75em;
}

.article-body__content h3 {
  font-family: var(--font-mono);
  font-size: var(--mono-sm);
  font-weight: 400;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-muted);
  margin-top: 2.2em;
  margin-bottom: 0.75em;
}

.article-body__content blockquote {
  border-left: 2px solid var(--c-accent);
  padding-left: var(--sp-4);
  margin-block: 2.5em;
  margin-left: 0;
}

.article-body__content blockquote p {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-style: italic;
  font-weight: 300;
  color: var(--c-text);
  line-height: 1.45;
  margin-bottom: 0;
}

.article-body__content strong { font-weight: 500; }

.article-body__content a {
  color: var(--c-accent);
  border-bottom: 1px solid rgba(27,58,92,0.25);
  transition: border-color var(--dur) var(--ease);
}

.article-body__content a:hover {
  border-bottom-color: var(--c-accent);
}

/* Article footer */
.article-footer__layer {
  padding-block: var(--sp-8);
  border-top: 1px solid var(--c-border);
}

.article-footer__grid {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr;
  gap: 0 var(--sp-4);
  align-items: center;
}

.article-footer__back {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color var(--dur) var(--ease);
}

.article-footer__back::before {
  content: '';
  display: block;
  width: 28px;
  height: 1px;
  background-color: currentColor;
  transition: width var(--dur) var(--ease);
}

.article-footer__back:hover { color: var(--c-accent); }
.article-footer__back:hover::before { width: 48px; }

/* ==========================================================================
   ARTICLES INDEX PAGE
   ========================================================================== */

.articles-index {
  padding-top: var(--sp-16);
  padding-bottom: var(--sp-20);
}

.articles-index__header {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr;
  gap: 0 var(--sp-4);
  padding-bottom: var(--sp-10);
  border-bottom: 1px solid var(--c-border);
  margin-bottom: var(--sp-2);
}

.articles-index__id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  padding-top: 0.3em;
}

.articles-index__title {
  font-family: var(--font-display);
  font-size: var(--display-md);
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: -0.015em;
}

.articles-index__count {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  letter-spacing: 0.04em;
  font-weight: 300;
  margin-top: var(--sp-3);
}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */

.about-page { padding-top: var(--sp-16); }

/* About hero — large serif statement, manifest on right */
.about-hero {
  padding-bottom: var(--sp-16);
  border-bottom: 1px solid var(--c-border);
}

.about-hero__grid {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr 280px;
  gap: 0 var(--sp-4);
  align-items: end;
}

.about-hero__id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  align-self: end;
  padding-bottom: 0.25em;
}

.about-hero__headline {
  font-family: var(--font-display);
  font-size: var(--display-lg);
  font-weight: 300;
  line-height: 0.97;
  letter-spacing: -0.025em;
}

/* About sections — same layer system as homepage */
.about-section {
  padding-block: var(--sp-10);
  border-top: 1px solid var(--c-border);
}

.about-section__row {
  display: grid;
  grid-template-columns: var(--rail-w) 1fr;
  gap: 0 var(--sp-4);
}

.about-section__id {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  font-weight: 300;
  letter-spacing: 0.04em;
  padding-top: 0.3em;
}

.about-section__content p {
  font-size: var(--body-lg);
  font-weight: 300;
  line-height: 1.8;
  color: var(--c-text);
  max-width: 660px;
}

.about-section__content p + p { margin-top: 1.4em; }

/* Responsibilities table */
.responsibility-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  max-width: 700px;
}

.responsibility-list__item {
  padding: var(--sp-3) 0;
  border-top: 1px solid var(--c-border);
}

.responsibility-list__item:nth-child(odd) { padding-right: var(--sp-4); }
.responsibility-list__item:nth-child(even) {
  padding-left: var(--sp-4);
  border-left: 1px solid var(--c-border);
}

.responsibility-list__code {
  font-family: var(--font-mono);
  font-size: var(--mono-xs);
  color: var(--c-faint);
  letter-spacing: 0.06em;
  font-weight: 300;
  display: block;
  margin-bottom: 0.5em;
}

.responsibility-list__title {
  font-size: var(--body-sm);
  font-weight: 400;
  color: var(--c-text);
  line-height: 1.4;
  margin-bottom: 0.3em;
}

.responsibility-list__desc {
  font-size: var(--body-sm);
  color: var(--c-muted);
  line-height: 1.55;
  font-weight: 300;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 1024px) {
  :root { --rail-w: 52px; }

  .statement__grid {
    grid-template-columns: var(--rail-w) 1fr 220px;
  }

  .article-header__grid {
    grid-template-columns: var(--rail-w) 1fr;
  }

  .article-header__manifest-col { display: none; }

  .about-hero__grid {
    grid-template-columns: var(--rail-w) 1fr 220px;
  }
}

@media (max-width: 768px) {
  :root { --rail-w: 40px; --gutter: 1.5rem; }

  .statement__grid {
    grid-template-columns: var(--rail-w) 1fr;
    row-gap: var(--sp-6);
  }

  .manifest { display: none; }

  .about-hero__grid {
    grid-template-columns: var(--rail-w) 1fr;
  }

  .about-hero__manifest { display: none; }

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

  .domain__item:nth-child(even) {
    border-left: none;
    padding-left: 0;
  }

  .domain__item:nth-child(1),
  .domain__item:nth-child(2) { border-top: 1px solid var(--c-border); }

  .domain__item:first-child { border-top: none; }

  .pub-list__item {
    grid-template-columns: 32px 1fr auto;
    gap: 0 var(--sp-2);
  }

  .pub-list__date { display: none; }

  .article-body__grid {
    grid-template-columns: var(--rail-w) 1fr;
  }

  .article-body__aside { display: none; }

  .responsibility-list {
    grid-template-columns: 1fr;
  }

  .responsibility-list__item:nth-child(even) {
    border-left: none;
    padding-left: 0;
  }
}

@media (max-width: 480px) {
  :root { --gutter: 1.25rem; }

  .site-header__nav { gap: var(--sp-4); }

  .pub-list__tag { display: none; }

  .site-footer__inner {
    grid-template-columns: 1fr;
    gap: var(--sp-1);
  }

  .site-footer__links { display: none; }
}
/* ==========================================================================
   MOBILE ARTICLE FIX — override broken layout
   Paste at very end of style.css
   ========================================================================== */

@media (max-width: 768px) {
  html, body {
    overflow-x: hidden;
  }

  /* Article header should stack cleanly */
  .article-header__grid {
    display: block;
  }

  .article-header__id {
    display: block;
    margin-bottom: 0.75rem;
    padding-top: 0;
  }

  .article-header__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
  }

  .article-header__title {
    font-size: clamp(2.25rem, 11vw, 3.25rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
    max-width: 100%;
  }

  .article-header__lede {
    max-width: 100%;
    font-size: 1rem;
    line-height: 1.5;
  }

  /* Manifest becomes normal stacked block */
  .article-manifest {
    margin-top: 1.5rem;
    border-left: none;
    border-top: 1px solid var(--c-border);
    padding-left: 0;
    padding-top: 0;
    max-width: 100%;
  }

  .article-manifest__row {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 0 1rem;
    align-items: baseline;
    padding-block: 0.7rem;
  }

  .article-manifest__val {
    text-align: left;
  }

  /* THIS is the critical fix */
  .article-body__grid {
    display: block;
  }

  .article-body__rail {
    display: none;
  }

  .article-body__content {
    max-width: 100%;
    width: 100%;
    min-width: 0;
    border-left: none;
    padding-left: 0;
    overflow-wrap: break-word;
    word-break: normal;
  }

  .article-body__content p,
  .article-body__content li,
  .article-body__content blockquote p {
    max-width: 100%;
  }

  .article-body__content p {
    font-size: 1.02rem;
    line-height: 1.78;
    margin-bottom: 1.35em;
  }

  .article-body__content h2 {
    font-size: 1.7rem;
    line-height: 1.08;
  }

  .article-body__content h3 {
    font-size: 0.72rem;
    line-height: 1.3;
  }

  .article-footer__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
}

@media (max-width: 480px) {
  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .article-header__meta {
    display: block;
  }

  .article-header__meta > * + * {
    margin-top: 0.25rem;
  }

  .article-manifest__row {
    grid-template-columns: 82px 1fr;
  }

  .article-body__content p {
    font-size: 1rem;
    line-height: 1.75;
  }
}
/* ==========================================================================
   DESKTOP ARTICLE HEADER ALIGNMENT FIX
   Paste at very end of style.css
   ========================================================================== */

@media (min-width: 769px) {
  .article-header__grid {
    display: grid;
    grid-template-columns: 72px minmax(0, 820px) 220px;
    gap: 0 2.5rem;
    align-items: start;
  }

  .article-header__id {
    padding-top: 0.7rem;
  }

  .article-header__main {
    min-width: 0;
    max-width: 820px;
  }

  .article-header__meta {
    display: flex;
    align-items: center;
    gap: 1rem 2rem;
    margin-bottom: 1.1rem;
    padding-bottom: 0.9rem;
    border-bottom: 1px solid var(--c-border);
  }

  .article-header__title {
    max-width: 14ch;
    font-size: clamp(3.2rem, 5vw, 4.8rem);
    line-height: 0.94;
    letter-spacing: -0.035em;
  }

  .article-header__lede {
    margin-top: 1.1rem;
    max-width: 34rem;
    font-size: 1.02rem;
    line-height: 1.55;
  }

  .article-manifest {
    align-self: start;
    margin-top: 8.2rem;
    max-width: 220px;
    border-left: 1px solid var(--c-border);
    border-top: none;
    padding-left: 1.5rem;
    padding-top: 0;
  }

  .article-manifest__row {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: 0 1rem;
    align-items: baseline;
    padding-block: 0.75rem;
    border-bottom: 1px solid var(--c-border);
  }

  .article-manifest__key {
    font-size: 9px;
    line-height: 1.2;
  }

  .article-manifest__val {
    font-size: 10px;
    line-height: 1.35;
    text-align: left;
  }
}
/* ==========================================================================
   ARTICLE DESKTOP PROPORTION TUNING
   Paste at end of style.css
   ========================================================================== */

@media (min-width: 769px) {
  .article-header__grid {
    grid-template-columns: 72px minmax(0, 920px) 220px;
    gap: 0 2rem;
    align-items: start;
  }

  .article-header__main {
    max-width: 920px;
  }

  .article-header__title {
    max-width: 16ch;
    font-size: clamp(3.2rem, 5vw, 4.8rem);
    line-height: 0.95;
    letter-spacing: -0.035em;
  }

  .article-header__lede {
    max-width: 40rem;
    margin-top: 1.1rem;
  }

  .article-manifest {
    margin-top: 7.4rem;
    max-width: 220px;
  }

  .article-body__grid {
    grid-template-columns: 72px minmax(0, 760px);
    gap: 0 2rem;
  }

  .article-body__content {
    max-width: 760px;
    padding-left: 1.5rem;
  }

  .article-body__content p {
    max-width: 38rem;
    font-size: 1.08rem;
    line-height: 1.85;
  }

  .article-body__content h2 {
    max-width: 38rem;
  }

  .article-body__content h3 {
    max-width: 38rem;
  }
}
/* ==========================================================================
   FINAL COMPOSITION FIX (DESKTOP)
   ========================================================================== */

@media (min-width: 769px) {

  /* Pull meta closer to title */
  .article-header__grid {
    grid-template-columns: 72px minmax(0, 880px) 180px;
    gap: 0 1.5rem;
  }

  /* Move meta UP so it aligns with title block */
  .article-manifest {
    margin-top: 5.8rem;
  }

  /* Reduce excessive space between header and body */
  .article-body {
    margin-top: 2.5rem;
  }

  /* Pull first paragraph closer to title */
  .article-body__content {
    padding-top: 0;
  }

  /* Improve visual continuity */
  .article-body__content p:first-of-type {
    margin-top: 0;
  }
}
/* ==========================================================================
   FINAL MOBILE WRITING LIST FIX
   Keeps SYS index separate from article title on mobile
   ========================================================================== */

@media (max-width: 768px) {
  .pub-list__item {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    column-gap: 1.25rem;
    row-gap: 0.35rem;
    align-items: start;
    padding-block: 1.35rem;
  }

  .pub-list__index {
    grid-column: 1;
    grid-row: 1;
    display: block;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    white-space: nowrap;
  }

  .pub-list__date {
    grid-column: 1;
    grid-row: 2;
    display: block;
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    white-space: nowrap;
    opacity: 0.65;
  }

  .pub-list__title {
    grid-column: 2;
    grid-row: 1 / span 2;
    display: block;
    min-width: 0;
    line-height: 1.15;
    overflow-wrap: break-word;
  }
}