:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;background:#eef2f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:#fff;border:1px solid #d9e0ea;border-radius:8px;gap:16px;width:min(420px,100%);padding:28px;display:grid;box-shadow:0 16px 40px #18274b14}.login-card h1,.page-header h1{margin:0;font-size:24px}.brand{letter-spacing:0;font-weight:800}.input{color:#172033;background:#fff;border:1px solid #cfd8e5;border-radius:6px;width:100%;min-height:40px;padding:0 12px}label{color:#56657a;gap:6px;font-size:14px;display:grid}.button-primary,.button-secondary{cursor:pointer;border:1px solid #0000;border-radius:6px;min-height:40px;padding:0 14px}.button-primary{color:#fff;background:#1d63ed}.button-primary:disabled{cursor:default;opacity:.5}.button-secondary{color:#172033;background:#fff;border-color:#cfd8e5}.notice{color:#174c91;background:#eef6ff;border-radius:6px;padding:10px 12px}.error{color:#9a1d1d;background:#fff0f0;border-radius:6px;padding:10px 12px}.shell{grid-template-columns:248px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:#fff;border-right:1px solid #d9e0ea;flex-direction:column;gap:18px;height:100vh;padding:24px 18px;display:flex;position:sticky;top:0}.sidebar-email{color:#6b778a;text-overflow:ellipsis;font-size:13px;overflow:hidden}.nav{gap:6px;display:grid}.nav button{text-align:left;color:#3c485c;cursor:pointer;background:0 0;border:0;border-radius:6px;min-height:38px;padding:0 12px}.nav button.active{color:#0c45b4;background:#e9f0ff}.signout{margin-top:auto}.content{min-width:0;padding:28px}.content>section{max-width:1180px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.page-header p{color:#6b778a;margin:6px 0 0}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.panel,.table,.empty{background:#fff;border:1px solid #d9e0ea;border-radius:8px}.metric{min-height:112px;padding:18px}.metric-label{color:#6b778a;font-size:13px}.metric-value{margin-top:8px;font-size:28px;font-weight:800}.charts-grid{gap:16px;display:grid}.chart-panel{gap:16px;padding:18px;display:grid}.chart-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.chart-header h2{margin:0;font-size:16px}.chart-legend{color:#56657a;flex-wrap:wrap;justify-content:flex-end;gap:10px;font-size:12px;display:flex}.chart-legend span{align-items:center;gap:5px;display:inline-flex}.legend-dot{border-radius:999px;width:8px;height:8px}.bar-chart{grid-auto-columns:minmax(16px,1fr);grid-auto-flow:column;align-items:end;gap:6px;min-height:260px;padding:8px 0 0;display:grid;overflow-x:auto}.bar-day{align-items:end;gap:8px;min-width:16px;display:grid}.bar-stack{border-bottom:1px solid #edf1f6;justify-content:center;align-items:end;gap:2px;height:220px;display:flex}.bar-segment{border-radius:3px 3px 0 0;width:8px;min-height:0;display:block}.bar-label{color:#6b778a;text-align:center;writing-mode:vertical-rl;font-size:10px}.blue{background:#1d63ed}.green{background:#16a34a}.amber{background:#d97706}.toolbar{flex-wrap:wrap;gap:10px;margin-bottom:12px;display:flex}.toolbar .input{max-width:360px}.select{max-width:180px}.table{border-collapse:separate;border-spacing:0;width:100%;overflow:hidden}.table th,.table td{text-align:left;vertical-align:top;border-bottom:1px solid #edf1f6;padding:11px 12px;font-size:14px}.table th{color:#6b778a;background:#f8fafc;font-weight:700}.table tr:last-child td{border-bottom:0}.badge{color:#56657a;white-space:nowrap;background:#eef2f7;border-radius:999px;align-items:center;min-height:22px;margin-right:6px;padding:0 8px;font-size:12px;display:inline-flex}.badge.green{color:#12633d;background:#e8f7ef}.badge.red{color:#8a1f1f;background:#ffecec}.badge.blue{color:#174c91;background:#e9f0ff}.empty{color:#6b778a;padding:28px}@media (width<=760px){.shell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.content{padding:18px}.page-header{display:grid}.metric-grid{grid-template-columns:1fr}.chart-header{flex-direction:column}.chart-legend{justify-content:flex-start}}
