/* A5: README §2 A5 Color System — canonical tokens in :root. No !important. */
:root {
	--a5-surface-light: #f5f7f6;
	--a5-surface-white: #ffffff;
	--a5-surface-dark: #2a2a2e;
	--a5-text-primary: #111111;
	--a5-text-secondary: #6b6f6d;
	--a5-text-on-dark: #ededed;
	--a5-accent: #7faf9a;
	--a5-accent-strong: #6e9f8a;
	--a5-accent-soft: #e4efeb;
	--a5-border-primary: #e6e9e7;
	--a5-border-secondary: #d8ddda;
	/* Legacy names (surface = white, ink = primary text on light) */
	--a5-ink: #111111;
	--a5-surface: #ffffff;
	--a5-shadow: 0 1px 0 rgba(17, 17, 17, 0.06), 0 18px 40px rgba(42, 42, 46, 0.06);
	--a5-radius: 0.75rem;
	--a5-radius-lg: 1.25rem;
	--a5-font-sans: "Inter", ui-sans-serif, system-ui, sans-serif;
	--a5-font-display: "Plus Jakarta Sans", "Inter", ui-sans-serif, system-ui, sans-serif;
	--a5-header-h: 3.4rem;
	--a5-header-pad-y: 0.45rem;
	--a5-header-pad-x: clamp(1rem, 4vw, 1.75rem);
	--a5-sticky-header-total: calc(2 * var(--a5-header-pad-y) + var(--a5-header-h) + 1px);
}

html {
	color-scheme: light;
	scroll-behavior: smooth;
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
	font-family: var(--a5-font-sans);
	font-synthesis: none;
}

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

body {
	margin: 0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.iv-body {
	background: var(--a5-surface-light);
	color: var(--a5-text-primary);
}

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

/* --- Site header: solid Surface / Dark on all pages (README §2); sticky lives on .iv-site-header-root */
.iv-site-header {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	background: var(--a5-surface-dark);
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
	border: none;
	outline: none;
	border-bottom: 1px solid rgba(230, 233, 231, 0.14);
}

.iv-site-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	row-gap: 0.35rem;
	gap: 0.45rem 1rem;
	width: 98%;
	max-width: 98%;
	box-sizing: border-box;
	margin-inline: auto;
	padding: var(--a5-header-pad-y) var(--a5-header-pad-x);
	min-height: var(--a5-header-h);
}

.iv-brand-mark {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	text-decoration: none;
	border-radius: 0.375rem;
}

.iv-brand-block {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.iv-brand-mark .iv-brand-mark-img {
	display: block;
	width: 2.4rem;
	height: 2.4rem;
	object-fit: contain;
}

/* Nav (§8: flat, specific) */
.iv-site-nav {
	margin-left: auto;
}

/* Mobile: desktop banner hidden; tablet/desktop-only (§8). iv-* only (§3). */
@media (max-width: 639px) {
	.iv-site-header {
		display: none;
	}
}

/*
 * Banner landmark wrapper: sticky, top-aligned, above page layers (§8).
 * Below mobile nav modal (500) and skip link (1000) so dialogs / focus skip stay on top.
 */
.iv-site-header-root {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	left: 0;
	right: 0;
	z-index: 400;
	width: 100%;
	box-sizing: border-box;
}

/* Mobile-only bar: solid Surface / Dark, same as desktop banner (§2) */
.iv-site-header-mobile {
	display: none;
	position: relative;
	width: 100%;
	box-sizing: border-box;
	background: var(--a5-surface-dark);
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
	border-bottom: 1px solid rgba(230, 233, 231, 0.14);
}

@media (max-width: 639px) {
	.iv-site-header-mobile {
		display: block;
	}
}

.iv-site-header-mobile-inner {
	display: grid;
	grid-template-columns: minmax(2.75rem, 1fr) auto minmax(2.75rem, 1fr);
	align-items: center;
	width: 98%;
	max-width: 98%;
	box-sizing: border-box;
	margin-inline: auto;
	padding: var(--a5-header-pad-y) var(--a5-header-pad-x);
	min-height: var(--a5-header-h);
	column-gap: 0.35rem;
}

.iv-site-header-mobile-col--start {
	justify-self: start;
}

.iv-site-header-mobile-col--center {
	justify-self: center;
	text-align: center;
}

.iv-site-header-mobile-col--end {
	justify-self: end;
}

.iv-mobile-nav-open,
.iv-mobile-nav-close,
.iv-mobile-build-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.75rem;
	min-height: 2.75rem;
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	border: none;
	border-radius: 0.375rem;
	background: transparent;
	color: var(--a5-surface-white);
	cursor: pointer;
	-webkit-tap-highlight-color: transparent;
	transition: color 0.25s ease, background 0.25s ease;
}

.iv-mobile-build-link {
	text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
	.iv-mobile-nav-open:hover,
	.iv-mobile-nav-close:hover,
	.iv-mobile-build-link:hover {
		color: var(--a5-accent);
	}
}

.iv-mobile-nav-open:focus-visible,
.iv-mobile-nav-close:focus-visible,
.iv-mobile-build-link:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
	color: var(--a5-accent);
}

.iv-brand-mark--mobile-bar .iv-brand-mark-img {
	width: 2.2rem;
	height: 2.2rem;
}

/* Full-screen nav modal: bottom sheet, centered column, safe-area; §2 §8 */
.iv-mobile-nav-modal {
	position: fixed;
	inset: 0;
	z-index: 500;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-end;
	box-sizing: border-box;
	padding: 0;
	margin: 0;
	border: none;
	background: transparent;
}

.iv-mobile-nav-modal[hidden] {
	display: none;
}

/* Bottom sheet motion: panel slides up / down; backdrop fades (§8; honor reduced-motion below) */
.iv-mobile-nav-modal:not([hidden]) .iv-mobile-nav-modal-backdrop {
	opacity: 0;
	transition: opacity 0.32s ease;
}

.iv-mobile-nav-modal:not([hidden]).iv-mobile-nav-modal--open .iv-mobile-nav-modal-backdrop {
	opacity: 1;
}

.iv-mobile-nav-modal-backdrop {
	position: absolute;
	inset: 0;
	z-index: 0;
	/* Text / Primary @ ~50% — scrim over page; panel below stays Surface / White (§2) */
	background: rgba(17, 17, 17, 0.48);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
}

.iv-mobile-nav-modal:not([hidden]) .iv-mobile-nav-modal-panel {
	transform: translate3d(0, 100%, 0);
	transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}

.iv-mobile-nav-modal:not([hidden]).iv-mobile-nav-modal--open .iv-mobile-nav-modal-panel {
	transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce) {
	.iv-mobile-nav-modal:not([hidden]) .iv-mobile-nav-modal-panel,
	.iv-mobile-nav-modal:not([hidden]) .iv-mobile-nav-modal-backdrop {
		transition-duration: 0.01ms;
	}
}

.iv-mobile-nav-modal-panel {
	position: relative;
	z-index: 1;
	flex: 0 1 auto;
	display: flex;
	flex-direction: column;
	min-height: 0;
	min-width: 0;
	width: 100%;
	max-width: min(28rem, 100%);
	margin: 0;
	box-sizing: border-box;
	background: var(--a5-surface-white);
	border: none;
	border-radius: var(--a5-radius-lg) var(--a5-radius-lg) 0 0;
	overflow: hidden;
	max-height: min(88vh, 100%);
	max-height: min(88dvh, 100%);
	box-shadow: var(--a5-shadow);
}

.iv-mobile-nav-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-shrink: 0;
	padding: max(var(--a5-header-pad-y), env(safe-area-inset-top, 0px)) var(--a5-header-pad-x) var(--a5-header-pad-y);
	border-bottom: 1px solid var(--a5-border-primary);
}

.iv-mobile-nav-modal-title {
	margin: 0;
	flex: 1 1 auto;
	min-width: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(1.12rem, 0.55vw + 1rem, 1.28rem);
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.2;
	color: var(--a5-text-primary);
}

/* Close control inside modal: dark foreground on white panel (bar uses .iv-mobile-nav-close + white) */
.iv-mobile-nav-modal .iv-mobile-nav-close {
	flex-shrink: 0;
	color: var(--a5-text-primary);
}

@media (hover: hover) and (pointer: fine) {
	.iv-mobile-nav-modal .iv-mobile-nav-close:hover {
		background: var(--a5-accent-soft);
	}
}

.iv-mobile-nav-modal-body {
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	padding: 0.75rem var(--a5-header-pad-x) calc(1.25rem + env(safe-area-inset-bottom, 0px));
}

.iv-mobile-nav-modal-nav .iv-mobile-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 0.375rem;
}

.iv-mobile-nav-modal-nav .iv-mobile-nav-list > li {
	list-style: none;
	margin: 0;
	padding: 0;
	display: block;
	width: 100%;
}

.iv-mobile-nav-modal-nav .iv-nav-link {
	display: flex;
	align-items: center;
	width: 100%;
	box-sizing: border-box;
	padding: 1rem 0.9rem;
	min-height: 3rem;
	font-family: var(--a5-font-display);
	font-size: 1.05rem;
	font-weight: 600;
	line-height: 1.3;
	color: var(--a5-text-primary);
	text-decoration: none;
	border-radius: var(--a5-radius);
	border: 1px solid transparent;
	background: transparent;
	transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
	.iv-mobile-nav-modal-nav .iv-nav-link:hover {
		color: var(--a5-accent);
		background: var(--a5-accent-soft);
		border-color: var(--a5-border-primary);
	}

	.iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-ancestor a.iv-nav-link:hover,
	.iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-item a.iv-nav-link:hover,
	.iv-mobile-nav-modal-nav .iv-mobile-nav-list .current_page_item a.iv-nav-link:hover,
	.iv-mobile-nav-modal-nav a.iv-nav-link[aria-current="page"]:hover {
		color: var(--a5-accent-strong);
		background: transparent;
		border-color: transparent;
	}
}

.iv-mobile-nav-modal-nav .iv-nav-link:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
	color: var(--a5-accent);
}

.iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-ancestor a.iv-nav-link,
.iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-item a.iv-nav-link,
.iv-mobile-nav-modal-nav .iv-mobile-nav-list .current_page_item a.iv-nav-link,
.iv-mobile-nav-modal-nav a.iv-nav-link[aria-current="page"] {
	color: var(--a5-accent);
	background: transparent;
	border-color: transparent;
}

body.a5-mobile-nav-open {
	overflow: hidden;
}

@media (min-width: 640px) {
	body.a5-mobile-nav-open {
		overflow: visible;
	}
}

/* WP menu + fallback: list layout and touch-friendly rows */
.iv-site-nav-list,
.iv-site-nav-list .menu-item {
	list-style: none;
	margin: 0;
}

.iv-site-nav-list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
	padding: 0;
}

.iv-site-nav-list .menu-item {
	display: flex;
	align-items: stretch;
}

/* Primary nav inside header: default Surface / White; hover/active Accent (§2); focus ring §8 */
.iv-site-header .iv-nav-link {
	font-family: var(--a5-font-display);
	font-size: clamp(0.88rem, 0.22vw + 0.8rem, 1rem);
	font-weight: 600;
	letter-spacing: 0.015em;
	text-transform: none;
	color: var(--a5-surface-white);
	text-decoration: none;
	white-space: nowrap;
	padding: 0.4rem 0.8rem;
	min-height: 2.2rem;
	display: inline-flex;
	align-items: center;
	box-sizing: border-box;
	border-radius: 0;
	background: transparent;
	border: 1px solid transparent;
	transition: color 0.35s ease;
}

@media (prefers-reduced-motion: reduce) {
	.iv-site-header .iv-nav-link {
		transition: none;
	}
}

@media (hover: hover) and (pointer: fine) {
	.iv-site-header .iv-nav-link:hover {
		color: var(--a5-accent);
	}
}

.iv-site-header .iv-nav-link:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
	color: var(--a5-accent);
}

@media (hover: none) {
	.iv-site-header .iv-nav-link:active {
		color: var(--a5-accent-strong);
		transition-duration: 0.35s;
	}
}

