/*
 * La Galga Gris · section-hero.css
 * Hero split editorial — reutilizable en home, category, landings.
 */

.lgg-hero {
	padding: clamp(2rem, 6vw, 5rem) var(--container-pad-x) clamp(3rem, 8vw, 6rem);
	overflow: hidden;
}
.lgg-hero__inner {
	max-width: var(--container-wide);
	margin-inline: auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}
@media (min-width: 960px) {
	.lgg-hero__inner { grid-template-columns: 1.2fr 1fr; gap: clamp(3rem, 6vw, 6rem); }
	.lgg-hero--reverse .lgg-hero__inner { grid-template-columns: 1fr 1.2fr; }
	.lgg-hero--reverse .lgg-hero__copy { order: 2; }
	.lgg-hero--reverse .lgg-hero__media { order: 1; }
}

.lgg-hero__copy {
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
	max-width: 620px;
}

.lgg-hero__title {
	margin: 0;
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 7vw, 5.5rem);
	font-weight: var(--fw-medium);
	line-height: 0.98;
	letter-spacing: -0.025em;
	color: var(--color-ink-primary);
	text-wrap: balance;
}
.lgg-hero__title-italic {
	font-style: italic;
	color: var(--color-accent);
	display: inline-block;
}

/* SplitText helper styles — el plugin envuelve cada línea en un span de esta clase. */
.lgg-split-line {
	display: block;
	overflow: hidden;
	padding-block: 0.05em;
}

.lgg-hero__sub {
	max-width: 52ch;
	font-size: clamp(1rem, 1.6vw, 1.2rem);
}

.lgg-hero__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sp-3);
	margin-top: var(--sp-2);
}

.lgg-hero__stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(110px, max-content));
	gap: var(--sp-5);
	margin: var(--sp-5) 0 0;
	padding-top: var(--sp-4);
	border-top: 1px solid var(--color-border-subtle);
	max-width: 520px;
}
.lgg-hero__stats > div { display: flex; flex-direction: column; gap: 2px; }
.lgg-hero__stats dt {
	font-size: var(--fz-micro);
	letter-spacing: var(--ls-eyebrow);
	text-transform: uppercase;
	color: var(--color-ink-muted);
}
.lgg-hero__stats dd {
	margin: 0;
	font-family: var(--font-display);
	font-size: 1.1rem;
	font-weight: var(--fw-medium);
	color: var(--color-ink-primary);
}

/* ── Media ──────────────────────────────────────────────────────── */
.lgg-hero__media {
	position: relative;
	margin: 0;
}
.lgg-hero__frame {
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-bg-subtle);
	transform: rotate(-1deg);
	will-change: transform;
	transition: transform var(--dur-slow) var(--ease-emphasized);
}
@media (min-width: 960px) {
	.lgg-hero__frame { transform: rotate(0.5deg); }
	.lgg-hero--reverse .lgg-hero__frame { transform: rotate(-0.6deg); }
}
.lgg-hero__frame img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease-emphasized);
}
.lgg-hero:hover .lgg-hero__frame { transform: rotate(0deg); }

.lgg-hero__badge {
	position: absolute;
	left: -12px; bottom: 24px;
	margin: 0;
}

.lgg-hero__decor {
	position: absolute;
	top: -28px; right: -28px;
	width: 80px; height: 80px;
	color: var(--color-accent);
	opacity: 0.5;
	animation: lgg-hero-spin 60s linear infinite;
}
@keyframes lgg-hero-spin {
	from { transform: rotate(0); }
	to   { transform: rotate(360deg); }
}
@media (prefers-reduced-motion: reduce) {
	.lgg-hero__decor { animation: none; }
	.lgg-hero__frame, .lgg-hero__frame img { transition: none; transform: none !important; }
}
