/* ==========================================================================
   MCAAS Custom — main.css
   Design tokens → reset → base → layout → components → utilities
   Detailed component styles (hero, service card, testimonial, etc.) will be
   filled in during Step 6. This file exists so the scaffolded site renders
   legibly before component work starts.
   ========================================================================== */

/* ---------- @font-face (Gilroy) ------------------------------------------ */
@font-face {
	font-family: "Gilroy";
	src: url("../fonts/Gilroy-Light.woff2") format("woff2");
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Gilroy";
	src: url("../fonts/Gilroy-Regular.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Gilroy";
	src: url("../fonts/Gilroy-Medium.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Gilroy";
	src: url("../fonts/Gilroy-Bold.woff2") format("woff2");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Gilroy";
	src: url("../fonts/Gilroy-Heavy.woff2") format("woff2");
	font-weight: 800;
	font-style: normal;
	font-display: swap;
}

/* ---------- Tokens -------------------------------------------------------- */
:root {
	/* Brand */
	--color-navy:        #00197E;
	--color-yellow:      #FFAF02;
	--color-cta-blue:    #2F6DFF;
	--color-whatsapp:    #15B746;

	/* Text + surfaces */
	--color-heading:     #1E1E1E;
	--color-body:        #3A4268;
	--color-muted:       #595959;
	--color-muted-2:     #7A7A7A;
	--color-border:      #DADADA;
	--color-surface:     #FFFFFF;
	--color-surface-alt: #F3F4F8;

	/* Focus ring */
	--color-focus:       #2F6DFF;

	/* Typography */
	--font-display: "Gilroy", system-ui, -apple-system, Segoe UI, Helvetica, Arial, sans-serif;
	--font-body:    "Gilroy", system-ui, -apple-system, Segoe UI, Helvetica, Arial, sans-serif;

	--fs-hero:    clamp(2rem, 1.25rem + 3vw, 3.5rem);
	--fs-h2:      clamp(1.5rem, 1.125rem + 1.25vw, 2rem);
	--fs-h3:      1.25rem;
	--fs-eyebrow: 1rem;
	--fs-body:    1rem;
	--fs-small:   0.875rem;

	--fw-regular: 400;
	--fw-medium:  500;
	--fw-bold:    700;
	--fw-heavy:   800;

	--lh-tight:   1.2;
	--lh-snug:    1.4;
	--lh-body:    1.625;

	/* Layout */
	--container-max:  1140px;
	--gutter:         clamp(1rem, 2vw, 2rem);
	--radius-sm:      4px;
	--radius-md:      8px;
	--radius-lg:      16px;
	--radius-pill:    999px;

	/* Shadows */
	--shadow-card:   0 2px 8px rgba(0, 25, 126, 0.06), 0 1px 2px rgba(0, 25, 126, 0.04);
	--shadow-card-hover: 0 8px 24px rgba(0, 25, 126, 0.08);

	/* Motion */
	--t-fast: 150ms;
	--t-med:  250ms;
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
	}
}

/* ---------- Reset --------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; -moz-tab-size: 4; tab-size: 4; scroll-behavior: smooth; }
body { margin: 0; }
h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd, ul, ol { margin: 0; }
ul, ol { padding: 0; list-style: none; }
img, svg, video, canvas, audio, iframe, embed, object { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }

/* ---------- Base ---------------------------------------------------------- */
body {
	font-family: var(--font-body);
	font-size: var(--fs-body);
	font-weight: var(--fw-regular);
	line-height: var(--lh-body);
	color: var(--color-body);
	background: var(--color-surface);
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	line-height: var(--lh-tight);
	color: var(--color-heading);
	font-weight: var(--fw-bold);
}
h1 { font-size: var(--fs-hero); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }

p + p { margin-top: 1em; }
a { color: var(--color-cta-blue); transition: color var(--t-fast); }
a:hover, a:focus-visible { color: var(--color-navy); }

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

.skip-link {
	position: absolute; left: -9999px; top: 0;
	background: var(--color-navy); color: #fff;
	padding: 0.75rem 1rem; z-index: 100;
}
.skip-link:focus { left: 0.5rem; top: 0.5rem; }

.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;
}

/* ---------- Layout helpers ------------------------------------------------ */
.container {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--gutter);
}

.section {
	padding-block: clamp(3rem, 2rem + 3vw, 5rem);
}
.section--page-header { padding-block: clamp(2.5rem, 1.5rem + 2vw, 4rem); background: var(--color-surface-alt); }
.section--center { text-align: center; }

.eyebrow {
	display: inline-block;
	font-family: var(--font-display);
	font-size: var(--fs-eyebrow);
	font-weight: var(--fw-bold);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--color-yellow);
	margin-bottom: 0.5rem;
}

.lead {
	font-size: 1.125rem;
	color: var(--color-muted);
	max-width: 60ch;
}

.cta-row {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 1.5rem;
}

/* Long-form prose (blog post body, legal pages) */
.prose {
	max-width: 68ch;
	color: var(--color-body);
}
.prose h2 { margin-top: 2em; margin-bottom: 0.5em; }
.prose h3 { margin-top: 1.5em; margin-bottom: 0.5em; }
.prose p, .prose ul, .prose ol, .prose blockquote { margin-bottom: 1em; }
.prose ul, .prose ol { padding-left: 1.5em; }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose a { text-decoration: underline; }
.prose img { border-radius: var(--radius-md); margin-block: 1.5em; }
.prose blockquote {
	border-left: 4px solid var(--color-yellow);
	padding: 0.5em 1em;
	color: var(--color-muted);
}

/* ---------- Buttons ------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	line-height: 1;
	text-align: center;
	cursor: pointer;
	transition: background-color var(--t-fast), color var(--t-fast), transform var(--t-fast);
	border-radius: var(--radius-pill);
	padding: 0.875rem 1.75rem;
	white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn--primary {
	background: var(--color-cta-blue);
	color: #fff;
}
.btn--primary:hover,
.btn--primary:focus-visible {
	background: var(--color-navy);
	color: #fff;
}

.btn--action {
	background: var(--color-whatsapp);
	color: #fff;
	font-weight: var(--fw-medium);
}
.btn--action:hover,
.btn--action:focus-visible {
	background: #109a3a;
	color: #fff;
}

.btn--ghost {
	background: transparent;
	color: var(--color-cta-blue);
	border: 1px solid currentColor;
}

.btn--link {
	background: transparent;
	color: var(--color-cta-blue);
	padding: 0;
	font-weight: var(--fw-bold);
	border-radius: 0;
}
.btn--link:hover { color: var(--color-navy); transform: none; }

/* Size modifiers — use .btn--sm on tight chrome (header), plain .btn for hero/section CTAs */
.btn--sm { padding: 0.625rem 1.25rem; font-size: 0.9375rem; }

.tag {
	display: inline-block;
	background: var(--color-navy);
	color: #fff;
	padding: 0.25rem 0.625rem;
	border-radius: var(--radius-sm);
	font-family: var(--font-display);
	font-size: 0.875rem;
	font-weight: var(--fw-medium);
}

/* ---------- Topbar -------------------------------------------------------- */
.site-topbar {
	background: var(--color-navy);
	color: #fff;
	font-size: var(--fs-small);
}
.site-topbar a { color: inherit; }
.site-topbar a:hover { color: var(--color-yellow); }
.site-topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 40px;
	padding-block: 0.5rem;
}
.site-topbar__info {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin: 0;
}
@media (max-width: 767px) {
	.site-topbar { display: none; }
}

/* ---------- Header / Primary nav ----------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	background: var(--color-surface);
	box-shadow: 0 1px 0 var(--color-border);
	z-index: 50;
}
.site-header__inner {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	min-height: 72px;
}
.site-header__brand { margin-right: auto; }
.site-logo {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 1.25rem;
	color: var(--color-navy);
}

.site-nav__list {
	display: flex;
	align-items: center;
	gap: 0.25rem;
}
.site-nav__link,
.site-nav__sublink {
	display: block;
	padding: 0.75rem 1rem;
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	color: var(--color-heading);
	border-radius: var(--radius-sm);
}
.site-nav__link:hover,
.site-nav__link:focus-visible,
.site-nav__sublink:hover,
.site-nav__sublink:focus-visible {
	color: var(--color-whatsapp);
}
.site-nav__item { position: relative; }
.site-nav__item--has-children > .site-nav__link::after {
	content: "";
	display: inline-block;
	width: 0.5em; height: 0.5em;
	margin-left: 0.4em;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-0.15em) rotate(45deg);
	transition: transform var(--t-fast);
}
/* Chevron rotates when the submenu is open (mobile tap-to-expand) */
.site-nav__item--has-children.is-submenu-open > .site-nav__link::after {
	transform: translateY(0.15em) rotate(-135deg);
}
.site-nav__submenu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 280px;
	background: var(--color-surface);
	box-shadow: var(--shadow-card);
	border-radius: var(--radius-md);
	padding: 0.5rem;
	display: none;
}
.site-nav__item:hover > .site-nav__submenu,
.site-nav__item:focus-within > .site-nav__submenu { display: block; }

.site-nav__toggle {
	display: none;
	width: 44px; height: 44px;
	padding: 10px;
	margin-left: auto;
}
.site-nav__toggle-bar {
	display: block;
	width: 100%;
	height: 2px;
	background: var(--color-heading);
	margin-block: 4px;
	border-radius: 2px;
}

@media (max-width: 1024px) {
	.site-nav__toggle { display: block; order: 3; }
	.site-header__cta { display: none; }
	.site-nav {
		display: none;
		position: absolute;
		top: 100%; left: 0; right: 0;
		background: var(--color-surface);
		border-top: 1px solid var(--color-border);
		padding: 1rem var(--gutter) 1.5rem;
	}
	.site-nav.is-open { display: block; }
	.site-nav__list { flex-direction: column; align-items: stretch; gap: 0; }

	/* Submenu is collapsed by default on mobile, expands on tap */
	.site-nav__submenu {
		position: static;
		display: none;
		box-shadow: none;
		padding-left: 1rem;
		min-width: auto;
	}
	.site-nav__item--has-children.is-submenu-open > .site-nav__submenu { display: block; }

	/* On mobile, links stretch to full width and have clearer hit targets */
	.site-nav__link,
	.site-nav__sublink { padding: 0.875rem 0.5rem; }
	.site-nav__item + .site-nav__item { border-top: 1px solid var(--color-border); }
	.site-nav__item--has-children > .site-nav__link { display: flex; justify-content: space-between; align-items: center; }
}

