/*
 * La Galga Gris · base.css
 * Reset moderno + tipografía baseline + a11y essentials. Solo lo común a todas las páginas.
 */

*, *::before, *::after { box-sizing: border-box; }

html {
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: transparent;
	text-rendering: optimizeLegibility;
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
}

body {
	margin: 0;
	min-height: 100vh;
	font-family: var(--font-body);
	font-size: var(--fz-body);
	line-height: var(--lh-body);
	color: var(--color-ink-primary);
	background: var(--color-bg-base);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: "ss01", "cv11";
	overflow-x: clip;
}

/* Lenis smooth scroll guard — el JS añade .lenis al html cuando está activo */
html.lenis,
html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: clip; }

img, picture, video, canvas, svg {
	display: block;
	max-width: 100%;
	height: auto;
}

img { font-style: italic; }
img[loading="lazy"] { background: var(--color-bg-subtle); }

input, button, textarea, select {
	font: inherit;
	color: inherit;
}

button { background: none; border: 0; padding: 0; cursor: pointer; color: inherit; }

a {
	color: var(--color-accent);
	text-decoration-color: color-mix(in srgb, var(--color-accent) 35%, transparent);
	text-underline-offset: 0.18em;
	transition: color var(--dur-fast) var(--ease-standard),
				text-decoration-color var(--dur-fast) var(--ease-standard);
}
a:hover { color: var(--color-accent-hover); text-decoration-color: currentColor; }

p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }

ul, ol { margin: 0 0 1em; padding-left: 1.25em; }

h1, h2, h3, h4, h5, h6 {
	margin: 0 0 0.5em;
	font-family: var(--font-display);
	font-weight: var(--fw-medium);
	line-height: var(--lh-heading);
	letter-spacing: var(--ls-heading);
	color: var(--color-ink-primary);
	text-wrap: balance;
}

h1, .lgg-h1 { font-size: var(--fz-h1); line-height: var(--lh-display); letter-spacing: var(--ls-display); }
h2, .lgg-h2 { font-size: var(--fz-h2); }
h3, .lgg-h3 { font-size: var(--fz-h3); }
h4, .lgg-h4 {
	font-size: var(--fz-h4);
	font-family: var(--font-body);
	font-weight: var(--fw-semibold);
	letter-spacing: 0.01em;
}

.lgg-display-xl { font-size: var(--fz-display-xl); line-height: var(--lh-display); letter-spacing: var(--ls-display); font-family: var(--font-display); font-weight: var(--fw-medium); }
.lgg-display-l  { font-size: var(--fz-display-l);  line-height: var(--lh-display); letter-spacing: var(--ls-display); font-family: var(--font-display); font-weight: var(--fw-medium); }

.lgg-eyebrow {
	display: inline-block;
	font-family: var(--font-body);
	font-size: var(--fz-micro);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-eyebrow);
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--sp-3);
}

.lgg-prose {
	font-size: var(--fz-body-l);
	line-height: var(--lh-body);
	color: var(--color-ink-secondary);
	max-width: 62ch;
}
.lgg-prose strong { color: var(--color-ink-primary); }
.lgg-prose a { font-weight: var(--fw-medium); }

::selection {
	background: var(--color-accent);
	color: var(--color-ink-inverse);
}

/* ── A11y ─────────────────────────────────────────────────────────── */
:focus { outline: none; }
:focus-visible {
	outline: 2px solid var(--color-focus-ring);
	outline-offset: 3px;
	border-radius: 4px;
}

.lgg-skip-link {
	position: absolute;
	top: -100px;
	left: var(--sp-4);
	z-index: var(--z-toast);
	padding: var(--sp-3) var(--sp-5);
	background: var(--color-ink-primary);
	color: var(--color-ink-inverse);
	font-weight: var(--fw-semibold);
	border-radius: var(--radius-md);
	transition: top var(--dur-base) var(--ease-emphasized);
}
.lgg-skip-link:focus,
.lgg-skip-link:focus-visible {
	top: var(--sp-4);
	color: var(--color-ink-inverse);
}

.lgg-sr-only {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}
