/* =========================================================================
   RedOne Impermeabilizaciones — main stylesheet
   Mobile-first. No external CSS framework. BEM-ish class names.
   ========================================================================= */

/* ---------- Design tokens --------------------------------------------- */
:root {
	--color-primary: #E63946;
	--color-primary-dark: #C42836;
	--color-secondary: #1D3557;
	--color-secondary-dark: #142844;
	--color-accent: #457B9D;
	--color-bg: #FFFFFF;
	--color-bg-alt: #F1FAEE;
	--color-bg-soft: #F7F8FA;
	--color-text: #1D1D1D;
	--color-text-muted: #5A5A5A;
	--color-border: #E5E5E5;
	--color-success: #2A9D8F;
	--color-error: #E63946;
	--color-whatsapp: #25D366;
	--color-whatsapp-dark: #1DA851;

	--font-heading: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

	--radius-sm: 6px;
	--radius-md: 10px;
	--radius-lg: 16px;

	--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .08);
	--shadow-md: 0 4px 12px rgba(15, 23, 42, .08), 0 2px 4px rgba(15, 23, 42, .04);
	--shadow-lg: 0 10px 30px rgba(15, 23, 42, .12), 0 4px 8px rgba(15, 23, 42, .06);

	--container: 1200px;
	--container-narrow: 880px;

	--space-1: .25rem;
	--space-2: .5rem;
	--space-3: .75rem;
	--space-4: 1rem;
	--space-5: 1.25rem;
	--space-6: 1.5rem;
	--space-8: 2rem;
	--space-10: 2.5rem;
	--space-12: 3rem;
	--space-16: 4rem;
	--space-20: 5rem;

	--header-h: 72px;
	--transition: 200ms cubic-bezier(.2, .8, .2, 1);
}

/* ---------- Reset ----------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	* { animation-duration: 0s !important; transition-duration: 0s !important; }
}
body {
	margin: 0;
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.6;
	color: var(--color-text);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
/* Always honour the [hidden] HTML attribute — display rules on classes
   (e.g. .redone-cookie-modal { display: flex }) would otherwise override
   the default `display: none` and let invisible overlays trap clicks. */
[hidden] { display: none !important; }
img, svg, video { max-width: 100%; height: auto; display: block; }
img { font-style: italic; background-color: var(--color-bg-soft); }
a { color: var(--color-secondary); text-decoration: none; transition: color var(--transition); }
a:hover, a:focus-visible { color: var(--color-primary); }
button { font: inherit; cursor: pointer; }
ul, ol { padding: 0; margin: 0; list-style: none; }
:focus-visible {
	outline: 3px solid var(--color-accent);
	outline-offset: 2px;
	border-radius: var(--radius-sm);
}

/* ---------- Typography ------------------------------------------------ */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 var(--space-4);
	color: var(--color-secondary);
	letter-spacing: -0.01em;
}
h1 { font-size: clamp(2rem, 5vw, 3.25rem); }
h2 { font-size: clamp(1.625rem, 3.6vw, 2.5rem); }
h3 { font-size: clamp(1.25rem, 2.4vw, 1.625rem); }
h4 { font-size: 1.125rem; }
p  { margin: 0 0 1em; }
strong { font-weight: 600; }

/* ---------- Utility helpers ------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--space-5);
}
.container--narrow { max-width: var(--container-narrow); }
.visually-hidden, .skip-link {
	position: absolute;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap; border: 0;
}
.skip-link:focus {
	position: fixed; top: 8px; left: 8px;
	width: auto; height: auto; clip: auto;
	padding: 10px 16px;
	background: var(--color-secondary); color: #fff;
	border-radius: var(--radius-md);
	z-index: 10000;
}
.icon { flex-shrink: 0; vertical-align: middle; }

/* ---------- Buttons --------------------------------------------------- */
.btn {
	--btn-bg: var(--color-primary);
	--btn-color: #fff;
	--btn-border: transparent;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: 12px 24px;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 1rem;
	line-height: 1.2;
	text-align: center;
	border: 2px solid var(--btn-border);
	border-radius: var(--radius-md);
	background: var(--btn-bg);
	color: var(--btn-color);
	cursor: pointer;
	transition: transform var(--transition), background-color var(--transition), box-shadow var(--transition), color var(--transition), border-color var(--transition);
	box-shadow: var(--shadow-sm);
	white-space: nowrap;
}
.btn:hover, .btn:focus-visible { color: var(--btn-color); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--lg { padding: 14px 28px; font-size: 1.0625rem; }
.btn--block { width: 100%; }

.btn--primary { --btn-bg: var(--color-primary); --btn-color: #fff; }
.btn--primary:hover { --btn-bg: var(--color-primary-dark); }

.btn--secondary { --btn-bg: #fff; --btn-color: var(--color-secondary); --btn-border: var(--color-secondary); }
.btn--secondary:hover { --btn-bg: var(--color-secondary); --btn-color: #fff; }

.btn--ghost { --btn-bg: transparent; --btn-color: var(--color-secondary); --btn-border: var(--color-secondary); }
.btn--ghost:hover { --btn-bg: var(--color-secondary); --btn-color: #fff; }

.btn--ghost-white { --btn-bg: rgba(255,255,255,.06); --btn-color: #fff; --btn-border: rgba(255,255,255,.85); backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px); }
.btn--ghost-white:hover { --btn-bg: #fff; --btn-color: var(--color-secondary); --btn-border: #fff; }

.btn--white { --btn-bg: #fff; --btn-color: var(--color-secondary); }
.btn--white:hover { --btn-bg: var(--color-bg-alt); }

.btn--whatsapp { --btn-bg: var(--color-whatsapp); --btn-color: #fff; }
.btn--whatsapp:hover { --btn-bg: var(--color-whatsapp-dark); }

/* ---------- Header / Nav --------------------------------------------- */
.site-header {
	position: sticky;
	top: 0; z-index: 100;
	background: #fff;
	border-bottom: 1px solid var(--color-border);
	min-height: var(--header-h);
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	min-height: var(--header-h);
}
.site-brand {
	display: inline-flex;
	align-items: center;
	line-height: 1;
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-secondary);
}
.site-brand__logo,
.site-brand .custom-logo {
	display: block;
	height: 56px;
	width: auto;
	max-width: 200px;
	object-fit: contain;
}
@media (min-width: 720px) {
	.site-brand__logo,
	.site-brand .custom-logo { height: 64px; }
}
/* Legacy text-brand fallback (kept in case someone removes the logo file). */
.site-brand__mark { font-size: 1.5rem; letter-spacing: -0.02em; }
.site-brand__accent { color: var(--color-primary); }
.site-brand__sub { font-size: .75rem; font-weight: 500; color: var(--color-text-muted); margin-top: 2px; letter-spacing: .04em; text-transform: uppercase; }

.site-nav { position: relative; }
.site-nav__toggle {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: var(--color-secondary);
}
.site-nav__toggle .icon-x { display: none; }
.site-nav__toggle[aria-expanded="true"] .icon-menu { display: none; }
.site-nav__toggle[aria-expanded="true"] .icon-x { display: block; }
.site-nav__menu {
	display: none;
	position: absolute;
	top: calc(100% + 12px);
	right: -8px;
	min-width: 240px;
	padding: var(--space-3);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	flex-direction: column;
	gap: 0;
}
.site-nav__menu a {
	display: block;
	padding: var(--space-3) var(--space-4);
	border-radius: var(--radius-sm);
	font-weight: 500;
	color: var(--color-secondary);
}
.site-nav__menu a:hover { background: var(--color-bg-alt); color: var(--color-primary); }
.site-nav__toggle[aria-expanded="true"] + .site-nav__menu { display: flex; }

.header-phone {
	display: none;
	align-items: center;
	gap: var(--space-2);
	padding: 10px 18px;
	border-radius: var(--radius-md);
	background: var(--color-primary);
	color: #fff !important;
	font-weight: 600;
	font-family: var(--font-heading);
	transition: background-color var(--transition), transform var(--transition);
}
.header-phone:hover { background: var(--color-primary-dark); transform: translateY(-1px); }

@media (min-width: 900px) {
	.site-nav__toggle { display: none; }
	.site-nav__menu {
		display: flex;
		position: static;
		flex-direction: row;
		min-width: 0;
		padding: 0;
		background: transparent;
		border: none;
		box-shadow: none;
		gap: var(--space-2);
	}
	.site-nav__menu a { padding: var(--space-2) var(--space-3); }
	.header-phone { display: inline-flex; }
}

/* ---------- Section base --------------------------------------------- */
.site-main { display: block; }
.section { padding: clamp(48px, 8vw, 96px) 0; }
.section--alt { background: var(--color-bg-alt); }
.section__header {
	max-width: 760px;
	margin: 0 auto var(--space-12);
	text-align: center;
}
.section__title { margin-bottom: var(--space-4); }
.section__lead {
	font-size: 1.125rem;
	color: var(--color-text-muted);
	margin: 0;
}

/* ---------- Hero ----------------------------------------------------- */
.hero {
	position: relative;
	overflow: hidden;
	color: #fff;
	min-height: 580px;
	display: flex;
	align-items: center;
	padding: clamp(72px, 10vw, 140px) 0;
	background: #1D3557;
}
.hero__media {
	position: absolute; inset: 0;
	background-image: url('../images/hero.jpg');
	background-size: cover;
	background-position: center 30%;
	z-index: 0;
	transform: scale(1.02);
}
.hero__overlay {
	position: absolute; inset: 0;
	background:
		linear-gradient(110deg, rgba(20, 40, 68, .92) 0%, rgba(29, 53, 87, .72) 45%, rgba(29, 53, 87, .35) 100%),
		linear-gradient(180deg, rgba(0, 0, 0, .15) 0%, rgba(0, 0, 0, .35) 100%);
	z-index: 1;
}
.hero__inner { position: relative; z-index: 2; max-width: 820px; }
.hero__title {
	color: #fff;
	font-size: clamp(2rem, 5vw, 3.5rem);
	margin-bottom: var(--space-5);
}
.hero__accent { color: #FFD166; }
.hero__subtitle {
	font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
	color: rgba(255, 255, 255, .92);
	max-width: 640px;
	margin-bottom: var(--space-8);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* ---------- Trust bar ------------------------------------------------- */
.trust-bar {
	background: var(--color-secondary);
	color: #fff;
	padding: var(--space-6) 0;
}
.trust-bar__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
.trust-bar__item {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	font-weight: 500;
}
.trust-bar__icon {
	display: inline-flex;
	width: 44px; height: 44px;
	align-items: center; justify-content: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, .12);
	color: #FFD166;
	flex-shrink: 0;
}
@media (min-width: 720px) {
	.trust-bar__list { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.trust-bar__list { grid-template-columns: repeat(4, 1fr); }
}

/* ---------- Services ------------------------------------------------- */
.services__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}
@media (min-width: 720px) {
	.services__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.services__grid { grid-template-columns: repeat(3, 1fr); }
}
.service-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.service-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--color-accent);
}
.service-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--color-secondary);
}
.service-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(.2, .8, .2, 1);
}
.service-card:hover .service-card__media img { transform: scale(1.06); }
.service-card__media::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(29,53,87,.45) 100%);
	pointer-events: none;
}
.service-card__body { padding: 36px var(--space-6) var(--space-6); display: flex; flex-direction: column; flex: 1; }
.service-card__icon {
	position: absolute;
	bottom: -22px; left: var(--space-6);
	display: inline-flex;
	width: 52px; height: 52px;
	align-items: center; justify-content: center;
	border-radius: var(--radius-md);
	background: var(--color-primary);
	color: #fff;
	box-shadow: var(--shadow-md);
	z-index: 2;
}
.service-card__icon--standalone {
	position: static;
	margin: var(--space-6) 0 0 var(--space-6);
	width: 64px; height: 64px;
}
.service-card__title { margin-bottom: var(--space-2); }
.service-card__subtitle {
	color: var(--color-accent);
	font-weight: 600;
	margin: 0 0 var(--space-4);
}
.service-card__description {
	color: var(--color-text-muted);
	margin-bottom: var(--space-5);
}
.service-card__apps-title {
	font-size: .8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--color-secondary);
	margin: 0 0 var(--space-3);
}
.service-card__apps {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	margin-bottom: var(--space-6);
}
.service-card__apps li {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: .9375rem;
}
.service-card__apps .icon { color: var(--color-success); }
.service-card__cta {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-weight: 600;
	color: var(--color-primary);
}
.service-card__cta:hover { color: var(--color-primary-dark); gap: var(--space-3); }

/* ---------- Why us --------------------------------------------------- */
.why-us__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}
@media (min-width: 720px) { .why-us__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .why-us__grid { grid-template-columns: repeat(3, 1fr); } }
.why-card {
	background: #fff;
	padding: var(--space-6);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	transition: transform var(--transition), box-shadow var(--transition);
}
.why-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.why-card__icon {
	display: inline-flex;
	width: 52px; height: 52px;
	align-items: center; justify-content: center;
	border-radius: var(--radius-md);
	background: var(--color-primary);
	color: #fff;
	margin-bottom: var(--space-4);
}
.why-card__title { font-size: 1.1875rem; margin-bottom: var(--space-2); }
.why-card__description { color: var(--color-text-muted); margin: 0; font-size: .9375rem; }

