/* ArgusWire — editorial type system.
   No photography. Weight is carried by Source Serif 4 (variable: opsz 8..60,
   wght 400/600/700) and Inter (400/500/600). Rules and whitespace replace
   boxes wherever possible. */

:root {
	/* Palette */
	--bg: #FAFAF7;
	--bg-elev: #FFFFFF;
	--text-primary: #1A1A1A;
	--text-muted: #5C5C5C;
	--text-subtle: #8A8A86;
	--border: #DCDAD2;
	--border-strong: #1A1A1A;
	--rule: #1A1A1A;
	--accent-red: #C8102E;
	--accent-red-dark: #8E0820;
	--accent-blue: #0F3D6E;
	--accent-gold: #B5882C;

	/* Region accents */
	--region-usa: #0F3D6E;
	--region-russia: #7A1224;
	--region-china: #B22222;
	--region-europe: #103B6E;
	--region-middleeast: #65733B;
	--region-india: #B5651D;
	--region-latinamerica: #246B45;

	/* Category accents (used by .kicker / .kicker-band) */
	--cat-geopolitics: var(--accent-red);
	--cat-human-rights: #B5651D;
	--cat-technology: #103B6E;
	--cat-global-economy: #246B45;
	--cat-economy: #246B45;
	--cat-science-health: #65733B;
	--cat-science: #65733B;
	--cat-global-culture: #7A1224;
	--cat-culture: #7A1224;
	--cat-world: #1A1A1A;

	/* Type families */
	--font-serif: "Source Serif 4", "Source Serif Pro", "Georgia", "Times New Roman", serif;
	--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", "Helvetica Neue", Arial, sans-serif;

	/* Type scale */
	--fs-mega: clamp(2.5rem, 8vw, 5.5rem);  /* lead title (homepage) */
	--fs-xxl:  clamp(2rem, 6vw, 4rem);       /* article H1 */
	--fs-xl:   clamp(1.5rem, 3.5vw, 2.4rem); /* secondary cards */
	--fs-lg:   clamp(1.2rem, 2.5vw, 1.6rem); /* tertiary cards, dek */
	--fs-md:   1.05rem;                       /* body */
	--fs-sm:   0.875rem;                      /* meta */
	--fs-xs:   0.75rem;                       /* kicker */

	/* Layout */
	--measure: 68ch;
	--gutter: clamp(1rem, 3vw, 2rem);
}

*, *::before, *::after { box-sizing: border-box; }

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

body {
	margin: 0;
	background: var(--bg);
	color: var(--text-primary);
	font-family: var(--font-sans);
	font-size: 17px;
	line-height: 1.55;
	font-feature-settings: "kern" 1, "liga" 1;
}

a {
	color: inherit;
	text-decoration: none;
}
a:hover, a:focus-visible {
	color: var(--accent-red);
	text-decoration: underline;
	text-underline-offset: 3px;
}

h1, h2, h3, h4 {
	font-family: var(--font-serif);
	font-weight: 700;
	letter-spacing: -0.015em;
	line-height: 1.1;
	margin: 0 0 0.6em;
	color: var(--text-primary);
}

p { margin: 0 0 1em; }

ul, ol { margin: 0 0 1em 1.25rem; padding: 0; }

img { max-width: 100%; height: auto; }

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

.skip-link {
	position: absolute;
	left: -1000px;
	top: 0;
	background: var(--text-primary);
	color: var(--bg);
	padding: 0.6rem 1rem;
	font-weight: 600;
	z-index: 100;
}
.skip-link:focus { left: 0; }

/* ---------- Masthead ---------- */
.masthead {
	border-bottom: 4px double var(--border-strong);
	padding: 1.4rem var(--gutter) 0.6rem;
	background: var(--bg);
}
.masthead-row {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: end;
	gap: 1rem;
	max-width: 1200px;
	margin: 0 auto;
}
.masthead-meta {
	font-family: var(--font-sans);
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-muted);
}
.masthead-meta-right { text-align: right; }
.masthead-title {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.1rem;
}
.masthead-title:hover, .masthead-title:focus-visible {
	color: var(--text-primary);
	text-decoration: none;
}
.masthead-name {
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: clamp(2.6rem, 6vw, 4rem);
	letter-spacing: -0.03em;
	line-height: 0.95;
	color: var(--text-primary);
	font-variation-settings: "opsz" 60;
}
.masthead-tagline {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 0.92rem;
	letter-spacing: 0;
	color: var(--text-muted);
	font-variation-settings: "opsz" 14;
}

