/* ============================================================
   Heir & Promise — Design tokens & global styles
   Editorial / heritage / quiet-authority
============================================================ */

:root {
	/* Palette */
	--navy: #0F1B3D;
	--navy-deep: #08102A;
	--navy-soft: #1B2A52;
	--gold: #C19A4B;
	--gold-deep: #A07F38;
	--gold-soft: #D9BE85;
	--cream: #F4ECD7;
	--cream-bright: #F8F2E2;
	--cream-deep: #E9DFC4;
	--paper: #F2E8CE;
	--ink: #14182B;
	--ink-soft: #2B3148;
	--muted: #5A5F73;
	--rule: rgba(15, 27, 61, 0.18);
	--rule-soft: rgba(15, 27, 61, 0.10);
	--gold-rule: rgba(193, 154, 75, 0.55);

	/* Type */
	--serif-display: "Cormorant Garamond", "EB Garamond", Georgia, serif;
	--serif-body: "Lora", "Source Serif Pro", Georgia, serif;
	--sans-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
	--sans: "Inter", -apple-system, system-ui, sans-serif;

	/* Reading widths */
	--read-width: 680px;
	--content-width: 1240px;
	--wide-width: 1480px;

	/* Spacing */
	--space-xs: 6px;
	--space-sm: 12px;
	--space-md: 24px;
	--space-lg: 48px;
	--space-xl: 96px;
}

* { box-sizing: border-box; }

html, body {
	margin: 0;
	padding: 0;
	background: var(--cream);
	color: var(--ink);
	font-family: var(--serif-body);
	font-size: 18px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

/* Paper texture (subtle) */
body::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 1;
	opacity: 0.5;
	background-image:
		radial-gradient(rgba(120, 95, 40, 0.05) 1px, transparent 1px),
		radial-gradient(rgba(15, 27, 61, 0.04) 1px, transparent 1px);
	background-size: 3px 3px, 7px 7px;
	background-position: 0 0, 1px 2px;
	mix-blend-mode: multiply;
}

body > * { position: relative; z-index: 2; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; height: auto; }

/* Skip link */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}
.skip-link:focus {
	background: var(--navy);
	color: var(--cream);
	clip: auto !important;
	clip-path: none;
	display: inline-block;
	height: auto;
	left: 16px;
	padding: 12px 18px;
	text-decoration: none;
	top: 16px;
	width: auto;
	z-index: 100000;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
}

/* ---------- Typography ---------- */

h1, h2, h3, h4, h5 {
	font-family: var(--serif-display);
	font-weight: 500;
	color: var(--navy);
	letter-spacing: -0.005em;
	line-height: 1.08;
	margin: 0;
	text-wrap: balance;
}

h1 { font-size: clamp(40px, 5vw, 72px); }
h2 { font-size: clamp(28px, 3vw, 44px); }
h3 { font-size: clamp(22px, 2vw, 28px); }
h4 { font-size: 20px; }

p { margin: 0 0 1.1em; text-wrap: pretty; }

.kicker {
	font-family: var(--serif-display);
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--gold-deep);
}

.dek {
	font-family: var(--serif-display);
	font-style: italic;
	font-weight: 400;
	font-size: clamp(20px, 1.6vw, 24px);
	color: var(--ink-soft);
	line-height: 1.4;
}

.meta {
	font-family: var(--sans-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--muted);
}

/* ---------- Ornaments ---------- */

.fleuron {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	color: var(--gold);
	font-family: var(--serif-display);
	font-size: 18px;
	margin: 48px 0;
}
.fleuron::before, .fleuron::after {
	content: "";
	flex: 1;
	max-width: 120px;
	height: 1px;
	background: var(--gold-rule);
}

.gold-rule {
	height: 1px;
	background: var(--gold-rule);
	border: 0;
	margin: 0;
}

.hairline {
	height: 1px;
	background: var(--rule);
	border: 0;
}

/* ---------- Layout helpers ---------- */

.shell {
	max-width: var(--content-width);
	margin: 0 auto;
	padding: 0 32px;
}

.shell-wide {
	max-width: var(--wide-width);
	margin: 0 auto;
	padding: 0 32px;
}

.shell-read {
	max-width: var(--read-width);
	margin: 0 auto;
	padding: 0 24px;
}

/* ---------- Site Header ---------- */

.site-top {
	background: var(--navy);
	color: var(--cream);
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	padding: 9px 0;
}
.site-top-inner {
	max-width: var(--wide-width);
	margin: 0 auto;
	padding: 0 32px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
}
.site-top .latin { color: var(--gold-soft); font-style: normal; }
.site-top .right { display: flex; gap: 22px; }
.site-top .right a { color: rgba(244, 236, 215, 0.75); transition: color 0.2s; }
.site-top .right a:hover, .site-top .right a:focus-visible { color: var(--gold-soft); }
.site-top em { font-style: normal; color: var(--gold-soft); }

