*,*:before,*:after{box-sizing:border-box}html{color-scheme:dark}body{margin:0;min-width:320px;min-height:100dvh;background:#06060c;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100dvh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#ffffff24}:root{--bg: #06060c;--bg2: #0c0c16;--card: #10111a;--card-hover: #161825;--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--ink: #e8eaed;--muted: #8b8fa3;--muted2: #565a6e;--green: #00ff88;--green-dim: rgba(0, 255, 136, .12);--red: #ff4466;--red-dim: rgba(255, 68, 102, .12);--cyan: #00d4ff;--cyan-dim: rgba(0, 212, 255, .1);--amber: #ffaa00;--mono: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--sans: "DM Sans", "General Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}.dashboard{min-height:100dvh;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);font-family:var(--sans)}.refreshBar{position:fixed;top:0;left:0;right:0;height:2px;z-index:100;background:var(--border)}.refreshBarFill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--green));transition:width 80ms linear;border-radius:0 1px 1px 0;box-shadow:0 0 8px #00d4ff66}.header{position:sticky;top:0;z-index:50;border-bottom:1px solid var(--border);background:#06060cd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.headerInner{max-width:1320px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.headerLeft{display:flex;align-items:center;gap:16px}.logo{font-weight:750;font-size:1.1rem;letter-spacing:-.03em;color:var(--ink)}.logoMark{color:var(--cyan);font-size:1.2em}.subtitle{color:var(--muted);font-size:.82rem;font-weight:500;padding-left:16px;border-left:1px solid var(--border)}.headerRight{display:flex;align-items:center;gap:18px}.connStatus{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;font-weight:600}.connStatus.ok{color:var(--green)}.connStatus.err{color:var(--red)}.connDot{width:7px;height:7px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.connStatus.ok .connDot{background:var(--green);box-shadow:0 0 8px #00ff8880}.connStatus.err .connDot{background:var(--red);box-shadow:0 0 8px #ff446680}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.lastUpdate{color:var(--muted2);font-size:.8rem;font-family:var(--mono);font-variant-numeric:tabular-nums}.main{max-width:1320px;margin:0 auto;padding:20px 24px 48px;width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:16px}.metricsRow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.metricCard{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 20px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s ease,box-shadow .2s ease}.metricCard:hover{border-color:var(--border-hover);box-shadow:0 4px 24px #0000004d}.metricCard.positive{border-left:3px solid var(--green)}.metricCard.negative{border-left:3px solid var(--red)}.metricCard.neutral{border-left:3px solid var(--cyan)}.metricLabel{font-size:.72rem;font-weight:650;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.metricValue{font-family:var(--mono);font-size:1.65rem;font-weight:700;letter-spacing:-.03em;font-variant-numeric:tabular-nums;transition:opacity .3s ease}.metricValue.positive{color:var(--green)}.metricValue.negative{color:var(--red)}.metricValue.neutral{color:var(--ink)}.metricSub{font-size:.76rem;color:var(--muted2);font-weight:500}.panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 20px}.panelHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}.panelTitle{margin:0;font-size:.92rem;font-weight:700;letter-spacing:-.01em}.panelBadge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;color:var(--muted);padding:3px 10px;border-radius:999px;border:1px solid var(--border);background:#ffffff05}.liveDot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px #00ff8880;animation:pulse 2s ease-in-out infinite}.tableWrap{overflow-x:auto}.dataTable{width:100%;border-collapse:collapse;font-size:.88rem}.dataTable th{text-align:left;padding:8px 12px;font-size:.72rem;font-weight:650;text-transform:uppercase;letter-spacing:.05em;color:var(--muted2);border-bottom:1px solid var(--border)}.dataTable td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.03);transition:opacity .3s ease}.dataTable tbody tr:hover{background:#ffffff05}.coinCell{font-weight:700;font-family:var(--mono);font-size:.9rem;letter-spacing:-.01em}.pctCell{font-family:var(--mono);font-weight:700;font-variant-numeric:tabular-nums}.pctCell.positive{color:var(--green)}.pctCell.negative{color:var(--red)}.dirCell{color:var(--muted);font-size:.84rem}.emptyRow{text-align:center;color:var(--muted2);padding:24px 12px}.statusPill{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:999px;font-size:.76rem;font-weight:600}.statusPill.active{background:var(--green-dim);color:var(--green)}.statusDotSmall{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 4px #0f86}.statusDotSmall.green{background:var(--green);box-shadow:0 0 4px #0f86}.statusDotSmall.red{background:var(--red);box-shadow:0 0 4px #f466}.twoCol{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.barChart{display:flex;flex-direction:column;gap:14px}.barRow{display:flex;flex-direction:column;gap:5px}.barInfo{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.barName{font-size:.84rem;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.barCount{font-family:var(--mono);font-size:.78rem;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0}.barTrack{height:6px;border-radius:999px;background:#ffffff0a;overflow:hidden}.barFill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--green));transition:width .5s ease;min-width:4px}.recentList{display:flex;flex-direction:column;gap:0;max-height:320px;overflow-y:auto}.recentHeader{display:grid;grid-template-columns:1.4fr .7fr .6fr .7fr;gap:10px;padding:0 0 10px;font-size:.72rem;font-weight:650;text-transform:uppercase;letter-spacing:.05em;color:var(--muted2);border-bottom:1px solid var(--border)}.recentRow{display:grid;grid-template-columns:1.4fr .7fr .6fr .7fr;gap:10px;padding:8px 0;align-items:center;font-size:.84rem;border-bottom:1px solid rgba(255,255,255,.03);transition:background .1s ease}.recentRow:hover{background:#ffffff05;border-radius:6px}.recentService{font-weight:650;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recentStatus{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:var(--muted)}.recentRt{font-family:var(--mono);font-size:.78rem;font-weight:600;font-variant-numeric:tabular-nums}.recentRt.fast{color:var(--green)}.recentRt.medium{color:var(--amber)}.recentRt.slow{color:var(--red)}.recentWhen{font-size:.76rem;color:var(--muted2)}.emptyText{color:var(--muted2);font-size:.88rem;padding:16px 0;margin:0}.healthRow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.healthCard{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;align-items:center;gap:12px;transition:border-color .2s ease}.healthCard:hover{border-color:var(--border-hover)}.healthDot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.healthDot.green{background:var(--green);box-shadow:0 0 10px #0f86;animation:pulse 2s ease-in-out infinite}.healthDot.red{background:var(--red);box-shadow:0 0 10px #f466;animation:pulse 2s ease-in-out infinite}.healthIcon{font-size:1.1rem;flex-shrink:0;opacity:.6}.healthInfo{display:flex;flex-direction:column;gap:2px;min-width:0}.healthLabel{font-size:.7rem;font-weight:650;text-transform:uppercase;letter-spacing:.05em;color:var(--muted2)}.healthValue{font-size:.88rem;font-weight:700;color:var(--ink)}.footer{margin-top:auto;border-top:1px solid var(--border);background:var(--bg2)}.footerInner{max-width:1320px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.footerBrand{font-size:.82rem;font-weight:600;color:var(--muted2)}.footerLinks{display:flex;gap:18px}.footerLinks a{color:var(--muted);text-decoration:none;font-size:.82rem;font-weight:600;transition:color .12s ease}.footerLinks a:hover{color:var(--cyan)}@keyframes fadeIn{0%{opacity:.4}to{opacity:1}}.fadeIn{animation:fadeIn .4s ease}@media(max-width:1024px){.metricsRow,.healthRow{grid-template-columns:repeat(2,1fr)}.twoCol{grid-template-columns:1fr}}@media(max-width:640px){.metricsRow,.healthRow{grid-template-columns:1fr}.headerInner{flex-direction:column;align-items:flex-start;gap:8px}.headerLeft{flex-direction:column;align-items:flex-start;gap:4px}.subtitle{border-left:none;padding-left:0}.main{padding:14px 14px 32px}.recentHeader,.recentRow{grid-template-columns:1fr 1fr;gap:4px}.recentHeader span:nth-child(4),.recentRow span:nth-child(4){display:none}.footerInner{flex-direction:column;align-items:flex-start;gap:10px}}
