/* ============================================================
   BASE — reset mínimo, tipografía y reglas de accesibilidad
   ============================================================ */

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

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--fuente-cuerpo);
  font-size: var(--tamano-cuerpo);
  line-height: 1.65;
  color: var(--color-ciruela);
  background-color: var(--color-champan);
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  display: block;
}

/* Sección que alterna fondo (70% del sitio se reparte entre estos dos) */
.fondo-champan { background-color: var(--color-champan); }
.fondo-rosa { background-color: var(--color-rosa-palido); }

h1, h2, h3, h4 {
  font-family: var(--fuente-titulos);
  font-weight: 500; /* Medium */
  color: var(--color-ciruela);
  line-height: 1.2;
  margin: 0 0 var(--espacio-sm) 0;
}

h1 { font-size: var(--tamano-h1); }
h2 { font-size: var(--tamano-h2); }
h3 { font-size: var(--tamano-h3); }

p {
  margin: 0 0 var(--espacio-sm) 0;
}

a {
  color: var(--color-ciruela);
  text-decoration-color: var(--color-oro);
  text-underline-offset: 3px;
}

a:hover, a:focus-visible {
  color: var(--color-oro); /* único lugar donde el oro reemplaza texto: hover */
}

/* Accesibilidad: foco visible siempre, nunca lo quitamos */
:focus-visible {
  outline: 2px solid var(--color-oro);
  outline-offset: 2px;
}

.contenedor {
  max-width: var(--ancho-contenido);
  margin: 0 auto;
  padding: 0 var(--espacio-sm);
}

.seccion {
  padding: var(--espacio-lg) 0;
}

/* Utilidad para lectores de pantalla: oculta visualmente sin ocultar del DOM */
.solo-lector {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Tamaños tipográficos más generosos en escritorio */
@media (min-width: 768px) {
  :root {
    --tamano-h1: 3.25rem;
    --tamano-h2: 2.25rem;
    --tamano-h3: 1.6rem;
    --tamano-cuerpo: 1.125rem;
  }
}
