/* ==========================================================================
   SCOLA — Editorial Design System
   Inspired by Azentos / Pentagram / Mother editorial agency websites.
   Classes que Roberto aplica desde Elementor "CSS Classes" field.
   ========================================================================== */

:root {
	--scola-orange: #FD8E25;
	--scola-ink: #1E1E1E;
	--scola-ink-2: #252F38;
	--scola-muted: #8A95A1;
	--scola-light: #D3DDDE;
	--scola-bg: #FAFAF7;
	--scola-hairline: rgba(30,30,30,0.08);
}

/* === DISPLAY TYPOGRAPHY === */

.scola-display-h1 {
	font-family: 'Hanken Grotesk', -apple-system, sans-serif !important;
	font-weight: 300 !important;
	font-size: clamp(56px, 9vw, 144px) !important;
	line-height: 0.95 !important;
	letter-spacing: -0.04em !important;
	color: var(--scola-ink) !important;
	margin: 0 !important;
}

.scola-display-h2 {
	font-family: 'Hanken Grotesk', -apple-system, sans-serif !important;
	font-weight: 500 !important;
	font-size: clamp(40px, 6vw, 96px) !important;
	line-height: 1.0 !important;
	letter-spacing: -0.03em !important;
	color: var(--scola-ink) !important;
	margin: 0 !important;
}

.scola-display-h3 {
	font-family: 'Hanken Grotesk', -apple-system, sans-serif !important;
	font-weight: 400 !important;
	font-size: clamp(28px, 3.5vw, 48px) !important;
	line-height: 1.15 !important;
	letter-spacing: -0.02em !important;
	color: var(--scola-ink) !important;
	margin: 0 !important;
}

/* Kicker — small uppercase label above headlines */
.scola-kicker {
	display: inline-block;
	font-family: 'Hanken Grotesk', sans-serif !important;
	font-weight: 700 !important;
	font-size: 11px !important;
	letter-spacing: 0.22em !important;
	text-transform: uppercase !important;
	color: var(--scola-orange) !important;
	margin-bottom: 24px !important;
}

.scola-kicker--ink   { color: var(--scola-ink) !important; }
.scola-kicker--muted { color: var(--scola-muted) !important; }

/* === NUMBERED SECTIONS (01. / 02. / 03.) === */

.scola-section-number {
	font-family: 'Hanken Grotesk', sans-serif !important;
	font-weight: 900 !important;
	font-size: clamp(120px, 18vw, 280px) !important;
	line-height: 0.85 !important;
	letter-spacing: -0.06em !important;
	color: var(--scola-orange) !important;
	opacity: 0.08 !important;
	pointer-events: none;
	user-select: none;
}

.scola-section-number--bg {
	position: absolute !important;
	z-index: 0 !important;
}

.scola-section-number--inline {
	display: block;
	margin-bottom: 16px;
}

.scola-section-number--lined::after {
	content: '';
	display: inline-block;
	height: 1px;
	width: 60px;
	background: var(--scola-orange);
	vertical-align: middle;
	margin-left: 16px;
	opacity: 1;
}

/* === MARQUEE — infinite horizontal scroll === */

.scola-marquee {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding: clamp(40px, 6vw, 80px) 0;
	font-family: 'Hanken Grotesk', sans-serif;
	-webkit-font-smoothing: antialiased;
}

.scola-marquee--dark { background: var(--scola-ink); }

.scola-marquee__track {
	display: flex;
	gap: clamp(32px, 4vw, 64px);
	width: max-content;
	animation: scola-marquee-scroll var(--scola-marquee-duration, 30s) linear infinite;
	will-change: transform;
}

.scola-marquee:hover .scola-marquee__track {
	animation-play-state: paused;
}

@keyframes scola-marquee-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

.scola-marquee__item {
	font-size: clamp(48px, 8vw, 128px);
	font-weight: 900;
	line-height: 1;
	letter-spacing: -0.04em;
	color: var(--scola-ink);
	white-space: nowrap;
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: clamp(32px, 4vw, 64px);
}

