/* ═════════════════════════════════════════════════════════════
 * APPMERC — main.css (v2)
 * Unified branding: Appmerc marketing site adopting Forge design tokens.
 * Token names mirror Forge's forge-* structure with appmerc-* prefix so
 * both brands read from the same semantic vocabulary.
 * ═════════════════════════════════════════════════════════════ */

:root {
	/* ── Navigation (Forge §2.1) ─────────────────────────────── */
	--appmerc-nav:            #0747A6;
	--appmerc-nav-bg:         linear-gradient(to bottom, #0747A6 0%, #e4eaf2 100%);
	--appmerc-nav-border:     #0052CC;
	--appmerc-nav-text:       #000000;  /* black for WCAG AA across gradient */

	/* ── Brand / interactive (Forge §2.2) ────────────────────── */
	--appmerc-primary:        #0052CC;
	--appmerc-primary-hover:  #0747A6;
	--appmerc-primary-light:  #DEEBFF;
	--appmerc-info:           #0052CC;

	/* ── Surfaces (Forge §2.3) ───────────────────────────────── */
	--appmerc-canvas:         #F4F5F7;
	--appmerc-surface:        #FFFFFF;
	--appmerc-surface-hover:  #F4F5F7;

	/* ── Borders (Forge §2.4) ────────────────────────────────── */
	--appmerc-border:         #DFE1E6;
	--appmerc-border-strong:  #C1C7D0;

	/* ── Text (Forge §2.5) ───────────────────────────────────── */
	--appmerc-text-primary:   #172B4D;
	--appmerc-text-secondary: #6B778C;
	--appmerc-text-disabled:  #A5ADBA;

	/* ── Semantic / status (Forge §2.6) ──────────────────────── */
	--appmerc-success:        #00875A;
	--appmerc-success-light:  #E3FCEF;
	--appmerc-warning:        #FF991F;
	--appmerc-warning-light:  #FFFAE6;
	--appmerc-danger:         #DE350B;
	--appmerc-danger-light:   #FFEBE6;

	/* ── Typography (Forge §3) ───────────────────────────────── */
	--appmerc-font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--appmerc-font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;

	/* ── Spacing (Forge §4, Tailwind 4px scale) ─────────────── */
	--space-0-5: 2px;
	--space-1:   4px;
	--space-1-5: 6px;
	--space-2:   8px;
	--space-3:   12px;
	--space-4:   16px;
	--space-6:   24px;
	--space-8:   32px;
	--space-12:  48px;

	/* ── Radius / shadow (Forge §4) ──────────────────────────── */
	--radius:    4px;
	--radius-lg: 8px;
	--shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
	--shadow-xl: 0 20px 25px -5px rgba(0,0,0,0.1), 0 10px 10px -5px rgba(0,0,0,0.04);

	/* ── Layout ───────────────────────────────────────────────── */
	--wrap-max: 1280px;  /* matches Forge max-w-screen-xl */
	--nav-height: 48px;   /* h-12 per Forge §15 */
}

/* ──────────────── RESET ──────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--appmerc-canvas);
	color: var(--appmerc-text-primary);
	font-family: var(--appmerc-font-sans);
	font-weight: 400;
	font-size: 14px;          /* text-sm default per Forge §3.2 */
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a {
	color: var(--appmerc-primary);
	text-decoration: none;
	transition: color .15s ease;
}
a:hover { color: var(--appmerc-primary-hover); text-decoration: underline; }

::selection { background: var(--appmerc-primary); color: #fff; }

.mono { font-family: var(--appmerc-font-mono); }

.wrap {
	max-width: var(--wrap-max);
	margin: 0 auto;
	padding: 0 var(--space-4);  /* p-4 per Forge §5.2 */
	position: relative;
}
@media (min-width: 1024px) {
	.wrap { padding: 0 var(--space-6); }  /* p-6 on larger displays */
}

.screen-reader-text {
	clip: rect(1px,1px,1px,1px); position: absolute !important;
	height: 1px; width: 1px; overflow: hidden; word-wrap: normal !important;
}

/* ──────────────── FOCUS (Forge §11) ──────────────── */
:focus-visible {
	outline: none;
	box-shadow: 0 0 0 2px var(--appmerc-primary), 0 0 0 3px #fff;
}
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: none;
	box-shadow: 0 0 0 2px var(--appmerc-primary);
}

/* ──────────────── HEADER (Forge §2.1, §5.1) ──────────────── */
header.site {
	position: fixed;
	inset: 0 0 auto 0;
	top: 0;
	z-index: 40;  /* z-40 per Forge §10 */
	background-image: var(--appmerc-nav-bg);
	border-bottom: 1px solid var(--appmerc-nav-border);
}
.nav {
	max-width: var(--wrap-max);
	margin: 0 auto;
	padding: 0 var(--space-4);
	height: var(--nav-height);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
}

/* Push main content below fixed nav */
main.site-main { padding-top: var(--nav-height); }

.brand-logo img,
.brand-logo .custom-logo {
	max-height: 32px;
	width: auto;
}
.brand-wordmark {
	display: inline-flex; align-items: center; gap: var(--space-2);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	font-weight: 600;
	color: var(--appmerc-nav-text);
	text-decoration: none;
}
.brand-wordmark:hover {
	color: var(--appmerc-nav-text);
	text-decoration: none;
	opacity: 0.85;
}
.brand-wordmark .dot {
	width: 8px; height: 8px;
	background: var(--appmerc-primary);
	display: inline-block;
	border-radius: 2px;
}
.brand-wordmark .sub {
	color: var(--appmerc-nav-text);
	font-weight: 400;
	opacity: 0.75;
}

.primary-nav > ul {
	display: flex;
	gap: var(--space-4);
	list-style: none;
	margin: 0; padding: 0;
	font-size: 14px;
}
.primary-nav a {
	color: var(--appmerc-nav-text);
	text-decoration: none;
	padding: var(--space-1-5) var(--space-3);
	border-radius: var(--radius);
	font-weight: 500;
	transition: background-color .15s ease;
}
.primary-nav a:hover,
.primary-nav .current-menu-item > a {
	background-color: var(--appmerc-nav-border);
	color: #fff;
	text-decoration: none;
}

.nav-cta {
	font-size: 14px;
	font-weight: 500;
	padding: var(--space-1-5) var(--space-3);
	height: 32px;  /* h-8 md button per Forge §7.1 */
	display: inline-flex;
	align-items: center;
	background: var(--appmerc-primary);
	color: #fff;
	border: none;
	border-radius: var(--radius);
	text-decoration: none;
	transition: background-color .15s ease;
	white-space: nowrap;
}
.nav-cta:hover {
	background: var(--appmerc-primary-hover);
	color: #fff;
	text-decoration: none;
}

.menu-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--appmerc-nav-border);
	border-radius: var(--radius);
	padding: var(--space-1) var(--space-2);
	font-size: 12px;
	color: var(--appmerc-nav-text);
	cursor: pointer;
	height: 32px;
}
.menu-toggle:hover { background-color: rgba(255,255,255,0.3); }

