/* ==========================================================================
   Tersbakis
   Modern portal redesign: bold homepage, calmer article pages, ad-aware shell
   ========================================================================== */

:root {
	--paper: #f8f9fb;
	--paper-strong: #f1f3f7;
	--surface: #ffffff;
	--surface-alt: #fbfcfe;
	--surface-dark: #ffffff;
	--surface-dark-soft: #f5f7fb;
	--ink: #11151a;
	--ink-soft: #505a66;
	--ink-muted: #75808b;
	--line: rgba(17, 21, 26, 0.08);
	--line-strong: rgba(17, 21, 26, 0.16);
	--signal: #c83a2a;
	--signal-strong: #9e271a;
	--signal-soft: #f9dfda;
	--gold: #b9954e;
	--shadow-sm: 0 10px 24px rgba(17, 21, 26, 0.05);
	--shadow-lg: 0 28px 60px rgba(17, 21, 26, 0.09);
	--font-display: 'Arial Narrow', 'Roboto Condensed', 'Helvetica Neue', Arial, sans-serif;
	--font-serif: Georgia, 'Times New Roman', Times, serif;
	--font-sans: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
	--t-xs: 0.72rem;
	--t-sm: 0.875rem;
	--t-base: 1rem;
	--t-md: 1.125rem;
	--t-lg: 1.375rem;
	--t-xl: 1.875rem;
	--t-2xl: 2.5rem;
	--t-3xl: 3.25rem;
	--s-1: 4px;
	--s-2: 8px;
	--s-3: 12px;
	--s-4: 16px;
	--s-5: 24px;
	--s-6: 32px;
	--s-7: 48px;
	--s-8: 64px;
	--s-9: 96px;
	--container: 1320px;
	--container-narrow: 780px;
	--radius-sm: 8px;
	--radius: 16px;
	--radius-lg: 28px;
	--header-h: 88px;
	--section-gap: var(--s-6);
	--section-pad: clamp(1.35rem, 1rem + 0.8vw, 2rem);
	--t-fast: 140ms ease;
	--t-med: 240ms ease;
}

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

html {
	-webkit-text-size-adjust: 100%;
	line-height: 1.55;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: var(--t-base);
	color: var(--ink);
	overflow-x: clip;
	background:
		radial-gradient(circle at top left, rgba(185, 149, 78, 0.06), transparent 26%),
		linear-gradient(180deg, #ffffff 0%, var(--paper) 24%, #fbfcfe 100%);
	-webkit-font-smoothing: antialiased;
}

img, picture, video, svg {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: inherit;
	text-decoration-color: rgba(200, 58, 42, 0.35);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
	transition: color var(--t-fast), text-decoration-color var(--t-fast), opacity var(--t-fast);
}

a:hover {
	color: var(--signal);
	text-decoration-color: currentColor;
}

a:focus-visible,
button:focus-visible,
input:focus-visible {
	outline: 2px solid var(--signal);
	outline-offset: 2px;
}

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 var(--s-3);
	font-family: var(--font-serif);
	font-weight: 700;
	line-height: 1.06;
	letter-spacing: -0.02em;
}

h1 { font-size: var(--t-3xl); }
h2 { font-size: var(--t-2xl); }
h3 { font-size: var(--t-xl); }
h4 { font-size: var(--t-lg); }

p { margin: 0 0 var(--s-4); }
ul, ol { padding-left: 1.15em; }
figure { margin: 0; }
button, input, textarea, select { font: inherit; }
code, pre { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

blockquote {
	margin: var(--s-6) 0;
	padding-left: var(--s-5);
	border-left: 3px solid var(--signal);
	font-family: var(--font-serif);
	font-size: var(--t-lg);
	color: var(--ink);
}

figcaption {
	margin-top: var(--s-3);
	font-size: var(--t-sm);
	color: var(--ink-soft);
}

.screen-reader-text,
.u-sr {
	position: absolute !important;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
}

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 110;
	padding: var(--s-2) var(--s-4);
	background: var(--ink);
	color: #fff;
}

