/* ============================================================
   THE BRUTALIST — editorial brutalism for Ghost
   hard rules, mono meta, heavy grotesque heads, serif body,
   no radius, no shadow, one accent.
   ============================================================ */

:root {
  --ink: #000;
  --paper: #fff;
  --accent: #ff2b00;          /* the only color */
  --grey: #6b6b6b;
  --rule: 2px solid var(--ink);
  --rule-hair: 1px solid var(--ink);
  /* Ghost custom-font vars respected, brutalist defaults as fallback */
  --font-display: var(--gh-font-heading, "Helvetica Neue", Helvetica, Arial, sans-serif);
  --font-mono: ui-monospace, "SF Mono", "Roboto Mono", Menlo, Consolas, monospace;
  --font-serif: var(--gh-font-body, Georgia, "Times New Roman", Times, serif);
  --gap: clamp(12px, 2vw, 28px);
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-underline-offset: 2px; }
a:hover { background: var(--ink); color: var(--paper); text-decoration: none; }

img { max-width: 100%; height: auto; display: block; filter: grayscale(1) contrast(1.05); }

.skip { position: absolute; left: -9999px; }
.skip:focus { left: 8px; top: 8px; background: var(--ink); color: var(--paper); padding: 8px 12px; font-family: var(--font-mono); z-index: 99; }

/* ---------- MASTHEAD ---------- */
.masthead { border-bottom: 6px solid var(--ink); padding: 0 var(--gap); }

.masthead__dateline {
  display: flex; justify-content: space-between; gap: 12px;
  font-family: var(--font-mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.08em; padding: 6px 0; border-bottom: var(--rule-hair);
}
.masthead__edition { color: var(--grey); }

.masthead__brand { padding: clamp(10px, 3vw, 28px) 0 14px; }
.masthead__title {
  display: block; font-family: var(--font-display); font-weight: 800;
  font-size: clamp(40px, 12vw, 150px); line-height: 0.88; letter-spacing: -0.03em;
  text-transform: uppercase; text-decoration: none;
}
.masthead__title:hover { background: var(--accent); color: var(--paper); }
.masthead__standfirst {
  font-family: var(--font-mono); font-size: 13px; text-transform: uppercase;
  letter-spacing: 0.04em; margin: 12px 0 0; color: var(--grey); max-width: 60ch;
}

/* nav */
.nav ul { list-style: none; display: flex; flex-wrap: wrap; gap: 0; margin: 0; padding: 0; border-top: var(--rule); }
.nav li { border-right: var(--rule-hair); }
.nav a {
  display: block; padding: 10px 18px; font-family: var(--font-mono);
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; text-decoration: none;
}

/* ticker */
.ticker { overflow: hidden; border-top: var(--rule); white-space: nowrap; }
.ticker__track { display: inline-flex; align-items: center; animation: marquee 40s linear infinite; }
.ticker:hover .ticker__track { animation-play-state: paused; }
.ticker__item { font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; padding: 8px 0; text-decoration: none; }
.ticker__sep { color: var(--accent); padding: 0 14px; font-family: var(--font-mono); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .ticker__track { animation: none; } }

/* ---------- LEDE ---------- */
.site-main { padding: 0 var(--gap); }
.kicker {
  display: inline-block; font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.12em; background: var(--accent); color: var(--paper);
  padding: 3px 8px; margin-bottom: 14px;
}
.kicker--lg { font-size: 13px; padding: 4px 10px; }

.lede { border-bottom: 6px solid var(--ink); padding: var(--gap) 0; }
.lede__link { display: block; text-decoration: none; }
.lede__link:hover { background: none; color: inherit; }
.lede__headline {
  font-family: var(--font-display); font-weight: 800; line-height: 0.92;
  letter-spacing: -0.025em; font-size: clamp(34px, 7vw, 92px); margin: 0;
}
.case-uppercase .lede__headline, .case-uppercase .card__headline, .case-uppercase .article__headline { text-transform: uppercase; }
.lede__link:hover .lede__headline { color: var(--accent); }
.lede__standfirst { font-size: clamp(18px, 2.2vw, 26px); max-width: 70ch; margin: 18px 0 0; }

.byline { font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; margin: 16px 0 0; }
.byline--sm { font-size: 11px; }
.byline__sep { color: var(--accent); padding: 0 4px; }

/* ---------- GRID (broken, hard-ruled) ---------- */
.grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  border-top: var(--rule-hair); border-left: var(--rule-hair);
}
.card { border-right: var(--rule-hair); border-bottom: var(--rule-hair); }
.card__link { display: block; padding: 20px; text-decoration: none; min-height: 100%; }
.card__link:hover { background: none; color: inherit; }
.card__index { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent); }
.card__headline { font-family: var(--font-display); font-weight: 800; line-height: 0.98; letter-spacing: -0.02em; font-size: clamp(22px, 2.4vw, 30px); margin: 10px 0 12px; }
.card__link:hover .card__headline { text-decoration: underline; text-decoration-thickness: 3px; }
.card__excerpt { font-size: 15px; margin: 0; }
/* every Nth card gets the accent block — broken rhythm */
.card:nth-child(5n+3) { background: var(--ink); color: var(--paper); }
.card:nth-child(5n+3) .card__index { color: var(--accent); }
.card:nth-child(5n+3) .card__link:hover { background: var(--accent); color: var(--paper); }

