/* ============================================================
 * article-v2.css — premium editorial article layout.
 * Loaded after pillar-premium-tight.css to compose tight rhythm.
 * ============================================================ */

.articlev2 { padding: 0; }

/* =====================================
 * HERO — 60/40 split, hero on light cream
 * ===================================== */
.articlev2-hero {
	padding-block: clamp(48px, 5vw, 80px) clamp(40px, 4vw, 64px);
}
.articlev2-hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
	gap: clamp(40px, 5vw, 80px);
	align-items: center;
}
.articlev2-hero__eyebrow a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
	transition: color 0.2s ease;
}
.articlev2-hero__eyebrow a:hover { color: var(--color-accent, #b94a2e); }

.articlev2-hero__title {
	font-family: var(--font-display, serif);
	font-size: clamp(32px, 4.5vw, 56px);
	font-weight: 350;
	letter-spacing: -0.025em;
	line-height: 1.06;
	margin: 14px 0 18px;
	color: var(--color-text-primary, #1a1a1a);
	max-width: 22ch;
}
.articlev2-hero__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 0 22px;
}
.articlev2-hero__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 12px;
	align-items: center;
	font-family: var(--font-mono, monospace);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted, #7a6f66);
}
.articlev2-hero__meta-sep { opacity: 0.4; }

.articlev2-hero__media {
	margin: 0;
	position: relative;
}
.articlev2-hero__media img {
	display: block;
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	border-radius: var(--radius-lg, 18px);
	box-shadow: 0 30px 60px rgba(15, 10, 4, 0.12);
}

/* =====================================
 * BODY 2-col — main prose + sticky sidebar
 * ===================================== */
.articlev2-body {
	padding-block: clamp(40px, 4vw, 64px) clamp(48px, 5vw, 72px);
	background: var(--color-bg-secondary, #efeae2);
	border-block: 1px solid var(--color-border-subtle, #e6e0d8);
}
.articlev2-body__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.6fr);
	gap: clamp(40px, 5vw, 80px);
	align-items: start;
}
.articlev2-body__main {
	font-size: 17px;
	line-height: 1.72;
	color: var(--color-text-primary, #1a1a1a);
}
.articlev2-body__main h2 {
	font-family: var(--font-display, serif);
	font-size: clamp(22px, 2.4vw, 28px);
	font-weight: 400;
	letter-spacing: -0.015em;
	margin-top: 1.6em;
	margin-bottom: 0.5em;
	color: var(--color-text-primary, #1a1a1a);
}
.articlev2-body__main h3 {
	font-family: var(--font-display, serif);
	font-size: clamp(18px, 1.8vw, 22px);
	font-weight: 400;
	letter-spacing: -0.01em;
	margin-top: 1.4em;
	margin-bottom: 0.4em;
	color: var(--color-text-primary, #1a1a1a);
}
.articlev2-body__main h4 {
	font-family: var(--font-display, serif);
	font-size: 17px;
	font-weight: 500;
	margin-top: 1.2em;
	margin-bottom: 0.3em;
}
.articlev2-body__main p {
	margin-bottom: 1.1em;
}
.articlev2-body__main ul,
.articlev2-body__main ol {
	padding-left: 1.6em;
	margin-bottom: 1.2em;
}
.articlev2-body__main li {
	margin-bottom: 0.4em;
}
.articlev2-body__main strong {
	color: var(--color-text-primary, #1a1a1a);
	font-weight: 600;
}
.articlev2-body__main a {
	color: var(--color-accent, #b94a2e);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
	transition: color 0.2s ease;
}
.articlev2-body__main a:hover {
	color: #a83a23;
}
.articlev2-body__main blockquote {
	border-left: 3px solid var(--color-accent, #b94a2e);
	padding: 6px 0 6px 22px;
	margin: 1.6em 0;
	font-family: var(--font-display, serif);
	font-style: italic;
	font-size: 18px;
	color: var(--color-text-secondary, #5a5550);
}
.articlev2-body__main img {
	max-width: 100%;
	border-radius: var(--radius-md, 12px);
	margin: 1.4em 0;
}

/* Side cards — sticky */
.articlev2-body__side {
	position: sticky;
	top: 90px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.articlev2-side-card {
	padding: 24px 26px;
	background: var(--color-surface, #fdf8f0);
	border: 1px solid var(--color-border, #d8cfc4);
	border-radius: var(--radius-lg, 18px);
}
.articlev2-side-card--dark {
	background: var(--color-text-primary, #190f0a);
	color: #fff;
	border-color: var(--color-text-primary, #190f0a);
}
.articlev2-side-card__eyebrow {
	font-family: var(--font-mono, monospace);
	font-size: 10.5px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-accent, #b94a2e);
	margin-bottom: 10px;
}
.articlev2-side-card--dark .articlev2-side-card__eyebrow {
	color: #d45b3d;
}
.articlev2-side-card__title {
	font-family: var(--font-display, serif);
	font-size: 19px;
	font-weight: 400;
	letter-spacing: -0.012em;
	line-height: 1.25;
	margin: 0 0 12px;
	color: inherit;
}
.articlev2-side-card__phone {
	display: block;
	font-family: var(--font-display, serif);
	font-size: clamp(26px, 3vw, 32px);
	font-weight: 350;
	letter-spacing: -0.02em;
	color: #fff;
	text-decoration: none;
	margin: 6px 0 8px;
	line-height: 1.1;
}
.articlev2-side-card__phone:hover {
	color: var(--color-accent, #d45b3d);
}
.articlev2-side-card__meta {
	font-family: var(--font-mono, monospace);
	font-size: 10.5px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.55);
	margin-bottom: 16px;
}
.articlev2-side-card__btn {
	display: block;
	padding: 12px 18px;
	background: var(--color-accent, #b94a2e);
	color: #fff;
	border-radius: 999px;
	text-decoration: none;
	font-family: var(--font-mono, monospace);
	font-size: 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-align: center;
	transition: background 0.25s ease, transform 0.25s ease;
}
.articlev2-side-card__btn:hover {
	background: #a83a23;
	transform: translateY(-1px);
}
.articlev2-side-card__txt {
	font-size: 14px;
	line-height: 1.55;
	color: var(--color-text-secondary, #5a5550);
	margin: 0 0 12px;
}
.articlev2-side-card__txt em {
	font-family: var(--font-display, serif);
	font-style: italic;
	color: var(--color-text-primary, #1a1a1a);
}
.articlev2-side-card__link {
	display: inline-block;
	font-family: var(--font-mono, monospace);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-accent, #b94a2e);
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
}
.articlev2-side-card__link:hover { color: #a83a23; }

/* =====================================
 * RELATED ARTICLES grid
 * ===================================== */
.articlev2-related {
	padding-block: clamp(48px, 5vw, 72px);
	background: var(--color-surface, #fdf8f0);
}
.articlev2-related__head {
	max-width: 640px;
	margin-bottom: 36px;
}
.articlev2-related__title {
	font-family: var(--font-display, serif);
	font-size: clamp(28px, 3.4vw, 42px);
	font-weight: 350;
	letter-spacing: -0.022em;
	line-height: 1.05;
	margin: 8px 0 0;
	color: var(--color-text-primary, #1a1a1a);
}
.articlev2-related__title em {
	font-style: italic;
	color: var(--color-accent, #b94a2e);
}
.articlev2-related__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: clamp(20px, 2.4vw, 32px);
}
.articlev2-rel-card {
	display: flex;
	flex-direction: column;
	background: var(--color-bg-secondary, #efeae2);
	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;
}
.articlev2-rel-card:hover,
.articlev2-rel-card:focus-visible {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px rgba(15, 10, 4, 0.10);
	border-color: var(--color-accent, #b94a2e);
}
.articlev2-rel-card__media {
	margin: 0;
	aspect-ratio: 16/9;
	overflow: hidden;
}
.articlev2-rel-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}
.articlev2-rel-card:hover .articlev2-rel-card__media img {
	transform: scale(1.04);
}
.articlev2-rel-card__body {
	padding: 22px 24px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}
.articlev2-rel-card__date {
	font-family: var(--font-mono, monospace);
	font-size: 10.5px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted, #7a6f66);
}
.articlev2-rel-card__title {
	font-family: var(--font-display, serif);
	font-size: 19px;
	font-weight: 400;
	letter-spacing: -0.012em;
	line-height: 1.25;
	margin: 0;
	color: var(--color-text-primary, #1a1a1a);
}
.articlev2-rel-card__lede {
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--color-text-secondary, #5a5550);
	margin: 0;
	flex: 1;
}
.articlev2-rel-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;
}

/* =====================================
 * RESPONSIVE
 * ===================================== */
@media (max-width: 1024px) {
	.articlev2-body__grid {
		grid-template-columns: 1fr;
	}
	.articlev2-body__side {
		position: static;
		flex-direction: row;
		flex-wrap: wrap;
	}
	.articlev2-side-card {
		flex: 1 1 280px;
	}
}
@media (max-width: 880px) {
	.articlev2-hero__grid {
		grid-template-columns: 1fr;
	}
	.articlev2-hero__title {
		font-size: clamp(28px, 7vw, 42px);
	}
	.articlev2-body__grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.articlev2-body__side {
		flex-direction: column;
	}
	.articlev2-related__grid {
		gap: 16px;
	}
}