/* ---------- Navigation ---------- */
.primary-nav, .region-nav {
	max-width: 1200px;
	margin: 0 auto;
	border-top: 1px solid var(--border);
	padding: 0.6rem 0 0.5rem;
}
.primary-nav ul, .region-nav ul {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem 1.4rem;
	list-style: none;
	margin: 0;
}
.primary-nav a, .region-nav a {
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-primary);
	padding: 0.15rem 0;
	border-bottom: 2px solid transparent;
}
.primary-nav a:hover, .region-nav a:hover,
.primary-nav [aria-current="page"], .region-nav [aria-current="page"] {
	color: var(--accent-red);
	border-bottom-color: var(--accent-red);
	text-decoration: none;
}
.region-nav {
	display: flex;
	align-items: baseline;
	gap: 0.6rem;
	border-top: 1px dashed var(--border);
	border-bottom: 1px dashed var(--border);
}
.region-nav-label, .lang-nav-label {
	font-family: var(--font-sans);
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-muted);
}
.lang-nav {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	padding: 0.4rem 0 0.3rem;
	border-top: 1px solid var(--border);
}
.lang-nav ul {
	display: flex;
	gap: 0.6rem;
	list-style: none;
	margin: 0;
}
.lang-nav a {
	font-family: var(--font-sans);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-muted);
	padding: 0.05rem 0.35rem;
	border: 1px solid transparent;
	border-radius: 2px;
}
.lang-nav a:hover, .lang-nav a.lang-active {
	color: var(--accent-red);
	border-color: var(--accent-red);
	text-decoration: none;
}
.nav-divider {
	width: 1px;
	background: var(--border);
	align-self: stretch;
}

/* ---------- Main shell ---------- */
main {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2.4rem var(--gutter) 3rem;
}

/* ---------- Kicker (category eyebrow) ---------- */
.kicker {
	font-family: var(--font-sans);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--accent-red);
	margin: 0 0 0.5rem;
	line-height: 1.4;
}
.kicker.cat-geopolitics    { color: var(--cat-geopolitics); }
.kicker.cat-human_rights,
.kicker.cat-rights,
.kicker.cat-human-rights   { color: var(--cat-human-rights); }
.kicker.cat-technology     { color: var(--cat-technology); }
.kicker.cat-global_economy,
.kicker.cat-economy,
.kicker.cat-global-economy { color: var(--cat-global-economy); }
.kicker.cat-science_health,
.kicker.cat-science,
.kicker.cat-science-health { color: var(--cat-science-health); }
.kicker.cat-global_culture,
.kicker.cat-culture,
.kicker.cat-global-culture { color: var(--cat-global-culture); }
.kicker.cat-world          { color: var(--cat-world); }

/* Kicker band — a 4px section flag below the eyebrow text, used on lead. */
.kicker-band {
	display: inline-block;
	padding-bottom: 0.55rem;
	border-bottom: 4px solid currentColor;
	margin-bottom: 0.9rem;
	color: var(--accent-red);
}

/* ---------- Lead story (homepage hero) ---------- */
.lead-stage {
	padding: clamp(1.5rem, 4vw, 3rem) 0 clamp(2rem, 5vw, 4rem);
	border-bottom: 1px solid var(--rule);
	margin-bottom: clamp(2.5rem, 6vw, 4.5rem);
}
.lead-story {
	display: grid;
	gap: 1rem;
	max-width: 64rem;
}
.lead-link { display: block; }
.lead-link:hover { text-decoration: none; }
.lead-title {
	font-family: var(--font-serif);
	font-size: var(--fs-mega);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 0.95;
	margin: 0;
	color: var(--text-primary);
	font-variation-settings: "opsz" 60;
	text-wrap: balance;
}
.lead-link:hover .lead-title { color: var(--accent-red); }
.lead-dek {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: var(--fs-lg);
	line-height: 1.35;
	letter-spacing: -0.005em;
	color: var(--text-muted);
	max-width: var(--measure);
	margin: 0.4rem 0 0;
	font-variation-settings: "opsz" 20;
	text-wrap: pretty;
}
.lead-byline {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	color: var(--text-muted);
	margin: 0.4rem 0 0;
	letter-spacing: 0.01em;
}
.lead-byline strong {
	color: var(--text-primary);
	font-weight: 600;
}

/* ---------- Multicultural strip ---------- */
.multicultural-strip {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0.5rem 0 0;
	padding: 0;
}
.region-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	padding: 0.22rem 0.65rem;
	border-radius: 999px;
	background: rgba(26,26,26,0.04);
	color: var(--text-primary);
	border: 1px solid var(--border);
	transition: color 120ms ease, border-color 120ms ease, background 120ms ease;
}
.region-badge:hover {
	color: var(--accent-red);
	border-color: var(--accent-red);
}
.region-badge .region-flag { font-size: 0.95em; line-height: 1; }
.region-badge .region-name { letter-spacing: inherit; }

.multicultural-strip.compact { gap: 0.3rem; }
.multicultural-strip.compact .region-badge {
	font-size: 0.7rem;
	padding: 0.15rem 0.5rem;
	letter-spacing: 0.04em;
}

/* Prominent — used on article header and homepage lead. Bigger pills,
   full region names, more breathing room. */
