/* ===========================================================================
   Vanflip — design system
   Reference: NYT typographic discipline + Buzzfeed structural moves.
   The visual joke: paper-of-record gravitas applied to absurd content.
   =========================================================================== */

/* --- Tokens ---------------------------------------------------------------- */
:root {
	--ink:       #1a1a1a;   /* primary text */
	--ink-soft:  #2c2c2c;   /* body text */
	--paper:     #fafaf7;   /* page background */
	--paper-2:   #f3f1ea;   /* section bands, alt rows */
	--rule:      #d4d2cc;   /* hairlines, borders */
	--muted:     #6b6b6b;   /* meta, captions, secondary */
	--flag:      #c8102e;   /* sole accent — kickers, breaking, link hover */
	--flag-ink:  #fff;

	--font-display: "Fraunces", Georgia, "Times New Roman", serif;
	--font-body:    "Public Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

	--container:   min(1280px, 100% - 2rem);
	--reading:     min(680px, 100% - 2rem);

	--space-1: .25rem;
	--space-2: .5rem;
	--space-3: .75rem;
	--space-4: 1rem;
	--space-5: 1.5rem;
	--space-6: 2rem;
	--space-7: 3rem;
	--space-8: 4.5rem;
	--space-9: 6rem;
}

/* --- Reset (minimal) ------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body {
	margin: 0;
	background: var(--paper);
	color: var(--ink-soft);
	font-family: var(--font-body);
	font-size: 1.0625rem;
	line-height: 1.55;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-optical-sizing: auto;
}
img, video, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover, a:focus-visible { color: var(--flag); }
button { font: inherit; cursor: pointer; }

/* --- Type ------------------------------------------------------------------ */
h1, h2, h3, h4 {
	font-family: var(--font-display);
	color: var(--ink);
	font-weight: 600;
	line-height: 1.08;
	margin: 0 0 var(--space-4);
	font-variation-settings: "opsz" 144, "SOFT" 30;
	text-wrap: balance;
}
h1 { font-size: clamp(2.25rem, 5vw, 3.75rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
h3 { font-size: 1.375rem; }
h4 { font-size: 1.125rem; }
p  { margin: 0 0 var(--space-4); }

.kicker, .label {
	font-family: var(--font-body);
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--flag);
	display: inline-block;
	margin: 0 0 var(--space-3);
}
.label--muted { color: var(--muted); }

/* --- Accessibility --------------------------------------------------------- */
.skip-link {
	position: absolute; top: -100px; left: 1rem;
	background: var(--ink); color: var(--paper);
	padding: .75rem 1rem; z-index: 100;
	text-transform: uppercase; font-size: .75rem; letter-spacing: .08em;
}
.skip-link:focus { top: 1rem; color: var(--paper); }
.screen-reader-text {
	border: 0; clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%); height: 1px; width: 1px;
	margin: -1px; overflow: hidden; padding: 0; position: absolute;
}

/* --- Header ---------------------------------------------------------------- */
.site-header {
	background: var(--paper);
	border-bottom: 1px solid var(--rule);
	position: sticky; top: 0; z-index: 50;
}
.site-header__inner {
	width: var(--container); margin: 0 auto;
	display: flex; align-items: center; justify-content: space-between;
	gap: var(--space-5); padding: var(--space-4) 0;
}
.site-header__brand { display: flex; align-items: baseline; gap: var(--space-3); flex-shrink: 0; }
.site-header__brand:hover { color: var(--ink); }
.site-header__logo {
	display: block;
	height: clamp(56px, 7vw, 72px);
	width: auto;
}
.site-header__tagline { display: none; }

.site-nav__list {
	list-style: none; margin: 0; padding: 0;
	display: flex; gap: var(--space-5); flex-wrap: wrap;
	font-size: .8125rem; font-weight: 600;
	letter-spacing: .04em; text-transform: uppercase;
}
.site-nav__list a { color: var(--ink); }
.site-nav__list .current-menu-item > a { color: var(--flag); }
.site-nav__list .sub-menu {
	display: none; position: absolute; background: var(--paper);
	border: 1px solid var(--rule); padding: var(--space-3);
	min-width: 200px; list-style: none; margin: 0;
}
.site-nav__list li { position: relative; }
.site-nav__list li:hover > .sub-menu,
.site-nav__list li:focus-within > .sub-menu { display: block; }

