:root {
  --paper: #f4f1ea;
  --paper-2: #ebe6db;
  --ink: #15140f;
  --ink-2: #2a2823;
  --muted: #6b6558;
  --rule: #1a1814;
  --rule-soft: rgba(21, 20, 15, 0.14);
  --accent: #b8461d;
  --serif: "Fraunces", Georgia, serif;
  --sans: "Inter Tight", "Helvetica Neue", Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; cursor: pointer; }
a:hover { color: var(--accent); }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; letter-spacing: -0.02em; margin: 0; line-height: 1.05; text-wrap: balance; }

.site { max-width: 1440px; margin: 0 auto; padding: 0 40px; }
@media (max-width: 720px) { .site { padding: 0 20px; } }

.rule { border: 0; border-top: 1px solid var(--rule); height: 0; margin: 0; }
.rule-soft { border: 0; border-top: 1px solid var(--rule-soft); height: 0; margin: 0; }

/* masthead */
.mast { display: grid; grid-template-columns: 1fr auto 1fr; align-items: end; padding: 28px 0 18px; gap: 24px; }
.mast .left, .mast .right { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); display: flex; gap: 14px; align-items: center; }
.mast .right { justify-content: flex-end; }
.mast .wordmark { font-family: var(--serif); font-weight: 600; font-size: clamp(44px, 7vw, 88px); letter-spacing: -0.035em; line-height: 0.9; font-style: italic; color: var(--ink); cursor: pointer; }
.mast .wordmark:hover { color: var(--accent); }

.nav-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; }
.nav-row nav { display: flex; gap: 26px; }
.nav-row nav a.active { color: var(--accent); }
.nav-row .sub { color: var(--muted); }

/* kicker */
.kicker { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); display: inline-flex; align-items: center; gap: 10px; }
.kicker .dot { width: 4px; height: 4px; background: var(--accent); border-radius: 50%; display: inline-block; }
.kicker .tag { color: var(--accent); }

/* image placeholder */
.img {
  background:
    repeating-linear-gradient(135deg, rgba(21,20,15,0.06) 0 2px, transparent 2px 10px),
    var(--paper-2);
  position: relative;
  overflow: hidden;
  border: 1px solid var(--rule-soft);
  width: 100%;
}
.img::after {
  content: attr(data-label);
  position: absolute; left: 12px; bottom: 10px;
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted);
}

/* buttons */
.btn { display: inline-flex; align-items: center; gap: 10px; padding: 12px 18px; border: 1px solid var(--ink); font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; background: transparent; color: var(--ink); cursor: pointer; transition: background 140ms ease, color 140ms ease; }
.btn:hover { background: var(--ink); color: var(--paper); }
.btn .arrow { transition: transform 160ms ease; }
.btn:hover .arrow { transform: translateX(3px); }
.btn.primary { background: var(--ink); color: var(--paper); }
.btn.primary:hover { background: var(--accent); border-color: var(--accent); }

/* ticker */
.ticker { border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: 10px 0; overflow: hidden; white-space: nowrap; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-2); }
.ticker .track { display: inline-block; animation: marquee 80s linear infinite; }
.ticker span.sep { color: var(--accent); margin: 0 18px; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* footer */
.foot { margin-top: 80px; padding: 40px 0 48px; border-top: 1px solid var(--rule); display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }
.foot h4 { font-family: var(--mono); font-size: 11px; font-weight: 600; margin: 0 0 14px; color: var(--ink); letter-spacing: 0.12em; }
.foot ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.foot .wm { font-family: var(--serif); font-style: italic; font-size: 32px; color: var(--ink); letter-spacing: -0.02em; font-weight: 600; margin-bottom: 10px; text-transform: none; }
.foot .about { max-width: 300px; text-transform: none; font-family: var(--serif); font-size: 14px; color: var(--muted); line-height: 1.5; letter-spacing: 0; }
.foot .colophon { grid-column: 1 / -1; display: flex; justify-content: space-between; padding-top: 28px; border-top: 1px solid var(--rule-soft); }
@media (max-width: 720px) { .foot { grid-template-columns: 1fr 1fr; } }

/* Broadsheet */
.bs { padding: 40px 0 56px; display: grid; grid-template-columns: 2.2fr 1fr; gap: 56px; }
.bs .hero { cursor: pointer; }
.bs .hero .k { margin-bottom: 22px; }
.bs .hero h1 { font-size: clamp(56px, 7.5vw, 112px); line-height: 0.92; font-weight: 500; letter-spacing: -0.035em; margin-bottom: 24px; }
.bs .hero .dek { font-family: var(--serif); font-size: 22px; line-height: 1.45; color: var(--ink-2); max-width: 640px; margin: 0 0 24px; text-wrap: pretty; }
.bs .hero .meta { display: flex; gap: 20px; align-items: center; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }
.bs .hero .cover { margin-top: 30px; aspect-ratio: 16/9; }
.bs .side { border-left: 1px solid var(--rule-soft); padding-left: 40px; }
.bs .side h5 { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); font-weight: 500; margin-bottom: 20px; display: flex; gap: 10px; align-items: center; }
.bs .side h5 .tag { color: var(--accent); }
.bs .side h5 .dot { width: 4px; height: 4px; background: var(--accent); border-radius: 50%; display: inline-block; }
.bs .side .row { padding-bottom: 24px; margin-bottom: 24px; border-bottom: 1px solid var(--rule-soft); cursor: pointer; display: block; }
.bs .side .row:last-child { border-bottom: 0; margin-bottom: 0; }
.bs .side .row:hover h3 { color: var(--accent); }
.bs .side .row .idx { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; color: var(--muted); text-transform: uppercase; margin-bottom: 10px; display: flex; gap: 10px; }
.bs .side .row .idx .n { color: var(--accent); }
.bs .side .row h3 { font-size: 20px; line-height: 1.15; font-weight: 500; letter-spacing: -0.015em; }
.bs .side .row .m { margin-top: 10px; font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }

