:root{--bg:#f6f7f2;--fg:#172016;--muted:#667063;--green:#1f5b32;--green-dark:#16351f;--line:#e2e6dc;--warn:#fff7e6;--bad:#ffecec;font-family:system-ui,-apple-system,Segoe UI,sans-serif;color:var(--fg);background:var(--bg)}*{box-sizing:border-box}body{margin:0}a{color:inherit}.layout{display:grid;grid-template-columns:235px 1fr;min-height:100vh}.side{background:var(--green-dark);color:#fff;padding:18px;display:flex;flex-direction:column;gap:18px;position:-webkit-sticky;position:sticky;top:0;align-self:start;height:100vh}.brand{font-size:22px;font-weight:800}.side nav{display:flex;flex-direction:column;gap:4px}.side hr{border:none;border-top:1px solid #ffffff22;margin:8px 0}.side a{color:#fff;text-decoration:none;padding:10px 12px;border-radius:10px}.side a:hover{background:#ffffff20}.userBox{margin-top:auto;border-top:1px solid #ffffff22;padding-top:12px;font-size:13px}.userName{font-weight:700}.userRole{color:#cfe6d2;font-size:11px;margin-bottom:6px}.logout{background:transparent;color:#cfe6d2;border:1px solid #ffffff33;font-size:12px;padding:6px 10px;border-radius:8px;cursor:pointer}.logout:hover{background:#ffffff15}.main{padding:28px;max-width:1180px}.loginMain{min-height:100vh;display:grid;place-items:center;padding:20px}h1{margin:0 0 4px}h2{margin:0 0 12px;font-size:17px}.muted,p.muted{color:var(--muted)}.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;margin:0 0 18px;box-shadow:0 1px 2px #00000008}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:12px;gap:12px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.right{margin-left:auto}input,select,textarea{width:100%;border:1px solid #cfd6c8;border-radius:10px;padding:10px;font:inherit;background:#fff}.btn,button{border:0;border-radius:10px;padding:10px 14px;font-weight:700;background:var(--green);color:#fff;text-decoration:none;display:inline-block;cursor:pointer;font-family:inherit;font-size:inherit}.btn.secondary,button.secondary{background:#e8ece3;color:var(--fg)}button.danger{background:#a22}button:disabled{background:#c7ccc1;color:#777;cursor:not-allowed}table{width:100%;border-collapse:collapse;background:#fff}td,th{text-align:left;border-bottom:1px solid #edf0e8;padding:10px;vertical-align:top}th{font-size:12px;color:var(--muted);font-weight:600}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:12px;gap:12px;margin-bottom:18px}.kpi{background:#fff;border-radius:16px;border:1px solid var(--line);padding:16px}.kpi span{font-size:12px;color:var(--muted)}.kpi b{display:block;font-size:28px;margin-top:4px}.kpi.warn{background:var(--warn)}.kpi.bad{background:var(--bad)}.warn{background:var(--warn)}.bad{background:var(--bad)}.pill{padding:4px 8px;border-radius:999px;background:#e8ece3;font-size:12px;font-weight:600}.pill.green{background:#d3eed9;color:#1f5b32}.pill.amber{background:#fde9c8;color:#884a00}.pill.red{background:#fbd2d2;color:#8b1c1c}.scanOverlay{position:fixed;inset:0;background:#000c;display:grid;place-items:center;z-index:50}.scanOverlay video{max-height:60vh;background:#000}.scanOverlay video,.scanPanel{max-width:92vw;border-radius:16px}.scanPanel{background:#fff;padding:14px;display:grid;grid-gap:8px;gap:8px}.loginCard{background:#fff;border-radius:18px;padding:26px;width:360px;box-shadow:0 2px 12px #00000010;border:1px solid var(--line)}.errorBox{background:var(--bad);border:1px solid #f5b5b5;color:#8b1c1c;padding:8px 12px;border-radius:10px;font-size:13px;margin:8px 0}@media (max-width:800px){.layout{grid-template-columns:1fr}.side{position:static;height:auto}.side nav{display:grid;grid-template-columns:repeat(3,1fr)}.userBox{display:none}.main{padding:14px}}