:root{color:#17202a;background:#f5f7fa;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}.app{min-height:100vh;display:grid;grid-template-columns:220px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;padding:20px 14px;background:#fff;border-right:1px solid #dfe5eb;display:flex;flex-direction:column;gap:18px}.brand{font-size:16px;font-weight:800;padding:0 8px}nav{display:grid;gap:6px}nav button,.logout{width:100%;height:40px;border:0;border-radius:8px;background:transparent;color:#53606c;display:flex;align-items:center;gap:10px;padding:0 10px;cursor:pointer}nav button.active{background:#eaf2ff;color:#155bb5;font-weight:700}.logout{margin-top:auto}.content{min-width:0;padding:24px}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}h1,h2,p{margin:0}h1{font-size:24px;line-height:1.2}h2{font-size:16px;margin-bottom:12px}.topbar p,.muted,.statHint{color:#71808f}.button,.textButton{border:0;border-radius:8px;cursor:pointer}.button{min-height:36px;padding:0 14px;background:#1864d9;color:#fff;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.button.secondary{background:#fff;color:#283747;border:1px solid #d6dee6}.button:disabled{opacity:.45;cursor:not-allowed}.textButton,.link{color:#155bb5;background:transparent;padding:0;border:0;cursor:pointer}.statsGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.statsGrid.compact{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat{min-height:116px;background:#fff;border:1px solid #dfe5eb;border-radius:8px;padding:16px;display:grid;align-content:space-between;gap:8px}.stat.good{border-color:#b8e0c9}.stat.bad{border-color:#f3b7b7}.statTitle{color:#53606c;font-weight:700}.statValue{font-size:28px;font-weight:850}.filters{background:#fff;border:1px solid #dfe5eb;border-radius:8px;padding:12px;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}input,select{height:36px;min-width:140px;border:1px solid #cfd8e3;border-radius:8px;background:#fff;padding:0 10px}.tableWrap{width:100%;overflow-x:auto;background:#fff;border:1px solid #dfe5eb;border-radius:8px}table{width:100%;min-width:860px;border-collapse:collapse}th,td{text-align:left;padding:11px 12px;border-bottom:1px solid #edf1f5;vertical-align:middle;white-space:nowrap}th{color:#647382;font-size:12px;background:#f9fafc}tr:last-child td{border-bottom:0}.wrapCell{display:inline-block;max-width:360px;white-space:normal;line-height:1.45}.badge{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 9px;background:#eef2f6;color:#53606c;font-size:12px;font-weight:700}.badge.good{background:#e7f6ec;color:#197044}.badge.bad{background:#fff0f0;color:#b42318}.empty,.state,.error,.notice{background:#fff;border:1px solid #dfe5eb;border-radius:8px;padding:18px;color:#647382}.error{color:#b42318;border-color:#f3b7b7;display:flex;align-items:center;gap:12px}.notice{margin-bottom:14px;border-color:#ffe2a8;background:#fffaf0;color:#8a5a00}.pager{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:12px}.section{margin-top:18px}.barList{display:grid;gap:8px}.barRow{min-height:36px;background:#fff;border:1px solid #dfe5eb;border-radius:8px;padding:8px 12px;display:grid;grid-template-columns:minmax(120px,220px) minmax(100px,1fr) auto;align-items:center;gap:12px}.barTrack{height:8px;border-radius:999px;overflow:hidden;background:#edf1f5}.barTrack i{display:block;height:100%;background:#2f80ed}.split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.thumb{width:44px;height:44px;object-fit:cover;border-radius:6px;border:1px solid #dfe5eb;background:#f2f4f7}.placeholder{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:6px;background:#f2f4f7;color:#71808f}.drawer{position:fixed;inset:0;background:#141e2847;display:flex;justify-content:flex-end;z-index:20}.drawerPanel{width:min(920px,94vw);height:100vh;overflow:auto;background:#f5f7fa;padding:20px;box-shadow:-16px 0 32px #141e282e}.drawerHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.detailStack{display:grid;gap:16px}.infoGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.infoGrid div{background:#fff;border:1px solid #dfe5eb;border-radius:8px;padding:12px;display:grid;gap:6px}.infoGrid span{color:#71808f}.login{min-height:100vh;display:grid;place-items:center;padding:24px}.loginBox{width:min(360px,100%);background:#fff;border:1px solid #dfe5eb;border-radius:8px;padding:22px;display:grid;gap:12px}.loginBox input,.loginBox button{width:100%}@media(max-width:760px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:12px}nav{grid-template-columns:repeat(2,minmax(0,1fr))}.content{padding:14px}.topbar,.split{grid-template-columns:1fr;display:grid}.barRow{grid-template-columns:1fr}}