.skip-link:focus {
	left: var(--s-2);
	top: var(--s-2);
}

.container {
	width: min(100%, var(--container));
	margin: 0 auto;
	padding: 0 var(--s-4);
}

.main-content > .container {
	display: grid;
	gap: var(--section-gap);
}

.container--narrow { max-width: var(--container-narrow); }
.cluster { display: flex; flex-wrap: wrap; gap: var(--s-3); align-items: center; }
.main-content { padding: var(--s-6) 0 var(--s-8); min-height: 65vh; }

.section-label {
	margin: 0 0 var(--s-2);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--signal);
}

.section-title {
	max-width: 18ch;
	font-size: clamp(2rem, 1.1rem + 2vw, 3.1rem);
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 80;
	backdrop-filter: blur(22px);
	background: rgba(255, 255, 255, 0.9);
	border-bottom: 1px solid rgba(17, 21, 26, 0.08);
	transition: box-shadow var(--t-med), background var(--t-med), border-color var(--t-med);
}

.site-header--scrolled {
	box-shadow: var(--shadow-sm);
	background: rgba(255, 255, 255, 0.96);
	border-color: rgba(17, 21, 26, 0.12);
}

.site-header__topbar {
	background: rgba(255, 255, 255, 0.72);
	color: var(--ink-soft);
	font-size: var(--t-xs);
	border-bottom: 1px solid var(--line);
}

.site-header__topbar-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 38px;
	gap: var(--s-4);
}

.site-header__status,
.site-header__date {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.site-header__pulse {
	width: 10px;
	height: 10px;
	border-radius: 999px;
	background: var(--signal);
	box-shadow: 0 0 0 6px rgba(200, 58, 42, 0.18);
}

.site-header__inner {
	display: grid;
	grid-template-columns: minmax(0, 280px) minmax(0, 1fr) auto;
	align-items: center;
	gap: var(--s-5);
	min-height: var(--header-h);
}

.site-header__brand-lockup {
	display: grid;
	gap: 6px;
}

.site-header__brand {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	color: var(--ink);
}

.site-header__brand img {
	width: auto;
	max-height: 50px;
}

.site-header__tagline {
	margin: 0;
	font-size: var(--t-sm);
	color: var(--ink-soft);
	max-width: 28ch;
}

.site-nav ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--s-4);
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav a {
	display: inline-flex;
	align-items: center;
	padding: var(--s-3) 0;
	border-bottom: 2px solid transparent;
	font-family: var(--font-display);
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
	color: var(--ink);
}

.site-nav a:hover,
.site-nav .current-menu-item > a {
	color: var(--signal);
	border-bottom-color: currentColor;
}

.site-header__actions {
	display: inline-flex;
	align-items: center;
	gap: var(--s-3);
}

.search-toggle,
.nav-toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: 10px 14px;
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.55);
	color: var(--ink);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.search-toggle svg,
.nav-toggle svg {
	width: 18px;
	height: 18px;
}

.nav-toggle { display: none; }

.search-drawer {
	display: none;
	padding: var(--s-4) 0 var(--s-5);
	border-top: 1px solid var(--line);
	background: rgba(255, 255, 255, 0.98);
}

.search-drawer[data-open="true"] { display: block; }

.search-form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: var(--s-3);
	max-width: 760px;
	margin: 0 auto;
}

.search-form input[type="search"] {
	width: 100%;
	padding: 16px 18px;
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.88);
}

