/**
 * design-system.css
 * Additional utility classes and component overrides.
 * Works alongside style.css.
 *
 * @package JenningsOpticians
 */

/* ─────────────────────────────────────────────
   BOOKING SECTION LAYOUT
   ───────────────────────────────────────────── */

.booking-section__grid {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: var(--space-12);
	align-items: start;
}

@media ( max-width: 900px ) {
	.booking-section__grid {
		grid-template-columns: 1fr;
	}
}

/* ─────────────────────────────────────────────
   BOOKING TRUST SIDEBAR
   ───────────────────────────────────────────── */

.booking-trust {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.booking-trust__item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--text-sm);
	color: var(--color-grey-800);
	padding: var(--space-3) 0;
	border-bottom: 1px solid var(--color-grey-200);
}

.booking-trust__item:last-of-type {
	border-bottom: none;
}

.booking-trust__icon {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	background: var(--color-teal);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 700;
}

/* ─────────────────────────────────────────────
   FORM STYLES (referenced in booking forms)
   ───────────────────────────────────────────── */

.form-group {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	margin-bottom: var(--space-5);
}

.form-label {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-text-primary);
}

.form-label .optional {
	font-weight: 400;
	color: var(--color-text-muted);
}

.form-input,
.form-select {
	width: 100%;
	padding: 0.625rem 0.875rem;
	border: 1.5px solid var(--color-grey-300);
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-text-primary);
	background: #fff;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	-webkit-appearance: none;
	appearance: none;
}

.form-input:focus,
.form-select:focus {
	outline: none;
	border-color: var(--color-teal);
	box-shadow: 0 0 0 3px rgba(26, 122, 130, 0.15);
}

.form-input::placeholder {
	color: var(--color-text-muted);
}

.form-microcopy {
	font-size: var(--text-xs);
	color: var(--color-text-muted);
}

.form-submit-wrap {
	margin-top: var(--space-6);
}

.form-privacy {
	margin-top: var(--space-3);
	font-size: var(--text-xs);
	color: var(--color-text-muted);
	display: flex;
	align-items: flex-start;
	gap: var(--space-2);
}

/* ─────────────────────────────────────────────
   OPENING HOURS TABLE
   ───────────────────────────────────────────── */

.hours-table {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-1) var(--space-4);
	font-size: var(--text-sm);
}

.hours-day {
	font-weight: 600;
	color: var(--color-text-primary);
	white-space: nowrap;
}

.hours-time {
	color: var(--color-grey-700);
}

/* ─────────────────────────────────────────────
   CONTACT PAGE PHONE LINK
   ───────────────────────────────────────────── */

.contact-phone {
	font-size: var(--text-2xl);
	font-weight: 700;
	color: var(--color-primary);
	text-decoration: none;
	display: inline-block;
	margin-top: var(--space-1);
}

.contact-phone:hover {
	color: var(--color-teal);
	text-decoration: underline;
}

/* ─────────────────────────────────────────────
   PAGE HERO VARIANTS
   ───────────────────────────────────────────── */

/* Landing page variant — slightly shorter, centred */
.page-hero--landing {
	padding: var(--space-14) 0;
	text-align: center;
}

.page-hero--landing .page-hero__title {
	font-size: clamp( 1.75rem, 4vw, 2.75rem );
}

