@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── Variables por tema ──────────────────────────────────────── */
/* Cada tema setea variables --sb-bg, --sb-link-active-bg, etc.  */

[data-tema="dark-pro"] {
  --sb-bg: #0f172a; --sb-border: rgba(255,255,255,.06);
  --sb-logo: #6366f1;
  --sb-name: #f1f5f9; --sb-sub: #475569; --sb-sec: #475569;
  --sb-active-bg: rgba(99,102,241,.2); --sb-active-color: #a5b4fc;
  --sb-link: #64748b; --sb-link-hover: #1e293b;
  --sb-avatar: #6366f1; --sb-uname: #f1f5f9;
  --sb-user-border: rgba(255,255,255,.06);
  --top-bg: #1e293b; --top-border: 1px solid #334155;
  --top-title: #f1f5f9; --top-btn-bg: #6366f1; --top-btn-color: #fff;
  --top-outline-border: rgba(255,255,255,.2); --top-outline-color: #94a3b8;
  --page-bg: #0f172a;
  --card-bg: #1e293b; --card-border: #334155; --card-header-bg: #1e293b; --card-header-color: #f1f5f9;
  --stat-bg: #1e293b; --stat-border: #334155; --stat-lbl: #64748b; --stat-val: #f1f5f9;
  --table-head-bg: #0f172a; --table-head-color: #475569; --table-row-border: #334155; --table-row-color: #94a3b8; --table-row-hover: #1e293b;
  --filter-bg: #1e293b; --filter-border: #334155;
  --input-bg: #0f172a; --input-border: #334155; --input-color: #f1f5f9;
  --accent: #6366f1; --accent-hover: #4f46e5;
  --success: #4ade80; --danger: #f87171;
}

[data-tema="midnight-teal"] {
  --sb-bg: #134e4a; --sb-border: rgba(255,255,255,.08);
  --sb-logo: #2dd4bf;
  --sb-name: #ccfbf1; --sb-sub: #5eead4; --sb-sec: #0d9488;
  --sb-active-bg: rgba(45,212,191,.15); --sb-active-color: #2dd4bf;
  --sb-link: #5eead4; --sb-link-hover: #0f3330;
  --sb-avatar: #0d9488; --sb-uname: #ccfbf1;
  --sb-user-border: rgba(255,255,255,.08);
  --top-bg: #0f3330; --top-border: none;
  --top-title: #ccfbf1; --top-btn-bg: #2dd4bf; --top-btn-color: #134e4a;
  --top-outline-border: rgba(255,255,255,.25); --top-outline-color: #ccfbf1;
  --page-bg: #f0fdfa;
  --card-bg: #fff; --card-border: #99f6e4; --card-header-bg: #f0fdfa; --card-header-color: #134e4a;
  --stat-bg: #fff; --stat-border: #99f6e4; --stat-lbl: #5eead4; --stat-val: #134e4a;
  --table-head-bg: #f0fdfa; --table-head-color: #5eead4; --table-row-border: #ccfbf1; --table-row-color: #334155; --table-row-hover: #f0fdfa;
  --filter-bg: #fff; --filter-border: #99f6e4;
  --input-bg: #fff; --input-border: #99f6e4; --input-color: #134e4a;
  --accent: #0d9488; --accent-hover: #0f766e;
  --success: #16a34a; --danger: #dc2626;
}

