:root {
	--site-header-offset: 104px;
}

body.has-page-background {
	background: var(--page-background-base);
}

body.has-page-background::after {
	content: "";
	position: fixed;
	inset: -4%;
	pointer-events: none;
	z-index: 0;
	background-color: var(--page-background-base);
	background-image: var(--page-background-image);
	background-position: var(--page-background-position);
	background-repeat: no-repeat;
	background-size: cover;
	transform: scale(1.04);
	transform-origin: center;
	will-change: opacity;
}

body.has-page-background::before {
	z-index: 1;
	background-image: linear-gradient(180deg, var(--page-background-overlay), rgba(14, 10, 8, calc(var(--page-background-overlay-strength) + 0.08)));
	background-size: auto;
	opacity: 1;
}

body.has-page-background .site-shell::before,
body.has-page-background .site-shell::after {
	display: none;
}

body.page-background--effect-static-soft.has-page-background::after {
	opacity: 0.98;
	filter: saturate(0.96) contrast(0.94);
}

body.page-background--effect-soft-parallax.has-page-background::after {
	animation: spv-page-background-float 24s ease-in-out infinite alternate;
	filter: saturate(0.98) contrast(0.94);
}

body.page-background--effect-mist.has-page-background::after {
	animation: spv-page-background-mist 28s ease-in-out infinite alternate;
	filter: saturate(0.94) contrast(0.92);
}

body.page-background--effect-soft-contrast.has-page-background::before {
	background-image: linear-gradient(180deg, var(--page-background-overlay), rgba(14, 10, 8, calc(var(--page-background-overlay-strength) + 0.06)));
	background-size: auto;
}

body.page-background--effect-soft-contrast.has-page-background::after {
	filter: saturate(0.94) contrast(0.93);
}

.site-shell {
	position: relative;
	min-height: 100vh;
	padding: var(--site-header-offset) 0 36px;
}

.site-shell::before,
.site-shell::after {
	content: "";
	position: fixed;
	inset: auto;
	pointer-events: none;
	filter: blur(34px);
	z-index: 0;
}

.site-shell::before {
	top: 9rem;
	right: 2rem;
	width: 12rem;
	height: 12rem;
	background: radial-gradient(circle, var(--shell-top-glow), transparent 70%);
}

.site-shell::after {
	left: 0;
	bottom: 10%;
	width: 14rem;
	height: 14rem;
	background: radial-gradient(circle, var(--shell-bottom-glow), transparent 72%);
}

@keyframes spv-page-background-float {
	0% { transform: scale(1.05) translate3d(0, 0, 0); }
	100% { transform: scale(1.1) translate3d(0, -1.5%, 0); }
}

@keyframes spv-page-background-mist {
	0% {
		transform: scale(1.06) translate3d(-0.6%, 0, 0);
		opacity: 0.94;
	}

	100% {
		transform: scale(1.12) translate3d(0.8%, -1.4%, 0);
		opacity: 1;
	}
}

.site-header,
.site-main,
.site-footer {
	position: relative;
	z-index: 2;
}

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 50;
	padding: 8px 0 0;
	transition:
		padding-top var(--motion-duration-base) var(--motion-soft-ease),
		transform var(--motion-duration-base) var(--motion-soft-ease);
}

.site-header__inner,
.site-footer__inner,
.content-frame,
.journal-stream {
	width: min(calc(100% - 40px), var(--content-width));
	margin: 0 auto;
}

.site-header__inner {
	position: relative;
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 18px;
	padding: var(--header-shell-padding);
	background: var(--header-bg);
	border: 1px solid var(--header-border);
	border-radius: var(--header-shell-radius);
	box-shadow: var(--header-shadow);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	overflow: hidden;
	transition:
		padding 420ms cubic-bezier(0.2, 0.9, 0.22, 1),
		border-radius 460ms cubic-bezier(0.18, 1.08, 0.3, 1),
		background-color 360ms var(--motion-ease),
		border-color 360ms var(--motion-ease),
		box-shadow 420ms cubic-bezier(0.2, 0.9, 0.22, 1),
		transform 420ms cubic-bezier(0.2, 0.9, 0.22, 1);
}

.site-header__inner::before,
.site-header__inner::after {
	content: "";
	position: absolute;
	inset: auto;
	pointer-events: none;
	z-index: 0;
}

