/*
Theme Name: UK Website
Theme URI: https://sblcorp.com/
Author: SBL
Author URI: https://sblcorp.com/
Description: Custom block theme (FSE) for the SBL UK website. Built from scratch — no parent theme, no page builder. All design tokens flow from theme.json.
Version: 0.1.0
Requires at least: 6.5
Tested up to: 6.7
Requires PHP: 8.1
License: Proprietary
License URI: https://sblcorp.com/
Text Domain: uk-website
Tags: full-site-editing, block-patterns, block-styles, custom-colors, custom-logo, custom-menu, featured-images, translation-ready
*/

/* ==========================================================================
   1. Token aliases
   --------------------------------------------------------------------------
   Source of truth lives in theme.json. These short aliases mirror the
   variable names used in the design mockups so component CSS reads cleanly.
   Do NOT change colour/font values here — change theme.json.
   ========================================================================== */
:root {
	--ink:        var(--wp--preset--color--ink);
	--ink-2:      var(--wp--preset--color--ink-2);
	--muted:      var(--wp--preset--color--muted);
	--quiet:      var(--wp--preset--color--quiet);
	--hairline:   var(--wp--preset--color--hairline);
	--surface:    var(--wp--preset--color--surface);
	--white:      var(--wp--preset--color--white);
	--green:      var(--wp--preset--color--green);
	--green-dk:   var(--wp--preset--color--green-dk);
	--blue:       var(--wp--preset--color--blue);
	--red:        var(--wp--preset--color--red);

	--max:        1200px;
	--pad:        var(--wp--preset--spacing--80);
	--section:    var(--wp--preset--spacing--70);

	--font-sans:  var(--wp--preset--font-family--poppins);

	--ease:       cubic-bezier(.4, 0, .2, 1);
	--t-fast:     .15s var(--ease);
	--t-med:      .3s var(--ease);
}

/* ==========================================================================
   2. Reset / base
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }

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

body {
	font-family: var(--font-sans);
	color: var(--ink);
	background: var(--white);
	line-height: 1.6;
	font-size: 16.5px;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

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

a { color: inherit; text-decoration: none; transition: color var(--t-fast); }
a:hover { color: var(--green-dk); }

::selection { background: var(--green); color: var(--white); }

:focus-visible {
	outline: 2px solid var(--green);
	outline-offset: 2px;
	border-radius: 2px;
}

/* ==========================================================================
   3. A11y skip link
   ========================================================================== */
.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.screen-reader-text:focus,
.uk-skiplinks a:focus {
	position: fixed; top: 12px; left: 12px;
	width: auto; height: auto;
	padding: 10px 16px;
	margin: 0;
	clip: auto;
	background: var(--ink);
	color: var(--white);
	z-index: 100;
	border-radius: 2px;
	font-weight: 500;
}

/* ==========================================================================
   4. Layout primitives
   ========================================================================== */
.uk-container { max-width: var(--max); margin-inline: auto; padding-inline: var(--pad); }
.uk-narrow    { max-width: 820px; }

section { padding-block: var(--section); }

/* ==========================================================================
   5. Typography components
   ========================================================================== */
.uk-display {
	font-family: var(--font-sans);
	font-weight: 700;
	letter-spacing: -0.028em;
	line-height: 1.04;
}
.uk-display em { font-style: italic; font-weight: 500; color: var(--green-dk); }

.uk-lede {
	font-size: clamp(16px, 1.2vw, 18px);
	color: var(--muted);
	max-width: 48ch;
	line-height: 1.6;
}

.uk-kicker {
	font-family: var(--font-sans);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--ink);
	display: inline-flex;
	align-items: center;
	gap: 14px;
}
.uk-kicker .uk-num {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 34px; height: 26px; padding: 0 8px;
	background: var(--green); color: var(--white);
	font-weight: 800; font-size: 12px; letter-spacing: 0.1em;
	border-radius: 2px;
}
.uk-kicker .uk-tick {
	height: 1px; width: 48px;
	background: currentColor;
	display: inline-block;
}

.uk-rule {
	height: 1px; border: 0;
	background: var(--ink);
	width: 42px;
	margin: 14px 0 26px;
}
.uk-rule.faint { background: rgba(255, 255, 255, .3); }

/* ==========================================================================
   6. Button system
   --------------------------------------------------------------------------
   Both .uk-btn (our patterns) and .wp-block-button__link (core) inherit.
   ========================================================================== */
.uk-btn,
.wp-block-button__link {
	display: inline-flex; align-items: center; gap: 10px;
	font: inherit; font-weight: 500;
	padding: 13px 22px;
	border-radius: 2px;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
	text-decoration: none;
}
.uk-btn--primary, .wp-block-button__link {
	background: var(--ink); color: var(--white);
}
.uk-btn--primary:hover, .wp-block-button__link:hover {
	background: var(--ink-2); color: var(--white);
}
.uk-btn--green   { background: var(--green); color: var(--white); }
.uk-btn--green:hover { background: var(--green-dk); color: var(--white); }
.uk-btn--outline { background: transparent; color: var(--ink); border-color: var(--ink); }
.uk-btn--outline:hover { background: var(--ink); color: var(--white); }
.uk-btn--light   { background: transparent; color: var(--white); border-color: rgba(255, 255, 255, .4); }
.uk-btn--light:hover { background: var(--white); color: var(--ink); }
.uk-btn .uk-arrow::after,
.uk-arrow::after { content: " →"; }

/* ==========================================================================
   7. Header
   ========================================================================== */
.uk-header,
header.wp-block-group.uk-header {
	position: fixed; top: 0; left: 0; right: 0; z-index: 50;
	/* Liquid glass: translucent base + heavy blur + saturation boost.
	   Top-to-bottom gradient mimics a curved glass highlight; the
	   inset top/bottom box-shadows are the specular edge + lower
	   reflection that sells the "glass" depth. */
	background:
		linear-gradient(180deg,
			rgba(255, 255, 255, 0.55) 0%,
			rgba(255, 255, 255, 0.30) 100%);
	backdrop-filter: saturate(180%) blur(22px);
	-webkit-backdrop-filter: saturate(180%) blur(22px);
	border-bottom: 1px solid rgba(255, 255, 255, 0.55);
	box-shadow:
		inset 0  1px 0 rgba(255, 255, 255, 0.85),
		inset 0 -1px 0 rgba(255, 255, 255, 0.25),
		0 10px 30px -16px rgba(11, 30, 63, 0.18);
}
@supports not (backdrop-filter: blur(10px)) {
	.uk-header { background: rgba(255, 255, 255, 0.92); }
}
/* Reserve space so page content isn't hidden behind the fixed header. */
body { padding-top: 120px; }
.uk-header__inner {
	max-width: var(--max);
	margin-inline: auto;
	padding: 18px var(--pad);
	display: flex; align-items: center; gap: 28px;
}
.uk-header__logo { display: inline-flex; flex-direction: column; align-items: stretch; gap: 4px; line-height: 1; }
.uk-header__logo img { height: 84px !important; width: auto !important; max-width: none; min-width: 0; display: block; aspect-ratio: auto; }
.uk-header__logo svg { height: 84px !important; width: auto !important; max-width: none; min-width: 0; display: block; aspect-ratio: 811.7 / 410; }
.uk-header__mark {
	font-family: var(--font-sans);
	font-weight: 700; font-size: 12.5px;
	color: var(--ink);
	display: block;
	width: 100%;
	text-align: justify;
	text-align-last: justify;
	-moz-text-align-last: justify;
}
.uk-header__nav {
	display: flex; gap: 22px;
	margin-left: 12px;
}
.uk-header__nav > a,
.uk-header__nav-item { position: relative; }
.uk-header__nav a,
.uk-header__nav-toggle {
	font-weight: 500;
	font-size: 15px;
	font-family: inherit;
	color: var(--ink);
	padding-block: 6px;
	position: relative;
	background: transparent;
	border: 0;
	cursor: pointer;
	white-space: nowrap;
}
.uk-header__nav a:hover,
.uk-header__nav-toggle:hover { color: var(--green-dk); }
.uk-header__nav .has-caret::after { content: " ⌄"; color: var(--quiet); font-size: 12px; margin-left: 2px; }
.uk-header__nav a.current,
.uk-header__nav-toggle.current { color: var(--green-dk); }
.uk-header__nav a.current::before,
.uk-header__nav-toggle.current::before { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 2px; background: var(--green); }

/* Dropdown submenu — animatable, with hover-intent bridge */
.uk-header__nav-item { display: inline-flex; }
.uk-header__submenu {
	position: absolute; top: 100%; left: 0;
	min-width: 240px;
	background: rgba(255, 255, 255, 0.78);
	backdrop-filter: saturate(180%) blur(20px);
	-webkit-backdrop-filter: saturate(180%) blur(20px);
	border: 1px solid rgba(255, 255, 255, 0.6);
	border-radius: 10px;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.9),
		0 18px 40px -18px rgba(11, 30, 63, 0.28),
		0 2px 6px -2px rgba(11, 30, 63, 0.12);
	padding: 8px 0;
	margin-top: 6px;
	z-index: 60;
	/* Animatable hide state — keep in flow so transitions can run */
	opacity: 0;
	visibility: hidden;
	transform: translateY(-4px) scale(0.985);
	transform-origin: top left;
	transition:
		opacity 130ms ease-out,
		transform 130ms ease-out,
		visibility 0s linear 130ms;
	will-change: opacity, transform;
}
/* Invisible bridge between trigger and panel so the cursor can travel
   through the small gap (margin-top: 6px) without triggering close. */
.uk-header__submenu::before {
	content: "";
	position: absolute;
	left: 0; right: 0;
	top: -10px;
	height: 10px;
}
.uk-header__submenu a {
	display: block;
	padding: 9px 16px;
	font-size: 14px;
	color: var(--ink);
	white-space: nowrap;
	border-radius: 6px;
	margin: 0 6px;
	transition: background-color 100ms ease, color 100ms ease;
}
.uk-header__submenu a:hover { background: rgba(11, 30, 63, 0.06); color: var(--green-dk); }
.uk-header__nav-item:hover > .uk-header__submenu,
.uk-header__nav-item:focus-within > .uk-header__submenu,
.uk-header__nav-item .uk-header__nav-toggle[aria-expanded="true"] + .uk-header__submenu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
	transition:
		opacity 130ms ease-out,
		transform 130ms ease-out,
		visibility 0s;
}
.uk-header__right {
	margin-left: auto;
	display: flex; align-items: center; gap: 10px;
}
.uk-header__cta {
	padding: 10px 18px;
	background: var(--ink); color: var(--white);
	border-radius: 2px;
	font-weight: 500; font-size: 15px;
	white-space: nowrap;
}
.uk-header__cta:hover { background: var(--ink-2); color: var(--white); }

/* Mobile nav toggle */
.uk-header__menu-btn {
	display: none;
	width: 40px; height: 40px;
	border: 1px solid var(--hairline);
	border-radius: 2px;
	background: var(--white); color: var(--ink);
	cursor: pointer;
	align-items: center; justify-content: center;
}
.uk-header__menu-btn:hover { border-color: var(--ink); }

@media (max-width: 960px) {
	.uk-header__nav {
		display: none;
		position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column; gap: 0;
		background: var(--white);
		padding: 12px var(--pad);
		border-bottom: 1px solid var(--hairline);
		box-shadow: 0 12px 30px -20px rgba(11, 30, 63, .25);
	}
	.uk-header[data-open="true"] .uk-header__nav { display: flex; }
	.uk-header__nav > a,
	.uk-header__nav-item,
	.uk-header__nav-toggle { padding-block: 12px; border-bottom: 1px solid var(--hairline); width: 100%; text-align: left; }
	.uk-header__nav > a:last-child,
	.uk-header__nav-item:last-child { border-bottom: 0; }
	.uk-header__nav-item { display: block; }
	.uk-header__submenu { position: static; box-shadow: none; border: 0; padding: 0 0 8px 16px; }
	.uk-header__nav-item:hover > .uk-header__submenu { display: block; }
	.uk-header__menu-btn { display: inline-flex; }
}

/* ==========================================================================
   8. Footer
   ========================================================================== */
.uk-footer {
	background: var(--ink);
	color: var(--white);
	padding-block: var(--wp--preset--spacing--60) var(--wp--preset--spacing--40);
}
.uk-footer__inner {
	max-width: var(--max);
	margin-inline: auto;
	padding-inline: var(--pad);
}
.uk-footer__cols {
	display: grid;
	grid-template-columns: 1.4fr repeat(3, 1fr);
	gap: 48px;
	padding-bottom: 48px;
	border-bottom: 1px solid rgba(255, 255, 255, .12);
}
.uk-footer__logo { display: inline-flex; flex-direction: column; align-items: flex-start; gap: 3px; line-height: 1; margin-bottom: 14px; text-decoration: none; }
.uk-footer__logo img,
.uk-footer__logo svg { height: 56px !important; width: auto !important; max-width: none; aspect-ratio: 811.7 / 410; display: block; }
.uk-footer__logo img { filter: brightness(0) invert(1); }
.uk-footer__mark {
	font-family: var(--font-sans);
	font-weight: 700;
	font-size: 10.5px;
	letter-spacing: 0.42em;
	color: var(--white);
	padding-left: 2px;
}
.uk-footer__brand p { color: rgba(255, 255, 255, .7); font-size: 14px; max-width: 32ch; margin-top: 14px; }
.uk-footer__col h4 {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgba(255, 255, 255, .85);
	margin-bottom: 16px;
}
.uk-footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.uk-footer__col a {
	color: rgba(255, 255, 255, .72);
	font-size: 14px;
}
.uk-footer__col a:hover { color: var(--white); }

.uk-footer__bottom {
	display: flex; justify-content: space-between; align-items: center;
	padding-top: 24px;
	gap: 24px; flex-wrap: wrap;
}
.uk-footer__legal { color: rgba(255, 255, 255, .55); font-size: 13px; }
.uk-footer__social { display: flex; gap: 14px; }
.uk-footer__social a {
	color: rgba(255, 255, 255, .65);
	font-size: 13px;
}
.uk-footer__social a:hover { color: var(--white); }

@media (max-width: 860px) {
	.uk-footer__cols { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 540px) {
	.uk-footer__cols { grid-template-columns: 1fr; }
}

/* ==========================================================================
   9. Chat widget (stub — kept structurally isolated for later swap)
   ========================================================================== */
.uk-chat {
	position: fixed;
	right: clamp(16px, 2vw, 28px);
	bottom: clamp(16px, 2vw, 28px);
	z-index: 60;
}
.uk-chat__btn {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 12px 18px;
	background: var(--ink); color: var(--white);
	border: 0; border-radius: 999px;
	font: inherit; font-weight: 500; font-size: 14px;
	cursor: pointer;
	box-shadow: 0 12px 30px -10px rgba(11, 30, 63, .45);
	transition: background var(--t-fast), transform var(--t-fast);
}
.uk-chat__btn:hover { background: var(--ink-2); transform: translateY(-1px); }
.uk-chat__dot {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--green);
	box-shadow: 0 0 0 0 rgba(118, 188, 33, .6);
	animation: uk-chat-pulse 2s infinite;
}
@keyframes uk-chat-pulse {
	0%   { box-shadow: 0 0 0 0   rgba(118, 188, 33, .6); }
	70%  { box-shadow: 0 0 0 8px rgba(118, 188, 33, 0); }
	100% { box-shadow: 0 0 0 0   rgba(118, 188, 33, 0); }
}
.uk-chat__panel {
	position: absolute;
	right: 0; bottom: calc(100% + 14px);
	width: min(360px, calc(100vw - 32px));
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 8px;
	box-shadow: 0 24px 60px -20px rgba(11, 30, 63, .35);
	padding: 18px;
	display: none;
}
.uk-chat[data-open="true"] .uk-chat__panel { display: block; }
.uk-chat__panel h4 { font-size: 15px; margin: 0 0 6px; }
.uk-chat__panel p  { font-size: 13.5px; color: var(--muted); margin: 0; }

/* ==========================================================================
   10. Core block adjustments
   ========================================================================== */
.wp-block-group.is-style-uk-section { padding-block: var(--section); }
.wp-block-separator { border-color: var(--hairline); opacity: 1; }
.wp-block-button { margin-bottom: 0; }
.wp-block-image figcaption { color: var(--muted); font-size: 13px; }

/* Surface / contrast helpers exposed as group block presets */
.wp-block-group.has-surface-background-color { background: var(--surface); }
.wp-block-group.has-ink-background-color     { color: var(--white); }
.wp-block-group.has-ink-background-color a   { color: var(--white); }

/* ==========================================================================
   11. Detail-page sections (CPT singles)
   --------------------------------------------------------------------------
   Conventions:
     .uk-{section} > .uk-container               for layout
     .uk-section__head { .uk-kicker, h2.uk-display, .uk-rule }
     dark sections: background var(--ink), color var(--white)
   ========================================================================== */

/* Breadcrumb above hero */
.uk-crumb {
	background: var(--surface);
	border-bottom: 1px solid var(--hairline);
	padding: 14px 0;
	font-size: 13px;
	color: var(--quiet);
}
.uk-crumb a { color: var(--ink); }
.uk-crumb a:hover { color: var(--green-dk); }
.uk-crumb__sep { margin: 0 8px; color: var(--quiet); }
.uk-crumb__parent { color: var(--quiet); }
.uk-crumb__here { color: var(--ink); }

/* Section head primitive */
.uk-section__head { margin-bottom: 48px; max-width: 720px; }
.uk-section__head .uk-kicker { color: var(--quiet); margin-bottom: 14px; }
.uk-section__h2 {
	font-size: clamp(28px, 3.4vw, 44px);
	letter-spacing: -0.024em;
	line-height: 1.1;
	color: inherit;
}

/* Prose blocks (Carbon rich_text output) */
.uk-prose { max-width: 64ch; line-height: 1.7; }
.uk-prose p { margin-bottom: 1em; color: inherit; }
.uk-prose p:last-child { margin-bottom: 0; }
.uk-prose a { color: var(--green-dk); text-decoration: underline; text-underline-offset: 3px; }
.uk-prose strong { font-weight: 600; }
.uk-prose ul, .uk-prose ol { margin: 0 0 1em 1.25em; }
.uk-prose li { margin-bottom: 0.4em; }

/* ----- Hero (single-CPT light hero) ----- */
.uk-hero-s {
	background: var(--white);
	color: var(--ink);
	padding-block: clamp(72px, 8vw, 120px);
	overflow: hidden;
}
.uk-hero-s__grid {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: 64px;
	align-items: center;
}
.uk-hero-s__copy .uk-kicker { color: var(--quiet); margin-bottom: 22px; }
.uk-hero-s__h1 {
	font-size: clamp(36px, 4.4vw, 60px);
	max-width: 16ch;
	color: var(--ink);
	margin-bottom: 24px;
}
.uk-hero-s__h1 em { color: var(--green); font-weight: 600; }
.uk-hero-s__lede {
	color: var(--muted);
	max-width: 50ch;
	margin-bottom: 32px;
}
.uk-hero-s__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.uk-hero-s__visual {
	aspect-ratio: 4/5;
	border-radius: 2px;
	overflow: hidden;
	background: var(--surface);
	box-shadow: 0 30px 80px -40px rgba(11,30,63,.18);
	position: relative;
}
.uk-hero-s__visual img { width: 100%; height: 100%; object-fit: cover; }

/* Hero stats meta */
.uk-hero-s__meta {
	margin-top: 36px;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 20px 32px;
	max-width: 540px;
}
.uk-hero-s__stat { display: flex; flex-direction: column; gap: 4px; }
.uk-hero-s__stat-n {
	font-family: var(--font-display, var(--font-sans));
	font-size: 28px;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--ink);
	line-height: 1.1;
	white-space: nowrap;
}
.uk-hero-s__stat-n em { color: var(--green); font-style: normal; font-weight: 600; }
.uk-hero-s__stat-l {
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--quiet);
	font-weight: 600;
}

/* Quick-jump bar */
.uk-jump {
	background: var(--white);
	border-bottom: 1px solid var(--hairline);
	padding: 14px 0;
	font-size: 13px;
}
.uk-jump .uk-container {
	display: flex;
	flex-wrap: wrap;
	gap: 22px;
	align-items: center;
}
.uk-jump__lab {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--quiet);
	font-weight: 600;
	margin-right: 6px;
}
.uk-jump a { color: var(--ink); }
.uk-jump a:hover { color: var(--green-dk); }

/* Leaf (folio) hero visual — industries default */
.uk-leaf {
	position: absolute; inset: 0;
	background: #fbf8f0;
	border: 1px solid var(--hairline);
	border-radius: 2px;
	overflow: hidden;
	font-family: 'Georgia', serif;
	color: #3a2f1d;
}
.uk-leaf__tag {
	position: absolute; top: 16px; left: 20px; right: 20px;
	display: flex; justify-content: space-between;
	font-family: var(--font-sans);
	font-size: 10.5px; letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--quiet);
	font-weight: 600;
}
.uk-leaf__tag .live { color: var(--green-dk); display: inline-flex; align-items: center; gap: 8px; }
.uk-leaf__tag .live::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 10px var(--green); }
.uk-leaf__ms {
	position: absolute; top: 60px; left: 28px; right: 28px;
	font-size: 15.5px; line-height: 2.1;
	color: #2c2310;
}
.uk-leaf__ms .line { display: block; }
.uk-leaf__ms em { font-style: italic; color: #4a3611; font-weight: 600; }
.uk-leaf__ms .strike { text-decoration: line-through; color: #8a7858; }
.uk-leaf__ms .red { color: #aa2b1d; font-weight: 600; }
.uk-leaf__scan {
	position: absolute; left: 0; right: 0; bottom: 124px; height: 2px;
	background: linear-gradient(90deg, transparent, var(--green) 50%, transparent);
	opacity: .35;
}
.uk-leaf__ocr {
	position: absolute; left: 20px; right: 20px; bottom: 18px;
	background: rgba(11, 30, 63, .94);
	color: #d8e6f5;
	padding: 14px 18px;
	border-radius: 2px;
	font-family: 'JetBrains Mono', 'Menlo', monospace;
	font-size: 11.5px; line-height: 1.7;
}
.uk-leaf__ocr .k { color: #76BC21; }
.uk-leaf__ocr .v { color: #ffd479; }
.uk-leaf__ocr .ok { color: #76BC21; }
.uk-leaf__ocr .c { color: #6f86a3; }

@media (max-width: 880px) {
	.uk-hero-s__grid { grid-template-columns: 1fr; gap: 40px; }
	.uk-hero-s__visual { aspect-ratio: 16/10; }
	.uk-hero-s__meta { grid-template-columns: repeat(2, 1fr); }
}

/* ----- Overview ----- */
.uk-overview { padding-block: var(--section); }
.uk-overview__grid {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: 80px;
	align-items: start;
}
.uk-overview__head .uk-section__h2 {
	font-size: clamp(34px, 3.8vw, 52px);
	max-width: 14ch;
	margin-top: 14px;
}
.uk-overview__body p {
	font-size: clamp(18px, 1.5vw, 22px);
	line-height: 1.55;
	color: var(--ink);
	font-weight: 500;
	max-width: 54ch;
	letter-spacing: -0.005em;
}
.uk-overview__body p + p {
	margin-top: 22px;
	font-size: 16px;
	color: var(--muted);
	font-weight: 400;
	max-width: 60ch;
	line-height: 1.7;
}
.uk-overview__credo {
	margin-top: 32px;
	padding-top: 22px;
	border-top: 1px solid var(--hairline);
	font-style: italic;
	font-weight: 500;
	font-size: 19px;
	color: var(--ink);
	max-width: 50ch;
}
.uk-overview__credo em { color: var(--green-dk); font-weight: 600; font-style: italic; }
.uk-overview__clients {
	margin-top: 36px;
	padding-top: 24px;
	border-top: 1px solid var(--hairline);
}
.uk-overview__clients-lab {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--muted);
	font-weight: 700;
	margin-bottom: 14px;
}
.uk-overview__clients-names {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 17px;
	line-height: 1.7;
	color: var(--ink);
}
.uk-overview__clients-div { color: var(--green-dk); margin-inline: 10px; }
@media (max-width: 900px) {
	.uk-overview__grid { grid-template-columns: 1fr; gap: 32px; }
}
.uk-overview__highlights {
	margin-top: 32px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 18px;
	list-style: none;
	padding: 0;
}
.uk-overview__highlights li {
	padding: 18px 22px;
	background: var(--surface);
	border-left: 2px solid var(--green);
	font-weight: 500;
	font-size: 15px;
}

/* ----- Problems (dark) ----- */
.uk-problems { background: var(--ink); color: var(--white); padding-block: var(--section); }
.uk-problems .uk-section__h2 { color: var(--white); }
.uk-problems__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
	list-style: none;
	padding: 0;
}
.uk-problems__item {
	padding: 28px;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 2px;
	font-size: 17px;
	line-height: 1.5;
	color: rgba(255,255,255,.9);
}

/* ----- Capabilities ----- */
.uk-cap { padding-block: var(--section); }
.uk-cap__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
}
.uk-cap__card {
	padding: 28px;
	border: 1px solid var(--hairline);
	border-radius: 2px;
	background: var(--white);
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-cap__card:hover { border-color: var(--ink); transform: translateY(-2px); }
.uk-cap__num {
	display: inline-block;
	font-size: 11px; letter-spacing: .12em;
	font-weight: 700;
	color: var(--green-dk);
	margin-bottom: 12px;
}
.uk-cap__h { font-size: 18px; font-weight: 600; margin-bottom: 8px; }
.uk-cap__body { color: var(--muted); font-size: 14.5px; line-height: 1.55; }
.uk-cap__icon { width: 48px; height: 48px; margin-bottom: 16px; }
.uk-cap__icon img { width: 100%; height: 100%; object-fit: contain; }

/* ----- Tech stack (surface) ----- */
.uk-stack {
	background: var(--surface);
	border-top: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
	padding-block: var(--section);
}
.uk-stack__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 36px;
}
.uk-stack__cat {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .18em;
	color: var(--green-dk);
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--hairline);
}
.uk-stack__tools { list-style: none; padding: 0; display: grid; gap: 8px; }
.uk-stack__tools li {
	font-size: 14.5px;
	color: var(--ink);
	font-weight: 500;
}

/* ----- Outcomes / KPI strip ----- */
.uk-outcomes { padding-block: var(--section); }
.uk-outcomes__grid,
.uk-cs-kpis .uk-outcomes__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 24px;
}
.uk-outcomes__item {
	padding: 24px;
	border-top: 2px solid var(--ink);
	background: var(--white);
}
.uk-outcomes__metric {
	display: block;
	font-size: clamp(28px, 3.6vw, 44px);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--ink);
	line-height: 1;
	margin-bottom: 8px;
}
.uk-outcomes__label { color: var(--muted); font-size: 13.5px; line-height: 1.45; margin: 0; }

.uk-cs-kpis { padding-block: var(--wp--preset--spacing--50); background: var(--surface); border-bottom: 1px solid var(--hairline); }
.uk-cs-kpis .uk-outcomes__item { background: transparent; border-top-color: var(--green); }

/* ----- Company X — Lead CTA (talk to leadership + form) ----- */
.uk-lead-cta { background: var(--surface); padding-block: clamp(56px, 7vw, 96px); }
.uk-lead-cta__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.uk-lead-cta__copy h2.uk-display { font-size: clamp(36px, 4.4vw, 60px); max-width: 14ch; color: var(--ink); }
.uk-lead-cta__intro { font-family: 'Poppins', sans-serif; font-weight: 600; font-size: clamp(18px, 1.6vw, 22px); line-height: 1.5; color: var(--ink); margin: 22px 0 0; max-width: 42ch; letter-spacing: -0.005em; }
.uk-lead-cta__toggle { display: inline-flex; gap: 0; margin-top: 32px; padding: 4px; background: var(--white); border: 1px solid var(--hairline); border-radius: 2px; }
.uk-lead-cta__toggle button { padding: 10px 18px; border: 0; background: transparent; font-size: 13px; font-weight: 600; cursor: pointer; color: var(--muted); letter-spacing: .04em; }
.uk-lead-cta__toggle button.is-on { background: var(--ink); color: var(--white); }
.uk-lead-cta__meta { margin-top: 36px; padding-top: 24px; border-top: 1px solid var(--hairline); display: flex; gap: 32px; flex-wrap: wrap; font-size: 13px; color: var(--muted); }
.uk-lead-cta__meta strong { color: var(--ink); display: block; font-size: 11px; letter-spacing: .22em; margin-bottom: 4px; text-transform: uppercase; }
.uk-lead-cta__form { display: flex; flex-direction: column; gap: 16px; }
.uk-lead-cta__form label { font-size: 11px; letter-spacing: .18em; color: var(--muted); text-transform: uppercase; font-weight: 600; margin-bottom: 4px; display: block; }
.uk-lead-cta__form input, .uk-lead-cta__form select, .uk-lead-cta__form textarea { width: 100%; padding: 14px 0; border: 0; border-bottom: 1px solid var(--ink); background: transparent; color: var(--ink); font: inherit; font-size: 16px; border-radius: 0; }
.uk-lead-cta__form input:focus, .uk-lead-cta__form select:focus, .uk-lead-cta__form textarea:focus { outline: none; border-bottom-color: var(--green-dk); }
.uk-lead-cta__row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.uk-lead-cta__form button[type=submit] { margin-top: 12px; background: var(--ink); color: var(--white); border: 0; padding: 15px 24px; font-weight: 500; font-size: 15px; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; align-self: flex-start; }
.uk-lead-cta__form button[type=submit]:hover { background: var(--green-dk); }
@media (max-width: 900px) { .uk-lead-cta__grid { grid-template-columns: 1fr; gap: 32px; } }

/* ----- CTA band (legacy / other pages) ----- */
.uk-cta-band {
	background: var(--surface);
	color: var(--ink);
	padding-block: clamp(48px, 6vw, 80px);
}
.uk-cta-band__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 32px; flex-wrap: wrap;
}
.uk-cta-band__h {
	font-size: clamp(24px, 2.6vw, 36px);
	color: var(--ink);
	max-width: 22ch;
	margin-bottom: 6px;
}
.uk-cta-band__h em { color: var(--green); font-weight: 600; }
.uk-cta-band__body { color: var(--muted); max-width: 48ch; }