/* WP: current / ancestor — same accent as hover; no pill border/bg on dark header (§2) */
.iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link,
.iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link,
.iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link,
.iv-site-header a.iv-nav-link[aria-current="page"] {
	color: var(--a5-accent);
	background: transparent;
	border-color: transparent;
	box-shadow: none;
}

@media (hover: hover) and (pointer: fine) {
	.iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link:hover,
	.iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link:hover,
	.iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link:hover,
	.iv-site-header a.iv-nav-link[aria-current="page"]:hover {
		color: var(--a5-accent-strong);
	}
}

.iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link:focus-visible,
.iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link:focus-visible,
.iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link:focus-visible,
.iv-site-header a.iv-nav-link[aria-current="page"]:focus-visible {
	color: var(--a5-accent);
}

/* Services + Work hub/listing: suppress “current” accent in the bar — links stay white like siblings; About + Contact use global current accent (§2) */
body.a5-body-services .iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link,
body.a5-body-services .iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link,
body.a5-body-services .iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link,
body.a5-body-services .iv-site-header a.iv-nav-link[aria-current="page"],
body.a5-body-work .iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link,
body.a5-body-work .iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link,
body.a5-body-work .iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link,
body.a5-body-work .iv-site-header a.iv-nav-link[aria-current="page"] {
	color: var(--a5-surface-white);
	background: transparent;
	border-color: transparent;
	box-shadow: none;
}

@media (hover: hover) and (pointer: fine) {
	body.a5-body-services .iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link:hover,
	body.a5-body-services .iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link:hover,
	body.a5-body-services .iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link:hover,
	body.a5-body-services .iv-site-header a.iv-nav-link[aria-current="page"]:hover,
	body.a5-body-work .iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link:hover,
	body.a5-body-work .iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link:hover,
	body.a5-body-work .iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link:hover,
	body.a5-body-work .iv-site-header a.iv-nav-link[aria-current="page"]:hover {
		color: var(--a5-accent);
	}
}

body.a5-body-services .iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link:focus-visible,
body.a5-body-services .iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link:focus-visible,
body.a5-body-services .iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link:focus-visible,
body.a5-body-services .iv-site-header a.iv-nav-link[aria-current="page"]:focus-visible,
body.a5-body-work .iv-site-header .iv-site-nav-list .current-menu-ancestor a.iv-nav-link:focus-visible,
body.a5-body-work .iv-site-header .iv-site-nav-list .current-menu-item a.iv-nav-link:focus-visible,
body.a5-body-work .iv-site-header .iv-site-nav-list .current_page_item a.iv-nav-link:focus-visible,
body.a5-body-work .iv-site-header a.iv-nav-link[aria-current="page"]:focus-visible {
	color: var(--a5-accent);
}

body.a5-body-services .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-ancestor a.iv-nav-link,
body.a5-body-services .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-item a.iv-nav-link,
body.a5-body-services .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current_page_item a.iv-nav-link,
body.a5-body-services .iv-mobile-nav-modal-nav a.iv-nav-link[aria-current="page"],
body.a5-body-work .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-ancestor a.iv-nav-link,
body.a5-body-work .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-item a.iv-nav-link,
body.a5-body-work .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current_page_item a.iv-nav-link,
body.a5-body-work .iv-mobile-nav-modal-nav a.iv-nav-link[aria-current="page"] {
	color: var(--a5-text-primary);
	background: transparent;
	border-color: transparent;
}

@media (hover: hover) and (pointer: fine) {
	body.a5-body-services .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-ancestor a.iv-nav-link:hover,
	body.a5-body-services .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-item a.iv-nav-link:hover,
	body.a5-body-services .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current_page_item a.iv-nav-link:hover,
	body.a5-body-services .iv-mobile-nav-modal-nav a.iv-nav-link[aria-current="page"]:hover,
	body.a5-body-work .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-ancestor a.iv-nav-link:hover,
	body.a5-body-work .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current-menu-item a.iv-nav-link:hover,
	body.a5-body-work .iv-mobile-nav-modal-nav .iv-mobile-nav-list .current_page_item a.iv-nav-link:hover,
	body.a5-body-work .iv-mobile-nav-modal-nav a.iv-nav-link[aria-current="page"]:hover {
		color: var(--a5-accent);
		background: var(--a5-accent-soft);
		border-color: var(--a5-border-primary);
	}
}

/* Shared focus: buttons, logo (not duplicate header nav) */
.iv-button:focus-visible,
.iv-brand-mark:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

/* --- Typographic scale: front page (strict hierarchy, spacing, scale) --- */
/*
 * Hero title: #hero-title + .iv-hero h1 (high specificity) so it wins over Tailwind CDN
 * and applies even if body class differs. body.a5-body-home kept for parity.
 */
#hero-title.iv-hero-title,
body.a5-body-home .iv-hero h1#hero-title.iv-hero-title,
body.a5-body-home .iv-hero .iv-hero-title {
	font-family: var(--a5-font-display);
	/* Full width of .iv-section-inner; lead/CTAs keep their own max-widths */
	max-width: 100%;
	box-sizing: border-box;
	font-size: clamp(3rem, 1.25rem + 8.5vw, 16rem);
	font-weight: 800;
	line-height: 0.95;
	letter-spacing: -0.15rem;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: clamp(0.06em, 0.35vw + 0.03em, 0.14em);
}

/* Hero h1: UA margin scales with huge display type; keep rhythm via .iv-lead (class-only §3) */
body.a5-body-home .iv-hero h1.iv-hero-title {
	margin-block: 0;
	margin-inline: 0;
}

body.a5-body-home .iv-hero h1.iv-hero-title + .iv-lead {
	margin-top: clamp(0.75rem, 1.65vw, 1.35rem);
}

/* Two title lines: identical size and style (inherited from h1) */
#hero-title .iv-hero-title-line,
body.a5-body-home .iv-hero h1#hero-title .iv-hero-title-line {
	display: block;
	margin: 0;
	padding: 0;
	font: inherit;
	letter-spacing: inherit;
	color: inherit;
}

/* Split lines: air between light + accent words (flex gap; no reliance on HTML whitespace) */
#hero-title .iv-hero-title-line.iv-hero-title-line--split,
body.a5-body-home .iv-hero h1#hero-title .iv-hero-title-line.iv-hero-title-line--split {
	display: inline-flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: baseline;
	column-gap: clamp(0.1em, 0.4vw + 0.05em, 0.24em);
	row-gap: 0.03em;
	min-width: 0;
}

/* Hero lines: words Surface / White; sentence-ending dots Accent / Primary (§2); iv-* only (§3) */
#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word,
body.a5-body-home .iv-hero h1#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word {
	font: inherit;
	letter-spacing: inherit;
}

#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word--light,
body.a5-body-home .iv-hero h1#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word--light {
	color: var(--a5-surface-white);
}

#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word--accent,
body.a5-body-home .iv-hero h1#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word--accent {
	color: var(--a5-surface-white);
}

#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word--accent .iv-hero-title-accent-dot,
body.a5-body-home .iv-hero h1#hero-title .iv-hero-title-line.iv-hero-title-line--split .iv-hero-title-word--accent .iv-hero-title-accent-dot {
	color: var(--a5-accent);
}

#hero-title + .iv-lead,
body.a5-body-home .iv-hero .iv-lead {
	font-size: clamp(1.12rem, 0.42vw + 1.02rem, 1.48rem);
	line-height: 1.65;
	font-weight: 300;
	max-width: 38rem;
}

/* Hero lead: Surface / White on dark hero (§2); iv-* only (§3) */
#hero-title + .iv-lead.iv-lead--surface-white,
body.a5-body-home .iv-hero .iv-lead.iv-lead--surface-white {
	color: var(--a5-surface-white);
}

/* Hero micro-proof: compact row; accent icon only (§2); iv-* only (§3) */
body.a5-body-home .iv-hero .iv-hero-micro-proof {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}

body.a5-body-home .iv-hero .iv-hero-micro-proof-icon {
	display: inline-flex;
	flex-shrink: 0;
	margin-top: 0.08em;
	color: var(--a5-accent);
}

body.a5-body-home .iv-hero .iv-hero-micro-proof-shield {
	display: block;
	width: 0.95rem;
	height: 0.95rem;
}

body.a5-body-home .iv-hero .iv-hero-micro-proof-text {
	flex: 1;
	min-width: 0;
	margin: 0;
	font-size: clamp(0.78rem, 0.06vw + 0.74rem, 0.875rem);
	line-height: 1.42;
	font-weight: 400;
	letter-spacing: 0.015em;
	color: rgba(237, 237, 237, 0.76);
}

@media (max-width: 639px) {
	#hero-title.iv-hero-title,
	body.a5-body-home .iv-hero h1#hero-title.iv-hero-title,
	body.a5-body-home .iv-hero .iv-hero-title {
		line-height: 1.1;
	}
}

body.a5-body-home h2.iv-section-title {
	font-family: var(--a5-font-display);
	font-size: clamp(1.85rem, 0.9rem + 1.4vw, 2.8rem);
	font-weight: 700;
	line-height: 1.18;
	letter-spacing: -0.03em;
}

/* Home landmark H2s (services / process / about / work): UA margin scales with display type; iv-* only (§3) */
body.a5-body-home .iv-page-home-landmark .iv-section-header h2.iv-section-title {
	margin-block: 0;
	margin-inline: 0;
}

body.a5-body-home .iv-page-home-landmark .iv-section-header h2.iv-section-title + .iv-section-kicker {
	margin-top: clamp(0.65rem, 1.35vw, 1rem);
}

/*
 * Services + About (Why Choose Us) title: same scale; #id only, not ref-*.
 */
section#services h2#services-title,
section#about h2#about-title,
section#engage h2#engage-title,
section.iv-engage-section h2.iv-engage-section-title {
	font-family: var(--a5-font-display);
	font-size: clamp(3.1rem, 1.35rem + 3.2vw, 4.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.045em;
	max-width: 100%;
	overflow-wrap: normal;
	color: var(--a5-text-primary);
}

body.a5-body-home .iv-section-kicker {
	font-size: clamp(1.04rem, 0.2vw + 0.9rem, 1.2rem);
	line-height: 1.65;
	font-weight: 600;
}

/* Services, About, Engage kicker: same size/weight as services (iv-section-kicker pattern) */
body.a5-body-home section#services p.iv-section-kicker,
body.a5-body-home section#about p.iv-section-kicker,
body.a5-body-home section#engage p.iv-section-kicker,
section.iv-engage-section p.iv-section-kicker {
	font-weight: 400;
	color: var(--a5-text-secondary);
}

/* Process + Work kicker: on ink, lighter weight to match services/about */
body.a5-body-home section#process p.iv-section-kicker,
body.a5-body-home section#work p.iv-section-kicker,
body.a5-body-work section#work p.iv-section-kicker {
	font-weight: 400;
	color: rgba(237, 237, 237, 0.88);
}

body.a5-body-home .iv-pillar-title {
	font-family: var(--a5-font-display);
	font-size: 1.1rem;
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: -0.015em;
}

body.a5-body-home .iv-pillar-copy {
	font-size: 0.95rem;
	line-height: 1.6;
}

body.a5-body-home .iv-process-item h3 {
	font-family: var(--a5-font-display);
	font-size: clamp(1.15rem, 0.2vw + 1rem, 1.4rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.2;
}

body.a5-body-home .iv-section--ink .iv-process-item p,
body.a5-body-home .iv-why-text {
	font-size: clamp(0.98rem, 0.1vw + 0.9rem, 1.1rem);
	line-height: 1.65;
}

body.a5-body-home .iv-why-text {
	font-weight: 600;
}

/* Home #about (Why Choose Us): larger list lines, light between-row rules (§2) */
body.a5-body-home section#about .iv-why-text {
	font-size: clamp(1.18rem, 0.45vw + 1.02rem, 1.48rem);
	line-height: 1.55;
	letter-spacing: -0.02em;
}

body.a5-body-home section#about .iv-why-item {
	padding: clamp(0.85rem, 1.2vw, 1.12rem) 0;
	border-top: 1px solid rgba(17, 17, 17, 0.1);
}

body.a5-body-home section#about .iv-why-item:first-of-type {
	border-top: 0;
}

