/* Brand Mention Tracking Agency — light theme from palette: #789DBC #FFE3E3 #FEF9F2 #C9E9D2 */
:root {
	/* Rem baseline: 100% × scale (default 16px root → smaller rem clamps site-wide). */
	--bmta-type-scale: 0.8;

	/* Base swatches */
	--c-blue: #789dbc;
	--c-blue-dark: #5f84a8;
	--c-blue-deep: #4a6d8f;
	--c-blue-light: #a8c4dd;
	--c-blush: #ffe3e3;
	--c-blush-deep: #ffd6d6;
	--c-blush-soft: #fff5f5;
	--c-cream: #fef9f2;
	--c-cream-deep: #f5ebe3;
	--c-mint: #c9e9d2;
	--c-mint-deep: #aedcc0;
	--c-mint-soft: #e8f5ec;

	--canvas: var(--c-cream);
	--wash-a: var(--c-blush-soft);
	--wash-b: #fcf4f0;
	--wash-c: var(--c-mint-soft);

	--bg: var(--canvas);
	--surface: rgba(254, 249, 242, 0.92);
	--surface-hot: #ffffff;

	--glass-edge: rgba(255, 255, 255, 0.72);
	--glass-shade: rgba(74, 109, 143, 0.06);

	--line: rgba(74, 109, 143, 0.12);
	--line-strong: rgba(74, 109, 143, 0.2);

	--text: #2c3a47;
	--text-muted: #5c6b78;
	--text-faint: #8a96a3;

	--accent: var(--c-blue);
	--accent-2: var(--c-blue-light);
	--accent-hover: var(--c-blue-dark);
	--accent-muted: #9eb6cc;
	--accent-soft: rgba(120, 157, 188, 0.2);

	--shadow-sm: 0 4px 24px rgba(74, 109, 143, 0.07);
	--shadow-md: 0 12px 48px rgba(74, 109, 143, 0.1), 0 4px 16px rgba(74, 109, 143, 0.05);
	--shadow-lg: 0 24px 80px rgba(74, 109, 143, 0.11), 0 8px 32px rgba(74, 109, 143, 0.06);
	--shadow-glow: 0 0 72px rgba(120, 157, 188, 0.22);

	--radius-sm: 12px;
	--radius-md: 18px;
	--radius-lg: 26px;
	--radius-xl: 36px;

	--font: "Inter", system-ui, -apple-system, sans-serif;
	--font-display: "Syne", system-ui, sans-serif;
	--header-h: 58px;
	/* Matches fixed bottom dock height (primary row: --header-h + vertical padding). Same value used for body padding and menu overlay bottom inset. */
	--header-dock-reserve: calc(var(--header-h) + 20px);
	/* Horizontal nav only at this width — below this = hamburger (avoids wrapped nav rows). */
	--nav-desktop-min: 1180px;
	--step: 8px;

	/* Decorative mesh — blush / mint / blue */
	--mesh-1a: var(--c-blush);
	--mesh-1b: var(--c-blush-deep);
	--mesh-2a: var(--c-mint-soft);
	--mesh-2b: var(--c-mint);
	--mesh-3a: #dcecf5;
	--mesh-3b: var(--c-blue-light);
	--mesh-4a: var(--c-cream-deep);
	--mesh-4b: var(--c-blush);
}

.site-main {
	width: 100%;
	position: relative;
	z-index: 2;
}

/* Ambient PNG backgrounds — uploads/bmta ambient-* (photo visible; light veil + dark type keeps copy readable) */
.bmta-ambient-bg {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	/* Slightly darker defaults inside ambient blocks so copy stays legible on varied photos */
	--ambient-fg: #1a252d;
	--ambient-fg-muted: #3d4d59;
	color: var(--ambient-fg);
}

.bmta-ambient-bg::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background-image: var(--bmta-ambient-img);
	background-size: cover;
	background-position: center;
	opacity: 0.22;
}

/* Clown / billboards / blimp — low photo opacity; scrim balanced for legibility */
.bmta-ambient-bg.bmta-ambient-bg--photo-faint::before {
	opacity: 0.155;
}

.bmta-ambient-bg.bmta-ambient-bg--photo-faint::after {
	background: linear-gradient(
		180deg,
		rgba(254, 249, 242, 0.615) 0%,
		rgba(255, 255, 255, 0.515) 45%,
		rgba(254, 249, 242, 0.595) 100%
	);
}

/* Light scrim over photo — enough to lift text; thin enough that imagery stays visible */
.bmta-ambient-bg::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: linear-gradient(
		180deg,
		rgba(254, 249, 242, 0.42) 0%,
		rgba(255, 255, 255, 0.32) 42%,
		rgba(254, 249, 242, 0.4) 100%
	);
}

.bmta-ambient-bg > * {
	position: relative;
	z-index: 2;
}

/* Drop redundant opaque section fills when ambient is active (prevents double stacking / muddy overlap) */
.proof-strip.bmta-ambient-bg {
	background: transparent;
	z-index: auto;
}

.section--geo-regions.bmta-ambient-bg {
	background: transparent;
}

/* Typography on ambient sections — headings & body slightly darker than global muted */
.bmta-ambient-bg .section-head__title,
.bmta-ambient-bg .section-head__kicker,
.bmta-ambient-bg .section__title,
.bmta-ambient-bg .proof-strip__label,
.bmta-ambient-bg .pricing-tease__title,
.bmta-ambient-bg .pricing-tease__label,
.bmta-ambient-bg .geo-regions__subhead {
	color: var(--ambient-fg);
}

.bmta-ambient-bg .section-head__lede,
.bmta-ambient-bg .section__lede,
.bmta-ambient-bg .proof-strip__hint,
.bmta-ambient-bg .faq-item p,
.bmta-ambient-bg .faq-item h2,
.bmta-ambient-bg .geo-regions__p,
.bmta-ambient-bg .geo-regions__list,
.bmta-ambient-bg .model-spec__note,
.bmta-ambient-bg .model-spec__brand,
.bmta-ambient-bg .model-spec__route,
.bmta-ambient-bg .pricing-tease__text,
.bmta-ambient-bg .pricing-tease__suffix,
.bmta-ambient-bg .pillar__text,
.bmta-ambient-bg .scope-list li,
.bmta-ambient-bg .feature-card p,
.bmta-ambient-bg .article-landing__h2,
.bmta-ambient-bg .article-landing__p {
	color: var(--ambient-fg-muted);
}