/* ---------- Owner / About ------------------------------------------- */
.owner {
	background:
		radial-gradient(circle at 100% 0%, rgba(230, 57, 70, .06) 0%, transparent 40%),
		linear-gradient(180deg, #fff 0%, var(--color-bg-alt) 100%);
}
.owner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items: center;
}
@media (min-width: 900px) {
	.owner__grid { grid-template-columns: 5fr 7fr; gap: var(--space-12); }
}
.owner__media {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-4);
	max-width: 320px;
	margin-inline: auto;
	width: 100%;
}
.owner__photo-wrap {
	position: relative;
	width: 100%;
	max-width: 280px;
	padding: 8px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 14px;
	box-shadow:
		0 18px 40px -12px rgba(15, 23, 42, .22),
		0 6px 14px -6px rgba(15, 23, 42, .12);
	transition: transform var(--transition), box-shadow var(--transition);
	overflow: hidden;
}
.owner__photo-wrap::after {
	content: '';
	position: absolute;
	left: 0; right: 0; bottom: 0;
	height: 3px;
	background: var(--color-primary);
	border-radius: 0 0 14px 14px;
}
.owner__photo-wrap:hover { transform: translateY(-3px); box-shadow:
	0 24px 48px -12px rgba(15, 23, 42, .28),
	0 8px 18px -6px rgba(15, 23, 42, .18); }
.owner__photo-wrap img {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 4;
	object-fit: cover;
	object-position: center 18%;
	border-radius: 8px;
}
.owner__caption {
	margin: 0;
	font-family: var(--font-heading);
	font-size: .9375rem;
	font-weight: 600;
	color: var(--color-secondary);
	text-align: center;
	line-height: 1.4;
}
.owner__caption span {
	display: block;
	font-family: var(--font-body);
	font-weight: 500;
	font-size: .8125rem;
	color: var(--color-text-muted);
	margin-top: 2px;
}
.owner__badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 7px 14px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	box-shadow: var(--shadow-sm);
	font-size: .75rem;
	font-weight: 600;
	color: var(--color-secondary);
	white-space: nowrap;
	letter-spacing: .01em;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
}
.owner__badge .icon { color: var(--color-success); flex-shrink: 0; }

.owner__content { max-width: 600px; }
.owner__eyebrow {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: .8125rem;
	font-weight: 600;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-bottom: var(--space-3);
}
.owner__title {
	font-size: clamp(1.625rem, 3.4vw, 2.5rem);
	margin-bottom: var(--space-4);
}
.owner__lead {
	font-size: 1.0625rem;
	color: var(--color-text);
	margin-bottom: var(--space-5);
}
.owner__quote {
	position: relative;
	padding: var(--space-5) var(--space-6);
	margin: 0 0 var(--space-6);
	background: #fff;
	border-left: 4px solid var(--color-primary);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
	font-family: var(--font-heading);
	font-style: italic;
	font-size: 1.0625rem;
	color: var(--color-secondary);
	line-height: 1.5;
	box-shadow: var(--shadow-sm);
}
.owner__points {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	margin-bottom: var(--space-7, var(--space-8));
}
.owner__points li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: .9375rem;
	color: var(--color-text);
}
.owner__points .icon { color: var(--color-success); flex-shrink: 0; margin-top: 3px; }
.owner__cta { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-6); }

