/* ============================================================
   Aceros Bugambilia — base.css
   2 paletas: Signature (dark) · Pearl (light)
   Incluye: variables, reset, #hx-bar, "Ir a", theme selector
   ============================================================ */

/* ── VARIABLES: CLARO (default) ─────────────────────────────── */
:root {
  --bg:        #f2f5fb;
  --surface:   #ffffff;
  --surface2:  #edf1f8;
  --surface3:  #e4eaf4;
  --border:    #cdd5e6;
  --accent:    #00b8d9;
  --accent-lt: #33c9e6;
  --accent-dk: #1b3163;
  --accent-bg: rgba(0,184,217,.08);
  --accent-2:  #7c3aed;
  --action:    #f97316;
  --green:     #16a36e;
  --red:       #e03535;
  --yellow:    #d97706;
  --blue:      #2563eb;
  --green-rgb: 22,163,110;  --red-rgb:    224,53,53;
  --yellow-rgb:217,119,6;   --blue-rgb:   37,99,235;
  --accent-rgb:0,184,217;   --accent-dk-rgb:27,49,99;
  --muted-rgb: 90,112,144;  --border-rgb: 205,213,230;
  --text:      #1e2d4a;
  --muted:     #5a7090;
  --muted2:    #8fa8c2;
  --text-inverse: #ffffff;
  --font: 'Segoe UI Variable','Segoe UI',Inter,system-ui,-apple-system,sans-serif;
  --mono: 'Cascadia Code','Courier New',monospace;
  --font-scale: 1;
  --radius-sm: 6px;  --radius: 10px;  --radius-lg: 14px;
  --shadow:    0 4px 24px rgba(27,49,99,.10);
  --shadow-sm: 0 2px 8px  rgba(27,49,99,.07);
  --fs-xs:11px; --fs-sm:12px; --fs-base:13px; --fs-md:14px;
  --fs-lg:15px; --fs-xl:16px; --fs-2xl:20px; --fs-4xl:24px;
  --grad: linear-gradient(90deg,#4a6fa5 0%,#c87941 100%);
}

/* ── TEMA 1 · SIGNATURE (data-theme="dark") ─────────────────── */
[data-theme="dark"] {
  --bg:#0d1117;       --surface:#161b22;  --surface2:#1c2330;
  --surface3:#090d13; --border:#21262d;
  --accent:#4a6fa5;   --accent-lt:#7a9fd4; --accent-dk:#2c4a7c;
  --accent-rgb:74,111,165; --accent-dk-rgb:44,74,124;
  --accent-bg:rgba(74,111,165,.10);
  --accent-2:#c87941; --action:#c87941;
  --accent-2-rgb:200,121,65; --action-rgb:200,121,65;
  --text:#e6edf3;     --text-inverse:#0d1117;
  --muted:#7d8590;    --muted2:#30363d;
  --border-rgb:33,38,45;
  --shadow:0 4px 20px rgba(0,0,0,.55);
  --shadow-sm:0 2px 8px rgba(0,0,0,.40);
  --green:#22c55e;  --green-rgb:34,197,94;
  --red:#f87171;    --red-rgb:248,113,113;
  --yellow:#fbbf24; --yellow-rgb:251,191,36;
  --blue:#60a5fa;   --blue-rgb:96,165,250;
  --orange:#fb923c; --orange-rgb:251,146,60;
  --grad:linear-gradient(90deg,#4a6fa5 0%,#c87941 100%);
}

/* ── TEMA 2 · PEARL (data-theme="light") ────────────────────── */
[data-theme="light"] {
  --bg:#faf7f3;       --surface:#ffffff;  --surface2:#f2ede8;
  --surface3:#e8e0d8; --border:#e0d8ce;
  --accent:#3a5578;   --accent-lt:#5a7898; --accent-dk:#1e3a5a;
  --accent-rgb:58,85,120; --accent-dk-rgb:30,58,90;
  --accent-bg:rgba(58,85,120,.08);
  --accent-2:#c07030; --action:#b86e30;
  --accent-2-rgb:192,112,48; --action-rgb:184,110,48;
  --text:#2a2218;     --text-inverse:#ffffff;
  --muted:#8a7a6a;    --muted2:#c0b0a0;
  --border-rgb:224,216,206;
  --shadow:0 4px 24px rgba(42,34,24,.10);
  --shadow-sm:0 2px 8px rgba(42,34,24,.07);
  --green:#16a34a;  --green-rgb:22,163,74;
  --red:#dc2626;    --red-rgb:220,38,38;
  --yellow:#d97706; --yellow-rgb:217,119,6;
  --blue:#2563eb;   --blue-rgb:37,99,235;
  --orange:#c2410c; --orange-rgb:194,65,12;
  --grad:linear-gradient(90deg,#1e3a6a 0%,#c07030 100%);
}

/* ── PUENTES DE COMPATIBILIDAD — variables Evidencia ─────────── */
:root,[data-theme="dark"],[data-theme="light"] {
  /* Semáforos alias */
  --verde: var(--green);   --verde2: var(--green);
  --rojo:  var(--red);     --red-alert: var(--red);
  --azul:  var(--accent);  --azul2: var(--accent-lt);
  --purple: var(--accent-2); --orange: var(--action);
  --accent2: var(--accent-2);
  /* Texto alias */
  --text2:   var(--muted);
  --text3:   var(--muted2);
  --subtle:  var(--surface3);
  --sidebar: var(--surface);
  --sidebar2: var(--surface2);
  /* Estado semántico alias */
  --ok:      var(--green);
  --warn:    var(--yellow);
  --danger:  var(--red);
  --border2: var(--border);
  /* Accent expanded */
  --accent-txt:    var(--text-inverse);
  --accent-dim:    rgba(var(--accent-rgb),.10);
  --accent-glow:   rgba(var(--accent-rgb),.22);
  --accent-subtle: rgba(var(--accent-rgb),.05);
  --accent-soft:   rgba(var(--accent-rgb),.14);
  --accent-border: rgba(var(--accent-rgb),.22);
  --accent-med:    rgba(var(--accent-rgb),.28);
  --accent-strong: rgba(var(--accent-rgb),.42);
  /* Shadow alias */
  --shadow-lg: 0 16px 36px rgba(0,0,0,.35);
  /* Prioridades */
  --prio-alta:  var(--red);
  --prio-media: var(--yellow);
  --prio-baja:  var(--green);
  /* ABC classification — colores semánticos fijos */
  --AA: #a78bfa;
  --A:  var(--green);
  --B:  var(--yellow);
  --C:  var(--red);
}
[data-theme="light"] {
  --AA: #7c3aed;
}

/* ── MEDIA QUERY: preferencia del SO ────────────────────────── */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    --bg:#0d1117; --surface:#161b22; --surface2:#1c2330;
    --surface3:#090d13; --border:#21262d;
    --accent:#4a6fa5; --accent-lt:#7a9fd4; --accent-dk:#2c4a7c;
    --accent-rgb:74,111,165; --accent-bg:rgba(74,111,165,.10);
    --accent-2:#c87941; --action:#c87941;
    --text:#e6edf3; --text-inverse:#0d1117;
    --muted:#7d8590; --muted2:#30363d;
    --border-rgb:33,38,45;
    --shadow:0 4px 20px rgba(0,0,0,.55);
    --shadow-sm:0 2px 8px rgba(0,0,0,.40);
    --green:#22c55e; --green-rgb:34,197,94;
    --red:#f87171;   --red-rgb:248,113,113;
    --yellow:#fbbf24; --yellow-rgb:251,191,36;
    --blue:#60a5fa;   --blue-rgb:96,165,250;
    --grad:linear-gradient(90deg,#4a6fa5 0%,#c87941 100%);
  }
}

/* ── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html,body {
  min-height:100%; font-family:var(--font);
  background:var(--bg); color:var(--text);
  font-size:calc(var(--fs-lg)*var(--font-scale));
  -webkit-font-smoothing:antialiased;
}
body { padding-top:56px !important; } /* altura del #hx-bar — solo en body, no en html */

/* ── SCROLLBAR ──────────────────────────────────────────────── */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--accent); }