/* Below Forge's nav-break (800px): show mobile accordion */
@media (max-width: 799px) {
	.primary-nav { display: none; }
	.primary-nav.is-open {
		display: block;
		position: absolute;
		top: var(--nav-height); left: 0; right: 0;
		background: #fff;
		border-bottom: 1px solid var(--appmerc-border);
		padding: var(--space-4);
		box-shadow: var(--shadow-lg);
	}
	.primary-nav.is-open > ul {
		flex-direction: column;
		gap: var(--space-2);
	}
	.primary-nav.is-open a {
		color: var(--appmerc-text-primary);
		padding: var(--space-2) var(--space-3);
	}
	.primary-nav.is-open a:hover {
		background: var(--appmerc-surface-hover);
		color: var(--appmerc-text-primary);
	}
	.menu-toggle { display: inline-flex; align-items: center; }
}
@media (max-width: 639px) {
	.brand-wordmark .sub { display: none; }  /* sm:block convention */
}

/* ──────────────── HERO ──────────────── */
.hero {
	padding: var(--space-12) 0 var(--space-12);
	background: var(--appmerc-surface);
	border-bottom: 1px solid var(--appmerc-border);
}
.hero-grid {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: var(--space-12);
	align-items: start;
}
@media (max-width: 1023px) {
	.hero-grid { grid-template-columns: 1fr; gap: var(--space-8); }
}

.eyebrow {
	font-size: 12px;
	font-weight: 600;
	color: var(--appmerc-text-secondary);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	margin-bottom: var(--space-4);
}

h1.hero-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: clamp(32px, 5vw, 48px);
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--appmerc-text-primary);
	margin: 0;
}
h1.hero-title .accent {
	color: var(--appmerc-primary);
}
h1.hero-title .mono-accent {
	font-family: var(--appmerc-font-sans);
	font-size: 16px;
	font-weight: 400;
	color: var(--appmerc-text-secondary);
	display: block;
	margin-top: var(--space-4);
	letter-spacing: 0;
	line-height: 1.5;
}
h1.hero-title .mono-accent b {
	color: var(--appmerc-primary);
	font-weight: 600;
}

.hero-side {
	background: var(--appmerc-canvas);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-6);
}
.hero-side p {
	color: var(--appmerc-text-secondary);
	font-size: 14px;
	line-height: 1.6;
	margin: 0 0 var(--space-4);
}
.hero-side p:last-of-type { margin-bottom: var(--space-6); }
.hero-side p strong { color: var(--appmerc-text-primary); font-weight: 600; }

.cta-row { display: flex; gap: var(--space-2); flex-wrap: wrap; }

/* Button — Forge §7.1 */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-1-5);
	font-family: var(--appmerc-font-sans);
	font-weight: 500;
	height: 32px;           /* h-8 md */
	padding: 0 var(--space-4);
	font-size: 14px;
	border-radius: var(--radius);
	text-decoration: none;
	cursor: pointer;
	border: 1px solid transparent;
	transition: background-color .15s ease, border-color .15s ease, color .15s ease;
	white-space: nowrap;
}
.btn-primary {
	background: var(--appmerc-primary);
	color: #fff;
	border-color: var(--appmerc-primary);
}
.btn-primary:hover {
	background: var(--appmerc-primary-hover);
	border-color: var(--appmerc-primary-hover);
	color: #fff;
	text-decoration: none;
}
.btn-secondary {
	background: var(--appmerc-surface);
	color: var(--appmerc-text-primary);
	border-color: var(--appmerc-border);
}
.btn-secondary:hover {
	background: var(--appmerc-surface-hover);
	color: var(--appmerc-text-primary);
	text-decoration: none;
}
.btn-ghost {
	background: transparent;
	color: var(--appmerc-primary);
	border-color: transparent;
}
.btn-ghost:hover {
	background: var(--appmerc-primary-light);
	color: var(--appmerc-primary);
	text-decoration: none;
}
.btn .arrow { transition: transform .15s ease; }
.btn:hover .arrow { transform: translateX(2px); }

