/* Zee Weekly — Sorbet palette + Classic typography (Fraunces / Source Serif 4 / JetBrains Mono) */

:root {
  /* Sorbet palette (from design) */
  --bg: #fff5f2;
  --surface: #ffe9e1;
  --surface-2: #ffdccf;
  --ink: #2a1a2e;
  --ink-dim: #7b5a6f;
  --ink-mute: #b892a7;
  --rule: #f5d4c4;
  --accent: #ff6fa5;
  --accent-ink: #2a1a2e;

  /* Wrapper fixed background (from design main.jsx line 72) */
  --wrapper-bg: rgb(255, 253, 252);

  /* Per-category colors (Sorbet-derived, extended to the 8 tags) */
  --cat-ai:         #ff6fa5; /* pink */
  --cat-marketing:  #6aa7f5; /* cornflower blue */
  --cat-investment: #5fcfbc; /* mint */
  --cat-politics:   #f5b84a; /* butter */
  --cat-psychology: #c78fd9; /* lavender */
  --cat-fitness:    #7dc87a; /* matcha green */
  --cat-food:       #ff9b7a; /* coral peach */
  --cat-other:      #a89f8f; /* warm grey */

  /* Category tints (14% alpha) and rule tints (35%) — matches resolveCardStyle */
  --cat-ai-tint:         rgba(255, 111, 165, 0.14);
  --cat-ai-rule:         rgba(255, 111, 165, 0.35);
  --cat-marketing-tint:  rgba(106, 167, 245, 0.14);
  --cat-marketing-rule:  rgba(106, 167, 245, 0.35);
  --cat-investment-tint: rgba(95, 207, 188, 0.14);
  --cat-investment-rule: rgba(95, 207, 188, 0.35);
  --cat-politics-tint:   rgba(245, 184, 74, 0.14);
  --cat-politics-rule:   rgba(245, 184, 74, 0.35);
  --cat-psychology-tint: rgba(199, 143, 217, 0.14);
  --cat-psychology-rule: rgba(199, 143, 217, 0.35);
  --cat-fitness-tint:    rgba(125, 200, 122, 0.14);
  --cat-fitness-rule:    rgba(125, 200, 122, 0.35);
  --cat-food-tint:       rgba(255, 155, 122, 0.14);
  --cat-food-rule:       rgba(255, 155, 122, 0.35);
  --cat-other-tint:      rgba(168, 159, 143, 0.14);
  --cat-other-rule:      rgba(168, 159, 143, 0.35);

  /* Typography — Classic pairing */
  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Source Serif 4', Georgia, serif;
  --font-mono:    'JetBrains Mono', 'SF Mono', Menlo, Monaco, monospace;
  --display-weight: 600;

  /* Layout */
  --max-w: 1240px;
  --pad: clamp(20px, 4vw, 56px);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--wrapper-bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-variation-settings: "opsz" 14;
}
a { color: inherit; }
button { font-family: inherit; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad);
}

/* ── Ticker animation (from design) ───────────────────────── */
@keyframes ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ─────────────────────────────────────────────────────────── */
/* Masthead                                                    */
/* ─────────────────────────────────────────────────────────── */
.masthead {
  padding: 24px 0;
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.masthead-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
}
.mast-left {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.mast-left .live { color: var(--accent); }
.mast-brand {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: 28px;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-decoration: none;
  text-align: center;
  white-space: nowrap;
}
.mast-nav {
  justify-self: end;
  display: flex;
  gap: 20px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.mast-nav a { color: var(--ink-dim); text-decoration: none; }
.mast-nav a.active { color: var(--ink); }

/* ── Subnav (tagline + archive link) ─────────────────────── */
.subnav {
  padding: 20px 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  border-bottom: 1px solid var(--rule);
}
.subnav .tagline {
  font-family: var(--font-body);
  font-size: 14px;
  font-style: italic;
  color: var(--ink-dim);
  letter-spacing: -0.005em;
}
.pill-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--surface);
  text-decoration: none;
  cursor: pointer;
}
.pill-btn .diamond { color: var(--accent); }