.multicultural-strip.prominent {
	gap: 0.55rem;
	margin: 0.9rem 0 0;
}
.multicultural-strip.prominent .region-badge {
	height: 32px;
	font-size: 0.82rem;
	font-weight: 600;
	padding: 0 1rem;
	letter-spacing: 0.02em;
	border-width: 1px;
}
.multicultural-strip.prominent .region-badge .region-flag {
	font-size: 1.1em;
}

/* Region accents — share with both compact and prominent. */
.region-usa          { background: rgba(15,61,110,0.08); color: var(--region-usa); border-color: rgba(15,61,110,0.30); }
.region-russia       { background: rgba(122,18,36,0.08); color: var(--region-russia); border-color: rgba(122,18,36,0.30); }
.region-china        { background: rgba(178,34,34,0.08); color: var(--region-china); border-color: rgba(178,34,34,0.30); }
.region-europe       { background: rgba(16,59,110,0.08); color: var(--region-europe); border-color: rgba(16,59,110,0.30); }
.region-middleeast   { background: rgba(101,115,59,0.10); color: var(--region-middleeast); border-color: rgba(101,115,59,0.32); }
.region-india        { background: rgba(181,101,29,0.08); color: var(--region-india); border-color: rgba(181,101,29,0.32); }
.region-latinamerica { background: rgba(36,107,69,0.08); color: var(--region-latinamerica); border-color: rgba(36,107,69,0.32); }

/* ---------- Card grids (homepage) ---------- */
.secondary-grid, .tertiary-grid {
	display: grid;
	margin: 0 0 clamp(2.5rem, 6vw, 4.5rem);
}
.secondary-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0;
	border-top: 1px solid var(--rule);
	padding-top: 2rem;
	padding-bottom: 2.4rem;
	border-bottom: 1px solid var(--rule);
}
.tertiary-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0;
	border-top: 1px solid var(--rule);
	padding-top: 1.6rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid var(--rule);
}

/* Hairline dividers between cards: vertical rules in the gutter. */
.secondary-card, .tertiary-card {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	padding: 0 1.6rem;
}
.secondary-card + .secondary-card,
.tertiary-card + .tertiary-card {
	border-left: 1px solid var(--border);
}
.secondary-card:first-child, .tertiary-card:first-child { padding-left: 0; }
.secondary-card:last-child, .tertiary-card:last-child { padding-right: 0; }

.card-link { display: block; }
.card-link:hover { text-decoration: none; }
.card-title {
	font-family: var(--font-serif);
	font-weight: 600;
	letter-spacing: -0.01em;
	margin: 0;
	color: var(--text-primary);
	text-wrap: balance;
}
.secondary-card .card-title {
	font-size: var(--fs-xl);
	line-height: 1.1;
}
.tertiary-card .card-title {
	font-size: var(--fs-lg);
	line-height: 1.2;
	font-weight: 600;
}
.card-link:hover .card-title { color: var(--accent-red); }

.card-dek {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 1.02rem;
	line-height: 1.4;
	color: var(--text-muted);
	margin: 0.3rem 0 0;
	max-width: 36ch;
	font-variation-settings: "opsz" 16;
}
.card-meta {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	color: var(--text-muted);
	margin: 0.4rem 0 0;
	letter-spacing: 0.01em;
}

/* ---------- More stories list ---------- */
.section-heading {
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--text-primary);
	margin: 0 0 1.1rem;
	padding-bottom: 0.45rem;
	border-bottom: 2px solid var(--rule);
}
.more-stories { margin-top: clamp(2.5rem, 6vw, 4rem); }
.more-list { list-style: none; margin: 0; padding: 0; }
.more-item {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--border);
}
.more-item:last-child { border-bottom: 0; }
.more-item a {
	display: flex;
	gap: 1.2rem;
	align-items: baseline;
	flex: 1;
	min-width: 0;
}
.more-cat {
	font-family: var(--font-sans);
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 600;
	min-width: 8rem;
	color: var(--accent-red);
}
.more-cat.cat-geopolitics    { color: var(--cat-geopolitics); }
.more-cat.cat-human_rights,
.more-cat.cat-rights         { color: var(--cat-human-rights); }
.more-cat.cat-technology     { color: var(--cat-technology); }
.more-cat.cat-global_economy,
.more-cat.cat-economy        { color: var(--cat-global-economy); }
.more-cat.cat-science_health,
.more-cat.cat-science        { color: var(--cat-science-health); }
.more-cat.cat-global_culture,
.more-cat.cat-culture        { color: var(--cat-global-culture); }
.more-title {
	font-family: var(--font-serif);
	font-size: 1.08rem;
	font-weight: 600;
	color: var(--text-primary);
}
.more-meta {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	color: var(--text-muted);
	white-space: nowrap;
}

/* ---------- Article page ---------- */
.story {
	max-width: 44rem;
	margin: 0 auto;
}
.breadcrumb {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	color: var(--text-muted);
	margin: 0 0 1.6rem;
}
.breadcrumb ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 0.4rem; }
.breadcrumb li + li::before { content: "›"; margin-right: 0.4rem; color: var(--text-subtle); }
.breadcrumb a { color: var(--text-muted); }