body.a5-body-home section#about .iv-why-line {
	width: 2px;
	min-height: 1.25rem;
	margin-top: 0.32rem;
	background: var(--a5-accent);
}

body.a5-body-home .iv-work-kicker {
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.2em;
}

body.a5-body-home .iv-work-name {
	font-family: var(--a5-font-display);
	font-size: clamp(1.2rem, 0.1vw + 1.1rem, 1.4rem);
	font-weight: 600;
	letter-spacing: -0.02em;
}

body.a5-body-home .iv-work-line {
	font-size: 0.95rem;
	line-height: 1.45;
}

/* Home + Work template #work: header, tiles, CTA (iv-* / #work only) — left-aligned copy column */
body.a5-body-home section#work .iv-work-section-header,
body.a5-body-work section#work .iv-work-section-header {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin: 0 0 clamp(1.5rem, 2vw, 2rem);
	padding: 0;
	text-align: left;
	width: 100%;
}
body.a5-body-home section#work p.iv-hero-cta-line,
body.a5-body-work section#work p.iv-hero-cta-line {
	margin-inline: 0;
	text-align: left;
}
/* --- Page layout --- */
/* Main landmarks (ref-page-*-main-landmark → main.iv-page / main.iv-page-home-main): full viewport width; gutters on inners (§3 iv-* only). */
main.iv-page,
main.iv-page-home-main {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	min-width: 0;
	margin-inline: 0;
	padding: 0;
}

/* Template mains (services … contact): vertical rhythm only; horizontal inset from inner columns */
main.iv-page.iv-page-services,
main.iv-page.iv-page-services-post,
main.iv-page.iv-page-work,
main.iv-page.iv-page-about,
main.iv-page.iv-page-contact {
	box-sizing: border-box;
	padding-top: 0;
	padding-bottom: 0;
}

/* Simple templates: entry / 404 copy — inset so text does not meet viewport edge */
main.iv-page.iv-page-page .iv-entry,
main.iv-page.iv-page-index .iv-entry,
main.iv-page.iv-page-single .iv-entry {
	box-sizing: border-box;
	width: 100%;
	padding-inline: clamp(1rem, 4vw, 1.25rem);
}

main.iv-page.iv-page-404 .iv-empty-state {
	box-sizing: border-box;
	padding-inline: clamp(1rem, 4vw, 1.25rem);
}

@media (max-width: 639px) {
	main.iv-page-services .iv-services-page-inner,
	main.iv-page-work .iv-work-page-inner,
	main.iv-page-about .iv-about-page-inner,
	main.iv-page-work-case .iv-about-page-inner,
	main.iv-page-services-post .iv-about-page-inner,
	main.iv-page-contact .iv-contact-page-inner {
		max-width: 100%;
	}
}

/* Home: full-bleed landmark sections; gutters on .iv-section-inner only (README §1 site asset layout) */
body.a5-body-home {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin-inline: 0;
	padding: 0;
}

.iv-section {
	padding-block: clamp(4rem, 8vw, 6.5rem);
}

/* Alternating: dark emphasis vs light surface (README §2) */
.iv-section--ink {
	background: var(--a5-surface-dark);
	color: var(--a5-text-on-dark);
}

.iv-section--surface {
	background: var(--a5-surface-white);
	color: var(--a5-text-primary);
}

/* page-home: landmark sections — height from content, full bleed; vertical rhythm on .iv-section-inner */
body.a5-body-home .iv-page-home-landmark.iv-section {
	width: 100%;
	max-width: none;
	margin-inline: 0;
	min-height: 0;
	height: auto;
	max-height: none;
	padding-block: 0;
	padding-inline: 0;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: flex-start;
	overflow-x: hidden;
	overflow-y: visible;
	position: relative;
}

/* Hero: full-bleed from viewport top; bar sits above (z 300) with blur so video/ink are visible under it. Text in padded area. */
body.a5-body-home .iv-page-home-landmark.iv-hero {
	/* top pad reserves space for headline/lead below frosted bar; no bottom pad */
	padding: var(--a5-sticky-header-total) 0 0;
	/* full-bleed background video, no double scroll on root */
	overflow: hidden;
	margin-top: calc(-1 * var(--a5-sticky-header-total));
	/* in-page #top targets land below the sticky bar */
	scroll-margin-top: var(--a5-sticky-header-total);
	z-index: 0;
}

.iv-section-inner {
	margin-inline: auto;
	width: 90%;
	max-width: 90%;
}

/* Home: inner column — content-driven height, generous vertical padding */
body.a5-body-home .iv-page-home-landmark .iv-section-inner {
	flex: 0 1 auto;
	width: 100%;
	min-height: 0;
	/* max-width: per landmark — each .iv-section-inner / iv-*-section-inner is distinct; see block below */
	margin-inline: auto;
	padding-inline: 1.25rem;
	padding-block: clamp(3.25rem, 8vw, 6rem);
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	overflow: visible;
}

/* Home: distinct max-width per content column (iv-services-section-inner, iv-process-section-inner, or #id + .iv-section-inner) */
body.a5-body-home .iv-page-home-landmark#top .iv-section-inner,
body.a5-body-home .iv-page-home-landmark.iv-hero .iv-section-inner {
	max-width: 90%;
	overflow: visible;
	/* Tighter than other home landmarks: shorter hero band */
	padding-block: clamp(2.25rem, 5.25vw, 4.25rem);
}
/* Home #services inner column: hook iv-services-section-inner */
body.a5-body-home .iv-page-home-landmark#services .iv-services-section-inner,
body.a5-body-home .iv-page-home-landmark#services .iv-section-inner.iv-services-section-inner {
	max-width: 90%;
	min-width: 0;
	margin-inline: auto;
	align-self: center;
	padding-inline: clamp(0.75rem, 3vw, 2rem);
	/* Shorter band than default home .iv-section-inner vertical padding */
	padding-block: clamp(2.35rem, 6vw, 4.5rem);
}
body.a5-body-home .iv-page-home-landmark#process .iv-process-section-inner,
body.a5-body-home .iv-page-home-landmark#process .iv-section-inner.iv-process-section-inner {
	max-width: min(920px, 54%);
	min-width: 0;
	margin-inline: auto;
	align-self: center;
	/* Shorter band than default home .iv-section-inner vertical padding */
	padding-block: clamp(2.35rem, 6vw, 4.5rem);
}

body.a5-body-home .iv-page-home-landmark#about .iv-section-inner {
	max-width: min(1020px, 60%);
}
body.a5-body-home .iv-page-home-landmark#engage .iv-section-inner,
section.iv-engage-section .iv-section-inner {
	max-width: min(1020px, 60%);
}

/* Mobile overrides must follow base max-width rules (same specificity). */
@media (max-width: 639px) {
	body.a5-body-home .iv-page-home-landmark#process .iv-process-section-inner,
	body.a5-body-home .iv-page-home-landmark#process .iv-section-inner.iv-process-section-inner {
		max-width: 90%;
	}

	body.a5-body-home .iv-page-home-landmark#about .iv-section-inner {
		max-width: 90%;
	}

	body.a5-body-home .iv-page-home-landmark#engage .iv-section-inner,
	section.iv-engage-section .iv-section-inner {
		max-width: 90%;
	}
}
body.a5-body-home .iv-page-home-landmark#work .iv-section-inner,
body.a5-body-work section#work .iv-section-inner {
	max-width: 90%;
}

/* #work: inner — clip rare horizontal overflow from the grid */
body.a5-body-home .iv-page-home-landmark#work .iv-work-section-inner,
body.a5-body-work section#work .iv-work-section-inner {
	overflow-x: hidden;
}

/* Home + Work template #work: full-bleed background video — dim while loading, slow fade in when .iv-work-video--ready (see main.js) */
body.a5-body-home section#work.iv-work-has-video,
body.a5-body-work section#work.iv-work-has-video {
	position: relative;
}

body.a5-body-home section#work .iv-work-ambient,
body.a5-body-work section#work .iv-work-ambient {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
	pointer-events: none;
}

body.a5-body-home section#work .iv-work-video-backdrop,
body.a5-body-work section#work .iv-work-video-backdrop {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 1.25s ease;
}

body.a5-body-home section#work .iv-work-video-backdrop.iv-work-video--ready,
body.a5-body-work section#work .iv-work-video-backdrop.iv-work-video--ready {
	opacity: 1;
}

body.a5-body-home section#work .iv-work-bg-video,
body.a5-body-work section#work .iv-work-bg-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	min-width: 100%;
	min-height: 100%;
	max-width: none;
	object-fit: cover;
	object-position: center;
	filter: grayscale(0.74) brightness(0.34) contrast(0.86) saturate(0.38);
}

body.a5-body-home section#work .iv-work-video-veil,
body.a5-body-work section#work .iv-work-video-veil {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(42, 42, 46, 0.54);
}

body.a5-body-home section#work.iv-work--reduced-motion .iv-work-ambient,
body.a5-body-work section#work.iv-work--reduced-motion .iv-work-ambient {
	display: none;
}

body.a5-body-home section#work.iv-work-has-video .iv-work-section-inner,
body.a5-body-home section#work.iv-work-has-video .iv-work-section-inner.iv-work-section-inner,
body.a5-body-work section#work.iv-work-has-video .iv-work-section-inner,
body.a5-body-work section#work.iv-work-has-video .iv-work-section-inner.iv-work-section-inner {
	position: relative;
	z-index: 1;
}

/* Services section shell */
body.a5-body-home section#services {
	width: 100%;
	max-width: none;
}

.iv-section-inner p,
.iv-section-inner li,
.iv-section-inner dd {
	font-size: clamp(1.04rem, 0.2vw + 0.98rem, 1.16rem);
	line-height: 1.7;
}

/* Eyebrow: accent only, typographic (within ~10% budget) */
.iv-eyebrow {
	font-size: 0.7rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--a5-accent);
	margin: 0 0 0.75rem;
}

.iv-section--surface .iv-eyebrow {
	color: var(--a5-ink);
	border-left: 3px solid var(--a5-accent);
	padding-left: 0.65rem;
	letter-spacing: 0.14em;
}

.iv-section-inner p.iv-eyebrow {
	font-size: 0.7rem;
	line-height: 1.45;
}

.iv-lead {
	line-height: 1.65;
}

.iv-cta-group {
	margin-top: 2.5rem;
}

/* Hero: full-bleed video + veil over Surface / Dark (README §2); height follows content on page-home */
.iv-hero {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	min-height: 0;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: flex-start;
	padding-block: 0;
	overflow: hidden;
}

.iv-hero .iv-section-inner {
	position: relative;
	z-index: 1;
}

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

.iv-hero-video-backdrop {
	position: absolute;
	inset: 0;
	/* Invisible until .iv-hero-video--ready; then fade in (set by JS) */
	opacity: 0;
	transition: opacity 0.9s ease;
}

.iv-hero-video-backdrop.iv-hero-video--ready {
	opacity: 1;
}

.iv-hero .iv-hero-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	min-width: 100%;
	min-height: 100%;
	max-width: none;
	object-fit: cover;
	object-position: center;
	/* Slightly more visible than prior pass; still muted for type contrast (§2) */
	filter: grayscale(0.78) brightness(0.3) contrast(0.85) saturate(0.32);
}

.iv-hero-video-veil {
	position: absolute;
	inset: 0;
	z-index: 1;
	/* Veil: Surface / Dark */
	background: rgba(42, 42, 46, 0.56);
}

/* When user requests reduced motion, no autoplaying background (README §8) */
.iv-hero--reduced-motion .iv-hero-ambient {
	display: none;
}

/* Buttons */
.iv-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	min-height: 3.1rem;
	padding: 0.7rem 1.6rem;
	font-size: 1.02rem;
	font-weight: 700;
	font-family: var(--a5-font-display);
	letter-spacing: 0.01em;
	border-radius: 9999px;
	text-decoration: none;
	border: 1px solid transparent;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}

.iv-button:active {
	transform: translateY(1px);
}

/* Primary = accent (CTA; README §2) */
.iv-button-primary {
	background: var(--a5-accent);
	color: var(--a5-surface-white);
}

.iv-button-primary:hover,
.iv-button-primary:focus-visible {
	background: var(--a5-accent-strong);
}

