:root{--bg:#0b0e14;--panel:#151a23;--panel2:#1a212c;--ink:#e7ebf2;--muted:#8a93a6;--line:#252c39;--line2:#1f2632;--brand:#6366f1;--brand2:#818cf8;--green:#34d399;--greenbg:#0f2a20;--red:#f87171;--redbg:#2c1619;--chip:#1c232f;--tagink:#aeb6c4;--hover:#1b222d;--shadow:0 1px 2px rgba(0,0,0,.35),0 10px 28px rgba(0,0,0,.4);color-scheme:dark}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}.wrap{max-width:1280px;margin:0 auto;padding:22px 22px 70px}a{color:var(--brand);text-decoration:none}.row{display:flex;gap:14px}.muted{color:var(--muted)}.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.pos{color:var(--green)}.neg{color:var(--red)}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600}.pill.up{background:var(--greenbg);color:var(--green)}.pill.down{background:var(--redbg);color:var(--red)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--line);background:var(--panel);color:var(--ink);padding:8px 13px;border-radius:9px;font-weight:600;font-size:13px;cursor:pointer;transition:.15s}.btn:hover{border-color:#39424f;background:var(--hover)}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:#4f46e5}.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn.sm{padding:5px 9px;font-size:12px;border-radius:7px}.seg{display:inline-flex;background:var(--chip);border-radius:9px;padding:3px;gap:2px}.seg button{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:12.5px;padding:5px 11px;border-radius:7px;cursor:pointer}.seg button.on{background:var(--panel);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.3)}.top{justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}.brand,.top{display:flex;align-items:center}.brand{gap:11px}.logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;box-shadow:var(--shadow)}.brand h1{font-size:17px;margin:0;font-weight:750;letter-spacing:-.01em}.brand .sub{font-size:12px;color:var(--muted);margin-top:1px}.hdr-actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.hero{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;grid-gap:14px;gap:14px;margin-bottom:16px}.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}.kpi{padding:16px 18px}.kpi .lab{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.kpi .val{font-size:26px;font-weight:760;letter-spacing:-.02em;margin-top:7px}.kpi .val.big{font-size:30px}.kpi .sub{margin-top:8px;font-size:12.5px;color:var(--muted);gap:8px;align-items:center}.kpi .sub,.tabs{display:flex;flex-wrap:wrap}.tabs{gap:4px;margin:6px 0 16px;border-bottom:1px solid var(--line)}.tab{border:0;background:transparent;padding:10px 14px;font-weight:650;font-size:14px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab.on{color:var(--ink);border-bottom-color:var(--brand)}.view{display:none}.view.on{display:block}.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px}.panel-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.panel-h h3{margin:0;font-size:15px;font-weight:720}.grid2{grid-template-columns:1.55fr 1fr;grid-gap:14px}.grid2,.grid3{display:grid;gap:14px}.grid3{grid-template-columns:1fr 1fr 1fr;grid-gap:14px}.chartbox{position:relative;height:340px}.donutbox{position:relative;height:230px}.tbl-tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.inp{border:1px solid var(--line);background:var(--panel);border-radius:9px;padding:7px 11px;font-size:13px;color:var(--ink);outline:none}.inp:focus{border-color:var(--brand2)}select.inp{cursor:pointer}.tbl-scroll{overflow-x:auto;border-radius:12px;border:1px solid var(--line2)}table{border-collapse:collapse;width:100%;font-size:13px}td,th{padding:9px 11px;text-align:right;white-space:nowrap;border-bottom:1px solid var(--line2)}th{position:-webkit-sticky;position:sticky;top:0;background:var(--panel2);color:var(--muted);font-weight:650;font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:2}td.l,th.l{text-align:left}tbody tr:hover{background:var(--hover)}.sym{font-weight:720}.nm{color:var(--muted);font-size:12px;max-width:230px;overflow:hidden;text-overflow:ellipsis}.flag{font-size:13px;margin-right:5px}.tag{display:inline-block;padding:1px 7px;border-radius:6px;background:var(--chip);color:var(--tagink);font-size:11px;font-weight:600}.wbar{position:relative;height:6px;background:var(--line2);overflow:hidden;min-width:54px}.wbar,.wbar>i{border-radius:4px}.wbar>i{position:absolute;left:0;top:0;bottom:0;background:var(--brand2)}.rowbtn{opacity:0;transition:.12s}tr:hover .rowbtn{opacity:1}.heat{display:inline-flex;gap:3px}.heat span{display:inline-block;min-width:42px;text-align:center;padding:3px 2px;border-radius:5px;font-size:11.5px;font-weight:650}.scrim{position:fixed;inset:0;background:rgba(2,4,10,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;z-index:50;padding:18px}.scrim.on{display:flex}.modal{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 60px rgba(0,0,0,.55);width:min(560px,100%);max-height:90vh;overflow:auto}.modal-h{padding:17px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.modal-h h3{margin:0;font-size:16px}.modal-b{padding:18px 20px}.modal-f{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:10px}.fgrid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:2px}.field label{font-size:12px;font-weight:650;color:var(--muted)}.field .inp{width:100%}.full{grid-column:1/-1}.x{cursor:pointer;font-size:20px;line-height:1;border:0;background:none}.note,.x{color:var(--muted)}.note{font-size:12px}.statusdot{width:8px;height:8px;border-radius:50%;display:inline-block;background:#3a4250}.statusdot.live{background:var(--green)}.statusdot.stale{background:#f59e0b}.statusdot.err{background:var(--red)}.legend{display:flex;flex-direction:column;gap:8px;font-size:13px}.legend .li{justify-content:space-between;gap:10px}.legend .li,.legend .lk{display:flex;align-items:center}.legend .lk{gap:8px}.dot{width:10px;height:10px;border-radius:3px;flex:none}.empty{padding:34px;text-align:center;color:var(--muted)}@media(max-width:980px){.hero{grid-template-columns:1fr 1fr}.grid2,.grid3{grid-template-columns:1fr}}@media(max-width:620px){.hero{grid-template-columns:1fr}}.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);background:#020409;border:1px solid var(--line);color:#fff;padding:11px 18px;border-radius:11px;font-size:13px;font-weight:600;opacity:0;transition:.25s;z-index:80;box-shadow:var(--shadow)}.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}.loadwrap{display:grid;place-items:center;min-height:60vh;color:var(--muted)}.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--brand);animation:spin 1s linear infinite;margin-bottom:12px}@keyframes spin{to{transform:rotate(1turn)}}.loginwrap{min-height:100vh;display:grid;place-items:center;padding:20px}.logincard{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:30px 28px;width:min(360px,100%);display:flex;flex-direction:column;gap:12px;align-items:stretch;text-align:center}.logincard h1{font-size:18px;margin:6px 0 0}.logincard p{margin:0 0 6px}.loginlogo{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--brand),var(--brand2));display:grid;place-items:center;color:#fff;font-weight:800;font-size:22px;margin:0 auto}.logincard .inp{width:100%;padding:10px 12px}.logincard .btn{width:100%;padding:10px}.loginerr{color:var(--red);font-size:13px}