/* ════════════════════════════════════════════════════════════
   #HX-BAR — Barra de navegación fija
   ════════════════════════════════════════════════════════════ */
#hx-bar {
  position:fixed; top:0; left:0; right:0; height:56px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 20px; z-index:9000;
  box-shadow:var(--shadow-sm);
}
/* Línea de marca (gradiente navy→copper) en tema oscuro */
[data-theme="dark"] #hx-bar {
  border-bottom:none;
  background:var(--surface) var(--grad) bottom / 100% 2px no-repeat;
}

/* ── Lado izquierdo: logo + Ir a ── */
.hxb-left { display:flex; align-items:center; gap:16px; flex-shrink:0; }

.hxb-brand {
  display:flex; align-items:center; gap:8px;
  text-decoration:none; color:var(--text);
  font-size:var(--fs-xl); font-weight:700; letter-spacing:-.3px;
}
/* Gradiente de marca en el texto del logo */
[data-theme="dark"]  .hxb-brand,
[data-theme="light"] .hxb-brand {
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; color:transparent;
}

/* ── Lado derecho: acciones + tema ── */
.hxb-right { display:flex; align-items:center; gap:6px; flex-shrink:0; }

/* Botón genérico de la barra */
.hxb-btn {
  padding:5px 12px; background:transparent;
  border:1px solid var(--border); color:var(--muted);
  border-radius:8px; font-size:var(--fs-sm);
  text-decoration:none; transition:all .2s;
  cursor:pointer; font-family:var(--font);
  display:inline-flex; align-items:center; gap:5px;
  white-space:nowrap;
}
.hxb-btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); }
.hxb-btn.primary {
  background:var(--accent-dk); color:var(--text-inverse); border-color:transparent;
}
.hxb-btn.primary:hover { background:var(--accent); }

/* ── Separador ── */
.hxb-sep { width:1px; height:22px; background:var(--border); margin:0 4px; flex-shrink:0; }

/* ════════════════════════════════════════════════════════════
   "IR A" — Navegación de módulos (dropdown)
   ════════════════════════════════════════════════════════════ */
.hxb-nav-wrap { position:relative; }