/* Badge / location pill above H1 */
.page-hero__badge {
	display: inline-block;
	background: rgba( 255, 255, 255, 0.2 );
	border: 1px solid rgba( 255, 255, 255, 0.4 );
	color: #fff;
	font-size: var(--text-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 0.25rem 0.75rem;
	border-radius: 100px;
	margin-bottom: var(--space-4);
}

/* ─────────────────────────────────────────────
   PROCESS STEPS
   ───────────────────────────────────────────── */

.steps {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}

.step {
	display: flex;
	align-items: flex-start;
	gap: var(--space-5);
}

.step__number {
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	background: var(--color-primary);
	color: #fff;
	font-weight: 700;
	font-size: var(--text-base);
	display: flex;
	align-items: center;
	justify-content: center;
}

.step__desc {
	flex: 1;
	font-size: var(--text-base);
	color: var(--color-grey-800);
	padding-top: 0.4rem;
}

/* ─────────────────────────────────────────────
   NOTICE / ALERT BOXES
   ───────────────────────────────────────────── */

.notice {
	padding: var(--space-5) var(--space-6);
	border-radius: var(--radius-md);
	display: flex;
	align-items: flex-start;
	gap: var(--space-4);
}

.notice--success {
	background: #edfdf3;
	border-left: 4px solid var(--color-success);
	color: #166534;
}

.notice--success h2,
.notice--success h3 {
	color: #166534;
}

.notice--info {
	background: #eff6ff;
	border-left: 4px solid #3b82f6;
	color: #1e40af;
}

.notice--warning {
	background: #fffbeb;
	border-left: 4px solid #f59e0b;
	color: #92400e;
}

.notice--urgent {
	background: #fef2f2;
	border-left: 4px solid #ef4444;
	color: #991b1b;
}

/* ─────────────────────────────────────────────
   WHY US GRID ITEM
   ───────────────────────────────────────────── */

.why-item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-4);
	padding: var(--space-4) 0;
}

.why-item__check {
	flex-shrink: 0;
	width: 1.75rem;
	height: 1.75rem;
	border-radius: 50%;
	background: var(--color-teal);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.75rem;
	font-weight: 700;
}

/* ─────────────────────────────────────────────
   PULL QUOTE
   ───────────────────────────────────────────── */

.pull-quote {
	padding: var(--space-6);
	background: var(--color-grey-50);
	border-left: 4px solid var(--color-teal);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.pull-quote p {
	font-size: var(--text-lg);
	font-family: var(--font-accent);
	font-style: italic;
	color: var(--color-text-primary);
	margin: 0 0 var(--space-3);
}

.pull-quote cite {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	font-style: normal;
}

.pull-quote--large p {
	font-size: var(--text-xl);
}

/* ─────────────────────────────────────────────
   STAR RATING
   ───────────────────────────────────────────── */

.stars {
	color: #f59e0b;
	font-size: 1.125rem;
	letter-spacing: 0.05em;
}

/* ─────────────────────────────────────────────
   REVIEW CARDS
   ───────────────────────────────────────────── */

.reviews-grid {
	display: grid;
	grid-template-columns: repeat( 3, 1fr );
	gap: var(--space-6);
}

@media ( max-width: 768px ) {
	.reviews-grid {
		grid-template-columns: 1fr;
	}
}

.review-card {
	padding: var(--space-6);
	background: #fff;
	border: 1px solid var(--color-grey-200);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.review-card__stars {
	color: #f59e0b;
	font-size: 1rem;
}

.review-card__text {
	flex: 1;
	font-size: var(--text-sm);
	color: var(--color-grey-800);
	line-height: 1.65;
	font-style: italic;
}

.review-card__author {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.review-card__name {
	font-weight: 600;
	font-size: var(--text-sm);
	color: var(--color-text-primary);
}

.review-card__location {
	font-size: var(--text-xs);
	color: var(--color-text-muted);
}

/* ─────────────────────────────────────────────
   TESTIMONIALS SECTION HEADER
   ───────────────────────────────────────────── */

.testimonials__header {
	text-align: center;
	margin-bottom: var(--space-10);
}

.testimonials__header .lead {
	max-width: 540px;
	margin: var(--space-3) auto 0;
}

.reviews-cta {
	text-align: center;
}

/* ─────────────────────────────────────────────
   TEAL CARD HIGHLIGHT
   ───────────────────────────────────────────── */

.card--highlight {
	background: var(--color-teal-light);
	border-color: rgba( 26, 122, 130, 0.2 );
}

/* ─────────────────────────────────────────────
   LOCATION MAP LAYOUT
   ───────────────────────────────────────────── */

.grid-2--map-layout {
	align-items: stretch;
}

.location-nap {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
}

.location-nap__block h3 {
	font-size: var(--text-sm);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-text-muted);
	margin-bottom: var(--space-2);
}

.location-phone {
	font-size: var(--text-2xl);
	font-weight: 700;
	color: var(--color-primary);
	text-decoration: none;
}

.location-phone:hover {
	color: var(--color-teal);
}

.location-nap__transport ul li {
	font-size: var(--text-sm);
	color: var(--color-grey-800);
}

.location-map-embed {
	border-radius: var(--radius-lg);
	overflow: hidden;
	min-height: 380px;
}

/* ─────────────────────────────────────────────
   CARD (base) — if not in style.css
   ───────────────────────────────────────────── */

.card {
	padding: var(--space-6);
	background: #fff;
	border: 1px solid var(--color-grey-200);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}

.card h3 {
	margin-bottom: var(--space-3);
	color: var(--color-text-primary);
}

/* ─────────────────────────────────────────────
   NAP / SECTION LABELS
   ───────────────────────────────────────────── */

.section-label {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-teal);
	margin-bottom: var(--space-3);
}

/* ─────────────────────────────────────────────
   TAG LINKS (area pages)
   ───────────────────────────────────────────── */

.tag-link {
	display: inline-flex;
	align-items: center;
	padding: 0.35rem 0.875rem;
	background: var(--color-grey-100);
	border: 1px solid var(--color-grey-300);
	border-radius: 100px;
	font-size: var(--text-sm);
	color: var(--color-text-primary);
	text-decoration: none;
	transition: background var(--transition-fast), border-color var(--transition-fast);
}

.tag-link:hover {
	background: var(--color-teal-light);
	border-color: var(--color-teal);
	color: var(--color-teal);
}

/* ─────────────────────────────────────────────
   ACCESSIBILITY HELPERS
   ───────────────────────────────────────────── */

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

/* ─────────────────────────────────────────────
   CTA BAND — outline-white button variant
   ───────────────────────────────────────────── */

.btn-outline-white {
	background: transparent;
	border: 2px solid rgba( 255, 255, 255, 0.8 );
	color: #fff;
}

.btn-outline-white:hover,
.btn-outline-white:focus-visible {
	background: rgba( 255, 255, 255, 0.15 );
	border-color: #fff;
	color: #fff;
}

/* ─────────────────────────────────────────────
   EYE TESTS PAGE
   ───────────────────────────────────────────── */

/* ── Hero ──────────────────────────────────── */
.page-hero--et {
	background: var(--color-ink, #0D1117);
	padding: var(--space-10) 0 var(--space-12);
	position: relative;
	overflow: hidden;
}

.page-hero--et::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient( ellipse 70% 80% at 100% 50%, rgba(15, 81, 132, 0.35) 0%, transparent 65% );
	pointer-events: none;
}

.page-hero--et .container { position: relative; }

/* Hero badges */
.et-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	margin-bottom: var(--space-6);
}

