/* ==========================================================
   Scrubswire — site.css
   Layout + components for the live site. Sits on top of
   colors_and_type.css (which owns all design tokens).
   ========================================================== */

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body { min-height: 100vh; display: flex; flex-direction: column; }

/* ---- Masthead ---- */
.masthead {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250, 250, 247, 0.85);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  border-bottom: 1px solid var(--rule);
}
.masthead__inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 var(--s-7);
  height: var(--header-h);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-6);
}
.masthead__brand {
  text-decoration: none;
  display: inline-flex; flex-direction: column; gap: 2px;
}
.masthead__wordmark {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.masthead__rule {
  display: block;
  width: 18px; height: 2px;
  background: var(--surgical-700);
}
.masthead__nav {
  display: flex; gap: var(--s-5);
  justify-content: center;
}
.masthead__nav a {
  font-family: var(--font-sans);
  font-size: var(--type-ui);
  font-weight: 500;
  text-decoration: none;
  color: var(--ink);
  position: relative;
  padding: 4px 0;
}
.masthead__nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 2px; background: var(--ink);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-fast) var(--ease-editorial);
}
.masthead__nav a:hover::after { transform: scaleX(1); }
.masthead__account {
  display: flex; align-items: center; gap: var(--s-4);
  font-family: var(--font-sans); font-size: var(--type-ui);
}
/* Apply link reset to non-button anchors only — otherwise the .btn--ink
   primary CTA inherits black-on-black text. */
.masthead__account a:not(.btn) { color: var(--ink); text-decoration: none; }
.masthead__account a:not(.btn):hover { color: var(--surgical-700); }
.masthead__greeting { color: var(--ink-60); }
.masthead__linkbtn {
  background: none; border: 0; padding: 0;
  font: inherit; color: var(--ink); cursor: pointer;
}
.masthead__linkbtn:hover { color: var(--surgical-700); }

/* ---- Flash ---- */
.flash {
  background: var(--surgical-100);
  border-bottom: 1px solid var(--rule);
}
.flash__inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: var(--s-3) var(--s-7);
  font-family: var(--font-sans); font-size: var(--type-meta);
  color: var(--surgical-900);
}

/* ---- Page ---- */
.page {
  flex: 1;
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
  padding: var(--s-7) var(--s-7) var(--s-9);
}

/* ---- Lede / hero ---- */
.lede__hero {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: var(--s-7);
  align-items: center;
  padding: var(--s-5) 0 var(--s-7);
}
.lede__image { display: block; overflow: hidden; aspect-ratio: 4 / 3; }
.lede__image img {
  width: 100%; height: 100%;
  display: block;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-editorial);
}
.lede__image:hover img { transform: scale(1.02); }
.lede__text { min-width: 0; }
.lede__hero h1.display { margin: var(--s-3) 0 var(--s-4); }
.lede__hero h1 a { color: inherit; text-decoration: none; }
.lede__hero h1 a:hover { color: var(--surgical-700); }
.lede__hero .deck { margin-bottom: var(--s-4); }
@media (max-width: 900px) {
  .lede__hero { grid-template-columns: 1fr; gap: var(--s-5); }
}

/* ---- Grid ---- */
.grid { display: grid; gap: var(--s-7) var(--s-6); padding: var(--s-5) 0; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1024px) { .grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px)  { .grid--3 { grid-template-columns: 1fr; } }

/* ---- Article tile ---- */
.tile { display: flex; flex-direction: column; gap: var(--s-3); }
.tile__image { display: block; overflow: hidden; aspect-ratio: 16 / 10; margin-bottom: var(--s-2); }
.tile__image img {
  width: 100%; height: 100%;
  display: block;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-editorial);
}
.tile__image:hover img { transform: scale(1.02); }
.tile__headline {
  font-family: var(--font-serif);
  font-size: 22px; line-height: 1.2; font-weight: 600;
  letter-spacing: -0.01em; margin: 0;
  text-wrap: balance;
}
.tile__headline a { color: inherit; text-decoration: none; }
.tile__headline a:hover { color: var(--surgical-700); }
.tile__deck {
  font-family: var(--font-sans);
  font-size: var(--type-ui); color: var(--ink-80); margin: 0;
}
.tile__meta { font-family: var(--font-sans); font-size: var(--type-meta); color: var(--ink-60); margin: 0; }
.tile__meta .dot { color: var(--ink-40); }
.tile--compact .tile__headline { font-size: 19px; }