.site-header {
	border-bottom: 1px solid var(--rule);
	background: var(--cream);
	position: relative;
	z-index: 50;
}

.masthead {
	max-width: var(--wide-width);
	margin: 0 auto;
	padding: 36px 32px 24px;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 24px;
}

.masthead .issue-meta {
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--muted);
}
.masthead .issue-meta strong { color: var(--navy); font-weight: 500; display: block; margin-bottom: 4px; }

.masthead .actions {
	display: flex;
	gap: 16px;
	justify-content: flex-end;
	align-items: center;
}

.brandmark {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 4px;
}
.brandmark img,
.brandmark .custom-logo,
.brandmark .custom-logo-link img {
	height: 64px;
	width: auto;
	display: block;
}
.brandmark .tagline {
	font-family: var(--serif-display);
	font-style: italic;
	font-size: 14px;
	color: var(--muted);
	letter-spacing: 0.02em;
	margin-top: 4px;
}

.masthead-search {
	max-width: var(--wide-width);
	margin: 0 auto;
	padding: 0 32px 16px;
}
.masthead-search[hidden] { display: none; }

/* Primary nav row */
.primary-nav {
	border-top: 1px solid var(--rule);
	background: var(--cream);
}
.primary-nav-inner {
	max-width: var(--wide-width);
	margin: 0 auto;
	padding: 14px 32px;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 36px;
	font-family: var(--serif-display);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--navy);
}
.primary-nav-inner a {
	position: relative;
	padding: 4px 0;
	transition: color 0.2s;
}
.primary-nav-inner a:hover,
.primary-nav-inner a:focus-visible { color: var(--gold-deep); }
.primary-nav-inner a.is-current { color: var(--gold-deep); }
.primary-nav-inner a.is-current::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -16px;
	width: 6px; height: 6px;
	background: var(--gold);
	transform: translateX(-50%) rotate(45deg);
}

.icon-btn {
	width: 34px; height: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--rule);
	border-radius: 999px;
	color: var(--navy);
	background: transparent;
	cursor: pointer;
	transition: border-color 0.2s, color 0.2s;
}
.icon-btn:hover,
.icon-btn:focus-visible { border-color: var(--gold); color: var(--gold-deep); }

/* Focus visibility */
:focus-visible {
	outline: 2px solid var(--gold-deep);
	outline-offset: 3px;
}

/* ---------- Buttons ---------- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 14px 28px;
	border: 1px solid var(--navy);
	background: var(--navy);
	color: var(--cream);
	font-family: var(--serif-display);
	font-weight: 500;
	font-size: 14px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	cursor: pointer;
	transition: all 0.25s ease;
}
.btn:hover, .btn:focus-visible { background: var(--navy-deep); border-color: var(--navy-deep); }

.btn-ghost {
	background: transparent;
	color: var(--navy);
}
.btn-ghost:hover, .btn-ghost:focus-visible {
	background: var(--navy);
	color: var(--cream);
}

.btn-gold {
	background: var(--gold);
	border-color: var(--gold);
	color: var(--navy);
}
.btn-gold:hover, .btn-gold:focus-visible { background: var(--gold-deep); border-color: var(--gold-deep); color: var(--cream); }

.linklike {
	font-family: var(--serif-display);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--navy);
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding-bottom: 4px;
	border-bottom: 1px solid var(--gold);
	transition: gap 0.2s, color 0.2s;
}
.linklike:hover, .linklike:focus-visible { gap: 16px; color: var(--gold-deep); }
.linklike .arr { font-family: var(--serif-display); font-style: italic; }

/* ---------- Placeholder imagery (parchment / plate) ---------- */

.plate {
	position: relative;
	width: 100%;
	background: var(--cream-deep);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}
.plate::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		135deg,
		rgba(15, 27, 61, 0.04) 0 1px,
		transparent 1px 14px
	);
}
.plate::after {
	content: "";
	position: absolute;
	inset: 12px;
	border: 1px solid var(--gold-rule);
}
.plate.has-image::before,
.plate.has-image::after { content: none; }
.plate.has-image > img { width: 100%; height: 100%; object-fit: cover; }
.plate-label {
	position: relative;
	z-index: 2;
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--navy-soft);
	text-align: center;
	padding: 0 24px;
	max-width: 80%;
}
.plate-label .lead {
	display: block;
	font-family: var(--serif-display);
	font-style: italic;
	font-size: 18px;
	letter-spacing: 0;
	text-transform: none;
	color: var(--navy);
	margin-bottom: 6px;
}

