/* ============================================================
   Newsroom — minimalist news theme for Bludit
   ============================================================ */

:root {
	--color-bg:         #ffffff;
	--color-surface:    #ffffff;
	--color-text:       #141414;
	--color-muted:      #5a5a5a;
	--color-line:       #e6e6e6;
	--color-line-soft:  #f1f1f1;
	--color-accent:     #bb1919;   /* BBC-ish red */
	--color-accent-2:   #222222;
	--color-link:       #141414;
	--color-link-hover: #bb1919;

	--font-serif: "Playfair Display", "Times New Roman", Georgia, serif;
	--font-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

	--radius: 0px;             /* flat, newsprint */
	--shadow-sm: 0 1px 0 var(--color-line);
	--container-max: 1180px;
}

/* ---------- Reset / Base ---------- */

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

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

a {
	color: var(--color-link);
	text-decoration: none;
	transition: color .15s ease;
}
a:hover, a:focus { color: var(--color-link-hover); }

h1, h2, h3, h4 {
	font-family: var(--font-serif);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.01em;
	margin: 0 0 .5rem;
	color: var(--color-text);
}

p { margin: 0 0 1rem; }

.container {
	width: 100%;
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 1.25rem;
}

/* ---------- Masthead ---------- */

.masthead {
	border-bottom: 1px solid var(--color-line);
	background: var(--color-bg);
}
.masthead__inner {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 1rem;
	padding-top: 1.25rem;
	padding-bottom: 1rem;
}
.masthead__date {
	font-size: .8rem;
	color: var(--color-muted);
	text-transform: uppercase;
	letter-spacing: .08em;
}
.masthead__brand {
	text-align: center;
	color: var(--color-text);
}
.masthead__brand:hover { color: var(--color-text); }
.masthead__title {
	font-family: var(--font-serif);
	font-size: clamp(1.6rem, 3.6vw, 2.4rem);
	font-weight: 900;
	letter-spacing: -0.02em;
}
.masthead__logo { max-height: 52px; margin: 0 auto; }
.masthead__social {
	display: flex;
	justify-content: flex-end;
	gap: .5rem;
}
.masthead__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px; height: 28px;
	opacity: .75;
	transition: opacity .15s ease;
}
.masthead__social-link:hover { opacity: 1; }
.masthead__social-link img { width: 18px; height: 18px; }

/* ---------- Sections navbar ---------- */

.navbar-news {
	background: var(--color-accent-2);
	position: sticky;
	top: 0;
	z-index: 10;
}
.navbar-news .container {
	display: flex;
	align-items: center;
	gap: .5rem;
}
.navbar-news__toggle {
	display: none;
	background: transparent;
	border: 0;
	color: #fff;
	font-size: 1.4rem;
	padding: .5rem .5rem;
	cursor: pointer;
}
.navbar-news__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	overflow-x: auto;
	scrollbar-width: none;
}
.navbar-news__list::-webkit-scrollbar { display: none; }

.navbar-news__link {
	display: inline-block;
	padding: .9rem 1rem;
	color: #fff;
	font-size: .82rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .06em;
	border-bottom: 3px solid transparent;
	white-space: nowrap;
}
.navbar-news__link:hover,
.navbar-news__link.is-active {
	color: #fff;
	border-bottom-color: var(--color-accent);
}

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

.site-main { padding: 2rem 0 3rem; }

.layout {
	display: grid;
	gap: 2rem;
}
.layout--home,
.layout--article {
	grid-template-columns: minmax(0, 1fr) 320px;
}
@media (max-width: 960px) {
	.layout--home,
	.layout--article { grid-template-columns: 1fr; }
}

/* ---------- Eyebrow / meta ---------- */

.eyebrow {
	display: inline-block;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: .5rem;
}
.eyebrow:hover { color: var(--color-accent); text-decoration: underline; }
.eyebrow--small { font-size: .68rem; margin-bottom: .35rem; }

.meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .5rem;
	color: var(--color-muted);
	font-size: .85rem;
}
.meta--small { font-size: .78rem; }
.meta__dot {
	display: inline-block;
	width: 3px; height: 3px;
	background: var(--color-muted);
	border-radius: 50%;
	opacity: .6;
}

/* ---------- Hero story ---------- */

.hero-story {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 1.75rem;
	padding-bottom: 1.75rem;
	margin-bottom: 1.75rem;
	border-bottom: 1px solid var(--color-line);
}
.hero-story--no-image { grid-template-columns: 1fr; }
@media (max-width: 720px) {
	.hero-story { grid-template-columns: 1fr; gap: 1rem; }
}
.hero-story__media {
	display: block;
	overflow: hidden;
	aspect-ratio: 16 / 10;
}
.hero-story__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}
.hero-story__media:hover img { transform: scale(1.02); }