/* ---------- Newsletter bar ----------------------------------------------- */
.newsletter {
	background: linear-gradient(135deg, #FFC64A 0%, var(--color-yellow) 60%, #F29B00 100%);
	color: var(--color-heading);
	position: relative;
	overflow: hidden;
}
.newsletter::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image: radial-gradient(circle at 15% 120%, rgba(255, 255, 255, 0.35), transparent 45%),
		radial-gradient(circle at 100% -30%, rgba(0, 25, 126, 0.10), transparent 45%);
}
.newsletter__inner {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem 2rem;
	align-items: center;
	justify-content: space-between;
	padding-block: clamp(1.5rem, 1rem + 1.5vw, 2.25rem);
}
.newsletter__lead {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex: 1 1 340px;
}
.newsletter__icon {
	display: grid; place-items: center;
	width: 48px; height: 48px;
	border-radius: var(--radius-md);
	background: rgba(0, 25, 126, 0.12);
	color: var(--color-navy);
	flex-shrink: 0;
}
.newsletter__title {
	font-size: clamp(1.125rem, 1rem + 0.4vw, 1.375rem);
	margin: 0 0 0.25rem;
	line-height: 1.25;
}
.newsletter__sub {
	margin: 0;
	color: rgba(30, 30, 30, 0.75);
	font-size: 0.875rem;
	line-height: 1.4;
}
.newsletter__form {
	display: flex;
	gap: 0.625rem;
	flex: 1 1 340px;
	max-width: 540px;
	align-items: stretch;
}
.newsletter__field {
	flex: 1;
	position: relative;
	display: flex;
	align-items: center;
	background: #fff;
	border-radius: var(--radius-pill);
	box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
}
.newsletter__field-icon {
	position: absolute;
	left: 1.125rem;
	color: var(--color-muted);
	pointer-events: none;
}
.newsletter__form input[type="email"] {
	flex: 1;
	padding: 0.875rem 1rem 0.875rem 3rem;
	border: 1px solid transparent;
	border-radius: var(--radius-pill);
	background: transparent;
	font-size: 0.9375rem;
}
.newsletter__form input[type="email"]:focus {
	outline: 0;
	box-shadow: 0 0 0 3px rgba(47, 109, 255, 0.25);
}
.newsletter__form .btn {
	gap: 0.5rem;
	display: inline-flex;
	align-items: center;
}

/* ---------- Footer -------------------------------------------------------- */
.site-footer {
	position: relative;
	background:
		radial-gradient(circle at 100% 0%, rgba(47, 109, 255, 0.15), transparent 50%),
		radial-gradient(circle at 0% 100%, rgba(47, 109, 255, 0.10), transparent 45%),
		linear-gradient(180deg, #000C40 0%, var(--color-navy) 100%);
	color: rgba(255, 255, 255, 0.82);
	overflow: hidden;
	isolation: isolate;
}
.site-footer a { color: inherit; transition: color var(--t-fast); }
.site-footer a:hover { color: var(--color-yellow); }

.site-footer__glow {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	pointer-events: none;
	z-index: -1;
}
.site-footer__glow--a {
	top: -120px; left: -80px;
	width: 300px; height: 300px;
	background: var(--color-cta-blue);
	opacity: 0.28;
}
.site-footer__glow--b {
	bottom: -160px; right: -100px;
	width: 380px; height: 380px;
	background: var(--color-yellow);
	opacity: 0.12;
}

.site-footer__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1.2fr;
	gap: 2.5rem;
	padding-block: clamp(3rem, 2rem + 3vw, 4.5rem);
}

/* Brand column */
.site-footer__logo img,
.site-footer__logo svg { max-width: 140px; height: auto; filter: brightness(0) invert(1); opacity: 0.95; }
.site-footer__wordmark {
	font-family: var(--font-display);
	font-weight: var(--fw-heavy);
	font-size: 1.375rem;
	color: #fff;
	margin: 0 0 0.5rem;
	letter-spacing: -0.01em;
}
.site-footer__tagline {
	color: rgba(255, 255, 255, 0.70);
	font-size: 0.9375rem;
	margin: 0.75rem 0 1.25rem;
	max-width: 34ch;
	line-height: 1.6;
}

.site-footer__chips {
	list-style: none;
	padding: 0;
	margin: 0 0 1.5rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.site-footer__chips li {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.375rem 0.75rem;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius-pill);
	color: rgba(255, 255, 255, 0.90);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.75rem;
	letter-spacing: 0.02em;
}
.site-footer__chips li svg { color: var(--color-yellow); flex-shrink: 0; }
.site-footer__chips li:nth-child(3) svg { color: var(--color-yellow); }

.site-footer__whatsapp {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	background: rgba(21, 183, 70, 0.12);
	border: 1px solid rgba(21, 183, 70, 0.35);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: background-color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.site-footer__whatsapp:hover {
	background: rgba(21, 183, 70, 0.20);
	border-color: var(--color-whatsapp);
	color: #fff;
	transform: translateY(-2px);
}
.site-footer__whatsapp-icon {
	display: grid; place-items: center;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--color-whatsapp);
	color: #fff;
	flex-shrink: 0;
}
.site-footer__whatsapp span span { display: block; }
.site-footer__whatsapp-label { font-size: 0.75rem; color: rgba(255, 255, 255, 0.7); text-transform: uppercase; letter-spacing: 0.05em; }
.site-footer__whatsapp strong { font-family: var(--font-display); color: #fff; font-size: 0.9375rem; font-weight: var(--fw-bold); }

/* Columns */
.site-footer__heading {
	position: relative;
	font-size: 1rem;
	font-weight: var(--fw-bold);
	margin-bottom: 1.25rem;
	padding-bottom: 0.75rem;
	color: #fff;
	letter-spacing: 0.01em;
}
.site-footer__heading::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 28px; height: 2px;
	background: var(--color-yellow);
	border-radius: 2px;
}
.site-footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.625rem; }
.site-footer__col a {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
}
.site-footer__col a:hover { color: var(--color-yellow); }
.site-footer__arrow {
	display: inline-block;
	opacity: 0;
	transform: translateX(-4px);
	transition: opacity var(--t-fast), transform var(--t-fast);
	color: var(--color-yellow);
	font-weight: var(--fw-bold);
}
.site-footer__col a:hover .site-footer__arrow { opacity: 1; transform: translateX(0); }

/* Contact list */
.site-footer__contact { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.875rem; }
.site-footer__contact li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	font-size: 0.9375rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.78);
}
.site-footer__contact-icon {
	display: grid; place-items: center;
	width: 32px; height: 32px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.08);
	color: var(--color-yellow);
	flex-shrink: 0;
	margin-top: 0.125rem;
}

/* Bottom bar */
.site-footer__bottom {
	background: rgba(0, 0, 0, 0.25);
	padding-block: 1.125rem;
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.6);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.site-footer__bottom-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 0.5rem 1.5rem;
}
.site-footer__copyright,
.site-footer__credit { margin: 0; }
.site-footer__credit a {
	color: #fff;
	font-weight: var(--fw-bold);
	border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	padding-bottom: 1px;
	transition: color var(--t-fast), border-color var(--t-fast);
}
.site-footer__credit a:hover {
	color: var(--color-yellow);
	border-color: var(--color-yellow);
}

@media (max-width: 1024px) {
	.site-footer__inner { grid-template-columns: 1fr 1fr; gap: 2rem; }
	.site-footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
	.site-footer__inner { grid-template-columns: 1fr; gap: 2.5rem; }
	.site-footer__bottom-inner { justify-content: center; text-align: center; }
}

/* ---------- WhatsApp floating action button ------------------------------ */
.whatsapp-fab {
	position: fixed;
	right: clamp(1rem, 3vw, 1.5rem);
	bottom: clamp(1rem, 3vw, 1.5rem);
	width: 60px; height: 60px;
	background: var(--color-whatsapp);
	color: #fff;
	border-radius: 50%;
	display: grid;
	place-items: center;
	box-shadow: 0 8px 24px rgba(21, 183, 70, 0.40);
	z-index: 80;
	transition: transform var(--t-fast), box-shadow var(--t-fast);
}
.whatsapp-fab::before {
	content: "";
	position: absolute;
	inset: -4px;
	border-radius: 50%;
	border: 2px solid rgba(21, 183, 70, 0.35);
	animation: faqDotPulseRing 2s ease-out infinite;
}
@keyframes faqDotPulseRing {
	0%   { transform: scale(0.9); opacity: 0.9; }
	70%  { transform: scale(1.25); opacity: 0; }
	100% { transform: scale(1.25); opacity: 0; }
}
.whatsapp-fab:hover {
	transform: scale(1.08);
	color: #fff;
	box-shadow: 0 12px 30px rgba(21, 183, 70, 0.50);
}
.whatsapp-fab__icon { display: block; }

/* ---------- Cards grid (placeholder for Step 6) -------------------------- */
.card-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 2rem;
}