.site-header__inner::before {
	inset: -38% -12%;
	background:
		radial-gradient(circle 13rem at var(--mx, 50%) var(--my, 50%), rgba(255, 244, 231, 0.42), transparent 34%),
		radial-gradient(circle at 22% 30%, var(--header-glow-a), transparent 42%),
		radial-gradient(circle at center, var(--header-glow-a), transparent 68%);
	filter: blur(22px);
	opacity: 0.62;
	transition: opacity 220ms var(--motion-ease);
}

.site-header__inner:hover::before,
.site-header__inner:focus-within::before {
	opacity: 0.96;
}

.site-header__inner::after {
	inset: 1px;
	border-radius: inherit;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.04));
	opacity: 0.46;
}

.site-header__inner > * {
	position: relative;
	z-index: 1;
	min-width: 0;
	max-width: 100%;
}

.site-branding {
	min-width: 0;
	display: grid;
	gap: 4px;
	transition: gap var(--motion-duration-base) var(--motion-ease);
}

.site-branding__logo {
	display: inline-flex;
	align-items: center;
	min-width: 0;
}

.site-branding__logo .custom-logo-link {
	display: inline-flex;
	align-items: center;
	max-width: 100%;
	text-decoration: none;
}

.site-branding__logo .custom-logo {
	display: block;
	width: auto;
	max-width: min(100%, 220px);
	max-height: 58px;
	height: auto;
}

.site-branding__title {
	display: inline-block;
	font-family: var(--display-font);
	font-size: clamp(1.28rem, 1.66vw, 1.62rem);
	font-weight: 700;
	line-height: 0.88;
	letter-spacing: 0.045em;
	text-decoration: none;
	min-width: 0;
	max-width: 100%;
	overflow-wrap: anywhere;
	text-wrap: balance;
	transition: transform var(--motion-duration-base) var(--motion-ease);
}

.site-branding__tagline {
	margin: 0;
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.19em;
	text-transform: uppercase;
	color: var(--text-muted);
	transition:
		opacity var(--motion-duration-base) var(--motion-ease),
		transform var(--motion-duration-base) var(--motion-ease),
		letter-spacing var(--motion-duration-base) var(--motion-ease);
}

.site-header.is-scrolled,
.site-header.is-pinned {
	top: 0;
	padding-top: 0;
}

.site-header.is-scrolled .site-header__inner {
	padding: 8px 12px 8px 14px;
	background: var(--header-scrolled-bg);
	border-color: var(--header-scrolled-border);
	box-shadow: var(--header-scrolled-shadow);
	transform: translateY(-1px);
}
.site-header.is-scrolled .site-branding { gap: 2px; }
.site-header.is-scrolled .site-branding__title { transform: translateY(-1px); }
.site-header.is-scrolled .site-branding__logo .custom-logo { max-height: 52px; }
.site-header.is-scrolled .site-branding__tagline {
	opacity: 0.68;
	letter-spacing: 0.15em;
	transform: translateY(-1px);
}

.site-navigation { min-width: 0; max-width: 100%; }
.site-navigation__panel { display: contents; min-width: 0; max-width: 100%; }
.site-navigation__meta { display: none; }

.site-navigation__eyebrow,
.site-footer__eyebrow,
.section-kicker,
.post-card__date,
.site-footer__heading {
	margin: 0 0 10px;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--text-muted);
}

.site-navigation__summary {
	margin: 0;
	font-size: 0.9rem;
	line-height: 1.5;
	color: var(--text-muted);
}

.site-menu,
.site-footer__menu {
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.site-menu { justify-content: center; flex-wrap: nowrap; min-width: 0; max-width: 100%; }
.site-menu > li > a,
.site-footer__menu a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
}

.site-menu > li { list-style: none; min-width: 0; max-width: 100%; }

.site-menu > li > a {
	padding: 0.62rem 0.8rem;
	border-radius: 999px;
	color: var(--text-secondary);
	font-size: 0.84rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	white-space: nowrap;
	min-width: 0;
	max-width: 100%;
	transition:
		color var(--motion-duration-fast) var(--motion-ease),
		background-color var(--motion-duration-fast) var(--motion-ease),
		transform var(--motion-duration-fast) var(--motion-ease);
}