.search-form button {
	padding: 16px 22px;
	border: 0;
	border-radius: 999px;
	background: var(--ink);
	color: #fff;
	font-family: var(--font-display);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.breaking-strip {
	background: linear-gradient(90deg, #c83a2a 0%, #a52d20 100%);
	color: #fff;
	box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.16);
}

.breaking-strip__inner {
	display: flex;
	align-items: center;
	gap: var(--s-4);
	min-height: 48px;
}

.breaking-strip__kicker {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.16);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.breaking-strip__headline {
	flex: 1 1 auto;
	text-decoration: none;
	font-weight: 700;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.breaking-strip__headline:hover,
.breaking-strip__close:hover { color: #fff; }

.breaking-strip__close {
	padding: var(--s-1);
	border: 0;
	background: transparent;
	color: inherit;
}

.site-footer {
	margin-top: var(--s-9);
	padding: var(--s-8) 0 var(--s-5);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 249, 251, 0.98)),
		linear-gradient(120deg, rgba(185, 149, 78, 0.05), transparent 45%);
	color: var(--ink-soft);
	border-top: 1px solid var(--line);
}

.site-footer a {
	color: var(--ink);
	text-decoration-color: rgba(17, 21, 26, 0.18);
}

.site-footer__intro {
	display: grid;
	gap: var(--s-2);
	max-width: 56ch;
	margin-bottom: var(--s-6);
}

.site-footer__eyebrow {
	margin: 0;
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--signal);
}

.site-footer__headline {
	font-size: clamp(2rem, 1.1rem + 1vw, 3rem);
	color: var(--ink);
}

.site-footer__cols {
	display: grid;
	grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr));
	gap: var(--s-6);
	padding: var(--s-6) 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.site-footer h4 {
	margin-bottom: var(--s-3);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

.site-footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--s-3);
}

.site-footer__blurb {
	max-width: 34ch;
	color: var(--ink-soft);
}

.site-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--s-4);
	padding-top: var(--s-5);
	font-size: var(--t-xs);
	color: var(--ink-muted);
}

.site-footer__brand {
	display: inline-flex;
	align-items: center;
	gap: var(--s-3);
	font-family: var(--font-display);
	font-size: 1.1rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink);
}

.site-footer__brand-mark {
	width: 12px;
	height: 12px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--gold), var(--signal));
}

.front-signal,
.editors-pick,
.section-block,
.latest-feed,
.article,
.widget,
.not-found {
	background: rgba(255, 255, 255, 0.9);
	border: 1px solid rgba(17, 21, 26, 0.08);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}

.front-signal {
	padding: var(--section-pad);
	display: grid;
	gap: var(--section-gap);
}

.front-signal__banner .ad-slot { margin: 0; }

.lead-grid {
	display: grid;
	grid-template-columns: minmax(0, 2fr) minmax(300px, 0.95fr);
	gap: clamp(1.2rem, 1rem + 1vw, 2rem);
	align-items: stretch;
}

.lead-grid--single {
	grid-template-columns: minmax(0, 1fr);
}

.lead-grid__main {
	min-width: 0;
	display: flex;
}

.lead-grid__secondary {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--s-5);
}

.lead-grid__rail { min-width: 0; }

.lead-carousel {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: calc(var(--radius-lg) - 4px);
	overflow: hidden;
	background: #eef2f7;
	box-shadow: inset 0 0 0 1px rgba(17, 21, 26, 0.06);
}

.lead-carousel__viewport {
	position: relative;
	height: 100%;
}

.lead-carousel__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity 320ms ease;
}

.lead-carousel__slide.is-active {
	opacity: 1;
	pointer-events: auto;
}

.lead-carousel__media,
.lead-carousel__media img {
	width: 100%;
	height: 100%;
}

.lead-carousel__media {
	position: relative;
	display: block;
}

.lead-carousel__media img {
	object-fit: cover;
}

.lead-carousel__media::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(10, 16, 24, 0.08) 0%, rgba(10, 16, 24, 0.26) 38%, rgba(10, 16, 24, 0.8) 100%);
}

.lead-carousel__overlay {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	display: grid;
	align-content: end;
	gap: var(--s-2);
	padding: clamp(1.4rem, 1rem + 1vw, 2.35rem) clamp(1.1rem, 0.9rem + 0.8vw, 1.9rem) clamp(4rem, 3.4rem + 0.9vw, 4.7rem);
	color: #fff;
	z-index: 1;
}

.lead-carousel__overlay .card__tag {
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	backdrop-filter: blur(8px);
}