.scola-marquee--dark .scola-marquee__item { color: #FFFFFF; }

/* Outlined variant — text stroke only */
.scola-marquee--outlined .scola-marquee__item {
	color: transparent;
	-webkit-text-stroke: 2px var(--scola-orange);
	text-stroke: 2px var(--scola-orange);
}

.scola-marquee__dot {
	display: inline-block;
	width: 0.25em;
	height: 0.25em;
	border-radius: 50%;
	background: var(--scola-orange);
	flex-shrink: 0;
}

@media (prefers-reduced-motion: reduce) {
	.scola-marquee__track { animation: none; }
}

/* === SCROLL REVEAL === */
/* Aplicar .scola-reveal a cualquier elemento → fade+slide al entrar viewport */

.scola-reveal {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
	            transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
}

.scola-reveal.is-revealed {
	opacity: 1;
	transform: translateY(0);
}

.scola-reveal--left {
	transform: translateX(-40px);
}
.scola-reveal--left.is-revealed { transform: translateX(0); }

.scola-reveal--right {
	transform: translateX(40px);
}
.scola-reveal--right.is-revealed { transform: translateX(0); }

.scola-reveal--scale {
	transform: scale(0.96);
}
.scola-reveal--scale.is-revealed { transform: scale(1); }

/* Stagger children — agregando data-stagger="80" en el padre, los hijos revelan con 80ms entre cada uno */
.scola-reveal-stagger > * {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
	            transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.scola-reveal-stagger.is-revealed > * {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	.scola-reveal, .scola-reveal-stagger > * {
		opacity: 1;
		transform: none;
	}
}

/* === MAGNETIC BUTTONS === */
/* Aplicar .scola-magnetic a un botón/elemento → JS le agrega lift+rotate hacia cursor */

.scola-magnetic {
	display: inline-block;
	transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: transform;
}

/* === CUSTOM CURSOR === */
/* Activado via JS solo en desktop con mouse */

body.scola-cursor-active {
	cursor: none;
}

body.scola-cursor-active a,
body.scola-cursor-active button,
body.scola-cursor-active [role="button"],
body.scola-cursor-active input,
body.scola-cursor-active textarea,
body.scola-cursor-active select {
	cursor: none;
}

.scola-cursor {
	position: fixed;
	top: 0;
	left: 0;
	width: 14px;
	height: 14px;
	background: var(--scola-orange);
	border-radius: 50%;
	pointer-events: none;
	z-index: 999999;
	transform: translate(-50%, -50%);
	transition: width 0.25s cubic-bezier(0.16, 1, 0.3, 1),
	            height 0.25s cubic-bezier(0.16, 1, 0.3, 1),
	            background 0.25s ease,
	            mix-blend-mode 0.2s ease;
	mix-blend-mode: difference;
	will-change: transform, width, height;
}

.scola-cursor.is-link {
	width: 48px;
	height: 48px;
	background: var(--scola-orange);
	mix-blend-mode: normal;
}

.scola-cursor.is-text {
	width: 4px;
	height: 24px;
	border-radius: 1px;
}

/* v1.12.1 — Labeled mode: el cursor crece y muestra un label adentro.
   Se activa via [data-cursor-label="TEXT"] en el target (e.g. el CTA del hero). */
.scola-cursor.is-labeled {
	width: 72px;
	height: 72px;
	background: var(--scola-orange);
	mix-blend-mode: normal;
}

.scola-cursor.is-labeled::after {
	content: attr(data-label);
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'JetBrains Mono', ui-monospace, monospace;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.18em;
	color: #0A0A0A;
	text-transform: uppercase;
	white-space: nowrap;
	pointer-events: none;
}

@media (max-width: 1024px), (hover: none), (pointer: coarse) {
	body.scola-cursor-active { cursor: auto; }
	.scola-cursor { display: none; }
}

/* === EDITORIAL LAYOUT HELPERS === */

.scola-section {
	position: relative;
	padding: clamp(80px, 12vw, 160px) clamp(24px, 6vw, 96px);
	background: var(--scola-bg);
}

.scola-section--dark {
	background: var(--scola-ink);
	color: var(--scola-light);
}

.scola-section--dark .scola-display-h1,
.scola-section--dark .scola-display-h2,
.scola-section--dark .scola-display-h3 {
	color: #FFFFFF !important;
}

.scola-container {
	max-width: 1440px;
	margin: 0 auto;
}

.scola-asymmetric {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: clamp(48px, 6vw, 120px);
	align-items: end;
}

@media (max-width: 768px) {
	.scola-asymmetric { grid-template-columns: 1fr; }
}

.scola-asymmetric--right {
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
}

/* Hairline divider */
.scola-hairline {
	display: block;
	height: 1px;
	background: var(--scola-hairline);
	margin: clamp(32px, 5vw, 64px) 0;
	border: 0;
}

/* === PAGE TRANSITION OVERLAY ===
   Full-screen orange (#FD8E25) fade-in con solo el dot animado.
   Después de cargar la nueva página, fade-out revelando el contenido. */

.scola-transition-overlay {
	position: fixed;
	inset: 0;
	background: var(--scola-orange);
	z-index: 99998;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.5s cubic-bezier(0.7, 0, 0.3, 1),
	            visibility 0.5s cubic-bezier(0.7, 0, 0.3, 1);
	pointer-events: none;
	display: flex;
	align-items: center;
	justify-content: center;
}

.scola-transition-overlay.is-leaving {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

/* Solo el dot animado en el centro — sin wordmark, sin texto */
.scola-transition-dot {
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #FFFFFF;
	animation: scola-transition-pulse 1s ease-in-out infinite alternate;
	will-change: transform, opacity;
}

@keyframes scola-transition-pulse {
	0% {
		transform: scale(1);
		opacity: 1;
	}
	100% {
		transform: scale(2.2);
		opacity: 0.4;
	}
}

@media (prefers-reduced-motion: reduce) {
	.scola-transition-dot {
		animation: scola-transition-pulse-reduced 2s ease infinite alternate;
	}
	@keyframes scola-transition-pulse-reduced {
		0%   { opacity: 1; }
		100% { opacity: 0.5; }
	}
}
