/* Hero Slider — full width, compatible con sección estirada Elementor */
.elementor-widget-cew-hero-slider {
	width: 100%;
	max-width: 100%;
}

/* Fondo en el envoltorio de Elementor (esquinas redondeadas del slide) */
.elementor-widget-cew-hero-slider > .elementor-widget-container {
	background-color: #f4fbf9;
}

.cew-hero-slider {
	--cew-hero-fade-ms: 600ms;
	--cew-hero-overlay-opacity: 0.7;
	width: 100%;
	position: relative;
	box-sizing: border-box;
}

/* GSAP: max-width se anima con scrub; auto centra cuando el bloque es más estrecho que la sección */
.cew-hero-slider--gsap-shrink.cew-hero-slider--gsap-parallax {
	width: 100%;
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	display: block;
}

.cew-hero-slider *,
.cew-hero-slider *::before,
.cew-hero-slider *::after {
	box-sizing: border-box;
}

.cew-hero-slider__viewport {
	position: relative;
	width: 100%;
	min-height: 520px;
	overflow: hidden;
	touch-action: pan-y pinch-zoom;
}

/*
 * Importante: touch-action no se hereda. El dedo pega en títulos, enlaces, etc. (por defecto auto)
 * y el navegador puede quedarse con el desplazamiento sin dejar al JS pasar al siguiente slide.
 * Misma acción en el slide y en hijos, sin tocar estructura ni JS extra.
 */
.cew-hero-slider__viewport .cew-hero-slider__slide,
.cew-hero-slider__viewport .cew-hero-slider__slide * {
	touch-action: pan-y pinch-zoom;
}

/* Los puntos cambian de slide con un toque: mismo criterio táctil */
.cew-hero-slider__viewport .cew-hero-slider__dot {
	touch-action: manipulation;
}

.cew-hero-slider__viewport.is-cew-hero-grabbing {
	cursor: grabbing;
	user-select: none;
}

.cew-hero-slider__slides {
	position: relative;
	width: 100%;
	min-height: inherit;
}

.cew-hero-slider__slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	min-height: inherit;
	background-color: #1a1a1a;
	background-repeat: no-repeat;
	background-position: center;
	opacity: 0;
	visibility: hidden;
	transition:
		opacity var(--cew-hero-fade-ms) ease,
		visibility 0s linear var(--cew-hero-fade-ms);
	z-index: 0;
}

/* Imagen de fondo en el slide (cover/contain vía background-size) */
.cew-hero-slider__slide--bg-cover {
	background-size: cover;
}

.cew-hero-slider__slide--bg-contain {
	background-size: contain;
}

.cew-hero-slider__slide.is-active {
	opacity: 1;
	visibility: visible;
	transition:
		opacity var(--cew-hero-fade-ms) ease,
		visibility 0s;
	z-index: 1;
	pointer-events: auto;
}

.cew-hero-slider__slide:not(.is-active) {
	pointer-events: none;
}

.cew-hero-slider__media {
	position: absolute;
	inset: 0;
	z-index: 0;
	background: #1a1a1a;
}

.cew-hero-slider__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

.cew-hero-slider__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	/*
	 * Doble gradiente: oscuro en la parte superior (para el header/nav)
	 * y oscuro en la parte inferior (para título, descripción y CTA).
	 * Centro transparente. La variable --cew-hero-overlay-opacity se
	 * controla desde el panel de Elementor (0–100).
	 */
	background:
		linear-gradient(180deg,
			rgba(0, 0, 0, 0) 55%,
			rgba(0, 0, 0, var(--cew-hero-overlay-opacity, 0.5)) 92%
		),
		linear-gradient(359deg,
			rgba(0, 0, 0, 0) 39%,
			rgba(0, 0, 0, var(--cew-hero-overlay-opacity, 0.5)) 85%
		);
}

/* Contenedor centrado tipo sección (max 1280px); el texto vive en el inner al 50% izquierda */
.cew-hero-slider__content-wrap {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	z-index: 2;
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	padding: 0 80px 80px;
	box-sizing: border-box;
}

.cew-hero-slider__content-inner {
	width: 50%;
	min-width: 0;
	text-align: left;
	align-self: flex-end;
}

/* Dos columnas (activado desde el panel de Elementor) */
.cew-hero-slider__content-inner--two-col {
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	/* gap y align-items vienen como estilos inline desde render.php */
}

.cew-hero-slider__col {
	min-width: 0;
	flex-shrink: 0;
	box-sizing: border-box;
}

/* La columna de plantilla hereda el color del slide para que los textos sean blancos por defecto */
.cew-hero-slider__col--aside {
	color: inherit;
}

/* Elementor añade padding/margen propio a las plantillas; neutralizamos el del wrapper de widget */
.cew-hero-slider__col--aside .elementor-widget-wrap,
.cew-hero-slider__col--aside .elementor-section-wrap {
	padding: 0 !important;
}