.lead-carousel__title {
	margin: 0;
	max-width: 14ch;
	font-size: clamp(2.3rem, 1.5rem + 2vw, 4.5rem);
	line-height: 0.98;
	overflow-wrap: break-word;
	text-wrap: balance;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.lead-carousel__title a {
	text-decoration: none;
	color: inherit;
	overflow-wrap: break-word;
	hyphens: auto;
}

.lead-carousel__dek {
	margin: 0;
	max-width: 54ch;
	font-size: clamp(1rem, 0.92rem + 0.3vw, 1.15rem);
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.9);
	overflow-wrap: break-word;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}

.lead-carousel__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.8);
}

.lead-carousel__control {
	position: absolute;
	top: 50%;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	margin-top: -26px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	color: #fff;
	backdrop-filter: blur(12px);
}

.lead-carousel__control span {
	font-size: 2rem;
	line-height: 1;
}

.lead-carousel__control--prev { left: var(--s-4); }
.lead-carousel__control--next { right: var(--s-4); }

.lead-carousel__numbers {
	position: absolute;
	left: var(--s-5);
	right: var(--s-5);
	bottom: var(--s-4);
	z-index: 2;
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	max-width: calc(100% - (var(--s-5) * 2));
}

.lead-carousel__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 40px;
	padding: 0 var(--s-3);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.92);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
}

.lead-carousel__number.is-active {
	background: #fff;
	color: var(--ink);
	border-color: #fff;
}

.quick-take {
	height: 100%;
	display: flex;
	flex-direction: column;
	padding: var(--s-5);
	border-radius: calc(var(--radius-lg) - 8px);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.96)),
		linear-gradient(120deg, rgba(200, 58, 42, 0.05), transparent 40%);
	color: var(--ink);
	border: 1px solid var(--line);
}

	.quick-take .section-label { color: var(--signal); }

.quick-take__head {
	display: grid;
	gap: var(--s-2);
}

.quick-take__title {
	margin: 0;
	font-size: clamp(1.55rem, 1rem + 1.2vw, 2.2rem);
	max-width: 12ch;
}

.quick-take__list {
	display: grid;
	gap: var(--s-4);
	margin-top: var(--s-5);
	flex: 1 1 auto;
	align-content: start;
}

.trend-band {
	padding: var(--section-pad);
	border-radius: calc(var(--radius-lg) - 8px);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.96)),
		linear-gradient(120deg, rgba(200, 58, 42, 0.04), transparent 36%);
	border: 1px solid var(--line);
}

.trend-band__header {
	display: flex;
	align-items: end;
	gap: var(--s-4);
	margin-bottom: var(--s-5);
}

.trend-band__title {
	margin: 0;
	font-size: clamp(1.55rem, 1rem + 0.8vw, 2rem);
}

.trend-band__list {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	grid-auto-flow: column;
	grid-auto-columns: minmax(220px, 1fr);
	gap: var(--s-4);
	list-style: none;
	margin: 0;
	padding: 0;
	overflow-x: auto;
	scrollbar-width: thin;
}

.trend-band__item {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	align-items: start;
	gap: var(--s-2);
	min-width: 0;
	padding: var(--s-3);
	border: 1px solid var(--line);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.74);
}

.trend-band__item:first-child {
	padding: var(--s-3);
	border: 1px solid var(--line);
}

.trend-band__number {
	flex: 0 0 auto;
	font-family: var(--font-display);
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1;
	color: var(--signal);
}

.trend-band__item a {
	text-decoration: none;
	font-weight: 700;
	line-height: 1.35;
	min-width: 0;
	overflow-wrap: break-word;
	hyphens: auto;
}

.home-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(290px, 320px);
	gap: var(--s-6);
	align-items: start;
}

.home-sections {
	display: grid;
	gap: var(--section-gap);
}

.rail,
.widget {
	padding: var(--section-pad);
}

.rail__head,
.widget__header {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: var(--s-4);
	margin-bottom: var(--s-5);
}

.rail__title,
.widget__title {
	margin: 0;
	font-size: clamp(1.5rem, 1rem + 1vw, 2.15rem);
}

.widget__title { font-size: 1.8rem; }

.rail__more {
	flex: 0 0 auto;
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-decoration: none;
	text-transform: uppercase;
	color: var(--signal);
}