.bmta-ambient-bg .manifesto__line {
	color: var(--ambient-fg);
}

.bmta-ambient-bg .feature-card h3 {
	color: var(--ambient-fg);
}

.bmta-ambient-bg .price-card {
	color: var(--ambient-fg-muted);
}

.bmta-ambient-bg .price-card h2,
.bmta-ambient-bg .price-card .price {
	color: var(--ambient-fg);
}

.bmta-ambient-bg .faq-item h2 {
	font-weight: 600;
	color: var(--ambient-fg);
}

.bmta-ambient-bg .pillar__title {
	color: var(--ambient-fg);
}

.site-main--article-landing .bmta-ambient-bg .article-landing__panel--plain {
	background: rgba(255, 255, 255, 0.92);
	border-color: rgba(74, 109, 143, 0.18);
}

.bmta-ambient-bg .services-scope-note,
.bmta-ambient-bg .services-scope-note a {
	color: var(--ambient-fg-muted);
}

.bmta-ambient-bg .services-scope-note a {
	font-weight: 600;
	color: var(--accent-hover);
}

/* Per-slot wash tints (rotate with ambient index; replaces removed fixed .site-atmosphere layer). */
.bmta-ambient-bg--wash-cream::after {
	background: linear-gradient(
		180deg,
		rgba(254, 249, 242, 0.42) 0%,
		rgba(255, 255, 255, 0.32) 42%,
		rgba(254, 249, 242, 0.4) 100%
	);
}

.bmta-ambient-bg--wash-blush::after {
	background: linear-gradient(
		180deg,
		rgba(255, 236, 240, 0.48) 0%,
		rgba(255, 248, 245, 0.34) 45%,
		rgba(252, 228, 236, 0.42) 100%
	);
}

.bmta-ambient-bg--wash-mint::after {
	background: linear-gradient(
		180deg,
		rgba(236, 248, 244, 0.46) 0%,
		rgba(245, 252, 249, 0.34) 45%,
		rgba(228, 242, 238, 0.44) 100%
	);
}

.bmta-ambient-bg--wash-blue::after {
	background: linear-gradient(
		180deg,
		rgba(236, 242, 252, 0.48) 0%,
		rgba(245, 248, 255, 0.34) 45%,
		rgba(228, 236, 248, 0.44) 100%
	);
}

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

html {
	scroll-behavior: smooth;
	font-size: calc(100% * var(--bmta-type-scale));
}

body.bmta-app {
	margin: 0;
	min-height: 100vh;
	padding-bottom: calc(var(--header-dock-reserve) + env(safe-area-inset-bottom, 0px));
	font-family: var(--font);
	font-size: 1.0625rem; /* was 17px at 16px root; tracks scaled html */
	line-height: 1.65;
	color: var(--text);
	background-color: var(--c-cream);
	background-image:
		radial-gradient(ellipse 100% 85% at 12% -25%, rgba(255, 227, 227, 0.85), transparent 52%),
		radial-gradient(ellipse 90% 75% at 92% 8%, rgba(120, 157, 188, 0.22), transparent 48%),
		radial-gradient(ellipse 75% 65% at 38% 105%, rgba(201, 233, 210, 0.55), transparent 46%),
		linear-gradient(168deg, var(--c-cream) 0%, var(--c-cream-deep) 52%, #f0e8df 100%);
	background-attachment: fixed;
	-webkit-font-smoothing: antialiased;
	font-optical-sizing: auto;
}

/* Ultra-light grain — sits under page chrome (header/main/footer use z-index ≥ 1) */
body.bmta-app::before {
	content: "";
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 0;
	opacity: 0.14;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	background-size: 180px 180px;
	mix-blend-mode: overlay;
}

a {
	color: var(--text);
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

a:hover {
	color: var(--accent);
}

/* Contained “studio” width — like NH1 / portfolio sites (not edge-to-edge boxes) */
.shell {
	width: 100%;
	max-width: 1120px;
	margin-inline: auto;
	padding-inline: clamp(20px, 4vw, 64px);
	box-sizing: border-box;
}

.shell--wide {
	max-width: 1320px;
}

.shell--narrow {
	max-width: 720px;
}

/* Articles / landing: full-width column (still respects horizontal padding) */
.shell--article {
	max-width: 100%;
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.skip-link:focus {
	position: fixed;
	top: 12px;
	left: 12px;
	z-index: 200;
	padding: 12px 20px;
	background: var(--c-blue);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.15);
	clip: auto;
	width: auto;
	height: auto;
	border-radius: 999px;
	box-shadow: var(--shadow-md);
}

/*
 * Bottom dock — fixed to viewport bottom, solid fill (opaque bar).
 * Primary row (logo + toggle) sits on the bottom edge; nav stacks above when open.
 */
/*
 * No backdrop-filter here — it creates a containing block so position:fixed children
 * (#primary-navigation overlay) only fill the dock strip instead of the viewport.
 */
.site-header {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 100;
	padding-bottom: env(safe-area-inset-bottom, 0px);
	background: var(--c-cream);
	border-top: 4px solid #000;
	box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.06);
}

.site-header__bar {
	display: flex;
	flex-direction: column-reverse;
	align-items: stretch;
	gap: 0;
	width: 100%;
	max-width: none;
	padding-inline: clamp(20px, 4vw, 64px);
	padding-top: 0;
	box-sizing: border-box;
}

.site-header__primary {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	min-height: var(--header-h);
	padding-block: 10px;
	gap: 12px;
}

.site-logo {
	display: flex;
	flex-direction: column;
	line-height: 1.12;
	text-decoration: none;
	color: #1a1a1a;
	font-family: var(--font);
	font-weight: 800;
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	justify-self: start;
}

.site-logo__line2 {
	font-size: 0.6875rem;
	font-weight: 700;
	color: #1a1a1a;
	margin-top: 3px;
	letter-spacing: 0.08em;
}

.site-header__actions {
	display: none;
	flex: 0 0 auto;
}

.cta-micro {
	display: flex;
	align-items: center;
	gap: 10px;
}

.cta-micro .btn--ghost {
	border-color: #000;
	color: var(--text);
}

.cta-micro .btn--ghost:hover {
	background: var(--accent-soft);
	color: var(--text);
	border-color: #000;
}

.nav-toggle {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: 3px solid #000;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.92);
	box-shadow: none;
	cursor: pointer;
	transition: box-shadow 0.25s ease, transform 0.2s ease, background 0.2s ease;
}

.nav-toggle:hover {
	box-shadow: 0 2px 0 #000;
}

.nav-toggle__bars,
.nav-toggle__bars::before,
.nav-toggle__bars::after {
	display: block;
	width: 18px;
	height: 2px;
	background: #1a1a1a;
	position: relative;
}

.nav-toggle__bars::before,
.nav-toggle__bars::after {
	content: "";
	position: absolute;
	left: 0;
}

.nav-toggle__bars::before {
	top: -6px;
}

.nav-toggle__bars::after {
	top: 6px;
}

/* Below --nav-desktop-min: hamburger + full-height overlay; at/above: single-row nav */
.nav-panel {
	display: none;
	flex-direction: column;
	flex: 0 1 auto;
	gap: 8px;
	padding: 0;
	background: transparent;
	width: 100%;
	margin: 0;
	border: none;
}

@media (max-width: 1179px) {
	body.nav-open {
		overflow: hidden;
	}

	/* Dock row stays above full-screen overlay so the toggle can close the menu */
	body.nav-open .site-header__primary {
		position: relative;
		z-index: 550;
	}

	/* ID + classes beat .nav-panel { display:none }; must fill real viewport */
	body.nav-open #primary-navigation.nav-panel {
		display: flex !important;
		position: fixed;
		left: 0;
		right: 0;
		top: 0;
		bottom: calc(var(--header-dock-reserve) + env(safe-area-inset-bottom, 0px));
		z-index: 500;
		width: 100vw;
		max-width: 100vw;
		max-height: none;
		min-height: 0;
		height: auto;
		overflow: hidden;
		padding: max(12px, env(safe-area-inset-top)) clamp(20px, 5vw, 40px) 16px;
		flex-direction: column;
		justify-content: space-evenly;
		align-items: stretch;
		box-sizing: border-box;
		background: rgba(254, 249, 242, 0.97);
		backdrop-filter: blur(22px) saturate(1.2);
		-webkit-backdrop-filter: blur(22px) saturate(1.2);
		box-shadow: inset 0 -1px 0 rgba(74, 109, 143, 0.1);
	}

	body.nav-open #primary-navigation.nav-panel .nav-list {
		flex: 1 1 auto;
		justify-content: center;
		min-height: 0;
		overflow: hidden;
		gap: clamp(0px, 1vh, 8px);
	}

	body.nav-open #primary-navigation.nav-panel .nav-link {
		padding: clamp(8px, 2vh, 14px) 12px;
		font-size: clamp(15px, 4.2vw, 18px);
		text-align: center;
	}

	body.nav-open #primary-navigation.nav-panel .nav-panel__cta {
		flex-shrink: 0;
		padding-top: clamp(8px, 2vh, 16px);
		border-top: 1px solid rgba(26, 26, 26, 0.15);
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 10px;
	}

	body.nav-open #primary-navigation.nav-panel .nav-panel__cta .cta-group {
		justify-content: center;
		flex-wrap: wrap;
	}
}

.nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.nav-link {
	display: block;
	padding: 11px 14px;
	text-decoration: none;
	color: #1a1a1a;
	font-family: var(--font);
	font-weight: 700;
	font-size: 0.8125rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	transition: background 0.2s ease, color 0.2s ease;
}

.nav-link:hover {
	background: rgba(26, 26, 26, 0.06);
	color: #1a1a1a;
	box-shadow: none;
}

.nav-panel__cta {
	padding-top: 14px;
	border-top: 1px solid rgba(26, 26, 26, 0.15);
}

.nav-panel__cta .btn--ghost {
	border-color: #000;
	color: var(--text);
}

.nav-panel__cta .btn--ghost:hover {
	background: var(--accent-soft);
	border-color: #000;
}

/* Buttons — flat fills; always black outline */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 28px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 15px;
	text-decoration: none;
	border: 2px solid #000;
	cursor: pointer;
	letter-spacing: -0.01em;
	text-transform: none;
	transition:
		transform 0.2s cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 0.25s ease,
		background-color 0.2s ease,
		border-color 0.2s ease,
		color 0.2s ease;
}

.btn:active {
	transform: scale(0.98);
}

.btn--sm {
	padding: 9px 18px;
	font-size: 14px;
}

.btn--primary {
	background: var(--c-blue);
	color: #fff;
	border: 2px solid #000;
	box-shadow: var(--shadow-sm);
}

.btn--primary:hover {
	background: var(--c-blue-dark);
	border-color: #000;
	box-shadow: var(--shadow-md);
	transform: translateY(-1px);
}

/* WhatsApp — same green on every chip that points at wa.me */
a.btn[href*="wa.me"],
a.btn--primary[href*="wa.me"],
a.btn--sm[href*="wa.me"],
a.btn--contact[href*="wa.me"] {
	background: #00ff66;
	color: #0a0a0a;
	border: 2px solid #000;
	box-shadow: var(--shadow-sm);
}

a.btn[href*="wa.me"]:hover,
a.btn--primary[href*="wa.me"]:hover,
a.btn--sm[href*="wa.me"]:hover,
a.btn--contact[href*="wa.me"]:hover {
	background: #00e65c;
	color: #000;
	border-color: #000;
	box-shadow: var(--shadow-md);
	transform: translateY(-1px);
}

.cta-final a.btn[href*="wa.me"],
.cta-final a.btn--primary[href*="wa.me"] {
	background: #00ff66;
	color: #0a0a0a;
	border: 2px solid #000;
}

.cta-final a.btn[href*="wa.me"]:hover,
.cta-final a.btn--primary[href*="wa.me"]:hover {
	background: #00e65c;
	color: #000;
	border-color: #000;
}

.btn--secondary {
	background: var(--c-blue-deep);
	color: var(--c-cream);
	border: 2px solid #000;
	box-shadow: var(--shadow-sm);
}

.btn--secondary:hover {
	background: #3d5266;
	border-color: #000;
	box-shadow: var(--shadow-md);
	transform: translateY(-1px);
}