/* ---------- Blog card ---------------------------------------------------- */
.blog-card {
	display: flex;
	flex-direction: column;
	background: var(--color-surface);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	transition: box-shadow var(--t-fast), transform var(--t-fast);
}
.blog-card:hover {
	box-shadow: var(--shadow-card-hover);
	transform: translateY(-2px);
}
.blog-card__media img { width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.blog-card__body { padding: 1.25rem 1.5rem 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
.blog-card__category { font-size: var(--fs-small); color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.05em; margin: 0; }
.blog-card__title { font-size: var(--fs-h3); line-height: var(--lh-snug); margin: 0; }
.blog-card__title a { color: var(--color-heading); }
.blog-card__title a:hover { color: var(--color-cta-blue); }
.blog-card__meta { font-size: var(--fs-small); color: var(--color-muted-2); margin: 0; margin-top: auto; }

/* ---------- Pagination --------------------------------------------------- */
.pagination { margin-top: 2.5rem; display: flex; justify-content: center; }
.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.75rem;
	margin: 0 0.15rem;
	border-radius: var(--radius-sm);
	color: var(--color-heading);
	font-weight: var(--fw-medium);
}
.pagination .page-numbers:hover,
.pagination .page-numbers.current { background: var(--color-navy); color: #fff; }

/* ---------- Single post -------------------------------------------------- */
.post-single__header { padding-block: clamp(2rem, 1rem + 3vw, 3.5rem); background: var(--color-surface-alt); }
.post-single__category { color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.05em; font-size: var(--fs-small); margin: 0 0 0.5rem; }
.post-single__title { font-size: clamp(1.75rem, 1.25rem + 2vw, 2.5rem); }
.post-single__meta { color: var(--color-muted-2); font-size: var(--fs-small); margin-top: 0.5rem; }
.post-single__featured { margin: 0; }
.post-single__featured img { width: 100%; max-height: 480px; object-fit: cover; }
.post-single__body { padding-block: 2.5rem; }

/* ---------- Page title fallback ------------------------------------------ */
.page-title {
	font-size: clamp(1.75rem, 1.25rem + 2vw, 2.75rem);
	margin-bottom: 0.5em;
}

/* ---------- Admin bar offset (WP) ---------------------------------------- */
.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) {
	.admin-bar .site-header { top: 46px; }
}

/* ==========================================================================
   Homepage + shared components
   ========================================================================== */

/* ---------- Shared: section header --------------------------------------- */
.section__header { margin-bottom: clamp(1.5rem, 1rem + 1.5vw, 2.5rem); }
.section__header--center { text-align: center; }
.section__header--center .lead,
.section__header-lead { margin-inline: auto; max-width: 60ch; margin-top: 0.75rem; }
.section__header h2 { max-width: 24ch; margin-inline: auto; }
.section__header:not(.section__header--center) h2 { margin-left: 0; margin-right: 0; max-width: none; }

.section--alt { background: var(--color-surface-alt); }

.cta-row--center { justify-content: center; }

/* Eyebrow on dark */
.eyebrow--on-dark { color: var(--color-yellow); }

.container--narrow { max-width: 860px; }

/* ---------- Home hero ---------------------------------------------------- */
.home-hero {
	background: var(--color-navy);
	color: #fff;
	overflow: hidden;
}
.home-hero__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	padding-block: clamp(2.5rem, 2rem + 3vw, 5rem);
	align-items: center;
}
.home-hero__copy { position: relative; z-index: 1; }
.home-hero__title {
	font-size: clamp(2rem, 1.25rem + 3.5vw, 3.5rem);
	font-weight: var(--fw-heavy);
	line-height: var(--lh-tight);
	color: #fff;
	margin-top: 0.75rem;
}
.home-hero__title-accent { color: var(--color-yellow); display: block; }
.home-hero__title-sep { color: #fff; display: block; font-weight: var(--fw-regular); font-size: 0.72em; }
.home-hero__lead {
	color: rgba(255, 255, 255, 0.85);
	font-size: 1.0625rem;
	margin-top: 1.25rem;
	max-width: 52ch;
}
.home-hero .cta-row { margin-top: 1.75rem; }
.home-hero__media {
	position: relative;
}
.home-hero__media img {
	width: 100%;
	max-width: 520px;
	margin-inline: auto;
	display: block;
	/* image already includes its own circular/sparkle styling */
}
@media (min-width: 1200px) {
	.home-hero__media img { max-width: 640px; }
}
@media (min-width: 1440px) {
	.home-hero__media img { max-width: 720px; }
}
@media (min-width: 900px) {
	.home-hero__inner { grid-template-columns: 1.05fr 1fr; gap: 3rem; }
	.home-hero__media img { max-width: none; }
}

/* Badge row under the hero (certifications strip) */
.home-hero__badges {
	background: rgba(255, 255, 255, 0.06);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.badge-row {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem 2.5rem;
	align-items: center;
	justify-content: space-between;
	padding-block: 1rem;
	color: rgba(255, 255, 255, 0.9);
	font-size: var(--fs-small);
}
.badge-row li { display: flex; align-items: center; gap: 0.5rem; }
.badge-row__num { color: var(--color-yellow); font-weight: var(--fw-bold); font-size: 1.25rem; }

/* ---------- Split section (text + image) ---------------------------------*/
.split-section {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
.split-section__media {
	position: relative;
	max-width: 560px;
	margin-inline: auto;
	width: 100%;
}
.split-section__media img {
	width: 100%;
	height: 100%;
	border-radius: var(--radius-lg);
	object-fit: cover;
	aspect-ratio: 4/3;
	display: block;
}
.split-section__copy h2 { margin-top: 0.5rem; }
.split-section__copy p + p { margin-top: 1em; }
.split-section__copy .cta-row { margin-top: 1.5rem; }
@media (min-width: 900px) {
	.split-section { grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
	.split-section--reverse .split-section__copy { order: 2; }
	.split-section--reverse .split-section__media { order: 1; }
}

/* About split — framed image, offset accent, floating stat card */
.split-section--about .split-section__media { max-width: 520px; }
.split-section__media-frame {
	position: relative;
	border-radius: clamp(1rem, 0.5rem + 1vw, 1.5rem);
	overflow: hidden;
	box-shadow: 0 24px 48px -16px rgba(0, 25, 126, 0.28);
	aspect-ratio: 4/5;
	z-index: 2;
}
.split-section__media-frame img {
	width: 100%; height: 100%;
	aspect-ratio: auto;
	border-radius: 0;
	object-position: center;
}
.split-section__media-accent {
	position: absolute;
	top: 1.5rem; left: -1.25rem;
	right: 1.5rem; bottom: -1.25rem;
	border-radius: clamp(1rem, 0.5rem + 1vw, 1.5rem);
	background: linear-gradient(135deg, var(--color-yellow), #F29B00);
	z-index: 1;
	opacity: 0.9;
}
.split-section--reverse .split-section__media-accent,
.split-section__media--framed.split-section__media--right .split-section__media-accent {
	left: 1.5rem;
	right: -1.25rem;
}

.split-section__stat {
	position: absolute;
	bottom: -18px;
	right: -12px;
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	padding: 0.875rem 1.125rem;
	background: #fff;
	border-radius: var(--radius-lg);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
	z-index: 3;
	border: 1px solid var(--color-border);
}
.split-section__stat strong {
	font-family: var(--font-display);
	font-size: 1.875rem;
	font-weight: var(--fw-heavy);
	color: var(--color-navy);
	line-height: 1;
}
.split-section__stat span {
	font-size: 0.75rem;
	color: var(--color-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-weight: var(--fw-bold);
	line-height: 1.25;
}
@media (max-width: 539px) {
	.split-section__media-accent { display: none; }
	.split-section__stat { bottom: -14px; right: 0.75rem; padding: 0.625rem 0.875rem; }
	.split-section__stat strong { font-size: 1.375rem; }
}

/* ---------- Service grid ------------------------------------------------- */
.service-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 600px) { .service-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .service-grid { grid-template-columns: repeat(4, 1fr); } }

.service-card {
	display: flex;
	flex-direction: column;
	background: var(--color-surface);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	transition: box-shadow var(--t-fast), transform var(--t-fast);
}
.service-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }
.service-card__media { display: block; overflow: hidden; aspect-ratio: 4/3; }
.service-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-med); }
.service-card:hover .service-card__media img { transform: scale(1.04); }
.service-card__body { padding: 1.25rem 1.25rem 1.5rem; display: flex; flex-direction: column; gap: 0.75rem; flex: 1; }
.service-card__title { font-size: 1.125rem; line-height: var(--lh-snug); margin: 0.25rem 0 0; }
.service-card__title a { color: var(--color-heading); }
.service-card__title a:hover { color: var(--color-cta-blue); }
.service-card__body-text { color: var(--color-muted); font-size: 0.9375rem; margin: 0; flex: 1; }
.service-card .btn--link { align-self: flex-start; }

/* ---------- Process ----------------------------------------------------- */
.process-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}
@media (min-width: 768px) { .process-grid { grid-template-columns: repeat(3, 1fr); } }

.process-step {
	text-align: center;
	padding: 0 1rem;
}
.process-step__icon {
	width: 88px; height: 88px;
	margin: 0 auto 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 50%;
	display: grid; place-items: center;
	padding: 1.125rem;
}
.process-step__icon img { max-width: 100%; height: auto; }
.process-step__title { font-size: 1.25rem; margin-bottom: 0.5rem; }
.process-step p { color: var(--color-muted); font-size: 0.9375rem; }

/* ---------- Why Choose -------------------------------------------------- */
.why-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 600px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .why-grid { grid-template-columns: repeat(4, 1fr); } }

.why-card {
	padding: 1.75rem 1.5rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	background: var(--color-surface);
	text-align: left;
}
.why-card__icon {
	width: 48px; height: 48px;
	border-radius: 50%;
	background: var(--color-yellow);
	color: var(--color-navy);
	display: grid; place-items: center;
	margin-bottom: 1rem;
}
.why-card__title { font-size: 1.125rem; margin-bottom: 0.5rem; }
.why-card p { color: var(--color-muted); font-size: 0.9375rem; }

/* ---------- Testimonials ------------------------------------------------ */
.testimonial-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 700px) { .testimonial-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .testimonial-grid { grid-template-columns: repeat(3, 1fr); } }

.testimonial-card {
	background: var(--color-surface);
	border-radius: var(--radius-lg);
	padding: 1.5rem 1.5rem 1.75rem;
	box-shadow: var(--shadow-card);
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin: 0;
}
.testimonial-card__google { position: absolute; top: 1.25rem; right: 1.25rem; }
.testimonial-card__stars { color: var(--color-yellow); letter-spacing: 0.15em; font-size: 1rem; }
.testimonial-card__quote { margin: 0; color: var(--color-body); font-size: 0.9375rem; line-height: 1.6; }
.testimonial-card__quote p { margin: 0; }
.testimonial-card__author {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: auto;
	padding-top: 0.75rem;
	border-top: 1px solid var(--color-border);
}
.testimonial-card__avatar {
	width: 44px; height: 44px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.testimonial-card__avatar--initials {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.875rem;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	user-select: none;
}
.testimonial-card__name { display: block; font-family: var(--font-display); font-weight: var(--fw-bold); color: var(--color-heading); font-size: 0.9375rem; }
.testimonial-card__date { display: block; color: var(--color-muted-2); font-size: 0.8125rem; }

/* ---------- FAQ --------------------------------------------------------- */
.faq-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.faq-item {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.faq-item__trigger {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1.125rem 1.5rem;
	text-align: left;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 1.0625rem;
	color: var(--color-heading);
	transition: background-color var(--t-fast);
}
.faq-item__trigger:hover { background: var(--color-surface-alt); }
.faq-item__question { flex: 1; }
.faq-item__chevron {
	display: inline-block;
	width: 0.75rem; height: 0.75rem;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	transition: transform var(--t-fast);
	flex-shrink: 0;
}
.faq-item__trigger[aria-expanded="true"] .faq-item__chevron { transform: rotate(-135deg); margin-top: 0.25rem; }
.faq-item__panel { padding: 0 1.5rem 1.25rem; color: var(--color-muted); line-height: 1.6; }

/* ---------- Small helper ------------------------------------------------- */
.section__empty { color: var(--color-muted); text-align: center; }

/* ==========================================================================
   Inner page header — slim breadcrumb bar (~48px tall) with inline h1
   ========================================================================== */
.page-hero {
	background: var(--color-surface-alt);
	border-bottom: 1px solid var(--color-border);
	padding-block: 0.625rem;
	text-align: left;
}
.page-hero__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 1rem;
	min-height: 28px;
}
.page-hero__title {
	font-size: 1rem;
	font-weight: var(--fw-bold);
	line-height: 1.2;
	margin: 0;
	color: var(--color-heading);
	max-width: none;
}

/* Breadcrumb — used inside page-hero and on service-detail page-banner */
.breadcrumb {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.8125rem;
	color: var(--color-muted);
	margin: 0;
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
}
.breadcrumb a {
	display: inline-flex;
	align-items: center;
	gap: 0.3125rem;
	color: var(--color-muted);
	text-decoration: none;
	transition: color var(--t-fast);
}
.breadcrumb a:hover { color: var(--color-cta-blue); }
.breadcrumb a svg { flex-shrink: 0; }
.breadcrumb__sep { color: var(--color-border); }
.breadcrumb [aria-current] { color: var(--color-heading); font-weight: var(--fw-bold); }

/* Visually hide the duplicate h1 — we keep it for SEO / a11y only */
.page-hero__title { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

/* Contact form-ish shared styling */
.form-field { display: flex; flex-direction: column; gap: 0.375rem; margin-bottom: 1rem; }
.form-field label { font-family: var(--font-display); font-weight: var(--fw-medium); font-size: 0.9375rem; color: var(--color-heading); }
.form-field input,
.form-field textarea,
.form-field select {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-surface);
	font-size: 1rem;
	transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
	outline: 0;
	border-color: var(--color-cta-blue);
	box-shadow: 0 0 0 3px rgba(47, 109, 255, 0.15);
}
.form-field textarea { min-height: 140px; resize: vertical; font-family: inherit; }
.form-row { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 600px) { .form-row { grid-template-columns: 1fr 1fr; } }

/* Two-column contact layout: form | info */
.contact-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}
@media (min-width: 900px) {
	.contact-layout { grid-template-columns: 1.1fr 1fr; gap: 4rem; }
}
.contact-info h2 { margin-bottom: 0.5rem; }
.contact-info__group { margin-top: 1.5rem; }
.contact-info__label { font-size: var(--fs-small); color: var(--color-muted-2); text-transform: uppercase; letter-spacing: 0.05em; font-weight: var(--fw-bold); margin-bottom: 0.25rem; }
.contact-info__value { font-size: 1.0625rem; color: var(--color-heading); }
.contact-info__value a { color: inherit; }
.contact-info__value a:hover { color: var(--color-cta-blue); }