.editors-pick {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 249, 252, 0.96)),
		linear-gradient(120deg, rgba(185, 149, 78, 0.05), transparent 42%);
	color: var(--ink);
}

.editors-pick .section-label { color: var(--signal); }

.editors-pick .card__dek { color: var(--ink-soft); }

.editors-pick .card__meta { color: var(--ink-muted); }

.editors-pick__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(0, 0.8fr);
	gap: var(--s-5);
	align-items: start;
}

.editors-pick__rest {
	display: grid;
	gap: var(--s-4);
	padding: var(--s-4);
	border-radius: var(--radius);
	background: var(--surface-alt);
	border: 1px solid var(--line);
}

.section-block__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr) minmax(240px, 0.8fr);
	gap: var(--s-5);
	align-items: stretch;
}

.section-block__layout--compact {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--s-4);
}

.section-block__lead,
.section-block__support,
.section-block__headlines {
	min-width: 0;
	display: grid;
	gap: var(--s-4);
}

.card--rail-grid {
	padding: var(--s-3);
	border: 1px solid var(--line);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.74);
}

.card--rail-grid .card__title {
	font-size: 1.22rem;
	line-height: 1.3;
}

.card--rail-grid .card__meta {
	margin-top: var(--s-2);
	font-size: 0.76rem;
}

.latest-feed__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--s-5);
}

.home-sidebar {
	display: grid;
	gap: var(--section-gap);
}

.widget--trending {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(249, 250, 252, 0.94)),
		linear-gradient(140deg, rgba(200, 58, 42, 0.05), transparent 38%);
}

.widget--trending ol {
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: trending;
}

.widget--trending li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--s-3);
	padding: var(--s-4) 0;
	border-top: 1px solid var(--line);
	counter-increment: trending;
}

.widget--trending li:first-child { border-top: 0; padding-top: 0; }

.widget--trending li::before {
	content: counter(trending);
	font-family: var(--font-display);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	color: var(--signal);
}

.widget--trending a {
	text-decoration: none;
	font-weight: 700;
	line-height: 1.38;
}

.widget--ad .ad-slot { margin: 0; }

.card {
	display: grid;
	gap: var(--s-3);
	align-content: start;
}

.card__media {
	position: relative;
	overflow: hidden;
	border-radius: calc(var(--radius-lg) - 10px);
	background: var(--paper-strong);
	aspect-ratio: 16 / 9;
}

.card__media::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 45%, rgba(17, 21, 26, 0.12) 100%);
	pointer-events: none;
}

.card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--t-med);
}

.card:hover .card__media img { transform: scale(1.03); }

.card__tag {
	display: inline-flex;
	align-items: center;
	justify-self: start;
	padding: 5px 10px;
	border-radius: 999px;
	background: var(--signal-soft);
	color: var(--signal-strong);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-decoration: none;
	text-transform: uppercase;
}

.card__title {
	margin: 0;
	font-size: clamp(1.35rem, 1rem + 0.8vw, 2rem);
	line-height: 1.08;
	overflow-wrap: break-word;
	hyphens: auto;
}

.card__title a {
	text-decoration: none;
	color: inherit;
	overflow-wrap: break-word;
}

