/* Estilos globales — equivalente funcional a 26NOWE/global.css.
 * Body, focus visible, selección, reduced-motion. Tipografía base.
 */

html {
  font-family: var(--font-sans);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-normal);
  color: var(--color-ink);
  background-color: var(--color-paper);
  font-feature-settings: "cv11";
  scroll-padding-top: 96px;
  overflow-x: clip;
}

body {
  min-height: 100vh;
  overflow-x: clip;
}

:focus-visible {
  outline: 2px solid var(--color-ink);
  outline-offset: 2px;
}

:focus:not(:focus-visible) {
  outline: none;
}

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

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

a {
  color: inherit;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
}

/* Typography utilities */
.heading-display {
  font-family: var(--font-sans);
  font-size: var(--font-size-display);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--tracking-tight);
}

.heading-h1 {
  font-family: var(--font-sans);
  font-size: var(--font-size-h1);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--tracking-tight);
}

.heading-h2 {
  font-family: var(--font-sans);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--tracking-tight);
}

.heading-h3 {
  font-family: var(--font-sans);
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-tight);
  letter-spacing: var(--tracking-tight);
}

.text-body-lg {
  font-size: var(--font-size-body-lg);
  line-height: var(--line-height-normal);
  color: var(--color-dim);
}

.text-ui {
  font-size: var(--font-size-ui);
  color: var(--color-dim);
}

.text-mono {
  font-family: var(--font-mono);
  font-size: var(--font-size-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
}

.em-serif {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
}

/* Container */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

@media (min-width: 768px) {
  .container {
    padding-inline: var(--space-16);
  }
}

/* Rule */
.rule {
  border: 0;
  border-top: 1px solid var(--color-rule);
  margin: 0;
}