/* ---------- Problems ------------------------------------------------- */
.problems__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}
@media (min-width: 640px) { .problems__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .problems__grid { grid-template-columns: repeat(4, 1fr); } }
.problem-card {
	background: var(--color-bg-alt);
	padding: var(--space-6);
	border-radius: var(--radius-lg);
	border-left: 4px solid var(--color-primary);
	transition: transform var(--transition);
}
.problem-card:hover { transform: translateY(-2px); }
.problem-card__icon {
	display: inline-flex;
	color: var(--color-primary);
	margin-bottom: var(--space-3);
}
.problem-card__title { font-size: 1.125rem; margin-bottom: var(--space-2); }
.problem-card__description { color: var(--color-text-muted); margin: 0; font-size: .9375rem; }

/* ---------- Process -------------------------------------------------- */
.process__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
	counter-reset: process;
}
@media (min-width: 720px) { .process__list { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .process__list { grid-template-columns: repeat(4, 1fr); } }
.process-step {
	background: #fff;
	padding: var(--space-6);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	position: relative;
	text-align: center;
}
.process-step__number {
	display: inline-flex;
	width: 56px; height: 56px;
	align-items: center; justify-content: center;
	border-radius: 50%;
	background: var(--color-primary);
	color: #fff;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.5rem;
	margin-bottom: var(--space-4);
}
.process-step__title { font-size: 1.125rem; margin-bottom: var(--space-2); }
.process-step__description { color: var(--color-text-muted); margin: 0; font-size: .9375rem; }

/* ---------- Coverage ------------------------------------------------- */
.coverage__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	margin-bottom: var(--space-8);
}
@media (min-width: 720px) { .coverage__grid { grid-template-columns: repeat(2, 1fr); } }
.coverage__col {
	background: #fff;
	padding: var(--space-6) var(--space-8);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
}
.coverage__region {
	font-size: 1.25rem;
	margin-bottom: var(--space-4);
	padding-bottom: var(--space-3);
	border-bottom: 2px solid var(--color-bg-alt);
	color: var(--color-secondary);
}
.coverage__cities {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}
.coverage__cities li {
	background: var(--color-bg-alt);
	padding: 6px 14px;
	border-radius: 999px;
	font-size: .875rem;
	color: var(--color-secondary);
	font-weight: 500;
}
.coverage__note {
	text-align: center;
	color: var(--color-text-muted);
	margin-bottom: var(--space-8);
}
.coverage__map {
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	border: 1px solid var(--color-border);
}
.coverage__map iframe { display: block; }
.coverage__map-cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	justify-content: center;
	margin-top: var(--space-6);
}

/* ---------- Testimonials --------------------------------------------- */
.testimonials__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}
@media (min-width: 720px) { .testimonials__grid { grid-template-columns: repeat(3, 1fr); } }
.testimonial {
	background: #fff;
	padding: var(--space-6);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.testimonial__rating {
	display: inline-flex;
	gap: 2px;
	color: #F5B400;
}
.testimonial__rating .icon { fill: #F5B400; }
.testimonial__quote { margin: 0; }
.testimonial__quote p { color: var(--color-text); margin: 0; font-style: italic; line-height: 1.7; }
.testimonial__author { font-style: normal; color: var(--color-text-muted); font-size: .9375rem; }

.testimonials__google {
	margin-top: var(--space-10);
	padding: var(--space-6) var(--space-8);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-5);
	text-align: center;
}
@media (min-width: 720px) {
	.testimonials__google { flex-direction: row; justify-content: space-between; text-align: left; }
}
.testimonials__google-text { display: flex; flex-direction: column; gap: 4px; }
.testimonials__google-text strong { font-family: var(--font-heading); font-size: 1.0625rem; color: var(--color-secondary); }
.testimonials__google-text span { font-size: .9375rem; color: var(--color-text-muted); }
.testimonials__google-actions { display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; justify-content: center; }
.testimonials__google-link { font-weight: 500; color: var(--color-text-muted); font-size: .9375rem; }
.testimonials__google-link:hover { color: var(--color-primary); }

.testimonials__google-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 8px 18px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	box-shadow: var(--shadow-sm);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: .9375rem;
	color: var(--color-secondary);
	text-decoration: none;
	transition: transform var(--transition), box-shadow var(--transition);
}
.testimonials__google-badge:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); color: var(--color-primary); }
.testimonials__google-stars { color: #F5B400; letter-spacing: 1px; font-size: 1rem; }

/* ---------- Gallery -------------------------------------------------- */
.gallery__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-3);
}
@media (min-width: 720px) { .gallery__grid { grid-template-columns: repeat(4, 1fr); gap: var(--space-4); } }
.gallery__item figure {
	margin: 0;
	border-radius: var(--radius-md);
	overflow: hidden;
	background: var(--color-bg-soft);
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition);
	position: relative;
	aspect-ratio: 4 / 3;
}
.gallery__item:hover figure { box-shadow: var(--shadow-lg); }
.gallery__item img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 500ms cubic-bezier(.2, .8, .2, 1);
}
.gallery__item:hover img { transform: scale(1.08); }
.gallery__caption {
	position: absolute;
	left: 0; right: 0; bottom: 0;
	padding: var(--space-6) var(--space-4) var(--space-3);
	background: linear-gradient(180deg, rgba(29,53,87,0) 0%, rgba(29,53,87,.85) 100%);
	color: #fff;
	font-size: .8125rem;
	font-weight: 600;
	font-family: var(--font-heading);
	letter-spacing: .01em;
	transition: padding var(--transition);
}
.gallery__item:hover .gallery__caption { padding-bottom: var(--space-4); }
.gallery__caption-text { display: block; }

/* ---------- FAQ ------------------------------------------------------ */
.faq__list { display: flex; flex-direction: column; gap: var(--space-3); }
.faq__item {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-4);
	padding: var(--space-5) var(--space-6);
	cursor: pointer;
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-secondary);
	font-size: 1.0625rem;
	list-style: none;
	transition: background-color var(--transition);
}
.faq__question::-webkit-details-marker { display: none; }
.faq__question:hover { background: var(--color-bg-alt); }
.faq__question .icon { transition: transform var(--transition); color: var(--color-primary); }
.faq__item[open] > .faq__question .icon { transform: rotate(180deg); }
.faq__answer {
	padding: 0 var(--space-6) var(--space-6);
	color: var(--color-text-muted);
}
.faq__answer p { margin: 0; line-height: 1.7; }

/* ---------- CTA final ------------------------------------------------ */
.cta-final {
	background: linear-gradient(135deg, var(--color-primary) 0%, #B82C39 100%);
	color: #fff;
	padding: clamp(48px, 8vw, 80px) 0;
}
.cta-final__inner { text-align: center; }
.cta-final__title {
	color: #fff;
	font-size: clamp(1.625rem, 3.4vw, 2.5rem);
	margin-bottom: var(--space-3);
}
.cta-final__lead {
	color: rgba(255, 255, 255, .92);
	font-size: 1.125rem;
	margin-bottom: var(--space-8);
}
.cta-final__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	justify-content: center;
}

/* ---------- Contact -------------------------------------------------- */
.contact__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}
@media (min-width: 900px) { .contact__grid { grid-template-columns: 1.4fr 1fr; gap: var(--space-12); } }