.card__dek {
	margin: 0;
	font-size: 0.98rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

.card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	font-size: var(--t-xs);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

.card--flagship .card__media { aspect-ratio: 16 / 9; }
.card--flagship .card__title { font-size: clamp(2.45rem, 1.4rem + 2vw, 4rem); }
.card--flagship .card__dek { max-width: 58ch; font-size: 1.06rem; }

.card--featured.card--section-lead .card__title,
.card--featured.card--archive-lead .card__title,
.card--featured.card--editors-lead .card__title {
	font-size: clamp(2rem, 1.15rem + 1.2vw, 2.8rem);
}

.card--story .card__title { font-size: clamp(1.35rem, 1rem + 0.6vw, 1.85rem); }
.card--story .card__media { aspect-ratio: 16 / 9; }

.card--compact {
	grid-template-columns: auto 1fr;
	gap: var(--s-3);
	align-items: start;
}

.card--compact .card__media {
	width: 92px;
	aspect-ratio: 1;
	border-radius: var(--radius);
}

.card--compact .card__title {
	font-size: 1.06rem;
	line-height: 1.24;
}

.card--headline {
	grid-template-columns: 1fr;
	padding-bottom: var(--s-4);
	border-bottom: 1px solid var(--line);
}

.card--headline:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.quick-take .card--headline .card__title,
.editors-pick .card--headline .card__title { font-size: 1.15rem; }

.quick-take .card__meta,
.editors-pick .card__meta { color: var(--ink-muted); }

.breadcrumbs {
	margin: var(--s-3) 0 var(--s-5);
	font-size: var(--t-xs);
	color: var(--ink-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	list-style: none;
	margin: 0;
	padding: 0;
}

.breadcrumbs li {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
}

.breadcrumbs li + li::before {
	content: '/';
	color: var(--ink-muted);
}

.breadcrumbs a {
	text-decoration: none;
	color: inherit;
}

.archive-header {
	padding: clamp(1.5rem, 1rem + 1vw, 2.3rem);
}

.archive-header__label {
	margin-bottom: var(--s-2);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--signal);
}

.archive-header__title {
	font-size: clamp(2.3rem, 1.2rem + 1.6vw, 3.6rem);
}

.archive-header__desc {
	max-width: 65ch;
	color: var(--ink-soft);
	font-size: var(--t-md);
}

.discovery-flow { display: grid; gap: var(--s-5); }
.archive-lead { margin-bottom: var(--s-2); }

.article {
	max-width: calc(var(--container-narrow) + 180px);
	margin: 0 auto;
	padding: clamp(1.4rem, 1rem + 1vw, 2.4rem);
}

.article-header {
	display: grid;
	gap: var(--section-gap);
}

.article__kicker {
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--signal);
}

.article__kicker a {
	text-decoration: none;
	color: inherit;
}

.article__title {
	font-size: clamp(2rem, 1.35rem + 1.2vw, 3.2rem);
	max-width: none;
	overflow-wrap: normal;
	word-break: normal;
	hyphens: manual;
}

.article__dek {
	max-width: none;
	font-family: var(--font-serif);
	font-size: clamp(1rem, 0.94rem + 0.28vw, 1.2rem);
	line-height: 1.5;
	color: var(--ink-soft);
	overflow-wrap: normal;
	word-break: normal;
	hyphens: manual;
}

.article__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	padding: var(--s-3);
	border: 1px solid var(--line);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.74);
	font-size: var(--t-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: none;
	color: var(--ink-muted);
}

.article__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	border: 1px solid var(--line);
	border-radius: 999px;
	background: var(--surface-alt);
	color: var(--ink-soft);
}

.article__meta-item .article__date time,
.article__meta-item time {
	color: var(--ink-muted);
}

.article__meta-item .article__byline a,
.article__byline a {
	font-weight: 700;
	text-decoration: none;
	color: var(--ink);
}

.article__hero {
	margin-bottom: var(--s-6);
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: 22px;
	background: var(--paper-strong);
}

.article__hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.article__body {
	max-width: var(--container-narrow);
	margin: 0 auto;
	font-family: var(--font-serif);
	font-size: clamp(1rem, 0.96rem + 0.14vw, 1.1rem);
	line-height: 1.75;
}

.article__body p,
.article__body ul,
.article__body ol {
	margin-bottom: var(--s-5);
}

.article__body h2 {
	margin-top: var(--s-7);
	font-size: clamp(1.5rem, 1.1rem + 0.45vw, 1.9rem);
}

.article__body h3 {
	margin-top: var(--s-6);
	font-size: clamp(1.25rem, 1rem + 0.35vw, 1.55rem);
}

.article__body a { text-decoration-color: rgba(200, 58, 42, 0.45); }