.btn--ghost {
	background: rgba(255, 255, 255, 0.78);
	color: var(--text);
	border: 2px solid #000;
	box-shadow: var(--shadow-sm);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.btn--ghost:hover {
	background: #ffffff;
	border-color: #000;
	box-shadow: var(--shadow-md);
}

/* Block editor buttons inside page/post content */
.entry-content .wp-block-button__link,
.site-main .wp-block-button__link {
	border: 2px solid #000 !important;
	box-shadow: none;
}

.entry-content .wp-block-button__link:hover,
.site-main .wp-block-button__link:hover {
	border-color: #000 !important;
}

.cta-group {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

main#main {
	min-height: 60vh;
}

.section {
	width: 100%;
	background: transparent;
	padding: clamp(40px, 6vw, 80px) 0;
	position: relative;
}

.section--tight {
	padding: clamp(32px, 5vw, 60px) 0;
	background: transparent;
}

.section--contact {
	background: transparent;
}

.section__title {
	font-family: var(--font-display);
	font-size: clamp(26px, 3.8vw, 38px);
	font-weight: 600;
	margin: 0 0 12px;
	letter-spacing: -0.035em;
	line-height: 1.15;
	color: var(--text);
}

.section__lede {
	max-width: 54ch;
	margin: 0 0 28px;
	color: var(--text-muted);
	font-size: 17px;
	line-height: 1.65;
}

.section__actions {
	margin: 0;
}

/* Models — soft floating panel feel */
.section--models {
	background: transparent;
	padding-top: clamp(40px, 6vw, 80px);
	padding-bottom: clamp(40px, 6vw, 80px);
	border: none;
}

/* Bottom CTA — aurora glass over ink; optional photo via .cta-final__photo */
.cta-final {
	width: 100%;
	position: relative;
	overflow: hidden;
	background: radial-gradient(ellipse 90% 120% at 18% 115%, rgba(120, 157, 188, 0.35), transparent 55%),
		radial-gradient(ellipse 70% 85% at 92% -8%, rgba(255, 227, 227, 0.18), transparent 48%),
		linear-gradient(155deg, #3a4f62 0%, #2c3a47 48%, #354559 100%);
	padding: clamp(44px, 7vw, 88px) 0 clamp(48px, 8vw, 96px);
	border: none;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.cta-final__photo {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background-image: var(--bmta-cta-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.cta-final__photo::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		155deg,
		rgba(44, 58, 71, 0.88) 0%,
		rgba(47, 64, 80, 0.82) 42%,
		rgba(53, 69, 89, 0.78) 100%
	);
}

.cta-final--has-photo::before {
	opacity: 0;
}

.cta-final > .shell {
	position: relative;
	z-index: 1;
}

.cta-final::before {
	content: "";
	position: absolute;
	inset: -40% -20%;
	background: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.06), transparent 55%);
	pointer-events: none;
	z-index: 0;
}

.cta-final__shell {
	display: grid;
	gap: 28px;
	align-items: start;
	position: relative;
	z-index: 1;
}

.cta-final__layout {
	display: grid;
	gap: clamp(28px, 5vw, 48px);
	align-items: end;
	position: relative;
	z-index: 1;
}

.cta-final__intro {
	max-width: 52ch;
}

.cta-final__kicker {
	font-size: 13px;
	font-weight: 600;
	color: rgba(247, 243, 234, 0.55);
	margin: 0 0 12px;
	letter-spacing: 0.02em;
}

.cta-final__title {
	font-family: var(--font-display);
	font-size: clamp(28px, 4vw, 44px);
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: 1.08;
	margin: 0 0 16px;
	color: #faf8f3;
}

.cta-final__text {
	margin: 0;
	max-width: 42ch;
	font-size: 17px;
	line-height: 1.65;
	color: rgba(247, 243, 234, 0.72);
}

.cta-final__actions .cta-group {
	justify-content: flex-start;
}

.cta-final__layout .cta-final__actions .cta-group {
	justify-content: flex-start;
}

.cta-final .btn--primary {
	background: var(--c-cream);
	color: var(--text);
	border: 2px solid #000;
	box-shadow: var(--shadow-sm);
}

.cta-final .btn--primary:hover {
	background: #ffffff;
	border-color: #000;
	color: var(--text);
	box-shadow: var(--shadow-md);
	transform: translateY(-1px);
}

.cta-final .btn--secondary {
	background: rgba(255, 255, 255, 0.12);
	color: #faf8f3;
	border: 2px solid #000;
	box-shadow: none;
	backdrop-filter: blur(8px);
}

.cta-final .btn--secondary:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
	border-color: #000;
	transform: translateY(-1px);
}

.cta-final .btn--ghost {
	background: transparent;
	color: rgba(250, 248, 243, 0.92);
	border: 2px solid #000;
	box-shadow: none;
	backdrop-filter: none;
}

.cta-final .btn--ghost:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: #000;
	color: #fff;
}

@media (min-width: 768px) {
	.cta-final__shell {
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: center;
		gap: 40px;
	}

	.cta-final__shell .cta-final__actions .cta-group {
		justify-content: flex-end;
		flex-wrap: nowrap;
	}

	.cta-final__layout {
		grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
		align-items: end;
		gap: 48px;
	}

	.cta-final__layout .cta-final__actions .cta-group {
		justify-content: flex-end;
		flex-wrap: wrap;
	}
}

/*
 * Hero — split editorial / visual (DN “headline + explore”, NH1 visual-forward).
 * No dashboard widget beside copy — proof moves to .proof-strip below.
 */
.hero--split {
	min-height: min(82vh, 840px);
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(20px, 4vw, 56px) 0 clamp(32px, 5vw, 60px);
	position: relative;
	overflow: hidden;
}

.hero--split::before,
.hero--split::after {
	content: "";
	position: absolute;
	pointer-events: none;
	border-radius: 50%;
	filter: blur(100px);
	opacity: 0.45;
	z-index: 0;
}

.hero--split::before {
	width: min(65vw, 480px);
	height: min(65vw, 480px);
	background: rgba(255, 227, 227, 0.55);
	top: -20%;
	right: -5%;
}

.hero--split::after {
	width: min(45vw, 360px);
	height: min(45vw, 360px);
	background: rgba(120, 157, 188, 0.28);
	bottom: 0;
	left: -8%;
}