.iv-ghost-on-ink {
	background: transparent;
	color: var(--a5-text-on-dark);
	border-color: rgba(237, 237, 237, 0.45);
}

/* Hero: single text CTA (not a pill; §2 tokens only) */
.iv-hero .iv-hero-cta-line {
	margin: 3rem 0 0;
}

.iv-hero-cta-text {
	display: inline-flex;
	align-items: center;
	gap: 0.55em;
	font-family: var(--a5-font-display);
	font-size: clamp(1.3rem, 0.7vw + 1.05rem, 1.75rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--a5-text-on-dark);
	text-decoration: none;
	border-bottom: 2px solid var(--a5-accent);
	padding-bottom: 0.3rem;
	transition: color 0.2s ease, border-color 0.2s ease;
}

.iv-hero-cta-text .iv-hero-cta-icon {
	display: inline-flex;
	flex-shrink: 0;
}

.iv-hero-cta-text .iv-hero-cta-arrow {
	width: 1.2em;
	height: 1.2em;
}

.iv-hero-cta-text:hover,
.iv-hero-cta-text:focus-visible {
	color: var(--a5-accent);
	border-bottom-color: var(--a5-text-on-dark);
}

.iv-ghost-on-surface {
	background: transparent;
	color: var(--a5-text-primary);
	border-color: var(--a5-border-primary);
}

.iv-section-header .iv-section-title {
	line-height: 1.15;
	letter-spacing: -0.02em;
}

.iv-section--surface .iv-section-title,
.iv-pillar-title,
.iv-section--surface .iv-pillar-title {
	color: var(--a5-text-primary);
}

.iv-section-kicker {
	font-size: 1.1rem;
	line-height: 1.65;
}

.iv-section--surface .iv-section-kicker {
	color: var(--a5-text-secondary);
}

/* Pillar grid (surface: ink text; ink: surface text) */
.iv-pillar-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

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

@media (min-width: 1024px) {
	.iv-pillar-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Services: 1:1 full-image tiles, no gap, equal cells — ref on markup only for ul/li */
.iv-pillar-grid--services {
	gap: 0;
}

/*
 * Home #services pillars: always exactly one row (any item count); equal-width columns.
 * Square tiles: aspect-ratio on .iv-service-card--fulltile + figure below.
 */
body.a5-body-home section#services .iv-pillar-grid--services {
	grid-template-columns: none;
	grid-template-rows: auto;
	grid-auto-flow: column;
	grid-auto-columns: minmax(0, 1fr);
	align-items: stretch;
	column-gap: clamp(0.45rem, 0.6vw, 0.85rem);
	row-gap: 0;
}

/* Work: 1:1 full-image tile grid; home showcase → one row of three on wide viewports */
body.a5-body-home .iv-pillar-grid--work,
body.a5-body-work .iv-pillar-grid--work,
main.iv-page-services .iv-pillar-grid--work {
	gap: 0;
	grid-template-columns: 1fr;
}

body.a5-body-home section#work .iv-pillar-grid--work,
main.iv-page-services .iv-services-page-section .iv-pillar-grid--work {
	column-gap: clamp(0.45rem, 0.6vw, 0.85rem);
	row-gap: 0;
}
@media (min-width: 640px) {
	body.a5-body-home .iv-pillar-grid--work,
	body.a5-body-work .iv-pillar-grid--work,
	main.iv-page-services .iv-pillar-grid--work {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (min-width: 1024px) {
	body.a5-body-home .iv-pillar-grid--work,
	body.a5-body-work .iv-pillar-grid--work,
	main.iv-page-services .iv-pillar-grid--work {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.iv-section--surface .iv-pillar {
	background: var(--a5-surface-white);
	border: 1px solid var(--a5-border-primary);
	color: var(--a5-text-primary);
}

.iv-pillar {
	margin: 0;
	padding: 1.4rem 1.35rem;
	border-radius: var(--a5-radius);
}

/* Service cards: home stack / legacy; full-tile is #services and #work a.iv-service-card--fulltile */
body.a5-body-home .iv-service-card,
.iv-service-card {
	margin: 0;
	padding: 0;
	border-radius: var(--a5-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	background: var(--a5-surface-white);
	border: 1px solid var(--a5-border-primary);
	box-shadow: var(--a5-shadow);
}

/* Services + work: one square tile, full-bleed image, copy on image, full-card link (§2) */
body.a5-body-home section#services .iv-service-card--fulltile,
body.a5-body-home section#work .iv-service-card--fulltile,
body.a5-body-work section#work .iv-service-card--fulltile {
	display: block;
	text-decoration: none;
	color: inherit;
	border: none;
	border-radius: 0;
	box-shadow: 0 0 0 1px var(--a5-surface-dark);
	background: var(--a5-surface-dark);
	margin: 0;
	overflow: hidden;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	min-width: 0;
	min-height: 0;
}

body.a5-body-home section#services .iv-pillar-grid--services > .iv-services-pillar-item,
body.a5-body-home section#services .iv-pillar-grid--services > li,
body.a5-body-home section#work .iv-pillar-grid--work > li,
body.a5-body-work section#work .iv-pillar-grid--work > li,
main.iv-page-services .iv-pillar-grid--work > li {
	margin: 0;
	min-width: 0;
}

body.a5-body-home section#services .iv-service-card--fulltile .iv-service-card-figure,
body.a5-body-home section#work .iv-service-card--fulltile .iv-service-card-figure,
body.a5-body-work section#work .iv-service-card--fulltile .iv-service-card-figure {
	position: relative;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	margin: 0;
	padding: 0;
	overflow: hidden;
	background: var(--a5-surface-dark);
	flex: none;
}

body.a5-body-home section#services .iv-service-card--fulltile .iv-service-card-img,
body.a5-body-home section#work .iv-service-card--fulltile .iv-service-card-img,
body.a5-body-work section#work .iv-service-card--fulltile .iv-service-card-img {
	position: absolute;
	z-index: 0;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(1) brightness(0.86) contrast(0.9);
	transition: filter 0.35s ease;
}

body.a5-body-home section#services .iv-service-card--fulltile:hover .iv-service-card-img,
body.a5-body-home section#services .iv-service-card--fulltile:focus-within .iv-service-card-img,
body.a5-body-home section#work .iv-service-card--fulltile:hover .iv-service-card-img,
body.a5-body-home section#work .iv-service-card--fulltile:focus-within .iv-service-card-img,
body.a5-body-work section#work .iv-service-card--fulltile:hover .iv-service-card-img,
body.a5-body-work section#work .iv-service-card--fulltile:focus-within .iv-service-card-img {
	filter: none;
}

body.a5-body-home section#services .iv-service-card--fulltile .iv-service-card-body--on-image,
body.a5-body-home section#work .iv-service-card--fulltile .iv-service-card-body--on-image,
body.a5-body-work section#work .iv-service-card--fulltile .iv-service-card-body--on-image {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	margin: 0;
	padding: 1.05rem 0.9rem 1.05rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 0;
	/* Band keeps title readable on grey, dull imagery. */
	background: linear-gradient(
		180deg,
		rgba(42, 42, 46, 0) 0%,
		rgba(42, 42, 46, 0.55) 38%,
		rgba(42, 42, 46, 0.88) 78%,
		var(--a5-surface-dark) 100%
	);
	box-sizing: border-box;
}

body.a5-body-home section#work .iv-service-card--fulltile .iv-service-card-body--on-image,
body.a5-body-work section#work .iv-service-card--fulltile .iv-service-card-body--on-image {
	gap: 0.4rem;
}

body.a5-body-home section#services .iv-service-card--fulltile .iv-pillar-title.iv-service-card-title,
body.a5-body-home section#services .iv-service-card--fulltile h3,
body.a5-body-home section#work .iv-service-card--fulltile .iv-pillar-title.iv-service-card-title,
body.a5-body-home section#work .iv-service-card--fulltile h3,
body.a5-body-work section#work .iv-service-card--fulltile .iv-pillar-title.iv-service-card-title,
body.a5-body-work section#work .iv-service-card--fulltile h3 {
	color: var(--a5-surface-white);
	text-shadow:
		0 0.06em 0.12em rgba(42, 42, 46, 0.75),
		0 0.12em 0.28em rgba(42, 42, 46, 0.45);
}

body.a5-body-home section#work .iv-service-card--fulltile .iv-work-card-outcome,
body.a5-body-work section#work .iv-service-card--fulltile .iv-work-card-outcome {
	margin: 0;
	color: rgba(237, 237, 237, 0.78);
	font-size: clamp(0.72rem, 0.16vw + 0.68rem, 0.82rem);
	line-height: 1.32;
	font-weight: 400;
	letter-spacing: 0.005em;
	text-shadow:
		0 0.04em 0.08em rgba(42, 42, 46, 0.62),
		0 0.08em 0.16em rgba(42, 42, 46, 0.38);
}

/* #work: type tag; Surface / Dark pill, Text / On Dark (§2); iv-work-tile-tag only (§3) */
body.a5-body-home section#work .iv-work-tile-tag,
body.a5-body-work section#work .iv-work-tile-tag {
	position: absolute;
	z-index: 2;
	top: 0.65rem;
	left: 0.65rem;
	right: auto;
	bottom: auto;
	max-width: calc(100% - 1.2rem);
	padding: 0.3em 0.55em;
	margin: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(0.6rem, 0.2vw + 0.5rem, 0.7rem);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--a5-text-on-dark);
	background: var(--a5-surface-dark);
	border: none;
	box-shadow: none;
	pointer-events: none;
	opacity: 0.45;
	transition: opacity 0.3s ease;
}
body.a5-body-home section#work .iv-service-card--fulltile:hover .iv-work-tile-tag,
body.a5-body-home section#work .iv-service-card--fulltile:focus-within .iv-work-tile-tag,
body.a5-body-work section#work .iv-service-card--fulltile:hover .iv-work-tile-tag,
body.a5-body-work section#work .iv-service-card--fulltile:focus-within .iv-work-tile-tag,
main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile:hover .iv-work-tile-tag,
main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile:focus-within .iv-work-tile-tag {
	opacity: 1;
}

/* Category archive work grid: same type pill + outcome as home #work (§3 iv-* only) */
main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-work-tile-tag {
	position: absolute;
	z-index: 2;
	top: 0.65rem;
	left: 0.65rem;
	right: auto;
	bottom: auto;
	max-width: calc(100% - 1.2rem);
	padding: 0.3em 0.55em;
	margin: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(0.6rem, 0.2vw + 0.5rem, 0.7rem);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--a5-text-on-dark);
	background: var(--a5-surface-dark);
	border: none;
	box-shadow: none;
	pointer-events: none;
	opacity: 0.45;
	transition: opacity 0.3s ease;
}

main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile .iv-work-card-outcome {
	margin: 0;
	color: rgba(237, 237, 237, 0.78);
	font-size: clamp(0.72rem, 0.16vw + 0.68rem, 0.82rem);
	line-height: 1.32;
	font-weight: 400;
	letter-spacing: 0.005em;
	text-shadow:
		0 0.04em 0.08em rgba(42, 42, 46, 0.62),
		0 0.08em 0.16em rgba(42, 42, 46, 0.38);
}

main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile .iv-service-card-body--on-image {
	gap: 0.4rem;
}

/* Match home #work: 1px ink frame (overrides services-posts-grid fulltile box-shadow: none) */
main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile {
	box-shadow: 0 0 0 1px var(--a5-surface-dark);
}

main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile:hover,
main.iv-page-services .iv-services-page-section .iv-pillar-grid--work .iv-service-card--fulltile:focus-visible {
	box-shadow: 0 0 0 1px var(--a5-surface-dark);
}

body.a5-body-home section#work .iv-service-card--fulltile .iv-pillar-title,
body.a5-body-work section#work .iv-service-card--fulltile .iv-pillar-title {
	margin: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(1.2rem, 1.1vw + 0.95rem, 1.7rem);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
}

body.a5-body-home section#services .iv-service-card--fulltile .iv-pillar-title {
	margin: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(1.05rem, 0.85vw + 0.82rem, 1.45rem);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
}

body.a5-body-home section#services .iv-service-card--fulltile:hover,
body.a5-body-home section#services .iv-service-card--fulltile:focus-visible {
	box-shadow: 0 0 0 1px var(--a5-accent);
}