.article__body .article__pullquote,
.article__body .wp-block-pullquote {
	margin: var(--s-7) 0;
	padding: var(--s-6);
	border: 0;
	border-radius: var(--radius);
	background: linear-gradient(180deg, rgba(244, 239, 230, 0.9), rgba(237, 229, 216, 0.8));
	font-family: var(--font-serif);
	font-size: clamp(1.45rem, 1rem + 1vw, 2rem);
	font-weight: 700;
	line-height: 1.35;
	text-align: center;
}

.article__body .article__pullquote cite,
.article__body .wp-block-pullquote cite {
	display: block;
	margin-top: var(--s-3);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-style: normal;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

.article__corrections,
.article__source {
	max-width: var(--container-narrow);
	margin: 0 auto var(--s-5);
	padding: var(--s-4) var(--s-5);
	border-radius: var(--radius);
	background: linear-gradient(180deg, rgba(249, 244, 235, 0.92), rgba(244, 239, 230, 0.92));
	border: 1px solid rgba(17, 21, 26, 0.08);
}

.article__corrections h2 {
	margin-bottom: var(--s-2);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.article__corrections ul {
	margin: 0;
	padding-left: 1.1em;
	color: var(--ink-soft);
}

.article__source {
	font-size: var(--t-sm);
	color: var(--ink-soft);
}

.article__source a {
	font-weight: 700;
	color: var(--ink);
}

.article__footer {
	max-width: var(--container-narrow);
	margin: var(--section-gap) auto 0;
	display: grid;
	gap: var(--section-gap);
}

.share {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--s-2);
	padding: var(--s-4);
	border-radius: var(--radius);
	background: linear-gradient(180deg, rgba(249, 244, 235, 0.95), rgba(244, 239, 230, 0.82));
	border: 1px solid rgba(17, 21, 26, 0.08);
}

.share__label {
	margin-right: var(--s-2);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-muted);
}

.share__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.7);
	color: var(--ink);
	text-decoration: none;
}

.share__btn:hover {
	background: var(--ink);
	color: #fff;
	border-color: var(--ink);
}

.share__btn svg {
	width: 16px;
	height: 16px;
}

.author-bio,
.related {
	margin-top: var(--s-6);
	padding: var(--s-5);
	border-radius: var(--radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(249, 244, 235, 0.9));
	border: 1px solid rgba(17, 21, 26, 0.08);
}

.author-bio {
	display: flex;
	gap: var(--s-4);
	align-items: flex-start;
}

.author-bio__avatar {
	flex: 0 0 auto;
	width: 68px;
	height: 68px;
	border-radius: 18px;
	background: linear-gradient(135deg, var(--signal), #e4673f);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	font-size: 1.6rem;
	font-weight: 700;
}

.author-bio__name {
	font-size: 1.7rem;
	margin-bottom: var(--s-2);
}

.author-bio__name a {
	text-decoration: none;
	color: var(--ink);
}

.author-bio__text {
	color: var(--ink-soft);
	font-size: var(--t-sm);
}

.author-bio__link {
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.14em;
	text-decoration: none;
	text-transform: uppercase;
	color: var(--signal);
}

.related__title {
	margin-bottom: var(--s-5);
	font-size: clamp(1.7rem, 1.2rem + 0.5vw, 2.2rem);
}

.related__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--s-4);
}

.pagination {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--s-2);
	margin: var(--s-6) 0 0;
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 var(--s-3);
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.68);
	color: var(--ink);
	font-family: var(--font-display);
	font-size: var(--t-xs);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

.pagination .page-numbers.current,
.pagination .page-numbers:hover {
	background: var(--ink);
	color: #fff;
	border-color: var(--ink);
}

.pagination .dots {
	border: 0;
	background: transparent;
}

.empty {
	padding: var(--s-6);
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.75);
	color: var(--ink-soft);
	text-align: center;
}

.not-found {
	padding: clamp(2rem, 1.4rem + 1.5vw, 3.4rem);
	text-align: center;
}

.not-found h1,
.not-found h2 {
	max-width: 12ch;
	margin: 0 auto var(--s-3);
	font-size: clamp(2.3rem, 1.5rem + 1.7vw, 4rem);
}