/* ──────────────── TRUST BAR ──────────────── */
.trust {
	background: var(--appmerc-canvas);
	border-bottom: 1px solid var(--appmerc-border);
	padding: var(--space-8) 0;
}
.trust-inner {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-6);
}
@media (max-width: 767px) {
	.trust-inner { grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
}
.trust-item {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-4);
}
.trust-num {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 24px;
	line-height: 1.1;
	color: var(--appmerc-text-primary);
	display: block;
	margin-bottom: var(--space-2);
	letter-spacing: -0.01em;
}
.trust-num .ac { color: var(--appmerc-primary); }
.trust-item p {
	font-size: 12px;
	color: var(--appmerc-text-secondary);
	line-height: 1.5;
	margin: 0;
}

/* ──────────────── SECTION SCAFFOLDING ──────────────── */
section.pad { padding: var(--space-12) 0; }
@media (max-width: 767px) { section.pad { padding: var(--space-8) 0; } }

.section-head {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: var(--space-8);
	margin-bottom: var(--space-8);
	align-items: start;
}
@media (max-width: 767px) {
	.section-head { grid-template-columns: 1fr; gap: var(--space-3); margin-bottom: var(--space-6); }
}
.section-num {
	font-size: 12px;
	font-weight: 600;
	color: var(--appmerc-primary);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding-top: var(--space-2);
	border-top: 2px solid var(--appmerc-primary);
	max-width: 140px;
}
.section-num span {
	color: var(--appmerc-text-secondary);
	margin-left: var(--space-1);
	font-weight: 400;
}

h2.section-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: clamp(24px, 3.5vw, 32px);
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--appmerc-text-primary);
	margin: 0;
}
h2.section-title .accent { color: var(--appmerc-primary); }

/* ──────────────── PHILOSOPHY ──────────────── */
.philosophy {
	background: var(--appmerc-surface);
	border-bottom: 1px solid var(--appmerc-border);
}
.philosophy-quote {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: clamp(22px, 3vw, 32px);
	line-height: 1.3;
	letter-spacing: -0.015em;
	max-width: 880px;
	margin: 0 auto;
	text-align: center;
	color: var(--appmerc-text-primary);
}
.philosophy-quote .strike {
	text-decoration: line-through;
	text-decoration-thickness: 2px;
	text-decoration-color: var(--appmerc-danger);
	color: var(--appmerc-text-disabled);
	font-weight: 400;
}
.philosophy-quote .hit {
	color: var(--appmerc-text-primary);
	display: block;
	margin-top: var(--space-4);
	font-weight: 700;
}
.philosophy-quote .hit .accent { color: var(--appmerc-primary); }

.philosophy-foot {
	margin-top: var(--space-8);
	text-align: center;
	font-size: 14px;
	color: var(--appmerc-text-secondary);
	max-width: 640px;
	margin-left: auto; margin-right: auto;
	line-height: 1.6;
}

/* ──────────────── CAPABILITIES ──────────────── */
.caps-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-4);
}
@media (max-width: 1023px) { .caps-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 639px)  { .caps-grid { grid-template-columns: 1fr; } }

.cap {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-6);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.cap:hover {
	border-color: var(--appmerc-primary);
	box-shadow: var(--shadow-lg);
}
.cap-tag {
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	color: var(--appmerc-text-secondary);
	margin-bottom: var(--space-3);
	font-weight: 500;
}
.cap-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 18px;  /* text-lg per Forge §3.3 heading pattern */
	letter-spacing: -0.01em;
	margin: 0 0 var(--space-2);
	line-height: 1.3;
	color: var(--appmerc-text-primary);
}
.cap-desc {
	font-size: 14px;
	color: var(--appmerc-text-secondary);
	line-height: 1.55;
	margin: 0;
}
.cap.cap-accent {
	background: var(--appmerc-primary-light);
	border-color: var(--appmerc-primary);
}
.cap.cap-accent .cap-title { color: var(--appmerc-primary); }
.cap.cap-accent .cap-tag { color: var(--appmerc-primary); }
.cap.cap-accent .cap-desc { color: var(--appmerc-text-primary); }

/* ──────────────── COST TRAPS (LEDGER) ──────────────── */
.ledger {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}
.ledger-row {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-6);
	display: grid;
	grid-template-columns: 56px 1fr 1fr;
	gap: var(--space-6);
	align-items: start;
}
@media (max-width: 899px) {
	.ledger-row { grid-template-columns: 48px 1fr; gap: var(--space-4); padding: var(--space-4); }
	.ledger-solution { grid-column: 2 / 3; margin-top: var(--space-2); }
}
.ledger-num {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 28px;
	color: var(--appmerc-primary);
	line-height: 1;
	letter-spacing: -0.02em;
}
.ledger-problem h3 {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 16px;
	line-height: 1.3;
	margin: 0 0 var(--space-2);
	color: var(--appmerc-text-primary);
}
.ledger-problem p {
	color: var(--appmerc-text-secondary);
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
}
.ledger-problem em {
	color: var(--appmerc-text-primary);
	font-style: normal;
	font-weight: 600;
}

