/**
 * Vores Afrika — bold editorial / sunset landscape system
 */

:root {
	--va-void: #0c0a09;
	--va-dusk: #1a1210;
	--va-ink: #171210;
	--va-clay: #6a4a3c;
	--va-umber: #5c3d2e;
	--va-ember: #e04d2b;
	--va-flame: #ff8f6b;
	--va-horizon: #e8a04a;
	--va-gold: #d9b978;
	--va-canopy: #1a3d30;
	--va-fern: #2f5e49;
	--va-cream: #f3ece1;
	--va-mist: #e8dfd2;
	--va-sand: #d4b896;
	--va-white: #fff;
	--va-font-display: "Fraunces", Georgia, "Times New Roman", serif;
	--va-font-hero: "DM Serif Display", Georgia, "Times New Roman", serif;
	--va-font-label: "Syne", system-ui, sans-serif;
	--va-font-body: "Source Sans 3", system-ui, -apple-system, sans-serif;
	--va-radius: 14px;
	--va-radius-lg: 22px;
	--va-radius-pill: 999px;
	--va-shadow: 0 22px 60px rgba(12, 10, 9, 0.14);
	--va-shadow-hover: 0 28px 80px rgba(12, 10, 9, 0.2);
	--va-header-h: 4.5rem;
	--va-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
	--va-texture: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.07'/%3E%3C/svg%3E");
	--va-noise-strong: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.12'/%3E%3C/svg%3E");
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

@keyframes va-hero-rise {
	from {
		opacity: 0;
		transform: translateY(28px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes va-scroll-nudge {
	0%,
	100% {
		transform: translateY(0);
		opacity: 0.55;
	}
	50% {
		transform: translateY(10px);
		opacity: 1;
	}
}

@keyframes va-shimmer {
	0% {
		transform: translateX(-120%) skewX(-18deg);
	}
	100% {
		transform: translateX(220%) skewX(-18deg);
	}
}

@keyframes va-glow-pulse {
	0%,
	100% {
		opacity: 0.45;
	}
	50% {
		opacity: 0.85;
	}
}

@keyframes va-sky-drift {
	0%,
	100% {
		background-position: 0% 40%, 100% 60%, 50% 50%;
	}
	50% {
		background-position: 100% 50%, 0% 45%, 40% 55%;
	}
}

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

html {
	scroll-behavior: smooth;
	scrollbar-gutter: stable;
	overflow-x: clip;
}

html.va-nav-open,
body.va-nav-open {
	overflow: hidden;
}

body {
	margin: 0;
	font-family: var(--va-font-body);
	font-size: clamp(1.03rem, 0.25vw + 0.98rem, 1.125rem);
	line-height: 1.68;
	color: var(--va-ink);
	background-color: var(--va-cream);
	position: relative;
}

/* Layered “landscape” wash + grain — no horizontal overflow */
body::before {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -2;
	background:
		radial-gradient(ellipse 100% 80% at 10% 0%, color-mix(in srgb, var(--va-ember) 14%, transparent), transparent 52%),
		radial-gradient(ellipse 90% 70% at 92% 8%, color-mix(in srgb, var(--va-horizon) 12%, transparent), transparent 48%),
		radial-gradient(ellipse 70% 55% at 50% 100%, color-mix(in srgb, var(--va-canopy) 09%, transparent), transparent 45%),
		var(--va-cream);
	background-size: 120% 120%, 110% 110%, 100% 100%, 100% 100%;
	background-position: 0% 40%, 100% 60%, 50% 50%, 50% 50%;
	pointer-events: none;
}

@media (prefers-reduced-motion: no-preference) {
	body::before {
		animation: va-sky-drift 28s ease-in-out infinite alternate;
	}
}

body::after {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -1;
	background-image: var(--va-texture);
	opacity: 1;
	pointer-events: none;
}

.site,
#page {
	overflow-x: clip;
	max-width: 100%;
}

::selection {
	background: color-mix(in srgb, var(--va-horizon) 45%, transparent);
	color: var(--va-void);
}

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

a {
	color: var(--va-ember);
	text-underline-offset: 0.2em;
	transition: color 0.2s var(--va-ease-out), opacity 0.2s var(--va-ease-out);
}

a:hover {
	color: var(--va-canopy);
}

a:focus-visible {
	outline: 2px solid var(--va-horizon);
	outline-offset: 3px;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	word-wrap: normal !important;
}

.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 100000;
	padding: 0.85rem 1.15rem;
	background: var(--va-void);
	color: var(--va-cream);
	text-decoration: none;
	border-radius: 0 0 var(--va-radius) 0;
	font-weight: 600;
}

.skip-link:focus {
	left: 0;
}

.site-main {
	min-height: 55vh;
}

.container {
	width: min(1280px, 100% - 2.75rem);
	margin-inline: auto;
}

.container.narrow {
	width: min(720px, 100% - 2.75rem);
}

/* ——— Shaped dividers ——— */
.va-divider {
	line-height: 0;
	position: relative;
	z-index: 3;
	margin-top: clamp(-4.5rem, -7vw, -2.5rem);
	color: var(--va-cream);
	pointer-events: none;
}

.va-divider--tilt {
	margin-top: clamp(-3rem, -5vw, -1.5rem);
	color: #132722;
}

.va-divider__svg {
	display: block;
	width: 100%;
	max-width: 100%;
	height: clamp(52px, 9vw, 112px);
	filter: drop-shadow(0 -12px 24px rgba(12, 10, 9, 0.08));
}

/* ——— Header (dark masthead — white wordmark) ——— */
.site-header {
	position: sticky;
	top: 0;
	z-index: 80;
	background: linear-gradient(165deg, var(--va-void) 0%, color-mix(in srgb, var(--va-dusk) 88%, #000) 48%, var(--va-void) 100%);
	border-bottom: 1px solid color-mix(in srgb, var(--va-ember) 28%, transparent);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.35);
	transition: box-shadow 0.3s var(--va-ease-out);
}

.site-header::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	background: linear-gradient(180deg, var(--va-ember), var(--va-horizon) 55%, color-mix(in srgb, var(--va-canopy) 70%, var(--va-horizon)));
	pointer-events: none;
}

.site-header::after {
	content: "";
	position: absolute;
	inset: auto 0 0 0;
	height: 2px;
	background: linear-gradient(90deg, transparent 5%, var(--va-horizon) 35%, var(--va-ember) 50%, var(--va-horizon) 65%, transparent 95%);
	opacity: 0.5;
	pointer-events: none;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	min-height: var(--va-header-h);
	padding-left: 0.35rem;
}

.site-header .container {
	width: min(1400px, 100% - 2rem);
}

/* Text fallback if no logo image (child themes) */
.site-header__title {
	text-decoration: none;
	color: var(--va-cream);
	display: flex;
	flex-direction: column;
	gap: 0.12rem;
}

.site-header__name {
	font-family: var(--va-font-label);
	font-weight: 700;
	font-size: clamp(1.08rem, 1vw + 0.95rem, 1.32rem);
	letter-spacing: 0.02em;
}

.site-header__tagline {
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--va-cream) 58%, transparent);
}