@media (max-width: 800px) {
	.site-header__inner { flex-direction: column; align-items: flex-start; }
	.site-nav__list { gap: var(--space-3); font-size: .75rem; }
}

/* --- Main / layout primitives --------------------------------------------- */
.site-main {
	width: var(--container); margin: 0 auto;
	padding: var(--space-6) 0 var(--space-9);
}
.layout-feed { /* default single-column feed wrapper */ }
.layout-with-sidebar {
	display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
	gap: var(--space-7);
}
@media (max-width: 900px) {
	.layout-with-sidebar { grid-template-columns: 1fr; }
}

/* --- Hero lede ------------------------------------------------------------- */
.hero {
	display: grid; grid-template-columns: 1fr; gap: var(--space-5);
	padding-bottom: var(--space-7); margin-bottom: var(--space-7);
	border-bottom: 1px solid var(--rule);
}
@media (min-width: 900px) {
	.hero { grid-template-columns: 7fr 5fr; gap: var(--space-7); align-items: center; }
}
.hero__media img { width: 100%; height: auto; aspect-ratio: 16 / 10; object-fit: cover; }
.hero__title { font-size: clamp(1.625rem, 2.6vw, 2.375rem); margin: var(--space-3) 0 var(--space-4); line-height: 1.1; letter-spacing: -0.01em; }
.hero__title a { color: var(--ink); }
.hero__title a:hover { color: var(--flag); }
.hero__dek { font-size: 1.1875rem; line-height: 1.45; color: var(--muted); margin: 0 0 var(--space-4); }

/* --- Top-stories 3-up ----------------------------------------------------- */
.topgrid {
	list-style: none; padding: 0; margin: 0 0 var(--space-7);
	display: grid; gap: var(--space-7) var(--space-6);
	grid-template-columns: 1fr;
	padding-bottom: var(--space-7); border-bottom: 1px solid var(--rule);
}
@media (min-width: 700px)  { .topgrid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .topgrid { grid-template-columns: 1fr 1fr 1fr; } }

/* --- Feed (image-right rows) ---------------------------------------------- */
.feed { list-style: none; padding: 0; margin: 0; }
.feed__row {
	display: grid; grid-template-columns: 1fr; gap: var(--space-4);
	padding: var(--space-6) 0; border-bottom: 1px solid var(--rule);
}
.feed__row:first-child { padding-top: 0; }
@media (min-width: 600px) {
	.feed__row { grid-template-columns: 1fr 220px; align-items: start; gap: var(--space-5); }
}
.feed__media img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.feed__title { font-family: var(--font-display); font-size: 1.5rem; line-height: 1.15; font-weight: 600; margin: var(--space-2) 0 var(--space-3); }
.feed__title a { color: var(--ink); }
.feed__title a:hover { color: var(--flag); }
.feed__dek { font-size: .9375rem; color: var(--muted); margin: 0 0 var(--space-3); }
.feed-section { min-width: 0; }

/* --- Card ------------------------------------------------------------------ */
.card { display: flex; flex-direction: column; gap: var(--space-3); }
.card__media { display: block; overflow: hidden; margin-bottom: var(--space-2); }
.card__media img {
	width: 100%; height: auto; aspect-ratio: 16 / 10; object-fit: cover;
	transition: transform .35s ease;
}
.card__media:hover img { transform: scale(1.015); }
.card__title { font-size: 1.5rem; line-height: 1.12; margin: 0 0 var(--space-2); }
.card__title a { color: var(--ink); }
.card__title a:hover { color: var(--flag); }
.card__dek { font-size: .9375rem; color: var(--muted); margin: 0; }
.card .kicker { margin-bottom: var(--space-2); }
.card--lg .card__title { font-size: 1.75rem; }