/* Solution panel — uses info/primary-light treatment per Forge §7.4 badge pattern */
.ledger-solution {
	background: var(--appmerc-primary-light);
	border: 1px solid var(--appmerc-primary);
	border-radius: var(--radius);
	padding: var(--space-4);
	position: relative;
}
.ledger-solution::before {
	content: "APPMERC";
	display: inline-block;
	font-family: var(--appmerc-font-mono);
	font-size: 10px;
	font-weight: 600;
	color: var(--appmerc-primary);
	letter-spacing: 0.08em;
	margin-bottom: var(--space-2);
}
.ledger-solution h4 {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 14px;
	color: var(--appmerc-text-primary);
	margin: 0 0 var(--space-2);
}
.ledger-solution > p {
	font-size: 13px;
	color: var(--appmerc-text-primary);
	line-height: 1.55;
	margin: 0;
}
.ledger-solution ul {
	list-style: none;
	margin: var(--space-2) 0 0;
	padding: 0;
}
.ledger-solution ul li {
	font-size: 13px;
	color: var(--appmerc-text-primary);
	padding: var(--space-0-5) 0 var(--space-0-5) var(--space-4);
	position: relative;
}
.ledger-solution ul li::before {
	content: "→";
	position: absolute; left: 0;
	color: var(--appmerc-primary);
	font-weight: 700;
}

/* ──────────────── AI PANEL ──────────────── */
.ai-panel {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-8);
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: var(--space-8);
	align-items: center;
}
@media (max-width: 899px) {
	.ai-panel { grid-template-columns: 1fr; padding: var(--space-6); gap: var(--space-6); }
}
.ai-panel h3 {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 22px;
	line-height: 1.25;
	letter-spacing: -0.015em;
	margin: 0 0 var(--space-3);
	color: var(--appmerc-text-primary);
}
.ai-panel h3 .accent { color: var(--appmerc-primary); }
.ai-panel > div > p {
	color: var(--appmerc-text-secondary);
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
}
.ai-code {
	font-family: var(--appmerc-font-mono);
	font-size: 13px;
	background: var(--appmerc-canvas);
	color: var(--appmerc-text-primary);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-4);
	line-height: 1.7;
	overflow-x: auto;
	margin: 0;
}
.ai-code .cmt { color: var(--appmerc-text-secondary); }
.ai-code .k   { color: var(--appmerc-primary); font-weight: 600; }
.ai-code .s   { color: var(--appmerc-success); }
.ai-code .n   { color: var(--appmerc-danger); }

/* ──────────────── COMPANY EXPERIENCE ──────────────── */
.experience-grid {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: var(--space-8);
	align-items: start;
}
@media (max-width: 899px) {
	.experience-grid { grid-template-columns: 1fr; gap: var(--space-6); }
}
.experience-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 24px;
	line-height: 1.2;
	letter-spacing: -0.015em;
	margin: 0 0 var(--space-3);
	color: var(--appmerc-text-primary);
}
.experience-title .accent { color: var(--appmerc-primary); }
.experience-lead {
	color: var(--appmerc-text-secondary);
	font-size: 14px;
	line-height: 1.6;
	margin: 0 0 var(--space-4);
}
.experience-lead strong { color: var(--appmerc-text-primary); font-weight: 600; }

.experience-tags {
	display: flex; flex-wrap: wrap; gap: var(--space-2);
	margin-top: var(--space-4);
}
/* Tags use Forge neutral badge pattern (§7.4) */
.tag {
	display: inline-flex; align-items: center;
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	font-weight: 500;
	padding: var(--space-0-5) var(--space-2);
	border-radius: var(--radius);
	background: var(--appmerc-canvas);
	color: var(--appmerc-text-secondary);
	border: 1px solid var(--appmerc-border);
}

.scale-ledger {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	overflow: hidden;
}
.scale-row {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: var(--space-4);
	padding: var(--space-4);
	border-bottom: 1px solid var(--appmerc-border);
	align-items: start;
}
.scale-row:last-child { border-bottom: 0; }
@media (max-width: 639px) {
	.scale-row { grid-template-columns: 1fr; gap: var(--space-1); padding: var(--space-3); }
}
.scale-label {
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	font-weight: 600;
	color: var(--appmerc-primary);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.scale-body {
	font-size: 14px;
	color: var(--appmerc-text-secondary);
	line-height: 1.55;
}
.scale-body .sh {
	color: var(--appmerc-text-primary);
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 15px;
	letter-spacing: -0.01em;
	display: block;
	margin-bottom: var(--space-1);
}

/* ──────────────── CTA BLOCK ──────────────── */
.cta-block {
	background: var(--appmerc-primary);
	color: #fff;
	padding: var(--space-12) 0;
	text-align: center;
}
.cta-block h2 {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: clamp(28px, 4vw, 40px);
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-4);
	color: #fff;
}
.cta-block h2 .accent {
	color: #fff;
	text-decoration: underline;
	text-decoration-color: rgba(255,255,255,0.5);
	text-underline-offset: 4px;
	text-decoration-thickness: 2px;
}
.cta-block > .wrap > p {
	color: rgba(255,255,255,0.9);
	font-size: 16px;
	max-width: 640px;
	margin: 0 auto var(--space-8);
	line-height: 1.6;
}
.cta-row-center { display: flex; gap: var(--space-2); justify-content: center; flex-wrap: wrap; }
.cta-block .btn-primary {
	background: #fff;
	color: var(--appmerc-primary);
	border-color: #fff;
}
.cta-block .btn-primary:hover {
	background: var(--appmerc-primary-light);
	color: var(--appmerc-primary);
	border-color: var(--appmerc-primary-light);
}
.cta-block .btn-ghost {
	background: transparent;
	color: #fff;
	border-color: rgba(255,255,255,0.5);
}
.cta-block .btn-ghost:hover {
	background: rgba(255,255,255,0.1);
	color: #fff;
	border-color: #fff;
}

