/* ═══════════════════════════════════════════════════════════════
   TESTROUTE HOMEPAGE — v5.12.9  Scoped CSS
   All selectors under .tr-hp.
   Uses !important for Cornerstone override protection.
   ═══════════════════════════════════════════════════════════════ */

.tr-hp, .tr-hp *, .tr-hp *::before, .tr-hp *::after {
	box-sizing: border-box !important;
	margin: 0 !important;
	padding: 0 !important;
	text-transform: none !important;
}

.tr-hp {
	position: relative !important;
	left: 50% !important; right: 50% !important;
	margin-left: -50vw !important; margin-right: -50vw !important;
	width: 100vw !important; max-width: 100vw !important;
	overflow-x: hidden !important;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
	-webkit-font-smoothing: antialiased !important;
	-moz-osx-font-smoothing: grayscale !important;
	color: #fff !important;
	line-height: 1.5 !important;

	/* ── Colour tokens ── */
	--tr-bg-navy: #0d1b2a; --tr-bg-deepnavy: #1b263b; --tr-bg-white: #ffffff; --tr-bg-offwhite: #f8f9fa;
	--tr-ink: #0d1b2a;
	--tr-sub: #415a77;
	--tr-green: #03c988; --tr-green-dark: #02a873; --tr-green-ink: #026644;
	--tr-tp-green: #00b67a;
	--tr-accent: #778da9;
	--tr-w08: rgba(255,255,255,.08); --tr-w12: rgba(255,255,255,.12);
	--tr-w45: rgba(255,255,255,.45); --tr-w65: rgba(255,255,255,.65);
	--tr-w78: rgba(255,255,255,.78); --tr-w92: rgba(255,255,255,.92);

	/* ── Spacing — 4px base grid ── */
	--tr-sp-2: 8px;   --tr-sp-3: 12px;  --tr-sp-4: 16px;
	--tr-sp-5: 20px;  --tr-sp-6: 24px;  --tr-sp-8: 32px;
	--tr-sp-12: 48px; --tr-sp-16: 64px;

	/* ── Radius — 3 tiers ── */
	--tr-r-sm: 8px;  --tr-r-md: 12px;  --tr-r-lg: 24px;

	/* ── Motion ── */
	--tr-ease: cubic-bezier(.4, 0, .2, 1);
	--tr-dur: .2s;
}


/* ─── Section backgrounds ─── */
/* FIX 5.9: Unified padding system — same rhythm for all sections */
.tr-hp__sec { padding: var(--tr-sp-16) var(--tr-sp-4) !important; text-align: center !important; }
@media (min-width: 600px) { .tr-hp__sec { padding: 80px var(--tr-sp-5) !important; } }
@media (min-width: 900px) { .tr-hp__sec { padding: 100px var(--tr-sp-5) !important; } }
/* ─── Section backgrounds — strategic dark/light rhythm ─── */
.tr-hp__sec--1 { background: var(--tr-bg-navy) !important; }
.tr-hp__sec--2 { background: var(--tr-bg-offwhite) !important; }
.tr-hp__sec--3 { background: var(--tr-bg-deepnavy) !important; }
.tr-hp__sec--4 { background: var(--tr-bg-white) !important; }
.tr-hp__sec--5 { background: var(--tr-bg-offwhite) !important; }
.tr-hp__sec--6 { background: var(--tr-bg-white) !important; }
.tr-hp__sec--7 { background: var(--tr-bg-navy) !important; }
.tr-hp__sec--map { background: var(--tr-bg-navy) !important; }

/* ─── Light section text overrides ─── */
.tr-hp__sec--2, .tr-hp__sec--4, .tr-hp__sec--5, .tr-hp__sec--6 {
	color: var(--tr-ink) !important;
}
.tr-hp__sec--2 .tr-hp__sec-title,
.tr-hp__sec--4 .tr-hp__sec-title,
.tr-hp__sec--5 .tr-hp__sec-title,
.tr-hp__sec--6 .tr-hp__sec-title { color: var(--tr-ink) !important; }
.tr-hp__sec--2 .tr-hp__sec-sub,
.tr-hp__sec--4 .tr-hp__sec-sub,
.tr-hp__sec--5 .tr-hp__sec-sub,
.tr-hp__sec--6 .tr-hp__sec-sub { color: var(--tr-sub) !important; }

/* ─── Gradient spacers ─── */
.tr-hp__spacer { height: var(--tr-sp-8) !important; }

/* ─── Green accent line ─── */
.tr-hp__accent { width: var(--tr-sp-8) !important; height: 1.5px !important; background: rgba(3,201,136,.35) !important; margin: 0 auto var(--tr-sp-5) !important; border-radius: 1px !important; }
.tr-hp__sec--2 .tr-hp__accent,
.tr-hp__sec--4 .tr-hp__accent,
.tr-hp__sec--5 .tr-hp__accent,
.tr-hp__sec--6 .tr-hp__accent { background: rgba(3,201,136,.5) !important; }

/* ─── Section headings — FIX 5.9: unified hierarchy ─── */
.tr-hp__sec-title { font-size: 28px !important; font-weight: 700 !important; color: var(--tr-w92) !important; letter-spacing: -.02em !important; margin: 0 0 8px !important; line-height: 1.2 !important; }
.tr-hp__sec-sub { font-size: 15px !important; color: var(--tr-w45) !important; margin: 0 0 var(--tr-sp-8) !important; line-height: 1.5 !important; }
/* Light section text — keep the same size, just override color */
.tr-hp__sec--2 .tr-hp__sec-sub,
.tr-hp__sec--4 .tr-hp__sec-sub,
.tr-hp__sec--5 .tr-hp__sec-sub,
.tr-hp__sec--6 .tr-hp__sec-sub { margin-bottom: 48px !important; }
@media (max-width: 599px) {
	.tr-hp__sec-title { font-size: 24px !important; }
	.tr-hp__sec-sub { font-size: 14px !important; }
}

/* ─── Container ─── */
.tr-hp__inner { max-width: 1040px !important; margin: 0 auto !important; }
.tr-hp__inner--narrow { max-width: 680px !important; margin: 0 auto !important; }

/* ─── Green emphasis ─── */
.tr-hp-green { color: var(--tr-green) !important; font-style: normal !important; font-weight: 600 !important; }


/* ═══════════════════════════════════════════════════════════════
   SECTION 1: HERO
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__hero {
	position: relative !important; display: flex !important;
	flex-direction: column !important; align-items: center !important;
	justify-content: space-between !important;
	overflow: hidden !important;
	min-height: 100vh !important; min-height: 100svh !important;
	padding: 100px var(--tr-sp-4) 24px !important;
	background: var(--tr-bg-navy) !important;}
@media (min-width: 600px) { .tr-hp__hero { min-height: 100vh !important; min-height: 100svh !important; padding-top: 120px !important; padding-bottom: 48px !important; } }
@media (min-width: 900px) { .tr-hp__hero { min-height: 100vh !important; min-height: 100svh !important; padding-top: 130px !important; padding-bottom: 56px !important; } }

.tr-hp__veil {
	position: absolute !important; inset: 0 !important; z-index: 2 !important; pointer-events: none !important;
	background: radial-gradient(ellipse 90% 70% at 50% 30%, rgba(13,27,42,0) 0%, rgba(13,27,42,.6) 50%, rgba(13,27,42,.95) 100%) !important;
}

/* Filmstrip */
.tr-hp__strip {
	position: absolute !important; left: 0 !important; right: 0 !important; height: 30% !important;
	overflow: hidden !important; z-index: 1 !important;
	-webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%) !important;
	mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%) !important;
}
.tr-hp__strip--top { top: 72px !important; }
@media (max-width: 768px) { .tr-hp__strip--top { top: 56px !important; } }
.tr-hp__strip--bot { bottom: 0 !important; }
.tr-hp__track { display: flex !important; gap: var(--tr-sp-3) !important; padding: var(--tr-sp-3) !important; height: 100% !important; width: max-content !important; will-change: transform !important; }
/* (marquee animations removed — static bento grid now) */
.tr-hp__strip--top .tr-hp__track { animation: tr-ml var(--tr-strip-dur, 40s) linear infinite !important; }
.tr-hp__strip--bot .tr-hp__track { animation: tr-mr var(--tr-strip-dur, 40s) linear infinite !important; }
.tr-hp__hero:hover .tr-hp__track { animation-play-state: paused !important; }

.tr-hp__cell {
	position: relative !important; flex-shrink: 0 !important; height: 100% !important;
	background: #132535 !important; border-radius: var(--tr-r-sm) !important; overflow: hidden !important;
	border: 1px solid rgba(255,255,255,.06) !important; width: clamp(140px, 18vw, 280px) !important;
}
.tr-hp__cell img, .tr-hp__cell video { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; }
.tr-hp__cell::after { content: '' !important; position: absolute !important; inset: 0 !important; pointer-events: none !important; background: linear-gradient(180deg, rgba(0,0,0,.18) 0%, transparent 28%, transparent 60%, rgba(0,0,0,.7) 100%) !important; }
.tr-hp__cell-label { position: absolute !important; bottom: var(--tr-sp-2) !important; left: var(--tr-sp-3) !important; right: var(--tr-sp-3) !important; z-index: 2 !important; display: flex !important; justify-content: space-between !important; align-items: center !important; gap: var(--tr-sp-2) !important; font-family: ui-monospace, 'SF Mono', Menlo, monospace !important; font-size: 9px !important; color: rgba(255,255,255,.85) !important; letter-spacing: .08em !important; }
.tr-hp__cell-rec { display: inline-flex !important; align-items: center !important; gap: 4px !important; flex-shrink: 0 !important; }
.tr-hp__cell-rec::before { content: "" !important; width: 5px !important; height: 5px !important; border-radius: 50% !important; background: var(--tr-green) !important; box-shadow: 0 0 6px var(--tr-green) !important; animation: tr-blink 1.6s ease-in-out infinite !important; }
@keyframes tr-blink { 0%,100% { opacity:1; } 50% { opacity:.3; } }

/* Glass card */
.tr-hp__card {
	position: relative !important; z-index: 5 !important;
	width: calc(100% - 32px) !important; max-width: 620px !important;
	margin: 0 !important;
	padding: 40px var(--tr-sp-8) 36px !important;
	background: rgba(13,27,42,.68) !important;
	border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-lg) !important;
	-webkit-backdrop-filter: blur(28px) saturate(150%) !important;
	backdrop-filter: blur(28px) saturate(150%) !important;
	box-shadow: 0 32px 64px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.04) inset !important;
	text-align: center !important;
}
@media (min-width: 600px) { .tr-hp__card { padding: 56px var(--tr-sp-12) var(--tr-sp-12) !important; } }
@media (min-width: 900px) { .tr-hp__card { max-width: 660px !important; padding: var(--tr-sp-16) var(--tr-sp-16) 56px !important; } }