.uk-cta-band--mid {
	background: var(--ink);
	color: var(--white);
	padding-block: clamp(48px, 6vw, 72px);
	position: relative;
	overflow: hidden;
}
.uk-cta-band--mid::before {
	content: "";
	position: absolute; inset: 0;
	background: radial-gradient(600px 300px at 90% 50%, rgba(118,188,33,.18), transparent 60%);
}
.uk-cta-band--mid .uk-cta-band__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1.5fr auto;
	gap: 48px;
	align-items: center;
	flex-wrap: nowrap;
}
.uk-cta-band--mid .uk-cta-band__h {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: clamp(22px, 2.2vw, 30px);
	line-height: 1.3;
	letter-spacing: -0.01em;
	color: var(--white);
	max-width: 48ch;
	margin: 0;
}
.uk-cta-band--mid .uk-cta-band__h em {
	color: var(--green);
	font-style: italic;
	font-weight: 500;
}
.uk-cta-band--mid .uk-cta-band__sub { color: var(--green); }
@media (max-width: 768px) {
	.uk-cta-band--mid .uk-cta-band__inner { grid-template-columns: 1fr; gap: 24px; }
}

/* ----- AI strip ----- */
.uk-aistrip { border-bottom: 1px solid var(--hairline); padding-block: var(--section); }
.uk-aistrip__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 32px;
}
.uk-aistrip__lens { padding-top: 18px; border-top: 1px solid var(--ink); }
.uk-aistrip__h { font-size: 18px; font-weight: 600; margin-bottom: 10px; }
.uk-aistrip__lens p { color: var(--muted); line-height: 1.6; font-size: 14.5px; }

/* ----- Industry mapping (surface) ----- */
.uk-indmap, .uk-actmap {
	background: var(--surface);
	border-top: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
	padding-block: var(--section);
}
.uk-indmap__grid, .uk-suite__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
	margin-top: 32px;
}
.uk-actmap__grid {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 80px;
	align-items: start;
}
.uk-actmap__head .uk-section__h2 {
	font-size: clamp(34px, 4vw, 52px);
	max-width: 14ch;
	margin-top: 14px;
}
.uk-actmap__head .uk-section__h2 em { color: var(--green-dk); }
.uk-actmap__lede {
	margin-top: 18px;
	font-size: 17px;
	color: var(--ink);
	font-weight: 500;
	line-height: 1.55;
	max-width: 38ch;
	letter-spacing: -0.005em;
}
.uk-actmap__lede em { color: var(--green-dk); font-style: italic; }
.uk-actmap__cta { margin-top: 24px; }

/* Module card (right column of actmap) */
.uk-pmod {
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 2px;
	padding: 36px;
}
.uk-pmod__head {
	display: flex; align-items: center; gap: 18px;
	padding-bottom: 22px;
	border-bottom: 1px solid var(--hairline);
	margin-bottom: 26px;
}
.uk-pmod__icon {
	width: 56px; height: 56px;
	background: var(--ink);
	color: var(--green);
	border-radius: 2px;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-sans);
	font-weight: 700; font-size: 22px;
	letter-spacing: -0.02em;
}
.uk-pmod__sub {
	font-size: 11.5px; letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--green-dk); font-weight: 600;
	margin-top: 4px; display: block;
}
.uk-pmod__h {
	font-family: var(--font-sans);
	font-weight: 600; font-size: 26px;
	letter-spacing: -0.01em;
}
.uk-pmod__desc {
	font-size: 15.5px; color: var(--muted);
	line-height: 1.65; max-width: 56ch;
	margin-bottom: 24px;
}
.uk-pmod__features { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.uk-pmod__feature {
	padding: 18px;
	background: var(--surface);
	border-radius: 2px;
	border-left: 2px solid var(--green);
}
.uk-pmod__ft {
	font-family: var(--font-sans);
	font-weight: 600; font-size: 14.5px;
	color: var(--ink);
	margin-bottom: 4px;
	letter-spacing: -0.005em;
}
.uk-pmod__fd { font-size: 13px; color: var(--muted); line-height: 1.5; }
.uk-pmod__ctas {
	margin-top: 28px;
	padding-top: 22px;
	border-top: 1px solid var(--hairline);
	display: flex; gap: 12px; flex-wrap: wrap;
}
@media (max-width: 900px) {
	.uk-actmap__grid { grid-template-columns: 1fr; gap: 32px; }
	.uk-pmod__features { grid-template-columns: 1fr; }
}
.uk-indmap__card, .uk-suite__card {
	display: block;
	padding: 28px;
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 2px;
	color: var(--ink);
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-indmap__card:hover, .uk-suite__card:hover {
	border-color: var(--ink); transform: translateY(-2px); color: var(--ink);
}
.uk-indmap__h, .uk-suite__h { font-size: 18px; font-weight: 600; margin-bottom: 8px; }
.uk-indmap__body, .uk-suite__body { color: var(--muted); font-size: 14.5px; line-height: 1.55; margin-bottom: 14px; }
.uk-indmap__more, .uk-suite__more {
	font-size: 13px; font-weight: 600; color: var(--green-dk);
	letter-spacing: .04em;
}
.uk-suite__card--custom { background: var(--ink); color: var(--white); border-color: var(--ink); }
.uk-suite__card--custom .uk-suite__body { color: rgba(255,255,255,.7); }

/* ----- Why us ----- */
.uk-whyus { padding-block: var(--section); }
.uk-whyus__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
}
.uk-whyus__item { padding-top: 18px; border-top: 1px solid var(--ink); }
.uk-whyus__h { font-size: 18px; font-weight: 600; margin-bottom: 10px; }
.uk-whyus__item p { color: var(--muted); line-height: 1.6; font-size: 14.5px; }

/* ----- Industry: challenges / solutions / use-cases (shared shape) ----- */
.uk-chal, .uk-sol, .uk-uc { padding-block: var(--section); }
.uk-chal { background: var(--ink); color: var(--white); }
.uk-chal .uk-section__h2 { color: var(--white); font-size: clamp(36px, 4.4vw, 60px); max-width: 16ch; }
.uk-chal .uk-section__h2 em { color: var(--green); }
.uk-chal .uk-kicker { color: var(--white); }
.uk-chal .uk-rule { background: rgba(255,255,255,.4); }
.uk-chal .uk-section__masthead p,
.uk-chal .uk-section__lede { color: rgba(255,255,255,.7); }
.uk-chal__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid rgba(255,255,255,.18);
}
.uk-chal__card {
	padding: 36px 28px 36px 0;
	border-right: 1px solid rgba(255,255,255,.12);
	border-bottom: 1px solid rgba(255,255,255,.12);
}
.uk-chal__card + .uk-chal__card { padding-left: 28px; }
.uk-chal__card:nth-child(3n) { border-right: 0; }
.uk-chal__card:nth-child(3n+1) { padding-left: 0; }
.uk-chal__lab {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--green);
	font-weight: 700;
}
.uk-chal__h {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 21px;
	color: var(--white);
	margin: 14px 0 12px;
	letter-spacing: -0.005em;
	max-width: 18ch;
}
.uk-chal__card p {
	color: rgba(255,255,255,.72);
	font-size: 14.5px;
	line-height: 1.65;
	max-width: 34ch;
}
.uk-chal__meta {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid rgba(255,255,255,.12);
	font-size: 11.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255,255,255,.55);
	font-weight: 600;
}
@media (max-width: 900px) {
	.uk-chal__grid { grid-template-columns: 1fr; }
	.uk-chal__card { border-right: 0 !important; padding: 28px 0 !important; }
}

.uk-sol { background: var(--surface); }
.uk-sol__row {
	display: grid;
	grid-template-columns: 140px 1fr 1fr;
	gap: 48px;
	padding: 36px 0;
	border-top: 1px solid var(--hairline);
	align-items: start;
}
.uk-sol__row:last-of-type { border-bottom: 1px solid var(--hairline); }
.uk-sol__n {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 38px;
	line-height: 1;
	color: var(--green-dk);
	letter-spacing: -0.02em;
	display: block;
}
.uk-sol__lab {
	display: block;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--green-dk);
	font-weight: 700;
	margin-top: 14px;
}
.uk-sol__h {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: clamp(22px, 2.1vw, 28px);
	letter-spacing: -0.008em;
	line-height: 1.2;
	margin-bottom: 12px;
	max-width: 18ch;
}
.uk-sol__desc { color: var(--muted); font-size: 15px; line-height: 1.65; max-width: 46ch; }
.uk-sol__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.uk-sol__tag {
	font-size: 10.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--quiet);
	font-weight: 600;
	padding: 4px 8px;
	border: 1px solid var(--hairline);
	border-radius: 2px;
	background: var(--white);
}
.uk-sol__bullets { list-style: none; display: grid; gap: 10px; padding: 0; margin: 0; }
.uk-sol__bullets li {
	display: flex;
	gap: 8px;
	font-size: 14.5px;
	color: var(--ink);
	align-items: flex-start;
	line-height: 1.55;
}
.uk-sol__bullets li::before { content: "→"; color: var(--green-dk); font-weight: 700; flex: 0 0 16px; }
.uk-sol__bullets li strong { font-weight: 600; }
@media (max-width: 900px) {
	.uk-sol__row { grid-template-columns: 1fr; gap: 16px; padding: 28px 0; }
}

.uk-uc__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	border-top: 1px solid var(--ink);
}
.uk-uc__card {
	display: grid;
	grid-template-columns: 1fr;
	gap: 14px;
	padding: 32px 32px 32px 0;
	border-bottom: 1px solid var(--hairline);
	background: transparent;
	border-left: 0; border-top: 0; border-right: 0;
}
.uk-uc__card:nth-child(odd) { border-right: 1px solid var(--hairline); padding-right: 32px; }
.uk-uc__card:nth-child(even) { padding-left: 32px; }
.uk-uc__head { display: flex; align-items: baseline; gap: 14px; }
.uk-uc__num {
	font-family: var(--font-sans);
	font-weight: 500; font-size: 22px;
	color: var(--green-dk);
	line-height: 1; letter-spacing: -0.01em;
}
.uk-uc__h {
	font-family: var(--font-sans);
	font-weight: 600; font-size: 21px;
	letter-spacing: -0.005em; line-height: 1.2;
	margin: 0;
}
.uk-uc__card p { font-size: 15px; color: var(--muted); line-height: 1.65; max-width: 46ch; }
.uk-uc__who {
	font-size: 11.5px; letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--green-dk); font-weight: 700;
}
.uk-uc__ex {
	margin-top: 6px; padding-top: 14px;
	border-top: 1px solid var(--hairline);
	display: grid; grid-template-columns: auto 1fr;
	gap: 6px 14px;
	font-size: 13px; color: var(--muted);
	align-items: baseline;
}
.uk-uc__ex strong {
	color: var(--ink); font-weight: 600;
	letter-spacing: 0.04em;
	font-size: 11px; text-transform: uppercase;
}
@media (max-width: 900px) {
	.uk-uc__grid { grid-template-columns: 1fr; }
	.uk-uc__card { border-right: 0 !important; padding: 28px 0 !important; }
}


/* ----- Industry: outcomes (3-col) + metrics tiles ----- */
.uk-out {
	padding-block: var(--section);
	background: var(--surface);
	border-top: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
}
.uk-out__cols {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid var(--ink);
}
.uk-out__col {
	padding: 36px 32px 36px 0;
	border-right: 1px solid var(--hairline);
	background: var(--white);
}
.uk-out__col + .uk-out__col { padding-left: 32px; }
.uk-out__col:last-child { border-right: 0; padding-right: 32px; }
.uk-out__lab {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--green-dk);
	font-weight: 700;
}
.uk-out__h {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 22px;
	margin: 14px 0 14px;
	letter-spacing: -0.005em;
	max-width: 18ch;
}
.uk-out__body { font-size: 14.5px; color: var(--muted); line-height: 1.65; max-width: 36ch; }
.uk-out__bullets {
	list-style: none;
	margin-top: 18px;
	padding: 14px 0 0;
	border-top: 1px solid var(--hairline);
	display: grid;
	gap: 10px;
}
.uk-out__bullets li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 10px;
	align-items: baseline;
	font-size: 13.5px;
	color: var(--ink);
}
.uk-out__bullets li::before { content: "●"; color: var(--green); font-size: 9px; }
@media (max-width: 900px) {
	.uk-out__cols { grid-template-columns: 1fr; }
	.uk-out__col {
		border-right: 0;
		padding: 28px 0 !important;
		border-bottom: 1px solid var(--hairline);
	}
	.uk-out__col:last-child { border-bottom: 0; }
}

.uk-metrics { padding-block: var(--section); }
.uk-metrics__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid var(--ink);
}
.uk-metrics__tile {
	padding: 36px 26px 36px 0;
	border-right: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
}
.uk-metrics__tile + .uk-metrics__tile { padding-left: 26px; }
.uk-metrics__tile:nth-child(3n) { border-right: 0; }
.uk-metrics__tile:nth-child(3n+1) { padding-left: 0; }
.uk-metrics__n {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: clamp(32px, 3.4vw, 44px);
	letter-spacing: -0.02em;
	color: var(--ink);
	line-height: 1;
}
.uk-metrics__n em { color: var(--green-dk); font-style: italic; }
.uk-metrics__l {
	font-size: 13px;
	color: var(--muted);
	letter-spacing: 0.02em;
	margin-top: 14px;
	line-height: 1.5;
}
.uk-metrics__src {
	margin-top: 10px;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--quiet);
	font-weight: 600;
}
.uk-metrics__footnote {
	margin-top: 24px;
	font-size: 12px;
	color: var(--quiet);
	font-style: italic;
	letter-spacing: 0.04em;
}
@media (max-width: 1024px) {
	.uk-metrics__grid { grid-template-columns: repeat(2, 1fr); }
	.uk-metrics__tile:nth-child(2n) { border-right: 0; padding-left: 26px; }
	.uk-metrics__tile:nth-child(2n+1) { padding-left: 0; }
	.uk-metrics__tile:nth-child(3n) { border-right: 1px solid var(--hairline); }
	.uk-metrics__tile:nth-child(3n+1) { padding-left: 26px; }
}
@media (max-width: 640px) {
	.uk-metrics__grid { grid-template-columns: 1fr; }
	.uk-metrics__tile { border-right: 0 !important; padding: 28px 0 !important; }
}

/* ----- Product extras: how-it / aiinside / integration ----- */
.uk-howit, .uk-aiinside, .uk-integ { padding-block: var(--section); }
.uk-aiinside { background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.uk-howit__grid {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 48px;
	align-items: center;
}
@media (max-width: 880px) { .uk-howit__grid { grid-template-columns: 1fr; gap: 32px; } }
.uk-integ__body { max-width: 64ch; color: var(--muted); margin-bottom: 24px; }
.uk-integ__points {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	list-style: none;
	padding: 0;
}
.uk-integ__points li {
	padding: 16px 20px;
	border-left: 2px solid var(--green);
	background: var(--surface);
	font-weight: 500;
	font-size: 14.5px;
}

/* ----- Related case studies ----- */
.uk-cases { padding-block: var(--section); background: var(--white); }
.uk-cases__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 28px;
}
.uk-case-card {
	display: flex;
	flex-direction: column;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	transition: border-color var(--t-fast), transform var(--t-fast);
	overflow: hidden;
}
.uk-case-card:hover { border-color: var(--ink); transform: translateY(-2px); color: var(--ink); }
.uk-case-card__media { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--surface); }
.uk-case-card__media img { width: 100%; height: 100%; object-fit: cover; }
.uk-case-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(circle at 70% 30%, rgba(255,255,255,.14), transparent 50%),
		repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
}
.uk-case-card__body { padding: 22px; display: flex; flex-direction: column; gap: 10px; }
.uk-case-card__client { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--quiet); font-weight: 700; }
.uk-case-card__h { font-size: 19px; font-weight: 600; line-height: 1.3; }
.uk-case-card__summary { color: var(--muted); font-size: 14.5px; line-height: 1.55; }
.uk-case-card__outcome {
	margin-top: auto;
	padding-top: 12px;
	border-top: 1px solid var(--hairline);
	font-size: 13px; font-weight: 600; color: var(--green-dk);
}

/* Industry rich case-study layout */
.uk-cases__art {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 56px;
	padding: 48px 0;
	border-top: 1px solid var(--hairline);
	align-items: center;
}
.uk-cases__art:last-of-type { border-bottom: 1px solid var(--hairline); }
.uk-cases__plate {
	aspect-ratio: 16/9;
	border-radius: 2px;
	position: relative;
	overflow: hidden;
	display: block;
	background: linear-gradient(135deg, var(--ink) 0%, #1a3060 100%);
}
.uk-cases__art--b .uk-cases__plate { background: linear-gradient(135deg, #3a2d18, #9a3119); }
.uk-cases__art--c .uk-cases__plate { background: linear-gradient(135deg, #0B4530, var(--green)); }
.uk-cases__art--d .uk-cases__plate { background: linear-gradient(135deg, #0B1E3F, var(--blue, #00A7E1)); }
.uk-cases__plate::after {
	content: "";
	position: absolute; inset: 0;
	z-index: 1;
	pointer-events: none;
	background:
		radial-gradient(circle at 25% 25%, rgba(255,255,255,.12), transparent 45%),
		repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
}
.uk-cases__num {
	position: absolute; top: 22px; left: 24px;
	z-index: 2;
	color: rgba(255,255,255,.85);
	font-size: 13px; letter-spacing: 0.2em;
}
.uk-cases__client-mark {
	position: absolute; bottom: 22px; left: 24px;
	z-index: 2;
	color: var(--white);
	font-weight: 600; font-size: 22px;
	line-height: 1.15; max-width: 20ch;
}
.uk-cases__byline {
	font-size: 12px;
	letter-spacing: 0.22em;
	color: var(--green-dk);
	text-transform: uppercase;
	font-weight: 600;
}
.uk-cases__h {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: clamp(24px, 2.4vw, 34px);
	line-height: 1.18;
	letter-spacing: -0.012em;
	margin: 14px 0 18px;
	max-width: 24ch;
}
.uk-cases__h a { color: inherit; }
.uk-cases__h a:hover { color: var(--green-dk); }
.uk-cases__copy p { font-size: 15.5px; color: var(--muted); line-height: 1.65; max-width: 56ch; }
.uk-cases__outcome {
	font-style: italic;
	font-weight: 500;
	font-size: 17px;
	color: var(--ink);
	margin-top: 22px;
	padding-top: 18px;
	border-top: 1px solid var(--hairline);
	max-width: 50ch;
}
.uk-cases__outcome em { color: var(--green-dk); }
.uk-cases__go {
	margin-top: 22px;
	display: inline-block;
	font-size: 13px;
	font-weight: 600;
	color: var(--ink);
}
.uk-cases__art:hover .uk-cases__go { color: var(--green-dk); }
.uk-cases__tail { display: flex; justify-content: center; margin-top: 48px; }
@media (max-width: 900px) {
	.uk-cases__art { grid-template-columns: 1fr; gap: 24px; padding: 36px 0; }
}

/* ----- Case study single ----- */
.uk-cs-hero { padding-block: clamp(56px, 6vw, 96px); border-bottom: 1px solid var(--hairline); }
.uk-cs-hero__grid {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: 64px;
	align-items: center;
}
@media (max-width: 880px) { .uk-cs-hero__grid { grid-template-columns: 1fr; gap: 32px; } }
.uk-cs-hero__h1 { font-size: clamp(32px, 4vw, 52px); margin: 22px 0 18px; }
.uk-cs-hero__outcome {
	display: inline-block;
	margin-top: 20px;
	padding: 10px 16px;
	background: var(--surface);
	border-left: 3px solid var(--green);
	font-weight: 600;
	font-size: 15px;
}
.uk-cs-hero__meta {
	margin-top: 24px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, max-content));
	gap: 28px;
}
.uk-cs-hero__meta dt {
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: var(--quiet); font-weight: 700; margin-bottom: 4px;
}
.uk-cs-hero__meta dd { font-weight: 500; font-size: 14.5px; margin: 0; }
.uk-cs-hero__visual { aspect-ratio: 16/9; overflow: hidden; background: var(--surface); }
.uk-cs-hero__visual img { width: 100%; height: 100%; object-fit: contain; }

.uk-cs-body { padding-block: var(--section); }
.uk-cs-body__block { margin-bottom: 56px; }
.uk-cs-body__block:last-child { margin-bottom: 0; }
.uk-cs-body__h {
	font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
	color: var(--green-dk); font-weight: 700;
	padding-bottom: 10px; border-bottom: 1px solid var(--ink);
	margin-bottom: 20px;
}

/* ==========================================================================
   12. Home page sections
   ========================================================================== */

/* Hero (light variant) */
.uk-hero {
	border-bottom: 1px solid var(--hairline);
	padding-block: clamp(48px, 6vw, 84px) clamp(40px, 5vw, 64px);
}
.uk-hero__grid {
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: 64px;
	align-items: center;
	min-height: 480px;
}
.uk-hero__copy .uk-kicker { color: var(--quiet); margin-bottom: 22px; }
.uk-hero__h1 {
	font-size: clamp(40px, 4.6vw, 64px);
	max-width: 15ch;
	margin-bottom: 24px;
}
.uk-hero__h1 em { font-style: italic; color: var(--green-dk); font-weight: 600; }
.uk-hero__lede { margin-bottom: 32px; }
.uk-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 40px; }
.uk-hero__stats {
	display: flex; gap: 36px; flex-wrap: wrap;
	padding-top: 24px; border-top: 1px solid var(--hairline);
	align-items: flex-end;
}
.uk-hero__stat { display: flex; flex-direction: column; gap: 4px; }
.uk-hero__stat-n {
	font-weight: 700; font-size: 28px;
	letter-spacing: -0.02em; color: var(--ink); line-height: 1;
}
.uk-hero__stat-l { font-size: 12px; color: var(--muted); letter-spacing: .03em; }
.uk-hero__certs { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; padding-top: 28px; }
.uk-hero__certs img { width: 64px; height: 64px; object-fit: contain; }
.uk-hero__visual {
	aspect-ratio: 4/5;
	border-radius: 2px;
	overflow: hidden;
	background: var(--ink);
	box-shadow: 0 30px 80px -40px rgba(11,30,63,.45);
}
.uk-hero__visual img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 880px) {
	.uk-hero__grid { grid-template-columns: 1fr; gap: 40px; }
	.uk-hero__visual { aspect-ratio: 16/10; }
}

/* Services brief / Industries loop / shared simple-card grid */
.uk-brief, .uk-industries { padding-block: var(--section); }
.uk-brief__grid, .uk-industries__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
}
.uk-brief__card, .uk-industries__card {
	display: block;
	padding: 28px;
	border: 1px solid var(--hairline);
	background: var(--white);
	color: var(--ink);
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-brief__card:hover, .uk-industries__card:hover {
	border-color: var(--ink); transform: translateY(-2px); color: var(--ink);
}
.uk-brief__h, .uk-industries__h { font-size: 19px; font-weight: 600; margin-bottom: 10px; }
.uk-brief__body, .uk-industries__body {
	color: var(--muted); font-size: 14.5px; line-height: 1.55; margin-bottom: 14px;
}
.uk-brief__more, .uk-industries__more {
	font-size: 13px; font-weight: 600; color: var(--green-dk); letter-spacing: .04em;
}
.uk-brief__footer { margin-top: 40px; }

/* Actigen strip — surface band */
.uk-actigen {
	background: var(--surface);
	border-top: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
	padding-block: var(--section);
}
.uk-actigen__lede { margin-bottom: 40px; }
.uk-actigen__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	margin-bottom: 40px;
}
.uk-actigen__card {
	display: block;
	padding: 24px;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-actigen__card:hover { border-color: var(--green); transform: translateY(-2px); color: var(--ink); }
.uk-actigen__h { font-size: 17px; font-weight: 600; margin-bottom: 8px; }
.uk-actigen__body { color: var(--muted); font-size: 14px; line-height: 1.5; }

/* How we engage — dark numbered phases */
.uk-engage { background: var(--ink); color: var(--white); padding-block: var(--section); }
.uk-engage .uk-section__h2 { color: var(--white); }
.uk-engage__phases {
	list-style: none; padding: 0; margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
}
.uk-engage__phase { padding-top: 18px; border-top: 1px solid rgba(255,255,255,.2); }
.uk-engage__num {
	display: inline-block;
	font-size: 11px; letter-spacing: .14em; font-weight: 700;
	color: var(--green); margin-bottom: 12px;
}
.uk-engage__h { font-size: 18px; font-weight: 600; color: var(--white); margin-bottom: 10px; }
.uk-engage__phase p { color: rgba(255,255,255,.78); font-size: 14.5px; line-height: 1.6; }

/* Testimonials roster — dark pull-quotes */
.uk-pull { background: var(--ink); color: var(--white); padding-block: clamp(80px, 10vw, 140px); }
.uk-pull .uk-section__h2 { color: var(--white); }
.uk-pull__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 32px;
}
.uk-pull__item { margin: 0; }
.uk-pull__item blockquote {
	font-size: clamp(18px, 1.5vw, 22px);
	line-height: 1.5;
	font-weight: 500;
	color: var(--white);
	margin: 0 0 18px;
	quotes: "“" "”";
}
.uk-pull__item blockquote::before { content: open-quote; color: var(--green); margin-right: 4px; }
.uk-pull__item blockquote::after  { content: close-quote; color: var(--green); margin-left: 4px; }
.uk-pull__item figcaption { font-size: 13.5px; color: rgba(255,255,255,.72); display: flex; flex-direction: column; gap: 2px; }
.uk-pull__item figcaption strong { color: var(--white); font-weight: 600; }

/* ==========================================================================
   13. Company page sections
   ========================================================================== */

/* Sticky in-page sub-nav */
.uk-subnav {
	position: sticky; top: 71px; z-index: 40;
	background: rgba(255,255,255,.96);
	backdrop-filter: saturate(180%) blur(10px);
	border-bottom: 1px solid var(--hairline);
}
.uk-subnav__inner {
	display: flex; gap: 24px; flex-wrap: wrap;
	padding-block: 14px;
	font-size: 13.5px; font-weight: 500;
}
.uk-subnav__inner a { color: var(--muted); }
.uk-subnav__inner a:hover { color: var(--ink); }

/* At a glance — stat tiles */
.uk-glance {
	background: var(--surface);
	border-bottom: 1px solid var(--hairline);
	padding-block: clamp(40px, 5vw, 64px);
}
.uk-glance__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-glance__masthead .uk-section__head { margin-bottom: 0; }
.uk-glance__lede { color: var(--muted); font-size: 15.5px; max-width: 44ch; margin: 0; }
.uk-glance__grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 0;
	border-top: 1px solid var(--ink);
	margin: 0;
}
.uk-glance__item {
	display: flex; flex-direction: column; gap: 10px;
	padding: 32px 16px;
	border-right: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
	background: var(--white);
	min-width: 0;
	overflow: hidden;
}
.uk-glance__item:last-child { border-right: 0; }
.uk-glance__metric {
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: clamp(20px, 1.9vw, 28px);
	letter-spacing: -0.02em;
	color: var(--ink); line-height: 1.1;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.uk-glance__metric em { color: var(--green-dk); font-style: italic; font-weight: 500; }
.uk-glance__label { color: var(--muted); font-size: 12px; line-height: 1.4; letter-spacing: .04em; margin: 0; }
@media (max-width: 1024px) { .uk-glance__grid { grid-template-columns: repeat(3, 1fr); } .uk-glance__item:nth-child(3n) { border-right: 0; } }
@media (max-width: 900px) { .uk-glance__masthead { grid-template-columns: 1fr; gap: 24px; align-items: start; } }
@media (max-width: 640px) { .uk-glance__grid { grid-template-columns: repeat(2, 1fr); } .uk-glance__item { border-right: 1px solid var(--hairline) !important; } .uk-glance__item:nth-child(2n) { border-right: 0 !important; } }

/* About — two-column */
.uk-about { padding-block: var(--section); }
.uk-about__grid {
	display: grid;
	grid-template-columns: 1fr 1.6fr;
	gap: 80px;
	align-items: start;
}
.uk-about .uk-section__h2 { max-width: 14ch; margin-top: 14px; }
.uk-about .uk-prose p {
	font-size: clamp(18px, 1.5vw, 22px);
	line-height: 1.55;
	color: var(--ink);
	font-weight: 500;
	max-width: 52ch;
	letter-spacing: -0.005em;
	margin: 0;
}
.uk-about .uk-prose p + p {
	margin-top: 22px;
	font-size: 16px;
	color: var(--muted);
	font-weight: 400;
	max-width: 60ch;
	line-height: 1.7;
}
.uk-about__credo {
	margin: 36px 0 0;
	padding-top: 24px;
	border-top: 1px solid var(--hairline);
	font-style: italic;
	font-weight: 500;
	font-size: 19px;
	color: var(--ink);
	max-width: 50ch;
}
.uk-about__credo em { color: var(--green-dk); font-weight: 600; font-style: italic; }
@media (max-width: 900px) { .uk-about__grid { grid-template-columns: 1fr; gap: 32px; } }

/* Stand for — 3-col (dark band) */
.uk-stand {
	background: var(--ink);
	color: var(--white);
	padding-block: var(--section);
}
.uk-stand__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid rgba(255,255,255,.18);
}
.uk-stand__col { background: transparent; padding: 44px 36px 44px 0; border-right: 1px solid rgba(255,255,255,.12); }
.uk-stand__col + .uk-stand__col { padding-left: 36px; }
.uk-stand__col:last-child { border-right: 0; padding-right: 0; }
.uk-stand__label { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--green); font-weight: 700; }
.uk-stand__statement { font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 24px; letter-spacing: -0.008em; margin: 18px 0 14px; color: var(--white); line-height: 1.25; }
.uk-stand__col p { color: rgba(255,255,255,.72); line-height: 1.65; font-size: 15px; max-width: 36ch; }
.uk-stand__principles { list-style: none; margin: 18px 0 0; padding: 0; }
.uk-stand__principles li { padding: 12px 0; border-top: 1px solid rgba(255,255,255,.1); font-size: 14.5px; color: rgba(255,255,255,.85); display: grid; grid-template-columns: 28px 1fr; gap: 8px; align-items: start; line-height: 1.5; }
.uk-stand__principles li::before { content: "—"; color: var(--green); font-weight: 700; }
@media (max-width: 900px) { .uk-stand__grid { grid-template-columns: 1fr; } .uk-stand__col { padding: 32px 0; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.12); } .uk-stand__col + .uk-stand__col { padding-left: 0; } }