/* #work .iv-work-showcase-item full-tiles: no accent frame on hover — same 1px ink as default */
body.a5-body-home section#work .iv-service-card--fulltile:hover,
body.a5-body-home section#work .iv-service-card--fulltile:focus-visible,
body.a5-body-work section#work .iv-service-card--fulltile:hover,
body.a5-body-work section#work .iv-service-card--fulltile:focus-visible {
	box-shadow: 0 0 0 1px var(--a5-surface-dark);
}

body.a5-body-home section#services .iv-service-card--fulltile:focus-visible,
body.a5-body-home section#work .iv-service-card--fulltile:focus-visible,
body.a5-body-work section#work .iv-service-card--fulltile:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

/* Services page template (page-services.php): full-tile grid like home #work; class hooks only (§3) */
/* Work page template (page-work.php): same layout pattern as Services; horizontal gutter on inner (§3). */
/* About page template (page-about.php): same inner gutters as Services / Work. */
/* Contact page template (page-contact.php): same inner gutters. */
main.iv-page-services .iv-services-page-inner {
	width: 100%;
	max-width: 90%;
	min-width: 0;
	margin-inline: auto;
	box-sizing: border-box;
	padding-inline: clamp(1rem, 4vw, 1.25rem);
}

/* Services listing → engage CTA: both bands use .iv-section padding-block, which stacks too much whitespace */
main.iv-page-services .iv-services-page-section.iv-section {
	padding-block-start: clamp(4rem, 8vw, 6.5rem);
	padding-block-end: clamp(1.35rem, 2.8vw, 2.25rem);
}

main.iv-page-services .iv-services-page-section.iv-section + section.iv-engage-section.iv-section {
	padding-block-start: clamp(1.35rem, 2.8vw, 2.25rem);
	padding-block-end: clamp(4rem, 8vw, 6.5rem);
}