.site-header__logo-link {
	display: block;
	line-height: 0;
	transition: opacity 0.25s var(--va-ease-out), transform 0.25s var(--va-ease-out);
}

.site-header__logo-link:hover {
	opacity: 0.92;
	transform: translateY(-1px);
}

.site-header__logo--default .site-header__logo-img,
.site-header__logo--custom .custom-logo-link img {
	height: auto;
	max-height: clamp(40px, 5.5vw, 52px);
	width: auto;
	max-width: min(268px, 52vw);
}

.site-header__logo .custom-logo-link {
	display: block;
	line-height: 0;
	transition: opacity 0.25s var(--va-ease-out), transform 0.25s var(--va-ease-out);
}

.site-header__logo .custom-logo-link:hover {
	opacity: 0.92;
	transform: translateY(-1px);
}

.menu-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: var(--va-radius);
	border: 1px solid color-mix(in srgb, var(--va-cream) 22%, transparent);
	background: color-mix(in srgb, var(--va-cream) 06%, transparent);
	cursor: pointer;
	transition: transform 0.2s var(--va-ease-out), background 0.2s var(--va-ease-out), border-color 0.2s var(--va-ease-out);
}

.menu-toggle:hover {
	transform: translateY(-2px);
	background: color-mix(in srgb, var(--va-cream) 11%, transparent);
	border-color: color-mix(in srgb, var(--va-cream) 35%, transparent);
}

.menu-toggle__box {
	width: 1.35rem;
	height: 1rem;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.menu-toggle__bar {
	display: block;
	height: 2px;
	width: 100%;
	background: var(--va-cream);
	border-radius: 2px;
	transform-origin: center;
	transition: transform 0.3s var(--va-ease-out), opacity 0.25s var(--va-ease-out);
}

.menu-toggle.is-active .menu-toggle__bar--top {
	transform: translateY(7px) rotate(45deg);
}

.menu-toggle.is-active .menu-toggle__bar--mid {
	opacity: 0;
	transform: scaleX(0.2);
}

.menu-toggle.is-active .menu-toggle__bar--bot {
	transform: translateY(-7px) rotate(-45deg);
}

.main-navigation {
	display: flex;
	align-items: center;
	position: relative;
}

.main-navigation__scrim {
	display: none;
}

.main-navigation__label {
	display: none;
}

.main-navigation__panel .menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	row-gap: 0.35rem;
	align-items: center;
	justify-content: flex-end;
}

.main-navigation__panel .menu > li {
	display: flex;
	align-items: center;
}

.main-navigation__panel .menu > li:not(:first-child)::before {
	content: "";
	width: 1px;
	height: 0.85rem;
	margin-right: 1.15rem;
	margin-left: 0.15rem;
	background: color-mix(in srgb, var(--va-cream) 20%, transparent);
	flex-shrink: 0;
}

.main-navigation__panel .menu > li > a {
	position: relative;
	text-decoration: none;
	font-family: var(--va-font-label);
	font-weight: 600;
	font-size: 0.82rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--va-cream) 92%, transparent);
	padding: 0.45rem 0;
}

.main-navigation__panel .menu > li > a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0.1rem;
	width: 100%;
	height: 2px;
	border-radius: 2px;
	background: linear-gradient(90deg, var(--va-flame), var(--va-horizon));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.35s var(--va-ease-out);
}

.main-navigation__panel .menu > li > a:hover::after,
.main-navigation__panel .menu .current-menu-item > a::after {
	transform: scaleX(1);
}

.main-navigation__panel .menu > li > a:hover,
.main-navigation__panel .menu .current-menu-item > a {
	color: var(--va-cream);
}

.main-navigation__panel .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0.65rem 0 0;
	position: absolute;
	min-width: 14rem;
	background: color-mix(in srgb, var(--va-dusk) 96%, black);
	border-radius: var(--va-radius);
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45);
	border: 1px solid color-mix(in srgb, var(--va-cream) 12%, transparent);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: opacity 0.22s var(--va-ease-out), transform 0.22s var(--va-ease-out), visibility 0.22s;
}

.main-navigation__panel .menu-item-has-children {
	position: relative;
}

.main-navigation__panel .menu-item-has-children:hover > .sub-menu,
.main-navigation__panel .menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.main-navigation__panel .sub-menu a {
	display: block;
	padding: 0.55rem 1.1rem;
	font-weight: 600;
	font-size: 0.88rem;
	letter-spacing: 0.04em;
	color: color-mix(in srgb, var(--va-cream) 90%, transparent);
}

.main-navigation__panel .sub-menu a:hover {
	color: var(--va-flame);
	background: color-mix(in srgb, var(--va-ember) 12%, transparent);
}