.hxb-ira-btn {
  padding:5px 12px; background:transparent;
  border:1px solid var(--border); color:var(--muted);
  border-radius:8px; font-size:var(--fs-sm); font-weight:600;
  cursor:pointer; font-family:var(--font);
  display:inline-flex; align-items:center; gap:4px;
  transition:all .2s; white-space:nowrap;
}
.hxb-ira-btn:hover,.hxb-ira-btn.open {
  border-color:var(--accent); color:var(--accent); background:var(--accent-dim);
}

.hxb-nav-panel {
  display:none; position:absolute;
  top:calc(100% + 8px); left:0;
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; box-shadow:var(--shadow);
  min-width:240px; z-index:9999; padding:6px; overflow:hidden;
}
.hxb-nav-panel.open { display:block; }

.hxb-nav-section {
  font-size:10px; font-weight:700; text-transform:uppercase;
  letter-spacing:.6px; color:var(--muted2);
  padding:8px 12px 4px; margin-top:4px;
}
.hxb-nav-section:first-child { margin-top:0; }
.hxb-nav-panel a {
  display:flex; align-items:center; gap:8px;
  padding:8px 12px; color:var(--text); text-decoration:none;
  font-size:var(--fs-sm); border-radius:8px;
  transition:background .12s,color .12s; white-space:nowrap;
}
.hxb-nav-panel a:hover { background:var(--surface2); color:var(--accent); }
.hxb-nav-panel a.active { background:var(--accent-dim); color:var(--accent); font-weight:600; }
.hxb-nav-sep { height:1px; background:var(--border); margin:4px 8px; }

/* ════════════════════════════════════════════════════════════
   SELECTOR DE TEMA (dropdown)
   ════════════════════════════════════════════════════════════ */
.hxb-theme-wrap { position:relative; }

.hxb-theme-btn {
  padding:5px 10px; background:transparent;
  border:1px solid var(--border); color:var(--muted);
  border-radius:8px; font-size:13px;
  cursor:pointer; font-family:var(--font);
  display:inline-flex; align-items:center; gap:4px;
  transition:all .2s;
}
.hxb-theme-btn:hover,.hxb-theme-btn.open {
  border-color:var(--accent); color:var(--accent); background:var(--accent-dim);
}

.hxb-theme-panel {
  display:none; position:absolute;
  top:calc(100% + 8px); right:0;
  background:var(--surface); border:1px solid var(--border);
  border-radius:12px; box-shadow:var(--shadow);
  min-width:160px; z-index:9999; padding:6px;
}
.hxb-theme-panel.open { display:block; }

.hxb-theme-opt {
  display:flex; align-items:center; gap:8px; width:100%;
  padding:8px 12px; background:transparent; border:none;
  color:var(--text); font-size:var(--fs-sm); font-family:var(--font);
  cursor:pointer; border-radius:8px; text-align:left;
  transition:background .12s,color .12s;
}
.hxb-theme-opt:hover { background:var(--surface2); color:var(--accent); }
.hxb-theme-opt.active { background:var(--accent-dim); color:var(--accent); font-weight:600; }

/* ── Dot de color del tema ── */
.theme-dot {
  width:10px; height:10px; border-radius:50%;
  flex-shrink:0; border:1px solid rgba(255,255,255,.2);
}

/* ════════════════════════════════════════════════════════════
   COMPONENTES COMUNES (tabla, badge, dif, etc.)
   ════════════════════════════════════════════════════════════ */

/* Tabla */
table { width:100%; border-collapse:separate; border-spacing:0; }
thead th {
  background:var(--surface2); padding:11px 12px;
  font-size:var(--fs-xs); font-weight:700; text-transform:uppercase;
  letter-spacing:.5px; color:var(--muted);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:5; white-space:nowrap;
}
thead th:hover { color:var(--accent); }
tbody td {
  padding:12px; font-size:var(--fs-md); color:var(--text);
  border-bottom:1px solid rgba(var(--border-rgb),.5);
  vertical-align:middle;
}
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover { background:var(--surface2); }

/* Diferencias */
.dif-neg  { color:var(--red);    font-weight:700; }
.dif-pos  { color:var(--green);  font-weight:700; }
.dif-ok   { color:var(--accent); font-weight:700; }

/* Badge ABC */
.badge-abc { display:inline-block; padding:1px 6px; border-radius:999px; font-weight:700; font-size:9px; vertical-align:middle; margin-right:4px; border:1px solid transparent; }
.badge-abc.AA { background:rgba(167,139,250,.18); color:var(--AA); border-color:rgba(167,139,250,.3); }
.badge-abc.A  { background:rgba(var(--green-rgb),.18); color:var(--green); border-color:rgba(var(--green-rgb),.3); }
.badge-abc.B  { background:rgba(var(--yellow-rgb),.18); color:var(--yellow); border-color:rgba(var(--yellow-rgb),.3); }
.badge-abc.C  { background:rgba(var(--red-rgb),.18); color:var(--red); border-color:rgba(var(--red-rgb),.3); }

