/**
 * 01-reset.css — Reset moderno
 *
 * Basado en Modern CSS Reset (Andy Bell) + ajustes propios.
 * Decisión: reset mínimo — solo lo que previene inconsistencias
 * entre navegadores sin sobre-resetear.
 */

/* Box-sizing universal */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Comportamiento de scroll suave */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%; /* Evita zoom automático en iOS */
  text-size-adjust: 100%;
}

/* Preferencias de usuario: desactivar animaciones si lo piden */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

body {
  background-color: var(--ic-bg-dark);
  color: var(--ic-text-primary);
  font-family: var(--ic-font-sans);
  font-size: var(--ic-text-body);
  font-weight: 400;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;   /* macOS: fuente más fina y nítida */
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;                     /* Prevenir scroll horizontal */
}

/* Tipografía base */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--ic-font-serif);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

p {
  line-height: 1.75;
}

/* Links */
a {
  color: inherit;
  text-decoration: none;
  transition: color var(--ic-duration-base) var(--ic-ease);
}

a:focus-visible {
  outline: 2px solid var(--ic-accent);
  outline-offset: 3px;
  border-radius: var(--ic-radius-sm);
}

/* Imágenes responsivas */
img,
video,
svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Listas sin estilo (se aplica con clase .list-reset) */
.list-reset {
  list-style: none;
}

/* Inputs base */
input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}

button {
  cursor: pointer;
  border: none;
  background: none;
}

/* Texto seleccionado */
::selection {
  background-color: var(--ic-accent);
  color: white;
}

/* Scrollbar personalizada (webkit) */
::-webkit-scrollbar {
  width: 6px;
}
::-webkit-scrollbar-track {
  background: var(--ic-bg-deep);
}
::-webkit-scrollbar-thumb {
  background: var(--ic-accent);
  border-radius: var(--ic-radius-pill);
}

/* Focus visible para accesibilidad */
:focus-visible {
  outline: 2px solid var(--ic-accent);
  outline-offset: 3px;
}
:focus:not(:focus-visible) {
  outline: none;
}
