:root{color:#111827;background:#fff;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;min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased}button,input{font:inherit}button{cursor:pointer}.app{min-height:100vh;background:#fff;color:#111827}.app.dark{background:#101419;color:#e5e7eb}.auth-page{display:grid;min-height:100vh;place-items:center;padding:24px;background:#fff;color:#111827}.auth-panel{display:grid;gap:14px;width:min(360px,100%);padding:22px;border:1px solid #d8dde7;border-radius:4px;background:#fff}.auth-panel svg{color:#1768d8}.auth-panel .primary-button{width:100%}.auth-panel p{margin:0;color:#be123c;font-weight:700}.topbar{display:flex;gap:14px;align-items:end;min-height:76px;padding:10px 18px 14px;border-bottom:1px solid #d8dde7;background:#fff}.dark .topbar{border-color:#2b3542;background:#111820}.field{display:grid;gap:8px;font-weight:700;color:#111827}.sku-field{width:min(420px,32vw);min-width:300px}.dark .field,.dark .grade-control>span,.dark .selected-total span{color:#d7dce5}.field input,.search-box{height:40px;border:1px solid #c9d1df;border-radius:4px;background:#fff}.field input{width:100%;padding:0 13px}.dark .field input,.dark .search-box,.dark .grade-control button,.dark .theme-switch{border-color:#2f3c4b;background:#151d26;color:#e5e7eb}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;border:1px solid #0b64d8;border-radius:4px;background:#1768d8;color:#fff;font-weight:700}.primary-button:disabled{opacity:.72}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-box{display:flex;align-items:center;padding-right:10px}.search-box input{border:0;outline:0;background:transparent;color:inherit}.search-box input::placeholder{color:#737373}.dark .search-box input::placeholder{color:#8d96a3}.grade-control{display:grid;grid-auto-flow:column;grid-template-columns:auto repeat(3,112px);gap:0;align-items:end;margin-left:8px;white-space:nowrap}.grade-control>span,.selected-total span{align-self:center;margin-right:10px;font-weight:700}.grade-control button{height:40px;padding:0 10px;border:1px solid #cbd4e1;background:#fff}.grade-control button:first-of-type{border-radius:4px 0 0 4px}.grade-control button:last-of-type{border-radius:0 4px 4px 0}.grade-control button.active{border-color:#1768d8;background:#1768d8;color:#fff}.selected-total{display:grid;gap:6px;margin-left:auto;min-width:118px}.selected-total strong{font-size:18px}.top-actions{display:flex;align-items:end;gap:8px}.top-actions>span{align-self:center;color:#64748b;font-size:12px;font-weight:700;white-space:nowrap}.icon-action{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 12px;border:1px solid #cbd4e1;border-radius:4px;background:#fff;color:#111827;font-weight:700;white-space:nowrap}.icon-action.danger{color:#b91c1c}.dark .top-actions>span{color:#94a3b8}.dark .icon-action{border-color:#2f3c4b;background:#151d26;color:#e5e7eb}.dark .icon-action.danger{color:#fca5a5}.theme-switch{display:grid;grid-template-columns:34px 40px 34px;align-items:center;justify-items:center;height:40px;border:1px solid #cbd4e1;border-radius:4px;background:#fff}.switch-track{width:34px;height:18px;padding:2px;border-radius:999px;background:#d9dee7}.switch-thumb{display:block;width:14px;height:14px;border-radius:999px;background:#fff;box-shadow:0 1px 3px #0f172a40;transition:transform .16s ease}.dark .switch-thumb{transform:translate(16px)}.error-banner{padding:10px 20px;border-bottom:1px solid #fecaca;background:#fff1f2;color:#be123c;font-weight:700}.workspace{display:grid;min-height:640px;border-bottom:1px solid #d8dde7;overflow:hidden}.team-panel{display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) 58px;background:#fff;min-width:430px}.resize-handle{width:8px;height:100%;border:0;border-left:1px solid #d8dde7;border-right:1px solid #d8dde7;background:#f5f7fb;cursor:col-resize}.resize-handle:hover,.is-resizing .resize-handle{background:#dbeafe}.dark .resize-handle{border-color:#2b3542;background:#151d26}.dark .resize-handle:hover,.dark.is-resizing .resize-handle,.is-resizing .dark .resize-handle{background:#1d3557}.dark .workspace,.dark .team-panel,.dark .selected-table{border-color:#2b3542;background:#101419}.team-panel-title{display:flex;align-items:center;justify-content:space-between;height:46px;padding:0 16px;font-size:16px}.team-panel-title span{color:#0866dc;font-weight:700}.team-search{display:grid;gap:6px;padding:0 14px 8px;color:#111827;font-weight:700}.team-search span{font-size:12px}.team-search .search-box{height:34px}.team-search .search-box input{width:100%;height:100%;padding:0 10px}.dark .team-search{color:#d7dce5}.team-sort{display:grid;grid-template-columns:minmax(0,1fr) 86px;gap:8px;padding:0 14px 10px;color:#111827}.team-sort label{display:grid;gap:6px;font-weight:700}.team-sort span{font-size:12px}.team-sort select,.team-sort button{height:32px;border:1px solid #c9d1df;border-radius:4px;background:#fff;color:#111827}.team-sort select{min-width:0;padding:0 9px}.team-sort button{align-self:end;display:inline-flex;align-items:center;justify-content:center;gap:5px;font-weight:700}.dark .team-sort{color:#d7dce5}.dark .team-sort select,.dark .team-sort button{border-color:#2f3c4b;background:#151d26;color:#e5e7eb}.team-table-head,.team-row{display:grid;grid-template-columns:34px 104px minmax(0,1fr) 58px;align-items:center}.team-table-head{height:34px;margin:0 14px;border-top:1px solid #e0e5ed;border-bottom:1px solid #e0e5ed;color:#111827;font-size:12px;font-weight:800}.dark .team-table-head{border-color:#2b3542;color:#e5e7eb}.team-list{overflow:auto;padding:0 14px}.team-row{width:100%;height:42px;border:0;border-bottom:1px solid #e2e7ef;background:transparent;color:inherit;text-align:left}.dark .team-row{border-color:#26313d}.team-row.active{background:#f3f7ff}.dark .team-row.active{background:#182536}input[type=checkbox]{width:15px;height:15px;accent-color:#1768d8}.team-number{font-weight:700}.team-name{overflow:hidden;color:#1f2937;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.dark .team-name{color:#cfd6e0}.grade{justify-self:start;min-width:32px;padding:3px 7px;border-radius:4px;text-align:center;font-size:12px;font-weight:800}.grade.ms{background:#c8f3ca;color:#11612f}.grade.hs{background:#dbeafe;color:#1459b8}.pagination{display:flex;gap:12px;align-items:center;justify-content:center;border-top:1px solid #e0e5ed}.dark .pagination{border-color:#2b3542}.pagination button{display:grid;place-items:center;width:30px;height:30px;border:1px solid #d4dbe6;border-radius:4px;background:#fff}.pagination .page{border-color:transparent}.pagination .active{border-color:#1768d8;background:#1768d8;color:#fff}.hidden-search{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.main-grid{display:grid;grid-template-rows:455px minmax(0,1fr);gap:8px;padding:10px 14px 16px;min-width:0;overflow:hidden}.chart-panel,.metric-panel{border:1px solid #d8dde7;border-radius:3px;background:#fff}.dark .chart-panel,.dark .metric-panel,.dark .summary-table{border-color:#2b3542;background:#111820}.chart-panel{position:relative;min-height:0;overflow:hidden;padding:10px 14px 0}.chart-title{height:28px;text-align:center;font-size:17px;font-weight:800;line-height:28px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-chart-svg{display:block;width:100%;height:calc(100% - 28px);overflow:visible}.chart-grid-line{stroke:#d9dee8;stroke-width:1;stroke-dasharray:5 5}.chart-axis-line{stroke:#6b7280;stroke-width:1.15}.chart-tick{fill:#666;font-size:17px;font-weight:400}.chart-axis-title{fill:#111827;font-size:18px;font-weight:700}.chart-point{stroke:#fff;stroke-width:2}.chart-label-line{stroke-width:1.6;stroke-linecap:round;opacity:.8}.chart-point-label{font-size:15px;font-weight:400;letter-spacing:0;paint-order:stroke;stroke:#fff;stroke-width:3.5px;stroke-linejoin:round}.dark .chart-grid-line{stroke:#2d3947}.dark .chart-axis-line{stroke:#9ca3af}.dark .chart-tick{fill:#cbd5e1}.dark .chart-axis-title{fill:#e5e7eb}.dark .chart-point,.dark .chart-point-label{stroke:#111820}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;min-height:0}.metric-panel{min-width:0;overflow:hidden}.metric-heading{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;height:36px;padding:0 12px;border-bottom:1px solid #e0e5ed}.dark .metric-heading{border-color:#2b3542}.metric-heading strong{font-size:15px}.metric-heading span{color:#6b7280;font-size:12px}.metric-heading button{border:0;background:transparent;color:#075dcc;font-weight:700;text-decoration:underline}.metric-table{max-height:354px;overflow-y:auto;overflow-x:hidden}.metric-row{display:grid;grid-template-columns:26px minmax(112px,1fr) 80px 98px 76px;align-items:center;min-height:25px;padding:0 10px;border-bottom:1px solid #e8ecf2;column-gap:6px;font-size:12px}.metric-row>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark .metric-row{border-color:#26313d}.metric-header{min-height:32px;background:#fbfcfe;font-weight:800}.dark .metric-header{background:#141d27}.scope-pill{display:inline-flex;align-items:center;justify-content:space-between;height:20px;max-width:86px;padding:0 8px;border:1px solid #d7dee8;border-radius:3px;background:#fff}.dark .scope-pill{border-color:#354253;background:#121922}.available{color:#0f9f4a;font-weight:800}.partial{color:#b45309;font-weight:800}.selected-count{margin:6px 12px 8px;color:#6b7280;font-size:12px}.selected-table{padding:12px 18px 20px;background:#fff}.selected-table h2{margin:0 0 12px;font-size:17px}.summary-table{border:1px solid #d8dde7}.summary-row{display:grid;grid-template-columns:48px 160px minmax(200px,1fr) 220px 210px 230px 250px;width:100%;min-height:31px;padding:0;border:0;border-bottom:1px solid #e2e7ef;background:transparent;color:inherit;text-align:left}.summary-row span{display:flex;align-items:center;min-width:0;padding:0 12px;border-right:1px solid #e2e7ef}.summary-row span:last-child{border-right:0}.summary-head{min-height:34px;background:#fbfcfe;font-weight:800}.dark .summary-row,.dark .summary-row span{border-color:#26313d}.dark .summary-head{background:#141d27}.color-cell{gap:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.color-cell i{width:12px;height:12px;border-radius:999px}.selected-table p{margin:14px 0 0;color:#6b7280}.empty-state{padding:18px 6px;color:#6b7280}@media(max-width:1100px){.topbar{grid-template-columns:1fr 120px;align-items:end}.workspace{grid-template-columns:1fr}.team-panel{min-height:360px;border-right:0;border-bottom:1px solid #d8dde7}.main-grid{grid-template-rows:420px auto}.metric-grid{grid-template-columns:1fr}.summary-table{overflow:auto}.summary-row{min-width:1160px}}
