/**
 * Portada — auditoría UX: CTAs duales, contraste hero, secciones nuevas, formulario portada.
 */

/* Hero: contraste + sombra en título (legibilidad sobre foto) */
.portada-root .hero-overlay {
	background: rgba(29, 38, 59, 0.72);
}

.portada-root .hero .hero-titulo-h1.text-align-center,
.portada-root .hero .hero-titulo-span,
.portada-root .hero .hero-titulo-linea {
	text-shadow: 0 2px 18px rgba(0, 0, 0, 0.55);
}

/* Dos CTAs + opcional tercero (ACF) */
.hero-botones--dual {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
	align-items: center;
	margin-top: 8px;
}

.hero-botones--extra {
	display: flex;
	justify-content: center;
	margin-top: 10px;
}

.boton-principal--secundario {
	background: transparent;
	border: 2px solid rgba(255, 255, 255, 0.95);
	color: #fff;
}

.boton-principal--secundario:hover,
.boton-principal--secundario:focus-visible {
	background: rgba(255, 255, 255, 0.12);
}

.boton-principal--outline {
	background: rgba(255, 255, 255, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.5);
}

/* Hero: prueba social breve (contraste AA sobre overlay) */
.portada-root .hero-trust-strip {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.35rem 0.65rem;
	margin: 0.35rem auto 0.85rem;
	padding: 0.45rem 0.95rem;
	max-width: 38rem;
	border-radius: 999px;
	font-family: var(--fuente-interfaz);
	font-size: var(--adcr-type-trust, clamp(0.86rem, 2vw, 0.95rem));
	font-weight: 600;
	line-height: 1.35;
	color: #fff;
	background: rgba(15, 22, 38, 0.42);
	border: 1px solid rgba(255, 255, 255, 0.28);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.18);
	text-align: center;
}

.portada-root .hero-trust-strip__item--accent {
	color: #f0df9a;
	text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
}

.portada-root .hero-trust-strip__sep {
	color: rgba(255, 255, 255, 0.55);
	font-weight: 500;
}

/*
 * Móvil (p. ej. Galaxy S20, 360×800): el hero global usa altura muy baja y el CTA secundario
 * (solo borde) pierde contraste sobre zonas claras del banner. Solo .portada-root — escritorio intacto.
 */
@media (max-width: 768px) {
	.portada-root .hero {
		height: auto;
		/* Menos «altillo» vacío; el peso visual lo lleva el H1, no los CTAs */
		min-height: clamp(21rem, 62vh, 30rem);
		box-sizing: border-box;
		padding-block: clamp(1.15rem, 4vw, 1.85rem);
		align-items: center;
	}

	.portada-root .hero-contenido {
		padding-bottom: clamp(0.75rem, 3vw, 1.35rem);
		text-align: center;
	}

	.portada-root .hero-overlay {
		background: rgba(18, 24, 38, 0.82);
	}

	/*
	 * Métricas / prueba social — no debe leerse como un tercer CTA (antes misma silueta píldora + 22rem que los botones).
	 * Estilo «caption»: banda rectangular suave, sin relieve de botón, tipografía editorial.
	 */
	.portada-root .hero-trust-strip {
		display: flex;
		flex-direction: column;
		flex-wrap: nowrap;
		align-items: stretch;
		justify-content: center;
		max-width: none;
		width: 100%;
		margin: 0.35rem 0 0.55rem;
		padding: 0.62rem 0.75rem;
		border-radius: 10px;
		border: 1px dashed rgba(255, 255, 255, 0.28);
		background: rgba(255, 255, 255, 0.055);
		box-shadow: none;
		font-size: clamp(0.76rem, 3.05vw, 0.85rem);
		font-weight: 500;
		line-height: 1.38;
		gap: 0.42rem;
		cursor: default;
	}

	.portada-root .hero-trust-strip__sep {
		display: none;
	}

	.portada-root .hero-trust-strip .hero-trust-strip__item {
		display: block;
		text-align: center;
	}

	.portada-root .hero-trust-strip__item--accent {
		color: rgba(232, 207, 122, 0.92);
		font-weight: 600;
		text-shadow: none;
		font-variant-numeric: tabular-nums;
	}

	/* CTAs del hero: área táctil mínima 44px, tipografía menor que el H1 */
	.portada-root .hero .boton-principal {
		display: inline-flex;
		margin-top: 0.35rem;
		font-size: clamp(0.875rem, 3.6vw, 0.9375rem);
		font-weight: 600;
		line-height: 1.25;
		padding: 0.5rem 1rem;
		min-height: 44px;
		box-sizing: border-box;
		border-width: 1px;
		align-items: center;
		justify-content: center;
	}

	.portada-root .hero .boton-principal--secundario {
		background: rgba(15, 20, 34, 0.94);
		border: 2px solid rgba(255, 255, 255, 0.98);
		color: #fff;
		font-weight: 600;
		min-height: 44px;
		box-shadow:
			0 2px 0 rgba(255, 255, 255, 0.06) inset,
			0 6px 18px rgba(0, 0, 0, 0.38);
		text-shadow: 0 1px 3px rgba(0, 0, 0, 0.55);
	}

	.portada-root .hero .boton-principal--secundario:hover,
	.portada-root .hero .boton-principal--secundario:focus-visible {
		background: rgba(35, 42, 62, 0.98);
		color: #fff;
		border-color: #fff;
	}

	.portada-root .hero .boton-principal:not(.boton-principal--secundario) {
		box-shadow: 0 6px 22px rgba(0, 0, 0, 0.28);
	}

	/* CTAs hero: columna centrada (antes solo ≤540px) */
	.portada-root .hero-botones--dual,
	.portada-root .hero-botones--extra {
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}

	.portada-root .hero-botones--dual .boton-principal,
	.portada-root .hero-botones--extra .boton-principal {
		width: min(100%, 22rem);
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
		text-align: center;
	}
}

/* Secciones auditoría */
.portada-precios,
.portada-cobertura,
.portada-empresas {
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}

.portada-precios {
	background: #fff;
}

