:root {
  --ink: #16130f;
  --muted: #6b6862;
  --line: #e5e2dc;
  --accent: #b91c1c;
  --bg: #ffffff;
  --soft: #faf8f5;
  --serif: Georgia, "Times New Roman", "Noto Serif", serif;
  --sans: -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; font: 17px/1.7 var(--sans); color: var(--ink); background: var(--bg); }
.wrap { max-width: 1040px; margin: 0 auto; padding: 0 22px; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }

/* Masthead */
.masthead { border-top: 4px solid var(--accent); background: #fff; }
.mast-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 22px; }
.logo img { height: 46px; width: auto; }
.mast-meta { text-align: right; }
.mast-date { font: 700 12px/1.2 var(--sans); letter-spacing: 1px; text-transform: uppercase; color: var(--accent); }
.mast-tag { font-size: 13px; color: var(--muted); margin-top: 3px; }
.topnav { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--soft); }
.topnav .wrap { display: flex; align-items: center; gap: 10px; padding: 9px 22px; font: 700 13px/1 var(--sans); text-transform: uppercase; letter-spacing: .6px; }
.topnav .active { color: var(--accent); }
.topnav .sep { color: var(--line); }
.topnav .section { color: var(--muted); }

main.wrap { padding-top: 30px; padding-bottom: 48px; }

/* Hero */
.hero { margin-bottom: 30px; padding-bottom: 28px; border-bottom: 2px solid var(--ink); }
.hero-link { display: grid; grid-template-columns: 1.15fr 1fr; gap: 26px; align-items: center; }
.hero-img img { width: 100%; aspect-ratio: 16/10; object-fit: cover; border-radius: 4px; }
.eyebrow { font: 700 12px/1 var(--sans); text-transform: uppercase; letter-spacing: 1.2px; color: var(--accent); }
.hero-body h1 { font: 800 2.3rem/1.12 var(--serif); margin: 10px 0 10px; letter-spacing: -0.4px; }
.hero-link:hover h1 { color: var(--accent); }
.dek { color: #44413c; font-size: 1.02rem; margin: 0 0 10px; }
.meta { color: var(--muted); font-size: .8rem; text-transform: uppercase; letter-spacing: .5px; }

/* Grid */
.section-head { font: 700 13px/1 var(--sans); text-transform: uppercase; letter-spacing: 1px; color: var(--accent); margin: 0 0 16px; padding-bottom: 8px; border-bottom: 1px solid var(--line); }
.grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.card { border-top: 0; }
.card-img img { width: 100%; aspect-ratio: 16/10; object-fit: cover; border-radius: 4px; margin-bottom: 10px; }
.card h3 { font: 700 1.16rem/1.25 var(--serif); margin: 0 0 6px; }
.card-link:hover h3 { color: var(--accent); }
.card .dek { font-size: .94rem; margin-top: 6px; }
.card .meta { font-size: .72rem; }

/* Article */
.post { max-width: 720px; margin: 0 auto; }
.kicker { font: 700 12px/1 var(--sans); text-transform: uppercase; letter-spacing: 1px; color: var(--accent); margin: 0 0 10px; }
.post h1 { font: 800 2.4rem/1.14 var(--serif); margin: 0 0 12px; letter-spacing: -0.5px; }
.standfirst { font-size: 1.2rem; line-height: 1.5; color: #44413c; margin: 0 0 14px; }
.post-meta { color: var(--muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .5px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.post-hero { margin: 22px 0; }
.post-hero img { width: 100%; border-radius: 4px; }
.post-body { font: 1.12rem/1.8 var(--serif); }
.post-body p { margin: 0 0 22px; }
.back { margin-top: 30px; font: 700 .9rem var(--sans); color: var(--accent); }

/* Footer */
.site-footer { border-top: 3px solid var(--ink); background: var(--soft); padding: 28px 0; margin-top: 40px; }
.copy { color: var(--muted); font-size: .82rem; margin: 0; }
.related h2 { font: 700 13px/1 var(--sans); text-transform: uppercase; letter-spacing: 1px; margin: 0 0 10px; }
.related ul { margin: 0; padding-left: 18px; columns: 2; }
.related li { font-size: .9rem; margin-bottom: 4px; }

@media (max-width: 860px) {
  .hero-link { grid-template-columns: 1fr; gap: 14px; }
  .hero-body h1 { font-size: 1.9rem; }
  .grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
}
@media (max-width: 560px) {
  .grid { grid-template-columns: 1fr; }
  .post h1 { font-size: 1.85rem; }
}