.plate-navy { background: var(--navy); color: var(--cream); }
.plate-navy::before {
	background-image: repeating-linear-gradient(
		135deg,
		rgba(193, 154, 75, 0.08) 0 1px,
		transparent 1px 14px
	);
}
.plate-navy::after { border-color: rgba(193, 154, 75, 0.35); }
.plate-navy .plate-label { color: var(--gold-soft); }
.plate-navy .plate-label .lead { color: var(--cream); }

/* ---------- Cards ---------- */

.card {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.card .plate { aspect-ratio: 4/3; }
.card .cat {
	font-family: var(--serif-display);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--gold-deep);
}
.card h3 {
	font-size: 26px;
	line-height: 1.15;
	font-weight: 500;
	transition: color 0.2s;
}
.card .dek-sm {
	font-family: var(--serif-body);
	font-size: 16px;
	color: var(--ink-soft);
	line-height: 1.55;
	margin: 0;
}
.card .byline {
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--muted);
	display: flex;
	gap: 14px;
	align-items: center;
	flex-wrap: wrap;
}
.card .byline .dot { width: 3px; height: 3px; border-radius: 999px; background: var(--gold); }

.card:hover h3, .card:focus-visible h3 { color: var(--gold-deep); }

/* ---------- Footer ---------- */

.site-footer {
	background: var(--navy);
	color: var(--cream);
	padding: 80px 0 32px;
	margin-top: 120px;
}
.site-footer .foot-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: 60px;
}
.site-footer h5 {
	font-family: var(--serif-display);
	font-size: 12px;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--gold-soft);
	margin-bottom: 18px;
	font-weight: 600;
}
.site-footer a {
	display: block;
	padding: 6px 0;
	font-size: 15px;
	color: rgba(244, 236, 215, 0.78);
	transition: color 0.2s;
}
.site-footer a:hover, .site-footer a:focus-visible { color: var(--gold-soft); }

.foot-brand .wordmark {
	font-family: var(--serif-display);
	font-size: 26px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--cream);
	margin-bottom: 10px;
}
.foot-brand p {
	color: rgba(244, 236, 215, 0.65);
	font-size: 15px;
	line-height: 1.65;
	max-width: 320px;
}

.foot-bottom {
	margin-top: 64px;
	padding-top: 24px;
	border-top: 1px solid rgba(193, 154, 75, 0.25);
	display: flex;
	justify-content: space-between;
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(244, 236, 215, 0.5);
}

/* ---------- Newsletter band ---------- */

.newsletter {
	background: var(--navy);
	color: var(--cream);
	padding: 100px 0;
	position: relative;
}
.newsletter::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		135deg,
		rgba(193, 154, 75, 0.04) 0 1px,
		transparent 1px 14px
	);
	pointer-events: none;
}
.newsletter-inner {
	max-width: 760px;
	margin: 0 auto;
	padding: 0 32px;
	text-align: center;
	position: relative;
}
.newsletter .kicker { color: var(--gold-soft); }
.newsletter h2 { color: var(--cream); margin: 16px 0 14px; font-size: clamp(34px, 4vw, 54px); }
.newsletter p { color: rgba(244, 236, 215, 0.75); max-width: 540px; margin: 0 auto 32px; }

.subscribe-form {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0;
	max-width: 540px;
	margin: 0 auto;
	border: 1px solid rgba(193, 154, 75, 0.4);
}
.subscribe-form input {
	background: transparent;
	border: 0;
	padding: 18px 22px;
	color: var(--cream);
	font-family: var(--serif-body);
	font-size: 16px;
	outline: none;
}
.subscribe-form input::placeholder { color: rgba(244, 236, 215, 0.45); }
.subscribe-form button {
	background: var(--gold);
	color: var(--navy);
	border: 0;
	padding: 0 28px;
	font-family: var(--serif-display);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.2s;
}
.subscribe-form button:hover, .subscribe-form button:focus-visible { background: var(--gold-soft); }

.newsletter-fineprint {
	margin-top: 18px;
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(244, 236, 215, 0.4);
}

/* ---------- Sponsored / Ad folio ---------- */

.folio {
	border-top: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
	padding: 22px 0 26px;
	margin: 36px 0;
	text-align: center;
	background:
		linear-gradient(var(--cream), var(--cream)) padding-box,
		repeating-linear-gradient(135deg, rgba(193, 154, 75, 0.06) 0 1px, transparent 1px 14px);
}
.folio .label {
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--muted);
	margin-bottom: 14px;
}
.folio .ad-body {
	font-family: var(--serif-display);
	font-style: italic;
	color: var(--navy-soft);
	font-size: 18px;
	max-width: 520px;
	margin: 0 auto;
}
.folio.large { padding: 40px 0 48px; }
.folio.large .ad-body { font-size: 22px; }

/* ============================================================
   Homepage sections
============================================================ */