.et-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.16);
	color: rgba(255, 255, 255, 0.75);
	font-size: 0.68rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 4px 12px;
	border-radius: var(--radius-full);
}

.et-hero__badge--nhs {
	background: rgba(40, 167, 69, 0.18);
	border-color: rgba(40, 167, 69, 0.4);
	color: #a8f0b8;
}

.et-hero__badge--new-patients {
	background: rgba(255, 107, 53, 0.18);
	border-color: rgba(255, 107, 53, 0.45);
	color: #ffcab5;
	font-weight: 700;
}

/* Hero actions */
.et-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-4);
	margin-bottom: var(--space-10);
}

/* Hero trust row */
.et-hero__trust-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-6);
	padding-top: var(--space-6);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.et-hero__trust-item {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-sm);
	color: rgba(255, 255, 255, 0.55);
}

.et-hero__trust-item svg { color: var(--color-teal); flex-shrink: 0; }

/* ── Stat strip ────────────────────────────── */
.et-stat-strip {
	background: var(--color-white);
	padding: var(--space-6) 0;
	border-top: 1px solid var(--color-grey-100);
	border-bottom: 1px solid var(--color-grey-100);
}

.et-stat-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

.et-stat {
	padding: var(--space-4) var(--space-6);
	border-right: 1px solid var(--color-grey-200);
	display: flex;
	align-items: baseline;
	gap: var(--space-3);
}

.et-stat:last-child { border-right: none; }

.et-stat__number {
	font-family: var(--font-accent, 'Playfair Display', Georgia, serif);
	font-size: clamp( 1.5rem, 2.5vw, 2rem );
	font-weight: 400;
	color: var(--color-text-primary);
	line-height: 1;
	letter-spacing: -0.02em;
	flex-shrink: 0;
}

