/* ============================================================================
   styles.css — Reset, base tipográfica y layout · Global Safety Solutions
   Cargar DESPUÉS de tokens.css y fonts.css.
   El sistema de componentes completo vive en components.css (Fase 1).
   ============================================================================ */

/* ---------------------------------------------------------------- Reset --- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth; /* Lenis lo gestiona en JS; esto es respaldo */
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  font-family: var(--font-cuerpo);
  font-weight: var(--peso-cuerpo);
  font-size: var(--fs-cuerpo);
  line-height: var(--lh-cuerpo);
  color: var(--color-texto);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}

img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
ul[role="list"], ol[role="list"] { list-style: none; padding: 0; }

a { color: var(--color-marca); text-decoration: none; transition: color var(--dur-rapida) var(--ease-suave); }
a:hover { color: var(--color-acento); }

/* ------------------------------------------------ Tipografía base --- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: var(--peso-display);
  line-height: var(--lh-titulo);
  letter-spacing: var(--tracking-titulo);
  color: var(--color-texto);
  text-wrap: balance;
}
h1 { font-size: var(--fs-h1); line-height: var(--lh-apretado); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
p  { max-width: var(--ancho-texto); }

/* ----------------------------------------- Barra de progreso de scroll --- */
.scroll-progreso {
  position: fixed; top: 0; left: 0; height: 3px; width: 0;
  background: var(--rojo); z-index: 1500; pointer-events: none;
  transition: width 80ms linear;
}
@media (prefers-reduced-motion: reduce) { .scroll-progreso { transition: none; } }

/* ---------------------------------------------------- Accesibilidad --- */
:focus-visible {
  outline: 3px solid var(--color-acento);
  outline-offset: 2px;
  border-radius: var(--radio-sm);
}

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

.skip-link {
  position: absolute;
  left: var(--space-4); top: -100%;
  z-index: var(--z-overlay);
  background: var(--azul-900);
  color: var(--blanco);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radio);
  transition: top var(--dur) var(--ease-suave);
}
.skip-link:focus { top: var(--space-4); color: var(--blanco); }

/* ------------------------------------------------------------ Layout --- */
.contenedor {
  width: 100%;
  max-width: var(--ancho-contenido);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.seccion { padding-block: var(--seccion-py); }
.seccion--alt { background: var(--color-bg-alt); }
.seccion--invertida {
  background: var(--color-bg-invertido);
  color: var(--color-texto-inv);
}
.seccion--invertida h1,
.seccion--invertida h2,
.seccion--invertida h3 { color: var(--color-texto-inv); }

main { min-height: 60vh; }

/* ---------------------------------------------------- Header / Nav --- */
/* El sistema completo del header (sticky que se compacta, mega-menús,
   selector ES/EN, menú móvil y transparencia sobre el hero) vive en
   header.css, cargado después de components.css. */

/* ----------------------------------------------- Footer (shell base) --- */
/* El footer completo con columnas y redes se construye en Fase 6. */
.site-footer {
  background: var(--azul-900);
  color: var(--color-texto-inv-suave);
  padding-block: var(--space-8) var(--space-6);
}
.site-footer a { color: var(--gris-300); }
.site-footer a:hover { color: var(--blanco); }
.site-footer__logo {
  height: 64px; width: auto;
  margin-bottom: var(--space-4);
  filter: brightness(0) invert(1); /* logo en blanco sobre footer oscuro */
  opacity: 0.95;
}
.site-footer__bottom {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: space-between;
  font-size: var(--fs-caption);
  color: var(--gris-300);
}
.site-footer__handles { color: var(--gris-300); }

/* Rejilla superior del footer: marca + columnas */
.site-footer__top {
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1fr;
}
@media (min-width: 600px) { .site-footer__top { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) {
  .site-footer__top { grid-template-columns: 1.7fr 1fr 1fr 1fr 1.2fr; gap: var(--space-8); }
}
.site-footer__marca { grid-column: 1 / -1; }
@media (min-width: 980px) { .site-footer__marca { grid-column: auto; } }

.site-footer__tagline {
  max-width: 38ch;
  margin-block: var(--space-3) var(--space-4);
  color: var(--gris-300);
  font-size: 0.95rem;
}

/* Iconos de redes */
.site-footer__redes { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.site-footer__redes a {
  display: inline-grid; place-items: center;
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.18);
  color: var(--gris-300);
  transition: background-color var(--dur-rapida) var(--ease-suave),
              color var(--dur-rapida) var(--ease-suave),
              border-color var(--dur-rapida) var(--ease-suave),
              transform var(--dur-rapida) var(--ease-suave);
}
.site-footer__redes svg { width: 18px; height: 18px; }
.site-footer__redes a:hover {
  background: rgba(255,255,255,0.10);
  color: var(--blanco);
  border-color: transparent;
  transform: translateY(-2px);
}

/* Columnas */
.site-footer__titulo {
  font-family: var(--font-display);
  font-weight: var(--peso-medio);
  font-size: 0.95rem;
  color: var(--blanco);
  margin-bottom: var(--space-4);
}
.site-footer__col ul { display: flex; flex-direction: column; gap: var(--space-2); }
.site-footer__col a, .site-footer__col li { font-size: 0.95rem; }
.site-footer .es-zona { color: var(--rojo); font-weight: var(--peso-medio); }
.site-footer .es-zona:hover { color: var(--rojo-700); }

/* --------------------------------------------- Placeholder de medios --- */
/* Marcador visible para assets pendientes (Sección 13). NUNCA stock genérico. */
.placeholder-media {
  display: grid;
  place-items: center;
  background:
    repeating-linear-gradient(45deg,
      var(--gris-100), var(--gris-100) 14px,
      var(--gris-50) 14px, var(--gris-50) 28px);
  color: var(--gris-500);
  border: 1px dashed var(--gris-300);
  border-radius: var(--radio);
  font-size: var(--fs-caption);
  text-align: center;
  padding: var(--space-5);
  min-height: 180px;
}
.placeholder-media span { max-width: 32ch; }
