:root{
  --azul:#004075;--rojo:#FF0432;--blanco:#FFFFFF;--azul-700:#003560;--azul-050:#E9F0F6;
  --bg:#F4F6F9;--surface:#FFFFFF;--line:#E4E9F0;--ink:#16222E;--muted:#697787;
  --ok:#10B981;--warn:#F59E0B;--radius:12px;
  --shadow:0 1px 2px rgba(16,34,52,.06),0 8px 24px rgba(16,34,52,.06);
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --accent:var(--azul); /* cada módulo puede sobreescribirlo */
}
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
*{box-sizing:border-box}html,body{margin:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);font-size:14px;line-height:1.5}
button{font-family:inherit;cursor:pointer}a{color:inherit;text-decoration:none}
::selection{background:var(--azul);color:#fff}:focus-visible{outline:3px solid var(--azul-050);outline-offset:1px}

label{display:block;font-weight:600;font-size:12.5px;margin:0 0 6px}.field{margin-bottom:14px}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{border-color:var(--azul);outline:none;box-shadow:0 0 0 3px var(--azul-050)}
.btn{display:inline-block;border:0;border-radius:9px;padding:10px 15px;font-weight:600;font-size:13.5px;text-align:center}
.btn-primary{background:var(--azul);color:#fff}.btn-primary:hover{background:var(--azul-700)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}.btn-ghost:hover{border-color:var(--azul);color:var(--azul)}
.btn-danger{background:var(--rojo);color:#fff}.btn-sm{padding:7px 11px;font-size:12.5px}

.topbar{position:sticky;top:0;z-index:30;height:60px;background:var(--azul);color:#fff;display:flex;align-items:center;gap:14px;padding:0 18px}
.topbar .logo{display:flex;align-items:center;gap:10px;font-weight:700}
.topbar .logo .mark{width:30px;height:30px;border-radius:8px;background:#fff;color:var(--azul);display:grid;place-items:center;font-weight:800}
.topbar .logo .mark b{color:var(--rojo)}.spacer{flex:1}
.user-chip{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.12);padding:6px 10px;border-radius:30px}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--rojo);display:grid;place-items:center;font-weight:700;font-size:12px}
.logout{color:#fff;background:rgba(255,255,255,.14);width:34px;height:34px;border-radius:8px;display:grid;place-items:center;font-size:15px}
.hamb{display:none;background:rgba(255,255,255,.14);border:0;color:#fff;width:38px;height:38px;border-radius:9px;font-size:18px}

.layout{display:flex;align-items:flex-start}
.sidebar{width:236px;flex:0 0 236px;background:#fff;border-right:1px solid var(--line);min-height:calc(100vh - 60px);padding:14px 12px;position:sticky;top:60px}
.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:8px 8px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:10px 11px;border-radius:9px;color:var(--ink);font-weight:500;font-size:13.5px;margin-bottom:2px}
.nav-item .ic{width:18px;height:18px;flex:0 0 18px;color:var(--muted)}
.nav-item:hover{background:var(--azul-050)}
.nav-item.active{background:var(--accent);color:#fff;font-weight:600}.nav-item.active .ic{color:#fff}
.main{flex:1;min-width:0;padding:22px 26px 60px}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.page-head h2{margin:0;font-size:21px;letter-spacing:-.01em}.page-head .sub{color:var(--muted);font-size:13px;margin-top:2px}

.flash{padding:11px 15px;border-radius:10px;font-size:13.5px;font-weight:500;margin-bottom:16px}
.flash-ok{background:#E7F7F0;color:#0B7A4F}.flash-err{background:#FFE7EC;color:#C20029}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}.kpi.alt::after{background:var(--rojo)}
.kpi .k-label{color:var(--muted);font-size:12.5px;font-weight:600}.kpi .k-value{font-size:29px;font-weight:800;letter-spacing:-.02em;margin-top:4px}
.kpi .k-foot{font-size:11.5px;color:var(--muted);margin-top:4px}

.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px}
.card .c-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.card .c-head h3{margin:0;font-size:14.5px}.card .c-body{padding:16px}

.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:14px}
.seg{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:9px;padding:3px}
.seg a{padding:7px 12px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--muted)}
.seg a.active{background:var(--accent);color:#fff}
.f-field{display:flex;flex-direction:column;gap:4px}.f-field label{margin:0;font-size:11px}
.f-field input,.f-field select{padding:8px 10px;font-size:13px;min-width:140px}
.export-group{display:flex;gap:7px;margin-left:auto}
.export-group .icon-btn svg{width:15px;height:15px;vertical-align:-2px;margin-right:4px}

.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
td{padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--azul-050)}
.empty{color:var(--muted);text-align:center;padding:26px}
.badge{display:inline-block;padding:3px 9px;border-radius:30px;font-size:11.5px;font-weight:600}
.b-ok{background:#E7F7F0;color:#0B7A4F}.b-warn{background:#FEF3E2;color:#B26A04}.b-red{background:#FFE7EC;color:#C20029}
.b-gray{background:#EEF1F5;color:#5A6675}.b-blue{background:var(--azul-050);color:var(--azul)}
.rank-pos{width:26px;height:26px;border-radius:50%;display:inline-grid;place-items:center;font-weight:800;font-size:12px;background:var(--azul-050);color:var(--azul)}.rank-pos.top{background:var(--accent);color:#fff}
.row-actions{display:flex;gap:6px}
.icon-btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 9px;font-size:12px;font-weight:600;color:var(--muted)}
.icon-btn:hover{border-color:var(--azul);color:var(--azul)}.icon-btn.del:hover{border-color:var(--rojo);color:var(--rojo)}.icon-btn.fin{border-color:var(--ok);color:var(--ok)}

.grid-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-form .full{grid-column:1/-1}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:16px}
.panel h3{margin:0 0 14px;font-size:15px}
.matrix td,.matrix th{text-align:center}.matrix td:first-child,.matrix th:first-child{text-align:left}.matrix input{width:auto}
.swatch{display:inline-flex;align-items:center;gap:8px}.swatch input[type=color]{width:42px;height:34px;padding:2px;border-radius:8px}

.scrim{display:none}
@media (max-width:1024px){.kpis{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media (max-width:880px){
  .hamb{display:block}
  .sidebar{position:fixed;left:0;top:60px;bottom:0;z-index:40;transform:translateX(-110%);transition:.25s;box-shadow:0 10px 40px rgba(0,0,0,.2);overflow:auto}
  body.nav-open .sidebar{transform:translateX(0)}
  body.nav-open .scrim{display:block;position:fixed;inset:60px 0 0 0;background:rgba(0,0,0,.35);z-index:35}
  .main{padding:16px}.user-chip .uname{display:none}
}
@media (max-width:520px){.kpis{grid-template-columns:1fr}.grid-form{grid-template-columns:1fr}.export-group{margin-left:0;width:100%}}