.contact-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin-top: 1.5rem;
}
@media (min-width: 480px) { .contact-cards { grid-template-columns: 1fr 1fr; } }
.contact-cards__item {
	display: flex;
	gap: 0.875rem;
	padding: 1rem 1.125rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-surface);
}
.contact-cards__icon {
	width: 40px; height: 40px;
	background: rgba(0, 25, 126, 0.06);
	color: var(--color-navy);
	border-radius: var(--radius-sm);
	display: grid; place-items: center;
	flex-shrink: 0;
}
.contact-cards__label { font-size: var(--fs-small); color: var(--color-muted); margin: 0; }
.contact-cards__value { font-family: var(--font-display); font-weight: var(--fw-bold); color: var(--color-heading); margin: 0.125rem 0 0; }
.contact-cards__value a { color: inherit; }

/* Reviews page — Google reviews grid */
.review-grid-wrap { margin-top: 2rem; }

/* Thank-you page */
.thank-you-hero {
	background: var(--color-navy);
	color: #fff;
	text-align: center;
	padding-block: clamp(4rem, 3rem + 4vw, 7rem);
}
.thank-you-hero h1 {
	color: #fff;
	font-size: clamp(2.5rem, 2rem + 2vw, 3.5rem);
	margin-bottom: 1rem;
}
.thank-you-hero p {
	color: rgba(255, 255, 255, 0.85);
	font-size: 1.125rem;
	max-width: 48ch;
	margin-inline: auto;
}
.thank-you-hero .cta-row { justify-content: center; margin-top: 2rem; }

/* Blog index (/blog/) */
.blog-index .card-grid {
	grid-template-columns: 1fr;
}
@media (min-width: 640px) { .blog-index .card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .blog-index .card-grid { grid-template-columns: repeat(3, 1fr); } }

/* ==========================================================================
   Inner-page extras — Step 6 pages
   ========================================================================== */

/* Page banner (image-overlay hero used on /our-services/, and later service detail pages) */
.page-banner {
	position: relative;
	color: #fff;
	padding-block: clamp(3rem, 2.5rem + 2vw, 5rem);
	background-image: var(--banner-image);
	background-size: cover;
	background-position: center;
	text-align: center;
	isolation: isolate;
}
.page-banner__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0, 25, 126, 0.75) 0%, rgba(0, 25, 126, 0.85) 100%);
	z-index: -1;
}
.page-banner__inner { position: relative; }
.page-banner__title {
	color: #fff;
	font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
}
.breadcrumb--on-dark { color: rgba(255, 255, 255, 0.8); }
.breadcrumb--on-dark a { color: rgba(255, 255, 255, 0.8); }
.breadcrumb--on-dark a:hover { color: var(--color-yellow); }
.breadcrumb--on-dark [aria-current] { color: #fff; }

/* 2-col service grid variant for /our-services/ */
.service-grid--2col { grid-template-columns: 1fr; }
@media (min-width: 640px) { .service-grid--2col { grid-template-columns: repeat(2, 1fr); gap: 2rem; } }
@media (min-width: 1024px) { .service-grid--2col { grid-template-columns: repeat(2, 1fr); gap: 2.5rem; } }

/* Reviews summary bar */
.reviews-summary {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 1.25rem 1.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-card);
}
.reviews-summary__rating { display: flex; align-items: center; gap: 1rem; }
.reviews-summary__label { font-size: var(--fs-small); color: var(--color-muted); margin: 0; }
.reviews-summary__score { margin: 0.125rem 0 0; font-family: var(--font-display); font-size: 1.125rem; color: var(--color-heading); }
.reviews-summary__score strong { font-weight: var(--fw-heavy); color: var(--color-navy); font-size: 1.5rem; }
.reviews-summary__stars { color: var(--color-yellow); letter-spacing: 0.1em; margin-inline: 0.25rem; }
.reviews-summary__count { color: var(--color-muted); font-weight: var(--fw-regular); font-size: 0.95rem; }

/* CTA banner (FAQ page, etc.) — image + dark navy CTA block */
.cta-banner {
	background: var(--color-navy);
	color: #fff;
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin: 0 var(--gutter);
}
.cta-banner__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	align-items: stretch;
}
.cta-banner__copy { padding: clamp(2rem, 1.5rem + 2vw, 3rem); }
.cta-banner__copy h2 { color: #fff; margin-top: 0.5rem; }
.cta-banner__copy p { color: rgba(255, 255, 255, 0.85); }
.cta-banner__media img {
	width: 100%;
	height: 100%;
	min-height: 260px;
	object-fit: cover;
	display: block;
}
@media (min-width: 900px) {
	.cta-banner { margin: 0 var(--gutter); max-width: calc(var(--container-max) - 0px); margin-inline: auto; }
	.cta-banner__inner { grid-template-columns: 1fr 1fr; }
}

/* Legal page — tighten spacing */
.section--legal { padding-block: clamp(2rem, 1.5rem + 2vw, 3.5rem); }
.section--legal .prose { max-width: 72ch; margin-inline: auto; }
.section--legal .prose h1 {
	font-size: clamp(2rem, 1.5rem + 2vw, 2.75rem);
	margin-bottom: 0.5em;
}
.section--legal .prose .effective-date { color: var(--color-muted); font-size: 0.9375rem; margin-bottom: 2em; }

/* ==========================================================================
   Single Service template — detailed service detail page
   ========================================================================== */

/* 2. Intro: 2-column (copy + media) */
.service-intro {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 900px) {
	.service-intro { grid-template-columns: 1.15fr 1fr; gap: 3rem; align-items: center; }
}
@media (min-width: 1200px) {
	.service-intro { grid-template-columns: 1.2fr 440px; gap: 4rem; }
}

.service-sidebar {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 1.25rem 1rem;
	position: sticky;
	top: 100px;
}
.service-sidebar__heading {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	color: var(--color-heading);
	font-size: 1.0625rem;
	margin-bottom: 0.5rem;
	padding: 0 0.5rem;
}
.service-sidebar ul { display: flex; flex-direction: column; gap: 0.125rem; }
.service-sidebar__item a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.75rem 0.875rem;
	color: var(--color-heading);
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	font-size: 0.9375rem;
	line-height: 1.35;
	border-radius: var(--radius-md);
	transition: background-color var(--t-fast), color var(--t-fast);
}
.service-sidebar__item a:hover { background: var(--color-surface-alt); color: var(--color-cta-blue); }
.service-sidebar__item.is-current a {
	background: var(--color-yellow);
	color: var(--color-navy);
}
.service-sidebar__arrow { flex-shrink: 0; color: var(--color-cta-blue); font-size: 1.125rem; line-height: 1; }
.service-sidebar__item.is-current .service-sidebar__arrow { color: var(--color-navy); }

.service-intro__copy h2 {
	font-size: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
	line-height: 1.2;
	margin-bottom: 1rem;
	letter-spacing: -0.01em;
}

/* Meta row: tag pill + price chip + rating */
.service-intro__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.625rem 0.75rem;
	margin-bottom: 1.25rem;
}
.service-intro__tag {
	display: inline-flex;
	align-items: center;
	padding: 0.3125rem 0.75rem;
	background: rgba(47, 109, 255, 0.10);
	color: var(--color-cta-blue);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	border-radius: var(--radius-pill);
}
.service-intro__price {
	display: inline-flex;
	align-items: baseline;
	gap: 0.3125rem;
	padding: 0.3125rem 0.75rem;
	background: var(--color-yellow);
	color: var(--color-navy);
	border-radius: var(--radius-pill);
	font-family: var(--font-display);
}
.service-intro__price span { font-size: 0.6875rem; font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: 0.06em; }
.service-intro__price strong { font-size: 0.9375rem; font-weight: var(--fw-heavy); }
.service-intro__rating {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	color: var(--color-muted);
	font-family: var(--font-display);
	font-size: 0.8125rem;
}
.service-intro__rating svg { color: var(--color-yellow); }
.service-intro__rating span { font-weight: var(--fw-bold); }

/* Feature checks */
.service-intro__checks {
	list-style: none;
	padding: 0;
	margin: 1.25rem 0 1.75rem;
	display: grid;
	gap: 0.5rem;
}
@media (min-width: 600px) { .service-intro__checks { grid-template-columns: 1fr 1fr; gap: 0.625rem 1.25rem; } }
.service-intro__checks li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	color: var(--color-body);
	font-size: 0.9375rem;
	line-height: 1.45;
}
.service-intro__check-icon {
	display: grid; place-items: center;
	width: 20px; height: 20px;
	border-radius: 50%;
	background: rgba(21, 183, 70, 0.12);
	color: var(--color-whatsapp);
	flex-shrink: 0;
	margin-top: 0.1rem;
}