/* CTA form wrap — uses Forge modal-lg surface treatment */
.cta-form-wrap {
	max-width: 640px;
	margin: var(--space-6) auto 0;
	text-align: left;
	background: var(--appmerc-surface);
	border-radius: var(--radius-lg);
	padding: var(--space-8);
	box-shadow: var(--shadow-xl);
	color: var(--appmerc-text-primary);
}
.cta-form-wrap label {
	display: block;
	font-size: 12px;
	font-weight: 500;
	color: var(--appmerc-text-primary);
	margin-bottom: var(--space-1);
}
.cta-form-wrap input[type="text"],
.cta-form-wrap input[type="email"],
.cta-form-wrap input[type="tel"],
.cta-form-wrap input[type="url"],
.cta-form-wrap textarea,
.cta-form-wrap select {
	width: 100%;
	height: 32px;
	padding: 0 var(--space-3);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	background: var(--appmerc-surface);
	color: var(--appmerc-text-primary);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	transition: border-color .15s;
	box-sizing: border-box;
}
.cta-form-wrap textarea {
	height: auto;
	min-height: 96px;
	padding: var(--space-2) var(--space-3);
}
.cta-form-wrap input:focus,
.cta-form-wrap textarea:focus,
.cta-form-wrap select:focus {
	outline: none;
	border-color: var(--appmerc-primary);
	box-shadow: 0 0 0 2px var(--appmerc-primary);
}
.cta-form-wrap input::placeholder,
.cta-form-wrap textarea::placeholder {
	color: var(--appmerc-text-disabled);
}
.cta-form-wrap button[type="submit"],
.cta-form-wrap input[type="submit"] {
	background: var(--appmerc-primary);
	color: #fff;
	border: 1px solid var(--appmerc-primary);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	font-weight: 500;
	height: 32px;
	padding: 0 var(--space-4);
	border-radius: var(--radius);
	cursor: pointer;
	transition: background-color .15s;
}
.cta-form-wrap button[type="submit"]:hover,
.cta-form-wrap input[type="submit"]:hover {
	background: var(--appmerc-primary-hover);
}

/* MailerLite embedded form — structural only. Inputs inherit the rules above;
   MailerLite's own stylesheet is intentionally not loaded so this matches the site. */
.cta-form-wrap .ml-form-embedContainer { width: 100%; }
.cta-form-wrap .ml-form-embedContent { margin-bottom: var(--space-4); }
.cta-form-wrap .ml-form-embedContent h4,
.cta-form-wrap .ml-form-successContent h4 {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 20px;
	letter-spacing: -0.015em;
	margin: 0 0 var(--space-2);
	color: var(--appmerc-text-primary);
}
.cta-form-wrap .ml-form-embedContent p,
.cta-form-wrap .ml-form-successContent p {
	font-size: 14px;
	line-height: 1.5;
	color: var(--appmerc-text-secondary);
	margin: 0;
}
.cta-form-wrap .ml-form-fieldRow { margin-bottom: var(--space-3); }
.cta-form-wrap .ml-form-embedSubmit { margin-top: var(--space-4); }
.cta-form-wrap .ml-form-embedSubmit button {
	width: 100%;
	background: var(--appmerc-primary);
	color: #fff;
	border: 1px solid var(--appmerc-primary);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	font-weight: 500;
	height: 32px;
	padding: 0 var(--space-4);
	border-radius: var(--radius);
	cursor: pointer;
	transition: background-color .15s;
}
.cta-form-wrap .ml-form-embedSubmit button:hover { background: var(--appmerc-primary-hover); }
.cta-form-wrap .ml-form-embedSubmit button.loading { display: none; }
.cta-form-wrap .ml-form-successContent { text-align: center; }
.cta-form-wrap .ml-error input,
.cta-form-wrap .ml-error textarea { border-color: #d64545 !important; }

/* Submit spinner (shown while MailerLite processes the AJAX submit). */
.cta-form-wrap .ml-form-embedSubmitLoad { display: inline-block; width: 20px; height: 20px; }
.cta-form-wrap .ml-form-embedSubmitLoad:after {
	content: " ";
	display: block;
	width: 11px;
	height: 11px;
	margin: 1px;
	border-radius: 50%;
	border: 4px solid #fff;
	border-color: #fff #fff #fff transparent;
	animation: ml-form-embedSubmitLoad 1.2s linear infinite;
}
@keyframes ml-form-embedSubmitLoad {
	0%   { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}
.cta-form-wrap .sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	border: 0;
}

/* ──────────────── FOOTER ──────────────── */
footer.site {
	padding: var(--space-6) 0;
	background: var(--appmerc-surface);
	border-top: 1px solid var(--appmerc-border);
	font-size: 13px;
	color: var(--appmerc-text-secondary);
}
.footer-inner {
	display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4);
	align-items: center;
}
.footer-inner a {
	color: var(--appmerc-text-secondary);
	text-decoration: none;
}
.footer-inner a:hover {
	color: var(--appmerc-primary);
	text-decoration: underline;
}
.footer-links {
	display: flex; gap: var(--space-4); flex-wrap: wrap;
	list-style: none; margin: 0; padding: 0;
}

/* ──────────────── BLOG ──────────────── */
.editorial-wrap {
	max-width: 720px;
	margin: 0 auto;
	padding: var(--space-12) var(--space-4) var(--space-12);
}
@media (max-width: 639px) { .editorial-wrap { padding: var(--space-8) var(--space-4); } }