.portada-cobertura {
	background: #f6f8fb;
	color: var(--color-texto-oscuro, #1d263b);
}

.portada-empresas {
	background: linear-gradient(135deg, #1d263b 0%, #243352 100%);
	color: #fff;
}

.portada-empresas .portada-seccion-titulo {
	color: #fff;
}

.portada-empresas-inner {
	max-width: 1060px;
}

.portada-empresas-list {
	margin: 1rem 0 1.25rem;
	padding-left: 1.25rem;
}

.portada-empresas-list li {
	margin-bottom: 0.35rem;
}

.portada-empresas .boton-principal {
	margin-top: 0.25rem;
}

.portada-seccion-titulo {
	font-family: var(--fuente-titulos);
	font-size: clamp(1.35rem, 3vw, 1.75rem);
	font-weight: 400;
	text-align: center;
	margin: 0 0 0.75rem;
	color: var(--color-texto-oscuro, #1d263b);
}

.portada-seccion-intro {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 1.5rem;
	line-height: 1.55;
	color: var(--color-texto-oscuro, #1d263b);
}

/* Portada: mini-FAQ y secciones audit — mismo peso de título que .portada-seccion-titulo */
.portada-root .servicios-acf--optimized .adcr-home-mini-faq__title {
	font-family: var(--fuente-titulos);
	font-size: clamp(1.35rem, 3vw, 1.75rem);
	font-weight: 400;
	line-height: 1.25;
	color: var(--color-texto-oscuro, #1d263b);
}

.portada-precios-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 16px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.portada-precios-card {
	position: relative;
	border: 1px solid rgba(29, 38, 59, 0.12);
	border-radius: 8px;
	padding: 1.1rem 1rem;
	background: #fafbfd;
	box-shadow: 0 4px 18px rgba(29, 38, 59, 0.06);
	transition:
		box-shadow 0.2s ease,
		transform 0.2s ease;
}

@media (hover: hover) {
	.portada-precios-card:hover {
		box-shadow: 0 10px 28px rgba(29, 38, 59, 0.1);
		transform: translateY(-2px);
	}
}

.portada-precios-card-tit {
	font-family: var(--fuente-interfaz);
	font-size: 1rem;
	font-weight: 600;
	margin: 0 0 0.35rem;
	color: #1d263b;
}

.portada-precios-card-precio {
	font-size: 1.35rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--color-principal, #2e7d32);
}

.portada-precios-card-nota {
	font-size: 0.9rem;
	line-height: 1.45;
	margin: 0;
	color: var(--adcr-text-muted-on-light, #4a5568);
}

.portada-precios-card--featured {
	border: 2px solid #c9a347;
	background: linear-gradient(165deg, #fffdf8 0%, #fafbfd 100%);
	box-shadow:
		0 6px 24px rgba(201, 163, 71, 0.18),
		0 4px 14px rgba(29, 38, 59, 0.06);
	padding-top: 2.15rem;
}

.portada-precios-card-badge {
	position: absolute;
	top: 0.65rem;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--fuente-interfaz);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #5c4a1a;
	background: linear-gradient(180deg, #f0e6c8 0%, #e6d9a8 100%);
	padding: 0.28rem 0.65rem;
	border-radius: 999px;
	border: 1px solid rgba(201, 163, 71, 0.65);
	white-space: nowrap;
}

.portada-precios-card--featured .portada-precios-card-tit {
	margin-top: 0.45rem;
}

.portada-precios-card--featured .portada-precios-card-precio {
	color: #1d263b;
	font-size: 1.45rem;
}

.portada-cobertura-lista li + li {
	margin-top: 0.5rem;
}

/* Formulario portada: bloque opcional colapsable */
.adcr-reserva-form--portada .adcr-form-more {
	grid-column: 1 / -1;
	border: 1px solid rgba(29, 38, 59, 0.15);
	border-radius: 8px;
	padding: 0.25rem 0.75rem 0.75rem;
	margin-top: 0.25rem;
	background: rgba(246, 248, 251, 0.65);
}

.adcr-reserva-form--portada .adcr-form-more-summary {
	cursor: pointer;
	font-weight: 600;
	padding: 0.65rem 0.25rem;
	list-style: none;
	font-family: var(--fuente-interfaz);
	color: #1d263b;
}

.adcr-reserva-form--portada .adcr-form-more-summary::-webkit-details-marker {
	display: none;
}

.adcr-reserva-form--portada .adcr-form-more-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	padding-top: 0.35rem;
}

/*
 * Bloque «servicios» Inicio (optimizado): ancho de .contenedor, rejilla tipo portada-precios,
 * barra B2C/B2B al estilo portada-empresas, FAQ en columnas en escritorio.
 */
.servicios-inicio--optimized {
	background: linear-gradient(180deg, #ffffff 0%, #f6f8fb 55%, #ffffff 100%);
}

.servicios-inicio--optimized .servicios-acf--optimized {
	text-align: left;
}

.servicios-inicio--optimized .servicios-inicio-stack {
	width: 100%;
	max-width: none;
	margin: 0;
}

.portada-root .servicios-acf--optimized .servicios-inicio-layout {
	display: grid;
	gap: clamp(1.35rem, 3vw, 2rem);
	align-items: stretch;
}

/* Tablet portrait + escritorio: lead | oferta en dos columnas (≥769). ≤768 permanece apilado vía cascada base. */
@media (min-width: 769px) {
	.portada-root .servicios-acf--optimized .servicios-inicio-layout {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: clamp(1.5rem, 3vw, 2.25rem);
		align-items: stretch;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-layout__lead {
		display: flex;
		flex-direction: column;
		min-height: 100%;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-lead-panel {
		flex: 1;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	@media (prefers-reduced-motion: no-preference) {
		.portada-root .servicios-acf--optimized .servicios-inicio-layout__lead {
			animation: adcr-servicios-enter 0.55s cubic-bezier(0.22, 1, 0.36, 1) both;
		}

		.portada-root .servicios-acf--optimized .servicios-inicio-layout__offer {
			animation: adcr-servicios-enter 0.55s cubic-bezier(0.22, 1, 0.36, 1) 0.07s both;
		}
	}
}

@keyframes adcr-servicios-enter {
	from {
		opacity: 0;
		transform: translateY(12px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Lead: peso visual fuerte, mismo lenguaje que portada-precios */
.portada-root .servicios-acf--optimized .servicios-inicio-lead-panel {
	position: relative;
	padding: clamp(1.35rem, 3vw, 1.85rem) clamp(1.25rem, 3vw, 1.75rem);
	border-radius: 10px;
	border: 1px solid rgba(29, 38, 59, 0.1);
	background: #fafbfd;
	box-shadow: 0 8px 28px rgba(29, 38, 59, 0.06);
	overflow: hidden;
}

.portada-root .servicios-acf--optimized .servicios-inicio-lead-panel::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	background: linear-gradient(180deg, var(--color-principal, #2ecc71), var(--color-h2, #2c3767));
}

.portada-root .servicios-acf--optimized .servicios-inicio-lead {
	margin: 0;
	padding-left: 0.35rem;
	text-align: left;
	font-size: clamp(1.08rem, 2.4vw, 1.28rem);
	line-height: 1.62;
	font-weight: 400;
	color: var(--color-texto, #2c3767);
}

.portada-root .servicios-acf--optimized .servicios-inicio-lead strong {
	font-weight: 700;
	color: var(--color-h2, #2c3767);
}

.portada-root .servicios-acf--optimized .servicios-inicio-inline-link {
	font-weight: 700;
	color: var(--color-h2, #2c3767);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
	text-decoration-color: rgba(46, 204, 113, 0.55);
	transition: color 0.15s ease, text-decoration-color 0.15s ease;
}

.portada-root .servicios-acf--optimized .servicios-inicio-inline-link:hover,
.portada-root .servicios-acf--optimized .servicios-inicio-inline-link:focus-visible {
	color: var(--color-principal, #2ecc71);
	text-decoration-color: var(--color-principal, #2ecc71);
}

.portada-root .servicios-acf--optimized .servicios-inicio-lead-actions {
	margin: 1.15rem 0 0;
	padding-top: 1rem;
	border-top: 1px solid rgba(29, 38, 59, 0.08);
}

.portada-root .servicios-acf--optimized .servicios-inicio-wa-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	max-width: 100%;
	padding: 0.55rem 1.15rem;
	border-radius: var(--adcr-radius-cta, 999px);
	font-family: var(--fuente-interfaz);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.25;
	text-decoration: none;
	color: #fff;
	background: var(--color-principal, #2ecc71);
	border: 2px solid transparent;
	box-shadow: 0 3px 12px rgba(46, 204, 113, 0.35);
	transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.portada-root .servicios-acf--optimized .servicios-inicio-wa-btn:hover,
.portada-root .servicios-acf--optimized .servicios-inicio-wa-btn:focus-visible {
	background: #27ae60;
	box-shadow: 0 5px 18px rgba(46, 204, 113, 0.4);
	color: #fff;
}

.portada-root .servicios-acf--optimized .servicios-inicio-wa-btn:focus-visible {
	outline: 2px solid var(--color-h2, #2c3767);
	outline-offset: 3px;
}

/* Color de enlace global del bloque servicios no debe oscurecer el botón WhatsApp */
.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-lead-panel a.servicios-inicio-wa-btn {
	color: #fff;
}

.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-lead-panel a.servicios-inicio-wa-btn:hover,
.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-lead-panel a.servicios-inicio-wa-btn:focus-visible {
	color: #fff;
}

/* Oferta: grid 2×2 uniforme + badge cobertura */
.portada-root .servicios-acf--optimized .servicios-inicio-offer-head {
	margin-bottom: 1rem;
	padding-bottom: 0.65rem;
	border-bottom: 2px solid rgba(201, 163, 71, 0.45);
}

.portada-root .servicios-acf--optimized .servicios-inicio-layout__offer .servicios-inicio-sub {
	margin: 0;
	font-family: var(--fuente-interfaz);
	font-size: clamp(1.05rem, 2.2vw, 1.22rem);
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: -0.02em;
	color: var(--color-h2, #2c3767);
	text-align: left;
}

.portada-root .servicios-acf--optimized .servicios-inicio-grid-2x2 {
	display: grid;
	grid-template-columns: 1fr;
	grid-auto-rows: 1fr;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 560px) {
	.portada-root .servicios-acf--optimized .servicios-inicio-grid-2x2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: clamp(12px, 2.2vw, 16px);
	}
}

/* Lista legada del tema añade ✓ vía ::before y margen inferior al <li>; anulado en el grid optimizado */
.portada-root .servicios-acf--optimized .servicios-inicio-grid-2x2 > li.servicios-inicio-tile {
	margin: 0;
}

.portada-root .servicios-acf--optimized .servicios-inicio-grid-2x2 > li.servicios-inicio-tile::before {
	content: none;
	display: none;
}

.portada-root .servicios-acf--optimized .servicios-inicio-tile {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	min-height: 0;
	margin: 0;
	padding: clamp(1.05rem, 2.8vw, 1.35rem) clamp(0.95rem, 2.5vw, 1.2rem);
	box-sizing: border-box;
	border-radius: 12px;
	border: 1px solid rgba(29, 38, 59, 0.1);
	background: #fff;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.92) inset,
		0 6px 20px rgba(29, 38, 59, 0.06);
	transition:
		transform 0.2s ease,
		box-shadow 0.2s ease,
		border-color 0.2s ease;
}

.portada-root .servicios-acf--optimized .servicios-inicio-tile__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.7rem;
	flex: 1 1 auto;
	min-height: 0;
}

.portada-root .servicios-acf--optimized .servicios-inicio-tile__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 3.25rem;
	height: 3.25rem;
	border-radius: 11px;
	color: #1d263b;
	background: linear-gradient(165deg, rgba(201, 163, 71, 0.18) 0%, rgba(201, 163, 71, 0.09) 100%);
	border: 1px solid rgba(201, 163, 71, 0.32);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset;
}

.portada-root .servicios-acf--optimized .servicios-inicio-tile__icon svg {
	display: block;
	width: 26px;
	height: 26px;
	margin: auto;
}

.portada-root .servicios-acf--optimized .servicios-inicio-tile__text {
	display: block;
	width: 100%;
	margin: 0;
	font-family: var(--fuente-interfaz);
	font-size: clamp(0.9rem, 1.85vw, 0.98rem);
	line-height: 1.45;
	font-weight: 600;
	color: #1d263b;
	letter-spacing: -0.01em;
}

/* Sobrescribe reglas globales `.servicios-inicio .servicios-prod-cuerpo ul li span` (peso 300, inline) */
.portada-root .servicios-acf--optimized .servicios-inicio-tile__inner .servicios-inicio-tile__text {
	font-weight: 600;
	line-height: 1.45;
}

@media (hover: hover) {
	.portada-root .servicios-acf--optimized .servicios-inicio-tile:hover {
		transform: translateY(-2px);
		border-color: rgba(201, 163, 71, 0.45);
		box-shadow: 0 10px 26px rgba(29, 38, 59, 0.09);
	}
}

@media (prefers-reduced-motion: reduce) {
	.portada-root .servicios-acf--optimized .servicios-inicio-tile {
		transition: none;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile:hover {
		transform: none;
	}
}

.portada-root .servicios-acf--optimized .servicios-inicio-coverage-badge {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-top: 0.85rem;
	padding: 0.85rem 1.1rem;
	border-radius: 10px;
	border: 1px dashed rgba(29, 38, 59, 0.22);
	background: rgba(246, 248, 251, 0.95);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.portada-root .servicios-acf--optimized .servicios-inicio-coverage-badge__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	color: var(--color-h2, #2c3767);
	background: rgba(44, 55, 103, 0.08);
}

.portada-root .servicios-acf--optimized .servicios-inicio-coverage-badge__text {
	margin: 0;
	font-family: var(--fuente-interfaz);
	font-size: 0.98rem;
	font-weight: 600;
	line-height: 1.45;
	color: var(--color-h2, #2c3767);
	text-align: left;
}

/* Barra CTA: fondo azul profundo sin verde; acento en botón dorado */
.servicios-inicio--optimized .servicios-inicio-trust-bar {
	margin-top: clamp(1.25rem, 3.2vw, 1.75rem);
	padding: clamp(1.35rem, 3.5vw, 1.85rem) clamp(1.25rem, 3vw, 2rem);
	border-radius: 10px;
	background: linear-gradient(145deg, #171e2e 0%, #1f2d45 48%, #1a2438 100%);
	color: #fff;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1.25rem 1.5rem;
	box-shadow: 0 12px 36px rgba(15, 20, 32, 0.35);
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.servicios-inicio--optimized .servicios-inicio-trust-bar__copy {
	flex: 1 1 240px;
	text-align: left;
	min-width: min(100%, 280px);
}

.servicios-inicio--optimized .servicios-inicio-trust-bar__actions {
	flex: 1 1 280px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.75rem 1rem;
}

.servicios-inicio--optimized .servicios-inicio-social {
	margin: 0 0 0.45rem;
	font-family: var(--fuente-interfaz);
	font-size: clamp(1rem, 2.2vw, 1.12rem);
	font-weight: 600;
	line-height: 1.45;
	color: #fff;
	text-shadow: 0 1px 14px rgba(0, 0, 0, 0.35);
}

/* Métricas en líneas separadas (misma fuente que brand-stats.php) */
.servicios-inicio--optimized .servicios-inicio-social--metrics {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.35rem 1.15rem;
	margin: 0 0 0.45rem;
}

.servicios-inicio--optimized .servicios-inicio-social--metrics .servicios-inicio-social__line {
	margin: 0;
	font-family: var(--fuente-interfaz);
	font-size: clamp(1rem, 2.2vw, 1.12rem);
	font-weight: 600;
	line-height: 1.45;
	color: #fff;
	text-shadow: 0 1px 14px rgba(0, 0, 0, 0.35);
}

.servicios-inicio--optimized .servicios-inicio-cta-caption {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 400;
}

/*
 * Barra CTA: CTA principal dorado (sin verde chillón); outline blanco para B2B.
 * `.servicios-inicio .servicios-prod-cuerpo a` fuerza color oscuro — subir especificidad.
 */
.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 0;
	padding: 11px 22px;
	border-radius: var(--adcr-radius-cta, 999px);
	font-family: var(--fuente-interfaz);
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.25;
	text-align: center;
	text-decoration: none;
	color: #1c2136;
	background: linear-gradient(180deg, #e3cf7c 0%, #c9a347 55%, #b8923a 100%);
	border: 1px solid rgba(255, 255, 255, 0.22);
	box-shadow: 0 4px 18px rgba(0, 0, 0, 0.28);
	transition: filter 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold:hover,
.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold:focus-visible {
	color: #141a2e;
	filter: brightness(1.05);
	box-shadow: 0 6px 22px rgba(0, 0, 0, 0.32);
}

.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.9);
	outline-offset: 3px;
}

.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.boton-principal.servicios-inicio-boton-cta--outline {
	margin-top: 0;
	text-align: center;
	background: transparent;
	color: #fff;
	border: 2px solid rgba(255, 255, 255, 0.92);
	font-weight: 400;
	border-radius: var(--adcr-radius-cta, 999px);
}

.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.boton-principal.servicios-inicio-boton-cta--outline:hover,
.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.boton-principal.servicios-inicio-boton-cta--outline:focus-visible {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	font-weight: 700;
}

@media (max-width: 768px) {
	.servicios-inicio--optimized .servicios-inicio-trust-bar__actions {
		justify-content: center;
		align-items: center;
		flex-wrap: nowrap;
		flex-direction: column;
		width: 100%;
		min-width: 0;
	}

	.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold,
	.servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.boton-principal.servicios-inicio-boton-cta--outline {
		flex: none;
		width: min(100%, 22rem);
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
		box-sizing: border-box;
		white-space: normal;
		word-break: break-word;
		display: flex;
		align-items: center;
		justify-content: center;
		text-align: center;
	}
}

/* FAQ: acordeón (<details>); ≥641px el script abre todos → lectura tipo tarjetas en rejilla */
.portada-root .servicios-acf--optimized .adcr-home-mini-faq {
	margin: clamp(1.75rem, 4vw, 2.5rem) 0 0;
	padding: 0;
	border: none;
	background: transparent;
	text-align: center;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__title {
	margin: 0 0 1.1rem;
	text-align: center;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__dl {
	margin: 0;
	display: grid;
	gap: 1rem;
	text-align: left;
}

@media (min-width: 640px) {
	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__dl {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		align-items: stretch;
		gap: 1rem 1.15rem;
	}
}

.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item {
	margin: 0;
	height: 100%;
	border-radius: 10px;
	border: 1px solid rgba(29, 38, 59, 0.1);
	background: #fff;
	box-shadow: 0 6px 22px rgba(29, 38, 59, 0.06);
	transition:
		box-shadow 0.2s ease,
		border-color 0.2s ease;
	overflow: hidden;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.65rem;
	padding: 1rem 1rem 1rem 1.05rem;
	list-style: none;
	cursor: pointer;
	font: inherit;
	text-align: left;
	color: inherit;
	user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary::-webkit-details-marker {
	display: none;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary::marker {
	content: '';
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary::after {
	content: '';
	flex-shrink: 0;
	width: 0.55rem;
	height: 0.55rem;
	margin-top: 0.1rem;
	border-right: 2px solid rgba(29, 38, 59, 0.45);
	border-bottom: 2px solid rgba(29, 38, 59, 0.45);
	transform: rotate(45deg);
	transition: transform 0.2s ease;
}

.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__summary::after {
	transform: rotate(-135deg);
	margin-top: 0.28rem;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary .adcr-home-mini-faq__q {
	flex: 1 1 auto;
	min-width: 0;
}

@media (hover: hover) {
	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item:hover {
		border-color: rgba(201, 163, 71, 0.45);
		box-shadow: 0 12px 32px rgba(29, 38, 59, 0.1);
	}

	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item .adcr-home-mini-faq__summary:hover {
		background: rgba(246, 248, 251, 0.55);
	}
}

@media (prefers-reduced-motion: reduce) {
	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item {
		transition: none;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary::after {
		transition: none;
	}
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__q {
	font-family: var(--fuente-interfaz);
	font-size: 0.95rem;
	font-weight: 700;
	margin: 0;
	color: #1d263b;
	line-height: 1.35;
	display: block;
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__a {
	margin: 0;
	padding: 0 1.05rem 1.05rem;
	font-size: 0.91rem;
	line-height: 1.58;
	font-weight: 400;
	color: var(--color-texto-oscuro, #1d263b);
	border-top: 1px solid rgba(29, 38, 59, 0.06);
}

.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__a {
	animation: adcr-mini-faq-reveal 0.2s ease;
}

@media (prefers-reduced-motion: reduce) {
	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__a {
		animation: none;
	}
}

@keyframes adcr-mini-faq-reveal {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.portada-root .servicios-acf--optimized .adcr-home-mini-faq__p {
	margin: 0;
	padding-top: 0.65rem;
	font-size: inherit;
	line-height: inherit;
	font-weight: inherit;
	color: inherit;
}

@media (min-width: 641px) {
	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__summary::after {
		opacity: 0.35;
	}

	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__summary {
		cursor: default;
		padding-bottom: 0.55rem;
	}

	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__a {
		border-top: none;
		padding-top: 0;
	}

	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item[open] .adcr-home-mini-faq__p {
		padding-top: 0;
	}
}

/* Por qué elegirnos — grid 2×2 en portada */
.portada-root .seccion-beneficios--portada-grid .portada-beneficios-wrap {
	max-width: 920px;
	margin: 0 auto;
}

.portada-root .seccion-beneficios--portada-grid .portada-beneficios__title {
	text-align: center;
	margin: 0 0 clamp(1.75rem, 4vw, 2.5rem);
}

.portada-root .portada-beneficios-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 2.8vw, 1.35rem);
	list-style: none;
	margin: 0;
	padding: 0;
}

@media (min-width: 640px) {
	.portada-root .portada-beneficios-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.25rem 1.35rem;
	}
}

.portada-root .portada-beneficio-card {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	padding: 1.35rem 1.2rem;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: 0 10px 32px rgba(0, 0, 0, 0.12);
}

.portada-root .portada-beneficio-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 3.1rem;
	height: 3.1rem;
	border-radius: 12px;
	font-size: 1.15rem;
	font-weight: 800;
	color: #fff;
	background: rgba(201, 163, 71, 0.25);
	border: 1px solid rgba(232, 207, 122, 0.45);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.portada-root .portada-beneficio-card__title {
	display: block;
	font-family: var(--fuente-interfaz);
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 0.35rem;
	color: #fff;
}

.portada-root .portada-beneficio-card__text {
	margin: 0;
	font-size: 0.96rem;
	line-height: 1.55;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.88);
}

/* Pie: redes más legibles */
.sitio-footer .footer-barra-inferior .red-social {
	width: 46px;
	height: 46px;
}

.sitio-footer .footer-barra-inferior .red-social svg {
	width: 22px;
	height: 22px;
}

/* Home v2: flujo operativo, requisitos, cobertura mapa y B2B cards */
.portada-como-funciona,
.portada-requisitos {
	padding: clamp(2rem, 5vw, 3.5rem) 0;
}

.portada-como-funciona {
	background: #fff;
}

.portada-requisitos {
	background: #f6f8fb;
}

.portada-pasos-grid,
.portada-requisitos-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
	gap: 14px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.portada-paso-item,
.portada-requisitos-grid li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.95rem 1rem;
	border: 1px solid rgba(29, 38, 59, 0.1);
	border-radius: 10px;
	background: #fff;
}

.portada-paso-item p {
	margin: 0;
	line-height: 1.5;
}

.portada-paso-num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.8rem;
	height: 1.8rem;
	border-radius: 50%;
	background: #1d263b;
	color: #fff;
	font-weight: 700;
	font-size: 0.86rem;
	flex-shrink: 0;
}

.portada-requisitos-grid li span {
	font-size: 1.2rem;
	line-height: 1;
}

.portada-requisitos-grid li strong {
	font-family: var(--fuente-interfaz);
	font-weight: 600;
	line-height: 1.4;
}

.portada-cobertura-grid {
	display: grid;
	gap: clamp(1rem, 2.5vw, 1.4rem);
	align-items: start;
}

@media (min-width: 900px) {
	.portada-cobertura-grid {
		grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
		align-items: center;
	}

	.portada-cobertura-mapa {
		max-width: min(540px, 100%);
		margin-inline: auto;
	}

	.portada-cobertura-lista {
		max-width: 46ch;
		align-self: center;
	}
}

.portada-cobertura-mapa {
	border: 1px solid rgba(29, 38, 59, 0.12);
	border-left: 4px solid #c9a347;
	border-radius: 14px;
	background: #fff;
	padding: clamp(0.5rem, 1.25vw, 0.78rem);
	box-shadow: 0 10px 28px rgba(29, 38, 59, 0.1);
}

.portada-cobertura-mapa svg {
	width: 100%;
	height: auto;
	display: block;
}

.portada-cobertura-mapa img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 12px;
	vertical-align: middle;
}

.portada-cobertura-lista {
	margin: 0;
	padding: clamp(1rem, 2.5vw, 1.35rem) clamp(1rem, 2.5vw, 1.25rem);
	border: 1px solid rgba(29, 38, 59, 0.1);
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 6px 20px rgba(29, 38, 59, 0.06);
	color: var(--color-texto-oscuro, #1d263b);
	line-height: 1.6;
}

.portada-root .portada-cobertura .portada-cobertura-lista.entry-content,
.portada-root .portada-cobertura .portada-cobertura-lista.entry-content p,
.portada-root .portada-cobertura .portada-cobertura-lista.entry-content li {
	color: var(--color-texto-oscuro, #1d263b);
	font-weight: 400;
}

.portada-cobertura-lista > * {
	margin-top: 0;
}

.portada-cobertura-lista p {
	margin: 0 0 0.8rem;
	font-size: clamp(0.94rem, 1.32vw, 1rem);
	line-height: 1.65;
}

.portada-cobertura-lista ul {
	margin: 0 0 0.9rem;
	padding-left: 0.05rem;
	list-style: none;
}

.portada-cobertura-lista li {
	position: relative;
	padding-left: 1.45rem;
	margin: 0 0 0.4rem;
}

.portada-cobertura-lista li::before {
	content: '✓';
	position: absolute;
	left: 0;
	top: 0.04rem;
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--color-h2, #2c3767);
}

.portada-cobertura-lista p:last-child,
.portada-cobertura-lista ul:last-child {
	margin-bottom: 0;
}

.portada-empresas-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: clamp(12px, 2.5vw, 18px);
	margin: 1rem 0 1.5rem;
}

.portada-empresas-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.5rem;
	padding: 1.35rem 1.15rem 1.25rem;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.07);
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12);
}

.portada-empresas-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 3rem;
	height: 3rem;
	margin: 0 0 0.15rem;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.11);
	border: 1px solid rgba(255, 255, 255, 0.2);
	font-size: 1.45rem;
	line-height: 1;
}

.portada-empresas-card h3 {
	margin: 0;
	font-size: 1.02rem;
	font-family: var(--fuente-interfaz);
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.01em;
}

.portada-empresas-card p {
	margin: 0;
	font-size: 0.94rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.82);
}

.portada-empresas-logos {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 1.25rem 1.5rem;
	padding: 1rem 0 0.25rem;
	margin: 0 0 1.25rem;
	border: none;
	min-height: 0;
}

.portada-empresas-logos__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 1rem 1.25rem;
	width: 100%;
}

.portada-empresas-logos__item {
	margin: 0;
	padding: 0;
}

.portada-empresas-logos__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.portada-empresas-logos__img {
	display: block;
	max-height: 36px;
	width: auto;
	max-width: 120px;
	object-fit: contain;
	opacity: 0.92;
}

.portada-empresas-cta {
	margin: 0;
	text-align: center;
}

.portada-empresas-cta .boton-principal {
	margin-top: 0;
	border-radius: var(--adcr-radius-cta, 999px);
}

/* CTAs portada — <dialog> nativo */
.adcr-modal {
	max-width: calc(100vw - 2rem);
	width: min(440px, 100%);
	padding: 0;
	border: none;
	background: transparent;
	color: inherit;
}

.adcr-modal::backdrop {
	background: rgba(13, 18, 28, 0.62);
	backdrop-filter: blur(3px);
}

.adcr-modal__panel {
	position: relative;
	padding: 1.75rem 1.5rem 1.5rem;
	border-radius: 14px;
	background: #fafbfd;
	border: 1px solid rgba(29, 38, 59, 0.12);
	box-shadow: 0 24px 56px rgba(15, 20, 32, 0.35);
	color: #1d263b;
}

.adcr-modal__close {
	position: absolute;
	top: 0.65rem;
	right: 0.65rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 8px;
	background: rgba(29, 38, 59, 0.06);
	color: #1d263b;
	font-size: 1.35rem;
	line-height: 1;
	cursor: pointer;
}

.adcr-modal__close:hover,
.adcr-modal__close:focus-visible {
	background: rgba(29, 38, 59, 0.12);
	outline: 2px solid rgba(201, 163, 71, 0.55);
	outline-offset: 2px;
}

.adcr-modal__title {
	margin: 0 2rem 0.65rem 0;
	font-family: var(--fuente-interfaz);
	font-size: 1.22rem;
	font-weight: 700;
	line-height: 1.25;
	color: #1d263b;
}

.adcr-modal__lead {
	margin: 0 0 1.25rem;
	font-size: 0.96rem;
	line-height: 1.55;
	color: rgba(29, 38, 59, 0.85);
}

.adcr-modal__actions {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.adcr-modal__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.72rem 1.15rem;
	border-radius: var(--adcr-radius-cta, 999px);
	font-family: var(--fuente-interfaz);
	font-size: 1rem;
	font-weight: 700;
	text-decoration: none;
	text-align: center;
	border: 1px solid transparent;
	transition:
		filter 0.15s ease,
		background 0.15s ease,
		color 0.15s ease;
}

.adcr-modal__btn--wa,
.adcr-modal__btn--primary {
	color: #1c2136;
	background: linear-gradient(180deg, #e3cf7c 0%, #c9a347 58%, #b8923a 100%);
	border-color: rgba(255, 255, 255, 0.22);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
}

.adcr-modal__btn--outline {
	background: #fff;
	color: #1d263b;
	border-color: rgba(29, 38, 59, 0.18);
	font-weight: 600;
}

.adcr-modal__btn--outline:hover,
.adcr-modal__btn--outline:focus-visible {
	border-color: rgba(201, 163, 71, 0.65);
}

@media (min-width: 480px) {
	.adcr-modal__actions {
		flex-direction: row;
		flex-wrap: wrap;
	}

	.adcr-modal__btn {
		flex: 1 1 calc(50% - 0.35rem);
		min-width: 140px;
	}
}

/* Modal CTAs: fila centrada en tablets estrechas; botones acotados en pantallas muy pequeñas */
@media (max-width: 768px) {
	.adcr-modal__actions {
		justify-content: center;
		align-items: center;
	}
}

@media (max-width: 479px) {
	.adcr-modal__btn {
		width: min(100%, 22rem);
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
		box-sizing: border-box;
	}
}

/*
 * Portada Inicio — móvil (≤768): ritmo vertical, safe-area, legibilidad y CTAs táctiles.
 * Todo bajo .portada-root; escritorio sin cambios.
 */
@media (max-width: 768px) {
	/*
	 * Tipografía portada: alineada con style.css :root (≤768) — hero > H2 sección > H3 FAQ > lead > cuerpo.
	 */
	.portada-root .servicios-acf--optimized .servicios-inicio-lead {
		font-size: var(--tamano-lead);
		line-height: 1.62;
	}

	/*
	 * Safe-area en bloques con .contenedor directo. Excluye .servicios-inicio: ahí el tema pone
	 * el padding en la sección y deja el .contenedor interior sin márgenes laterales.
	 */
	.portada-root section:not(.servicios-inicio) > .contenedor {
		padding-left: max(1.25rem, env(safe-area-inset-left, 0px));
		padding-right: max(1.25rem, env(safe-area-inset-right, 0px));
	}

	.portada-root h2.portada-seccion-titulo,
	.portada-root h2#adcr-heading-servicios-inicio {
		scroll-margin-top: 5.5rem;
	}

	/* Título largo bajo header sticky: un poco más de offset al anclar */
	.portada-root h2#adcr-heading-beneficios {
		scroll-margin-top: 6.5rem;
	}

	/* H1 por encima de CTAs y de cualquier H2 de sección (--tamano-h2 máx. 1.5rem); tope 2rem en hero */
	.portada-root .hero .hero-titulo-h1.text-align-center {
		font-size: clamp(1.75rem, 5.65vw, 2rem);
		line-height: 1.13;
		letter-spacing: -0.025em;
		margin-bottom: 0.45rem;
		max-width: min(22rem, 100%);
	}

	.portada-root .hero .hero-subtitulo,
	.portada-root .hero .hero-subtitulo p {
		max-width: min(26rem, 100%);
		margin-left: auto;
		margin-right: auto;
		line-height: 1.58;
		font-size: var(--tamano-lead);
	}

	.portada-root .hero-botones--dual {
		gap: 0.55rem;
		margin-top: 0.55rem;
	}

	.portada-root .hero-botones--extra {
		margin-top: 0.55rem;
	}

	.portada-root .hero-botones--extra .boton-principal {
		font-size: clamp(0.82rem, 3.4vw, 0.9rem);
		min-height: 44px;
		padding: 0.45rem 0.85rem;
		margin-top: 0.35rem;
	}

	.portada-root .servicios-inicio {
		padding-top: clamp(2.65rem, 8vw, 3.75rem);
		padding-bottom: clamp(2.45rem, 7vw, 3.5rem);
		padding-left: clamp(1rem, 4vw, 2rem);
		padding-right: clamp(1rem, 4vw, 2rem);
		min-width: 0;
	}

	.portada-root .servicios-inicio .servicios-acf--optimized {
		min-width: 0;
		max-width: 100%;
	}

	.portada-root .servicios-prod-titulo .servicios-titulo {
		line-height: 1.22;
		hyphens: auto;
		-webkit-hyphens: auto;
		padding-inline: 0.15rem;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-layout {
		gap: clamp(1.25rem, 4.2vw, 1.75rem);
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-lead-panel {
		padding: clamp(1.1rem, 4vw, 1.45rem) clamp(1rem, 3.5vw, 1.3rem);
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-lead-actions {
		margin-top: 0.95rem;
		padding-top: 0.8rem;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: center;
		text-align: center;
		gap: 0.5rem;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-wa-btn {
		width: min(100%, 22rem);
		margin-left: auto;
		margin-right: auto;
		justify-content: center;
		min-height: 48px;
		padding-block: 0.65rem;
		box-sizing: border-box;
	}

	/*
	 * Grid servicios: sin 1fr en filas (evita tarjetas tan altas como la más larga en móvil).
	 * Tarjetas en fila icono+texto = más densidad y menos scroll.
	 */
	.portada-root .servicios-acf--optimized .servicios-inicio-grid-2x2 {
		grid-auto-rows: auto;
		gap: 10px;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-offer-head {
		margin-bottom: 0.55rem;
		padding-bottom: 0.4rem;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-layout__offer .servicios-inicio-sub {
		font-size: var(--tamano-lead);
		line-height: 1.42;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile {
		padding: 0.62rem 0.72rem;
		border-radius: 10px;
		box-shadow:
			0 1px 0 rgba(255, 255, 255, 0.92) inset,
			0 4px 14px rgba(29, 38, 59, 0.06);
		align-items: stretch;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile__inner {
		flex-direction: row;
		align-items: center;
		justify-content: flex-start;
		text-align: left;
		gap: 0.72rem;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile__icon {
		width: 2.65rem;
		height: 2.65rem;
		border-radius: 10px;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile__icon svg {
		width: 22px;
		height: 22px;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile__text {
		font-size: var(--tamano-parrafo);
		line-height: 1.32;
		font-weight: 600;
		text-align: left;
		letter-spacing: -0.015em;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-tile__inner .servicios-inicio-tile__text {
		line-height: 1.32;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-trust-bar {
		flex-direction: column;
		align-items: stretch;
		flex-wrap: nowrap;
		text-align: center;
		gap: 0.95rem;
		padding: clamp(1.15rem, 4vw, 1.45rem) clamp(1rem, 3.5vw, 1.25rem);
		max-width: 100%;
		min-width: 0;
		box-sizing: border-box;
		border-color: rgba(255, 255, 255, 0.14);
		box-shadow:
			0 16px 44px rgba(10, 14, 26, 0.45),
			inset 0 1px 0 rgba(255, 255, 255, 0.06);
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-trust-bar__copy {
		flex: 0 1 auto;
		width: 100%;
		max-width: 100%;
		min-width: 0;
		text-align: center;
		display: flex;
		flex-direction: column;
		gap: 0.65rem;
	}

	/* Prueba social: más presencia; líneas apiladas; acento dorado en volumen */
	.portada-root .servicios-inicio--optimized .servicios-inicio-social--metrics {
		flex-direction: column;
		align-items: stretch;
		gap: 0.5rem;
		margin: 0;
		padding: 0.65rem 0.75rem;
		border-radius: 10px;
		background: rgba(255, 255, 255, 0.06);
		border: 1px solid rgba(255, 255, 255, 0.1);
		text-align: center;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-social--metrics .servicios-inicio-social__line {
		line-height: 1.35;
		max-width: 100%;
		white-space: normal;
		overflow-wrap: anywhere;
		word-break: break-word;
		hyphens: auto;
		-webkit-hyphens: auto;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-social--metrics .servicios-inicio-social__line--services {
		font-size: clamp(0.98rem, 4vw, 1.12rem);
		font-weight: 700;
		letter-spacing: -0.02em;
		color: #f4e8b8;
		text-shadow:
			0 1px 2px rgba(0, 0, 0, 0.45),
			0 0 24px rgba(244, 232, 184, 0.18);
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-social--metrics .servicios-inicio-social__line--businesses {
		font-size: clamp(0.92rem, 3.65vw, 1.04rem);
		font-weight: 600;
		color: rgba(255, 255, 255, 0.96);
		text-shadow: 0 2px 18px rgba(0, 0, 0, 0.42);
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-social:not(.servicios-inicio-social--metrics) {
		font-size: clamp(0.92rem, 3.65vw, 1.04rem);
		line-height: 1.38;
		margin: 0;
		max-width: 100%;
		white-space: normal;
		overflow-wrap: anywhere;
		word-break: break-word;
		hyphens: auto;
		-webkit-hyphens: auto;
		font-weight: 600;
		color: rgba(255, 255, 255, 0.98);
		text-shadow: 0 2px 16px rgba(0, 0, 0, 0.4);
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-cta-caption {
		font-size: 0.84rem;
		line-height: 1.48;
		margin: 0;
		max-width: 100%;
		padding: 0 0.15rem;
		opacity: 1;
		color: rgba(255, 255, 255, 0.88);
		font-weight: 500;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-trust-bar__actions {
		flex: none;
		width: 100%;
		max-width: 100%;
		min-width: 0;
		justify-content: center;
		flex-direction: column;
		align-items: center;
		flex-wrap: nowrap;
		gap: 0.55rem;
		padding-top: 0.15rem;
	}

	.portada-root .servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold,
	.portada-root .servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.boton-principal.servicios-inicio-boton-cta--outline {
		flex: none;
		width: min(100%, 22rem);
		max-width: 100%;
		min-width: 0;
		margin-left: auto;
		margin-right: auto;
		min-height: 46px;
		display: flex;
		align-items: center;
		justify-content: center;
		font-size: clamp(0.82rem, 3.35vw, 0.91rem);
		font-weight: 600;
		line-height: 1.3;
		padding: 0.52rem 0.85rem;
		box-sizing: border-box;
		white-space: normal;
		word-break: break-word;
		text-align: center;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-coverage-badge {
		margin-top: 0.65rem;
		/* Espacio para el FAB WhatsApp (~54px + márgenes del tema móvil) */
		padding: 0.52rem calc(0.65rem + 58px) 0.52rem 0.65rem;
		gap: 0.5rem;
		align-items: flex-start;
		box-sizing: border-box;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-coverage-badge__icon {
		width: 2rem;
		height: 2rem;
		flex-shrink: 0;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-coverage-badge__text {
		font-size: 0.78rem;
		line-height: 1.3;
		font-weight: 600;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq {
		margin-top: clamp(1.15rem, 4vw, 1.75rem);
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__dl {
		gap: 0.45rem;
	}

	.portada-root .servicios-acf--optimized details.adcr-home-mini-faq__item {
		box-shadow: 0 2px 10px rgba(29, 38, 59, 0.05);
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary {
		padding: 0.62rem 0.72rem 0.62rem 0.78rem;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary::after {
		width: 0.48rem;
		height: 0.48rem;
		border-width: 1.5px;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__q {
		font-size: var(--tamano-parrafo);
		line-height: var(--line-height-parrafo);
		font-weight: 700;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__a {
		font-size: clamp(0.9rem, 2.9vw, 0.97rem);
		line-height: var(--line-height-parrafo);
		padding: 0 0.78rem 0.58rem;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__p {
		padding-top: 0.4rem;
	}

	/*
	 * "Preguntas rápidas": por encima del acordeón (preguntas en DM Sans bold ~cuerpo);
	 * sin subirlo a H2 semántico: Alice, escala entre H3 y H2 + subrayado de anclaje visual.
	 */
	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__title {
		font-family: var(--fuente-titulos);
		font-size: clamp(1.28rem, 4.35vw, 1.48rem);
		line-height: 1.2;
		font-weight: 400;
		letter-spacing: -0.02em;
		color: #1d263b;
		padding: 0 0.35rem 0.65rem;
		margin: 0.2rem auto 0.95rem;
		max-width: min(20rem, 100%);
		border-bottom: 2px solid rgba(201, 163, 71, 0.5);
	}

	.portada-root .seccion-beneficios--portada-grid {
		padding-block: clamp(2rem, 7vw, 3rem);
		padding-top: max(2.5rem, env(safe-area-inset-top, 0px));
	}

	.portada-root .seccion-beneficios--portada-grid .portada-beneficios__title {
		font-family: var(--fuente-interfaz);
		font-weight: 700;
		font-size: var(--tamano-h2);
		line-height: var(--line-height-h2);
		letter-spacing: -0.02em;
		margin-bottom: 1rem;
		padding-inline: 0.35rem;
		max-width: 22rem;
		margin-left: auto;
		margin-right: auto;
	}

	/* Aire inferior para el FAB WhatsApp */
	.portada-root .portada-beneficios-grid {
		gap: 0.65rem;
		padding-bottom: calc(4.25rem + env(safe-area-inset-bottom, 0px));
	}

	.portada-root .portada-beneficio-card {
		align-items: center;
		gap: 0.72rem;
		padding: 0.68rem 0.82rem;
		border-radius: 14px;
		border: 1px solid rgba(255, 255, 255, 0.18);
		background: rgba(255, 255, 255, 0.078);
		box-shadow:
			0 1px 0 rgba(255, 255, 255, 0.07) inset,
			0 10px 28px rgba(0, 0, 0, 0.2);
	}

	.portada-root .portada-beneficio-card__body {
		min-width: 0;
		flex: 1 1 auto;
	}

	.portada-root .portada-beneficio-card__icon {
		width: 2.42rem;
		height: 2.42rem;
		border-radius: 10px;
		font-size: 0.92rem;
		font-weight: 700;
		color: #f0df9a;
		background: rgba(255, 255, 255, 0.07);
		border: 1px solid rgba(232, 207, 122, 0.38);
		box-shadow: none;
	}

	.portada-root .portada-beneficio-card__title {
		font-size: var(--tamano-h3);
		line-height: var(--line-height-h3);
		margin-bottom: 0.18rem;
	}

	.portada-root .portada-beneficio-card__text {
		font-size: var(--tamano-parrafo);
		line-height: var(--line-height-parrafo);
		font-weight: 500;
		color: rgba(255, 255, 255, 0.93);
	}

	.portada-root .portada-beneficio-card__text::first-letter {
		text-transform: uppercase;
	}

	.portada-root .portada-precios,
	.portada-root .portada-cobertura,
	.portada-root .portada-empresas,
	.portada-root .portada-como-funciona,
	.portada-root .portada-requisitos {
		padding-block: clamp(2.35rem, 8vw, 3.35rem);
	}

	.portada-root .portada-seccion-titulo {
		font-size: var(--tamano-h2);
		padding-inline: 0.35rem;
		line-height: var(--line-height-h2);
		letter-spacing: -0.015em;
	}

	.portada-root .portada-seccion-intro {
		font-size: var(--tamano-lead);
		padding-inline: 0.25rem;
		margin-bottom: clamp(1.2rem, 4vw, 1.65rem);
		line-height: 1.62;
	}

	.portada-root .portada-precios-grid {
		gap: clamp(12px, 3vw, 18px);
	}

	.portada-root .portada-pasos-grid,
	.portada-root .portada-requisitos-grid {
		grid-template-columns: 1fr;
		gap: clamp(14px, 3.5vw, 18px);
	}

	.portada-root .portada-paso-item,
	.portada-root .portada-requisitos-grid li {
		padding: clamp(1rem, 3.6vw, 1.25rem);
	}

	.portada-root .portada-paso-item p {
		line-height: 1.58;
	}

	.portada-root .portada-cobertura-grid {
		gap: 1.15rem;
	}

	.portada-root .portada-cobertura-mapa {
		padding: 0.45rem;
	}

	.portada-root .portada-empresas-cards {
		grid-template-columns: 1fr;
		gap: clamp(1rem, 4vw, 1.25rem);
		margin-top: 0.35rem;
		margin-bottom: 1.35rem;
	}

	.portada-root .portada-empresas .portada-seccion-titulo {
		font-family: var(--fuente-interfaz);
		font-weight: 700;
		font-size: var(--tamano-h2);
		line-height: var(--line-height-h2);
		letter-spacing: -0.02em;
		margin-bottom: 1rem;
		max-width: 22rem;
		margin-left: auto;
		margin-right: auto;
	}

	/*
	 * Empresas/flotas móvil: rejilla icono + texto (misma estructura HTML article > icon, h3, p).
	 */
	.portada-root .portada-empresas-card {
		display: grid;
		grid-template-columns: auto 1fr;
		grid-template-rows: auto auto;
		column-gap: 0.85rem;
		row-gap: 0.28rem;
		align-items: start;
		text-align: left;
		padding: 1rem 1rem 1.08rem;
		border-radius: 14px;
		border: 1px solid rgba(255, 255, 255, 0.28);
		background: rgba(255, 255, 255, 0.11);
		box-shadow:
			0 1px 0 rgba(255, 255, 255, 0.08) inset,
			0 10px 32px rgba(0, 0, 0, 0.22);
	}

	.portada-root .portada-empresas-card__icon {
		grid-column: 1;
		grid-row: 1 / -1;
		align-self: center;
		width: 3.35rem;
		height: 3.35rem;
		margin: 0;
		font-size: 1.65rem;
		border-radius: 14px;
		background: rgba(244, 232, 184, 0.14);
		border-color: rgba(244, 232, 184, 0.35);
		box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
	}

	.portada-root .portada-empresas-card h3 {
		grid-column: 2;
		grid-row: 1;
		margin: 0;
		font-size: var(--tamano-h3);
		line-height: var(--line-height-h3);
		text-align: left;
	}

	.portada-root .portada-empresas-card p {
		grid-column: 2;
		grid-row: 2;
		margin: 0;
		font-size: var(--tamano-parrafo);
		line-height: var(--line-height-parrafo);
		color: rgba(255, 255, 255, 0.9);
		text-align: left;
	}

	.portada-root .portada-empresas-cta {
		display: flex;
		justify-content: center;
		width: 100%;
		margin: 0;
		padding-inline: max(1rem, env(safe-area-inset-left, 0px)) max(1rem, env(safe-area-inset-right, 0px));
		padding-bottom: max(0.85rem, env(safe-area-inset-bottom, 0px));
		box-sizing: border-box;
	}

	.portada-root .portada-empresas-cta .boton-principal {
		min-height: 50px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: min(100%, 22rem);
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
		box-sizing: border-box;
		font-weight: 700;
		font-size: clamp(0.94rem, 3.8vw, 1.02rem);
		padding-inline: clamp(1rem, 4vw, 1.35rem);
		border-radius: var(--adcr-radius-cta, 999px);
		box-shadow: 0 4px 18px rgba(0, 0, 0, 0.25);
	}

	.portada-root .portada-empresas-logos {
		gap: 1rem 1.25rem;
		padding-top: 0.85rem;
	}
}

/*
 * Portada Inicio — tablet / iPad (769–1024px).
 * Lectura, ritmo vertical, objetivos táctiles (~44px) y scroll con cabecera sticky.
 * No afecta móvil (≤768) ni pantallas anchas (≥1025).
 */
@media (min-width: 769px) and (max-width: 1024px) {
	/* iOS / tablet: background-attachment fixed suele degradar scroll y LCP */
	.portada-root .hero.hero--parallax-trial:not(.adcr-hero-has-video) {
		background-attachment: scroll;
	}

	.portada-root .hero-trust-strip {
		flex-direction: row;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
		max-width: min(42rem, 94vw);
		margin-left: auto;
		margin-right: auto;
		padding: 0.6rem 1.15rem;
		border-radius: 14px;
		gap: 0.45rem 0.75rem;
	}

	.portada-root .hero .hero-subtitulo,
	.portada-root .hero .hero-subtitulo p {
		max-width: min(40rem, 92vw);
		margin-left: auto;
		margin-right: auto;
		line-height: 1.55;
	}

	.portada-root .hero .boton-principal {
		min-height: 44px;
		padding: 0.62rem 1.4rem;
		box-sizing: border-box;
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	.portada-root .hero-botones--dual {
		gap: 0.65rem 0.85rem;
		margin-top: 0.65rem;
	}

	.portada-root h2.portada-seccion-titulo,
	.portada-root h2#adcr-heading-servicios-inicio {
		scroll-margin-top: 5rem;
	}

	.portada-root h2#adcr-heading-beneficios {
		scroll-margin-top: 6rem;
	}

	.portada-root .servicios-inicio {
		padding-left: clamp(1.4rem, 4vw, 2.35rem);
		padding-right: clamp(1.4rem, 4vw, 2.35rem);
		padding-top: clamp(2.65rem, 5vw, 3.5rem);
		padding-bottom: clamp(2.5rem, 5vw, 3.35rem);
	}

	/*
	 * Barra CTA (métricas + botones): en tablet el layout en fila estrecha los botones y separa demasiado el texto.
	 * Columna centrada — mismo patrón que móvil, con más aire y hueco entre CTAs táctiles.
	 */
	.portada-root .servicios-inicio--optimized .servicios-inicio-trust-bar {
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		flex-wrap: nowrap;
		text-align: center;
		gap: clamp(1rem, 2.5vw, 1.35rem);
		padding: clamp(1.45rem, 3.4vw, 2rem) clamp(1.35rem, 4vw, 2.15rem);
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-trust-bar__copy {
		flex: none;
		width: 100%;
		max-width: 38rem;
		margin-left: auto;
		margin-right: auto;
		min-width: 0;
		text-align: center;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-social--metrics {
		justify-content: center;
		flex-direction: column;
		align-items: center;
		gap: 0.35rem;
		margin-bottom: 0.35rem;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-social--metrics .servicios-inicio-social__line {
		text-align: center;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-cta-caption {
		margin-left: auto;
		margin-right: auto;
		max-width: 36rem;
		font-size: clamp(0.86rem, 2.1vw, 0.94rem);
		line-height: 1.5;
	}

	.portada-root .servicios-inicio--optimized .servicios-inicio-trust-bar__actions {
		flex: none;
		width: 100%;
		max-width: min(28rem, 100%);
		margin-left: auto;
		margin-right: auto;
		justify-content: center;
		flex-direction: column;
		align-items: stretch;
		flex-wrap: nowrap;
		gap: 0.85rem;
		padding-top: 0.2rem;
	}

	.portada-root .servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.servicios-inicio-boton-cta--gold,
	.portada-root .servicios-inicio.servicios-inicio--optimized .servicios-prod-cuerpo .servicios-inicio-trust-bar a.boton-principal.servicios-inicio-boton-cta--outline {
		width: 100%;
		max-width: 100%;
		min-height: 48px;
		padding: 0.62rem 1.15rem;
		box-sizing: border-box;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		text-align: center;
		white-space: normal;
		word-break: break-word;
		line-height: 1.28;
		font-size: clamp(0.92rem, 2.15vw, 1.02rem);
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-layout {
		gap: clamp(1.15rem, 2.6vw, 1.75rem);
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-lead-panel {
		padding: clamp(1.25rem, 2.8vw, 1.65rem) clamp(1.15rem, 2.6vw, 1.55rem);
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-lead-actions {
		display: flex;
		flex-wrap: wrap;
		gap: 0.65rem;
		align-items: center;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-wa-btn {
		min-height: 44px;
		padding: 0.55rem 1.2rem;
		box-sizing: border-box;
	}

	.portada-root .servicios-acf--optimized .servicios-inicio-grid-2x2 {
		grid-auto-rows: auto;
	}

	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__summary {
		min-height: 44px;
		padding-top: 0.85rem;
		padding-bottom: 0.85rem;
		align-items: center;
	}

	.portada-root .seccion-beneficios--portada-grid .portada-beneficios-wrap {
		max-width: min(960px, 94vw);
	}

	.portada-root .portada-beneficio-card {
		padding: 1.45rem 1.35rem;
		gap: 1.05rem;
	}

	.portada-root .portada-beneficio-card__icon {
		width: 3.25rem;
		height: 3.25rem;
	}

	/*
	 * «Cómo funciona»: 4 pasos en 2×2 (evita auto-fit → 3 columnas + 1 hueco vacío en ~900–1150px).
	 */
	.portada-root .portada-pasos-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1rem 1.15rem;
		align-items: stretch;
	}

	.portada-root .portada-requisitos-grid {
		gap: 1rem;
	}

	.portada-root .portada-como-funciona .portada-paso-item {
		align-items: center;
		min-height: 0;
	}

	.portada-root .portada-paso-item,
	.portada-root .portada-requisitos-grid li {
		padding: 1.08rem 1.15rem;
	}

	.portada-root .portada-precios-grid {
		gap: 1rem;
		grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
	}

	.portada-root .portada-cobertura-grid {
		grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
		gap: 1.15rem;
		align-items: center;
	}

	.portada-root .portada-empresas-cards {
		grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
		gap: clamp(14px, 2.5vw, 20px);
	}

	.portada-root .portada-empresas-card {
		padding: 1.45rem 1.25rem 1.35rem;
	}

	.portada-root .portada-empresas-cta .boton-principal {
		min-height: 44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
	}

	.adcr-modal {
		width: min(480px, calc(100vw - 2.5rem));
	}

	.adcr-modal__panel {
		padding: 1.85rem 1.65rem 1.55rem;
	}

	.adcr-modal__btn {
		min-height: 44px;
		box-sizing: border-box;
	}

	/*
	 * Rendimiento Core Web Vitals (tablet/iPad): menos trabajo de layout inicial; hero fuera — candidato LCP.
	 */
	.portada-root section:not(.hero) {
		contain: layout;
	}

	.portada-root .portada-precios,
	.portada-root .portada-cobertura,
	.portada-root .portada-empresas {
		content-visibility: auto;
		contain-intrinsic-size: 520px;
	}

	@media (prefers-reduced-motion: reduce) {
		.portada-root .portada-precios,
		.portada-root .portada-cobertura,
		.portada-root .portada-empresas {
			content-visibility: visible;
			contain-intrinsic-size: unset;
		}
	}
}

/* Mini-FAQ: tres columnas solo en tablet ancha (el escritorio ≥1025 mantiene la rejilla de 640px en 2 cols). */
@media (min-width: 900px) and (max-width: 1024px) {
	.portada-root .servicios-acf--optimized .adcr-home-mini-faq__dl {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 1rem 1.05rem;
		align-items: stretch;
	}
}