.site-menu > li > a:hover,
.site-menu > li > a:focus-visible {
	color: var(--text-primary);
	background: var(--menu-hover-bg);
	transform: translateY(-2px);
}

.site-menu .current-menu-item > a,
.site-menu .current-menu-ancestor > a,
.site-menu .current_page_item > a,
.site-menu .current_page_ancestor > a {
	color: var(--text-primary);
	background: rgba(255, 251, 246, 0.84);
	transform: none;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.74), inset 0 0 0 1px var(--menu-active-line), 0 3px 8px rgba(162, 85, 40, 0.05);
}

.site-menu .current-menu-item > a::after,
.site-menu .current-menu-ancestor > a::after,
.site-menu .current_page_item > a::after,
.site-menu .current_page_ancestor > a::after { content: none; }

.header-cta,
.site-navigation__cta,
.site-footer__brief {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 46px;
	padding: 0.8rem 1.14rem;
	background:
		linear-gradient(180deg, rgba(255, 248, 241, 0.42), rgba(244, 228, 213, 0.26)),
		radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.16), transparent 42%);
	border: 1px solid rgba(214, 176, 144, 0.3);
	border-radius: 999px;
	color: var(--calm-cta-text);
	font-size: 0.92rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	text-decoration: none;
	min-width: 0;
	max-width: 100%;
	box-shadow:
		0 10px 24px rgba(41, 23, 10, 0.06),
		inset 0 1px 0 rgba(255, 255, 255, 0.18);
	backdrop-filter: blur(8px) saturate(1.02);
	-webkit-backdrop-filter: blur(8px) saturate(1.02);
	transition:
		opacity var(--motion-duration-fast) var(--motion-ease),
		border-color var(--motion-duration-fast) var(--motion-ease),
		transform var(--motion-duration-fast) var(--motion-ease),
		box-shadow var(--motion-duration-fast) var(--motion-ease),
		background-color var(--motion-duration-fast) var(--motion-ease);
}

.header-cta:hover,
.header-cta:focus-visible,
.site-navigation__cta:hover,
.site-navigation__cta:focus-visible,
.site-footer__brief:hover,
.site-footer__brief:focus-visible {
	transform: translateY(-1px);
	box-shadow: 0 12px 22px rgba(41, 23, 10, 0.07);
	opacity: 1;
}

.site-nav-toggle,
.site-navigation__cta { display: none; }

.site-nav-toggle {
	position: relative;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-width: 48px;
	min-height: 48px;
	padding: 0.72rem 0.95rem;
	border-radius: 999px;
	border: 1px solid var(--header-control-border);
	background: var(--header-control-bg);
	color: var(--text-primary);
	font: inherit;
	max-width: 100%;
	box-shadow: var(--header-control-shadow);
	z-index: 3;
	transition:
		background-color var(--motion-duration-fast) var(--motion-ease),
		border-color var(--motion-duration-fast) var(--motion-ease),
		box-shadow var(--motion-duration-fast) var(--motion-ease),
		transform var(--motion-duration-fast) var(--motion-ease);
}

.site-nav-toggle:hover,
.site-nav-toggle:focus-visible {
	background: var(--header-control-bg-hover);
	border-color: var(--header-control-border-hover);
	box-shadow: var(--header-control-shadow-hover);
	transform: translateY(-1px);
}