.et-stat__label {
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-muted);
	line-height: 1.4;
}

/* ── Section headers ────────────────────────── */
.et-section-header {
	text-align: center;
	margin-bottom: var(--space-14);
}

.et-section-sub {
	font-size: var(--text-lg);
	color: var(--color-text-secondary);
	max-width: 520px;
	margin: var(--space-3) auto 0;
	line-height: 1.7;
}

/* Eyebrow label */
.section-eyebrow {
	display: inline-block;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-teal);
	margin-bottom: var(--space-3);
}

/* ── Intro 2-col grid ───────────────────────── */
.et-intro-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-20);
	align-items: start;
}

.et-intro__text h2 { margin-top: var(--space-2); }

/* ── Benefit items ──────────────────────────── */
.et-intro__benefits {
	display: flex;
	flex-direction: column;
}

.et-benefit {
	display: flex;
	align-items: flex-start;
	gap: var(--space-5);
	padding: var(--space-6) 0;
	border-bottom: 1px solid var(--color-grey-100);
}

.et-benefit:last-child { border-bottom: none; }

.et-benefit__icon {
	flex-shrink: 0;
	width: 42px;
	height: 42px;
	border-radius: var(--radius-md);
	background: var(--color-teal-light);
	color: var(--color-teal);
	display: flex;
	align-items: center;
	justify-content: center;
}

.et-benefit__title {
	display: block;
	font-size: var(--text-base);
	font-weight: 600;
	color: var(--color-text-primary);
	margin-bottom: var(--space-1);
}

.et-benefit__desc {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: 1.65;
	margin: 0;
}

/* ── Process steps ──────────────────────── */
.et-process-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-20);
	align-items: start;
}

.et-process-lead {
	position: sticky;
	top: var(--space-20);
	padding-top: var(--space-4);
}

.et-process-lead p {
	color: var(--color-text-secondary);
	font-size: var(--text-base);
	line-height: 1.75;
	margin-top: var(--space-4);
}

.et-process {
	display: flex;
	flex-direction: column;
	padding: var(--space-4) 0;
}

.et-process__step {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 0 var(--space-8);
	position: relative;
	padding-bottom: var(--space-10);
	align-items: start;
}

.et-process__step:last-child {
	padding-bottom: 0;
}

.et-process__step::after {
	content: '';
	position: absolute;
	left: 19px;
	top: 52px;
	bottom: 0;
	width: 1px;
	background: linear-gradient(
		to bottom,
		var(--color-grey-300) 0%,
		var(--color-grey-100) 100%
	);
}

.et-process__step:last-child::after {
	display: none;
}

.et-process__num {
	font-family: var(--font-display, 'Playfair Display', Georgia, serif);
	font-size: clamp(2.5rem, 4vw, 3.5rem);
	font-weight: 400;
	color: var(--color-grey-300);
	line-height: 1;
	letter-spacing: -0.03em;
}

.et-process__desc {
	font-size: var(--text-base);
	color: var(--color-text-primary);
	line-height: 1.75;
	margin: 0;
	padding-top: 6px;
}

/* ── NHS / Private cards (clean, minimal) ───── */
.et-type-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-8);
}

.et-type-card {
	background: var(--color-white);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-grey-200);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 20px rgba(0, 0, 0, 0.05);
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.et-type-card:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.10);
	transform: translateY(-2px);
}

/* Coloured top accent bar */
.et-type-card::before {
	content: '';
	display: block;
	height: 4px;
	background: var(--color-grey-300);
}

.et-type-card--nhs::before    { background: #28a745; }
.et-type-card--private::before { background: var(--color-primary); }

.et-type-card__body {
	padding: var(--space-8);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.et-type-card__top {
	margin-bottom: var(--space-6);
	padding-bottom: var(--space-6);
	border-bottom: 1px solid var(--color-grey-100);
}

.et-type-card__badge {
	display: inline-block;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: var(--radius-full);
	margin-bottom: var(--space-3);
	background: var(--color-teal-light);
	color: var(--color-teal);
}

.et-type-card__badge--nhs {
	background: rgba(40, 167, 69, 0.1);
	color: #1a7a2e;
}

.et-type-card__title {
	font-family: var(--font-accent, 'Playfair Display', Georgia, serif);
	font-size: var(--text-2xl);
	font-weight: 400;
	color: var(--color-text-primary);
	margin: 0 0 var(--space-2);
	line-height: 1.2;
}

.et-type-card__tagline {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin: 0;
}

.et-type-card__note {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin: 0 0 var(--space-6);
	flex: 1;
	line-height: 1.6;
}

/* ── Check list ─────────────────────────────── */
.et-check-list {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	margin: 0 0 var(--space-6);
	padding: 0;
}

.et-check-list li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--text-sm);
	color: var(--color-grey-800);
	line-height: 1.55;
}