.story-header {
	padding-top: clamp(2rem, 6vw, 5rem);
	margin-bottom: clamp(2rem, 5vw, 3rem);
}
.story-header .kicker {
	margin-bottom: 0.9rem;
}
.story-title {
	font-family: var(--font-serif);
	font-size: var(--fs-xxl);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 0.98;
	margin: 0 0 1rem;
	color: var(--text-primary);
	font-variation-settings: "opsz" 60;
	text-wrap: balance;
}
.story-dek {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: var(--fs-lg);
	line-height: 1.35;
	color: var(--text-muted);
	margin: 0 0 1.2rem;
	max-width: var(--measure);
	font-variation-settings: "opsz" 22;
	text-wrap: pretty;
}
.story-byline {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	color: var(--text-muted);
	margin: 1.2rem 0 0;
	letter-spacing: 0.01em;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.45rem;
}
.story-byline .byline-author {
	font-weight: 600;
	color: var(--text-primary);
	letter-spacing: 0.02em;
}
.story-byline .byline-meta strong {
	color: var(--text-primary);
	font-weight: 600;
}
.story-byline .byline-sep {
	color: var(--text-subtle);
}
.story-byline time {
	font-variant-numeric: tabular-nums;
}
.story-rule {
	border: 0;
	border-top: 1px solid var(--rule);
	margin: 1.6rem 0 0;
}

/* Body — broadsheet flow with first-paragraph drop cap and indented runs. */
.story-body {
	font-family: var(--font-serif);
	font-size: var(--fs-md);
	font-weight: 400;
	line-height: 1.65;
	color: var(--text-primary);
	max-width: var(--measure);
	margin: clamp(2rem, 4vw, 3rem) 0 0;
	font-variation-settings: "opsz" 11;
}
.story-body p { margin: 0 0 1.1em; }
.story-body p + p { text-indent: 1.5em; }
.story-body p:first-of-type { text-indent: 0; }

/* Drop cap — only on the first prose paragraph. */
.story-body > p:first-of-type::first-letter {
	float: left;
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: 5.5em;
	line-height: 0.85;
	padding: 0.08em 0.08em 0 0;
	color: var(--text-primary);
	font-variation-settings: "opsz" 60;
	-webkit-initial-letter: 3;
	initial-letter: 3;
}

.story-body h2 {
	font-family: var(--font-serif);
	font-size: 1.45rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.2;
	margin: 2.4rem 0 0.8rem;
	padding-top: 1.1rem;
	border-top: 1px solid var(--border);
}
.story-body h3 {
	font-size: 1.2rem;
	font-weight: 700;
	margin: 1.6rem 0 0.6rem;
}
.story-body ul, .story-body ol {
	margin: 0 0 1.2em 1.4rem;
}
.story-body li { margin-bottom: 0.5em; }
.story-body strong { font-weight: 700; }
.story-body em { font-style: italic; }
.story-body a {
	color: var(--accent-red);
	border-bottom: 1px solid rgba(200,16,46,0.3);
}
.story-body a:hover { background: rgba(200,16,46,0.06); }

/* Pull quote — CSS-prepared for future use; not yet emitted by the
   pipeline. Place a <blockquote class="pull-quote"> in the story body. */
.story-body .pull-quote, .story .pull-quote {
	font-family: var(--font-serif);
	font-weight: 600;
	font-style: normal;
	font-size: clamp(1.4rem, 2.8vw, 1.9rem);
	line-height: 1.25;
	letter-spacing: -0.015em;
	color: var(--text-primary);
	margin: 2.4rem 0;
	padding: 0.4rem 0 0.4rem 1.2rem;
	border-left: 3px solid var(--accent-red);
	max-width: 36rem;
	text-wrap: balance;
	font-variation-settings: "opsz" 28;
}
.story-body .pull-quote::before { content: "“"; margin-right: 0.05em; }
.story-body .pull-quote::after  { content: "”"; }
.story-body .pull-quote cite {
	display: block;
	margin-top: 0.6rem;
	font-family: var(--font-sans);
	font-style: normal;
	font-weight: 500;
	font-size: 0.78rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-muted);
}

/* ---------- Divergences ---------- */
.divergences {
	margin: 2.4rem 0;
	border: 1px solid var(--border-strong);
	border-left-width: 6px;
	background: var(--bg-elev);
	padding: 1.1rem 1.4rem;
	border-radius: 2px;
}
.divergences[open] summary { margin-bottom: 0.8rem; }
.divergences summary {
	cursor: pointer;
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--text-primary);
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.6rem;
}
.divergences summary::-webkit-details-marker { display: none; }
.divergences-marker {
	width: 0.6rem;
	height: 0.6rem;
	background: var(--accent-red);
	border-radius: 50%;
	display: inline-block;
}
.divergence-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.85rem;
}
.divergence-list li {
	font-family: var(--font-serif);
	font-size: 1.02rem;
	line-height: 1.55;
	padding-left: 1rem;
	border-left: 3px solid var(--accent-red);
}
.divergence-list li p { margin: 0; }