/* ---- Article view ---- */
.article {
  max-width: var(--column-text);
  margin: var(--s-5) auto var(--s-9);
  padding: 0 var(--s-4);
}
.article h1 { margin: var(--s-3) 0 var(--s-4); }
.article .deck { margin-bottom: var(--s-4); }
.article__cover { margin: var(--s-5) 0; padding: 0; aspect-ratio: 16 / 9; overflow: hidden; }
.article__cover img {
  width: 100%; height: 100%;
  display: block;
  object-fit: cover;
}

/* ---- Cover placeholder (when no cover_image is set) ---- */
.cover-frame:not(:has(img)) {
  background: var(--bone);
  border: 1px solid var(--ink-40);
  display: flex; align-items: center; justify-content: center;
}
.cover-frame__caption {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-60);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.article__meta {
  font-family: var(--font-sans); font-size: var(--type-meta); color: var(--ink-60);
  margin: 0 0 var(--s-4);
}
.article__body p { margin: 0 0 var(--s-5); }
.article__body p + p { margin-top: 0; }
.article__body h2,
.article__body h3 { margin: var(--s-7) 0 var(--s-3); }
.article__body blockquote {
  border-left: 3px solid var(--surgical-700);
  padding-left: var(--s-4);
  margin: var(--s-6) 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px; line-height: 1.4;
  color: var(--ink-80);
}
.article__body code {
  background: var(--bone);
  padding: 1px 6px; border-radius: 3px;
}
.article__body pre {
  background: var(--bone);
  padding: var(--s-4);
  overflow-x: auto;
  border-radius: var(--radius-1);
}

/* ---- Section list ---- */
.section-page { max-width: 1440px; margin: 0 auto; padding: var(--s-3) 0; }
.section-page > h1 {
  font-family: var(--font-serif);
  font-size: var(--type-h1);
  margin: var(--s-3) 0 var(--s-5);
}
.section-page > .grid { padding-top: var(--s-5); }

/* ---- Long-form doc pages (privacy, terms, etc.) ---- */
.doc {
  max-width: var(--column-text);
  margin: var(--s-5) auto var(--s-9);
  padding: 0 var(--s-4);
}
.doc h1 {
  font-family: var(--font-serif);
  font-size: var(--type-h1);
  line-height: var(--lh-h1);
  margin: var(--s-3) 0 var(--s-6);
}
.doc__body {
  font-family: var(--font-sans);
  font-size: var(--type-body);
  line-height: var(--lh-body);
  color: var(--ink);
}
.doc__body p { margin: 0 0 var(--s-5); }
.doc__body h2 {
  font-family: var(--font-serif);
  font-size: 26px; line-height: 1.25;
  margin: var(--s-7) 0 var(--s-3);
  font-weight: 600;
}
.doc__body h3 {
  font-family: var(--font-serif);
  font-size: 20px; line-height: 1.3;
  margin: var(--s-6) 0 var(--s-3);
  font-weight: 600;
}
.doc__body ul, .doc__body ol { margin: 0 0 var(--s-5); padding-left: var(--s-6); }
.doc__body li { margin-bottom: var(--s-2); }
.doc__body blockquote {
  border-left: 3px solid var(--ink-20);
  padding-left: var(--s-4);
  margin: var(--s-5) 0;
  color: var(--ink-80);
}
.doc__body code {
  font-family: var(--font-mono); font-size: 14px;
  background: var(--bone);
  padding: 1px 6px; border-radius: 3px;
}
.doc__body table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-5) 0;
  font-size: var(--type-ui);
}
.doc__body th, .doc__body td {
  text-align: left;
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.doc__body th {
  font-weight: 600;
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: var(--type-meta);
  color: var(--ink-60);
  background: var(--bone);
  border-bottom: 1px solid var(--ink-20);
}
.doc__body strong { font-weight: 600; }
.doc__body em { font-style: italic; }
.doc__body hr { border: 0; border-top: 1px solid var(--rule); margin: var(--s-7) 0; }
.doc__body a { color: var(--ink); text-underline-offset: 3px; }
.doc__body a:hover { color: var(--surgical-700); }

/* ---- Auth pages / forms ---- */
.auth {
  max-width: 460px;
  margin: var(--s-7) auto var(--s-9);
}
.auth h1 { margin: 0 0 var(--s-3); }
.auth__alt { margin-top: var(--s-5); font-size: var(--type-meta); color: var(--ink-60); }

.form { display: flex; flex-direction: column; gap: var(--s-5); margin-top: var(--s-5); }
.form label { display: flex; flex-direction: column; gap: var(--s-2); }
.form .kicker { color: var(--ink-60); }
.form input,
.form select,
.form textarea {
  font-family: var(--font-sans); font-size: var(--type-body);
  color: var(--ink);
  background: var(--paper);
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-1);
  padding: var(--s-3) var(--s-4);
  outline: 0;
  transition: border-color var(--dur-fast) var(--ease-editorial);
}
.form textarea {
  font-family: var(--font-mono);
  font-size: 14px; line-height: 1.55;
  resize: vertical; min-height: 220px;
}
.form input:focus,
.form select:focus,
.form textarea:focus { border-color: var(--surgical-700); }
.form__hint { font-size: var(--type-meta); color: var(--ink-60); }
.form__error {
  font-size: var(--type-meta);
  color: var(--pulse-700);
  background: var(--pulse-100);
  border-left: 3px solid var(--pulse-600);
  padding: var(--s-3) var(--s-4);
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-sans); font-size: var(--type-ui); font-weight: 600;
  padding: var(--s-3) var(--s-5);
  border: 1px solid transparent;
  border-radius: var(--radius-1);
  cursor: pointer; text-decoration: none;
  transition: background var(--dur-fast) var(--ease-editorial),
              color var(--dur-fast) var(--ease-editorial),
              transform var(--dur-fast) var(--ease-editorial);
}
.btn--ink { background: var(--ink); color: var(--paper); }
.btn--ink:hover { background: var(--surgical-700); }
.btn--ink:active { transform: translateY(1px); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--ink-20); }
.btn--ghost:hover { border-color: var(--ink); }

