/*--------------------------------------------------------------
# Edudire landing (hero propio + contenido)
# Bloque .edudire-hero: valores por defecto para Edudire. Ciclo de vida reutiliza la misma maquetación con .ciclo-vida-hero en ciclo-vida.css (no tocar colores aquí para esa plantilla).
--------------------------------------------------------------*/

.edudire-landing {
	width: 100%;
	max-width: 100%;
	overflow-x: clip;
	box-sizing: border-box;
	background-color: var(--black-5, #f3f5f6);
}

/* Sin hueco bajo el header fijo: el fondo del hero sube hasta arriba del viewport (detrás del menú). */
.edudire-landing.site-main {
	margin-top: 0;
	/* overflow-x: clip recorta desbordamientos horizontales sin crear un scroll container
	   (overflow-x: hidden activa overflow-y: auto implícitamente, generando doble scrollbar). */
	overflow-x: clip;
}

/*
 * Separadores `.gap-seccion` entre hero / reto / solución / impacto / contenido (page-edudire.php).
 * Móvil 32px y desktop 100px: misma escala que filas «El impacto» y column-gap solución; no cambia gaps.css global.
 */
.edudire-landing>.gap-seccion {
	height: 40px;
}

@media (min-width: 992px) {
	.edudire-landing>.gap-seccion {
		height: 100px;
	}
}

/* Fondo a ancho completo; el contenido va en .edudire-hero__contenedor (misma lógica que .contenedor: padding izq/der y max-width). */
.edudire-hero {
	--edudire-hero-bg: #508696;

	position: relative;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	background-color: var(--edudire-hero-bg);
	color: var(--white-100, #fff);
	min-height: auto;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: center;
	overflow: hidden;
}

.edudire-hero__contenedor {
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--contenedor-padding, 16px);
	padding-right: var(--contenedor-padding, 16px);
	width: 100%;
	max-width: calc(var(--contenedor-width) + var(--contenedor-padding) + var(--contenedor-padding));
	min-width: 0;
	box-sizing: border-box;
	position: relative;
}

/* Dos columnas 50/50 en desktop; gap 40px. Padding vertical en .edudire-hero__inner. */
.edudire-hero__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	overflow-x: hidden;
	/* Móvil: solo offset del header (variable del tema) + safe area; sin clamp. */
	padding-top: var(--altura-contenido-mobile);
	padding-bottom: 2.5rem;
	display: flex;
	/* Móvil: lectura primero (título/CTA), imagen debajo. El HTML va imagen→texto; column-reverse evita duplicar el bloque. */
	flex-direction: column-reverse;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: 40px;
	position: relative;
	z-index: 1;
}

/* Ritmo vertical entre título, subtítulo y CTA: utilidades .gap32 en la plantilla (sin flex aquí). */
.edudire-hero__content {
	text-align: left;
	width: 100%;
	min-width: 0;
	max-width: 100%;
}

/* CTA al inicio de la columna; gap si hubiera varios enlaces */
.edudire-hero__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	gap: 1rem;
	margin-top: 0;
	width: 100%;
}

@media (max-width: 991px) {

	.edudire-hero__content,
	.edudire-hero__media {
		flex: 0 0 auto;
		width: 100%;
		max-width: 100%;
	}

	.edudire-hero__actions {
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
	}

	.edudire-hero__actions .boton {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
		text-align: center;
	}
}

/* Radio inferior en móvil */
.edudire-hero {
	border-bottom-left-radius: 24px;
	border-bottom-right-radius: 24px;
}