.site-nav-toggle__label {
	font-size: 0.88rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.site-nav-toggle__icon {
	position: relative;
	display: inline-block;
	width: 1rem;
	height: 1rem;
	flex: 0 0 auto;
}

.site-nav-toggle__icon::before,
.site-nav-toggle__icon::after {
	content: "";
	position: absolute;
	left: 0.12rem;
	width: 0.78rem;
	height: 2px;
	background: currentColor;
	border-radius: 999px;
	transform-origin: left center;
	transition:
		transform 260ms cubic-bezier(0.22, 0.86, 0.24, 1),
		top 220ms cubic-bezier(0.22, 0.86, 0.24, 1),
		left 220ms cubic-bezier(0.22, 0.86, 0.24, 1),
		width 220ms cubic-bezier(0.22, 0.86, 0.24, 1),
		opacity 180ms ease-out;
}

.site-nav-toggle__icon::before { top: 0.31rem; }
.site-nav-toggle__icon::after { top: 0.63rem; }
.site-header.is-menu-open .site-nav-toggle__icon::before {
	top: 0.49rem;
	left: 0.18rem;
	width: 0.68rem;
	opacity: 0.96;
	transform: rotate(-42deg);
}
.site-header.is-menu-open .site-nav-toggle__icon::after {
	top: 0.49rem;
	left: 0.18rem;
	width: 0.68rem;
	opacity: 0.96;
	transform: rotate(42deg);
}

.site-main { padding: clamp(42px, 6vw, 88px) 0 104px; }
.content-frame { display: grid; gap: 40px; }
.content-frame--front { padding-top: 8px; }

@media (max-width: 960px) {
	.site-header {
		top: 0;
		padding-top: 0;
	}

	.site-header__inner {
		--header-shell-radius: 0 0 30px 30px;
		--header-shell-padding: 12px 16px;
		--header-bg: linear-gradient(135deg, rgba(255, 251, 246, 0.44), rgba(246, 239, 232, 0.3));
		--header-border: rgba(255, 255, 255, 0.22);
		--header-shadow: 0 14px 28px rgba(36, 23, 17, 0.034), 0 4px 10px rgba(36, 23, 17, 0.01);
		--header-control-bg: rgba(255, 251, 246, 0.72);
		--header-control-bg-hover: rgba(255, 251, 246, 0.82);
		--header-control-border: rgba(255, 255, 255, 0.4);
		--header-control-border-hover: rgba(255, 255, 255, 0.54);
		--header-control-shadow: 0 8px 18px rgba(36, 23, 17, 0.038);
		--header-control-shadow-hover: 0 10px 22px rgba(36, 23, 17, 0.055);
		display: grid;
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-areas:
			"branding toggle"
			"nav nav";
		align-items: center;
		row-gap: 0;
		column-gap: 12px;
		overflow: hidden;
	}

	.site-header.is-menu-open .site-header__inner {
		--header-bg: linear-gradient(135deg, rgba(255, 251, 246, 0.46), rgba(246, 239, 232, 0.32));
		--header-border: rgba(255, 255, 255, 0.24);
		--header-shadow: 0 16px 32px rgba(36, 23, 17, 0.038), 0 4px 10px rgba(36, 23, 17, 0.011);
		--header-shell-radius: 0 0 38px 38px;
		transform: translateY(-1px);
	}

	.site-branding {
		grid-area: branding;
	}

	.site-navigation {
		grid-area: nav;
		position: static;
		min-width: 0;
		max-width: 100%;
	}

	.site-nav-toggle {
		grid-area: toggle;
		display: inline-flex;
		gap: 0;
		width: 48px;
		min-width: 48px;
		padding: 0;
	}

	.site-nav-toggle__label {
		display: none;
	}

	.header-cta {
		display: none;
	}

	.site-navigation__panel {
		display: grid;
		grid-template-columns: 1fr;
		align-content: start;
		gap: 14px;
		width: 100%;
		min-width: 0;
		max-width: 100%;
		padding: 0;
		border: 0;
		border-radius: 0;
		background: transparent;
		box-shadow: none;
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		opacity: 0;
		transform: translateY(-10px) scale(0.985);
		transform-origin: top center;
		transition:
			transform 480ms cubic-bezier(0.2, 0.9, 0.22, 1),
			opacity 330ms ease-out,
			visibility 330ms ease-out;
	}

	.site-navigation__meta {
		display: grid;
		gap: 6px;
		padding-top: 14px;
		padding-bottom: 10px;
		border-top: 1px solid rgba(111, 63, 34, 0.1);
	}

	.site-navigation__eyebrow {
		margin-bottom: 2px;
		font-size: 0.66rem;
		letter-spacing: 0.22em;
		color: rgba(119, 99, 85, 0.9);
	}

	.site-navigation__summary {
		font-size: 0.92rem;
		line-height: 1.45;
		color: rgba(78, 49, 37, 0.78);
	}

	.site-navigation__cta {
		display: inline-flex;
		width: 100%;
		justify-content: center;
		min-height: 50px;
	}

	.site-menu {
		display: grid;
		grid-template-columns: 1fr;
		gap: 10px;
		justify-content: stretch;
	}

	.site-menu > li {
		opacity: 0;
		transform: translateY(10px) scale(0.985);
		filter: blur(6px);
		transition:
			transform 480ms cubic-bezier(0.18, 0.88, 0.22, 1),
			opacity 330ms ease-out,
			filter 450ms ease-out;
		transition-delay: var(--menu-item-delay, 0ms);
		will-change: transform, opacity, filter;
	}

	.site-menu > li > a {
		justify-content: flex-start;
		width: 100%;
		min-height: 50px;
		padding: 0.92rem 1rem;
		white-space: normal;
		overflow-wrap: anywhere;
		background: linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 248, 241, 0.06));
		border: 1px solid rgba(255, 255, 255, 0.1);
		border-radius: 18px;
		font-size: 0.98rem;
		font-weight: 600;
		color: rgba(33, 21, 16, 0.88);
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 6px 14px rgba(18, 10, 7, 0.03);
		transition:
			background-color var(--motion-duration-fast) var(--motion-ease),
			border-color var(--motion-duration-fast) var(--motion-ease),
			box-shadow var(--motion-duration-fast) var(--motion-ease);
	}

	.site-menu > li > a:hover,
	.site-menu > li > a:focus-visible,
	.site-menu > li > a:active {
		background: linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 248, 241, 0.1));
		border-color: rgba(239, 208, 181, 0.18);
		box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 8px 16px rgba(18, 10, 7, 0.045);
		transform: none;
	}

	.has-js .site-navigation {
		overflow: hidden;
		max-height: 0;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition:
			max-height 630ms cubic-bezier(0.2, 0.9, 0.22, 1),
			opacity 330ms ease-out,
			visibility 270ms var(--motion-ease);
	}

	.site-header.is-menu-open .site-navigation {
		max-height: 36rem;
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		padding-top: 12px;
	}

	.site-header.is-menu-open .site-navigation__panel {
		opacity: 1;
		transform: translateY(0) scale(1);
	}

	.site-header.is-menu-open .site-menu > li {
		opacity: 1;
		transform: translateY(0) scale(1);
		filter: blur(0);
	}

	.site-header.is-menu-open .site-branding__tagline {
		opacity: 0.78;
	}

	.site-header.is-scrolled .site-header__inner {
		padding: var(--header-shell-padding);
		transform: none;
	}

	.site-header.is-scrolled .site-branding {
		gap: 4px;
	}

	.site-header.is-scrolled .site-branding__title,
	.site-header.is-scrolled .site-branding__tagline {
		transform: none;
	}

	.site-header.is-scrolled .site-branding__logo .custom-logo {
		max-height: 58px;
	}

	.site-header.is-scrolled .site-branding__tagline {
		opacity: 1;
		letter-spacing: 0.19em;
	}

	.site-nav-toggle:focus-visible,
	.site-navigation__cta:focus-visible {
		outline: 2px solid rgba(162, 85, 40, 0.48);
		outline-offset: 2px;
	}
}

