/* ==========================================================================
   Coschool Hero Widget
   ========================================================================== */

/* ── Variables por defecto (sobreescritas desde PHP via style inline) ─────── */
.cs-hero {
	--cs-gap:       14px;
	--cs-aspect:    1.35;
	--cs-opacity:   0.75;
	--cs-duration:  28s;
	--cs-rotation: -12deg;
	--cs-grayscale: 100%;
}

/* ── Contenedor ─────────────────────────────────────────────────────────── */
.cs-hero {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	background: #000;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ── Columnas de fondo ───────────────────────────────────────────────────── */
.cs-hero__columns {
	position: absolute;
	/* Agrandar para cubrir las esquinas al rotar */
	top: -25%;
	left: -15%;
	right: -15%;
	bottom: -25%;
	display: flex;
	gap: var(--cs-gap);
	padding: var(--cs-gap);
	z-index: 0;
	pointer-events: none;
	/* Inclinación controlada desde Elementor */
	transform: rotate(var(--cs-rotation));
	transform-origin: center center;
}

.cs-hero__col {
	flex: 1;
	overflow: hidden;
	min-width: 0;
}

/* Wrapper animado — contiene las imágenes duplicadas */
.cs-hero__col-track {
	display: flex;
	flex-direction: column;
	gap: var(--cs-gap);
	will-change: transform;
}

/* Columnas pares suben */
.cs-col--up .cs-hero__col-track {
	animation: cs-scroll-up var(--cs-duration) linear infinite;
}

/* Columnas impares bajan */
.cs-col--down .cs-hero__col-track {
	/* Empieza en -50% para que el movimiento sea inmediatamente visible */
	animation: cs-scroll-down var(--cs-duration) linear infinite;
}

@keyframes cs-scroll-up {
	0%   { transform: translateY(0); }
	100% { transform: translateY(-50%); }
}

@keyframes cs-scroll-down {
	0%   { transform: translateY(-50%); }
	100% { transform: translateY(0); }
}

/* Tarjeta de imagen */
.cs-hero__card {
	flex-shrink: 0;
	border-radius: 12px;
	overflow: hidden;
	aspect-ratio: calc(1 / var(--cs-aspect));
	opacity: var(--cs-opacity);
	transition: opacity 0.4s ease;
}

.cs-hero__card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	/* Grayscale controlado desde Elementor */
	filter: grayscale(var(--cs-grayscale));
}

/* ── Overlay degradado ───────────────────────────────────────────────────── */
.cs-hero__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.40) 0%,
		rgba(0, 0, 0, 0.68) 45%,
		rgba(0, 0, 0, 0.92) 100%
	);
}

/* ── Contenido central ───────────────────────────────────────────────────── */
.cs-hero__inner {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 140px 80px 100px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

/* ── Título ──────────────────────────────────────────────────────────────── */
.cs-hero__title {
	font-family: 'Montserrat', sans-serif;
	font-size: clamp(40px, 5vw, 64px);
	font-weight: 600;
	line-height: 1.1;
	color: #fff;
	margin: 0 0 28px;
}

.cs-hero__highlight {
	font-style: italic;
	font-weight: 700;
	color: #ffe53c;
}

/* ── Subtítulo ───────────────────────────────────────────────────────────── */
.cs-hero__subtitle {
	font-family: 'Montserrat', sans-serif;
	font-size: clamp(15px, 1.25vw, 18px);
	font-weight: 500;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.88);
	max-width: 680px;
	margin: 0 0 44px;
}

/* ── Botones ─────────────────────────────────────────────────────────────── */
.cs-hero__ctas {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	justify-content: center;
}

.cs-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 16px 32px;
	border-radius: 9999px;
	font-family: 'Montserrat', sans-serif;
	font-size: 18px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	white-space: nowrap;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.cs-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.cs-btn--primary {
	background: #e6d45d;
	color: #000;
	border: 2px solid transparent;
}

.cs-btn--outline {
	background: transparent;
	color: #e6d45d;
	border: 2px solid #e6d45d;
}

/* ── Animaciones fade-in ─────────────────────────────────────────────────── */
.cs-anim {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
	            transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.cs-anim.cs-visible {
	opacity: 1;
	transform: translateY(0);
}

/* En el editor de Elementor mostrar todo visible de inmediato */
.elementor-editor-active .cs-anim {
	opacity: 1;
	transform: translateY(0);
	transition: none;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
	.cs-hero__inner { padding: 120px 48px 80px; }
}

@media (max-width: 768px) {
	.cs-hero__inner { padding: 100px 24px 60px; }

	.cs-hero__title { font-size: clamp(32px, 8vw, 48px); }

	.cs-btn {
		font-size: 16px;
		padding: 14px 24px;
	}

	/* En móvil reducir columnas via JS; el CSS solo ajusta el gap */
	.cs-hero__columns { gap: 8px; padding: 8px; }
}

@media (max-width: 480px) {
	.cs-hero__ctas {
		flex-direction: column;
		align-items: stretch;
	}

	/* Solo mostrar 3 columnas en móvil */
	.cs-hero__col:nth-child(n+4) { display: none; }
}

/* ── Respeto por preferencia de movimiento reducido ─────────────────────── */
@media (prefers-reduced-motion: reduce) {
	.cs-hero__col-track {
		animation-play-state: paused !important;
	}
}