/* Faded photography — full-bleed layer, not a framed image block */
.hero__atmosphere {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	background-image: var(--bmta-hero-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0.38;
}

.hero__atmosphere::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		rgba(254, 249, 242, 0.94) 0%,
		rgba(254, 249, 242, 0.72) 38%,
		rgba(254, 249, 242, 0.35) 72%,
		rgba(254, 249, 242, 0.12) 100%
	);
}

.hero--has-atmosphere.hero--split::before,
.hero--has-atmosphere.hero--split::after {
	opacity: 0.22;
}

.hero__split {
	display: grid;
	gap: clamp(40px, 6vw, 64px);
	align-items: center;
	position: relative;
	z-index: 1;
}

.hero__copy {
	min-width: 0;
}

.hero__kicker {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-muted);
	margin: 0 0 16px;
	max-width: 40ch;
}

.hero--split h1 {
	font-family: var(--font-display);
	font-size: clamp(40px, 6.5vw, 76px);
	line-height: 0.98;
	margin: 0 0 clamp(18px, 2.5vw, 24px);
	letter-spacing: -0.055em;
	font-weight: 700;
	color: var(--text);
	max-width: 22ch;
}

.hero__lede {
	margin: 0;
	color: var(--text-muted);
	font-size: clamp(16px, 1.25vw, 19px);
	max-width: 52ch;
	line-height: 1.65;
}

.hero__cta {
	margin: 0 0 clamp(22px, 3vw, 36px);
}

/* Editorial band — atmospheric strip between hero and pillars */
.studio-editorial {
	width: 100%;
	padding: 0;
	background: transparent;
	border: none;
}

.studio-editorial--atmosphere {
	position: relative;
	min-height: min(42vh, 520px);
	overflow: hidden;
	background-image: var(--bmta-editorial-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.studio-editorial__veil {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: linear-gradient(
		180deg,
		rgba(254, 249, 242, 0.88) 0%,
		rgba(254, 249, 242, 0.45) 45%,
		rgba(254, 249, 242, 0.92) 100%
	);
}

/* Proof strip — horizontal signal row (editorial, not a widget panel) */
.proof-strip {
	padding: clamp(18px, 3vw, 32px) 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	background: rgba(254, 249, 242, 0.55);
	position: relative;
	z-index: 1;
}

.proof-strip__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(20px, 3vw, 32px);
}

@media (min-width: 720px) {
	.proof-strip__list {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 24px;
	}
}

.proof-strip__item {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 0;
	border: none;
}

.proof-strip__label {
	font-family: var(--font-display);
	font-size: clamp(22px, 3vw, 32px);
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 1;
	color: var(--text);
}

.proof-strip__hint {
	font-size: 14px;
	line-height: 1.45;
	color: var(--text-muted);
	max-width: 26ch;
}

/* Section heads — kicker + title (Volume-style hierarchy) */
.section-head {
	margin-bottom: clamp(36px, 6vw, 56px);
	max-width: 720px;
}

.section-head--left {
	text-align: left;
}

.section-head__kicker {
	font-size: 13px;
	font-weight: 600;
	color: var(--text-muted);
	margin: 0 0 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.section-head__title {
	font-family: var(--font-display);
	font-size: clamp(28px, 4vw, 44px);
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 1.1;
	margin: 0 0 16px;
	color: var(--text);
}

.section-head__lede {
	margin: 0;
	font-size: 17px;
	line-height: 1.65;
	color: var(--text-muted);
	max-width: 54ch;
}

.section-head__lede--narrow {
	max-width: 42ch;
}

/* Pillars — three editorial columns (Purpose / Human / Creative rhythm) */
.section--pillars {
	padding-top: clamp(40px, 7vw, 84px);
	padding-bottom: clamp(40px, 7vw, 84px);
}

.pillar-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(32px, 5vw, 48px);
}

@media (min-width: 900px) {
	.pillar-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: clamp(28px, 4vw, 48px);
		align-items: start;
	}
}

.pillar {
	padding: 0;
	border: none;
	background: transparent;
}

.pillar__title {
	font-family: var(--font-display);
	font-size: clamp(22px, 2.5vw, 28px);
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0 0 14px;
	color: var(--text);
	line-height: 1.15;
}

.pillar__text {
	margin: 0;
	font-size: 16px;
	line-height: 1.65;
	color: var(--text-muted);
	max-width: 38ch;
}

/* GEO / regions — semantic keywords + markets */
.section--geo-regions {
	padding-top: clamp(36px, 6vw, 72px);
	padding-bottom: clamp(36px, 6vw, 72px);
	background: linear-gradient(180deg, rgba(255, 227, 227, 0.35) 0%, transparent 100%);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.section--geo-regions .section-head__lede {
	max-width: 62ch;
}

.geo-regions__layout {
	display: grid;
	gap: clamp(28px, 4vw, 40px);
	margin-top: clamp(24px, 4vw, 40px);
	align-items: start;
}

@media (min-width: 880px) {
	.geo-regions__layout {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: clamp(32px, 5vw, 56px);
	}
}

.geo-regions__p {
	margin: 0;
	font-size: 16px;
	line-height: 1.65;
	color: var(--text-muted);
}

.geo-regions__subhead {
	font-family: var(--font-display);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 0 0 14px;
	color: var(--text);
}

.geo-regions__list {
	margin: 0;
	padding-left: 1.15em;
	font-size: 15px;
	line-height: 1.65;
	color: var(--text-muted);
}

.geo-regions__list li {
	margin-bottom: 0.5em;
}

.geo-regions__list li:last-child {
	margin-bottom: 0;
}

/* Manifesto band — single editorial line */
.manifesto {
	padding: clamp(36px, 6vw, 72px) 0;
	text-align: center;
	position: relative;
	z-index: 1;
}

.manifesto__line {
	margin: 0 auto;
	font-family: var(--font-display);
	font-size: clamp(22px, 3.5vw, 34px);
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: -0.03em;
	color: var(--text);
	max-width: 28ch;
}

/* Pricing tease — asymmetric split (figure | copy) */
.section--pricing-tease {
	padding: clamp(40px, 7vw, 84px) 0;
}

.pricing-tease {
	display: grid;
	gap: clamp(32px, 5vw, 48px);
	align-items: center;
	padding: clamp(32px, 5vw, 56px);
	border-radius: var(--radius-xl);
	background: rgba(255, 255, 255, 0.55);
	border: 1px solid rgba(255, 255, 255, 0.65);
	box-shadow: var(--shadow-md);
	backdrop-filter: blur(16px);
}

@media (min-width: 880px) {
	.pricing-tease {
		grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
		gap: clamp(40px, 6vw, 72px);
		padding: clamp(40px, 5vw, 64px);
	}
}

.pricing-tease__label {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--text-muted);
	margin: 0 0 12px;
}