@media (max-width: 959px) {
	.menu-toggle {
		display: inline-flex;
		z-index: 95;
	}

	.main-navigation__scrim {
		display: block;
		position: fixed;
		inset: 0;
		z-index: 85;
		background: color-mix(in srgb, var(--va-void) 55%, transparent);
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.35s var(--va-ease-out), visibility 0.35s;
		backdrop-filter: blur(4px);
	}

	.main-navigation.is-open .main-navigation__scrim {
		opacity: 1;
		visibility: visible;
	}

	.main-navigation__label {
		display: block;
		margin: 0 0 1.25rem;
		font-family: var(--va-font-label);
		font-size: 0.68rem;
		font-weight: 700;
		letter-spacing: 0.24em;
		text-transform: uppercase;
		color: color-mix(in srgb, var(--va-flame) 55%, var(--va-cream));
	}

	.main-navigation__panel {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		width: min(420px, 92vw);
		z-index: 90;
		padding: calc(var(--va-header-h) + 1.25rem) 1.75rem 2rem;
		overflow: auto;
		background:
			radial-gradient(120% 80% at 100% 0%, color-mix(in srgb, var(--va-ember) 22%, transparent), transparent 55%),
			linear-gradient(165deg, var(--va-dusk), var(--va-void));
		color: var(--va-cream);
		transform: translateX(104%);
		transition: transform 0.45s var(--va-ease-out);
		box-shadow: -30px 0 80px rgba(0, 0, 0, 0.45);
		border-left: 1px solid color-mix(in srgb, var(--va-cream) 12%, transparent);
	}

	.main-navigation.is-open .main-navigation__panel {
		transform: translateX(0);
	}

	.main-navigation__panel .menu {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.main-navigation__panel .menu > li {
		display: block;
	}

	.main-navigation__panel .menu > li:not(:first-child)::before {
		display: none;
	}

	.main-navigation__panel .menu > li > a {
		color: var(--va-cream);
		font-size: clamp(1.1rem, 2.5vw, 1.3rem);
		letter-spacing: 0.06em;
		padding: 1rem 0;
		border-bottom: 1px solid color-mix(in srgb, var(--va-cream) 10%, transparent);
	}

	.main-navigation__panel .menu > li > a::after {
		display: none;
	}

	.main-navigation__panel .menu > li > a:hover,
	.main-navigation__panel .menu .current-menu-item > a {
		color: var(--va-flame);
		padding-left: 0.35rem;
	}

	.main-navigation__panel .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		background: color-mix(in srgb, var(--va-void) 40%, transparent);
		border-radius: var(--va-radius);
		margin: 0.35rem 0 0.85rem;
		padding: 0.35rem 0;
		border: 1px solid color-mix(in srgb, var(--va-cream) 8%, transparent);
	}

	.main-navigation__panel .sub-menu a {
		color: color-mix(in srgb, var(--va-cream) 88%, transparent);
		padding: 0.55rem 1rem;
	}

	.main-navigation__panel .menu > li {
		opacity: 1;
		transform: none;
	}

	.main-navigation.is-open .main-navigation__panel .menu > li {
		opacity: 0;
		transform: translateX(12px);
		animation: va-menu-item-in 0.5s var(--va-ease-out) forwards;
	}

	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(1) {
		animation-delay: 0.05s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(2) {
		animation-delay: 0.1s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(3) {
		animation-delay: 0.14s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(4) {
		animation-delay: 0.18s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(5) {
		animation-delay: 0.22s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(6) {
		animation-delay: 0.26s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(7) {
		animation-delay: 0.3s;
	}
	.main-navigation.is-open .main-navigation__panel .menu > li:nth-child(8) {
		animation-delay: 0.34s;
	}
}

@keyframes va-menu-item-in {
	from {
		opacity: 0;
		transform: translateX(14px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@media (max-width: 959px) and (prefers-reduced-motion: reduce) {
	.main-navigation__panel .menu > li,
	.main-navigation.is-open .main-navigation__panel .menu > li {
		opacity: 1;
		transform: none;
		animation: none;
	}
}

/* ——— Hero ——— */
.hero {
	position: relative;
	min-height: min(92vh, 900px);
	display: grid;
	align-items: end;
	padding: clamp(3rem, 11vw, 7rem) 0 clamp(4rem, 12vw, 8rem);
	overflow: clip;
	isolation: isolate;
	clip-path: polygon(0 0, 100% 0, 100% calc(100% - min(5vw, 3.5rem)), 50% 100%, 0 calc(100% - min(2.5vw, 1.75rem)));
}

.hero--home:not(.hero--has-media) {
	background:
		radial-gradient(80% 60% at 15% 20%, color-mix(in srgb, var(--va-ember) 35%, transparent), transparent 60%),
		radial-gradient(70% 50% at 85% 10%, color-mix(in srgb, var(--va-horizon) 28%, transparent), transparent 55%),
		linear-gradient(165deg, var(--va-canopy), var(--va-dusk) 45%, var(--va-void));
}

.hero__atmosphere {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}

.hero__atmosphere--compact {
	opacity: 0.85;
}

.hero__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(0px);
	opacity: 0.55;
	mix-blend-mode: screen;
	animation: va-glow-pulse 9s ease-in-out infinite;
}

.hero__orb--a {
	width: min(52vw, 520px);
	height: min(52vw, 520px);
	top: -18%;
	right: -8%;
	background: radial-gradient(circle at 30% 30%, var(--va-flame), transparent 65%);
	animation-delay: 0s;
}

.hero__orb--b {
	width: min(42vw, 420px);
	height: min(42vw, 420px);
	bottom: -12%;
	left: -10%;
	background: radial-gradient(circle at 70% 60%, var(--va-horizon), transparent 62%);
	animation-delay: 1.2s;
}

.hero__orb--c {
	width: min(28vw, 280px);
	height: min(28vw, 280px);
	top: 38%;
	left: 22%;
	background: radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--va-gold) 80%, transparent), transparent 70%);
	opacity: 0.35;
	animation-duration: 11s;
}

.hero__grain {
	position: absolute;
	inset: 0;
	background-image: var(--va-noise-strong);
	opacity: 0.35;
	mix-blend-mode: overlay;
}

.hero__media {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.hero__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.03);
	transition: transform 8s var(--va-ease-out);
}

.hero--has-media:hover .hero__image {
	transform: scale(1.06);
}

.hero__overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	background:
		linear-gradient(120deg, color-mix(in srgb, var(--va-void) 72%, transparent) 0%, transparent 42%),
		linear-gradient(180deg, color-mix(in srgb, var(--va-void) 15%, transparent) 0%, color-mix(in srgb, var(--va-dusk) 78%, transparent) 55%, color-mix(in srgb, var(--va-void) 92%, transparent) 100%),
		radial-gradient(90% 70% at 70% 100%, color-mix(in srgb, var(--va-ember) 22%, transparent), transparent 55%);
}

.hero__vignette {
	position: absolute;
	inset: 0;
	z-index: 2;
	box-shadow: inset 0 0 120px rgba(0, 0, 0, 0.35);
	pointer-events: none;
}

.hero__content {
	position: relative;
	z-index: 3;
	color: var(--va-cream);
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: end;
	width: 100%;
}

.hero__copy {
	max-width: min(52rem, 100%);
}

.hero__kicker {
	margin: 0 0 1rem;
	font-family: var(--va-font-label);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--va-flame) 75%, var(--va-cream));
}

.hero__kicker--on-dark {
	color: color-mix(in srgb, var(--va-cream) 65%, transparent);
}

.hero__title {
	font-family: var(--va-font-hero);
	font-size: clamp(3rem, 7vw + 1rem, 5.75rem);
	line-height: 0.95;
	margin: 0 0 1.25rem;
	letter-spacing: -0.03em;
	font-weight: 400;
	text-wrap: balance;
	text-shadow:
		0 2px 0 color-mix(in srgb, var(--va-horizon) 35%, transparent),
		0 18px 50px rgba(0, 0, 0, 0.38);
}

@media (prefers-reduced-motion: no-preference) {
	.hero--home .hero__copy > * {
		animation: va-hero-rise 0.9s var(--va-ease-out) backwards;
	}
	.hero--home .hero__kicker {
		animation-delay: 0.08s;
	}
	.hero--home .hero__title {
		animation-delay: 0.14s;
	}
	.hero--home .hero__lead {
		animation-delay: 0.22s;
	}
	.hero--home .hero__actions {
		animation-delay: 0.3s;
	}
}

.hero__lead {
	font-size: clamp(1.15rem, 0.9vw + 1rem, 1.45rem);
	line-height: 1.55;
	margin: 0 0 2rem;
	max-width: 44ch;
	color: color-mix(in srgb, var(--va-cream) 90%, transparent);
	font-weight: 500;
}

.hero__lead--on-dark {
	color: color-mix(in srgb, var(--va-cream) 88%, transparent);
	margin: 0;
	max-width: 48ch;
}

.hero__lead p {
	margin: 0 0 0.85rem;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem 1rem;
	align-items: center;
	margin: 0;
}

.hero__aside {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding-bottom: 0.35rem;
	color: color-mix(in srgb, var(--va-cream) 55%, transparent);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	writing-mode: vertical-rl;
	transform: rotate(180deg);
}

.hero__line {
	width: 1px;
	height: clamp(3.5rem, 10vw, 6rem);
	background: linear-gradient(180deg, transparent, var(--va-horizon), transparent);
	opacity: 0.85;
}

.hero__scroll-hint {
	position: absolute;
	left: 50%;
	bottom: clamp(1rem, 3vw, 1.75rem);
	z-index: 3;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	color: color-mix(in srgb, var(--va-cream) 55%, transparent);
	font-size: 0.65rem;
	font-weight: 800;
	letter-spacing: 0.28em;
	text-transform: uppercase;
}

.hero__scroll-line {
	width: 1px;
	height: 2.5rem;
	background: linear-gradient(180deg, var(--va-cream), transparent);
	opacity: 0.65;
}

@media (prefers-reduced-motion: no-preference) {
	.hero__scroll-hint {
		animation: va-scroll-nudge 2.8s ease-in-out infinite;
	}
}

.hero--blog {
	min-height: min(48vh, 520px);
	align-items: center;
	padding: clamp(3rem, 10vw, 5.5rem) 0;
	background:
		radial-gradient(90% 80% at 80% 20%, color-mix(in srgb, var(--va-ember) 25%, transparent), transparent 55%),
		linear-gradient(145deg, var(--va-canopy), var(--va-dusk));
	color: var(--va-cream);
}

.hero--blog .hero__content {
	grid-template-columns: 1fr;
}

.hero--blog {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.hero--blog .hero__title {
	font-family: var(--va-font-hero);
	text-shadow: 0 14px 40px rgba(0, 0, 0, 0.3);
	font-size: clamp(2.65rem, 5.5vw + 1rem, 4.25rem);
}

@media (max-width: 900px) {
	.hero__content {
		grid-template-columns: 1fr;
	}
	.hero__aside {
		display: none;
	}
	.hero__scroll-hint {
		display: none;
	}
}

/* ——— Buttons ——— */
.button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	padding: 0.95rem 1.65rem;
	font-family: inherit;
	font-weight: 700;
	font-size: 0.98rem;
	letter-spacing: 0.02em;
	text-decoration: none;
	border-radius: var(--va-radius-pill);
	border: none;
	cursor: pointer;
	overflow: hidden;
	transition: transform 0.2s var(--va-ease-out), box-shadow 0.25s var(--va-ease-out);
}

.button--primary {
	background: linear-gradient(135deg, var(--va-ember), color-mix(in srgb, var(--va-flame) 70%, var(--va-ember)));
	color: var(--va-white);
	box-shadow: 0 16px 44px color-mix(in srgb, var(--va-ember) 42%, transparent);
}

.button--primary:hover {
	color: var(--va-white);
	transform: translateY(-2px);
	box-shadow: 0 22px 55px color-mix(in srgb, var(--va-ember) 48%, transparent);
}

.button--ghost {
	background: color-mix(in srgb, var(--va-cream) 10%, transparent);
	color: var(--va-cream);
	border: 1px solid color-mix(in srgb, var(--va-cream) 42%, transparent);
	backdrop-filter: blur(6px);
}

.button--ghost:hover {
	color: var(--va-void);
	background: var(--va-cream);
	border-color: var(--va-cream);
}

.button--glow::after {
	content: "";
	position: absolute;
	inset: -40% auto auto -30%;
	width: 40%;
	height: 180%;
	background: linear-gradient(120deg, transparent, color-mix(in srgb, var(--va-white) 55%, transparent), transparent);
	transform: translateX(-120%) skewX(-18deg);
	opacity: 0;
}

@media (prefers-reduced-motion: no-preference) {
	.button--glow:hover::after {
		opacity: 1;
		animation: va-shimmer 0.85s var(--va-ease-out);
	}
}

.button--sunset {
	background: linear-gradient(135deg, var(--va-horizon), var(--va-flame));
	color: var(--va-void);
	box-shadow: 0 18px 50px color-mix(in srgb, var(--va-horizon) 38%, transparent);
}

.button--sunset:hover {
	color: var(--va-void);
	transform: translateY(-2px);
}

.button:focus-visible {
	outline: 2px solid var(--va-horizon);
	outline-offset: 3px;
}

.button:active {
	transform: translateY(0);
}

/* ——— Sections ——— */
.section {
	padding: clamp(3.5rem, 11vw, 7.5rem) 0;
	position: relative;
}

.section--editorial {
	background: linear-gradient(180deg, var(--va-cream), color-mix(in srgb, var(--va-mist) 65%, var(--va-cream)));
	overflow: hidden;
}

.section__backdrop {
	position: absolute;
	inset: -20% -10% auto -10%;
	height: 70%;
	background: radial-gradient(55% 80% at 10% 0%, color-mix(in srgb, var(--va-horizon) 14%, transparent), transparent 70%);
	pointer-events: none;
}

.section--layered {
	background:
		repeating-linear-gradient(
			-12deg,
			transparent,
			transparent 14px,
			color-mix(in srgb, var(--va-ember) 04%, transparent) 14px,
			color-mix(in srgb, var(--va-ember) 04%, transparent) 15px
		),
		radial-gradient(120% 90% at 100% 0%, color-mix(in srgb, var(--va-sand) 38%, transparent), transparent 55%),
		linear-gradient(180deg, var(--va-mist), var(--va-cream));
	overflow: hidden;
}

.section__glow {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.section__glow--stories {
	background: radial-gradient(55% 45% at 12% 18%, color-mix(in srgb, var(--va-ember) 10%, transparent), transparent 70%);
}

.section__head {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: clamp(2rem, 5vw, 3rem);
}

.section__head--editorial {
	align-items: flex-end;
	border-bottom: 1px solid color-mix(in srgb, var(--va-umber) 12%, transparent);
	padding-bottom: 1.75rem;
}

.section__head-copy {
	max-width: min(40rem, 100%);
}

.section__kicker {
	margin: 0 0 0.65rem;
	font-family: var(--va-font-label);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--va-ember);
}

.section__title {
	font-family: var(--va-font-hero);
	font-size: clamp(2.25rem, 3.5vw + 1rem, 3.65rem);
	margin: 0 0 0.75rem;
	letter-spacing: -0.03em;
	line-height: 1.02;
	font-weight: 400;
	background: linear-gradient(120deg, var(--va-ink) 0%, color-mix(in srgb, var(--va-ember) 22%, var(--va-ink)) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

@supports not (background-clip: text) {
	.section__title {
		background: none;
		color: var(--va-ink);
	}
}

.section__deck {
	margin: 0;
	font-size: clamp(1.05rem, 0.5vw + 1rem, 1.2rem);
	line-height: 1.55;
	color: color-mix(in srgb, var(--va-ink) 72%, transparent);
	max-width: 48ch;
}

.section__link {
	font-weight: 700;
	text-decoration: none;
}

.section__link--pill {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.15rem;
	border-radius: var(--va-radius-pill);
	background: var(--va-white);
	border: 1px solid color-mix(in srgb, var(--va-umber) 14%, transparent);
	box-shadow: 0 12px 34px rgba(12, 10, 9, 0.08);
	transition: transform 0.25s var(--va-ease-out), box-shadow 0.25s var(--va-ease-out), border-color 0.25s var(--va-ease-out);
}

.section__link--pill:hover {
	transform: translateY(-3px);
	box-shadow: var(--va-shadow-hover);
	border-color: color-mix(in srgb, var(--va-ember) 35%, transparent);
	color: var(--va-ember);
}

.section__link-icon {
	transition: transform 0.25s var(--va-ease-out);
}

.section__link--pill:hover .section__link-icon {
	transform: translateX(4px);
}

/* ——— Cards ——— */
.card-grid--editorial {
	grid-template-columns: repeat(12, 1fr);
	gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.card-grid--editorial .card-grid__item {
	grid-column: span 12;
}

@media (min-width: 900px) {
	.card-grid--editorial .card-grid__item:not(.card-grid__item--lead) {
		grid-column: span 6;
	}
	.card-grid--editorial .card-grid__item--lead {
		grid-column: span 12;
	}
}

.card {
	position: relative;
	background: var(--va-white);
	border-radius: clamp(18px, 3vw, 26px) clamp(10px, 2vw, 16px) clamp(22px, 3.5vw, 30px) clamp(12px, 2vw, 18px);
	overflow: hidden;
	box-shadow: var(--va-shadow);
	display: flex;
	flex-direction: column;
	min-height: 100%;
	border: 1px solid color-mix(in srgb, var(--va-umber) 8%, transparent);
	transition: transform 0.35s var(--va-ease-out), box-shadow 0.35s var(--va-ease-out);
}

.card:hover {
	transform: translateY(-6px);
	box-shadow: var(--va-shadow-hover), 0 0 0 1px color-mix(in srgb, var(--va-horizon) 35%, transparent);
}

.card--feature {
	flex-direction: column;
}

@media (min-width: 900px) {
	.card--feature {
		flex-direction: row;
		align-items: stretch;
		min-height: clamp(280px, 32vw, 360px);
	}
	.card--feature .card__media {
		flex: 1.15;
		aspect-ratio: auto;
		min-height: 100%;
	}
	.card--feature .card__body {
		flex: 1;
		justify-content: center;
		padding: clamp(1.5rem, 3vw, 2.25rem);
	}
}

.card__media {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.65s var(--va-ease-out);
}

.card:hover .card__image {
	transform: scale(1.07);
}

.card__shine {
	position: absolute;
	inset: 0;
	background: linear-gradient(125deg, transparent 30%, color-mix(in srgb, var(--va-white) 35%, transparent), transparent 70%);
	opacity: 0;
	transition: opacity 0.45s var(--va-ease-out);
	pointer-events: none;
}

.card:hover .card__shine {
	opacity: 1;
}

.card__body {
	padding: 1.45rem 1.65rem 1.65rem;
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	flex: 1;
}

.card__badge {
	margin: 0 0 0.15rem;
	align-self: flex-start;
	padding: 0.28rem 0.65rem;
	border-radius: var(--va-radius-pill);
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--va-void);
	background: linear-gradient(135deg, var(--va-horizon), color-mix(in srgb, var(--va-gold) 70%, var(--va-horizon)));
}

.card__title {
	font-family: var(--va-font-display);
	font-size: clamp(1.25rem, 1vw + 1.05rem, 1.55rem);
	margin: 0;
	line-height: 1.18;
	letter-spacing: -0.02em;
}

.card__title a {
	text-decoration: none;
	color: inherit;
	transition: color 0.2s var(--va-ease-out);
}

.card__title a:hover {
	color: var(--va-ember);
}

.card__meta {
	margin: 0;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--va-ink) 48%, transparent);
}

.card__excerpt {
	margin: 0;
	flex: 1;
	color: color-mix(in srgb, var(--va-ink) 76%, transparent);
	font-size: 1.02rem;
	line-height: 1.55;
}

.card__cta {
	margin: 0.85rem 0 0;
}

.card__cta-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-weight: 800;
	font-size: 0.92rem;
	text-decoration: none;
	color: var(--va-ember);
}