/* Toast */
#toast {
  position:fixed; bottom:24px; left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--surface2); border:1px solid var(--border);
  border-radius:10px; padding:11px 22px;
  font-size:var(--fs-base); font-weight:500;
  z-index:9999; transition:transform .28s ease;
  box-shadow:var(--shadow); color:var(--text); white-space:nowrap;
}
#toast.show        { transform:translateX(-50%) translateY(0); }
#toast.toast-ok    { border-color:rgba(var(--green-rgb),.4);  color:var(--green);  }
#toast.toast-error { border-color:rgba(var(--red-rgb),.4);    color:var(--red);    }
#toast.toast-warn  { border-color:rgba(var(--yellow-rgb),.4); color:var(--yellow); }

/* ════════════════════════════════════════════════════════════
   SISTEMA DE DISEÑO UNIFICADO — Aceros Bugambilia
   Todos los módulos heredan estos componentes de base.css
   ════════════════════════════════════════════════════════════ */

/* ══ BOTONES ══════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--surface2); color:var(--text);
  font-size:var(--fs-sm); font-weight:600; font-family:var(--font);
  cursor:pointer; white-space:nowrap; text-decoration:none;
  transition:border-color .15s, color .15s, background .15s, transform .15s;
}
.btn:hover { border-color:var(--accent); color:var(--accent); background:var(--accent-dim); transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn:focus-visible { outline:2px solid var(--accent); outline-offset:2px; }
.btn.primary { background:var(--accent); color:var(--text-inverse); border-color:transparent; }
.btn.primary:hover { background:var(--accent-lt); transform:translateY(-1px); }
.btn.primary:active { transform:translateY(0); }
.btn.danger  { background:rgba(var(--red-rgb),.10); color:var(--red); border-color:rgba(var(--red-rgb),.35); }
.btn.danger:hover  { background:rgba(var(--red-rgb),.18); transform:translateY(-1px); }
.btn.danger:active { transform:translateY(0); }
.btn.success { background:rgba(var(--green-rgb),.12); color:var(--green); border-color:rgba(var(--green-rgb),.35); }
.btn.success:hover { background:rgba(var(--green-rgb),.20); transform:translateY(-1px); }
.btn.success:active { transform:translateY(0); }
.btn.ghost   { background:transparent; border-color:transparent; color:var(--muted); }
.btn.ghost:hover { background:var(--surface2); color:var(--text); border-color:var(--border); }
.btn.ghost:active { transform:none; }
.btn.secondary { background:var(--surface2); color:var(--text); border-color:var(--border); }
.btn.secondary:hover { background:var(--surface3); border-color:var(--accent); color:var(--accent); transform:translateY(-1px); }
.btn.secondary:active { transform:translateY(0); }
.btn.accent { background:var(--accent); color:var(--text-inverse); border-color:transparent; }
.btn.accent:hover { background:var(--accent-lt); transform:translateY(-1px); }
.btn.accent:active { transform:translateY(0); }
.btn.icon { padding:5px 8px; min-width:32px; justify-content:center; }
.btn.sm { padding:5px 10px; font-size:var(--fs-xs); border-radius:var(--radius-sm); }
.btn.lg { padding:11px 22px; font-size:var(--fs-base); }
.btn:disabled,.btn[disabled] { opacity:.38; pointer-events:none; transform:none; }

/* ══ HEADER DE MÓDULO ═════════════════════════════════════════ */
.mod-header {
  position:sticky; top:56px; z-index:800;
  background:var(--surface); border-bottom:1px solid var(--border);
  padding:14px 24px;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; flex-wrap:wrap;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.mod-header-left { display:flex; flex-direction:column; gap:2px; min-width:0; }
.mod-header-left h1 { font-size:var(--fs-xl); font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mod-header-left p  { font-size:var(--fs-xs); color:var(--muted); }
.mod-header-right { display:flex; align-items:center; gap:8px; flex-wrap:wrap; flex-shrink:0; }

/* ══ TABS ═════════════════════════════════════════════════════ */
.tab-nav {
  display:flex; gap:0;
  border-bottom:1px solid var(--border);
  background:var(--surface);
  padding:0 24px;
  position:sticky; top:56px; z-index:700;
  overflow-x:auto; scrollbar-width:none;
}
.tab-nav::-webkit-scrollbar { display:none; }
.tab-btn {
  padding:12px 22px; font-size:var(--fs-sm); font-weight:600;
  color:var(--muted); cursor:pointer;
  border:none; background:none;
  border-bottom:2px solid transparent;
  font-family:var(--font); transition:color .2s, border-color .2s;
  display:inline-flex; align-items:center; gap:7px;
  white-space:nowrap; margin-bottom:-1px; flex-shrink:0;
}
.tab-btn:hover { color:var(--text); }
.tab-btn.active { color:var(--accent); border-bottom-color:var(--accent); }
.tab-badge {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:18px; height:18px; padding:0 5px;
  background:var(--red); color:#fff;
  border-radius:99px; font-size:10px; font-weight:700;
  font-family:var(--mono);
}

/* ══ KPI CARDS ════════════════════════════════════════════════ */
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; }
.kpi-card {
  background:var(--surface); border:1px solid var(--border);
  border-left:3px solid var(--accent);
  border-radius:var(--radius); padding:14px 16px;
  transition:transform .15s, box-shadow .15s;
}
.kpi-card:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.kpi-card.green  { border-left-color:var(--green);  }
.kpi-card.red    { border-left-color:var(--red);    }
.kpi-card.yellow { border-left-color:var(--yellow); }
.kpi-card.blue   { border-left-color:var(--blue);   }
.kpi-card.muted  { border-left-color:var(--muted);  }
.kpi-label { font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.7px; color:var(--muted); margin-bottom:6px; font-family:var(--mono); }
.kpi-value { font-size:22px; font-weight:700; color:var(--text); font-family:var(--mono); line-height:1.1; }
.kpi-sub   { font-size:10px; color:var(--muted); margin-top:4px; }

/* ══ CHIPS / FILTROS ══════════════════════════════════════════ */
.chips { display:flex; flex-wrap:wrap; gap:6px; }
.chip {
  padding:5px 12px; border-radius:20px;
  border:1px solid var(--border);
  background:var(--surface2); color:var(--muted);
  font-size:var(--fs-xs); font-weight:600; font-family:var(--font);
  cursor:pointer; white-space:nowrap; transition:all .15s;
}
.chip:hover { border-color:var(--accent); color:var(--accent); }
.chip.active { background:var(--accent); border-color:var(--accent); color:var(--text-inverse); }
.chip.disabled { opacity:.3; pointer-events:none; }

/* ══ MODAL ════════════════════════════════════════════════════ */
.modal-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.65); backdrop-filter:blur(4px);
  z-index:9500; align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-lg);
  max-width:520px; width:94%; max-height:88vh;
  display:flex; flex-direction:column; overflow:hidden;
}
.modal.wide { max-width:820px; }
.modal-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.modal-title { font-size:var(--fs-md); font-weight:700; color:var(--text); }
.modal-close {
  width:28px; height:28px; border-radius:var(--radius-sm);
  border:1px solid var(--border); background:var(--surface2); color:var(--muted);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  font-size:15px; transition:all .15s; font-family:var(--font); line-height:1;
}
.modal-close:hover { border-color:var(--red); color:var(--red); background:rgba(var(--red-rgb),.08); }
.modal-body { overflow-y:auto; padding:20px; flex:1; }
.modal-foot {
  display:flex; gap:8px; justify-content:flex-end;
  padding:14px 20px; border-top:1px solid var(--border); flex-shrink:0;
}