/* ---------- Sources cited ---------- */
.sources-cited { margin: 2.6rem 0 1.6rem; }
.cited-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0; }
.cited-item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.6rem;
	padding: 0.7rem 0;
	border-bottom: 1px solid var(--border);
}
.cited-item:last-child { border-bottom: 0; }
.cited-item a {
	font-family: var(--font-serif);
	font-weight: 600;
	color: var(--accent-red);
	flex: 1;
	min-width: 12rem;
}
.cited-tier {
	font-family: var(--font-sans);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.15rem 0.55rem;
	border-radius: 999px;
	background: rgba(26,26,26,0.06);
}
.tier-mainstream { color: var(--accent-blue); background: rgba(15,61,110,0.08); }
.tier-independent { color: var(--accent-red); background: rgba(200,16,46,0.08); }

/* ---------- AI disclosure ---------- */
.ai-disclosure {
	margin: 2.4rem 0 0;
	padding: 1.1rem 1.3rem;
	background: rgba(26,26,26,0.04);
	border-left: 3px solid var(--text-primary);
	font-family: var(--font-sans);
	font-size: 0.92rem;
	color: var(--text-muted);
	border-radius: 2px;
}
.ai-disclosure h3 {
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0 0 0.5rem;
	color: var(--text-primary);
}
.ai-disclosure p { margin: 0 0 0.5rem; }
.ai-meta { font-size: 0.78rem; color: var(--text-subtle); }

/* ---------- List pages (category, region) ---------- */
.list-page { max-width: 52rem; margin: 0 auto; }
.list-header {
	margin-bottom: 2.4rem;
	padding-bottom: 1.6rem;
	border-bottom: 2px solid var(--rule);
}
.list-title {
	font-family: var(--font-serif);
	font-size: var(--fs-xxl);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 0.98;
	margin: 0 0 0.45rem;
	font-variation-settings: "opsz" 60;
}
.list-subtitle {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	color: var(--text-muted);
	font-size: var(--fs-lg);
	margin: 0;
}
.list-stories {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}
.list-story {
	padding: 1.4rem 0;
	border-bottom: 1px solid var(--border);
}
.list-story:last-child { border-bottom: 0; }
.list-story-link { display: block; }
.list-story-link:hover { text-decoration: none; }
.list-story-title {
	font-family: var(--font-serif);
	font-size: var(--fs-xl);
	font-weight: 700;
	letter-spacing: -0.015em;
	line-height: 1.1;
	margin: 0 0 0.5rem;
	color: var(--text-primary);
	text-wrap: balance;
}
.list-story-link:hover .list-story-title { color: var(--accent-red); }
.list-story-dek {
	font-family: var(--font-serif);
	font-style: italic;
	font-weight: 400;
	font-size: 1.05rem;
	line-height: 1.4;
	color: var(--text-muted);
	margin: 0 0 0.4rem;
	max-width: var(--measure);
	font-variation-settings: "opsz" 16;
}
.list-story-meta {
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	color: var(--text-muted);
	margin: 0.6rem 0 0;
}

/* ---------- Prose pages (about, sources) ---------- */
.prose {
	max-width: 44rem;
	margin: 0 auto;
	font-family: var(--font-serif);
	font-size: 1.08rem;
	line-height: 1.7;
}
.prose-header { margin-bottom: 2.2rem; }
.prose h1 {
	font-family: var(--font-serif);
	font-size: clamp(1.8rem, 4vw, 2.6rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.05;
	margin: 0 0 1rem;
	font-variation-settings: "opsz" 36;
	text-wrap: balance;
}
.prose .lede {
	font-family: var(--font-serif);
	font-style: italic;
	color: var(--text-muted);
	font-size: 1.18rem;
	line-height: 1.4;
	font-variation-settings: "opsz" 18;
}
.prose h2 {
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--border);
}
.prose code {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	background: rgba(26,26,26,0.06);
	padding: 0 0.3rem;
	border-radius: 2px;
	font-size: 0.95em;
}
.prose ul, .prose ol { margin-left: 1.6rem; }
.prose li { margin-bottom: 0.45em; }
.prose a {
	color: var(--accent-red);
	border-bottom: 1px solid rgba(200,16,46,0.3);
}

.sources-page .sources-table {
	width: 100%;
	border-collapse: collapse;
	font-family: var(--font-sans);
	font-size: 0.95rem;
	margin: 1.6rem 0;
}
.sources-table th, .sources-table td {
	padding: 0.7rem 0.6rem;
	text-align: left;
	border-bottom: 1px solid var(--border);
	vertical-align: middle;
}
.sources-table th {
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-muted);
	border-bottom: 2px solid var(--rule);
	background: var(--bg-elev);
}
.sources-table tbody tr:hover { background: rgba(26,26,26,0.025); }
.sources-note { font-style: italic; color: var(--text-muted); font-size: 0.95rem; }