.card__cta-arrow {
	transition: transform 0.25s var(--va-ease-out);
}

.card__cta-link:hover .card__cta-arrow {
	transform: translateX(5px);
}

/* ——— CTA band ——— */
.section--cta {
	padding-block: clamp(4rem, 12vw, 8rem);
}

.cta-band {
	position: relative;
	overflow: hidden;
	background: radial-gradient(90% 120% at 10% 0%, color-mix(in srgb, var(--va-ember) 18%, transparent), transparent 55%), linear-gradient(155deg, #132722, var(--va-void));
	color: var(--va-cream);
}

.cta-band__sky {
	position: absolute;
	inset: 0;
	z-index: 0;
	background:
		radial-gradient(60% 50% at 85% 15%, color-mix(in srgb, var(--va-flame) 22%, transparent), transparent 60%),
		radial-gradient(50% 40% at 20% 80%, color-mix(in srgb, var(--va-fern) 35%, transparent), transparent 65%);
	opacity: 0.95;
	pointer-events: none;
}

.cta-band__blobs {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

.cta-band__blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(50px);
	opacity: 0.4;
}

.cta-band__blob--one {
	width: min(55vw, 480px);
	height: min(55vw, 480px);
	top: -25%;
	left: -10%;
	background: var(--va-ember);
}

.cta-band__blob--two {
	width: min(45vw, 400px);
	height: min(45vw, 400px);
	bottom: -30%;
	right: -5%;
	background: var(--va-horizon);
}

.cta-band__texture {
	position: absolute;
	inset: 0;
	z-index: 0;
	background-image: var(--va-noise-strong);
	opacity: 0.22;
	mix-blend-mode: overlay;
	pointer-events: none;
}

.cta-band::after {
	content: "";
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(
		-35deg,
		transparent,
		transparent 24px,
		color-mix(in srgb, var(--va-cream) 03%, transparent) 24px,
		color-mix(in srgb, var(--va-cream) 03%, transparent) 25px
	);
	pointer-events: none;
	z-index: 1;
}

.cta-band__shell {
	position: relative;
	z-index: 2;
}

.cta-band__panel {
	position: relative;
	border-radius: calc(var(--va-radius-lg) + 8px);
	padding: clamp(2rem, 5vw, 2.75rem);
	background: color-mix(in srgb, var(--va-dusk) 55%, transparent);
	border: 1px solid color-mix(in srgb, var(--va-cream) 14%, transparent);
	box-shadow: 0 40px 100px rgba(0, 0, 0, 0.45);
	backdrop-filter: blur(10px);
}

.cta-band__accent {
	position: absolute;
	top: 0;
	left: clamp(1.5rem, 4vw, 2.5rem);
	right: clamp(1.5rem, 4vw, 2.5rem);
	height: 3px;
	border-radius: 3px;
	background: linear-gradient(90deg, var(--va-ember), var(--va-horizon), var(--va-gold));
	opacity: 0.95;
}

.cta-band__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: clamp(1.75rem, 4vw, 2.5rem);
	padding-top: 0.5rem;
}

