﻿@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=DM+Mono:wght@300;400;500&display=swap');

/* ── THEMES ───────────────────────────────────────────── */
:root {
  --bg:    #09090b; --bg1:   #111114; --bg2:   #18181c;
  --bg3:   #1e1e23; --bg4:   #252529; --bg5:   #2c2c32;
  --b0:    rgba(255,255,255,0.045); --b1: rgba(255,255,255,0.075);
  --b2:    rgba(255,255,255,0.12);  --b3: rgba(255,255,255,0.18);
  --tx:    #ededf0; --txs: #8888a0; --txd: #44444f; --txm: #5a5a68;
  --live:  #4caf50; --dead: #ef5350; --warn: #ff9800; --info: #42a5f5;
  --live-bg: rgba(76,175,80,0.09); --dead-bg: rgba(239,83,80,0.09);
  --warn-bg: rgba(255,152,0,0.09); --info-bg: rgba(66,165,245,0.09);
  --fs: 'DM Sans', sans-serif; --fm: 'DM Mono', monospace;
  --r4:4px; --r6:6px; --r8:8px; --r10:10px; --r12:12px; --r16:16px; --r20:20px;
  --sb-w: 240px; --tb-h: 52px; --t1: 0.12s ease; --t2: 0.22s ease;
  --border: var(--b1); --n: var(--live); --re: var(--dead); --cy: var(--info);
  --am: var(--warn); --pu: #b794f6; --fmo: var(--fm); --r14: 14px;
}
[data-theme="light"] {
  --bg:#f7f7f8; --bg1:#ffffff; --bg2:#f0f0f3; --bg3:#e8e8ed; --bg4:#dfdfe6; --bg5:#d4d4dc;
  --b0:rgba(0,0,0,0.04); --b1:rgba(0,0,0,0.07); --b2:rgba(0,0,0,0.12); --b3:rgba(0,0,0,0.18);
  --tx:#0a0a0c; --txs:#58586a; --txd:#9898aa; --txm:#b8b8c8;
}
[data-theme="dim"] {
  --bg:#141416; --bg1:#1a1a1e; --bg2:#202025; --bg3:#26262c; --bg4:#2c2c33; --bg5:#33333b;
  --b0:rgba(255,255,255,0.04); --b1:rgba(255,255,255,0.07); --b2:rgba(255,255,255,0.11); --b3:rgba(255,255,255,0.16);
}
[data-theme="abyss"] {
  --bg:#000000; --bg1:#0a0a0a; --bg2:#111111; --bg3:#161616; --bg4:#1c1c1c; --bg5:#222222;
  --tx:#ffffff;
}

/* ── BASE ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-font-smoothing:antialiased}
body{font-family:var(--fs);background:var(--bg);color:var(--tx);line-height:1.5;min-height:100vh;overflow-x:hidden}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font-family:var(--fs);color:inherit;background:none;border:none;outline:none}
button{cursor:pointer}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:99px}

/* ── LAYOUT ───────────────────────────────────────────── */
.vl-shell{display:flex;min-height:100vh}
.vl-sidebar{
  width:var(--sb-w);flex-shrink:0;background:var(--bg1);
  border-right:1px solid var(--b0);display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  transition:transform var(--t2);overflow-y:auto;overflow-x:hidden
}
.sb-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:95;
  opacity:0;pointer-events:none;transition:opacity var(--t2)
}
.sb-overlay.show{opacity:1;pointer-events:auto}
.vl-main{flex:1;margin-left:var(--sb-w);min-height:100vh;display:flex;flex-direction:column}

/* ── BRAND ────────────────────────────────────────────── */
.vl-sb-brand{
  display:flex;align-items:center;gap:10px;
  padding:16px 14px;border-bottom:1px solid var(--b0);flex-shrink:0
}
.vl-sb-logo{
  width:30px;height:30px;border-radius:var(--r8);
  overflow:hidden;flex-shrink:0;border:1px solid var(--b1)
}
.vl-sb-logo img{width:100%;height:100%;object-fit:cover}
.vl-sb-title{font-size:13px;font-weight:700;color:var(--tx);letter-spacing:0.3px}
.vl-sb-ver{font-size:9px;color:var(--txd);font-family:var(--fm)}