.editorial-kicker {
	font-size: 12px;
	font-weight: 600;
	color: var(--appmerc-primary);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-bottom: var(--space-4);
}

h1.editorial-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: clamp(28px, 4.5vw, 40px);
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-4);
	color: var(--appmerc-text-primary);
}
h1.editorial-title .accent { color: var(--appmerc-primary); }

.post-meta {
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	color: var(--appmerc-text-secondary);
	margin-bottom: var(--space-6);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--appmerc-border);
}
.post-meta .sep { margin: 0 var(--space-2); color: var(--appmerc-border-strong); }
.post-meta .meta-cats a { color: var(--appmerc-text-secondary); }
.post-meta .meta-cats a:hover { color: var(--appmerc-primary); }

.editorial-featured {
	margin: 0 0 var(--space-6);
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--appmerc-border);
}

.editorial-body {
	font-size: 16px;
	line-height: 1.65;
	color: var(--appmerc-text-primary);
}
.editorial-body > * { margin: 0 0 var(--space-4); }
.editorial-body > *:last-child { margin-bottom: 0; }

.editorial-body h2 {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 24px;
	line-height: 1.25;
	letter-spacing: -0.01em;
	color: var(--appmerc-text-primary);
	margin: var(--space-8) 0 var(--space-3);
}
.editorial-body h3 {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 18px;
	line-height: 1.3;
	color: var(--appmerc-text-primary);
	margin: var(--space-6) 0 var(--space-2);
}
.editorial-body h4 {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 14px;
	color: var(--appmerc-text-primary);
	margin: var(--space-4) 0 var(--space-2);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.editorial-body p { color: var(--appmerc-text-primary); font-size: 16px; }
.editorial-body p.intro {
	font-size: 18px;
	line-height: 1.55;
	color: var(--appmerc-text-primary);
	font-weight: 500;
}
.editorial-body a {
	color: var(--appmerc-primary);
	text-decoration: underline;
	text-underline-offset: 2px;
}
.editorial-body a:hover { color: var(--appmerc-primary-hover); }
.editorial-body strong { color: var(--appmerc-text-primary); font-weight: 600; }
.editorial-body em { font-style: italic; }
.editorial-body blockquote {
	border-left: 4px solid var(--appmerc-primary);
	padding: var(--space-1) 0 var(--space-1) var(--space-4);
	margin: var(--space-6) 0;
	color: var(--appmerc-text-secondary);
	font-style: italic;
}
.editorial-body ul,
.editorial-body ol {
	padding-left: var(--space-6);
	color: var(--appmerc-text-primary);
}
.editorial-body li { margin-bottom: var(--space-1); }
.editorial-body code {
	font-family: var(--appmerc-font-mono);
	font-size: 0.88em;
	background: var(--appmerc-canvas);
	padding: 2px 6px;
	border-radius: 2px;
	color: var(--appmerc-text-primary);
	border: 1px solid var(--appmerc-border);
}
.editorial-body pre {
	background: var(--appmerc-canvas);
	color: var(--appmerc-text-primary);
	padding: var(--space-4);
	border-radius: var(--radius);
	overflow-x: auto;
	font-family: var(--appmerc-font-mono);
	font-size: 13px;
	line-height: 1.6;
	border: 1px solid var(--appmerc-border);
}
.editorial-body pre code {
	background: transparent;
	padding: 0;
	color: inherit;
	font-size: inherit;
	border: 0;
}
.editorial-body img,
.editorial-body figure {
	border-radius: var(--radius);
	overflow: hidden;
	border: 1px solid var(--appmerc-border);
}
.editorial-body figure figcaption {
	font-size: 12px;
	color: var(--appmerc-text-secondary);
	padding: var(--space-2) var(--space-3);
	border-top: 1px solid var(--appmerc-border);
	background: var(--appmerc-canvas);
}
.editorial-body hr {
	border: 0;
	border-top: 1px solid var(--appmerc-border);
	margin: var(--space-6) 0;
}

.editorial-footer {
	margin-top: var(--space-8);
	padding-top: var(--space-4);
	border-top: 1px solid var(--appmerc-border);
	font-size: 13px;
	color: var(--appmerc-text-secondary);
}
.editorial-tags a {
	display: inline-block;
	padding: var(--space-0-5) var(--space-2);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	margin: 0 var(--space-1) var(--space-1) 0;
	color: var(--appmerc-text-secondary);
	text-decoration: none;
	font-size: 12px;
	background: var(--appmerc-canvas);
}
.editorial-tags a:hover {
	border-color: var(--appmerc-primary);
	color: var(--appmerc-primary);
	background: var(--appmerc-primary-light);
}

/* ──────────────── BLOG LIST / ARCHIVE ──────────────── */
.archive-hero {
	padding: var(--space-12) 0 var(--space-8);
	background: var(--appmerc-surface);
	border-bottom: 1px solid var(--appmerc-border);
}
.archive-hero h1 {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: clamp(32px, 5vw, 48px);
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: var(--space-2) 0 var(--space-3);
	color: var(--appmerc-text-primary);
}
.archive-hero h1 .accent { color: var(--appmerc-primary); }
.archive-hero p {
	font-size: 16px;
	color: var(--appmerc-text-secondary);
	max-width: 640px;
	line-height: 1.6;
	margin: 0;
}

.post-list {
	padding: var(--space-8) 0 var(--space-12);
}
.post-list-inner {
	max-width: 960px;
}
.post-entry {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-6);
	margin-bottom: var(--space-4);
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: var(--space-6);
	align-items: start;
	transition: border-color .15s ease, box-shadow .15s ease;
}
.post-entry:hover {
	border-color: var(--appmerc-primary);
	box-shadow: var(--shadow-lg);
}
@media (max-width: 767px) {
	.post-entry {
		grid-template-columns: 1fr;
		gap: var(--space-2);
		padding: var(--space-4);
	}
}
.post-entry .post-entry-meta {
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	color: var(--appmerc-text-secondary);
	line-height: 1.5;
}
.post-entry .post-entry-meta .date {
	display: block;
	color: var(--appmerc-primary);
	margin-bottom: var(--space-1);
	font-weight: 600;
}
.post-entry h2 {
	font-family: var(--appmerc-font-sans);
	font-weight: 600;
	font-size: 20px;
	line-height: 1.25;
	letter-spacing: -0.01em;
	margin: 0 0 var(--space-2);
}
.post-entry h2 a { color: var(--appmerc-text-primary); text-decoration: none; }
.post-entry h2 a:hover { color: var(--appmerc-primary); }
.post-entry .excerpt {
	color: var(--appmerc-text-secondary);
	font-size: 14px;
	line-height: 1.6;
	margin: 0 0 var(--space-3);
}
.post-entry .read-more {
	font-family: var(--appmerc-font-sans);
	font-size: 13px;
	font-weight: 500;
	color: var(--appmerc-primary);
	text-decoration: none;
}
.post-entry .read-more:hover { text-decoration: underline; }

