:root{--bg:#f5f7fb;--panel:#fff;--panel-strong:#111827;--line:#dce3ee;--line-strong:#c9d3e2;--text:#172033;--muted:#667085;--soft:#eef3f9;--accent:#1769e0;--accent-dark:#0e4fb0;--good:#0f9f6e;--warn:#d9822b;--shadow:0 18px 45px #14234614}*{box-sizing:border-box}html,body{background:var(--bg);min-height:100%;color:var(--text);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}button,input{font:inherit}.shell{grid-template-columns:336px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#fff;background:#101827;height:100vh;padding:28px;position:sticky;top:0;overflow:auto}.brand{align-items:center;gap:14px;margin-bottom:28px;display:flex}.brand-mark{background:#1e6eea;border:1px solid #fff3;border-radius:8px;place-items:center;width:44px;height:44px;font-size:14px;font-weight:800;display:grid}.brand h1,.brand p,.content-header h2,.content-header p,.table-title h3,.table-title span{margin:0}.brand h1{font-size:20px;line-height:1.2}.brand p{color:#aeb9cb;margin-top:4px;font-size:13px}.query-form{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;gap:16px;padding:18px;display:grid}.query-form label{gap:7px;display:grid}.query-form span{color:#c6d0df;font-size:13px;font-weight:650}.query-form input{color:#101827;background:#fffffff5;border:1px solid #ffffff29;border-radius:7px;outline:none;width:100%;height:42px;padding:0 12px}.query-form input:focus{border-color:#77a8ff;box-shadow:0 0 0 3px #1769e040}.query-form button,.ghost-button{cursor:pointer;border:0;border-radius:7px;height:42px;font-size:14px;font-weight:750}.query-form button{background:var(--accent);color:#fff}.query-form button:hover{background:var(--accent-dark)}.query-form button:disabled{cursor:wait;opacity:.72}.note{color:#cbd5e1;background:#ffffff0d;border-radius:8px;margin-top:18px;padding:16px;font-size:13px;line-height:1.6}.note strong{color:#fff;margin-bottom:4px;display:block}.note p{margin:0}.content{min-width:0;padding:30px}.content-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:22px;display:flex}.date-line{color:var(--muted);font-size:14px}.content-header h2{letter-spacing:0;margin-top:4px;font-size:30px;line-height:1.18}.ghost-button{border:1px solid var(--line);background:var(--panel);color:var(--text);padding:0 16px}.ghost-button:hover{border-color:var(--line-strong)}.header-actions{align-items:center;gap:10px;display:flex}.alert{color:#9b2c1f;background:#fff4f1;border:1px solid #f4c7bd;border-radius:8px;margin-bottom:18px;padding:13px 14px}.stats{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px;display:grid}.stat-card{border:1px solid var(--line);background:var(--panel);min-height:112px;box-shadow:var(--shadow);border-radius:8px;padding:16px}.stat-card span,.stat-card small{color:var(--muted);font-size:13px;display:block}.stat-card strong{letter-spacing:0;margin:10px 0 6px;font-size:24px;line-height:1.1;display:block}.chart-frame,.table-panel,.empty-state,.empty{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:8px}.chart-frame{margin-bottom:18px;padding:18px 16px 14px;overflow-x:auto}.chart-grid{grid-auto-columns:minmax(54px,1fr);grid-auto-flow:column;align-items:end;gap:10px;min-height:310px;display:grid}.bar-wrap{grid-template-rows:26px 220px 22px;align-items:end;min-width:54px;display:grid}.bar-value{color:var(--muted);text-align:center;white-space:nowrap;font-size:11px}.bar-track{background:var(--soft);border-radius:7px;height:220px;position:relative;overflow:hidden}.bar{background:linear-gradient(#3a8cff,#1769e0);border-radius:7px 7px 0 0;position:absolute;bottom:0;left:0;right:0}.bar-label{color:var(--muted);text-align:center;align-self:center;font-size:12px}.table-panel{overflow:hidden}.table-title{border-bottom:1px solid var(--line);justify-content:space-between;gap:12px;padding:16px 18px;display:flex}.table-title h3{font-size:18px}.table-title span{color:var(--muted);font-size:13px}.table-scroll{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:620px;font-size:14px}th,td{border-bottom:1px solid var(--line);text-align:right;white-space:nowrap;padding:13px 18px}th:first-child,td:first-child{text-align:left}th{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:750}tbody tr:hover{background:#f8fbff}.empty-state,.empty{text-align:center;place-items:center;min-height:260px;padding:28px;display:grid}.empty-state strong{margin-bottom:8px;font-size:22px;display:block}.empty-state p,.empty{color:var(--muted)}@media (max-width:980px){.shell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:620px){.sidebar,.content{padding:18px}.content-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .ghost-button{flex:1}.content-header h2{font-size:24px}.stats{grid-template-columns:1fr}}.login-shell{background:radial-gradient(circle at 30% 18%, #1769e024, transparent 28%), var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.login-panel{border:1px solid var(--line);background:var(--panel);width:min(100%,420px);box-shadow:var(--shadow);border-radius:8px;padding:28px}.login-brand{align-items:center;gap:14px;margin-bottom:24px;display:flex}.login-brand h1,.login-brand p{margin:0}.login-brand h1{font-size:22px;line-height:1.2}.login-brand p{color:var(--muted);margin-top:4px;font-size:13px}.login-form{gap:16px;display:grid}.login-form label{gap:7px;display:grid}.login-form span{color:var(--muted);font-size:13px;font-weight:700}.login-form input{border:1px solid var(--line-strong);width:100%;height:44px;color:var(--text);background:#fff;border-radius:7px;outline:none;padding:0 12px}.login-form input:focus{border-color:#77a8ff;box-shadow:0 0 0 3px #1769e02e}.login-form button{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:7px;height:44px;font-size:14px;font-weight:750}.login-form button:hover{background:var(--accent-dark)}.login-form button:disabled{cursor:wait;opacity:.72}.login-alert{color:#9b2c1f;background:#fff4f1;border:1px solid #f4c7bd;border-radius:8px;padding:11px 12px;font-size:13px}
