:root{--navy: #10132a;--violet: #6b4eff;--violet2: #9a86ff;--cyan: #2ad4d4;--bg: #f5f6fb;--card: #fff;--line: #e7e9f3;--texto: #1b1f3b;--tenue: #8a90b5;--ok: #16a34a;--late: #e0466e;--pend: #d39a00}*{box-sizing:border-box;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}body{background:var(--bg);color:var(--texto)}.login{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(700px 400px at 50% -10%,rgba(107,78,255,.25),transparent 60%),linear-gradient(168deg,#12152a,#0a0d1c)}.login-card{background:var(--card);border-radius:20px;padding:36px 32px;width:340px;text-align:center;box-shadow:0 30px 80px #0006}.login-card h1{font-size:22px;margin-top:14px}.login-card p{color:var(--tenue);font-size:13px;margin:4px 0 20px}.login-card input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;font-size:15px}.login-card button{width:100%;margin-top:14px}.logo{width:56px;height:56px;border-radius:16px;margin:0 auto;display:grid;place-items:center;color:#fff;font-weight:800;font-size:24px;background:linear-gradient(135deg,var(--violet2),var(--cyan))}.logo.sm{width:30px;height:30px;font-size:15px;border-radius:9px;display:inline-grid;vertical-align:middle}button{background:var(--violet);color:#fff;border:none;border-radius:12px;padding:10px 16px;font-weight:600;font-size:14px;cursor:pointer}button:hover{filter:brightness(1.05)}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:#eef0fb;color:var(--violet)}button.link{background:none;color:var(--tenue);padding:10px 8px}button.x{background:none;color:var(--tenue);font-size:24px;padding:0 6px;line-height:1}.app{max-width:1000px;margin:0 auto;padding:20px}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.brand{font-weight:700;font-size:18px}.acciones{display:flex;gap:8px;align-items:center}.resumen{display:flex;gap:18px;align-items:center;flex-wrap:wrap;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 18px;margin-bottom:16px;font-size:14px}.resumen strong{font-size:15px;text-transform:capitalize}.resumen .ok{color:var(--ok)}.resumen .late{color:var(--late)}.resumen .pend{color:var(--pend)}.tabla{width:100%;border-collapse:collapse;background:var(--card);border-radius:14px;overflow:hidden;border:1px solid var(--line)}.tabla th{text-align:left;font-size:12px;color:var(--tenue);text-transform:uppercase;letter-spacing:.04em;padding:12px 16px;background:#fafbff}.tabla td{padding:14px 16px;border-top:1px solid var(--line);font-size:14px;vertical-align:middle}.fila{cursor:pointer}.fila:hover{background:#faf9ff}.muted,.meta{color:var(--tenue)}.pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:600;background:#f0f1f8}.pill.ok{background:#e7f7ee;color:var(--ok)}.pill.late{background:#fdeaf0;color:var(--late)}.pill.pend{background:#fdf4e0;color:var(--pend)}.acum{font-weight:600}.barra{height:6px;background:#eef0f8;border-radius:99px;margin-top:6px;overflow:hidden;max-width:220px}.barra div{height:100%;background:linear-gradient(90deg,var(--violet),var(--cyan))}.vacio{text-align:center;color:var(--tenue);padding:30px}.banner.err{background:#fdeaf0;color:var(--late);padding:12px 16px;border-radius:12px;margin-bottom:12px}.err{color:var(--late);font-size:13px;margin:6px 0}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#10132a80;display:grid;place-items:center;padding:20px;z-index:20}.modal{background:var(--card);border-radius:18px;padding:22px;width:420px;max-width:100%;max-height:90vh;overflow:auto}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal-head h2{font-size:18px}.modal label{display:block;font-size:13px;color:var(--tenue);margin-bottom:12px}.modal input,.modal select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;margin-top:4px;color:var(--texto)}.modal .row{display:flex;gap:12px}.modal .row label{flex:1}.modal button{width:100%;margin-top:8px}.ficha-kpis{display:flex;gap:12px;margin:12px 0 18px}.ficha-kpis div{flex:1;background:#fafbff;border:1px solid var(--line);border-radius:12px;padding:12px;text-align:center}.ficha-kpis span{display:block;font-size:12px;color:var(--tenue)}.ficha-kpis b{font-size:17px}.tabla.mini td,.tabla.mini th{padding:8px 10px;font-size:13px}h3{font-size:17px}h4{font-size:14px;color:var(--tenue);margin:8px 0}