/* ─────────────────────────────────────────────────────────── */
/* Hero                                                        */
/* ─────────────────────────────────────────────────────────── */
.hero {
  padding: 48px 0 40px;
  border-bottom: 1px solid var(--rule);
}
.hero-ticker {
  overflow: hidden;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 14px 0;
  margin-bottom: 40px;
  background: var(--surface);
}
.hero-ticker .track {
  display: flex;
  gap: 40px;
  white-space: nowrap;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
  animation: ticker 40s linear infinite;
  width: max-content;
}
.hero-ticker .track span { display: inline-flex; align-items: center; gap: 40px; }
.hero-ticker .dot { color: var(--accent); }
.hero-ticker .dim { color: var(--ink-dim); }

.hero h1 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(44px, 9vw, 136px);
  line-height: 0.95;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.035em;
  max-width: 14ch;
}
.hero-meta {
  margin-top: 28px;
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.hero-meta .accent { color: var(--accent); }

/* ─────────────────────────────────────────────────────────── */
/* Editor's letter                                             */
/* ─────────────────────────────────────────────────────────── */
.letter {
  padding: 56px 0;
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 3fr);
  gap: 40px;
}
.letter-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 14px;
}
.letter-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--accent-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: 22px;
}
.letter-body {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(20px, 2.6vw, 30px);
  line-height: 1.4;
  color: var(--ink);
  margin: 0;
  letter-spacing: -0.01em;
  max-width: 36ch;
  text-wrap: pretty;
}

