/* ============================================================
 * blog-v2.css — premium blog archive layout.
 * Loaded after article-v2.css.
 * ============================================================ */

.blog-archive { padding: 0; }

/* HERO */
.blog-archive__hero {
	padding-block: clamp(48px, 5vw, 80px) clamp(32px, 3.5vw, 56px);
}
.blog-archive__title {
	font-family: var(--font-display, serif);
	font-size: clamp(36px, 5.2vw, 72px);
	letter-spacing: -0.025em;
	font-weight: 350;
	line-height: 1.04;
	margin: 14px 0 18px;
	color: var(--color-text-primary, #1a1a1a);
}
.blog-archive__title em {
	display: block;
	font-style: italic;
	color: var(--color-accent, #b94a2e);
	font-size: 0.55em;
	margin-top: 6px;
	font-weight: 350;
}
.blog-archive__lede {
	font-family: var(--font-display, serif);
	font-size: clamp(16px, 1.3vw, 19px);
	font-style: italic;
	color: var(--color-text-secondary, #5a5550);
	line-height: 1.55;
	max-width: 56ch;
	margin: 0;
}

/* CATEGORIES FILTER STRIP */
.blog-archive__cats {
	padding-block: clamp(20px, 2vw, 32px);
	border-block: 1px solid var(--color-border-subtle, #e6e0d8);
	background: var(--color-surface, #fdf8f0);
}
.blog-archive__cats-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.blog-archive__cat-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 9px 16px 9px 18px;
	background: transparent;
	border: 1px solid var(--color-border, #d8cfc4);
	border-radius: 999px;
	color: var(--color-text-primary, #1a1a1a);
	font-family: var(--font-mono, monospace);
	font-size: 12px;
	letter-spacing: 0.04em;
	text-decoration: none;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
.blog-archive__cat-pill:hover {
	background: var(--color-bg-secondary, #efeae2);
	border-color: var(--color-accent, #b94a2e);
}
.blog-archive__cat-pill.is-active {
	background: var(--color-text-primary, #190f0a);
	color: #fff;
	border-color: var(--color-text-primary, #190f0a);
}
.blog-archive__cat-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 7px;
	border-radius: 999px;
	background: var(--color-bg-secondary, #efeae2);
	color: var(--color-text-muted, #7a6f66);
	font-size: 10.5px;
	font-weight: 500;
}
.blog-archive__cat-pill.is-active .blog-archive__cat-count {
	background: rgba(255, 255, 255, 0.15);
	color: rgba(255, 255, 255, 0.7);
}
.blog-archive__cat-pill:hover .blog-archive__cat-count {
	background: var(--color-surface, #fdf8f0);
}

/* GRID */
.blog-archive__grid-wrap {
	padding-block: clamp(48px, 5vw, 80px);
}
.blog-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: clamp(24px, 2.5vw, 36px);
}
.blog-card {
	display: flex;
	flex-direction: column;
	background: var(--color-surface, #fdf8f0);
	border: 1px solid var(--color-border, #d8cfc4);
	border-radius: var(--radius-lg, 18px);
	overflow: hidden;
	text-decoration: none;
	color: var(--color-text-primary, #1a1a1a);
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.blog-card:hover,
.blog-card:focus-visible {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px rgba(15, 10, 4, 0.10);
	border-color: var(--color-accent, #b94a2e);
}
.blog-card__media {
	margin: 0;
	aspect-ratio: 16/9;
	overflow: hidden;
}
.blog-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}
.blog-card:hover .blog-card__media img {
	transform: scale(1.04);
}
.blog-card__body {
	padding: 22px 26px 24px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}
.blog-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 10px;
	font-family: var(--font-mono, monospace);
	font-size: 10.5px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted, #7a6f66);
}
.blog-card__cat {
	color: var(--color-accent, #b94a2e);
	font-weight: 500;
}
.blog-card__sep { opacity: 0.5; }
.blog-card__title {
	font-family: var(--font-display, serif);
	font-size: 20px;
	font-weight: 400;
	letter-spacing: -0.012em;
	line-height: 1.25;
	margin: 0;
	color: var(--color-text-primary, #1a1a1a);
}
.blog-card__lede {
	font-size: 14px;
	line-height: 1.55;
	color: var(--color-text-secondary, #5a5550);
	margin: 0;
	flex: 1;
}
.blog-card__arrow {
	font-family: var(--font-mono, monospace);
	font-size: 10.5px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-accent, #b94a2e);
	margin-top: 4px;
}

.blog-archive__empty {
	text-align: center;
	font-style: italic;
	color: var(--color-text-secondary, #5a5550);
	padding: 64px 0;
}

/* PAGINATION */
.blog-archive__pagination {
	margin-top: clamp(40px, 4vw, 64px);
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px;
}
.blog-archive__page-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 14px;
	background: var(--color-surface, #fdf8f0);
	border: 1px solid var(--color-border, #d8cfc4);
	border-radius: 8px;
	color: var(--color-text-primary, #1a1a1a);
	font-family: var(--font-mono, monospace);
	font-size: 13px;
	text-decoration: none;
	transition: background 0.2s ease, border-color 0.2s ease;
}
.blog-archive__page-link:hover {
	background: var(--color-bg-secondary, #efeae2);
	border-color: var(--color-accent, #b94a2e);
}
.blog-archive__page-link.current {
	background: var(--color-text-primary, #190f0a);
	color: #fff;
	border-color: var(--color-text-primary, #190f0a);
}

@media (max-width: 880px) {
	.blog-archive__title {
		font-size: clamp(28px, 7vw, 44px);
	}
	.blog-archive__grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}