.cta-band__kicker {
	margin: 0 0 0.65rem;
	font-family: var(--va-font-label);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--va-flame) 70%, var(--va-cream));
}

.cta-band__title {
	font-family: var(--va-font-hero);
	font-size: clamp(2.1rem, 3.2vw + 1rem, 3.35rem);
	margin: 0 0 0.65rem;
	letter-spacing: -0.03em;
	line-height: 1.03;
	max-width: 18ch;
	font-weight: 400;
}

.cta-band__text {
	margin: 0;
	max-width: 46ch;
	font-size: clamp(1.05rem, 0.45vw + 1rem, 1.2rem);
	line-height: 1.6;
	color: color-mix(in srgb, var(--va-cream) 86%, transparent);
}

.cta-band__note {
	margin: 1rem 0 0;
	font-size: 0.92rem;
	font-style: italic;
	color: color-mix(in srgb, var(--va-cream) 70%, transparent);
}

.cta-band__action {
	margin: 0;
}

/* ——— Newsletter ——— */
.section--overlap-up {
	margin-top: clamp(-3rem, -5vw, -1.5rem);
	position: relative;
	z-index: 2;
}

.newsletter__ambient {
	position: absolute;
	inset: 20% -20% -30% -20%;
	background: radial-gradient(50% 50% at 50% 50%, color-mix(in srgb, var(--va-ember) 12%, transparent), transparent 65%);
	pointer-events: none;
}