.contact-form {
	background: #fff;
	padding: var(--space-8);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	box-shadow: var(--shadow-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}
.contact-form__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
@media (min-width: 600px) { .contact-form__row { grid-template-columns: repeat(2, 1fr); } }
.contact-form__field { display: flex; flex-direction: column; gap: var(--space-2); }
.contact-form__label {
	font-size: .875rem;
	font-weight: 600;
	color: var(--color-secondary);
}
.contact-form__label em { color: var(--color-primary); font-style: normal; margin-left: 2px; }
.contact-form input,
.contact-form select,
.contact-form textarea {
	width: 100%;
	padding: 12px 14px;
	font: inherit;
	color: var(--color-text);
	background: #fff;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-md);
	transition: border-color var(--transition), box-shadow var(--transition);
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(69, 123, 157, .18);
	outline: none;
}
.contact-form input[aria-invalid="true"],
.contact-form select[aria-invalid="true"],
.contact-form textarea[aria-invalid="true"] {
	border-color: var(--color-error);
	box-shadow: 0 0 0 3px rgba(230, 57, 70, .15);
}
.contact-form textarea { resize: vertical; min-height: 120px; }
.contact-form__error {
	display: none;
	font-size: .8125rem;
	color: var(--color-error);
}
.contact-form__error:not(:empty) { display: block; }
.contact-form__consent {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: .9375rem;
	color: var(--color-text-muted);
	cursor: pointer;
}
.contact-form__consent input { width: 18px; height: 18px; margin-top: 4px; flex-shrink: 0; }
.contact-form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.contact-form__submit { align-self: flex-start; min-width: 200px; position: relative; }
.contact-form__submit-spinner { display: none; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,.4); border-top-color: #fff; border-radius: 50%; animation: redone-spin 600ms linear infinite; }
.contact-form.is-loading .contact-form__submit-spinner { display: inline-block; }
.contact-form.is-loading .contact-form__submit { opacity: .8; pointer-events: none; }
@keyframes redone-spin { to { transform: rotate(360deg); } }
.contact-form__status {
	padding: var(--space-4);
	border-radius: var(--radius-md);
	font-size: .9375rem;
	display: none;
}
.contact-form__status.is-success { display: block; background: #E6F7F3; color: var(--color-success); border: 1px solid #B5E5DB; white-space: pre-wrap; }
.contact-form__status.is-error { display: block; background: #FDECEE; color: var(--color-error); border: 1px solid #F5BEC4; white-space: pre-wrap; }

.contact-info {
	background: var(--color-secondary);
	color: #fff;
	padding: var(--space-8);
	border-radius: var(--radius-lg);
	height: fit-content;
}
.contact-info__title {
	color: #fff;
	font-size: 1.25rem;
	margin-bottom: var(--space-6);
	padding-bottom: var(--space-4);
	border-bottom: 1px solid rgba(255,255,255,.15);
}
.contact-info__list { display: flex; flex-direction: column; gap: var(--space-5); margin-bottom: var(--space-8); }
.contact-info__list li { display: flex; gap: var(--space-3); align-items: flex-start; }
.contact-info__list strong { display: block; font-size: .8125rem; text-transform: uppercase; letter-spacing: .05em; color: rgba(255,255,255,.65); margin-bottom: 2px; }
.contact-info__list a { color: #FFD166; font-weight: 500; }
.contact-info__list a:hover { color: #fff; }
.contact-info__list span { color: rgba(255,255,255,.92); }
.contact-info__icon {
	flex-shrink: 0;
	display: inline-flex;
	width: 40px; height: 40px;
	align-items: center; justify-content: center;
	border-radius: var(--radius-md);
	background: rgba(255,255,255,.1);
	color: #FFD166;
}

/* ---------- Footer --------------------------------------------------- */
.site-footer {
	background: var(--color-secondary-dark);
	color: rgba(255,255,255,.82);
	padding-top: var(--space-16);
}
.site-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	padding-bottom: var(--space-12);
}
@media (min-width: 720px) { .site-footer__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .site-footer__grid { grid-template-columns: 2fr 1fr 1fr 1.4fr; gap: var(--space-12); } }
.site-footer h3, .site-footer h4 {
	color: #fff;
	margin-bottom: var(--space-4);
	font-size: 1.0625rem;
}
.site-footer__brand { font-size: 1.25rem !important; }
.site-footer p { color: rgba(255,255,255,.7); font-size: .9375rem; line-height: 1.7; }
.site-footer ul { display: flex; flex-direction: column; gap: var(--space-2); }
.site-footer a { color: rgba(255,255,255,.82); font-size: .9375rem; }
.site-footer a:hover { color: #FFD166; }
.site-footer__contact li { display: flex; gap: var(--space-2); align-items: center; }
.site-footer__contact .icon { color: #FFD166; }
.site-footer__bottom {
	border-top: 1px solid rgba(255,255,255,.1);
	padding: var(--space-6) 0;
}
.site-footer__bottom .container {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	align-items: center;
	text-align: center;
}
@media (min-width: 720px) {
	.site-footer__bottom .container { flex-direction: row; justify-content: space-between; text-align: left; }
}
.site-footer__legal { font-size: .875rem; }
.site-footer__legal-list {
	display: flex; flex-wrap: wrap;
	gap: var(--space-3);
	align-items: center;
	justify-content: center;
	list-style: none;
	padding: 0; margin: 0;
}
@media (min-width: 720px) { .site-footer__legal-list { justify-content: flex-start; } }
.site-footer__legal-list li { position: relative; padding-right: var(--space-3); }
.site-footer__legal-list li:not(:last-child)::after {
	content: '·';
	position: absolute;
	right: 0;
	color: rgba(255,255,255,.4);
	pointer-events: none;
}
.site-footer__legal-list li:last-child { padding-right: 0; }
.site-footer__copy { font-size: .8125rem; color: rgba(255,255,255,.55); margin: 0; }

/* ---------- Floating WhatsApp button --------------------------------- */
.floating-whatsapp {
	position: fixed;
	bottom: 20px; right: 20px;
	width: 56px; height: 56px;
	border-radius: 50%;
	background: var(--color-whatsapp);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 6px 20px rgba(37, 211, 102, .45);
	z-index: 90;
	transition: transform var(--transition), box-shadow var(--transition), background-color var(--transition);
}
.floating-whatsapp:hover { transform: scale(1.08); background: var(--color-whatsapp-dark); color: #fff; }
@media (min-width: 720px) { .floating-whatsapp { bottom: 28px; right: 28px; width: 60px; height: 60px; } }

/* ---------- Page content (legal pages, 404, blog) -------------------- */
.page-content { padding: var(--space-16) 0; }
.page-header { margin-bottom: var(--space-8); }
.page-header__title { font-size: clamp(1.75rem, 4vw, 2.5rem); }
.page-article__body p, .page-article__body li { line-height: 1.8; color: var(--color-text); }
.page-article__body h2 { margin-top: var(--space-10); }
.page-article__body h3 { margin-top: var(--space-8); }
.page-article__body ul, .page-article__body ol { padding-left: 1.4em; margin-bottom: 1em; }
.page-article__body ul { list-style: disc; }
.page-article__body ol { list-style: decimal; }
.page-article__body a { color: var(--color-primary); text-decoration: underline; }

.page-404 { text-align: center; padding: var(--space-20) 0; }
.page-404__code {
	font-size: clamp(5rem, 14vw, 8rem);
	color: var(--color-primary);
	margin-bottom: 0;
	line-height: 1;
}
.page-404__title { margin-bottom: var(--space-4); }
.page-404 .btn { margin: var(--space-2); }

.post-card { padding: var(--space-6) 0; border-bottom: 1px solid var(--color-border); }
.post-card__meta { font-size: .875rem; color: var(--color-text-muted); margin-bottom: var(--space-2); }
.post-card__more { font-weight: 600; color: var(--color-primary); }

/* ---------- WordPress core compatibility ----------------------------- */
.wp-caption, .wp-caption-text, .gallery-caption, .bypostauthor, .sticky, .alignright, .alignleft, .aligncenter, .screen-reader-text { /* core classes used by WP */ }
.alignleft { float: left; margin: 0 var(--space-5) var(--space-3) 0; }
.alignright { float: right; margin: 0 0 var(--space-3) var(--space-5); }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px; height: 1px; overflow: hidden;
}

/* ---------- Page hero (used on Servicios + future subpages) ---------- */
.page-hero {
	position: relative;
	overflow: hidden;
	background: linear-gradient(135deg, var(--color-secondary) 0%, #2A4A75 100%);
	color: #fff;
	padding: clamp(64px, 9vw, 120px) 0 clamp(48px, 7vw, 80px);
}
.page-hero::before {
	content: '';
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 90% 10%, rgba(230, 57, 70, .15) 0%, transparent 40%),
		radial-gradient(circle at 10% 100%, rgba(69, 123, 157, .25) 0%, transparent 50%);
	z-index: 0;
}
.page-hero__inner { position: relative; z-index: 1; max-width: 820px; }
.page-hero__breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	align-items: center;
	font-size: .875rem;
	color: rgba(255, 255, 255, .7);
	margin-bottom: var(--space-4);
}
.page-hero__breadcrumb a { color: rgba(255, 255, 255, .85); text-decoration: none; font-weight: 500; }
.page-hero__breadcrumb a:hover { color: #FFD166; }
.page-hero__current { color: #FFD166; font-weight: 500; }
.page-hero__title {
	color: #fff;
	font-size: clamp(2rem, 4.5vw, 3rem);
	margin: 0 0 var(--space-5);
	letter-spacing: -0.02em;
}
.page-hero__lead {
	font-size: clamp(1.0625rem, 1.4vw, 1.1875rem);
	color: rgba(255, 255, 255, .92);
	margin: 0;
	max-width: 660px;
	line-height: 1.6;
}

/* ---------- Services directory page ---------------------------------- */
.services-directory__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
}
@media (min-width: 900px) {
	.services-directory__grid { gap: var(--space-12); }
}
.services-directory__card {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition);
}
.services-directory__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
@media (min-width: 720px) {
	.services-directory__card { grid-template-columns: 5fr 7fr; }
}
.services-directory__media {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--color-secondary);
}
@media (min-width: 720px) {
	.services-directory__media { aspect-ratio: auto; height: 100%; min-height: 320px; }
}
.services-directory__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(.2, .8, .2, 1);
}
.services-directory__card:hover .services-directory__media img { transform: scale(1.05); }
.services-directory__media::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(29,53,87,.45) 100%);
	pointer-events: none;
}
.services-directory__icon {
	position: absolute;
	bottom: 16px; left: 16px;
	display: inline-flex;
	width: 52px; height: 52px;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-md);
	background: var(--color-primary);
	color: #fff;
	box-shadow: var(--shadow-md);
	z-index: 2;
}
.services-directory__body {
	padding: var(--space-7, var(--space-8)) var(--space-6) var(--space-6);
	display: flex;
	flex-direction: column;
}
@media (min-width: 720px) {
	.services-directory__body { padding: var(--space-8) var(--space-8) var(--space-8); justify-content: center; }
}
.services-directory__title {
	font-size: clamp(1.375rem, 2.4vw, 1.625rem);
	margin: 0 0 var(--space-2);
}
.services-directory__title a { color: var(--color-secondary); text-decoration: none; }
.services-directory__title a:hover { color: var(--color-primary); }
.services-directory__subtitle {
	color: var(--color-accent);
	font-weight: 600;
	margin: 0 0 var(--space-4);
	font-size: .9375rem;
}
.services-directory__description {
	color: var(--color-text-muted);
	margin: 0 0 var(--space-5);
	line-height: 1.7;
}
.services-directory__apps-title {
	font-size: .8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--color-secondary);
	margin: 0 0 var(--space-3);
}
.services-directory__apps {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	margin: 0 0 var(--space-6);
}
.services-directory__apps li {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: .9375rem;
	color: var(--color-text);
}
.services-directory__apps .icon { color: var(--color-success); flex-shrink: 0; }
.services-directory__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