/* ---------- Footer (minimalist) ---------- */
.site-footer {
	max-width: 1200px;
	margin: 4rem auto 1.5rem;
	padding: 1.6rem var(--gutter) 1.2rem;
	border-top: 1px solid var(--rule);
	font-family: var(--font-sans);
	font-size: 0.85rem;
	color: var(--text-muted);
}
.footer-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: baseline;
	gap: 1rem 2rem;
	margin-bottom: 1.2rem;
}
.footer-grid > div { min-width: 0; }
.footer-grid > div:first-child {
	flex: 1 1 100%;
	max-width: 36rem;
}
.footer-grid > div:first-child p:not(.footer-brand) {
	font-style: italic;
	color: var(--text-subtle);
	margin: 0;
}
.footer-brand {
	font-family: var(--font-serif);
	font-size: 1.3rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--text-primary);
	margin: 0 0 0.3rem;
	font-variation-settings: "opsz" 32;
}
.footer-heading {
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 0.5rem;
}
.site-footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem 1rem;
}
.site-footer ul li { display: inline; }
.footer-disclosure {
	font-style: italic;
	border-top: 1px solid var(--border);
	padding-top: 0.9rem;
	margin: 0 0 0.4rem;
	font-size: 0.8rem;
	color: var(--text-subtle);
}
.footer-copy {
	font-size: 0.75rem;
	color: var(--text-subtle);
	margin: 0;
}

/* ---------- Responsive ---------- */
@media (max-width: 880px) {
	.masthead-row { grid-template-columns: 1fr; text-align: center; }
	.masthead-meta, .masthead-meta-right { text-align: center; }
	.secondary-grid { grid-template-columns: 1fr; }
	.tertiary-grid { grid-template-columns: 1fr 1fr; }
	.secondary-card, .tertiary-card {
		padding: 1.2rem 0;
	}
	.secondary-card + .secondary-card,
	.tertiary-card + .tertiary-card {
		border-left: 0;
		border-top: 1px solid var(--border);
	}
	.tertiary-grid .tertiary-card:nth-child(2) {
		border-top: 0;
		border-left: 1px solid var(--border);
		padding-left: 1.2rem;
	}
	.footer-grid { flex-direction: column; align-items: flex-start; }
	.more-item { flex-direction: column; align-items: flex-start; gap: 0.3rem; }
	.more-item a { flex-direction: column; align-items: flex-start; gap: 0.2rem; }
	.more-cat { min-width: 0; }
}
@media (max-width: 720px) {
	main { padding-top: 1.6rem; padding-bottom: 2rem; }
	.story-header { padding-top: clamp(1.2rem, 6vw, 2rem); margin-bottom: 1.6rem; }
	.lead-stage {
		padding: clamp(1rem, 4vw, 1.6rem) 0 clamp(1.4rem, 5vw, 2rem);
		margin-bottom: 1.6rem;
	}
	.lead-title { font-size: clamp(2rem, 8vw, 2.8rem); }
	.story-title { font-size: clamp(1.6rem, 7vw, 2.2rem); }
	.story-body > p:first-of-type::first-letter {
		font-size: 4em;
		padding: 0.04em 0.06em 0 0;
	}
	.story-byline { gap: 0.35rem; }
	.multicultural-strip.prominent .region-badge {
		height: 28px;
		font-size: 0.78rem;
		padding: 0 0.8rem;
	}
}
@media (max-width: 540px) {
	.tertiary-grid { grid-template-columns: 1fr; }
	.tertiary-grid .tertiary-card:nth-child(2) {
		border-left: 0;
		border-top: 1px solid var(--border);
		padding-left: 0;
	}
	body { font-size: 16px; }
	main { padding-top: 1.4rem; }
}