/* --- Trending rail (NYT most-popular pattern) ----------------------------- */
.trending {
	border-top: 3px solid var(--ink);
	padding-top: var(--space-4);
}
.trending__title {
	font-family: var(--font-body);
	font-size: .75rem; font-weight: 700; letter-spacing: .12em;
	text-transform: uppercase; color: var(--ink);
	margin: 0 0 var(--space-4);
}
.trending__list { list-style: none; padding: 0; margin: 0; counter-reset: trend; }
.trending__item {
	counter-increment: trend;
	display: grid; grid-template-columns: 2.5rem 1fr;
	gap: var(--space-3); align-items: baseline;
	padding: var(--space-4) 0; border-bottom: 1px solid var(--rule);
}
.trending__item:last-child { border-bottom: 0; }
.trending__item::before {
	content: counter(trend, decimal-leading-zero);
	font-family: var(--font-display);
	font-size: 1.5rem; font-weight: 600; color: var(--muted);
	line-height: 1;
}
.trending__item a { font-family: var(--font-display); font-weight: 600; line-height: 1.2; color: var(--ink); font-size: 1rem; }
.trending__item a:hover { color: var(--flag); }

/* --- Single article -------------------------------------------------------- */
.post { width: 100%; }
.post__header {
	width: var(--reading); margin: 0 auto var(--space-5);
	padding-top: var(--space-5);
}
.post__title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	letter-spacing: -0.005em;
	margin: var(--space-2) 0 var(--space-4);
	text-wrap: balance;
}
.post__dek {
	font-size: 1.25rem; line-height: 1.45; color: var(--muted);
	margin: 0 0 var(--space-5);
	font-family: var(--font-body); font-weight: 400;
}
.post__hero {
	margin: 0 0 var(--space-6); width: 100%;
}
.post__hero img { width: 100%; height: auto; }
.post__hero figcaption {
	width: var(--reading); margin: var(--space-2) auto 0;
	font-size: .8125rem; color: var(--muted);
}
.post__body {
	width: var(--reading); margin: 0 auto;
	font-size: 1.125rem; line-height: 1.65; color: var(--ink-soft);
}
.post__body p { margin: 0 0 var(--space-5); }
.post__body > p:first-of-type::first-letter {
	font-family: var(--font-display);
	font-weight: 700;
	float: left;
	font-size: 4.5rem;
	line-height: .85;
	padding: .35rem .5rem 0 0;
	color: var(--ink);
}
.post__body h2 { font-size: 1.625rem; margin-top: var(--space-7); }
.post__body h3 { font-size: 1.25rem; margin-top: var(--space-6); }
.post__body a { color: var(--flag); border-bottom: 1px solid currentColor; }
.post__body a:hover { background: var(--paper-2); }
.post__body blockquote {
	border-left: 3px solid var(--flag);
	margin: var(--space-6) 0;
	padding: var(--space-2) var(--space-5);
	font-family: var(--font-display);
	font-size: 1.5rem; line-height: 1.3; color: var(--ink);
}
.post__body figure { margin: var(--space-6) 0; }
.post__body img { width: 100%; height: auto; }
.post__body figcaption { font-size: .8125rem; color: var(--muted); margin-top: var(--space-2); }
.story-nav {
	width: var(--reading);
	margin: var(--space-7) auto 0;
	border-top: 3px solid var(--ink);
	border-bottom: 1px solid var(--rule);
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-5);
}
.story-nav__link {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding: var(--space-4) 0;
	color: var(--ink);
	min-width: 0;
}
.story-nav__link--next {
	text-align: right;
}
.story-nav__link--next:only-child { grid-column: 2; }
.story-nav__label {
	font-family: var(--font-body);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--muted);
}
.story-nav__title {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 600;
	line-height: 1.18;
	color: var(--ink);
}
.story-nav__link:hover .story-nav__title,
.story-nav__link:focus-visible .story-nav__title { color: var(--flag); }

.related-stories {
	width: var(--container);
	margin: var(--space-8) auto 0;
	padding-top: var(--space-4);
	border-top: 3px solid var(--ink);
}
.related-stories__title {
	font-family: var(--font-body);
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	margin: 0 0 var(--space-5);
}
.related-stories__grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-6);
}
.related-stories .card__title {
	font-size: 1.25rem;
	line-height: 1.15;
}