/* ── SIDEBAR USER ─────────────────────────────────────── */
.vl-sb-user{padding:10px;border-bottom:1px solid var(--b0);flex-shrink:0}
.vl-sb-user-card{
  background:var(--bg2);border-radius:var(--r10);padding:10px 12px;
  display:flex;align-items:center;gap:10px
}
.vl-sb-av{
  width:32px;height:32px;border-radius:50%;background:var(--bg4);border:1px solid var(--b1);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:600;color:var(--txs);flex-shrink:0;overflow:hidden
}
.vl-sb-av img{
  width:100%;height:100%;display:block;object-fit:cover;object-position:center 30%;
}
.vl-sb-uname{font-size:12px;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vl-sb-uid{font-size:10px;color:var(--txd);font-family:var(--fm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vl-sb-plan-wrap{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0}
.vl-sb-plan{font-size:9px;color:var(--txd);font-family:var(--fm);text-align:right;text-transform:uppercase}

/* ── NAV ──────────────────────────────────────────────── */
.vl-nav{flex:1;padding:8px;overflow-y:auto}
.vl-nav-sec-label{
  font-size:9px;font-weight:600;color:var(--txd);letter-spacing:1px;
  text-transform:uppercase;padding:10px 8px 4px;font-family:var(--fm)
}
.vl-sb-item{
  display:flex;align-items:center;gap:9px;padding:7px 8px;
  border-radius:var(--r8);font-size:13px;font-weight:400;
  color:var(--txs);cursor:pointer;transition:all var(--t1);margin-bottom:1px
}
.vl-sb-item:hover{background:var(--bg2);color:var(--tx)}
.vl-sb-item.active{background:var(--bg3);color:var(--tx);font-weight:500}
.vl-sb-item i{width:16px;text-align:center;font-size:12px;flex-shrink:0}
.vl-sb-badge{
  margin-left:auto;font-size:9px;font-weight:700;padding:1px 6px;
  border-radius:99px;font-family:var(--fm)
}
.vl-sb-badge.live-b{background:var(--live-bg);color:var(--live)}
.vl-sb-badge.hot{background:var(--warn-bg);color:var(--warn)}
.vl-sb-badge.admin{background:var(--dead-bg);color:var(--dead)}

/* Group toggle */
.vl-sb-grp-btn{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  padding:6px 8px;font-size:9px;font-weight:600;color:var(--txd);
  letter-spacing:1px;text-transform:uppercase;border-radius:var(--r6);
  transition:color var(--t1);font-family:var(--fm)
}
.vl-sb-grp-btn:hover{color:var(--txs)}
.vl-sb-grp-btn i{font-size:9px;transition:transform var(--t1)}
.vl-sb-grp-btn.open i{transform:rotate(180deg)}

/* Bottom */
.vl-sb-bottom{padding:10px;border-top:1px solid var(--b0);flex-shrink:0}
.vl-sb-logout{
  display:flex;align-items:center;gap:9px;padding:8px 10px;
  border-radius:var(--r8);font-size:12px;color:var(--dead);
  cursor:pointer;transition:background var(--t1)
}
.vl-sb-logout:hover{background:var(--dead-bg)}

/* ── TOPBAR ───────────────────────────────────────────── */
.vl-topbar{
  height:var(--tb-h);display:flex;align-items:center;
  justify-content:space-between;padding:0 18px;
  border-bottom:1px solid var(--b0);background:var(--bg);
  position:sticky;top:0;z-index:90;flex-shrink:0
}
.vl-topbar-left{display:flex;align-items:center;gap:10px}
.vl-topbar-title{font-size:14px;font-weight:600;color:var(--tx)}
.vl-topbar-right{display:flex;align-items:center;gap:6px}

/* Topbar chips */
.vl-tb-chip{
  display:flex;align-items:center;gap:5px;padding:0 10px;height:30px;
  border-radius:var(--r8);border:1px solid var(--b1);background:var(--bg1);
  font-size:11px;color:var(--txs);font-family:var(--fm);white-space:nowrap
}
.vl-online-dot{width:6px;height:6px;border-radius:50%;background:var(--live)}
.vl-online-count{color:var(--tx);font-weight:600}
.vl-cr-val{color:var(--tx);font-weight:600}

/* Topbar icon buttons */
.vl-tb-btn{
  width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--r8);border:1px solid var(--b1);background:var(--bg1);
  color:var(--txs);font-size:12px;transition:all var(--t1);cursor:pointer;position:relative
}
.vl-tb-btn:hover{border-color:var(--b2);color:var(--tx);background:var(--bg2)}
.vl-notif-dot{
  position:absolute;top:5px;right:5px;width:6px;height:6px;
  border-radius:50%;background:var(--warn);border:1.5px solid var(--bg);
  box-shadow:0 0 0 0 rgba(255,179,0,0.55);
  animation: notifPulse 1.6s ease-out infinite
}
.vl-tb-btn.has-unread{
  border-color: rgba(255,179,0,0.34);
  box-shadow: 0 0 0 1px rgba(255,179,0,0.08), 0 0 20px rgba(255,179,0,0.12);
}
.vl-tb-btn.has-unread i{
  color: var(--warn);
}
@keyframes notifPulse{
  0%{box-shadow:0 0 0 0 rgba(255,179,0,0.55)}
  70%{box-shadow:0 0 0 8px rgba(255,179,0,0)}
  100%{box-shadow:0 0 0 0 rgba(255,179,0,0)}
}
.vl-sidebar-toggle{
  display:none;width:30px;height:30px;align-items:center;justify-content:center;
  border-radius:var(--r8);border:1px solid var(--b1);background:var(--bg1);
  color:var(--txs);font-size:13px;cursor:pointer
}

/* ── NOTIFICATION PANEL ───────────────────────────────── */
.vl-notif-panel{
  position:fixed;top:calc(var(--tb-h) + 8px);right:16px;width:300px;
  background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r12);
  z-index:200;overflow:hidden;display:none;
  box-shadow:0 8px 32px rgba(0,0,0,0.5)
}
.vl-notif-panel.open{display:block;animation:slideDown .15s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.vl-notif-hdr{
  padding:12px 14px;border-bottom:1px solid var(--b0);
  display:flex;align-items:center;justify-content:space-between
}
.vl-notif-hdr-title{font-size:12px;font-weight:600;color:var(--tx)}
.vl-notif-clear{font-size:10px;color:var(--txd);cursor:pointer;font-family:var(--fm)}
.vl-notif-clear:hover{color:var(--txs)}
.vl-notif-list{max-height:300px;overflow-y:auto}
.vl-notif-item{
  padding:11px 14px;border-bottom:1px solid var(--b0);
  display:flex;gap:10px;cursor:default
}
.vl-notif-item:last-child{border-bottom:none}
.vl-notif-item:hover{background:var(--bg2)}
.vl-ndot{width:7px;height:7px;border-radius:50%;margin-top:4px;flex-shrink:0}
.vl-notif-msg{font-size:12px;color:var(--txs);line-height:1.5}
.vl-notif-msg b{color:var(--tx);font-weight:600}
.vl-notif-time{font-size:10px;color:var(--txd);font-family:var(--fm);margin-top:2px}
.vl-notif-empty{padding:20px;text-align:center;font-size:12px;color:var(--txd);font-family:var(--fm)}

/* ── THEME PANEL ──────────────────────────────────────── */
.vl-theme-panel{
  position:fixed;top:calc(var(--tb-h) + 8px);right:16px;width:170px;
  background:var(--bg1);border:1px solid var(--b2);border-radius:var(--r12);
  z-index:200;display:none;box-shadow:0 8px 32px rgba(0,0,0,0.5)
}
.vl-theme-panel.open{display:block;animation:slideDown .15s ease}
.vl-theme-hdr{
  padding:9px 12px;border-bottom:1px solid var(--b0);
  font-size:9px;font-weight:600;color:var(--txd);
  text-transform:uppercase;letter-spacing:1px;font-family:var(--fm)
}
.vl-theme-item{
  display:flex;align-items:center;gap:9px;padding:9px 12px;
  cursor:pointer;font-size:12px;color:var(--txs);transition:background var(--t1)
}
.vl-theme-item:hover{background:var(--bg2);color:var(--tx)}
.vl-theme-item.active{color:var(--tx);font-weight:500}
.vl-theme-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.vl-theme-check{margin-left:auto;font-size:10px;color:var(--live)}

/* ── CONTENT ──────────────────────────────────────────── */
.vl-content{flex:1;position:relative}
.vl-page{display:none;padding:20px;animation:pageIn .18s ease}
.vl-page.active{display:block}
@keyframes pageIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.vl-page-title{font-size:20px;font-weight:700;color:var(--tx);letter-spacing:-0.3px;margin-bottom:3px}
.vl-page-sub{font-size:11px;color:var(--txd);font-family:var(--fm);margin-bottom:18px}

/* ── CARDS ────────────────────────────────────────────── */
.vl-card{
  background:var(--bg1);border:1px solid var(--b1);
  border-radius:var(--r12);padding:16px;margin-bottom:12px
}
.vl-card-title{
  font-size:10px;font-weight:600;color:var(--txd);
  letter-spacing:0.8px;text-transform:uppercase;font-family:var(--fm);margin-bottom:14px
}
.vl-card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}

/* ── STAT GRID ────────────────────────────────────────── */
.vl-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
.vl-stat{
  background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r12);padding:16px
}
.vl-stat .lbl{
  font-size:9px;font-weight:600;color:var(--txd);
  letter-spacing:0.8px;text-transform:uppercase;font-family:var(--fm);margin-bottom:6px
}
.vl-stat .val{
  font-size:24px;font-weight:700;color:var(--tx);
  letter-spacing:-0.5px;font-family:var(--fm)
}
.vl-stat .val.g{color:var(--live)}
.vl-stat .val.r{color:var(--dead)}
.vl-stat .val.a{color:var(--warn)}
.vl-stat .val.b{color:var(--info)}
.vl-stat .sub{font-size:10px;color:var(--txd);margin-top:2px;font-family:var(--fm)}