.et-check-list li::before {
	content: '';
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--color-teal-light);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%231A7A82' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	margin-top: 1px;
}

/* ── Specialist section (editorial rows, light) ── */
.et-specialist-grid {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--color-grey-200);
}

.et-spec-card {
	display: grid;
	grid-template-columns: 80px 1fr 52px;
	align-items: center;
	gap: var(--space-10);
	padding: var(--space-10) 0;
	text-decoration: none;
	border-bottom: 1px solid var(--color-grey-200);
	background: transparent;
	border-radius: 0;
	position: relative;
	transition: background var(--transition-base);
}

.et-spec-card:hover {
	background: var(--color-bg-section);
	box-shadow: none;
	transform: none;
}

.et-spec-card__index {
	font-family: var(--font-display, 'Playfair Display', Georgia, serif);
	font-size: clamp(2.75rem, 5vw, 4rem);
	font-weight: 400;
	color: var(--color-grey-200);
	line-height: 1;
	letter-spacing: -0.03em;
	flex-shrink: 0;
	transition: color var(--transition-base);
}

.et-spec-card:hover .et-spec-card__index {
	color: var(--color-teal);
}

.et-spec-card__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.et-spec-card__title {
	font-family: var(--font-display, 'Playfair Display', Georgia, serif);
	font-size: clamp(1.25rem, 2vw, 1.75rem);
	font-weight: 400;
	color: var(--color-text-primary);
	margin: 0;
	line-height: 1.2;
	transition: color var(--transition-base);
}

.et-spec-card__desc {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: 1.65;
	margin: 0;
}

.et-spec-card__arrow {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 1px solid var(--color-grey-300);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-grey-400);
	transition: border-color var(--transition-base), color var(--transition-base), transform var(--transition-base);
}

.et-spec-card:hover .et-spec-card__arrow {
	border-color: var(--color-teal);
	color: var(--color-teal);
	transform: rotate(-45deg);
}

/* ─────────────────────────────────────────────
   SHARED HUB-PAGE COMPONENTS
   (Glasses & Contact Lenses pages)
   ───────────────────────────────────────────── */

/* ── Hub hero (reuses page-hero--et styles) ─ */
.page-hero--hub {
	background: var(--color-ink, #0D1117);
	padding: var(--space-10) 0 var(--space-12);
	position: relative;
	overflow: hidden;
}

.page-hero--hub::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient( ellipse 70% 80% at 100% 50%, rgba(15, 81, 132, 0.3) 0%, transparent 65% );
	pointer-events: none;
}

.page-hero--hub .container { position: relative; }

/* ── Feature grid (6-up or 4-up cards) ─────── */
.hub-feature-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-6);
}

.hub-feature-grid--2col {
	grid-template-columns: repeat(2, 1fr);
}

.hub-card {
	background: var(--color-white);
	border: 1px solid var(--color-grey-200);
	border-radius: var(--radius-lg);
	padding: var(--space-7) var(--space-8);
	position: relative;
	overflow: hidden;
	transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.hub-card:hover {
	box-shadow: 0 8px 28px rgba(0,0,0,0.08);
	transform: translateY(-2px);
}

.hub-card::before {
	content: '';
	display: block;
	height: 3px;
	background: var(--color-grey-200);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
}

.hub-card--accent::before { background: var(--color-teal); }
.hub-card--primary::before { background: var(--color-primary); }
.hub-card--green::before   { background: #28a745; }

.hub-card__icon {
	width: 40px;
	height: 40px;
	border-radius: var(--radius-md);
	background: var(--color-teal-light);
	color: var(--color-teal);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-4);
}

.hub-card__title {
	font-family: var(--font-display, 'Playfair Display', Georgia, serif);
	font-size: var(--text-xl);
	font-weight: 400;
	color: var(--color-text-primary);
	margin: 0 0 var(--space-3);
	line-height: 1.2;
}

.hub-card__desc {
	font-size: var(--text-sm);
	color: var(--color-text-secondary);
	line-height: 1.7;
	margin: 0;
}

/* ── 2-col intro split ──────────────────────── */
.hub-intro-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-20);
	align-items: center;
}