.pricing-tease__figure {
	font-family: var(--font-display);
	font-size: clamp(56px, 8vw, 96px);
	font-weight: 700;
	letter-spacing: -0.06em;
	line-height: 1;
	margin: 0;
	color: var(--text);
}

.pricing-tease__currency {
	font-size: 0.45em;
	vertical-align: super;
	margin-right: 4px;
	opacity: 0.85;
}

.pricing-tease__suffix {
	margin: 12px 0 0;
	font-size: 14px;
	color: var(--text-muted);
	max-width: 22ch;
	line-height: 1.45;
}

.pricing-tease__title {
	font-family: var(--font-display);
	font-size: clamp(22px, 2.8vw, 30px);
	font-weight: 700;
	letter-spacing: -0.035em;
	margin: 0 0 14px;
	line-height: 1.15;
	color: var(--text);
}

.pricing-tease__text {
	margin: 0 0 22px;
	font-size: 17px;
	line-height: 1.65;
	color: var(--text-muted);
	max-width: 52ch;
}

.pricing-tease__action {
	margin: 0;
}

/* Model coverage — magazine spec sheet */
.model-spec {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--line-strong);
}

.model-spec__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px 16px;
	padding: clamp(18px, 2.5vw, 24px) 0;
	border-bottom: 1px solid var(--line);
	align-items: baseline;
}

@media (min-width: 768px) {
	.model-spec__row {
		grid-template-columns: minmax(140px, 180px) minmax(160px, 240px) minmax(0, 1fr);
		gap: 24px;
	}
}

.model-spec__brand {
	font-family: var(--font-display);
	font-size: clamp(17px, 1.6vw, 19px);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--text);
}

.model-spec__route {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-muted);
}

.model-spec__note {
	margin: 0;
	font-size: 15px;
	line-height: 1.6;
	color: var(--text-muted);
}

.card-grid {
	display: grid;
	gap: 20px;
	grid-template-columns: 1fr;
	background: transparent;
	border: none;
}

.feature-card {
	background: linear-gradient(155deg, rgba(255, 255, 255, 0.72) 0%, rgba(254, 249, 242, 0.5) 100%);
	padding: 28px;
	min-height: 100%;
	border-radius: var(--radius-lg);
	border: 1px solid rgba(255, 255, 255, 0.65);
	box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.35s ease;
}

.feature-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--shadow-lg), 0 0 56px rgba(120, 157, 188, 0.12);
}

@media (min-width: 640px) {
	.card-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.feature-card h3 {
	margin: 0 0 8px;
	font-size: 16px;
	font-weight: 600;
	color: var(--text);
	letter-spacing: -0.02em;
}

.feature-card p {
	margin: 0;
	color: var(--text-muted);
	font-size: 14px;
	line-height: 1.6;
}

.pricing-grid {
	display: grid;
	gap: 20px;
	grid-template-columns: 1fr;
	background: transparent;
	border: none;
}

.price-card {
	background: rgba(255, 255, 255, 0.65);
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	border-radius: var(--radius-lg);
	border: 1px solid rgba(255, 255, 255, 0.65);
	box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(14px);
}

.price-card--accent {
	background: linear-gradient(145deg, rgba(254, 249, 242, 0.98) 0%, rgba(232, 245, 236, 0.75) 42%, rgba(255, 227, 227, 0.45) 100%);
	box-shadow: var(--shadow-lg), 0 0 0 2px rgba(120, 157, 188, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.92);
	position: relative;
}

.price-card__tag {
	display: inline-flex;
	align-self: flex-start;
	padding: 6px 12px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: none;
	background: rgba(255, 255, 255, 0.75);
	color: var(--text-muted);
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.8);
	box-shadow: var(--shadow-sm);
}

.price-card h2 {
	margin: 0;
	font-size: 19px;
	font-weight: 600;
	letter-spacing: -0.02em;
}

.price-card .price {
	font-size: 34px;
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0;
	line-height: 1;
	color: var(--text);
}

.price-card .price small {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-muted);
}

.price-card ul {
	margin: 0;
	padding-left: 18px;
	color: var(--text-muted);
	display: grid;
	gap: 8px;
	font-size: 14px;
	line-height: 1.55;
}

.price-card .cta-group {
	margin-top: auto;
	padding-top: 10px;
}

.page-hero {
	width: 100%;
	padding: clamp(22px, 4vw, 52px) 0 clamp(20px, 4vw, 36px);
	background: transparent;
	border: none;
	position: relative;
	z-index: 1;
}

.page-hero h1 {
	font-family: var(--font-display);
	margin: 0 0 14px;
	font-size: clamp(30px, 4.5vw, 46px);
	letter-spacing: -0.04em;
	font-weight: 700;
	line-height: 1.12;
}

.page-hero__label {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-transform: none;
	color: var(--text-muted);
	margin: 0 0 14px;
}

.page-hero .page-hero__lead {
	font-size: 18px;
	line-height: 1.65;
	max-width: 54ch;
	color: var(--text-muted);
	margin: 0;
}

.page-hero--contact {
	padding-bottom: clamp(20px, 4vw, 36px);
}

.section--contact {
	padding-top: clamp(16px, 3vw, 28px);
}

/* Contact — floating cards, aligned actions */
.contact-methods {
	display: grid;
	gap: clamp(20px, 3vw, 28px);
	grid-template-columns: 1fr;
	align-items: stretch;
}

.contact-card {
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 30px 28px 26px;
	background: linear-gradient(165deg, rgba(255, 255, 255, 0.78), rgba(254, 249, 242, 0.48));
	border-radius: var(--radius-lg);
	border: 1px solid rgba(255, 255, 255, 0.65);
	box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255, 255, 255, 0.88);
	backdrop-filter: blur(18px) saturate(1.2);
	-webkit-backdrop-filter: blur(18px) saturate(1.2);
	transition: box-shadow 0.35s ease, transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-card:hover {
	box-shadow: var(--shadow-lg), 0 0 72px rgba(120, 157, 188, 0.14);
	transform: translateY(-6px);
}