.hero { padding: 64px 0 96px; }
.hero-grid { display: grid; grid-template-columns: 1fr 1.15fr; gap: 80px; align-items: start; }
.hero-headline { font-size: clamp(44px, 5.2vw, 78px); font-weight: 500; line-height: 1.02; margin: 14px 0 28px; }
.hero-headline em { font-style: italic; color: var(--gold-deep); font-weight: 400; }
.hero-dek { font-family: var(--serif-display); font-style: italic; font-size: 22px; line-height: 1.45; color: var(--ink-soft); max-width: 480px; margin-bottom: 36px; }
.hero-cta { display: flex; gap: 28px; align-items: center; margin-bottom: 60px; flex-wrap: wrap; }
.hero-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin: 0; padding-top: 28px; border-top: 1px solid var(--rule); max-width: 480px; }
.hero-stats > div { margin: 0; }
.hero-stats dt { font-family: var(--sans-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.hero-stats dd { margin: 0; font-family: var(--serif-display); font-size: 32px; color: var(--navy); font-weight: 500; }

.hero-featured-link { display: block; }
.hero-plate { aspect-ratio: 4/5; }
.hero-featured-body { padding: 28px 0 0; }
.featured-headline { font-size: clamp(30px, 3vw, 44px); margin: 14px 0 16px; line-height: 1.1; transition: color 0.2s; }
.hero-featured-link:hover .featured-headline,
.hero-featured-link:focus-visible .featured-headline { color: var(--gold-deep); }
.featured-meta { font-family: var(--sans-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.featured-meta strong { font-weight: 500; color: var(--navy); }
.featured-meta .sep { color: var(--gold); }

.section { padding: 40px 0 80px; }
.section-head { display: grid; grid-template-columns: auto 1fr auto; gap: 32px; align-items: end; margin-bottom: 48px; padding-bottom: 22px; border-bottom: 1px solid var(--rule); }
.section-head .kicker { padding-bottom: 8px; }
.section-head h2 { font-size: clamp(28px, 2.4vw, 38px); font-weight: 500; }
.section-head .linklike { white-space: nowrap; }

.latest-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 56px 40px;
}
.latest-grid .lead-card { grid-column: span 3; display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: center; }
.latest-grid .lead-card .plate { aspect-ratio: 4/3; }
.latest-grid .lead-card h3 { font-size: clamp(32px, 3vw, 46px); margin: 0; }
.latest-grid .lead-card .dek-sm { font-family: var(--serif-display); font-style: italic; font-size: 20px; color: var(--ink-soft); line-height: 1.45; }
.latest-grid .lead-card .cat { margin-bottom: -6px; }

.topics-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.topic {
	padding: 40px 32px 36px;
	border-right: 1px solid var(--rule);
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: background 0.2s;
	position: relative;
}
.topic:last-child { border-right: 0; }
.topic:hover, .topic:focus-visible { background: rgba(193, 154, 75, 0.07); }
.topic-num { font-family: var(--serif-display); font-style: italic; font-weight: 500; font-size: 22px; color: var(--gold-deep); margin-bottom: 8px; }
.topic h3 { font-size: 26px; font-weight: 500; margin: 0; }
.topic p { color: var(--ink-soft); font-size: 16px; line-height: 1.55; margin: 0; flex: 1; }
.topic-count { font-family: var(--sans-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); margin-top: 22px; padding-top: 14px; border-top: 1px solid var(--rule-soft); }

.shorts-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.short { position: relative; }
.phone-frame {
	position: relative;
	display: block;
	border-radius: 22px;
	overflow: hidden;
	background: var(--navy-deep);
	box-shadow: 0 24px 40px -28px rgba(15,27,61,0.55), 0 2px 0 rgba(193,154,75,0.18);
	border: 1px solid rgba(193, 154, 75, 0.2);
	cursor: pointer;
	transition: transform 0.3s ease;
}
.phone-frame:hover, .phone-frame:focus-visible { transform: translateY(-4px); }
.phone-frame .plate { border-radius: 0; }
.play-btn {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
	width: 60px; height: 60px;
	border-radius: 999px;
	background: rgba(244, 236, 215, 0.94);
	color: var(--navy);
	border: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: transform 0.2s;
	z-index: 2;
}
.phone-frame:hover .play-btn { transform: translate(-50%, -50%) scale(1.08); }
.short-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 18px;
	pointer-events: none;
	background: linear-gradient(to bottom, rgba(8, 16, 42, 0.5) 0%, transparent 22%, transparent 65%, rgba(8, 16, 42, 0.85) 100%);
}
.short-meta-top { font-family: var(--sans-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-soft); }
.short-bottom { color: var(--cream); }
.short-title { font-family: var(--serif-display); font-size: 18px; line-height: 1.2; font-weight: 500; margin-bottom: 6px; }
.short-stats { font-family: var(--sans-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(244, 236, 215, 0.75); }

.editors-note { padding-top: 80px; }
.editors-note h2 { font-family: var(--serif-display); }

/* ============================================================
   Archive / Library page
============================================================ */

.index-head { padding: 64px 0 48px; }
.page-title { font-size: clamp(56px, 7vw, 110px); font-weight: 500; margin: 14px 0 18px; line-height: 1; }
.page-dek { font-family: var(--serif-display); font-style: italic; font-size: clamp(20px, 1.8vw, 24px); color: var(--ink-soft); max-width: 60ch; line-height: 1.45; margin-bottom: 56px; }

.filter-bar {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: center;
	padding: 22px 0;
	border-top: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
}
.filter-row { display: flex; gap: 4px; flex-wrap: wrap; }
.filter {
	background: transparent;
	border: 1px solid var(--rule);
	padding: 10px 18px;
	font-family: var(--serif-display);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--navy);
	cursor: pointer;
	transition: all 0.2s;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.filter:hover, .filter:focus-visible { border-color: var(--gold); color: var(--gold-deep); }
.filter.is-active { background: var(--navy); border-color: var(--navy); color: var(--cream); }
.filter.is-active .count { color: var(--gold-soft); }
.filter .count { font-family: var(--sans-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--muted); }

.search-form {
	display: flex;
	align-items: center;
	gap: 10px;
	border: 1px solid var(--rule);
	padding: 10px 16px;
	min-width: 280px;
	color: var(--muted);
	transition: border-color 0.2s;
}
.search-form:focus-within { border-color: var(--gold); color: var(--navy); }
.search-form input {
	background: transparent;
	border: 0;
	outline: none;
	font-family: var(--serif-body);
	font-size: 15px;
	flex: 1;
	color: var(--navy);
}
.search-form input::placeholder { color: var(--muted); }

.featured-row {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 48px;
	align-items: center;
	padding: 0;
	border: 1px solid var(--rule);
	background: var(--cream-bright);
	position: relative;
	transition: border-color 0.2s;
}
.featured-row:hover, .featured-row:focus-visible { border-color: var(--gold); }
.featured-row::before {
	content: "";
	position: absolute;
	top: 8px; left: 8px; right: 8px; bottom: 8px;
	border: 1px solid var(--gold-rule);
	pointer-events: none;
}
.featured-row-img { position: relative; }
.featured-row-img .plate { margin: 8px 0 8px 8px; aspect-ratio: 4/3; }
.featured-tag {
	position: absolute;
	top: 24px; left: 24px;
	background: var(--gold);
	color: var(--navy);
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	padding: 6px 12px;
	z-index: 3;
}
.featured-row-body { padding: 40px 48px 40px 16px; }
.featured-row-body .cat { font-family: var(--serif-display); font-weight: 600; font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold-deep); display: block; margin-bottom: 14px; }
.featured-row-body h2 { font-size: clamp(28px, 3vw, 42px); margin: 0 0 16px; font-weight: 500; line-height: 1.12; }
.featured-row-body .dek { font-family: var(--serif-display); font-style: italic; font-size: 19px; line-height: 1.45; color: var(--ink-soft); margin: 0 0 24px; }
.featured-row-body .byline-row { font-family: var(--sans-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.featured-row-body .byline-row strong { color: var(--navy); font-weight: 500; }
.featured-row-body .byline-row .sep { color: var(--gold); }

.archive-head {
	display: flex;
	align-items: center;
	gap: 22px;
	margin: 64px 0 36px;
}
.archive-head .kicker { white-space: nowrap; }
.archive-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px 32px;
}
.archive-grid .card h3 { font-size: 22px; }

.pagination, .nav-links {
	display: flex;
	gap: 6px;
	justify-content: center;
	align-items: center;
	margin: 80px 0 0;
	padding-top: 36px;
	border-top: 1px solid var(--rule);
	flex-wrap: wrap;
}
.pagination .page-numbers, .nav-links .page-numbers {
	width: 40px; height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--serif-display);
	font-size: 16px;
	color: var(--navy);
	border: 1px solid transparent;
	transition: all 0.2s;
}
.pagination .page-numbers:hover,
.pagination .page-numbers:focus-visible { border-color: var(--gold); color: var(--gold-deep); }
.pagination .page-numbers.current,
.pagination .current { border-color: var(--navy); background: var(--navy); color: var(--cream); }
.pagination .dots { font-family: var(--serif-display); color: var(--muted); padding: 0 6px; }

/* ============================================================
   Article (single essay)
============================================================ */

.breadcrumb-row { padding: 18px 0 0; }
.breadcrumb { display: flex; gap: 12px; align-items: center; font-family: var(--sans-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); flex-wrap: wrap; }
.breadcrumb a { transition: color 0.2s; }
.breadcrumb a:hover, .breadcrumb a:focus-visible { color: var(--navy); }
.breadcrumb .sep { color: var(--gold); }

.essay-head { padding: 40px 0 0; }
.essay-title { font-size: clamp(40px, 5.4vw, 76px); text-align: center; font-weight: 500; line-height: 1.06; margin: 0 auto; max-width: 18ch; }
.essay-dek { font-family: var(--serif-display); font-style: italic; font-size: clamp(20px, 2vw, 26px); color: var(--ink-soft); text-align: center; max-width: 32em; margin: 24px auto 0; line-height: 1.4; }

.essay-byline {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 40px;
	align-items: center;
	padding: 24px 0;
	border-top: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
}
.byline-left { display: flex; gap: 16px; align-items: center; }
.author-thumb { width: 52px; height: 52px; border-radius: 999px; flex-shrink: 0; aspect-ratio: 1; }
.author-thumb::after { border-radius: 999px; inset: 4px; }
.by-label { font-family: var(--sans-mono); font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.by-name { font-family: var(--serif-display); font-size: 18px; font-weight: 500; color: var(--navy); }
.byline-right { display: flex; gap: 36px; }
.byline-right > div { display: flex; flex-direction: column; }
.byline-right .by-value { font-family: var(--serif-display); font-size: 15px; color: var(--navy); }
.byline-right .by-value a { color: var(--gold-deep); text-decoration: underline; text-decoration-color: var(--gold-rule); text-underline-offset: 4px; }

.hero-figure { margin: 0; }
.hero-figure .plate { width: 100%; }
.figure-cap { font-family: var(--serif-display); font-style: italic; font-size: 14px; color: var(--muted); text-align: center; padding: 14px 0 0; max-width: 600px; margin: 0 auto; }

.essay-body-wrap { padding: 64px 0 80px; }
.essay-body-grid {
	display: grid;
	grid-template-columns: 80px var(--read-width) 1fr;
	gap: 40px;
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 24px;
}

.share-rail {
	position: sticky;
	top: 24px;
	height: max-content;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	padding-top: 20px;
}
.share-label { font-family: var(--sans-mono); font-size: 9px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--muted); writing-mode: vertical-rl; transform: rotate(180deg); margin-bottom: 6px; }
.share-btn { width: 38px; height: 38px; border: 1px solid var(--rule); border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; color: var(--navy); background: transparent; cursor: pointer; transition: all 0.2s; }
.share-btn:hover, .share-btn:focus-visible { border-color: var(--gold); color: var(--gold-deep); background: rgba(193, 154, 75, 0.08); }
.share-progress { width: 2px; height: 120px; background: var(--rule); margin-top: 18px; border-radius: 2px; position: relative; overflow: hidden; }
.progress-bar { width: 100%; height: 0; background: var(--gold); border-radius: 2px; transition: height 0.1s linear; }

/* Essay body type */
.essay-body { color: var(--ink); font-size: 19px; line-height: 1.72; }
.essay-body p { margin: 0 0 1.25em; text-wrap: pretty; }
.essay-body p em, .essay-body em { font-style: italic; }
.essay-body strong { font-weight: 600; }
.essay-body .hebrew { font-family: "Cormorant Garamond", serif; font-size: 1.15em; color: var(--navy); }

.essay-body h2 { font-size: clamp(28px, 2.6vw, 36px); margin: 56px 0 24px; font-weight: 500; line-height: 1.15; }
.essay-body h3 { font-size: 22px; margin: 36px 0 14px; font-style: italic; color: var(--navy-soft); font-weight: 500; }

.lede, .essay-body p.hp-dropcap:first-of-type { font-size: 21px; line-height: 1.6; }
.lede::first-line { font-variant: small-caps; letter-spacing: 0.06em; color: var(--navy); }

.dropcap, .hp-dropcap::first-letter {
	float: left;
	font-family: var(--serif-display);
	font-weight: 500;
	font-size: 88px;
	line-height: 0.85;
	padding: 8px 12px 0 0;
	color: var(--gold-deep);
}

/* Pull quote */
.pullquote, .wp-block-quote.hp-pullquote {
	margin: 44px -40px;
	padding: 28px 40px;
	font-family: var(--serif-display);
	font-style: italic;
	font-weight: 400;
	font-size: 28px;
	line-height: 1.32;
	color: var(--navy);
	border-top: 1px solid var(--gold-rule);
	border-bottom: 1px solid var(--gold-rule);
	text-align: left;
	position: relative;
}
.pullquote.large { font-size: 32px; }
.pullquote .pq-mark {
	font-family: var(--serif-display);
	font-size: 56px;
	line-height: 0.4;
	color: var(--gold);
	vertical-align: -0.1em;
	margin-right: 6px;
}
.pullquote .pq-mark.close { margin: 0 0 0 4px; }

/* Scripture block */
.scripture {
	margin: 36px 0;
	padding: 28px 32px;
	background: var(--cream-bright);
	border-left: 3px solid var(--gold);
	font-family: var(--serif-display);
	font-size: 22px;
	line-height: 1.5;
	color: var(--navy);
	position: relative;
}
.scripture::before {
	content: "";
	position: absolute;
	top: 6px; left: 6px; right: 6px; bottom: 6px;
	border: 1px solid var(--gold-rule);
	pointer-events: none;
}
.scripture .ref {
	display: block;
	font-family: var(--sans-mono);
	font-size: 10px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--gold-deep);
	margin-bottom: 10px;
}
.scripture p { margin: 0; }
.scripture strong { font-weight: 600; color: var(--navy); }

.essay-body .fleuron { margin: 56px auto; font-size: 22px; max-width: 200px; }

.essay-end {
	text-align: center;
	font-family: var(--serif-display);
	font-size: 28px;
	color: var(--gold);
	margin: 48px 0 64px;
}

/* Inline newsletter CTA */
.inline-cta {
	margin: 56px -40px;
	background: var(--navy);
	color: var(--cream);
	padding: 40px 44px;
	position: relative;
}
.inline-cta::before {
	content: "";
	position: absolute;
	inset: 8px;
	border: 1px solid rgba(193, 154, 75, 0.35);
	pointer-events: none;
}
.inline-cta-inner { position: relative; }
.inline-cta .kicker { color: var(--gold-soft); }
.inline-cta h3 { color: var(--cream); font-size: 30px; margin: 10px 0 8px; font-weight: 500; }
.inline-cta p { color: rgba(244, 236, 215, 0.72); font-size: 16px; margin: 0 0 22px; max-width: 36em; }
.inline-form {
	display: grid;
	grid-template-columns: 1fr auto;
	border: 1px solid rgba(193, 154, 75, 0.4);
	max-width: 460px;
}
.inline-form input { background: transparent; border: 0; padding: 14px 18px; color: var(--cream); font-family: var(--serif-body); font-size: 15px; outline: none; }
.inline-form input::placeholder { color: rgba(244, 236, 215, 0.4); }
.inline-form button { background: var(--gold); color: var(--navy); border: 0; padding: 0 22px; font-family: var(--serif-display); font-weight: 500; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; cursor: pointer; }

/* Author bio */
.author-bio {
	margin: 72px 0 0;
	padding: 36px 0 0;
	border-top: 1px solid var(--gold-rule);
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 32px;
	align-items: start;
}
.author-photo { width: 120px; height: 120px; aspect-ratio: 1; flex-shrink: 0; }
.author-body h3 { font-size: 28px; margin: 6px 0 12px; font-weight: 500; }
.author-body p { font-size: 16px; line-height: 1.65; color: var(--ink-soft); margin: 0 0 16px; }

/* Related */
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.related-grid .plate { aspect-ratio: 4/3; }

/* ============================================================
   About page
============================================================ */

.about-hero { padding: 64px 0 56px; }
.about-title { font-size: clamp(44px, 5.6vw, 84px); font-weight: 500; line-height: 1.04; margin: 14px auto 0; max-width: 18ch; }
.about-dek { font-family: var(--serif-display); font-style: italic; font-size: clamp(20px, 1.8vw, 26px); color: var(--ink-soft); line-height: 1.5; max-width: 32em; margin: 0 auto; }

.mission-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 80px; padding: 40px 32px 80px; }
.mission-grid h2 { font-size: clamp(28px, 2.4vw, 36px); font-weight: 500; font-style: italic; line-height: 1.25; color: var(--navy); }
.mission-grid .kicker { margin-bottom: 18px; }
.mission-prose p { font-size: 18px; line-height: 1.7; color: var(--ink-soft); max-width: 56ch; }