/* ─────────────────────────────────────────────────────────── */
/* Category filter pills                                       */
/* ─────────────────────────────────────────────────────────── */
.cat-filter {
  padding: 28px 0 4px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cat-filter .prefix {
  color: var(--ink-mute);
  margin-right: 10px;
}
.cat-filter a {
  padding: 6px 12px;
  border: 1px solid var(--rule);
  color: var(--ink);
  text-decoration: none;
}
.cat-filter a.all.active   { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.cat-filter a.ai.active          { background: var(--cat-ai);          color: #fff; border-color: var(--cat-ai); }
.cat-filter a.marketing.active   { background: var(--cat-marketing);   color: #fff; border-color: var(--cat-marketing); }
.cat-filter a.investment.active  { background: var(--cat-investment);  color: #fff; border-color: var(--cat-investment); }
.cat-filter a.politics.active    { background: var(--cat-politics);    color: var(--ink); border-color: var(--cat-politics); }
.cat-filter a.psychology.active  { background: var(--cat-psychology);  color: #fff; border-color: var(--cat-psychology); }
.cat-filter a.fitness.active     { background: var(--cat-fitness);     color: var(--ink); border-color: var(--cat-fitness); }
.cat-filter a.food.active        { background: var(--cat-food);        color: var(--ink); border-color: var(--cat-food); }
.cat-filter a.other.active       { background: var(--cat-other);       color: #fff; border-color: var(--cat-other); }

/* ─────────────────────────────────────────────────────────── */
/* Section (category block)                                    */
/* ─────────────────────────────────────────────────────────── */
.section { padding: 64px 0 32px; }
.section-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  margin-bottom: 28px;
  align-items: end;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 20px;
}
.section-head .rule {
  height: 4px;
  width: 40px;
  margin-bottom: 16px;
}
.section-head h2 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(40px, 5vw, 64px);
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.03em;
  line-height: 1;
}
.section-head .right {
  text-align: right;
  max-width: 32ch;
}
.section-head .count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-mute);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.section-head .blurb {
  font-family: var(--font-body);
  font-size: 14px;
  font-style: italic;
  color: var(--ink-dim);
  margin: 0;
  line-height: 1.5;
}

/* ── Per-category section accent rule colors ─────────────── */
.cat-ai         .rule { background: var(--cat-ai); }
.cat-marketing  .rule { background: var(--cat-marketing); }
.cat-investment .rule { background: var(--cat-investment); }
.cat-politics   .rule { background: var(--cat-politics); }
.cat-psychology .rule { background: var(--cat-psychology); }
.cat-fitness    .rule { background: var(--cat-fitness); }
.cat-food       .rule { background: var(--cat-food); }
.cat-other      .rule { background: var(--cat-other); }

/* ─────────────────────────────────────────────────────────── */
/* Magazine card grid                                          */
/* ─────────────────────────────────────────────────────────── */
.mag-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.mag-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-top: 3px solid var(--accent);
  position: relative;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
  padding: 26px 28px;
  gap: 12px;
  min-width: 0;
  text-decoration: none;
  color: inherit;
}
.mag-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(42, 26, 46, 0.13);
}
.mag-card.lead {
  grid-column: 1 / -1;
  padding: 36px 40px;
}

/* Per-category top border */
.mag-card.cat-ai         { border-top-color: var(--cat-ai); }
.mag-card.cat-marketing  { border-top-color: var(--cat-marketing); }
.mag-card.cat-investment { border-top-color: var(--cat-investment); }
.mag-card.cat-politics   { border-top-color: var(--cat-politics); }
.mag-card.cat-psychology { border-top-color: var(--cat-psychology); }
.mag-card.cat-fitness    { border-top-color: var(--cat-fitness); }
.mag-card.cat-food       { border-top-color: var(--cat-food); }
.mag-card.cat-other      { border-top-color: var(--cat-other); }

/* Alternating card fill — idx-even tints, idx-odd is neutral (matches resolveCardStyle alternating) */
.mag-card.fill-tinted.cat-ai         { background: var(--cat-ai-tint);          border-color: var(--cat-ai-rule); }
.mag-card.fill-tinted.cat-marketing  { background: var(--cat-marketing-tint);   border-color: var(--cat-marketing-rule); }
.mag-card.fill-tinted.cat-investment { background: var(--cat-investment-tint);  border-color: var(--cat-investment-rule); }
.mag-card.fill-tinted.cat-politics   { background: var(--cat-politics-tint);    border-color: var(--cat-politics-rule); }
.mag-card.fill-tinted.cat-psychology { background: var(--cat-psychology-tint);  border-color: var(--cat-psychology-rule); }
.mag-card.fill-tinted.cat-fitness    { background: var(--cat-fitness-tint);     border-color: var(--cat-fitness-rule); }
.mag-card.fill-tinted.cat-food       { background: var(--cat-food-tint);        border-color: var(--cat-food-rule); }
.mag-card.fill-tinted.cat-other      { background: var(--cat-other-tint);       border-color: var(--cat-other-rule); }

.mag-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.mag-head .cat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
}
.mag-head .idx {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* Per-category cat-label color */
.mag-card.cat-ai         .cat-label { color: var(--cat-ai); }
.mag-card.cat-marketing  .cat-label { color: var(--cat-marketing); }
.mag-card.cat-investment .cat-label { color: var(--cat-investment); }
.mag-card.cat-politics   .cat-label { color: var(--cat-politics); }
.mag-card.cat-psychology .cat-label { color: var(--cat-psychology); }
.mag-card.cat-fitness    .cat-label { color: var(--cat-fitness); }
.mag-card.cat-food       .cat-label { color: var(--cat-food); }
.mag-card.cat-other      .cat-label { color: var(--cat-other); }

.mag-card h3 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(20px, 1.8vw, 26px);
  line-height: 1.15;
  color: var(--ink);
  letter-spacing: -0.02em;
  margin: 0;
  text-wrap: pretty;
}
.mag-card.lead h3 {
  font-size: clamp(30px, 3.6vw, 48px);
}
.mag-card h3 a { color: inherit; text-decoration: none; padding-bottom: 2px; border-bottom: 1px solid transparent; transition: border-color 0.25s; }
.mag-card:hover h3 a { border-bottom-color: currentColor; }

.mag-lead-text {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-dim);
  margin: 0;
  text-wrap: pretty;
}
.mag-card.lead .mag-lead-text { font-size: 17px; }

.mag-card ul, .mag-card ol {
  margin: 4px 0 0;
  padding-left: 20px;
  color: var(--ink-dim);
  font-size: 14.5px;
}
.mag-card ul li, .mag-card ol li { margin: 0 0 6px; }

/* Recipe card emphasis */
.mag-card.recipe p strong {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
}
.mag-card.recipe .recipe-meta {
  font-style: italic;
  color: var(--ink-dim);
  font-size: 13px;
  margin: 0;
}