.newsletter {
	position: relative;
}

.newsletter__inner {
	position: relative;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: clamp(1.75rem, 4vw, 2.75rem);
	align-items: center;
	padding: clamp(2.25rem, 5vw, 3.25rem);
	background:
		linear-gradient(135deg, color-mix(in srgb, var(--va-white) 92%, var(--va-mist)), var(--va-white));
	border-radius: calc(var(--va-radius-lg) + 10px);
	box-shadow: var(--va-shadow-hover);
	border: 1px solid color-mix(in srgb, var(--va-sand) 55%, transparent);
	overflow: hidden;
}

.newsletter__inner::before {
	content: "";
	position: absolute;
	inset: -1px;
	border-radius: inherit;
	background: linear-gradient(120deg, color-mix(in srgb, var(--va-ember) 25%, transparent), transparent 45%, color-mix(in srgb, var(--va-horizon) 22%, transparent));
	opacity: 0.35;
	pointer-events: none;
}

.newsletter__copy,
.newsletter__form-wrap {
	position: relative;
	z-index: 1;
}

.newsletter__kicker {
	margin: 0 0 0.55rem;
	font-family: var(--va-font-label);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--va-ember);
}

.newsletter__title {
	font-family: var(--va-font-display);
	margin: 0 0 0.55rem;
	font-size: clamp(1.85rem, 2vw + 1rem, 2.45rem);
	letter-spacing: -0.03em;
}

.newsletter__text {
	margin: 0;
	color: color-mix(in srgb, var(--va-ink) 72%, transparent);
	font-size: 1.05rem;
}

.newsletter__form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
}

.newsletter__input {
	flex: 1 1 220px;
	padding: 0.9rem 1.15rem;
	border-radius: var(--va-radius-pill);
	border: 1px solid color-mix(in srgb, var(--va-umber) 18%, transparent);
	font: inherit;
	background: color-mix(in srgb, var(--va-cream) 55%, var(--va-white));
	transition: border-color 0.2s var(--va-ease-out), box-shadow 0.2s var(--va-ease-out);
}

.newsletter__input:focus {
	outline: none;
	border-color: color-mix(in srgb, var(--va-ember) 45%, transparent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--va-horizon) 35%, transparent);
}

.newsletter__hint {
	font-size: 0.85rem;
	color: color-mix(in srgb, var(--va-ink) 52%, transparent);
	margin: 0.85rem 0 0;
}

/* ——— Contact ——— */
.section--dusk {
	background: linear-gradient(180deg, var(--va-cream), color-mix(in srgb, var(--va-mist) 80%, var(--va-cream)));
	padding-bottom: clamp(4.5rem, 12vw, 8rem);
}

.contact-block__wash {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(70% 55% at 100% 0%, color-mix(in srgb, var(--va-canopy) 12%, transparent), transparent 60%),
		var(--va-texture);
	opacity: 0.9;
	pointer-events: none;
}

.contact-block {
	position: relative;
}

.contact-block__panel {
	position: relative;
	z-index: 1;
	border-radius: calc(var(--va-radius-lg) + 8px);
	padding: clamp(2rem, 5vw, 3rem);
	background: var(--va-white);
	border: 1px solid color-mix(in srgb, var(--va-umber) 10%, transparent);
	box-shadow: var(--va-shadow);
}

.contact-block__kicker {
	margin: 0 0 0.55rem;
	font-family: var(--va-font-label);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--va-ember);
}

.contact-block__title {
	font-family: var(--va-font-hero);
	font-size: clamp(2.1rem, 2.8vw + 1rem, 2.95rem);
	margin: 0 0 1rem;
	letter-spacing: -0.03em;
	font-weight: 400;
}

.contact-block__intro {
	margin-bottom: 1.35rem;
	color: color-mix(in srgb, var(--va-ink) 76%, transparent);
	font-size: 1.05rem;
	line-height: 1.6;
}

.contact-block__list {
	margin: 0;
	display: grid;
	gap: 1.1rem;
}

.contact-block__row {
	display: grid;
	grid-template-columns: minmax(100px, 170px) 1fr;
	gap: 0.75rem 1.5rem;
	align-items: baseline;
	padding: 1rem 0;
	border-bottom: 1px solid color-mix(in srgb, var(--va-umber) 10%, transparent);
}

.contact-block__row:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.contact-block__row dt {
	font-weight: 800;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: color-mix(in srgb, var(--va-ink) 48%, transparent);
}

.contact-block__row dd {
	margin: 0;
	font-size: 1.05rem;
}

@media (max-width: 520px) {
	.contact-block__row {
		grid-template-columns: 1fr;
	}
}

/* ——— Archives & lists ——— */
.content-area {
	padding: clamp(3rem, 8vw, 5rem) 0 clamp(4.5rem, 12vw, 7rem);
}

.content-area--lifted {
	margin-top: clamp(-2.5rem, -4vw, -1rem);
	position: relative;
	z-index: 2;
	padding-top: clamp(2rem, 5vw, 3rem);
	background: linear-gradient(180deg, color-mix(in srgb, var(--va-cream) 92%, transparent), var(--va-cream));
	border-radius: var(--va-radius-lg) var(--va-radius-lg) 0 0;
	box-shadow: 0 -24px 60px rgba(12, 10, 9, 0.12);
}

.content-area--archive {
	position: relative;
	padding-left: clamp(0.75rem, 2.5vw, 1.5rem);
	margin-left: clamp(0rem, 1.5vw, 0.75rem);
}