/* ---- Admin queue ---- */
.admin { max-width: 880px; margin: 0 auto; }
.admin__list { list-style: none; padding: 0; margin: var(--s-5) 0; }
.admin__item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: var(--s-5);
  padding: var(--s-5) 0;
  border-bottom: 1px solid var(--rule);
}
.admin__item h3 { margin: var(--s-2) 0; }
.admin__actions { display: flex; gap: var(--s-3); align-items: center; }
.admin__source {
  font-family: var(--font-mono); font-size: 14px; line-height: 1.6;
  background: var(--bone);
  padding: var(--s-5);
  white-space: pre-wrap; word-wrap: break-word;
}

/* ---- Empty state ---- */
.empty {
  padding: var(--s-9) 0;
  text-align: center;
  color: var(--ink-60);
}

/* ---- Footer ---- */
.footer {
  max-width: 1440px;
  width: 100%;
  margin: var(--s-9) auto 0;
  padding: 0 var(--s-7) var(--s-7);
}
.footer__inner {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--s-7);
  padding: var(--s-6) 0;
}
.footer__brand { display: flex; flex-direction: column; gap: var(--s-3); }
.footer__wordmark {
  font-family: var(--font-serif); font-weight: 700; font-size: 24px;
  letter-spacing: -0.02em;
}
.footer__tag { color: var(--ink-60); font-size: var(--type-meta); margin: 0; max-width: 320px; }
.footer__address {
  font-family: var(--font-mono); font-size: 12px; line-height: 1.6;
  color: var(--ink-60);
  margin: var(--s-3) 0 0;
  font-style: normal;
}
.footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
.footer__list { list-style: none; padding: 0; margin: var(--s-3) 0 0; display: flex; flex-direction: column; gap: var(--s-2); }
.footer__list a { color: var(--ink); text-decoration: none; font-size: var(--type-ui); }
.footer__list a:hover { color: var(--surgical-700); }
.footer__legal {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--s-4);
  padding-top: var(--s-5);
  border-top: 1px solid var(--rule);
}
.footer__copyright {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--ink-60);
  margin: 0;
}
.footer__legal-links {
  font-family: var(--font-sans); font-size: var(--type-meta);
  color: var(--ink-60);
  margin: 0;
}
.footer__legal-links a { color: var(--ink-80); text-decoration: none; }
.footer__legal-links a:hover { color: var(--surgical-700); }
.footer__legal-links .dot { color: var(--ink-40); }
/* =========================================================
   New components added in v4 (newsletter, share, account,
   admin edit, mobile menu, cookie banner, headlines rail).
   ========================================================= */

/* Screen-reader only */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0;
  margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* Masthead — hamburger + drawer + search */