/* ---------- Page hero — service variant ------------------------------ */
.page-hero--service .page-hero__lead { max-width: 720px; }
.page-hero__eyebrow {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: .875rem;
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: #FFD166;
	margin-bottom: var(--space-3);
}
.page-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-top: var(--space-6);
}

/* ---------- Service detail page (long-form layout) ------------------- */
.service-detail__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
}
@media (min-width: 1000px) {
	.service-detail__grid { grid-template-columns: 1fr 360px; gap: var(--space-12); align-items: start; }
}
.service-detail__main { min-width: 0; }
.service-detail__feature-image {
	margin: 0 0 var(--space-8);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}
.service-detail__feature-image img { width: 100%; height: auto; display: block; }
.service-detail__section {
	margin-bottom: var(--space-10);
}
.service-detail__section h2 {
	font-size: clamp(1.375rem, 2.2vw, 1.75rem);
	margin: 0 0 var(--space-4);
	color: var(--color-secondary);
}
.service-detail__section p {
	color: var(--color-text);
	line-height: 1.8;
	font-size: 1.0625rem;
	margin: 0 0 var(--space-4);
}
.service-detail__section p strong { color: var(--color-secondary); }
.service-detail__apps {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	margin: 0;
}
@media (min-width: 600px) { .service-detail__apps { grid-template-columns: repeat(2, 1fr); } }
.service-detail__apps li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	padding: var(--space-3) var(--space-4);
	background: var(--color-bg-alt);
	border-radius: var(--radius-md);
	font-size: .9375rem;
	color: var(--color-text);
}
.service-detail__apps .icon { color: var(--color-success); flex-shrink: 0; margin-top: 2px; }
.service-detail__pricing {
	background: linear-gradient(135deg, var(--color-bg-alt) 0%, #fff 100%);
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-primary);
	border-radius: var(--radius-md);
	padding: var(--space-5) var(--space-6);
	margin-top: var(--space-8);
}
.service-detail__pricing h3 {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: 1.125rem;
	margin: 0 0 var(--space-3);
	color: var(--color-secondary);
}
.service-detail__pricing h3 .icon { color: var(--color-primary); }
.service-detail__pricing p { margin: 0; color: var(--color-text); line-height: 1.7; }

/* Sticky sidebar with benefits, CTA, trust */
.service-detail__sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}
@media (min-width: 1000px) {
	.service-detail__sidebar { position: sticky; top: calc(var(--header-h) + 24px); }
}
.service-detail__card {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	box-shadow: var(--shadow-sm);
}
.service-detail__card h3 {
	font-size: 1.0625rem;
	margin: 0 0 var(--space-4);
	color: var(--color-secondary);
}
.service-detail__card ul {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.service-detail__card li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-2);
	font-size: .9375rem;
	color: var(--color-text);
	line-height: 1.5;
}
.service-detail__card li .icon { color: var(--color-success); flex-shrink: 0; margin-top: 3px; }
.service-detail__card--cta { background: var(--color-secondary); color: #fff; border-color: transparent; }
.service-detail__card--cta h3 { color: #fff; }
.service-detail__card--cta p { color: rgba(255,255,255,.85); font-size: .9375rem; margin: 0 0 var(--space-4); }
.service-detail__card--cta .btn { margin-bottom: var(--space-2); }
.service-detail__card--cta .btn:last-child { margin-bottom: 0; }
.service-detail__card--trust ul li .icon { color: var(--color-primary); }

/* ---------- Emergency callout (goteras page) ------------------------- */
.emergency-callout {
	background: linear-gradient(135deg, var(--color-primary) 0%, #B82C39 100%);
	color: #fff;
	padding: var(--space-5) 0;
	box-shadow: 0 4px 14px -6px rgba(230, 57, 70, .5);
}
.emergency-callout__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-4);
	text-align: center;
}
@media (min-width: 900px) {
	.emergency-callout__inner { flex-direction: row; text-align: left; }
}
.emergency-callout__icon {
	display: inline-flex;
	width: 56px; height: 56px;
	align-items: center; justify-content: center;
	background: rgba(255, 255, 255, .15);
	border-radius: 50%;
	flex-shrink: 0;
}
.emergency-callout__text { flex: 1; }
.emergency-callout__text strong {
	display: block;
	font-family: var(--font-heading);
	font-size: 1.125rem;
	margin-bottom: 2px;
}
.emergency-callout__text span {
	font-size: .9375rem;
	color: rgba(255, 255, 255, .92);
}
.emergency-callout__actions { display: flex; gap: var(--space-2); flex-wrap: wrap; justify-content: center; }
.emergency-callout__actions .btn--primary { background: #fff; color: var(--color-primary); }
.emergency-callout__actions .btn--primary:hover { background: var(--color-bg-alt); color: var(--color-primary-dark); }

/* ---------- Local context band -------------------------------------- */
.local-context__inner {
	display: flex;
	gap: var(--space-5);
	align-items: flex-start;
}
.local-context__icon {
	display: inline-flex;
	width: 52px; height: 52px;
	align-items: center; justify-content: center;
	background: var(--color-secondary);
	color: #fff;
	border-radius: var(--radius-md);
	flex-shrink: 0;
}
.local-context__title {
	font-size: 1.375rem;
	margin: 0 0 var(--space-3);
	color: var(--color-secondary);
}
.local-context__body {
	margin: 0;
	color: var(--color-text);
	line-height: 1.75;
	font-size: 1.0625rem;
}

/* ---------- Service detail extras ----------------------------------- */

/* Timeline */
.service-timeline__list {
	list-style: none;
	margin: 0;
	padding: 0;
	position: relative;
}
.service-timeline__list::before {
	content: '';
	position: absolute;
	left: 96px;
	top: 8px; bottom: 8px;
	width: 2px;
	background: var(--color-border);
}
@media (max-width: 600px) {
	.service-timeline__list::before { left: 60px; }
}
.service-timeline__item {
	position: relative;
	display: flex;
	gap: var(--space-5);
	padding: var(--space-3) 0;
	align-items: flex-start;
}
.service-timeline__stage {
	flex-shrink: 0;
	width: 88px;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: .875rem;
	color: #fff;
	background: var(--color-primary);
	border-radius: 999px;
	padding: 4px 10px;
	text-align: center;
	position: relative;
	z-index: 1;
}
@media (max-width: 600px) {
	.service-timeline__stage { width: 56px; font-size: .75rem; }
}
.service-timeline__body {
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.6;
	padding-top: 4px;
}

/* Mistakes */
.service-mistakes__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	margin: 0;
}
.service-mistakes__list li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	padding: var(--space-3) var(--space-4);
	background: #FDF4F5;
	border-left: 3px solid var(--color-primary);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.6;
}
.service-mistakes__icon {
	display: inline-flex;
	width: 24px; height: 24px;
	align-items: center; justify-content: center;
	background: var(--color-primary);
	color: #fff;
	border-radius: 50%;
	flex-shrink: 0;
	margin-top: 1px;
}