.manifesto {
	background: var(--navy);
	color: var(--cream);
	padding: 100px 0;
	position: relative;
}
.manifesto::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(135deg, rgba(193, 154, 75, 0.04) 0 1px, transparent 1px 14px);
	pointer-events: none;
}
.manifesto-inner { display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px; align-items: start; position: relative; }
.manifesto-plate { position: sticky; top: 24px; }
.manifesto-body h2 { color: var(--cream); font-size: clamp(28px, 2.6vw, 40px); font-weight: 500; margin: 12px 0 32px; font-style: italic; line-height: 1.18; }
.manifesto-list { list-style: none; padding: 0; margin: 0; counter-reset: man; }
.manifesto-list li {
	counter-increment: man;
	position: relative;
	padding: 22px 0 22px 64px;
	border-top: 1px solid rgba(193, 154, 75, 0.25);
	color: rgba(244, 236, 215, 0.85);
	font-size: 17px;
	line-height: 1.6;
}
.manifesto-list li:last-child { border-bottom: 1px solid rgba(193, 154, 75, 0.25); }
.manifesto-list li::before {
	content: counter(man, upper-roman);
	position: absolute;
	left: 0;
	top: 22px;
	font-family: var(--serif-display);
	font-style: italic;
	font-size: 22px;
	color: var(--gold-soft);
	width: 48px;
	text-align: center;
}
.manifesto-list strong { color: var(--cream); font-weight: 500; }

