:root{--bg: #f4f6fb;--card: #ffffff;--ink: #1f2733;--muted: #6b7686;--line: #e4e8f0;--brand: #2563eb;--brand-ink: #ffffff;--error: #c0392b;--ok: #137a4b;--warn: #b26a00}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,PingFang SC,Microsoft YaHei,system-ui,sans-serif;background:var(--bg);color:var(--ink)}.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:16px}h1{font-size:20px;margin:0 0 4px}h2{font-size:17px;margin:0 0 12px}h3{font-size:14px;margin:18px 0 8px}.muted{color:var(--muted)}.small{font-size:12px}.error{color:var(--error);font-size:13px;margin:8px 0 0}.ok{color:var(--ok);font-size:13px;margin:8px 0 0}code.mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;color:var(--muted)}label{display:block;font-size:13px;color:var(--muted);margin:12px 0 4px}input,textarea,select{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}textarea{min-height:88px;resize:vertical}button{padding:9px 16px;background:var(--brand);color:var(--brand-ink);border:none;border-radius:8px;font-size:14px;cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}button.link{background:none;color:var(--brand);padding:4px 0}button.ghost{background:#eef2fb;color:var(--brand)}button.danger{background:#fbecea;color:var(--error)}button.sm{padding:5px 10px;font-size:12px}.inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline button{white-space:nowrap}.centered{min-height:100vh;display:grid;place-items:center;padding:20px}.login{width:340px}.login button{margin-top:12px;width:100%}.app{min-height:100vh}.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--card);border-bottom:1px solid var(--line)}.topbar .title{font-size:16px;font-weight:600}.topbar .right{display:flex;gap:12px;align-items:center}.layout{display:grid;grid-template-columns:184px 1fr;gap:16px;padding:16px;align-items:start}.sidebar{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:8px;position:sticky;top:16px}.sidebar button{display:block;width:100%;text-align:left;background:none;color:var(--ink);padding:10px 12px;border-radius:8px;font-size:14px;margin:2px 0}.sidebar button.active{background:#eef4ff;color:var(--brand);font-weight:600}.main{min-width:0}.rowBetween{display:flex;justify-content:space-between;align-items:center;gap:12px}.toolbar{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;margin-bottom:14px}.toolbar .field{display:flex;flex-direction:column}.toolbar label{margin:0 0 4px}.toolbar input,.toolbar select{width:auto;min-width:150px}.toolbar button{margin:0}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{border:1px solid var(--line);border-radius:10px;padding:14px;background:var(--card)}.statValue{font-size:24px;font-weight:600}.statLabel{font-size:12px;color:var(--muted);margin-top:4px}.table{width:100%;border-collapse:collapse;font-size:13px}.table th,.table td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);white-space:nowrap}.table th{color:var(--muted);font-weight:500;font-size:12px}.table tbody tr.clickable{cursor:pointer}.table tbody tr.clickable:hover{background:#f7f9ff}.tableWrap{overflow-x:auto}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;background:#eef2f7;color:var(--muted)}.badge.brand{background:#e8efff;color:var(--brand)}.badge.ok{background:#e4f4ec;color:var(--ok)}.badge.warn{background:#fbf0dc;color:var(--warn)}.badge.danger{background:#fbecea;color:var(--error)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#141c2866;display:flex;justify-content:flex-end;z-index:10}.drawer{width:460px;max-width:92vw;height:100%;background:var(--bg);overflow-y:auto;padding:18px;box-shadow:-8px 0 24px #0000001f}.drawer .card{margin-bottom:12px}.empty{color:var(--muted);text-align:center;padding:40px 18px}.kv{display:grid;grid-template-columns:96px 1fr;gap:4px 10px;font-size:13px}.kv .k{color:var(--muted)}
