:root{
  --bg:#eef4fb;
  --panel:#ffffff;
  --text:#172033;
  --muted:#68758a;
  --line:#dde7f3;
  --primary:#0b63ce;
  --primary-dark:#063b7c;
  --success:#0e8f60;
  --warning:#b36b00;
  --danger:#c7283d;
  --shadow:0 18px 45px rgba(15,47,84,.10);
  --radius:22px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
.app-shell{display:flex;min-height:100vh}.sidebar{width:280px;background:linear-gradient(180deg,#071a34,#0a356f);color:#fff;padding:24px;display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0}.brand{display:flex;align-items:center;gap:12px;margin-bottom:32px}.brand-mark{width:44px;height:44px;border-radius:15px;background:linear-gradient(135deg,#3aa0ff,#ffffff);color:#063b7c;display:grid;place-items:center;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.22)}.brand-mark.big{width:76px;height:76px;border-radius:24px;font-size:25px}.brand span{display:block;color:#bdd5f2;font-size:12px;margin-top:2px}.sidebar nav{display:grid;gap:8px}.sidebar nav a{padding:13px 14px;border-radius:14px;color:#dcecff}.sidebar nav a:hover,.sidebar nav a.active{background:rgba(255,255,255,.12);color:#fff}.sidebar-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.16);padding-top:18px;display:flex;align-items:center;justify-content:space-between;color:#cfe3ff}.sidebar-footer a{color:#fff;font-weight:700}.main{margin-left:280px;width:calc(100% - 280px);padding:28px}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--primary);font-size:12px;font-weight:800;margin:0 0 4px}h1{font-size:32px;margin:0}h2{font-size:20px;margin:0 0 10px}.muted{color:var(--muted)}small{color:var(--muted)}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cards-4{grid-template-columns:repeat(4,minmax(0,1fr))}.align-start{align-items:start}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:18px}.card-head{display:flex;align-items:start;justify-content:space-between;gap:16px;margin-bottom:14px}.kpi span{display:block;color:var(--muted);font-size:13px;font-weight:700}.kpi strong{display:block;font-size:26px;margin-top:8px}.kpi.danger strong{color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);background:#fff;color:var(--text);padding:11px 15px;border-radius:14px;font-weight:800;cursor:pointer}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-color:transparent}.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}.btn.full{width:100%}.alert{padding:14px 16px;border-radius:16px;margin-bottom:18px;border:1px solid var(--line);background:#fff}.alert.success{border-color:#bfe8d8;background:#eefbf6;color:#08623e}.alert.error{border-color:#ffd0d7;background:#fff0f2;color:#9d1025}.alert.info{border-color:#cfe1ff;background:#f1f6ff;color:#0d468b}.form-grid{display:grid;gap:12px}.form-grid label{font-weight:800;font-size:13px;color:#2e3c52}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:11px 12px;font:inherit;background:#fbfdff;color:var(--text)}textarea{min-height:105px;resize:vertical}.compact-inputs{gap:12px!important}.filters{display:grid;grid-template-columns:1.2fr 1.2fr .9fr auto auto;gap:12px;align-items:end}.checkline{display:flex;align-items:center;gap:8px;font-weight:800}.checkline input{width:auto}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{border-collapse:collapse;width:100%;background:#fff}th,td{padding:12px 13px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;font-size:14px}th{background:#f6f9fd;color:#3d4c63;font-size:12px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}tr:hover td{background:#fbfdff}.wide{max-width:100%;overflow:auto}.data-table{min-width:1350px}.small-col{max-width:360px;font-size:12px;color:#536174}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:#edf3fb;color:#38506e;font-size:12px;font-weight:900}.badge.ok,.badge.activo,.badge.crecimiento{background:#eafaf4;color:#08764e}.badge.critico{background:#ffe8ec;color:#b01029}.badge.alto,.badge.en_riesgo{background:#fff0dc;color:#9b5900}.badge.medio,.badge.seguimiento{background:#fff8d9;color:#806700}.badge.estable{background:#edf3fb;color:#38506e}.neg{color:var(--danger);font-weight:900}.pos{color:var(--success);font-weight:900}.comparison-note,.note{background:linear-gradient(135deg,#f5f9ff,#fff);border:1px solid var(--line);padding:14px;border-radius:16px;color:#475870;margin-bottom:14px}.steps{display:grid;gap:12px;margin:18px 0}.steps div{display:flex;gap:12px;align-items:center}.steps b{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;background:#e8f2ff;color:var(--primary)}.steps.slim b{background:#eafaf4;color:#08764e}.rank-list{display:grid;gap:10px}.rank-row{display:grid;grid-template-columns:1fr auto;gap:12px;position:relative;padding:12px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}.rank-row strong,.rank-row span,.rank-row small{position:relative;z-index:2}.rank-row small{display:block}.rank-row i{position:absolute;left:0;bottom:0;height:4px;background:linear-gradient(90deg,var(--primary),#a5d3ff);border-radius:0 999px 999px 0}.action-panel{background:linear-gradient(135deg,#ffffff,#eef6ff)}.client-hero{display:flex;align-items:center;justify-content:space-between}.client-hero h2{font-size:28px}.bar-chart{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:210px 1fr 140px;gap:12px;align-items:center}.bar-row label{font-weight:800}.bar-row label small{display:block;font-weight:500}.bar{height:14px;background:#edf3fb;border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#3aa0ff);border-radius:999px}.timeline{display:grid;gap:10px;margin-top:16px}.timeline div{border:1px solid var(--line);border-radius:16px;padding:12px;background:#fbfdff}.timeline small{display:block;margin-top:3px}.timeline p{margin:8px 0 0;color:#40516a}.inline-form select{padding:7px 9px;border-radius:10px}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,#e5f2ff,#f8fbff 40%,#eaf1fa)}.login-card{width:min(980px,94vw);display:grid;grid-template-columns:1.2fr .8fr;border-radius:30px;overflow:hidden;background:#fff;box-shadow:0 30px 80px rgba(6,32,66,.18);border:1px solid #dfe9f5}.login-hero{background:linear-gradient(135deg,#071a34,#0d62c5);color:#fff;padding:44px}.login-hero h1{font-size:38px;line-height:1.05;margin:22px 0 12px}.login-hero p{color:#cfe3ff;font-size:17px;max-width:520px}.mini-kpis{display:flex;gap:10px;margin-top:28px}.mini-kpis span{padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.13);font-weight:800}.login-form{padding:44px;display:grid;gap:12px;align-content:center}.login-form h2{font-size:28px}.login-form small{text-align:center;margin-top:8px}.small-form input,.small-form select{padding:9px 10px}
@media(max-width:1100px){.sidebar{position:static;width:100%;height:auto}.app-shell{display:block}.main{margin-left:0;width:100%;padding:18px}.grid.two,.grid.cards-4{grid-template-columns:1fr}.filters{grid-template-columns:1fr}.login-card{grid-template-columns:1fr}.bar-row{grid-template-columns:1fr}.card-head{display:block}.btn{margin-top:10px}}
.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.note.warning{border-color:#ffe1ad;background:#fff8ea;color:#7a4a00}.success-note{border-color:#bfe8d8;background:#eefbf6;color:#08623e}.progress-shell{height:18px;background:#edf3fb;border-radius:999px;overflow:hidden;border:1px solid var(--line);margin:18px 0}.progress-bar{height:100%;width:0;background:linear-gradient(90deg,var(--primary),#3aa0ff);border-radius:999px;transition:width .25s ease}.stats-row{margin:16px 0}.stat{background:#fbfdff;border:1px solid var(--line);border-radius:18px;padding:16px}.stat span{display:block;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.stat strong{display:block;margin-top:8px;font-size:22px}.actions{gap:10px;align-items:center;margin-top:16px}.mini-link{margin-left:8px;font-size:12px;font-weight:900;color:var(--primary)}.badge.status-procesando{background:#fff8d9;color:#806700}.badge.status-procesado{background:#eafaf4;color:#08764e}.badge.status-error{background:#ffe8ec;color:#b01029}@media(max-width:1100px){.grid.four{grid-template-columns:1fr}}