/* ---------- Print ---------- */
@media print {
	body { background: #fff; color: #000; font-size: 11pt; }
	.masthead, .primary-nav, .region-nav, .lang-nav, .site-footer, .ai-disclosure, .breadcrumb { display: none; }
	.story-body { font-size: 11pt; line-height: 1.5; }
	.story-body > p:first-of-type::first-letter { color: #000; }
	a { color: #000; text-decoration: underline; }
	.divergences { border: 1px solid #000; }
	.region-badge { border: 1px solid #000; background: transparent; color: #000; }
}

/* ---------- Focus ---------- */
:focus-visible {
	outline: 3px solid var(--accent-red);
	outline-offset: 3px;
}

/* ---------- Ad slots ---------- */
/* Base */
.ad-slot {
	display: block;
	margin: 28px auto;
	padding: 14px 18px;
	border-radius: 2px;
	text-align: center;
	font-size: 13px;
	line-height: 1.5;
	max-width: var(--measure);
}
.ad-slot a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.ad-slot[data-slot-id]::before {
	content: "Sponsored";
	display: block;
	font-size: 9px;
	letter-spacing: 2px;
	text-transform: uppercase;
	opacity: 0.55;
	margin-bottom: 6px;
}
.ad-slot:empty { display: none; }

/* Hero — Insider promo (gold/cream, premium feel) */
.ad-slot.ad-slot-hero {
	background: #FBF6E9;
	border-top: 2px solid var(--accent-gold);
	border-bottom: 2px solid var(--accent-gold);
	color: #5a4514;
	padding: 18px 22px;
	font-size: 14px;
	margin: 18px auto 32px;
}
.ad-slot.ad-slot-hero::before {
	content: "From the editors";
	color: var(--accent-gold);
	opacity: 1;
}
.ad-slot.ad-slot-hero a {
	text-decoration: none;
}

/* Sidebar — appears inline on desktop too because the homepage is one column;
   keep it compact, never tall. We override the legacy "min-height: 600px". */
.ad-slot.ad-slot-sidebar {
	background: #F4ECEC;
	border-left: 3px solid var(--accent-red);
	color: #4a1620;
	padding: 16px 20px;
	max-width: 480px;
	margin: 32px auto;
	min-height: 0;
	position: static;
	text-align: left;
}
.ad-slot.ad-slot-sidebar::before {
	content: "Premium tier";
	color: var(--accent-red);
	opacity: 1;
}

/* In-content — neutral, native-feel (gray) */
.ad-slot.ad-slot-incontent,
.ad-slot[data-slot-id^="ad-incontent"] {
	background: #F2F0EA;
	border: 1px solid #DCDAD2;
	color: #5C5C5C;
	font-size: 12px;
}
.ad-slot[data-slot-id^="ad-incontent"]::before {
	content: "Sponsored";
}

/* Newsletter CTA — dark, contrast (editorial signature) */
.ad-slot.ad-slot-newsletter {
	background: #1A1A1A;
	color: #FAFAF7;
	border: none;
	padding: 22px 24px;
	margin: 40px auto;
}
.ad-slot.ad-slot-newsletter::before {
	content: "Newsletter";
	color: #B5882C;
	opacity: 1;
}
.ad-slot.ad-slot-newsletter a {
	color: #FAFAF7;
}
.ad-slot.ad-slot-newsletter input[type="email"] {
	color: #1A1A1A;
}

/* Mobile anchor — only show on small screens, sticky bottom */
.ad-slot.ad-slot-mobile-anchor {
	display: none;
}
@media (max-width: 720px) {
	.ad-slot.ad-slot-mobile-anchor {
		display: block;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		margin: 0;
		max-width: none;
		background: #FFFFFF;
		border-top: 1px solid var(--border);
		padding: 8px 12px;
		font-size: 11px;
		z-index: 100;
		box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.06);
	}
}

/* Article-page sidebar slot — when inside an aside.article-rail it stays
   sticky like a real sidebar. Outside that context it stays compact. */
.article-rail .ad-slot.ad-slot-sidebar {
	position: sticky;
	top: 80px;
	max-width: none;
	margin: 0 0 24px;
}

/* ---------- Search: nav trigger + modal overlay ---------- */
.nav-search-item { margin-left: auto; }
.search-trigger {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: transparent;
	border: 1px solid var(--border);
	border-radius: 2px;
	padding: 6px 10px;
	font-size: 12px;
	color: var(--text-muted);
	cursor: pointer;
	font-family: inherit;
	line-height: 1;
}
.search-trigger:hover,
.search-trigger:focus-visible {
	border-color: var(--text-primary);
	color: var(--text-primary);
	outline: none;
}
.search-trigger svg { display: block; }
.search-trigger kbd {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	font-size: 10px;
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: 2px;
	padding: 1px 5px;
	color: var(--text-muted);
}

body.search-open { overflow: hidden; }

.search-modal {
	position: fixed;
	inset: 0;
	z-index: 200;
	display: none;
}
.search-modal[aria-hidden="false"] { display: block; }
.search-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(26, 26, 26, 0.55);
	-webkit-backdrop-filter: blur(2px);
	backdrop-filter: blur(2px);
}
.search-modal-panel {
	position: relative;
	max-width: 720px;
	margin: 60px auto;
	background: var(--bg);
	border-radius: 2px;
	border: 1px solid var(--border);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
	overflow: hidden;
	max-height: calc(100vh - 120px);
	display: flex;
	flex-direction: column;
}
.search-modal-header {
	padding: 12px 16px;
	border-bottom: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: var(--font-serif);
	font-size: 14px;
	color: var(--text-primary);
	background: var(--bg-elev);
}
.search-modal-header button {
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: 2px;
	padding: 2px 8px;
	font-size: 11px;
	cursor: pointer;
	font-family: inherit;
	color: var(--text-muted);
}
.search-modal-header button:hover,
.search-modal-header button:focus-visible {
	border-color: var(--text-primary);
	color: var(--text-primary);
	outline: none;
}
#search-ui {
	flex: 1;
	overflow-y: auto;
	padding: 16px;
	background: var(--bg);
}

/* Map Pagefind UI tokens to ArgusWire's editorial palette. */
.pagefind-ui {
	--pagefind-ui-primary: var(--accent-red);
	--pagefind-ui-text: var(--text-primary);
	--pagefind-ui-background: var(--bg);
	--pagefind-ui-border: var(--border);
	--pagefind-ui-tag: var(--bg-elev);
	--pagefind-ui-border-width: 1px;
	--pagefind-ui-border-radius: 2px;
	--pagefind-ui-font: var(--font-sans);
}
.pagefind-ui__result-title { font-family: var(--font-serif); }

@media (max-width: 720px) {
	.nav-search-item { margin-left: 0; }
	.search-modal-panel {
		margin: 0;
		max-height: 100vh;
		border-radius: 0;
		border: none;
		height: 100vh;
	}
	.search-trigger-label { display: none; }
}

/* ---------- /advertise (sponsorship landing) ---------- */
.advertise.prose {
	max-width: 70rem;
}
.advertise-pitch {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
	margin: 32px 0 12px;
	font-family: var(--font-sans);
	font-size: 0.96rem;
	line-height: 1.5;
}
.advertise-pitch-item h3 {
	font-family: var(--font-sans);
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--text-muted);
	margin: 0 0 8px;
	border-top: 2px solid var(--rule);
	padding-top: 10px;
}
.advertise-pitch-item p { margin: 0; color: var(--text-primary); }

.advertise .plans-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
	margin: 48px 0;
}
.plan-card {
	border: 1px solid var(--border);
	border-radius: 4px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	background: var(--bg-elev);
	font-family: var(--font-sans);
}
.plan-card .kicker {
	font-family: var(--font-sans);
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-muted);
	margin: 0 0 8px;
}
.plan-card.plan-featured {
	border-color: var(--accent-gold);
	background: #FBF6E9;
}
.plan-card.plan-custom {
	border-style: dashed;
}
.plan-price {
	font-family: var(--font-serif);
	font-size: 2.5rem;
	font-weight: 600;
	line-height: 1;
	margin: 8px 0 4px;
	color: var(--text-primary);
}
.plan-price span { font-size: 0.9rem; font-weight: 400; opacity: 0.6; }
.plan-duration {
	font-size: 0.85rem;
	color: var(--text-muted);
	margin: 0 0 14px;
}
.plan-description {
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--text-primary);
	margin: 0 0 14px;
}
.plan-features {
	margin: 16px 0;
	padding: 0;
	list-style: none;
	font-size: 0.92rem;
	line-height: 1.55;
}
.plan-features li {
	margin: 0 0 6px;
	padding: 0;
}
.plan-features li::before {
	content: "→ ";
	color: var(--accent-red);
	font-weight: 600;
}
.plan-cta {
	display: inline-block;
	margin-top: auto;
	padding: 10px 16px;
	background: var(--text-primary);
	color: var(--bg);
	text-decoration: none;
	border-radius: 3px;
	text-align: center;
	font-size: 0.9rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	border: 1px solid var(--text-primary);
}
.plan-cta:hover {
	background: var(--accent-red);
	border-color: var(--accent-red);
	color: var(--bg);
}
.plan-card.plan-featured .plan-cta {
	background: var(--accent-red);
	border-color: var(--accent-red);
}
.plan-card.plan-featured .plan-cta:hover {
	background: var(--accent-red-dark);
	border-color: var(--accent-red-dark);
}