main.iv-page-services .iv-services-page-section h1.iv-section-title {
	font-family: var(--a5-font-display);
	font-size: clamp(3.1rem, 1.35rem + 3.2vw, 4.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.045em;
	max-width: 100%;
	color: var(--a5-text-primary);
}

/* Category + services-layout mains: display H1 UA margins scale with type; iv-* only (§3) */
main.iv-page-services .iv-services-page-section .iv-section-header h1.iv-section-title {
	margin-block: 0;
	margin-inline: 0;
}

main.iv-page-services .iv-services-page-section .iv-section-header h1.iv-section-title + .iv-section-kicker {
	margin-top: clamp(0.65rem, 1.35vw, 1rem);
}

main.iv-page-services .iv-services-page-section p.iv-section-kicker {
	font-size: clamp(1.04rem, 0.2vw + 0.9rem, 1.2rem);
	line-height: 1.65;
	font-weight: 400;
	color: var(--a5-text-secondary);
}

main.iv-page-services .iv-pillar-grid--services-page {
	gap: clamp(0.85rem, 2.2vw, 1.35rem);
	grid-template-columns: 1fr;
}

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

@media (min-width: 1024px) {
	main.iv-page-services .iv-pillar-grid--services-page {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

main.iv-page-services .iv-services-page-section .iv-services-page-item {
	margin: 0;
	min-width: 0;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile {
	display: block;
	text-decoration: none;
	color: inherit;
	border: none;
	border-radius: 0;
	box-shadow: none;
	background: var(--a5-surface-dark);
	margin: 0;
	overflow: hidden;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	min-width: 0;
	min-height: 0;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile .iv-service-card-figure {
	position: relative;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	margin: 0;
	padding: 0;
	overflow: hidden;
	background: var(--a5-surface-dark);
	flex: none;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile .iv-service-card-img {
	position: absolute;
	z-index: 0;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(1) brightness(0.86) contrast(0.9);
	transition: filter 0.35s ease;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile:hover .iv-service-card-img,
main.iv-page-services .iv-services-page-section .iv-service-card--fulltile:focus-within .iv-service-card-img {
	filter: none;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile .iv-service-card-body--on-image {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	margin: 0;
	padding: 1.05rem 0.9rem 1.05rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 0.4rem;
	background: linear-gradient(
		180deg,
		rgba(42, 42, 46, 0) 0%,
		rgba(42, 42, 46, 0.55) 38%,
		rgba(42, 42, 46, 0.88) 78%,
		var(--a5-surface-dark) 100%
	);
	box-sizing: border-box;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile .iv-pillar-title.iv-service-card-title,
main.iv-page-services .iv-services-page-section .iv-service-card--fulltile h3 {
	margin: 0;
	color: var(--a5-surface-white);
	font-family: var(--a5-font-display);
	font-size: clamp(1.2rem, 1.1vw + 0.95rem, 1.7rem);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
	text-shadow:
		0 0.06em 0.12em rgba(42, 42, 46, 0.75),
		0 0.12em 0.28em rgba(42, 42, 46, 0.45);
}

main.iv-page-services .iv-services-page-section .iv-services-page-card-desc {
	margin: 0;
	color: var(--a5-text-on-dark);
	font-size: clamp(0.8rem, 0.2vw + 0.75rem, 0.9rem);
	line-height: 1.35;
	font-weight: 500;
	letter-spacing: 0.01em;
	text-shadow:
		0 0.06em 0.1em rgba(42, 42, 46, 0.75),
		0 0.1em 0.2em rgba(42, 42, 46, 0.45);
}

main.iv-page-services .iv-services-page-section .iv-services-posts-grid .iv-services-page-card-desc {
	opacity: 0.75;
	transition: opacity 0.22s ease;
}

main.iv-page-services .iv-services-page-section .iv-services-posts-grid .iv-service-card--fulltile:hover .iv-services-page-card-desc,
main.iv-page-services .iv-services-page-section .iv-services-posts-grid .iv-service-card--fulltile:focus-within .iv-services-page-card-desc {
	opacity: 1;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile:hover,
main.iv-page-services .iv-services-page-section .iv-service-card--fulltile:focus-visible {
	border: none;
	box-shadow: none;
}

main.iv-page-services .iv-services-page-section .iv-service-card--fulltile:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

/* Work page template (page-work.php): Services-aligned surface + full-tile cards; 1 / 2 / 3 columns like Services (§3 iv-* only) */
main.iv-page-work .iv-work-page-inner {
	width: 100%;
	max-width: 90%;
	min-width: 0;
	margin-inline: auto;
	box-sizing: border-box;
	padding-inline: clamp(1rem, 4vw, 1.25rem);
}

main.iv-page-work .iv-work-page-section h1.iv-section-title {
	font-family: var(--a5-font-display);
	font-size: clamp(3.1rem, 1.35rem + 3.2vw, 4.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.045em;
	max-width: 100%;
	color: var(--a5-text-primary);
}

main.iv-page-work .iv-work-page-section p.iv-section-kicker {
	font-size: clamp(1.04rem, 0.2vw + 0.9rem, 1.2rem);
	line-height: 1.65;
	font-weight: 400;
	color: var(--a5-text-secondary);
}

main.iv-page-work .iv-pillar-grid--work-page {
	gap: clamp(0.85rem, 2.2vw, 1.35rem);
	grid-template-columns: 1fr;
}

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

@media (min-width: 1024px) {
	main.iv-page-work .iv-pillar-grid--work-page {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

main.iv-page-work .iv-work-page-section .iv-work-page-item {
	margin: 0;
	min-width: 0;
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile {
	display: block;
	text-decoration: none;
	color: inherit;
	border: none;
	border-radius: 0;
	box-shadow: none;
	background: var(--a5-surface-dark);
	margin: 0;
	overflow: hidden;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	min-width: 0;
	min-height: 0;
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile .iv-service-card-figure {
	position: relative;
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
	margin: 0;
	padding: 0;
	overflow: hidden;
	background: var(--a5-surface-dark);
	flex: none;
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile .iv-service-card-img {
	position: absolute;
	z-index: 0;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(1) brightness(0.86) contrast(0.9);
	transition: filter 0.35s ease;
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile:hover .iv-service-card-img,
main.iv-page-work .iv-work-page-section .iv-service-card--fulltile:focus-within .iv-service-card-img {
	filter: none;
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile .iv-service-card-body--on-image {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	margin: 0;
	padding: 1.05rem 0.9rem 1.05rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 0.35rem;
	background: linear-gradient(
		180deg,
		rgba(42, 42, 46, 0) 0%,
		rgba(42, 42, 46, 0.55) 38%,
		rgba(42, 42, 46, 0.88) 78%,
		var(--a5-surface-dark) 100%
	);
	box-sizing: border-box;
}

main.iv-page-work .iv-work-page-card-category {
	margin: 0;
	padding: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(0.62rem, 0.18vw + 0.52rem, 0.72rem);
	font-weight: 800;
	line-height: 1.2;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--a5-accent);
	text-shadow:
		0 0.06em 0.1em rgba(42, 42, 46, 0.75),
		0 0.1em 0.2em rgba(42, 42, 46, 0.45);
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile .iv-pillar-title.iv-service-card-title,
main.iv-page-work .iv-work-page-section .iv-service-card--fulltile h3 {
	margin: 0;
	color: var(--a5-surface-white);
	font-family: var(--a5-font-display);
	font-size: clamp(1.2rem, 1.1vw + 0.95rem, 1.7rem);
	font-weight: 700;
	line-height: 1.12;
	letter-spacing: -0.02em;
	text-shadow:
		0 0.06em 0.12em rgba(42, 42, 46, 0.75),
		0 0.12em 0.28em rgba(42, 42, 46, 0.45);
}

main.iv-page-work .iv-work-page-section .iv-work-page-card-desc {
	margin: 0;
	color: var(--a5-text-on-dark);
	font-size: clamp(0.8rem, 0.2vw + 0.75rem, 0.9rem);
	line-height: 1.35;
	font-weight: 500;
	letter-spacing: 0.01em;
	text-shadow:
		0 0.06em 0.1em rgba(42, 42, 46, 0.75),
		0 0.1em 0.2em rgba(42, 42, 46, 0.45);
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile:hover,
main.iv-page-work .iv-work-page-section .iv-service-card--fulltile:focus-visible {
	border: none;
	box-shadow: none;
}

main.iv-page-work .iv-work-page-section .iv-service-card--fulltile:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

/* About (page-about.php) + Work case (single-work.php) + Services post (single-services.php): article prose on surface (§2 typography; §3 iv-* only) */
main.iv-page-about .iv-about-page-inner,
main.iv-page-work-case .iv-about-page-inner,
main.iv-page-services-post .iv-about-page-inner {
	width: 100%;
	min-width: 0;
	margin-inline: auto;
	box-sizing: border-box;
	padding-inline: clamp(1rem, 4vw, 1.25rem);
}

main.iv-page-about .iv-about-page-inner {
	max-width: min(1180px, 96%);
}

/* About + Contact: generous vertical band around the page H1 (about-page-title / contact-page-title in markup; spacing via iv-* only §3) */
main.iv-page-about .iv-about-page-section.iv-section,
main.iv-page-contact .iv-contact-page-section.iv-section {
	padding-block-start: clamp(3rem, 6.5vw, 5.25rem);
	padding-block-end: clamp(4.25rem, 8.5vw, 7rem);
}

/* Work case: slightly tighter measure than About for long-form reading */
main.iv-page-work-case .iv-about-page-inner,
main.iv-page-services-post .iv-about-page-inner {
	max-width: min(1000px, 92%);
}

/* No featured image: narrow column; title + prose align with other iv-page templates (left) */
main.iv-page-about .iv-about-page-inner.iv-about-page-inner--text-only {
	max-width: min(42rem, 94%);
}

main.iv-page-about .iv-about-page-inner--text-only > header.iv-section-header {
	text-align: left;
}

/* About page: additional space below the H1 (about-page-title in markup; §3 iv-* only) */
main.iv-page-about .iv-about-page-section .iv-section-header {
	padding-block-end: clamp(1.75rem, 3.25vw, 3rem);
}

main.iv-page-about .iv-about-page-section h1.iv-section-title,
main.iv-page-work-case .iv-about-page-section h1.iv-section-title,
main.iv-page-services-post .iv-about-page-section h1.iv-section-title {
	margin-block: 0;
	margin-inline: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(3.1rem, 1.35rem + 3.2vw, 4.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.045em;
	max-width: 100%;
	color: var(--a5-text-primary);
}

/* Work case: tighter vertical band around the article title */
main.iv-page-work-case .iv-about-page-section.iv-section,
main.iv-page-services-post .iv-about-page-section.iv-section {
	padding-block: clamp(2.75rem, 5.5vw, 4.75rem);
}

main.iv-page-work-case .iv-about-page-section .iv-section-header h1.iv-section-title,
main.iv-page-services-post .iv-about-page-section .iv-section-header h1.iv-section-title {
	margin-block: 0;
}

main.iv-page-about .iv-about-page-prose,
main.iv-page-work-case .iv-about-page-prose,
main.iv-page-services-post .iv-about-page-prose {
	max-width: 100%;
	color: var(--a5-text-secondary);
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.4rem, 2.4vw, 2rem);
	align-items: start;
}

@media (min-width: 960px) {
	main.iv-page-about .iv-about-page-prose.iv-about-page-prose--has-media {
		grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.62fr);
		column-gap: clamp(1.75rem, 3.2vw, 2.6rem);
	}
}

main.iv-page-about .iv-about-page-prose .iv-about-page-prose-content > *,
main.iv-page-work-case .iv-about-page-prose .iv-about-page-prose-content > *,
main.iv-page-services-post .iv-about-page-prose .iv-about-page-prose-content > * {
	margin: 0 0 clamp(1.15rem, 2vw, 1.5rem);
}

main.iv-page-about .iv-about-page-prose .iv-about-page-prose-content > *:last-child,
main.iv-page-work-case .iv-about-page-prose .iv-about-page-prose-content > *:last-child,
main.iv-page-services-post .iv-about-page-prose .iv-about-page-prose-content > *:last-child {
	margin-bottom: 0;
}

main.iv-page-about .iv-about-page-prose .iv-about-page-prose-media {
	margin: 0;
	width: 100%;
	aspect-ratio: 9 / 16;
	overflow: hidden;
	background: var(--a5-surface-dark);
	border: 1px solid var(--a5-border-primary);
}

main.iv-page-about .iv-about-page-prose .iv-about-page-prose-media-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

main.iv-page-about .iv-about-page-prose p,
main.iv-page-work-case .iv-about-page-prose p,
main.iv-page-services-post .iv-about-page-prose p,
main.iv-page-about .iv-about-page-prose-p {
	font-size: clamp(1.04rem, 0.2vw + 0.98rem, 1.16rem);
	line-height: 1.75;
	font-weight: 400;
	color: var(--a5-text-secondary);
}

main.iv-page-about .iv-about-page-prose h2,
main.iv-page-about .iv-about-page-prose h3,
main.iv-page-about .iv-about-page-prose h4,
main.iv-page-about .iv-about-page-prose h5,
main.iv-page-about .iv-about-page-prose h6,
main.iv-page-work-case .iv-about-page-prose h2,
main.iv-page-services-post .iv-about-page-prose h2,
main.iv-page-work-case .iv-about-page-prose h3,
main.iv-page-services-post .iv-about-page-prose h3,
main.iv-page-work-case .iv-about-page-prose h4,
main.iv-page-services-post .iv-about-page-prose h4,
main.iv-page-work-case .iv-about-page-prose h5,
main.iv-page-services-post .iv-about-page-prose h5,
main.iv-page-work-case .iv-about-page-prose h6,
main.iv-page-services-post .iv-about-page-prose h6 {
	margin: clamp(2rem, 3.4vw, 2.75rem) 0 clamp(0.8rem, 1.4vw, 1.1rem);
	font-family: var(--a5-font-display);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
	color: var(--a5-text-primary);
}

main.iv-page-about .iv-about-page-prose h2,
main.iv-page-work-case .iv-about-page-prose h2,
main.iv-page-services-post .iv-about-page-prose h2 {
	font-size: clamp(1.65rem, 0.8vw + 1.4rem, 2.1rem);
}

main.iv-page-about .iv-about-page-prose h3,
main.iv-page-work-case .iv-about-page-prose h3,
main.iv-page-services-post .iv-about-page-prose h3 {
	font-size: clamp(1.35rem, 0.55vw + 1.15rem, 1.7rem);
}

main.iv-page-about .iv-about-page-prose h4,
main.iv-page-work-case .iv-about-page-prose h4,
main.iv-page-services-post .iv-about-page-prose h4 {
	font-size: clamp(1.18rem, 0.35vw + 1.02rem, 1.4rem);
}

main.iv-page-about .iv-about-page-prose h5,
main.iv-page-about .iv-about-page-prose h6,
main.iv-page-work-case .iv-about-page-prose h5,
main.iv-page-services-post .iv-about-page-prose h5,
main.iv-page-work-case .iv-about-page-prose h6,
main.iv-page-services-post .iv-about-page-prose h6 {
	font-size: clamp(1.02rem, 0.2vw + 0.95rem, 1.15rem);
}

main.iv-page-about .iv-about-page-prose strong,
main.iv-page-about .iv-about-page-prose b,
main.iv-page-work-case .iv-about-page-prose strong,
main.iv-page-services-post .iv-about-page-prose strong,
main.iv-page-work-case .iv-about-page-prose b,
main.iv-page-services-post .iv-about-page-prose b {
	color: var(--a5-text-primary);
	font-weight: 700;
}

main.iv-page-about .iv-about-page-prose em,
main.iv-page-about .iv-about-page-prose i,
main.iv-page-work-case .iv-about-page-prose em,
main.iv-page-services-post .iv-about-page-prose em,
main.iv-page-work-case .iv-about-page-prose i,
main.iv-page-services-post .iv-about-page-prose i {
	font-style: italic;
	color: var(--a5-text-primary);
}

main.iv-page-about .iv-about-page-prose a,
main.iv-page-work-case .iv-about-page-prose a,
main.iv-page-services-post .iv-about-page-prose a {
	color: var(--a5-text-primary);
	text-decoration: underline;
	text-decoration-color: var(--a5-accent);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.16em;
	transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

main.iv-page-about .iv-about-page-prose a:hover,
main.iv-page-about .iv-about-page-prose a:focus-visible,
main.iv-page-work-case .iv-about-page-prose a:hover,
main.iv-page-services-post .iv-about-page-prose a:hover,
main.iv-page-work-case .iv-about-page-prose a:focus-visible,
main.iv-page-services-post .iv-about-page-prose a:focus-visible {
	color: var(--a5-accent-strong);
	text-decoration-color: var(--a5-text-primary);
}

main.iv-page-about .iv-about-page-prose blockquote,
main.iv-page-work-case .iv-about-page-prose blockquote,
main.iv-page-services-post .iv-about-page-prose blockquote {
	margin: clamp(1.5rem, 3vw, 2rem) 0;
	padding: clamp(1rem, 1.9vw, 1.35rem) clamp(1rem, 1.9vw, 1.35rem) clamp(0.95rem, 1.7vw, 1.2rem) clamp(1.2rem, 2.2vw, 1.55rem);
	border-left: 4px solid var(--a5-accent);
	border-radius: 0.25rem;
	color: var(--a5-text-primary);
}

main.iv-page-about .iv-about-page-prose blockquote > *,
main.iv-page-work-case .iv-about-page-prose blockquote > *,
main.iv-page-services-post .iv-about-page-prose blockquote > * {
	margin: 0 0 0.8rem;
	font-size: clamp(1.08rem, 0.28vw + 1rem, 1.24rem);
	line-height: 1.68;
	font-weight: 600;
	color: var(--a5-text-primary);
}

main.iv-page-about .iv-about-page-prose blockquote > *:last-child,
main.iv-page-work-case .iv-about-page-prose blockquote > *:last-child,
main.iv-page-services-post .iv-about-page-prose blockquote > *:last-child {
	margin-bottom: 0;
}

main.iv-page-about .iv-about-page-prose ul,
main.iv-page-about .iv-about-page-prose ol,
main.iv-page-work-case .iv-about-page-prose ul,
main.iv-page-services-post .iv-about-page-prose ul,
main.iv-page-work-case .iv-about-page-prose ol,
main.iv-page-services-post .iv-about-page-prose ol {
	margin: 0 0 clamp(1.15rem, 2vw, 1.5rem);
	padding-inline-start: 1.25rem;
}

main.iv-page-about .iv-about-page-prose li,
main.iv-page-work-case .iv-about-page-prose li,
main.iv-page-services-post .iv-about-page-prose li {
	margin: 0 0 0.55rem;
	font-size: clamp(1.01rem, 0.18vw + 0.95rem, 1.12rem);
	line-height: 1.65;
	color: var(--a5-text-secondary);
}

main.iv-page-about .iv-about-page-prose li::marker,
main.iv-page-work-case .iv-about-page-prose li::marker,
main.iv-page-services-post .iv-about-page-prose li::marker {
	color: var(--a5-accent);
}

/* Work case article stack: editorial list rhythm, nesting, block-editor-safe (§2 §3) */
main.iv-page-work-case .iv-about-page-prose ul,
main.iv-page-services-post .iv-about-page-prose ul,
main.iv-page-work-case .iv-about-page-prose ol,
main.iv-page-services-post .iv-about-page-prose ol {
	list-style-position: outside;
	padding-inline-start: 1.5rem;
	margin: clamp(0.35rem, 0.8vw, 0.55rem) 0 clamp(1.25rem, 2.1vw, 1.65rem);
}

main.iv-page-work-case .iv-about-page-prose ul,
main.iv-page-services-post .iv-about-page-prose ul {
	list-style-type: disc;
}

main.iv-page-work-case .iv-about-page-prose ol,
main.iv-page-services-post .iv-about-page-prose ol {
	list-style-type: decimal;
}

main.iv-page-work-case .iv-about-page-prose li,
main.iv-page-services-post .iv-about-page-prose li {
	padding-inline-start: 0.4rem;
	margin: 0 0 clamp(0.58rem, 1.05vw, 0.8rem);
	line-height: 1.68;
}

main.iv-page-work-case .iv-about-page-prose li:last-child,
main.iv-page-services-post .iv-about-page-prose li:last-child {
	margin-bottom: 0;
}

main.iv-page-work-case .iv-about-page-prose ul > li::marker,
main.iv-page-services-post .iv-about-page-prose ul > li::marker {
	color: var(--a5-accent-strong);
	font-size: 0.72em;
}

main.iv-page-work-case .iv-about-page-prose ol > li::marker,
main.iv-page-services-post .iv-about-page-prose ol > li::marker {
	color: var(--a5-accent-strong);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

main.iv-page-work-case .iv-about-page-prose li > ul,
main.iv-page-services-post .iv-about-page-prose li > ul,
main.iv-page-work-case .iv-about-page-prose li > ol,
main.iv-page-services-post .iv-about-page-prose li > ol {
	margin-top: clamp(0.45rem, 0.9vw, 0.65rem);
	margin-bottom: clamp(0.45rem, 0.9vw, 0.65rem);
	padding-inline-start: 1.35rem;
}

main.iv-page-work-case .iv-about-page-prose li > ul,
main.iv-page-services-post .iv-about-page-prose li > ul {
	list-style-type: circle;
}

main.iv-page-work-case .iv-about-page-prose li > ul > li::marker,
main.iv-page-services-post .iv-about-page-prose li > ul > li::marker {
	color: var(--a5-text-secondary);
	font-size: 0.68em;
}

main.iv-page-work-case .iv-about-page-prose li > ol,
main.iv-page-services-post .iv-about-page-prose li > ol {
	list-style-type: lower-alpha;
}

main.iv-page-work-case .iv-about-page-prose li > ol > li::marker,
main.iv-page-services-post .iv-about-page-prose li > ol > li::marker {
	color: var(--a5-text-secondary);
	font-weight: 600;
	font-size: 0.95em;
}

main.iv-page-work-case .iv-about-page-prose li > p,
main.iv-page-services-post .iv-about-page-prose li > p {
	margin: 0 0 clamp(0.45rem, 0.85vw, 0.65rem);
	font-size: inherit;
	line-height: inherit;
	color: inherit;
}

main.iv-page-work-case .iv-about-page-prose li > p:last-child,
main.iv-page-services-post .iv-about-page-prose li > p:last-child {
	margin-bottom: 0;
}

main.iv-page-work-case .iv-about-page-prose li > ul > li > ul,
main.iv-page-services-post .iv-about-page-prose li > ul > li > ul {
	list-style-type: square;
}

main.iv-page-work-case .iv-about-page-prose li > ul > li > ul > li::marker,
main.iv-page-services-post .iv-about-page-prose li > ul > li > ul > li::marker {
	color: var(--a5-border-secondary);
	font-size: 0.65em;
}

main.iv-page-about .iv-about-page-prose hr,
main.iv-page-work-case .iv-about-page-prose hr,
main.iv-page-services-post .iv-about-page-prose hr {
	border: 0;
	border-top: 1px solid var(--a5-border-primary);
	margin: clamp(1.6rem, 3vw, 2.2rem) 0;
}

main.iv-page-about .iv-about-page-prose code,
main.iv-page-about .iv-about-page-prose kbd,
main.iv-page-work-case .iv-about-page-prose code,
main.iv-page-services-post .iv-about-page-prose code,
main.iv-page-work-case .iv-about-page-prose kbd,
main.iv-page-services-post .iv-about-page-prose kbd {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.92em;
	color: var(--a5-text-primary);
	background: var(--a5-accent-soft);
	padding: 0.08em 0.34em;
	border-radius: 0.22rem;
}

main.iv-page-about .iv-about-page-prose pre,
main.iv-page-work-case .iv-about-page-prose pre,
main.iv-page-services-post .iv-about-page-prose pre {
	margin: clamp(1.2rem, 2.2vw, 1.6rem) 0;
	padding: clamp(0.85rem, 1.5vw, 1.1rem);
	overflow-x: auto;
	background: var(--a5-surface-dark);
	color: var(--a5-text-on-dark);
	border-radius: 0.35rem;
}

main.iv-page-about .iv-about-page-prose pre code,
main.iv-page-work-case .iv-about-page-prose pre code,
main.iv-page-services-post .iv-about-page-prose pre code {
	background: transparent;
	color: inherit;
	padding: 0;
	border-radius: 0;
}

main.iv-page-about .iv-about-page-prose table,
main.iv-page-work-case .iv-about-page-prose table,
main.iv-page-services-post .iv-about-page-prose table {
	width: 100%;
	border-collapse: collapse;
	margin: clamp(1.2rem, 2.2vw, 1.6rem) 0;
}

main.iv-page-about .iv-about-page-prose th,
main.iv-page-about .iv-about-page-prose td,
main.iv-page-work-case .iv-about-page-prose th,
main.iv-page-services-post .iv-about-page-prose th,
main.iv-page-work-case .iv-about-page-prose td,
main.iv-page-services-post .iv-about-page-prose td {
	border-bottom: 1px solid var(--a5-border-primary);
	padding: 0.55rem 0.4rem;
	text-align: left;
}

main.iv-page-about .iv-about-page-prose th,
main.iv-page-work-case .iv-about-page-prose th,
main.iv-page-services-post .iv-about-page-prose th {
	color: var(--a5-text-primary);
	font-weight: 600;
}

main.iv-page-about .iv-about-page-prose img,
main.iv-page-about .iv-about-page-prose figure,
main.iv-page-work-case .iv-about-page-prose img,
main.iv-page-services-post .iv-about-page-prose img,
main.iv-page-work-case .iv-about-page-prose figure,
main.iv-page-services-post .iv-about-page-prose figure {
	max-width: 100%;
	height: auto;
}

main.iv-page-about .iv-about-page-prose figcaption,
main.iv-page-work-case .iv-about-page-prose figcaption,
main.iv-page-services-post .iv-about-page-prose figcaption {
	margin-top: 0.45rem;
	font-size: 0.9rem;
	line-height: 1.5;
	color: var(--a5-text-secondary);
}

main.iv-page-about .iv-about-page-tagline,
main.iv-page-work-case .iv-about-page-tagline,
main.iv-page-services-post .iv-about-page-tagline {
	margin-top: clamp(1.75rem, 3vw, 2.25rem);
	margin-bottom: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(1.35rem, 0.5vw + 1.15rem, 1.65rem);
	line-height: 1.25;
	letter-spacing: -0.02em;
}

main.iv-page-about .iv-about-page-tagline {
	font-weight: 700;
	color: var(--a5-text-primary);
}

/* Work case kicker under title: softer than body headline (§2 Text / Secondary) */
main.iv-page-work-case .iv-about-page-tagline,
main.iv-page-services-post .iv-about-page-tagline {
	font-weight: 600;
	color: var(--a5-text-secondary);
}

/* Work case + Services post: full-width lead + section imagery (natural aspect, article width) */
main.iv-page-work-case .iv-work-case-featured-figure,
main.iv-page-services-post .iv-work-case-featured-figure {
	margin: clamp(2rem, 3.5vw, 2.75rem) 0 clamp(1.75rem, 3vw, 2.25rem);
	width: 100%;
	overflow: hidden;
	background: var(--a5-surface-dark);
	border: 1px solid var(--a5-border-primary);
	border-radius: 0.25rem;
}

main.iv-page-work-case .iv-work-case-featured-img,
main.iv-page-services-post .iv-work-case-featured-img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
}

main.iv-page-work-case .iv-work-case-section-figure,
main.iv-page-services-post .iv-work-case-section-figure {
	margin: 0;
	width: 100%;
	overflow: hidden;
	background: var(--a5-surface-dark);
	border: 1px solid var(--a5-border-primary);
	border-radius: 0.25rem;
}

main.iv-page-work-case .iv-work-case-section-img,
main.iv-page-services-post .iv-work-case-section-img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
}

/* Contact page template (page-contact.php): narrow column — light inner content (§2 §6; iv-* only) */
main.iv-page-contact .iv-contact-page-inner {
	width: 100%;
	max-width: min(36rem, 92%);
	min-width: 0;
	margin-inline: auto;
	box-sizing: border-box;
	padding-inline: clamp(1rem, 4vw, 1.25rem);
}

main.iv-page-contact .iv-contact-page-section h1.iv-section-title {
	margin-block: 0;
	margin-inline: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(3.1rem, 1.35rem + 3.2vw, 4.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.045em;
	max-width: 100%;
	color: var(--a5-text-primary);
}

main.iv-page-contact .iv-contact-page-section p.iv-section-kicker {
	font-size: clamp(1.04rem, 0.2vw + 0.9rem, 1.2rem);
	line-height: 1.65;
	font-weight: 400;
	color: var(--a5-text-secondary);
}

main.iv-page-contact .iv-contact-page-stack {
	display: flex;
	flex-direction: column;
	gap: clamp(3rem, 8vw, 4.75rem);
}

/* Get in Touch card (§3: iv-* only) */
main.iv-page-contact .iv-contact-page-pair {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 5vw, 3rem);
	align-items: start;
	min-width: 0;
}

main.iv-page-contact .iv-contact-page-pair > .iv-contact-page-card {
	min-width: 0;
}

main.iv-page-contact .iv-contact-page-h2 {
	margin: 0 0 0.65rem;
	font-family: var(--a5-font-display);
	font-size: clamp(1.35rem, 0.35vw + 1.15rem, 1.55rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
	color: var(--a5-text-primary);
}

main.iv-page-contact .iv-contact-page-lead {
	margin: 0 0 1.25rem;
	font-size: clamp(1.04rem, 0.2vw + 0.98rem, 1.14rem);
	line-height: 1.65;
	color: var(--a5-text-secondary);
}

main.iv-page-contact .iv-contact-page-channel-list {
	list-style: none;
	margin: 0;
	padding-inline: 0;
	padding-block: clamp(0.65rem, 1.8vw, 1.15rem);
	display: flex;
	flex-direction: column;
	gap: clamp(1.55rem, 3.2vw, 2.05rem);
}

main.iv-page-contact .iv-contact-page-channel {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	min-width: 0;
	padding-block: clamp(0.45rem, 1.2vw, 0.8rem);
}

main.iv-page-contact .iv-contact-page-icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: var(--a5-radius);
	color: var(--a5-accent);
	background: var(--a5-accent-soft);
}

main.iv-page-contact .iv-contact-page-channel-body {
	min-width: 0;
	flex: 1;
}

main.iv-page-contact .iv-contact-page-channel-label {
	margin: 0 0 0.25rem;
	font-family: var(--a5-font-display);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--a5-text-primary);
}

main.iv-page-contact .iv-contact-page-channel-link {
	font-size: clamp(1.05rem, 0.15vw + 0.95rem, 1.15rem);
	font-weight: 600;
	color: var(--a5-text-primary);
	text-decoration: none;
	border-bottom: 1px solid var(--a5-border-secondary);
	padding-bottom: 0.12em;
	transition: color 0.2s ease, border-color 0.2s ease;
}

main.iv-page-contact .iv-contact-page-channel-link:hover,
main.iv-page-contact .iv-contact-page-channel-link:focus-visible {
	color: var(--a5-accent-strong);
	border-bottom-color: var(--a5-accent-strong);
}

main.iv-page-contact .iv-contact-page-channel-link:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 3px;
}

main.iv-page-contact .iv-contact-page-wa-lines {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

main.iv-page-contact .iv-contact-page-wa-row {
	display: grid;
	grid-template-columns: minmax(4.5rem, auto) 1fr;
	gap: 0.35rem 1rem;
	align-items: baseline;
	margin: 0;
}

main.iv-page-contact .iv-contact-page-wa-city {
	margin: 0;
	font-size: clamp(0.95rem, 0.12vw + 0.88rem, 1.02rem);
	font-weight: 600;
	color: var(--a5-text-primary);
}

main.iv-page-contact .iv-contact-page-wa-num {
	margin: 0;
	font-size: clamp(0.95rem, 0.12vw + 0.88rem, 1.02rem);
	color: var(--a5-text-secondary);
}

/* Stack above base .iv-service-card-figure: default 3/2 is not used in #services full-tile */
.iv-service-card-figure {
	margin: 0;
	padding: 0;
	position: relative;
	aspect-ratio: 3 / 2;
	background: var(--a5-surface-dark);
	overflow: hidden;
	flex-shrink: 0;
}

.iv-service-card-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.iv-service-card-body {
	padding: 1.35rem 1.25rem 1.45rem;
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
}

@media (min-width: 640px) {
	.iv-service-card-body {
		padding: 1.45rem 1.35rem 1.5rem;
	}
}

.iv-service-card-cta-line {
	margin: 0.85rem 0 0;
	padding: 0;
}

.iv-service-card-cta {
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: var(--a5-text-primary);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.22em;
	text-decoration-color: rgba(17, 17, 17, 0.28);
}

.iv-service-card-cta:hover {
	color: var(--a5-accent);
	text-decoration-color: var(--a5-accent);
}

.iv-service-card-cta:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
	border-radius: 0.2rem;
}

body.a5-body-home .iv-service-card .iv-pillar-title {
	margin: 0 0 0.4rem;
}

body.a5-body-home .iv-service-card .iv-pillar-copy {
	margin: 0;
}

body.a5-body-home .iv-service-card .iv-pillar-copy.iv-service-card-copy {
	margin-top: 0.35rem;
}

.iv-section--surface .iv-pillar:hover,
body.a5-body-home
	.iv-service-card:hover:not(.iv-service-card--fulltile) {
	border-color: var(--a5-accent);
}

.iv-pillar-title {
	margin: 0 0 0.35rem;
	letter-spacing: -0.01em;
}

.iv-pillar-copy {
	margin: 0;
	line-height: 1.55;
}

/* Process (on surface: ink) */
.iv-process-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}

.iv-process-item {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.25rem 1.5rem;
	align-items: start;
	padding: 1.5rem 0;
	border-top: 1px solid var(--a5-border-secondary);
}

.iv-section--ink .iv-process-item {
	border-top: 1px solid rgba(237, 237, 237, 0.22);
}

.iv-process-item:first-of-type {
	border-top: 0;
	padding-top: 0.25rem;
}

.iv-process-marker {
	font-family: var(--a5-font-display);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	color: var(--a5-text-on-dark);
	background: var(--a5-surface-dark);
	border: 1px solid var(--a5-border-secondary);
	border-radius: 0.35rem;
	line-height: 1;
	padding: 0.45rem 0.6rem;
}

.iv-section--ink .iv-process-marker {
	color: var(--a5-text-primary);
	background: var(--a5-surface-white);
	border-color: var(--a5-surface-white);
}

/* Home #process: full-bleed background video (muted vs hero) + veil; foreground above (§2) */
body.a5-body-home section#process.iv-process-has-video {
	position: relative;
}

body.a5-body-home section#process .iv-process-ambient {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
	pointer-events: none;
}

body.a5-body-home section#process .iv-process-video-backdrop {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 1s ease;
}

body.a5-body-home section#process .iv-process-video-backdrop.iv-process-video--ready {
	opacity: 1;
}

body.a5-body-home section#process .iv-process-bg-video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	min-width: 100%;
	min-height: 100%;
	max-width: none;
	object-fit: cover;
	object-position: center;
	/* Slightly more prominent: a touch more color/brightness; hero-level contrast budget for copy (§2) */
	filter: grayscale(0.74) brightness(0.34) contrast(0.86) saturate(0.38);
}

body.a5-body-home section#process .iv-process-video-veil {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(42, 42, 46, 0.54);
}

/* Reduced motion: no background motion on #process (README §8) */
body.a5-body-home section#process.iv-process--reduced-motion .iv-process-ambient {
	display: none;
}

/* Home #process: text + prominent icons on ink (README §2) */
body.a5-body-home section#process .iv-section-inner.iv-process-section-inner {
	position: relative;
	z-index: 1;
	width: 100%;
	box-sizing: border-box;
}

body.a5-body-home section#process .iv-section-header.iv-process-section-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin: 0 0 clamp(2rem, 2.5vw + 1rem, 2.85rem);
	padding: 0;
	text-align: center;
	width: 100%;
}

/* Process + work titles: same display scale as section#services h2#services-title */
body.a5-body-home section#process h2#process-title,
body.a5-body-home section#work h2#work-title,
body.a5-body-work section#work h1#work-page-title {
	font-size: clamp(3.1rem, 1.35rem + 3.2vw, 4.75rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.045em;
	max-width: 100%;
}
body.a5-body-home section#process h2#process-title {
	margin-left: auto;
	margin-right: auto;
}
body.a5-body-home section#work h2#work-title,
body.a5-body-work section#work h1#work-page-title {
	margin-left: 0;
	margin-right: 0;
	text-align: left;
}

body.a5-body-home section#process .iv-process-list--text {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	width: 100%;
	margin-inline: 0;
	box-sizing: border-box;
}

@media (min-width: 800px) {
	body.a5-body-home section#process .iv-process-list--text {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: clamp(1.75rem, 2.5vw, 2.75rem);
		align-items: start;
	}
}

/* Icons: Accent / Primary (green) via currentColor in SVG strokes (§2) */
body.a5-body-home section#process .iv-process-step-icon {
	width: min(5.5rem, 24vw);
	height: min(5.5rem, 24vw);
	margin: 0 0 1.15rem;
	color: var(--a5-accent);
	flex-shrink: 0;
}

body.a5-body-home section#process .iv-process-step-icon-svg {
	display: block;
	width: 100%;
	height: 100%;
}