/* Mythbusters */
.service-myths__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}
.service-myths__item {
	background: var(--color-bg-alt);
	border-radius: var(--radius-md);
	overflow: hidden;
	display: grid;
	grid-template-columns: 1fr;
	border: 1px solid var(--color-border);
}
@media (min-width: 720px) {
	.service-myths__item { grid-template-columns: 1fr 1fr; }
}
.service-myths__myth, .service-myths__reality {
	padding: var(--space-4) var(--space-5);
}
.service-myths__myth { border-bottom: 1px solid var(--color-border); background: #fff; }
@media (min-width: 720px) {
	.service-myths__myth { border-bottom: 0; border-right: 1px solid var(--color-border); }
}
.service-myths__reality { background: #F0F9F4; }
.service-myths__label {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: var(--space-2);
}
.service-myths__label--reality { color: var(--color-success); }
.service-myths__myth p, .service-myths__reality p {
	margin: 0;
	color: var(--color-text);
	line-height: 1.6;
	font-size: .9375rem;
}
.service-myths__myth p { font-style: italic; }

/* Cities notes */
.service-cities__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	margin: 0;
}
@media (min-width: 720px) { .service-cities__list { grid-template-columns: repeat(2, 1fr); } }
.service-cities__list li {
	display: flex;
	gap: var(--space-3);
	align-items: flex-start;
	padding: var(--space-3) var(--space-4);
	background: var(--color-bg-alt);
	border-radius: var(--radius-md);
	font-size: .9375rem;
	line-height: 1.55;
}
.service-cities__icon {
	display: inline-flex;
	color: var(--color-accent);
	margin-top: 3px;
	flex-shrink: 0;
}
.service-cities__list strong { color: var(--color-secondary); }

/* Standards */
.service-standards p {
	background: #F7F8FA;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-4) var(--space-5);
	font-size: .9375rem;
	line-height: 1.65;
	color: var(--color-text-muted);
}
.service-standards p strong { color: var(--color-secondary); }

/* Related services */
.related-services__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
@media (min-width: 720px) { .related-services__grid { grid-template-columns: repeat(3, 1fr); } }
.related-services__card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
	text-decoration: none;
	color: inherit;
}
.related-services__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--color-accent);
	color: inherit;
}
.related-services__media {
	aspect-ratio: 3 / 2;
	overflow: hidden;
	background: var(--color-secondary);
}
.related-services__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 500ms cubic-bezier(.2, .8, .2, 1);
}
.related-services__card:hover .related-services__media img { transform: scale(1.06); }
.related-services__body { padding: var(--space-5); display: flex; flex-direction: column; flex: 1; }
.related-services__title {
	font-size: 1.0625rem;
	margin: 0 0 var(--space-2);
	color: var(--color-secondary);
}
.related-services__desc {
	font-size: .9375rem;
	color: var(--color-text-muted);
	margin: 0 0 var(--space-4);
	flex: 1;
}
.related-services__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: .9375rem;
	color: var(--color-primary);
}
.related-services__card:hover .related-services__cta { gap: var(--space-3); }

/* ---------- Zonas (city pages + index) ------------------------------ */

.page-hero__aka {
	font-weight: 500;
	color: rgba(255, 255, 255, .75);
	font-size: 0.7em;
}

/* City page: services list */
.city-services__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	margin: 0;
	list-style: none;
	padding: 0;
}
@media (min-width: 720px) { .city-services__grid { grid-template-columns: repeat(2, 1fr); } }
.city-services__item { list-style: none; }
.city-services__link {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	padding: var(--space-4) var(--space-5);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: inherit;
	text-decoration: none;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.city-services__link:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: var(--color-accent);
	color: inherit;
}
.city-services__icon {
	display: inline-flex;
	width: 44px; height: 44px;
	align-items: center; justify-content: center;
	background: var(--color-bg-alt);
	color: var(--color-primary);
	border-radius: var(--radius-sm);
	flex-shrink: 0;
}
.city-services__body { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.city-services__body strong { color: var(--color-secondary); font-family: var(--font-heading); font-size: 1rem; }
.city-services__body span { font-size: .875rem; color: var(--color-text-muted); }
.city-services__link > .icon { color: var(--color-primary); flex-shrink: 0; transition: transform var(--transition); }
.city-services__link:hover > .icon { transform: translateX(3px); }

/* Related cities under a city page */
.related-cities__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-3);
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (min-width: 720px) { .related-cities__grid { grid-template-columns: repeat(4, 1fr); } }
.related-cities__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-2);
	padding: var(--space-4);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: inherit;
	text-decoration: none;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.related-cities__card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: var(--color-accent);
	color: inherit;
}
.related-cities__card .icon { color: var(--color-primary); }
.related-cities__name {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-secondary);
	font-size: .9375rem;
}
.related-cities__cluster {
	font-size: .75rem;
	color: var(--color-text-muted);
}

/* Zonas index — clusters of cities */
.zonas-cluster { margin-bottom: var(--space-12); }
.zonas-cluster:last-child { margin-bottom: 0; }
.zonas-cluster__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--space-4);
	padding-bottom: var(--space-4);
	margin-bottom: var(--space-6);
	border-bottom: 2px solid var(--color-bg-alt);
}
.zonas-cluster__title {
	font-size: clamp(1.375rem, 2.4vw, 1.75rem);
	margin: 0;
	color: var(--color-secondary);
}
.zonas-cluster__count {
	font-family: var(--font-heading);
	font-size: .8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--color-text-muted);
	background: var(--color-bg-alt);
	padding: 4px 12px;
	border-radius: 999px;
	white-space: nowrap;
}
.zonas-cluster__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (min-width: 600px) { .zonas-cluster__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .zonas-cluster__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .zonas-cluster__grid { grid-template-columns: repeat(4, 1fr); } }
.zonas-cluster__card {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	padding: var(--space-4);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: inherit;
	text-decoration: none;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.zonas-cluster__card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
	border-color: var(--color-accent);
	color: inherit;
}
.zonas-cluster__icon {
	display: inline-flex;
	width: 36px; height: 36px;
	align-items: center; justify-content: center;
	background: var(--color-bg-alt);
	color: var(--color-primary);
	border-radius: 50%;
	flex-shrink: 0;
}
.zonas-cluster__body { flex: 1; display: flex; flex-direction: column; gap: 1px; }
.zonas-cluster__body strong { color: var(--color-secondary); font-family: var(--font-heading); font-size: .9375rem; }
.zonas-cluster__aka { font-size: .75rem; color: var(--color-text-muted); font-style: italic; }
.zonas-cluster__province { font-size: .75rem; color: var(--color-text-muted); }
.zonas-cluster__card > .icon { color: var(--color-primary); flex-shrink: 0; transition: transform var(--transition); }
.zonas-cluster__card:hover > .icon { transform: translateX(2px); }

/* ---------- City detail page — extra deep sections ------------------ */