[data-tema="corporate-blue"] {
  --sb-bg: #1e3a8a; --sb-border: rgba(255,255,255,.08);
  --sb-logo: #60a5fa;
  --sb-name: #eff6ff; --sb-sub: #93c5fd; --sb-sec: #3b82f6;
  --sb-active-bg: rgba(96,165,250,.2); --sb-active-color: #bfdbfe;
  --sb-link: #93c5fd; --sb-link-hover: #1e40af;
  --sb-avatar: #3b82f6; --sb-uname: #eff6ff;
  --sb-user-border: rgba(255,255,255,.08);
  --top-bg: #1d4ed8; --top-border: none;
  --top-title: #fff; --top-btn-bg: #fff; --top-btn-color: #1d4ed8;
  --top-outline-border: rgba(255,255,255,.35); --top-outline-color: #fff;
  --page-bg: #eff6ff;
  --card-bg: #fff; --card-border: #bfdbfe; --card-header-bg: #f8fafc; --card-header-color: #1e3a8a;
  --stat-bg: #fff; --stat-border: #bfdbfe; --stat-lbl: #93c5fd; --stat-val: #1e3a8a;
  --table-head-bg: #eff6ff; --table-head-color: #93c5fd; --table-row-border: #dbeafe; --table-row-color: #334155; --table-row-hover: #eff6ff;
  --filter-bg: #fff; --filter-border: #bfdbfe;
  --input-bg: #fff; --input-border: #bfdbfe; --input-color: #1e3a8a;
  --accent: #2563eb; --accent-hover: #1d4ed8;
  --success: #16a34a; --danger: #dc2626;
}

[data-tema="warm-slate"] {
  --sb-bg: #292524; --sb-border: rgba(255,255,255,.06);
  --sb-logo: #f59e0b;
  --sb-name: #fafaf9; --sb-sub: #78716c; --sb-sec: #57534e;
  --sb-active-bg: rgba(245,158,11,.15); --sb-active-color: #fbbf24;
  --sb-link: #78716c; --sb-link-hover: #1c1917;
  --sb-avatar: #d97706; --sb-uname: #fafaf9;
  --sb-user-border: rgba(255,255,255,.06);
  --top-bg: #1c1917; --top-border: 1px solid #292524;
  --top-title: #fafaf9; --top-btn-bg: #f59e0b; --top-btn-color: #1c1917;
  --top-outline-border: rgba(255,255,255,.2); --top-outline-color: #a8a29e;
  --page-bg: #fafaf9;
  --card-bg: #fff; --card-border: #e7e5e4; --card-header-bg: #fafaf9; --card-header-color: #1c1917;
  --stat-bg: #fff; --stat-border: #e7e5e4; --stat-lbl: #a8a29e; --stat-val: #1c1917;
  --table-head-bg: #fafaf9; --table-head-color: #a8a29e; --table-row-border: #f5f5f4; --table-row-color: #44403c; --table-row-hover: #fafaf9;
  --filter-bg: #fff; --filter-border: #e7e5e4;
  --input-bg: #fff; --input-border: #d6d3d1; --input-color: #1c1917;
  --accent: #f59e0b; --accent-hover: #d97706;
  --success: #16a34a; --danger: #dc2626;
}

[data-tema="pure-white"] {
  --sb-bg: #fff; --sb-border: #f1f5f9;
  --sb-logo: #0ea5e9;
  --sb-name: #0f172a; --sb-sub: #94a3b8; --sb-sec: #cbd5e1;
  --sb-active-bg: #f0f9ff; --sb-active-color: #0284c7;
  --sb-link: #94a3b8; --sb-link-hover: #f8fafc;
  --sb-avatar: #0ea5e9; --sb-uname: #0f172a;
  --sb-user-border: #f1f5f9;
  --top-bg: #fff; --top-border: 1px solid #f1f5f9;
  --top-title: #0f172a; --top-btn-bg: #0ea5e9; --top-btn-color: #fff;
  --top-outline-border: #e2e8f0; --top-outline-color: #64748b;
  --page-bg: #f8fafc;
  --card-bg: #fff; --card-border: #e2e8f0; --card-header-bg: #f8fafc; --card-header-color: #0f172a;
  --stat-bg: #fff; --stat-border: #e2e8f0; --stat-lbl: #94a3b8; --stat-val: #0f172a;
  --table-head-bg: #f8fafc; --table-head-color: #94a3b8; --table-row-border: #f1f5f9; --table-row-color: #475569; --table-row-hover: #f8fafc;
  --filter-bg: #fff; --filter-border: #e2e8f0;
  --input-bg: #fff; --input-border: #e2e8f0; --input-color: #0f172a;
  --accent: #0ea5e9; --accent-hover: #0284c7;
  --success: #16a34a; --danger: #f43f5e;
}