/* Timeline */
.uk-timeline { padding-block: var(--section); }
.uk-timeline__list {
	list-style: none; padding: 0 0 0 8px; margin: 0 auto;
	max-width: 820px;
	position: relative;
}
.uk-timeline__list::before {
	content: ""; position: absolute; left: 80px; top: 0; bottom: 0;
	width: 1px; background: var(--hairline);
}
.uk-timeline__item {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 40px;
	padding: 26px 0;
	position: relative;
}
.uk-timeline__item::before {
	content: ""; position: absolute; left: 76px; top: 34px;
	width: 9px; height: 9px; border-radius: 50%;
	background: var(--white); border: 2px solid var(--ink);
	box-shadow: none;
}
.uk-timeline__year { font-family: 'Poppins', sans-serif; font-weight: 700; color: var(--ink); font-size: 22px; letter-spacing: -0.01em; line-height: 1; padding-top: 6px; }
.uk-timeline__h { font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 20px; letter-spacing: -0.005em; margin-bottom: 6px; color: var(--ink); }
.uk-timeline__body p { color: var(--muted); line-height: 1.65; font-size: 15px; max-width: 52ch; margin: 0; }
@media (max-width: 900px) {
	.uk-timeline__list::before { left: 60px; }
	.uk-timeline__item { grid-template-columns: 60px 1fr; gap: 24px; }
	.uk-timeline__item::before { left: 56px; }
}

/* Leadership grid */
.uk-leadership { background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); padding-block: var(--section); }
.uk-leadership__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}
.uk-leader { background: var(--white); padding: 24px; border: 1px solid var(--hairline); border-radius: 2px; transition: border-color .2s ease, transform .2s ease; }
.uk-leader:hover { border-color: var(--ink); transform: translateY(-2px); }
.uk-leader__portrait {
	width: 100%;
	aspect-ratio: 1/1;
	background: linear-gradient(135deg, var(--ink) 0%, #1a3060 100%);
	border-radius: 2px;
	display: flex; align-items: center; justify-content: center;
	color: var(--white);
	margin-bottom: 18px;
	position: relative;
	overflow: hidden;
}
.uk-leader__portrait::after {
	content: "";
	position: absolute; inset: 0;
	background: radial-gradient(circle at 30% 20%, rgba(118,188,33,.18), transparent 55%);
	pointer-events: none;
}
.uk-leader__portrait img { width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }
.uk-leader__initials {
	font-family: 'Poppins', sans-serif;
	font-weight: 600;
	font-size: 38px;
	letter-spacing: -0.02em;
	color: var(--white);
	position: relative;
	z-index: 1;
}
.uk-leader__name { font-family: 'Poppins', sans-serif; font-size: 17px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; margin: 0; }
.uk-leader__role { display: block; font-size: 12px; text-transform: uppercase; color: var(--green-dk); font-weight: 600; letter-spacing: .12em; margin-top: 4px; }
.uk-leader__bio { color: var(--muted); font-size: 13.5px; line-height: 1.55; margin: 12px 0 0; }
.uk-leader__link { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: 12px; color: var(--quiet); font-weight: 600; letter-spacing: .04em; text-decoration: none; }
.uk-leader__link:hover { color: var(--green-dk); }
@media (max-width: 1024px) { .uk-leadership__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .uk-leadership__grid { grid-template-columns: 1fr; } }

/* Locations */
.uk-loc { padding-block: var(--section); }
.uk-loc__grid-base { /* placeholder removed */ }
.uk-loc__hq {
	font-size: 10px; letter-spacing: .18em; font-weight: 700;
	background: var(--green); color: var(--white);
	padding: 3px 8px; border-radius: 2px;
}
.uk-loc__addr { color: var(--muted); font-size: 14.5px; line-height: 1.55; margin-bottom: 14px; }
.uk-loc__meta { display: flex; gap: 24px; flex-wrap: wrap; margin: 0; }
.uk-loc__meta dt { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--quiet); font-weight: 700; }
.uk-loc__meta dd { font-size: 14px; font-weight: 500; margin: 2px 0 0; }

/* Recognition wall */
.uk-recog { background: transparent; padding-block: var(--section); }

/* Careers */
.uk-careers { padding-block: var(--section); }
.uk-careers__lede { margin-bottom: 32px; }
.uk-careers__benefits {
	list-style: none; padding: 0; margin: 0 0 40px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
}
.uk-careers__benefits li {
	padding: 14px 18px;
	background: var(--surface);
	border-left: 2px solid var(--green);
	font-weight: 500; font-size: 14px;
}
.uk-careers__roles { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--ink); }
.uk-careers__role { border-bottom: 1px solid var(--hairline); }
.uk-careers__role a {
	display: grid;
	grid-template-columns: 1.4fr 1fr auto;
	gap: 20px;
	align-items: center;
	padding: 22px 0;
	color: var(--ink);
}
.uk-careers__role a {
	display: grid;
	grid-template-columns: 2fr 1.2fr 1.2fr 0.8fr 80px;
	gap: 24px;
	padding: 22px 0;
	align-items: center;
	color: var(--ink);
	text-decoration: none;
}
.uk-careers__role a:hover .uk-careers__role-apply { color: var(--green-dk); }
.uk-careers__role-title { font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 17px; color: var(--ink); letter-spacing: -0.005em; }
.uk-careers__role-team,
.uk-careers__role-loc { font-size: 13px; color: var(--muted); letter-spacing: .02em; }
.uk-careers__role-type { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--green-dk); font-weight: 600; }
.uk-careers__role-apply { font-size: 13px; font-weight: 600; color: var(--ink); white-space: nowrap; text-align: right; }
.uk-careers__empty-row { display: grid; grid-template-columns: 1fr auto; gap: 24px; padding: 28px 24px; border-bottom: 1px solid var(--hairline); align-items: center; background: var(--surface); margin-inline: -24px; }
.uk-careers__empty-msg { font-family: 'Poppins', sans-serif; font-style: italic; font-weight: 500; font-size: 17px; color: var(--ink); }
@media (max-width: 1024px) {
	.uk-careers__role a { grid-template-columns: 1fr 1fr; gap: 8px 16px; }
	.uk-careers__role-title { grid-column: 1 / -1; }
	.uk-careers__role-apply { grid-column: 1 / -1; text-align: left; padding-top: 4px; }
}
@media (max-width: 720px) {
	.uk-careers__role a { grid-template-columns: 1fr; gap: 6px; }
	.uk-careers__role-apply { margin-top: 6px; }
}

/* ==========================================================================
   14. Hub pages (Services / Products / Industries)
   ========================================================================== */
.uk-hub { padding-block: var(--section); }
.uk-hub__lede { margin-bottom: 40px; }
.uk-hub__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 28px;
}
.uk-hub__card {
	display: flex;
	flex-direction: column;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	overflow: hidden;
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-hub__card:hover { border-color: var(--ink); transform: translateY(-2px); color: var(--ink); }
.uk-hub__media { aspect-ratio: 16/10; background: var(--surface); overflow: hidden; }
.uk-hub__media img { width: 100%; height: 100%; object-fit: cover; }
.uk-hub__body { padding: 24px; display: flex; flex-direction: column; gap: 10px; }
.uk-hub__h { font-size: 19px; font-weight: 600; line-height: 1.3; }
.uk-hub__ex { color: var(--muted); font-size: 14.5px; line-height: 1.55; }
.uk-hub__more { margin-top: auto; font-size: 13px; font-weight: 600; color: var(--green-dk); letter-spacing: .04em; }

/* ==========================================================================
   15. Insights hub
   ========================================================================== */
.uk-insights-feat { padding-block: var(--section); }
.uk-insights-feat__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 28px;
}
.uk-insights-feat__card {
	display: flex; flex-direction: column;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	overflow: hidden;
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-insights-feat__card:hover { border-color: var(--ink); transform: translateY(-2px); color: var(--ink); }
.uk-insights-feat__media { aspect-ratio: 16/9; background: var(--surface); overflow: hidden; }
.uk-insights-feat__media img { width: 100%; height: 100%; object-fit: cover; }
.uk-insights-feat__body { padding: 22px; display: flex; flex-direction: column; gap: 10px; }
.uk-insights-feat__type { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--green-dk); font-weight: 700; }
.uk-insights-feat__h { font-size: 20px; font-weight: 600; line-height: 1.3; }

.uk-insights { background: var(--surface); border-top: 1px solid var(--hairline); padding-block: var(--section); }
.uk-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.uk-chip {
	padding: 6px 14px;
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 999px;
	font-size: 13px;
	color: var(--muted);
	transition: all var(--t-fast);
}
.uk-chip:hover { color: var(--ink); border-color: var(--ink); }
.uk-chip.is-active { background: var(--ink); color: var(--white); border-color: var(--ink); }

.uk-insights__empty { color: var(--muted); padding: 40px 0; text-align: center; }
.uk-insights__grid {
	margin-top: 24px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
}
.uk-insight-card {
	display: flex; flex-direction: column;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	overflow: hidden;
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-insight-card:hover { border-color: var(--ink); transform: translateY(-2px); color: var(--ink); }
.uk-insight-card__media { aspect-ratio: 16/9; background: var(--surface); overflow: hidden; }
.uk-insight-card__media img { width: 100%; height: 100%; object-fit: cover; }
.uk-insight-card__body { padding: 20px; display: flex; flex-direction: column; gap: 8px; }
.uk-insight-card__type { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--green-dk); font-weight: 700; }
.uk-insight-card__h { font-size: 17px; font-weight: 600; line-height: 1.35; }
.uk-insight-card__ex { color: var(--muted); font-size: 14px; line-height: 1.55; }
.uk-insight-card__meta { margin-top: auto; font-size: 12px; color: var(--quiet); letter-spacing: .04em; }

.uk-pagination {
	display: flex; justify-content: center; gap: 6px;
	margin-top: 48px;
}
.uk-pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 36px; height: 36px;
	padding: 0 10px;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	font-size: 14px; font-weight: 500;
}
.uk-pagination .page-numbers:hover { border-color: var(--ink); }
.uk-pagination .page-numbers.current { background: var(--ink); color: var(--white); border-color: var(--ink); }

/* Newsletter */
.uk-newsletter { background: var(--ink); color: var(--white); padding-block: clamp(48px, 6vw, 80px); }
.uk-newsletter__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
}
@media (max-width: 880px) { .uk-newsletter__inner { grid-template-columns: 1fr; gap: 28px; } }
.uk-newsletter__h { font-size: clamp(24px, 2.4vw, 32px); color: var(--white); margin-bottom: 8px; }
.uk-newsletter__body { color: rgba(255,255,255,.78); max-width: 44ch; }

/* ==========================================================================
   16. Contact page
   ========================================================================== */
.uk-contact { padding-block: var(--section); }
.uk-contact__grid {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 64px;
	align-items: start;
}
@media (max-width: 880px) { .uk-contact__grid { grid-template-columns: 1fr; gap: 40px; } }
.uk-contact__h { font-size: clamp(32px, 3.6vw, 48px); margin: 18px 0 18px; }
.uk-contact__meta { margin-top: 32px; display: grid; gap: 18px; }
.uk-contact__meta dt {
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: var(--quiet); font-weight: 700; margin-bottom: 4px;
}
.uk-contact__meta dd { font-size: 16px; font-weight: 500; margin: 0; }
.uk-contact__form {
	padding: 32px;
	background: var(--surface);
	border: 1px solid var(--hairline);
}
.uk-contact__form-fallback { color: var(--muted); font-style: italic; }

/* ==========================================================================
   17. Home page (mockup-faithful)
   ========================================================================== */

/* ----- Hero ----- */
.uk-h-hero { padding-block: clamp(20px, 2.5vw, 36px) clamp(40px, 5vw, 64px); border-bottom: 1px solid var(--hairline); background: var(--white); }
main { margin-top: 0 !important; }
.uk-h-hero__grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 64px; align-items: center; min-height: 560px; }
.uk-h-hero__eyebrow { display: flex; align-items: center; gap: 18px; margin-bottom: 22px; }
.uk-h-hero__tick { height: 1px; width: 48px; background: var(--ink); display: inline-block; }
.uk-h-hero__kicker { font-size: 13px; font-weight: 700; letter-spacing: 0.24em; text-transform: uppercase; color: var(--quiet); }
.uk-h-hero__h1 { font-size: clamp(40px, 4.6vw, 64px); max-width: 15ch; color: var(--ink); margin-bottom: 24px; }
.uk-h-hero__h1 em { font-style: italic; color: var(--green-dk); font-weight: 600; }
.uk-h-hero__lede { font-size: clamp(16px, 1.2vw, 18px); color: var(--muted); max-width: 48ch; margin-bottom: 32px; line-height: 1.6; }
.uk-h-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 40px; }
.uk-h-hero__foot { display: flex; gap: 36px; flex-wrap: wrap; padding-top: 24px; border-top: 1px solid var(--hairline); align-items: flex-end; }
.uk-h-hero__stat { display: flex; flex-direction: column; gap: 4px; }
.uk-h-hero__stat .n { font-weight: 700; font-size: 28px; letter-spacing: -0.02em; color: var(--ink); line-height: 1; }
.uk-h-hero__stat .n em { font-size: .65em; color: var(--green-dk); font-style: normal; }
.uk-h-hero__stat .l { font-size: 12px; color: var(--muted); letter-spacing: .03em; }
.uk-h-hero__certs { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; padding-top: 28px; color: var(--ink); }
.uk-cert-seal { width: 78px; height: 78px; flex: 0 0 auto; transition: transform .2s ease; }
.uk-cert-seal:hover { transform: scale(1.05); }
.uk-h-hero__visual { aspect-ratio: 4/5; border-radius: 2px; overflow: hidden; background: var(--ink); box-shadow: 0 30px 80px -40px rgba(11, 30, 63, .45); position: relative; }
.uk-h-hero__visual::before { content: ""; position: absolute; inset: 0; background: radial-gradient(700px 400px at 85% 15%, rgba(0,167,225,.22), transparent 55%), radial-gradient(500px 500px at 15% 85%, rgba(118,188,33,.18), transparent 60%), linear-gradient(180deg, var(--ink) 0%, #050F24 100%); }
@media (max-width: 880px) { .uk-h-hero__grid { grid-template-columns: 1fr; gap: 40px; } .uk-h-hero__visual { aspect-ratio: 16/10; } }

/* ----- I — Brief ----- */
.uk-h-brief { background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); padding-block: var(--section); }
.uk-h-brief .uk-container { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
.uk-h-brief__title .uk-kicker { color: var(--green-dk); }
.uk-h-brief__title h2 { font-size: clamp(22px, 2.3vw, 30px); line-height: 1.2; max-width: 14ch; font-weight: 600; letter-spacing: -0.02em; margin-top: 14px; }
.uk-h-brief__body p { font-size: clamp(19px, 1.7vw, 24px); line-height: 1.45; color: var(--ink); font-weight: 600; letter-spacing: -0.012em; max-width: 42ch; }
.uk-h-brief__body p + p { margin-top: 20px; font-size: 15.5px; color: var(--muted); max-width: 58ch; line-height: 1.65; font-weight: 400; letter-spacing: 0; }
@media (max-width: 900px) { .uk-h-brief .uk-container { grid-template-columns: 1fr; gap: 32px; } }

/* ----- II — Disciplines ----- */
.uk-h-disc { padding-block: var(--section); }
.uk-h-disc__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 72px; }
.uk-h-disc__masthead h2.uk-display { font-size: clamp(40px, 5vw, 72px); max-width: 14ch; }
.uk-h-disc__masthead p { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-h-disc__row { display: grid; grid-template-columns: 88px 1.2fr 2fr auto; gap: 40px; padding: 44px 0; border-top: 1px solid var(--hairline); align-items: start; }
.uk-h-disc__row:last-of-type { border-bottom: 1px solid var(--hairline); }
.uk-h-disc__row .num { font-weight: 600; font-size: 38px; line-height: 1; color: var(--green-dk); letter-spacing: -0.02em; }
.uk-h-disc__row .ttl { font-weight: 600; font-size: clamp(22px, 2.1vw, 30px); line-height: 1.18; color: var(--ink); letter-spacing: -0.01em; max-width: 16ch; }
.uk-h-disc__row .meta { font-size: 13px; color: var(--quiet); letter-spacing: .04em; margin-top: 8px; font-weight: 500; }
.uk-h-disc__row .body { font-size: 16px; color: var(--muted); line-height: 1.65; max-width: 56ch; }
.uk-h-disc__row .go { font-size: 13px; font-weight: 600; color: var(--ink); white-space: nowrap; }
.uk-h-disc__row:hover .go { color: var(--green-dk); }
.uk-h-disc__tail { margin-top: 56px; display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; padding-top: 28px; }
.uk-h-disc__tail p { font-style: italic; font-weight: 500; font-size: 20px; color: var(--ink); max-width: 56ch; }
@media (max-width: 900px) { .uk-h-disc__masthead { grid-template-columns: 1fr; gap: 24px; } .uk-h-disc__row { grid-template-columns: 56px 1fr; gap: 20px 16px; } .uk-h-disc__row .body, .uk-h-disc__row .go { grid-column: 1 / -1; } }

/* ----- III — Actigen 2.0 ----- */
.uk-h-actigen { background: var(--ink); color: var(--white); padding-block: var(--section); }
.uk-h-actigen .uk-container { display: grid; grid-template-columns: 1fr; gap: 64px; }
.uk-h-actigen__masthead { max-width: 100%; }
.uk-h-actigen__kicker { color: var(--blue); margin-bottom: 8px; }
.uk-h-actigen__masthead h2.uk-display { font-size: clamp(40px, 5vw, 72px); max-width: 18ch; color: var(--white); margin-top: 16px; }
.uk-h-actigen__masthead h2.uk-display em { color: var(--green); font-style: italic; }
.uk-h-actigen__lede { font-weight: 600; font-size: clamp(18px, 1.5vw, 22px); color: rgba(255,255,255,.8); max-width: 52ch; margin-top: 20px; line-height: 1.5; }
.uk-h-actigen__split { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.uk-h-actigen__loop { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.uk-h-actigen__step { padding: 24px; border: 1px solid rgba(255,255,255,.12); border-radius: 2px; }
.uk-h-actigen__step .lab { font-size: 28px; color: var(--green); line-height: 1; font-weight: 500; }
.uk-h-actigen__step .t { font-weight: 600; font-size: 17px; margin-top: 10px; }
.uk-h-actigen__step .d { color: rgba(255,255,255,.6); font-size: 13.5px; margin-top: 4px; }
.uk-h-actigen__claim { font-weight: 600; font-size: clamp(22px, 2vw, 30px); line-height: 1.35; color: rgba(255,255,255,.95); letter-spacing: -0.005em; max-width: 36ch; }
.uk-h-actigen__claim em { font-style: italic; color: var(--green); font-weight: 600; }
.uk-h-actigen__stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 36px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.1); }
.uk-h-actigen__stats .s-n { font-size: 32px; font-weight: 500; color: var(--white); letter-spacing: -0.01em; white-space: nowrap; }
.uk-h-actigen__stats .s-n em { color: var(--green); font-style: italic; font-weight: 500; }
.uk-h-actigen__stats .s-l { font-size: 12.5px; color: rgba(255,255,255,.6); letter-spacing: .04em; margin-top: 4px; line-height: 1.4; }
.uk-h-actigen__cta { display: flex; align-items: center; gap: 20px; margin-top: 20px; flex-wrap: wrap; }
@media (max-width: 900px) { .uk-h-actigen__split { grid-template-columns: 1fr; gap: 32px; } .uk-h-actigen__stats { grid-template-columns: repeat(2, 1fr); } }

/* ----- IV — Receipts ----- */
.uk-h-receipts { background: var(--white); padding-block: var(--section); }
.uk-h-receipts__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 72px; }
.uk-h-receipts__masthead h2.uk-display { font-size: clamp(40px, 5vw, 72px); max-width: 14ch; }
.uk-h-receipts__masthead p { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-h-receipts__row { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; padding: 56px 0; border-top: 1px solid var(--hairline); align-items: center; }
.uk-h-receipts__row:last-of-type { border-bottom: 1px solid var(--hairline); }
.uk-h-receipts__row .plate { aspect-ratio: 4/3; border-radius: 2px; position: relative; overflow: hidden; background: linear-gradient(135deg, var(--ink) 0%, #1a3060 100%); }
.uk-h-receipts__row--b .plate { background: linear-gradient(135deg, #0B4530, #76BC21); }
.uk-h-receipts__row--c .plate { background: linear-gradient(135deg, #4a0909, #E1251B); }
.uk-h-receipts__row .plate::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 25% 25%, rgba(255,255,255,.12), transparent 45%), repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px); }
.uk-h-receipts__row .plate .num-mark { position: absolute; top: 22px; left: 24px; color: rgba(255,255,255,.85); font-size: 13px; letter-spacing: .2em; }
.uk-h-receipts__row .plate .client-mark { position: absolute; bottom: 22px; left: 24px; color: var(--white); font-weight: 600; font-size: 22px; line-height: 1.15; max-width: 20ch; }
.uk-h-receipts__row .copy .byline { font-size: 12px; letter-spacing: .22em; color: var(--green-dk); text-transform: uppercase; font-weight: 600; }
.uk-h-receipts__row .copy h3 { font-weight: 600; font-size: clamp(26px, 2.6vw, 38px); line-height: 1.15; letter-spacing: -0.012em; margin: 14px 0 20px; max-width: 22ch; }
.uk-h-receipts__row .copy p { font-size: 16px; color: var(--muted); line-height: 1.65; max-width: 56ch; }
.uk-h-receipts__row .copy .outcome { font-weight: 500; font-style: italic; font-size: 18px; color: var(--ink); margin-top: 24px; padding-top: 18px; border-top: 1px solid var(--hairline); max-width: 50ch; }
.uk-h-receipts__row .copy .outcome em { color: var(--green-dk); }
.uk-h-receipts__row .copy .go { margin-top: 22px; display: inline-block; font-size: 13px; font-weight: 600; color: var(--ink); letter-spacing: .02em; }
.uk-h-receipts__row:hover .copy .go { color: var(--green-dk); }
.uk-h-receipts__tail { display: flex; justify-content: center; margin-top: 56px; }
@media (max-width: 900px) { .uk-h-receipts__masthead { grid-template-columns: 1fr; gap: 24px; } .uk-h-receipts__row { grid-template-columns: 1fr; gap: 24px; padding: 40px 0; } }

/* ----- V — Industries typographic list ----- */
.uk-h-industries { background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); padding-block: var(--section); }
.uk-h-industries__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-h-industries__masthead h2.uk-display { font-size: clamp(36px, 4.4vw, 60px); max-width: 16ch; }
.uk-h-industries__masthead p { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-h-industries__table { width: 100%; border-collapse: collapse; border-top: 2px solid var(--ink); table-layout: fixed; }
.uk-h-industries__table th, .uk-h-industries__table td { vertical-align: middle; border-bottom: 1px solid var(--hairline); text-align: left; }
/* Header: kicker-style labels, matching the section's typographic voice. */
.uk-h-industries__table thead th { font-family: var(--font-sans); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); padding: 14px 24px 14px 0; }
/* Column widths: keep the two columns visually connected (no far-edge void). */
.uk-h-industries__table .ind-name { width: 44%; }
.uk-h-industries__table .ind-tag  { width: 56%; }
/* Body rows: editorial ledger rhythm with a subtle hover lift. */
.uk-h-industries__table tbody tr { transition: background var(--t-fast); }
.uk-h-industries__table tbody tr:hover { background: var(--white); }
.uk-h-industries__table tbody td, .uk-h-industries__table tbody th { padding: 20px 24px 20px 0; }
.uk-h-industries__table .ind-name { font-weight: 500; }
.uk-h-industries__table .ind-name a { display: inline-flex; align-items: center; gap: 12px; font-size: clamp(18px, 1.5vw, 21px); font-weight: 500; letter-spacing: -0.01em; line-height: 1.25; color: var(--ink); text-decoration: none; transition: color var(--t-fast); }
.uk-h-industries__table .ind-name a::after { content: "\2192"; font-size: 16px; color: var(--green-dk); opacity: 0; transform: translateX(-6px); transition: opacity var(--t-fast), transform var(--t-fast); }
.uk-h-industries__table tbody tr:hover .ind-name a { color: var(--green-dk); }
.uk-h-industries__table tbody tr:hover .ind-name a::after { opacity: 1; transform: translateX(0); }
/* Processed values as chip/pill badges. */
.uk-h-industries__table .ind-tag { display: flex; flex-wrap: wrap; gap: 8px; }
.uk-ind-chip { display: inline-flex; align-items: center; padding: 5px 13px; border: 1px solid var(--hairline); border-radius: 999px; background: var(--white); font-size: 12.5px; font-weight: 500; letter-spacing: .01em; color: var(--ink-2); white-space: nowrap; transition: border-color var(--t-fast), color var(--t-fast); }
.uk-h-industries__table tbody tr:hover .uk-ind-chip { border-color: var(--green); color: var(--green-dk); }
@media (max-width: 760px) {
	.uk-h-industries__masthead { grid-template-columns: 1fr; gap: 24px; }
	.uk-h-industries__table, .uk-h-industries__table tbody, .uk-h-industries__table tr, .uk-h-industries__table td, .uk-h-industries__table th { display: block; width: 100%; }
	.uk-h-industries__table thead { display: none; }
	.uk-h-industries__table tbody tr { padding: 18px 0; }
	.uk-h-industries__table tbody td, .uk-h-industries__table tbody th { padding: 0; border-bottom: 0; }
	.uk-h-industries__table .ind-name { margin-bottom: 12px; }
	.uk-h-industries__table .ind-name a { font-size: 18px; }
}

/* ----- VI — Engage ----- */
.uk-h-engage { padding-block: var(--section); }
.uk-h-engage__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 96px; align-items: start; }
.uk-h-engage h2.uk-display { font-size: clamp(36px, 4.4vw, 60px); max-width: 14ch; }
.uk-h-engage__prose { font-weight: 600; font-size: clamp(19px, 1.6vw, 22px); line-height: 1.5; color: var(--ink); max-width: 40ch; margin-top: 22px; }
.uk-h-engage__prose p + p { margin-top: 18px; }
.uk-h-engage ol { list-style: none; counter-reset: step; padding: 0; margin: 0; }
.uk-h-engage li { counter-increment: step; display: grid; grid-template-columns: 72px 1fr; gap: 20px; padding: 26px 0; border-top: 1px solid var(--hairline); }
.uk-h-engage li:last-child { border-bottom: 1px solid var(--hairline); }
.uk-h-engage li::before { content: counter(step, decimal-leading-zero); font-size: 22px; color: var(--green-dk); font-weight: 500; line-height: 1; }
.uk-h-engage li h4 { font-size: 22px; font-weight: 600; margin-bottom: 6px; letter-spacing: -0.005em; }
.uk-h-engage li p { color: var(--muted); font-size: 15px; line-height: 1.6; }
@media (max-width: 900px) { .uk-h-engage__grid { grid-template-columns: 1fr; gap: 32px; } }

/* ----- Pull quote ----- */
.uk-h-pull { background: var(--ink); color: var(--white); padding-block: clamp(88px, 11vw, 160px); }
.uk-h-pull .uk-container { max-width: 980px; }
.uk-h-pull blockquote { font-weight: 500; font-style: italic; font-size: clamp(30px, 4vw, 54px); line-height: 1.25; letter-spacing: -0.012em; color: var(--white); margin: 0; }
.uk-h-pull blockquote .m { color: var(--green); font-style: normal; font-weight: 600; }
.uk-h-pull cite { font-style: normal; display: block; margin-top: 40px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.2); max-width: 460px; }
.uk-h-pull cite .n { font-size: 15px; font-weight: 600; letter-spacing: .02em; display: block; }
.uk-h-pull cite .r { font-size: 13px; color: rgba(255,255,255,.6); margin-top: 4px; letter-spacing: .04em; display: block; }

/* ----- VII — Roster ----- */
.uk-h-roster { border-bottom: 1px solid var(--hairline); padding-block: var(--section); }
.uk-h-roster .uk-container { display: grid; grid-template-columns: 1fr 2.5fr; gap: 80px; align-items: start; }
.uk-h-roster__kicker { color: var(--green-dk); }
.uk-h-roster h2 { font-weight: 600; font-size: clamp(24px, 2.4vw, 32px); max-width: 14ch; letter-spacing: -0.008em; margin-top: 14px; }
.uk-h-roster__names { font-weight: 600; font-size: clamp(18px, 1.6vw, 22px); line-height: 1.6; letter-spacing: -0.003em; color: var(--ink); }
.uk-h-roster__names .div { color: var(--green-dk); margin-inline: 10px; font-weight: 600; }
.uk-h-roster__part { margin-top: 36px; padding-top: 20px; border-top: 1px solid var(--hairline); }
.uk-h-roster__part .label { font-size: 11px; letter-spacing: .22em; color: var(--muted); text-transform: uppercase; font-weight: 600; margin-bottom: 14px; }
.uk-h-roster__part .list2 { font-size: 15.5px; color: var(--muted); line-height: 1.8; }
@media (max-width: 900px) { .uk-h-roster .uk-container { grid-template-columns: 1fr; gap: 24px; } }

/* ----- VIII — Contact ----- */
.uk-h-contact { background: var(--surface); padding-block: var(--section); }
.uk-h-contact__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.uk-h-contact__grid h2.uk-display { font-size: clamp(40px, 5vw, 72px); max-width: 14ch; }
.uk-h-contact__intro { font-weight: 600; font-size: clamp(20px, 1.8vw, 26px); line-height: 1.45; color: var(--ink); margin-top: 22px; max-width: 40ch; letter-spacing: -0.005em; }
.uk-h-contact__meta { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--hairline); display: flex; gap: 32px; flex-wrap: wrap; font-size: 13px; color: var(--muted); }
.uk-h-contact__meta strong { color: var(--ink); display: block; font-size: 11px; letter-spacing: .22em; margin-bottom: 4px; font-weight: 600; }
.uk-h-contact__form form { display: flex; flex-direction: column; gap: 16px; }
.uk-h-contact__form label { font-size: 11px; letter-spacing: .18em; color: var(--muted); text-transform: uppercase; font-weight: 600; margin-bottom: 4px; display: block; }
.uk-h-contact__form input, .uk-h-contact__form textarea { width: 100%; padding: 14px 0; border: 0; border-bottom: 1px solid var(--ink); background: transparent; color: var(--ink); font: inherit; font-size: 16px; border-radius: 0; }
.uk-h-contact__form button { margin-top: 12px; background: var(--ink); color: var(--white); border: 0; padding: 15px 24px; font-weight: 500; font-size: 15px; cursor: pointer; }
.uk-h-contact__form button:hover { background: var(--green-dk); }
@media (max-width: 900px) { .uk-h-contact__grid { grid-template-columns: 1fr; gap: 32px; } }

/* ==========================================================================
   18. Service detail extras (X · XI · trust)
   ========================================================================== */

/* X — Engagement models (dark) */
.uk-s-engage { background: var(--ink); color: var(--white); padding-block: var(--section); }
.uk-s-engage__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-s-engage__masthead h2.uk-display { font-size: clamp(40px, 5vw, 64px); max-width: 14ch; color: var(--white); }
.uk-s-engage__masthead h2.uk-display em { color: var(--green); font-style: italic; }
.uk-s-engage__masthead p { color: rgba(255,255,255,.75); font-size: 16px; max-width: 48ch; }
.uk-s-engage__masthead .uk-kicker { color: rgba(255,255,255,.6); }
.uk-s-engage__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.uk-s-engage__card { padding: 28px; border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.03); border-radius: 2px; display: flex; flex-direction: column; gap: 14px; }
.uk-s-engage__card .lab { font-size: 12px; letter-spacing: .2em; color: var(--green); font-weight: 600; }
.uk-s-engage__card h3 { font-size: 22px; font-weight: 600; color: var(--white); margin: 0; line-height: 1.2; }
.uk-s-engage__card .prop { font-size: 15px; color: rgba(255,255,255,.85); line-height: 1.5; font-weight: 500; margin: 0; }
.uk-s-engage__card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; padding-top: 6px; border-top: 1px solid rgba(255,255,255,.12); }
.uk-s-engage__card li { display: grid; grid-template-columns: 88px 1fr; gap: 10px; font-size: 13px; color: rgba(255,255,255,.78); line-height: 1.5; }
.uk-s-engage__card li .k { color: rgba(255,255,255,.55); font-weight: 600; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; }
.uk-s-engage__card .go { font-size: 13px; font-weight: 600; color: var(--green); margin-top: auto; padding-top: 6px; }
@media (max-width: 900px) { .uk-s-engage__masthead { grid-template-columns: 1fr; gap: 24px; } .uk-s-engage__grid { grid-template-columns: 1fr; } }