/* ══ EMPTY STATE ══════════════════════════════════════════════ */
.empty-state { text-align:center; padding:56px 24px; }
.empty-icon  { font-size:44px; margin-bottom:14px; opacity:.35; }
.empty-title { font-size:var(--fs-lg); font-weight:700; color:var(--text); margin-bottom:6px; }
.empty-sub   { font-size:var(--fs-sm); color:var(--muted); }

/* ══ ACTION BAR (footer sticky) ══════════════════════════════ */
.action-bar {
  position:sticky; bottom:0; z-index:700;
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  padding:12px 20px;
  background:var(--surface); border-top:1px solid var(--border);
  box-shadow:0 -4px 16px rgba(0,0,0,.10);
}

/* ════════════════════════════════════════════════════════════
   UTILIDADES — para no usar inline styles
   ════════════════════════════════════════════════════════════ */
.w-full { width:100%; }
.mt-xs { margin-top:4px; }
.mt-sm { margin-top:8px; }
.mt-md { margin-top:12px; }
.mt-lg { margin-top:16px; }
.ml-auto { margin-left:auto; }
.ml-sm { margin-left:6px; }
.text-center { text-align:center; }
.whitespace-nowrap { white-space:nowrap; }
.block { display:block; }
.flex { display:flex; }
.gap-sm { gap:8px; }
.hidden { display:none !important; }
.mb-0 { margin-bottom:0 !important; }
.mb-xs { margin-bottom:4px; }
.mb-sm { margin-bottom:8px; }
.w-110 { width:110px; }
.w-120 { width:120px; }
.w-160 { width:160px; }
.w-180 { width:180px; }
.w-220 { width:220px; }
.min-h-auto { min-height:auto; }
.resize-none { resize:none; }

/* ════════════════════════════════════════════════════════════
   FORMULARIOS — Inputs, selects, textareas estandarizados
   ════════════════════════════════════════════════════════════ */
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-label { font-size:var(--fs-xs); font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:.8px; }
.form-hint { font-size:var(--fs-xs); color:var(--muted2); margin-top:2px; }
.form-error { font-size:var(--fs-xs); color:var(--red); margin-top:2px; }

.form-control {
  padding:8px 12px; background:var(--surface2); border:1px solid var(--border);
  color:var(--text); font-family:var(--font); font-size:var(--fs-sm);
  border-radius:var(--radius-sm); transition:border-color .15s, box-shadow .15s;
}
.form-control:hover { border-color:var(--accent-border); }
.form-control:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
.form-control:focus-visible { outline:2px solid var(--accent); outline-offset:1px; }
.form-control:disabled { opacity:.4; cursor:not-allowed; background:var(--surface3); }
.form-control::placeholder { color:var(--muted2); }