.hero-story__body { display: flex; flex-direction: column; justify-content: center; }
.hero-story__title {
	font-size: clamp(1.75rem, 3.6vw, 2.75rem);
	line-height: 1.1;
	margin: .25rem 0 .75rem;
}
.hero-story__title a { color: var(--color-text); }
.hero-story__title a:hover { color: var(--color-link-hover); }
.hero-story__lede {
	font-size: 1.05rem;
	color: #333;
	margin-bottom: .9rem;
}

/* ---------- Card grid ---------- */

.card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.5rem 1.25rem;
}
@media (max-width: 900px) { .card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .card-grid { grid-template-columns: 1fr; } }

.news-card { display: flex; flex-direction: column; }
.news-card__media {
	display: block;
	overflow: hidden;
	aspect-ratio: 16 / 10;
	margin-bottom: .75rem;
}
.news-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}
.news-card__media:hover img { transform: scale(1.03); }
.news-card__title {
	font-family: var(--font-serif);
	font-size: 1.15rem;
	line-height: 1.25;
	margin: .1rem 0 .5rem;
}
.news-card__title a { color: var(--color-text); }
.news-card__title a:hover { color: var(--color-link-hover); }

/* ---------- Card list (older stories) ---------- */

.card-list { margin-top: 2.25rem; }
.section-heading {
	font-family: var(--font-sans);
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--color-muted);
	padding-bottom: .5rem;
	margin-bottom: 1rem;
	border-bottom: 2px solid var(--color-accent-2);
}

.news-row {
	display: block;
	width: 100%;
	padding: 1.25rem 0;
	border-bottom: 1px solid var(--color-line-soft);
}
.news-row::after { content: ""; display: block; clear: both; }
.news-row:last-child { border-bottom: 0; }

.news-row__media {
	display: block;
	float: left;
	width: 220px;
	margin: 0 1.25rem .25rem 0;
	overflow: hidden;
	aspect-ratio: 16 / 10;
}
@media (max-width: 720px) {
	.news-row { padding: 1rem 0; }
	.news-row__media { width: 140px; margin-right: 1rem; }
}
@media (max-width: 480px) {
	.news-row__media { float: none; width: 100%; margin: 0 0 .75rem; }
}
.news-row__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}
.news-row__media:hover img { transform: scale(1.03); }

.news-row__body { display: flex; flex-direction: column; }
.news-row__title {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	line-height: 1.25;
	margin: .15rem 0 .5rem;
}
.news-row__title a { color: var(--color-text); }
.news-row__title a:hover { color: var(--color-link-hover); }

.news-row__excerpt {
	color: #333;
	font-size: .95rem;
	line-height: 1.55;
	margin: 0 0 .65rem;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.news-row__excerpt p { margin: 0; }
.news-row__excerpt p + p { display: none; }
.news-row__excerpt img,
.news-row__excerpt h1,
.news-row__excerpt h2,
.news-row__excerpt h3,
.news-row__excerpt blockquote,
.news-row__excerpt pre { display: none; }

.news-row__more {
	font-size: .8rem;
	font-weight: 600;
	letter-spacing: .04em;
	color: var(--color-accent);
}
.news-row__more:hover { color: var(--color-accent); text-decoration: underline; }

/* ---------- Article view ---------- */

.article { max-width: 760px; }
.article__header { margin-bottom: 1.5rem; }
.article__title {
	font-size: clamp(1.85rem, 4vw, 2.8rem);
	line-height: 1.1;
	margin: .4rem 0 .8rem;
}
.article__lede {
	font-size: 1.15rem;
	color: #333;
	font-weight: 500;
	margin-bottom: 1rem;
}
.article__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .55rem;
	padding: .75rem 0;
	border-top: 1px solid var(--color-line);
	border-bottom: 1px solid var(--color-line);
	color: var(--color-muted);
	font-size: .85rem;
}
.article__byline {
	font-weight: 600;
	color: var(--color-text);
}
.article__cover {
	margin: 0 0 1.5rem;
}
.article__cover img { width: 100%; }

.article__body {
	font-size: 1.075rem;
	line-height: 1.75;
	color: #1a1a1a;
}
.article__body p,
.article__body ul,
.article__body ol,
.article__body blockquote,
.article__body pre,
.article__body figure { margin-bottom: 1.25rem; }
.article__body h2,
.article__body h3 {
	margin: 2rem 0 .75rem;
	line-height: 1.25;
}
.article__body h2 { font-size: 1.6rem; }
.article__body h3 { font-size: 1.25rem; }
.article__body a { color: var(--color-accent); border-bottom: 1px solid transparent; }
.article__body a:hover { border-bottom-color: var(--color-accent); }
.article__body img { margin: 0 auto 1rem; }
.article__body blockquote {
	margin-left: 0;
	padding: .25rem 0 .25rem 1.25rem;
	border-left: 4px solid var(--color-accent);
	font-family: var(--font-serif);
	font-size: 1.2rem;
	color: #222;
	font-style: italic;
}
.article__body pre,
.article__body code {
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	background: #f6f6f6;
	border-radius: 3px;
}
.article__body code { padding: .1rem .35rem; font-size: .9em; }
.article__body pre { padding: 1rem; overflow-x: auto; }

