/* Weelis — base.css
 * Tokens de marca + reset + tipografía global.
 * Doc canónico: docs/BRAND.md
 *
 * Tipografía dual: Anybody para títulos, DM Sans para body / UI.
 * Paleta: cream de fondo, navy para chrome oscuro, azul como acción primaria,
 * cyan/yellow/orange/pink como acentos de estado e insight.
 */

:root {
  /* ---------- Paleta nueva — fuente de verdad ---------- */
  --c-cream:       #F7F0E2;
  --c-cream-soft:  #FBF7EE;
  --c-white:       #FFFFFF;
  --c-surface-soft: #FCFAF5;

  --c-yellow:      #F8B839;
  --c-orange:      #F95D00;
  --c-pink:        #FA18F4;
  --c-blue:        #2D5AFA;
  --c-cyan:        #01A6F6;
  --c-navy:        #090F3F;

  --c-text:        #0D0D0F;
  --c-text-muted:  #555555;
  --c-text-soft:   #7A7A7A;
  --c-border:      #E6E0D4;

  /* ---------- Aliases legacy → mantienen app.css y install.php funcionando ----------
   * Semántica preservada: --color-bg era "el blanco de las cards" (FFFFFF),
   * --color-surface era "la tinta suave de fondos secundarios" (CBF3F0).
   * Al pasar a cream+white, el "blanco-card" sigue siendo blanco, y la
   * "tinta suave" pasa a ser cream. Los otros tokens se remapean por
   * función semántica (primary=acción, accent=ok, danger=alerta). */
  --color-primary:      var(--c-blue);
  --color-primary-soft: var(--c-yellow);  /* hover/warn tint, antes warm soft */
  --color-bg:           var(--c-white);   /* superficie clara de cards */
  --color-surface:      var(--c-cream);   /* fondo secundario suave */
  --color-accent:       var(--c-cyan);    /* OK / dato positivo */
  --color-text:         var(--c-text);
  --color-danger:       var(--c-orange);  /* alerta — la nueva paleta no incluye rojo */

  /* ---------- Tipografía dual ---------- */
  --font-title: 'Anybody', system-ui, -apple-system, sans-serif;
  --font-body:  'DM Sans', system-ui, -apple-system, sans-serif;
  --font-base:  var(--font-body);

  /* ---------- Escala tipográfica ---------- */
  --text-xs:   12px;
  --text-sm:   14px;
  --text-md:   16px;
  --text-lg:   18px;
  --text-xl:   24px;
  --text-2xl:  32px;
  --text-3xl:  48px;
  --text-hero: 72px;

  /* ---------- Radios ---------- */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-xl:   28px;
  --radius-2xl:  40px;
  --radius-pill: 999px;

  /* ---------- Espaciado ---------- */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;
  --space-6: 48px;
  --space-7: 64px;
  --space-8: 96px;

  /* ---------- Sombras ---------- */
  --shadow-sm: 0 1px 2px rgba(9, 15, 63, 0.06);
  --shadow-md: 0 4px 16px rgba(9, 15, 63, 0.08);
  --shadow-lg: 0 18px 48px rgba(9, 15, 63, 0.12);
}

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

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-body);
  color: var(--c-text);
  background: var(--c-cream);
  line-height: 1.55;
  font-size: var(--text-md);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0 0 var(--space-3);
  font-family: var(--font-title);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--c-text);
}

h1 { font-size: clamp(40px, 6vw, 72px); font-weight: 900; letter-spacing: -0.04em; }
h2 { font-size: clamp(28px, 4vw, 44px); font-weight: 900; letter-spacing: -0.03em; }
h3 { font-size: var(--text-xl); font-weight: 700; }
h4 { font-size: var(--text-lg); font-weight: 700; }

p {
  margin: 0 0 var(--space-3);
  color: var(--c-text-muted);
}

a {
  color: var(--c-blue);
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

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

button {
  cursor: pointer;
}

:focus-visible {
  outline: 2px solid var(--c-blue);
  outline-offset: 2px;
}

img {
  max-width: 100%;
  height: auto;
}

hr {
  border: 0;
  border-top: 1px solid var(--c-border);
  margin: var(--space-4) 0;
}

::selection {
  background: var(--c-yellow);
  color: var(--c-text);
}