@media (min-width: 992px) {
	.edudire-hero {
		/* Cálculo explícito: márgenes + caja no superan el 100% del main (evita scroll horizontal). */
		width: calc(100% - 2 * 8px);
		max-width: 100%;
		margin-left: 8px;
		margin-right: 8px;
		margin-bottom: 8px;
		border-bottom-left-radius: 24px;
		border-bottom-right-radius: 24px;
		/*
		 * Altura útil: una ventana menos el margen inferior (el margen no entra en 100vh/svh).
		 * 100svh evita el clásico desbordamiento por barra de URL en móvil; en desktop equivale a ~100vh.
		 */
		min-height: calc(100vh - 8px);
		min-height: calc(100svh - 8px);
		/* El bloque con .contenedor al inicio: si no, queda centrado en ~100vh y el FAB (antes anclado al fondo de la sección) quedaba muy lejos del flex de dos columnas. */
		justify-content: flex-start;
	}

	.edudire-hero__inner {
		padding-top: calc(var(--altura-contenido) + env(safe-area-inset-top, 0px));
		padding-bottom: clamp(3rem, 8vh, 4.5rem);
		/* DOM: imagen, texto — row-reverse deja título/CTA a la izquierda e imagen a la derecha. */
		flex-direction: row-reverse;
		align-items: center;
		gap: 40px;
	}

	/* Reparto 50/50 del espacio disponible tras el gap (flex-basis 0). */
	.edudire-hero__content {
		flex: 1 1 0;
		min-width: 0;
		max-width: none;
	}

	.edudire-hero__media {
		flex: 1 1 0;
		min-width: 0;
		max-width: none;
	}

	.edudire-hero--no-image .edudire-hero__inner {
		flex-direction: column;
		align-items: flex-start;
		max-width: 40rem;
	}

	.edudire-hero--no-image .edudire-hero__content {
		flex: 1 1 auto;
		max-width: 40rem;
	}
}

.edudire-hero__heading,
.edudire-hero__subheading {
	margin: 0;
	color: var(--white-100, #fff);
}

.edudire-hero__heading {
	text-wrap: balance;
}

.edudire-hero__subheading {
	text-wrap: wrap;
}

.edudire-hero__subheading p {
	margin: 0 0 0.65rem;
	color: inherit;
}

.edudire-hero__subheading p:last-child {
	margin-bottom: 0;
}

.edudire-hero__media {
	border-radius: 0;
	min-width: 0;
	max-width: 100%;
	/* AOS (fade-left) usa transform: overflow visible hacía desbordar el layout. */
	overflow: hidden;
	box-shadow: none;
	display: flex;
	align-items: center;
	justify-content: center;
}

@media (min-width: 992px) {
	.edudire-hero__media {
		justify-content: flex-end;
		align-self: center;
	}
}

.edudire-hero__img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	max-height: clamp(220px, 52vh, 560px);
	object-fit: contain;
	object-position: center center;
}

@media (min-width: 992px) {
	.edudire-hero__img {
		min-height: 560px;
		max-height: min(58vh, 600px);
		object-position: center right;
	}
}

/*--------------------------------------------------------------
# Sección «El reto» (prototipo; pasará a ACF)
# Cabecera centrada max 900px; cuadrícula: móvil 2x2, 4 a partir de 992px.
--------------------------------------------------------------*/

.edudire-seccion--reto {
	position: relative;
}

.edudire-landing.edudire-page .edudire-seccion--reto {
	overflow: hidden;
}

.edudire-landing.edudire-page .edudire-seccion--reto > .contenedor {
	position: relative;
	z-index: 1;
}