body.a5-body-home section#process .iv-process-text-block {
	margin: 0;
	padding: 0 0 clamp(1.9rem, 2.2vw, 2.4rem);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	border: 0;
	background: transparent;
	box-shadow: none;
}

@media (max-width: 799px) {
	body.a5-body-home section#process .iv-process-text-block {
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
	}

	body.a5-body-home section#process .iv-process-text-block:last-child {
		border-bottom: 0;
		padding-bottom: 0;
	}
}

body.a5-body-home section#process .iv-process-text-title {
	margin: 0 0 0.45rem;
	display: block;
	font-family: var(--a5-font-display);
	font-size: clamp(1.95rem, 0.8vw + 1.5rem, 2.8rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.12;
	color: var(--a5-text-on-dark);
}

body.a5-body-home section#process .iv-process-text-body {
	margin: 0;
	font-size: clamp(0.92rem, 0.1vw + 0.85rem, 1.02rem);
	line-height: 1.6;
	font-weight: 400;
	letter-spacing: 0.01em;
	color: rgba(237, 237, 237, 0.92);
}

/* Why */
.iv-why-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0;
}

.iv-why-item {
	display: flex;
	gap: 0.9rem;
	align-items: flex-start;
	padding: 0.9rem 0;
	border-top: 1px solid var(--a5-border-secondary);
}