.masthead__hamburger {
  display: none;
  background: none; border: 0; padding: 8px; cursor: pointer;
  width: 40px; height: 40px;
  flex-direction: column; gap: 4px;
  align-items: center; justify-content: center;
}
.masthead__hamburger-bar {
  display: block; width: 22px; height: 2px;
  background: var(--ink);
  transition: transform var(--dur-fast) var(--ease-editorial);
}
.masthead__drawer {
  border-top: 1px solid var(--rule);
  background: var(--paper);
  padding: var(--s-5) var(--s-7);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.masthead__drawer[hidden] { display: none; }
.masthead__drawer a,
.masthead__drawer .masthead__linkbtn {
  font-family: var(--font-sans); font-size: var(--type-body);
  color: var(--ink); text-decoration: none;
  padding: var(--s-2) 0;
}
.masthead__drawer nav { display: flex; flex-direction: column; gap: var(--s-2); }
.masthead__drawer .btn { align-self: flex-start; }
.masthead__search-link {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  color: var(--ink-80);
}
.masthead__search-link:hover { color: var(--surgical-700); }

/* Cookie banner */
.cookie-banner {
  position: fixed; bottom: var(--s-4); left: var(--s-4); right: var(--s-4);
  z-index: 100;
  background: var(--paper);
  border: 1px solid var(--ink-20);
  box-shadow: var(--shadow-2);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--radius-1);
  max-width: 720px;
  margin: 0 auto;
}
.cookie-banner[hidden] { display: none; }
.cookie-banner__inner {
  display: flex; gap: var(--s-5); align-items: center;
}
.cookie-banner__text {
  flex: 1; margin: 0;
  font-family: var(--font-sans); font-size: var(--type-meta);
  color: var(--ink-80); line-height: 1.5;
}
@media (max-width: 600px) {
  .cookie-banner__inner { flex-direction: column; align-items: flex-start; }
}

/* Newsletter card */
.newsletter-card {
  margin: var(--s-9) 0 var(--s-7);
  padding: var(--s-7) var(--s-7);
  background: var(--bone);
  border: 1px solid var(--rule);
  display: grid; grid-template-columns: 7fr 5fr; gap: var(--s-7); align-items: center;
}
.newsletter-card__title {
  font-family: var(--font-serif); font-weight: 600;
  font-size: 28px; line-height: 1.2; margin: var(--s-3) 0 var(--s-3);
}
.newsletter-card__deck {
  font-family: var(--font-sans); font-size: var(--type-ui);
  color: var(--ink-80); margin: 0;
}
.newsletter-card__form {
  display: flex; flex-direction: column; gap: var(--s-3);
}
.newsletter-card__form input {
  font-family: var(--font-sans); font-size: var(--type-body);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-1);
  background: var(--paper);
}
.newsletter-card__form input:focus { outline: none; border-color: var(--surgical-700); }
.newsletter-card__form .btn { align-self: flex-start; }
.newsletter-card--thanks,
.newsletter-card--error { display: block; }
@media (max-width: 800px) {
  .newsletter-card { grid-template-columns: 1fr; padding: var(--s-6) var(--s-5); }
}

/* Share row */
.share-row {
  margin: var(--s-7) 0 var(--s-5);
  display: flex; align-items: center; gap: var(--s-4);
}
.share-row__buttons { display: flex; gap: var(--s-2); }
.share-row__btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-pill);
  font-family: var(--font-sans); font-weight: 600; font-size: 14px;
  color: var(--ink); background: var(--paper);
  text-decoration: none; cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-editorial),
              color var(--dur-fast) var(--ease-editorial);
}
.share-row__btn:hover { border-color: var(--ink); color: var(--surgical-700); }

/* Related rail */
.related { margin-top: var(--s-7); }

/* Headlines list (more-from-the-wire rail under homepage grid) */
.headlines-list {
  list-style: none; padding: 0; margin: var(--s-3) 0;
  display: flex; flex-direction: column;
}
.headlines-list__item {
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: var(--s-4);
  align-items: baseline;
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--rule);
}
.headlines-list__kicker {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: var(--track-kicker);
  color: var(--ink-60);
}
.headlines-list__link {
  font-family: var(--font-serif);
  font-size: 18px; font-weight: 500; line-height: 1.3;
  color: var(--ink); text-decoration: none;
}
.headlines-list__link:hover { color: var(--surgical-700); }
.headlines-list__time { color: var(--ink-60); font-size: 12px; }
@media (max-width: 600px) {
  .headlines-list__item { grid-template-columns: 1fr; gap: var(--s-2); }
  .headlines-list__time { display: none; }
}