/* Issue strip */
.issue-strip { padding: 56px 0; border-top: 1px solid var(--rule); }
.issue-strip .ih { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 32px; gap: 24px; }
.issue-strip .ih h2 { font-size: clamp(32px, 4vw, 56px); margin-top: 12px; letter-spacing: -0.025em; max-width: 22ch; }
.issue-strip .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.issue-strip article { cursor: pointer; display: block; }
.issue-strip article:hover h3 { color: var(--accent); }
.issue-strip article .im { aspect-ratio: 4/5; }
.issue-strip article .k { margin-top: 18px; }
.issue-strip article h3 { font-size: 26px; line-height: 1.1; font-weight: 500; letter-spacing: -0.02em; margin-top: 12px; }
.issue-strip article p { font-family: var(--serif); color: var(--muted); margin-top: 10px; font-size: 15px; line-height: 1.5; }
.issue-strip article .m { margin-top: 14px; font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); }

/* Pull quote */
.pull { padding: 84px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); margin-top: 32px; text-align: center; }
.pull blockquote { font-family: var(--serif); font-size: clamp(30px, 3.6vw, 56px); font-style: italic; font-weight: 500; line-height: 1.12; max-width: 22ch; margin: 0 auto; letter-spacing: -0.015em; }
.pull blockquote .a { color: var(--accent); }
.pull cite { display: block; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); margin-top: 28px; font-style: normal; }

/* Newsletter */
.dispatch { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; padding: 80px 0; align-items: center; }
.dispatch h2 { font-size: clamp(36px, 4vw, 60px); font-style: italic; font-weight: 500; letter-spacing: -0.025em; }
.dispatch p { font-family: var(--serif); font-size: 18px; color: var(--ink-2); max-width: 44ch; line-height: 1.5; }
.dispatch form { display: flex; border: 1px solid var(--ink); }
.dispatch input { flex: 1; border: 0; padding: 16px 18px; background: transparent; font-family: var(--mono); font-size: 12px; color: var(--ink); outline: none; min-width: 0; }
.dispatch input::placeholder { color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; font-size: 11px; }
.dispatch form button { background: var(--ink); color: var(--paper); padding: 0 22px; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; cursor: pointer; }
.dispatch form button:hover { background: var(--accent); }

@media (max-width: 960px) {
  .bs { grid-template-columns: 1fr; }
  .bs .side { border-left: 0; padding-left: 0; border-top: 1px solid var(--rule); padding-top: 30px; }
  .issue-strip .grid { grid-template-columns: 1fr; }
  .dispatch { grid-template-columns: 1fr; gap: 28px; padding: 56px 0; }
}

/* Article */
.article-wrap { padding: 40px 0 0; }
.article { max-width: 760px; margin: 0 auto; padding: 16px 0 40px; }
.article .back { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); display: inline-flex; align-items: center; gap: 8px; margin-bottom: 40px; }
.article .back:hover { color: var(--accent); }
.article .k { margin-bottom: 18px; }
.article h1 { font-size: clamp(40px, 5.2vw, 76px); font-weight: 500; letter-spacing: -0.03em; line-height: 1; margin-bottom: 24px; }
.article .dek { font-family: var(--serif); font-size: 22px; line-height: 1.45; color: var(--ink-2); font-style: italic; margin-bottom: 36px; max-width: 40ch; }
.article .byline { display: flex; gap: 28px; padding: 18px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); margin-bottom: 36px; flex-wrap: wrap; }
.article .byline b { color: var(--ink); font-weight: 500; }
.article .hero-img { aspect-ratio: 16/10; margin-bottom: 40px; }
.article .body p { font-family: var(--serif); font-size: 19px; line-height: 1.65; color: var(--ink-2); margin: 0 0 24px; text-wrap: pretty; }
.article .body p:first-of-type::first-letter { font-family: var(--serif); font-size: 5.5em; float: left; line-height: 0.85; margin: 8px 14px 0 0; font-weight: 500; color: var(--accent); }
.article .pull-q { padding: 28px 0; margin: 40px auto; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); font-family: var(--serif); font-style: italic; font-size: 28px; line-height: 1.25; text-align: center; max-width: 24ch; }
.article .end { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent); text-align: center; margin-top: 32px; }

.related { max-width: 1440px; margin: 0 auto; padding: 56px 40px; border-top: 1px solid var(--rule); }
.related h4 { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); margin-bottom: 24px; font-weight: 500; }
.related .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.related .grid article { cursor: pointer; display: block; }
.related .grid article:hover h3 { color: var(--accent); }
.related .grid article h3 { font-size: 22px; line-height: 1.2; margin: 12px 0 8px; font-weight: 500; letter-spacing: -0.015em; }
.related .grid article p { font-size: 14px; color: var(--ink-2); margin: 0; font-family: var(--serif); line-height: 1.5; }
.related .grid .im { aspect-ratio: 4/3; }
@media (max-width: 720px) { .related .grid { grid-template-columns: 1fr; } }