/* Variantes */
.form-control.sm { padding:5px 10px; font-size:var(--fs-xs); }
.form-control.lg { padding:12px 16px; font-size:var(--fs-base); }
.form-control.error { border-color:var(--red); }

/* Select */
select.form-control { padding:7px 12px; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%237d8590' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; padding-right:32px; }

/* ══ INPUTS / SELECTS ESTÁNDAR ════════════════════════════════ */
.inp, .sel {
  padding:8px 12px; border:1.5px solid var(--border); border-radius:var(--radius);
  background:var(--surface2); color:var(--text);
  font-family:var(--font); font-size:var(--fs-sm); outline:none;
  transition:border-color .2s, background .2s;
}
.inp:focus, .sel:focus { border-color:var(--accent); background:var(--surface); }
.inp::placeholder { color:var(--muted); }

/* ══ SECTION LABEL (divisor con texto) ═══════════════════════ */
.section-label {
  display:flex; align-items:center; gap:10px;
  font-size:var(--fs-xs); font-weight:700; text-transform:uppercase;
  letter-spacing:1px; color:var(--muted); margin:20px 0 12px;
}
.section-label::after { content:''; flex:1; height:1px; background:var(--border); }

/* ══ DROP ZONE — carga de archivos CSV/Excel ════════════════ */
.drop-zone {
  border:2px dashed var(--border); border-radius:var(--radius-lg);
  background:var(--surface2); color:var(--muted);
  padding:32px 24px; text-align:center;
  cursor:pointer; transition:border-color .2s, background .2s, color .2s;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.drop-zone:hover, .drop-zone.dragover {
  border-color:var(--accent); background:var(--accent-dim); color:var(--accent);
}
.drop-zone input[type="file"] { display:none; }
.drop-zone-icon { font-size:32px; line-height:1; }
.drop-zone-label { font-size:var(--fs-sm); font-weight:600; }
.drop-zone-sub   { font-size:var(--fs-xs); color:var(--muted); }
.drop-zone input[type="file"],
.drop-zone input[type="file" i] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.drop-zone.loaded  { border-color:var(--green); background:rgba(var(--green-rgb),.06); }
.drop-zone.dz-icon { font-size:26px; margin-bottom:6px; }
.drop-zone.dz-text,.drop-zone .dz-text { font-size:var(--fs-xs); color:var(--muted); line-height:1.6; }
.drop-zone .dz-icon  { font-size:26px; margin-bottom:6px; }
.drop-zone .dz-label { font-size:var(--fs-sm); font-weight:500; color:var(--text); }
.drop-zone .dz-sub   { font-size:var(--fs-xs); color:var(--muted); }

/* ══ SPLASH WRAP + CARD ════════════════════════════════════ */
.splash-wrap,
#splash,#loginPanel,#lock-overlay,.login-wrap {
  display:flex; align-items:center; justify-content:center;
  min-height:calc(100vh - 56px); padding:40px; background:var(--bg);
}
.splash-card, .login-card, .upload-card {
  background:linear-gradient(145deg,var(--surface),var(--surface2));
  border:1px solid var(--border); border-radius:16px;
  padding:36px 44px; max-width:460px; width:100%;
  text-align:center; position:relative; overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.splash-card::before, .login-card::before, .upload-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
}
.splash-card h2, .login-card h2, .upload-card h2 {
  font-size:18px; font-weight:700; color:var(--text); margin:0 0 6px;
}
.splash-card p, .login-card p, .upload-card p {
  font-size:12px; color:var(--muted); line-height:1.65; margin:0 0 20px;
}
.splash-card-icon { font-size:38px; margin-bottom:12px; display:block; }

/* ── COMPATIBILIDAD: Clases antiguas redirigidas a nuevos estándares ── */
/* Las clases antiguas (.btn-primary, etc.) ya no se usan. */
/* Todos los botones ahora usan: .btn + .primary/.secondary/.danger/.ghost/.accent/.success */

/* ── ACTIVO (tabs, toggles, paginación activa) ── */
.tab-btn.active, .tgb.active, .tgb.active-blue,
.ptab.active, .sep-btn.active, .chip.active,
.pagBtn.active, .page-btn.active, .pb.active,
.paginate_button.current, .receptora-btn.active,
.toggle-btn.active, .view-btn.active,
.filter-btn.active {
  background: var(--accent) !important;
  color: var(--accent-txt) !important;
  border-color: var(--accent) !important;
  font-weight: 700 !important;
  box-shadow: 0 0 10px var(--accent-glow) !important;
}

/* ── PAGINACIÓN INACTIVA ── */
.pagBtn:not(.active), .page-btn:not(.active),
.pb:not(.active), .paginate_button:not(.current) {
  background: var(--surface2) !important;
  border: 1px solid var(--border) !important;
  color: var(--text2) !important;
}
.pagBtn:not(.active):hover, .page-btn:not(.active):hover,
.pb:not(.active):hover, .paginate_button:not(.current):hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

/* ── LOG / SAVE botones en formularios inline ── */
.log-btn, .comment-btn {
  background: var(--accent) !important;
  color: var(--accent-txt) !important;
  border: none !important;
  font-weight: 700 !important;
  padding: 6px 12px;
}
.log-btn:hover, .comment-btn:hover {
  background: var(--accent-2) !important;
  box-shadow: 0 4px 10px var(--accent-glow) !important;
}

/* ── DISABLED global ── */
button:disabled, .btn:disabled, [class*="btn"]:disabled {
  opacity: .32 !important;
  pointer-events: none !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ═══ CONTRASTE GARANTIZADO — 4 TEMAS ═══ */
body,.container,.content,.main,.main-panel,.layout{color:var(--text);background:var(--bg);}
h1,h2,h3,h4,.hx-title h1,.mod-name{color:var(--text)!important;}
p,label,.sub,.description{color:var(--text2)!important;}.hx-header h1,.hx-header .hx-header .sub{color:rgba(255,255,255,.82)!important;}
.fp-title,.kl,.kpi .kl,.stat-label,thead th,.section-title{color:var(--muted)!important;}
.kpi .kv,.kv,.stat-value,.kpi-value,.donut-center-val{color:var(--accent);font-family:var(--mono)!important;font-weight:700!important;}
input,textarea,select{color:var(--text)!important;background:var(--surface2)!important;border-color:var(--border)!important;font-family:var(--font)!important;}
input::placeholder,textarea::placeholder{color:var(--muted)!important;opacity:1!important;}
[data-theme="dark"] .kpi .kv{text-shadow:0 0 14px var(--accent-glow);}
[data-theme="light"] .kpi .kv{text-shadow:none!important;}
.card,.kpi,.stat-card,.kpi-card,.kpiCard,.tabla-card,.chart-card,.splash-card,.login-card,.modal{background:linear-gradient(145deg,var(--surface),var(--surface2))!important;border-color:var(--border)!important;color:var(--text)!important;}
.filters-panel,.sidebar,.fp{background:var(--sidebar)!important;border-color:var(--border)!important;}
.chip{color:var(--muted);background:var(--surface2);border-color:var(--border);}
.chip:hover{border-color:var(--accent);color:var(--accent);}
.chip.active{background:var(--accent)!important;border-color:var(--accent)!important;color:var(--accent-txt)!important;font-weight:700!important;}
[data-theme="light"] .chip.active{color:#fff!important;}
[data-theme="light"] tbody tr{background:var(--surface)!important;}
[data-theme="light"] tbody tr:nth-child(even){background:var(--surface2)!important;}
[data-theme="light"] tbody tr:hover{background:var(--accent-dim)!important;}
[data-theme="light"] tbody td{color:var(--text)!important;border-color:var(--border)!important;}
[data-theme="light"] .badge.AA{background:rgba(124,58,237,.12)!important;color:#5b21b6!important;border-color:rgba(124,58,237,.3)!important;}
[data-theme="light"] .badge.A{background:rgba(22,163,74,.12)!important;color:#15803d!important;border-color:rgba(22,163,74,.3)!important;}
[data-theme="light"] .badge.B{background:rgba(217,119,6,.12)!important;color:#92400e!important;border-color:rgba(217,119,6,.3)!important;}
[data-theme="light"] .badge.C{background:rgba(225,29,72,.12)!important;color:#9f1239!important;border-color:rgba(225,29,72,.3)!important;}
/* ── PEARL — tarjetas planas (vence gradiente de CONTRASTE en modo claro) ── */
[data-theme="light"] .card,[data-theme="light"] .kpi,[data-theme="light"] .stat-card,
[data-theme="light"] .kpi-card,[data-theme="light"] .kpiCard,[data-theme="light"] .re-card,
[data-theme="light"] .tabla-card,[data-theme="light"] .chart-card,
[data-theme="light"] .splash-card,[data-theme="light"] .login-card,
[data-theme="light"] .modal{background:var(--surface)!important;border-color:var(--border)!important;}

/* ── PEARL — overrides módulo-específicos (clases no genéricas) ── */
[data-theme="light"] #dashboard,[data-theme="light"] #mainContent,
[data-theme="light"] #tabAnalisis,[data-theme="light"] #tabTransferencias,
[data-theme="light"] .conteoWrap { background:var(--bg)!important; }
[data-theme="light"] .selector { background:var(--surface)!important; border-color:var(--border)!important; }
[data-theme="light"] .opcion { background:var(--surface2)!important; border-color:var(--border)!important; color:var(--text)!important; }
[data-theme="light"] .aviso { background:var(--surface2)!important; border-color:var(--border)!important; color:var(--text)!important; }
[data-theme="light"] .folio-meta-item { color:var(--muted)!important; }
[data-theme="light"] .folio-meta-item strong { color:var(--text)!important; }
[data-theme="light"] .folio-title { color:var(--azul)!important; }
[data-theme="light"] .folio-table td { color:var(--text)!important; }
[data-theme="light"] .export-dropdown,[data-theme="light"] .export-menu { background:var(--surface)!important; border-color:var(--border)!important; }
[data-theme="light"] #tablaResumen tbody td { color:var(--text)!important; }
[data-theme="light"] .footer,[data-theme="light"] .conteoHeader { background:var(--surface)!important; border-color:var(--border)!important; }
[data-theme="light"] .vault-card,[data-theme="light"] .vault-section { background:var(--surface)!important; border-color:var(--border)!important; }
[data-theme="light"] .dp-body,[data-theme="light"] .card-body { background:var(--surface)!important; }
[data-theme="light"] .hx-author,[data-theme="light"] .header-title .author-tag { color:var(--accent-2)!important; background:var(--accent-dim)!important; }
[data-theme="light"] .hx-title h1,[data-theme="light"] .header-title h1 { color:#fff!important; }
[data-theme="light"] .hx-title .sub,[data-theme="light"] .header-title .subtitle,[data-theme="light"] .header-title p { color:rgba(255,255,255,.65)!important; }

/* ── COL-HINTS (malla de columnas requeridas en splash CSV) ── */
.col-hints { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; margin-top:16px; text-align:left; }
.col-hint { background:var(--surface2); border:1px solid var(--border); border-radius:7px; padding:6px 9px; font-size:11px; font-family:var(--mono); color:var(--muted); }
.col-hint span { color:var(--azul); font-weight:500; display:block; margin-bottom:1px; }

/* ── COL-OK / COL-ERROR (feedback validación CSV) ── */
.col-error { background:rgba(244,63,94,.08); border:1px solid rgba(244,63,94,.3); border-radius:10px; padding:14px 16px; margin-top:14px; text-align:left; display:none; }
.col-error-title { font-size:13px; font-weight:600; color:var(--rojo); margin-bottom:6px; }
.col-error-list { font-size:12px; font-family:var(--mono); color:var(--muted); line-height:1.8; }
.col-error-list span { color:var(--rojo); }
.col-ok { background:rgba(16,185,129,.08); border:1px solid rgba(16,185,129,.25); border-radius:10px; padding:10px 14px; margin-top:14px; font-size:12px; color:var(--verde); font-family:var(--mono); display:none; }

/* ── SEP-TOGGLE (selector de separador CSV) ── */
.sep-toggle { display:flex; align-items:center; gap:8px; justify-content:center; margin-bottom:14px; }
.sep-toggle label { font-size:12px; color:var(--muted); }
.sep-btns { display:flex; border:1px solid var(--border); border-radius:7px; overflow:hidden; }
.sep-btn { padding:5px 14px; font-size:12px; font-family:var(--mono); cursor:pointer; color:var(--muted); background:var(--surface2); border:none; transition:all .15s; }
.sep-btn.active { background:var(--azul); color:#fff; font-weight:700; }
[data-theme="light"] .sep-btn:not(.active) { background:var(--surface2) !important; color:var(--muted) !important; }

/* ── UPLOAD-ROWS (carga multi-archivo — Motor Logístico, Conciliación) ── */
.upload-rows { display:flex; flex-direction:column; gap:12px; text-align:left; margin-top:4px; }
.upload-row { background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:12px 14px; transition:border-color .2s; }
.upload-row.loaded { border-color:rgba(16,185,129,.4); }
.upload-row-label { font-size:9px; font-family:var(--mono); text-transform:uppercase; letter-spacing:.7px; color:var(--muted); margin-bottom:8px; font-weight:700; }
.upload-row-picker { display:flex; align-items:center; gap:8px; cursor:pointer; }
.upload-row-picker input[type="file"] { display:none; }
.upload-row-name { font-size:11px; color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; transition:color .2s; }
.upload-row-name.loaded { color:var(--verde); font-weight:600; }
.upload-row .col-hints { margin-top:10px; }

/* ── STAT-CARD / KPICARD — ::before accent line + ::after glow (canonical) ── */
.stat-card, .kpiCard, .re-card {
  background:linear-gradient(145deg,var(--surface),var(--surface2));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px 16px;
  position:relative;
  overflow:hidden;
  transition:transform .2s, box-shadow .2s;
}
.stat-card::before, .kpiCard::before, .re-card::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  pointer-events:none;
}
.stat-card::after, .kpiCard::after, .re-card::after {
  content:''; position:absolute; bottom:0; left:15%; right:15%; height:16px;
  background:radial-gradient(ellipse at 50% 100%,var(--accent-glow) 0%,transparent 70%);
  pointer-events:none;
}
.stat-card:hover, .kpiCard:hover, .re-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }

/* ── KPI (.kpi) — misma base que stat-card ── */
.kpi {
  background:linear-gradient(145deg,var(--surface),var(--surface2));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px 16px;
  position:relative;
  overflow:hidden;
  transition:transform .2s, box-shadow .2s;
}
.kpi::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  pointer-events:none;
}
.kpi::after {
  content:''; position:absolute; bottom:0; left:15%; right:15%; height:16px;
  background:radial-gradient(ellipse at 50% 100%,var(--accent-glow) 0%,transparent 70%);
  pointer-events:none;
}
.kpi:hover { transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.kpi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; }
.kl, .kpi-label, .stat-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.7px; color:var(--muted); margin-bottom:6px; font-family:var(--mono); }
.kv, .kpi-value, .stat-value { font-size:22px; font-weight:700; font-family:var(--mono); line-height:1.1; }

/* ── TBODY HOVER unificado ── */
tbody tr:hover { background:var(--accent-dim) !important; }

/* ── THEAD TH estándar (font-size + padding base) ── */
thead th { padding:10px 12px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.6px; }