/* H1 */
.tr-hp__h1 { font-weight: 600 !important; line-height: 1.15 !important; letter-spacing: -.015em !important; }
.tr-hp__intro { display: block !important; font-size: clamp(18px, 2.5vw + 10px, 28px) !important; font-weight: 600 !important; color: var(--tr-w92) !important; margin-bottom: var(--tr-sp-2) !important; }
.tr-hp__city-line { display: block !important; font-size: clamp(34px, 5.5vw + 14px, 52px) !important; font-weight: 800 !important; color: var(--tr-green) !important; letter-spacing: -.03em !important; line-height: 1 !important; min-height: 1.1em !important; margin-bottom: 10px !important; }
.tr-hp__sub { display: block !important; font-size: clamp(13px, .5vw + 11px, 15px) !important; font-weight: 400 !important; color: var(--tr-w78) !important; letter-spacing: .005em !important; }

/* City crossfade */
.tr-hp__city-stack { position: relative !important; display: inline-block !important; min-height: 1em !important; min-width: 6ch !important; max-width: 100% !important; width: var(--tr-city-w, auto) !important; }
.tr-hp__city-slot { position: absolute !important; left: 0 !important; right: 0 !important; top: 0 !important; white-space: nowrap !important; text-align: center !important; opacity: 0 !important; transition: opacity .45s ease !important; }
.tr-hp__city-slot.is-vis { opacity: 1 !important; }
.tr-hp__city-meas { position: absolute !important; left: -9999px !important; top: 0 !important; visibility: hidden !important; pointer-events: none !important; white-space: nowrap !important; font-weight: 800 !important; }

/* Search bar */
.tr-hp__search-wrap { position: relative !important; margin-top: 28px !important; z-index: 6 !important; }
.tr-hp__search {
	all: unset !important; display: flex !important; align-items: center !important; gap: var(--tr-sp-2) !important;
	background: #fff !important; border: none !important; border-radius: var(--tr-r-sm) !important;
	padding: 4px 4px 4px var(--tr-sp-4) !important;
	transition: box-shadow var(--tr-dur) var(--tr-ease) !important; cursor: text !important;
}
.tr-hp__search:focus-within { box-shadow: 0 0 0 3px rgba(3,201,136,.25) !important; }
.tr-hp__search-icon { flex-shrink: 0 !important; width: 18px !important; height: 18px !important; color: rgba(13,27,42,.4) !important; }
.tr-hp__search input[type="search"],
.tr-hp__search input[type="text"] {
	all: unset !important; flex: 1 1 auto !important; min-width: 0 !important;
	font-family: inherit !important; font-size: 16px !important; font-weight: 500 !important;
	color: var(--tr-ink) !important; padding: var(--tr-sp-2) 0 !important;
	-webkit-appearance: none !important; appearance: none !important;
}
.tr-hp__search input::placeholder { color: rgba(13,27,42,.38) !important; font-weight: 400 !important; }
.tr-hp__search input[type="search"]::-webkit-search-decoration,
.tr-hp__search input[type="search"]::-webkit-search-cancel-button,
.tr-hp__search input[type="search"]::-webkit-search-results-button,
.tr-hp__search input[type="search"]::-webkit-search-results-decoration { -webkit-appearance: none !important; display: none !important; }
.tr-hp__search-btn {
	all: unset !important; flex-shrink: 0 !important; display: inline-flex !important; align-items: center !important; gap: 4px !important;
	padding: 13px var(--tr-sp-4) !important; min-height: 44px !important; box-sizing: border-box !important;
	background: var(--tr-green) !important; color: var(--tr-ink) !important; border-radius: 6px !important;
	cursor: pointer !important; font-family: inherit !important; font-size: 13px !important; font-weight: 700 !important;
	line-height: 1 !important; white-space: nowrap !important;
	transition: background var(--tr-dur) var(--tr-ease), transform var(--tr-dur) var(--tr-ease) !important;
}
.tr-hp__search-btn:hover { background: var(--tr-green-dark) !important; transform: translateY(-1px) !important; }
.tr-hp__search-btn:active { transform: translateY(0) !important; }
.tr-hp__search-btn svg { width: 12px !important; height: 12px !important; flex-shrink: 0 !important; }

/* Search dropdown */
.tr-hp__results {
	position: absolute !important; top: calc(100% + var(--tr-sp-2)) !important; left: 0 !important; right: 0 !important; z-index: 10 !important;
	background: #fff !important; border: 1px solid rgba(13,27,42,.08) !important; border-radius: var(--tr-r-md) !important;
	box-shadow: 0 var(--tr-sp-4) var(--tr-sp-12) rgba(0,0,0,.4) !important;
	max-height: 360px !important; overflow-y: auto !important; text-align: left !important; display: none !important;
}
.tr-hp__results[data-open="true"] { display: block !important; }
@media (max-width: 599px) { .tr-hp__results { max-height: 40vh !important; } }

.tr-hp__result { display: flex !important; align-items: center !important; gap: var(--tr-sp-3) !important; padding: var(--tr-sp-3) var(--tr-sp-4) !important; border-bottom: 1px solid rgba(13,27,42,.06) !important; transition: background var(--tr-dur) var(--tr-ease) !important; text-decoration: none !important; color: var(--tr-ink) !important; }
.tr-hp__result:last-child { border-bottom: none !important; }
.tr-hp__result:hover, .tr-hp__result.is-focus { background: #fafbfc !important; }
.tr-hp__result-pin { flex-shrink: 0 !important; width: 36px !important; height: 36px !important; background: rgba(3,201,136,.12) !important; color: var(--tr-green-ink) !important; border-radius: var(--tr-r-sm) !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.tr-hp__result-pin svg { width: 16px !important; height: 16px !important; }
.tr-hp__result-text { flex: 1 !important; min-width: 0 !important; }
.tr-hp__result-name { font-size: 14px !important; font-weight: 600 !important; color: var(--tr-ink) !important; }
.tr-hp__result-meta { font-size: 12px !important; color: rgba(13,27,42,.45) !important; margin: 2px 0 0 !important; display: flex !important; align-items: center !important; gap: 4px !important; flex-wrap: wrap !important; }
.tr-hp__result-meta .postcode { font-family: ui-monospace, 'SF Mono', Menlo, monospace !important; color: rgba(13,27,42,.6) !important; }
.tr-hp__result-arrow { color: rgba(13,27,42,.22) !important; font-size: 13px !important; flex-shrink: 0 !important; }
.tr-hp__result mark { background: rgba(3,201,136,.18) !important; color: var(--tr-green-ink) !important; padding: 0 2px !important; border-radius: 2px !important; }

/* Search loader – skeleton rows */
.tr-hp__search-loader { padding: 0 !important; }
.tr-hp__skel-row { display: flex !important; align-items: center !important; gap: var(--tr-sp-3) !important; padding: var(--tr-sp-3) var(--tr-sp-4) !important; border-bottom: 1px solid rgba(13,27,42,.06) !important; }
.tr-hp__skel-row:last-child { border-bottom: none !important; }
.tr-hp__skel-pin { flex-shrink: 0 !important; width: 36px !important; height: 36px !important; border-radius: var(--tr-r-sm) !important; background: rgba(13,27,42,.05) !important; }
.tr-hp__skel-text { flex: 1 !important; min-width: 0 !important; display: flex !important; flex-direction: column !important; gap: 6px !important; }
.tr-hp__skel-line { height: 10px !important; border-radius: 4px !important; background: rgba(13,27,42,.05) !important; }
.tr-hp__skel-line--name { width: 72% !important; }
.tr-hp__skel-line--meta { width: 45% !important; height: 8px !important; }
.tr-hp__skel-row:nth-child(2) { opacity: .7 !important; }
.tr-hp__skel-row:nth-child(2) .tr-hp__skel-line--name { width: 58% !important; }
.tr-hp__skel-row:nth-child(3) { opacity: .4 !important; }
.tr-hp__skel-row:nth-child(3) .tr-hp__skel-line--name { width: 65% !important; }
.tr-hp__skel-shimmer { position: relative !important; overflow: hidden !important; }
.tr-hp__skel-shimmer::after { content: '' !important; position: absolute !important; top: 0 !important; left: -100% !important; width: 100% !important; height: 100% !important; background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.45) 50%, transparent 100%) !important; animation: tr-skel-shimmer 1.5s ease-in-out infinite !important; }
@keyframes tr-skel-shimmer { 0% { left: -100%; } 100% { left: 100%; } }