/* XI — How we deliver */
.uk-s-deliver { padding-block: var(--section); }
.uk-s-deliver__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-s-deliver__masthead h2.uk-display { font-size: clamp(40px, 5vw, 64px); max-width: 14ch; }
.uk-s-deliver__masthead p { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-s-deliver__phases { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.uk-s-deliver__phase { padding: 24px; background: var(--surface); border-top: 2px solid var(--ink); display: flex; flex-direction: column; gap: 10px; }
.uk-s-deliver__phase .lab { font-size: 28px; color: var(--green-dk); font-weight: 500; line-height: 1; }
.uk-s-deliver__phase h4 { font-size: 17px; font-weight: 600; margin: 0; }
.uk-s-deliver__phase p { color: var(--muted); font-size: 14px; line-height: 1.55; }
.uk-s-deliver__phase .meta { margin-top: auto; padding-top: 8px; border-top: 1px solid var(--hairline); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--quiet); font-weight: 600; }
.uk-s-deliver__tail { display: flex; justify-content: space-between; align-items: center; gap: 32px; flex-wrap: wrap; padding-top: 40px; margin-top: 40px; border-top: 1px solid var(--hairline); }
.uk-s-deliver__tail p { font-style: italic; font-weight: 500; font-size: 18px; color: var(--ink); max-width: 56ch; }
@media (max-width: 900px) { .uk-s-deliver__masthead { grid-template-columns: 1fr; gap: 24px; } .uk-s-deliver__phases { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .uk-s-deliver__phases { grid-template-columns: 1fr; } }

/* Trust strip */
.uk-s-trust { background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); padding-block: 28px; }
.uk-s-trust .uk-container { display: flex; align-items: center; justify-content: center; gap: 18px; flex-wrap: wrap; font-size: 14px; color: var(--muted); }
.uk-s-trust .sep { color: var(--quiet); }
.uk-s-trust strong { color: var(--ink); font-weight: 700; }

/* ==========================================================================
   19. Header polish — search + locale chip
   ========================================================================== */
.uk-header__icon-btn {
	width: 40px; height: 40px;
	border: 1px solid var(--hairline);
	border-radius: 2px;
	background: var(--white);
	color: var(--ink);
	display: inline-flex; align-items: center; justify-content: center;
	cursor: pointer;
	transition: border-color var(--t-fast);
}
.uk-header__icon-btn:hover { border-color: var(--ink); }
.uk-header__loc-btn {
	width: auto;
	padding: 0 12px;
	gap: 8px;
	font-size: 13.5px;
	font-weight: 500;
}
.uk-header__loc-flag {
	width: 16px; height: 11px;
	background: linear-gradient(to bottom, #00247d 33%, #fff 33% 66%, #cf142b 66%);
	border-radius: 1px;
	flex: 0 0 auto;
}
@media (max-width: 760px) {
	.uk-header__icon-btn:not(.uk-header__loc-btn) { display: none; }
	.uk-header__loc-btn { display: none; }
}

/* ==========================================================================
   20. Company — How we deliver + Life at SBL
   ========================================================================== */
.uk-c-deliver { padding-block: var(--section); }
.uk-section__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-section__masthead .uk-section__head { margin-bottom: 0; }
.uk-section__lede { color: var(--muted); font-size: 16px; max-width: 48ch; margin: 0; }
.uk-stand .uk-section__lede { color: rgba(255,255,255,.7); }
@media (max-width: 900px) { .uk-section__masthead { grid-template-columns: 1fr; gap: 24px; align-items: start; } }
.uk-c-deliver__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-c-deliver__masthead h2.uk-display { font-size: clamp(36px, 4vw, 56px); max-width: 14ch; }
.uk-c-deliver__masthead p { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-c-deliver__phases { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--ink); }
.uk-c-deliver__phase { padding: 36px 28px 36px 0; border-right: 1px solid var(--hairline); position: relative; display: flex; flex-direction: column; }
.uk-c-deliver__phase + .uk-c-deliver__phase { padding-left: 28px; }
.uk-c-deliver__phase:last-child { border-right: 0; padding-right: 0; }
.uk-c-deliver__phase .lab { font-family: 'Poppins', sans-serif; font-size: 28px; color: var(--green-dk); font-weight: 500; line-height: 1; letter-spacing: -0.01em; }
.uk-c-deliver__phase h4 { font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 22px; margin: 16px 0 12px; letter-spacing: -0.005em; color: var(--ink); word-break: keep-all; overflow-wrap: break-word; hyphens: none; text-wrap: balance; }
.uk-c-deliver__phase p { color: var(--muted); font-size: 14.5px; line-height: 1.6; margin: 0; word-break: keep-all; overflow-wrap: break-word; hyphens: none; text-wrap: pretty; }
.uk-c-deliver__phase .meta { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--hairline); font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--quiet); font-weight: 600; }
@media (max-width: 900px) {
	.uk-c-deliver__masthead { grid-template-columns: 1fr; gap: 24px; }
	.uk-c-deliver__phases { grid-template-columns: repeat(2, 1fr); }
	.uk-c-deliver__phase { padding: 24px 0; border-right: 0; border-bottom: 1px solid var(--hairline); }
	.uk-c-deliver__phase + .uk-c-deliver__phase { padding-left: 0; }
}
@media (max-width: 540px) { .uk-c-deliver__phases { grid-template-columns: 1fr; } }

.uk-c-life { padding-block: var(--section); background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.uk-c-life__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; margin-bottom: 56px; }
.uk-c-life__masthead h2.uk-display { font-size: clamp(36px, 4vw, 56px); max-width: 14ch; }
.uk-c-life__prose p { font-size: clamp(17px, 1.4vw, 20px); line-height: 1.55; color: var(--ink); font-weight: 500; max-width: 56ch; }
.uk-c-life__prose p + p { margin-top: 18px; }
.uk-c-life__pillars { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; margin-top: 64px; padding-top: 48px; border-top: 1px solid var(--hairline); }
.uk-c-life__pillar { padding-top: 18px; border-top: 1px solid var(--ink); }
.uk-c-life__pillar h4 { font-size: 17px; font-weight: 600; margin-bottom: 10px; }
.uk-c-life__pillar p { color: var(--muted); font-size: 14.5px; line-height: 1.6; }
@media (max-width: 900px) { .uk-c-life__masthead { grid-template-columns: 1fr; gap: 24px; } }

/* ==========================================================================
   21. Hero visual SVGs (records / spines / terminal)
   ========================================================================== */
.uk-vis { position: absolute; inset: 0; overflow: hidden; }
.uk-vis svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.uk-vis__bar { position: absolute; top: 16px; left: 16px; right: 16px; display: flex; justify-content: space-between; align-items: center; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.55); z-index: 2; }
.uk-vis__bar .live { color: var(--green); display: inline-flex; align-items: center; gap: 6px; }
.uk-vis__bar .live::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green); display: inline-block; }
.uk-vis__cap { position: absolute; top: 16px; left: 16px; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.55); z-index: 2; }
.uk-vis__tag { position: absolute; top: 16px; right: 16px; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--green); z-index: 2; display: inline-flex; align-items: center; gap: 6px; }
.uk-vis__tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green); display: inline-block; }
.uk-vis__q { position: absolute; bottom: 24px; left: 24px; right: 24px; margin: 0; color: rgba(255,255,255,.85); font-size: 14px; font-style: italic; line-height: 1.5; z-index: 2; }
.uk-vis__q .cite { display: block; margin-top: 8px; font-style: normal; font-size: 11px; letter-spacing: .14em; color: var(--green); text-transform: uppercase; }

/* — Spines (Company hero — light archive panel) — */
.uk-hero-s__visual .uk-vis--spines { position: absolute; inset: 0; padding: 36px 32px; background: var(--surface); border: 1px solid var(--hairline); border-radius: 2px; overflow: hidden; }
.uk-hero-s__visual .uk-vis--spines .uk-vis__bar { position: absolute; top: 24px; left: 32px; right: 32px; display: flex; justify-content: space-between; font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase; color: var(--quiet); font-weight: 600; }
.uk-hero-s__visual .uk-vis--spines .uk-vis__bar .live { color: var(--green-dk); display: inline-flex; align-items: center; gap: 8px; }
.uk-hero-s__visual .uk-vis--spines .uk-vis__bar .live::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 10px var(--green); }
.uk-hero-s__visual .uk-vis__spines { position: absolute; left: 32px; right: 32px; top: 80px; bottom: 100px; display: flex; gap: 6px; align-items: flex-end; padding: 0; }
.uk-hero-s__visual .uk-vis__spine { flex: 1; min-height: 0; background: var(--white); border: 1px solid var(--hairline); border-bottom: 4px solid var(--ink); display: flex; align-items: flex-start; justify-content: center; padding: 18px 0 0; transition: transform .3s ease; }
.uk-hero-s__visual .uk-vis__spine.accent { border-bottom-color: var(--green); }
.uk-hero-s__visual .uk-vis__spine .yr { font-family: 'Poppins', sans-serif; font-size: 10.5px; letter-spacing: .15em; color: var(--quiet); writing-mode: vertical-rl; transform: rotate(180deg); font-weight: 600; }
.uk-hero-s__visual .uk-vis__spine.accent .yr { color: var(--green-dk); }
.uk-hero-s__visual .uk-vis__note { position: absolute; left: 32px; right: 32px; bottom: 32px; font-style: italic; font-weight: 500; font-size: 14px; color: var(--ink); line-height: 1.5; padding-left: 14px; border-left: 2px solid var(--green); }
.uk-hero-s__visual .uk-vis__note .cite { display: block; margin-top: 8px; font-style: normal; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--green-dk); font-weight: 600; }
/* Per-spine heights — bars of varied lengths (mockup uses height variation) */
.uk-hero-s__visual .uk-vis__spine:nth-child(1) { height: 32%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(2) { height: 44%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(3) { height: 58%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(4) { height: 50%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(5) { height: 66%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(6) { height: 78%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(7) { height: 70%; }
.uk-hero-s__visual .uk-vis__spine:nth-child(8) { height: 92%; }

/* — Terminal (Service hero) — */
.uk-vis--term { background: #050F24; padding: 56px 22px 22px; font-family: 'JetBrains Mono', 'Menlo', ui-monospace, monospace; font-size: 12.5px; color: rgba(255,255,255,.86); display: flex; flex-direction: column; gap: 6px; line-height: 1.5; overflow: hidden; }
.uk-vis--term .uk-vis__bar .name { color: rgba(255,255,255,.65); font-family: var(--font-sans); }
.uk-vis--term .ln { display: block; }
.uk-vis--term .pmt { color: var(--green); margin-right: 8px; }
.uk-vis--term .c { color: rgba(255,255,255,.4); }
.uk-vis--term .k { color: var(--blue); }
.uk-vis--term .v { color: var(--green); }
.uk-vis--term .ok { color: var(--green); margin-right: 4px; }

/* Position visuals correctly inside hero containers */
.uk-h-hero__visual { position: relative; }
.uk-hero-s__visual { position: relative; }
.uk-h-hero__visual .uk-vis { background: var(--ink); }

/* Tech stack column sub-headings (R1) */
.uk-stack__cat { display: block; font-size: 11px; letter-spacing: .18em; color: var(--green-dk); text-transform: uppercase; font-weight: 700; margin-bottom: 6px; }
.uk-stack__sub { font-size: 17px; font-weight: 600; color: var(--ink); margin-bottom: 6px; line-height: 1.3; letter-spacing: -0.005em; }
.uk-stack__desc { color: var(--muted); font-size: 13.5px; line-height: 1.55; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--hairline); }

.uk-cta-band__sub { display: block; font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--green); font-weight: 700; margin-bottom: 10px; }

/* Actigen "How it works" flow + stats (R3) */
.uk-howit__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-howit__intro { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-howit__flow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 56px; }
.uk-howit__step { padding: 24px; background: var(--surface); border-top: 2px solid var(--ink); position: relative; display: flex; flex-direction: column; gap: 10px; }
.uk-howit__step .num { font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--green-dk); font-weight: 700; }
.uk-howit__step .dot { width: 10px; height: 10px; background: var(--green); border-radius: 50%; }
.uk-howit__step .t { font-size: 19px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; }
.uk-howit__step .d { color: var(--muted); font-size: 14px; line-height: 1.55; }
.uk-howit__statswrap { display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: center; margin-top: 32px; padding-top: 32px; border-top: 1px solid var(--hairline); }
.uk-howit__claim { font-size: clamp(20px, 1.8vw, 26px); line-height: 1.4; color: var(--ink); font-weight: 600; max-width: 36ch; }
.uk-howit__claim em { color: var(--green-dk); font-style: italic; }
.uk-howit__stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.uk-howit__stats .s-n { font-size: 28px; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); line-height: 1; }
.uk-howit__stats .s-n em { color: var(--green); font-style: normal; }
.uk-howit__stats .s-l { font-size: 13px; color: var(--muted); margin-top: 4px; line-height: 1.4; }
@media (max-width: 900px) { .uk-howit__masthead, .uk-howit__statswrap { grid-template-columns: 1fr; gap: 24px; } .uk-howit__flow { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .uk-howit__flow { grid-template-columns: 1fr; } }

/* Industry Platform showcase (R4) — dark with module tiles */
.uk-platform {
	padding-block: var(--section);
	background: var(--ink);
	color: var(--white);
}
.uk-platform .uk-section__h2 { color: var(--white); font-size: clamp(34px, 4vw, 52px); max-width: 14ch; }
.uk-platform .uk-section__h2 em { color: var(--green); }
.uk-platform .uk-kicker { color: var(--white); }
.uk-platform .uk-rule { background: rgba(255,255,255,.4); }
.uk-platform .uk-section__lede { color: rgba(255,255,255,.7); }
.uk-platform__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.uk-platform__mod {
	padding: 22px 20px;
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 2px;
	background: rgba(255,255,255,.03);
	transition: border-color .2s, transform .2s;
	display: flex;
	flex-direction: column;
	gap: 8px;
	color: inherit;
	text-decoration: none;
}
a.uk-platform__mod:hover { border-color: rgba(118,188,33,.5); transform: translateY(-2px); color: inherit; }
.uk-platform__mod.is-current {
	border-color: var(--green);
	background: linear-gradient(180deg, rgba(118,188,33,.08), transparent 70%);
	position: relative;
}
.uk-platform__mod.is-current::before {
	content: "For this industry";
	position: absolute;
	top: -9px; right: 14px;
	font-size: 9.5px; letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink); font-weight: 700;
	background: var(--green);
	padding: 3px 8px;
	border-radius: 2px;
}
.uk-platform__lab {
	font-family: var(--font-sans);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--green);
	font-weight: 700;
}
.uk-platform__h {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 18px;
	color: var(--white);
	letter-spacing: -0.005em;
	margin: 0;
}
.uk-platform__mod p { font-size: 13px; color: rgba(255,255,255,.65); line-height: 1.55; margin: 0; }
.uk-platform__tail {
	margin-top: 36px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,.12);
	display: flex;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
	align-items: center;
}
.uk-platform__tail p { color: rgba(255,255,255,.7); font-style: italic; font-weight: 500; font-size: 17px; max-width: 48ch; margin: 0; }
@media (max-width: 1024px) { .uk-platform__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .uk-platform__grid { grid-template-columns: 1fr; } }

/* Industry Compliance & standards (R5) */
.uk-compliance { padding-block: var(--section); }
.uk-compliance__grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 0;
	border-top: 1px solid var(--ink);
}
.uk-compliance__col {
	padding: 32px 28px 32px 0;
	border-right: 1px solid var(--hairline);
}
.uk-compliance__col + .uk-compliance__col { padding-left: 28px; }
.uk-compliance__col:last-child { border-right: 0; padding-right: 0; }
.uk-compliance__lab {
	font-size: 11px; letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--green-dk); font-weight: 700;
}
.uk-compliance__h {
	font-family: var(--font-sans);
	font-weight: 600; font-size: 20px;
	letter-spacing: -0.005em;
	margin: 14px 0;
}
.uk-compliance__body { color: var(--muted); font-size: 14.5px; line-height: 1.65; max-width: 34ch; margin-bottom: 16px; }
.uk-compliance__bullets {
	list-style: none;
	display: grid;
	gap: 10px;
	border-top: 1px solid var(--hairline);
	padding: 14px 0 0;
	margin: 0;
}
.uk-compliance__bullets li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 10px;
	align-items: baseline;
	font-size: 13px;
	color: var(--ink);
}
.uk-compliance__bullets li::before { content: "●"; color: var(--green); font-size: 8px; }
.uk-compliance__seals {
	display: flex; flex-wrap: wrap; gap: 14px;
	align-items: center;
	margin-top: 32px; padding-top: 24px;
	border-top: 1px solid var(--hairline);
}
.uk-compliance__seals-lab {
	font-size: 11px; letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--muted); font-weight: 700;
	margin-right: 8px;
}
.uk-compliance__seal { width: 72px; height: 72px; }
.uk-compliance__ctas { margin-top: 32px; display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 900px) {
	.uk-compliance__grid { grid-template-columns: 1fr; }
	.uk-compliance__col {
		border-right: 0;
		padding: 24px 0 !important;
		border-bottom: 1px solid var(--hairline);
	}
	.uk-compliance__col:last-child { border-bottom: 0; }
}

/* Lead CTA — final form section */
.uk-lead { background: var(--surface); padding-block: var(--section); }
.uk-lead__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: start;
}
.uk-lead__copy .uk-section__h2 {
	font-size: clamp(36px, 4.4vw, 60px);
	max-width: 14ch;
}
.uk-lead__intro {
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: clamp(19px, 1.7vw, 24px);
	line-height: 1.45;
	color: var(--ink);
	margin-top: 22px;
	max-width: 42ch;
	letter-spacing: -0.005em;
}
.uk-lead__meta {
	margin-top: 48px;
	padding-top: 24px;
	border-top: 1px solid var(--hairline);
	display: flex;
	gap: 32px;
	flex-wrap: wrap;
	font-size: 13px;
	color: var(--muted);
}
.uk-lead__meta strong {
	color: var(--ink);
	display: block;
	font-size: 11px;
	letter-spacing: 0.22em;
	margin-bottom: 4px;
	font-weight: 700;
	text-transform: uppercase;
}
.uk-lead__form input,
.uk-lead__form select,
.uk-lead__form textarea {
	width: 100%;
	padding: 14px 0;
	border: 0;
	border-bottom: 1px solid var(--ink);
	background: transparent;
	color: var(--ink);
	font: inherit;
	font-size: 16px;
	border-radius: 0;
}
.uk-lead__form input:focus,
.uk-lead__form select:focus,
.uk-lead__form textarea:focus { outline: none; border-bottom-color: var(--green-dk); }
.uk-lead__form button[type=submit] {
	margin-top: 12px;
	background: var(--ink);
	color: var(--white);
	border: 0;
	padding: 15px 24px;
	font-weight: 500;
	font-size: 15px;
	cursor: pointer;
}
.uk-lead__form button[type=submit]:hover { background: var(--green-dk); }
@media (max-width: 900px) {
	.uk-lead__grid { grid-template-columns: 1fr; gap: 32px; }
}

