:root{--bg:#121212;--bg2:#161616;--card:#1e1e1e;--card2:#262626;--bd:#323232;--fg:#e8eaed;--mut:#9aa0a6;--acc:#8ab4f8;--grn:#81c784;--red:#f28b82;--amber:#fdd663;--glass:rgba(30,30,30,.82);--shadow:0 1px 3px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.35);--grid:#2a2a2a;--hm0:#262d36;--hm1:#0e4429;--hm2:#006d32;--hm3:#26a641;--hm4:#39d353}
@media (prefers-color-scheme:light){:root{--bg:#f1f3f4;--bg2:#e8eaed;--card:#ffffff;--card2:#f7f8fa;--bd:#e1e3e6;--fg:#202124;--mut:#5f6368;--acc:#1a73e8;--grn:#188038;--red:#d93025;--amber:#f29900;--glass:rgba(255,255,255,.86);--shadow:0 1px 2px rgba(60,64,67,.12),0 1px 3px rgba(60,64,67,.18);--grid:#eaecef;--hm0:#ebedf0;--hm1:#9be9a8;--hm2:#40c463;--hm3:#30a14e;--hm4:#216e39}}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);font:14px/1.45 "Roboto",ui-sans-serif,system-ui,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}
.ms{font-family:'Material Symbols Rounded';font-weight:400;font-style:normal;line-height:1;letter-spacing:normal;text-transform:none;white-space:nowrap;font-feature-settings:'liga';-webkit-font-smoothing:antialiased;font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24}
.tr{font-size:.82em;vertical-align:-.13em;margin-left:2px;font-variation-settings:'FILL' 0,'wght' 700,'GRAD' 0,'opsz' 20}

.top{position:sticky;top:0;z-index:10}
.bar{display:flex;align-items:center;gap:12px;row-gap:8px;flex-wrap:wrap;padding:11px 18px;background:var(--glass);backdrop-filter:blur(12px);border-bottom:1px solid var(--bd)}
.tabs{display:flex;gap:4px;padding:7px 12px;background:var(--glass);backdrop-filter:blur(12px);border-bottom:1px solid var(--bd);overflow-x:auto}
.tab{flex:none;display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:10px;color:var(--mut);cursor:pointer;font-size:13.5px;font-weight:500;white-space:nowrap;transition:.12s}
.tab .ms{font-size:18px}
.tab:hover{color:var(--fg);background:var(--card)}
.tab.on{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}
.bar .logo{line-height:0;display:inline-flex;cursor:default}
.logo-box{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:grid;place-items:center;box-shadow:0 2px 8px rgba(99,102,241,.35)}
.logo-dna{font-size:20px;color:#fff;animation:dna 3.6s ease-in-out infinite}
.bar .logo:hover .logo-box{box-shadow:0 0 10px color-mix(in srgb,var(--acc) 70%,transparent)}
@keyframes dna{0%,100%{transform:rotate(-7deg) scale(1)}50%{transform:rotate(7deg) scale(1.07)}}
.bar h1{font-size:16px;margin:0;font-weight:600;letter-spacing:.3px}
.badges{display:inline-flex;gap:6px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:500;padding:4px 10px;border-radius:999px;border:1px solid var(--bd);background:var(--card);color:var(--mut)}
.badge .d{width:7px;height:7px;border-radius:50%;background:var(--mut)}
.badge .bi{font-size:15px}
.badge.ok{color:var(--grn);border-color:color-mix(in srgb,var(--grn) 38%,var(--bd))}
.badge.ok .d{background:var(--grn);box-shadow:0 0 7px var(--grn)}
.badge.bad{color:var(--red);border-color:color-mix(in srgb,var(--red) 45%,var(--bd))}
.badge.bad .d{background:var(--red);box-shadow:0 0 7px var(--red)}
.spacer{margin-left:auto}
.iconbtn{width:36px;height:36px;border-radius:10px;border:1px solid var(--bd);background:var(--card);color:var(--fg);cursor:pointer;font-size:20px;display:grid;place-items:center;text-decoration:none}
.iconbtn:hover{border-color:var(--acc)}
.ranges{display:inline-flex;border:1px solid var(--bd);border-radius:10px;overflow:hidden;background:var(--card2)}
.ranges button{background:transparent;color:var(--mut);border:0;border-left:1px solid var(--bd);padding:6px 13px;cursor:pointer;font-size:13px;font-weight:500;transition:background .12s,color .12s}
.ranges button:first-child{border-left:0}
.ranges button:hover:not(.on){background:color-mix(in srgb,var(--fg) 10%,transparent);color:var(--fg)}
.ranges button.on{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}
.sec{margin:26px 18px 8px;display:flex;align-items:center;gap:11px;font-size:15px;font-weight:700;letter-spacing:.3px;color:var(--fg)}
.sec .ms{font-size:21px;width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:color-mix(in srgb,var(--sc,var(--acc)) 20%,transparent);color:var(--sc,var(--acc))}
.sec:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,color-mix(in srgb,var(--sc,var(--acc)) 45%,var(--bd)),transparent)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;padding:10px 18px 4px}
.grp{margin:18px 18px 3px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--mut)}
.grp .ms{font-size:18px}
.grp::after{content:"";flex:1;height:1px;background:var(--bd);margin-left:4px}
.card{display:flex;gap:11px;align-items:flex-start;background:var(--card);border:1px solid var(--bd);border-radius:16px;padding:14px}
.cic{flex:none;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:23px;background:color-mix(in srgb,var(--ac) 18%,transparent);color:var(--ac)}
.cbody{min-width:0;flex:1}
.cbody .k{color:var(--mut);font-size:12.5px;margin-bottom:2px;font-weight:500}
.cbody .v{font-size:21px;font-weight:700;letter-spacing:.1px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cbody .s{color:var(--mut);font-size:13px;margin-top:3px}
.cbody .v .u{color:var(--mut);font-weight:500;font-size:.82em}
#app{padding-top:8px;flex:1 0 auto}
.charts{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px;padding:8px 18px 6px;align-items:start}
.split{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:14px;padding:8px 18px 6px;align-items:start}
.split>.chart{display:flex;flex-direction:column}
.split .tbl{padding:0}
.split .ax{font-size:8.5px}
.alcard{margin:8px 18px 10px}
.alog{padding:2px 0}
.arow{display:flex;align-items:center;gap:10px;padding:8px 2px;border-bottom:1px solid var(--bd);font-size:13.5px}
.arow:last-child{border-bottom:0}
.arow .ms{font-size:19px;flex:none}
.arow .atitle{font-weight:500}
.arow .at{margin-left:auto;color:var(--mut);font-size:12.5px;white-space:nowrap}
.aok{display:flex;align-items:center;gap:9px;padding:14px 2px;color:var(--mut);font-size:13.5px}
.aok .ms{font-size:20px;flex:none}
.hm{margin:12px 18px 6px}
.hm svg{width:100%;height:auto}
.hmnav{display:flex;align-items:center;gap:8px}
.hmar{background:var(--card2);border:1px solid var(--bd);color:var(--fg);border-radius:7px;min-width:24px;height:22px;cursor:pointer;font-size:15px;line-height:1;padding:0 2px}
.hmar:disabled{opacity:.4;cursor:default}
.chart{background:var(--card);border:1px solid var(--bd);border-radius:16px;padding:12px 14px}
.chart .ct{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.chart .ct .t{font-size:13.5px;color:var(--mut)}
.chart .ct .cur{font-size:15px;font-weight:700}
svg{width:100%;height:auto;display:block}
.ax{fill:var(--mut);font-size:13px}
.gl{stroke:var(--grid);stroke-width:1}
.cl{stroke:var(--acc);stroke-width:1;opacity:.55}
.tipbg{fill:var(--card2);stroke:var(--bd)}
.tiptx{font-size:13px}
.lc .ax{font-size:15px}
.lc .tiptx{font-size:17px}
.hmsvg .ax{font-size:8.5px}
.legend{display:flex;gap:14px;font-size:12.5px;color:var(--mut);margin-top:3px;flex-wrap:wrap}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}
.tbl{padding:8px 18px 6px;overflow-x:auto}
.tbl table{width:100%;border-collapse:separate;border-spacing:0;background:var(--card);border:1px solid var(--bd);border-radius:16px;overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:10px 14px;font-size:14px;border-bottom:1px solid var(--bd)}
.tbl th{color:var(--mut);font-weight:600;font-size:13px}
.tbl tr:last-child td{border-bottom:0}
.tbl td.r{text-align:right;color:var(--grn);font-weight:600}
.tbl td.addr{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em;color:var(--mut);white-space:nowrap}
.pager{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:9px 4px 0;color:var(--mut);font-size:13px}
.pager button{background:var(--card2);border:1px solid var(--bd);color:var(--fg);border-radius:8px;padding:5px 12px;cursor:pointer;font-size:13px}
.pager button:disabled{opacity:.4;cursor:default}
footer{color:var(--mut);font-size:12.5px;padding:6px 18px 26px;text-align:center}
.anim .card,.anim .chart{animation:rise .35s ease both}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes grow{from{transform:scaleY(.001)}to{transform:scaleY(1)}}
.toast{position:fixed;left:50%;top:18px;transform:translateX(-50%);z-index:50;background:var(--card2);border:1px solid var(--bd);border-radius:12px;padding:11px 16px;font-size:14px;display:flex;align-items:center;gap:6px;box-shadow:0 10px 28px rgba(0,0,0,.32);animation:tin .3s ease both}
.toast.out{animation:tout .5s ease forwards}
@keyframes tin{from{opacity:0;transform:translate(-50%,-14px)}to{opacity:1;transform:translate(-50%,0)}}
@keyframes tout{to{opacity:0;transform:translate(-50%,-14px)}}
.confetti{position:fixed;top:-12px;width:9px;height:9px;border-radius:2px;z-index:49;pointer-events:none;animation:fall 2.6s linear forwards}
@keyframes fall{to{transform:translateY(106vh) rotate(620deg);opacity:.15}}
.upd{display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;padding:5px 11px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;animation:updpulse 2s ease-in-out infinite}
.upd .ms{font-size:17px}
.upd:disabled{opacity:.7;cursor:default;animation:none}
@keyframes updpulse{0%,100%{box-shadow:0 0 0 0 rgba(139,92,246,.5)}50%{box-shadow:0 0 0 6px rgba(139,92,246,0)}}
.pop{position:fixed;z-index:60;background:var(--card2);border:1px solid var(--bd);border-radius:12px;padding:14px 16px;box-shadow:0 12px 32px rgba(0,0,0,.35);font-size:13.5px;line-height:1.45;max-width:290px}
.pop b{color:var(--fg)}
.pop .row{display:flex;gap:8px;margin-top:13px;justify-content:flex-end}
.pop button{border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;border:1px solid var(--bd);background:var(--card);color:var(--fg)}
.pop button.go{background:#6366f1;color:#fff;border-color:#6366f1}
.anim .bar{transform-box:fill-box;transform-origin:bottom;animation:grow .55s cubic-bezier(.2,.85,.25,1) both}

body.login{min-height:100vh;display:grid;place-items:center;overflow:hidden;position:relative}
body.login:before{content:"";position:fixed;inset:-30%;z-index:0;background:
  radial-gradient(40% 40% at 20% 25%,rgba(138,180,248,.30),transparent 60%),
  radial-gradient(38% 38% at 82% 30%,rgba(129,199,132,.22),transparent 60%),
  radial-gradient(45% 45% at 55% 90%,rgba(242,139,130,.18),transparent 60%);
  filter:blur(30px);animation:float 18s ease-in-out infinite alternate}
@keyframes float{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-3%,2%) scale(1.08)}}
.loginwrap{position:relative;z-index:1;width:340px;max-width:92vw;text-align:center}
.logincard{background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--bd);border-radius:20px;padding:30px 26px 26px;box-shadow:var(--shadow)}
.brand .mark{display:inline-block;line-height:0;filter:drop-shadow(0 6px 14px rgba(0,0,0,.28));animation:bob 4s ease-in-out infinite}
.brand .logo-box-lg{width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:grid;place-items:center;box-shadow:0 8px 22px rgba(99,102,241,.4)}
.brand .logo-dna-lg{font-size:38px;color:#fff;animation:dna 3.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes dna{0%,100%{transform:rotate(-7deg) scale(1)}50%{transform:rotate(7deg) scale(1.07)}}
.brand h1{margin:8px 0 2px;font-size:22px;letter-spacing:.5px}
.brand p{margin:0 0 18px;color:var(--mut);font-size:13px}
.logincard form{display:flex;flex-direction:column;gap:12px;text-align:left}
.logincard label{font-size:12px;color:var(--mut);display:flex;flex-direction:column;gap:5px}
.logincard input{background:var(--card2);border:1px solid var(--bd);border-radius:11px;padding:11px 13px;color:var(--fg);font-size:15px;outline:none;transition:border-color .15s,box-shadow .15s}
.logincard input:focus{border-color:var(--acc);box-shadow:0 0 0 3px color-mix(in srgb,var(--acc) 22%,transparent)}
.logincard button{margin-top:6px;background:linear-gradient(135deg,#5b8cff,#3b6fe0);color:#fff;border:0;border-radius:11px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .08s,filter .15s}
.logincard button:hover{filter:brightness(1.05)}
.logincard button:active{transform:translateY(1px)}
.err{background:color-mix(in srgb,var(--red) 16%,transparent);border:1px solid var(--red);color:var(--red);border-radius:10px;padding:9px 11px;font-size:13px;margin-bottom:6px}
.foot{margin-top:14px;color:var(--mut);font-size:12px}