/* ── ALL-TIME ────────────────────────────────────────── */
.vl-alltime-hero{
  margin-bottom:12px;padding:14px;border-radius:var(--r16);border:1px solid var(--b1);
  background:
    radial-gradient(circle at top right, rgba(66,165,245,0.14), transparent 34%),
    radial-gradient(circle at bottom left, rgba(76,175,80,0.12), transparent 30%),
    var(--bg1)
}
.vl-alltime-hero-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.vl-alltime-kpi{
  min-width:0;padding:16px;border-radius:var(--r12);border:1px solid var(--b1);
  background:rgba(0,0,0,0.18)
}
.vl-alltime-kpi .lbl,.vl-alltime-user-stat .lbl{
  font-size:9px;font-weight:600;color:var(--txd);letter-spacing:.8px;
  text-transform:uppercase;font-family:var(--fm);margin-bottom:8px
}
.vl-alltime-kpi .val,.vl-alltime-user-stat .val{
  font-size:28px;font-weight:800;color:var(--tx);line-height:1;
  letter-spacing:-1px;font-family:var(--fm)
}
.vl-alltime-kpi .sub{
  margin-top:8px;font-size:10px;line-height:1.5;color:var(--txs);font-family:var(--fm)
}
.vl-alltime-kpi.live .val,.vl-alltime-user-stat.live .val{color:var(--live)}
.vl-alltime-kpi.dead .val{color:var(--dead)}
.vl-alltime-kpi.info .val{color:var(--info)}
.vl-alltime-card{padding:18px}
.vl-alltime-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px
}
.vl-alltime-head-sub{font-size:11px;color:var(--txs);line-height:1.5;font-family:var(--fm)}
.vl-alltime-user-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.vl-alltime-user-stat{
  padding:18px;border-radius:var(--r12);border:1px solid var(--b1);
  background:linear-gradient(180deg,var(--bg1),var(--bg))
}
.vl-alltime-panels{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vl-alltime-list{display:flex;flex-direction:column;gap:10px}
.vl-alltime-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;
  border-radius:var(--r12);border:1px solid var(--b1);background:linear-gradient(180deg,var(--bg1),var(--bg));
  transition:border-color var(--t1),transform var(--t1),background var(--t1)
}
.vl-alltime-row:hover{border-color:var(--b2);background:var(--bg2);transform:translateY(-1px)}
.vl-alltime-rank{
  width:34px;height:34px;border-radius:10px;border:1px solid var(--b1);background:var(--bg2);
  color:var(--tx);display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-family:var(--fm);font-size:12px;font-weight:700
}
.vl-alltime-rank.top-1{color:#f6c453;background:rgba(246,196,83,0.08);border-color:rgba(246,196,83,0.25)}
.vl-alltime-rank.top-2{color:#c8d0df;background:rgba(200,208,223,0.08);border-color:rgba(200,208,223,0.24)}
.vl-alltime-rank.top-3{color:#d49363;background:rgba(212,147,99,0.08);border-color:rgba(212,147,99,0.24)}
.vl-alltime-main{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.vl-alltime-avatar{
  width:38px;height:38px;border-radius:12px;border:1px solid var(--b1);background:var(--bg2);
  color:var(--tx);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0
}
.vl-alltime-copy{min-width:0}
.vl-alltime-title{font-size:13px;font-weight:700;color:var(--tx);line-height:1.3;word-break:break-word}
.vl-alltime-subtitle{margin-top:4px;font-size:10px;color:var(--txs);font-family:var(--fm);line-height:1.5}
.vl-alltime-metrics{display:flex;align-items:center;gap:18px;flex-shrink:0}
.vl-alltime-metric{text-align:right;min-width:58px}
.vl-alltime-metric-value{
  font-size:18px;font-weight:800;color:var(--tx);line-height:1;font-family:var(--fm)
}
.vl-alltime-metric-value.live{color:var(--live)}
.vl-alltime-metric-label{
  margin-top:4px;font-size:9px;color:var(--txd);text-transform:uppercase;
  letter-spacing:.7px;font-family:var(--fm)
}
.vl-alltime-empty{
  padding:24px 16px;border-radius:var(--r12);border:1px dashed var(--b1);text-align:center;
  font-size:11px;color:var(--txd);font-family:var(--fm)
}

/* Meta strip */
.vl-meta-strip{display:flex;gap:10px;margin-bottom:12px}
.vl-meta-card{
  flex:1;background:var(--bg1);border:1px solid var(--b1);
  border-radius:var(--r12);padding:12px 14px;display:flex;align-items:center;gap:10px
}
.vl-meta-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.vl-meta-l{font-size:10px;color:var(--txd);font-family:var(--fm)}
.vl-meta-v{font-size:13px;font-weight:600;color:var(--tx)}

/* ── DAILY REWARD ─────────────────────────────────────── */
.vl-reward{
  background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r12);
  padding:14px 16px;display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;transition:border-color var(--t1)
}
.vl-reward:hover{border-color:var(--b2)}
.vl-reward-icon{
  width:36px;height:36px;border-radius:var(--r8);background:var(--warn-bg);
  display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0
}
.vl-reward-title{font-size:13px;font-weight:600;color:var(--tx)}
.vl-reward-sub{font-size:10px;color:var(--txd);font-family:var(--fm);margin-top:2px}
.vl-reward-claim{
  padding:6px 14px;border-radius:var(--r6);background:var(--live);
  color:#fff;font-size:11px;font-weight:700;border:none;cursor:pointer;transition:opacity var(--t1)
}
.vl-reward-claim:hover{opacity:.85}
.vl-reward-claim.done{background:var(--bg3);color:var(--txd);cursor:default}

/* ── GATE ─────────────────────────────────────────────── */
.vl-gate-panel{
  background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r12);
  overflow:hidden;margin-bottom:12px
}
.vl-gate-hdr{
  padding:14px 16px;border-bottom:1px solid var(--b0);
  display:flex;align-items:center;justify-content:space-between
}
.vl-gate-name{font-size:15px;font-weight:700;color:var(--tx)}
.vl-gate-desc{font-size:10px;color:var(--txd);font-family:var(--fm);margin-top:2px}
.vl-cr-badge{
  padding:4px 10px;border-radius:var(--r6);background:var(--bg2);
  border:1px solid var(--b1);font-size:10px;font-family:var(--fm);color:var(--txs)
}

/* Pools */
.vl-pool-row{padding:10px 16px;border-bottom:1px solid var(--b0);display:flex;align-items:center;gap:6px}
.vl-pool-lbl{font-size:9px;color:var(--txd);font-family:var(--fm);text-transform:uppercase;letter-spacing:.8px;margin-right:6px}
.vl-pool{
  display:flex;align-items:center;gap:5px;padding:4px 10px;
  border-radius:var(--r6);border:1px solid var(--b1);
  font-size:11px;font-weight:500;color:var(--txs);cursor:pointer;
  transition:all var(--t1);font-family:var(--fm)
}
.vl-pool:hover{border-color:var(--b2);color:var(--tx)}
.vl-pool.active{border-color:var(--live);background:var(--live-bg);color:var(--live)}
.vl-pool-dot{width:5px;height:5px;border-radius:50%;background:currentColor}

/* Textarea */
.vl-textarea{
  width:100%;min-height:130px;padding:12px 14px;background:var(--bg);border:none;
  border-bottom:1px solid var(--b0);color:var(--tx);font-family:var(--fm);
  font-size:12px;resize:vertical;display:block;line-height:1.6
}
.vl-textarea:focus{outline:none}
.vl-textarea::placeholder{color:var(--txd)}
.vl-ta-bar{
  padding:7px 12px;border-bottom:1px solid var(--b0);
  display:flex;align-items:center;gap:6px;background:var(--bg1)
}
.vl-ta-btn{
  width:26px;height:26px;border-radius:var(--r6);border:1px solid var(--b1);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:var(--txs);cursor:pointer;transition:all var(--t1)
}
.vl-ta-btn:hover{border-color:var(--b2);color:var(--tx);background:var(--bg2)}
#line-count{margin-left:auto;font-size:10px;color:var(--txd);font-family:var(--fm)}

/* Istats */
.vl-istats{
  padding:8px 16px;border-bottom:1px solid var(--b0);
  display:flex;align-items:center;gap:18px;background:var(--bg1)
}
.vl-istat{font-size:10px;color:var(--txd);font-family:var(--fm);display:flex;align-items:center;gap:5px}
.iv{font-weight:700;font-size:12px}.iv.ok{color:var(--live)}.iv.dead{color:var(--dead)}

/* Threads */
#thread-selector{padding:10px 16px;border-bottom:1px solid var(--b0);display:flex;align-items:center;gap:6px}
.vl-thread-btn{
  width:32px;height:27px;border-radius:var(--r6);border:1px solid var(--b1);
  background:transparent;font-size:11px;font-weight:600;color:var(--txs);
  cursor:pointer;font-family:var(--fm);transition:all var(--t1);
  display:flex;align-items:center;justify-content:center;gap:3px
}
.vl-thread-btn:hover{border-color:var(--b2);color:var(--tx)}
.vl-thread-btn.active{border-color:var(--live);background:var(--live-bg);color:var(--live)}
.vl-thread-btn.locked{color:var(--txd);border-color:var(--b0);cursor:not-allowed}

/* Action row */
.vl-actions{padding:12px 16px;display:flex;align-items:center;gap:8px}
.vl-prog{height:1px;background:var(--b0)}.vl-prog-fill{height:100%;background:var(--live);width:0;transition:width .4s ease}

/* Results */
.vl-results-wrap{background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r12);overflow:hidden;margin-bottom:12px}
.vl-results-hdr{padding:10px 14px;border-bottom:1px solid var(--b0);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.vl-pills{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.vl-pill{
  padding:3px 9px;border-radius:var(--r6);border:1px solid var(--b1);
  font-size:10px;font-weight:600;color:var(--txd);font-family:var(--fm);
  cursor:pointer;transition:all var(--t1);display:inline-flex;align-items:center;gap:6px
}
.vl-pill:hover{border-color:var(--b2);color:var(--txs)}
.vl-pill .pill-label{letter-spacing:.35px;text-transform:uppercase}
.vl-pill .pill-count{
  min-width:18px;padding:1px 6px;border-radius:999px;
  background:var(--bg3);color:var(--tx);font-weight:800;text-align:center
}
.vl-pill.live{border-color:rgba(76,175,80,.22);background:rgba(76,175,80,.06);color:#b7dfbd}
.vl-pill.live .pill-count{background:rgba(76,175,80,.16);color:var(--live)}
.vl-pill.charged{border-color:rgba(76,175,80,.22);background:rgba(76,175,80,.06);color:#b7dfbd}
.vl-pill.charged .pill-count{background:rgba(76,175,80,.16);color:var(--live)}
.vl-pill.dead{border-color:rgba(239,83,80,.22);background:rgba(239,83,80,.06);color:#f0b6b4}
.vl-pill.dead .pill-count{background:rgba(239,83,80,.16);color:var(--dead)}
.vl-pill.err{border-color:rgba(255,152,0,.22);background:rgba(255,152,0,.06);color:#f0cd97}
.vl-pill.err .pill-count{background:rgba(255,152,0,.16);color:var(--warn)}
.vl-pill.active-filter{border-color:var(--b3);color:var(--tx)}
.vl-pill.live.active-filter{border-color:var(--live);color:var(--live);background:var(--live-bg)}
.vl-pill.charged.active-filter{border-color:var(--live);color:var(--live);background:var(--live-bg)}
.vl-pill.dead.active-filter{border-color:var(--dead);color:var(--dead);background:var(--dead-bg)}
.vl-pill.err.active-filter{border-color:var(--warn);color:var(--warn);background:var(--warn-bg)}
.vl-pill.active-filter .pill-count{background:rgba(255,255,255,.08)}
.vl-results{max-height:360px;overflow-y:auto;padding:8px}
.vl-ri{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:9px 10px;border-radius:var(--r8);font-size:11px;font-family:var(--fm);
  color:var(--txs);margin-bottom:6px;line-height:1.5;transition:background var(--t1), border-color var(--t1);
  border:1px solid var(--b0)
}
.vl-ri:hover{background:var(--bg2)}
.vl-ri-main{display:flex;align-items:flex-start;gap:9px;min-width:0;flex:1}
.vl-ri-copy{min-width:0;flex:1}
.vl-ri.live{
  color:#b6ffd2;
  background:linear-gradient(180deg, rgba(34,197,94,0.14), rgba(34,197,94,0.06));
  border-color:rgba(34,197,94,0.25)
}
.vl-ri.charged{
  color:#b6ffd2;
  background:linear-gradient(180deg, rgba(34,197,94,0.14), rgba(34,197,94,0.06));
  border-color:rgba(34,197,94,0.25)
}
.vl-ri.dead{
  color:#ffb7b7;
  background:linear-gradient(180deg, rgba(239,68,68,0.12), rgba(239,68,68,0.05));
  border-color:rgba(239,68,68,0.22)
}
.vl-ri.warn{color:var(--warn);background:var(--warn-bg)}
.vl-ri .ri-card{font-weight:700;color:var(--tx);word-break:break-all}
.vl-ri.live .ri-card{color:#eafff1}
.vl-ri.charged .ri-card{color:#eafff1}
.vl-ri.dead .ri-card{color:#ffe1e1}
.vl-ri .ri-msg{display:block;margin-top:2px;color:inherit;opacity:.95}
.vl-ri-copy-btn{
  flex-shrink:0;height:28px;padding:0 10px;border-radius:999px;border:1px solid var(--b1);
  background:rgba(255,255,255,0.04);color:var(--tx);font-size:10px;font-weight:700;
  font-family:var(--fm);cursor:pointer;transition:all var(--t1)
}
.vl-ri-copy-btn:hover{border-color:var(--b2);background:rgba(255,255,255,0.08)}

/* ── BUTTONS ──────────────────────────────────────────── */
.vl-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:0 14px;height:34px;border-radius:var(--r8);font-size:12px;font-weight:600;
  cursor:pointer;transition:all var(--t1);border:1px solid transparent;white-space:nowrap
}
.vl-btn i{font-size:11px}
.full{width:100%}.vl-btn.sm{height:30px;padding:0 10px;font-size:11px}.vl-btn.xs{height:26px;padding:0 8px;font-size:10px}
.vl-btn-neon{background:var(--live);color:#fff;border-color:var(--live)}
.vl-btn-neon:hover{opacity:.85}
.vl-btn-ghost{background:transparent;color:var(--txs);border-color:var(--b1)}
.vl-btn-ghost:hover{border-color:var(--b2);color:var(--tx);background:var(--bg2)}
.vl-btn-danger{background:transparent;color:var(--dead);border-color:var(--dead-bg)}
.vl-btn-danger:hover{background:var(--dead-bg)}
.vl-btn-run{background:var(--bg2);color:var(--tx);border-color:var(--b1);flex:1}
.vl-btn-run:hover{border-color:var(--b2);background:var(--bg3)}

/* ── INPUTS ───────────────────────────────────────────── */
.vl-input{
  width:100%;height:36px;padding:0 12px;background:var(--bg2);
  border:1px solid var(--b1);border-radius:var(--r8);font-size:13px;color:var(--tx);transition:border-color var(--t1)
}
.vl-input:focus{border-color:var(--b3);outline:none}
.vl-input::placeholder{color:var(--txd)}
.vl-label{font-size:10px;font-weight:600;color:var(--txd);display:block;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--fm)}
.vl-form-group{margin-bottom:12px}
.vl-select{appearance:none;cursor:pointer}

/* ── TABLE ────────────────────────────────────────────── */
.vl-table{width:100%;border-collapse:collapse;font-size:12px}
.vl-table thead th{
  text-align:left;padding:8px 12px;font-size:9px;font-weight:600;
  color:var(--txd);text-transform:uppercase;letter-spacing:.5px;
  font-family:var(--fm);border-bottom:1px solid var(--b0)
}
.vl-table tbody td{padding:10px 12px;border-bottom:1px solid var(--b0);color:var(--txs);vertical-align:middle}
.vl-table tbody tr:last-child td{border-bottom:none}
.vl-table tbody tr:hover td{background:var(--bg2)}
.td-mono{font-family:var(--fm);font-size:11px}

/* ── BADGES ───────────────────────────────────────────── */
.vl-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:var(--r4);font-size:10px;font-weight:700;font-family:var(--fm)}
.vl-badge.ok{background:var(--live-bg);color:var(--live)}
.vl-badge.dead{background:var(--dead-bg);color:var(--dead)}
.vl-badge.warn{background:var(--warn-bg);color:var(--warn)}
.vl-badge.off{background:var(--bg3);color:var(--txd)}

/* Plan badges */
.plan-tag{
  display:inline-flex;align-items:center;justify-content:center;min-width:64px;
  padding:5px 10px;border-radius:999px;font-size:9px;font-weight:800;
  font-family:var(--fm);letter-spacing:.9px;text-transform:uppercase;
  border:1px solid transparent;transition:all var(--t1)
}
.plan-tag.free{
  background:var(--bg3);color:#b5b5c4;border-color:var(--b1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03)
}
.plan-tag.basic{
  color:#8fd6ff;border-color:rgba(66,165,245,.35);
  background:linear-gradient(180deg, rgba(66,165,245,.16), rgba(66,165,245,.07));
  box-shadow:0 0 10px rgba(66,165,245,.16), inset 0 0 10px rgba(66,165,245,.08)
}
.plan-tag.elite{
  color:#ffd978;border-color:rgba(255,193,7,.42);
  background:linear-gradient(180deg, rgba(255,193,7,.22), rgba(255,152,0,.1));
  box-shadow:0 0 14px rgba(255,193,7,.24), inset 0 0 14px rgba(255,193,7,.12)
}

/* ── AUTH ─────────────────────────────────────────────── */
.vl-auth{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.vl-auth-card{
  width:100%;max-width:380px;background:var(--bg1);border:1px solid var(--b1);
  border-radius:var(--r20);padding:32px 28px;overflow:hidden
}
.vl-auth-logo{width:48px;height:48px;border-radius:var(--r12);overflow:hidden;margin:0 auto 20px;border:1px solid var(--b1)}
.vl-auth-logo img{width:100%;height:100%;object-fit:cover}
.vl-auth-title{font-size:20px;font-weight:700;color:var(--tx);text-align:center;margin-bottom:6px}
.vl-auth-sub{font-size:12px;color:var(--txd);text-align:center;font-family:var(--fm);margin-bottom:24px;line-height:1.6}
.vl-eyebrow{font-size:9px;font-weight:600;color:var(--txd);letter-spacing:1.5px;text-transform:uppercase;font-family:var(--fm);text-align:center;margin-bottom:8px}
.vl-alert.error{background:var(--dead-bg);border:1px solid var(--dead);border-radius:var(--r8);padding:10px 12px;font-size:12px;color:var(--dead);margin-bottom:14px;font-family:var(--fm)}
.vl-features{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:16px}
.vl-features span{font-size:10px;color:var(--txd);font-family:var(--fm);display:flex;align-items:center;gap:5px}

/* OTP */
.vl-otp-row{display:flex;gap:7px;margin-bottom:16px;width:100%}
.vl-otp-inp{
  flex:1 1 0;width:0;min-width:0;height:44px;background:var(--bg2);border:1px solid var(--b1);
  border-radius:var(--r8);text-align:center;font-size:18px;font-weight:700;
  color:var(--tx);font-family:var(--fm);transition:border-color var(--t1)
}
.vl-otp-inp:focus{border-color:var(--live);outline:none}

/* Channel */
.vl-challenge{background:var(--bg2);border:1px solid var(--b1);border-radius:var(--r10);padding:14px;margin-bottom:14px}
.vl-challenge-prompt{font-size:11px;color:var(--txd);font-family:var(--fm);text-align:center;margin-bottom:10px}
.vl-channel{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 0;border-bottom:1px solid var(--b0)
}
.vl-channel:last-of-type{border-bottom:none;padding-bottom:12px}
.vl-ch-info{min-width:0;flex:1}
.vl-ch-name{font-size:12px;font-weight:600;color:var(--tx)}
.vl-ch-handle{
  font-size:11px;color:var(--info);font-family:var(--fm);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.vl-ch-status{font-size:9px;font-weight:700;font-family:var(--fm);padding:2px 7px;border-radius:var(--r4)}
.vl-ch-status.pending{background:var(--bg4);color:var(--txd)}
.vl-ch-status.ok{background:var(--live-bg);color:var(--live)}

/* ── LEADERBOARD ──────────────────────────────────────── */
.vl-podium{display:grid;grid-template-columns:1fr 1.1fr 1fr;gap:10px;margin-bottom:12px}
.vl-pod{
  position:relative;overflow:hidden;text-align:center;padding:24px 14px 18px;
  background:
    radial-gradient(circle at top, rgba(255,255,255,.04), transparent 40%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)),
    var(--bg1);
  border:1px solid var(--b1);border-radius:var(--r12);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03), 0 10px 30px rgba(0,0,0,.18);
}
.vl-pod::before{
  content:'';position:absolute;inset:-20% 15% auto;height:90px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.12), transparent 70%);
  opacity:.18;pointer-events:none;filter:blur(10px)
}
.vl-pod::after{
  content:'✦';position:absolute;top:14px;right:16px;font-size:12px;
  color:rgba(255,255,255,.22);text-shadow:0 0 12px currentColor;pointer-events:none
}
.vl-pod.p1{
  border-color:rgba(255,215,0,.28);
  background:
    radial-gradient(circle at top, rgba(255,215,0,.12), transparent 42%),
    linear-gradient(180deg, rgba(255,215,0,.05), rgba(255,255,255,0)),
    var(--bg1);
  box-shadow:0 0 0 1px rgba(255,215,0,.05), 0 16px 40px rgba(255,196,0,.12), inset 0 1px 0 rgba(255,255,255,.04)
}
.vl-pod.p2{
  border-color:rgba(167,177,255,.18);
  background:
    radial-gradient(circle at top, rgba(167,177,255,.10), transparent 42%),
    linear-gradient(180deg, rgba(167,177,255,.04), rgba(255,255,255,0)),
    var(--bg1)
}
.vl-pod.p3{
  border-color:rgba(255,170,120,.18);
  background:
    radial-gradient(circle at top, rgba(255,170,120,.10), transparent 42%),
    linear-gradient(180deg, rgba(255,170,120,.04), rgba(255,255,255,0)),
    var(--bg1)
}
.vl-pod.p1::after{content:'✦ ✦';color:rgba(255,215,0,.55);letter-spacing:3px}
.vl-pod.p2::after{color:rgba(190,198,255,.45)}
.vl-pod.p3::after{color:rgba(255,184,120,.45)}
.vl-pod-crown{
  font-size:22px;margin-bottom:12px;display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.04);
  box-shadow:0 0 18px rgba(255,255,255,.06)
}
.vl-pod-av{
  width:44px;height:44px;border-radius:50%;background:var(--bg3);border:1px solid var(--b1);
  display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;
  color:var(--txs);margin:0 auto 10px;overflow:hidden;position:relative;
  box-shadow:0 0 0 4px rgba(255,255,255,.02), 0 0 20px rgba(255,255,255,.05)
}
.vl-pod-av img,.vl-lb-av img{
  width:100%;height:100%;display:block;object-fit:cover;object-position:center 30%;
}
.vl-pod.p1 .vl-pod-av{
  width:54px;height:54px;
  box-shadow:0 0 0 5px rgba(255,215,0,.08), 0 0 28px rgba(255,215,0,.16)
}
.vl-pod-name{
  font-size:13px;font-weight:700;color:var(--tx);
  text-shadow:0 0 12px rgba(255,255,255,.05)
}
.vl-pod.p1 .vl-pod-name{color:#ffd95e;text-shadow:0 0 14px rgba(255,217,94,.25)}
.vl-pod.p2 .vl-pod-name{color:#d8dcff}
.vl-pod.p3 .vl-pod-name{color:#ffc9a1}
.vl-pod-stat{
  font-size:10px;color:var(--live);font-family:var(--fm);margin-top:4px;
  letter-spacing:.4px;text-transform:uppercase
}
.vl-pod.p1 .vl-pod-stat{color:#bdfc7a}
.vl-lb-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--b0);transition:background var(--t1)}
.vl-lb-row:hover{background:var(--bg2)}.vl-lb-row:last-child{border-bottom:none}
.vl-lb-num{width:24px;font-size:11px;font-weight:700;color:var(--txd);font-family:var(--fm);flex-shrink:0}
.vl-lb-av{
  width:30px;height:30px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--txs);flex-shrink:0;overflow:hidden;
  box-shadow:0 0 0 3px rgba(255,255,255,.02)
}
.vl-lb-name{font-size:12px;font-weight:600;color:var(--tx)}
.vl-lb-sub{font-size:10px;color:var(--txd);font-family:var(--fm)}
.vl-lb-stats{text-align:right}

/* ── BILLING ──────────────────────────────────────────── */
.vl-plan{background:var(--bg1);border:1px solid var(--b1);border-radius:var(--r12);padding:20px;margin-bottom:10px;position:relative;transition:border-color var(--t1)}
.vl-plan.current-plan{border-color:var(--live);background:rgba(76,175,80,.04)}
.vl-plan.current-plan .vl-plan-current-tag{display:block}
.vl-plan-current-tag{display:none;font-size:9px;font-weight:700;color:var(--live);font-family:var(--fm);letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}
.vl-plan-badge{position:absolute;top:-1px;right:16px;background:var(--info);color:#fff;font-size:9px;font-weight:700;padding:3px 10px;border-radius:0 0 var(--r6) var(--r6);font-family:var(--fm);letter-spacing:.5px}
.vl-plan-icon{font-size:22px;margin-bottom:8px}
.vl-plan-name{font-size:17px;font-weight:700;color:var(--tx)}
.vl-plan-credits{font-size:11px;color:var(--txd);font-family:var(--fm);margin-bottom:8px}
.vl-plan-price{font-size:28px;font-weight:700;color:var(--tx);margin-bottom:14px}
.vl-plan-price span{font-size:13px;font-weight:400;color:var(--txd)}
.vl-plan-feats{list-style:none;margin-bottom:16px}
.vl-plan-feats li{font-size:12px;color:var(--txs);padding:4px 0;display:flex;align-items:center;gap:8px}
.vl-plan-feats li i{color:var(--live);font-size:10px}
.popular{border-color:var(--b2)}

/* ── STAR RATING ──────────────────────────────────────── */
.vl-star{font-size:20px;cursor:pointer;color:var(--txd);transition:color var(--t1),transform var(--t1)}
.vl-star:hover,.vl-star.active{color:var(--warn);transform:scale(1.15)}

/* ── TOASTS ───────────────────────────────────────────── */
.vl-toasts{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:7px;pointer-events:none}
.vl-toast{
  padding:10px 14px;border-radius:var(--r8);font-size:12px;font-family:var(--fm);
  background:var(--bg3);border:1px solid var(--b2);color:var(--txs);
  animation:toastIn .18s ease;pointer-events:auto;max-width:280px
}
.vl-toast.ok{background:var(--live-bg);border-color:var(--live);color:var(--live)}
.vl-toast.err{background:var(--dead-bg);border-color:var(--dead);color:var(--dead)}
.vl-toast.warn{background:var(--warn-bg);border-color:var(--warn);color:var(--warn)}
@keyframes toastIn{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── PARTICLES ────────────────────────────────────────── */
.vl-particles{position:fixed;inset:0;pointer-events:none;z-index:9990}
.vl-ptcl{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--live);animation:ptcl .9s ease-out forwards}
@keyframes ptcl{0%{opacity:1;transform:translate(0,0) scale(1)}100%{opacity:0;transform:translate(var(--dx),var(--dy)) scale(0)}}

/* ── PROXY ────────────────────────────────────────────── */
#tool-results,
#proxy-results{margin-top:10px;max-height:200px;overflow-y:auto;border-radius:var(--r8);border:1px solid var(--b0);background:var(--bg);padding:6px}
.vl-ri .ri-icon{flex-shrink:0;line-height:1.2;margin-top:1px}
.tool-meta-line{opacity:.82}

/* ── HELPERS ──────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.flex-b{display:flex;align-items:center;justify-content:space-between}
.flex-g{display:flex;align-items:center;gap:8px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt20{margin-top:20px}
.mono{font-family:var(--fm)}.muted{color:var(--txd);font-family:var(--fm);font-size:11px}
.text-n{color:var(--live)}

/* ── SCAN LINE (subtle) ───────────────────────────────── */
.vl-scan{display:none}

/* ── RESPONSIVE ───────────────────────────────────────── */
@media(max-width:768px){
  .vl-sidebar{transform:translateX(-100%)}
  .vl-sidebar.open{transform:translateX(0);box-shadow:8px 0 32px rgba(0,0,0,.6)}
  .vl-main{margin-left:0}
  .vl-sidebar-toggle{display:flex}
  .vl-stat-grid{grid-template-columns:1fr 1fr}
  .vl-alltime-hero-grid,.vl-alltime-panels,.vl-alltime-user-grid{grid-template-columns:1fr}
  .vl-podium{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .vl-meta-strip{flex-direction:column}
  .vl-gate-cost,.vl-tb-chip:not(.always-show){display:none}
}
@media(max-width:480px){
  .vl-page{padding:12px}
  .vl-stat-grid{grid-template-columns:1fr 1fr}
  .vl-auth{padding:12px}
  .vl-auth-card{padding:24px 18px}
  .vl-otp-row{gap:6px}
  .vl-otp-inp{height:42px;font-size:16px}
  .vl-channel{align-items:flex-start}
  .vl-channel .flex-g{flex-shrink:0}
  .flex-b{gap:8px;flex-wrap:wrap}
  .vl-alltime-hero{padding:12px}
  .vl-alltime-kpi,.vl-alltime-user-stat,.vl-alltime-row{padding:12px}
  .vl-alltime-main{gap:10px}
  .vl-alltime-avatar{width:34px;height:34px;border-radius:10px}
  .vl-alltime-metrics{gap:10px}
  .vl-alltime-metric{min-width:48px}
  .vl-alltime-metric-value{font-size:15px}
  .vl-alltime-title{font-size:12px}
  .vl-alltime-subtitle{font-size:9px}
}