@media (max-width: 960px), (prefers-reduced-motion: reduce) {
	.site-header__inner::before {
		display: none;
	}
}

@media (max-width: 640px) {
	.site-header__inner,
	.site-footer__inner,
	.content-frame,
	.journal-stream {
		width: min(calc(100% - 20px), var(--content-width));
	}

	.site-header__inner {
		--header-shell-padding: 9px 12px;
		column-gap: 8px;
	}

	.site-branding__tagline,
	.site-navigation__meta {
		display: none;
	}

	.site-nav-toggle {
		width: 46px;
		min-width: 46px;
		min-height: 46px;
		padding: 0.68rem 0.78rem;
	}

	.site-branding__title {
		font-size: clamp(1.18rem, 5.8vw, 1.34rem);
		line-height: 0.9;
		letter-spacing: 0.035em;
	}

	.site-branding__logo .custom-logo {
		max-width: min(100%, 168px);
		max-height: 42px;
	}

	.site-navigation__panel {
		gap: 12px;
	}

	.site-header.is-menu-open .site-navigation {
		max-height: 30rem;
		padding-top: 8px;
	}

	.site-menu > li > a {
		min-height: 46px;
		padding: 0.82rem 0.92rem;
		font-size: 0.93rem;
		border-radius: 16px;
	}

}