.mag-byline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
}
.mag-byline .avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  color: #fff;
  background: var(--accent);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  font-family: var(--font-display);
}
.mag-card.cat-ai         .mag-byline .avatar { background: var(--cat-ai); }
.mag-card.cat-marketing  .mag-byline .avatar { background: var(--cat-marketing); }
.mag-card.cat-investment .mag-byline .avatar { background: var(--cat-investment); }
.mag-card.cat-politics   .mag-byline .avatar { background: var(--cat-politics); color: var(--ink); }
.mag-card.cat-psychology .mag-byline .avatar { background: var(--cat-psychology); }
.mag-card.cat-fitness    .mag-byline .avatar { background: var(--cat-fitness); color: var(--ink); }
.mag-card.cat-food       .mag-byline .avatar { background: var(--cat-food); color: var(--ink); }
.mag-card.cat-other      .mag-byline .avatar { background: var(--cat-other); }

.mag-actions {
  margin-top: auto;
  padding-top: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  border-top: 1px solid var(--rule);
}
.mag-actions .open-link {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.mag-card.cat-ai         .open-link { color: var(--cat-ai); }
.mag-card.cat-marketing  .open-link { color: var(--cat-marketing); }
.mag-card.cat-investment .open-link { color: var(--cat-investment); }
.mag-card.cat-politics   .open-link { color: var(--cat-politics); }
.mag-card.cat-psychology .open-link { color: var(--cat-psychology); }
.mag-card.cat-fitness    .open-link { color: var(--cat-fitness); }
.mag-card.cat-food       .open-link { color: var(--cat-food); }
.mag-card.cat-other      .open-link { color: var(--cat-other); }
.mag-actions .permalink {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
  text-decoration: none;
}

/* ─────────────────────────────────────────────────────────── */
/* Week / archive list                                         */
/* ─────────────────────────────────────────────────────────── */
.week-list { list-style: none; padding: 0; margin: 0; }
.week-list li {
  padding: 16px 0;
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 16px;
}
.week-list a {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: 22px;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: -0.01em;
  padding-bottom: 2px;
  border-bottom: 1px solid transparent;
}
.week-list a:hover { border-bottom-color: var(--accent); }
.week-list .count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* ─────────────────────────────────────────────────────────── */
/* Reel detail page                                            */
/* ─────────────────────────────────────────────────────────── */
.reel-detail { padding: 48px 0 32px; }
.reel-detail .kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin: 0 0 14px;
}
.reel-detail .kicker a { color: var(--accent); text-decoration: none; }
.transcript, .caption {
  margin-top: 16px;
  padding: 16px 20px;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: 4px;
}
.transcript summary, .caption summary {
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-dim);
  user-select: none;
}
.transcript summary:hover, .caption summary:hover { color: var(--ink); }
.transcript[open] summary, .caption[open] summary { margin-bottom: 12px; }
.transcript .body, .caption .body {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.65;
  color: var(--ink-dim);
  white-space: pre-wrap;
}

/* ─────────────────────────────────────────────────────────── */
/* Subscribe                                                   */
/* ─────────────────────────────────────────────────────────── */
.subscribe {
  padding: 80px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  margin-top: 40px;
}
.subscribe .kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}
.subscribe h2 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.05;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.025em;
  text-wrap: balance;
  max-width: 20ch;
}
.subscribe p.lede {
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--ink-dim);
  max-width: 56ch;
  margin-top: 16px;
  line-height: 1.55;
}
.subscribe form {
  margin-top: 28px;
  display: flex;
  gap: 8px;
  max-width: 520px;
  flex-wrap: wrap;
}
.subscribe input[type="email"] {
  flex: 1 1 260px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--rule);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 15px;
  outline: none;
}
.subscribe button {
  padding: 14px 24px;
  background: var(--accent);
  color: var(--accent-ink);
  border: none;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  white-space: nowrap;
}
.subscribe .tiny {
  margin-top: 14px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-mute);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ─────────────────────────────────────────────────────────── */
/* Search                                                      */
/* ─────────────────────────────────────────────────────────── */
#search {
  --pagefind-ui-font: var(--font-body);
  --pagefind-ui-primary: var(--ink);
  --pagefind-ui-text: var(--ink);
  --pagefind-ui-background: var(--surface);
  --pagefind-ui-border: var(--rule);
  --pagefind-ui-tag: var(--accent);
  --pagefind-ui-border-radius: 4px;
  --pagefind-ui-border-width: 1px;
}

/* ─────────────────────────────────────────────────────────── */
/* Signoff                                                     */
/* ─────────────────────────────────────────────────────────── */
.signoff {
  padding: 48px 0;
  border-top: 1px solid var(--rule);
  max-width: 620px;
}
.signoff .label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: 14px;
}
.signoff p {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: 24px;
  line-height: 1.4;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}