@media (max-width: 760px) {
	.story-nav,
	.related-stories__grid { grid-template-columns: 1fr; }
	.story-nav__link--next {
		text-align: left;
		border-top: 1px solid var(--rule);
	}
	.story-nav__link--next:only-child {
		grid-column: auto;
		border-top: 0;
	}
}

/* Post meta (byline + date) */
.post-meta {
	font-size: .8125rem; color: var(--muted);
	display: flex; align-items: center; gap: var(--space-2);
	letter-spacing: .02em;
}
.post-meta__sep { opacity: .5; }

/* --- Page (static) --------------------------------------------------------- */
.page { width: var(--reading); margin: 0 auto; }
.page__title { font-size: clamp(2rem, 4vw, 3rem); margin-top: var(--space-5); }
.page__body { font-size: 1.125rem; line-height: 1.65; }

/* --- Archive --------------------------------------------------------------- */
.archive__header {
	width: var(--container); margin: 0 auto var(--space-7);
	padding-top: var(--space-5); border-bottom: 1px solid var(--rule);
	padding-bottom: var(--space-4);
}
.archive__kicker {
	font-size: .75rem; font-weight: 700; letter-spacing: .12em;
	text-transform: uppercase; color: var(--flag); margin: 0 0 var(--space-2);
}
.archive__title {
	font-size: clamp(2rem, 4vw, 3rem); margin: 0;
}
.archive__description { color: var(--muted); margin: var(--space-3) 0 0; max-width: 60ch; }

.post-feed { list-style: none; padding: 0; margin: 0; }
.post-feed__item {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
	padding: var(--space-6) 0;
	border-bottom: 1px solid var(--rule);
}
@media (min-width: 700px) {
	.post-feed__item { grid-template-columns: 1fr 280px; align-items: center; }
	.post-feed__item .card__media { order: 2; }
}

/* --- Sidebar --------------------------------------------------------------- */
.site-sidebar { font-size: .9375rem; }
.site-sidebar .widget { margin-bottom: var(--space-7); }
.widget__title {
	font-family: var(--font-body);
	font-size: .75rem; font-weight: 700; letter-spacing: .12em;
	text-transform: uppercase;
	border-top: 3px solid var(--ink);
	padding-top: var(--space-3);
	margin: 0 0 var(--space-4);
}
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget li { padding: var(--space-3) 0; border-bottom: 1px solid var(--rule); font-family: var(--font-display); font-weight: 600; line-height: 1.25; }
.widget li:last-child { border-bottom: 0; }

/* WordPress Popular Posts plugin compat (existing widget) */
.wpp-list { list-style: none; padding: 0; margin: 0; counter-reset: wpp; }
.wpp-list > li {
	counter-increment: wpp;
	display: grid; grid-template-columns: 2.5rem 1fr; gap: var(--space-3);
	padding: var(--space-3) 0; border-bottom: 1px solid var(--rule);
	font-family: var(--font-display); font-weight: 600;
}
.wpp-list > li::before {
	content: counter(wpp, decimal-leading-zero);
	font-family: var(--font-display);
	font-size: 1.25rem; color: var(--muted);
}

/* --- Search form ----------------------------------------------------------- */
.search-form {
	display: flex; gap: 0; max-width: 480px;
	border: 1px solid var(--ink);
}
.search-form__input {
	flex: 1; border: 0; padding: var(--space-3) var(--space-4);
	font: inherit; background: var(--paper);
}
.search-form__input:focus { outline: 2px solid var(--flag); outline-offset: -2px; }
.search-form__submit {
	background: var(--ink); color: var(--paper); border: 0;
	padding: var(--space-3) var(--space-5);
	font-family: var(--font-body); font-size: .75rem; font-weight: 700;
	letter-spacing: .08em; text-transform: uppercase;
}
.search-form__submit:hover { background: var(--flag); }

/* --- 404 ------------------------------------------------------------------- */
.not-found {
	width: var(--reading); margin: 0 auto;
	padding: var(--space-8) 0; text-align: center;
}
.not-found__title {
	font-size: clamp(5rem, 15vw, 10rem); margin: 0 0 var(--space-3);
	color: var(--flag); line-height: 1;
}
.not-found__lede { font-size: 1.25rem; color: var(--muted); margin: 0 0 var(--space-6); }
.not-found .search-form { margin: 0 auto; }