.contact-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	margin-bottom: 20px;
	border-radius: var(--radius-md);
	background: linear-gradient(145deg, rgba(200, 225, 236, 0.65), rgba(120, 157, 188, 0.2));
	border: 1px solid rgba(255, 255, 255, 0.65);
	color: var(--accent-hover);
	box-shadow: var(--shadow-sm);
}

.contact-card__title {
	font-family: var(--font-display);
	font-size: 21px;
	font-weight: 600;
	margin: 0 0 10px;
	letter-spacing: -0.03em;
	line-height: 1.25;
	color: var(--text);
}

.contact-card__desc {
	margin: 0 0 18px;
	font-size: 15px;
	line-height: 1.6;
	color: var(--text-muted);
	flex: 0 0 auto;
}

.contact-card__detail {
	min-height: 1.5em;
	margin: 0 0 6px;
	font-size: 15px;
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

.contact-card__detail a {
	text-decoration: none;
	color: var(--text);
	border-bottom: 1px solid var(--line-strong);
	transition: border-color 0.15s ease, color 0.15s ease;
}

.contact-card__detail a:hover {
	color: var(--accent);
	border-bottom-color: var(--accent);
}

.contact-card__detail--placeholder {
	visibility: hidden;
	user-select: none;
	pointer-events: none;
}

.contact-card__action {
	margin-top: auto;
	padding-top: 22px;
}

.btn--contact {
	width: 100%;
	justify-content: center;
	background: var(--c-blue);
	color: #fff;
	padding: 15px 22px;
	font-size: 15px;
	font-weight: 600;
	letter-spacing: -0.01em;
	border-radius: 999px;
	box-shadow: var(--shadow-sm);
	text-transform: none;
	border: 2px solid #000;
}

.contact-card .btn--contact {
	box-sizing: border-box;
}

.btn--contact:hover {
	background: var(--c-blue-dark);
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
	color: #fff;
	border-color: #000;
}

@media (min-width: 900px) {
	.contact-methods {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.page-hero p {
	margin: 0;
	max-width: 54ch;
	color: var(--text-muted);
	font-size: 17px;
	line-height: 1.65;
}

.page-hero--article {
	padding-top: 28px;
	border-bottom: none;
}

.entry-content {
	max-width: 62ch;
}

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

.entry-content p {
	margin: 0 0 1em;
}

.post-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 14px;
	background: transparent;
	border: none;
}

.post-list__item {
	list-style: none;
	background: rgba(255, 255, 255, 0.55);
	padding: 22px;
	border-radius: var(--radius-md);
	border: 1px solid rgba(255, 255, 255, 0.55);
	box-shadow: var(--shadow-sm);
	backdrop-filter: blur(12px);
}

.post-list__title {
	margin: 0 0 8px;
	font-size: 18px;
	font-weight: 600;
	letter-spacing: -0.02em;
}

.faq-list {
	display: grid;
	gap: 12px;
	max-width: 720px;
	background: transparent;
	border: none;
}

.faq-item {
	background: rgba(255, 255, 255, 0.55);
	padding: 22px 24px;
	border-radius: var(--radius-md);
	border: 1px solid rgba(255, 255, 255, 0.55);
	box-shadow: var(--shadow-sm);
	backdrop-filter: blur(12px);
}

.faq-item h2 {
	margin: 0 0 8px;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: -0.02em;
}

.faq-item p {
	margin: 0;
	color: var(--text-muted);
	line-height: 1.65;
	font-size: 15px;
}

.faq-list--home {
	max-width: 800px;
}

.section--home-faq .home-faq__more {
	margin: 28px 0 0;
	text-align: center;
	font-size: 15px;
}

.section--home-faq .home-faq__more a {
	font-weight: 600;
	color: var(--text);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.section--home-faq .home-faq__more a:hover {
	color: var(--accent-hover);
}

.section--scope .section__lede--scope {
	max-width: 52ch;
	margin-bottom: 20px;
}

.scope-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 18px;
	max-width: 720px;
}

.scope-list li {
	margin: 0;
	padding: 18px 20px;
	border-radius: var(--radius-md);
	border: 1px solid rgba(255, 255, 255, 0.45);
	background: rgba(255, 255, 255, 0.45);
	line-height: 1.65;
	font-size: 15px;
	color: var(--text-muted);
}

.scope-list strong {
	display: block;
	margin-bottom: 6px;
	color: var(--text);
	font-weight: 600;
}

.services-scope-note {
	margin: 28px 0 0;
	max-width: 640px;
	font-size: 15px;
	line-height: 1.6;
	color: var(--text-muted);
}

.services-scope-note a {
	font-weight: 600;
	color: var(--accent);
	text-underline-offset: 3px;
}

.site-footer {
	width: 100%;
	position: relative;
	z-index: 2;
	overflow: hidden;
	background: radial-gradient(ellipse 80% 90% at 10% 0%, rgba(120, 157, 188, 0.28), transparent 50%),
		radial-gradient(ellipse 60% 80% at 95% 80%, rgba(255, 227, 227, 0.12), transparent 45%),
		linear-gradient(180deg, #3d5266 0%, #2f4050 100%);
	color: rgba(247, 243, 234, 0.9);
	margin-top: 0;
	padding: 52px 0 36px;
	border: none;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.site-footer::before {
	content: "";
	position: absolute;
	inset: 0;
	background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
	opacity: 0.12;
	mix-blend-mode: overlay;
	pointer-events: none;
}

.site-footer a {
	color: #f4efe6;
	text-decoration: none;
	border-bottom: 1px solid transparent;
}

.site-footer a:hover {
	border-bottom-color: var(--accent-muted);
	color: #fff;
}

.site-footer__grid {
	display: grid;
	gap: 28px;
	position: relative;
	z-index: 1;
}

@media (min-width: 720px) {
	.site-footer__grid {
		grid-template-columns: 2fr 1fr;
		align-items: start;
	}
}

.site-footer__brand {
	font-weight: 700;
	margin: 0 0 8px;
	font-size: 17px;
	letter-spacing: -0.03em;
	color: #faf8f3;
	font-family: var(--font-display);
}

.site-footer__muted {
	margin: 0;
	color: rgba(247, 243, 234, 0.65);
	max-width: 44ch;
	line-height: 1.65;
	font-size: 14px;
}

.site-footer__links {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.site-footer__links a {
	font-size: 14px;
}

.site-footer__pages-row {
	margin-top: 28px;
	padding-top: 28px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
	z-index: 1;
}

.site-footer__pages-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	align-items: baseline;
}

.site-footer__pages-links a {
	font-size: 14px;
	line-height: 1.45;
	max-width: 100%;
}

.site-footer__bottom {
	margin-top: 28px;
	padding-top: 22px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
	z-index: 1;
}

.site-footer__legal {
	margin: 0;
	font-size: 13px;
	color: rgba(247, 243, 234, 0.45);
}

.site-footer__legal a {
	font-weight: 500;
}

@media (min-width: 640px) {
	.card-grid--four {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1180px) {
	.site-header__bar {
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: flex-start;
		gap: 24px;
		padding-block: 12px;
	}

	.site-header__primary {
		flex: 0 0 auto;
		min-height: unset;
		padding-block: 0;
		width: auto;
	}

	.nav-toggle {
		display: none;
	}

	.site-header__actions {
		display: block;
	}

	.nav-panel {
		display: flex !important;
		flex: 1 1 auto;
		flex-direction: row;
		align-items: center;
		justify-content: flex-end;
		padding: 0;
		width: auto;
		max-height: none;
		overflow: visible;
		border-bottom: none;
	}

	.nav-list {
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		gap: 6px;
	}

	.nav-link {
		white-space: nowrap;
	}

	.nav-panel__cta {
		display: none;
	}

	body.nav-open .nav-panel {
		display: flex;
	}

	.card-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.card-grid--four {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.pricing-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* Entry hero — posts & articles: kicker → H1 → CTAs → summary; featured image = hero BG */
.hero.hero--article-entry.hero--split {
	min-height: min(52vh, 640px);
	padding-bottom: clamp(28px, 4vw, 48px);
}

.hero__split--article-entry {
	align-self: stretch;
	min-height: 0;
}

.hero__copy--article-entry {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}

.hero--article-entry .hero__cta--article {
	margin-top: clamp(14px, 2vw, 22px);
}

.hero--article-entry .hero__lede--entry-summary {
	margin-top: clamp(18px, 2.5vw, 28px);
	max-width: 52ch;
	margin-bottom: 0;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content > *:first-child {
	margin-top: 0;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content > *:last-child {
	margin-bottom: 0;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content p {
	margin: 0 0 1.15em;
	font-size: 17px;
	line-height: 1.65;
	color: var(--text-muted);
	max-width: 72ch;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content h3 {
	font-family: var(--font-display);
	font-size: clamp(18px, 2vw, 22px);
	font-weight: 700;
	margin: 1.35em 0 0.55em;
	color: var(--text);
	line-height: 1.25;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content h3:first-child {
	margin-top: 0;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content h4 {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin: 1.2em 0 0.45em;
	color: var(--text-muted);
}

.site-main--article-landing .article-landing__panel.article-content.entry-content ul,
.site-main--article-landing .article-landing__panel.article-content.entry-content ol {
	margin: 0 0 1.15em 1.25em;
	padding: 0;
	color: var(--text-muted);
	line-height: 1.6;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content blockquote {
	margin: 1em 0;
	padding-left: 1rem;
	border-left: 3px solid var(--accent-muted);
	color: var(--text-muted);
	font-style: italic;
}

.site-main--article-landing .article-landing__panel.article-content.entry-content .wp-block-image {
	margin: 1.25em 0;
}

/* Article landing — full-width column; plain panels (no cards/grids) */
.site-main--article-landing .article-landing__chunk {
	padding-bottom: clamp(28px, 4vw, 52px);
}

.site-main--article-landing .article-landing__h2 {
	font-family: var(--font-display);
	font-size: clamp(22px, 2.9vw, 34px);
	font-weight: 700;
	letter-spacing: -0.035em;
	line-height: 1.18;
	margin: 0 0 12px;
	color: var(--text);
	max-width: none;
}

.site-main--article-landing .article-landing__panel--plain {
	border: 1px solid var(--line-strong);
	background: rgba(255, 255, 255, 0.88);
	box-shadow: var(--shadow-sm);
	padding: clamp(22px, 3vw, 32px) clamp(20px, 3vw, 28px);
	margin: 0;
	width: 100%;
	box-sizing: border-box;
}

.site-main--article-landing .article-landing__panel .article-landing__p {
	margin: 0 0 1.25em;
	font-size: 17px;
	line-height: 1.65;
	color: var(--text-muted);
	max-width: 72ch;
}

.site-main--article-landing .article-landing__panel .article-landing__p:last-child {
	margin-bottom: 0;
}

.site-main--article-landing .article-landing__h3 {
	font-family: var(--font-display);
	font-size: clamp(18px, 2vw, 23px);
	font-weight: 700;
	margin: 1.35em 0 0.55em;
	color: var(--text);
	line-height: 1.28;
	max-width: 72ch;
}

.site-main--article-landing .article-landing__panel--plain > .article-landing__h3:first-child {
	margin-top: 0;
}

.site-main--article-landing .article-landing__h4 {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	margin: 1.25em 0 0.45em;
	color: var(--text-muted);
	max-width: 72ch;
}

.site-main--article-landing .article-landing__panel-lede {
	margin: 0 0 1.25rem;
	font-size: 17px;
	line-height: 1.65;
	color: var(--text-muted);
	max-width: 72ch;
}

.site-main--article-landing .article-landing__panel-cta .cta-group {
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 12px;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	body.bmta-app::before {
		opacity: 0.2;
	}

	.hero--split::before,
	.hero--split::after {
		filter: blur(60px);
	}

	.btn:hover,
	.feature-card:hover,
	.contact-card:hover,
	.btn--contact:hover {
		transform: none !important;
	}
}

/* No rounded corners — overrides earlier component radii */
body.bmta-app *,
body.bmta-app *::before,
body.bmta-app *::after {
	border-radius: 0 !important;
}

/* Brutalist homepage + fixed dock: keep bottom inset from main theme (brutalist theme.css sets 88px). */
body.bmta-brutalist-home {
	padding-bottom: var(--header-dock-reserve, 88px) !important;
}

body.bmta-brutalist-home .site-header {
	z-index: 1001;
}