/* ─────────────────────────────────────────────────────────── */
/* Footer                                                      */
/* ─────────────────────────────────────────────────────────── */
.site-footer {
  padding: 40px 0 60px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.08em;
}
.site-footer .row {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.site-footer a { color: var(--ink-dim); text-decoration: none; }
.site-footer a:hover { color: var(--ink); }

/* ─────────────────────────────────────────────────────────── */
/* Responsive                                                  */
/* ─────────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .masthead-grid { grid-template-columns: auto 1fr; }
  .mast-left { display: none; }
  .subnav { grid-template-columns: 1fr; }
  .letter { grid-template-columns: 1fr; gap: 20px; }
  .section-head { grid-template-columns: 1fr; gap: 16px; padding-bottom: 16px; }
  .mag-grid { grid-template-columns: 1fr; }
  .mag-card.lead { padding: 28px 24px; }
  .mag-card { padding: 22px 22px; }
}

/* Intro / archive page headers */
.intro {
  font-family: var(--font-body);
  font-size: 18px;
  font-style: italic;
  color: var(--ink-dim);
  padding-left: 16px;
  border-left: 3px solid var(--accent);
  margin: 0 0 32px;
  max-width: 56ch;
}

h1.page-h1 {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(40px, 6vw, 84px);
  margin: 40px 0 12px;
  color: var(--ink);
  letter-spacing: -0.035em;
  line-height: 0.95;
}

.page-date {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-dim);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 40px 0 6px;
}

/* Email-capture popup */
.zw-popup {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(11, 31, 58, 0.55);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; animation: zw-fade 0.25s ease;
}
.zw-popup[hidden] { display: none; }
@keyframes zw-fade { from { opacity: 0 } to { opacity: 1 } }
.zw-popup-card {
  position: relative;
  max-width: 460px; width: 100%;
  background: var(--wrapper-bg);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 14px;
  padding: 36px 32px 28px;
  box-shadow: 0 20px 60px rgba(11, 31, 58, 0.25);
  animation: zw-pop 0.3s cubic-bezier(0.2, 0.9, 0.3, 1.2);
}
@keyframes zw-pop { from { transform: translateY(12px) scale(0.98); opacity: 0 } to { transform: none; opacity: 1 } }
.zw-popup-card .kicker { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-dim); margin-bottom: 6px; }
.zw-popup-card h2 { font-family: var(--font-display); font-weight: var(--display-weight); font-size: clamp(22px, 2.4vw, 30px); line-height: 1.15; letter-spacing: -0.02em; margin: 0 0 10px; }
.zw-popup-card .lede { color: var(--ink-dim); margin: 0 0 18px; font-size: 15px; }
.zw-popup-card .tiny { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); margin-top: 12px; }
.zw-popup-close {
  position: absolute; top: 10px; right: 12px;
  background: none; border: none;
  font-size: 24px; line-height: 1; cursor: pointer;
  color: var(--ink-mute); padding: 4px 8px; border-radius: 6px;
}
.zw-popup-close:hover { color: var(--ink); background: rgba(0,0,0,0.05); }

/* Shared subscribe-form styling (inline + popup) */
.zw-subscribe-form { display: flex; gap: 8px; flex-wrap: wrap; }
.zw-subscribe-form input[type=email] {
  flex: 1; min-width: 200px;
  padding: 11px 14px; font-size: 15px;
  border: 1px solid rgba(0,0,0,0.15); border-radius: 8px;
  font-family: var(--font-body); background: #fff;
}
.zw-subscribe-form input[type=email]:focus { outline: 2px solid var(--cat-ai); outline-offset: 1px; }
.zw-subscribe-form button {
  padding: 11px 18px; font-size: 14px; font-weight: 600;
  font-family: var(--font-mono); letter-spacing: 0.04em;
  background: var(--ink); color: var(--bg);
  border: none; border-radius: 8px; cursor: pointer;
  transition: background 0.2s, transform 0.15s;
}
.zw-subscribe-form button:hover:not(:disabled) { background: var(--cat-ai); transform: translateY(-1px); }
.zw-subscribe-form button:disabled { opacity: 0.7; cursor: default; }