/* Barrios grid */
.city-barrios__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (min-width: 720px) { .city-barrios__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .city-barrios__grid { grid-template-columns: repeat(3, 1fr); } }
.city-barrios__item {
	display: flex;
	gap: var(--space-3);
	align-items: flex-start;
	padding: var(--space-4);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	transition: transform var(--transition), box-shadow var(--transition);
}
.city-barrios__item:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.city-barrios__icon {
	display: inline-flex;
	width: 32px; height: 32px;
	align-items: center; justify-content: center;
	background: var(--color-bg-alt);
	color: var(--color-primary);
	border-radius: 50%;
	flex-shrink: 0;
}
.city-barrios__item div { flex: 1; }
.city-barrios__item strong {
	display: block;
	font-family: var(--font-heading);
	color: var(--color-secondary);
	font-size: .9375rem;
	margin-bottom: 2px;
}
.city-barrios__item span {
	font-size: .8125rem;
	color: var(--color-text-muted);
	line-height: 1.5;
}

/* Common jobs */
.city-jobs__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}
.city-jobs__item {
	background: #fff;
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-primary);
	border-radius: var(--radius-md);
	padding: var(--space-5);
}
.city-jobs__title {
	font-size: 1.0625rem;
	margin: 0 0 var(--space-2);
	color: var(--color-secondary);
}
.city-jobs__description {
	margin: 0;
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.65;
}

/* Local tips — numbered list */
.city-tips__list {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	list-style: none;
	padding: 0;
	margin: 0;
}
.city-tips__item {
	display: flex;
	gap: var(--space-4);
	align-items: flex-start;
	padding: var(--space-4) var(--space-5);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.65;
}
.city-tips__num {
	display: inline-flex;
	width: 32px; height: 32px;
	align-items: center; justify-content: center;
	background: var(--color-primary);
	color: #fff;
	border-radius: 50%;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: .9375rem;
	flex-shrink: 0;
	margin-top: -2px;
}

/* Seasonal advice — callout band */
.city-seasonal__inner {
	display: flex;
	gap: var(--space-5);
	align-items: flex-start;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
}
.city-seasonal__icon {
	display: inline-flex;
	width: 56px; height: 56px;
	align-items: center; justify-content: center;
	background: var(--color-secondary);
	color: #fff;
	border-radius: 50%;
	flex-shrink: 0;
}
.city-seasonal__title {
	font-size: 1.25rem;
	margin: 0 0 var(--space-3);
	color: var(--color-secondary);
}
.city-seasonal__body {
	margin: 0;
	color: var(--color-text);
	line-height: 1.75;
	font-size: 1rem;
}

/* Case studies */
.city-cases__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
@media (min-width: 720px) { .city-cases__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .city-cases__grid { grid-template-columns: repeat(3, 1fr); } }
.city-cases__card {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}
.city-cases__head {
	background: var(--color-secondary);
	color: #fff;
	padding: var(--space-3) var(--space-5);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: .875rem;
}
.city-cases__body {
	margin: 0;
	padding: var(--space-5);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.city-cases__body dt {
	font-family: var(--font-heading);
	font-size: .75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--color-primary);
	margin-bottom: 2px;
}
.city-cases__body dd {
	margin: 0 0 var(--space-2);
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.6;
}
.city-cases__body dd:last-child { margin-bottom: 0; }

/* Why local — conversion block */
.city-why__inner {
	background: linear-gradient(135deg, var(--color-secondary) 0%, #2A4A75 100%);
	color: #fff;
	padding: var(--space-8) var(--space-7, var(--space-8));
	border-radius: var(--radius-lg);
	text-align: center;
}
.city-why__title {
	color: #fff;
	font-size: clamp(1.375rem, 2.4vw, 1.75rem);
	margin: 0 0 var(--space-4);
}
.city-why__body {
	color: rgba(255, 255, 255, .92);
	font-size: 1.0625rem;
	line-height: 1.7;
	margin: 0 0 var(--space-6);
	max-width: 720px;
	margin-inline: auto;
}
.city-why__cta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	justify-content: center;
}
.city-why__cta .btn--secondary { background: #fff; color: var(--color-secondary); border-color: #fff; }
.city-why__cta .btn--secondary:hover { background: var(--color-bg-alt); }

/* ---------- Comparativa de sistemas (page-comparativa.php) ----------- */

/* TL;DR cards */
.comp-tldr__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
@media (min-width: 720px) { .comp-tldr__grid { grid-template-columns: repeat(3, 1fr); } }
.comp-tldr__card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--color-border);
	border-top: 4px solid var(--color-primary);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	box-shadow: var(--shadow-sm);
	transition: transform var(--transition), box-shadow var(--transition);
}
.comp-tldr__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.comp-tldr__card--tela    { border-top-color: var(--color-primary); }
.comp-tldr__card--pvc     { border-top-color: var(--color-accent); }
.comp-tldr__card--caucho  { border-top-color: var(--color-success); }
.comp-tldr__icon {
	display: inline-flex;
	width: 52px; height: 52px;
	align-items: center; justify-content: center;
	background: var(--color-bg-alt);
	color: var(--color-primary);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-4);
}
.comp-tldr__card--pvc    .comp-tldr__icon { color: var(--color-accent); }
.comp-tldr__card--caucho .comp-tldr__icon { color: var(--color-success); }
.comp-tldr__card h3 {
	font-size: 1.25rem;
	margin: 0 0 var(--space-2);
	color: var(--color-secondary);
}
.comp-tldr__verdict {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-primary);
	margin: 0 0 var(--space-3);
	font-size: .9375rem;
}
.comp-tldr__card p:not(.comp-tldr__verdict) {
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.65;
	flex: 1;
	margin: 0 0 var(--space-4);
}
.comp-tldr__link {
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-primary);
	font-size: .9375rem;
}
.comp-tldr__link:hover { color: var(--color-primary-dark); }

/* Comparison table */
.comp-table-wrap {
	overflow-x: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	background: #fff;
	border: 1px solid var(--color-border);
}
.comp-table {
	width: 100%;
	border-collapse: collapse;
	font-size: .9375rem;
	min-width: 680px;
}
.comp-table thead th {
	background: var(--color-secondary);
	color: #fff;
	padding: var(--space-4) var(--space-4);
	text-align: left;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: .9375rem;
	border-bottom: 2px solid var(--color-secondary-dark);
	position: sticky; top: 0;
}
.comp-table thead th:first-child { background: var(--color-secondary-dark); }
.comp-table tbody th {
	text-align: left;
	padding: var(--space-3) var(--space-4);
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-secondary);
	background: var(--color-bg-alt);
	font-size: .9375rem;
	border-bottom: 1px solid var(--color-border);
	width: 28%;
}
.comp-table tbody td {
	padding: var(--space-3) var(--space-4);
	color: var(--color-text);
	border-bottom: 1px solid var(--color-border);
	vertical-align: middle;
}
.comp-table tbody tr:last-child th,
.comp-table tbody tr:last-child td { border-bottom: 0; }
.comp-table tbody tr:hover { background: var(--color-bg-soft); }
.comp-table tbody td strong { color: var(--color-primary); font-weight: 700; }
.comp-table__note {
	margin-top: var(--space-5);
	font-size: .875rem;
	color: var(--color-text-muted);
	line-height: 1.65;
	padding: var(--space-4);
	background: #FFF8E1;
	border-left: 3px solid #FFD166;
	border-radius: var(--radius-sm);
}

/* Decision guide by use case */
.comp-decision__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
@media (min-width: 720px) { .comp-decision__grid { grid-template-columns: repeat(2, 1fr); } }
.comp-decision__case {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5) var(--space-6);
	transition: transform var(--transition), box-shadow var(--transition);
}
.comp-decision__case:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.comp-decision__case h3 {
	font-size: 1.0625rem;
	margin: 0 0 var(--space-3);
	color: var(--color-secondary);
}
.comp-decision__choice {
	display: inline-block;
	background: var(--color-bg-alt);
	color: var(--color-primary);
	padding: 6px 12px;
	border-radius: 999px;
	font-size: .875rem;
	margin: 0 0 var(--space-3);
}
.comp-decision__case p:not(.comp-decision__choice) {
	margin: 0;
	color: var(--color-text);
	font-size: .9375rem;
	line-height: 1.65;
}

