:root{--bg:#f5f6f8;--paper:#fff;--ink:#17202f;--muted:#6b7280;--line:#dfe3ea;--red:#d71920;--blue:#2563eb;--green:#059669;--amber:#d97706;--violet:#7c3aed;--cyan:#0891b2;--soft-red:#fff1f1;--soft-blue:#eff6ff;--soft-green:#ecfdf5;--soft-amber:#fffbeb;--soft-violet:#f5f3ff}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select{font:inherit}.app-shell{min-height:100vh}.sidebar{z-index:50;border-right:1px solid var(--line);visibility:hidden;background:#fff;flex-direction:column;gap:14px;width:min(252px,86vw);height:100vh;padding:14px;transition:transform .22s,visibility .22s;display:flex;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar.open{visibility:visible;transform:translate(0);box-shadow:0 24px 60px #0f172a2e}.scrim{z-index:40;opacity:0;visibility:hidden;background:#0f172a57;transition:opacity .22s,visibility .22s;position:fixed;inset:0}.app-shell.nav-open .scrim{opacity:1;visibility:visible}.nav-toggle{border:1px solid var(--line);background:var(--paper);color:#334155;cursor:pointer;border-radius:8px;flex:none;place-items:center;width:38px;height:38px;display:inline-grid}.nav-toggle:hover{background:#f8fafc;border-color:#cbd5e1}.side-close{border:1px solid var(--line);color:#475569;cursor:pointer;background:#fff;border-radius:8px;flex:none;place-items:center;width:30px;height:30px;margin-left:auto;display:grid}.side-close:hover{background:#f8fafc}.side-brand{border-bottom:1px solid #eef1f5;align-items:center;gap:10px;padding:4px 4px 10px;display:flex}.side-title{font-size:13px;font-weight:800;line-height:1.2}.side-sub{color:var(--muted);margin-top:2px;font-size:10px}.side-nav{gap:5px;display:grid}.side-link{color:#334155;text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:9px;width:100%;padding:10px 9px;font-size:13px;font-weight:800;text-decoration:none;display:flex}.side-link:hover{background:#f8fafc;border-color:#eef1f5}.side-link.active{color:var(--red);background:#fff1f1;border-color:#fecaca}.side-link small{color:var(--muted);margin-top:1px;font-size:10px;font-weight:600;display:block}.side-link.active small{color:#991b1b}.side-meta{color:var(--muted);border-top:1px solid #eef1f5;margin-top:auto;padding-top:10px;font-size:11px;line-height:1.45}.main{min-width:0}.wrap{max-width:none;margin:0 auto;padding:18px}.topbar{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px;display:flex}.brand{align-items:center;gap:11px;display:flex}.logo{background:var(--red);color:#fff;border-radius:8px;place-items:center;width:36px;height:36px;font-weight:800;display:grid}h1{margin:0;font-size:20px;line-height:1.2}.sub{color:var(--muted);margin-top:3px;font-size:12px}.actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.actions.start{justify-content:flex-start;margin-bottom:10px}.pill{border:1px solid var(--line);background:var(--paper);white-space:nowrap;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:700}.pill.live{color:var(--green);background:var(--soft-green);border-color:#bbf7d0}.btn{border:1px solid var(--line);background:var(--paper);color:var(--ink);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 11px;font-size:12px;font-weight:700;display:inline-flex}.btn.primary{background:var(--red);border-color:var(--red);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.live{background:var(--soft-green);color:var(--green);border-color:#bbf7d0}.tab{border:1px solid var(--line);background:var(--paper);color:var(--muted);cursor:pointer;border-radius:999px;padding:8px 13px;font-size:12px;font-weight:800}.tab.active{background:var(--ink);border-color:var(--ink);color:#fff}.route-title{align-items:center;gap:9px;margin-bottom:12px;display:flex}.route-title h2{margin:0;font-size:18px}.route-title span{color:var(--muted);font-size:12px}.api-note{color:var(--muted);text-align:right;width:100%;font-size:11px}.api-note.error{color:var(--red)}.auth-shell{background:var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-panel{background:var(--paper);border:1px solid var(--line);border-radius:8px;width:min(420px,100%);padding:22px;box-shadow:0 18px 50px #0f172a14}.auth-mark{background:var(--red);color:#fff;border-radius:8px;place-items:center;width:42px;height:42px;margin-bottom:14px;font-weight:800;display:grid}.auth-panel h1{margin:0;font-size:22px}.auth-panel p{color:var(--muted);margin:8px 0 16px;font-size:13px;line-height:1.5}.auth-form{gap:11px;display:grid}.auth-form label{color:var(--muted);font-size:12px;font-weight:800}.auth-form input{border:1px solid var(--line);width:100%;color:var(--ink);background:#fbfcfe;border-radius:8px;outline:none;margin-top:5px;padding:10px}.auth-form input:focus{background:#fff;border-color:#94a3b8}.auth-error{background:var(--soft-red);color:var(--red);border:1px solid #fecaca;border-radius:8px;padding:9px;font-size:12px;font-weight:700}.auth-hint{color:var(--muted);margin-top:12px;font-size:11px;line-height:1.5}.filters{background:var(--paper);border:1px solid var(--line);border-radius:8px;margin-bottom:14px;padding:12px}.filter-grid{grid-template-columns:1.2fr repeat(6,minmax(120px,1fr));gap:8px;display:grid}.control{min-width:0}.control label{color:var(--muted);text-transform:uppercase;margin:0 0 4px;font-size:10px;font-weight:800;display:block}.control input,.control select{border:1px solid var(--line);width:100%;color:var(--ink);background:#fbfcfe;border-radius:8px;outline:none;padding:8px;font-size:12px}.control input:focus,.control select:focus{background:#fff;border-color:#94a3b8}.grid{gap:12px;display:grid}.kpis{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:12px}.card{background:var(--paper);border:1px solid var(--line);border-radius:8px;min-width:0;padding:13px}.space{margin-bottom:12px}.kpi-label{text-transform:uppercase;color:var(--muted);letter-spacing:.02em;font-size:10px;font-weight:800}.kpi-value{margin-top:8px;font-size:25px;font-weight:800;line-height:1.1}.kpi-sub{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-top:5px;font-size:11px;overflow:hidden}.split{grid-template-columns:minmax(0,1.4fr) minmax(0,.9fr)}.three{grid-template-columns:repeat(3,minmax(0,1fr))}.section-title{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.section-title h2{margin:0;font-size:14px}.section-title span{color:var(--muted);font-size:11px}.chart{min-width:0;height:300px}.chart.small{height:250px}.chart.tall{height:340px}.filter-pills{flex-wrap:wrap;align-items:center;gap:8px;min-height:30px;display:flex}.pill.filter{cursor:pointer;color:var(--blue);background:var(--soft-blue);border-color:#bfdbfe;align-items:center;gap:6px;display:inline-flex}.pill.filter:hover{background:#dbeafe}.pill.ghost{cursor:pointer;color:#475569;background:0 0;border-style:dashed}.pill.ghost:hover{color:var(--ink)}.seg{flex-wrap:wrap;gap:6px;display:flex}.seg .tab{padding:5px 11px;font-size:11px}.quality{gap:8px;display:grid}.quality-row{border-bottom:1px solid #eef1f5;justify-content:space-between;align-items:center;gap:12px;padding-bottom:8px;display:flex}.quality-row:last-child{border-bottom:0;padding-bottom:0}.quality-row b{font-size:14px}.quality-row span{color:var(--muted);font-size:12px}.bar{background:#edf0f5;border-radius:999px;height:8px;overflow:hidden}.bar i{border-radius:999px;height:100%;display:block}.stage-list{gap:8px;display:grid}.stage-button{border:1px solid var(--line);cursor:pointer;text-align:left;background:#fff;border-radius:8px;gap:7px;padding:9px;display:grid}.stage-button.active{background:#fff7f7;border-color:#fecaca}.stage-top{justify-content:space-between;align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.mini-bars{gap:7px;display:grid}.mini-bar{color:var(--muted);grid-template-columns:110px minmax(0,1fr) 56px;align-items:center;gap:8px;font-size:11px;display:grid}.mini-track{background:#edf0f5;border-radius:999px;height:8px;overflow:hidden}.mini-fill{background:var(--blue);border-radius:999px;height:100%}.click-row{cursor:pointer}.click-row.active{background:#fff7f7}table{border-collapse:separate;border-spacing:0;width:100%;font-size:12px}thead th{color:var(--muted);text-align:left;text-transform:uppercase;border-bottom:1px solid var(--line);z-index:1;background:#f8fafc;padding:9px;font-size:10px;position:sticky;top:0}tbody td{vertical-align:top;border-bottom:1px solid #eef1f5;padding:9px}tbody tr:hover{background:#fafafa}.right{text-align:right}.tnum{font-variant-numeric:tabular-nums}.tag{white-space:nowrap;border:0;border-radius:999px;align-items:center;padding:3px 7px;font-size:11px;font-weight:800;display:inline-flex}.tag.red{color:var(--red);background:var(--soft-red)}.tag.green{color:var(--green);background:var(--soft-green)}.tag.blue{color:var(--blue);background:var(--soft-blue)}.tag.amber{color:var(--amber);background:var(--soft-amber)}.tag.violet{color:var(--violet);background:var(--soft-violet)}.tag.gray{color:#475569;background:#f1f5f9}.scroll{border:1px solid var(--line);border-radius:8px;max-height:480px;overflow:auto}.scroll.tall{max-height:560px}.need{color:#334155;max-width:430px;line-height:1.35}.muted{color:var(--muted)}.empty{text-align:center;color:var(--muted);padding:40px;font-size:13px}.footer{color:var(--muted);padding:18px 0 4px;font-size:11px;line-height:1.6}.gap4{height:4px}@media (width<=1180px){.filter-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.split,.three{grid-template-columns:minmax(0,1fr)}.scroll{-webkit-overflow-scrolling:touch;overflow:auto}.scroll table{min-width:680px}}@media (width<=720px){.wrap{padding:12px}.topbar{display:block}.actions{justify-content:flex-start;margin-top:12px}.filter-grid{grid-template-columns:1fr 1fr}.kpi-value{font-size:22px}.kpi-sub{white-space:normal}.chart{height:260px}.chart.tall{height:300px}.section-title{flex-wrap:wrap}}@media (width<=460px){.kpis{grid-template-columns:1fr 1fr}.chart{height:240px}}