.article__footer {
	margin-top: 2rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--color-line);
}
.article__tags { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; }
.article__tags-label {
	font-size: .75rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--color-muted);
	margin-right: .35rem;
}
.tag-chip {
	display: inline-block;
	padding: .25rem .6rem;
	font-size: .8rem;
	color: var(--color-text);
	background: var(--color-line-soft);
	border: 1px solid transparent;
	transition: all .15s ease;
}
.tag-chip:hover {
	background: #fff;
	border-color: var(--color-accent);
	color: var(--color-accent);
}

/* ---------- Sidebar ---------- */

.sidebar { position: sticky; top: 64px; }
@media (max-width: 960px) { .sidebar { position: static; } }

.sidebar__block { margin-bottom: 2rem; }
.sidebar__title {
	font-family: var(--font-sans);
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--color-muted);
	padding-bottom: .5rem;
	margin: 0 0 1rem;
	border-bottom: 2px solid var(--color-accent);
}
.sidebar__list { list-style: none; margin: 0; padding: 0; }
.sidebar__item {
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: .75rem;
	padding: .85rem 0;
	border-bottom: 1px solid var(--color-line-soft);
}
.sidebar__item:first-child { padding-top: 0; }
.sidebar__item:last-child { border-bottom: 0; }
.sidebar__item:has(:only-child) { grid-template-columns: 1fr; } /* no thumb */
.sidebar__thumb {
	display: block;
	overflow: hidden;
	aspect-ratio: 1 / 1;
}
.sidebar__thumb img { width: 100%; height: 100%; object-fit: cover; }
.sidebar__link {
	display: block;
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: .98rem;
	line-height: 1.25;
	color: var(--color-text);
}
.sidebar__link:hover { color: var(--color-link-hover); }
.sidebar__desc {
	margin: .3rem 0 0;
	font-size: .82rem;
	color: var(--color-muted);
	line-height: 1.45;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.sidebar__block--plugins {
	font-size: .9rem;
	display: flex;
	flex-direction: column;
	gap: 2rem;
}
.sidebar__block--plugins h2,
.sidebar__block--plugins h3,
.sidebar__block--plugins h4 {
	font-family: var(--font-sans);
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--color-muted);
	padding-bottom: .5rem;
	margin: 0 0 1rem;
	border-bottom: 2px solid var(--color-accent);
}

/* ---------- Plugin forms ---------- */

.sidebar__block--plugins input,
.sidebar__block--plugins select,
.sidebar__block--plugins textarea {
	background: var(--color-surface);
	color: var(--color-text);
	border: 1px solid var(--color-line);
	border-radius: 3px;
	padding: .4rem .6rem;
	width: 100%;
	box-sizing: border-box;
}

/* ---------- Pagination ---------- */

.paginator {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	margin-top: 3rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--color-line);
}
.paginator__btn {
	display: inline-flex;
	align-items: center;
	gap: .35rem;
	padding: .5rem 1rem;
	border: 1px solid var(--color-line);
	color: var(--color-text);
	font-weight: 600;
	font-size: .9rem;
	background: #fff;
}
.paginator__btn:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}
.paginator__pos {
	font-size: .85rem;
	color: var(--color-muted);
}

/* ---------- Empty / 404 ---------- */

.empty-state {
	padding: 3rem 0;
	text-align: center;
	color: var(--color-muted);
}

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

.site-footer {
	border-top: 3px solid var(--color-accent-2);
	background: #fafafa;
	margin-top: 3rem;
}
.site-footer__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: .5rem;
	padding-top: 1.25rem;
	padding-bottom: 1.25rem;
	font-size: .85rem;
	color: var(--color-muted);
}
.site-footer p { margin: 0; }
.site-footer a { color: var(--color-text); }
.site-footer a:hover { color: var(--color-accent); }

/* ---------- Mobile navbar ---------- */

@media (max-width: 720px) {
	.masthead__inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.masthead__date, .masthead__social { justify-content: center; }
	.masthead__social { justify-content: center; }

	.navbar-news__toggle { display: inline-flex; }
	.navbar-news__list {
		display: none;
		flex-direction: column;
		width: 100%;
	}
	.navbar-news__list.is-open { display: flex; }
	.navbar-news__link {
		width: 100%;
		border-bottom: 1px solid rgba(255,255,255,.08);
	}
	.navbar-news__link.is-active { border-bottom-color: var(--color-accent); }
}