/* Account pages */
.account { max-width: 720px; margin: 0 auto; padding: var(--s-3) 0; }
.account__tabs {
  display: flex; gap: var(--s-5);
  margin: var(--s-5) 0 var(--s-3);
  border-bottom: 1px solid var(--rule);
}
.account__tabs a {
  padding: var(--s-2) 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  text-decoration: none; color: var(--ink-60);
  font-family: var(--font-sans); font-size: var(--type-ui);
}
.account__tabs a:hover { color: var(--ink); }
.account__tabs a.is-active {
  color: var(--ink); border-bottom-color: var(--ink);
}
.account__danger { margin-top: var(--s-7); }
.account__danger summary { display: inline-flex; cursor: pointer; }
.account__danger form { margin-top: var(--s-4); border-left: 3px solid var(--pulse-600); padding-left: var(--s-4); }

/* Author byline page */
.author-page { max-width: 1440px; margin: 0 auto; padding: var(--s-5) 0; }
.author-page__bio {
  font-family: var(--font-serif); font-style: italic;
  font-size: 22px; line-height: 1.4;
  color: var(--ink-80); max-width: var(--column-text);
  margin: var(--s-3) 0;
}
.author-page__social {
  font-family: var(--font-sans); font-size: var(--type-meta);
  color: var(--ink-60);
}

/* Search page */
.search-page { max-width: 1440px; margin: 0 auto; padding: var(--s-3) 0; }
.search-page__form {
  flex-direction: row;
  gap: var(--s-3);
  align-items: stretch;
  margin-top: var(--s-5);
}
.search-page__form input {
  flex: 1;
  font-family: var(--font-sans); font-size: var(--type-h3);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-1);
}
.search-page__form input:focus { outline: none; border-color: var(--surgical-700); }
.search-page__form .btn { align-self: stretch; }

/* Markdown preview pane on submit */
.preview-pane {
  border: 1px dashed var(--ink-20);
  background: var(--bone);
  padding: var(--s-5);
  margin-top: var(--s-3);
}
.preview-pane > .kicker { color: var(--ink-60); margin: 0 0 var(--s-3); }
.preview-pane__body { font-family: var(--font-sans); }
.preview-pane__body h1,
.preview-pane__body h2,
.preview-pane__body h3 { font-family: var(--font-serif); margin: var(--s-4) 0 var(--s-2); }
.preview-pane__body p { margin: 0 0 var(--s-3); }

/* Submit form wider */
.auth--wide { max-width: 760px; }

/* Admin edit + reject UI */
.admin__edit { background: var(--bone); padding: var(--s-5); margin: var(--s-5) 0; }
.admin__edit textarea {
  font-family: var(--font-mono); font-size: 14px; line-height: 1.55;
  resize: vertical;
}
.admin__actions--bar {
  display: flex; gap: var(--s-4); align-items: center; flex-wrap: wrap;
  padding: var(--s-5) 0;
}
.admin__reject summary {
  list-style: none; cursor: pointer;
}
.admin__reject summary::-webkit-details-marker { display: none; }
.admin__reject-form {
  margin-top: var(--s-4); padding: var(--s-4);
  background: var(--pulse-100);
  border-left: 3px solid var(--pulse-600);
}
.admin__reject-form textarea {
  font-family: var(--font-sans); font-size: var(--type-ui);
}

/* Flash messages */
.form__flash {
  font-size: var(--type-meta);
  background: var(--surgical-100);
  border-left: 3px solid var(--surgical-700);
  padding: var(--s-3) var(--s-4);
  color: var(--surgical-900);
}

/* =========================================================
   v7.1 editorial polish: reading progress, drop cap,
   hero fade-in, refined pull quote. All zero-JS-friendly,
   no perf cost.
   ========================================================= */

/* Reading progress bar (article pages) */
.reading-progress {
  position: fixed; top: 0; left: 0; right: 0;
  height: 2px;
  z-index: 60; /* above masthead's sticky backdrop */
  background: transparent;
  pointer-events: none;
}
.reading-progress__bar {
  height: 100%;
  background: var(--surgical-700);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 120ms linear;
}

/* Drop cap on first paragraph of an article body. The selector intentionally
   excludes paragraphs that start with the dateline (which has a span before
   the text). */
