/* MemeShield — Node app design system (sidebar shell, dark navy + violet/cyan). */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root{
  --bg:#0a0b16; --bg2:#0c0e1c; --panel:#111327; --panel2:#15172e; --panel3:#1b1e3a;
  --glass:rgba(255,255,255,.025); --hair:rgba(255,255,255,.06);
  --line:#22264a; --line2:#2f3358;
  /* primary accent kept under the legacy --lime* names so the whole system reflows */
  --lime:#8b6dff; --lime2:#a78bfa; --lime-d:#6d4ad9; --limeglow:rgba(139,109,255,.30);
  --cyan:#22d3ee; --cyan2:#38bdf8; --cyanglow:rgba(34,211,238,.26);
  --txt:#eef0fb; --muted:#9aa0c4; --dim:#6b7099;
  --up:#34d399; --upbg:rgba(52,211,153,.13); --down:#f87171; --downbg:rgba(248,113,113,.13); --gold:#fbbf24;
  --radius:16px; --sidebar:236px;
  --sans:"Inter",ui-sans-serif,system-ui,Segoe UI,Roboto,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;
  --shadow:0 12px 40px rgba(0,0,0,.5);
}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{background:radial-gradient(1100px 620px at 88% -12%,rgba(139,109,255,.12),transparent 58%),radial-gradient(900px 600px at -8% 6%,rgba(34,211,238,.06),transparent 55%),var(--bg);
  color:var(--txt);font:14px/1.55 var(--sans);letter-spacing:-.005em;-webkit-font-smoothing:antialiased}
a{color:var(--lime2);text-decoration:none;cursor:pointer;transition:opacity .15s}a:hover{opacity:.82}
.mono,.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:0}
.muted{color:var(--muted)}.dim{color:var(--dim)}.up{color:var(--up)}.down{color:var(--down)}.gold{color:var(--gold)}.ok{color:var(--up)}.err{color:var(--down)}
button{font:inherit;cursor:pointer;border:0;letter-spacing:-.01em}input,select,textarea{font:inherit}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#262a52;border-radius:8px;border:2px solid var(--bg)}

/* ===== app shell ===== */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:6px;padding:16px 14px;
  background:linear-gradient(180deg,rgba(20,22,48,.7),rgba(10,11,22,.5));border-right:1px solid var(--line);backdrop-filter:blur(10px)}