/* No results + notify */
.tr-hp__noresults { padding: var(--tr-sp-5) var(--tr-sp-4) var(--tr-sp-4) !important; }
.tr-hp__noresults-header { display: flex !important; align-items: center !important; gap: 10px !important; margin-bottom: 14px !important; }
.tr-hp__noresults-icon { width: 32px !important; height: 32px !important; background: rgba(255,180,0,.12) !important; border-radius: var(--tr-r-sm) !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; }
.tr-hp__noresults-icon svg { width: 15px !important; height: 15px !important; color: #b45309 !important; }
.tr-hp__noresults-msg { font-size: 13px !important; font-weight: 600 !important; color: var(--tr-ink) !important; }
.tr-hp__noresults-sub { font-size: 12px !important; color: rgba(13,27,42,.5) !important; }
.tr-hp__notify-label { font-size: 11px !important; font-weight: 600 !important; letter-spacing: .04em !important; color: rgba(13,27,42,.4) !important; text-transform: uppercase !important; margin: 0 0 6px !important; display: block !important; }
.tr-hp__notify { display: flex !important; gap: 4px !important; padding: 4px 4px 4px var(--tr-sp-3) !important; background: #fafbfc !important; border: 1px solid rgba(13,27,42,.1) !important; border-radius: var(--tr-r-sm) !important; transition: border-color var(--tr-dur) var(--tr-ease), box-shadow var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__notify:focus-within { border-color: var(--tr-green) !important; box-shadow: 0 0 0 3px rgba(3,201,136,.18) !important; }
.tr-hp__notify input { all: unset !important; flex: 1 1 auto !important; min-width: 0 !important; font-family: inherit !important; font-size: 16px !important; color: var(--tr-ink) !important; padding: var(--tr-sp-2) 0 !important; }
.tr-hp__notify input::placeholder { color: rgba(13,27,42,.38) !important; }
.tr-hp__notify button { all: unset !important; flex-shrink: 0 !important; padding: 10px 18px !important; min-height: 40px !important; box-sizing: border-box !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; background: var(--tr-ink) !important; color: #fff !important; border-radius: 6px !important; font-size: 13px !important; font-weight: 700 !important; cursor: pointer !important; transition: background var(--tr-dur) var(--tr-ease), color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__notify button:hover { background: var(--tr-green) !important; color: var(--tr-ink) !important; }
.tr-hp__notify-success { display: flex !important; align-items: center !important; gap: 10px !important; padding: var(--tr-sp-3) 14px !important; background: rgba(3,201,136,.08) !important; border: 1px solid rgba(3,201,136,.2) !important; border-radius: var(--tr-r-sm) !important; }
.tr-hp__notify-success-icon { width: 28px !important; height: 28px !important; background: rgba(3,201,136,.18) !important; color: var(--tr-green-ink) !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.tr-hp__notify-success-text { font-size: 13px !important; color: var(--tr-ink) !important; font-weight: 600 !important; }
.tr-hp__notify-success-sub { font-size: 12px !important; color: rgba(13,27,42,.55) !important; }
.tr-hp__notify-error { margin-top: var(--tr-sp-2) !important; padding: var(--tr-sp-2) var(--tr-sp-3) !important; background: rgba(239,68,68,.07) !important; border: 1px solid rgba(239,68,68,.18) !important; border-radius: 6px !important; font-size: 12px !important; color: #b91c1c !important; text-align: center !important; }

/* Inline notify — compact expandable row below proximity results */
.tr-hp__inline-notify { border-top: 1px solid rgba(13,27,42,.06) !important; }
.tr-hp__inline-notify-toggle { all: unset !important; display: flex !important; align-items: center !important; gap: var(--tr-sp-3) !important; width: 100% !important; box-sizing: border-box !important; padding: 10px var(--tr-sp-4) !important; min-height: 44px !important; font-family: inherit !important; font-size: 13px !important; color: rgba(13,27,42,.45) !important; cursor: pointer !important; transition: background var(--tr-dur) var(--tr-ease), color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__inline-notify-toggle:hover { background: #fafbfc !important; color: rgba(13,27,42,.65) !important; }
.tr-hp__inline-notify-icon { flex-shrink: 0 !important; width: 28px !important; height: 28px !important; border-radius: 6px !important; background: rgba(13,27,42,.04) !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: background var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__inline-notify-toggle:hover .tr-hp__inline-notify-icon { background: rgba(3,201,136,.1) !important; }
.tr-hp__inline-notify-icon svg { width: 14px !important; height: 14px !important; }
.tr-hp__inline-notify-cta { color: var(--tr-green-ink) !important; font-weight: 600 !important; }
.tr-hp__inline-notify-form { max-height: 0 !important; overflow: hidden !important; transition: max-height .25s var(--tr-ease), padding .25s var(--tr-ease) !important; padding: 0 var(--tr-sp-4) !important; }
.tr-hp__inline-notify.is-open .tr-hp__inline-notify-toggle { color: rgba(13,27,42,.65) !important; }
.tr-hp__inline-notify.is-open .tr-hp__inline-notify-icon { background: rgba(3,201,136,.12) !important; color: var(--tr-green-ink) !important; }
.tr-hp__inline-notify.is-open .tr-hp__inline-notify-form { max-height: 80px !important; padding: 0 var(--tr-sp-4) 12px !important; }

/* Microstats */
/* Trust badges — bottom of hero, outside card */
.tr-hp__trust-badges { position: relative !important; z-index: 5 !important; width: 100% !important; display: flex !important; flex-wrap: wrap !important; justify-content: center !important; align-items: center !important; gap: 6px 24px !important; margin-top: var(--tr-sp-6) !important; padding: 0 var(--tr-sp-5) !important; }
.tr-hp__trust-badge { display: inline-flex !important; align-items: center !important; gap: 6px !important; font-size: 11px !important; color: rgba(255,255,255,.6) !important; font-weight: 600 !important; white-space: nowrap !important; text-transform: uppercase !important; letter-spacing: .05em !important; }
.tr-hp__tb-ico { width: 14px !important; height: 14px !important; flex-shrink: 0 !important; color: rgba(255,255,255,.5) !important; }
.tr-hp__tb-dot { color: rgba(255,255,255,.2) !important; font-size: 14px !important; line-height: 1 !important; user-select: none !important; }
@media (max-width: 599px) { .tr-hp__trust-badges { gap: 4px 16px !important; padding: 16px var(--tr-sp-4) 20px !important; } .tr-hp__trust-badge { font-size: 10px !important; gap: 5px !important; } .tr-hp__tb-ico { width: 12px !important; height: 12px !important; } }

/* Browse link */
.tr-hp__browse { display: inline-flex !important; align-items: center !important; gap: 4px !important; margin: 20px 0 0 !important; font-size: 13px !important; color: rgba(255,255,255,.50) !important; text-decoration: none !important; font-weight: 500 !important; border-bottom: 1px solid rgba(255,255,255,.15) !important; padding-bottom: 1px !important; cursor: pointer !important; transition: color var(--tr-dur) var(--tr-ease), border-color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__browse:hover { color: var(--tr-green) !important; border-color: rgba(3,201,136,.4) !important; }

/* Trustpilot pill */
/* Trustpilot widget */
.tr-hp__tp-wrap { display: block !important; text-align: center !important; }
.tr-hp__tp { display: inline-flex !important; flex-wrap: wrap !important; align-items: center !important; justify-content: center !important; gap: 8px !important; margin: 24px 0 0 !important; padding: 0 !important; background: none !important; border: none !important; text-decoration: none !important; }
.tr-hp__tp:hover { opacity: .8 !important; }
.tr-hp__tp-text { font-size: 13px !important; font-weight: 600 !important; color: #fff !important; }
.tr-hp__tp-stars { height: 18px !important; width: auto !important; display: block !important; }
.tr-hp__tp-stars-inline { display: inline-flex !important; gap: 2px !important; align-items: center !important; }
.tr-hp__tp-star-box { width: 18px !important; height: 18px !important; display: block !important; }
.tr-hp__tp-count { font-size: 12px !important; font-weight: 500 !important; color: rgba(255,255,255,.55) !important; }
.tr-hp__tp-brand { display: inline-flex !important; align-items: center !important; gap: 4px !important; }
.tr-hp__tp-brand-star { width: 16px !important; height: 16px !important; display: block !important; }
.tr-hp__tp-logo { height: 16px !important; width: auto !important; display: block !important; }
.tr-hp__tp-logo-text { font-size: 13px !important; font-weight: 700 !important; color: rgba(255,255,255,.75) !important; letter-spacing: .03em !important; }
@media (max-width: 599px) { .tr-hp__tp { gap: 6px !important; margin: 20px 0 0 !important; } .tr-hp__tp-text { font-size: 11px !important; } .tr-hp__tp-star-box { width: 14px !important; height: 14px !important; } .tr-hp__tp-brand-star { width: 12px !important; height: 12px !important; } .tr-hp__tp-count { font-size: 10px !important; } .tr-hp__tp-logo-text { font-size: 11px !important; } }
@media (min-width: 600px) and (max-width: 899px) { .tr-hp__tp { gap: 5px !important; padding: 6px 12px !important; } .tr-hp__tp-star-box { width: 16px !important; height: 16px !important; } }

/* ─── Browse Modal ─── */
.tr-hp__browse-modal { display: none; position: fixed !important; inset: 0 !important; z-index: 2147483647 !important; align-items: center !important; justify-content: center !important; padding: var(--tr-sp-5) !important; }
.tr-hp__browse-modal.is-open { display: flex !important; }
.tr-hp__browse-modal-bg { position: absolute !important; inset: 0 !important; background: rgba(5,10,20,.72) !important; -webkit-backdrop-filter: blur(8px) brightness(.45) !important; backdrop-filter: blur(8px) brightness(.45) !important; opacity: 0 !important; transition: opacity .25s var(--tr-ease) !important; }
.tr-hp__browse-modal.is-open .tr-hp__browse-modal-bg { opacity: 1 !important; }
.tr-hp__browse-modal-box { position: relative !important; z-index: 1 !important; width: 100% !important; max-width: 640px !important; max-height: 80vh !important; background: rgba(13,27,42,.95) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-md) !important; -webkit-backdrop-filter: blur(20px) !important; backdrop-filter: blur(20px) !important; box-shadow: 0 var(--tr-sp-8) 100px rgba(0,0,0,.6) !important; overflow: hidden !important; display: flex !important; flex-direction: column !important; transform: translateY(20px) !important; opacity: 0 !important; transition: transform .3s var(--tr-ease), opacity .3s var(--tr-ease) !important; }
.tr-hp__browse-modal.is-open .tr-hp__browse-modal-box { transform: translateY(0) !important; opacity: 1 !important; }
.tr-hp__browse-modal-close { position: absolute !important; top: 14px !important; right: 14px !important; width: 44px !important; height: 44px !important; border-radius: 50% !important; background: rgba(255,255,255,.08) !important; border: 1px solid rgba(255,255,255,.06) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: rgba(255,255,255,.6) !important; font-size: 16px !important; cursor: pointer !important; z-index: 2 !important; }
.tr-hp__browse-modal-header { position: sticky !important; top: 0 !important; z-index: 3 !important; padding: var(--tr-sp-6) var(--tr-sp-6) var(--tr-sp-4) !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; background: rgba(13,27,42,.98) !important; -webkit-backdrop-filter: blur(12px) !important; backdrop-filter: blur(12px) !important; flex-shrink: 0 !important; }
.tr-hp__browse-modal-title { font-size: 18px !important; font-weight: 700 !important; color: var(--tr-w92) !important; margin-bottom: 14px !important; }
.tr-hp__browse-search { display: flex !important; align-items: center !important; gap: var(--tr-sp-2) !important; background: rgba(255,255,255,.06) !important; border: 1px solid rgba(255,255,255,.08) !important; border-radius: var(--tr-r-sm) !important; padding: 10px var(--tr-sp-3) !important; min-height: 44px !important; box-sizing: border-box !important; }
.tr-hp__browse-search input { all: unset !important; flex: 1 !important; font-family: inherit !important; font-size: 16px !important; color: #fff !important; }
.tr-hp__browse-search input::placeholder { color: rgba(255,255,255,.3) !important; }
.tr-hp__browse-search svg { width: 16px !important; height: 16px !important; color: rgba(255,255,255,.3) !important; flex-shrink: 0 !important; }
.tr-hp__browse-tabs { display: flex !important; gap: 0 !important; margin-top: var(--tr-sp-3) !important; }
.tr-hp__browse-tab { all: unset !important; flex: 1 !important; text-align: center !important; padding: 10px 0 !important; min-height: 44px !important; box-sizing: border-box !important; font-size: 13px !important; font-weight: 600 !important; color: rgba(255,255,255,.4) !important; cursor: pointer !important; border-bottom: 2px solid transparent !important; transition: color var(--tr-dur) var(--tr-ease), border-color var(--tr-dur) var(--tr-ease) !important; -webkit-tap-highlight-color: transparent !important; }
.tr-hp__browse-tab.is-active { color: var(--tr-green) !important; border-bottom-color: var(--tr-green) !important; }
.tr-hp__browse-body { flex: 1 !important; overflow-y: auto !important; -webkit-overflow-scrolling: touch !important; padding: var(--tr-sp-4) var(--tr-sp-6) var(--tr-sp-6) !important; scrollbar-width: thin !important; scrollbar-color: rgba(255,255,255,.1) transparent !important; overscroll-behavior: contain !important; }

.tr-hp__browse-back { all: unset !important; display: inline-flex !important; align-items: center !important; gap: 6px !important; padding: var(--tr-sp-2) 14px var(--tr-sp-2) 10px !important; margin-bottom: var(--tr-sp-4) !important; min-height: 36px !important; box-sizing: border-box !important; background: rgba(255,255,255,.06) !important; border: 1px solid rgba(255,255,255,.08) !important; border-radius: var(--tr-r-sm) !important; font-size: 13px !important; font-weight: 600 !important; color: var(--tr-w65) !important; cursor: pointer !important; transition: background var(--tr-dur) var(--tr-ease), color var(--tr-dur) var(--tr-ease) !important; -webkit-tap-highlight-color: transparent !important; }
.tr-hp__browse-back:hover { background: rgba(255,255,255,.1) !important; color: var(--tr-w92) !important; }
.tr-hp__browse-back svg { width: 14px !important; height: 14px !important; flex-shrink: 0 !important; }

.tr-hp__browse-region-cards { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: var(--tr-sp-2) !important; }
.tr-hp__browse-region-card { all: unset !important; display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 14px var(--tr-sp-4) !important; min-height: 48px !important; box-sizing: border-box !important; background: rgba(255,255,255,.04) !important; border: 1px solid rgba(255,255,255,.06) !important; border-radius: var(--tr-r-sm) !important; cursor: pointer !important; transition: background var(--tr-dur) var(--tr-ease), border-color var(--tr-dur) var(--tr-ease) !important; -webkit-tap-highlight-color: transparent !important; }
.tr-hp__browse-region-card:hover { background: rgba(3,201,136,.06) !important; border-color: rgba(3,201,136,.18) !important; }
.tr-hp__browse-region-card:active { background: rgba(3,201,136,.1) !important; }
.tr-hp__browse-region-name { font-size: 13px !important; font-weight: 600 !important; color: var(--tr-w92) !important; }
.tr-hp__browse-region-count { font-size: 11px !important; font-weight: 500 !important; color: rgba(255,255,255,.3) !important; flex-shrink: 0 !important; }
.tr-hp__browse-region-arrow { font-size: 12px !important; color: rgba(255,255,255,.2) !important; flex-shrink: 0 !important; margin-left: 6px !important; }

.tr-hp__browse-region-label { font-size: 11px !important; font-weight: 700 !important; color: rgba(3,201,136,.5) !important; text-transform: uppercase !important; letter-spacing: .06em !important; margin: var(--tr-sp-4) 0 var(--tr-sp-2) !important; }
.tr-hp__browse-region-label:first-child { margin-top: 0 !important; }
.tr-hp__browse-region-grid { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; }
.tr-hp__browse-loc { all: unset !important; display: inline-flex !important; align-items: center !important; gap: 6px !important; padding: 9px 14px !important; min-height: 40px !important; box-sizing: border-box !important; background: rgba(255,255,255,.04) !important; border: 1px solid rgba(255,255,255,.06) !important; border-radius: var(--tr-r-sm) !important; font-size: 13px !important; color: var(--tr-w92) !important; font-weight: 500 !important; cursor: pointer !important; transition: background var(--tr-dur) var(--tr-ease), border-color var(--tr-dur) var(--tr-ease) !important; text-decoration: none !important; -webkit-tap-highlight-color: transparent !important; }
.tr-hp__browse-loc:hover { background: rgba(3,201,136,.08) !important; border-color: rgba(3,201,136,.2) !important; }
.tr-hp__browse-loc-pc { font-size: 11px !important; color: rgba(255,255,255,.3) !important; font-family: ui-monospace, monospace !important; }
.tr-hp__browse-empty { font-size: 13px !important; color: rgba(255,255,255,.35) !important; padding: var(--tr-sp-5) 0 !important; }

@media (max-width: 599px) {
	.tr-hp__browse-modal { padding: 0 !important; align-items: flex-end !important; }
	.tr-hp__browse-modal-box { max-height: 95vh !important; max-width: 100% !important; border-radius: var(--tr-r-md) var(--tr-r-md) 0 0 !important; transform: translateY(40px) !important; }
	.tr-hp__browse-modal.is-open .tr-hp__browse-modal-box { transform: translateY(0) !important; }
	.tr-hp__browse-modal-header { padding: var(--tr-sp-5) var(--tr-sp-4) var(--tr-sp-3) !important; }
	.tr-hp__browse-modal-title { font-size: 16px !important; margin-bottom: var(--tr-sp-3) !important; }
	.tr-hp__browse-body { padding: var(--tr-sp-3) var(--tr-sp-4) var(--tr-sp-8) !important; }
	.tr-hp__browse-region-cards { grid-template-columns: 1fr !important; gap: 6px !important; }
	.tr-hp__browse-region-card { padding: var(--tr-sp-4) !important; min-height: 52px !important; }
	.tr-hp__browse-region-name { font-size: 14px !important; }
	.tr-hp__browse-loc { padding: 11px 14px !important; min-height: 44px !important; font-size: 14px !important; }
}


/* ═══════════════════════════════════════════════════════════════
   SECTION 2: HOW IT WORKS
   FIX 5.9.0 — Proportion pass: unified padding, larger mobile
   carousel (130→240px), bigger desktop cards & text, aligned
   heading hierarchy with other sections.
   ═══════════════════════════════════════════════════════════════ */
/* FIX 5.9: Removed sec-2 custom padding — now uses universal padding from .tr-hp__sec */
/* ─── Feature grid (Why TestRoute) — Desktop ─── */
/* FIX 5.9: Increased gap from 10→16px, card padding from 24/14→28/20, title 14→15, desc 12→13 */
.tr-hp__feat-grid { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 16px !important; }
@media (max-width: 899px) { .tr-hp__feat-grid { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 599px) { .tr-hp__feat-grid { display: none !important; } }
.tr-hp__feat-card { background: var(--tr-bg-white) !important; border: 1px solid rgba(13,27,42,.06) !important; border-radius: 16px !important; padding: 28px 24px 24px !important; text-align: left !important; transition: border-color var(--tr-dur) var(--tr-ease), box-shadow var(--tr-dur) var(--tr-ease) !important; display: flex !important; flex-direction: column !important; align-items: flex-start !important; }
.tr-hp__feat-card:hover { border-color: rgba(13,27,42,.1) !important; box-shadow: 0 4px 16px rgba(13,27,42,.05) !important; }
.tr-hp__feat-ico { width: 56px !important; height: 56px !important; margin-bottom: 16px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.tr-hp__feat-ico img { width: 56px !important; height: 56px !important; object-fit: contain !important; display: block !important; }
.tr-hp__feat-slide-ico img { width: 36px !important; height: 36px !important; object-fit: contain !important; display: block !important; }
.tr-hp__feat-ico-fb { width: 48px !important; height: 48px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.tr-hp__feat-ico-fb svg { width: 48px !important; height: 48px !important; }
.tr-hp__feat-title { font-size: 15px !important; font-weight: 700 !important; color: var(--tr-ink) !important; line-height: 1.3 !important; margin-bottom: 10px !important; }
.tr-hp__feat-desc { font-size: 13px !important; color: var(--tr-sub) !important; line-height: 1.5 !important; }
.tr-hp__feat-img { width: 100% !important; margin-top: auto !important; padding-top: 16px !important; }
.tr-hp__feat-img img { width: 100% !important; height: auto !important; border-radius: var(--tr-r-sm) !important; display: block !important; }
.tr-hp__feat-stat { font-size: 12px !important; font-weight: 600 !important; color: var(--tr-green-ink) !important; margin-top: 12px !important; }
/* ─── Sat nav tooltip ─── */
.tr-hp__feat-tt { position: relative !important; display: inline-flex !important; align-items: center !important; cursor: default !important; }
.tr-hp__feat-tt-i { width: 14px !important; height: 14px !important; border-radius: 50% !important; border: 1px solid rgba(13,27,42,.15) !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; font-size: 9px !important; font-weight: 700 !important; font-style: normal !important; color: rgba(13,27,42,.3) !important; margin-left: 4px !important; transition: border-color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__feat-tt:hover .tr-hp__feat-tt-i, .tr-hp__feat-tt:focus .tr-hp__feat-tt-i { border-color: rgba(3,201,136,.5) !important; color: var(--tr-green-ink) !important; }
.tr-hp__feat-tt-box { display: none !important; position: absolute !important; bottom: calc(100% + 10px) !important; left: 50% !important; transform: translateX(-50%) !important; background: #1b2d44 !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: 10px !important; padding: 12px 14px !important; width: 220px !important; font-size: 12px !important; color: rgba(255,255,255,.55) !important; line-height: 1.6 !important; text-align: left !important; z-index: 10 !important; }
.tr-hp__feat-tt-box::after { content: '' !important; position: absolute !important; top: 100% !important; left: 50% !important; transform: translateX(-50%) !important; border: 6px solid transparent !important; border-top-color: #1b2d44 !important; }
.tr-hp__feat-tt:hover .tr-hp__feat-tt-box, .tr-hp__feat-tt:focus .tr-hp__feat-tt-box { display: block !important; }
/* ─── Mobile swipe carousel ─── */
.tr-hp__feat-carousel { display: none !important; position: relative !important; }
@media (max-width: 599px) { .tr-hp__feat-carousel { display: block !important; } }
.tr-hp__feat-track { display: flex !important; gap: 12px !important; overflow-x: auto !important; padding: 0 16px !important; -webkit-overflow-scrolling: touch !important; scroll-snap-type: x mandatory !important; scrollbar-width: none !important; overscroll-behavior-x: contain !important; }
.tr-hp__feat-track::-webkit-scrollbar { display: none !important; }
.tr-hp__feat-track.tr-hp__feat-track--peek { animation: tr-feat-peek 1.2s ease-in-out 1.5s 1 both !important; }
@keyframes tr-feat-peek { 0%,100%{transform:translateX(0)} 35%{transform:translateX(-40px)} 70%{transform:translateX(4px)} }
/* FIX 5.9.1: Slides 240→280px for better proportions, progress bar !important removed to allow JS updates */
.tr-hp__feat-slide { background: var(--tr-bg-white) !important; border: 1px solid rgba(13,27,42,.06) !important; border-radius: 14px !important; padding: 24px 20px 20px !important; text-align: center !important; flex: 0 0 280px !important; scroll-snap-align: start !important; display: flex !important; flex-direction: column !important; align-items: center !important; }
.tr-hp__feat-slide-ico { width: 48px !important; height: 48px !important; margin-bottom: 12px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.tr-hp__feat-slide-ico-fb { width: 44px !important; height: 44px !important; }
.tr-hp__feat-slide-ico-fb svg { width: 44px !important; height: 44px !important; }
.tr-hp__feat-slide-title { font-size: 14px !important; font-weight: 700 !important; color: var(--tr-ink) !important; line-height: 1.3 !important; margin-bottom: 6px !important; }
.tr-hp__feat-slide-desc { font-size: 12px !important; color: var(--tr-sub) !important; line-height: 1.5 !important; }
.tr-hp__feat-slide-img { width: 100% !important; margin-top: auto !important; padding-top: 12px !important; }
.tr-hp__feat-slide-img img { width: 100% !important; height: auto !important; border-radius: var(--tr-r-sm) !important; display: block !important; }
.tr-hp__feat-slide-stat { font-size: 11px !important; font-weight: 600 !important; color: var(--tr-green-ink) !important; margin-top: 10px !important; }
.tr-hp__feat-fade { position: absolute !important; right: 0 !important; top: 0 !important; bottom: 28px !important; width: 40px !important; background: linear-gradient(90deg, transparent, var(--tr-bg-offwhite)) !important; pointer-events: none !important; z-index: 2 !important; }
.tr-hp__feat-prog { height: 2px !important; background: rgba(13,27,42,.06) !important; border-radius: 1px !important; margin: 10px 16px 0 !important; overflow: hidden !important; }
.tr-hp__feat-prog-fill { height: 100% !important; width: 20% !important; background: rgba(3,201,136,.5) !important; border-radius: 1px !important; transition: width .15s ease !important; }


/* ═══════════════════════════════════════════════════════════════
   SECTION 2B: INTERACTIVE MAP
   v5.8.0 — MapLibre-based UK test centres map
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__map-wrap { position: relative !important; border-radius: 16px !important; overflow: hidden !important; border: 1px solid rgba(255,255,255,.06) !important; box-shadow: 0 16px 48px rgba(0,0,0,.35) !important; }
/* FIX 5.9.2: isolation:isolate forces the map to create its own stacking context,
   preventing the cooperativeGestures overlay from bleeding above the search/locate/counter UI */
.tr-hp__map-wrap .maplibregl-map { font-family: inherit !important; isolation: isolate !important; }

.tr-hp__map-loader { position: absolute !important; inset: 0 !important; z-index: 20 !important; background: var(--tr-bg-navy) !important; display: flex !important; align-items: center !important; justify-content: center !important; gap: 10px !important; transition: opacity .8s ease !important; pointer-events: none !important; font-size: 13px !important; color: var(--tr-w45) !important; }
.tr-hp__map-loader.is-done { opacity: 0 !important; }
.tr-hp__map-spinner { width: 24px !important; height: 24px !important; border: 2px solid rgba(3,201,136,.15) !important; border-top-color: var(--tr-green) !important; border-radius: 50% !important; animation: tr-map-spin .7s linear infinite !important; }
@keyframes tr-map-spin { to { transform: rotate(360deg); } }

.tr-hp__map-search { position: absolute !important; top: 14px !important; left: 14px !important; z-index: 10 !important; width: 300px !important; max-width: calc(100% - 28px) !important; }
.tr-hp__map-search-bar { display: flex !important; align-items: center !important; background: rgba(13,27,42,.85) !important; backdrop-filter: blur(20px) !important; -webkit-backdrop-filter: blur(20px) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-sm) !important; padding: 4px 4px 4px 12px !important; transition: border-color var(--tr-dur) var(--tr-ease), box-shadow var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__map-search-bar:focus-within { border-color: rgba(3,201,136,.3) !important; box-shadow: 0 0 0 3px rgba(3,201,136,.08) !important; }
.tr-hp__map-search-bar svg { flex-shrink: 0 !important; width: 15px !important; height: 15px !important; color: var(--tr-w45) !important; }
/* FIX 5.9.2: font-size 16px prevents iOS Safari auto-zoom on focus */
.tr-hp__map-search-bar input { all: unset !important; flex: 1 !important; font-family: inherit !important; font-size: 16px !important; font-weight: 500 !important; color: #fff !important; padding: 8px 8px !important; min-width: 0 !important; text-align: left !important; }
.tr-hp__map-search-bar input::placeholder { color: var(--tr-w45) !important; font-weight: 400 !important; }

.tr-hp__map-results { margin-top: 4px !important; background: rgba(13,27,42,.92) !important; backdrop-filter: blur(20px) !important; -webkit-backdrop-filter: blur(20px) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-sm) !important; max-height: 260px !important; overflow-y: auto !important; display: none !important; scrollbar-width: thin !important; scrollbar-color: rgba(255,255,255,.1) transparent !important; text-align: left !important; }
.tr-hp__map-results.is-open { display: block !important; }
.tr-hp__map-result { display: flex !important; align-items: center !important; gap: 10px !important; padding: 9px 12px !important; cursor: pointer !important; transition: background var(--tr-dur) var(--tr-ease) !important; border-bottom: 1px solid rgba(255,255,255,.04) !important; text-decoration: none !important; color: #fff !important; }
.tr-hp__map-result:last-child { border-bottom: none !important; }
.tr-hp__map-result:hover { background: rgba(3,201,136,.08) !important; }
.tr-hp__map-result-pin { width: 26px !important; height: 26px !important; background: rgba(3,201,136,.1) !important; border-radius: 6px !important; display: flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; }
.tr-hp__map-result-pin svg { width: 13px !important; height: 13px !important; color: var(--tr-green) !important; }
.tr-hp__map-result-name { font-size: 13px !important; font-weight: 600 !important; color: var(--tr-w92) !important; }
.tr-hp__map-result-meta { font-size: 11px !important; color: var(--tr-w45) !important; }

.tr-hp__map-locate { all: unset !important; position: absolute !important; top: 14px !important; right: 14px !important; z-index: 10 !important; display: flex !important; align-items: center !important; gap: 6px !important; background: rgba(13,27,42,.85) !important; backdrop-filter: blur(12px) !important; -webkit-backdrop-filter: blur(12px) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-sm) !important; padding: 8px 14px !important; cursor: pointer !important; transition: all var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__map-locate:hover { background: rgba(3,201,136,.1) !important; border-color: rgba(3,201,136,.2) !important; }
.tr-hp__map-locate svg { width: 15px !important; height: 15px !important; color: var(--tr-w45) !important; transition: color var(--tr-dur) var(--tr-ease) !important; flex-shrink: 0 !important; }
.tr-hp__map-locate:hover svg { color: var(--tr-green) !important; }
.tr-hp__map-locate-text { font-size: 12px !important; font-weight: 600 !important; color: var(--tr-w45) !important; transition: color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__map-locate:hover .tr-hp__map-locate-text { color: var(--tr-w92) !important; }

.tr-hp__map-counter { position: absolute !important; bottom: 14px !important; left: 14px !important; z-index: 10 !important; background: rgba(13,27,42,.85) !important; backdrop-filter: blur(12px) !important; -webkit-backdrop-filter: blur(12px) !important; border: 1px solid rgba(255,255,255,.08) !important; border-radius: 6px !important; padding: 6px 12px !important; font-size: 12px !important; color: var(--tr-w45) !important; }
.tr-hp__map-counter strong { color: var(--tr-green) !important; font-weight: 700 !important; }

.tr-hp__map-nearest { position: absolute !important; bottom: 90px !important; right: 14px !important; z-index: 10 !important; background: rgba(3,201,136,.1) !important; backdrop-filter: blur(12px) !important; -webkit-backdrop-filter: blur(12px) !important; border: 1px solid rgba(3,201,136,.15) !important; border-radius: 6px !important; padding: 6px 12px !important; font-size: 12px !important; color: var(--tr-green) !important; display: none !important; }
.tr-hp__map-nearest.is-show { display: block !important; }

/* MapLibre control overrides */
.tr-hp__map-wrap .maplibregl-ctrl-group { background: rgba(13,27,42,.85) !important; backdrop-filter: blur(12px) !important; -webkit-backdrop-filter: blur(12px) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-sm) !important; overflow: hidden !important; box-shadow: none !important; }
.tr-hp__map-wrap .maplibregl-ctrl-group button { background: transparent !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; width: 34px !important; height: 34px !important; }
.tr-hp__map-wrap .maplibregl-ctrl-group button:hover { background: rgba(255,255,255,.06) !important; }
.tr-hp__map-wrap .maplibregl-ctrl-group button:last-child { border-bottom: none !important; }
.tr-hp__map-wrap .maplibregl-ctrl-group button .maplibregl-ctrl-icon { filter: invert(1) brightness(.7) !important; }
.tr-hp__map-wrap .maplibregl-ctrl-attrib { background: rgba(13,27,42,.5) !important; color: rgba(255,255,255,.2) !important; font-size: 10px !important; }
.tr-hp__map-wrap .maplibregl-ctrl-attrib a { color: rgba(255,255,255,.3) !important; }

/* MapLibre popup overrides */
.tr-hp__map-wrap .maplibregl-popup-content { background: rgba(13,27,42,.92) !important; backdrop-filter: blur(20px) !important; -webkit-backdrop-filter: blur(20px) !important; border: 1px solid rgba(255,255,255,.1) !important; border-radius: var(--tr-r-md) !important; padding: 14px 16px 12px !important; box-shadow: 0 12px 40px rgba(0,0,0,.5) !important; color: #fff !important; font-family: inherit !important; min-width: 180px !important; text-align: left !important; }
.tr-hp__map-wrap .maplibregl-popup-anchor-bottom .maplibregl-popup-tip { border-top-color: rgba(13,27,42,.92) !important; }
.tr-hp__map-wrap .maplibregl-popup-anchor-top .maplibregl-popup-tip { border-bottom-color: rgba(13,27,42,.92) !important; }
.tr-hp__map-wrap .maplibregl-popup-anchor-left .maplibregl-popup-tip { border-right-color: rgba(13,27,42,.92) !important; }
.tr-hp__map-wrap .maplibregl-popup-anchor-right .maplibregl-popup-tip { border-left-color: rgba(13,27,42,.92) !important; }
.tr-hp__map-wrap .maplibregl-popup-close-button { color: var(--tr-w45) !important; font-size: 18px !important; right: 6px !important; top: 4px !important; }
.tr-hp__map-popup-name { font-size: 14px !important; font-weight: 700 !important; color: var(--tr-w92) !important; margin-bottom: 2px !important; }
.tr-hp__map-popup-region { font-size: 11px !important; color: var(--tr-w45) !important; margin-bottom: 8px !important; }
.tr-hp__map-popup-cta { display: block !important; text-align: center !important; background: var(--tr-green) !important; color: var(--tr-ink) !important; border-radius: 6px !important; padding: 12px 16px !important; min-height: 44px !important; box-sizing: border-box !important; font-family: inherit !important; font-size: 12px !important; font-weight: 700 !important; text-decoration: none !important; transition: background var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__map-popup-cta:hover { background: var(--tr-green-dark) !important; }

@media (max-width: 599px) {
	#tr-hp-map { height: 400px !important; }
	.tr-hp__map-locate-text { display: none !important; }
	.tr-hp__map-locate { padding: 8px !important; }
	.tr-hp__map-search { width: calc(100% - 70px) !important; }
}

/* FIX 5.9.1: Cooperative gesture overlay — styled for dark navy theme */
.tr-hp__map-wrap .maplibregl-cooperative-gesture-screen { background: rgba(13,27,42,.75) !important; font-family: inherit !important; font-size: 14px !important; font-weight: 600 !important; color: rgba(255,255,255,.85) !important; }
.tr-hp__map-wrap .maplibregl-cooperative-gesture-screen .maplibregl-desktop-message,
.tr-hp__map-wrap .maplibregl-cooperative-gesture-screen .maplibregl-mobile-message { background: rgba(13,27,42,.85) !important; border-radius: var(--tr-r-sm) !important; padding: 10px 18px !important; border: 1px solid rgba(255,255,255,.1) !important; }


/* ═══════════════════════════════════════════════════════════════
   SECTION 3: SAMPLE ROUTE PREVIEW
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__pv-video { position: relative !important; max-width: 560px !important; margin: 0 auto var(--tr-sp-6) !important; border-radius: var(--tr-r-md) !important; overflow: hidden !important; border: 1px solid rgba(255,255,255,.08) !important; box-shadow: 0 var(--tr-sp-4) var(--tr-sp-12) rgba(0,0,0,.4) !important; cursor: pointer !important; transition: box-shadow var(--tr-dur) var(--tr-ease), transform var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__pv-video:hover { transform: translateY(-2px) !important; box-shadow: 0 var(--tr-sp-6) var(--tr-sp-16) rgba(0,0,0,.5) !important; }
.tr-hp__pv-thumb { padding-bottom: 56.25% !important; background: linear-gradient(135deg, #162a3e 0%, #0d1f30 40%, #1a3545 100%) !important; position: relative !important; }
.tr-hp__pv-play { position: absolute !important; top: 50% !important; left: 50% !important; transform: translate(-50%, -50%) !important; z-index: 3 !important; width: 68px !important; height: 68px !important; border-radius: 50% !important; background: rgba(3,201,136,.9) !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: transform var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__pv-video:hover .tr-hp__pv-play { transform: translate(-50%, -50%) scale(1.08) !important; }
.tr-hp__pv-play-tri { width: 0 !important; height: 0 !important; border-left: 22px solid var(--tr-ink) !important; border-top: 13px solid transparent !important; border-bottom: 13px solid transparent !important; margin-left: 4px !important; }
@media (max-width: 599px) { .tr-hp__pv-play { width: 56px !important; height: 56px !important; } .tr-hp__pv-play-tri { border-left-width: 18px !important; border-top-width: 10px !important; border-bottom-width: 10px !important; } }
.tr-hp__pv-badge { position: absolute !important; top: var(--tr-sp-3) !important; right: 14px !important; z-index: 3 !important; font-size: 9px !important; font-weight: 700 !important; color: var(--tr-green) !important; background: rgba(3,201,136,.12) !important; border: 1px solid rgba(3,201,136,.2) !important; padding: 2px var(--tr-sp-2) !important; border-radius: 4px !important; letter-spacing: .04em !important; }
.tr-hp__pv-cta { display: inline-flex !important; align-items: center !important; gap: var(--tr-sp-2) !important; padding: 14px 28px !important; background: var(--tr-green) !important; color: var(--tr-ink) !important; border-radius: var(--tr-r-sm) !important; font-size: 15px !important; font-weight: 600 !important; text-decoration: none !important; cursor: pointer !important; border: none !important; transition: background var(--tr-dur) var(--tr-ease), transform var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__pv-cta:hover { background: var(--tr-green-dark) !important; transform: translateY(-1px) !important; }
@media (max-width: 599px) { .tr-hp__pv-cta { width: 100% !important; justify-content: center !important; } }
.tr-hp__pv-sub { margin: 10px 0 0 !important; font-size: 12px !important; color: rgba(255,255,255,.35) !important; }
.tr-hp__pv-sub-mobile { display: none !important; }
@media (max-width: 479px) { .tr-hp__pv-sub-desktop { display: none !important; } .tr-hp__pv-sub-mobile { display: block !important; } }

/* Video modal */
.tr-hp__modal { display: none; position: fixed !important; inset: 0 !important; z-index: 2147483647 !important; align-items: center !important; justify-content: center !important; padding: var(--tr-sp-5) !important; overscroll-behavior: contain !important; }
.tr-hp__modal.is-open { display: flex !important; }
.tr-hp__modal-bg { position: absolute !important; inset: 0 !important; background: rgba(5,10,20,.72) !important; -webkit-backdrop-filter: blur(8px) brightness(.45) !important; backdrop-filter: blur(8px) brightness(.45) !important; }
.tr-hp__modal-close { position: absolute !important; top: var(--tr-sp-4) !important; right: var(--tr-sp-4) !important; width: 44px !important; height: 44px !important; border-radius: 50% !important; background: rgba(255,255,255,.1) !important; border: 1px solid rgba(255,255,255,.08) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: rgba(255,255,255,.7) !important; font-size: 18px !important; cursor: pointer !important; z-index: 2 !important; }
.tr-hp__modal-video { position: relative !important; z-index: 1 !important; width: 100% !important; max-width: 800px !important; border-radius: var(--tr-r-md) !important; overflow: hidden !important; box-shadow: 0 var(--tr-sp-8) 100px rgba(0,0,0,.7) !important; }
.tr-hp__modal-aspect { padding-bottom: 56.25% !important; background: #000 !important; position: relative !important; }
.tr-hp__modal-aspect iframe { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; border: none !important; }
@media (max-width: 599px) { .tr-hp__modal { padding: 0 !important; } .tr-hp__modal-bg { background: rgba(5,10,20,.88) !important; -webkit-backdrop-filter: blur(10px) brightness(.35) !important; backdrop-filter: blur(10px) brightness(.35) !important; } .tr-hp__modal-video { border-radius: 0 !important; max-width: 100% !important; } }


/* ═══════════════════════════════════════════════════════════════
   SECTION 4: REVIEWS MARQUEE
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__rv-tp-link { display: inline-flex !important; align-items: center !important; gap: 4px !important; font-size: 13px !important; font-weight: 500 !important; color: var(--tr-sub) !important; text-decoration: none !important; transition: color var(--tr-dur) var(--tr-ease) !important; min-height: 44px !important; }
.tr-hp__rv-tp-link:hover { color: var(--tr-ink) !important; }
.tr-hp__rv-tp-icon { width: 16px !important; height: 16px !important; }
.tr-hp__rv-tp-name { font-weight: 700 !important; color: var(--tr-ink) !important; }

.tr-hp__rv-grid { position: relative !important; z-index: 1 !important; display: flex !important; gap: 16px !important; overflow-x: auto !important; overflow-y: hidden !important; scroll-snap-type: x mandatory !important; -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important; touch-action: manipulation !important; cursor: grab !important; padding-bottom: 4px !important; overscroll-behavior-x: contain !important; scroll-padding-left: 16px !important; }
.tr-hp__rv-grid::-webkit-scrollbar { display: none !important; }
.tr-hp__rv-grid.is-dragging { cursor: grabbing !important; scroll-snap-type: none !important; }

.tr-hp__rv-featured { flex: 0 0 320px !important; background: linear-gradient(145deg, var(--tr-bg-navy) 0%, #1b3a4b 40%, #0a3d2e 100%) !important; border-radius: 16px !important; padding: 32px 28px !important; display: flex !important; flex-direction: column !important; justify-content: center !important; align-items: center !important; text-align: center !important; scroll-snap-align: start !important; min-height: 380px !important; }
@media (max-width: 599px) { .tr-hp__rv-featured { flex: 0 0 280px !important; padding: 28px 24px !important; min-height: 320px !important; } }
.tr-hp__rv-featured-text { font-size: 18px !important; font-weight: 700 !important; color: #fff !important; line-height: 1.4 !important; margin-bottom: 24px !important; }
.tr-hp__rv-featured-text b { color: var(--tr-green) !important; font-weight: 700 !important; }
.tr-hp__rv-featured-score { font-size: 56px !important; font-weight: 800 !important; color: #fff !important; letter-spacing: -.03em !important; line-height: 1 !important; margin-bottom: 20px !important; }
.tr-hp__rv-featured-tp { font-size: 12px !important; color: rgba(255,255,255,.55) !important; display: flex !important; align-items: center !important; gap: 5px !important; }
.tr-hp__rv-featured-tp-star { width: 16px !important; height: 16px !important; }

.tr-hp__rv-card { flex: 0 0 300px !important; background: var(--tr-bg-offwhite) !important; border: 1px solid rgba(13,27,42,.05) !important; border-radius: 16px !important; padding: 28px 24px 24px !important; display: flex !important; flex-direction: column !important; text-align: left !important; scroll-snap-align: start !important; text-decoration: none !important; color: inherit !important; transition: border-color var(--tr-dur) var(--tr-ease), box-shadow var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__rv-card:hover { border-color: rgba(13,27,42,.12) !important; box-shadow: 0 4px 16px rgba(13,27,42,.06) !important; }
@media (max-width: 599px) { .tr-hp__rv-card { flex: 0 0 260px !important; } }
.tr-hp__rv-card-stars { display: flex !important; gap: 2px !important; margin-bottom: 20px !important; }
.tr-hp__rv-card-star-box { width: 20px !important; height: 20px !important; display: block !important; }
.tr-hp__rv-stars-img { height: 20px !important; width: auto !important; display: block !important; }
.tr-hp__rv-quote { font-size: 16px !important; color: var(--tr-ink) !important; line-height: 1.55 !important; font-weight: 500 !important; flex: 1 !important; }
.tr-hp__rv-quote b { color: var(--tr-green-ink) !important; font-weight: 600 !important; }
.tr-hp__rv-card-foot { margin-top: 20px !important; padding-top: 0 !important; display: flex !important; flex-direction: column !important; gap: 2px !important; }
.tr-hp__rv-card-name { font-size: 12px !important; font-weight: 700 !important; color: var(--tr-ink) !important; text-transform: uppercase !important; letter-spacing: .04em !important; }
.tr-hp__rv-card-date { font-size: 11px !important; color: var(--tr-sub) !important; }

/* Scroll reveal */
.tr-hp__rv-header, .tr-hp__rv-marquee, .tr-hp__rv-footer { opacity: 0 !important; transform: translateY(10px) !important; transition: opacity .45s var(--tr-ease), transform .45s var(--tr-ease) !important; }
.tr-hp__rv-header.is-visible, .tr-hp__rv-marquee.is-visible, .tr-hp__rv-footer.is-visible { opacity: 1 !important; transform: translateY(0) !important; }
.tr-hp__rv-marquee.is-visible { transition-delay: .08s !important; }
.tr-hp__rv-footer.is-visible { transition-delay: .14s !important; }

@media (max-width: 600px) {
	.tr-hp__rv-card { width: 290px !important; padding: 20px !important; }
	.tr-hp__rv-quote { font-size: 14px !important; }
	.tr-hp__rv-quote--desk { display: none !important; }
	.tr-hp__rv-quote--mob { display: block !important; }
	.tr-hp__rv-card-foot { font-size: 12px !important; }
	.tr-hp__rv-marquee::before, .tr-hp__rv-marquee::after { width: 28px !important; }
}


/* ═══════════════════════════════════════════════════════════════
   SECTION 5: PRICING
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__pr-payment { display: inline-flex !important; align-items: center !important; gap: var(--tr-sp-2) !important; font-size: 13px !important; color: var(--tr-green) !important; font-weight: 600 !important; margin-bottom: var(--tr-sp-8) !important; }

.tr-hp__pr-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: var(--tr-sp-4) !important; margin-bottom: var(--tr-sp-6) !important; }
.tr-hp__pr-card { background: var(--tr-bg-white) !important; border: 1px solid rgba(13,27,42,.06) !important; border-radius: 16px !important; padding: 36px 28px !important; text-align: left !important; position: relative !important; transition: border-color var(--tr-dur) var(--tr-ease), transform var(--tr-dur) var(--tr-ease), box-shadow var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__pr-card:hover { border-color: rgba(13,27,42,.12) !important; transform: translateY(-2px) !important; box-shadow: 0 8px 24px rgba(13,27,42,.06) !important; }
.tr-hp__pr-card.is-hero { background: rgba(3,201,136,.04) !important; border-color: rgba(3,201,136,.2) !important; }
.tr-hp__pr-card.is-hero:hover { background: rgba(3,201,136,.06) !important; border-color: rgba(3,201,136,.3) !important; }
.tr-hp__pr-badge { position: absolute !important; top: -10px !important; left: 50% !important; transform: translateX(-50%) !important; font-size: 10px !important; font-weight: 700 !important; padding: 4px var(--tr-sp-3) !important; border-radius: 6px !important; white-space: nowrap !important; }
.tr-hp__pr-card.is-hero .tr-hp__pr-badge { background: rgba(3,201,136,.9) !important; color: var(--tr-ink) !important; }
.tr-hp__pr-card:not(.is-hero) .tr-hp__pr-badge { background: rgba(13,27,42,.06) !important; color: var(--tr-accent) !important; }
.tr-hp__pr-name { font-size: 18px !important; font-weight: 700 !important; color: var(--tr-ink) !important; margin-bottom: 6px !important; }
.tr-hp__pr-price-row { display: flex !important; align-items: baseline !important; gap: 2px !important; margin-bottom: 4px !important; }
.tr-hp__pr-pound { font-size: 15px !important; font-weight: 600 !important; color: rgba(13,27,42,.2) !important; }
.tr-hp__pr-amount { font-size: 42px !important; font-weight: 700 !important; color: var(--tr-ink) !important; line-height: 1 !important; }
.tr-hp__pr-period { font-size: 13px !important; color: var(--tr-accent) !important; margin-bottom: var(--tr-sp-4) !important; }
.tr-hp__pr-perks { list-style: none !important; margin-bottom: 24px !important; }
.tr-hp__pr-perk { font-size: 14px !important; color: rgba(13,27,42,.65) !important; padding: 8px 0 !important; border-bottom: 1px solid rgba(13,27,42,.04) !important; display: flex !important; align-items: center !important; gap: var(--tr-sp-2) !important; }
.tr-hp__pr-perk::before { content: '✓' !important; color: var(--tr-green) !important; font-weight: 700 !important; font-size: 12px !important; }
.tr-hp__pr-perk:last-child { border-bottom: none !important; }
.tr-hp__pr-cta { display: block !important; text-align: center !important; padding: 14px var(--tr-sp-5) !important; border-radius: 10px !important; font-size: 15px !important; font-weight: 600 !important; text-decoration: none !important; cursor: pointer !important; border: none !important; transition: background var(--tr-dur) var(--tr-ease), color var(--tr-dur) var(--tr-ease), transform var(--tr-dur) var(--tr-ease), border-color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__pr-cta:hover { transform: translateY(-1px) !important; }
.tr-hp__pr-card.is-hero .tr-hp__pr-cta { background: var(--tr-green) !important; color: var(--tr-ink) !important; }
.tr-hp__pr-card.is-hero .tr-hp__pr-cta:hover { background: var(--tr-green-dark) !important; }
.tr-hp__pr-card:not(.is-hero) .tr-hp__pr-cta { background: rgba(13,27,42,.06) !important; color: rgba(13,27,42,.65) !important; border: 1px solid rgba(13,27,42,.06) !important; }
.tr-hp__pr-card:not(.is-hero) .tr-hp__pr-cta:hover { background: rgba(13,27,42,.1) !important; color: var(--tr-ink) !important; border-color: rgba(13,27,42,.12) !important; }

.tr-hp__pr-trust { font-size: 12px !important; color: var(--tr-sub) !important; opacity: .6 !important; margin-bottom: var(--tr-sp-2) !important; }
.tr-hp__pr-social { display: none !important; }

.tr-hp__pr-dots { display: none !important; }
.tr-hp__pr-prog { display: none !important; height: 2px !important; background: rgba(13,27,42,.06) !important; border-radius: 1px !important; overflow: hidden !important; }
.tr-hp__pr-prog-fill { height: 100% !important; width: 33% !important; background: rgba(3,201,136,.5) !important; border-radius: 1px !important; transition: width .15s ease !important; }

/* ── Promo pricing state ── */
.tr-hp__pr-banner { text-align: center !important; font-size: 15px !important; margin-bottom: 28px !important; line-height: 1.5 !important; }
.tr-hp__pr-banner-icon { vertical-align: -4px !important; margin-right: 8px !important; width: 18px !important; height: 18px !important; }
.tr-hp__pr-banner-label { font-weight: 600 !important; color: var(--tr-ink) !important; }
.tr-hp__pr-banner-detail { font-weight: 400 !important; color: var(--tr-sub) !important; }
.tr-hp__pr-banner-mobile { display: none !important; }
@media (max-width: 599px) { .tr-hp__pr-banner { font-size: 13px !important; } .tr-hp__pr-banner-desktop { display: none !important; } .tr-hp__pr-banner-mobile { display: inline !important; } }
.tr-hp__pr-code { font-size: 11px !important; color: var(--tr-sub) !important; text-align: center !important; margin-top: 12px !important; opacity: .6 !important; }
.tr-hp__pr-code strong { font-weight: 600 !important; letter-spacing: .5px !important; }
.tr-hp__pr-was { font-size: 15px !important; font-weight: 500 !important; color: rgba(13,27,42,.35) !important; text-decoration: line-through !important; text-decoration-color: rgba(239,68,68,.45) !important; text-decoration-thickness: 1.5px !important; margin-bottom: 2px !important; }
.tr-hp__pr-pound--promo { color: rgba(3,201,136,.4) !important; }
.tr-hp__pr-amount--promo { color: var(--tr-green) !important; }
.tr-hp__pr-save { display: inline-block !important; font-size: 11px !important; font-weight: 600 !important; padding: 5px 14px !important; border-radius: 100px !important; margin-top: 8px !important; margin-bottom: 4px !important; background: rgba(3,201,136,.08) !important; color: var(--tr-green) !important; }
/* Summer — amber accents */
.tr-hp__pr-card[data-campaign="summer"] .tr-hp__pr-pound--promo { color: rgba(180,83,9,.3) !important; }
.tr-hp__pr-card[data-campaign="summer"] .tr-hp__pr-amount--promo { color: #b45309 !important; }
.tr-hp__pr-card[data-campaign="summer"] .tr-hp__pr-save { background: rgba(251,191,36,.1) !important; color: #92400e !important; }
.tr-hp__pr-card[data-campaign="summer"].is-hero .tr-hp__pr-badge { background: #fbbf24 !important; color: #422006 !important; }
.tr-hp__pr-card[data-campaign="summer"].is-hero .tr-hp__pr-cta { background: #f59e0b !important; color: #422006 !important; }
.tr-hp__pr-card[data-campaign="summer"].is-hero .tr-hp__pr-cta:hover { background: #d97706 !important; }
/* Black Friday — dark + gold accents */
.tr-hp__pr-card[data-campaign="blackfriday"] .tr-hp__pr-pound--promo { color: rgba(13,27,42,.18) !important; }
.tr-hp__pr-card[data-campaign="blackfriday"] .tr-hp__pr-amount--promo { color: var(--tr-ink) !important; }
.tr-hp__pr-card[data-campaign="blackfriday"] .tr-hp__pr-save { background: rgba(13,27,42,.06) !important; color: var(--tr-ink) !important; }
.tr-hp__pr-card[data-campaign="blackfriday"].is-hero .tr-hp__pr-badge { background: var(--tr-ink) !important; color: #ffd700 !important; }
.tr-hp__pr-card[data-campaign="blackfriday"].is-hero .tr-hp__pr-cta { background: var(--tr-ink) !important; color: #ffd700 !important; }
.tr-hp__pr-card[data-campaign="blackfriday"].is-hero .tr-hp__pr-cta:hover { background: #162d46 !important; }

@media (max-width: 599px) {
	.tr-hp__sec--5 .tr-hp__inner { overflow: hidden !important; }
	.tr-hp__pr-grid { display: flex !important; grid-template-columns: unset !important; flex-wrap: nowrap !important; overflow-x: auto !important; scroll-snap-type: x mandatory !important; scrollbar-width: none !important; padding: 16px var(--tr-sp-5) 0 !important; gap: var(--tr-sp-3) !important; -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%) !important; mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%) !important; overscroll-behavior-x: contain !important; }
	.tr-hp__pr-grid::-webkit-scrollbar { display: none !important; }
	.tr-hp__pr-card { flex: 0 0 260px !important; scroll-snap-align: center !important; }
	.tr-hp__pr-card:not(.is-hero) { opacity: .72 !important; transition: opacity .3s var(--tr-ease) !important; }
	.tr-hp__pr-prog { display: block !important; margin: 10px 16px 0 !important; }
	.tr-hp__pr-trust { margin-top: var(--tr-sp-6) !important; }
}


/* ═══════════════════════════════════════════════════════════════
   SECTION 6: FAQ
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__faq-block { background: var(--tr-bg-offwhite) !important; border-radius: 20px !important; padding: 48px !important; }
@media (max-width: 599px) { .tr-hp__faq-block { padding: 28px 20px !important; border-radius: 16px !important; } }

.tr-hp__faq-layout { display: grid !important; grid-template-columns: 1fr 1.6fr !important; gap: 48px !important; align-items: start !important; }
.tr-hp__faq-left { position: sticky !important; top: 100px !important; text-align: left !important; }
.tr-hp__faq-help { font-size: 14px !important; color: var(--tr-sub) !important; margin-top: 12px !important; }
.tr-hp__faq-help-link { color: var(--tr-green-ink) !important; text-decoration: underline !important; text-underline-offset: 2px !important; font-weight: 500 !important; transition: color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__faq-help-link:hover { color: var(--tr-green) !important; }

.tr-hp__faq-list { text-align: left !important; }
.tr-hp__faq-item { border-bottom: 1px solid rgba(13,27,42,.08) !important; }
.tr-hp__faq-q { all: unset !important; display: flex !important; align-items: center !important; gap: var(--tr-sp-3) !important; width: 100% !important; padding: 22px 0 !important; cursor: pointer !important; font-size: 16px !important; font-weight: 600 !important; color: var(--tr-ink) !important; transition: color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__faq-q:hover { color: var(--tr-green) !important; }
.tr-hp__faq-q-text { flex: 1 !important; }
.tr-hp__faq-q-mobile { display: none !important; }
.tr-hp__faq-chevron { flex-shrink: 0 !important; width: 18px !important; height: 18px !important; color: var(--tr-accent) !important; transition: transform .25s var(--tr-ease), color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__faq-item.is-open .tr-hp__faq-chevron { transform: rotate(180deg) !important; color: var(--tr-green) !important; }
.tr-hp__faq-item.is-open .tr-hp__faq-q { color: var(--tr-green) !important; }

.tr-hp__faq-a { display: block !important; max-height: 0 !important; overflow: hidden !important; opacity: 0 !important; padding: 0 !important; font-size: 14px !important; color: var(--tr-sub) !important; line-height: 1.6 !important; transition: max-height .3s var(--tr-ease), opacity .25s var(--tr-ease), padding-bottom .3s var(--tr-ease) !important; }
.tr-hp__faq-item.is-open .tr-hp__faq-a { max-height: 300px !important; opacity: 1 !important; padding-bottom: 18px !important; }

@media (max-width: 599px) {
	.tr-hp__faq-layout { grid-template-columns: 1fr !important; gap: 24px !important; }
	.tr-hp__faq-left { position: static !important; }
	.tr-hp__faq-q { font-size: 14px !important; padding: var(--tr-sp-4) 0 !important; min-height: 44px !important; }
	.tr-hp__faq-q-text { display: none !important; }
	.tr-hp__faq-q-mobile { display: block !important; flex: 1 !important; }
	.tr-hp__faq-a { font-size: 14px !important; }
}


/* ═══════════════════════════════════════════════════════════════
   SECTION 7: FINAL CTA
   ═══════════════════════════════════════════════════════════════ */
.tr-hp__cta-glow { position: relative !important; }
.tr-hp__cta-glow::before { content: '' !important; position: absolute !important; top: -60px !important; left: 50% !important; transform: translateX(-50%) !important; width: 300px !important; height: 200px !important; background: radial-gradient(ellipse, rgba(3,201,136,.04) 0%, transparent 70%) !important; pointer-events: none !important; }
/* FIX 5.9: CTA title aligned with universal heading hierarchy (28px/700) */
.tr-hp__cta-title { font-size: 28px !important; font-weight: 700 !important; color: var(--tr-w92) !important; margin-bottom: var(--tr-sp-5) !important; letter-spacing: -.02em !important; position: relative !important; }
.tr-hp__cta-search-wrap { position: relative !important; max-width: 520px !important; margin: 0 auto var(--tr-sp-6) !important; }
.tr-hp__cta-divider { width: 100% !important; max-width: 520px !important; height: 0.5px !important; background: rgba(255,255,255,.06) !important; margin: 0 auto var(--tr-sp-5) !important; }
.tr-hp__cta-invite { display: flex !important; justify-content: center !important; gap: var(--tr-sp-6) !important; flex-wrap: wrap !important; font-size: 13px !important; }
.tr-hp__cta-invite-item { color: rgba(255,255,255,.35) !important; }
.tr-hp__cta-invite-link { color: rgba(255,255,255,.55) !important; text-decoration: none !important; border-bottom: 1px solid rgba(255,255,255,.15) !important; padding-bottom: 1px !important; margin-left: 4px !important; transition: color var(--tr-dur) var(--tr-ease), border-color var(--tr-dur) var(--tr-ease) !important; }
.tr-hp__cta-invite-link:hover { color: var(--tr-green) !important; border-color: rgba(3,201,136,.3) !important; }
@media (max-width: 599px) { .tr-hp__cta-invite-link { padding: 10px 4px !important; } }


/* ─── Mobile search: icon-only button + larger bar ─── */
@media (max-width: 599px) {
	.tr-hp__search-btn .tr-btn-text { display: none !important; }
	.tr-hp__search-btn .tr-btn-arrow { width: 18px !important; height: 18px !important; }
	.tr-hp__search-btn { padding: 14px !important; min-height: 48px !important; min-width: 48px !important; justify-content: center !important; border-radius: 8px !important; }
	.tr-hp__search { padding: 5px 5px 5px var(--tr-sp-4) !important; }
	.tr-hp__search input[type="search"],
	.tr-hp__search input[type="text"] { font-size: 16px !important; padding: var(--tr-sp-3) 0 !important; }
}


/* ═══════════════════════════════════════════════════════════════
   SECTION TRANSITIONS — generous spacing + scroll reveal
   ═══════════════════════════════════════════════════════════════ */

/* ─── Generous spacing before hard colour transitions ─── */
.tr-hp__sec--3 { padding-bottom: 120px !important; }
.tr-hp__sec--4 { padding-bottom: 120px !important; }
.tr-hp__sec--map { padding-bottom: 120px !important; }
.tr-hp__sec--6 { padding-bottom: 100px !important; }
@media (max-width: 599px) {
	.tr-hp__sec--3, .tr-hp__sec--4, .tr-hp__sec--map { padding-bottom: 80px !important; }
	.tr-hp__sec--6 { padding-bottom: 72px !important; }
}

/* ─── Scroll reveal: headings only, subtle, once ─── */
.tr-hp__reveal .tr-hp__accent,
.tr-hp__reveal .tr-hp__sec-title,
.tr-hp__reveal .tr-hp__sec-sub { opacity: 0 !important; transform: translateY(12px) !important; transition: opacity .45s var(--tr-ease), transform .45s var(--tr-ease) !important; }
.tr-hp__reveal.is-vis .tr-hp__accent { opacity: 1 !important; transform: translateY(0) !important; transition-delay: 0ms !important; }
.tr-hp__reveal.is-vis .tr-hp__sec-title { opacity: 1 !important; transform: translateY(0) !important; transition-delay: 80ms !important; }
.tr-hp__reveal.is-vis .tr-hp__sec-sub { opacity: 1 !important; transform: translateY(0) !important; transition-delay: 160ms !important; }


/* ═══════════════════════════════════════════════════════════════
   ACCESSIBILITY: Reduced motion
   ═══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
	.tr-hp__track, .tr-hp__cell-rec::before { animation: none !important; }
	.tr-hp__city-slot { transition: none !important; }
	.tr-hp *, .tr-hp *::before, .tr-hp *::after { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
	.tr-hp__reveal .tr-hp__accent, .tr-hp__reveal .tr-hp__sec-title, .tr-hp__reveal .tr-hp__sec-sub { opacity: 1 !important; transform: none !important; }
}