/* Media — framed image with accent block + badge + card */
.service-intro__media {
	position: relative;
	margin-top: 0.5rem;
}
.service-intro__media-frame {
	position: relative;
	border-radius: clamp(1rem, 0.5rem + 1vw, 1.5rem);
	overflow: hidden;
	box-shadow: 0 24px 48px -16px rgba(0, 25, 126, 0.28);
	aspect-ratio: 4/5;
	z-index: 2;
	background: var(--color-surface-alt);
}
.service-intro__media-frame img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.service-intro__media-accent {
	position: absolute;
	top: 1.5rem; right: -1.25rem;
	left: 1.5rem; bottom: -1.25rem;
	border-radius: clamp(1rem, 0.5rem + 1vw, 1.5rem);
	background: linear-gradient(135deg, var(--color-yellow), #F29B00);
	z-index: 1;
	opacity: 0.9;
}
.service-intro__media-badge {
	position: absolute;
	top: -12px;
	left: 16px;
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.5rem 0.875rem;
	background: var(--color-yellow);
	color: var(--color-navy);
	font-family: var(--font-display);
	font-weight: var(--fw-heavy);
	font-size: 0.8125rem;
	border-radius: var(--radius-pill);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
	transform: rotate(-3deg);
	z-index: 3;
}
.service-intro__media-card {
	position: absolute;
	bottom: -18px;
	right: 12px;
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	padding: 0.625rem 0.875rem 0.625rem 0.625rem;
	background: #fff;
	border-radius: var(--radius-pill);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.20);
	z-index: 3;
	border: 1px solid var(--color-border);
}
.service-intro__media-card-icon {
	display: grid; place-items: center;
	width: 34px; height: 34px;
	border-radius: 50%;
	background: var(--color-whatsapp);
	color: #fff;
	flex-shrink: 0;
}
.service-intro__media-card > span:not(.service-intro__media-card-icon) {
	display: flex; flex-direction: column; line-height: 1.1;
}
.service-intro__media-card strong {
	font-family: var(--font-display);
	color: var(--color-navy);
	font-size: 0.875rem;
	font-weight: var(--fw-heavy);
}
.service-intro__media-card-label {
	font-size: 0.6875rem;
	color: var(--color-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-weight: var(--fw-bold);
	margin-top: 0.1875rem;
}
@media (max-width: 539px) {
	.service-intro__media-accent { display: none; }
}

/* 3. Copy Blocks — 4 colored-icon cards */
.copy-blocks {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 640px)  { .copy-blocks { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .copy-blocks { grid-template-columns: repeat(4, 1fr); } }

.copy-block {
	padding: 1.5rem 1.25rem;
	background: var(--color-surface);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	text-align: left;
}
.copy-block__icon {
	display: grid; place-items: center;
	width: 48px; height: 48px;
	border-radius: var(--radius-md);
	margin-bottom: 1rem;
}
.copy-block__icon svg { width: 24px; height: 24px; }
.copy-block--tone-0 .copy-block__icon { background: rgba(255, 175, 2, 0.12);  color: var(--color-yellow); }
.copy-block--tone-1 .copy-block__icon { background: rgba(47, 109, 255, 0.12); color: var(--color-cta-blue); }
.copy-block--tone-2 .copy-block__icon { background: rgba(21, 183, 70, 0.12);  color: var(--color-whatsapp); }
.copy-block--tone-3 .copy-block__icon { background: rgba(0, 25, 126, 0.10);   color: var(--color-navy); }
.copy-block__title { font-size: 1rem; margin-bottom: 0.5rem; }
.copy-block__body  { color: var(--color-muted); font-size: 0.9375rem; line-height: 1.55; }

/* 4. Small benefits — lighter variant */
.small-benefits {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	max-width: 1040px;
	margin-inline: auto;
}
@media (min-width: 600px)  { .small-benefits { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .small-benefits { grid-template-columns: repeat(4, 1fr); } }

.small-benefit {
	text-align: center;
	padding: 1.25rem 0.75rem;
}
.small-benefit__icon {
	display: inline-grid; place-items: center;
	width: 44px; height: 44px;
	border-radius: 50%;
	background: var(--color-yellow);
	color: var(--color-navy);
	margin-bottom: 0.75rem;
}
.small-benefit__icon svg { width: 20px; height: 20px; }
.small-benefit__title { font-size: 0.9375rem; margin-bottom: 0.25rem; }
.small-benefit__body  { color: var(--color-muted); font-size: 0.875rem; line-height: 1.5; }

/* 5. Process detail — list + image */
.process-detail {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
}
@media (min-width: 900px) {
	.process-detail {
		grid-template-columns: 1fr 1fr;
		gap: 3rem;
		align-items: stretch; /* image fills the full height of the steps column */
	}
}
.process-detail__steps { display: flex; flex-direction: column; gap: 0.875rem; }
.process-detail__step {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 1rem 1.125rem;
}
.process-detail__num {
	flex-shrink: 0;
	width: 40px; height: 40px;
	background: var(--color-cta-blue);
	color: #fff;
	border-radius: 50%;
	display: grid; place-items: center;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.875rem;
}
.process-detail__step-title { font-size: 1rem; margin-bottom: 0.25rem; }
.process-detail__content p { color: var(--color-muted); font-size: 0.9375rem; line-height: 1.55; }
.process-detail__media { height: 100%; }
.process-detail__media img {
	width: 100%;
	height: 100%;
	border-radius: var(--radius-lg);
	object-fit: cover;
	display: block;
}

/* 6. Pricing tables */
.pricing-tables {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	align-items: stretch;
}
@media (min-width: 900px) { .pricing-tables { grid-template-columns: repeat(2, 1fr); gap: 2rem; } }

.pricing-table {
	background: var(--color-cta-blue);
	color: #fff;
	border-radius: 1.75rem;
	padding: 1.25rem 1.75rem;
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
}
.pricing-table__header {
	display: flex; align-items: center; gap: 0.875rem;
	padding: 0;
	background: transparent;
}
.pricing-table__header h3 {
	color: #fff;
	font-size: 1.5rem;
	line-height: 1.2;
	margin: 0;
	font-weight: var(--fw-bold);
}
.pricing-table__icon {
	display: grid; place-items: center;
	width: 44px; height: 44px;
	border-radius: 0;
	background: transparent;
	color: #fff;
	flex-shrink: 0;
}
.pricing-table__icon svg { width: 100%; height: 100%; }

.pricing-table__body {
	background: #fff;
	border-radius: 1.25rem;
	padding: 0.25rem 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.pricing-table table { width: 100%; height: 100%; border-collapse: collapse; }
.pricing-table thead tr { background: transparent; }
.pricing-table th {
	text-align: left;
	padding: 0.75rem 0;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 1.0625rem;
	letter-spacing: 0;
	text-transform: none;
	color: var(--color-navy);
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
.pricing-table tbody tr + tr td { border-top: 1px solid rgba(0, 0, 0, 0.08); }
.pricing-table td {
	padding: 0.65rem 0;
	font-size: 1rem;
	color: var(--color-navy);
}
.pricing-table td:last-child {
	text-align: left;
	font-family: var(--font-display);
	font-weight: var(--fw-regular);
}
.pricing-table__note {
	margin: 0;
	color: rgba(255, 255, 255, 0.92);
	font-size: 0.9375rem;
	font-style: italic;
	line-height: 1.5;
}
.pricing-table__note strong { font-weight: var(--fw-bold); font-style: italic; }
.pricing-note {
	max-width: 920px;
	margin: 1.5rem auto 0;
	color: var(--color-muted);
	font-size: 0.8125rem;
	text-align: center;
}

/* 7. Included carousel (scroll-snap, 3 visible on desktop) */
.included-header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 2rem;
	margin-bottom: 2.5rem;
}
.included-header__copy { max-width: 620px; }
.included-header__copy h2 {
	margin: 0 0 1rem;
	font-size: clamp(1.75rem, 1.25rem + 1.5vw, 2.5rem);
	line-height: 1.15;
	color: var(--color-navy);
}
.included-header__copy .lead { margin: 0; color: var(--color-muted); font-size: 1rem; }
.included-header__nav {
	display: flex;
	gap: 0.875rem;
	flex-shrink: 0;
	padding-bottom: 0.25rem;
}
.included-nav-btn {
	width: 52px; height: 52px;
	border-radius: 50%;
	border: 0;
	display: grid;
	place-items: center;
	cursor: pointer;
	background: #BFD3FF;
	color: #fff;
	transition: background var(--t-fast), transform var(--t-fast), opacity var(--t-fast), box-shadow var(--t-fast);
}
.included-nav-btn:hover:not([disabled]) { transform: translateY(-2px); box-shadow: 0 8px 18px -8px rgba(47, 109, 255, 0.55); }
.included-nav-btn--next { background: var(--color-cta-blue); }
.included-nav-btn[disabled] { opacity: 0.4; cursor: not-allowed; }
@media (max-width: 700px) {
	.included-header { flex-direction: column; align-items: flex-start; }
	.included-header__nav { padding-bottom: 0; }
}

.included-strip {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: min(320px, 85%);
	gap: 1.5rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	padding-bottom: 0.5rem;
	scrollbar-width: none;
	scroll-padding-inline: 0;
}
.included-strip::-webkit-scrollbar { display: none; }
@media (min-width: 700px) {
	.included-strip { grid-auto-columns: calc((100% - 1.5rem) / 2); }
}
@media (min-width: 960px) {
	.included-strip { grid-auto-columns: calc((100% - 3rem) / 3); }
}

.included-card {
	scroll-snap-align: start;
	background: #fff;
	border: 1px solid #E8EAF0;
	border-radius: 1.25rem;
	padding: 1rem 1rem 1.5rem;
	display: flex;
	flex-direction: column;
	transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}
.included-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 16px 40px -22px rgba(0, 25, 126, 0.22);
	border-color: transparent;
}
.included-card__media {
	aspect-ratio: 4/3;
	overflow: hidden;
	border-radius: 0.875rem;
	background: #EEF1F6;
	margin-bottom: 1.25rem;
}
.included-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 400ms ease; }
.included-card:hover .included-card__media img { transform: scale(1.04); }

.included-card__body { padding: 0 0.5rem 0.25rem; display: flex; flex-direction: column; gap: 1rem; flex: 1; }
.included-card__title {
	font-size: 1.25rem;
	font-weight: var(--fw-bold);
	margin: 0;
	color: var(--color-navy);
	line-height: 1.3;
}
.included-card__list {
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--color-muted);
	font-size: 0.9375rem;
	line-height: 1.55;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.included-card__list li {
	position: relative;
	padding-left: 1.75rem;
}
.included-card__list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.15rem;
	width: 1.125rem;
	height: 1.125rem;
	border-radius: 50%;
	background: var(--color-cta-blue);
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
	background-size: 70% 70%;
	background-position: center;
	background-repeat: no-repeat;
	flex-shrink: 0;
}

/* 8. Certifications showcase (navy bg, text + grid) */
.section--certs {
	background: var(--color-navy);
	color: #fff;
}
.section--certs h2 { color: #fff; }
.section--certs p, .section--certs li { color: rgba(255, 255, 255, 0.88); }

.certs-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	align-items: center;
}
@media (min-width: 900px) {
	.certs-layout { grid-template-columns: 1.15fr 1fr; gap: 3rem; }
}
.certs-copy h2 { margin: 0.5rem 0 1rem; }
.certs-bullets {
	display: flex; flex-direction: column; gap: 0.75rem;
	margin-block: 1.25rem;
}
.certs-bullets li {
	position: relative;
	padding-left: 1.75rem;
	line-height: 1.55;
}
.certs-bullets li::before {
	content: "";
	position: absolute;
	left: 0; top: 0.5rem;
	width: 1rem; height: 1rem;
	background: var(--color-yellow);
	border-radius: 50%;
}
.certs-bullets strong { color: #fff; }

.certs-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	background: rgba(255, 255, 255, 0.05);
	padding: 1.25rem;
	border-radius: var(--radius-lg);
	border: 1px solid rgba(255, 255, 255, 0.1);
}
.cert-tile {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: var(--radius-md);
	padding: 1.25rem 1rem;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 0.5rem;
	min-height: 120px;
	text-align: center;
}
.cert-tile__icon {
	width: 48px; height: 48px;
	display: grid; place-items: center;
	border-radius: 50%;
	background: var(--color-yellow);
	color: var(--color-navy);
}
.cert-tile__icon svg { width: 24px; height: 24px; }
.cert-tile__label { font-family: var(--font-display); font-weight: var(--fw-bold); color: #fff; font-size: 0.9375rem; }

/* ==========================================================================
   FAQ page — category rail + panels
   ========================================================================== */
.section--faq-categories { padding-top: clamp(2.5rem, 1.5rem + 2vw, 4rem); }

.faq-cats {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	align-items: start;
}
@media (min-width: 900px) {
	.faq-cats { grid-template-columns: 280px 1fr; gap: 2.5rem; }
}
@media (min-width: 1100px) {
	.faq-cats { grid-template-columns: 320px 1fr; }
}

/* Left rail */
.faq-cats__rail {
	position: sticky;
	top: 1rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding: 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
}
.faq-cats__rail-title {
	font-family: var(--font-display);
	font-size: var(--fs-small);
	color: var(--color-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: var(--fw-bold);
	margin: 0 0 0.5rem 0.5rem;
}
.faq-cats__tab {
	display: flex;
	align-items: center;
	gap: 0.875rem;
	padding: 0.875rem 1rem;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--radius-md);
	text-align: left;
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	font-size: 0.9375rem;
	color: var(--color-heading);
	cursor: pointer;
	transition: background-color var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.faq-cats__tab:hover { background: var(--color-surface-alt); }
.faq-cats__tab.is-active {
	background: var(--color-navy);
	color: #fff;
	border-color: var(--color-navy);
}
.faq-cats__tab-icon {
	display: grid; place-items: center;
	width: 36px; height: 36px;
	border-radius: var(--radius-sm);
	background: rgba(47, 109, 255, 0.10);
	color: var(--color-cta-blue);
	flex-shrink: 0;
}
.faq-cats__tab-icon svg { width: 18px; height: 18px; }
.faq-cats__tab.is-active .faq-cats__tab-icon {
	background: var(--color-yellow);
	color: var(--color-navy);
}
.faq-cats__tab-label { flex: 1; }
.faq-cats__tab-count {
	display: inline-grid; place-items: center;
	min-width: 28px; height: 22px;
	padding: 0 0.5rem;
	border-radius: var(--radius-pill);
	background: rgba(0, 25, 126, 0.08);
	color: var(--color-navy);
	font-size: 0.75rem;
	font-weight: var(--fw-bold);
}
.faq-cats__tab.is-active .faq-cats__tab-count {
	background: rgba(255, 255, 255, 0.15);
	color: #fff;
}

.faq-cats__rail-cta {
	margin-top: 0.75rem;
	padding: 1.125rem;
	background: var(--color-surface-alt);
	border-radius: var(--radius-md);
	text-align: center;
}
.faq-cats__rail-cta-title {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	color: var(--color-heading);
	margin: 0 0 0.25rem;
	font-size: 0.9375rem;
}
.faq-cats__rail-cta-body {
	color: var(--color-muted);
	font-size: 0.8125rem;
	margin: 0 0 0.875rem;
	line-height: 1.5;
}

/* Right panels */
.faq-cats__content { min-width: 0; }
.faq-cats__panel { display: none; }
.faq-cats__panel.is-active { display: block; animation: faqFadeIn 0.2s ease; }
@keyframes faqFadeIn {
	from { opacity: 0; transform: translateY(4px); }
	to   { opacity: 1; transform: translateY(0); }
}
.faq-cats__panel-header {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--color-border);
}
.faq-cats__panel-header .eyebrow { margin-bottom: 0.125rem; }
.faq-cats__panel-header h2 {
	font-size: clamp(1.25rem, 1rem + 0.8vw, 1.625rem);
	margin: 0;
	max-width: none;
}
.faq-cats__panel-icon {
	display: grid; place-items: center;
	width: 56px; height: 56px;
	border-radius: var(--radius-md);
	background: var(--color-navy);
	color: #fff;
	flex-shrink: 0;
}
.faq-cats__panel-icon svg { width: 28px; height: 28px; }

/* ==========================================================================
   Contact page
   ========================================================================== */
.section--contact { padding-top: clamp(2rem, 1.5rem + 1.5vw, 3rem); }

.contact-quick-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin-bottom: 2.5rem;
}
@media (min-width: 640px)  { .contact-quick-cards { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; } }

.contact-quick-card {
	display: block;
	padding: 1.5rem 1.5rem 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	transition: box-shadow var(--t-med), transform var(--t-med), border-color var(--t-fast);
	color: var(--color-heading);
	text-decoration: none;
}
.contact-quick-card:hover {
	box-shadow: var(--shadow-card-hover);
	transform: translateY(-2px);
	border-color: transparent;
	color: var(--color-heading);
}
.contact-quick-card__icon {
	display: grid; place-items: center;
	width: 48px; height: 48px;
	border-radius: var(--radius-md);
	margin-bottom: 1rem;
}
.contact-quick-card__icon svg { width: 24px; height: 24px; }
.contact-quick-card__icon--wa    { background: rgba(21, 183, 70, 0.12);  color: var(--color-whatsapp); }
.contact-quick-card__icon--phone { background: rgba(47, 109, 255, 0.12); color: var(--color-cta-blue); }
.contact-quick-card__icon--mail  { background: rgba(255, 175, 2, 0.15);  color: #b87800; }
.contact-quick-card__label {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	color: var(--color-heading);
	margin: 0 0 0.25rem;
	font-size: 1.0625rem;
}
.contact-quick-card__value {
	color: var(--color-navy);
	font-weight: var(--fw-medium);
	margin: 0 0 0.25rem;
}
.contact-quick-card__hint {
	color: var(--color-muted);
	font-size: 0.8125rem;
	margin: 0;
}

.contact-main {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
}
@media (min-width: 960px) {
	.contact-main { grid-template-columns: 1.3fr 1fr; gap: 2.5rem; }
}

.contact-form-card {
	padding: clamp(1.5rem, 1rem + 1.5vw, 2.5rem);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-card);
}
.contact-form-card__header { margin-bottom: 1.5rem; }
.contact-form-card__header .eyebrow { margin-bottom: 0.25rem; }
.contact-form-card__header h2 {
	font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem);
	margin: 0 0 0.5rem;
}
.contact-form-card__header p { color: var(--color-muted); margin: 0; }