/* En tablet/móvil las columnas se apilan */
@media (max-width: 1024px) {
	.cew-hero-slider__content-inner--two-col {
		flex-direction: column;
	}

	.cew-hero-slider__col {
		width: 100% !important;
	}
}

/*
 * Fade-in del contenido por slide: las transiciones CSS en hijos fallan dentro del slide
 * que usa opacity + visibility; se usa keyframes + clase --enter reiniciada en JS (goTo).
 */
@keyframes cew-hero-content-fade-in {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.cew-hero-slider__slide:not(.is-active) .cew-hero-slider__content-inner {
	opacity: 0;
}

.cew-hero-slider__slide.is-active .cew-hero-slider__content-inner:not(.cew-hero-slider__content-inner--enter) {
	opacity: 0;
}

.cew-hero-slider__slide.is-active .cew-hero-slider__content-inner.cew-hero-slider__content-inner--enter {
	animation: cew-hero-content-fade-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) 0.12s both;
}

@media (prefers-reduced-motion: reduce) {
	/* Misma especificidad que :not(.--enter); forzar texto visible sin animación */
	.cew-hero-slider__slide.is-active .cew-hero-slider__content-inner:not(.cew-hero-slider__content-inner--enter),
	.cew-hero-slider__slide.is-active .cew-hero-slider__content-inner.cew-hero-slider__content-inner--enter {
		opacity: 1;
		animation: none !important;
	}

	.cew-hero-slider__slide:not(.is-active) .cew-hero-slider__content-inner {
		opacity: 0;
	}
}

@media (max-width: 1024px) {
	.cew-hero-slider__content-inner {
		width: 100%;
	}
}

.cew-hero-slider__title {
	margin: 0;
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.02em;
}

.cew-hero-slider__description {
	margin: 0;
	line-height: 1.55;
	opacity: 0.95;
}

.cew-hero-slider__description p {
	margin: 0;
}

.cew-hero-slider__cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0;
	font-weight: 600;
	text-decoration: none;
	line-height: 1.2;
	transition: opacity 0.2s ease, color 0.2s ease;
}

.cew-hero-slider__cta:hover {
	opacity: 0.9;
}

.cew-hero-slider__cta--static {
	cursor: default;
	pointer-events: none;
}

.cew-hero-slider__cta-icon {
	display: inline-flex;
	flex-shrink: 0;
	line-height: 0;
}

.cew-hero-slider__cta-icon svg {
	display: block;
}

/* Misma columna centrada que el contenido (--cew-hero-content-max-width la define Elementor, fallback 1280px) */
.cew-hero-slider__dots {
	position: absolute;
	left: max(0px, calc(50% - (var(--cew-hero-content-max-width, 1280px) / 2)));
	right: max(0px, calc(50% - (var(--cew-hero-content-max-width, 1280px) / 2)));
	top: auto;
	bottom: 24px;
	transform: none;
	z-index: 4;
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
	margin: 0;
	padding: 0;
	padding-inline-end: 24px;
	list-style: none;
	box-sizing: border-box;
}

/* Puntos: color en fill/stroke del SVG (los `button` del tema suelen pisar `color` / `background`) */
.elementor-widget-cew-hero-slider .cew-hero-slider__dot {
	appearance: none;
	-webkit-appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 0;
	border: 0;
	box-shadow: none;
	background: transparent !important;
	color: transparent;
	font-size: 0;
	line-height: 0;
	border-radius: 50%;
	overflow: hidden;
	aspect-ratio: 1 / 1;
	flex: 0 0 auto;
	min-width: 0;
	min-height: 0;
	cursor: pointer;
	vertical-align: middle;
}

.cew-hero-slider__dot-svg {
	display: block;
	width: 100%;
	height: 100%;
	max-width: 100%;
	max-height: 100%;
	flex-shrink: 0;
}

/* Inactivo: relleno + borde mismo color (#ffffff78 por defecto) */
.cew-hero-slider__dot-muted {
	fill: #ffffff52 !important;
	stroke: #ffffff52 !important;
	opacity: 1;
	transition: opacity 0.2s ease;
}

.cew-hero-slider__dot-fill {
	fill: #ffffff;
	stroke: none;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.cew-hero-slider__dot.is-active .cew-hero-slider__dot-muted {
	opacity: 0;
}

.cew-hero-slider__dot.is-active .cew-hero-slider__dot-fill {
	opacity: 1;
}

.cew-hero-slider__dot:focus-visible {
	outline: 2px solid #fff;
	outline-offset: 3px;
}

@media (max-width: 1024px) {
	.cew-hero-slider__content-wrap {
		padding: 0 40px 48px;
	}
}

@media (max-width: 767px) {
	.cew-hero-slider__content-wrap {
		padding: 0 20px 48px;
	}

	.cew-hero-slider__dots {
		padding-inline-end: 16px;
		bottom: 20px;
		gap: 10px;
	}
}