[data-tema="graphite-orange"] {
  --sb-bg: #18181b; --sb-border: rgba(255,255,255,.05);
  --sb-logo: #f97316;
  --sb-name: #fafafa; --sb-sub: #52525b; --sb-sec: #3f3f46;
  --sb-active-bg: rgba(249,115,22,.15); --sb-active-color: #fb923c;
  --sb-link: #52525b; --sb-link-hover: #27272a;
  --sb-avatar: #ea580c; --sb-uname: #fafafa;
  --sb-user-border: rgba(255,255,255,.05);
  --top-bg: #09090b; --top-border: 1px solid #27272a;
  --top-title: #fafafa; --top-btn-bg: #f97316; --top-btn-color: #fff;
  --top-outline-border: rgba(255,255,255,.15); --top-outline-color: #71717a;
  --page-bg: #09090b;
  --card-bg: #18181b; --card-border: #27272a; --card-header-bg: #18181b; --card-header-color: #fafafa;
  --stat-bg: #18181b; --stat-border: #27272a; --stat-lbl: #52525b; --stat-val: #fafafa;
  --table-head-bg: #09090b; --table-head-color: #3f3f46; --table-row-border: #27272a; --table-row-color: #a1a1aa; --table-row-hover: #27272a;
  --filter-bg: #18181b; --filter-border: #27272a;
  --input-bg: #09090b; --input-border: #27272a; --input-color: #fafafa;
  --accent: #f97316; --accent-hover: #ea580c;
  --success: #4ade80; --danger: #f87171;
}

[data-tema="slate-emerald"] {
  --sb-bg: #f8fafc; --sb-border: #e2e8f0;
  --sb-logo: #059669;
  --sb-name: #0f172a; --sb-sub: #94a3b8; --sb-sec: #cbd5e1;
  --sb-active-bg: #d1fae5; --sb-active-color: #065f46;
  --sb-link: #64748b; --sb-link-hover: #f1f5f9;
  --sb-avatar: #059669; --sb-uname: #0f172a;
  --sb-user-border: #e2e8f0;
  --top-bg: #064e3b; --top-border: none;
  --top-title: #d1fae5; --top-btn-bg: #34d399; --top-btn-color: #064e3b;
  --top-outline-border: rgba(255,255,255,.25); --top-outline-color: #6ee7b7;
  --page-bg: #f8fafc;
  --card-bg: #fff; --card-border: #d1fae5; --card-header-bg: #f0fdf4; --card-header-color: #064e3b;
  --stat-bg: #fff; --stat-border: #d1fae5; --stat-lbl: #6ee7b7; --stat-val: #064e3b;
  --table-head-bg: #f0fdf4; --table-head-color: #6ee7b7; --table-row-border: #ecfdf5; --table-row-color: #334155; --table-row-hover: #f0fdf4;
  --filter-bg: #fff; --filter-border: #d1fae5;
  --input-bg: #fff; --input-border: #a7f3d0; --input-color: #064e3b;
  --accent: #059669; --accent-hover: #047857;
  --success: #059669; --danger: #dc2626;
}

[data-tema="deep-purple"] {
  --sb-bg: #1e1b4b; --sb-border: rgba(255,255,255,.06);
  --sb-logo: #a78bfa;
  --sb-name: #e0e7ff; --sb-sub: #6366f1; --sb-sec: #3730a3;
  --sb-active-bg: rgba(167,139,250,.2); --sb-active-color: #c4b5fd;
  --sb-link: #6366f1; --sb-link-hover: #312e81;
  --sb-avatar: #7c3aed; --sb-uname: #e0e7ff;
  --sb-user-border: rgba(255,255,255,.06);
  --top-bg: #312e81; --top-border: none;
  --top-title: #e0e7ff; --top-btn-bg: #a78bfa; --top-btn-color: #1e1b4b;
  --top-outline-border: rgba(255,255,255,.2); --top-outline-color: #c4b5fd;
  --page-bg: #f5f3ff;
  --card-bg: #fff; --card-border: #ddd6fe; --card-header-bg: #f5f3ff; --card-header-color: #1e1b4b;
  --stat-bg: #fff; --stat-border: #ddd6fe; --stat-lbl: #a78bfa; --stat-val: #1e1b4b;
  --table-head-bg: #f5f3ff; --table-head-color: #a78bfa; --table-row-border: #ede9fe; --table-row-color: #4c1d95; --table-row-hover: #f5f3ff;
  --filter-bg: #fff; --filter-border: #ddd6fe;
  --input-bg: #fff; --input-border: #c4b5fd; --input-color: #1e1b4b;
  --accent: #7c3aed; --accent-hover: #6d28d9;
  --success: #16a34a; --danger: #dc2626;
}