.article__body > p:first-of-type:first-letter {
  font-family: var(--font-serif);
  font-weight: 700;
  float: left;
  font-size: 4.6em;
  line-height: 0.9;
  margin: 0.05em 0.08em 0 0;
  color: var(--ink);
  letter-spacing: -0.02em;
}
/* If the lede starts with the dateline span, skip the drop cap (it would
   blow up the OAKLAND, CALIF. — text). */
.article__body > p:first-of-type:has(.dateline):first-letter {
  font-size: inherit; font-weight: inherit; float: none; margin: 0;
}

/* Homepage hero — soft fade-up on first paint. Design system § animation:
   "Scroll reveals: none on article pages. Allowed on the homepage hero
   only — a 12px upward fade-in on first paint." */
@media (prefers-reduced-motion: no-preference) {
  .lede__hero {
    animation: hero-rise 600ms var(--ease-editorial) both;
  }
}
@keyframes hero-rise {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Refined pull quote — adds a large decorative open-quote mark like a
   magazine, lifted from FT / The Atlantic editorial conventions. */
.article__body blockquote {
  position: relative;
  margin: var(--s-7) 0;
  padding: 0 0 0 var(--s-6);
  border-left: 3px solid var(--surgical-700);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 24px;
  line-height: 1.4;
  color: var(--ink);
  font-weight: 500;
  text-wrap: balance;
}
.article__body blockquote::before {
  content: "";
  position: absolute;
  left: -2px;
  top: -28px;
  width: 1.2em;
  height: 28px;
  background:
    linear-gradient(var(--surgical-700), var(--surgical-700)) left top / 3px 28px no-repeat;
}
.article__body blockquote p { margin: 0 0 var(--s-3); }

/* Bigger top-of-article H2/H3 spacing for breathing room. */
.article__body h2 {
  font-family: var(--font-serif);
  font-size: 28px; line-height: 1.25;
  margin: var(--s-7) 0 var(--s-3);
  font-weight: 600;
}
.article__body h3 {
  font-family: var(--font-serif);
  font-size: 20px; line-height: 1.3;
  margin: var(--s-6) 0 var(--s-2);
  font-weight: 600;
}

/* Article author bio card (foot of article) */
.author-bio-card {
  max-width: var(--column-text);
  margin: var(--s-7) 0;
  padding: var(--s-5);
  background: var(--bone);
  border: 1px solid var(--rule);
}
.author-bio-card__row {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--s-4);
  align-items: start;
  margin-top: var(--s-3);
}
.author-bio-card__avatar {
  width: 64px; height: 64px;
  background: var(--ink);
  color: var(--paper);
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
}
.author-bio-card__monogram {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: 26px;
}
.author-bio-card__name {
  font-family: var(--font-serif); font-weight: 600;
  font-size: 18px; margin: 0;
}
.author-bio-card__name a { color: var(--ink); text-decoration: none; }
.author-bio-card__name a:hover { color: var(--surgical-700); }
.author-bio-card__bio {
  font-size: var(--type-ui); color: var(--ink-80);
  margin: var(--s-2) 0 var(--s-3); line-height: 1.55;
}
.author-bio-card__more {
  font-size: var(--type-meta);
  margin: 0;
}
.author-bio-card__more a { color: var(--surgical-700); }

/* "Updated" stamp */
.article__updated {
  font-family: var(--font-mono); font-size: var(--type-meta);
  color: var(--surgical-700);
}

/* Staff (masthead) page */
.staff__list {
  list-style: none; padding: 0; margin: var(--s-5) 0;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-5);
}
@media (max-width: 720px) {
  .staff__list { grid-template-columns: 1fr; }
}
.staff__card {
  display: grid; grid-template-columns: 56px 1fr; gap: var(--s-4);
  padding: var(--s-4);
  border: 1px solid var(--rule);
  background: var(--paper);
}
.staff__avatar {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--ink); color: var(--paper);
  display: flex; align-items: center; justify-content: center;
}
.staff__monogram {
  font-family: var(--font-serif); font-weight: 700; font-size: 22px;
}
.staff__name {
  font-family: var(--font-serif); font-size: 18px; font-weight: 600;
  margin: 0;
}
.staff__name a { color: var(--ink); text-decoration: none; }
.staff__name a:hover { color: var(--surgical-700); }
.staff__role {
  font-family: var(--font-sans); font-size: 11px;
  letter-spacing: var(--track-kicker);
  text-transform: uppercase;
  color: var(--ink-60);
  margin: 2px 0 var(--s-2);
}
.staff__bio {
  font-size: var(--type-meta); color: var(--ink-80); line-height: 1.55;
  margin: 0 0 var(--s-2);
}
.staff__social {
  font-size: var(--type-meta); color: var(--ink-60); margin: 0;
}
.staff__social a { color: var(--ink-80); }

