*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#eef2f7;--panel:#ffffff;--border:#e3e8ef;--border-soft:#eef1f6;--fg:#1e293b;--fg-strong:#0f172a;--muted:#64748b;--primary:#1d4ed8;--primary-hover:#1e40af;--primary-soft:#e8effc;--sidebar-top:#1e3a8a;--sidebar-bot:#1c2f6b;--success:#15803d;--success-soft:#e7f6ec;--warning:#b45309;--warning-soft:#fdf0dd;--danger:#dc2626;--danger-soft:#fce8e8;--info:#1d4ed8;--info-soft:#e8effc;--shadow:0 1px 2px rgba(15,23,42,0.04),0 1px 3px rgba(15,23,42,0.06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.center{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#1e3a8a,#1c2f6b)}.card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:36px;width:100%;max-width:390px;box-shadow:0 20px 50px rgba(15,23,42,.25)}.brand{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--fg-strong)}.brand span{color:var(--primary)}.subtitle{color:var(--muted);font-size:13px;margin-top:4px;margin-bottom:22px}label{display:block;font-size:12px;font-weight:600;color:#475569;margin:14px 0 6px}input,select{width:100%;background:#fff;border:1px solid #cdd5e0;border-radius:8px;padding:11px 12px;color:var(--fg);font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.btn{width:100%;margin-top:22px;background:var(--primary);color:#fff;border:none;border-radius:8px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.btn:hover{background:var(--primary-hover)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{width:auto;margin:0;padding:9px 16px;font-size:13px}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--fg)}.btn-danger{background:transparent;border:1px solid #f0c4c4;color:var(--danger);padding:6px 11px;font-size:12px;border-radius:6px;cursor:pointer}.btn-danger:hover{background:var(--danger-soft)}.error{color:var(--danger);font-size:13px;margin-top:14px}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.side{background:linear-gradient(180deg,var(--sidebar-top),var(--sidebar-bot));padding:20px 14px;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow:hidden}.nav-scroll,.side{display:flex;gap:3px}.nav-scroll{flex:1 1;min-height:0;overflow-y:auto;flex-direction:column;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent}.nav-scroll::-webkit-scrollbar{width:6px}.nav-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.side .logo{font-size:19px;font-weight:800;letter-spacing:-.02em;color:#fff;padding:6px 12px 18px}.side .logo span{color:#93b4f5}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:8px;color:#c7d4ee;font-size:13.5px;font-weight:500;cursor:pointer;border:none;background:none;width:100%;text-align:left;transition:background .12s,color .12s}.nav-item:hover{background:rgba(255,255,255,.1);color:#fff}.nav-item.active{background:#fff;color:var(--primary);font-weight:600}.side .spacer{flex:1 1}.side .me{font-size:11.5px;color:#9fb3d8;padding:12px;border-top:1px solid rgba(255,255,255,.15);margin-top:8px}.content{padding:26px 32px;overflow-y:auto;max-height:100vh}.page-title{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--fg-strong);margin-bottom:2px}.page-sub{color:var(--muted);font-size:13px}.kpis,.page-sub{margin-bottom:22px}.kpis{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px}.kpi{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow)}.kpi .l{color:var(--muted);font-size:12px;font-weight:500}.kpi .v{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-top:6px;color:var(--fg-strong)}.kpi .v.warn{color:var(--danger)}.bar{display:flex;align-items:center;gap:10px;margin-bottom:16px}.bar .grow{flex:1 1}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}.panel-head{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--border)}.panel-head h2{font-size:14px;font-weight:700;color:var(--fg-strong)}.panel-head .right{margin-left:auto;display:flex;gap:8px}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600;padding:11px 20px;background:#f8fafc;border-bottom:1px solid var(--border)}td{padding:13px 20px;font-size:14px;border-bottom:1px solid var(--border-soft);color:var(--fg)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f9fbfd}.mono{font-family:SF Mono,ui-monospace,Menlo,monospace}.empty,.muted{color:var(--muted)}.empty{padding:48px;text-align:center}.link{color:var(--primary);cursor:pointer;font-weight:500}.link:hover{text-decoration:underline}.badge,.tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;background:#eef1f6;color:var(--muted);display:inline-block}.badge.ok,.tag{background:var(--success-soft);color:var(--success)}.badge.warn{background:var(--danger-soft);color:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.pill-days{font-weight:700}.pill-days.red{color:var(--danger)}.pill-days.amber{color:var(--warning)}.pill-days.green{color:var(--success)}.row-actions{display:flex;gap:6px;justify-content:flex-end}.btn-mini{padding:6px 11px;font-size:12px;font-weight:500;border-radius:6px;border:1px solid #cdd5e0;background:#fff;color:#334155;cursor:pointer;transition:all .12s}.btn-mini:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.45);display:grid;place-items:center;z-index:50}.modal{background:var(--panel);border-radius:14px;padding:26px;width:500px;max-width:92vw;max-height:88vh;overflow-y:auto;box-shadow:0 25px 60px rgba(15,23,42,.3)}.modal h3{font-size:17px;font-weight:700;color:var(--fg-strong);margin-bottom:18px}.grid2{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.grid2 .full{grid-column:1/-1}.field label{margin-top:0}.field input,.field select{margin:0}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}.shell{max-width:1100px;margin:0 auto;padding:24px}.formrow{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:#f8fafc}.formrow .full{grid-column:1/-1}.notif{display:flex;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border-soft)}.notif:last-child{border-bottom:none}.notif-bar{width:3px;border-radius:3px;flex-shrink:0}.notif-title{font-size:13px;font-weight:600;color:var(--fg-strong)}.notif-sub{font-size:12px;color:var(--muted)}.kpi .l,.notif-sub{margin-top:2px}