/* --- Comments -------------------------------------------------------------- */
.comments { width: var(--reading); margin: var(--space-7) auto 0; }
.comments__title {
	font-family: var(--font-body); font-size: .75rem; font-weight: 700;
	letter-spacing: .12em; text-transform: uppercase;
	border-top: 3px solid var(--ink); padding-top: var(--space-3); margin: 0 0 var(--space-5);
}
.comments__list { list-style: none; padding: 0; margin: 0; }
.comment-body { padding: var(--space-4) 0; border-bottom: 1px solid var(--rule); }
.comment-author { font-family: var(--font-display); font-weight: 600; }
.comment-meta { font-size: .8125rem; color: var(--muted); margin: var(--space-1) 0 var(--space-3); }
.comment-form label { display: block; font-size: .8125rem; text-transform: uppercase; letter-spacing: .08em; margin: var(--space-3) 0 var(--space-1); color: var(--muted); }
.comment-form input[type=text],
.comment-form input[type=email],
.comment-form input[type=url],
.comment-form textarea {
	width: 100%; border: 1px solid var(--rule); padding: var(--space-3); font: inherit; background: var(--paper);
}
.comment-form .submit {
	background: var(--ink); color: var(--paper); border: 0;
	padding: var(--space-3) var(--space-5);
	font-family: var(--font-body); font-size: .75rem; font-weight: 700;
	letter-spacing: .08em; text-transform: uppercase; cursor: pointer;
}
.comment-form .submit:hover { background: var(--flag); }

/* --- Pagination ------------------------------------------------------------ */
.pagination, .nav-links {
	display: flex; gap: var(--space-2); justify-content: center;
	margin: var(--space-8) 0 0;
	font-family: var(--font-body); font-size: .8125rem; font-weight: 700;
	letter-spacing: .08em; text-transform: uppercase;
}
.pagination a, .pagination span,
.nav-links a, .nav-links span {
	padding: var(--space-3) var(--space-4); border: 1px solid var(--rule);
	color: var(--ink);
}
.pagination .current, .nav-links .current { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* --- Footer ---------------------------------------------------------------- */
.site-footer {
	background: var(--ink); color: var(--paper);
	margin-top: var(--space-9); padding: var(--space-8) 0 var(--space-6);
}
.site-footer__inner {
	width: var(--container); margin: 0 auto;
	display: grid; grid-template-columns: 2fr 3fr; gap: var(--space-7);
}
@media (max-width: 700px) { .site-footer__inner { grid-template-columns: 1fr; } }
.site-footer__brand-link { display: inline-block; }
.site-footer__logo { display: block; height: 64px; width: auto; }
.site-footer__about { color: rgba(255,255,255,.7); margin-top: var(--space-3); max-width: 36ch; }
.site-footer__list {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5);
	font-size: .8125rem; text-transform: uppercase; letter-spacing: .08em;
}
.site-footer__list a { color: rgba(255,255,255,.85); }
.site-footer__list a:hover { color: var(--flag); }
.site-footer__legal {
	grid-column: 1 / -1; margin-top: var(--space-7);
	padding-top: var(--space-5); border-top: 1px solid rgba(255,255,255,.15);
	font-size: .8125rem; color: rgba(255,255,255,.6);
}

/* --- Ad slots -------------------------------------------------------------- */
.ad-slot {
	margin: var(--space-6) auto;
	width: var(--reading);
	min-height: 90px;
	display: flex; align-items: center; justify-content: center;
}
.ad-slot:empty { display: none; }
.ad-slot--full { width: var(--container); max-width: var(--container); }
.ad-slot ins { display: block; width: 100%; }

/* --- Empty state ----------------------------------------------------------- */
.empty-state {
	text-align: center; padding: var(--space-8) 0;
	font-family: var(--font-display); font-size: 1.5rem; color: var(--muted);
}

/* --- Print ----------------------------------------------------------------- */
@media print {
	.site-header, .site-footer, .site-sidebar, .ad-slot, .comments { display: none; }
	body { background: white; color: black; }
	.post__body { width: 100%; }
}

/* --- Reduced motion -------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation: none !important; transition: none !important; }
	.card__media:hover img { transform: none; }
}