/* ── USP check list (light on white) ───────── */
.hub-check-list {
	list-style: none;
	padding: 0;
	margin: var(--space-6) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.hub-check-list li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--text-base);
	color: var(--color-text-primary);
	line-height: 1.6;
}

.hub-check-list li::before {
	content: '';
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--color-teal-light);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%231A7A82' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	margin-top: 2px;
}

/* ── Highlight banner (replaces .notice) ────── */
.hub-banner {
	background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
	border-radius: var(--radius-lg);
	padding: var(--space-10) var(--space-12);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-8);
	color: var(--color-white);
}

.hub-banner__body { flex: 1; }

.hub-banner__eyebrow {
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: rgba(255,255,255,0.6);
	display: block;
	margin-bottom: var(--space-2);
}

.hub-banner__title {
	font-family: var(--font-display, 'Playfair Display', Georgia, serif);
	font-size: clamp(1.5rem, 2.5vw, 2.25rem);
	font-weight: 400;
	color: var(--color-white);
	margin: 0 0 var(--space-3);
	line-height: 1.15;
}

.hub-banner__desc {
	font-size: var(--text-base);
	color: rgba(255,255,255,0.75);
	margin: 0;
	line-height: 1.6;
}

/* ── Process steps (hub variant — white bg) ── */
.hub-process-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-20);
	align-items: start;
}

.hub-process-lead {
	position: sticky;
	top: var(--space-20);
}

.hub-process-lead p {
	color: var(--color-text-secondary);
	font-size: var(--text-base);
	line-height: 1.75;
	margin-top: var(--space-4);
}

/* ── Responsive ─────────────────────────────── */
@media ( max-width: 900px ) {
	.hub-feature-grid        { grid-template-columns: 1fr 1fr; }
	.hub-feature-grid--2col  { grid-template-columns: 1fr; }
	.hub-intro-grid          { grid-template-columns: 1fr; gap: var(--space-10); }
	.hub-banner              { flex-direction: column; align-items: flex-start; }
	.hub-process-layout      { grid-template-columns: 1fr; gap: var(--space-10); }
	.hub-process-lead        { position: static; }
}

@media ( max-width: 640px ) {
	.hub-feature-grid { grid-template-columns: 1fr; }
	.hub-banner       { padding: var(--space-8); }
}

/* ── Responsive ─────────────────────────────── */
@media ( max-width: 1024px ) {
	.et-stat-grid { grid-template-columns: repeat(2, 1fr); }
	.et-stat { border-bottom: 1px solid rgba(255, 255, 255, 0.07); }
	.et-stat:nth-child(2) { border-right: none; }
	.et-stat:nth-child(3) { border-bottom: none; }
	.et-stat:last-child   { border-bottom: none; }
}

@media ( max-width: 900px ) {
	.et-intro-grid { grid-template-columns: 1fr; gap: var(--space-10); }
	.et-type-grid  { grid-template-columns: 1fr; }
	.et-process-layout { grid-template-columns: 1fr; gap: var(--space-10); }
	.et-process-lead { position: static; }
}

@media ( max-width: 640px ) {
	.et-hero__trust-row  { gap: var(--space-4); }
	.et-hero__actions    { flex-direction: column; }
	.et-hero__actions .btn { width: 100%; justify-content: center; }
	.et-spec-card {
		grid-template-columns: 52px 1fr 40px;
		gap: var(--space-5);
		padding: var(--space-7) 0;
	}
	.et-spec-card__index { font-size: 2.25rem; }
	.et-spec-card__arrow { width: 36px; height: 36px; }
	.et-stat-grid { grid-template-columns: 1fr 1fr; }
}

@media ( max-width: 480px ) {
	.et-stat-grid { grid-template-columns: 1fr 1fr; }
}
