:root{--bg:#f7f5f4;--panel:#fff;--border:#e8e5e2;--border2:#f0edea;--ink:#1c1a19;--ink2:#6b655e;--ink3:#a39c95;--hover:#faf7f6;--accent:#b3001b;--accent-tint:#fbe7ea;--pass:#1b8a3f;--pass-bg:#e7f3eb;--fail:#b3001b;--fail-bg:#fbe7ea;--due:#c7711a;--due-bg:#fbefd9;--info:#2563b5;--info-bg:#e7f0fb}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Archivo,system-ui,-apple-system,sans-serif;font-size:14px}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.mono{font-family:IBM Plex Mono,ui-monospace,monospace}.center{height:100%;color:var(--ink2);place-items:center;display:grid}.app{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;flex:none;width:214px;padding:16px 12px;display:flex}.brand{align-items:center;gap:9px;padding:4px 8px 16px;display:flex}.brand-mark{background:var(--accent);color:#fff;border-radius:7px;place-items:center;width:26px;height:26px;font-size:14px;font-weight:800;display:grid}.brand-name{letter-spacing:-.01em;font-size:16px;font-weight:800}.nav{flex-direction:column;gap:2px;display:flex;overflow-y:auto}.navitem{color:var(--ink2);border-radius:8px;align-items:center;gap:10px;padding:9px 11px;font-size:13px;font-weight:600;display:flex}.navitem:hover{background:var(--hover)}.navitem.active{background:var(--accent-tint);color:var(--accent)}.navicon{background:var(--border2);width:18px;height:18px;color:var(--ink2);border-radius:5px;flex:none;place-items:center;font-size:12px;display:grid}.navitem.active .navicon{background:var(--accent);color:#fff}.nav-badge{background:var(--due);color:#fff;text-align:center;border-radius:20px;min-width:18px;margin-left:auto;padding:1px 7px;font-size:10px;font-weight:800}.sidebar-foot{color:var(--ink3);margin-top:auto;padding:10px 8px 2px;font-size:11px}.main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--panel);border-bottom:1px solid var(--border);flex:none;align-items:center;gap:14px;height:58px;padding:0 26px;display:flex}.search{background:var(--bg);border:1px solid var(--border);max-width:460px;color:var(--ink3);border-radius:9px;flex:1;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.search input{font:inherit;color:var(--ink);background:0 0;border:0;outline:none;flex:1}.kbd{border:1px solid var(--border);color:var(--ink3);border-radius:5px;padding:1px 6px;font-size:11px}.topbar-right{align-items:center;gap:12px;margin-left:auto;display:flex}.avatar{background:var(--accent);color:#fff;border-radius:50%;place-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:grid}.content{flex:1;padding:24px 26px;overflow-y:auto}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px}.page-title{margin:0;font-size:24px;font-weight:800}.page-sub{color:var(--ink2);margin:3px 0 0;font-size:13px}.page-head{justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.row{align-items:center;gap:10px;display:flex}.spacer{flex:1}.btn{border:1px solid var(--border);background:var(--panel);color:var(--ink);border-radius:9px;padding:8px 13px;font-size:13px;font-weight:700}.btn:hover{background:var(--hover)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.06)}.btn-sm{padding:6px 10px;font-size:12px}.badge{letter-spacing:.02em;text-transform:uppercase;border-radius:6px;align-items:center;padding:3px 9px;font-size:10px;font-weight:800;display:inline-flex}.badge.pass{color:var(--pass);background:var(--pass-bg)}.badge.fail{color:#fff;background:var(--fail)}.badge.active{color:var(--pass);background:var(--pass-bg)}.badge.withdrawn,.badge.disposed{color:var(--ink2);background:var(--border2)}.badge.destroyed{color:#fff;background:var(--fail)}.badge.due{color:var(--due);background:var(--due-bg)}.badge.overdue{color:#fff;background:var(--due)}.chip{border:1px solid var(--border);background:var(--panel);color:var(--ink2);border-radius:8px;align-items:center;gap:6px;padding:5px 11px;font-size:12px;font-weight:600;display:inline-flex}.chip.active{background:var(--accent-tint);border-color:var(--accent);color:var(--accent)}.chip.dashed{color:var(--ink3);border-style:dashed}.chip button,button.chip{cursor:pointer}.table{background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden}.thead,.trow{align-items:center;gap:12px;display:grid}.thead{border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.07em;color:var(--ink3);padding:11px 18px;font-size:10px;font-weight:700}.trow{border-bottom:1px solid var(--border2);text-align:left;background:0 0;border-top:0;border-left:0;border-right:0;width:100%;padding:13px 18px;font-size:13px}.trow:last-child{border-bottom:0}button.trow:hover{background:var(--hover)}.cell-strong{font-weight:600}.cell-sub{color:var(--ink2);font-size:11px}.accent-link{color:var(--accent);font-weight:700}.empty{text-align:center;color:var(--ink3);padding:40px}.kpis{grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:16px;display:grid}.kpi{padding:15px 16px}.kpi.flag{border-left:4px solid var(--due)}.kpi-num{font-size:30px;font-weight:800;line-height:1}.kpi-label{color:var(--ink2);margin-top:6px;font-size:12px}.banner{background:var(--accent);color:#fff;border-radius:12px;align-items:center;gap:12px;margin-bottom:16px;padding:13px 18px;font-size:13px;font-weight:600;display:flex}.banner .btn{color:#fff;background:#ffffff29;border-color:#ffffff4d;margin-left:auto}.grid2{grid-template-columns:1.3fr 1fr;align-items:start;gap:16px;display:grid}.card-title{border-bottom:1px solid var(--border);padding:14px 16px;font-size:14px;font-weight:700}.feed-row{border-bottom:1px solid var(--border2);align-items:center;gap:11px;padding:12px 16px;font-size:13px;display:flex}.feed-row:last-child{border-bottom:0}.dot{border-radius:50%;flex:none;width:8px;height:8px}.login-wrap{place-items:center;height:100vh;display:grid}.login{width:360px;padding:28px}.login h1{margin:0 0 4px;font-size:20px}.login .field{margin-top:14px}.login label{color:var(--ink2);font-size:12px;font-weight:600}.login input{border:1px solid var(--border);width:100%;font:inherit;border-radius:9px;outline:none;margin-top:5px;padding:10px 12px}.login input:focus{border-color:var(--accent)}.login .err{color:var(--fail);margin-top:10px;font-size:12px}.login button{width:100%;margin-top:18px;padding:11px}