.form-field label span[aria-hidden] { color: var(--color-yellow); margin-left: 0.125rem; }

.form-actions {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
	margin-top: 0.5rem;
}
.form-hint { color: var(--color-muted); font-size: 0.875rem; margin: 0; }

.contact-sidebar {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.contact-sidebar__card {
	padding: 1.75rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
}
.contact-sidebar__card h3 { margin: 0 0 1rem; font-size: 1.25rem; }
.contact-sidebar__card--dark {
	background: var(--color-navy);
	color: #fff;
	border-color: var(--color-navy);
	background-image: radial-gradient(circle at 100% 0%, rgba(47, 109, 255, 0.25), transparent 50%);
}
.contact-sidebar__card--dark h3 { color: #fff; }
.contact-sidebar__card--dark p { color: rgba(255, 255, 255, 0.85); margin: 0 0 1.25rem; }
.contact-sidebar__card--dark .btn { width: 100%; justify-content: center; }

.contact-detail-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1.125rem; }
.contact-detail-list li { display: flex; align-items: flex-start; gap: 0.875rem; }
.contact-detail-list__icon {
	display: grid; place-items: center;
	flex-shrink: 0;
	width: 40px; height: 40px;
	border-radius: var(--radius-sm);
	background: rgba(47, 109, 255, 0.10);
	color: var(--color-cta-blue);
}
.contact-detail-list__icon svg { width: 20px; height: 20px; }
.contact-detail-list__label {
	font-size: var(--fs-small);
	color: var(--color-muted);
	margin: 0 0 0.125rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: var(--fw-bold);
}
.contact-detail-list__value {
	font-family: var(--font-display);
	color: var(--color-heading);
	margin: 0;
	font-weight: var(--fw-medium);
	line-height: 1.4;
}
.contact-detail-list__value a { color: inherit; }
.contact-detail-list__value a:hover { color: var(--color-cta-blue); }
.contact-detail-list__value--muted { color: var(--color-muted); font-weight: var(--fw-regular); font-size: 0.875rem; margin-top: 0.125rem; }

/* Coverage */
.section--coverage { padding-block: clamp(3rem, 2rem + 3vw, 5rem); }
.coverage-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin-top: 0.5rem;
}
@media (min-width: 600px)  { .coverage-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px)  { .coverage-grid { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; } }

.coverage-card {
	padding: 1.5rem 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	transition: box-shadow var(--t-fast), transform var(--t-fast);
}
.coverage-card:hover {
	box-shadow: var(--shadow-card);
	transform: translateY(-2px);
}
.coverage-card__pin {
	display: grid; place-items: center;
	width: 40px; height: 40px;
	border-radius: 50%;
	background: var(--color-yellow);
	color: var(--color-navy);
	margin-bottom: 0.75rem;
}
.coverage-card__pin svg { width: 20px; height: 20px; }
.coverage-card h3 { font-size: 1.125rem; margin: 0 0 0.25rem; }
.coverage-card p  { color: var(--color-muted); font-size: 0.9375rem; margin: 0; line-height: 1.5; }
.coverage-note {
	text-align: center;
	color: var(--color-muted);
	margin-top: 1.75rem;
	font-size: 0.9375rem;
}

/* ==========================================================================
   Blog index — featured + grid + category chips + placeholders
   ========================================================================== */
.blog-cat-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--color-border);
}
.blog-cat-chip {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.5rem 0.875rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-pill);
	color: var(--color-heading);
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	font-size: 0.875rem;
	text-decoration: none;
	transition: background-color var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}
.blog-cat-chip:hover {
	background: var(--color-surface-alt);
	border-color: var(--color-cta-blue);
	color: var(--color-cta-blue);
}
.blog-cat-chip.is-active {
	background: var(--color-navy);
	border-color: var(--color-navy);
	color: #fff;
}
.blog-cat-chip__count {
	display: inline-grid; place-items: center;
	min-width: 22px; height: 18px;
	padding: 0 0.375rem;
	background: rgba(0, 25, 126, 0.08);
	color: var(--color-navy);
	border-radius: var(--radius-pill);
	font-size: 0.6875rem;
	font-weight: var(--fw-bold);
}
.blog-cat-chip.is-active .blog-cat-chip__count {
	background: rgba(255, 255, 255, 0.18);
	color: #fff;
}

/* Featured post hero */
.blog-featured { margin-bottom: 2.5rem; }
.blog-card--featured {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	padding: 0;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: box-shadow var(--t-med), transform var(--t-med);
}
.blog-card--featured:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }
@media (min-width: 800px) {
	.blog-card--featured { grid-template-columns: 1.15fr 1fr; }
}
.blog-card--featured .blog-card__media {
	aspect-ratio: 16/10;
	position: relative;
	display: block;
	overflow: hidden;
}
.blog-card--featured .blog-card__media img { height: 100%; }
.blog-card--featured .blog-card__body {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
	justify-content: center;
}
.blog-card--featured .blog-card__title { font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2.125rem); }
.blog-card--featured .blog-card__excerpt {
	color: var(--color-muted);
	line-height: 1.6;
	margin: 0;
}

/* Grid */
.blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.75rem;
}
@media (min-width: 640px)  { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

/* Updates to .blog-card baseline */
.blog-card__media { position: relative; display: block; aspect-ratio: 16/10; overflow: hidden; background: var(--color-surface-alt); }
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-med); }
.blog-card:hover .blog-card__media img { transform: scale(1.04); }
.blog-card__placeholder {
	position: absolute; inset: 0;
	display: grid; place-items: center;
	background: linear-gradient(135deg, var(--ph-a), var(--ph-b));
	color: rgba(255, 255, 255, 0.85);
}
.blog-card__placeholder::after {
	content: "";
	position: absolute; inset: 0;
	background-image:
		radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.18) 0, transparent 40%),
		radial-gradient(circle at 80% 70%, rgba(255, 255, 255, 0.12) 0, transparent 45%);
	pointer-events: none;
}
.blog-card__placeholder-icon {
	position: relative;
	width: 88px; height: 88px;
	display: grid; place-items: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.3);
}
.blog-card__placeholder-icon svg { width: 42px; height: 42px; color: #fff; }
.blog-card:hover .blog-card__placeholder { filter: brightness(1.08); }

.blog-card__cat-badge {
	position: absolute;
	top: 0.875rem;
	left: 0.875rem;
	padding: 0.3125rem 0.75rem;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(6px);
	color: var(--color-navy);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--radius-pill);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}

.blog-card__body { padding: 1.25rem 1.5rem 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
.blog-card__title { font-size: 1.125rem; line-height: 1.35; margin: 0; }
.blog-card__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	color: var(--color-muted-2);
	font-size: 0.8125rem;
	margin: 0;
	margin-top: auto;
}
.blog-card__dot { color: var(--color-border); }
.blog-card__link {
	margin-left: auto;
	color: var(--color-cta-blue);
	font-weight: var(--fw-bold);
	font-family: var(--font-display);
	font-size: 0.875rem;
	text-decoration: none;
}
.blog-card__link:hover { color: var(--color-navy); }