/* ---------- ARTICLE ---------- */
.article { max-width: 1200px; margin: 0 auto; padding: var(--gap) 0 64px; }
.article__head { border-bottom: var(--rule); padding-bottom: 22px; margin-bottom: 28px; }
.article__headline {
  font-family: var(--font-display); font-weight: 800; line-height: 0.92; letter-spacing: -0.03em;
  font-size: clamp(36px, 7vw, 96px); margin: 14px 0 0;
}
.article__standfirst { font-family: var(--font-serif); font-style: italic; font-size: clamp(20px, 2.6vw, 30px); max-width: 60ch; margin: 20px 0 0; }
.article__meta { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.dateline { font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; margin: 0; color: var(--grey); }
.article__lead-img { margin: 0 0 28px; border: var(--rule); }
.article__lead-img figcaption { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; padding: 8px 10px; border-top: var(--rule-hair); color: var(--grey); }

/* the readable measure for body copy */
.article__body { max-width: 68ch; margin: 0 auto; font-size: 20px; line-height: 1.6; }
.gh-content > * { margin: 0 0 1.2em; }
.gh-content h2 { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; letter-spacing: -0.02em; font-size: 1.7em; line-height: 1; margin: 1.6em 0 0.5em; }
.gh-content h3 { font-family: var(--font-display); font-weight: 800; font-size: 1.3em; margin: 1.4em 0 0.4em; }
.gh-content a { text-decoration: underline; text-decoration-thickness: 2px; text-decoration-color: var(--accent); }
.gh-content blockquote { border-left: 6px solid var(--accent); margin: 1.4em 0; padding: 4px 0 4px 22px; font-style: italic; font-size: 1.15em; }
.gh-content pre { background: var(--ink); color: var(--paper); padding: 18px; overflow-x: auto; font-family: var(--font-mono); font-size: 14px; }
.gh-content code { font-family: var(--font-mono); font-size: 0.85em; }
.gh-content figure { margin: 1.6em 0; }
.gh-content figcaption { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; color: var(--grey); margin-top: 8px; text-align: center; }
.gh-content hr { border: 0; border-top: var(--rule); margin: 2em 0; }

/* sponsor */
.sponsor { max-width: 68ch; margin: 0 auto 28px; border: var(--rule); border-style: dashed; padding: 10px 14px; display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.sponsor__label, .sponsor__pitch { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.sponsor__pitch a { text-decoration: underline; }

/* article footer */
.article__foot { max-width: 68ch; margin: 40px auto 0; border-top: var(--rule); padding-top: 18px; }
.tag-chip { display: inline-block; font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; border: var(--rule-hair); padding: 4px 8px; margin: 0 6px 6px 0; text-decoration: none; }
.article__colophon { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--grey); margin-top: 18px; }

/* ---------- FOOT ---------- */
.site-foot { margin-top: 64px; border-top: 6px solid var(--ink); padding: 0 var(--gap) 40px; }
.site-foot__cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--gap); padding-top: 20px; }
.site-foot__col { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; margin: 0; }
.site-foot__col ul { list-style: none; margin: 0; padding: 0; }
.site-foot__col a { text-decoration: underline; }

/* pagination */
.pagination { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; padding: 24px var(--gap); border-top: var(--rule); }

/* ---------- RECEIPTS (source-on-tap) ---------- */
.receipt { border-bottom: 2px dotted var(--accent); cursor: pointer; }
.receipt::after { content: "\00b0"; font-family: var(--font-mono); color: var(--accent); font-size: 0.8em; vertical-align: super; line-height: 0; }
.receipt:hover { background: var(--accent); color: var(--paper); }
.receipt[aria-expanded="true"] { background: var(--ink); color: var(--paper); }
.receipt[aria-expanded="true"]::after { color: var(--paper); }
.receipt-note { max-width: 68ch; margin: 0 auto 1.3em; border-left: 6px solid var(--accent); background: #f3f3f3; padding: 12px 16px; }
.receipt-note__tag { display: block; font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--grey); margin-bottom: 6px; }
.receipt-note__quote { font-family: var(--font-serif); font-size: 0.95em; line-height: 1.5; }
.no-js .receipt { border-bottom: none; }
.no-js .receipt::after { content: ""; }

/* ---------- KOENIG content cards (required by gscan) ---------- */
.gh-content .kg-card { margin: 1.6em auto; }
.kg-width-wide { position: relative; width: min(100vw, 1100px); left: 50%; transform: translateX(-50%); }
.kg-width-full { position: relative; width: 100vw; left: 50%; transform: translateX(-50%); }
.kg-width-full img { width: 100%; }
.kg-image { display: block; margin-left: auto; margin-right: auto; }
figure.kg-image-card img, figure.kg-gallery-card img { border: var(--rule); filter: grayscale(1) contrast(1.05); }
.kg-image-card figcaption, .kg-embed-card + figcaption { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; color: var(--grey); text-align: center; margin-top: 8px; }
.kg-bookmark-card a, .kg-bookmark-container { border: var(--rule); display: block; text-decoration: none; }
.kg-bookmark-content { padding: 14px 16px; }
.kg-bookmark-title { font-family: var(--font-display); font-weight: 800; }
.kg-callout-card { border: var(--rule); border-left: 6px solid var(--accent); padding: 14px 16px; margin: 1.4em 0; }
.kg-button-card a { display: inline-block; border: var(--rule); padding: 10px 18px; font-family: var(--font-mono); text-transform: uppercase; text-decoration: none; }