/* Tag chips on article + tag page header */
.tag-chips {
  list-style: none;
  padding: 0;
  margin: var(--s-6) 0 var(--s-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}
.tag-chip {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-pill);
  font-family: var(--font-sans); font-size: 12px;
  text-transform: lowercase;
  letter-spacing: 0.02em;
  color: var(--ink-80);
  text-decoration: none;
}
.tag-chip:hover {
  border-color: var(--ink);
  color: var(--surgical-700);
}

/* Email-not-verified banner */
.verify-banner {
  background: var(--pulse-100);
  border-bottom: 1px solid var(--pulse-600);
}
.verify-banner__inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: var(--s-3) var(--s-7);
  font-family: var(--font-sans); font-size: var(--type-meta);
  color: var(--pulse-700);
}
.verify-banner__inner strong { color: var(--pulse-700); }

/* EasyMDE editor — gentle overrides so it fits Scrubswire's neutral palette */
.editor-label .EasyMDEContainer { margin-top: var(--s-2); }
.EasyMDEContainer .CodeMirror {
  font-family: var(--font-mono);
  font-size: 14px;
  line-height: 1.55;
  border: 1px solid var(--ink-20);
  background: var(--paper);
}
.EasyMDEContainer .editor-toolbar {
  border: 1px solid var(--ink-20);
  border-bottom: 0;
  background: var(--bone);
}
.EasyMDEContainer .editor-toolbar button {
  color: var(--ink-80);
}
.EasyMDEContainer .editor-toolbar button:hover,
.EasyMDEContainer .editor-toolbar button.active {
  background: var(--paper);
  border-color: var(--ink-20);
  color: var(--ink);
}
.EasyMDEContainer .editor-preview,
.EasyMDEContainer .editor-preview-side {
  background: var(--bone);
  font-family: var(--font-sans);
  color: var(--ink);
}
.editor-statusbar {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-60);
}

/* Cover-image uploader (in submit + admin edit forms) */
.cover-uploader {
  border: 1px solid var(--ink-20);
  background: var(--bone);
  padding: var(--s-4) var(--s-5);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.cover-uploader legend {
  padding: 0 6px;
  color: var(--ink-60);
}
.cover-uploader__row {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  flex-wrap: wrap;
}
.cover-uploader input[type="file"] {
  /* Hidden — the visible "Choose image…" button triggers it via JS. */
  position: absolute; left: -9999px; opacity: 0; width: 1px; height: 1px;
}
.cover-uploader__status {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-60);
}
.cover-uploader__status[data-kind="ok"]    { color: var(--surgical-700); }
.cover-uploader__status[data-kind="error"] { color: var(--pulse-700); }
.cover-uploader__preview img {
  border: 1px solid var(--ink-20);
}

/* Comments */
.comments {
  max-width: var(--column-text);
  margin: var(--s-7) 0;
}
.comments__heading {
  font-family: var(--font-serif);
  font-size: var(--type-h2);
  margin: var(--s-3) 0 var(--s-5);
}
.comments__list { list-style: none; padding: 0; margin: 0 0 var(--s-7); }
.comments__item {
  padding: var(--s-5) 0;
  border-bottom: 1px solid var(--rule);
}
.comments__byline {
  font-family: var(--font-sans); font-size: var(--type-meta);
  color: var(--ink-60); margin: 0 0 var(--s-2);
}
.comments__byline strong {
  color: var(--ink); font-weight: 600;
}
.comments__byline .dot { color: var(--ink-40); }
.comments__body {
  font-family: var(--font-sans); font-size: var(--type-ui);
  line-height: 1.55; color: var(--ink-80);
}
.comments__body p { margin: 0 0 var(--s-2); }