.content-area--archive::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	border-radius: 2px;
	background: linear-gradient(180deg, var(--va-ember), var(--va-horizon) 42%, color-mix(in srgb, var(--va-umber) 35%, transparent) 100%);
	pointer-events: none;
}

.archive-header {
	margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
	max-width: 56ch;
	padding-top: 0.35rem;
}

.archive-kicker {
	margin: 0 0 0.75rem;
	font-family: var(--va-font-label);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--va-ember);
}

.archive-title {
	font-family: var(--va-font-hero);
	font-size: clamp(2.5rem, 4vw + 1rem, 3.85rem);
	margin: 0 0 0.85rem;
	letter-spacing: -0.03em;
	line-height: 1.04;
	font-weight: 400;
}

.archive-description {
	margin: 0;
	font-size: 1.08rem;
	line-height: 1.6;
	color: color-mix(in srgb, var(--va-ink) 72%, transparent);
}

/* Entry cards — editorial rail, not “WP cards” */
.post-list {
	counter-reset: va-rail;
	display: grid;
	gap: clamp(2.25rem, 5vw, 3.5rem);
}

.entry--card {
	counter-increment: va-rail;
	display: grid;
	grid-template-columns: minmax(0, 1.12fr) minmax(0, 1.45fr);
	gap: clamp(1.35rem, 3vw, 2.25rem);
	align-items: center;
	padding: clamp(1.5rem, 3vw, 2rem) 0 clamp(2.25rem, 5vw, 3rem);
	padding-left: clamp(2.75rem, 5vw, 3.75rem);
	border-bottom: 1px solid color-mix(in srgb, var(--va-umber) 14%, transparent);
	position: relative;
	background: transparent;
}

.entry--card::before {
	content: counter(va-rail, decimal-leading-zero);
	position: absolute;
	left: 0;
	top: clamp(1.5rem, 3vw, 2rem);
	font-family: var(--va-font-hero);
	font-size: clamp(2rem, 3.5vw, 2.85rem);
	line-height: 1;
	font-weight: 400;
	color: color-mix(in srgb, var(--va-ember) 28%, transparent);
	letter-spacing: -0.04em;
	pointer-events: none;
}

.entry--card::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -1px;
	width: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--va-ember), var(--va-horizon));
	transition: width 0.5s var(--va-ease-out);
}

.entry--card:hover::after {
	width: 100%;
}

.entry--card:last-child {
	border-bottom: none;
}

.entry--card:last-child::after {
	display: none;
}

.entry__thumb-link {
	position: relative;
	border-radius: 0;
	overflow: hidden;
	box-shadow: none;
	border: 1px solid color-mix(in srgb, var(--va-umber) 16%, transparent);
	clip-path: polygon(0 0, 100% 2%, 100% 100%, 0 98%);
	transition: transform 0.35s var(--va-ease-out), border-color 0.35s var(--va-ease-out);
}

.entry__thumb-link:hover {
	transform: translateY(-3px);
	border-color: color-mix(in srgb, var(--va-ember) 45%, transparent);
	box-shadow: 0 20px 50px rgba(12, 10, 9, 0.12);
}

.entry__image {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	transition: transform 0.6s var(--va-ease-out);
}

.entry__thumb-link:hover .entry__image {
	transform: scale(1.05);
}

.entry__shine {
	position: absolute;
	inset: 0;
	background: linear-gradient(125deg, transparent 25%, color-mix(in srgb, var(--va-white) 40%, transparent), transparent 75%);
	opacity: 0;
	transition: opacity 0.4s var(--va-ease-out);
	pointer-events: none;
}

.entry__thumb-link:hover .entry__shine {
	opacity: 1;
}

.entry__header .entry__title {
	font-family: var(--va-font-hero);
	font-size: clamp(1.5rem, 1.4vw + 1.05rem, 2.05rem);
	margin: 0 0 0.55rem;
	line-height: 1.12;
	letter-spacing: -0.03em;
	font-weight: 400;
}

.entry__header .entry__title a {
	text-decoration: none;
	color: inherit;
	transition: color 0.2s var(--va-ease-out);
}

.entry__header .entry__title a:hover {
	color: var(--va-ember);
}

.entry__meta {
	font-size: 0.88rem;
	font-weight: 600;
	color: color-mix(in srgb, var(--va-ink) 52%, transparent);
}

.entry__summary {
	margin: 0.85rem 0 0;
	color: color-mix(in srgb, var(--va-ink) 76%, transparent);
	font-size: 1.05rem;
	line-height: 1.6;
}

.entry__more {
	margin: 1.15rem 0 0;
}

.entry__more-link {
	font-weight: 800;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.entry__more-link::after {
	content: "→";
	transition: transform 0.25s var(--va-ease-out);
}

.entry__more-link:hover::after {
	transform: translateX(5px);
}

@media (max-width: 720px) {
	.entry--card {
		grid-template-columns: 1fr;
		padding-left: 0;
		padding-top: clamp(2.5rem, 8vw, 3rem);
	}

	.entry--card::before {
		top: 0;
		left: 0;
		font-size: clamp(2.5rem, 12vw, 3.25rem);
		opacity: 0.85;
	}
}

/* Single & page */
.entry__header--page,
.entry__header--single {
	margin-bottom: 1.75rem;
}

.entry__header--single .entry__title {
	font-family: var(--va-font-hero);
	font-size: clamp(2.45rem, 4.2vw + 1rem, 3.5rem);
	margin: 0 0 0.85rem;
	line-height: 1.04;
	letter-spacing: -0.03em;
	font-weight: 400;
}

.entry__meta--single {
	font-size: 0.95rem;
	font-weight: 600;
	color: color-mix(in srgb, var(--va-ink) 55%, transparent);
}

.entry__featured {
	margin: 0 0 2.25rem;
	border-radius: calc(var(--va-radius-lg) + 8px);
	overflow: hidden;
	box-shadow: var(--va-shadow-hover);
	border: 1px solid color-mix(in srgb, var(--va-umber) 10%, transparent);
}

.entry__featured--single .entry__featured-image {
	width: 100%;
	max-height: min(72vh, 680px);
	object-fit: cover;
}

.entry__footer {
	margin-top: 2.75rem;
	padding-top: 1.75rem;
	border-top: 1px solid color-mix(in srgb, var(--va-umber) 12%, transparent);
	font-size: 0.95rem;
	color: color-mix(in srgb, var(--va-ink) 68%, transparent);
}

.entry__footer .cat-links,
.entry__footer .tags-links {
	display: inline-block;
	margin-right: 1rem;
}

/* Prose */
.prose--editorial {
	font-size: clamp(1.05rem, 0.35vw + 1rem, 1.15rem);
}

@media (min-width: 600px) {
	.prose--editorial > p:first-of-type:first-letter {
		float: left;
		font-family: var(--va-font-hero);
		font-size: 3.4em;
		line-height: 0.82;
		padding-right: 0.14em;
		margin-top: 0.06em;
		font-weight: 400;
		color: var(--va-ember);
	}
}

.prose > *:first-child {
	margin-top: 0;
}

.prose > *:last-child {
	margin-bottom: 0;
}

.prose h2,
.prose h3,
.prose h4 {
	font-family: var(--va-font-display);
	line-height: 1.15;
	margin-top: 2.5rem;
	letter-spacing: -0.02em;
}

.prose p,
.prose ul,
.prose ol,
.prose blockquote,
.prose figure {
	margin: 0 0 1.35rem;
}

.prose blockquote {
	border-left: 4px solid var(--va-horizon);
	padding: 0.35rem 0 0.35rem 1.35rem;
	color: color-mix(in srgb, var(--va-ink) 78%, transparent);
	font-style: italic;
	background: color-mix(in srgb, var(--va-mist) 45%, transparent);
	border-radius: 0 var(--va-radius) var(--va-radius) 0;
}

.prose .alignwide {
	width: min(1280px, 92vw);
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
}

.prose .alignfull {
	width: 100vw;
	max-width: none;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	box-sizing: border-box;
}

.wp-block-image figcaption,
.wp-block-embed figcaption {
	font-size: 0.9rem;
	color: color-mix(in srgb, var(--va-ink) 58%, transparent);
}

/* Pagination */
.pagination,
.nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	justify-content: center;
	margin-top: clamp(2.5rem, 6vw, 3.5rem);
}

