*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{min-height:100vh;display:flex}.sidebar{color:#e0e0e0;background:#1a1a2e;flex-direction:column;flex-shrink:0;align-self:flex-start;width:180px;min-height:100vh;padding:8px 0 24px;display:flex;position:sticky;top:0}.sidebar.collapsed{width:52px}.sidebar h2{border-bottom:1px solid #2d2d4a;margin-bottom:8px;padding:0 20px 20px;font-size:16px}.sidebar a{color:#a0a0c0;white-space:nowrap;text-overflow:ellipsis;padding:10px 20px;font-size:14px;text-decoration:none;transition:all .15s;display:block;overflow:hidden}.sidebar.collapsed a{text-align:center;letter-spacing:.05em;padding:10px 0;font-size:11px;font-weight:600}.sidebar a:hover,.sidebar a.active{color:#fff;background:#2d2d4a}.main-content{flex:1;padding:24px 16px 24px 24px;overflow-x:auto}.page-title{margin-bottom:24px;font-size:22px;font-weight:600}.card{background:#fff;border-radius:12px;margin-bottom:24px;padding:24px;box-shadow:0 1px 3px #00000014}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000014}.kpi-card .label{color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:12px}.kpi-card .value{font-size:24px;font-weight:700}.granularity-toggle{gap:8px;margin-bottom:20px;display:flex}.granularity-toggle button{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:6px;padding:6px 16px;font-size:13px}.granularity-toggle button.active{color:#fff;background:#1a1a2e;border-color:#1a1a2e}.heatmap-container{overflow-x:auto}.heatmap-table{border-collapse:collapse;white-space:nowrap;font-size:12px}.heatmap-table th,.heatmap-table td{text-align:right;border:1px solid #eee;padding:5px 2px;font-size:11px}.heatmap-table th{background:#f8f9fa;font-weight:600;position:sticky;top:0}.heatmap-table th:first-child,.heatmap-table td:first-child{text-align:left;z-index:1;background:#f8f9fa;font-weight:600;position:sticky;left:0}.upload-zone{text-align:center;cursor:pointer;border:2px dashed #ccc;border-radius:12px;padding:48px;transition:border-color .2s}.upload-zone:hover,.upload-zone.drag-over{border-color:#1a1a2e}.upload-zone input{display:none}.upload-table{border-collapse:collapse;width:100%;font-size:14px}.upload-table th,.upload-table td{text-align:left;border-bottom:1px solid #eee;padding:10px 12px}.upload-table th{color:#888;text-transform:uppercase;font-size:12px;font-weight:600}.upload-table.tight-cohort-table th,.upload-table.tight-cohort-table td{padding:4px}.upload-table.tight-cohort-table th{letter-spacing:-.02em;font-size:10px}.btn{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px}.btn-danger{color:#fff;background:#1a1a2e}.btn-danger:hover{background:#2d2d4e}.sim-grid{grid-template-columns:300px 1fr;gap:24px;display:grid}.sim-field{margin-bottom:16px}.sim-field label{color:#888;margin-bottom:4px;font-size:12px;display:block}.sim-field input{box-sizing:border-box;border:1px solid #ddd;border-radius:6px;width:100%;padding:8px 12px;font-size:14px}.loading{text-align:center;color:#888;padding:48px}[data-theme=dark] body{color:#e0e0e0;background:#0d0d1a}[data-theme=dark] .card,[data-theme=dark] .kpi-card{background:#1a1a2e;box-shadow:0 1px 3px #0006}[data-theme=dark] .kpi-card .label{color:#7a7a9a}[data-theme=dark] .heatmap-table th,[data-theme=dark] .heatmap-table td{border-color:#2d2d4a}[data-theme=dark] .heatmap-table th,[data-theme=dark] .heatmap-table th:first-child,[data-theme=dark] .heatmap-table td:first-child{color:#c0c0d8;background:#1a1a2e}[data-theme=dark] .granularity-toggle button{color:#c0c0d8;background:#1a1a2e;border-color:#3d3d6a}[data-theme=dark] .granularity-toggle button.active{color:#fff;background:#3d3d6a;border-color:#3d3d6a}[data-theme=dark] .upload-zone{color:#c0c0d8;border-color:#3d3d6a}[data-theme=dark] .upload-zone:hover,[data-theme=dark] .upload-zone.drag-over{border-color:#6060a0}[data-theme=dark] .upload-table th,[data-theme=dark] .upload-table td{border-color:#2d2d4a}[data-theme=dark] .upload-table th{color:#7a7a9a}[data-theme=dark] .sim-field input{color:#e0e0e0;background:#1a1a2e;border-color:#3d3d6a}[data-theme=dark] .page-title{color:#e0e0e0}.theme-toggle{color:#7a7a9a;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:8px 20px;font-size:12px;transition:color .15s;display:flex}.theme-toggle:hover{color:#fff}
