:root {
  --bg0:      #070710;
  --bg1:      #0f0f1c;
  --bg2:      #171726;
  --bg3:      #1f1f33;
  --surface:  #252540;
  --border:   rgba(255,255,255,0.07);
  --border2:  rgba(255,255,255,0.13);

  --p:   #7c3aed;
  --p2:  #9d5ff5;
  --p3:  rgba(124,58,237,0.15);
  --c:   #06b6d4;
  --c2:  rgba(6,182,212,0.15);
  --hot: #ec4899;
  --hot2:rgba(236,72,153,0.15);
  --ok:  #22c55e;
  --warn:#f59e0b;
  --err: #ef4444;

  --t1: #f1f5f9;
  --t2: #94a3b8;
  --t3: #64748b;

  --font-h: 'Exo 2', sans-serif;
  --font-b: 'DM Sans', sans-serif;
  --r: 12px;
  --r2: 8px;
  --sh: 0 8px 32px rgba(0,0,0,0.5);
}

/* ── MODO CLARO ── */
body.light {
  --bg0:      #f1f5f9;
  --bg1:      #ffffff;
  --bg2:      #f8fafc;
  --bg3:      #eef1f7;
  --surface:  #e2e8f0;
  --border:   rgba(0,0,0,0.08);
  --border2:  rgba(0,0,0,0.15);

  --p:   #7c3aed;
  --p2:  #6d28d9;
  --p3:  rgba(124,58,237,0.10);
  --c:   #0891b2;
  --c2:  rgba(8,145,178,0.10);
  --hot: #db2777;
  --hot2:rgba(219,39,119,0.10);
  --ok:  #16a34a;
  --warn:#d97706;
  --err: #dc2626;

  --t1: #0f172a;
  --t2: #475569;
  --t3: #94a3b8;

  --sh: 0 8px 32px rgba(0,0,0,0.10);
}

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

body {
  font-family: var(--font-b);
  background: var(--bg0);
  color: var(--t1);
  min-height: 100vh;
  overflow-x: hidden;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg1); }
::-webkit-scrollbar-thumb { background: var(--surface); border-radius: 3px; }

/* ── UTILS ── */
.text-muted { color: var(--t2); }
.text-sm    { font-size: 13px; }
.text-xs    { font-size: 11px; }
.fw-600     { font-weight: 600; }
.gap-4      { gap: 4px; }
.gap-8      { gap: 8px; }
.gap-12     { gap: 12px; }
.gap-16     { gap: 16px; }
.flex       { display: flex; }
.flex-col   { flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }

/* ── BADGE ── */
.badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: 0.3px;
}
.badge-ok   { background: rgba(34,197,94,0.15);  color: var(--ok); }
.badge-warn { background: rgba(245,158,11,0.15); color: var(--warn); }
.badge-err  { background: rgba(239,68,68,0.15);  color: var(--err); }
.badge-p    { background: var(--p3); color: var(--p2); }