.pagination .page-numbers,
.nav-links a {
	display: inline-flex;
	min-width: 2.65rem;
	height: 2.65rem;
	align-items: center;
	justify-content: center;
	padding: 0 0.75rem;
	border-radius: var(--va-radius);
	text-decoration: none;
	font-weight: 700;
	background: var(--va-white);
	border: 1px solid color-mix(in srgb, var(--va-umber) 16%, transparent);
	color: var(--va-ink);
	box-shadow: 0 8px 22px rgba(12, 10, 9, 0.06);
	transition: transform 0.2s var(--va-ease-out), box-shadow 0.2s var(--va-ease-out), border-color 0.2s var(--va-ease-out);
}

.pagination .page-numbers:hover,
.nav-links a:hover {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--va-ember) 35%, transparent);
}

.pagination .page-numbers.current,
.nav-links span.post-page-numbers.current {
	background: linear-gradient(135deg, var(--va-ember), color-mix(in srgb, var(--va-flame) 65%, var(--va-ember)));
	color: var(--va-white);
	border-color: transparent;
	box-shadow: 0 14px 36px color-mix(in srgb, var(--va-ember) 35%, transparent);
}

/* Post navigation */
.post-navigation {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.15rem;
	margin-top: clamp(2.75rem, 6vw, 3.75rem);
	padding-top: 2.25rem;
	border-top: 1px solid color-mix(in srgb, var(--va-umber) 12%, transparent);
}

.post-navigation a {
	text-decoration: none;
	display: block;
	padding: 1.15rem 1.35rem;
	border-radius: calc(var(--va-radius) + 4px);
	background: var(--va-white);
	border: 1px solid color-mix(in srgb, var(--va-umber) 11%, transparent);
	box-shadow: 0 14px 40px rgba(12, 10, 9, 0.08);
	transition: transform 0.25s var(--va-ease-out), box-shadow 0.25s var(--va-ease-out), border-color 0.25s var(--va-ease-out);
}

.post-navigation a:hover {
	transform: translateY(-4px);
	box-shadow: var(--va-shadow-hover);
	border-color: color-mix(in srgb, var(--va-ember) 28%, transparent);
}

.nav-subtitle {
	display: block;
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: color-mix(in srgb, var(--va-ink) 48%, transparent);
	margin-bottom: 0.4rem;
}

.nav-title {
	font-family: var(--va-font-display);
	font-weight: 600;
	font-size: 1.08rem;
	color: var(--va-ink);
	transition: color 0.2s var(--va-ease-out);
}

.post-navigation a:hover .nav-title {
	color: var(--va-ember);
}

/* Search */
.search-form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	margin: 1.15rem 0;
}

.search-form__input {
	flex: 1 1 240px;
	padding: 0.9rem 1.15rem;
	border-radius: var(--va-radius-pill);
	border: 1px solid color-mix(in srgb, var(--va-umber) 18%, transparent);
	font: inherit;
	background: var(--va-white);
	transition: border-color 0.2s var(--va-ease-out), box-shadow 0.2s var(--va-ease-out);
}

.search-form__input:focus {
	outline: none;
	border-color: color-mix(in srgb, var(--va-ember) 40%, transparent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--va-horizon) 30%, transparent);
}

/* Footer */
.site-footer {
	position: relative;
	padding: clamp(3rem, 8vw, 4.5rem) 0 clamp(3.25rem, 9vw, 4.75rem);
	background:
		radial-gradient(80% 120% at 50% 0%, color-mix(in srgb, var(--va-ember) 10%, transparent), transparent 55%),
		linear-gradient(180deg, var(--va-dusk), var(--va-void));
	color: color-mix(in srgb, var(--va-cream) 88%, transparent);
	border-top: 1px solid color-mix(in srgb, var(--va-cream) 10%, transparent);
	overflow: hidden;
}

.site-footer__horizon {
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--va-ember), var(--va-horizon), var(--va-gold), transparent);
	opacity: 0.85;
	pointer-events: none;
}

.site-footer__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.35rem;
	text-align: center;
}

.menu--footer {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem 1.75rem;
	justify-content: center;
}

.menu--footer a {
	text-decoration: none;
	font-weight: 700;
	color: var(--va-cream);
	letter-spacing: 0.02em;
	transition: color 0.2s var(--va-ease-out);
}

.menu--footer a:hover {
	color: var(--va-flame);
}

.site-footer__credit {
	margin: 0;
	font-size: 0.88rem;
	color: color-mix(in srgb, var(--va-cream) 55%, transparent);
}

/* Comments */
.comments-area {
	margin-top: clamp(2.75rem, 6vw, 3.75rem);
	padding-top: 2.25rem;
	border-top: 1px solid color-mix(in srgb, var(--va-umber) 12%, transparent);
}

.comments-title {
	font-family: var(--va-font-display);
	font-size: clamp(1.55rem, 1.5vw + 1rem, 1.85rem);
	letter-spacing: -0.02em;
}

.comment-list {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
}

.comment-body {
	margin-bottom: 1.25rem;
	padding: 1.15rem 1.35rem;
	background: var(--va-white);
	border-radius: var(--va-radius);
	border: 1px solid color-mix(in srgb, var(--va-umber) 10%, transparent);
	box-shadow: 0 10px 28px rgba(12, 10, 9, 0.06);
}

/* Front page content */
.front-page__content {
	padding-bottom: clamp(2.5rem, 7vw, 4.5rem);
	position: relative;
	z-index: 1;
}

/* 404 */
.error-404 .page-title {
	font-family: var(--va-font-display);
	font-size: clamp(2.25rem, 3.5vw + 1rem, 3rem);
	letter-spacing: -0.03em;
}