/* ==========================================================================
   Our Services — rich service index cards + why strip + numbered process
   ========================================================================== */
.page-banner__lead {
	color: rgba(255, 255, 255, 0.9);
	font-size: clamp(1rem, 0.95rem + 0.2vw, 1.125rem);
	max-width: 55ch;
	margin: 1rem auto 0;
}

.service-index-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.75rem;
}
@media (min-width: 760px)  { .service-index-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem; } }

.service-index-card {
	display: flex;
	flex-direction: column;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: box-shadow var(--t-med), transform var(--t-med);
}
.service-index-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-3px); }
.service-index-card__media {
	position: relative;
	display: block;
	overflow: hidden;
	aspect-ratio: 16/10;
	background: var(--color-surface-alt);
}
.service-index-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-med); }
.service-index-card:hover .service-index-card__media img { transform: scale(1.04); }
.service-index-card__tag {
	position: absolute;
	top: 0.875rem;
	left: 0.875rem;
	padding: 0.3125rem 0.75rem;
	background: rgba(255, 255, 255, 0.95);
	color: var(--color-navy);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--radius-pill);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}
.service-index-card__price {
	position: absolute;
	top: 0.875rem;
	right: 0.875rem;
	padding: 0.5rem 0.875rem;
	background: var(--color-yellow);
	color: var(--color-navy);
	border-radius: var(--radius-pill);
	font-family: var(--font-display);
	display: flex;
	align-items: baseline;
	gap: 0.375rem;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}
.service-index-card__price-label { font-size: 0.6875rem; font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: 0.05em; }
.service-index-card__price strong { font-size: 1.0625rem; font-weight: var(--fw-bold); }

.service-index-card__body {
	padding: 1.5rem 1.75rem 1.75rem;
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
	flex: 1;
}
.service-index-card__title { font-size: 1.375rem; margin: 0; line-height: 1.25; }
.service-index-card__title a { color: var(--color-heading); }
.service-index-card__title a:hover { color: var(--color-cta-blue); }
.service-index-card__headline {
	margin: 0;
	color: var(--color-cta-blue);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.9375rem;
}
.service-index-card__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.service-index-card__list li {
	position: relative;
	padding-left: 1.5rem;
	color: var(--color-body);
	font-size: 0.9375rem;
	line-height: 1.5;
}
.service-index-card__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.45rem;
	width: 0.625rem;
	height: 0.325rem;
	border-left: 2px solid var(--color-whatsapp);
	border-bottom: 2px solid var(--color-whatsapp);
	transform: rotate(-45deg);
}
.service-index-card__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	margin-top: auto;
	padding-top: 0.5rem;
}

/* Why strip — 4-col benefits */
.why-strip {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 640px)  { .why-strip { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .why-strip { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; } }
.why-strip__item {
	padding: 1.75rem 1.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	text-align: center;
}
.why-strip__icon {
	display: grid; place-items: center;
	width: 56px; height: 56px;
	border-radius: 50%;
	background: var(--color-navy);
	color: var(--color-yellow);
	margin: 0 auto 1rem;
}
.why-strip__icon svg { width: 28px; height: 28px; }
.why-strip__item h3 { font-size: 1.0625rem; margin: 0 0 0.5rem; }
.why-strip__item p  { color: var(--color-muted); font-size: 0.9375rem; margin: 0; line-height: 1.55; }

/* Numbered process */
.process-grid--numbered {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 720px) { .process-grid--numbered { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }
.process-step--numbered {
	position: relative;
	padding: 2rem 1.5rem 1.75rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	text-align: center;
}
.process-step__num {
	position: absolute;
	top: -1rem;
	left: 50%;
	transform: translateX(-50%);
	display: grid; place-items: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.75rem;
	background: var(--color-cta-blue);
	color: #fff;
	border-radius: var(--radius-pill);
	font-family: var(--font-display);
	font-weight: var(--fw-heavy);
	font-size: 0.9375rem;
	box-shadow: 0 4px 12px rgba(47, 109, 255, 0.28);
}
.process-step--numbered .process-step__icon {
	width: 72px; height: 72px;
	display: grid; place-items: center;
	margin: 0.5rem auto 1rem;
}
.process-step--numbered .process-step__icon img { width: 100%; height: 100%; object-fit: contain; }
.process-step--numbered .process-step__title { font-size: 1.0625rem; margin: 0 0 0.5rem; }
.process-step--numbered p { color: var(--color-muted); margin: 0; font-size: 0.9375rem; line-height: 1.55; }

/* Ghost button — dark variant */
.btn--ghost-on-dark {
	background: transparent;
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.4);
}
.btn--ghost-on-dark:hover,
.btn--ghost-on-dark:focus-visible {
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
}

/* FAQ rail: mobile layout — stack rail as horizontal chips */
@media (max-width: 899px) {
	.faq-cats__rail {
		position: static;
		flex-direction: row;
		flex-wrap: wrap;
		gap: 0.5rem;
		padding: 1rem;
	}
	.faq-cats__rail-title { width: 100%; margin: 0; }
	.faq-cats__tab {
		flex: 1 0 calc(50% - 0.25rem);
		padding: 0.625rem 0.75rem;
		gap: 0.5rem;
	}
	.faq-cats__tab-icon { width: 30px; height: 30px; }
	.faq-cats__tab-icon svg { width: 16px; height: 16px; }
	.faq-cats__rail-cta { width: 100%; }
}

/* ==========================================================================
   Inline SVG process icons (replace numbered PNGs)
   ========================================================================== */
.process-step__icon--svg {
	display: grid; place-items: center;
	width: 72px; height: 72px;
	margin: 0 auto 1rem;
	border-radius: var(--radius-lg);
	background: rgba(47, 109, 255, 0.10);
	color: var(--color-cta-blue);
}
.process-step__icon--svg svg { width: 32px; height: 32px; }

.process-step--numbered .process-step__icon--svg {
	width: 80px; height: 80px;
}
.process-step--numbered .process-step__icon--svg svg { width: 36px; height: 36px; }

/* ==========================================================================
   CTA Banner v2 — decorative navy block with image + stat card
   ========================================================================== */
.section--cta-banner {
	padding-block: clamp(2.5rem, 2rem + 2vw, 4rem);
}

.cta-banner-v2 {
	position: relative;
	overflow: hidden;
	padding: clamp(2rem, 1.5rem + 3vw, 4rem) clamp(1.5rem, 1rem + 2vw, 3.5rem);
	border-radius: clamp(1.25rem, 1rem + 1vw, 2rem);
	background:
		radial-gradient(circle at 100% 0%, rgba(47, 109, 255, 0.35), transparent 55%),
		radial-gradient(circle at 0% 100%, rgba(255, 175, 2, 0.18), transparent 55%),
		linear-gradient(135deg, #000F4D 0%, var(--color-navy) 50%, #0A2A9E 100%);
	color: #fff;
	isolation: isolate;
	box-shadow:
		0 24px 48px -16px rgba(0, 25, 126, 0.45),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

/* Decorative blurred circles */
.cta-banner-v2__shape {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	z-index: -1;
	filter: blur(40px);
	opacity: 0.55;
}
.cta-banner-v2__shape--tl {
	top: -120px; left: -60px;
	width: 280px; height: 280px;
	background: var(--color-cta-blue);
	opacity: 0.35;
}
.cta-banner-v2__shape--br {
	bottom: -140px; right: -80px;
	width: 340px; height: 340px;
	background: var(--color-yellow);
	opacity: 0.20;
}

/* Dotted pattern overlay */
.cta-banner-v2__pattern {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: -1;
	opacity: 0.35;
	background-image: radial-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px);
	background-size: 22px 22px;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 30%, rgba(0, 0, 0, 0.6) 70%, rgba(0, 0, 0, 0) 100%);
	-webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 30%, rgba(0, 0, 0, 0.6) 70%, rgba(0, 0, 0, 0) 100%);
}

/* Grid */
.cta-banner-v2__grid {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 900px) {
	.cta-banner-v2__grid { grid-template-columns: 1.15fr 1fr; gap: clamp(2rem, 1rem + 3vw, 4rem); }
}

/* Copy column */
.cta-banner-v2__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.4375rem 0.875rem;
	border-radius: var(--radius-pill);
	background: rgba(255, 255, 255, 0.10);
	border: 1px solid rgba(255, 255, 255, 0.15);
	color: rgba(255, 255, 255, 0.9);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 1.25rem;
	backdrop-filter: blur(6px);
}
.cta-banner-v2__eyebrow-dot {
	display: inline-block;
	width: 0.5rem; height: 0.5rem;
	background: var(--color-yellow);
	border-radius: 50%;
	box-shadow: 0 0 0 3px rgba(255, 175, 2, 0.25);
	animation: ctaDotPulse 2s ease-in-out infinite;
}
@keyframes ctaDotPulse {
	0%, 100% { box-shadow: 0 0 0 3px rgba(255, 175, 2, 0.25); }
	50%      { box-shadow: 0 0 0 7px rgba(255, 175, 2, 0.10); }
}

.cta-banner-v2__title {
	color: #fff;
	font-size: clamp(1.75rem, 1.3rem + 2.2vw, 3rem);
	line-height: 1.1;
	margin: 0 0 1rem;
	letter-spacing: -0.01em;
}
.cta-banner-v2__title-accent {
	position: relative;
	color: var(--color-yellow);
	white-space: nowrap;
}
.cta-banner-v2__title-accent::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0.05em;
	height: 0.28em;
	background: rgba(255, 175, 2, 0.25);
	border-radius: 999px;
	z-index: -1;
}

.cta-banner-v2__body {
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(1rem, 0.95rem + 0.2vw, 1.125rem);
	line-height: 1.6;
	margin: 0 0 1.75rem;
	max-width: 48ch;
}

.cta-banner-v2__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.875rem;
	margin-bottom: 1.75rem;
}
.cta-banner-v2__actions .btn { display: inline-flex; align-items: center; gap: 0.5rem; }
.btn--lg { padding: 0.9375rem 1.625rem; font-size: 1rem; }

.cta-banner-v2__trust {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.625rem 1rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.cta-banner-v2__stars {
	display: inline-flex;
	align-items: center;
	gap: 0.125rem;
	color: var(--color-yellow);
}
.cta-banner-v2__trust-text {
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.875rem;
	font-family: var(--font-display);
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
}
.cta-banner-v2__trust-text strong { color: #fff; font-weight: var(--fw-bold); }
.cta-banner-v2__trust-sep {
	display: inline-block;
	width: 1px; height: 16px;
	background: rgba(255, 255, 255, 0.18);
}
.cta-banner-v2__tick {
	display: inline-grid; place-items: center;
	width: 18px; height: 18px;
	border-radius: 50%;
	background: var(--color-whatsapp);
	color: #fff;
	flex-shrink: 0;
}

/* Media column */
.cta-banner-v2__media {
	position: relative;
	display: block;
	min-height: 260px;
}

.cta-banner-v2__media-halo {
	position: absolute;
	inset: -12%;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 175, 2, 0.20) 0%, transparent 60%);
	filter: blur(24px);
	pointer-events: none;
}