.advertise-inventory { margin: 48px 0; }
.advertise-inventory h2,
.advertise-faq h2,
.advertise-contact h2 {
	font-family: var(--font-serif);
	font-size: 1.4rem;
	margin: 0 0 12px;
}
.advertise-inventory table {
	width: 100%;
	border-collapse: collapse;
	margin: 16px 0;
	font-family: var(--font-sans);
}
.advertise-inventory th,
.advertise-inventory td {
	padding: 10px 12px;
	text-align: left;
	border-bottom: 1px solid var(--border);
	font-size: 0.9rem;
	vertical-align: top;
}
.advertise-inventory th {
	font-family: var(--font-sans);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.7rem;
	color: var(--text-muted);
	border-bottom: 2px solid var(--rule);
}
.advertise-inventory code {
	font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
	background: rgba(26,26,26,0.06);
	padding: 1px 6px;
	border-radius: 2px;
	font-size: 0.85em;
}

.advertise-faq { margin: 48px 0; }
.advertise-faq h3 {
	margin-top: 22px;
	font-family: var(--font-serif);
	font-size: 1.08rem;
	font-weight: 600;
	border-top: 1px solid var(--border);
	padding-top: 14px;
}
.advertise-faq p {
	font-size: 0.98rem;
	line-height: 1.6;
}

.advertise-contact { margin: 48px 0 24px; }

.btn-pill {
	display: inline-block;
	padding: 6px 14px;
	border: 1px solid var(--border-strong);
	border-radius: 999px;
	font-family: var(--font-sans);
	font-size: 0.85rem;
	color: var(--text-primary);
	background: var(--bg);
}
.btn-pill:hover { background: var(--text-primary); color: var(--bg); }