.appmerc-pagination {
	margin-top: var(--space-8);
	padding-top: var(--space-4);
	border-top: 1px solid var(--appmerc-border);
}
.appmerc-pagination ul {
	list-style: none; padding: 0; margin: 0;
	display: flex; gap: var(--space-1); flex-wrap: wrap;
	justify-content: center;
}
.appmerc-pagination li a,
.appmerc-pagination li span {
	display: inline-block;
	height: 32px;
	padding: 0 var(--space-3);
	line-height: 30px;
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	font-size: 13px;
	color: var(--appmerc-text-primary);
	text-decoration: none;
	background: var(--appmerc-surface);
	transition: all .15s;
}
.appmerc-pagination li a:hover {
	border-color: var(--appmerc-primary);
	color: var(--appmerc-primary);
	background: var(--appmerc-primary-light);
}
.appmerc-pagination li .current {
	border-color: var(--appmerc-primary);
	background: var(--appmerc-primary);
	color: #fff;
}

/* ──────────────── COMMENTS ──────────────── */
.comments-area {
	max-width: 720px;
	margin: 0 auto;
	padding: 0 var(--space-4) var(--space-12);
}
.comments-area h2.comments-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 20px;
	letter-spacing: -0.01em;
	margin-bottom: var(--space-6);
	color: var(--appmerc-text-primary);
}
.comment-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-8);
}
.comment-list .comment {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-4);
	margin-bottom: var(--space-3);
}
.comment-meta {
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	color: var(--appmerc-text-secondary);
	margin-bottom: var(--space-2);
}
.comment-form label {
	display: block;
	font-size: 12px;
	font-weight: 500;
	color: var(--appmerc-text-primary);
	margin-bottom: var(--space-1);
}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: var(--space-2) var(--space-3);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	background: var(--appmerc-surface);
	color: var(--appmerc-text-primary);
	margin-bottom: var(--space-3);
}
.comment-form input:focus,
.comment-form textarea:focus {
	outline: none;
	border-color: var(--appmerc-primary);
	box-shadow: 0 0 0 2px var(--appmerc-primary);
}
.comment-form .submit {
	background: var(--appmerc-primary);
	color: #fff;
	border: 1px solid var(--appmerc-primary);
	padding: 0 var(--space-4);
	height: 32px;
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	font-weight: 500;
	border-radius: var(--radius);
	cursor: pointer;
}
.comment-form .submit:hover {
	background: var(--appmerc-primary-hover);
	border-color: var(--appmerc-primary-hover);
}

/* ──────────────── 404 / SEARCH ──────────────── */
.error-hero {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: var(--space-12) var(--space-4);
	background: var(--appmerc-surface);
}
.error-hero h1 {
	font-family: var(--appmerc-font-sans);
	font-size: clamp(48px, 8vw, 96px);
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.03em;
	margin: 0 0 var(--space-3);
	color: var(--appmerc-text-primary);
}
.error-hero h1 .accent { color: var(--appmerc-primary); }
.error-hero p {
	color: var(--appmerc-text-secondary);
	font-size: 16px;
	margin: 0 0 var(--space-6);
	max-width: 480px;
}

.search-form {
	display: flex; gap: var(--space-2); max-width: 480px; margin: 0 auto;
}
.search-form input[type="search"] {
	flex: 1;
	height: 32px;
	padding: 0 var(--space-3);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	background: var(--appmerc-surface);
	color: var(--appmerc-text-primary);
}
.search-form input[type="search"]:focus {
	outline: none;
	border-color: var(--appmerc-primary);
	box-shadow: 0 0 0 2px var(--appmerc-primary);
}
.search-form button {
	background: var(--appmerc-primary);
	color: #fff;
	border: 1px solid var(--appmerc-primary);
	font-family: var(--appmerc-font-sans);
	font-size: 14px;
	font-weight: 500;
	padding: 0 var(--space-4);
	height: 32px;
	border-radius: var(--radius);
	cursor: pointer;
}
.search-form button:hover {
	background: var(--appmerc-primary-hover);
	border-color: var(--appmerc-primary-hover);
}