/* Cost table */
.comp-cost__table {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
}
.comp-cost__row {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1.5fr;
	gap: var(--space-3);
	padding: var(--space-3) var(--space-5);
	border-bottom: 1px solid var(--color-border);
	align-items: center;
	font-size: .9375rem;
}
@media (max-width: 720px) {
	.comp-cost__row { grid-template-columns: 1fr; padding: var(--space-3) var(--space-4); }
	.comp-cost__row span:not(:first-child) { font-size: .8125rem; color: var(--color-text-muted); }
}
.comp-cost__row:last-child { border-bottom: 0; }
.comp-cost__row--head {
	background: var(--color-secondary);
	color: #fff;
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: .8125rem;
	text-transform: uppercase;
	letter-spacing: .04em;
}
@media (max-width: 720px) {
	.comp-cost__row--head { display: none; }
}
.comp-cost__row strong { color: var(--color-primary); }
.comp-cost__row--bad { background: #FDF4F5; }
.comp-cost__row--bad strong { color: var(--color-primary); }
.comp-cost__note {
	margin-top: var(--space-4);
	font-size: .875rem;
	color: var(--color-text-muted);
	line-height: 1.65;
	padding: var(--space-4);
	background: #FDF4F5;
	border-left: 3px solid var(--color-primary);
	border-radius: var(--radius-sm);
}
.comp-cost__note strong { color: var(--color-primary); }

/* ---------- Cookie consent ------------------------------------------- */
.redone-cookie-banner {
	position: fixed;
	left: 16px; right: 16px; bottom: 16px;
	z-index: 9990;
	background: #fff;
	color: var(--color-text);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: 0 20px 50px -12px rgba(15, 23, 42, .28), 0 8px 20px -6px rgba(15, 23, 42, .18);
	padding: var(--space-5) var(--space-6);
	transform: translateY(20px);
	opacity: 0;
	transition: transform 250ms cubic-bezier(.2, .8, .2, 1), opacity 250ms ease;
	max-width: 920px;
	margin-inline: auto;
}
.redone-cookie-banner.is-visible { transform: translateY(0); opacity: 1; }
@media (min-width: 720px) {
	.redone-cookie-banner { left: 24px; right: 24px; bottom: 24px; padding: var(--space-6) var(--space-7, var(--space-8)); }
}
.redone-cookie-banner__inner {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}
@media (min-width: 900px) {
	.redone-cookie-banner__inner { flex-direction: row; align-items: center; gap: var(--space-8); }
}
.redone-cookie-banner__text { flex: 1; }
.redone-cookie-banner__title {
	font-size: 1.0625rem;
	margin: 0 0 var(--space-2);
	color: var(--color-secondary);
}
.redone-cookie-banner__desc {
	margin: 0;
	font-size: .9375rem;
	line-height: 1.55;
	color: var(--color-text-muted);
}
.redone-cookie-banner__desc a { color: var(--color-primary); text-decoration: underline; }
.redone-cookie-banner__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	flex-shrink: 0;
}
@media (min-width: 900px) {
	.redone-cookie-banner__actions { flex-wrap: nowrap; }
}

.redone-cookie-btn {
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: .875rem;
	padding: 10px 16px;
	border-radius: var(--radius-md);
	border: 1.5px solid transparent;
	background: transparent;
	cursor: pointer;
	white-space: nowrap;
	transition: background-color var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}
.redone-cookie-btn--primary { background: var(--color-primary); color: #fff; }
.redone-cookie-btn--primary:hover { background: var(--color-primary-dark); transform: translateY(-1px); }
.redone-cookie-btn--ghost { color: var(--color-secondary); border-color: var(--color-border); background: #fff; }
.redone-cookie-btn--ghost:hover { background: var(--color-bg-alt); border-color: var(--color-secondary); }

/* Preferences modal */
.redone-cookie-modal {
	position: fixed; inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-4);
}
.redone-cookie-modal__backdrop {
	position: absolute; inset: 0;
	background: rgba(15, 23, 42, .55);
	opacity: 0;
	transition: opacity 200ms ease;
}
.redone-cookie-modal.is-visible .redone-cookie-modal__backdrop { opacity: 1; }
.redone-cookie-modal__panel {
	position: relative;
	background: #fff;
	border-radius: var(--radius-lg);
	max-width: 560px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 30px 60px -20px rgba(15, 23, 42, .4);
	transform: translateY(20px) scale(.98);
	opacity: 0;
	transition: transform 250ms cubic-bezier(.2, .8, .2, 1), opacity 200ms ease;
}
.redone-cookie-modal.is-visible .redone-cookie-modal__panel { transform: translateY(0) scale(1); opacity: 1; }
.redone-cookie-modal__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	padding: var(--space-5) var(--space-6);
	border-bottom: 1px solid var(--color-border);
}
.redone-cookie-modal__title { font-size: 1.125rem; margin: 0; color: var(--color-secondary); }
.redone-cookie-modal__close {
	background: transparent;
	border: 0;
	width: 36px; height: 36px;
	border-radius: 50%;
	font-size: 1.5rem;
	line-height: 1;
	color: var(--color-text-muted);
	cursor: pointer;
}
.redone-cookie-modal__close:hover { background: var(--color-bg-alt); color: var(--color-secondary); }
.redone-cookie-modal__intro {
	margin: 0;
	padding: var(--space-4) var(--space-6) 0;
	font-size: .9375rem;
	color: var(--color-text-muted);
}
.redone-cookie-modal__list {
	list-style: none;
	margin: 0;
	padding: var(--space-4) var(--space-6);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}
.redone-cookie-cat {
	background: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
}
.redone-cookie-cat__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	font-family: var(--font-heading);
	font-weight: 600;
	color: var(--color-secondary);
	cursor: pointer;
}
.redone-cookie-cat__label { font-size: .9375rem; }
.redone-cookie-cat__locked {
	font-size: .75rem;
	font-weight: 600;
	color: var(--color-text-muted);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	padding: 4px 10px;
}
.redone-cookie-cat__toggle { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.redone-cookie-cat__toggle input { position: absolute; opacity: 0; width: 100%; height: 100%; margin: 0; cursor: pointer; z-index: 1; }
.redone-cookie-cat__switch {
	position: absolute; inset: 0;
	background: #ccc;
	border-radius: 999px;
	transition: background-color var(--transition);
}
.redone-cookie-cat__switch::after {
	content: '';
	position: absolute;
	top: 2px; left: 2px;
	width: 20px; height: 20px;
	background: #fff;
	border-radius: 50%;
	transition: transform var(--transition);
	box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.redone-cookie-cat__toggle input:checked + .redone-cookie-cat__switch { background: var(--color-primary); }
.redone-cookie-cat__toggle input:checked + .redone-cookie-cat__switch::after { transform: translateX(20px); }
.redone-cookie-cat__desc {
	margin: var(--space-2) 0 0;
	font-size: .8125rem;
	color: var(--color-text-muted);
	line-height: 1.5;
}
.redone-cookie-modal__footer {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	justify-content: flex-end;
	padding: var(--space-4) var(--space-6) var(--space-6);
	border-top: 1px solid var(--color-border);
}

/* Reopen preferences button (small persistent button bottom-left) */
.redone-cookie-reopen {
	position: fixed;
	left: 16px; bottom: 16px;
	z-index: 80;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: #fff;
	color: var(--color-secondary);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	padding: 8px 14px;
	font-size: .8125rem;
	font-weight: 600;
	cursor: pointer;
	box-shadow: var(--shadow-md);
	transition: transform var(--transition), box-shadow var(--transition);
}
.redone-cookie-reopen:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.redone-cookie-reopen__icon { font-size: 1rem; }
@media (max-width: 720px) {
	.redone-cookie-reopen { left: 12px; bottom: 12px; }
	/* Avoid overlap with the floating WhatsApp button on small screens. */
	.floating-whatsapp { bottom: 70px; }
}

/* ---------- Print ---------------------------------------------------- */
@media print {
	.site-header, .site-nav, .floating-whatsapp, .cta-final, .contact-form, .hero__media, .hero__overlay { display: none !important; }
	.hero { background: none !important; color: #000; min-height: 0; }
	.hero__title, .hero__subtitle { color: #000; }
	a { color: #000; text-decoration: underline; }
	.section { padding: 1.5rem 0; }
}