.cta-banner-v2__media-frame {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	transform: rotate(-1.5deg);
	box-shadow:
		0 28px 48px -12px rgba(0, 0, 0, 0.55),
		0 0 0 1px rgba(255, 255, 255, 0.10),
		inset 0 0 0 6px rgba(255, 255, 255, 0.06);
	aspect-ratio: 4/3;
	max-width: 520px;
	margin-inline: auto;
	transition: transform var(--t-med);
}
.cta-banner-v2__media-frame:hover { transform: rotate(-1.5deg) scale(1.01); }
.cta-banner-v2__media-frame img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}

/* Satisfaction badge */
.cta-banner-v2__badge {
	position: absolute;
	top: -12px;
	right: 8%;
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.5rem 0.875rem;
	background: var(--color-yellow);
	color: var(--color-navy);
	font-family: var(--font-display);
	font-weight: var(--fw-heavy);
	font-size: 0.8125rem;
	border-radius: var(--radius-pill);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
	transform: rotate(3deg);
	z-index: 2;
}

/* Stat bubble */
.cta-banner-v2__stat {
	position: absolute;
	bottom: -14px;
	left: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	padding: 0.625rem 0.875rem 0.625rem 0.625rem;
	background: #fff;
	border-radius: var(--radius-pill);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.20);
	z-index: 2;
}
.cta-banner-v2__stat-icon {
	display: grid; place-items: center;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--color-whatsapp);
	color: #fff;
	flex-shrink: 0;
}
.cta-banner-v2__stat-text { display: flex; flex-direction: column; line-height: 1.1; }
.cta-banner-v2__stat-label { font-size: 0.6875rem; color: var(--color-muted); letter-spacing: 0.04em; text-transform: uppercase; font-weight: var(--fw-bold); }
.cta-banner-v2__stat-value { font-family: var(--font-display); color: var(--color-navy); font-size: 0.9375rem; font-weight: var(--fw-heavy); margin-top: 0.1875rem; }

/* Small-screen: hide stat bubble on tiny mobiles */
@media (max-width: 419px) {
	.cta-banner-v2__stat { display: none; }
}

/* Hide old .cta-banner v1 styling if still referenced (no-op if unused) */

/* ==========================================================================
   Home page — modernized hero, stats strip, health grid, service card
   ========================================================================== */

/* Hero additions */
.home-hero__pill {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.4375rem 0.875rem;
	border-radius: var(--radius-pill);
	background: rgba(255, 255, 255, 0.10);
	border: 1px solid rgba(255, 255, 255, 0.18);
	color: #fff;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 1.25rem;
	backdrop-filter: blur(6px);
}
.home-hero__pill-dot {
	display: inline-block;
	width: 0.5rem; height: 0.5rem;
	background: var(--color-whatsapp);
	border-radius: 50%;
	box-shadow: 0 0 0 3px rgba(21, 183, 70, 0.30);
	animation: heroPillPulse 2s ease-in-out infinite;
}
@keyframes heroPillPulse {
	0%, 100% { box-shadow: 0 0 0 3px rgba(21, 183, 70, 0.30); }
	50%      { box-shadow: 0 0 0 7px rgba(21, 183, 70, 0.10); }
}

.home-hero__rating {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem 0.75rem;
	margin-top: 1.75rem;
	color: rgba(255, 255, 255, 0.85);
	font-family: var(--font-display);
	font-size: 0.875rem;
}
.home-hero__rating-stars {
	display: inline-flex;
	align-items: center;
	gap: 0.125rem;
	color: var(--color-yellow);
}
.home-hero__rating strong { color: #fff; font-weight: var(--fw-bold); }

/* Hero media floating badge + card */
.home-hero__media { position: relative; }
.home-hero__media-badge {
	position: absolute;
	top: 8%;
	left: -4%;
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	padding: 0.5rem 0.875rem;
	background: var(--color-yellow);
	color: var(--color-navy);
	font-family: var(--font-display);
	font-weight: var(--fw-heavy);
	font-size: 0.8125rem;
	border-radius: var(--radius-pill);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.28);
	transform: rotate(-4deg);
	z-index: 2;
}
.home-hero__media-card {
	position: absolute;
	bottom: 6%;
	right: -4%;
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	padding: 0.625rem 0.875rem 0.625rem 0.625rem;
	background: #fff;
	border-radius: var(--radius-pill);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.20);
	z-index: 2;
}
.home-hero__media-card-icon {
	display: grid; place-items: center;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--color-whatsapp);
	color: #fff;
	flex-shrink: 0;
}
.home-hero__media-card > span:not(.home-hero__media-card-icon) {
	display: flex; flex-direction: column; line-height: 1.1;
}
.home-hero__media-card strong {
	font-family: var(--font-display);
	color: var(--color-navy);
	font-size: 0.9375rem;
	font-weight: var(--fw-heavy);
}
.home-hero__media-card-label {
	font-size: 0.6875rem;
	color: var(--color-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-weight: var(--fw-bold);
	margin-top: 0.1875rem;
}

@media (max-width: 900px) {
	.home-hero__media-badge { top: 2%; left: 2%; }
	.home-hero__media-card  { bottom: 2%; right: 2%; }
}

/* Stats strip */
.section--stats { padding-block: clamp(1.5rem, 1rem + 1vw, 2.25rem); }
.stats-strip {
	list-style: none;
	padding: 1.25rem 1.5rem;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem 1.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-card);
}
@media (min-width: 720px) { .stats-strip { grid-template-columns: repeat(4, 1fr); padding: 1.75rem 2rem; } }
.stats-strip li {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.25rem;
	position: relative;
}
@media (min-width: 720px) {
	.stats-strip li + li::before {
		content: "";
		position: absolute;
		left: calc(-0.75rem);
		top: 50%;
		transform: translateY(-50%);
		width: 1px;
		height: 36px;
		background: var(--color-border);
	}
}
.stats-strip strong {
	font-family: var(--font-display);
	font-size: clamp(1.375rem, 1.1rem + 1vw, 2rem);
	font-weight: var(--fw-heavy);
	color: var(--color-navy);
	line-height: 1;
}
.stats-strip span {
	color: var(--color-muted);
	font-size: 0.8125rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: var(--fw-bold);
}

/* About check list */
.about-checks {
	list-style: none;
	padding: 0;
	margin: 1.25rem 0 1.5rem;
	display: grid;
	gap: 0.625rem;
}
.about-checks li {
	display: flex;
	align-items: flex-start;
	gap: 0.625rem;
	color: var(--color-body);
	font-size: 0.9375rem;
}
.about-checks__icon {
	display: grid; place-items: center;
	width: 22px; height: 22px;
	border-radius: 50%;
	background: rgba(21, 183, 70, 0.12);
	color: var(--color-whatsapp);
	flex-shrink: 0;
	margin-top: 0.1rem;
}

/* Service cards on home — add tag + price chip overlays */
.service-card--home { position: relative; }
.service-card--home .service-card__media { position: relative; aspect-ratio: 4/3; display: block; overflow: hidden; }
.service-card--home .service-card__tag {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	padding: 0.3125rem 0.75rem;
	background: rgba(255, 255, 255, 0.95);
	color: var(--color-navy);
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: 0.6875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-radius: var(--radius-pill);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
	z-index: 2;
}
.service-card--home .service-card__price {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	padding: 0.4375rem 0.75rem;
	background: var(--color-yellow);
	color: var(--color-navy);
	border-radius: var(--radius-pill);
	font-family: var(--font-display);
	display: inline-flex;
	align-items: baseline;
	gap: 0.3125rem;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
	z-index: 2;
}
.service-card--home .service-card__price span { font-size: 0.625rem; font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: 0.06em; }
.service-card--home .service-card__price strong { font-size: 1rem; font-weight: var(--fw-heavy); }

/* Health grid */
.health-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 640px)  { .health-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .health-grid { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; } }

.health-card {
	padding: 2rem 1.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	transition: box-shadow var(--t-med), transform var(--t-med);
	position: relative;
	overflow: hidden;
}
.health-card::before {
	content: "";
	position: absolute;
	top: -20px; right: -20px;
	width: 90px; height: 90px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(47, 109, 255, 0.08), transparent 70%);
	pointer-events: none;
}
.health-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-3px); }
.health-card__icon {
	display: grid; place-items: center;
	width: 56px; height: 56px;
	border-radius: var(--radius-md);
	background: linear-gradient(135deg, rgba(47, 109, 255, 0.12), rgba(0, 25, 126, 0.08));
	color: var(--color-cta-blue);
	margin-bottom: 1.25rem;
}
.health-card__icon svg { width: 28px; height: 28px; }
.health-card h3 {
	font-size: 1.0625rem;
	margin: 0 0 0.5rem;
	line-height: 1.3;
}
.health-card p { color: var(--color-muted); font-size: 0.9375rem; margin: 0; line-height: 1.55; }

/* Review summary inline (on testimonials section header) */
.review-summary-inline {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem 0.625rem;
	margin-top: 0.75rem;
	padding: 0.5rem 1rem;
	border-radius: var(--radius-pill);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	font-family: var(--font-display);
	font-size: 0.9375rem;
}
.review-summary-inline__stars {
	display: inline-flex;
	align-items: center;
	gap: 0.125rem;
	color: var(--color-yellow);
}
.review-summary-inline strong {
	color: var(--color-navy);
	font-weight: var(--fw-heavy);
}
.review-summary-inline span { color: var(--color-muted); }

/* Stretched-link card pattern — whole service card becomes clickable */
.service-card--stretched { position: relative; cursor: pointer; }
.service-card--stretched .service-card__stretched-link {
	color: var(--color-heading);
	text-decoration: none;
}
.service-card--stretched .service-card__stretched-link::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	border-radius: inherit;
}
.service-card--stretched .service-card__stretched-link:hover,
.service-card--stretched:hover .service-card__stretched-link { color: var(--color-cta-blue); }
.service-card--stretched .service-card__cta { align-self: flex-start; pointer-events: none; }
.service-card--stretched:hover .service-card__cta { color: var(--color-navy); }
/* The image scale-on-hover still works via .service-card:hover in existing CSS */

/* Form submit notices (contact + newsletter) */
.form-notice {
	padding: 0.875rem 1.125rem;
	border-radius: var(--radius-md);
	font-size: 0.9375rem;
	line-height: 1.5;
	margin-bottom: 1.5rem;
	border: 1px solid;
}
.form-notice--ok  { background: rgba(21, 183, 70, 0.08);  border-color: rgba(21, 183, 70, 0.30);  color: #0b6b29; }
.form-notice--err { background: rgba(255, 107, 107, 0.08); border-color: rgba(255, 107, 107, 0.30); color: #b33636; }
.form-notice strong { font-weight: var(--fw-bold); }

.newsletter__notice {
	margin: 0.75rem 0 0;
	padding: 0.5rem 0.75rem;
	border-radius: var(--radius-pill);
	display: inline-block;
	font-size: 0.8125rem;
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	background: rgba(0, 0, 0, 0.08);
	color: var(--color-heading);
}
.newsletter__notice--err { background: rgba(255, 255, 255, 0.5); color: #b33636; }

/* Hide the floating reCAPTCHA v3 badge. Per Google's ToS, the inline notice
   under the form submit (.recaptcha-notice) replaces it. */
.grecaptcha-badge { visibility: hidden !important; }
.recaptcha-notice {
	margin: 0.5rem 0 0;
	font-size: 0.75rem;
	color: var(--color-muted, #6b7280);
	line-height: 1.4;
}
.recaptcha-notice a { color: inherit; text-decoration: underline; }