/* Trust strip */
.uk-trust {
	background: var(--surface);
	border-top: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
	padding: 28px 0;
}
.uk-trust .uk-container {
	display: flex;
	justify-content: center;
	gap: 32px;
	flex-wrap: wrap;
	align-items: center;
	font-size: 13.5px;
	letter-spacing: 0.04em;
	color: var(--ink);
	font-weight: 500;
}
.uk-trust strong { color: var(--green-dk); font-weight: 700; }
.uk-trust__sep { color: var(--quiet); }

/* Pull testimonial */
.uk-pull {
	background: var(--ink);
	color: var(--white);
	padding: clamp(80px, 10vw, 140px) 0;
}
.uk-pull .uk-container { max-width: 980px; }
.uk-pull blockquote {
	font-family: var(--font-sans);
	font-weight: 500;
	font-style: italic;
	font-size: clamp(28px, 3.6vw, 46px);
	line-height: 1.25;
	letter-spacing: -0.012em;
	color: var(--white);
	margin: 0;
}
.uk-pull__m { color: var(--green); font-style: normal; font-weight: 600; }
.uk-pull cite {
	font-style: normal;
	display: block;
	margin-top: 36px;
	padding-top: 22px;
	border-top: 1px solid rgba(255,255,255,.2);
	max-width: 480px;
}
.uk-pull__n { font-size: 15px; font-weight: 600; letter-spacing: 0.02em; display: block; }
.uk-pull__r { font-size: 13px; color: rgba(255,255,255,.6); margin-top: 4px; letter-spacing: 0.04em; display: block; }
.uk-pull__tags {
	margin-top: 32px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,.1);
}
.uk-pull__tag {
	font-size: 10.5px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
	font-weight: 600;
	padding: 5px 10px;
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 2px;
}

/* ==========================================================================
   22. Cookie consent banner
   ========================================================================== */
.uk-ck { position: fixed; left: 0; right: 0; bottom: 0; z-index: 80; padding: var(--pad); pointer-events: none; }
.uk-ck.is-shown { pointer-events: auto; }
.uk-ck__panel {
	max-width: 520px;
	margin: 0 0 0 auto;
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 4px;
	box-shadow: 0 24px 60px -16px rgba(11,30,63,.35);
	padding: 24px;
	transform: translateY(20px);
	opacity: 0;
	transition: transform .35s var(--ease), opacity .35s var(--ease);
}
.uk-ck.is-shown .uk-ck__panel { transform: translateY(0); opacity: 1; }
.uk-ck__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 8px; }
.uk-ck__title { font-size: 17px; font-weight: 600; line-height: 1.3; margin: 0; color: var(--ink); }
.uk-ck__close { width: 32px; height: 32px; border: 0; background: transparent; color: var(--quiet); font-size: 24px; line-height: 1; cursor: pointer; flex-shrink: 0; }
.uk-ck__close:hover { color: var(--ink); }
.uk-ck__body { color: var(--muted); font-size: 14px; line-height: 1.55; margin: 0 0 18px; }
.uk-ck__cats { display: grid; gap: 12px; padding: 14px 0; margin: 0 0 18px; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.uk-ck__cat { display: grid; grid-template-columns: 22px 1fr; gap: 12px; align-items: start; cursor: pointer; }
.uk-ck__cat input { margin-top: 4px; accent-color: var(--green); }
.uk-ck__cat.is-locked { cursor: default; opacity: 0.85; }
.uk-ck__cat-name { display: block; font-size: 14px; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.uk-ck__cat-name em { font-style: normal; font-weight: 500; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--green-dk); margin-left: 6px; }
.uk-ck__cat-desc { display: block; font-size: 13px; color: var(--muted); line-height: 1.5; }
.uk-ck__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.uk-ck__actions .uk-btn { padding: 10px 16px; font-size: 13.5px; }
.uk-ck__links { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--hairline); font-size: 12.5px; color: var(--quiet); }
.uk-ck__links a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }
.uk-ck__links a:hover { color: var(--green-dk); }
.uk-ck__links span { margin-inline: 8px; }

@media (max-width: 540px) {
	.uk-ck { padding: 12px; }
	.uk-ck__panel { max-width: 100%; padding: 18px; }
}

/* Bump the chat widget above the cookie banner */
.uk-chat { z-index: 70; }
.uk-ck { z-index: 80; }

/* ==========================================================================
   23. Fluent Forms theming — overrides FF defaults to match SBL look
   ========================================================================== */
.ff-default,
.fluentform .ff-el-form-control,
.fluentform input[type="text"],
.fluentform input[type="email"],
.fluentform input[type="number"],
.fluentform input[type="url"],
.fluentform input[type="tel"],
.fluentform select,
.fluentform textarea {
	width: 100% !important;
	padding: 12px 0 !important;
	border: 0 !important;
	border-bottom: 1px solid var(--ink) !important;
	background: transparent !important;
	color: var(--ink) !important;
	font: inherit !important;
	font-size: 16px !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	min-height: auto !important;
	height: auto !important;
	transition: border-color var(--t-fast);
}
.fluentform .ff-el-form-control:focus,
.fluentform input:focus,
.fluentform select:focus,
.fluentform textarea:focus {
	outline: none !important;
	border-bottom-color: var(--green-dk) !important;
	box-shadow: none !important;
}
.fluentform textarea { min-height: 96px !important; }
.fluentform .ff-el-input--label label,
.fluentform label {
	font-size: 11px !important;
	letter-spacing: .18em !important;
	color: var(--muted) !important;
	text-transform: uppercase !important;
	font-weight: 600 !important;
	margin-bottom: 4px !important;
	display: block !important;
}
.fluentform .ff-el-is-required.asterisk-right label::after {
	content: " *";
	color: var(--green-dk);
}
.fluentform .ff-el-group { margin-bottom: 18px !important; padding: 0 !important; }
.fluentform .ff-el-input--content { padding: 0 !important; }

/* Submit button — match our brand button style */
.fluentform .ff-btn,
.fluentform button[type="submit"],
.fluentform .ff-btn-submit {
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 14px 22px !important;
	background: var(--ink) !important;
	color: var(--white) !important;
	border: 0 !important;
	border-radius: 2px !important;
	font: inherit !important;
	font-weight: 500 !important;
	font-size: 15px !important;
	letter-spacing: .02em !important;
	cursor: pointer !important;
	box-shadow: none !important;
	margin-top: 12px !important;
	transition: background var(--t-fast) !important;
	min-height: auto !important;
	height: auto !important;
}
.fluentform .ff-btn:hover,
.fluentform button[type="submit"]:hover {
	background: var(--green-dk) !important;
}

/* Validation messages */
.fluentform .error,
.fluentform .ff-el-is-error {
	color: var(--red) !important;
	font-size: 12px !important;
	margin-top: 4px !important;
}
.fluentform .ff-el-is-error input,
.fluentform .ff-el-is-error select,
.fluentform .ff-el-is-error textarea {
	border-bottom-color: var(--red) !important;
}

/* Success message after submit */
.fluentform .ff-message-success,
.fluentform_wrapper_form_id_3 .ff-message-success,
.ff_form_success {
	padding: 18px 20px !important;
	background: var(--surface) !important;
	border-left: 3px solid var(--green) !important;
	color: var(--ink) !important;
	font-size: 15px !important;
	font-weight: 500 !important;
	border-radius: 0 !important;
}

/* Newsletter form — horizontal email + button on Insights */
.uk-newsletter__form .fluentform { display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap; }
.uk-newsletter__form .ff-el-group { flex: 1 1 240px; margin-bottom: 0 !important; }
.uk-newsletter__form .ff-el-form-control { color: var(--white) !important; border-bottom-color: rgba(255,255,255,.4) !important; }
.uk-newsletter__form .ff-el-form-control:focus { border-bottom-color: var(--green) !important; }
.uk-newsletter__form .ff-el-form-control::placeholder { color: rgba(255,255,255,.45) !important; }
.uk-newsletter__form label { color: rgba(255,255,255,.6) !important; }
.uk-newsletter__form .ff-btn { background: var(--green) !important; }
.uk-newsletter__form .ff-btn:hover { background: var(--green-dk) !important; }

/* Wrap select dropdown in our look (Fluent uses a custom div sometimes) */
.fluentform .ff-el-select { background: transparent !important; }
.fluentform select { appearance: auto; cursor: pointer; }

/* ==========================================================================
   24. Hero "records" animations + visual quote (parity with mockup)
   ========================================================================== */
.uk-vis--records .records .row {
	transform-origin: 0 50%;
	animation: uk-row-shimmer 4.4s ease-in-out infinite;
}
.uk-vis--records .records .row:nth-of-type(2) { animation-delay: -0.6s; }
.uk-vis--records .records .row:nth-of-type(3) { animation-delay: -1.4s; }
.uk-vis--records .records .row:nth-of-type(4) { animation-delay: -2.1s; }
.uk-vis--records .records .row:nth-of-type(5) { animation-delay: -2.8s; }
.uk-vis--records .records .row:nth-of-type(6) { animation-delay: -3.5s; }
.uk-vis--records .records .row.hi    { animation: uk-row-hi-pulse 2.6s ease-in-out infinite; }
.uk-vis--records .records .row.write { animation: uk-row-write 3.4s cubic-bezier(.6,.05,.4,1) infinite; }
.uk-vis--records .records .scanbeam  { animation: uk-rec-scan 6s cubic-bezier(.55,.05,.45,1) infinite; }
.uk-vis--records .records .idx-label { animation: uk-idx-flicker 4.2s steps(1,end) infinite; transform-origin: left center; }
.uk-vis--records .records .idx-label:nth-of-type(2) { animation-delay: -1.4s; }
.uk-vis--records .records .idx-label:nth-of-type(3) { animation-delay: -2.8s; }

@keyframes uk-row-shimmer {
	0%, 100% { transform: scaleX(1);   opacity: 1; }
	50%      { transform: scaleX(.96); opacity: .82; }
}
@keyframes uk-row-hi-pulse {
	0%, 100% { opacity: 1; }
	50%      { opacity: .55; }
}
@keyframes uk-row-write {
	0%   { transform: scaleX(0); opacity: 0; }
	8%   { opacity: 1; }
	55%  { transform: scaleX(1); opacity: 1; }
	100% { transform: scaleX(1); opacity: .85; }
}
@keyframes uk-rec-scan {
	0%   { transform: translateY(40px);  opacity: 0; }
	6%   { opacity: 1; }
	94%  { opacity: 1; }
	100% { transform: translateY(700px); opacity: 0; }
}
@keyframes uk-idx-flicker {
	0%, 92%, 100% { opacity: .4; }
	93%, 95%      { opacity: .15; }
	94%           { opacity: .7; }
}

/* Pulse dot on the "Record → Data" tag */
.uk-vis--records .uk-vis__tag::before { animation: uk-rec-pulse 1.4s ease-in-out infinite; }
@keyframes uk-rec-pulse {
	0%, 100% { box-shadow: 0 0 6px  rgba(118,188,33,.5),  0 0 0 0   rgba(118,188,33,.5); opacity: 1; }
	50%      { box-shadow: 0 0 16px rgba(118,188,33,.95), 0 0 0 6px rgba(118,188,33,0); opacity: .55; }
}

/* Word-by-word visual quote */
.uk-vis__q--anim {
	position: absolute; left: 34px; right: 34px; bottom: 34px;
	padding: 14px 0 14px 18px;
	color: rgba(255,255,255,.9);
	font-size: 15px; font-weight: 500; font-style: italic;
	line-height: 1.5;
	max-width: 36ch;
	overflow: hidden;
}
.uk-vis__q--anim::before {
	content: "";
	position: absolute; left: 0; top: 14px; bottom: 14px; width: 2px;
	background: var(--green);
	transform-origin: top center;
	transform: scaleY(0);
	box-shadow: 0 0 14px rgba(118,188,33,.55);
	animation: uk-vq-bar 1.05s cubic-bezier(.7,0,.2,1) .15s forwards,
	           uk-vq-bar-breathe 3.6s ease-in-out 1.6s infinite;
}
.uk-vis__q--anim::after {
	content: "";
	position: absolute; left: 18px; right: 0; height: 36px; top: -36px;
	background: linear-gradient(180deg, transparent 0%, rgba(118,188,33,0) 30%, rgba(118,188,33,.32) 50%, rgba(118,188,33,0) 70%, transparent 100%);
	pointer-events: none;
	animation: uk-vq-scan 2.1s cubic-bezier(.6,.05,.3,1) .55s 1 both;
}
.uk-vis__q--anim .quote-text { display: block; position: relative; z-index: 1; }
.uk-vis__q--anim .w {
	display: inline-block; margin-right: 0.28em;
	opacity: 0; filter: blur(6px); transform: translateY(6px);
	animation: uk-vq-word .55s cubic-bezier(.2,.7,.25,1) both;
	animation-delay: calc(.7s + var(--i) * 0.07s);
}
.uk-vis__q--anim .caret {
	display: inline-block; width: 7px; height: 1em;
	background: var(--green); vertical-align: -2px; margin-left: 4px;
	box-shadow: 0 0 10px rgba(118,188,33,.7);
	opacity: 0;
	animation: uk-vq-caret-on 0s 1.55s forwards,
	           uk-vq-blink 1.05s steps(1,end) 1.55s infinite;
}
.uk-vis__q--anim .cite {
	display: block; margin-top: 10px;
	font-style: normal; font-weight: 600; font-size: 10.5px; letter-spacing: .2em;
	text-transform: uppercase; color: var(--green);
	opacity: 0; transform: translateY(6px);
	animation: uk-vq-cite .7s cubic-bezier(.2,.7,.25,1) 1.85s both;
}
@keyframes uk-vq-bar         { 0% { transform: scaleY(0); } 100% { transform: scaleY(1); } }
@keyframes uk-vq-bar-breathe { 0%, 100% { box-shadow: 0 0 10px rgba(118,188,33,.45); opacity: .9; } 50% { box-shadow: 0 0 20px rgba(118,188,33,.85); opacity: 1; } }
@keyframes uk-vq-scan        { 0% { top: -36px; opacity: 0; } 10% { opacity: 1; } 90% { opacity: 1; } 100% { top: 100%; opacity: 0; } }
@keyframes uk-vq-word        { to { opacity: 1; filter: blur(0); transform: translateY(0); } }
@keyframes uk-vq-caret-on    { to { opacity: 1; } }
@keyframes uk-vq-blink       { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } }
@keyframes uk-vq-cite        { to { opacity: 1; transform: translateY(0); } }

@media (prefers-reduced-motion: reduce) {
	.uk-vis--records .records .row,
	.uk-vis--records .records .row.hi,
	.uk-vis--records .records .row.write,
	.uk-vis--records .records .scanbeam,
	.uk-vis--records .records .idx-label,
	.uk-vis--records .uk-vis__tag::before,
	.uk-vis__q--anim::before, .uk-vis__q--anim::after,
	.uk-vis__q--anim .w, .uk-vis__q--anim .caret, .uk-vis__q--anim .cite {
		animation: none !important; transform: none !important; opacity: 1;
	}
	.uk-vis__q--anim::before { transform: scaleY(1); }
	.uk-vis__q--anim .w, .uk-vis__q--anim .cite { filter: none; }
}

/* ==========================================================================
   25. Footer mid-band (certs strip + social) + bottom legal links
   ========================================================================== */
.uk-footer__mid {
	display: flex; justify-content: space-between; align-items: center;
	gap: 20px; flex-wrap: wrap;
	padding: 28px 0;
	border-bottom: 1px solid rgba(255,255,255,.1);
}
.uk-footer__certs {
	display: flex; gap: 22px; flex-wrap: wrap;
	font-size: 12px; color: rgba(255,255,255,.72); letter-spacing: .04em;
}
.uk-footer__certs span strong { color: var(--white); font-weight: 600; }
.uk-footer__bottom {
	padding-top: 24px;
	display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap;
	font-size: 12.5px; color: rgba(255,255,255,.54);
	border-top: 0;
}
.uk-footer__bottom a { color: rgba(255,255,255,.7); }
.uk-footer__bottom a:hover { color: var(--green); }
.uk-footer__legal-links { display: inline-flex; gap: 8px; flex-wrap: wrap; }
.uk-footer__legal-links span.sep { color: rgba(255,255,255,.3); }
.uk-footer__social { display: flex; gap: 10px; }
.uk-footer__social a {
	width: 36px; height: 36px; border-radius: 2px;
	border: 1px solid rgba(255,255,255,.2);
	display: inline-flex; align-items: center; justify-content: center;
	color: rgba(255,255,255,.72); font-size: 12px;
}
.uk-footer__social a:hover { color: var(--green); border-color: var(--green); }

/* ==========================================================================
   26. Engage list — tighten alignment of the number + title baseline
   ========================================================================== */
.uk-h-engage ol li { align-items: start; }
.uk-h-engage ol li::before { padding-top: 4px; }
.uk-h-engage ol li h4 { line-height: 1.2; }

/* Receipts masthead — keep the headline left-anchored & not overflowing */
.uk-h-receipts__masthead h2.uk-display { line-height: 1.04; }
.uk-h-receipts__row .copy h3 { line-height: 1.1; }

/* "Read more" / "Read the case" arrow links — match HTML hover */
.uk-h-disc__row a.go,
.uk-h-receipts__row a.go { transition: color var(--t-fast); }

/* ==========================================================================
   27. Corner frame inside the hero visual (parity with mockup)
   ========================================================================== */
.uk-vis__frame {
	position: absolute;
	inset: 20px;
	border: 1px solid rgba(255, 255, 255, .1);
	pointer-events: none;
	z-index: 1;
}

/* Anchor the cap/tag/quote above the corner frame */
.uk-vis__cap, .uk-vis__tag, .uk-vis__q { z-index: 2; }
/* Push the cap inside the frame so it visually anchors to it (matches mockup) */
.uk-vis--records .uk-vis__cap { top: 30px; left: 34px; }
.uk-vis--records .uk-vis__tag { top: 30px; right: 34px; }

/* ==========================================================================
   28. Force consistent section width (kill the inherited root padding leftover)
   ========================================================================== */
.wp-site-blocks { padding-inline: 0 !important; }
body > .is-layout-flow > * { max-width: none !important; }

/* All home + CPT-detail section wrappers should be edge-to-edge so the
   coloured backgrounds (Actigen ink, Pull ink) bleed full-width like the
   mockup, with .uk-container holding the gutter. */
.uk-h-hero, .uk-h-brief, .uk-h-disc, .uk-h-actigen, .uk-h-receipts,
.uk-h-industries, .uk-h-engage, .uk-h-pull, .uk-h-roster, .uk-h-contact {
	width: 100%;
	max-width: none;
	margin-inline: 0;
}

/* ==========================================================================
   29. Dark-background heading colour fixes
   ========================================================================== */
/* Actigen (ink bg) — make sure h2 stays white even when global h2 element
   styles from theme.json paint --ink. */
.uk-h-actigen h2,
.uk-h-actigen .uk-display { color: var(--white); }
.uk-h-actigen .uk-display em { color: var(--green); }
.uk-h-actigen p, .uk-h-actigen li { color: rgba(255,255,255,.85); }

/* Pull quote section */
.uk-h-pull blockquote,
.uk-h-pull cite,
.uk-h-pull cite .n,
.uk-h-pull cite .r { color: var(--white); }
.uk-h-pull cite .r { color: rgba(255,255,255,.65); }

/* Footer headings */
.uk-footer h2, .uk-footer h3, .uk-footer h4 { color: var(--white); }

/* ==========================================================================
   30. Company page — Batch 1 (timeline accent, glance footnote, careers values)
   ========================================================================== */
/* Timeline accent — green dot + green-dk year */
.uk-timeline__item--accent .uk-timeline__year { color: var(--green-dk); }
.uk-timeline__item--accent::before {
	background: var(--green) !important;
	border-color: var(--green) !important;
}

/* Glance footnote */
.uk-glance__foot {
	margin-top: 24px;
	font-size: 12.5px;
	color: var(--quiet);
	letter-spacing: .02em;
	font-style: italic;
}

/* Careers values strip (3 columns above filters/roles) */
.uk-careers__values {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	padding: 32px 0;
	border-top: 1px solid var(--hairline);
	border-bottom: 1px solid var(--hairline);
	margin-bottom: 48px;
}
.uk-careers__value .lab { font-family: 'Poppins', sans-serif; font-size: 20px; color: var(--green-dk); font-weight: 500; line-height: 1; letter-spacing: -0.005em; }
.uk-careers__value h4 { font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 18px; margin: 12px 0 8px; color: var(--ink); letter-spacing: -0.005em; }
.uk-careers__value p { color: var(--muted); font-size: 14.5px; line-height: 1.6; max-width: 36ch; margin: 0; }
@media (max-width: 900px) {
	.uk-careers__values { grid-template-columns: 1fr; gap: 24px; }
}

/* Sub-nav: ensure new items wrap nicely on narrow screens */
.uk-subnav__inner { flex-wrap: wrap; }

/* ==========================================================================
   31. Company page — Batch 2
   - Recognition: 3 blocks (Awards / Certifications / Partners) with badges
   - Careers benefits: 4-column tile grid
   - Life at SBL: 5-tile mosaic + pull quote + CTA
   ========================================================================== */

/* --- Recognition 3-block layout --- */
.uk-recog__masthead { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: end; margin-bottom: 56px; }
.uk-recog__intro { color: var(--muted); font-size: 16px; max-width: 48ch; }
.uk-recog__block {
	padding: 36px 0;
	border-top: 1px solid var(--hairline);
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 56px;
	align-items: center;
}
.uk-recog__block:last-of-type { border-bottom: 1px solid var(--hairline); }
.uk-recog__label {
	font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
	color: var(--green-dk); font-weight: 700;
}
.uk-recog__badge {
	display: inline-flex; width: 26px; height: 22px;
	align-items: center; justify-content: center;
	background: var(--ink); color: var(--white);
	margin-right: 10px; font-size: 11px;
}
.uk-recog__desc {
	display: block; margin-top: 8px;
	color: var(--muted); font-size: 13px;
	letter-spacing: 0; text-transform: none; font-weight: 400; line-height: 1.5;
	max-width: 22ch;
}
.uk-recog__row { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; }

.uk-recog__award {
	display: flex; flex-direction: column; gap: 4px;
	padding: 16px 22px; border: 1px solid var(--hairline); border-radius: 2px;
	background: var(--surface); min-width: 180px;
}
.uk-recog__award-name { font-size: 13px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; }
.uk-recog__award-yr   { font-size: 11px; color: var(--quiet); letter-spacing: .1em; font-weight: 600; }

.uk-recog__cert       { color: var(--ink); }
.uk-recog__cert .uk-cert-seal { width: 84px; height: 84px; transition: transform .2s ease; }
.uk-recog__cert .uk-cert-seal:hover { transform: scale(1.05); }
.uk-recog__cert-logo  { height: 84px; width: auto; }

.uk-recog__partner {
	padding: 18px 24px; border: 1px solid var(--hairline); border-radius: 2px;
	background: var(--white); font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 14px; color: var(--ink);
	letter-spacing: .02em; min-width: 130px; text-align: center;
}
.uk-recog__partner:hover { border-color: var(--ink); }

@media (max-width: 900px) {
	.uk-recog__masthead, .uk-recog__block { grid-template-columns: 1fr; gap: 24px; }
}