.not-found p {
	max-width: 54ch;
	margin-left: auto;
	margin-right: auto;
	color: var(--ink-soft);
}

.not-found__actions {
	margin-top: var(--s-5);
}

.ad-slot {
	margin: var(--s-5) 0;
	text-align: center;
}

.ad-slot--sidebar-sticky {
	position: sticky;
	top: calc(var(--header-h) + var(--s-5));
}

.u-hide-desktop { display: none; }

@media (max-width: 1100px) {
	.lead-grid,
	.home-layout,
	.section-block__layout,
	.editors-pick__grid {
		grid-template-columns: 1fr;
	}

	.lead-grid__secondary,
	.latest-feed__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.section-block__layout--compact {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.site-header__inner {
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.site-nav {
		grid-column: 1 / -1;
		order: 3;
	}
}

@media (max-width: 860px) {
	.site-header__topbar-inner,
	.rail__head,
	.widget__header,
	.author-bio,
	.site-footer__bottom {
		flex-direction: column;
		align-items: flex-start;
	}

	.site-header__inner {
		grid-template-columns: minmax(0, 1fr) auto;
		min-height: 74px;
	}

	.site-nav {
		display: none;
		padding: 0 0 var(--s-5);
	}

	.site-nav[data-open="true"] { display: block; }

	.site-nav ul {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
	}

	.site-nav li { width: 100%; }

	.site-nav a {
		width: 100%;
		padding: var(--s-3) 0;
		border-bottom: 1px solid var(--line);
	}

	.nav-toggle { display: inline-flex; }

	.search-toggle span,
	.nav-toggle span { display: none; }

	.lead-grid__secondary,
	.latest-feed__grid,
	.related__grid {
		grid-template-columns: 1fr;
	}

	.section-block__layout--compact {
		grid-template-columns: 1fr;
	}

	.lead-carousel__control {
		width: 46px;
		height: 46px;
		margin-top: -23px;
	}

	.lead-carousel__overlay {
		padding-left: calc(var(--s-4) + 34px);
		padding-right: calc(var(--s-4) + 34px);
	}

	.site-footer__cols {
		grid-template-columns: 1fr;
	}

	.article {
		padding: var(--s-5);
	}

	.article__title { max-width: none; }
}

@media (max-width: 560px) {
	.main-content { padding-top: var(--s-5); }
	.container { padding: 0 var(--s-3); }
	.site-header__date,
	.site-header__tagline,
	.breaking-strip__kicker { display: none; }
	.search-form { grid-template-columns: 1fr; }
	.share { gap: var(--s-3); }
	.lead-carousel__overlay {
		padding: var(--s-4) var(--s-4) 4.4rem;
	}
	.lead-carousel__title {
		font-size: clamp(1.7rem, 1.2rem + 1.8vw, 2.4rem);
		max-width: none;
		-webkit-line-clamp: 3;
	}
	.lead-carousel__dek {
		max-width: 95%;
		font-size: 0.92rem;
		-webkit-line-clamp: 1;
		color: rgba(255, 255, 255, 0.86);
	}
	.lead-carousel__meta {
		display: none;
	}
	.lead-carousel__numbers {
		left: var(--s-4);
		right: var(--s-4);
		bottom: var(--s-3);
		overflow-x: auto;
		padding-bottom: 2px;
		flex-wrap: nowrap;
	}
	.lead-carousel__number {
		min-width: 40px;
		height: 36px;
	}
	.lead-carousel__control--prev { left: var(--s-3); }
	.lead-carousel__control--next { right: var(--s-3); }
	.trend-band__header {
		flex-direction: column;
		align-items: flex-start;
	}
	.trend-band__item {
		padding: var(--s-3);
	}
	.trend-band__item:first-child {
		padding: var(--s-3);
	}
	.u-hide-mobile { display: none; }
	.u-hide-desktop { display: block; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { transition: none !important; animation: none !important; }
}

@media print {
	.site-header,
	.site-footer,
	.ad-slot,
	.share,
	.related,
	aside,
	.breaking-strip {
		display: none !important;
	}

	body {
		background: #fff;
		color: #000;
	}
}
