/* =========================================================
   UK Accountants — Theme Stylesheet
   Implements brand guidelines v1.0 (navy / gold / slate)
   ========================================================= */

:root {
	/* Brand guidelines v1.0 — Navy + Sovereign Gold. */
	--uka-navy:       #0B1F3A;   /* Primary navy */
	--uka-navy-mid:   #1C3557;   /* Hover / mid states */
	--uka-navy-soft:  #2A4468;
	--uka-gold:       #C4A064;   /* Sovereign Gold (accent / CTA) */
	--uka-gold-soft:  #D4B57E;   /* Hover */
	--uka-slate:      #4A5568;   /* Body text */
	--uka-slate-2:    #718096;   /* Secondary */
	--uka-cloud:      #F0F4F8;   /* Cloud background */
	--uka-cloud-2:    #F8FAFC;
	--uka-border:     #E2E8F0;
	--uka-white:      #FFFFFF;
	--uka-red:        #C0392B;   /* ICAEW red */
	--uka-green:      #E8F5E0;
	--uka-shadow:     0 12px 40px -12px rgba(11, 31, 58, 0.16);
	--uka-shadow-lg:  0 30px 80px -30px rgba(11, 31, 58, 0.28);
	--uka-radius:     14px;
	--uka-radius-sm:  8px;
	--uka-container:  1200px;

	--uka-font-sans:  'Plus Jakarta Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--uka-font-serif: 'Lora', Georgia, 'Times New Roman', serif;
}

/* --------- Base --------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--uka-font-sans);
	font-size: 16px;
	line-height: 1.7;
	color: var(--uka-slate);
	background: var(--uka-white);
	-webkit-font-smoothing: antialiased;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--uka-navy); text-decoration: none; transition: color .2s; }
a:hover { color: var(--uka-gold); }
p { margin: 0 0 1em; }
h1, h2, h3, h4, h5 { color: var(--uka-navy); margin: 0 0 .5em; line-height: 1.2; }
h1, h2 { font-family: var(--uka-font-serif); font-weight: 600; letter-spacing: -0.01em; }
h3, h4 { font-family: var(--uka-font-sans); font-weight: 700; letter-spacing: -0.01em; }
strong { color: var(--uka-navy); font-weight: 700; }
ul, ol { padding-left: 1.25em; }

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

.uka-skiplink {
	position: absolute;
	left: -9999px;
	top: 0;
	background: var(--uka-navy);
	color: #fff;
	padding: 12px 20px;
	z-index: 9999;
}
.uka-skiplink:focus { left: 8px; top: 8px; }

/* --------- Container --------- */
.uka-container {
	width: 100%;
	max-width: var(--uka-container);
	margin: 0 auto;
	padding: 0 24px;
}
@media (min-width: 900px) { .uka-container { padding: 0 40px; } }
@media (min-width: 1200px) { .uka-container { padding: 0 60px; } }