/* --- Careers benefits 4-column tile grid --- */
.uk-careers__benefits {
	margin-top: 56px;
	padding-top: 32px;
	border-top: 1px solid var(--hairline);
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	list-style: none;
}
.uk-careers__benefit { display: flex; flex-direction: column; gap: 6px; }
.uk-careers__benefit .b-lab { font-size: 13px; color: var(--green-dk); font-weight: 700; letter-spacing: .12em; }
.uk-careers__benefit strong { font-size: 16px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; }
.uk-careers__benefit p { color: var(--muted); font-size: 14px; line-height: 1.6; }
@media (max-width: 1024px) { .uk-careers__benefits { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .uk-careers__benefits { grid-template-columns: 1fr; } }

/* --- Life at SBL: 2-column hero with mosaic on the left --- */
.uk-c-life__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}
.uk-c-life__mosaic {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-template-rows: repeat(3, 1fr);
	gap: 8px;
	aspect-ratio: 5/4;
}
.uk-c-life__tile {
	position: relative;
	overflow: hidden;
	border-radius: 2px;
	background: linear-gradient(135deg, var(--ink), #1a3060);
}
.uk-c-life__tile::after {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(circle at 30% 20%, rgba(118,188,33,.18), transparent 60%), repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
	pointer-events: none;
}
/* Tile 1 (large) spans 2 cols × 2 rows in top-left, green gradient */
.uk-c-life__mosaic > .uk-c-life__tile:nth-child(1) {
	grid-column: span 2; grid-row: span 2;
	background: linear-gradient(135deg, #0B4530, var(--green));
}
/* Alternating blue tile */
.uk-c-life__tile--b { background: linear-gradient(135deg, #1B2E52, var(--blue)); }
.uk-c-life__tile img { width: 100%; height: 100%; object-fit: cover; display: block; position: relative; z-index: 1; }
.uk-c-life__cap {
	position: relative; z-index: 1;
	color: rgba(255,255,255,.85);
	font-size: 11px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600;
}
.uk-c-life__tile:has(.uk-c-life__cap) { display: flex; align-items: flex-end; padding: 18px; }
.uk-c-life__copy .uk-display { font-size: clamp(34px, 4vw, 52px); max-width: 16ch; margin: 14px 0 0; }
.uk-c-life__prose { margin-top: 24px; }
.uk-c-life__prose p { color: var(--muted); font-size: 16px; line-height: 1.7; max-width: 48ch; margin: 0; }
.uk-c-life__prose p + p { margin-top: 18px; }
.uk-c-life__pull {
	margin: 28px 0 0; padding: 20px 24px;
	background: var(--white); border-left: 3px solid var(--green);
	font-family: 'Poppins', sans-serif;
	font-style: italic; font-weight: 500; font-size: 18px; line-height: 1.5; color: var(--ink);
}
.uk-c-life__pull cite {
	display: block; margin-top: 10px;
	font-style: normal; font-size: 11px; letter-spacing: .2em;
	text-transform: uppercase; color: var(--green-dk); font-weight: 700;
}
.uk-c-life__cta { margin-top: 32px; }
@media (max-width: 900px) {
	.uk-c-life__grid    { grid-template-columns: 1fr; gap: 32px; }
}

/* ==========================================================================
   32. Company page — Batch 3
   - Locations: world map with markers (HQ pulses) + coverage line
   - Sub-nav active-state styling (scroll-spy paints .is-active)
   ========================================================================== */

/* Locations section is on a dark background like the mockup */
.uk-loc { background: var(--ink); color: var(--white); padding-block: var(--section); }
.uk-loc .uk-section__head .uk-kicker { color: rgba(255,255,255,.55); }
.uk-loc .uk-section__head h2.uk-display { color: var(--white); }
.uk-loc__lede { color: rgba(255,255,255,.7); margin-bottom: 32px; max-width: 60ch; }

.uk-loc__map-wrap {
	background: rgba(255,255,255,.03);
	border: 1px solid rgba(255,255,255,.1);
	border-radius: 2px;
	padding: 32px;
	margin-bottom: 48px;
	position: relative;
}
.uk-loc__map { width: 100%; height: auto; display: block; }
.uk-loc__map--uk { max-width: 380px; max-height: 560px; margin: 0 auto; }
@media (max-width: 640px) { .uk-loc__map--uk { max-height: 420px; } }

/* eParliament — chamber visual mockup */
.uk-product-hero__visual { display: flex; align-items: center; justify-content: center; }
.uk-chamber {
	background: linear-gradient(180deg, #0B1E3F 0%, #0a1730 100%);
	border-radius: 8px;
	padding: 18px 18px 14px;
	color: #fff;
	font-family: 'Poppins', sans-serif;
	box-shadow: 0 12px 40px rgba(0,0,0,.35);
	max-width: 460px;
	width: 100%;
}
.uk-chamber__bar {
	display: flex; justify-content: space-between; align-items: center;
	font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
	color: rgba(255,255,255,.7);
	margin-bottom: 8px;
}
.uk-chamber__live { color: #76BC21; font-weight: 600; animation: uk-rec-pulse 1.6s ease-in-out infinite; }
.uk-chamber__bowl svg { width: 100%; height: auto; display: block; }
.uk-chamber .seat { fill: rgba(255,255,255,.32); transition: fill .6s ease; }
.uk-chamber .seat.active { fill: #76BC21; animation: uk-chamber-pulse 1.4s ease-in-out infinite; }
.uk-chamber__panel {
	display: grid; grid-template-columns: 1fr 1fr; gap: 6px 16px;
	border-top: 1px solid rgba(255,255,255,.12);
	border-bottom: 1px solid rgba(255,255,255,.12);
	padding: 10px 4px; margin: 6px 0;
}
.uk-chamber__row { display: flex; flex-direction: column; gap: 2px; }
.uk-chamber__row .k { font-size: 9px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.5); }
.uk-chamber__row .v { font-size: 12px; color: #fff; font-weight: 500; }
.uk-chamber__row .v em { color: #76BC21; font-style: normal; font-weight: 600; }
.uk-chamber__log {
	display: flex; align-items: center; gap: 8px;
	font-size: 10.5px; color: rgba(255,255,255,.65);
	padding-top: 4px;
}
.uk-chamber__dot {
	width: 6px; height: 6px; border-radius: 50%;
	background: #76BC21; box-shadow: 0 0 8px #76BC21;
	animation: uk-rec-pulse 1.6s ease-in-out infinite;
}
.uk-chamber__item { font-family: 'JetBrains Mono', monospace; font-size: 11px; }
@keyframes uk-chamber-pulse { 0%,100% { fill: #76BC21; opacity: 1; } 50% { fill: #76BC21; opacity: 0.45; } }
@media (prefers-reduced-motion: reduce) { .uk-chamber .seat.active, .uk-chamber__dot, .uk-chamber__live { animation: none; } }
@media (max-width: 640px) { .uk-chamber__panel { grid-template-columns: 1fr; } }
.uk-loc__map-tag {
	position: absolute; top: 24px; left: 32px;
	font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase;
	color: var(--green); font-weight: 600;
	display: inline-flex; align-items: center; gap: 8px;
}
.uk-loc__map-tag::before {
	content: ""; width: 7px; height: 7px; border-radius: 50%;
	background: var(--green); box-shadow: 0 0 10px var(--green);
	animation: uk-rec-pulse 1.6s ease-in-out infinite;
}
.uk-loc__marker--hq circle.pulse {
	transform-origin: center;
	transform-box: fill-box;
	animation: uk-marker-pulse 2.2s ease-out infinite;
}
@keyframes uk-marker-pulse {
	0%   { transform: scale(1);   opacity: .55; }
	100% { transform: scale(4.5); opacity: 0;   }
}
@media (prefers-reduced-motion: reduce) {
	.uk-loc__marker--hq circle.pulse { animation: none; opacity: 0; }
	.uk-loc__map-tag::before         { animation: none; }
}

/* Office cells on dark bg — cell-based mockup layout */
.uk-loc__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border-top: 1px solid rgba(255,255,255,.18);
}
.uk-loc__card {
	padding: 32px 28px 32px 0;
	border-right: 1px solid rgba(255,255,255,.12);
	border-bottom: 1px solid rgba(255,255,255,.12);
	background: transparent;
	border-radius: 0;
	color: rgba(255,255,255,.85);
}
.uk-loc__card + .uk-loc__card { padding-left: 28px; }
.uk-loc__card:nth-child(3n) { border-right: 0; padding-right: 0; }
.uk-loc__card:nth-child(3n+1) { padding-left: 0; }
.uk-loc__card--hq { /* no special border; HQ tag handles emphasis */ }
.uk-loc__country  { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--green); font-weight: 700; margin-bottom: 4px; display: flex; align-items: center; gap: 10px; }
.uk-loc__country--hq { color: var(--white); }
.uk-loc__country--hq::after { content: " · HQ"; color: var(--green); }
.uk-loc__hq-tag    { display: none; }
.uk-loc__city      { font-family: 'Poppins', sans-serif; font-size: 19px; font-weight: 600; color: var(--white); margin: 0 0 10px; letter-spacing: -0.005em; }
.uk-loc__addr      { font-size: 13.5px; line-height: 1.6; color: rgba(255,255,255,.72); margin-bottom: 8px; }
.uk-loc__phone     { font-size: 13px; color: rgba(255,255,255,.85); letter-spacing: .02em; margin-bottom: 14px; font-variant-numeric: tabular-nums; }
.uk-loc__meta      { display: flex; gap: 32px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.08); margin: 0; flex-wrap: wrap; }
.uk-loc__meta dt   { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.45); font-weight: 600; margin: 0; }
.uk-loc__meta dd   { font-size: 13px; color: rgba(255,255,255,.85); margin: 2px 0 0; }

@media (max-width: 1024px) {
	.uk-loc__grid { grid-template-columns: repeat(2, 1fr); }
	.uk-loc__card { padding: 28px 24px 28px 0; border-right: 1px solid rgba(255,255,255,.12); }
	.uk-loc__card + .uk-loc__card { padding-left: 24px; }
	.uk-loc__card:nth-child(3n) { border-right: 1px solid rgba(255,255,255,.12); padding-right: 24px; }
	.uk-loc__card:nth-child(3n+1) { padding-left: 24px; }
	.uk-loc__card:nth-child(2n) { border-right: 0; padding-right: 0; }
	.uk-loc__card:nth-child(2n+1) { padding-left: 0; }
}
@media (max-width: 600px)  {
	.uk-loc__grid { grid-template-columns: 1fr; }
	.uk-loc__card { padding: 24px 0 !important; border-right: 0 !important; }
}

.uk-loc__coverage {
	margin-top: 32px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,.08);
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 32px;
	align-items: baseline;
}
.uk-loc__coverage-label {
	font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
	color: var(--green); font-weight: 700;
}
.uk-loc__coverage-text { font-size: 16px; line-height: 1.6; color: rgba(255,255,255,.85); }
.uk-loc__coverage-text em { color: var(--green); font-style: normal; font-weight: 600; }
@media (max-width: 600px) { .uk-loc__coverage { grid-template-columns: 1fr; gap: 12px; } }

/* Sub-nav scroll-spy active state (set by JS, see assets/js/main.js) */
.uk-subnav__inner a {
	position: relative;
	transition: color var(--t-fast);
}
.uk-subnav__inner a.is-active {
	color: var(--green-dk);
}
.uk-subnav__inner a.is-active::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -8px;
	height: 2px; background: var(--green);
}

/* ----- Service: Problems tile (lab + q + a) ----- */
.uk-problems__item { display: flex; flex-direction: column; gap: 14px; }
.uk-problems__lab {
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--green);
}
.uk-problems__q {
	font-size: 18px;
	font-weight: 600;
	line-height: 1.45;
	color: var(--white);
	margin: 0;
	letter-spacing: -0.005em;
}
.uk-problems__a {
	font-size: 14.5px;
	line-height: 1.6;
	color: rgba(255,255,255,.78);
	margin: 0;
}
.uk-problems__a strong { color: var(--white); font-weight: 600; }

/* ----- Service: Capabilities meta + tail ----- */
.uk-cap__card { display: flex; flex-direction: column; gap: 8px; }
.uk-cap__meta { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.uk-cap__tag {
	font-size: 11px;
	letter-spacing: .04em;
	font-weight: 600;
	color: var(--muted);
	padding: 4px 10px;
	border: 1px solid var(--hairline);
	border-radius: 999px;
	background: var(--surface);
}
.uk-cap__tail {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--hairline);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 32px;
	align-items: center;
}
.uk-cap__tail p {
	font-style: italic;
	font-size: 17px;
	line-height: 1.55;
	color: var(--ink);
	margin: 0;
	max-width: 60ch;
}
.uk-cap__tail p em { color: var(--green-dk); font-weight: 600; }
@media (max-width: 700px) {
	.uk-cap__tail { grid-template-columns: 1fr; }
}

/* ----- Service: Stack — filters + dot-prefixed marks ----- */
.uk-stack__filters {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 32px;
}
.uk-stack__flab {
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--muted);
	font-weight: 700;
	margin-right: 8px;
}
.uk-stack__chip {
	border: 1px solid var(--hairline);
	background: var(--white);
	color: var(--ink);
	font-family: inherit;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .02em;
	padding: 8px 14px;
	border-radius: 2px;
	cursor: pointer;
	transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.uk-stack__chip:hover { border-color: var(--ink); }
.uk-stack__chip.is-on { background: var(--ink); color: var(--white); border-color: var(--ink); }
.uk-stack__col.is-hide { display: none; }
.uk-stack__sub {
	font-size: 17px;
	font-weight: 600;
	color: var(--ink);
	margin: 0 0 4px;
}
.uk-stack__desc {
	font-size: 13px;
	color: var(--muted);
	line-height: 1.55;
	margin: 0 0 14px;
}
.uk-stack__marks { display: flex; flex-direction: column; gap: 8px; }
.uk-stack__mark {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14.5px;
	color: var(--ink);
	font-weight: 500;
}
.uk-stack__dot {
	width: 6px; height: 6px;
	border-radius: 50%;
	background: var(--green);
	flex-shrink: 0;
}

/* ----- Service: Outcomes — em accent + footnote ----- */
.uk-outcomes__metric em {
	font-style: normal;
	color: var(--green-dk);
	font-weight: 700;
}
.uk-outcomes__footnote {
	margin-top: 24px;
	font-size: 12.5px;
	color: var(--muted);
	letter-spacing: .01em;
}

/* ----- Service: AI strip — anchor items + current state ----- */
.uk-aistrip__lens {
	display: flex;
	flex-direction: column;
	gap: 10px;
	color: inherit;
	text-decoration: none;
	transition: border-color var(--t-fast), transform var(--t-fast);
}
.uk-aistrip__lens:hover { border-top-color: var(--green); transform: translateY(-2px); }
.uk-aistrip__lens.is-current { border-top-color: var(--green); }
.uk-aistrip__lab {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--muted);
}
.uk-aistrip__lens.is-current .uk-aistrip__lab { color: var(--green-dk); }
.uk-aistrip__go {
	margin-top: 6px;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .04em;
	color: var(--ink);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

/* ----- Service: Industry mapping — row layout ----- */
.uk-indmap__rows {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--hairline);
}
.uk-indmap__row {
	display: grid;
	grid-template-columns: 1.2fr 2.4fr auto auto;
	gap: 24px;
	align-items: center;
	padding: 22px 0;
	border-bottom: 1px solid var(--hairline);
	color: var(--ink);
	text-decoration: none;
	transition: background var(--t-fast);
}
.uk-indmap__row:hover { background: rgba(118,188,33,.05); }
.uk-indmap__ind {
	font-size: 16px;
	font-weight: 600;
	letter-spacing: -0.005em;
}
.uk-indmap__case {
	font-size: 14px;
	color: var(--muted);
	line-height: 1.5;
}
.uk-indmap__tag {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--green-dk);
	white-space: nowrap;
}
.uk-indmap__go {
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .04em;
	color: var(--ink);
	display: inline-flex;
	align-items: center;
	gap: 6px;
	white-space: nowrap;
}
@media (max-width: 800px) {
	.uk-indmap__row {
		grid-template-columns: 1fr auto;
		gap: 8px 16px;
	}
	.uk-indmap__case { grid-column: 1 / -1; }
	.uk-indmap__tag  { grid-column: 1; }
	.uk-indmap__go   { grid-column: 2; }
}

/* ----- Service: Why us — lede + ordered list ----- */
.uk-whyus__head { max-width: 60ch; margin-bottom: 48px; }
.uk-whyus__lede {
	margin-top: 18px;
	font-size: 16px;
	color: var(--muted);
	line-height: 1.6;
	max-width: 48ch;
}
.uk-whyus__list {
	list-style: none;
	padding: 0;
	margin: 0;
	counter-reset: whyus;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
}
.uk-whyus__item {
	counter-increment: whyus;
	display: flex;
	gap: 20px;
	padding: 28px 28px 28px 0;
	border-top: 1px solid var(--hairline);
	position: relative;
}
.uk-whyus__item::before {
	content: counter(whyus, decimal-leading-zero);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .18em;
	color: var(--green-dk);
	min-width: 32px;
	padding-top: 4px;
}
.uk-whyus__item:nth-child(odd) { padding-right: 36px; border-right: 1px solid var(--hairline); }
.uk-whyus__item:nth-child(even) { padding-left: 36px; }
.uk-whyus__h {
	font-size: 17px;
	font-weight: 600;
	margin: 0 0 8px;
	letter-spacing: -0.005em;
}
.uk-whyus__body {
	color: var(--muted);
	line-height: 1.6;
	font-size: 14.5px;
	margin: 0;
}
@media (max-width: 800px) {
	.uk-whyus__list { grid-template-columns: 1fr; }
	.uk-whyus__item:nth-child(odd) { padding-right: 0; border-right: 0; }
	.uk-whyus__item:nth-child(even) { padding-left: 0; }
}

/* ----- Service: Cases filters ----- */
.uk-cases__filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-bottom: 32px;
}
.uk-cases__flab {
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--muted);
	font-weight: 700;
	margin-right: 8px;
}
.uk-cases__flab--ind { margin-left: 16px; }
.uk-cases__chip {
	border: 1px solid var(--hairline);
	background: var(--white);
	color: var(--ink);
	font-family: inherit;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .02em;
	padding: 8px 14px;
	border-radius: 2px;
	cursor: pointer;
	transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.uk-cases__chip:hover { border-color: var(--ink); }
.uk-cases__chip.is-on { background: var(--ink); color: var(--white); border-color: var(--ink); }
.uk-cases__art.is-hide { display: none; }
.uk-cases__art-list { display: flex; flex-direction: column; }

/* ----- Service: Lead CTA service variant ----- */
.uk-lead-cta--service .uk-lead-cta__meta strong::after { content: none; }
.uk-lead-cta--service .uk-lead-cta__meta div {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

/* ==========================================================================
   Insights — hero (vol/date + 2-col + Editor's Pick)
   ========================================================================== */
.uk-rule--faint { background: rgba(255,255,255,.3); }

.uk-i-hero {
	background: var(--white);
	border-bottom: 1px solid var(--hairline);
	padding: clamp(56px, 7vw, 96px) 0 clamp(48px, 6vw, 80px);
	position: relative;
}
.uk-i-hero__rule {
	display: flex; align-items: center; justify-content: space-between; gap: 24px;
	padding-bottom: 28px; margin-bottom: 48px;
	border-bottom: 1px solid var(--ink);
}
.uk-i-hero__vol  { font-size: 11.5px; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; color: var(--ink); }
.uk-i-hero__vol em { color: var(--green-dk); font-style: normal; font-weight: 700; }
.uk-i-hero__date { font-size: 12px; color: var(--muted); letter-spacing: .12em; text-transform: uppercase; }

.uk-i-hero__layout {
	display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px;
	align-items: stretch;
}
.uk-i-hero__h {
	font-size: clamp(44px, 5.6vw, 78px);
	line-height: 1.02; letter-spacing: -0.03em;
	color: var(--ink); margin-bottom: 26px;
	max-width: 14ch;
}
.uk-i-hero__h em { font-style: italic; font-weight: 500; color: var(--green-dk); }
.uk-i-hero__lede {
	font-weight: 500;
	font-size: clamp(17px, 1.4vw, 21px); line-height: 1.55;
	color: var(--muted); max-width: 48ch; margin-bottom: 32px;
}
.uk-i-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }
.uk-i-hero__meta {
	display: flex; gap: 28px; flex-wrap: wrap; padding-top: 24px;
	border-top: 1px solid var(--hairline); font-size: 13px; color: var(--muted);
}
.uk-i-hero__m { display: flex; flex-direction: column; gap: 2px; }
.uk-i-hero__m strong { font-size: 18px; color: var(--ink); font-weight: 700; letter-spacing: -0.01em; }
.uk-i-hero__m strong em { color: var(--green-dk); font-style: normal; }
.uk-i-hero__m-l { font-size: 11.5px; color: var(--muted); letter-spacing: .08em; text-transform: uppercase; font-weight: 500; }

.uk-i-hero__feat {
	position: relative;
	display: flex; flex-direction: column;
	border: 1px solid var(--hairline);
	background: var(--white);
	color: var(--ink);
	overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease;
}
.uk-i-hero__feat:hover { transform: translateY(-3px); box-shadow: 0 28px 60px -32px rgba(11,30,63,.32); color: var(--ink); }
.uk-i-hero__feat-plate {
	position: relative; aspect-ratio: 16/9; overflow: hidden;
	background: linear-gradient(135deg, #1B2E52 0%, #050F24 100%);
}
.uk-i-hero__feat-plate::before {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(600px 360px at 80% 20%, rgba(118,188,33,.32), transparent 60%),
		radial-gradient(500px 360px at 20% 80%, rgba(0,167,225,.22), transparent 60%);
}
.uk-i-hero__feat-plate::after {
	content: ""; position: absolute; inset: 0;
	background: repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
}
.uk-i-hero__feat-badge {
	position: absolute; top: 18px; left: 22px; z-index: 2;
	padding: 6px 12px;
	background: var(--green); color: var(--white);
	font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
}
.uk-i-hero__feat-pinned {
	position: absolute; bottom: 18px; left: 22px; right: 22px; z-index: 2;
	font-weight: 600;
	font-size: clamp(20px, 2vw, 28px); line-height: 1.18; color: var(--white);
	letter-spacing: -0.012em; max-width: 22ch; margin: 0;
}
.uk-i-hero__feat-pinned em { color: var(--green); font-style: italic; }
.uk-i-hero__feat-body {
	padding: 24px 26px 26px;
	display: flex; flex-direction: column; gap: 14px; flex: 1;
}
.uk-i-hero__feat-topic {
	font-size: 11px; letter-spacing: .22em; color: var(--green-dk);
	text-transform: uppercase; font-weight: 600;
}
.uk-i-hero__feat-body p { font-size: 14.5px; color: var(--muted); line-height: 1.6; margin: 0; }
.uk-i-hero__feat-byline {
	display: flex; gap: 10px; align-items: center; margin-top: auto;
	padding-top: 14px; border-top: 1px solid var(--hairline);
	font-size: 12.5px; color: var(--muted);
}
.uk-i-hero__feat-byline strong { color: var(--ink); font-weight: 600; }
.uk-i-hero__feat-dot { width: 4px; height: 4px; background: var(--quiet); border-radius: 50%; display: inline-block; }
.uk-i-hero__feat-read {
	margin-top: 6px;
	font-size: 13px; font-weight: 600; color: var(--ink);
	display: inline-flex; align-items: center; gap: 6px;
}
.uk-i-hero__feat:hover .uk-i-hero__feat-read { color: var(--green-dk); }

/* "Browse by format" cross-links — surfaced on /insights/ only */
.uk-i-browse { background: var(--white); padding: 48px 0 8px; }
.uk-i-browse__grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px;
}
.uk-i-browse__card {
	position: relative;
	display: flex; flex-direction: column; gap: 12px;
	padding: 28px 28px 22px;
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 4px;
	color: var(--ink);
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
	overflow: hidden;
}
.uk-i-browse__card::before {
	content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
	background: var(--green);
	transform: scaleY(0); transform-origin: top;
	transition: transform .25s ease;
}
.uk-i-browse__card:hover {
	transform: translateY(-3px);
	box-shadow: 0 22px 50px -28px rgba(11,30,63,.25);
	border-color: var(--ink);
	color: var(--ink);
}
.uk-i-browse__card:hover::before { transform: scaleY(1); }
.uk-i-browse__card--cases::before { background: var(--ink); }
.uk-i-browse__lab {
	font-size: 11px; letter-spacing: .18em; font-weight: 700;
	color: var(--quiet);
	font-family: var(--font-mono, ui-monospace, monospace);
}
.uk-i-browse__h {
	font-size: clamp(22px, 2.4vw, 30px); letter-spacing: -0.01em;
	color: var(--ink); font-weight: 700; line-height: 1.15; margin: 0;
}
.uk-i-browse__d {
	font-size: 14.5px; color: var(--muted); line-height: 1.55; margin: 0;
	max-width: 46ch;
}
.uk-i-browse__meta {
	font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase;
	color: var(--quiet); font-weight: 600;
	font-family: var(--font-mono, ui-monospace, monospace);
}
.uk-i-browse__go {
	margin-top: 4px;
	font-size: 14px; font-weight: 600; color: var(--green-dk);
	display: inline-flex; align-items: center; gap: 6px;
}
.uk-i-browse__card:hover .uk-i-browse__go { color: var(--ink); }
@media (max-width: 720px) {
	.uk-i-browse__grid { grid-template-columns: 1fr; }
}

/* Hero mockup — "On the record" library panel, renders when no Editor's Pick set */
.uk-i-hero__mock {
	position: relative;
	background: linear-gradient(180deg, #0B1E3F 0%, #07142b 100%);
	border-radius: 4px;
	padding: 22px 22px 18px;
	color: var(--white);
	box-shadow: 0 26px 60px -28px rgba(11,30,63,.5);
	overflow: hidden;
}
.uk-i-hero__mock::after {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(circle at 90% 0%, rgba(118,188,33,.18), transparent 40%),
		linear-gradient(180deg, transparent 0%, rgba(255,255,255,.02) 100%);
	pointer-events: none;
}
.uk-i-hero__mock-head {
	display: flex; justify-content: space-between; align-items: center;
	padding-bottom: 14px; margin-bottom: 14px;
	border-bottom: 1px solid rgba(255,255,255,.08);
}
.uk-i-hero__mock-label {
	font-size: 10px; letter-spacing: .22em; font-weight: 600;
	color: rgba(255,255,255,.6);
	font-family: var(--font-mono, ui-monospace, "SF Mono", Menlo, monospace);
}
.uk-i-hero__mock-live {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 10px; letter-spacing: .18em; font-weight: 700;
	color: var(--green);
}
.uk-i-hero__mock-dot {
	width: 6px; height: 6px; border-radius: 50%; background: var(--green);
	box-shadow: 0 0 0 0 rgba(118,188,33,.6);
	animation: ukIMockPulse 1.6s ease-out infinite;
}
@keyframes ukIMockPulse {
	0%   { box-shadow: 0 0 0 0   rgba(118,188,33,.55); }
	70%  { box-shadow: 0 0 0 8px rgba(118,188,33,0); }
	100% { box-shadow: 0 0 0 0   rgba(118,188,33,0); }
}
.uk-i-hero__mock-list {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-direction: column; gap: 10px;
}
.uk-i-hero__mock-row {
	display: grid;
	grid-template-columns: 76px 1fr auto;
	gap: 10px; align-items: baseline;
	padding: 10px 12px;
	border-radius: 3px;
	background: rgba(255,255,255,.02);
	border: 1px solid rgba(255,255,255,.05);
	transition: background .25s ease, border-color .25s ease;
}
.uk-i-hero__mock-row.is-current {
	background: rgba(118,188,33,.08);
	border-color: rgba(118,188,33,.22);
}
.uk-i-hero__mock-tag {
	font-size: 9.5px; letter-spacing: .14em; font-weight: 700;
	padding: 3px 6px; border-radius: 2px;
	background: rgba(255,255,255,.06); color: rgba(255,255,255,.7);
	text-align: center; font-family: var(--font-mono, ui-monospace, monospace);
}
.uk-i-hero__mock-tag--case      { color: var(--green); background: rgba(118,188,33,.10); }
.uk-i-hero__mock-tag--framework { color: #ffb653;      background: rgba(255,182,83,.10); }
.uk-i-hero__mock-title {
	font-size: 13px; font-weight: 500; color: var(--white);
	line-height: 1.35;
	overflow: hidden; text-overflow: ellipsis;
	display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1;
}
.uk-i-hero__mock-meta {
	font-size: 10.5px; color: rgba(255,255,255,.45);
	letter-spacing: .04em; white-space: nowrap;
	font-family: var(--font-mono, ui-monospace, monospace);
}
.uk-i-hero__mock-foot {
	display: flex; align-items: center; gap: 12px;
	margin-top: 16px; padding-top: 12px;
	border-top: 1px solid rgba(255,255,255,.08);
}
.uk-i-hero__mock-bar {
	flex: 1; height: 3px; border-radius: 2px;
	background: rgba(255,255,255,.06);
	overflow: hidden;
}
.uk-i-hero__mock-bar-fill {
	display: block; height: 100%; width: 4.16%;
	background: var(--green);
	box-shadow: 0 0 8px rgba(118,188,33,.6);
	animation: ukIMockBar 4.5s ease-out infinite;
}
@keyframes ukIMockBar {
	0%   { width: 4.16%; }
	70%  { width: 92%; }
	100% { width: 100%; }
}
.uk-i-hero__mock-count {
	font-size: 10.5px; letter-spacing: .12em; font-weight: 600;
	color: rgba(255,255,255,.55);
	font-family: var(--font-mono, ui-monospace, monospace);
}
@media (max-width: 600px) {
	.uk-i-hero__mock-row { grid-template-columns: 64px 1fr; }
	.uk-i-hero__mock-meta { grid-column: 2; padding-top: 2px; }
}
@media (max-width: 980px) {
	.uk-i-hero__layout { grid-template-columns: 1fr; gap: 48px; }
}

/* ==========================================================================
   Insights — I Featured (3 cards + featured case banner)
   ========================================================================== */
.uk-i-featured { background: var(--surface); border-bottom: 1px solid var(--hairline); padding-block: var(--section); }
.uk-i-featured .uk-section__masthead h2.uk-display { font-size: clamp(36px, 4.4vw, 56px); max-width: 16ch; }

.uk-i-featured__grid {
	display: grid;
	grid-template-columns: 1.3fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 20px;
	margin-bottom: 36px;
}
.uk-i-feat-card {
	display: flex; flex-direction: column;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease;
}
.uk-i-feat-card:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -28px rgba(11,30,63,.25); color: var(--ink); }
.uk-i-feat-card--lg { grid-row: span 2; }
.uk-i-feat-card--lg .uk-i-feat-card__plate { aspect-ratio: 16/9; background: linear-gradient(135deg, #0B4530 0%, var(--green) 100%); }
.uk-i-feat-card--sm { display: grid; grid-template-columns: 200px 1fr; gap: 0; }
.uk-i-feat-card--sm .uk-i-feat-card__plate { aspect-ratio: 16/9; align-self: start; }
.uk-i-featured__grid .uk-i-feat-card--sm:nth-child(2) .uk-i-feat-card__plate { background: linear-gradient(135deg, #0a3a72 0%, var(--blue, #00A7E1) 100%); }
.uk-i-featured__grid .uk-i-feat-card--sm:nth-child(3) .uk-i-feat-card__plate { background: linear-gradient(135deg, #4a0909 0%, var(--red) 100%); }
.uk-i-feat-card__plate {
	position: relative; aspect-ratio: 16/9; overflow: hidden;
	background: linear-gradient(135deg, #1B2E52 0%, #050F24 100%);
}
.uk-card-plate__img {
	position: absolute;
	inset: 0;
	z-index: 0;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.uk-i-feat-card__plate:has(.uk-card-plate__img)::after,
.uk-i-art-card__plate:has(.uk-card-plate__img)::after,
.uk-cases__plate:has(.uk-card-plate__img)::after,
.uk-case-card__media:has(img)::after {
	background:
		linear-gradient(rgba(11,30,63,.34), rgba(11,30,63,.34)),
		radial-gradient(circle at 70% 30%, rgba(255,255,255,.18), transparent 50%),
		repeating-linear-gradient(45deg, rgba(255,255,255,.12) 0 2px, transparent 2px 14px);
}
.uk-i-feat-card__plate::after {
	content: ""; position: absolute; inset: 0;
	z-index: 1;
	pointer-events: none;
	background:
		radial-gradient(circle at 70% 30%, rgba(255,255,255,.14), transparent 50%),
		repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
}
.uk-i-feat-card__chip {
	position: absolute; top: 16px; left: 18px; z-index: 2;
	display: inline-flex; padding: 5px 11px;
	background: rgba(11,30,63,.6); backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.2);
	border-radius: 999px;
	font-size: 10.5px; font-weight: 700; letter-spacing: .18em; color: var(--white); text-transform: uppercase;
}
.uk-i-feat-card__pinned {
	position: absolute; bottom: 22px; left: 24px; right: 24px; z-index: 2;
	font-weight: 700;
	font-size: clamp(22px, 2.4vw, 32px); line-height: 1.15; color: var(--white);
	letter-spacing: -0.018em; max-width: 22ch; margin: 0;
}
.uk-i-feat-card__pinned em { color: var(--white); font-style: italic; opacity: .82; }
.uk-i-feat-card__body {
	padding: 24px 26px;
	display: flex; flex-direction: column; gap: 12px; flex: 1;
}
.uk-i-feat-card--sm .uk-i-feat-card__body { padding: 22px; }
.uk-i-feat-card__topic {
	font-size: 11px; letter-spacing: .22em; color: var(--green-dk);
	text-transform: uppercase; font-weight: 600;
}
.uk-i-feat-card--sm .uk-i-feat-card__topic { font-size: 10.5px; }
.uk-i-feat-card__h {
	font-weight: 600;
	font-size: clamp(17px, 1.4vw, 21px); line-height: 1.25;
	color: var(--ink); letter-spacing: -0.012em; margin: 0;
}
.uk-i-feat-card__body p { font-size: 14.5px; color: var(--muted); line-height: 1.55; margin: 0; }
.uk-i-feat-card--sm .uk-i-feat-card__body p { font-size: 13.5px; line-height: 1.5; }
.uk-i-feat-card__byline {
	display: flex; gap: 10px; align-items: center; margin-top: auto;
	padding-top: 14px; border-top: 1px solid var(--hairline);
	font-size: 12.5px; color: var(--muted);
}
.uk-i-feat-card__byline strong { color: var(--ink); font-weight: 600; }

/* Featured case study banner */
.uk-i-feat-case {
	display: grid; grid-template-columns: 1.2fr 1fr; gap: 56px;
	background: var(--ink); color: var(--white);
	padding: 44px;
	position: relative; overflow: hidden;
	align-items: center;
}
.uk-i-feat-case::before {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background:
		radial-gradient(500px 360px at 90% 10%, rgba(118,188,33,.18), transparent 60%),
		radial-gradient(400px 300px at 5% 95%, rgba(0,167,225,.12), transparent 60%);
}
.uk-i-feat-case > * { position: relative; z-index: 1; }
.uk-i-feat-case__tag {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 5px 12px;
	background: var(--green); color: var(--white);
	border-radius: 999px;
	font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
	margin-bottom: 18px;
}
.uk-i-feat-case__h {
	font-weight: 600;
	font-size: clamp(24px, 2.6vw, 36px); line-height: 1.18;
	color: var(--white); letter-spacing: -0.015em;
	max-width: 22ch; margin: 0 0 16px;
}
.uk-i-feat-case__h em { color: var(--green); font-style: italic; }
.uk-i-feat-case__body { font-size: 15.5px; color: rgba(255,255,255,.78); line-height: 1.6; max-width: 50ch; margin: 0; }
.uk-i-feat-case__meta {
	margin-top: 22px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.16);
	display: flex; gap: 28px; flex-wrap: wrap; font-size: 12px; color: rgba(255,255,255,.55);
	letter-spacing: .04em; text-transform: uppercase; font-weight: 500;
}
.uk-i-feat-case__meta strong { color: var(--green); font-weight: 600; }
.uk-i-feat-case__cta {
	margin-top: 24px; display: inline-flex; align-items: center; gap: 8px;
	font-size: 13px; font-weight: 600; color: var(--green);
}
.uk-i-feat-case__stats {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px;
	padding-left: 24px; border-left: 1px solid rgba(255,255,255,.12);
}
.uk-i-feat-case__s-n {
	font-weight: 700;
	font-size: clamp(28px, 2.6vw, 36px); color: var(--white); line-height: 1; letter-spacing: -0.018em;
}
.uk-i-feat-case__s-n em { color: var(--green); font-style: italic; }
.uk-i-feat-case__s-l {
	font-size: 11.5px; color: rgba(255,255,255,.55);
	letter-spacing: .06em; margin-top: 6px; text-transform: uppercase; font-weight: 500;
	line-height: 1.4;
}
@media (max-width: 1024px) {
	.uk-i-featured__grid { grid-template-columns: 1fr; grid-template-rows: auto; }
	.uk-i-feat-card--lg { grid-row: auto; }
	.uk-i-feat-card--sm { grid-template-columns: 160px 1fr; }
	.uk-i-feat-case { grid-template-columns: 1fr; gap: 32px; padding: 32px 28px; }
	.uk-i-feat-case__stats { padding-left: 0; border-left: 0; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.12); }
}
@media (max-width: 600px) {
	.uk-i-feat-card--sm { grid-template-columns: 1fr; }
	.uk-i-feat-card--sm .uk-i-feat-card__plate { aspect-ratio: 16/9; height: auto; }
}

/* ==========================================================================
   Insights — II Filter bar
   ========================================================================== */
.uk-i-filterbar { background: var(--white); padding: 36px 0 0; border-bottom: 1px solid var(--hairline); }
.uk-i-filterbar .uk-container { display: flex; flex-direction: column; gap: 24px; }
.uk-i-filterbar__head {
	display: flex; justify-content: space-between; gap: 24px; align-items: end; flex-wrap: wrap;
	padding-bottom: 14px;
}
.uk-i-filterbar__h {
	font-weight: 700;
	font-size: clamp(28px, 3vw, 42px); letter-spacing: -0.02em; color: var(--ink);
	line-height: 1.1; margin-top: 14px;
}
.uk-i-filterbar__h em { font-style: italic; color: var(--green-dk); font-weight: 500; }
.uk-i-filterbar__right { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.uk-i-filterbar__count { font-size: 12.5px; color: var(--muted); letter-spacing: .04em; }
.uk-i-filterbar__count strong { color: var(--ink); font-weight: 700; }
.uk-i-filterbar__sort {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 8px 14px;
	border: 1px solid var(--hairline);
	font-size: 13px; color: var(--ink); cursor: pointer; background: var(--white);
	font-family: inherit;
}
.uk-i-filterbar__sort:hover { border-color: var(--ink); }
.uk-i-filterbar__sort::after { content: " ⌄"; color: var(--quiet); font-size: 11px; }

/* Filter dropdowns — single row, native <select> wrapped for styling */
.uk-i-filters {
	display: flex; gap: 12px; flex-wrap: wrap; align-items: stretch;
	padding: 18px 0 24px; border-top: 1px solid var(--ink);
}
.uk-i-filt {
	position: relative;
	display: inline-flex; flex-direction: column; gap: 4px;
	min-width: 180px; flex: 1 1 180px;
}
.uk-i-filt__lab {
	font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
	color: var(--quiet); font-weight: 600;
}
.uk-i-filt__sel {
	appearance: none; -webkit-appearance: none; -moz-appearance: none;
	width: 100%;
	padding: 10px 36px 10px 14px;
	background: var(--white);
	border: 1px solid var(--hairline);
	border-radius: 4px;
	font: inherit; font-size: 14px; font-weight: 500; color: var(--ink);
	cursor: pointer;
	transition: border-color .15s ease, box-shadow .15s ease;
}
.uk-i-filt__sel:hover  { border-color: var(--ink); }
.uk-i-filt__sel:focus  { outline: none; border-color: var(--green-dk); box-shadow: 0 0 0 3px rgba(118, 188, 33, .18); }
.uk-i-filt__caret {
	position: absolute; right: 12px; bottom: 11px;
	color: var(--quiet); font-size: 16px;
	transform: rotate(90deg); pointer-events: none;
}
.uk-i-filters__clear {
	align-self: flex-end;
	font-size: 12px; color: var(--quiet); text-decoration: underline;
	padding: 10px 4px;
}
.uk-i-filters__clear:hover { color: var(--green-dk); }
.uk-i-filters__go {
	align-self: flex-end;
	padding: 10px 18px;
	background: var(--ink); color: var(--white);
	border: 0; border-radius: 4px; font: inherit; font-size: 14px;
	cursor: pointer;
}
@media (max-width: 720px) {
	.uk-i-filt { flex: 1 1 calc(50% - 6px); min-width: 0; }
}
@media (max-width: 420px) {
	.uk-i-filt { flex-basis: 100%; }
}

/* ==========================================================================
   Insights — Listing (art-cards) + pagination
   ========================================================================== */
.uk-i-listing { background: var(--white); padding: 56px 0 80px; }
.uk-i-listing__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px 24px;
}
.uk-i-art-card {
	display: flex; flex-direction: column;
	background: var(--white);
	border: 1px solid var(--hairline);
	color: var(--ink);
	overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.uk-i-art-card:hover {
	transform: translateY(-4px);
	border-color: rgba(11,30,63,.18);
	box-shadow: 0 22px 48px -28px rgba(11,30,63,.25);
	color: var(--ink);
}
.uk-i-art-card__plate {
	position: relative; aspect-ratio: 16/9; overflow: hidden;
	background: linear-gradient(135deg, var(--ink) 0%, #1B2E52 100%);
}
.uk-i-art-card--green .uk-i-art-card__plate { background: linear-gradient(135deg, #0B4530 0%, var(--green) 100%); }
.uk-i-art-card--blue  .uk-i-art-card__plate { background: linear-gradient(135deg, #0a3a72 0%, var(--blue, #00A7E1) 100%); }
.uk-i-art-card--red   .uk-i-art-card__plate { background: linear-gradient(135deg, #4a0909 0%, var(--red) 100%); }
.uk-i-art-card--gray  .uk-i-art-card__plate { background: linear-gradient(135deg, #1B2E52 0%, #3a5081 100%); }
.uk-i-art-card--warm  .uk-i-art-card__plate { background: linear-gradient(135deg, #4a2200 0%, #c97a17 100%); }
.uk-i-art-card__plate::after {
	content: ""; position: absolute; inset: 0;
	z-index: 1;
	pointer-events: none;
	background:
		radial-gradient(circle at 70% 30%, rgba(255,255,255,.14), transparent 50%),
		repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
}
.uk-i-art-card__type {
	position: absolute; top: 14px; left: 16px; z-index: 2;
	display: inline-flex; padding: 4px 10px;
	background: rgba(11,30,63,.65); backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 999px;
	font-size: 10px; font-weight: 700; letter-spacing: .18em; color: var(--white); text-transform: uppercase;
}
.uk-i-art-card__rt {
	position: absolute; top: 14px; right: 16px; z-index: 2;
	font-size: 10.5px; color: rgba(255,255,255,.7); letter-spacing: .08em; font-weight: 500;
}
.uk-i-art-card__body {
	padding: 22px;
	display: flex; flex-direction: column; gap: 12px; flex: 1;
}
.uk-i-art-card__topic {
	font-size: 11px; letter-spacing: .22em; color: var(--green-dk);
	text-transform: uppercase; font-weight: 600;
}
.uk-i-art-card__h {
	font-weight: 600;
	font-size: 18px; line-height: 1.28; color: var(--ink); letter-spacing: -0.012em;
	max-width: 22ch; margin: 0;
}
.uk-i-art-card__ex { font-size: 14px; color: var(--muted); line-height: 1.55; margin: 0; }
.uk-i-art-card__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.uk-i-art-card__tags span {
	display: inline-flex; padding: 3px 8px;
	background: var(--surface); border: 1px solid var(--hairline);
	border-radius: 999px;
	font-size: 11px; color: var(--muted); font-weight: 500;
	letter-spacing: .02em;
}
.uk-i-art-card__byline {
	display: flex; gap: 10px; align-items: center; margin-top: auto;
	padding-top: 14px; border-top: 1px solid var(--hairline);
	font-size: 12.5px; color: var(--muted);
}
.uk-i-art-card__byline strong { color: var(--ink); font-weight: 600; }
@media (max-width: 1024px) { .uk-i-listing__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .uk-i-listing__grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Insights — III Newsletter (The Dispatch)
   ========================================================================== */
.uk-i-newsletter {
	background: var(--ink);
	color: var(--white);
	position: relative; overflow: hidden;
	padding-block: clamp(72px, 9vw, 132px);
}
.uk-i-newsletter::before {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background:
		radial-gradient(800px 500px at 100% 0%, rgba(118,188,33,.18), transparent 60%),
		radial-gradient(700px 500px at 0% 100%, rgba(0,167,225,.14), transparent 60%);
}
.uk-i-newsletter__inner {
	position: relative; z-index: 1;
	display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.uk-i-newsletter__lhs .uk-kicker { color: var(--green); }
.uk-i-newsletter__h {
	font-size: clamp(36px, 4.4vw, 60px);
	color: var(--white); max-width: 14ch; margin-top: 16px;
}
.uk-i-newsletter__h em { color: var(--green); }
.uk-i-newsletter__lede {
	font-weight: 500;
	font-size: clamp(16px, 1.3vw, 19px); color: rgba(255,255,255,.78);
	margin-top: 22px; max-width: 44ch; line-height: 1.55;
}
.uk-i-newsletter__perks {
	margin-top: 28px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.16);
	display: grid; gap: 12px;
}
.uk-i-newsletter__p {
	display: grid; grid-template-columns: 22px 1fr; gap: 12px;
	font-size: 14px; color: rgba(255,255,255,.85); line-height: 1.5;
}
.uk-i-newsletter__ic {
	width: 18px; height: 18px; border-radius: 50%;
	background: var(--green); color: var(--white);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 11px; font-weight: 700; margin-top: 2px;
}

.uk-i-newsletter__form-card {
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.14);
	backdrop-filter: blur(8px);
	padding: 40px 36px;
}
.uk-i-newsletter__form-head {
	font-size: 11px; letter-spacing: .22em; color: var(--green);
	text-transform: uppercase; font-weight: 700; margin-bottom: 8px;
}
.uk-i-newsletter__form-h {
	font-weight: 600;
	font-size: 22px; color: var(--white); letter-spacing: -0.01em;
	margin: 0 0 22px;
}
.uk-i-newsletter__nlform { display: flex; flex-direction: column; gap: 16px; }
.uk-i-newsletter__nlform label {
	font-size: 11px; letter-spacing: .18em; color: rgba(255,255,255,.55);
	text-transform: uppercase; font-weight: 600; margin-bottom: 6px; display: block;
}
.uk-i-newsletter__nlform input {
	width: 100%; padding: 12px 14px;
	background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.16);
	color: var(--white); font: inherit; font-size: 15px; border-radius: 0;
}
.uk-i-newsletter__nlform input::placeholder { color: rgba(255,255,255,.4); }
.uk-i-newsletter__nlform input:focus { outline: none; border-color: var(--green); }
.uk-i-newsletter__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.uk-i-newsletter__topics { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.uk-i-newsletter__pill {
	display: inline-flex; align-items: center;
	padding: 6px 12px; border-radius: 999px;
	font-size: 12.5px; font-weight: 500;
	border: 1px solid rgba(255,255,255,.18);
	color: rgba(255,255,255,.85);
	background: transparent;
	transition: all .15s ease;
}
.uk-i-newsletter__pill:hover { border-color: var(--green); color: var(--white); }
.uk-i-newsletter__pill.is-on { background: var(--green); border-color: var(--green); color: var(--white); }
.uk-i-newsletter__topics-wrap { margin-top: 22px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.16); }
.uk-i-newsletter__topics-wrap label {
	font-size: 11px; letter-spacing: .18em; color: rgba(255,255,255,.55);
	text-transform: uppercase; font-weight: 600; margin-bottom: 10px; display: block;
}
.uk-i-newsletter__nlform button {
	margin-top: 8px; background: var(--green); color: var(--white);
	border: 0; padding: 14px 22px;
	font-weight: 600; font-size: 14.5px; cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center; gap: 10px;
	font-family: inherit;
}
.uk-i-newsletter__nlform button:hover { background: var(--green-dk); }
.uk-i-newsletter__micro { font-size: 11.5px; color: rgba(255,255,255,.5); margin-top: 4px; line-height: 1.5; }
.uk-i-newsletter__micro a { color: var(--green); text-decoration: underline; text-decoration-color: rgba(118,188,33,.4); }
@media (max-width: 980px) { .uk-i-newsletter__inner { grid-template-columns: 1fr; gap: 40px; } }

/* ==========================================================================
   Single insights post — hero + body + related
   ========================================================================== */
.uk-arrow--left::after { content: "←"; }

.uk-p-hero {
	background: linear-gradient(135deg, var(--ink) 0%, #1B2E52 100%);
	color: var(--white);
	padding-block: clamp(64px, 8vw, 120px);
	position: relative; overflow: hidden;
}
.uk-p-hero--green { background: linear-gradient(135deg, #0B4530 0%, var(--green) 100%); }
.uk-p-hero--blue  { background: linear-gradient(135deg, #0a3a72 0%, var(--blue, #00A7E1) 100%); }
.uk-p-hero--red   { background: linear-gradient(135deg, #4a0909 0%, var(--red) 100%); }
.uk-p-hero--gray  { background: linear-gradient(135deg, #1B2E52 0%, #3a5081 100%); }
.uk-p-hero--warm  { background: linear-gradient(135deg, #4a2200 0%, #c97a17 100%); }
.uk-p-hero::after {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background:
		radial-gradient(800px 500px at 90% 10%, rgba(255,255,255,.06), transparent 60%),
		repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 2px, transparent 2px 14px);
}
.uk-p-hero > .uk-container { position: relative; z-index: 1; max-width: 880px; }
.uk-p-hero__back {
	display: inline-flex; align-items: center; gap: 8px;
	font-size: 12px; letter-spacing: .18em; text-transform: uppercase;
	color: rgba(255,255,255,.7); font-weight: 600;
	margin-bottom: 36px;
}
.uk-p-hero__back:hover { color: var(--green); }
.uk-p-hero__plate {
	display: flex; gap: 12px; align-items: center; margin-bottom: 24px;
}
.uk-p-hero__type {
	display: inline-flex; padding: 5px 12px;
	background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
	border-radius: 999px;
	font-size: 11px; font-weight: 700; letter-spacing: .18em; color: var(--white); text-transform: uppercase;
}
.uk-p-hero__rt { font-size: 12px; color: rgba(255,255,255,.65); letter-spacing: .08em; }
.uk-p-hero__topic {
	display: inline-block;
	font-size: 11px; letter-spacing: .22em; color: var(--green);
	text-transform: uppercase; font-weight: 600; margin-bottom: 18px;
}
.uk-p-hero__h {
	font-weight: 700;
	font-size: clamp(34px, 4.6vw, 56px); line-height: 1.08; letter-spacing: -0.022em;
	color: var(--white); max-width: 22ch; margin: 0 0 22px;
}
.uk-p-hero__h em { font-style: italic; color: var(--green); font-weight: 500; }
.uk-p-hero__dek {
	font-weight: 500;
	font-size: clamp(17px, 1.4vw, 21px); line-height: 1.5;
	color: rgba(255,255,255,.78); max-width: 56ch; margin: 0 0 24px;
}
.uk-p-hero__byline {
	display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
	padding-top: 22px; border-top: 1px solid rgba(255,255,255,.18);
	font-size: 13px; color: rgba(255,255,255,.7);
}
.uk-p-hero__byline strong { color: var(--white); font-weight: 600; }

.uk-p-body { padding-block: clamp(56px, 7vw, 96px); background: var(--white); }
.uk-p-body__grid {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	gap: 56px;
	align-items: start;
}
.uk-p-body__aside { position: sticky; top: 96px; }
.uk-p-body__aside-inner { display: flex; flex-direction: column; gap: 22px; padding-right: 8px; }
.uk-p-body__aside-lab {
	font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
	color: var(--quiet); font-weight: 700; display: block; margin-bottom: 6px;
}
.uk-p-body__chips { display: flex; flex-wrap: wrap; gap: 6px; }
.uk-p-body__chip {
	display: inline-flex; padding: 4px 10px;
	background: var(--surface); border: 1px solid var(--hairline);
	border-radius: 999px;
	font-size: 11.5px; color: var(--muted); font-weight: 500;
}
.uk-p-body__share { display: flex; flex-direction: column; gap: 6px; padding-top: 22px; border-top: 1px solid var(--hairline); }
.uk-p-body__share a {
	font-size: 13px; color: var(--ink); font-weight: 500;
	padding: 4px 0;
}
.uk-p-body__share a:hover { color: var(--green-dk); }
.uk-p-body__prose {
	max-width: 68ch;
	font-size: 17.5px; line-height: 1.72; color: var(--ink);
}
.uk-p-body__prose h2 {
	font-weight: 700; letter-spacing: -0.018em;
	font-size: clamp(24px, 2.2vw, 32px); line-height: 1.2;
	margin: 48px 0 16px;
}
.uk-p-body__prose h3 {
	font-weight: 600; letter-spacing: -0.012em;
	font-size: clamp(19px, 1.6vw, 22px); line-height: 1.3;
	margin: 36px 0 12px;
}
.uk-p-body__prose p { margin: 0 0 22px; }
.uk-p-body__prose strong { font-weight: 700; color: var(--ink); }
.uk-p-body__prose em { font-style: italic; color: var(--green-dk); }
.uk-p-body__prose ol, .uk-p-body__prose ul { margin: 0 0 24px; padding-left: 24px; }
.uk-p-body__prose li { margin-bottom: 10px; }
.uk-p-body__prose a { color: var(--green-dk); text-decoration: underline; text-decoration-color: rgba(95,160,26,.4); }

.uk-p-pull {
	margin: 36px 0;
	padding: 28px 0;
	border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink);
}
.uk-p-pull p {
	font-style: italic; font-weight: 500;
	font-size: clamp(22px, 2vw, 30px); line-height: 1.3;
	color: var(--ink); letter-spacing: -0.012em;
	max-width: 28ch; margin: 0;
}
@media (max-width: 900px) {
	.uk-p-body__grid { grid-template-columns: 1fr; gap: 32px; }
	.uk-p-body__aside { position: static; }
}

/* Related row */
.uk-p-related { background: var(--surface); padding-block: clamp(56px, 7vw, 96px); border-top: 1px solid var(--hairline); }
.uk-p-related__head { margin-bottom: 32px; }
.uk-p-related__h {
	font-size: clamp(28px, 3vw, 40px); margin-top: 14px; max-width: 16ch;
}
.uk-p-related__h em { color: var(--green-dk); font-style: italic; font-weight: 500; }

/* ====================================================================== *
 *  Homepage refinements
 *  The default per-heading max-width values (14–18ch) clamp the display
 *  headings tighter than the desktop columns that contain them, forcing
 *  excessive line wraps (hero ran to six lines, disciplines five). Relax
 *  the limits so the parent grid column drives line breaks; the result
 *  is 2–4 line headings on desktop without changing semantics or markup.
 * ====================================================================== */
.uk-h-hero__h1                            { max-width: 28ch; }
.uk-h-brief__title h2                     { max-width: 18ch; }
.uk-h-disc__masthead h2.uk-display        { max-width: 24ch; }
.uk-h-actigen__masthead h2.uk-display     { max-width: 28ch; }
.uk-h-industries__masthead h2.uk-display  { max-width: 24ch; }
.uk-h-engage h2.uk-display                { max-width: 22ch; }

/* Tighten the gap between Actigen masthead and the decision-loop split. */
.uk-h-actigen .uk-container               { gap: 48px; }

/* ---------------------------------------------------------------- *
 *  Hero "records" visual — fix overlapping mock CSS labels
 *  --------------------------------------------------------------
 *  Two visible overlaps before this rule:
 *    · the top labels "LIVE CAPTURE · ACTIGEN 2.0" (left) and
 *      "RECORD → DATA" (right) ran into each other once the right
 *      column narrowed.
 *    · the bottom quote ("The record is the institution.") sat
 *      directly on top of the INDEX C bars.
 *  Fix the top by tightening their type-scale and giving the cap
 *  a hard right-bound at 60% of the container so the tag stays
 *  in its lane. Fix the bottom by laying a navy gradient over
 *  the lower 55% of the visual so the bars fade into darkness
 *  before the quote is reached. */
.uk-h-hero__visual                        { isolation: isolate; }
.uk-h-hero__visual::after {
	content: "";
	position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 55%;
	background: linear-gradient(
		180deg,
		rgba(5, 15, 36, 0)   0%,
		rgba(5, 15, 36, .35) 30%,
		rgba(5, 15, 36, .85) 60%,
		rgba(5, 15, 36, .98) 100%
	);
	pointer-events: none;
	z-index: 1;
}
.uk-vis--records .uk-vis__cap {
	font-size: 10.5px; letter-spacing: .14em;
	max-width: 58%;
	line-height: 1.2;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.uk-vis--records .uk-vis__tag {
	font-size: 10.5px; letter-spacing: .14em;
	white-space: nowrap;
}
.uk-vis--records .uk-vis__q--anim {
	bottom: 28px;
	font-size: 14px;
	line-height: 1.45;
}
.uk-vis--records .uk-vis__q--anim .cite {
	margin-top: 8px;
}

/* Widen the columns that contain display headings. The default 1fr/1.4fr
 * ratio puts the heading in the narrower track, which forces it to wrap
 * to 5–6 lines on a 1440px viewport. Inverting the ratio gives the
 * heading the larger track without crowding the descriptive paragraph
 * or the visual on the right. */
.uk-h-hero__grid                          { grid-template-columns: 1.75fr 1fr; }
.uk-h-disc__masthead                      { grid-template-columns: 1.5fr 1fr; }
.uk-h-industries__masthead                { grid-template-columns: 1.4fr 1fr; }
.uk-h-engage__grid                        { grid-template-columns: 1.3fr 1fr; }

/* Hero: reduce the type-scale cap so the headline sits in 3–4 lines,
 * not six — the six-line stack felt cramped against the side visual. */
.uk-h-hero__h1                            { font-size: clamp(40px, 4.2vw, 58px); line-height: 1.05; }

/* Disciplines: the masthead uses align-items:end which floats the
 * paragraph oddly when heading and paragraph differ in height. Pin
 * both to the top so they share the same baseline. */
.uk-h-disc__masthead                      { align-items: start; }

/* ====================================================================== *
 *  Service-page hero visuals — bespoke per service
 *  Each .uk-vis--<type> fills the .uk-h-hero__visual portrait container,
 *  layered above the existing radial-gradient backdrop and below the
 *  bottom-fade gradient (which masks any low-contrast collisions).
 * ====================================================================== */

/* Shared chrome-bar for every new visual */
.uk-vis--loop, .uk-vis--roadmap, .uk-vis--channels, .uk-vis--forge,
.uk-vis--pipeline, .uk-vis--cadence, .uk-vis--bench, .uk-vis--replumb {
	position: absolute; inset: 0;
	padding: 22px 26px 22px;
	display: flex; flex-direction: column; gap: 22px;
	color: rgba(255,255,255,.85);
	font-family: 'Poppins', system-ui, sans-serif;
	font-size: 12px;
	overflow: hidden;
	z-index: 2;
	background: linear-gradient(180deg, var(--ink) 0%, #050F24 100%);
}
.uk-vis--loop .uk-vis__bar, .uk-vis--roadmap .uk-vis__bar,
.uk-vis--channels .uk-vis__bar, .uk-vis--forge .uk-vis__bar,
.uk-vis--pipeline .uk-vis__bar, .uk-vis--cadence .uk-vis__bar,
.uk-vis--bench .uk-vis__bar, .uk-vis--replumb .uk-vis__bar {
	position: static;       /* override the base .uk-vis__bar { position: absolute } so the bar */
	top: auto; left: auto; right: auto;  /* participates in our flex column flow with proper gap */
	display: flex; justify-content: space-between; align-items: center;
	font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase;
	color: rgba(255,255,255,.5);
	padding-bottom: 0;
	border-bottom: none;
	flex-shrink: 0;
	min-height: 16px;
}
.uk-vis--loop .uk-vis__bar .live, .uk-vis--roadmap .uk-vis__bar .live,
.uk-vis--channels .uk-vis__bar .live, .uk-vis--forge .uk-vis__bar .live,
.uk-vis--pipeline .uk-vis__bar .live, .uk-vis--cadence .uk-vis__bar .live,
.uk-vis--bench .uk-vis__bar .live, .uk-vis--replumb .uk-vis__bar .live {
	color: var(--green); font-weight: 600;
}
.uk-vis--loop .uk-vis__bar .live::before, .uk-vis--roadmap .uk-vis__bar .live::before,
.uk-vis--channels .uk-vis__bar .live::before, .uk-vis--forge .uk-vis__bar .live::before,
.uk-vis--pipeline .uk-vis__bar .live::before, .uk-vis--cadence .uk-vis__bar .live::before,
.uk-vis--bench .uk-vis__bar .live::before, .uk-vis--replumb .uk-vis__bar .live::before {
	content: ""; display: inline-block; width: 6px; height: 6px;
	border-radius: 50%; background: var(--green); margin-right: 6px;
	vertical-align: 1px;
	animation: uk-rec-pulse 1.4s ease-in-out infinite;
}

/* ---------- LOOP — Agentic AI ---------- */
.uk-vis--loop .loop-stage {
	position: relative; flex: 1;
	display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr;
	gap: 26px; padding: 14px;
}
.uk-vis--loop .loop-arrows {
	position: absolute; inset: 0; width: 100%; height: 100%;
	pointer-events: none;
	z-index: 0; /* arrows render BEHIND the node cards */
}
.uk-vis--loop .loop-arrows .arc {
	stroke-dasharray: 220; stroke-dashoffset: 220;
	animation: uk-loop-flow 6s linear infinite;
	opacity: .7;
}
.uk-vis--loop .loop-arrows .a2 { animation-delay: -1.5s; }
.uk-vis--loop .loop-arrows .a3 { animation-delay: -3s; }
.uk-vis--loop .loop-arrows .a4 { animation-delay: -4.5s; }
.uk-vis--loop .node {
	position: relative; z-index: 2;
	background: linear-gradient(180deg, rgba(11,30,63,.95) 0%, rgba(5,15,36,.95) 100%);
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 4px;
	padding: 14px 12px;
	display: flex; flex-direction: column; gap: 4px;
}
.uk-vis--loop .node .num { font-size: 18px; color: var(--green); font-weight: 500; line-height: 1; }
.uk-vis--loop .node .t   { font-weight: 600; font-size: 14px; color: var(--white); }
.uk-vis--loop .node .d   { font-size: 11px; color: rgba(255,255,255,.55); }
.uk-vis--loop .node.n2   { animation: uk-loop-pulse 6s ease-in-out infinite; }
.uk-vis--loop .node.n3   { animation: uk-loop-pulse 6s ease-in-out 1.5s infinite; }
.uk-vis--loop .node.n4   { animation: uk-loop-pulse 6s ease-in-out 3s infinite; }
.uk-vis--loop .node.n1   { animation: uk-loop-pulse 6s ease-in-out 4.5s infinite; }
.uk-vis--loop .loop-core {
	position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
	background: rgba(11, 30, 63, 0.92);
	border: 1px solid var(--green);
	padding: 6px 10px; border-radius: 999px;
	font-size: 10px; letter-spacing: .15em; color: var(--green);
	display: flex; align-items: center; gap: 6px;
	z-index: 2;
}
.uk-vis--loop .loop-core .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--green); animation: uk-rec-pulse 1.2s ease-in-out infinite; }
.uk-vis--loop .loop-trace { display: flex; flex-direction: column; gap: 4px; font-size: 11.5px; color: rgba(255,255,255,.7); }
.uk-vis--loop .loop-trace .ok { color: var(--green); margin-right: 6px; }
@keyframes uk-loop-flow  { 0% { stroke-dashoffset: 220; opacity: .25; } 30% { opacity: 1; } 70% { opacity: 1; } 100% { stroke-dashoffset: -220; opacity: .25; } }
@keyframes uk-loop-pulse { 0%, 80%, 100% { box-shadow: 0 0 0 rgba(118,188,33,0); border-color: rgba(255,255,255,.12); } 10%, 30% { box-shadow: 0 0 16px rgba(118,188,33,.25); border-color: var(--green); } }

/* ---------- ROADMAP — AI Consulting ---------- */
.uk-vis--roadmap .rm-grid {
	flex: 1;
	display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(2, 1fr);
	gap: 10px;
}
.uk-vis--roadmap .uc {
	background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
	border-radius: 3px; padding: 8px 10px;
	display: flex; flex-direction: column; justify-content: space-between; gap: 4px;
}
.uk-vis--roadmap .uc .t  { font-size: 11.5px; font-weight: 500; color: rgba(255,255,255,.85); }
.uk-vis--roadmap .uc .s  { font-size: 9px; letter-spacing: .18em; font-weight: 600; align-self: flex-start; padding: 2px 6px; border-radius: 2px; }
.uk-vis--roadmap .uc.build { border-color: rgba(118,188,33,.45); background: rgba(118,188,33,.08); }
.uk-vis--roadmap .uc.build .s { color: var(--green); background: rgba(118,188,33,.12); }
.uk-vis--roadmap .uc.pilot { border-color: rgba(0,167,225,.45); background: rgba(0,167,225,.06); }
.uk-vis--roadmap .uc.pilot .s { color: var(--blue); background: rgba(0,167,225,.12); }
.uk-vis--roadmap .uc.skip  { opacity: .45; }
.uk-vis--roadmap .uc.skip  .s { color: rgba(255,255,255,.4); background: rgba(255,255,255,.06); }
.uk-vis--roadmap .rm-foot {
	display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
	font-size: 11px; padding-top: 8px; border-top: 1px solid rgba(255,255,255,.08);
}
.uk-vis--roadmap .legend .lg { font-size: 14px; margin-right: 4px; vertical-align: -1px; }
.uk-vis--roadmap .legend .lg.build { color: var(--green); }
.uk-vis--roadmap .legend .lg.pilot { color: var(--blue); }
.uk-vis--roadmap .legend .lg.skip  { color: rgba(255,255,255,.3); }
.uk-vis--roadmap .callout { margin-left: auto; color: var(--green); font-weight: 600; font-size: 11.5px; }

/* ---------- CHANNELS — Conversational AI ---------- */
.uk-vis--channels .ch-row { display: flex; gap: 8px; flex-wrap: wrap; }
.uk-vis--channels .ch-pill {
	background: rgba(0,167,225,.08); border: 1px solid rgba(0,167,225,.35);
	color: var(--blue); padding: 6px 12px; border-radius: 999px;
	font-size: 11px; font-weight: 600;
}
.uk-vis--channels .ch-pill .i { color: var(--blue); margin-right: 4px; }
.uk-vis--channels .ch-arrow {
	width: 1px; height: 22px; background: rgba(118,188,33,.5); margin: 0 auto;
	box-shadow: 0 0 6px rgba(118,188,33,.4);
}
.uk-vis--channels .ch-core {
	background: rgba(118,188,33,.06); border: 1px solid var(--green);
	border-radius: 4px; padding: 12px 14px;
	display: flex; flex-direction: column; gap: 4px;
}
.uk-vis--channels .ch-core .lab { font-size: 11px; letter-spacing: .15em; text-transform: uppercase; color: var(--green); font-weight: 600; }
.uk-vis--channels .ch-core .src { font-size: 11px; color: rgba(255,255,255,.6); font-family: 'JetBrains Mono', monospace; }
.uk-vis--channels .ch-out  {
	background: rgba(255,255,255,.04); border-left: 2px solid var(--green);
	padding: 10px 14px; border-radius: 0 3px 3px 0;
	display: flex; flex-direction: column; gap: 6px;
}
.uk-vis--channels .ch-out .ans { font-size: 12px; line-height: 1.5; color: rgba(255,255,255,.92); font-style: italic; }
.uk-vis--channels .ch-out .cite { display: block; margin-top: 4px; font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--green); font-style: normal; }
.uk-vis--channels .ch-out .esc { font-size: 11px; color: rgba(255,200,100,.85); }
.uk-vis--channels .ch-foot { display: flex; flex-direction: column; gap: 3px; font-size: 11px; }
.uk-vis--channels .ch-foot .ok { color: var(--green); margin-right: 6px; }

/* ---------- FORGE — Custom Development ---------- */
.uk-vis--forge .fg-card, .uk-vis--forge .fg-shap {
	background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
	border-radius: 3px; padding: 12px 14px;
	display: flex; flex-direction: column; gap: 6px;
	font-size: 11px;
}
.uk-vis--forge .fg-shap { flex: 1; }
.uk-vis--forge .hdr {
	font-size: 10px; letter-spacing: .15em; text-transform: uppercase;
	color: var(--green); font-weight: 600; padding-bottom: 6px;
	border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 2px;
}
.uk-vis--forge .fg-card .kv { display: flex; justify-content: space-between; gap: 8px; font-family: 'JetBrains Mono', monospace; font-size: 10.5px; }
.uk-vis--forge .fg-card .kv .k { color: rgba(255,255,255,.5); }
.uk-vis--forge .fg-card .kv .v { color: var(--white); }
.uk-vis--forge .fg-shap .bar { display: grid; grid-template-columns: 88px 1fr 30px; align-items: center; gap: 8px; }
.uk-vis--forge .fg-shap .bar .lbl { font-size: 10px; color: rgba(255,255,255,.65); font-family: 'JetBrains Mono', monospace; }
.uk-vis--forge .fg-shap .bar .b {
	height: 7px; background: linear-gradient(90deg, var(--green) 0%, rgba(118,188,33,.25) 100%);
	border-radius: 1px; width: var(--w);
}
.uk-vis--forge .fg-shap .bar .num { font-size: 10px; color: var(--green); font-weight: 600; text-align: right; font-family: 'JetBrains Mono', monospace; }
.uk-vis--forge .fg-foot { display: flex; flex-direction: column; gap: 3px; font-size: 11px; padding-top: 6px; border-top: 1px solid rgba(255,255,255,.08); }
.uk-vis--forge .fg-foot .ok { color: var(--green); margin-right: 6px; }

/* ---------- PIPELINE — IDP ---------- */
.uk-vis--pipeline .pl-stages {
	display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 64px;
	gap: 8px;
}
.uk-vis--pipeline .st {
	background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
	border-radius: 3px; padding: 6px 8px;
	display: flex; flex-direction: column; gap: 1px;
}
.uk-vis--pipeline .st .lab { font-size: 10px; letter-spacing: .14em; color: var(--green); font-weight: 600; }
.uk-vis--pipeline .st .t   { font-size: 11.5px; color: var(--white); font-weight: 600; }
.uk-vis--pipeline .st .d   { font-size: 9.5px; color: rgba(255,255,255,.5); font-family: monospace; }
.uk-vis--pipeline .st.active { border-color: var(--green); background: rgba(118,188,33,.08); box-shadow: 0 0 12px rgba(118,188,33,.2); }
.uk-vis--pipeline .pl-conf, .uk-vis--pipeline .pl-foot {
	display: flex; flex-direction: column; gap: 3px; font-size: 11px;
}
.uk-vis--pipeline .pl-conf .ln { display: flex; justify-content: space-between; }
.uk-vis--pipeline .pl-conf .k { color: rgba(255,255,255,.5); font-family: monospace; }
.uk-vis--pipeline .pl-conf .v { color: var(--green); font-family: monospace; font-weight: 600; }
.uk-vis--pipeline .pl-foot .ok { color: var(--green); margin-right: 6px; }

/* ---------- CADENCE — Product Engineering ---------- */
.uk-vis--cadence .cd-rail {
	position: relative; padding: 16px 0 28px;
}
.uk-vis--cadence .rail-bg {
	position: absolute; left: 0; right: 0; top: 50%; height: 2px;
	background: rgba(255,255,255,.12); transform: translateY(-50%);
}
.uk-vis--cadence .cd-ticks {
	position: relative; display: flex; justify-content: space-between; align-items: center; padding: 0 4px;
}
.uk-vis--cadence .tick {
	width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.25); flex-shrink: 0;
}
.uk-vis--cadence .tick.release { background: var(--blue); box-shadow: 0 0 8px rgba(0,167,225,.5); }
.uk-vis--cadence .tick.ship    { background: var(--green); box-shadow: 0 0 12px var(--green); width: 10px; height: 10px; }
.uk-vis--cadence .cd-pin {
	position: absolute; right: 0; bottom: 0; font-size: 10px; letter-spacing: .14em; color: var(--green); font-weight: 600;
}
.uk-vis--cadence .cd-legend {
	display: flex; gap: 16px; font-size: 10px; color: rgba(255,255,255,.6);
}
.uk-vis--cadence .cd-legend .ic { display: inline-block; width: 6px; height: 6px; border-radius: 50%; vertical-align: 2px; margin-right: 4px; }
.uk-vis--cadence .cd-legend .ic.release { background: var(--blue); }
.uk-vis--cadence .cd-legend .ic.ship    { background: var(--green); }
.uk-vis--cadence .cd-dora {
	display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.uk-vis--cadence .cd-dora .d {
	background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
	border-radius: 3px; padding: 8px 10px;
	display: flex; justify-content: space-between; align-items: baseline;
}
.uk-vis--cadence .cd-dora .k { font-size: 10px; color: rgba(255,255,255,.55); letter-spacing: .08em; text-transform: uppercase; }
.uk-vis--cadence .cd-dora .v { font-size: 16px; font-weight: 600; color: var(--green); }
.uk-vis--cadence .cd-foot { font-size: 11px; color: rgba(255,255,255,.65); padding-top: 4px; border-top: 1px solid rgba(255,255,255,.08); }
.uk-vis--cadence .cd-foot .ok { color: var(--green); margin-right: 6px; }

/* ---------- BENCH — Resource Augmentation ---------- */
.uk-vis--bench .bn-grid {
	flex: 1; display: grid; grid-template-columns: 1fr; gap: 6px;
}
.uk-vis--bench .prof {
	background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
	border-radius: 3px; padding: 7px 12px;
	display: grid; grid-template-columns: 70px 1fr auto; gap: 10px; align-items: center;
	min-height: 0;
}
.uk-vis--bench .prof .role  { font-size: 12px; font-weight: 600; color: var(--green); }
.uk-vis--bench .prof .stack { font-size: 10.5px; color: rgba(255,255,255,.65); font-family: monospace; }
.uk-vis--bench .prof .count { font-size: 11px; font-weight: 700; color: var(--white); padding: 2px 8px; background: rgba(118,188,33,.12); border: 1px solid rgba(118,188,33,.3); border-radius: 999px; }
.uk-vis--bench .bn-ramp {
	display: flex; align-items: center; gap: 4px; padding: 6px 0; border-top: 1px solid rgba(255,255,255,.08);
	flex-shrink: 0;
}
.uk-vis--bench .bn-ramp .step {
	display: flex; flex-direction: column; align-items: center; gap: 1px;
	flex: 0 0 auto;
}
.uk-vis--bench .bn-ramp .step .d { font-size: 10px; font-weight: 700; color: var(--green); padding: 1px 5px; background: rgba(118,188,33,.12); border-radius: 2px; }
.uk-vis--bench .bn-ramp .step.done .d { background: rgba(0,167,225,.15); color: var(--blue); }
.uk-vis--bench .bn-ramp .step .l { font-size: 8.5px; color: rgba(255,255,255,.5); letter-spacing: .06em; text-transform: uppercase; }
.uk-vis--bench .bn-ramp .dash { flex: 1; height: 1px; background: rgba(255,255,255,.15); }
.uk-vis--bench .bn-foot { font-size: 10.5px; color: rgba(255,255,255,.65); flex-shrink: 0; }
.uk-vis--bench .bn-foot .ok { color: var(--green); margin-right: 6px; }
.uk-vis--bench .prof .role  { font-size: 11.5px; }
.uk-vis--bench .prof .stack { font-size: 10px; }

/* ---------- REPLUMB — Workflow Automation ---------- */
.uk-vis--replumb .rp-split {
	flex: 1; display: grid; grid-template-columns: 1fr auto 1fr;
	gap: 8px; align-items: stretch; min-height: 0;
}
.uk-vis--replumb .rp-side {
	background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.08);
	border-radius: 3px; padding: 10px;
	display: flex; flex-direction: column; gap: 5px;
	min-height: 0;
}
.uk-vis--replumb .rp-side .hdr { font-size: 9.5px; letter-spacing: .14em; color: rgba(255,255,255,.5); text-transform: uppercase; padding-bottom: 4px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 2px; }
.uk-vis--replumb .rp-before .chip {
	font-size: 10px; padding: 3px 8px; background: rgba(255,255,255,.05);
	border: 1px solid rgba(255,255,255,.12); border-radius: 2px;
	color: rgba(255,255,255,.65); align-self: flex-start;
}
.uk-vis--replumb .rp-before { opacity: .65; }
.uk-vis--replumb .rp-after  { border-color: rgba(118,188,33,.35); }
.uk-vis--replumb .rp-after .hdr { color: var(--green); }
.uk-vis--replumb .rp-after .step {
	font-size: 10.5px; color: rgba(255,255,255,.85);
	display: flex; align-items: center; gap: 6px;
	padding: 3px 0; border-bottom: 1px dashed rgba(255,255,255,.08);
}
.uk-vis--replumb .rp-after .step:last-of-type { border-bottom: none; }
.uk-vis--replumb .rp-after .step .i { color: var(--green); font-weight: 600; }
.uk-vis--replumb .rp-after .step .ai, .uk-vis--replumb .rp-after .step .hitl {
	font-size: 8.5px; padding: 1px 5px; border-radius: 2px;
	letter-spacing: .12em; margin-left: auto;
}
.uk-vis--replumb .rp-after .step .ai   { background: rgba(0,167,225,.15); color: var(--blue); }
.uk-vis--replumb .rp-after .step .hitl { background: rgba(255,200,100,.15); color: rgb(255,200,100); }
.uk-vis--replumb .rp-arrow { display: flex; align-items: center; justify-content: center; color: var(--green); font-size: 18px; padding: 0 4px; }
.uk-vis--replumb .rp-side .hdr { font-weight: 600; }
.uk-vis--replumb .rp-before .hdr { color: rgb(255,150,100); }
.uk-vis--replumb .rp-after  .hdr { color: var(--green); }
.uk-vis--replumb .rp-foot { font-size: 10.5px; color: rgba(255,255,255,.7); padding-top: 6px; border-top: 1px solid rgba(255,255,255,.08); flex-shrink: 0; }
.uk-vis--replumb .rp-foot .ok { color: var(--green); margin-right: 6px; }

/* ====================================================================== *
 *  Service-page inline mockups — compact, in-flow illustrations
 * ====================================================================== */
.uk-svc-inline {
	background: var(--ink);
	color: rgba(255,255,255,.85);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: 4px;
	padding: 18px 20px;
	font-family: 'Poppins', system-ui, sans-serif;
	font-size: 13px;
	margin: 28px 0;
	display: flex; flex-direction: column; gap: 8px;
	max-width: 720px;
}
.uk-svc-inline .hd {
	display: flex; justify-content: space-between; align-items: center;
	font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase;
	color: rgba(255,255,255,.5);
	padding-bottom: 8px; border-bottom: 1px solid rgba(255,255,255,.08);
	margin-bottom: 4px;
}
.uk-svc-inline .hd .live { color: var(--green); animation: uk-rec-pulse 1.4s ease-in-out infinite; }
.uk-svc-inline .ok   { color: var(--green); }
.uk-svc-inline .warn { color: rgb(255,200,100); }
.uk-svc-inline .ft   { font-size: 11px; color: rgba(255,255,255,.55); padding-top: 6px; border-top: 1px solid rgba(255,255,255,.06); }

/* RAG trace · terminal */
.uk-svc-inline--rag .ln { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: rgba(255,255,255,.8); }
.uk-svc-inline--rag .ok { margin-right: 8px; }

/* Approval-gate ladder · loop */
.uk-svc-inline--gates .rung {
	display: flex; align-items: center; gap: 10px;
	padding: 6px 0; font-size: 12px; color: rgba(255,255,255,.85);
	border-bottom: 1px dashed rgba(255,255,255,.06);
}
.uk-svc-inline--gates .rung:last-of-type { border-bottom: none; }
.uk-svc-inline--gates .rung .i { color: var(--green); font-weight: 600; }
.uk-svc-inline--gates .rung.pause .i { color: rgb(255,200,100); }
.uk-svc-inline--gates .rung .ok, .uk-svc-inline--gates .rung .warn { margin-left: auto; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; }

/* Build/Pilot/Skip scorecard · roadmap */
.uk-svc-inline--scorecard .rows { display: flex; flex-direction: column; gap: 6px; }
.uk-svc-inline--scorecard .row { display: grid; grid-template-columns: 60px 1fr 30px; align-items: center; gap: 12px; }
.uk-svc-inline--scorecard .row .t { font-size: 11px; color: rgba(255,255,255,.6); letter-spacing: .12em; text-transform: uppercase; font-weight: 600; }
.uk-svc-inline--scorecard .row .bar { height: 8px; background: rgba(255,255,255,.06); border-radius: 1px; overflow: hidden; }
.uk-svc-inline--scorecard .row .b { display: block; height: 100%; width: var(--w); background: var(--green); }
.uk-svc-inline--scorecard .row .b.pilot { background: var(--blue); }
.uk-svc-inline--scorecard .row .b.skip  { background: rgba(255,255,255,.25); }
.uk-svc-inline--scorecard .row .n { font-size: 12px; font-weight: 600; color: var(--green); text-align: right; }

/* Confidence gauge · channels */
.uk-svc-inline--gauge .gauge { position: relative; height: 10px; background: rgba(255,255,255,.08); border-radius: 1px; overflow: hidden; margin: 4px 0; }
.uk-svc-inline--gauge .g-fill { display: block; height: 100%; width: var(--p); background: linear-gradient(90deg, rgb(255,150,100) 0%, var(--green) 100%); }
.uk-svc-inline--gauge .g-lbl  { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); font-size: 10px; font-weight: 700; color: var(--white); }
.uk-svc-inline--gauge .ln { font-size: 12px; }

/* Model card · forge */
.uk-svc-inline--card .kv { display: flex; justify-content: space-between; gap: 10px; padding: 4px 0; font-size: 12px; border-bottom: 1px dashed rgba(255,255,255,.06); }
.uk-svc-inline--card .kv:last-of-type { border-bottom: none; }
.uk-svc-inline--card .kv .k { color: rgba(255,255,255,.5); font-family: monospace; }
.uk-svc-inline--card .kv .v { color: var(--white); font-family: monospace; }

/* CER strip · pipeline */
.uk-svc-inline--cer .cer-bars { display: flex; align-items: flex-end; gap: 4px; height: 56px; padding: 4px 0; }
.uk-svc-inline--cer .cer-bars .b { flex: 1; height: var(--w); background: linear-gradient(180deg, var(--green) 0%, rgba(118,188,33,.4) 100%); border-radius: 1px 1px 0 0; }
.uk-svc-inline--cer .cer-bars .b.warn { background: linear-gradient(180deg, rgb(255,200,100) 0%, rgba(255,200,100,.4) 100%); }

/* DORA quad · cadence */
.uk-svc-inline--dora .quad { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.uk-svc-inline--dora .q { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 3px; padding: 8px 12px; display: flex; justify-content: space-between; align-items: baseline; }
.uk-svc-inline--dora .q .k { font-size: 10px; color: rgba(255,255,255,.55); letter-spacing: .08em; text-transform: uppercase; }
.uk-svc-inline--dora .q .v { font-size: 18px; font-weight: 700; color: var(--green); }

/* Onboarding ramp · bench */
.uk-svc-inline--ramp .ramp { display: flex; align-items: center; gap: 0; padding: 8px 0; }
.uk-svc-inline--ramp .ramp .dot { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 0 0 auto; }
.uk-svc-inline--ramp .ramp .dot b { font-size: 11px; font-weight: 700; color: var(--green); padding: 3px 8px; background: rgba(118,188,33,.12); border-radius: 2px; }
.uk-svc-inline--ramp .ramp .dot.done b { background: rgba(0,167,225,.15); color: var(--blue); }
.uk-svc-inline--ramp .ramp .dot span { font-size: 9.5px; color: rgba(255,255,255,.55); letter-spacing: .06em; text-transform: uppercase; }
.uk-svc-inline--ramp .ramp .line { flex: 1; height: 1px; background: rgba(255,255,255,.18); margin: 0 4px; align-self: center; }
.uk-svc-inline--ramp .ramp .line.dashed { background: repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 4px, transparent 4px 8px); }

/* SLA dashboard · replumb */
.uk-svc-inline--sla .tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.uk-svc-inline--sla .t { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 3px; padding: 10px; display: flex; flex-direction: column; gap: 2px; }
.uk-svc-inline--sla .t .k { font-size: 10px; color: rgba(255,255,255,.5); letter-spacing: .08em; text-transform: uppercase; }
.uk-svc-inline--sla .t .v { font-size: 20px; font-weight: 700; color: var(--green); line-height: 1; }
.uk-svc-inline--sla .t .d { font-size: 10px; color: rgba(255,255,255,.55); }

/* Engagement masthead right column gets the new wrapper */
.uk-s-engage__masthead-right { display: flex; flex-direction: column; gap: 14px; }
.uk-s-engage__masthead-right > .uk-svc-inline { margin: 8px 0 0; }
.uk-svc-inline--gates, .uk-svc-inline--gauge, .uk-svc-inline--cer,
.uk-svc-inline--ramp { background: rgba(11,30,63,.92); }

/* Reduced motion: cut all animations on the new visuals */
@media (prefers-reduced-motion: reduce) {
	.uk-vis--loop .loop-arrows .arc,
	.uk-vis--loop .node,
	.uk-vis--loop .loop-core .dot,
	.uk-vis--forge .fg-shap .bar .b,
	.uk-svc-inline .hd .live {
		animation: none !important;
	}
	.uk-vis--loop .loop-arrows .arc { stroke-dashoffset: 0; opacity: .7; }
}

/* Mobile: keep visuals readable on narrow viewports */
@media (max-width: 880px) {
	.uk-vis--loop, .uk-vis--roadmap, .uk-vis--channels, .uk-vis--forge,
	.uk-vis--pipeline, .uk-vis--cadence, .uk-vis--bench, .uk-vis--replumb {
		padding: 22px 22px 70px; font-size: 11px;
	}
	.uk-vis--forge .fg-grid { grid-template-columns: 1fr; }
	.uk-vis--forge .fg-arrow { transform: rotate(90deg); }
	.uk-vis--replumb .rp-split { grid-template-columns: 1fr; }
	.uk-vis--replumb .rp-arrow { transform: rotate(90deg); padding: 4px 0; }
	.uk-svc-inline--sla .tiles { grid-template-columns: 1fr; }
}