/* ============================================================
   WP block compatibility
============================================================ */

.wp-block-image { margin: 32px 0; }
.wp-block-image img { max-width: 100%; height: auto; }
.wp-block-quote { border-left: 3px solid var(--gold); padding: 12px 0 12px 24px; font-style: italic; font-family: var(--serif-display); font-size: 22px; line-height: 1.45; color: var(--navy-soft); }
.wp-block-quote cite { display: block; margin-top: 12px; font-family: var(--sans-mono); font-style: normal; font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.alignwide { max-width: calc(var(--wide-width) - 64px); margin-left: auto; margin-right: auto; }

/* ============================================================
   Responsive
============================================================ */

@media (max-width: 900px) {
	.masthead {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: 24px 20px 16px;
		text-align: center;
	}
	.masthead .issue-meta, .masthead .actions { display: none; }
	.brandmark img,
	.brandmark .custom-logo,
	.brandmark .custom-logo-link img { height: 52px; }
	.primary-nav-inner {
		padding: 12px 20px;
		gap: 18px;
		font-size: 11px;
		letter-spacing: 0.22em;
		overflow-x: auto;
		flex-wrap: nowrap;
		white-space: nowrap;
		justify-content: flex-start;
	}
	.site-top-inner { padding: 0 20px; font-size: 9px; gap: 12px; }
	.site-top .right a:nth-child(n+2) { display: none; }
	.site-footer .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
	.foot-bottom { flex-direction: column; gap: 12px; }
	.shell, .shell-wide { padding: 0 20px; }

	.hero-grid { grid-template-columns: 1fr; gap: 56px; }
	.hero-stats { grid-template-columns: repeat(3, 1fr); gap: 16px; }
	.hero-stats dd { font-size: 24px; }
	.hero-cta { flex-direction: column; align-items: flex-start; gap: 18px; }

	.section-head { grid-template-columns: 1fr; gap: 12px; align-items: start; }
	.latest-grid { grid-template-columns: 1fr 1fr; gap: 40px 28px; }
	.latest-grid .lead-card { grid-column: span 2; grid-template-columns: 1fr; gap: 22px; }

	.topics-grid { grid-template-columns: 1fr 1fr; }
	.topic:nth-child(2n) { border-right: 0; }
	.topic:nth-child(-n+2) { border-bottom: 1px solid var(--rule); }

	.shorts-row { grid-template-columns: repeat(2, 1fr); }

	.filter-bar { grid-template-columns: 1fr; }
	.search-form { min-width: 0; }
	.featured-row { grid-template-columns: 1fr; gap: 0; }
	.featured-row-body { padding: 28px; }
	.archive-grid { grid-template-columns: 1fr 1fr; }

	.essay-body-grid { grid-template-columns: 1fr; padding: 0 24px; gap: 0; }
	.share-rail { display: none; }
	.pullquote, .inline-cta { margin-left: 0; margin-right: 0; }
	.essay-byline { grid-template-columns: 1fr; gap: 18px; }
	.byline-right { flex-wrap: wrap; gap: 18px 28px; }
	.related-grid { grid-template-columns: 1fr; gap: 40px; }
	.author-bio { grid-template-columns: 80px 1fr; gap: 20px; }
	.author-photo { width: 80px; height: 80px; }

	.mission-grid { grid-template-columns: 1fr; gap: 24px; padding: 32px 20px 60px; }
	.manifesto-inner { grid-template-columns: 1fr; gap: 36px; }
	.manifesto-plate { position: static; }
}

@media (max-width: 600px) {
	body { font-size: 17px; }
	h1 { font-size: 38px; }
	h2 { font-size: 30px; }
	.site-footer .foot-grid { grid-template-columns: 1fr; }
	.newsletter { padding: 64px 0; }
	.subscribe-form { grid-template-columns: 1fr; }
	.subscribe-form button { padding: 14px; }

	.latest-grid { grid-template-columns: 1fr; }
	.latest-grid .lead-card { grid-column: span 1; }
	.topics-grid { grid-template-columns: 1fr; }
	.topic { border-right: 0; border-bottom: 1px solid var(--rule); }
	.topic:last-child { border-bottom: 0; }

	.archive-grid { grid-template-columns: 1fr; }
	.filter { font-size: 11px; padding: 8px 14px; }
}

@media (max-width: 480px) {
	.shorts-row { grid-template-columns: 1fr 1fr; gap: 16px; }
}