.iv-section--ink .iv-why-item {
	border-top: 1px solid rgba(237, 237, 237, 0.22);
}

.iv-why-item:first-of-type {
	border-top: 0;
}

.iv-why-line {
	width: 3px;
	margin-top: 0.3rem;
	border-radius: 2px;
	flex-shrink: 0;
	min-height: 1.15rem;
	background: var(--a5-accent);
}

.iv-why-text {
	font-size: 1.02rem;
	line-height: 1.5;
}

/* Work cards */
.iv-work-grid {
	display: grid;
	gap: 1.75rem;
}

@media (min-width: 900px) {
	.iv-work-grid {
		gap: 2rem;
	}
}

.iv-work-card {
	margin: 0;
	padding: 0;
	border-radius: var(--a5-radius-lg);
	overflow: hidden;
	display: grid;
	grid-template-columns: 1fr;
	background: var(--a5-surface-white);
	border: 1px solid var(--a5-border-primary);
	box-shadow: var(--a5-shadow);
}

@media (min-width: 800px) {
	.iv-work-card {
		grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.15fr);
		align-items: stretch;
	}
}

.iv-work-figure {
	margin: 0;
	display: block;
	background: var(--a5-surface-dark);
	min-height: 200px;
}

.iv-work-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.iv-work-body {
	padding: 1.4rem 1.5rem 1.5rem;
	background: var(--a5-surface-white);
	color: var(--a5-text-primary);
}

/* Case titles sit on surface panel inside ink section: ink text, not global section heading color */
.iv-work-body h3,
.iv-work-body p,
.iv-work-body dd {
	color: var(--a5-text-primary);
}

@media (min-width: 800px) {
	.iv-work-body {
		padding: 1.75rem 1.85rem;
	}
}

.iv-work-kicker {
	color: var(--a5-accent);
}

.iv-work-name {
	margin: 0;
	letter-spacing: -0.02em;
}

.iv-work-line {
	margin: 0;
}

.iv-case-dt {
	margin: 0;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--a5-accent);
}

.iv-case-dd {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.55;
}

.iv-case-meta {
	margin: 0;
}

.iv-case-row {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.4rem 1.25rem;
}

/* Engage band + home #services CTA: same iv-hero-cta-* pattern; surface = primary text + accent rule (§2); scope #services via .iv-services-section-cta (§3) */
body.a5-body-home section#engage .iv-hero-cta-line,
section.iv-engage-section .iv-hero-cta-line,
body.a5-body-home section#services .iv-services-section-cta .iv-hero-cta-line {
	margin: 3rem 0 0;
}
body.a5-body-home section#engage .iv-hero-cta-text,
section.iv-engage-section .iv-hero-cta-text,
body.a5-body-home section#services .iv-services-section-cta .iv-hero-cta-text {
	color: var(--a5-text-primary);
	border-bottom-color: var(--a5-accent);
}
body.a5-body-home section#engage .iv-hero-cta-text:hover,
body.a5-body-home section#engage .iv-hero-cta-text:focus-visible,
section.iv-engage-section .iv-hero-cta-text:hover,
section.iv-engage-section .iv-hero-cta-text:focus-visible,
body.a5-body-home section#services .iv-services-section-cta .iv-hero-cta-text:hover,
body.a5-body-home section#services .iv-services-section-cta .iv-hero-cta-text:focus-visible {
	color: var(--a5-accent);
	border-bottom-color: var(--a5-text-primary);
}

/* Footer: Surface / Dark band (README §2) */
.iv-site-footer {
	border-top: 1px solid rgba(237, 237, 237, 0.12);
	background: var(--a5-surface-dark);
}

/* Match .iv-site-header-inner width / horizontal inset (§8 alignment) */
.iv-site-footer-inner {
	box-sizing: border-box;
	width: 98%;
	max-width: 98%;
	margin-inline: auto;
	padding: clamp(1.85rem, 4.5vw, 2.65rem) var(--a5-header-pad-x);
	display: grid;
	grid-template-columns: 1fr;
	justify-items: center;
	text-align: center;
	gap: 0.75rem;
}

/* Two columns when tagline present: primary | logo + tagline (§8 layout) */
.iv-site-footer-inner--split {
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	align-items: center;
	column-gap: clamp(1.25rem, 4vw, 2.75rem);
	row-gap: 1rem;
	text-align: start;
	justify-items: stretch;
}

.iv-site-footer-inner--split .iv-site-footer-col--primary {
	justify-self: start;
	text-align: left;
}

.iv-site-footer-inner--split .iv-site-footer-col--aside {
	justify-self: end;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	text-align: right;
	gap: 0.5rem;
	min-width: 0;
}

.iv-site-footer-inner--split .iv-site-footer-logo {
	margin: 0;
}

.iv-site-footer-col--primary {
	min-width: 0;
}

.iv-site-footer-primary {
	margin: 0;
	font-family: var(--a5-font-display);
	font-size: clamp(0.78rem, 0.12vw + 0.72rem, 0.88rem);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	line-height: 1.35;
	color: var(--a5-text-on-dark);
}

/* Small white mark above slogan (§1 site-root asset; iv-* visual only) */
.iv-site-footer-logo {
	display: block;
	width: clamp(1.65rem, 3.5vw, 2rem);
	height: auto;
	max-height: 2rem;
	object-fit: contain;
	margin: 0.15rem 0 0;
	flex-shrink: 0;
}

.iv-site-footer-inner--split .iv-site-footer-tagline {
	max-width: none;
}

.iv-site-footer-tagline {
	margin: 0;
	max-width: 28rem;
	font-size: clamp(0.72rem, 0.14vw + 0.66rem, 0.82rem);
	font-weight: 500;
	line-height: 1.45;
	letter-spacing: -0.01em;
	color: var(--a5-text-on-dark);
}

@media (max-width: 639px) {
	.iv-site-footer-inner--split {
		grid-template-columns: 1fr;
		justify-items: center;
		text-align: center;
	}

	.iv-site-footer-inner--split .iv-site-footer-col--primary {
		justify-self: center;
		text-align: center;
	}

	.iv-site-footer-inner--split .iv-site-footer-col--aside {
		justify-self: center;
		align-items: center;
		text-align: center;
	}
}

body.a5-body-home section#engage a:focus-visible,
section.iv-engage-section a:focus-visible,
.iv-hero-cta-line a:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

.iv-site-footer a:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

.iv-section--surface a.iv-nav-link:focus-visible {
	outline: 2px solid var(--a5-accent);
	outline-offset: 2px;
}

/* Index / single fallback: bold hierarchy on surface */
main.iv-page .iv-entry-title {
	color: var(--a5-text-primary);
	font-family: var(--a5-font-display);
	font-size: clamp(1.8rem, 0.4rem + 2.5vw, 2.4rem);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
}

main.iv-page .iv-entry .iv-entry-content,
main.iv-page .iv-empty-state {
	font-size: 1.1rem;
	line-height: 1.65;
}

/* Ink sections: Text / On Dark (README §2) */
.iv-hero h1,
.iv-hero .iv-lead {
	color: var(--a5-text-on-dark);
}

.iv-section--ink .iv-section-header h1,
.iv-section--ink .iv-section-header h2,
.iv-section--ink .iv-section-kicker,
.iv-section--ink .iv-process-item h3,
.iv-section--ink .iv-process-item p {
	color: var(--a5-text-on-dark);
}

/* Surface: Text / Primary on white */
.iv-section--surface h1,
.iv-section--surface h2,
.iv-section--surface h3,
.iv-section--surface .iv-lead,
.iv-why-text {
	color: var(--a5-text-primary);
}