.comments__form {
  background: var(--bone);
  padding: var(--s-5);
  border: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: var(--s-4);
}
.comments__form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4);
}
@media (max-width: 600px) {
  .comments__form-row { grid-template-columns: 1fr; }
}
.comments__form label { display: flex; flex-direction: column; gap: var(--s-2); }
.comments__form input,
.comments__form textarea {
  font-family: var(--font-sans); font-size: var(--type-body);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-1);
  background: var(--paper);
}
.comments__form input:focus,
.comments__form textarea:focus { outline: none; border-color: var(--surgical-700); }
.comments__form textarea { resize: vertical; min-height: 90px; }
.comments__form-actions {
  display: flex; align-items: center; gap: var(--s-4);
  flex-wrap: wrap;
}
.comments__hint { font-size: var(--type-meta); color: var(--ink-60); margin: 0; }
.comments__as { font-family: var(--font-sans); font-size: var(--type-meta); color: var(--ink-60); margin: 0; }

/* Honeypot — visually hidden but bots see it */
.comments__honeypot {
  position: absolute; left: -9999px; top: -9999px;
  width: 1px; height: 1px; opacity: 0;
}

/* Pending-comment hint shown after the form when form posts to anchor */
.comments__pending-note {
  margin-top: var(--s-4);
  padding: var(--s-4);
  background: var(--surgical-100);
  border-left: 3px solid var(--surgical-700);
  font-size: var(--type-meta);
  display: none;
}
.comments__pending-note:target { display: block; }

/* Admin: comment-body preview block */
.admin__comment-body {
  margin: var(--s-3) 0 0;
  padding: var(--s-3) var(--s-4);
  background: var(--bone);
  border-left: 3px solid var(--ink-20);
  font-family: var(--font-sans); font-size: var(--type-ui);
  color: var(--ink-80);
  white-space: pre-wrap;
}

/* Newsletter modal */
.nl-modal {
  position: fixed; inset: 0;
  z-index: 200;
  display: grid; place-items: center;
}
.nl-modal[hidden] { display: none; }
.nl-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(14,16,20,0.55);
  backdrop-filter: blur(2px);
  animation: nl-fade var(--dur-base) var(--ease-editorial);
}
.nl-modal__panel {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-3);
  width: min(520px, calc(100vw - 32px));
  padding: var(--s-7) var(--s-7) var(--s-6);
  animation: nl-rise var(--dur-base) var(--ease-editorial);
}
.nl-modal__close {
  position: absolute; top: 8px; right: 8px;
  width: 36px; height: 36px;
  background: none; border: 0; cursor: pointer;
  font-size: 26px; line-height: 1;
  color: var(--ink-60);
}
.nl-modal__close:hover { color: var(--ink); }
.nl-modal__title {
  font-family: var(--font-serif);
  font-size: 28px; line-height: 1.2; font-weight: 600;
  margin: var(--s-3) 0 var(--s-3);
}
.nl-modal__deck {
  color: var(--ink-80); font-size: var(--type-ui);
  margin: 0 0 var(--s-5);
}
.nl-modal__form { display: flex; flex-direction: column; gap: var(--s-3); }
.nl-modal__form input {
  font-family: var(--font-sans); font-size: var(--type-body);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--ink-20);
  border-radius: var(--radius-1);
}
.nl-modal__form input:focus { outline: none; border-color: var(--surgical-700); }
.nl-modal__form .btn { align-self: stretch; }
.nl-modal__legal {
  font-size: 12px; color: var(--ink-60); margin: var(--s-2) 0 0;
}
@keyframes nl-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes nl-rise {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Error pages */
.error-page {
  max-width: 520px;
  margin: var(--s-9) auto;
  text-align: left;
  padding: 0 var(--s-4);
}
.error-page h1 {
  font-family: var(--font-serif);
  font-size: var(--type-h1);
  line-height: var(--lh-h1);
  margin: var(--s-3) 0 var(--s-4);
}

/* Responsive masthead */
@media (max-width: 900px) {
  .footer__inner { grid-template-columns: 1fr; }
  .footer__cols { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 800px) {
  .masthead__inner {
    grid-template-columns: 1fr auto auto;
    gap: var(--s-3);
  }
  .masthead__nav { display: none; }
  .masthead__account a:not(.btn):not(.masthead__search-link),
  .masthead__account .masthead__greeting,
  .masthead__account form { display: none; }
  .masthead__hamburger { display: flex; }
}
@media (max-width: 720px) {
  .footer__cols { grid-template-columns: 1fr; }
  .footer__legal { flex-direction: column; align-items: flex-start; }
  .page { padding: var(--s-5) var(--s-5) var(--s-8); }
}