/* --------- Typography helpers --------- */
.uka-eyebrow {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--uka-slate-2);
	margin: 0 0 10px;
}
.uka-eyebrow--gold { color: var(--uka-gold); }
.uka-eyebrow--centered { text-align: center; }
.uka-h2 { font-family: var(--uka-font-serif); font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 600; color: var(--uka-navy); letter-spacing: -0.01em; margin: 0 0 .5em; }
.uka-h3 { font-family: var(--uka-font-serif); font-size: clamp(1.4rem, 2vw, 1.9rem); font-weight: 600; color: var(--uka-navy); }
.uka-h2--light { color: #fff; }
.uka-lede { font-size: 1.05rem; color: var(--uka-slate); max-width: 60ch; margin: 0 0 .5em; }
.uka-lede--light { color: rgba(255,255,255,0.75); }
.uka-link-arrow { color: var(--uka-navy); font-weight: 600; display: inline-flex; align-items: center; gap: 6px; border-bottom: 1.5px solid var(--uka-gold); padding-bottom: 2px; }

/* --------- Buttons --------- */
.uka-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-family: var(--uka-font-sans);
	font-weight: 600;
	font-size: 14px;
	line-height: 1;
	padding: 14px 24px;
	border-radius: 8px;
	border: 1.5px solid transparent;
	cursor: pointer;
	transition: transform .15s ease, background .2s, color .2s, border-color .2s, box-shadow .2s;
	text-decoration: none;
	white-space: nowrap;
}
.uka-btn:hover { transform: translateY(-1px); }
.uka-btn--lg { padding: 17px 28px; font-size: 15px; border-radius: 10px; }
.uka-btn--block { width: 100%; }
.uka-btn--gold { background: var(--uka-gold); color: var(--uka-navy); border-color: var(--uka-gold); font-weight: 700; }
.uka-btn--gold:hover { background: var(--uka-gold-soft); color: var(--uka-navy); box-shadow: 0 12px 28px -10px rgba(196,160,100,0.55); }
.uka-btn--dark { background: var(--uka-navy); color: #fff; border-color: var(--uka-navy); }
.uka-btn--dark:hover { background: var(--uka-navy-mid); color: #fff; }
.uka-btn--ghost { background: transparent; color: var(--uka-navy); border-color: var(--uka-navy); }
.uka-btn--ghost:hover { background: var(--uka-navy); color: #fff; }
.uka-btn--ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,0.35); }
.uka-btn--ghost-light:hover { background: rgba(255,255,255,0.08); color: #fff; border-color: #fff; }

/* --------- Badges / chips --------- */
.uka-badge {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 11px; font-weight: 700; letter-spacing: 0.04em;
	padding: 5px 10px; border-radius: 999px;
}
.uka-badge--gold { background: var(--uka-gold); color: var(--uka-navy); }
.uka-badge--ghost { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.85); border: 1px solid rgba(255,255,255,0.15); }

.uka-chip {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 12px; font-weight: 600;
	padding: 6px 12px; border-radius: 999px;
	background: var(--uka-cloud); color: var(--uka-navy);
	border: 1px solid var(--uka-border);
}
.uka-chip--gold { background: var(--uka-gold); color: var(--uka-navy); border-color: var(--uka-gold); }

/* --------- Icons --------- */
.uka-icon { flex-shrink: 0; display: inline-block; vertical-align: middle; }

/* =========================================================
   ANNOUNCEMENT BAR
   ========================================================= */
.uka-announce {
	background: var(--uka-navy);
	color: rgba(255,255,255,0.8);
	font-size: 12px;
	padding: 8px 0;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}
.uka-announce__inner {
	display: flex; flex-wrap: wrap; gap: 16px 24px;
	align-items: center; justify-content: center;
}
.uka-announce__inner span { display: inline-flex; align-items: center; gap: 6px; }
.uka-announce__inner span svg { color: var(--uka-gold); }
.uka-announce__phone { color: #fff; font-weight: 600; margin-left: auto; display: inline-flex; align-items: center; gap: 6px; }
.uka-announce__phone:hover { color: var(--uka-gold); }

/* =========================================================
   HEADER
   ========================================================= */
.uka-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(255,255,255,0.96);
	backdrop-filter: saturate(180%) blur(10px);
	border-bottom: 1px solid var(--uka-border);
}
.uka-header__inner {
	display: flex; align-items: center;
	gap: 24px;
	padding: 14px 0;
}
.uka-brand__link { display: inline-flex; align-items: center; gap: 12px; color: var(--uka-navy); }
.uka-brand__mark {
	width: 40px; height: 40px;
	background: var(--uka-navy);
	color: var(--uka-gold);
	border-radius: 10px;
	display: inline-flex; align-items: center; justify-content: center;
	font-family: var(--uka-font-serif);
	font-weight: 600; font-size: 15px;
	letter-spacing: 0.02em;
}
.uka-brand__text { display: inline-flex; flex-direction: column; line-height: 1; }
.uka-brand__name {
	font-family: var(--uka-font-serif);
	font-size: 1.25rem; font-weight: 600;
	color: var(--uka-navy);
	letter-spacing: -0.02em;
}
.uka-brand__sub {
	font-size: 10px; font-weight: 600; letter-spacing: 0.15em;
	text-transform: uppercase; color: var(--uka-gold); margin-top: 4px;
}
.uka-brand__link--dark .uka-brand__name { color: #fff; }

.uka-nav { display: flex; align-items: center; gap: 28px; margin-left: auto; }
.uka-nav__list {
	display: flex; list-style: none; margin: 0; padding: 0;
	gap: 4px; align-items: center;
}
.uka-nav__list > li { position: relative; }
.uka-nav__list a {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 10px 14px;
	font-weight: 500; font-size: 15px; color: var(--uka-navy);
	border-radius: 8px;
}
.uka-nav__list a:hover, .uka-nav__list .current-menu-item > a { color: var(--uka-navy); background: var(--uka-cloud); }

/* Dropdown submenu (desktop) */
.uka-nav__caret { transition: transform .2s; opacity: .7; }
.uka-nav__submenu,
.uka-nav__list .sub-menu {
	position: absolute; top: calc(100% + 8px); left: 0;
	min-width: 280px;
	list-style: none; margin: 0; padding: 8px;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: 12px;
	box-shadow: 0 12px 44px rgba(11,31,58,.15), 0 4px 14px rgba(11,31,58,.08);
	opacity: 0; visibility: hidden;
	transform: translateY(-6px);
	transition: opacity .18s ease, transform .18s ease, visibility .18s;
	z-index: 50;
}
.uka-nav__submenu::before,
.uka-nav__list .sub-menu::before {
	content: '';
	position: absolute; top: -6px; left: 24px;
	width: 12px; height: 12px;
	background: #fff;
	border-top: 1px solid var(--uka-border);
	border-left: 1px solid var(--uka-border);
	transform: rotate(45deg);
}
.uka-nav__submenu li,
.uka-nav__list .sub-menu li { display: block; }
.uka-nav__submenu a,
.uka-nav__list .sub-menu a {
	display: block; padding: 10px 14px;
	font-size: 14px; font-weight: 500;
	color: var(--uka-navy);
	border-radius: 8px; white-space: normal;
}
.uka-nav__submenu a:hover,
.uka-nav__list .sub-menu a:hover {
	background: var(--uka-cloud);
	color: var(--uka-navy);
}
.uka-nav__submenu-all {
	border-top: 1px solid var(--uka-border);
	margin-top: 6px; padding-top: 6px;
}
.uka-nav__submenu-all a {
	color: var(--uka-gold) !important;
	font-weight: 700 !important;
	font-size: 13px !important;
}
.uka-nav__list > li:hover > .uka-nav__submenu,
.uka-nav__list > li:hover > .sub-menu,
.uka-nav__list > li:focus-within > .uka-nav__submenu,
.uka-nav__list > li:focus-within > .sub-menu {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.uka-nav__list > li:hover > a > .uka-nav__caret,
.uka-nav__list > li:focus-within > a > .uka-nav__caret { transform: rotate(180deg); }

.uka-nav-toggle {
	display: none;
	background: transparent; border: 0;
	color: var(--uka-navy); padding: 10px;
	margin-left: auto;
	cursor: pointer;
	border-radius: 8px;
	-webkit-tap-highlight-color: transparent;
}
.uka-nav-toggle:hover { background: var(--uka-cloud); }
.uka-nav-toggle[aria-expanded="true"] { background: var(--uka-cloud); }

/* -------- Mobile navigation (< 960px) -------- */
@media (max-width: 960px) {
	.uka-nav-toggle { display: inline-flex; }

	/* IMPORTANT: the header uses backdrop-filter, which creates a new containing
	   block for position:fixed descendants on WebKit. That was clipping the
	   mobile nav panel to the header's box, so only the first menu row was
	   visible. Drop the filter at the mobile breakpoint — solid white is fine
	   here and readability improves. */
	.uka-header {
		-webkit-backdrop-filter: none;
		backdrop-filter: none;
		background: #fff;
	}

	/* Nav becomes a fixed, full-width slide-in panel from under the header.
	   z-index sits ABOVE the sticky header (100) so taps on sub-items aren't
	   blocked by the header bar. */
	.uka-nav {
		position: fixed;
		top: 68px; /* approx header height — overridden below if header taller */
		left: 0;
		right: 0;
		bottom: 0;
		width: 100%;
		max-width: 100%;
		height: calc(100dvh - 68px);
		max-height: calc(100dvh - 68px);
		z-index: 110;
		background: #fff;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 20px 20px 120px;
		margin: 0;
		overflow-y: auto;
		overscroll-behavior: contain;
		-webkit-overflow-scrolling: touch;
		transform: translateX(100%);
		transition: transform .28s cubic-bezier(.4,0,.2,1);
		visibility: hidden;
		box-shadow: -4px 0 24px rgba(11,31,58,0.12);
	}
	.uka-nav.is-open {
		transform: translateX(0);
		visibility: visible;
	}
	/* Freeze body scroll when menu is open */
	body.uka-nav-open { overflow: hidden; }

	.uka-nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		width: 100%;
	}
	.uka-nav__list > li {
		width: 100%;
		border-bottom: 1px solid var(--uka-border);
	}
	.uka-nav__list > li:first-child { border-top: 1px solid var(--uka-border); }
	.uka-nav__list a {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 16px 4px;
		font-size: 16px;
		font-weight: 600;
		color: var(--uka-navy);
		border-radius: 0;
		background: transparent;
	}
	.uka-nav__list a:hover,
	.uka-nav__list .current-menu-item > a {
		background: transparent;
		color: var(--uka-gold);
	}
	.uka-nav__cta {
		margin-top: 24px;
		padding: 0;
	}
	.uka-nav__cta .uka-btn {
		width: 100%;
		justify-content: center;
		padding: 16px;
		font-size: 15px;
	}

	/* Submenu: flatten / always visible on mobile */
	.uka-nav__submenu,
	.uka-nav__list .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		border: 0;
		border-radius: 0;
		background: var(--uka-cloud-2);
		padding: 4px 0;
		min-width: 0;
		margin: 0 -20px 0; /* bleed to edges */
	}
	.uka-nav__submenu::before,
	.uka-nav__list .sub-menu::before { display: none; }
	.uka-nav__submenu li,
	.uka-nav__list .sub-menu li { border-bottom: 0 !important; }
	.uka-nav__submenu a,
	.uka-nav__list .sub-menu a {
		padding: 12px 24px;
		font-size: 14px;
		font-weight: 500;
		color: var(--uka-slate);
		border-bottom: 0;
	}
	.uka-nav__submenu a:hover,
	.uka-nav__list .sub-menu a:hover { color: var(--uka-gold); background: transparent; }
	.uka-nav__submenu-all a { color: var(--uka-gold) !important; font-weight: 700 !important; }
	.uka-nav__caret { display: inline-block; opacity: .5; transform: rotate(-90deg); }
}

@media (max-width: 560px) {
	.uka-nav {
		top: 60px;
		height: calc(100dvh - 60px);
		max-height: calc(100dvh - 60px);
		padding: 16px 16px 100px;
	}
	.uka-header__inner { padding: 10px 0; gap: 12px; }
	.uka-brand__mark { width: 36px; height: 36px; font-size: 13px; }
	.uka-brand__name { font-size: 1.05rem; }
	.uka-brand__sub { font-size: 9px; letter-spacing: 0.12em; }
	.uka-announce { display: none; } /* Hide announcement bar on small screens */
}

/* WP admin bar — push everything down so the sticky header sits below it and
   the mobile nav panel doesn't hide behind it. WP's built-in rule adds 32px
   on desktop and 46px on small screens via `html { margin-top }`, but our
   position:fixed nav calculates off the viewport, so we offset top/height too. */
@media (max-width: 960px) {
	body.admin-bar .uka-header { top: 46px; }
	body.admin-bar .uka-nav {
		top: calc(68px + 46px);
		height: calc(100dvh - 68px - 46px);
		max-height: calc(100dvh - 68px - 46px);
	}
}
@media (max-width: 560px) {
	body.admin-bar .uka-nav {
		top: calc(60px + 46px);
		height: calc(100dvh - 60px - 46px);
		max-height: calc(100dvh - 60px - 46px);
	}
}
@media (min-width: 783px) and (max-width: 960px) {
	body.admin-bar .uka-header { top: 32px; }
	body.admin-bar .uka-nav {
		top: calc(68px + 32px);
		height: calc(100dvh - 68px - 32px);
		max-height: calc(100dvh - 68px - 32px);
	}
}

/* =========================================================
   SECTIONS
   ========================================================= */
.uka-section { padding: 80px 0; }
@media (max-width: 700px) { .uka-section { padding: 56px 0; } }
.uka-section--dark { background: var(--uka-navy); color: rgba(255,255,255,0.8); }
.uka-section--dark .uka-lede { color: rgba(255,255,255,0.75); }
.uka-section--cloud { background: var(--uka-cloud-2); }
/* Warm cream tint — used directly below navy hero so the two sections clearly separate */
.uka-section--gold-tint { background: #F8F4EC; }
.uka-section__head { max-width: 720px; margin: 0 auto 48px; text-align: center; }
.uka-section__head--light h2, .uka-section__head--light { color: #fff; }
.uka-section__cta-row { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 40px; }

/* --------- Grids --------- */
.uka-grid-3 { display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 700px) { .uka-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px){ .uka-grid-3 { grid-template-columns: repeat(3, 1fr); } }
.uka-grid-2 { display: grid; gap: 32px; grid-template-columns: 1fr; align-items: start; }
@media (min-width: 900px) { .uka-grid-2 { grid-template-columns: 1fr 1fr; gap: 64px; } }
.uka-grid-2--balanced { align-items: center; }
.uka-grid-2--sidebar { grid-template-columns: 1fr; }
@media (min-width: 900px) { .uka-grid-2--sidebar { grid-template-columns: minmax(0, 1fr) 360px; gap: 48px; } }
.uka-grid-2--form { grid-template-columns: 1fr; }
@media (min-width: 900px) { .uka-grid-2--form { grid-template-columns: minmax(0, 1fr) 340px; gap: 48px; } }

/* =========================================================
   HERO
   ========================================================= */
.uka-hero {
	position: relative;
	background: linear-gradient(180deg, #081a33 0%, #0B1F3A 60%, #10294D 100%);
	color: #fff;
	padding: 96px 0 112px;
	overflow: hidden;
}
.uka-hero__bg { position: absolute; inset: 0; pointer-events: none; }
.uka-hero__blob {
	position: absolute; border-radius: 50%; filter: blur(2px);
}
.uka-hero__blob--1 { top: -140px; right: -120px; width: 420px; height: 420px; background: radial-gradient(circle, rgba(196,160,100,0.22), transparent 70%); }
.uka-hero__blob--2 { bottom: -160px; left: -80px; width: 380px; height: 380px; background: radial-gradient(circle, rgba(28,53,87,0.9), transparent 70%); }
.uka-hero__grid {
	position: relative; z-index: 1;
	display: grid; gap: 56px;
	grid-template-columns: 1fr;
	align-items: center;
}
@media (min-width: 1000px) { .uka-hero__grid { grid-template-columns: 1.15fr 1fr; gap: 72px; } }

.uka-hero__title {
	font-family: var(--uka-font-serif); font-weight: 600;
	font-size: clamp(2.2rem, 5vw, 3.7rem);
	line-height: 1.08;
	color: #fff;
	letter-spacing: -0.01em;
	margin: 8px 0 20px;
}
.uka-hero__title span { color: var(--uka-gold); }
.uka-hero__sub { font-size: clamp(1rem, 1.6vw, 1.15rem); color: rgba(255,255,255,0.78); max-width: 56ch; margin-bottom: 28px; }
.uka-hero__sub strong { color: #fff; }
.uka-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 20px; }
.uka-hero__note { font-size: 13px; color: rgba(255,255,255,0.55); margin-bottom: 24px; }

/* Slider container holding For Companies / For Individuals cards */
.uka-hero__cards {
	position: relative;
	width: 100%;
}
.uka-hero__cards-tabs {
	display: flex;
	gap: 6px;
	padding: 6px;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 999px;
	margin: 0 0 14px;
	max-width: max-content;
}
.uka-hero__cards-tab {
	appearance: none;
	background: transparent;
	border: 0;
	color: rgba(255,255,255,0.7);
	font: 600 13px/1 var(--uka-font-sans);
	padding: 9px 16px;
	border-radius: 999px;
	cursor: pointer;
	transition: background .18s, color .18s;
	white-space: nowrap;
}
.uka-hero__cards-tab:hover { color: #fff; }
.uka-hero__cards-tab.is-active {
	background: var(--uka-gold);
	color: var(--uka-navy);
}
.uka-hero__cards-tab:focus-visible {
	outline: 2px solid var(--uka-gold);
	outline-offset: 2px;
}
.uka-hero__cards-track {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
}
.uka-hero__cards-track > .uka-hero__card {
	grid-column: 1;
	grid-row: 1;
	opacity: 0;
	transform: translateY(6px);
	pointer-events: none;
	transition: opacity .28s ease, transform .28s ease;
}
.uka-hero__cards-track > .uka-hero__card.uka-hero__card--active {
	opacity: 1;
	transform: none;
	pointer-events: auto;
}
.uka-hero__cards-dots {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-top: 14px;
}
.uka-hero__cards-dot {
	appearance: none;
	width: 8px;
	height: 8px;
	padding: 0;
	border-radius: 999px;
	border: 0;
	background: rgba(255,255,255,0.25);
	cursor: pointer;
	transition: background .18s, width .18s;
}
.uka-hero__cards-dot.is-active { background: var(--uka-gold); width: 22px; }
.uka-hero__cards-dot:focus-visible { outline: 2px solid var(--uka-gold); outline-offset: 2px; }

.uka-hero__card {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 18px;
	padding: 28px;
	color: #fff;
	box-shadow: 0 40px 80px -30px rgba(0,0,0,0.6);
	backdrop-filter: blur(6px);
}
.uka-hero__card-header { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.uka-hero__card-name { font-family: var(--uka-font-serif); font-size: 1.25rem; color: #fff; margin: 0 0 4px; }
.uka-hero__card-price {
	font-family: var(--uka-font-sans);
	font-weight: 800;
	font-size: clamp(2.6rem, 5vw, 3.4rem);
	line-height: 1;
	margin: 0 0 20px;
	color: #fff;
}
.uka-price__currency { font-size: .55em; vertical-align: top; margin-right: 4px; color: var(--uka-gold); }
.uka-price__unit { font-size: .3em; font-weight: 500; color: rgba(255,255,255,0.55); margin-left: 10px; vertical-align: middle; }
.uka-hero__card-list { list-style: none; padding: 0; margin: 0 0 24px; display: grid; gap: 10px; }
.uka-hero__card-list li { display: flex; align-items: center; gap: 10px; font-size: 14px; color: rgba(255,255,255,0.85); }
.uka-hero__card-list svg { color: var(--uka-gold); flex-shrink: 0; }
.uka-hero__card-micro { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.5); text-align: center; margin: 14px 0 0; }

/* Trust strip */
.uka-trust-strip {
	display: flex; flex-wrap: wrap; gap: 10px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,0.1);
	margin-top: 12px;
}
.uka-hero .uka-trust-strip, .uka-section--dark .uka-trust-strip, .uka-section--final .uka-trust-strip { border-top-color: rgba(255,255,255,0.1); }
.uka-trust-item {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 8px 14px; border-radius: 999px;
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.1);
	font-size: 13px; font-weight: 600; color: rgba(255,255,255,0.85);
}
.uka-trust-item__icon { color: var(--uka-gold); display: inline-flex; }
body:not(.uka-home) .uka-section:not(.uka-section--dark):not(.uka-section--final) .uka-trust-strip {
	border-top-color: var(--uka-border);
}
body:not(.uka-home) .uka-section:not(.uka-section--dark):not(.uka-section--final) .uka-trust-item {
	background: var(--uka-white);
	border-color: var(--uka-border);
	color: var(--uka-navy);
}

/* =========================================================
   SECTION 2 — TRUST GRID
   ========================================================= */
.uka-section--trust { padding-top: 72px; padding-bottom: 72px; border-bottom: 1px solid var(--uka-border); }
.uka-trust-grid { display: grid; gap: 16px; grid-template-columns: 1fr; margin-top: 24px; }
@media (min-width: 700px) { .uka-trust-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .uka-trust-grid { grid-template-columns: repeat(4, 1fr); } }
.uka-trust-card {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 28px 24px;
	text-align: left;
}
.uka-trust-card h3 { font-size: 16px; margin: 12px 0 6px; font-weight: 700; }
.uka-trust-card p { font-size: 14px; color: var(--uka-slate); margin: 0; }
.uka-trust-card__icon {
	width: 52px; height: 52px; border-radius: 12px;
	background: var(--uka-cloud);
	color: var(--uka-navy);
	display: inline-flex; align-items: center; justify-content: center;
}
.uka-trust-card__icon--red { background: rgba(192,57,43,0.1); color: var(--uka-red); }

/* =========================================================
   SECTION 3 — ELIGIBILITY
   ========================================================= */
.uka-section--eligibility { background: var(--uka-cloud-2); }
.uka-eligibility__cards { display: grid; gap: 16px; grid-template-columns: 1fr; }
@media (min-width: 600px) { .uka-eligibility__cards { grid-template-columns: repeat(3, 1fr); } }
.uka-eligibility__card {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-left: 4px solid var(--uka-gold);
	border-radius: var(--uka-radius);
	padding: 24px 20px;
	text-align: center;
}
.uka-eligibility__value {
	font-family: var(--uka-font-sans); font-weight: 800;
	font-size: clamp(1.8rem, 4vw, 2.4rem); color: var(--uka-navy);
	margin: 0 0 4px; line-height: 1;
}
.uka-eligibility__value span {
	display: block; font-size: 11px; color: var(--uka-slate-2);
	font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; margin-top: 6px;
}
.uka-eligibility__label { font-size: 13px; color: var(--uka-slate); margin: 0; }

/* =========================================================
   SECTION 4 — SERVICES GRID
   ========================================================= */
.uka-services-grid { margin-top: 24px; }
.uka-service-card {
	position: relative;
	display: flex; flex-direction: column; gap: 10px;
	background: #fff;
	border: 1.5px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 28px 24px;
	color: var(--uka-navy);
	text-decoration: none;
	transition: transform .2s, box-shadow .2s, border-color .2s;
	min-height: 260px;
	overflow: hidden;
}
/* Gold left-border accent — reveals on hover */
.uka-service-card::before {
	content: '';
	position: absolute;
	left: 0; top: 16px; bottom: 16px;
	width: 3px; border-radius: 0 2px 2px 0;
	background: var(--uka-gold);
	transform: scaleY(0); transform-origin: center;
	transition: transform .22s ease;
}
.uka-service-card:hover {
	transform: translateY(-2px);
	border-color: rgba(196, 160, 100, .5);
	box-shadow: var(--uka-shadow);
	color: var(--uka-navy);
}
.uka-service-card:hover::before { transform: scaleY(1); }

.uka-service-card__icon {
	width: 44px; height: 44px; border-radius: 10px;
	background: rgba(196, 160, 100, .12); color: var(--uka-gold);
	display: inline-flex; align-items: center; justify-content: center;
	margin-bottom: 6px;
}
.uka-service-card__icon svg { color: var(--uka-gold); }

.uka-service-card__title {
	font-family: var(--uka-font-sans);
	font-size: 1rem; font-weight: 700;
	margin: 0; color: var(--uka-navy);
	letter-spacing: -.01em; line-height: 1.3;
}
.uka-service-card__desc {
	color: var(--uka-slate);
	font-size: 14px; line-height: 1.65;
	margin: 0; flex: 1;
}
.uka-service-card__price-line {
	font-size: 13px; font-weight: 700;
	color: var(--uka-gold);
	margin: 2px 0 0;
	letter-spacing: .01em;
}
.uka-service-card__link {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 13px; font-weight: 700;
	color: var(--uka-navy);
	margin-top: 4px;
}
.uka-service-card__link svg { transition: transform .18s; }
.uka-service-card:hover .uka-service-card__link svg { transform: translateX(3px); }

/* Legacy — still used in case older templates render tag/foot */
.uka-service-card__tag { color: var(--uka-slate); font-size: 14px; margin: 0 0 24px; }
.uka-service-card__foot {
	margin-top: auto;
	display: flex; align-items: center; justify-content: space-between;
	padding-top: 16px; border-top: 1px solid var(--uka-border);
}
.uka-service-card__price { font-weight: 800; color: var(--uka-navy); }

/* =========================================================
   SECTION 5 — STEPS
   ========================================================= */
.uka-steps {
	list-style: none; margin: 0; padding: 0;
	display: grid; gap: 20px; grid-template-columns: 1fr;
	counter-reset: step;
}
@media (min-width: 800px) { .uka-steps { grid-template-columns: repeat(3, 1fr); gap: 28px; } }
.uka-step {
	position: relative;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 32px 28px 28px;
	box-shadow: 0 2px 14px -8px rgba(11,31,58,0.12);
}
.uka-step__num {
	position: absolute; top: -18px; left: 28px;
	background: var(--uka-gold); color: var(--uka-navy);
	font-weight: 800; font-size: 14px;
	padding: 6px 14px; border-radius: 999px; letter-spacing: 0.1em;
}
.uka-step__title {
	color: var(--uka-navy);
	font-size: 1.05rem;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 10px;
}
.uka-step__title svg { color: var(--uka-gold); }
.uka-step p { color: var(--uka-slate); font-size: 14.5px; margin: 0; }

/* Dark-section variant — when steps live inside the navy --dark section,
   swap back to the glassy light-on-dark treatment. */
.uka-section--dark .uka-step {
	background: rgba(255,255,255,0.03);
	border-color: rgba(255,255,255,0.1);
	box-shadow: none;
}
.uka-section--dark .uka-step__title { color: #fff; }
.uka-section--dark .uka-step p { color: rgba(255,255,255,0.72); }

/* =========================================================
   SECTION 6 — PRICING
   ========================================================= */
.uka-pricing-grid { display: grid; gap: 24px; grid-template-columns: 1fr; margin-top: 24px; }
@media (min-width: 800px) { .uka-pricing-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .uka-pricing-grid { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); } }
.uka-price-card {
	position: relative;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: 18px;
	padding: 36px 32px 32px;
	display: flex; flex-direction: column;
}
.uka-price-card--featured {
	border: 2px solid var(--uka-gold);
	background: linear-gradient(180deg, #fff 0%, #FFFDF7 100%);
	box-shadow: var(--uka-shadow);
}
.uka-price-card__flag {
	position: absolute; top: -14px; left: 24px;
	background: var(--uka-gold); color: var(--uka-navy);
	font-size: 11px; font-weight: 700; letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 6px 14px; border-radius: 999px;
}
.uka-price-card__name { font-size: 1.25rem; font-family: var(--uka-font-sans); font-weight: 700; margin: 0 0 6px; color: var(--uka-navy); }
.uka-price-card__desc { font-size: 14px; color: var(--uka-slate); margin: 0 0 20px; }
.uka-price-card__price {
	font-family: var(--uka-font-sans); font-weight: 800;
	font-size: 3rem; color: var(--uka-navy);
	margin: 0 0 24px; line-height: 1;
	display: flex; align-items: baseline; gap: 4px; flex-wrap: wrap;
}
.uka-price-card__price span { font-size: .55em; color: var(--uka-gold); font-weight: 700; }
.uka-price-card__price small { font-size: .33em; color: var(--uka-slate-2); font-weight: 500; margin-left: 6px; }
.uka-price-card__list { list-style: none; padding: 0; margin: 0 0 28px; display: grid; gap: 10px; }
.uka-price-card__list li { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--uka-slate); }
.uka-price-card__list svg { color: var(--uka-gold); flex-shrink: 0; }
.uka-price-card__micro { font-size: 12px; color: var(--uka-slate-2); margin: 12px 0 0; text-align: center; }
.uka-pricing-foot { text-align: center; margin: 32px 0 0; color: var(--uka-slate); font-size: 14px; }

/* =========================================================
   SECTION 7 — PERSONAS
   ========================================================= */
.uka-persona-grid { display: grid; gap: 20px; grid-template-columns: 1fr; margin-top: 24px; }
@media (min-width: 600px) { .uka-persona-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px){ .uka-persona-grid { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 600px) and (max-width: 999px) { .uka-persona-grid > :last-child { grid-column: span 2; } }
.uka-persona-card {
	display: flex; flex-direction: column; align-items: flex-start;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 24px 22px;
	color: var(--uka-navy);
	text-decoration: none;
	transition: all .2s;
}
.uka-persona-card:hover { border-color: var(--uka-navy); transform: translateY(-2px); box-shadow: var(--uka-shadow); color: var(--uka-navy); }
.uka-persona-card__icon {
	width: 44px; height: 44px; border-radius: 10px;
	background: var(--uka-cloud); color: var(--uka-navy);
	display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px;
}
.uka-persona-card__title { font-size: 1rem; font-weight: 700; margin: 0 0 6px; color: var(--uka-navy); }
.uka-persona-card__tag { font-size: 13px; color: var(--uka-slate); margin: 0 0 16px; flex: 1; }
.uka-persona-card__link { display: inline-flex; align-items: center; gap: 4px; font-size: 13px; font-weight: 600; color: var(--uka-gold); margin-top: auto; }

/* =========================================================
   SECTION 8 — REVIEWS
   ========================================================= */
.uka-review {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 28px;
	display: flex; flex-direction: column; gap: 12px;
	height: 100%;
}
.uka-review__stars { color: var(--uka-gold); display: flex; gap: 2px; }
.uka-review__stars svg { fill: currentColor; }
.uka-review__quote { font-family: var(--uka-font-serif); font-size: 1.1rem; font-style: italic; color: var(--uka-navy); margin: 0; line-height: 1.5; }
.uka-review__foot { margin-top: auto; padding-top: 12px; border-top: 1px dashed var(--uka-border); }
.uka-review__author { margin: 0 0 8px; font-size: 14px; color: var(--uka-navy); }
.uka-review__author span { color: var(--uka-slate-2); font-weight: 400; }
.uka-review__meta { margin: 0; font-size: 12px; color: var(--uka-slate-2); display: inline-flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.uka-review__source { font-style: italic; }

/* =========================================================
   SECTION 9 — ICAEW
   ========================================================= */
.uka-section--icaew {
	background: linear-gradient(135deg, #0B1F3A 0%, #1C3557 100%);
	color: rgba(255,255,255,0.82);
}
.uka-icaew__badge { display: flex; justify-content: center; }
.uka-icaew__seal {
	width: 260px; height: 260px;
	border-radius: 50%;
	background: #fff;
	border: 6px solid var(--uka-red);
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	text-align: center;
	box-shadow:
		0 0 0 10px rgba(192, 57, 43, 0.08),
		0 0 0 22px rgba(192, 57, 43, 0.04),
		0 30px 60px -20px rgba(0,0,0,0.55);
}
.uka-icaew__seal-text {
	font-family: var(--uka-font-serif);
	font-weight: 700;
	font-size: 2.6rem;
	color: var(--uka-red);
	letter-spacing: 0.08em;
	line-height: 1;
}
.uka-icaew__seal-sub {
	font-family: var(--uka-font-sans);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--uka-navy);
	margin-top: 14px;
	max-width: 140px;
	line-height: 1.4;
}
.uka-icaew__list { list-style: none; padding: 0; margin: 24px 0; display: grid; gap: 14px; }
.uka-icaew__list li { display: flex; align-items: flex-start; gap: 12px; color: rgba(255,255,255,0.82); }
.uka-icaew__list li svg { color: var(--uka-gold); flex-shrink: 0; margin-top: 2px; }
.uka-icaew__list strong { color: #fff; }

/* =========================================================
   SECTION 10 — MTD
   ========================================================= */
.uka-section--mtd { background: var(--uka-cloud); padding: 48px 0; }
.uka-mtd__inner {
	display: flex; flex-direction: column; gap: 20px; align-items: flex-start;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-left: 4px solid var(--uka-gold);
	border-radius: var(--uka-radius);
	padding: 28px 32px;
}
@media (min-width: 800px) { .uka-mtd__inner { flex-direction: row; align-items: center; gap: 32px; } }
.uka-mtd__tag {
	display: inline-flex; align-items: center;
	background: var(--uka-gold); color: var(--uka-navy);
	font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
	padding: 6px 12px; border-radius: 999px;
	flex-shrink: 0;
}
.uka-mtd__copy { flex: 1; }
.uka-mtd__copy h2 { margin: 0 0 4px; font-size: 1.25rem; }
.uka-mtd__copy p { margin: 0; color: var(--uka-slate); font-size: 14.5px; }

/* =========================================================
   SECTION 11 — FINAL CTA
   ========================================================= */
.uka-section--final {
	background: linear-gradient(180deg, #0B1F3A 0%, #06132A 100%);
	color: #fff;
	text-align: center;
}
.uka-final { max-width: 760px; margin: 0 auto; }
.uka-final__title { font-family: var(--uka-font-serif); font-weight: 600; font-size: clamp(2rem, 4.5vw, 3rem); color: #fff; margin: 0 0 12px; letter-spacing: -0.01em; }
.uka-final__sub { color: rgba(255,255,255,0.72); font-size: 1.05rem; margin: 0 0 32px; }
.uka-final__cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-bottom: 28px; }
.uka-final .uka-trust-strip { justify-content: center; border-top-color: rgba(255,255,255,0.1); }

/* =========================================================
   PRE-FOOTER (form + CTA)
   ========================================================= */
.uka-pre-footer {
	background: linear-gradient(180deg, #F8FAFC 0%, #EDF2F7 100%);
	padding: 80px 0;
	border-top: 1px solid var(--uka-border);
}
.uka-pre-footer__grid {
	display: grid; gap: 48px; align-items: center;
	grid-template-columns: 1fr;
}
@media (min-width: 960px) { .uka-pre-footer__grid { grid-template-columns: 1fr 480px; } }
.uka-pre-footer__title { font-size: clamp(1.8rem, 3.5vw, 2.6rem); color: var(--uka-navy); margin: 0 0 16px; }
.uka-pre-footer__sub { color: var(--uka-slate); font-size: 1.05rem; max-width: 55ch; }
.uka-pre-footer__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.uka-pre-footer__cta .uka-btn--ghost-light { color: var(--uka-navy); border-color: var(--uka-navy); }
.uka-pre-footer__cta .uka-btn--ghost-light:hover { background: var(--uka-navy); color: #fff; }
.uka-pre-footer__form {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	box-shadow: var(--uka-shadow);
	padding: 28px;
}

/* =========================================================
   FOOTER
   ========================================================= */
.uka-footer {
	background: var(--uka-navy);
	color: rgba(255,255,255,0.7);
	padding: 64px 0 24px;
}
.uka-footer__grid {
	display: grid; gap: 40px;
	grid-template-columns: 1fr;
}
@media (min-width: 700px) { .uka-footer__grid { grid-template-columns: 1.4fr repeat(3, 1fr); } }
.uka-footer__brand .uka-brand__name { color: #fff; }
.uka-footer__about { font-size: 14px; margin: 16px 0 8px; max-width: 40ch; }
.uka-footer__parent { font-size: 11.5px; color: rgba(255,255,255,0.45); margin: 0 0 16px; max-width: 40ch; letter-spacing: 0.01em; }
.uka-footer__contact { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.uka-footer__contact li { display: flex; align-items: center; gap: 10px; font-size: 14px; }
.uka-footer__contact svg { color: var(--uka-gold); }
.uka-footer__contact a { color: rgba(255,255,255,0.9); }
.uka-footer__col h4 { color: #fff; font-size: 13px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; margin: 0 0 16px; }
.uka-footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.uka-footer__col a { color: rgba(255,255,255,0.7); font-size: 14px; }
.uka-footer__col a:hover { color: var(--uka-gold); }
.uka-footer__bottom {
	margin-top: 48px; padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,0.1);
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 16px; align-items: center;
	font-size: 12px; color: rgba(255,255,255,0.5);
}
.uka-footer__copyright { margin: 0; text-align: left; }
.uka-footer__credit {
	margin: 0; text-align: center;
	color: rgba(255,255,255,0.55);
	font-size: 12px;
}
.uka-footer__credit a {
	color: rgba(255,255,255,0.85);
	font-weight: 600;
	border-bottom: 1px solid rgba(196,160,100,0.4);
	padding-bottom: 1px;
	transition: color .2s, border-color .2s;
}
.uka-footer__credit a:hover {
	color: var(--uka-gold);
	border-bottom-color: var(--uka-gold);
}
.uka-footer__legal { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; justify-content: flex-end; }
.uka-footer__bottom ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; }
.uka-footer__bottom a { color: rgba(255,255,255,0.7); font-size: 12px; }
.uka-footer__bottom a:hover { color: var(--uka-gold); }
@media (max-width: 720px) {
	.uka-footer__bottom {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.uka-footer__copyright,
	.uka-footer__credit { text-align: center; }
	.uka-footer__legal { justify-content: center; }
}

/* =========================================================
   BREADCRUMBS
   ========================================================= */
.uka-breadcrumbs ol {
	list-style: none; padding: 0; margin: 0 0 16px;
	display: flex; flex-wrap: wrap; gap: 8px;
	font-size: 12px; font-weight: 500; color: var(--uka-slate-2);
	letter-spacing: 0.04em;
}
.uka-breadcrumbs li:not(:last-child)::after { content: "→"; color: var(--uka-slate-2); margin-left: 8px; }
.uka-breadcrumbs a { color: var(--uka-slate-2); }
.uka-breadcrumbs a:hover { color: var(--uka-gold); }
.uka-breadcrumbs [aria-current="page"] { color: var(--uka-navy); font-weight: 600; }

/* =========================================================
   PAGE HERO — navy/primary background, light text
   ========================================================= */
.uka-page-hero {
	background: linear-gradient(135deg, #0B1F3A 0%, #15315A 60%, #0B1F3A 100%);
	padding: 72px 0 64px;
	border-bottom: 1px solid rgba(255,255,255,0.06);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.uka-page-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 85% 20%, rgba(196,160,100,0.18) 0, transparent 45%),
		radial-gradient(circle at 10% 80%, rgba(196,160,100,0.08) 0, transparent 40%);
	pointer-events: none;
}
.uka-page-hero > .uka-container { position: relative; z-index: 1; }
.uka-page-hero--narrow { padding-bottom: 24px; }
.uka-page-hero__title {
	font-family: var(--uka-font-serif);
	font-weight: 600;
	font-size: clamp(2rem, 4vw, 3rem);
	margin: 8px 0 16px;
	color: #fff;
	letter-spacing: -0.01em;
}
.uka-page-hero__title em { color: var(--uka-gold); font-style: normal; }
.uka-page-hero__sub { font-size: 1.1rem; color: rgba(255,255,255,0.82); max-width: 62ch; }
.uka-page-hero__sub strong, .uka-page-hero__sub b { color: var(--uka-gold); font-weight: 700; }
.uka-page-hero__sub a { color: var(--uka-gold); }
.uka-page-hero__icon {
	display: inline-flex; align-items: center; justify-content: center;
	width: 60px; height: 60px; border-radius: 14px;
	background: rgba(255,255,255,0.08); color: var(--uka-gold);
	border: 1px solid rgba(196,160,100,0.35);
	margin-bottom: 12px;
}
.uka-page-hero__meta { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0 24px; }
.uka-page-hero__meta .uka-chip {
	background: rgba(255,255,255,0.08);
	color: #fff;
	border: 1px solid rgba(255,255,255,0.15);
}
.uka-page-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.uka-page-hero--service, .uka-page-hero--persona { padding-bottom: 64px; }

/* Breadcrumbs inside navy hero */
.uka-page-hero .uka-breadcrumbs ol { color: rgba(255,255,255,0.55); }
.uka-page-hero .uka-breadcrumbs a { color: rgba(255,255,255,0.7); }
.uka-page-hero .uka-breadcrumbs a:hover { color: var(--uka-gold); }
.uka-page-hero .uka-breadcrumbs [aria-current="page"] { color: #fff; }
.uka-page-hero .uka-breadcrumbs li:not(:last-child)::after { color: rgba(255,255,255,0.35); }

/* Eyebrow inside navy hero — keep gold for --gold variant, lighten the plain one */
.uka-page-hero .uka-eyebrow { color: rgba(255,255,255,0.7); }
.uka-page-hero .uka-eyebrow--gold { color: var(--uka-gold); }

/* Ghost button over navy must be light, not dark */
.uka-page-hero .uka-btn--ghost,
.uka-page-hero .uka-btn--ghost-light {
	color: #fff; border-color: rgba(255,255,255,0.5); background: transparent;
}
.uka-page-hero .uka-btn--ghost:hover,
.uka-page-hero .uka-btn--ghost-light:hover { background: #fff; color: var(--uka-navy); border-color: #fff; }

@media (max-width: 640px) {
	.uka-page-hero { padding: 48px 0 40px; }
	.uka-page-hero__title { font-size: clamp(1.6rem, 6vw, 2.2rem); }
	.uka-page-hero__sub { font-size: 1rem; }
	.uka-page-hero__cta { gap: 10px; }
	.uka-page-hero__cta .uka-btn { flex: 1 1 100%; justify-content: center; }
}

/* =========================================================
   PROSE (service / blog body)
   ========================================================= */
.uka-prose { max-width: 72ch; font-size: 16px; color: var(--uka-slate); }
.uka-prose h2 { font-family: var(--uka-font-serif); font-size: 1.6rem; margin: 2em 0 .6em; color: var(--uka-navy); }
.uka-prose h3 { font-size: 1.2rem; margin: 1.4em 0 .5em; color: var(--uka-navy); }
.uka-prose p { margin: 0 0 1em; }
.uka-prose ul, .uka-prose ol { margin: 0 0 1em 1.2em; }
.uka-prose li { margin: 0 0 .5em; }
.uka-prose a { color: var(--uka-navy); border-bottom: 1.5px solid var(--uka-gold); }
.uka-prose a:hover { color: var(--uka-gold); }
.uka-prose__hero { margin: 0 0 24px; border-radius: var(--uka-radius); overflow: hidden; }
.uka-prose blockquote {
	margin: 1.5em 0; padding: 16px 24px;
	border-left: 3px solid var(--uka-gold);
	background: var(--uka-cloud);
	font-family: var(--uka-font-serif); font-style: italic; color: var(--uka-navy);
	border-radius: 0 var(--uka-radius-sm) var(--uka-radius-sm) 0;
}

.uka-feature-list { list-style: none; padding: 0; margin: 16px 0 28px; display: grid; gap: 10px; }
.uka-feature-list li { display: flex; align-items: flex-start; gap: 10px; color: var(--uka-slate); }
.uka-feature-list svg { color: var(--uka-gold); margin-top: 3px; }

.uka-list { list-style: none; padding: 0; margin: 12px 0 0; display: grid; gap: 10px; }
.uka-list li { display: flex; align-items: flex-start; gap: 10px; color: var(--uka-slate); }
.uka-list--check svg { color: var(--uka-gold); }
.uka-list--x svg { color: var(--uka-red); }

.uka-callout {
	background: var(--uka-cloud);
	border: 1px solid var(--uka-border);
	border-left: 4px solid var(--uka-gold);
	border-radius: var(--uka-radius);
	padding: 22px 26px;
	margin: 32px 0;
}
.uka-callout h3 { margin: 0 0 6px; color: var(--uka-navy); }
.uka-callout p { margin: 0; color: var(--uka-slate); }
.uka-callout--wide { display: flex; flex-direction: column; gap: 16px; align-items: flex-start; margin: 48px 0 0; }
@media (min-width: 800px) { .uka-callout--wide { flex-direction: row; align-items: center; justify-content: space-between; gap: 24px; } }
.uka-callout--tight { padding: 16px 20px; margin: 16px 0 0; }

/* =========================================================
   SIDEBAR
   ========================================================= */
.uka-sidebar__card {
	position: sticky; top: 96px;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 24px;
	box-shadow: var(--uka-shadow);
}
.uka-sidebar__card h3 { margin: 0 0 6px; }
.uka-sidebar__card p { font-size: 14px; color: var(--uka-slate); margin: 0 0 16px; }
.uka-sidebar__card--dark { background: var(--uka-navy); color: #fff; }
.uka-sidebar__card--dark h3 { color: #fff; }
.uka-sidebar__card--dark p { color: rgba(255,255,255,0.72); }

/* =========================================================
   LEAD FORM
   ========================================================= */
.uka-lead-form {
	position: relative;
}
.uka-lead-form__head { margin-bottom: 16px; }
.uka-lead-form__title { font-size: 1.2rem; margin: 0 0 4px; color: var(--uka-navy); font-weight: 700; font-family: var(--uka-font-sans); }
.uka-lead-form__sub { font-size: 13.5px; color: var(--uka-slate); margin: 0; }
.uka-lead-form__grid {
	display: grid; gap: 14px; grid-template-columns: 1fr;
}
@media (min-width: 600px) { .uka-lead-form__grid { grid-template-columns: 1fr 1fr; } }
.uka-field--full { grid-column: 1 / -1; }
.uka-field { display: flex; flex-direction: column; gap: 6px; }
.uka-field > span {
	font-size: 12px; font-weight: 600; color: var(--uka-navy);
	letter-spacing: 0.04em;
}
.uka-field > span em { color: var(--uka-red); font-style: normal; margin-left: 2px; }
.uka-field input, .uka-field select, .uka-field textarea {
	font-family: var(--uka-font-sans); font-size: 14.5px;
	padding: 11px 14px;
	border: 1px solid var(--uka-border);
	border-radius: 8px;
	background: #fff;
	color: var(--uka-navy);
	transition: border-color .2s, box-shadow .2s;
}
.uka-field input:focus, .uka-field select:focus, .uka-field textarea:focus {
	outline: none;
	border-color: var(--uka-gold);
	box-shadow: 0 0 0 3px rgba(196,160,100,0.18);
}
.uka-field textarea { resize: vertical; }
.uka-field--check { flex-direction: row; align-items: flex-start; gap: 8px; font-size: 13px; color: var(--uka-slate); }
.uka-field--check span { font-weight: 400; color: var(--uka-slate); letter-spacing: 0; font-size: 13px; line-height: 1.5; }
.uka-field--check input { margin-top: 4px; width: 16px; height: 16px; accent-color: var(--uka-navy); }
.uka-field--check a { text-decoration: underline; }

.uka-hp { position: absolute !important; left: -9999px !important; height: 1px !important; width: 1px !important; overflow: hidden !important; }

.uka-lead-form__actions { margin-top: 20px; display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: space-between; }
.uka-lead-form__actions .uka-btn { padding: 14px 24px; }
.uka-lead-form__trust { display: flex; flex-wrap: wrap; gap: 10px; font-size: 11px; font-weight: 600; color: var(--uka-slate); margin: 0; }
.uka-lead-form__trust span { color: var(--uka-navy); }

.uka-lead-form__msg { margin-top: 14px; font-size: 14px; min-height: 0; }
.uka-lead-form__msg.is-error { color: var(--uka-red); }
.uka-lead-form__msg.is-success { color: #2F855A; background: var(--uka-green); padding: 12px 16px; border-radius: 8px; border: 1px solid #C6E8A7; }

.uka-btn__spinner { display: none; width: 14px; height: 14px; border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: uka-spin .7s linear infinite; }
.uka-lead-form.is-loading .uka-btn__spinner { display: inline-block; }
.uka-lead-form.is-loading button[type="submit"] { opacity: .7; pointer-events: none; }
@keyframes uka-spin { to { transform: rotate(360deg); } }

.uka-lead-form.is-compact .uka-lead-form__grid { grid-template-columns: 1fr; gap: 10px; }

/* =========================================================
   FAQ
   ========================================================= */
.uka-faq { display: grid; gap: 10px; }
.uka-faq__item {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 0;
	overflow: hidden;
}
.uka-faq__item summary {
	list-style: none;
	cursor: pointer;
	padding: 20px 24px;
	font-weight: 600; color: var(--uka-navy);
	display: flex; align-items: center; justify-content: space-between; gap: 16px;
	font-size: 15.5px;
}
.uka-faq__item summary::-webkit-details-marker { display: none; }
.uka-faq__item summary svg { color: var(--uka-gold); transition: transform .2s; }
.uka-faq__item[open] summary svg { transform: rotate(180deg); }
.uka-faq__body { padding: 0 24px 22px; color: var(--uka-slate); font-size: 14.5px; line-height: 1.7; }

/* =========================================================
   MISC
   ========================================================= */
.uka-pagination { margin-top: 32px; text-align: center; }
.uka-pagination .page-numbers { display: inline-block; padding: 10px 14px; margin: 0 4px; border-radius: 8px; color: var(--uka-navy); font-weight: 600; font-size: 14px; }
.uka-pagination .page-numbers.current { background: var(--uka-navy); color: #fff; }
.uka-pagination .page-numbers:hover { background: var(--uka-cloud); color: var(--uka-navy); }

.uka-search { display: flex; gap: 8px; }
.uka-search input { flex: 1; padding: 11px 14px; border: 1px solid var(--uka-border); border-radius: 8px; }

.uka-mini-steps { padding: 0; list-style: none; margin: 16px 0 24px; display: grid; gap: 14px; }
.uka-mini-steps li { padding-left: 0; font-size: 14.5px; color: var(--uka-slate); }
.uka-mini-steps strong { display: block; color: var(--uka-navy); margin-bottom: 2px; }

.uka-form-side .uka-form-wrap {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	box-shadow: var(--uka-shadow);
	padding: 28px;
}
.uka-form-reassure { font-size: 14px; }
.uka-form-reassure__trust { margin: 24px 0; }
.uka-form-reassure .uka-trust-item { background: #fff; border-color: var(--uka-border); color: var(--uka-navy); }
.uka-form-reassure .uka-trust-strip { border-top-color: var(--uka-border); }

@media (max-width: 700px) {
	.uka-hero { padding: 72px 0 80px; }
	.uka-pre-footer { padding: 56px 0; }
	.uka-footer { padding-top: 48px; }
}

/* ===========================================================
   WhatsApp floating button
   =========================================================== */
.uka-whatsapp {
	position: fixed;
	right: 18px;
	bottom: 18px;
	z-index: 9999;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: #25D366;
	color: #fff;
	padding: 12px 16px 12px 14px;
	border-radius: 999px;
	font-family: var(--uka-font-ui);
	font-weight: 600;
	font-size: 14px;
	line-height: 1;
	text-decoration: none;
	box-shadow: 0 10px 24px rgba(37, 211, 102, 0.35), 0 2px 6px rgba(0,0,0,0.18);
	transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.uka-whatsapp:hover, .uka-whatsapp:focus {
	background: #20bd5a;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 14px 30px rgba(37, 211, 102, 0.45), 0 4px 10px rgba(0,0,0,0.2);
}
.uka-whatsapp svg { flex: 0 0 auto; }
.uka-whatsapp__label { white-space: nowrap; }
@media (max-width: 600px) {
	.uka-whatsapp { right: 12px; bottom: 12px; padding: 12px; }
	.uka-whatsapp__label { display: none; }
}

/* =========================================================
   SINGLE SERVICE TEMPLATE — SEO + CRO
   ========================================================= */

/* --- Red chip variant (ICAEW badge) --- */
.uka-chip--red {
	background: rgba(192, 57, 43, 0.08);
	color: var(--uka-red);
	border-color: rgba(192, 57, 43, 0.22);
	font-weight: 700;
}
.uka-chip--red svg { color: var(--uka-red); }

/* --- Service hero --- */
.uka-service-hero {
	position: relative;
	background: linear-gradient(180deg, #081a33 0%, #0B1F3A 60%, #10294D 100%);
	color: #fff;
	padding: 40px 0 88px;
	overflow: hidden;
}
.uka-service-hero .uka-breadcrumbs ol {
	color: rgba(255,255,255,0.55);
	margin-bottom: 32px;
}
.uka-service-hero .uka-breadcrumbs a { color: rgba(255,255,255,0.65); }
.uka-service-hero .uka-breadcrumbs a:hover { color: var(--uka-gold); }
.uka-service-hero .uka-breadcrumbs [aria-current="page"] { color: #fff; }
.uka-service-hero .uka-breadcrumbs li:not(:last-child)::after { color: rgba(255,255,255,0.4); }

.uka-service-hero__grid {
	display: grid; gap: 48px;
	grid-template-columns: 1fr;
	align-items: start;
}
@media (min-width: 1000px) {
	.uka-service-hero__grid { grid-template-columns: 1.2fr 1fr; gap: 64px; }
}

.uka-service-hero__badges {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin-bottom: 20px;
}
.uka-service-hero__badges .uka-chip {
	background: rgba(255,255,255,0.06);
	color: rgba(255,255,255,0.9);
	border-color: rgba(255,255,255,0.14);
}
.uka-service-hero__badges .uka-chip--gold {
	background: var(--uka-gold);
	color: var(--uka-navy);
	border-color: var(--uka-gold);
}
.uka-service-hero__badges .uka-chip--red {
	background: rgba(192, 57, 43, 0.18);
	color: #FFC9C2;
	border-color: rgba(192, 57, 43, 0.35);
}
.uka-service-hero__badges .uka-chip--red svg { color: #FFC9C2; }

.uka-service-hero__title {
	font-family: var(--uka-font-serif);
	font-weight: 600;
	font-size: clamp(2rem, 4.4vw, 3.3rem);
	line-height: 1.1;
	color: #fff;
	letter-spacing: -0.01em;
	margin: 0 0 20px;
}
.uka-service-hero__title em {
	font-style: italic;
	color: var(--uka-gold);
	font-weight: 500;
}
.uka-service-hero__sub {
	font-size: 1.05rem;
	color: rgba(255,255,255,0.78);
	max-width: 58ch;
	margin: 0 0 24px;
}
.uka-service-hero__bullets {
	list-style: none; padding: 0; margin: 0 0 28px;
	display: grid; gap: 10px;
}
.uka-service-hero__bullets li {
	display: flex; align-items: flex-start; gap: 10px;
	color: rgba(255,255,255,0.88);
	font-size: 14.5px;
}
.uka-service-hero__bullets li svg {
	color: var(--uka-gold);
	flex-shrink: 0;
	margin-top: 2px;
}
.uka-service-hero__cta {
	display: flex; flex-wrap: wrap; gap: 12px;
	margin-bottom: 18px;
}
.uka-service-hero__micro {
	font-size: 12.5px; color: rgba(255,255,255,0.55);
	margin: 0;
	display: inline-flex; align-items: center; gap: 8px;
}
.uka-service-hero__micro svg { color: var(--uka-gold); }

/* Service hero sidecard */
.uka-service-hero__card {
	background: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 18px;
	padding: 28px;
	color: #fff;
	box-shadow: 0 40px 90px -30px rgba(0,0,0,0.6);
	backdrop-filter: blur(6px);
}
.uka-service-hero__card-header {
	display: flex; align-items: center; gap: 14px;
	padding-bottom: 20px;
	border-bottom: 1px solid rgba(255,255,255,0.1);
	margin-bottom: 20px;
}
.uka-service-hero__card-icon {
	flex-shrink: 0;
	width: 54px; height: 54px; border-radius: 12px;
	background: rgba(196,160,100,0.16);
	color: var(--uka-gold);
	display: inline-flex; align-items: center; justify-content: center;
}
.uka-service-hero__card-icon svg { color: var(--uka-gold); }
.uka-service-hero__card-label {
	font-size: 11px; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--uka-gold);
	margin: 0 0 4px;
}
.uka-service-hero__card-name {
	font-family: var(--uka-font-serif);
	font-size: 1.2rem; color: #fff;
	margin: 0; line-height: 1.2;
}
.uka-service-hero__card-price {
	font-family: var(--uka-font-sans); font-weight: 800;
	font-size: clamp(1.9rem, 3.4vw, 2.5rem);
	color: #fff;
	margin: 0 0 18px;
	line-height: 1;
}
.uka-service-hero__card-list {
	list-style: none; padding: 0; margin: 0 0 20px;
	display: grid; gap: 10px;
}
.uka-service-hero__card-list li {
	display: flex; align-items: flex-start; gap: 10px;
	font-size: 14px; color: rgba(255,255,255,0.85);
}
.uka-service-hero__card-list svg {
	color: var(--uka-gold);
	flex-shrink: 0; margin-top: 2px;
}
.uka-service-hero__card-micro {
	font-size: 11px; text-align: center;
	color: rgba(255,255,255,0.5);
	margin: 14px 0 0;
	letter-spacing: 0.08em;
}

/* --- Social proof strip --- */
.uka-service-proof {
	background: var(--uka-cloud-2);
	border-bottom: 1px solid var(--uka-border);
	padding: 20px 0;
}
.uka-service-proof__inner {
	display: flex; flex-wrap: wrap;
	align-items: center; justify-content: center;
	gap: 14px 28px;
}
.uka-service-proof__stars {
	display: inline-flex; gap: 2px;
	color: var(--uka-gold);
}
.uka-service-proof__stars svg { fill: currentColor; color: var(--uka-gold); }
.uka-service-proof__text {
	margin: 0;
	font-size: 14px;
	color: var(--uka-slate);
}
.uka-service-proof__text strong { color: var(--uka-navy); }
.uka-service-proof__list {
	list-style: none; padding: 0; margin: 0;
	display: flex; flex-wrap: wrap; gap: 14px 22px;
}
.uka-service-proof__list li {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 13px; font-weight: 600; color: var(--uka-navy);
}
.uka-service-proof__list svg { color: var(--uka-gold); }

/* --- Pain points grid --- */
.uka-pain-grid {
	display: grid; gap: 20px;
	grid-template-columns: 1fr;
	margin-top: 8px;
}
@media (min-width: 700px) { .uka-pain-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .uka-pain-grid { grid-template-columns: repeat(3, 1fr); } }

.uka-pain-card {
	position: relative;
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 28px 24px 24px;
	transition: border-color .2s, box-shadow .2s, transform .2s;
}
.uka-pain-card:hover {
	border-color: rgba(192, 57, 43, 0.25);
	box-shadow: var(--uka-shadow);
	transform: translateY(-2px);
}
.uka-pain-card__mark {
	display: inline-flex; align-items: center; justify-content: center;
	width: 36px; height: 36px; border-radius: 10px;
	background: rgba(192, 57, 43, 0.08);
	color: var(--uka-red);
	font-size: 18px; font-weight: 700;
	margin-bottom: 14px;
}
.uka-pain-card h3 {
	font-family: var(--uka-font-sans);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--uka-navy);
	margin: 0 0 8px;
	line-height: 1.35;
}
.uka-pain-card p {
	margin: 0;
	font-size: 14.5px;
	color: var(--uka-slate);
	line-height: 1.6;
}

/* --- Service body grid (main + sticky sidebar) --- */
.uka-service-body .uka-prose { max-width: 100%; }
.uka-service-longform {
	margin: 32px 0;
	padding: 24px 0;
	border-top: 1px solid var(--uka-border);
	border-bottom: 1px solid var(--uka-border);
}
.uka-service-longform h2 { margin-top: 1.5em; }

/* --- Comparison block: bad vs good --- */
.uka-compare {
	display: grid; gap: 16px;
	grid-template-columns: 1fr;
	margin: 40px 0;
}
@media (min-width: 700px) { .uka-compare { grid-template-columns: 1fr 1fr; gap: 20px; } }

.uka-compare__col {
	background: #fff;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 24px 22px;
}
.uka-compare__col--bad {
	background: var(--uka-cloud-2);
	border-color: var(--uka-border);
}
.uka-compare__col--bad .uka-compare__label { color: var(--uka-slate-2); }
.uka-compare__col--bad ul li {
	color: var(--uka-slate);
	text-decoration: line-through;
	text-decoration-color: rgba(192, 57, 43, 0.4);
	text-decoration-thickness: 1px;
}
.uka-compare__col--bad ul svg { color: var(--uka-red); }

.uka-compare__col--good {
	background: linear-gradient(180deg, #fff 0%, #FFFDF7 100%);
	border: 2px solid var(--uka-gold);
	box-shadow: var(--uka-shadow);
}
.uka-compare__col--good .uka-compare__label { color: var(--uka-gold); }
.uka-compare__col--good ul li { color: var(--uka-navy); font-weight: 500; }
.uka-compare__col--good ul svg { color: var(--uka-gold); }

.uka-compare__label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0 0 16px;
}
.uka-compare ul {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: 12px;
}
.uka-compare ul li {
	display: flex; align-items: flex-start; gap: 10px;
	font-size: 14.5px;
	line-height: 1.5;
}
.uka-compare ul svg { flex-shrink: 0; margin-top: 3px; }

/* --- Guarantee banner --- */
.uka-guarantee {
	display: flex; flex-wrap: wrap; gap: 18px;
	align-items: flex-start;
	background: linear-gradient(135deg, rgba(196,160,100,0.08) 0%, rgba(196,160,100,0.14) 100%);
	border: 1px solid rgba(196,160,100,0.3);
	border-left: 4px solid var(--uka-gold);
	border-radius: var(--uka-radius);
	padding: 24px 26px;
	margin: 40px 0;
}
.uka-guarantee__icon {
	flex-shrink: 0;
	width: 52px; height: 52px; border-radius: 12px;
	background: var(--uka-gold);
	color: var(--uka-navy);
	display: inline-flex; align-items: center; justify-content: center;
}
.uka-guarantee__icon svg { color: var(--uka-navy); }
.uka-guarantee__title {
	font-family: var(--uka-font-sans);
	font-size: 1.15rem; font-weight: 700;
	color: var(--uka-navy);
	margin: 0 0 6px;
}
.uka-guarantee p {
	margin: 0;
	color: var(--uka-slate);
	font-size: 14.5px;
	line-height: 1.6;
}

/* --- Inline testimonial quote --- */
.uka-inline-quote {
	background: var(--uka-cloud-2);
	border-left: 4px solid var(--uka-gold);
	border-radius: 0 var(--uka-radius) var(--uka-radius) 0;
	padding: 28px 32px;
	margin: 40px 0;
}
.uka-inline-quote__stars {
	display: inline-flex; gap: 2px;
	color: var(--uka-gold);
	margin-bottom: 10px;
}
.uka-inline-quote__stars svg { fill: currentColor; color: var(--uka-gold); }
.uka-inline-quote p {
	font-family: var(--uka-font-serif);
	font-style: italic;
	font-size: 1.2rem;
	line-height: 1.5;
	color: var(--uka-navy);
	margin: 0 0 12px;
}
.uka-inline-quote footer {
	font-size: 13.5px;
	color: var(--uka-slate);
	font-style: normal;
}
.uka-inline-quote footer strong { color: var(--uka-navy); }

/* --- Mid-content CTA --- */
.uka-mid-cta {
	display: flex; flex-wrap: wrap; gap: 20px;
	align-items: center; justify-content: space-between;
	background: linear-gradient(135deg, var(--uka-navy) 0%, var(--uka-navy-mid) 100%);
	border-radius: var(--uka-radius);
	padding: 28px 32px;
	margin: 40px 0 0;
	color: #fff;
}
.uka-mid-cta > div { flex: 1 1 280px; }
.uka-mid-cta h3 {
	font-family: var(--uka-font-serif);
	font-size: 1.35rem;
	color: #fff;
	margin: 0 0 6px;
}
.uka-mid-cta p {
	margin: 0;
	color: rgba(255,255,255,0.78);
	font-size: 14.5px;
}
.uka-mid-cta .uka-btn { flex-shrink: 0; }

/* --- Sticky sidebar --- */
.uka-sidebar--sticky {
	position: relative;
}
@media (min-width: 1000px) {
	.uka-sidebar--sticky { position: sticky; top: 100px; align-self: start; }
}
.uka-sidebar__price-label {
	font-size: 11px; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--uka-gold);
	margin: 0 0 4px;
}
.uka-sidebar__price {
	font-family: var(--uka-font-sans); font-weight: 800;
	font-size: clamp(1.8rem, 3vw, 2.2rem);
	color: #fff;
	margin: 0 0 16px;
	line-height: 1;
}
.uka-sidebar__points {
	list-style: none; padding: 0; margin: 0 0 20px;
	display: grid; gap: 8px;
	padding-bottom: 20px;
	border-bottom: 1px solid rgba(255,255,255,0.12);
}
.uka-sidebar__points li {
	display: flex; align-items: center; gap: 8px;
	font-size: 13.5px;
	color: rgba(255,255,255,0.85);
}
.uka-sidebar__points svg { color: var(--uka-gold); flex-shrink: 0; }

/* Dark sidebar overrides for the lead form within */
.uka-sidebar__card--dark .uka-lead-form__title { color: #fff; }
.uka-sidebar__card--dark .uka-lead-form__sub { color: rgba(255,255,255,0.7); }
.uka-sidebar__card--dark .uka-field > span { color: rgba(255,255,255,0.85); }
.uka-sidebar__card--dark .uka-field input,
.uka-sidebar__card--dark .uka-field select,
.uka-sidebar__card--dark .uka-field textarea {
	background: rgba(255,255,255,0.06);
	border-color: rgba(255,255,255,0.14);
	color: #fff;
}
.uka-sidebar__card--dark .uka-field input::placeholder,
.uka-sidebar__card--dark .uka-field textarea::placeholder { color: rgba(255,255,255,0.4); }
.uka-sidebar__card--dark .uka-field--check span { color: rgba(255,255,255,0.72); }
.uka-sidebar__card--dark .uka-lead-form__trust { color: rgba(255,255,255,0.6); }
.uka-sidebar__card--dark .uka-lead-form__trust span { color: #fff; }

/* --- Sticky mobile CTA --- */
.uka-sticky-cta {
	display: none;
	position: fixed;
	left: 12px; right: 12px; bottom: 12px;
	z-index: 95;
	background: var(--uka-navy);
	color: #fff;
	border-radius: 999px;
	padding: 12px 16px 12px 20px;
	box-shadow: 0 14px 32px -8px rgba(11, 31, 58, 0.55), 0 6px 12px rgba(0,0,0,0.18);
	text-decoration: none;
	align-items: center; justify-content: space-between;
	gap: 16px;
	font-size: 14px; font-weight: 600;
}
.uka-sticky-cta__price {
	color: var(--uka-gold);
	font-weight: 700;
	font-size: 13.5px;
}
.uka-sticky-cta__btn {
	display: inline-flex; align-items: center; gap: 6px;
	background: var(--uka-gold);
	color: var(--uka-navy);
	padding: 8px 14px;
	border-radius: 999px;
	font-weight: 700;
	font-size: 13px;
}
.uka-sticky-cta__btn svg { color: var(--uka-navy); }
@media (max-width: 720px) {
	.uka-sticky-cta { display: flex; }
	body.single-uka_service .uka-whatsapp { bottom: 78px; }
	body.single-uka_service { padding-bottom: 70px; }
}

/* --- Fine-tune service hero on small screens --- */
@media (max-width: 700px) {
	.uka-service-hero { padding: 24px 0 64px; }
	.uka-service-hero__card { padding: 24px; }
	.uka-mid-cta { padding: 24px; }
	.uka-guarantee { padding: 20px; }
	.uka-inline-quote { padding: 22px 24px; }
}

/* =========================================================
   About — EEAT hero, stats, team, credentials, longform
   ========================================================= */
.uka-about-hero { padding: 56px 0 40px; }
.uka-about-hero__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px;
	align-items: center;
}
@media (min-width: 900px) {
	.uka-about-hero__grid { grid-template-columns: 1.3fr 1fr; gap: 64px; }
}
.uka-about-hero__lead { font-size: 1.1rem; color: var(--uka-slate); max-width: 62ch; margin-bottom: 24px; }
.uka-about-hero__stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin: 28px 0 0;
}
@media (min-width: 600px) {
	.uka-about-hero__stats { grid-template-columns: repeat(4, 1fr); }
}
.uka-about-hero__stat {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius-sm);
	padding: 16px 14px;
	text-align: center;
}
.uka-about-hero__stat strong {
	display: block;
	font-family: var(--uka-font-serif);
	font-size: 1.6rem;
	color: var(--uka-navy);
	line-height: 1;
}
.uka-about-hero__stat span {
	display: block;
	font-size: 12.5px;
	color: var(--uka-slate-2);
	margin-top: 6px;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}
.uka-about-hero__badge {
	position: relative;
	aspect-ratio: 1 / 1;
	max-width: 320px;
	margin: 0 auto;
	background: radial-gradient(circle at 50% 50%, #fff 0, var(--uka-cloud-2) 65%, var(--uka-cloud) 100%);
	border: 2px solid var(--uka-gold);
	border-radius: 50%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 32px;
	box-shadow: var(--uka-shadow);
}
.uka-about-hero__badge strong { display: block; color: var(--uka-navy); font-size: 18px; margin: 8px 0 4px; }
.uka-about-hero__badge span { display: block; color: var(--uka-slate-2); font-size: 13px; }
.uka-about-hero__badge svg { color: var(--uka-red); }

.uka-about-values {
	list-style: none;
	padding: 0;
	margin: 24px 0 0;
	display: grid;
	gap: 14px;
}
.uka-about-values li {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	font-size: 15px;
	color: var(--uka-slate);
}
.uka-about-values li svg { color: var(--uka-gold); flex: 0 0 auto; margin-top: 3px; }
.uka-about-values strong { color: var(--uka-navy); }

/* Team grid */
.uka-team-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	margin-top: 32px;
}
@media (min-width: 720px) { .uka-team-grid { grid-template-columns: repeat(3, 1fr); } }
.uka-team-card {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 28px 24px;
	text-align: left;
	box-shadow: 0 2px 12px -8px rgba(11,31,58,0.12);
}
.uka-team-card__photo {
	width: 76px;
	height: 76px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--uka-navy), var(--uka-navy-mid));
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--uka-font-serif);
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 18px;
	border: 2px solid var(--uka-gold);
}
.uka-team-card h3 { font-size: 17px; margin: 0 0 4px; }
.uka-team-card__role { color: var(--uka-slate-2); font-size: 13.5px; margin: 0 0 10px; text-transform: uppercase; letter-spacing: 0.04em; }
.uka-team-card__quals {
	display: inline-block;
	background: rgba(196,160,100,0.12);
	color: var(--uka-navy);
	font-size: 12px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 999px;
	margin-bottom: 12px;
	letter-spacing: 0.03em;
}
.uka-team-card__bio { font-size: 14.5px; color: var(--uka-slate); line-height: 1.7; margin: 0; }

/* Credentials definition list (About / Contact) */
.uka-credentials {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 24px;
	margin: 0;
}
.uka-credentials dt {
	font-size: 12px;
	color: var(--uka-slate-2);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-top: 14px;
}
.uka-credentials dt:first-of-type { margin-top: 0; }
.uka-credentials dd {
	margin: 4px 0 0;
	color: var(--uka-navy);
	font-weight: 600;
	font-size: 14.5px;
}
.uka-credentials--wide {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0 40px;
	padding: 28px 32px;
}
@media (min-width: 720px) {
	.uka-credentials--wide { grid-template-columns: 1fr 1fr; }
}

/* About — Heritage timeline */
.uka-about-timeline {
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
	display: grid;
	gap: 28px;
	max-width: 880px;
	margin-left: auto;
	margin-right: auto;
}
.uka-about-timeline::before {
	content: "";
	position: absolute;
	left: 12px;
	top: 12px;
	bottom: 12px;
	width: 2px;
	background: linear-gradient(to bottom, var(--uka-gold) 0%, var(--uka-gold) 50%, rgba(196,160,100,0.25) 100%);
	border-radius: 2px;
}
@media (min-width: 720px) {
	.uka-about-timeline::before { left: 16px; }
}
.uka-about-timeline__item {
	position: relative;
	display: grid;
	grid-template-columns: 40px 1fr;
	gap: 16px;
	align-items: start;
}
@media (min-width: 720px) {
	.uka-about-timeline__item { grid-template-columns: 56px 1fr; gap: 24px; }
}
.uka-about-timeline__marker {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 28px;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	padding-top: 8px;
}
.uka-about-timeline__dot {
	display: block;
	width: 14px;
	height: 14px;
	border-radius: 999px;
	background: var(--uka-gold);
	border: 3px solid var(--uka-white);
	box-shadow: 0 0 0 1px var(--uka-gold), 0 4px 14px -4px rgba(196,160,100,0.6);
	margin-left: 5px;
}
@media (min-width: 720px) {
	.uka-about-timeline__dot { margin-left: 9px; }
}
.uka-about-timeline__body {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 18px 22px 16px;
	box-shadow: 0 2px 12px -8px rgba(11,31,58,0.08);
}
.uka-about-timeline__period {
	font-size: 12px;
	color: var(--uka-gold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0 0 6px;
	font-weight: 700;
}
.uka-about-timeline__title {
	font-family: var(--uka-font-serif);
	font-size: 18px;
	color: var(--uka-navy);
	margin: 0 0 8px;
	line-height: 1.3;
}
.uka-about-timeline__text {
	color: var(--uka-slate);
	font-size: 14.5px;
	line-height: 1.65;
	margin: 0;
}

/* About — Principal spotlight */
.uka-about-principal {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 32px;
	box-shadow: 0 4px 24px -12px rgba(11,31,58,0.12);
	max-width: 980px;
	margin: 0 auto;
}
@media (min-width: 720px) {
	.uka-about-principal { grid-template-columns: 180px 1fr; gap: 36px; padding: 40px; align-items: start; }
}
.uka-about-principal__avatar {
	width: 140px;
	height: 140px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--uka-navy), #1c3557);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 4px solid var(--uka-gold);
	box-shadow: 0 8px 24px -10px rgba(11,31,58,0.4);
}
@media (min-width: 720px) {
	.uka-about-principal__avatar { width: 180px; height: 180px; }
}
.uka-about-principal__initials {
	font-family: var(--uka-font-serif);
	font-size: 56px;
	color: var(--uka-gold);
	font-weight: 600;
	letter-spacing: 0.02em;
}
@media (min-width: 720px) {
	.uka-about-principal__initials { font-size: 72px; }
}
.uka-about-principal__role {
	font-size: 12px;
	color: var(--uka-gold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0 0 12px;
	font-weight: 700;
}
.uka-about-principal__body p {
	color: var(--uka-slate);
	line-height: 1.7;
	margin: 0 0 14px;
}
.uka-about-principal__body p:first-of-type { color: var(--uka-navy); font-size: 1.05rem; }
.uka-about-principal__facts {
	list-style: none;
	padding: 16px 0 0;
	margin: 16px 0 0;
	border-top: 1px solid var(--uka-border);
	display: grid;
	gap: 8px;
}
.uka-about-principal__facts li {
	display: grid;
	grid-template-columns: 90px 1fr;
	gap: 12px;
	font-size: 14px;
	color: var(--uka-slate);
}
.uka-about-principal__facts strong {
	color: var(--uka-slate-2);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 11.5px;
	font-weight: 700;
	padding-top: 2px;
}
.uka-about-team-note {
	margin: 40px auto 0;
	max-width: 820px;
	text-align: center;
}
.uka-about-team-note h3 {
	color: var(--uka-navy);
	font-size: 22px;
	margin: 0 0 12px;
}
.uka-about-team-note p {
	color: var(--uka-slate);
	line-height: 1.75;
	margin: 0;
	font-size: 15px;
}

/* EEAT longform section (About) */
.uka-eeat { margin-top: 32px; }
.uka-eeat h3 {
	font-family: var(--uka-font-serif);
	font-weight: 600;
	font-size: 20px;
	color: var(--uka-navy);
	border-left: 3px solid var(--uka-gold);
	padding-left: 14px;
	margin: 28px 0 10px;
}
.uka-eeat p { font-size: 15px; color: var(--uka-slate); }

/* =========================================================
   Contact — card grid
   ========================================================= */
.uka-contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin: 24px 0 40px;
}
@media (min-width: 720px) { .uka-contact-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .uka-contact-grid { grid-template-columns: repeat(4, 1fr); } }
.uka-contact-card {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 22px 20px;
}
.uka-contact-card__icon {
	width: 40px;
	height: 40px;
	border-radius: 10px;
	background: var(--uka-cloud);
	color: var(--uka-navy);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
}
.uka-contact-card h3 { font-size: 14px; margin: 0 0 6px; color: var(--uka-slate-2); text-transform: uppercase; letter-spacing: 0.04em; }
.uka-contact-card p { font-size: 15.5px; color: var(--uka-navy); margin: 0; font-weight: 600; word-break: break-word; }
.uka-contact-card p a { color: var(--uka-navy); border-bottom: 1px solid var(--uka-gold); }
.uka-contact-card p a:hover { color: var(--uka-gold); }
.uka-contact-card small { display: block; margin-top: 6px; font-size: 12.5px; color: var(--uka-slate-2); font-weight: 500; }

.uka-press-callout {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	background: var(--uka-cloud-2);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 20px 24px;
	margin-top: 20px;
}
.uka-press-callout svg { color: var(--uka-gold); flex: 0 0 auto; margin-top: 2px; }
.uka-press-callout h3 { font-size: 15px; margin: 0 0 4px; }
.uka-press-callout p { font-size: 14px; color: var(--uka-slate); margin: 0; }

/* =========================================================
   Legal — prose, TOC, footnote
   ========================================================= */
.uka-legal-prose {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 32px 36px;
	font-size: 15.5px;
	line-height: 1.75;
	color: var(--uka-slate);
}
@media (max-width: 600px) {
	.uka-legal-prose { padding: 24px 20px; }
}
.uka-legal-prose h2 {
	font-family: var(--uka-font-serif);
	font-size: 22px;
	font-weight: 600;
	color: var(--uka-navy);
	margin: 32px 0 10px;
	padding-top: 8px;
	border-top: 1px solid var(--uka-border);
}
.uka-legal-prose h2:first-of-type { border-top: 0; padding-top: 0; margin-top: 8px; }
.uka-legal-prose h3 { font-size: 17px; margin-top: 22px; color: var(--uka-navy); }
.uka-legal-prose p { margin: 0 0 1em; }
.uka-legal-prose ul, .uka-legal-prose ol { padding-left: 1.2em; margin: 0 0 1em; }
.uka-legal-prose li { margin-bottom: 6px; }
.uka-legal-prose a { color: var(--uka-navy); border-bottom: 1px solid var(--uka-gold); }
.uka-legal-prose a:hover { color: var(--uka-gold); }
.uka-legal-intro { font-size: 17px !important; color: var(--uka-navy) !important; font-weight: 500; }

.uka-legal-foot {
	margin-top: 24px;
	padding: 16px 20px;
	background: var(--uka-cloud-2);
	border-radius: var(--uka-radius-sm);
	font-size: 13.5px;
	color: var(--uka-slate-2);
}
.uka-legal-foot strong { color: var(--uka-navy); }

.uka-legal-toc {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 2px;
}
.uka-legal-toc li { margin: 0; }
.uka-legal-toc a {
	display: block;
	padding: 8px 10px;
	border-radius: 6px;
	font-size: 14px;
	color: var(--uka-slate);
	border-left: 2px solid transparent;
}
.uka-legal-toc a:hover { background: var(--uka-cloud); border-left-color: var(--uka-gold); color: var(--uka-navy); }
.uka-legal-toc a.is-current { background: var(--uka-cloud); border-left-color: var(--uka-gold); color: var(--uka-navy); font-weight: 600; }

/* =========================================================
   Sitemap (HTML) page
   ========================================================= */
.uka-sitemap-group {
	margin: 0 0 40px;
	padding: 28px 28px 20px;
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	box-shadow: 0 2px 12px -8px rgba(11,31,58,0.08);
}
.uka-sitemap-group + .uka-sitemap-group { margin-top: 0; }
.uka-sitemap-group__title {
	font-size: 22px;
	margin: 0 0 6px;
	color: var(--uka-navy);
	position: relative;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--uka-gold);
	display: inline-block;
}
.uka-sitemap-group__intro {
	margin: 12px 0 20px;
	color: var(--uka-slate);
	font-size: 15px;
}
.uka-sitemap-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 4px;
}
@media (min-width: 640px) {
	.uka-sitemap-list { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px 24px; }
}
.uka-sitemap-list__item {
	margin: 0;
	padding: 10px 12px;
	border-radius: 8px;
	border-left: 2px solid transparent;
	transition: background .15s, border-color .15s;
}
.uka-sitemap-list__item:hover { background: var(--uka-cloud); border-left-color: var(--uka-gold); }
.uka-sitemap-list__link {
	display: block;
	font-weight: 600;
	color: var(--uka-navy);
	text-decoration: none;
	line-height: 1.35;
}
.uka-sitemap-list__link:hover { color: var(--uka-gold); }
.uka-sitemap-list__desc {
	display: block;
	margin-top: 4px;
	font-size: 13.5px;
	color: var(--uka-slate-2);
	line-height: 1.45;
}
.uka-sitemap-note {
	font-size: 12.5px;
	color: var(--uka-slate-2);
	margin-top: -6px !important;
}
@media (max-width: 640px) {
	.uka-sitemap-group { padding: 22px 18px 14px; }
	.uka-sitemap-group__title { font-size: 19px; }
}

/* =========================================================
   Pricing — comparison table (CSS grid, not <table>)
   ========================================================= */
.uka-compare-table {
	margin-top: 32px;
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	overflow: hidden;
	box-shadow: 0 2px 12px -8px rgba(11,31,58,0.1);
}
.uka-compare-table__row {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
	align-items: center;
	padding: 14px 18px;
	border-bottom: 1px solid var(--uka-border);
	font-size: 14.5px;
	color: var(--uka-slate);
	gap: 12px;
}
.uka-compare-table__row:last-child { border-bottom: 0; }
.uka-compare-table__row > div { min-width: 0; }
.uka-compare-table__row .is-us {
	background: rgba(196,160,100,0.08);
	color: var(--uka-navy);
	font-weight: 700;
	margin: -14px -8px;
	padding: 14px 8px;
}
.uka-compare-table__row svg { display: inline-block; vertical-align: middle; }
.uka-compare-table__row svg + svg { display: none; } /* guard */
.uka-compare-table__row .is-us svg { color: #2f7a3a; }
.uka-compare-table__row svg[data-icon="close"], .uka-compare-table__row .uka-icon-close { color: var(--uka-red); }
.uka-compare-table__feat { color: var(--uka-navy); font-weight: 600; }
.uka-compare-table__row--head {
	background: var(--uka-cloud-2);
	color: var(--uka-navy);
	font-family: var(--uka-font-sans);
	font-weight: 700;
	font-size: 13.5px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.uka-compare-table__row--head .is-us {
	background: var(--uka-navy);
	color: #fff;
	position: relative;
	border-radius: 8px;
}
.uka-compare-table__row--head .is-us::after {
	content: 'Us';
	position: absolute;
	top: -8px;
	right: 8px;
	background: var(--uka-gold);
	color: var(--uka-navy);
	font-size: 10px;
	padding: 2px 8px;
	border-radius: 999px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	font-weight: 700;
}
@media (max-width: 680px) {
	.uka-compare-table__row { grid-template-columns: 1.2fr 1fr 1fr 1fr; padding: 10px 12px; font-size: 13px; gap: 6px; }
	.uka-compare-table__row .is-us { margin: -10px -4px; padding: 10px 4px; }
}

/* =========================================================
   How It Works — timeline
   Markup: <li><span class="uka-timeline__day">Day 0</span><h3>…</h3><p>…</p></li>
   ========================================================= */
.uka-timeline {
	list-style: none;
	padding: 0;
	margin: 32px 0 0;
	display: grid;
	gap: 16px;
	counter-reset: uka-timeline;
}
.uka-timeline > li {
	position: relative;
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-left: 3px solid var(--uka-gold);
	border-radius: var(--uka-radius);
	padding: 22px 26px 22px 160px;
	box-shadow: 0 2px 12px -8px rgba(11,31,58,0.1);
	min-height: 84px;
}
.uka-timeline__day {
	position: absolute;
	left: 22px;
	top: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 110px;
	padding: 8px 14px;
	background: var(--uka-navy);
	color: var(--uka-gold);
	border-radius: 999px;
	font-family: var(--uka-font-sans);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border: 1px solid rgba(196,160,100,0.4);
}
.uka-timeline > li > h3 {
	font-size: 17px;
	margin: 0 0 6px;
	color: var(--uka-navy);
	font-family: var(--uka-font-serif);
	font-weight: 600;
}
.uka-timeline > li > p { font-size: 14.5px; color: var(--uka-slate); margin: 0; line-height: 1.6; }

@media (max-width: 720px) {
	.uka-timeline > li { padding: 20px 22px; }
	.uka-timeline__day {
		position: static;
		left: auto;
		top: auto;
		margin-bottom: 12px;
	}
}

/* =========================================================
   FAQ — search + category headers + empty
   ========================================================= */
.uka-faq-search {
	position: relative;
	margin: 0 0 24px;
}
.uka-faq-search input[type="search"] {
	width: 100%;
	padding: 14px 18px 14px 46px;
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius-sm);
	background: var(--uka-white);
	font: inherit;
	font-size: 15.5px;
	color: var(--uka-navy);
	box-shadow: 0 1px 2px rgba(11,31,58,0.04);
}
.uka-faq-search input[type="search"]::placeholder { color: var(--uka-slate-2); }
.uka-faq-search input[type="search"]:focus {
	outline: none;
	border-color: var(--uka-gold);
	box-shadow: 0 0 0 3px rgba(196,160,100,0.25);
}
.uka-faq-search svg {
	position: absolute;
	left: 16px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--uka-gold);
	pointer-events: none;
}
.uka-faq__cat-title {
	font-family: var(--uka-font-serif);
	font-size: 20px;
	color: var(--uka-navy);
	margin: 32px 0 12px;
	padding-top: 16px;
	border-top: 1px solid var(--uka-border);
}
.uka-faq__cat-title:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.uka-faq__empty {
	padding: 28px 24px;
	text-align: center;
	background: var(--uka-cloud-2);
	border: 1px dashed var(--uka-border);
	border-radius: var(--uka-radius);
	color: var(--uka-slate-2);
	font-size: 14px;
	margin-top: 16px;
}

/* =========================================================
   Get a Quote hero — two-column with proof aside
   ========================================================= */
.uka-quote-hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	align-items: start;
	margin-top: 20px;
}
@media (min-width: 900px) {
	.uka-quote-hero { grid-template-columns: 1.5fr 1fr; gap: 56px; }
}
.uka-quote-hero__list {
	list-style: none;
	padding: 0;
	margin: 24px 0 0;
	display: grid;
	gap: 10px;
}
.uka-quote-hero__list li {
	display: flex;
	gap: 10px;
	align-items: center;
	font-size: 15px;
	color: var(--uka-navy);
	font-weight: 500;
}
.uka-quote-hero__list svg { color: var(--uka-gold); flex: 0 0 auto; }

/* Quote hero sits inside the navy .uka-page-hero — force the bullet list
   and proof copy into a light palette so everything is legible. */
.uka-page-hero .uka-quote-hero__list li { color: rgba(255,255,255,0.92); font-weight: 500; }
.uka-page-hero .uka-quote-hero__list svg { color: var(--uka-gold); }
.uka-quote-hero__proof {
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius);
	padding: 24px 22px;
	box-shadow: var(--uka-shadow);
	text-align: center;
}
.uka-quote-hero__stars {
	display: inline-flex;
	gap: 2px;
	color: var(--uka-gold);
	margin-bottom: 10px;
}
.uka-quote-hero__stars svg { fill: currentColor; }
.uka-quote-hero__proof p { font-size: 14.5px; color: var(--uka-slate); margin: 0 0 14px; }
.uka-quote-hero__proof strong { color: var(--uka-navy); }
.uka-quote-hero__logos {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px 10px;
	margin-top: 12px;
	padding-top: 14px;
	border-top: 1px solid var(--uka-border);
}
.uka-quote-hero__logos span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	font-weight: 600;
	color: var(--uka-navy);
	background: var(--uka-cloud-2);
	padding: 6px 10px;
	border-radius: 999px;
}
.uka-quote-hero__logos svg { color: var(--uka-gold); }

/* =========================================================
   Footer — compliance strip
   ========================================================= */
.uka-footer__compliance {
	border-top: 1px solid rgba(255,255,255,0.08);
	padding: 28px 0 16px;
	margin-top: 32px;
	color: rgba(255,255,255,0.72);
	font-size: 12.5px;
	line-height: 1.7;
}
.uka-footer__compliance-title {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--uka-gold);
	font-size: 11.5px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin: 0 0 10px;
}
.uka-footer__compliance-title svg { color: var(--uka-gold); }
.uka-footer__compliance-body {
	margin: 0 0 14px;
	color: rgba(255,255,255,0.78);
}
.uka-footer__compliance-body strong {
	color: rgba(255,255,255,0.95);
	font-weight: 600;
	margin-right: 4px;
}
.uka-footer__compliance-body br + strong,
.uka-footer__compliance-body span { margin-right: 10px; }
.uka-footer__compliance-disc {
	font-size: 12px;
	color: rgba(255,255,255,0.55);
	margin: 0;
	max-width: 85ch;
}
.uka-footer__compliance-disc a { color: var(--uka-gold); border-bottom: 1px solid rgba(196,160,100,0.4); }
.uka-footer__compliance-disc a:hover { color: #fff; }

/* =========================================================
   Cookie consent banner — uses `hidden` attribute to show/hide
   ========================================================= */
.uka-cookie {
	position: fixed;
	left: 16px;
	right: 16px;
	bottom: 16px;
	z-index: 1001;
	background: var(--uka-navy);
	color: #fff;
	border: 1px solid var(--uka-gold);
	border-radius: var(--uka-radius);
	padding: 16px 18px;
	box-shadow: var(--uka-shadow-lg);
}
.uka-cookie[hidden] { display: none !important; }
@media (min-width: 700px) {
	.uka-cookie { left: auto; right: 24px; bottom: 24px; max-width: 520px; }
}
.uka-cookie__inner {
	display: flex;
	gap: 16px;
	align-items: center;
	flex-wrap: wrap;
}
.uka-cookie__text {
	margin: 0;
	font-size: 13.5px;
	line-height: 1.6;
	color: rgba(255,255,255,0.85);
	flex: 1 1 240px;
}
.uka-cookie__text strong { color: #fff; }
.uka-cookie__text a { color: var(--uka-gold); border-bottom: 1px solid rgba(196,160,100,0.4); }
.uka-cookie__text a:hover { color: #fff; }
.uka-cookie__actions { display: flex; gap: 8px; flex-wrap: wrap; }
.uka-cookie__actions .uka-btn { padding: 10px 16px; font-size: 13px; border-radius: 999px; }
.uka-cookie__actions .uka-btn--ghost-light { background: transparent; border: 1px solid rgba(255,255,255,0.3); color: rgba(255,255,255,0.85); }
.uka-cookie__actions .uka-btn--ghost-light:hover { color: #fff; border-color: #fff; background: rgba(255,255,255,0.06); }

/* =========================================================
   About hero — seal aside, value numbers, CTA row
   ========================================================= */
.uka-about-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.uka-about-hero__seal-wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 10px;
}
.uka-about-hero__seal-meta { margin: 0; font-size: 13.5px; color: var(--uka-slate); }
.uka-about-hero__seal-meta strong { color: var(--uka-navy); }
.uka-about-hero__seal-verify { margin: 0; font-size: 13px; }
.uka-about-hero__seal-verify a {
	color: var(--uka-navy);
	font-weight: 700;
	border-bottom: 1.5px solid var(--uka-gold);
	padding-bottom: 1px;
}

/* About hero inside the navy .uka-page-hero — lighten the seal meta + verify link
   so they are legible against dark navy bg (they default to navy/slate for when
   the seal card sits on a light page). */
.uka-page-hero .uka-about-hero__seal-meta { color: rgba(255,255,255,0.72); }
.uka-page-hero .uka-about-hero__seal-meta strong { color: #fff; }
.uka-page-hero .uka-about-hero__seal-verify a {
	color: var(--uka-gold);
	border-bottom-color: rgba(196,160,100,0.7);
}
.uka-page-hero .uka-about-hero__seal-verify a:hover {
	color: #fff;
	border-bottom-color: #fff;
}

/* Values list numbered bullets */
.uka-about-values ul {
	list-style: none;
	padding: 0;
	margin: 16px 0 0;
	display: grid;
	gap: 14px;
}
.uka-about-values ul li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 14px;
	align-items: start;
	padding: 14px 16px;
	background: var(--uka-white);
	border: 1px solid var(--uka-border);
	border-radius: var(--uka-radius-sm);
}
.uka-about-values__n {
	font-family: var(--uka-font-serif);
	font-weight: 600;
	font-size: 20px;
	color: var(--uka-gold);
	line-height: 1;
	padding-top: 2px;
}
.uka-about-values ul li div { font-size: 14.5px; color: var(--uka-slate); line-height: 1.6; }
.uka-about-values ul li strong { color: var(--uka-navy); display: block; margin-bottom: 2px; }

/* Team card tweaks that override generic rules */
.uka-team-card__icon {
	width: 56px;
	height: 56px;
	border-radius: 14px;
	background: var(--uka-navy);
	color: var(--uka-gold);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
	border: 2px solid var(--uka-gold);
}
.uka-team-card__name {
	font-family: var(--uka-font-serif);
	font-weight: 600;
	font-size: 19px;
	color: var(--uka-navy);
	margin: 0 0 4px;
}
.uka-team-card__quals {
	list-style: none;
	padding: 0;
	margin: 14px 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.uka-team-card__quals li {
	background: rgba(196,160,100,0.12);
	color: var(--uka-navy);
	font-size: 11.5px;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 999px;
	letter-spacing: 0.03em;
}

/* Contact card tweaks */
.uka-contact-card__note {
	display: block;
	margin-top: 6px;
	font-size: 12.5px;
	color: var(--uka-slate-2);
	font-weight: 500;
}

/* =========================================================
   Print — hide non-content chrome on legal pages
   ========================================================= */
@media print {
	.uka-site-header, .uka-site-footer, .uka-sticky-cta, .uka-cookie, .uka-whatsapp, .uka-sidebar { display: none !important; }
	.uka-legal-prose { border: 0; padding: 0; }
	body { color: #000; }
}

/* =========================================================
   Empty-page fallback (page.php graceful default)
   ========================================================= */
.uka-empty-page {
	max-width: 640px;
	margin: 0 auto;
	padding: 40px 32px;
	background: linear-gradient(180deg, #FAFBFD 0%, #F4F6FA 100%);
	border: 1px solid var(--uka-border);
	border-radius: 16px;
	text-align: left;
}
.uka-empty-page .uka-lede { font-size: 1.05rem; color: var(--uka-navy); margin: 0 0 20px; font-weight: 500; }
.uka-empty-page__links { list-style: none; padding: 0; margin: 0 0 28px; }
.uka-empty-page__links li { padding: 10px 0; border-bottom: 1px solid var(--uka-border); }
.uka-empty-page__links li:last-child { border-bottom: 0; }
.uka-empty-page__links a { color: var(--uka-navy); text-decoration: none; font-weight: 500; display: flex; align-items: center; gap: 8px; }
.uka-empty-page__links a::before { content: "→"; color: var(--uka-gold); font-weight: 700; }
.uka-empty-page__links a:hover { color: var(--uka-gold); }

/* =========================================================
   MOBILE POLISH — final-pass fixes for <720px screens
   ========================================================= */
@media (max-width: 720px) {
	/* Trust/social-proof strip — stack neatly */
	.uka-service-proof { padding: 16px 0; }
	.uka-service-proof__inner { flex-direction: column; text-align: center; gap: 10px; }
	.uka-service-proof__text { font-size: 13px; line-height: 1.5; }
	.uka-service-proof__list { justify-content: center; gap: 10px 16px; font-size: 12px; }
	.uka-service-proof__list li { font-size: 12px; }

	/* Page hero — ensure CTA stack is roomy */
	.uka-page-hero { padding: 56px 0 48px; }
	.uka-page-hero__cta { flex-direction: column; }
	.uka-page-hero__cta .uka-btn { width: 100%; justify-content: center; }
	.uka-page-hero__meta { gap: 6px; }

	/* Big buttons on mobile — full-width is cleaner */
	.uka-hero__cta { flex-direction: column; align-items: stretch; gap: 10px; }
	.uka-hero__cta .uka-btn { width: 100%; justify-content: center; }

	/* Section headings — tighter on small screens */
	.uka-section__head { margin-bottom: 32px; padding: 0 4px; }
	.uka-h2 { font-size: clamp(1.5rem, 6vw, 2rem); }
	.uka-lede { font-size: 1rem; }

	/* Containers — extra breathing on edges */
	.uka-container { padding-left: 20px; padding-right: 20px; }

	/* Cards — prevent horizontal overflow */
	.uka-price-card,
	.uka-persona-card,
	.uka-team-card,
	.uka-contact-card,
	.uka-pain-card { padding: 22px; }

	/* Footer — columns stack vertically with more space */
	.uka-footer__grid { gap: 36px; }
	.uka-footer__col h4 { margin-bottom: 12px; }
	.uka-footer__bottom { flex-direction: column; align-items: flex-start; gap: 12px; text-align: left; }

	/* WhatsApp float — keep label hidden, just the icon */
	.uka-whatsapp__label { display: none; }
	.uka-whatsapp { padding: 12px; }

	/* Sticky bottom CTA — don't overlap last section */
	body { padding-bottom: env(safe-area-inset-bottom, 0); }

	/* Prevent runaway horizontal scroll from any rogue wide element */
	html, body { overflow-x: hidden; }
	img, svg, video, iframe { max-width: 100%; height: auto; }
}

@media (max-width: 480px) {
	/* Very small screens — tighten further */
	.uka-page-hero { padding: 44px 0 36px; }
	.uka-page-hero__title { font-size: 1.75rem; line-height: 1.15; }
	.uka-page-hero__sub { font-size: 0.95rem; }
	.uka-breadcrumbs ol { font-size: 11px; }
	.uka-section { padding: 44px 0; }
	.uka-empty-page { padding: 28px 20px; }
	.uka-empty-page__links a { font-size: 0.95rem; }
}
