/* ============================================================
   Vminer 数据面板 stats.vminers.com —— 复用主站暗黑玻璃风
   ============================================================ */
@font-face{font-family:"Space Grotesk";src:url("assets/fonts/space-grotesk-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Space Grotesk";src:url("assets/fonts/space-grotesk-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Space Grotesk";src:url("assets/fonts/space-grotesk-700.woff2") format("woff2");font-weight:700;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("assets/fonts/jetbrains-mono-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"JetBrains Mono";src:url("assets/fonts/jetbrains-mono-700.woff2") format("woff2");font-weight:700;font-display:swap}

:root{
  --bg:#070a12; --surface:#0d1424; --surface-2:#111a2e;
  --line:rgba(120,170,255,.12); --line-strong:rgba(120,180,255,.26);
  --text:#e7eefb; --text-dim:#94a3c0; --text-mute:#6c7a99;
  --cyan:#3dd2ff; --blue:#4d8dff; --amber:#ffb454; --good:#39e0a3; --bad:#ff6b81;
  --grad:linear-gradient(110deg,#62e7ff 0%,#3dd2ff 38%,#4d8dff 100%);
  --grad-soft:linear-gradient(135deg,rgba(61,210,255,.14),rgba(77,141,255,.05));
  --shadow:0 30px 80px -24px rgba(0,0,0,.7);
  --font-sans:"Space Grotesk","PingFang SC","HarmonyOS Sans SC","Microsoft YaHei","Noto Sans SC",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"Cascadia Code","Consolas",monospace;
  --wrap:1100px; --radius:18px;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;background:
  radial-gradient(1200px 600px at 80% -10%,rgba(61,210,255,.08),transparent 60%),
  radial-gradient(900px 500px at 0% 0%,rgba(77,141,255,.07),transparent 55%),
  var(--bg);
  color:var(--text);font-family:var(--font-sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2{margin:0;font-weight:700;letter-spacing:-.02em;line-height:1.14}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 22px}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.scanline{position:fixed;top:0;left:0;right:0;height:2px;z-index:1000;
  background:linear-gradient(90deg,transparent,var(--cyan),var(--blue),transparent);
  background-size:200% 100%;animation:scan 6s linear infinite;opacity:.7}
@keyframes scan{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ---------- 顶栏 ---------- */
.sb-nav{position:sticky;top:0;z-index:900;background:rgba(8,11,20,.72);backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--line)}
.sb-nav-inner{display:flex;align-items:center;gap:16px;height:64px}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:700}
.brand-mark{filter:drop-shadow(0 0 10px rgba(61,210,255,.5))}
.brand-name{font-size:20px}
.sb-tag{font-family:var(--font-mono);font-size:11.5px;font-weight:700;color:var(--cyan);
  padding:3px 8px;border:1px solid var(--line-strong);border-radius:999px;background:rgba(61,210,255,.08)}
.sb-nav-actions{display:flex;align-items:center;gap:12px;margin-left:auto}
.sb-back{color:var(--text-dim);font-size:14.5px;font-weight:500;transition:color .2s}
.sb-back:hover{color:var(--cyan)}
.lang-toggle{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--text-dim);
  background:transparent;border:1px solid var(--line);border-radius:9px;padding:7px 10px;cursor:pointer;transition:color .2s,border-color .2s}
.lang-toggle:hover{color:var(--text);border-color:var(--line-strong)}
.lang-toggle .lang-sep{opacity:.4;margin:0 1px}
body[data-lang="zh"] .lang-zh{color:var(--cyan)}
body[data-lang="en"] .lang-en{color:var(--cyan)}

/* ---------- 按钮 ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-sans);
  font-weight:700;font-size:15px;line-height:1;padding:13px 20px;border-radius:12px;border:1px solid transparent;
  cursor:pointer;transition:transform .18s,box-shadow .25s,background .25s,opacity .2s;white-space:nowrap}
.btn-lg{padding:15px 28px;font-size:16px;border-radius:13px}
.btn-primary{color:#04121e;background:var(--grad);box-shadow:0 10px 30px -8px rgba(61,210,255,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px -8px rgba(61,210,255,.75)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* ---------- 主体 ---------- */
.sb-main{padding:38px 0 60px}
.sb-head{text-align:center;max-width:640px;margin:0 auto 30px}
.sb-title{font-size:clamp(1.7rem,4.4vw,2.6rem)}
.sb-sub{margin-top:12px;color:var(--text-dim);font-size:clamp(.95rem,2vw,1.05rem)}

/* ---------- 全网算力面板 ---------- */
.sb-net-panel{position:relative;border:1px solid var(--line-strong);border-radius:var(--radius);
  background:var(--grad-soft),var(--surface);padding:24px 26px;overflow:hidden;box-shadow:var(--shadow)}
.sb-net-glow{position:absolute;inset:0;background:radial-gradient(420px 160px at 78% 0%,rgba(61,210,255,.18),transparent 70%);pointer-events:none}
.sb-net-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;position:relative}
.sb-net-kicker{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--cyan);
  display:inline-flex;align-items:center;gap:8px}
.sb-net-kicker::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 8px var(--good);animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.sb-net-src{font-family:var(--font-mono);font-size:11.5px;color:var(--text-mute)}
.sb-net-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:18px;position:relative}
.sb-net-cell{display:flex;flex-direction:column;gap:5px;padding-left:16px;border-left:1px solid var(--line)}
.sb-net-cell:first-child{padding-left:0;border-left:none}
.sb-net-num{font-family:var(--font-mono);font-weight:700;font-size:clamp(1.6rem,3.8vw,2.5rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.sb-net-num2{font-family:var(--font-mono);font-weight:700;font-size:clamp(1.05rem,2.2vw,1.4rem);color:var(--text)}
.sb-net-label{font-size:12.5px;color:var(--text-dim)}
/* 矿池排名(页面区块) */
.sb-pools{margin-top:46px}
.sb-pools-title{font-size:clamp(1.2rem,2.6vw,1.5rem)}
.sb-pools-sub{display:block;margin-top:7px;font-size:12px;color:var(--text-dim)}
.sb-pool-list{margin-top:16px;border:1px solid var(--line);border-radius:16px;background:var(--surface);overflow:hidden}
.sb-pool-row{display:flex;align-items:center;gap:26px;padding:15px 22px;border-top:1px solid var(--line)}
.sb-pool-row:first-child{border-top:none}
.sb-pool-row:hover{background:rgba(61,210,255,.03)}
.sb-pool-rank{flex:0 0 auto;width:18px;font-family:var(--font-mono);font-weight:700;font-size:15px;color:var(--text-mute);text-align:center}
.sb-pool-row.ours .sb-pool-rank{color:var(--cyan)}
.sb-pool-name{flex:0 0 190px;font-weight:600;font-size:15.5px;display:flex;align-items:center;gap:7px}
.sb-pool-row.ours .sb-pool-name{color:var(--cyan)}
.sb-pool-mid{flex:1;min-width:0;display:flex;justify-content:center;align-items:center}
.sb-pool-stack{width:234px;display:flex;flex-direction:column;gap:4px}
.sb-pool-meta{font-family:var(--font-mono);font-size:12px;color:var(--text-mute)}
.sb-pool-earn{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--good);white-space:nowrap}
.sb-pool-earn span{color:var(--text-mute);font-size:10.5px;font-weight:400}
.sb-pool-rr{flex:0 0 auto;display:flex;align-items:center;gap:20px}
.sb-spark{width:150px;height:32px;color:var(--cyan);display:block;opacity:.9}
.sb-pool-row.ours .sb-spark{color:var(--good)}
.sb-pool-hash{flex:0 0 116px;text-align:right;font-family:var(--font-mono);font-weight:700;font-size:16px;color:var(--text);white-space:nowrap}
.sb-pool-loading{text-align:center;color:var(--text-dim);padding:42px 0}
@media (max-width:760px){
  .sb-pool-row{flex-wrap:wrap;gap:8px 14px;padding:14px 16px}
  .sb-pool-rank{order:1}
  .sb-pool-name{order:2;flex:0 1 auto}
  .sb-pool-rr{order:3;margin-left:auto}
  .sb-pool-mid{order:4;flex:0 0 100%;justify-content:flex-start}
  .sb-pool-stack{width:auto;flex-direction:column;gap:3px;align-items:flex-start}
  .sb-spark{display:none}
}

/* 矿池排名弹窗 */
.sb-modal[hidden]{display:none}
.sb-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}
.sb-modal-backdrop{position:absolute;inset:0;background:rgba(4,7,14,.72);backdrop-filter:blur(6px);animation:fadeIn .2s}
.sb-modal-card{position:relative;width:100%;max-width:640px;max-height:88vh;overflow:auto;background:var(--surface);
  border:1px solid var(--line-strong);border-radius:20px;box-shadow:var(--shadow);padding:24px 26px;animation:popIn .22s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.sb-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.sb-modal-title{font-size:1.25rem}
.sb-modal-close{width:34px;height:34px;flex:0 0 auto;border-radius:9px;border:1px solid var(--line);background:transparent;
  color:var(--text-dim);font-size:15px;cursor:pointer;transition:color .2s,border-color .2s,background .2s}
.sb-modal-close:hover{color:var(--text);border-color:var(--line-strong);background:rgba(255,255,255,.04)}
.sb-modal-sub{font-size:12.5px;color:var(--text-dim);margin-bottom:14px}
.sb-modal-foot{margin-top:16px;font-size:11.5px;color:var(--text-mute);text-align:center}
.sb-modal-loading{text-align:center;color:var(--text-dim);padding:46px 0}

/* 排名行(条形图) */
.sb-rank-row{display:flex;align-items:flex-start;gap:13px;padding:13px 0;border-top:1px solid var(--line)}
.sb-rank-row:first-child{border-top:none}
.sb-rank-num{font-family:var(--font-mono);font-weight:700;font-size:15px;color:var(--text-mute);width:20px;flex:0 0 auto;text-align:center;padding-top:1px}
.sb-rank-row.ours .sb-rank-num{color:var(--cyan)}
.sb-rank-main{flex:1;min-width:0}
.sb-rank-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.sb-rank-name{font-weight:600;font-size:15px}
.sb-rank-row.ours .sb-rank-name{color:var(--cyan)}
.sb-rank-tag{font-family:var(--font-mono);font-size:9px;font-weight:700;color:#04121e;background:var(--grad);border-radius:4px;padding:1px 5px;margin-left:7px;vertical-align:middle}
.sb-rank-hash{font-family:var(--font-mono);font-weight:700;font-size:14px;color:var(--text);white-space:nowrap}
.sb-rank-bar{height:6px;border-radius:999px;background:rgba(120,170,255,.1);overflow:hidden;margin:7px 0 6px}
.sb-rank-bar>i{display:block;height:100%;border-radius:999px;background:var(--grad);width:0;transition:width .8s ease}
.sb-rank-row.ours .sb-rank-bar>i{background:linear-gradient(110deg,var(--good),var(--cyan))}
.sb-rank-meta{font-family:var(--font-mono);font-size:11.5px;color:var(--text-mute);display:flex;gap:13px;flex-wrap:wrap}

/* ---------- 查询 ---------- */
.sb-query{max-width:680px;margin:34px auto 0;text-align:center}
.sb-query-label{display:block;font-size:13.5px;color:var(--text-dim);margin-bottom:10px;text-align:left}
.sb-query-row{display:flex;gap:12px}
.sb-input{flex:1;min-width:0;font-family:var(--font-mono);font-size:15px;color:var(--text);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:13px;padding:15px 18px;outline:none;transition:border-color .2s,box-shadow .2s}
.sb-input::placeholder{color:var(--text-mute)}
.sb-input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(61,210,255,.14)}
.sb-input.err{border-color:var(--bad);box-shadow:0 0 0 3px rgba(255,107,129,.14)}
.sb-go{min-width:108px}
.sb-hint{margin-top:11px;font-size:12.5px;color:var(--text-mute);text-align:left}
.sb-hint.err{color:var(--bad)}

/* ---------- 结果 ---------- */
.sb-results{margin-top:40px}
.sb-results-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.sb-results-title{font-size:clamp(1.2rem,2.6vw,1.55rem)}
.sb-results-wallet{font-family:var(--font-mono);font-size:12.5px;color:var(--text-mute);word-break:break-all}
.sb-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.sb-card{position:relative;border:1px solid var(--line);border-radius:16px;background:var(--surface);
  padding:18px 20px;display:flex;flex-direction:column;gap:13px;transition:border-color .2s,transform .2s,box-shadow .25s}
.sb-card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 18px 50px -28px rgba(61,210,255,.5)}
.sb-card.failed{opacity:.62}
.sb-card.idle{opacity:.55}
.sb-card.idle:hover{opacity:.85}
.sb-card.idle .sb-card-dot{background:var(--text-mute);box-shadow:none}
.sb-status{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;line-height:1.3}
.sb-status.mining{color:#04121e;background:var(--good)}
.sb-status.idle{color:var(--text-mute);background:rgba(120,170,255,.08);border:1px solid var(--line)}
.sb-card-top{display:flex;align-items:center;gap:9px}
.sb-card-dot{width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 7px var(--good);flex:0 0 auto}
.sb-card.failed .sb-card-dot{background:var(--text-mute);box-shadow:none}
.sb-card-name{font-weight:700;font-size:16.5px}
.sb-card-src{margin-left:auto;font-family:var(--font-mono);font-size:10.5px;color:var(--text-mute);
  border:1px solid var(--line);border-radius:6px;padding:2px 7px}
.sb-rows{display:flex;flex-direction:column;gap:9px}
.sb-row{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.sb-row-k{font-size:13px;color:var(--text-dim)}
.sb-row-v{font-family:var(--font-mono);font-weight:700;font-size:15px;color:var(--text)}
.sb-row-v.muted{color:var(--text-mute);font-weight:400;font-size:13px}
.sb-row-v.accent{color:var(--good)}
.sb-bar{height:5px;border-radius:999px;background:rgba(120,170,255,.1);overflow:hidden;margin-top:2px}
.sb-bar > i{display:block;height:100%;border-radius:999px;background:var(--grad);width:0;transition:width .7s ease}
.sb-card-foot{font-size:11.5px;color:var(--text-mute);border-top:1px solid var(--line);padding-top:10px;display:flex;justify-content:space-between}
.sb-card-msg{font-size:13px;color:var(--text-mute);padding:6px 0}

/* 加载骨架 */
.sb-card.loading .sb-skel{background:linear-gradient(90deg,rgba(120,170,255,.06),rgba(120,170,255,.16),rgba(120,170,255,.06));
  background-size:200% 100%;animation:shimmer 1.3s linear infinite;border-radius:6px;height:13px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ---------- 页脚 ---------- */
.sb-footer{border-top:1px solid var(--line);padding:22px 0;color:var(--text-mute);font-size:13px}
.sb-footer .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.sb-footer a:hover{color:var(--cyan)}

/* ---------- 响应式 ---------- */
@media (max-width:900px){
  .sb-main{padding-left:22px;padding-right:22px}
  .sb-cards{grid-template-columns:repeat(2,1fr)}
  .sb-net-grid{grid-template-columns:1fr 1fr 1fr;gap:16px 14px}
  .sb-net-cell:first-child{grid-column:1/-1;padding-bottom:14px;border-bottom:1px solid var(--line)}
}
@media (max-width:560px){
  .wrap{padding:0 16px}
  .sb-main{padding:28px 16px 48px}
  .sb-cards{grid-template-columns:1fr}
  .sb-net-panel{padding:20px 17px}
  .sb-net-grid{grid-template-columns:1fr 1fr}
  .sb-net-head{margin-bottom:14px}
  .sb-query-row{flex-direction:column}
  .sb-go{width:100%}
  .sb-tag{display:none}
  .sb-pools{margin-top:34px}
  .sb-footer .wrap{justify-content:center;text-align:center}
}