.edudire-reto__cabecera {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.edudire-reto__titulo {
	margin: 0;
	color: var(--secondary-100, #196c87);
	text-wrap: balance;
}

.edudire-reto__texto {
	margin: 0;
	color: var(--body-text-100, #545454);
	text-wrap: pretty;
}

.edudire-reto__texto p {
	margin: 0 0 0.75em;
}

.edudire-reto__texto p:last-child {
	margin-bottom: 0;
}

.edudire-reto__cuadros {
	list-style: none;
	margin: clamp(2rem, 5vw, 3rem) 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(0.75rem, 2vw, 1.25rem);
}

@media (min-width: 992px) {
	.edudire-reto__cuadros {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: clamp(1rem, 2.5vw, 1.25rem);
	}
}

.edudire-reto__cuadro {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: clamp(0.75rem, 2vw, 1rem);
	margin: 0;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	background-color: var(--white-100, #fff);
	border: 1px solid var(--secondary-40, #a3c4cf);
	border-radius: 24px;
	box-sizing: border-box;
	min-width: 0;
}

.edudire-reto__cuadro-icono {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--secondary-100, #196c87);
	line-height: 0;
}

.edudire-reto__cuadro-icono svg,
.edudire-reto__cuadro-img {
	display: block;
	height: 75px;
	width: auto;
	max-width: 100%;
	object-fit: contain;
}

.edudire-reto__cuadro-texto {
	margin: 0;
	color: var(--secondary-100, #196c87);
}

/* Móvil/tablet 2x2: tipografía ligeramente más compacta (clase body-XL en cuadro). */
@media (max-width: 767.98px) {
	.edudire-reto__cuadro-texto.body-XL {
		font-size: 18px;
		line-height: 1.35;
	}
}

@media (min-width: 768px) and (max-width: 991.98px) {
	.edudire-reto__cuadro-texto.body-XL {
		font-size: 22px;
		line-height: 1.35;
	}
}

/*--------------------------------------------------------------
# Sección «Diseñado para adaptarse» (cabecera + 4 tarjetas ACF)
--------------------------------------------------------------*/

.edudire-seccion--adapta {
	position: relative;
	color: var(--secondary-100, #196c87);
}

.edudire-adapta__cabecera {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: clamp(2rem, 5vw, 3rem);
	text-align: center;
}

.edudire-adapta__titulo {
	margin: 0;
	text-wrap: balance;
}

.edudire-adapta__intro {
	margin: 0;
	color: var(--body-text-100, #545454);
	text-wrap: pretty;
}

.edudire-adapta__intro p {
	margin: 0 0 0.75em;
}

.edudire-adapta__intro p:last-child {
	margin-bottom: 0;
}

.edudire-adapta__tarjetas {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 2.5vw, 1.25rem);
}

@media (min-width: 768px) {
	.edudire-adapta__tarjetas {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 992px) {
	.edudire-adapta__tarjetas {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

.edudire-adapta__tarjeta {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: clamp(0.75rem, 2vw, 1rem);
	margin: 0;
	padding: clamp(1.25rem, 3vw, 1.75rem);
	background-color: var(--white-100, #fff);
	border: 1px solid var(--secondary-40, #a3c4cf);
	border-radius: 24px;
	box-sizing: border-box;
	min-width: 0;
}

.edudire-adapta__etiqueta {
	margin: 0;
	color: var(--accent-100, #86c8bc);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.edudire-adapta__icono {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	color: var(--secondary-100, #196c87);
}

.edudire-adapta__icono-img {
	display: block;
	height: 75px;
	width: auto;
	max-width: 100%;
	object-fit: contain;
}

.edudire-adapta__titulo-tarjeta {
	margin: 0;
	text-wrap: balance;
}

.edudire-adapta__texto-tarjeta {
	margin: 0;
	color: var(--body-text-100, #545454);
	line-height: 1.45;
	text-wrap: pretty;
}

.edudire-adapta__texto-tarjeta p {
	margin: 0 0 0.5em;
}

.edudire-adapta__texto-tarjeta p:last-child {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
# Sección «La solución» (slider; prototipo → ACF)
--------------------------------------------------------------*/

.edudire-seccion--solucion {
	color: var(--secondary-100, #196c87);
}

.edudire-solucion__cabecera {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	max-width: 900px;
	margin: 0 0 clamp(2rem, 5vw, 3rem);
	text-align: left;
}

.edudire-solucion__titulo {
	margin: 0;
	color: var(--secondary-100, #196c87);
	text-wrap: balance;
}

.edudire-solucion__subtitulo {
	margin: 0;
	color: var(--secondary-100, #196c87);
	text-wrap: pretty;
}

.edudire-solucion__subtitulo p {
	margin: 0 0 0.5em;
}

.edudire-solucion__subtitulo p:last-child {
	margin-bottom: 0;
}

.edudire-solucion__texto {
	margin: 0;
	color: var(--body-text-100, #545454);
}

.edudire-solucion__texto p {
	margin: 0 0 0.5em;
}

.edudire-solucion__texto p:last-child {
	margin-bottom: 0;
}

/*
 * Proporción maqueta en desktop: imagen 546, texto + controles 733 (546fr : 733fr).
 * En móvil el DOM pone recuadro+nav y debajo la imagen; en 992+ se reparten columnas.
 */
.edudire-solucion__layout {
	display: grid;
	grid-template-columns: 1fr;
	align-items: center;
	gap: clamp(2rem, 5vw, 3.5rem);
}

.edudire-solucion__media {
	position: relative;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	margin-left: auto;
	margin-right: auto;
}

.edudire-solucion--single .edudire-solucion__nav {
	display: none;
}

.edudire-solucion__slide--visual {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	z-index: 1;
	pointer-events: none;
}

.edudire-solucion__slide--visual:not(.is-active) {
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s linear 0.5s;
}

.edudire-solucion__slide--visual.is-active {
	z-index: 2;
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s;
}

@media (prefers-reduced-motion: reduce) {
	.edudire-solucion__slide--visual,
	.edudire-solucion__slide--visual:not(.is-active),
	.edudire-solucion__slide--visual.is-active {
		transition-duration: 0.15s;
	}

	.edudire-solucion__slide--visual:not(.is-active) {
		opacity: 0;
		visibility: hidden;
	}

	.edudire-solucion__slide--visual.is-active {
		opacity: 1;
	}
}

.edudire-solucion__img {
	display: block;
	max-width: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
}

/* Móvil: la altura del bloque la marca la imagen (ancho = contenedor; sin min-height fijo). */
@media (max-width: 991.98px) {
	.edudire-solucion__slide--visual {
		position: relative;
		inset: auto;
		left: auto;
		top: auto;
	}

	.edudire-solucion__slide--visual:not(.is-active) {
		display: none !important;
	}

	.edudire-solucion__slide--visual.is-active {
		display: flex;
	}

	.edudire-solucion__img {
		width: 100%;
		max-height: none;
	}
}

.edudire-solucion__columna--panel {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.edudire-solucion__cuadro {
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
	min-width: 0;
	padding: 64px 32px 32px;
	border-radius: 24px;
	background-color: var(--primary-40, #d4e5ec);
}

.edudire-solucion__tarjetas {
	position: relative;
	flex: 1 1 auto;
	min-height: 0;
	display: grid;
}

.edudire-solucion__tarjeta {
	grid-area: 1 / 1;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	z-index: 0;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.edudire-solucion__tarjeta.is-active {
	z-index: 1;
	opacity: 1;
	pointer-events: auto;
}

@media (prefers-reduced-motion: reduce) {
	.edudire-solucion__tarjeta {
		transition: opacity 0.15s ease;
	}
}

.edudire-solucion__tarjeta-titulo {
	margin: 0 0 1rem;
	color: var(--secondary-100, #196c87);
}

.edudire-solucion__tarjeta-texto {
	margin: 0;
	color: var(--body-text-100, #545454);
	line-height: 1.45;
}

.edudire-solucion__tarjeta-texto p {
	margin: 0 0 0.5em;
}

.edudire-solucion__tarjeta-texto p:last-child {
	margin-bottom: 0;
}

.edudire-solucion__nav {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	margin-top: 32px;
	gap: 1rem;
}

.edudire-solucion__nav-btn {
	box-sizing: border-box;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 80px;
	height: 80px;
	padding: 0;
	border: 1px solid var(--secondary-100, #196c87);
	border-radius: 50%;
	background-color: transparent;
	cursor: pointer;
}

.edudire-solucion__nav-btn:hover {
	background-color: rgba(255, 255, 255, 0.35);
}

.edudire-solucion__nav-btn:focus-visible {
	outline: 2px solid var(--accent-100, #86c8bc);
	outline-offset: 2px;
}

/*
 * arrow.svg es diagonal: respecto a -45deg/135deg (arriba/abajo), +90deg alinea → derecha / ← izquierda.
 */
.edudire-solucion__nav-btn::after {
	content: '';
	display: block;
	width: 28px;
	height: 28px;
	mask-image: url('../img/svg/arrow.svg');
	-webkit-mask-image: url('../img/svg/arrow.svg');
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
	mask-size: contain;
	-webkit-mask-size: contain;
	mask-position: center;
	-webkit-mask-position: center;
	background-color: var(--secondary-100, #196c87);
	transform: rotate(45deg);
	transform-origin: center center;
}

.edudire-solucion__nav-btn--prev::after {
	transform: rotate(225deg);
}

@media (max-width: 991.98px) {
	.edudire-solucion__nav-btn {
		width: 60px;
		height: 60px;
	}

	.edudire-solucion__nav-btn::after {
		width: 22px;
		height: 22px;
	}
}

@media (min-width: 992px) {
	.edudire-solucion__layout {
		grid-template-columns: minmax(0, 546fr) minmax(0, 733fr);
		column-gap: 100px;
		row-gap: clamp(2rem, 4vw, 3rem);
		align-items: center;
	}

	/* Primer nodo (panel) en DOM, segundo (visual); colocar imagen izquierda, panel derecha. */
	.edudire-solucion__columna--visual {
		grid-column: 1;
		grid-row: 1;
		min-width: 0;
	}

	.edudire-solucion__columna--panel {
		grid-column: 2;
		grid-row: 1;
		min-width: 0;
	}

	.edudire-solucion__media {
		min-height: min(546px, 85vh);
		margin-left: 0;
		margin-right: 0;
		width: 100%;
	}

	/* Superponer diapositivas; anula el display:none móvil en las inactivas. */
	.edudire-solucion__slide--visual {
		display: flex !important;
		position: absolute;
		left: 0;
		top: 0;
	}

	.edudire-solucion__img {
		max-width: 100%;
		max-height: min(546px, 85vh);
		width: auto;
	}
}

/*--------------------------------------------------------------
# Sección «El impacto» (prototipo → ACF)
--------------------------------------------------------------*/

.edudire-seccion--impacto {
	color: var(--secondary-100, #196c87);
}

.edudire-impacto__cabecera {
	box-sizing: border-box;
	max-width: 900px;
	margin: 0 auto clamp(2rem, 5vw, 3rem);
	padding-left: var(--contenedor-padding, 16px);
	padding-right: var(--contenedor-padding, 16px);
	text-align: center;
}

.edudire-impacto__titulo {
	margin: 0 0 clamp(0.75rem, 2vw, 1rem);
	color: var(--secondary-100, #196c87);
	text-wrap: balance;
}

.edudire-impacto__intro {
	margin: 0;
	color: var(--body-text-100, #545454);
	line-height: 1.5;
	text-wrap: pretty;
}

.edudire-impacto__intro p {
	margin: 0 0 0.5em;
}

.edudire-impacto__intro p:last-child {
	margin-bottom: 0;
}

.edudire-impacto__filas {
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
}

.edudire-impacto__fila {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	align-items: center;
	padding: clamp(1.25rem, 3vw, 1.75rem) 0;
	border-bottom: 1px solid var(--primary-40, #cfe9e4);
}

.edudire-impacto__fila:first-of-type {
	border-top: 1px solid var(--primary-40, #cfe9e4);
}

.edudire-impacto__icono {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	min-width: 90px;
	min-height: 90px;
	color: var(--secondary-100, #196c87);
}

.edudire-impacto__svg {
	display: block;
	width: 48px;
	height: 48px;
}

.edudire-impacto__icono-img {
	display: block;
	width: 90px;
	height: 90px;
	object-fit: contain;
}

.edudire-impacto__fila-titulo {
	margin: 0;
	color: var(--secondary-100, #196c87);
	text-align: left;
}

.edudire-impacto__fila-texto {
	margin: 0;
	color: var(--black-100, #1a1a1a);
	line-height: 1.45;
	text-align: left;
}

.edudire-impacto__fila-texto p {
	margin: 0 0 0.5em;
}

.edudire-impacto__fila-texto p:last-child {
	margin-bottom: 0;
}

.edudire-impacto__fila-cta {
	margin-top: clamp(1rem, 2.5vw, 1.5rem);
}

.edudire-impacto__fila-boton {
	display: inline-flex;
}

.edudire-impacto__cta {
	margin: clamp(2rem, 5vw, 3rem) 0 0;
	text-align: center;
}

/* Desktop: ancho al contenido, centrado en el párrafo */
a.edudire-impacto__cta-boton.boton.secondary.dark,
.edudire-impacto__cta .edudire-impacto__cta-boton {
	margin-left: auto;
	margin-right: auto;
}

/* Mobile: 100% del contenedor; flex + ::after en flujo (como .contacto-form__submit) */
@media (max-width: 991px) {
	.edudire-impacto__cta {
		padding: 0;
		max-width: 100%;
		box-sizing: border-box;
	}

	.edudire-impacto__cta .edudire-impacto__cta-boton,
	a.edudire-impacto__cta-boton.boton.secondary.dark {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 0.5rem;
		padding: 0 20px !important;
		margin: 0;
		text-align: center;
	}

	a.edudire-impacto__cta-boton.boton.secondary.dark::after {
		position: relative;
		inset: auto;
		top: auto;
		right: auto;
		left: auto;
		transform: none;
		margin: 0 0 0 0.1rem;
		flex: 0 0 auto;
	}

	a.edudire-impacto__cta-boton.boton.secondary.dark:hover::after,
	a.edudire-impacto__cta-boton.boton.secondary.dark:focus-visible::after {
		transform: rotate(45deg) !important;
	}
}

@media (min-width: 768px) {
	.edudire-impacto__fila {
		grid-template-columns: 120px minmax(0, 1.1fr) minmax(0, 1.4fr);
		gap: 100px;
		align-items: center;
	}

	.edudire-impacto__icono {
		justify-content: center;
		min-width: 120px;
		min-height: 120px;
	}

	.edudire-impacto__icono-img {
		width: 120px;
		height: 120px;
	}
}

/*--------------------------------------------------------------
# Bloque «Pantalla» (fondo ACF + logo + captura)
--------------------------------------------------------------*/

.edudire-seccion--pantalla {
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	color: var(--secondary-100, #196c87);
}

/*
 * Foto de fondo + velo, logo + captura. Altura del panel = contenido (sin aspect-ratio / max-height que recorten la captura).
 */
.edudire-pantalla__panel {
	position: relative;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
	width: 100%;
	border-radius: 8px;
	overflow: hidden;
	padding: 16px;
	background-color: var(--secondary-10, #e8f0f3);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-height: 220px;
}

.edudire-pantalla__panel--has-bg::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	background: linear-gradient(105deg,
			rgba(19, 48, 64, 0.38) 0%,
			rgba(19, 48, 64, 0.24) 45%,
			rgba(19, 48, 64, 0.18) 100%);
	pointer-events: none;
	border-radius: inherit;
}

.edudire-pantalla__inner {
	position: relative;
	z-index: 1;
	box-sizing: border-box;
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: clamp(1rem, 3vw, 1.5rem);
	padding: 0;
}

.edudire-pantalla__logo {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	line-height: 0;
	flex-shrink: 0;
	min-width: 0;
}

.edudire-pantalla__logo-img {
	display: block;
	box-sizing: border-box;
	width: 234px;
	max-width: 100%;
	height: auto;
	object-fit: contain;
	object-position: left top;
}

.edudire-pantalla__captura-frame {
	flex: 0 0 auto;
	min-width: 0;
	width: 100%;
	max-width: none;
	align-self: stretch;
}

.edudire-pantalla__captura {
	margin: 0;
	padding: 0;
	line-height: 0;
	overflow: visible;
	width: 100%;
	max-width: 100%;
}

.edudire-pantalla__captura-img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	border-radius: 0;
	object-fit: contain;
	object-position: center top;
}

@media (min-width: 768px) {
	.edudire-pantalla__panel {
		padding: 32px;
		min-height: 280px;
	}

	.edudire-pantalla__inner {
		flex-direction: row;
		align-items: flex-start;
		justify-content: space-between;
		gap: clamp(2.5rem, 6vw, 4.5rem);
	}

	.edudire-pantalla__logo {
		align-self: flex-start;
	}

	.edudire-pantalla__captura-frame {
		flex: 1 1 0;
		min-width: 0;
		width: auto;
		align-self: flex-start;
	}

	.edudire-pantalla__inner>.edudire-pantalla__captura-frame:only-child {
		flex: 1 1 0;
	}
}

/*--------------------------------------------------------------
# Sección «Contacta» (caja blanca: imagen + texto + CTA)
--------------------------------------------------------------*/

.edudire-seccion--contacta {
	position: relative;
}

.edudire-contacta__caja {
	box-sizing: border-box;
	background-color: var(--white-100, #fff);
	border: 1px solid var(--secondary-40, #a3c4cf);
	border-radius: 24px;
	overflow: hidden;
}

.edudire-contacta__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 4vw, 2.5rem);
	padding: clamp(1.25rem, 3vw, 2rem);
	align-items: center;
}

.edudire-contacta__media {
	display: flex;
	justify-content: center;
	min-width: 0;
}

.edudire-contacta__figura {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	box-sizing: border-box;
	width: min(100%, 320px);
	max-width: 100%;
	margin-inline: auto;
	padding: 0;
	border-radius: 16px;
	overflow: hidden;
}

.edudire-contacta__img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 100%;
	object-fit: contain;
}

.edudire-contacta__contenido {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: clamp(0.75rem, 2vw, 1rem);
	text-align: left;
	min-width: 0;
}

.edudire-contacta__etiqueta {
	margin: 0;
	color: var(--accent-100, #86c8bc);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.edudire-contacta__titulo {
	margin: 0;
	color: var(--secondary-100, #196c87);
	text-wrap: balance;
}

.edudire-contacta__texto {
	margin: 0;
	color: var(--body-text-100, #545454);
	line-height: 1.6;
	text-wrap: pretty;
}

.edudire-contacta__texto p {
	margin: 0 0 0.5em;
}

.edudire-contacta__texto p:last-child {
	margin-bottom: 0;
}

.edudire-contacta__cta {
	margin-top: clamp(0.5rem, 2vw, 0.75rem);
}

@media (max-width: 991px) {
	.edudire-contacta__cta {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}

	.edudire-contacta__cta .edudire-contacta__boton,
	.edudire-contacta__cta a.boton {
		width: 100%;
		max-width: 100%;
		box-sizing: border-box;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		gap: 0.5rem;
		padding: 0 20px !important;
		margin: 0;
		text-align: center;
	}

	a.edudire-contacta__boton.boton.primary.dark::after {
		position: relative;
		inset: auto;
		top: auto;
		right: auto;
		left: auto;
		transform: none;
		margin: 0 0 0 0.1rem;
		flex: 0 0 auto;
	}

	a.edudire-contacta__boton.boton.primary.dark:hover::after,
	a.edudire-contacta__boton.boton.primary.dark:focus-visible::after {
		transform: rotate(45deg) !important;
	}
}

.edudire-contacta__boton {
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

@media (min-width: 768px) {
	.edudire-contacta__inner {
		grid-template-columns: minmax(0, clamp(200px, 34vw, 320px)) minmax(0, 1fr);
		gap: clamp(1.5rem, 4vw, 3rem);
		padding: clamp(1.5rem, 3vw, 2.5rem);
	}

	.edudire-contacta__media {
		justify-content: center;
		width: 100%;
	}

	.edudire-contacta__figura {
		width: 100%;
		max-width: 100%;
		aspect-ratio: 1;
		margin-inline: auto;
	}

	.edudire-contacta__img {
		width: auto;
		max-width: 100%;
		height: auto;
		max-height: 100%;
		margin-inline: auto;
		object-fit: contain;
		object-position: center;
	}
}

@media (min-width: 992px) {
	.edudire-contacta__inner {
		grid-template-columns: minmax(0, clamp(240px, 30vw, 360px)) minmax(0, 1fr);
	}

	.edudire-contacta__media {
		align-self: center;
	}
}

/*--------------------------------------------------------------
# Módulo contenido (editor; ritmo vertical: .gap-seccion; alturas en .edudire-landing > .gap-seccion arriba)
--------------------------------------------------------------*/

/* Ancho de lectura dentro del .contenedor; no se añaden clases al .contenedor */
.edudire-landing__content-inner {
	max-width: 48rem;
	margin-left: auto;
	margin-right: auto;
}

.edudire-landing__content-inner>*:first-child {
	margin-top: 0;
}

.edudire-landing__content-inner>*:last-child {
	margin-bottom: 0;
}