/* ──────────────── REVEAL (Forge §9 motion) ──────────────── */
.reveal {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity .3s ease, transform .3s ease;
}
.reveal.on { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
	.reveal { opacity: 1; transform: none; transition: none; }
	html { scroll-behavior: auto; }
	.btn, .cap, .post-entry { transition: none !important; }
}

/* ──────────────── WIDGETS ──────────────── */
.widget { margin-bottom: var(--space-6); }
.widget-title {
	font-family: var(--appmerc-font-sans);
	font-size: 12px;
	font-weight: 600;
	color: var(--appmerc-text-secondary);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin: 0 0 var(--space-2);
}
.widget ul { list-style: none; padding: 0; margin: 0; }
.widget li {
	padding: var(--space-1) 0;
	border-bottom: 1px solid var(--appmerc-border);
	font-size: 14px;
}
.widget li a {
	color: var(--appmerc-text-secondary);
	text-decoration: none;
}
.widget li a:hover {
	color: var(--appmerc-primary);
	text-decoration: underline;
}

/* ──────────────── VETRIX PARTNER CARD ──────────────── */
.vetrix-card {
	background: var(--appmerc-surface);
	border: 1px solid var(--appmerc-border);
	border-radius: var(--radius);
	padding: var(--space-8);
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--space-8);
	align-items: center;
	overflow: hidden;
	position: relative;
}
.vetrix-card::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 4px;
	background: var(--appmerc-primary);
}
@media (max-width: 899px) {
	.vetrix-card {
		grid-template-columns: 1fr;
		padding: var(--space-6);
		gap: var(--space-6);
	}
}

/* Mirrored variant: side panel on the left, body aligned to the right —
   the opposite of the 01A tooling card, for an alternating layout. */
.vetrix-card--reverse {
	grid-template-columns: 1fr 1.4fr;
}
.vetrix-card--reverse .vetrix-card-body { order: 2; }
.vetrix-card--reverse .vetrix-card-side { order: 1; }
.vetrix-card--reverse::before {
	inset: 0 0 0 auto;  /* accent bar on the right edge */
}
@media (max-width: 899px) {
	.vetrix-card--reverse { grid-template-columns: 1fr; }
	/* Stack body first on small screens for natural reading order. */
	.vetrix-card--reverse .vetrix-card-body { order: 0; }
	.vetrix-card--reverse .vetrix-card-side { order: 0; }
}

.vetrix-title {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 24px;
	line-height: 1.2;
	letter-spacing: -0.015em;
	margin: 0 0 var(--space-3);
	color: var(--appmerc-text-primary);
}
.vetrix-title .accent { color: var(--appmerc-primary); }

.vetrix-lead {
	color: var(--appmerc-text-secondary);
	font-size: 14px;
	line-height: 1.6;
	margin: 0 0 var(--space-4);
}

.vetrix-points {
	list-style: none;
	margin: 0 0 var(--space-6);
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-3) var(--space-6);
}
@media (max-width: 639px) {
	.vetrix-points { grid-template-columns: 1fr; }
}
.vetrix-points li {
	font-size: 13px;
	line-height: 1.55;
	color: var(--appmerc-text-secondary);
	padding-left: var(--space-3);
	position: relative;
}
.vetrix-points li::before {
	content: "";
	position: absolute;
	left: 0; top: 8px;
	width: 6px; height: 6px;
	background: var(--appmerc-primary);
	border-radius: 1px;
}
.vetrix-points strong {
	color: var(--appmerc-text-primary);
	font-weight: 600;
	display: block;
	margin-bottom: 2px;
}

.vetrix-cta-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

/* Right-side tagline panel — primary-light surface to echo Forge §2.2 */
.vetrix-card-side {
	background: var(--appmerc-primary-light);
	border-radius: var(--radius);
	padding: var(--space-6);
	align-self: stretch;
	display: flex;
	flex-direction: column;
	position: relative;  /* anchor for the upper-right logo */
}
.vetrix-tagline-eyebrow {
	font-family: var(--appmerc-font-mono);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--appmerc-primary-hover);
	margin-bottom: var(--space-3);
}
/* Logo pinned to the upper-right of the side panel — out of normal flow so
   the tagline + sub stay vertically centered relative to the panel itself. */
.vetrix-logo {
	position: absolute;
	top: var(--space-4);
	right: var(--space-4);
	margin: 0;
	line-height: 0;
}
.vetrix-logo-img {
	max-width: 125px;
	max-height: 80px;  /* clamp portrait-orientation logos */
	width: auto;
	height: auto;
	display: block;
}
/* Push the tagline below the corner logo. Sibling selector means this
   only applies when a logo is present — the text-eyebrow fallback path
   doesn't leave a phantom gap. */
.vetrix-logo + .vetrix-tagline {
	margin-top: 90px;
}
@media (max-width: 639px) {
	.vetrix-logo-img { max-width: 96px; max-height: 60px; }
	.vetrix-logo + .vetrix-tagline { margin-top: 70px; }
}
.vetrix-tagline {
	font-family: var(--appmerc-font-sans);
	font-weight: 700;
	font-size: 28px;
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--appmerc-text-primary);
	margin-bottom: var(--space-2);
}
.vetrix-tagline .accent { color: var(--appmerc-primary); }
.vetrix-sub {
	font-size: 13px;
	color: var(--appmerc-text-secondary);
	line-height: 1.5;
}