.brand{display:flex;align-items:center;gap:11px;font-weight:900;font-size:18px;letter-spacing:-.03em;padding:8px 10px 16px}
.brand .mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--lime),var(--lime-d));display:grid;place-items:center;font-size:19px;box-shadow:0 0 22px var(--limeglow),inset 0 1px 0 rgba(255,255,255,.35)}
.brand .bt{background:linear-gradient(120deg,#fff,#b9a8ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.rail{display:flex;flex-direction:column;gap:4px}
.navbtn{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:transparent;color:var(--muted);border:1px solid transparent;border-radius:11px;padding:11px 13px;font-weight:700;font-size:14px;transition:all .14s}
.navbtn:hover{color:var(--txt);background:var(--glass)}
.navbtn.active{color:var(--txt);background:linear-gradient(90deg,var(--limeglow),transparent);border-color:var(--line2);box-shadow:inset 2px 0 0 var(--lime)}
.railfoot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding:8px 6px}
.netstat{font:600 11px/1.3 var(--mono);color:var(--muted);background:var(--panel2);border:1px solid var(--line);padding:8px 10px;border-radius:10px}
.poweredby{font:700 10px/1 var(--sans);color:var(--dim);letter-spacing:.1em;text-transform:uppercase;padding-left:4px}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot.ok{background:var(--up);box-shadow:0 0 9px var(--up)}.dot.err{background:var(--down);box-shadow:0 0 9px var(--down)}

.main-col{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;padding:13px 24px;
  background:rgba(10,11,22,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar .grow{flex:1}.crumbs{font-weight:700;color:var(--muted);font-size:14px}
.btn{background:var(--panel2);color:var(--txt);border:1px solid var(--line2);border-radius:10px;padding:9px 15px;font-weight:700;font-size:13px;transition:all .16s;display:inline-flex;align-items:center;gap:7px}
.btn:hover{border-color:var(--lime);color:var(--lime2);transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--lime),var(--lime-d));color:#fff;border:0;box-shadow:0 4px 20px var(--limeglow),inset 0 1px 0 rgba(255,255,255,.25)}
.btn.primary:hover{filter:brightness(1.08);color:#fff}
.btn.big{padding:13px 16px;font-size:14px;width:100%;justify-content:center}
.btn.buy{background:linear-gradient(135deg,var(--up),#1fc488);color:#03241a}.btn.sell{background:linear-gradient(135deg,var(--down),#e0454f);color:#2a0709}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.acctpill{font:700 12px/1 var(--mono);color:var(--lime2);background:var(--panel2);border:1px solid var(--line);padding:9px 12px;border-radius:10px}
main{max-width:1760px;width:100%;margin:0 auto;padding:26px 34px 80px;animation:pagein .3s ease}
@media(max-width:1500px){main{padding:24px 26px 72px}}
@keyframes pagein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;align-items:center;gap:10px;border-right:0;border-bottom:1px solid var(--line);padding:10px 12px;overflow-x:auto}
  .brand{padding:0 6px 0 2px}.brand .bt{display:none}
  .rail{flex-direction:row}.railfoot{display:none}.navbtn{padding:9px 12px}
}

/* ===== components (premium) ===== */
.card{background:linear-gradient(180deg,var(--glass),transparent),var(--panel2);border:1px solid var(--line);border-radius:var(--radius);padding:17px 19px;margin-bottom:16px;box-shadow:0 1px 0 var(--hair) inset,var(--shadow)}
.card h2{margin:0 0 14px;font-size:11.5px;color:var(--lime2);text-transform:uppercase;letter-spacing:.12em;font-weight:800}
.card h3{margin:15px 0 6px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-weight:700}
.row{display:flex;gap:12px;flex-wrap:wrap}.row>div{flex:1;min-width:120px}
.grid2{display:grid;grid-template-columns:1.55fr 1fr;gap:16px}@media(max-width:900px){.grid2{grid-template-columns:1fr}}
label{display:block;font-size:11.5px;color:var(--muted);margin:12px 0 5px;font-weight:600}
input,select,textarea{width:100%;padding:11px 13px;background:#0b0d1c;border:1px solid var(--line2);border-radius:10px;color:var(--txt);transition:border-color .15s,box-shadow .15s}
input::placeholder{color:var(--dim)}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--lime);box-shadow:0 0 0 3px var(--limeglow)}
table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:8px 9px;border-bottom:1px solid var(--line);font-size:12.5px}
th{color:var(--dim);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.06em}
td.num,td.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}tbody tr:hover{background:var(--glass)}
.pill{display:inline-block;background:var(--panel3);border:1px solid var(--line2);border-radius:999px;padding:3px 10px;font-size:11px;color:var(--muted);font-weight:600}
.kv{display:grid;grid-template-columns:140px 1fr;gap:6px;padding:7px 0;border-bottom:1px solid var(--line)}.kv b{color:var(--muted);font-weight:600}
.kpi{background:linear-gradient(180deg,var(--glass),transparent),var(--panel);border:1px solid var(--line);border-radius:13px;padding:13px 15px;position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--lime),var(--cyan));opacity:.7}
.kpi b{display:block;font:800 19px/1.2 var(--mono);color:var(--txt)}.kpi span{color:var(--dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.cards4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}@media(max-width:720px){.cards4{grid-template-columns:repeat(2,1fr)}}
.logbox{background:#0b0d1c;border:1px solid var(--line2);border-radius:10px;padding:10px;max-height:150px;overflow:auto;font:11.5px/1.5 var(--mono);white-space:pre-wrap;color:var(--muted)}
.empty{padding:54px;text-align:center;color:var(--muted)}
.av{border-radius:50%;display:grid;place-items:center;font-size:1.05em;flex:none;color:#0c1108;font-weight:900;box-shadow:inset 0 0 0 2px rgba(255,255,255,.16),0 4px 14px rgba(0,0,0,.4)}

/* board */
.board-top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.board-top h1{margin:0;font-size:26px;font-weight:900;letter-spacing:-.03em;background:linear-gradient(120deg,#fff,#a78bfa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.searchbar{flex:1;min-width:200px;max-width:400px}
.tabs{display:flex;gap:7px;flex-wrap:wrap}
.chip{background:var(--panel2);border:1px solid var(--line2);color:var(--muted);border-radius:999px;padding:7px 14px;font-weight:700;font-size:12px;transition:all .14s}
.chip:hover{color:var(--txt);transform:translateY(-1px)}.chip.active{background:linear-gradient(135deg,var(--lime),var(--lime-d));color:#fff;border-color:transparent;box-shadow:0 3px 14px var(--limeglow)}
.king{display:flex;gap:18px;align-items:center;background:linear-gradient(120deg,rgba(139,109,255,.14),transparent 50%),linear-gradient(180deg,var(--glass),transparent),var(--panel2);border:1px solid rgba(139,109,255,.32);border-radius:var(--radius);padding:18px 20px;margin-bottom:20px;position:relative;overflow:hidden;box-shadow:0 16px 50px rgba(0,0,0,.45)}
.king::before{content:"👑 KING OF THE HILL";position:absolute;top:11px;right:15px;font:800 10px/1 var(--sans);color:var(--gold);letter-spacing:.1em}
.king .av{width:72px;height:72px;font-size:29px;box-shadow:inset 0 0 0 2px rgba(255,255,255,.18),0 0 26px rgba(139,109,255,.34)}
.king .info{flex:1;min-width:0}.king .nm{font-size:19px;font-weight:900;letter-spacing:-.02em}.king .mc{font:600 13px/1.5 var(--mono);color:var(--muted)}
.coingrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:16px}
.coin{background:linear-gradient(180deg,var(--glass),transparent),var(--panel2);border:1px solid var(--line);border-radius:15px;padding:14px;cursor:pointer;transition:transform .16s cubic-bezier(.2,.8,.2,1),border-color .16s,box-shadow .16s;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}
.coin::before{content:"";position:absolute;top:0;left:0;right:0;height:38px;background:linear-gradient(180deg,var(--limeglow),transparent);opacity:0;transition:opacity .2s}
.coin:hover{transform:translateY(-4px);border-color:var(--lime);box-shadow:0 18px 44px rgba(0,0,0,.55),0 0 0 1px var(--limeglow)}.coin:hover::before{opacity:.5}
.coin .head{display:flex;gap:12px;align-items:center;position:relative}.coin .av{width:46px;height:46px;font-size:20px}
.coin .nm{font-weight:800;font-size:15px;line-height:1.12;word-break:break-word;letter-spacing:-.01em}
.coin .tk{color:var(--muted);font-size:11.5px;font-weight:700;font-family:var(--mono)}
.coin .desc{color:var(--muted);font-size:11.5px;min-height:30px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.coin .meta{display:flex;justify-content:space-between;font-size:10.5px;color:var(--dim);font-family:var(--mono)}
.coin .mc{font:800 14px/1 var(--mono);background:linear-gradient(90deg,var(--lime2),var(--cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.bar{height:6px;background:#0b0d1c;border:1px solid var(--line2);border-radius:999px;overflow:hidden}.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--lime-d),var(--lime2));border-radius:999px;transition:width .6s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 10px var(--limeglow)}
.ticker{overflow:hidden;white-space:nowrap;border:1px solid var(--line);border-radius:999px;background:var(--panel2);margin-bottom:18px}.ticker .track{display:inline-block;padding:8px 0;animation:scroll 32s linear infinite}.ticker .it{display:inline-block;margin:0 18px;font:700 11.5px/1 var(--mono);color:var(--muted)}.ticker .it b{color:var(--lime2)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* coin terminal */
.back{color:var(--muted);font-weight:700;margin-bottom:14px;display:inline-flex;align-items:center;gap:6px;font-size:13px}.back:hover{color:var(--lime2)}
.coinhead{display:flex;gap:15px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.coinhead .av{width:56px;height:56px;font-size:23px}
.coinhead .nm{font-size:22px;font-weight:900;letter-spacing:-.025em;line-height:1}.coinhead .tk{color:var(--muted);font-weight:700;font-size:12.5px}
.coinhead .px{margin-left:auto;text-align:right}.coinhead .px .big{font:900 24px/1 var(--mono)}.coinhead .px .muted{font-size:11px}
.statbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.stat{background:linear-gradient(180deg,var(--glass),transparent),var(--panel);border:1px solid var(--line);border-radius:11px;padding:10px 14px;min-width:100px;position:relative;overflow:hidden}.stat::after{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--lime),var(--cyan));opacity:.55}
.stat span{display:block;font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat b{font:800 15px/1.3 var(--mono)}
.term{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}@media(max-width:1000px){.term{grid-template-columns:1fr}}
.chartbox{background:linear-gradient(180deg,var(--glass),transparent),var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:8px;position:relative;box-shadow:var(--shadow)}
.chartwrap{width:100%;height:520px}.chart-empty{position:absolute;inset:0;display:grid;place-items:center;color:var(--muted);font-weight:600;pointer-events:none}
.tradepanel{background:linear-gradient(180deg,var(--glass),transparent),var(--panel2);border:1px solid var(--line);border-radius:var(--radius);padding:18px 19px;position:sticky;top:74px;box-shadow:var(--shadow)}
/* full-width trades/holders row under the terminal */
.tradesrow{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}@media(max-width:1000px){.tradesrow{grid-template-columns:1fr}}
.trade-tabs{display:flex;margin-bottom:14px;border:1px solid var(--line2);border-radius:11px;overflow:hidden;background:var(--panel)}
.trade-tabs button{flex:1;background:transparent;color:var(--muted);padding:12px;font-weight:800;font-size:13px;transition:all .15s}
.trade-tabs button.buy.active{background:linear-gradient(135deg,var(--up),#1fc488);color:#03241a}.trade-tabs button.sell.active{background:linear-gradient(135deg,var(--down),#e0454f);color:#2a0709}
.amtbtns{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}.amtbtns .chip{cursor:pointer;padding:5px 12px;font-size:11.5px}
.tradebox .out{font:13px/1.4 var(--mono);color:var(--muted);margin:10px 0}
.tabbar{display:flex;gap:6px;margin-bottom:11px}.tabbar button{background:var(--panel);border:1px solid var(--line2);color:var(--muted);border-radius:9px;padding:6px 13px;font-weight:700;font-size:12px;transition:all .14s}.tabbar button.active{color:#fff;background:linear-gradient(135deg,var(--lime),var(--lime-d));border-color:transparent}

/* modal + toasts */
.modal-bg{position:fixed;inset:0;background:rgba(4,5,12,.72);backdrop-filter:blur(6px);z-index:40;display:grid;place-items:center;padding:18px;animation:fadein .2s ease}
.modal{background:linear-gradient(180deg,var(--glass),transparent),var(--panel2);border:1px solid var(--line2);border-radius:20px;max-width:500px;width:100%;max-height:90vh;overflow:auto;padding:24px 26px;box-shadow:0 40px 100px rgba(0,0,0,.7);animation:modalin .26s cubic-bezier(.2,.8,.2,1)}
@keyframes modalin{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal h2{margin:0 0 4px;font-size:20px;color:var(--txt);text-transform:none;letter-spacing:-.02em;font-weight:800}
.modal .x{float:right;background:transparent;color:var(--muted);font-size:23px;line-height:1;margin:-8px -8px 0 0}.modal .x:hover{color:var(--txt)}
.modal .preview{display:flex;gap:13px;align-items:center;margin:15px 0;padding:13px;background:var(--panel);border:1px solid var(--line);border-radius:13px}.modal .preview .av{width:52px;height:52px;font-size:22px}
#toasts{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:9px;z-index:60}
.toast{background:linear-gradient(180deg,var(--glass),transparent),var(--panel2);border:1px solid var(--line2);border-left:3px solid var(--lime);border-radius:11px;padding:12px 16px;max-width:360px;box-shadow:0 14px 40px rgba(0,0,0,.6);font-weight:600;font-size:13px;animation:toastin .3s cubic-bezier(.2,.8,.2,1)}
.toast.err{border-left-color:var(--down)}.toast.ok{border-left-color:var(--up)}
@keyframes toastin{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--line2);border-top-color:var(--lime);border-radius:50%;animation:sp .8s linear infinite;vertical-align:middle}@keyframes sp{to{transform:rotate(360deg)}}
@keyframes flashin{0%{background:rgba(139,109,255,.18)}100%{background:transparent}}.flash{animation:flashin 1.2s ease-out}
@keyframes fadein{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.fadein{animation:fadein .26s ease-out}
@keyframes bump{0%{transform:scale(1)}30%{transform:scale(1.07)}100%{transform:scale(1)}}.bump{animation:bump .4s ease;display:inline-block}
.skel{position:relative;color:transparent!important;background:linear-gradient(90deg,#15172e,#1d2042,#15172e);background-size:200% 100%;animation:shimmer 1.3s linear infinite;border-radius:8px}@keyframes shimmer{to{background-position:-200% 0}}

/* ===== rich components (sparklines, % change, badges, segmented, dense) ===== */
.spark{display:block}
.chg{font-family:var(--mono);font-weight:700;font-size:12px;padding:2px 8px;border-radius:7px;white-space:nowrap;display:inline-flex;align-items:center;gap:3px}
.chg.up{color:var(--up);background:var(--upbg)}.chg.down{color:var(--down);background:var(--downbg)}.chg.flat{color:var(--muted);background:var(--glass)}
.badge{font:800 9.5px/1 var(--sans);padding:3px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:3px;white-space:nowrap}
.badge.new{color:#a78bfa;background:rgba(139,109,255,.16);border:1px solid rgba(139,109,255,.3)}
.badge.hot{color:#ff9a3c;background:rgba(255,154,60,.14);border:1px solid rgba(255,154,60,.25)}
.badge.live{color:var(--up);background:var(--upbg);border:1px solid rgba(52,211,153,.25)}
.badge.king{color:var(--gold);background:rgba(251,191,36,.14);border:1px solid rgba(251,191,36,.3)}
.badges{display:flex;gap:5px;flex-wrap:wrap}
.seg{display:inline-flex;background:var(--panel);border:1px solid var(--line2);border-radius:9px;overflow:hidden}
.seg button{background:transparent;color:var(--muted);padding:5px 11px;font-weight:700;font-size:11px;transition:all .13s}
.seg button:hover{color:var(--txt)}.seg button.active{background:var(--panel3);color:var(--lime2)}
.table.dense th,.table.dense td{padding:5px 7px;font-size:11.5px}
/* card row holding sparkline + change */
.coin .spark-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}
.coin .badges{position:absolute;top:11px;right:11px;z-index:1}
/* trade-size mini bar behind a value */
.szbar{position:relative;display:inline-block;min-width:64px}
.szbar>i{position:absolute;left:0;top:50%;transform:translateY(-50%);height:16px;border-radius:4px;opacity:.16;z-index:0}
.szbar>span{position:relative;z-index:1}
.szbar.b>i{background:var(--up)}.szbar.s>i{background:var(--down)}
/* price-change header chip on the coin page */
.coinhead .px .chg{margin-top:4px;display:inline-flex}
.miniwrap{height:54px}

/* ===== mining pool — futuristic 2030 dashboard ===== */
.pool-wrap{display:flex;flex-direction:column;gap:16px}
.pool-hero{position:relative;overflow:hidden;border-radius:20px;border:1px solid var(--line2);
  background:radial-gradient(130% 150% at 0% 0%,rgba(139,109,255,.18),transparent 46%),radial-gradient(130% 150% at 100% 100%,rgba(34,211,238,.13),transparent 46%),linear-gradient(180deg,#13152d,#0c0e1d);
  box-shadow:0 30px 90px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.05);
  display:grid;grid-template-columns:250px 1fr;gap:26px;padding:24px 28px;align-items:center}
.pool-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(139,109,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(139,109,255,.06) 1px,transparent 1px);background-size:32px 32px;-webkit-mask:radial-gradient(120% 120% at 18% 8%,#000,transparent 72%);mask:radial-gradient(120% 120% at 18% 8%,#000,transparent 72%);pointer-events:none}
@media(max-width:760px){.pool-hero{grid-template-columns:1fr;justify-items:center;text-align:center}}
.gauge{position:relative;width:230px;height:230px}
.gauge svg{position:absolute;inset:0;width:100%;height:100%}
.gauge .ring-rot{animation:spin360 18s linear infinite;transform-origin:center}
@keyframes spin360{to{transform:rotate(360deg)}}
.gauge .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.gauge .glbl{font:800 9px/1 var(--sans);color:var(--dim);letter-spacing:.22em;text-transform:uppercase}
.gauge .ghr{font:900 33px/1 var(--mono);background:linear-gradient(90deg,#7cf3ff,#b69bff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 16px rgba(124,211,255,.45))}
.gauge .gunit{font:700 12px/1 var(--mono);color:var(--muted);letter-spacing:.14em}
.live{display:inline-flex;align-items:center;gap:6px;font:800 9px/1 var(--sans);letter-spacing:.18em;color:var(--up);text-transform:uppercase}
.live i{width:7px;height:7px;border-radius:50%;background:var(--up);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,211,153,.55)}70%{box-shadow:0 0 0 8px rgba(52,211,153,0)}100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}}
.hero-r{display:flex;flex-direction:column;gap:15px;min-width:0;width:100%}
.hero-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.hero-top .glbl{font:800 10px/1 var(--sans);color:var(--lime2);letter-spacing:.2em;text-transform:uppercase}
.hero-spark{height:74px;border-radius:14px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(124,211,255,.05),transparent);overflow:hidden;position:relative}
.hero-spark svg{width:100%;height:100%;display:block}
.hero-spark .glow{position:absolute;inset:0;background:radial-gradient(70% 120% at 50% 120%,rgba(139,109,255,.22),transparent 70%);pointer-events:none}
.ptiles{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:720px){.ptiles{grid-template-columns:repeat(2,1fr)}}
.ptile{position:relative;overflow:hidden;border-radius:15px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.022),transparent),var(--panel);padding:15px 16px;transition:transform .15s,border-color .15s}
.ptile:hover{transform:translateY(-3px);border-color:var(--line2)}
.ptile::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--lime),var(--cyan));opacity:.75}
.ptile .ic{font-size:15px;filter:drop-shadow(0 0 8px rgba(139,109,255,.4))}
.ptile .v{font:900 21px/1.1 var(--mono);color:var(--txt);margin-top:9px}
.ptile .l{font:700 9.5px/1 var(--sans);color:var(--dim);letter-spacing:.13em;text-transform:uppercase;margin-top:6px}
.pool-cols{display:grid;grid-template-columns:1.25fr 1fr;gap:16px}@media(max-width:900px){.pool-cols{grid-template-columns:1fr}}
.pool-panel{position:relative;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.015),transparent),var(--panel2);padding:18px 20px;box-shadow:var(--shadow)}
.ph{display:flex;align-items:center;gap:9px;font:800 11px/1 var(--sans);letter-spacing:.13em;text-transform:uppercase;color:var(--lime2);margin-bottom:14px}
.ph .badge{margin-left:auto}
.miner-help{font-size:12px;color:var(--muted);margin-bottom:12px}
.cmd-line{display:flex;align-items:center;gap:10px;background:#0b0d1c;border:1px solid var(--line2);border-radius:11px;padding:10px 12px;margin:8px 0}
.cmd-line .ck{font:700 9.5px/1 var(--sans);color:var(--dim);letter-spacing:.1em;text-transform:uppercase;min-width:80px}
.cmd-line code{flex:1;min-width:0;overflow:auto;white-space:nowrap;font:600 12px/1.4 var(--mono);color:#cdd3f5}
.cmd-line .cpy{flex:none;width:32px;height:30px;display:grid;place-items:center;background:var(--panel3);border:1px solid var(--line2);border-radius:8px;color:var(--lime2);font-size:13px;transition:all .14s}
.cmd-line .cpy:hover{border-color:var(--lime);color:#fff;background:var(--lime-d)}
.pay-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}
.pay-cell{background:#0e1023;border:1px solid var(--line);border-radius:11px;padding:11px 13px}
.pay-cell .v{font:900 17px/1 var(--mono);color:var(--txt)}.pay-cell .v.cy{color:#7cf3ff}.pay-cell .v.vi{color:#b69bff}
.pay-cell .l{font:700 9px/1 var(--sans);color:var(--dim);letter-spacing:.1em;text-transform:uppercase;margin-top:7px}
.pay-you{margin-top:11px;border-radius:12px;border:1px solid rgba(139,109,255,.35);background:linear-gradient(100deg,rgba(139,109,255,.14),transparent);padding:11px 14px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.pay-you .yv{font:900 16px/1 var(--mono)}
.miner-rows{display:flex;flex-direction:column;gap:9px}
.miner-row{display:grid;grid-template-columns:1.6fr 1.7fr repeat(3,.85fr);gap:14px;align-items:center;border-radius:13px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.015),transparent),var(--panel);padding:11px 14px;transition:border-color .15s,transform .15s,box-shadow .15s}
.miner-row:hover{border-color:rgba(139,109,255,.4);transform:translateX(2px);box-shadow:-3px 0 0 var(--lime),0 8px 30px rgba(0,0,0,.4)}
@media(max-width:820px){.miner-row{grid-template-columns:1fr 1fr;gap:9px}}
.mr-id{display:flex;align-items:center;gap:11px;min-width:0}
.mr-id .av{width:38px;height:38px;font-size:17px}
.mr-nm{font-weight:800;font-size:14px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mr-sub{font:600 10.5px/1.3 var(--mono);color:var(--dim);display:flex;gap:7px;align-items:center;flex-wrap:wrap;margin-top:2px}
.mr-hr{display:flex;flex-direction:column;gap:7px}
.mr-hrv{font:900 16px/1 var(--mono);background:linear-gradient(90deg,#7cf3ff,#b69bff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.mr-bar{height:6px;border-radius:999px;background:#0b0d1c;border:1px solid var(--line2);overflow:hidden}
.mr-bar>i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--lime));box-shadow:0 0 12px rgba(124,211,255,.6);transition:width .6s cubic-bezier(.2,.8,.2,1)}
.mr-cell{display:flex;flex-direction:column;gap:4px}
.mr-cell b{font:800 14px/1 var(--mono);color:var(--txt)}
.mr-cell span{font:700 9px/1 var(--sans);color:var(--dim);letter-spacing:.1em;text-transform:uppercase}
.mr-cell b.pend{color:#fbbf24}.mr-cell b.paid{color:var(--up)}
.miner-empty{padding:38px;text-align:center;color:var(--muted);border:1px dashed var(--line2);border-radius:13px}
.pool-status{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.pool-status .pill b{color:var(--txt)}
.pool-status .hashline{flex-basis:100%;color:var(--dim);font:600 10.5px/1.4 var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== simple Uniswap-style swap ===== */
.swapcard{max-width:460px}
.swaprow{background:var(--panel);border:1px solid var(--line2);border-radius:14px;padding:13px 15px;margin:8px 0;transition:border-color .15s}
.swaprow:focus-within{border-color:var(--lime)}
.swaplbl{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-bottom:7px}
.swaplbl .bal{cursor:pointer}.swaplbl .bal:hover{color:var(--lime2)}
.swapinput{display:flex;align-items:center;gap:10px}
.swapinput input{flex:1;min-width:0;background:transparent;border:0;font:800 26px/1 var(--mono);padding:2px 0;color:var(--txt)}
.swapinput input:focus{outline:0;box-shadow:none;border:0}
.swapinput input[readonly]{color:var(--muted)}
.tokensel{flex:none;width:auto;min-width:104px;background:var(--panel3);border:1px solid var(--line2);border-radius:999px;padding:9px 14px;font-weight:800;color:var(--txt);cursor:pointer;font-size:14px}
.tokensel:focus{outline:0;border-color:var(--lime);box-shadow:none}
.flip{width:36px;height:36px;margin:-12px auto;border:3px solid var(--bg);background:var(--panel3);border-radius:11px;display:grid;place-items:center;cursor:pointer;position:relative;z-index:1;color:var(--lime2);font-size:17px;transition:transform .25s,border-color .15s}
.flip:hover{transform:rotate(180deg)}
.rate{font:12px/1.5 var(--mono);color:var(--muted);margin:11px 3px;min-height:18px;display:flex;justify-content:space-between;gap:10px}
.swaphint{font-size:11.5px;color:var(--dim);margin:6px 2px}
details.adv{margin-top:18px}details.adv>summary{cursor:pointer;font-weight:700;color:var(--muted);list-style:none;padding:4px 0}
details.adv>summary::-webkit-details-marker{display:none}details.adv[open]>summary{color:var(--lime2)}