[data-tema="rose-charcoal"] {
  --sb-bg: #1c1917; --sb-border: rgba(255,255,255,.05);
  --sb-logo: #fb7185;
  --sb-name: #fafaf9; --sb-sub: #57534e; --sb-sec: #44403c;
  --sb-active-bg: rgba(251,113,133,.15); --sb-active-color: #fda4af;
  --sb-link: #57534e; --sb-link-hover: #292524;
  --sb-avatar: #e11d48; --sb-uname: #fafaf9;
  --sb-user-border: rgba(255,255,255,.05);
  --top-bg: #fff1f2; --top-border: 1px solid #fecdd3;
  --top-title: #881337; --top-btn-bg: #fb7185; --top-btn-color: #fff;
  --top-outline-border: #fecdd3; --top-outline-color: #be123c;
  --page-bg: #fff;
  --card-bg: #fff; --card-border: #fecdd3; --card-header-bg: #fff1f2; --card-header-color: #881337;
  --stat-bg: #fff; --stat-border: #fecdd3; --stat-lbl: #fda4af; --stat-val: #881337;
  --table-head-bg: #fff1f2; --table-head-color: #fda4af; --table-row-border: #fff1f2; --table-row-color: #44403c; --table-row-hover: #fff1f2;
  --filter-bg: #fff; --filter-border: #fecdd3;
  --input-bg: #fff; --input-border: #fecdd3; --input-color: #1c1917;
  --accent: #e11d48; --accent-hover: #be123c;
  --success: #16a34a; --danger: #dc2626;
}

[data-tema="sky-sand"] {
  --sb-bg: #faf5eb; --sb-border: #e7e0d0;
  --sb-logo: #0284c7;
  --sb-name: #0c4a6e; --sb-sub: #94a3b8; --sb-sec: #c4b9a8;
  --sb-active-bg: #bae6fd; --sb-active-color: #0369a1;
  --sb-link: #94a3b8; --sb-link-hover: #f0e8d6;
  --sb-avatar: #0284c7; --sb-uname: #0c4a6e;
  --sb-user-border: #e7e0d0;
  --top-bg: #0c4a6e; --top-border: none;
  --top-title: #e0f2fe; --top-btn-bg: #38bdf8; --top-btn-color: #0c4a6e;
  --top-outline-border: rgba(255,255,255,.25); --top-outline-color: #7dd3fc;
  --page-bg: #faf5eb;
  --card-bg: #fff; --card-border: #e7e0d0; --card-header-bg: #faf5eb; --card-header-color: #0c4a6e;
  --stat-bg: #fff; --stat-border: #e7e0d0; --stat-lbl: #a8a29e; --stat-val: #0c4a6e;
  --table-head-bg: #faf5eb; --table-head-color: #c4b9a8; --table-row-border: #f0e8d6; --table-row-color: #44403c; --table-row-hover: #faf5eb;
  --filter-bg: #fff; --filter-border: #e7e0d0;
  --input-bg: #fff; --input-border: #d4c9b0; --input-color: #0c4a6e;
  --accent: #0284c7; --accent-hover: #0369a1;
  --success: #16a34a; --danger: #dc2626;
}

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

body { font-family: 'Inter', sans-serif; background: var(--page-bg); color: var(--table-row-color); line-height: 1.5; -webkit-font-smoothing: antialiased; margin: 0; transition: background .3s; }

/* ── Sidebar ─────────────────────────────────────────────────── */
.mp-sidebar { position: fixed; top: 0; left: 0; width: 252px; height: 100vh; background: var(--sb-bg); border-right: 1px solid var(--sb-border); display: flex; flex-direction: column; z-index: 200; box-shadow: 2px 0 12px rgba(0,0,0,.08); transition: background .3s; }
.mp-sidebar-brand { display: flex; align-items: center; gap: 11px; padding: 18px 16px; border-bottom: 1px solid var(--sb-border); text-decoration: none; }
.mp-sidebar-logo { width: 34px; height: 34px; background: var(--sb-logo); border-radius: 9px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mp-sidebar-logo svg { width: 18px !important; height: 18px !important; color: #fff; display: block; }
.mp-brand-name { font-size: 14px; font-weight: 700; color: var(--sb-name); letter-spacing: -.02em; line-height: 1; transition: color .3s; }
.mp-brand-sub  { font-size: 10px; color: var(--sb-sub); text-transform: uppercase; letter-spacing: .07em; margin-top: 2px; display: block; transition: color .3s; }
.mp-nav { flex: 1; overflow-y: auto; padding: 10px 8px; }
.mp-nav::-webkit-scrollbar { width: 0; }
.mp-nav-section { font-size: 10px; font-weight: 700; color: var(--sb-sec); text-transform: uppercase; letter-spacing: .09em; padding: 0 8px; margin: 18px 0 5px; transition: color .3s; }
.mp-nav-section:first-child { margin-top: 4px; }
.mp-nav-link { display: flex; align-items: center; gap: 9px; padding: 8px 8px; border-radius: 8px; font-size: 13px; font-weight: 500; color: var(--sb-link); text-decoration: none; transition: all .15s; margin-bottom: 1px; }
.mp-nav-link svg { width: 15px; height: 15px; flex-shrink: 0; }
.mp-nav-link:hover { background: var(--sb-link-hover); color: var(--sb-name); }
.mp-nav-link.active { background: var(--sb-active-bg); color: var(--sb-active-color); font-weight: 600; }
.mp-sidebar-user { padding: 10px 8px; border-top: 1px solid var(--sb-user-border); }
.mp-user-card { display: flex; align-items: center; gap: 9px; padding: 8px; border-radius: 8px; background: rgba(0,0,0,.06); }
.mp-user-avatar { width: 30px; height: 30px; background: var(--sb-avatar); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: #fff; flex-shrink: 0; }
.mp-user-name { font-size: 12px; font-weight: 600; color: var(--sb-uname); line-height: 1; margin-bottom: 3px; }
.mp-user-logout { font-size: 11px; color: var(--sb-sub); background: none; border: none; padding: 0; cursor: pointer; transition: color .15s; }
.mp-user-logout:hover { color: var(--sb-name); }

/* Selector de tema en sidebar */
.mp-tema-selector { padding: 10px 8px; border-top: 1px solid var(--sb-user-border); }
.mp-tema-label { font-size: 10px; font-weight: 700; color: var(--sb-sec); text-transform: uppercase; letter-spacing: .09em; margin-bottom: 6px; display: block; }
.mp-tema-select { width: 100%; font-size: 11.5px; padding: 5px 8px; border-radius: 7px; border: 1px solid var(--sb-border); background: rgba(0,0,0,.08); color: var(--sb-name); cursor: pointer; }
.mp-tema-select option { background: #1e293b; color: #fff; }

/* ── Main ────────────────────────────────────────────────────── */
.mp-main { margin-left: 252px; min-height: 100vh; display: flex; flex-direction: column; }
.mp-topbar { height: 56px; background: var(--top-bg); border-bottom: var(--top-border, none); display: flex; align-items: center; justify-content: space-between; padding: 0 24px; position: sticky; top: 0; z-index: 100; box-shadow: 0 2px 8px rgba(0,0,0,.12); transition: background .3s; }
.mp-topbar-title { font-size: 19px; font-weight: 700; color: var(--top-title); letter-spacing: -.02em; transition: color .3s; }
.mp-topbar-actions { display: flex; gap: 8px; align-items: center; }
.mp-body { padding: 24px; flex: 1; }

/* ── Cards ───────────────────────────────────────────────────── */
.card { border: 1px solid var(--card-border) !important; border-radius: 12px !important; box-shadow: 0 2px 8px rgba(0,0,0,.07) !important; background: var(--card-bg) !important; transition: background .3s, border-color .3s; }
.card-header { background: var(--card-header-bg) !important; border-bottom: 1px solid var(--card-border) !important; padding: 14px 18px !important; font-size: 17px !important; font-weight: 700 !important; color: var(--card-header-color) !important; border-radius: 12px 12px 0 0 !important; }
.card-body { padding: 18px !important; }

.stat-card { background: var(--stat-bg); border: 1px solid var(--stat-border); border-radius: 12px; padding: 18px; box-shadow: 0 2px 8px rgba(0,0,0,.07); transition: all .2s; }
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.10); }
.stat-label { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--stat-lbl); margin-bottom: 8px; }
.stat-value { font-size: 40px; font-weight: 800; color: var(--stat-val); line-height: 1; letter-spacing: -.03em; }
.stat-value.success { color: var(--success) !important; }
.stat-value.danger  { color: var(--danger)  !important; }
.stat-card.accent-success { border-left: 4px solid var(--success); }
.stat-card.accent-danger  { border-left: 4px solid var(--danger); }
.stat-card.accent-blue    { border-left: 4px solid var(--accent); }

/* ── Tablas ──────────────────────────────────────────────────── */
.table { font-size: 16px; color: var(--table-row-color); }
.table thead th { font-size: 13px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .07em !important; color: var(--table-head-color) !important; background: var(--table-head-bg) !important; border-bottom: 1px solid var(--card-border) !important; padding: 11px 16px !important; }
.table td { padding: 12px 16px !important; border-color: var(--table-row-border) !important; }
.table-hover tbody tr:hover { background: var(--table-row-hover) !important; }

/* ── Badges ──────────────────────────────────────────────────── */
.badge { font-size: 14px !important; font-weight: 700 !important; padding: 4px 10px !important; border-radius: 99px !important; }
.badge.bg-warning   { background: #fef08a !important; color: #713f12 !important; border: 1px solid #fde047 !important; }
.badge.bg-primary   { background: #bfdbfe !important; color: #1e40af !important; border: 1px solid #93c5fd !important; }
.badge.bg-info      { background: #bae6fd !important; color: #0369a1 !important; border: 1px solid #7dd3fc !important; }
.badge.bg-success   { background: #bbf7d0 !important; color: #15803d !important; border: 1px solid #86efac !important; }
.badge.bg-danger    { background: #fecaca !important; color: #991b1b !important; border: 1px solid #fca5a5 !important; }
.badge.bg-secondary { background: #e2e8f0 !important; color: #475569 !important; border: 1px solid #cbd5e1 !important; }

/* ── Botones ─────────────────────────────────────────────────── */
.btn { font-size: 16px; font-weight: 600; border-radius: 8px; transition: all .15s; }
.btn-primary { background: var(--accent) !important; border-color: var(--accent) !important; color: #fff !important; }
.btn-primary:hover { background: var(--accent-hover) !important; border-color: var(--accent-hover) !important; }
.btn-outline-secondary { border-color: var(--top-outline-border) !important; color: var(--top-outline-color) !important; background: transparent !important; }
.btn-outline-secondary:hover { background: rgba(255,255,255,.1) !important; }
.mp-topbar-actions .btn-primary { background: var(--top-btn-bg) !important; color: var(--top-btn-color) !important; border-color: var(--top-btn-bg) !important; font-weight: 700; }
.mp-body .btn-primary { background: var(--accent) !important; border-color: var(--accent) !important; color: #fff !important; }
.mp-body .btn-outline-secondary { border-color: var(--card-border) !important; color: var(--table-row-color) !important; background: transparent !important; }
.mp-body .btn-outline-secondary:hover { background: var(--table-row-hover) !important; }
.btn-sm { padding: 6px 14px; font-size: 14px; }
.btn-success { background: var(--success) !important; border-color: var(--success) !important; color: #fff !important; }
.btn-outline-primary { color: var(--accent) !important; border-color: var(--accent) !important; }
.btn-outline-primary:hover { background: var(--stat-bg) !important; }
.btn-outline-danger { color: var(--danger) !important; border-color: var(--danger) !important; }

/* ── Formularios ─────────────────────────────────────────────── */
.form-control, .form-select { font-size: 16px; border-color: var(--input-border); border-radius: 8px; color: var(--input-color); background: var(--input-bg); padding: 7px 12px; transition: border-color .15s, box-shadow .15s; }
.form-control:focus, .form-select:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(37,99,235,.15); outline: none; background: var(--input-bg); color: var(--input-color); }
.form-label { font-size: 15px; font-weight: 600; color: var(--stat-lbl); margin-bottom: 5px; }
.form-control-sm, .form-select-sm { font-size: 14px; padding: 5px 10px; }
.form-control::placeholder { color: var(--sb-sec); }

/* ── Alertas ─────────────────────────────────────────────────── */
.alert { border-radius: 10px; font-size: 16px; padding: 12px 16px; font-weight: 500; }
.alert-success { background: #f0fdf4; border-color: #86efac; color: #15803d; }
.alert-danger   { background: #fef2f2; border-color: #fca5a5; color: #dc2626; }
.alert-warning  { background: #fffbeb; border-color: #fde047; color: #b45309; }
.alert-info     { background: #eff6ff; border-color: #93c5fd; color: #1d4ed8; }

/* ── Utilidades ──────────────────────────────────────────────── */
.text-muted   { color: var(--stat-lbl) !important; }
.text-success { color: var(--success) !important; }
.text-danger  { color: var(--danger) !important; }
.text-primary { color: var(--accent) !important; }
.fw-semibold  { font-weight: 600 !important; }
.section-label { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--stat-lbl); margin-bottom: 10px; }
.empty-state { text-align: center; padding: 52px 24px; color: var(--stat-lbl); font-size: 16px; }
.filter-bar { background: var(--filter-bg); border: 1px solid var(--filter-border); border-radius: 12px; padding: 12px 16px; margin-bottom: 16px; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.search-wrap { position: relative; }
.search-wrap .search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--stat-lbl); pointer-events: none; }
.search-wrap .form-control { padding-left: 34px; }
.progress { background: var(--card-border); border-radius: 99px; }
.progress-bar { border-radius: 99px; }
.progress-bar.bg-success { background: var(--success) !important; }
.progress-bar.bg-primary { background: var(--accent) !important; }
.htmx-indicator { display: none; }
.htmx-request .htmx-indicator { display: inline-block; }

/* ── Auth ────────────────────────────────────────────────────── */
.auth-wrap { min-height: 100vh; background: #f1f5f9; display: flex; align-items: center; justify-content: center; padding: 32px 16px; }
.auth-card { width: 100%; max-width: 400px; background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; box-shadow: 0 4px 24px rgba(0,0,0,.10); padding: 36px 32px; }
.auth-logo { width: 40px; height: 40px; background: #2563eb; border-radius: 10px; display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.auth-logo svg { width: 22px; height: 22px; color: #fff; }
.auth-title { font-size: 18px; font-weight: 800; color: #0f172a; text-align: center; margin-bottom: 4px; letter-spacing: -.02em; }
.auth-subtitle { font-size: 13px; color: #94a3b8; text-align: center; margin-bottom: 28px; }
.auth-footer { text-align: center; font-size: 12px; color: #94a3b8; margin-top: 20px; }
.auth-footer a { color: #2563eb; text-decoration: none; font-weight: 600; }
.btn-google { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; padding: 10px 16px; background: #fff; border: 1px solid #e2e8f0; border-radius: 8px; font-size: 13px; font-weight: 600; color: #334155; text-decoration: none; transition: all .15s; cursor: pointer; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.btn-google:hover { background: #f8fafc; border-color: #cbd5e1; }
.btn-google svg { width: 18px; height: 18px; flex-shrink: 0; }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--card-border); border-radius: 3px; }