/* ─── HPOS10I ($BITCOIN) palette ───────────────────────────── */
:root{
  --bg-0:#07070b;
  --bg-1:#0f0f16;
  --bg-2:#181826;
  --bg-3:#232339;
  --ink:#f7f7ff;
  --ink-dim:#a8a8c4;
  --orange:#f7931a;      /* bitcoin orange */
  --gold:#ffd700;
  --red:#ff2244;
  --pink:#ff69b4;
  --purple:#8a2be2;
  --blue:#1a7fff;
  --cyan:#00e5ff;
  --green:#00ff88;
  --yellow:#ffe600;
  --glow-gold:0 0 18px rgba(255,215,0,.55), 0 0 40px rgba(247,147,26,.35);
  --glow-red:0 0 20px rgba(255,34,68,.6), 0 0 45px rgba(255,34,68,.3);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg-0);color:var(--ink);font-family:'Russo One','Segoe UI',sans-serif;overflow-x:hidden}
body{
  background:
    radial-gradient(ellipse at top,rgba(247,147,26,.12),transparent 55%),
    radial-gradient(ellipse at bottom right,rgba(255,34,68,.10),transparent 50%),
    radial-gradient(ellipse at bottom left,rgba(138,43,226,.10),transparent 50%),
    var(--bg-0);
  min-height:100vh;
}
button{font-family:inherit;cursor:pointer;border:0}
a{color:var(--gold)}
code{font-family:'Share Tech Mono',monospace}

/* ─── top bar ─────────────────────────────────────────────── */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 24px;background:linear-gradient(180deg,#12121c,#0b0b12);
  border-bottom:2px solid var(--orange);
  box-shadow:0 2px 24px rgba(247,147,26,.35);
  position:sticky;top:0;z-index:50;
}
.brand{display:flex;align-items:center;gap:14px}
.brand .logo{font-size:34px;filter:drop-shadow(0 0 12px var(--gold))}
.brand .name{font-family:'Bungee',sans-serif;font-size:28px;letter-spacing:2px;color:var(--gold);text-shadow:var(--glow-gold)}
.brand .name i{color:var(--red);font-style:italic}
.brand .tag{font-size:11px;color:var(--orange);letter-spacing:2px;opacity:.9}
.bank{display:flex;gap:10px;flex:1;justify-content:center;flex-wrap:wrap}
.bank-cell{
  background:linear-gradient(180deg,#1b1b29,#0f0f1a);
  border:1px solid #2a2a3e;border-radius:8px;padding:6px 14px;min-width:110px;text-align:center;
}
.bank-cell .k{display:block;font-size:10px;color:var(--ink-dim);letter-spacing:1px}
.bank-cell .v{display:block;font-family:'Share Tech Mono',monospace;font-size:20px;color:var(--gold)}
.bank-cell.hot{border-color:var(--orange);box-shadow:0 0 14px rgba(247,147,26,.45)}
.bank-cell.hot .v{color:var(--orange)}
.auth{display:flex;align-items:center;gap:10px}
#youAre{font-size:12px;color:var(--ink-dim)}
#youAre.you-logged{color:var(--green)}

.btn-gold{background:linear-gradient(180deg,#ffd700,#f7931a);color:#1a0f00;padding:9px 18px;border-radius:8px;font-family:'Bungee',sans-serif;font-size:13px;letter-spacing:1px;box-shadow:var(--glow-gold);transition:transform .12s}
.btn-gold:hover{transform:translateY(-1px) scale(1.02)}
.btn-gold:active{transform:translateY(1px)}
.btn-ghost{background:transparent;color:var(--ink-dim);border:1px solid #33334a;padding:8px 16px;border-radius:8px;font-size:12px;letter-spacing:1px}
.btn-copy{background:var(--bg-3);color:var(--gold);padding:6px 12px;border-radius:6px;font-size:11px;letter-spacing:1px}

/* ─── grid ────────────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) 320px;gap:18px;padding:18px;max-width:1700px;margin:0 auto}
@media (max-width:1280px){.grid{grid-template-columns:1fr;}}

/* ─── wheel area ──────────────────────────────────────────── */
.wheel-area{display:flex;flex-direction:column;align-items:center;gap:14px}
.phase-banner{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  width:100%;max-width:760px;padding:10px 18px;border-radius:10px;
  background:linear-gradient(90deg,rgba(247,147,26,.15),rgba(255,34,68,.15));
  border:1px solid var(--orange);font-family:'Bungee',sans-serif;font-size:16px;letter-spacing:2px;
}
#phaseLabel{color:var(--gold);text-shadow:var(--glow-gold)}
.timer{font-family:'Share Tech Mono',monospace;font-size:22px;color:var(--red);text-shadow:var(--glow-red)}
.phase-banner.betting{border-color:var(--green);background:linear-gradient(90deg,rgba(0,255,136,.18),rgba(26,127,255,.15))}
.phase-banner.betting #phaseLabel{color:var(--green);text-shadow:0 0 12px var(--green)}
.phase-banner.spinning{border-color:var(--orange)}
.phase-banner.bonus{border-color:var(--red);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{box-shadow:var(--glow-red)}50%{box-shadow:0 0 40px var(--red)}}

.wheel-wrap{position:relative;width:760px;max-width:92vw;aspect-ratio:1/1}
#wheelCanvas{width:100%;height:100%;filter:drop-shadow(0 0 40px rgba(247,147,26,.55))}
.wheel-pointer{
  position:absolute;top:-4px;left:50%;transform:translateX(-50%);
  width:0;height:0;border-left:22px solid transparent;border-right:22px solid transparent;
  border-top:40px solid var(--gold);filter:drop-shadow(0 0 16px var(--gold));z-index:3;
}
/* Compact dashboard row combining phase + live bets aggregate */
.dashboard{display:flex;gap:10px;width:100%;max-width:760px;flex-wrap:wrap}
.dashboard .phase-banner{flex:2;min-width:240px}
.dashboard .live-bets{flex:1;min-width:220px;max-width:none}

/* Top slot — compact horizontal bar placed below the bankroll card */
.top-slot-row{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-top:14px;padding:10px 16px;
  background:linear-gradient(180deg,#1a1328,#0e0a18);
  border:2px solid var(--gold);border-radius:10px;
  box-shadow:0 0 14px rgba(255,215,0,.3);
  font-family:'Bungee',sans-serif;
}
.top-slot-row .ts-label{font-size:11px;letter-spacing:2px;color:var(--orange)}
.top-slot-row .ts-sep{color:var(--ink-dim);font-size:14px}
.top-slot-row .ts-mult{font-size:22px;color:var(--red);text-shadow:var(--glow-red)}
.top-slot-row .ts-bucket{font-size:16px;color:var(--cyan);letter-spacing:1px}

/* history strip */
.history{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;max-width:760px;margin-top:10px}
.history .h-cell{
  width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-family:'Bungee',sans-serif;font-size:12px;color:#0b0b12;border:1px solid #000;
}

/* ─── live bets banner ────────────────────────────────────── */
.live-bets{
  display:flex;gap:16px;align-items:center;justify-content:center;flex-wrap:wrap;
  width:100%;max-width:760px;padding:8px 16px;border-radius:10px;
  background:linear-gradient(90deg,rgba(0,255,136,.1),rgba(26,127,255,.08));
  border:1px solid rgba(0,255,136,.3);
  font-family:'Share Tech Mono',monospace;font-size:13px;color:var(--ink-dim);
}
.live-bets .lb-lab{font-family:'Bungee',sans-serif;font-size:12px;letter-spacing:2px;color:var(--green);text-shadow:0 0 8px var(--green)}
.live-bets .lb-val{color:var(--ink-dim);font-size:13px}
.live-bets .lb-val b{color:var(--gold);font-size:22px;margin-right:4px;font-family:'Share Tech Mono',monospace}

/* ─── round result modal ──────────────────────────────────── */
.result-card{max-width:520px;text-align:center;border-color:var(--gold);animation:resultPop .4s ease-out}
@keyframes resultPop{from{transform:scale(0.85);opacity:0}to{transform:scale(1);opacity:1}}
.result-wheel{margin:12px 0;padding:18px;background:radial-gradient(circle,rgba(255,215,0,.15),transparent 70%);border-radius:12px}
.result-label{font-family:'Bungee',sans-serif;font-size:34px;letter-spacing:2px;color:var(--gold);text-shadow:var(--glow-gold)}
.result-mult{font-family:'Bungee',sans-serif;font-size:56px;color:var(--red);text-shadow:var(--glow-red);margin-top:6px}
.result-stats{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;margin:14px 0}
.result-stats > div{background:#0a0a12;border:1px solid #2a2a3e;border-radius:6px;padding:8px 4px}
.result-stats .k{display:block;font-size:9px;color:var(--ink-dim);letter-spacing:1px;margin-bottom:3px}
.result-stats .v{display:block;font-family:'Share Tech Mono',monospace;font-size:14px;color:var(--gold)}
.result-payouts{max-height:140px;overflow-y:auto;margin-top:8px;text-align:left;font-family:'Share Tech Mono',monospace;font-size:11px}
.result-payouts .rp-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;padding:4px 8px;border-bottom:1px dashed #222;color:var(--ink-dim)}
.result-payouts .rp-row .a{color:var(--cyan)}
.result-payouts .rp-row .w{color:var(--green)}
.result-timer{height:4px;background:var(--gold);margin-top:12px;border-radius:2px;box-shadow:0 0 10px var(--gold);transform-origin:left;transform:scaleX(1);transition:transform linear}

/* ─── bonus stage — full-viewport takeover ───────────────── */
.bonus-stage{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:90;
  background:radial-gradient(ellipse at center,rgba(20,0,30,.82),rgba(0,0,0,.96));
  backdrop-filter:blur(6px);
  animation:bonusFadeIn .5s ease-out;
}
.bonus-stage.hidden{display:none}
@keyframes bonusFadeIn{
  from{opacity:0}
  to{opacity:1}
}
#bonusCanvas{
  width:min(96vw, 1400px);
  height:auto;
  aspect-ratio:1400/800;
  max-height:78vh;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(11,11,22,.98),rgba(26,10,36,.98));
  border:4px solid var(--red);
  box-shadow:var(--glow-red), 0 0 120px rgba(0,0,0,.9), inset 0 0 80px rgba(0,0,0,.5);
}

/* Intro card — pops up for the first ~2 seconds of every bonus */
.bonus-intro{
  position:absolute;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  text-align:center;
  z-index:2;
  pointer-events:none;
  animation:bonusIntroShow 2.2s ease-out forwards;
}
.bonus-intro-label{
  font-family:'Bungee',sans-serif;
  font-size:24px;letter-spacing:6px;
  color:var(--orange);
  text-shadow:0 0 22px var(--orange);
  margin-bottom:10px;
}
.bonus-intro-name{
  font-family:'Bungee',sans-serif;
  font-size:96px;letter-spacing:4px;
  color:var(--gold);
  text-shadow:
    0 0 30px var(--gold),
    0 0 60px var(--orange),
    0 0 120px var(--red);
  animation:bonusNamePulse 1s ease-in-out infinite;
}
.bonus-intro-sub{
  font-family:'Bungee',sans-serif;
  font-size:18px;letter-spacing:3px;
  color:var(--ink-dim);
  margin-top:14px;
}
@keyframes bonusIntroShow{
  0%  {opacity:0; transform:translate(-50%,-50%) scale(.6)}
  15% {opacity:1; transform:translate(-50%,-50%) scale(1.15)}
  25% {opacity:1; transform:translate(-50%,-50%) scale(1)}
  80% {opacity:1; transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0; transform:translate(-50%,-50%) scale(.85)}
}
@keyframes bonusNamePulse{
  0%,100%{filter:brightness(1) hue-rotate(0deg)}
  50%    {filter:brightness(1.4) hue-rotate(10deg)}
}

.bonus-banner{
  position:absolute;top:24px;left:24px;right:24px;
  text-align:center;font-family:'Bungee',sans-serif;font-size:34px;
  color:var(--gold);text-shadow:var(--glow-gold);pointer-events:none;
  letter-spacing:4px;
  z-index:3;
}
.bonus-feed{
  position:absolute;bottom:16px;left:16px;right:16px;
  display:flex;gap:6px;overflow-x:auto;padding:6px;
  font-family:'Share Tech Mono',monospace;font-size:12px;
  pointer-events:auto;
  scrollbar-width:thin;
  z-index:3;
}
.bonus-feed .bf-row{
  flex:0 0 auto;
  background:rgba(0,0,0,.75);
  border:1px solid var(--gold);
  border-radius:6px;padding:6px 12px;
  color:var(--gold);white-space:nowrap;
}
.bonus-feed .bf-row .addr{color:var(--cyan);margin-right:6px}
.bonus-feed .bf-row .mult{color:var(--green);font-weight:bold}
.bonus-feed .bf-row.win{border-color:var(--green);box-shadow:0 0 14px var(--green);animation:bfFlash .5s}
@keyframes bfFlash{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* ─── demo bar ────────────────────────────────────────────── */
.demo-bar{display:flex;align-items:center;gap:6px;margin-top:12px;padding:8px 12px;background:rgba(255,255,255,.03);border:1px dashed #2a2a3e;border-radius:8px;flex-wrap:wrap;max-width:760px}
.demo-label{font-size:10px;letter-spacing:2px;color:var(--ink-dim);font-family:'Bungee',sans-serif}
.demo-btn{font-size:11px;padding:6px 12px}
.demo-btn:hover{border-color:var(--gold);color:var(--gold)}

/* ─── bet area ────────────────────────────────────────────── */
.bet-area{background:linear-gradient(180deg,#0e0e18,#090912);border:1px solid #1e1e2e;border-radius:12px;padding:16px}
.section-title{font-family:'Bungee',sans-serif;font-size:17px;letter-spacing:2px;color:var(--orange);margin:0 0 6px;text-shadow:0 0 12px rgba(247,147,26,.5)}
.bet-hint{font-size:12px;color:var(--ink-dim);margin:0 0 12px}
.bucket-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;position:relative;transition:opacity .2s}
.bucket-grid.locked{opacity:.45}
.bucket-grid.locked .bucket{cursor:not-allowed;pointer-events:none;filter:grayscale(.7)}
.bucket-grid.locked::after{
  content:'🔒 BETS CLOSED';
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Bungee',sans-serif;font-size:24px;letter-spacing:3px;
  color:var(--red);text-shadow:var(--glow-red);
  pointer-events:none;
  background:rgba(0,0,0,.35);
  border-radius:10px;
  backdrop-filter:blur(1px);
}
.bucket{
  background:linear-gradient(180deg,var(--bg-2),var(--bg-1));
  border:2px solid #2a2a40;border-radius:12px;padding:14px;cursor:pointer;
  transition:transform .12s,box-shadow .12s,border-color .12s;position:relative;overflow:hidden;
}
.bucket:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:var(--glow-gold)}
.bucket::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 0%,var(--bcol,#fff),transparent 60%);opacity:.14;pointer-events:none}
.bucket .b-label{font-family:'Bungee',sans-serif;font-size:26px;letter-spacing:1px;color:var(--bcol,var(--gold));text-shadow:0 0 14px var(--bcol,var(--gold))}
.bucket .b-payout{font-size:13px;color:var(--ink-dim)}
.bucket .b-stats{display:flex;justify-content:space-between;align-items:baseline;margin-top:10px;font-family:'Share Tech Mono',monospace;color:var(--ink-dim)}
.bucket .b-stats span{font-size:12px}
.bucket .b-stats b.b-count{font-size:22px;color:var(--gold);display:inline-block;margin-left:4px}
.bucket .b-total{color:var(--gold);font-size:18px}
.bucket .b-bettors{margin-top:8px;display:flex;flex-wrap:wrap;gap:3px}
.bucket .b-bettors .chip{font-size:9px;background:#1a1a2a;color:var(--ink-dim);padding:2px 6px;border-radius:4px;font-family:'Share Tech Mono',monospace}
.bucket.win{
  border-color:var(--gold);
  transform:scale(1.04);
  animation:winPulse 1.2s ease-in-out infinite;
}
@keyframes winPulse{
  0%,100%{box-shadow:0 0 30px var(--gold), inset 0 0 14px rgba(255,215,0,.28)}
  50%    {box-shadow:0 0 60px var(--gold), inset 0 0 26px rgba(255,215,0,.5)}
}

/* bet landed — quick tilt/scale pulse on the bucket card */
.bucket.bet-pulse{
  animation:betPulse .6s cubic-bezier(.2,1.6,.3,1);
  border-color:var(--green) !important;
  box-shadow:0 0 28px rgba(0,255,136,.55), inset 0 0 16px rgba(0,255,136,.2);
}
@keyframes betPulse{
  0%  {transform:scale(1) rotate(0)}
  25% {transform:scale(1.07) rotate(-1.3deg)}
  50% {transform:scale(1.03) rotate(1.1deg)}
  75% {transform:scale(1.045) rotate(-.5deg)}
  100%{transform:scale(1) rotate(0)}
}

/* number shake — triggers on updates to bet counts / totals / live aggregate */
.num-shake{
  display:inline-block;
  animation:numShake .55s ease-out;
}
@keyframes numShake{
  0%,100%{transform:translate(0,0);color:inherit;text-shadow:none}
  15% {transform:translate(-2px,-1px);color:var(--green);text-shadow:0 0 10px var(--green)}
  30% {transform:translate( 2px, 1px);color:var(--green);text-shadow:0 0 14px var(--green)}
  45% {transform:translate(-2px, 1px);color:var(--gold);text-shadow:0 0 10px var(--gold)}
  60% {transform:translate( 1px,-1px);color:var(--gold)}
  80% {transform:translate(-1px, 0)}
}

/* floating +X SOL bubble that rises from the center of the bucket */
.bet-float{
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,0);
  font-family:'Bungee',sans-serif;
  font-size:16px; letter-spacing:1px;
  color:var(--green);
  text-shadow:0 0 14px var(--green), 0 0 22px rgba(0,255,136,.55);
  pointer-events:none;
  z-index:6;
  animation:floatUp 1.8s cubic-bezier(.2,.7,.3,1) forwards;
  white-space:nowrap;
}
@keyframes floatUp{
  0%  {opacity:0; transform:translate(-50%, 8px) scale(.7)}
  15% {opacity:1; transform:translate(-50%, 0) scale(1.15)}
  30% {transform:translate(-50%,-8px) scale(1)}
  100%{opacity:0; transform:translate(-50%,-60px) scale(.9)}
}

/* ─── bankroll investors ──────────────────────────────────── */
.bankroll{margin-top:18px;padding:14px;border-radius:12px;border:1px dashed var(--orange);background:linear-gradient(180deg,rgba(247,147,26,.06),rgba(255,215,0,.03))}
.bankroll .section-title.small{font-size:14px;margin-bottom:4px}
.bankroll-stats{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;margin:10px 0 12px}
.bcell{background:#0a0a12;border:1px solid #2a2a3e;border-radius:6px;padding:6px 8px;text-align:center}
.bcell .k{display:block;font-size:9px;color:var(--ink-dim);letter-spacing:1px}
.bcell .v{display:block;font-family:'Share Tech Mono',monospace;font-size:13px;color:var(--gold)}
.invest-positions{margin-top:10px;max-height:160px;overflow-y:auto;font-size:11px;font-family:'Share Tech Mono',monospace}
.invest-positions .ip-row{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;padding:4px 6px;border-bottom:1px dashed #222;color:var(--ink-dim)}
.invest-positions .ip-row .addr{color:var(--cyan)}
.invest-positions .ip-row .amt{color:var(--gold)}
.invest-positions .ip-row .got{color:var(--green)}
.invest-positions .ip-row .days{color:var(--orange)}

/* Investooor ranking tab — read-only leaderboard of investor addresses */
.inv-ranking{flex:1;min-height:0;overflow-y:auto;padding:4px}
.inv-ranking .ir-head{
  display:grid;grid-template-columns:26px 1fr auto;gap:6px;
  padding:8px 10px;font-size:9px;color:var(--ink-dim);letter-spacing:1.5px;
  border-bottom:1px solid #222;
}
.inv-ranking .ir-row{
  display:grid;grid-template-columns:26px 1fr auto;gap:8px;
  padding:10px 10px;align-items:center;
  border-bottom:1px solid #161622;font-size:12px;
}
.inv-ranking .ir-row .rank{
  color:var(--gold);font-family:'Bungee',sans-serif;font-size:14px;text-align:center;
}
.inv-ranking .ir-row .rank.top1{color:var(--gold);text-shadow:0 0 10px var(--gold)}
.inv-ranking .ir-row .rank.top2{color:#c0c0c0;text-shadow:0 0 8px #c0c0c0}
.inv-ranking .ir-row .rank.top3{color:#cd7f32;text-shadow:0 0 8px #cd7f32}
.inv-ranking .ir-row .addr{font-family:'Share Tech Mono',monospace;color:var(--cyan);font-size:11px}
.inv-ranking .ir-row .sub{font-size:10px;color:var(--ink-dim);margin-top:2px}
.inv-ranking .ir-row .amt{text-align:right}
.inv-ranking .ir-row .amt .sol{color:var(--gold);font-family:'Share Tech Mono',monospace;font-size:13px}
.inv-ranking .ir-row .amt .got{color:var(--green);font-family:'Share Tech Mono',monospace;font-size:10px;display:block}
.inv-ranking .ir-empty{text-align:center;padding:30px 20px;color:var(--ink-dim);font-size:12px;font-style:italic}

/* ─── side area (chat / lb) ───────────────────────────────── */
.side-area{background:linear-gradient(180deg,#0e0e18,#090912);border:1px solid #1e1e2e;border-radius:12px;padding:10px;display:flex;flex-direction:column;min-height:620px}
.tabs{display:flex;gap:4px;margin-bottom:8px}
.tab{flex:1;background:#121220;color:var(--ink-dim);padding:9px 8px;font-size:11px;letter-spacing:1px;border-radius:6px}
.tab.active{background:linear-gradient(180deg,var(--orange),#9a5800);color:#0b0b12}
.tab-pane{display:none;flex:1;min-height:0;flex-direction:column}
.tab-pane.active{display:flex}
.chat-log{flex:1;overflow-y:auto;padding:8px;font-size:13px;background:#060608;border-radius:8px;border:1px solid #1a1a2a;min-height:0}
.chat-log .msg{margin-bottom:5px;word-wrap:break-word}
.chat-log .msg .u{font-weight:bold;margin-right:6px}
.chat-log .sys{color:var(--orange);font-style:italic;font-size:11px}
.chat-form{display:flex;gap:6px;margin-top:8px}
.chat-form input{flex:1;background:#0a0a12;color:var(--ink);border:1px solid #2a2a3e;border-radius:6px;padding:9px 12px;font-family:inherit;font-size:13px}
.chat-form input:focus{outline:0;border-color:var(--gold)}
.chat-form button{padding:9px 14px;font-size:11px}
.leaderboard{overflow-y:auto;flex:1;min-height:0;padding:4px}
.lb-empty{text-align:center;padding:30px 12px;color:var(--ink-dim);font-style:italic;font-size:12px}
.lb-row{
  display:grid;grid-template-columns:32px 1fr auto;gap:10px;
  padding:10px 12px;
  border-bottom:1px solid #161622;
  align-items:center;
}
.lb-row .rank{
  color:var(--gold);font-family:'Bungee',sans-serif;font-size:15px;text-align:center;
}
.lb-row .rank.top1{color:var(--gold);text-shadow:0 0 12px var(--gold)}
.lb-row .rank.top2{color:#c0c0c0;text-shadow:0 0 10px #c0c0c0}
.lb-row .rank.top3{color:#cd7f32;text-shadow:0 0 10px #cd7f32}
.lb-row .lb-body{min-width:0}
.lb-row .addr{font-family:'Share Tech Mono',monospace;color:var(--cyan);font-size:12px;overflow:hidden;text-overflow:ellipsis}
.lb-row .lb-sub{color:var(--ink-dim);font-size:10px;margin-top:2px;font-family:'Share Tech Mono',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-row .lb-net{
  font-family:'Bungee',sans-serif;font-size:16px;letter-spacing:.5px;text-align:right;white-space:nowrap;
}
.lb-row .lb-net .unit{font-size:9px;color:var(--ink-dim);margin-left:3px}
.lb-row .lb-net.net-pos{color:var(--green);text-shadow:0 0 10px rgba(0,255,136,.5)}
.lb-row .lb-net.net-neg{color:var(--red);text-shadow:0 0 10px rgba(255,34,68,.5)}
.lb-row .lb-net.net-zero{color:var(--ink-dim)}
.online-list{overflow-y:auto;flex:1;padding:8px}
.online-list .u-row{padding:6px 8px;font-size:13px}
.online-list .u-row .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);margin-right:8px;box-shadow:0 0 8px var(--green)}

/* Bet history feed — scrolling list of every bet placed (newest on top) */
.bet-history{flex:1;min-height:0;overflow-y:auto;padding:4px}
.bet-history .bh-empty{text-align:center;padding:30px 12px;color:var(--ink-dim);font-style:italic;font-size:12px}
.bet-history .bh-row{
  display:grid;grid-template-columns:42px 1fr auto;gap:8px;
  padding:8px 10px;align-items:center;
  border-bottom:1px solid #161622;
  font-family:'Share Tech Mono',monospace;font-size:11px;
  animation:bhSlideIn .35s ease-out;
}
@keyframes bhSlideIn{
  from{opacity:0;transform:translateX(-16px)}
  to  {opacity:1;transform:translateX(0)}
}
.bet-history .bh-row .time{color:var(--ink-dim);font-size:10px}
.bet-history .bh-row .addr{color:var(--cyan);font-size:11px}
.bet-history .bh-row .bucket{font-family:'Bungee',sans-serif;font-size:10px;letter-spacing:1px;display:inline-block;padding:1px 6px;border-radius:3px;margin-top:2px;color:#0b0b12;background:var(--bcol,var(--gold))}
.bet-history .bh-row .sol{color:var(--gold);font-family:'Bungee',sans-serif;font-size:13px;text-align:right}

/* ─── modals ──────────────────────────────────────────────── */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:12px;overflow-y:auto}
.modal.hidden{display:none}
.modal-card{background:linear-gradient(180deg,#12121e,#070711);border:2px solid var(--orange);border-radius:14px;padding:24px 28px;max-width:460px;width:100%;max-height:calc(100vh - 24px);overflow-y:auto;box-shadow:var(--glow-gold)}

/* ─── bet modal bits ──────────────────────────────────────── */
.bet-amount-row{margin:14px 0 8px}
.bet-amount-label{display:block;font-size:10px;letter-spacing:2px;color:var(--orange);margin-bottom:6px}
.bet-amount-input input{width:100%;background:#0a0a12;color:var(--gold);border:2px solid #2a2a3e;border-radius:8px;padding:14px 16px;font-family:'Share Tech Mono',monospace;font-size:22px;text-align:center}
.bet-amount-input input:focus{outline:0;border-color:var(--gold);box-shadow:0 0 16px rgba(255,215,0,.35)}
.bet-quick{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.bet-quick button{flex:1;min-width:54px;min-height:40px;background:#1a1a2a;color:var(--ink-dim);border:1px solid #2a2a3e;border-radius:6px;padding:8px 10px;font-family:'Share Tech Mono',monospace;font-size:13px;cursor:pointer;transition:all .12s}
.bet-quick button:hover,.bet-quick button:active{background:#2a2a3e;color:var(--gold);border-color:var(--gold)}

.btn-phantom{
  display:block;width:100%;margin:14px 0 8px;
  background:linear-gradient(180deg,#ab9ff2,#4e44ce);
  color:#fff;padding:16px 20px;border:0;border-radius:10px;
  font-family:'Bungee',sans-serif;font-size:15px;letter-spacing:1.5px;
  cursor:pointer;min-height:54px;
  box-shadow:0 0 24px rgba(171,159,242,.55), 0 4px 0 #2a2480;
  transition:transform .12s, box-shadow .12s;
}
.btn-phantom:hover{transform:translateY(-1px);box-shadow:0 0 32px rgba(171,159,242,.7), 0 5px 0 #2a2480}
.btn-phantom:active{transform:translateY(2px);box-shadow:0 0 16px rgba(171,159,242,.45), 0 2px 0 #2a2480}

.or-divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--ink-dim);font-size:10px;letter-spacing:2px}
.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,#333,transparent)}
.modal-card h2{font-family:'Bungee',sans-serif;color:var(--gold);margin:0 0 6px;letter-spacing:2px;text-shadow:var(--glow-gold)}
.modal-sub{font-size:12px;color:var(--ink-dim);margin:0 0 16px}
.modal-card label{display:block;font-size:11px;color:var(--orange);letter-spacing:1px;margin-bottom:10px}
.modal-card input{display:block;width:100%;margin-top:4px;background:#0a0a12;color:var(--ink);border:1px solid #2a2a3e;border-radius:6px;padding:10px 12px;font-family:inherit;font-size:14px}
.modal-card input:focus{outline:0;border-color:var(--gold)}
.modal-actions{display:flex;justify-content:space-between;gap:10px;margin-top:14px}
.modal-actions.single{justify-content:center}
.err{color:var(--red);font-size:11px;min-height:14px;margin-top:6px}
.qr-wrap{display:flex;justify-content:center;margin:10px 0;padding:12px;background:#fff;border-radius:10px}
#betQr{width:220px;height:220px}
.addr-row{display:flex;gap:8px;align-items:center;background:#0a0a12;border:1px solid #2a2a3e;border-radius:6px;padding:8px 10px;margin-top:10px}
.addr-row code{flex:1;font-size:11px;color:var(--cyan);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ─── MOBILE (≤768px) ────────────────────────────────────── */
@media (max-width: 900px) {
  .grid{grid-template-columns:1fr;padding:10px;gap:12px}
  .topbar{flex-wrap:wrap;padding:10px 12px;gap:8px;position:relative}
  .brand .logo{font-size:26px}
  .brand .name{font-size:20px;letter-spacing:1px}
  .brand .tag{display:none}
  .bank{gap:6px;flex:1 1 100%;order:3}
  .bank-cell{min-width:0;flex:1;padding:4px 6px}
  .bank-cell .k{font-size:8px}
  .bank-cell .v{font-size:12px}
  .auth{gap:6px}
  .btn-gold{padding:8px 14px;font-size:11px}
  .wheel-wrap{max-width:95vw;width:95vw}
  .phase-banner{font-size:13px;padding:8px 12px;letter-spacing:1px}
  .timer{font-size:18px}
  .live-bets{font-size:11px;gap:10px;padding:6px 10px}
  .live-bets .lb-lab{font-size:9px}
  .live-bets .lb-val b{font-size:14px}
  .top-slot{width:180px;top:-68px;padding:6px 10px}
  .ts-label{font-size:9px}
  .ts-reel{font-size:16px}
  .wheel-pointer{border-left-width:16px;border-right-width:16px;border-top-width:30px}
  .bucket-grid{grid-template-columns:1fr 1fr}
  .bucket{padding:12px;min-height:90px}
  .bucket .b-label{font-size:20px}
  .bucket .b-payout{font-size:11px}
  .bucket .b-stats{font-size:10px}
  .side-area{min-height:420px;padding:8px}
  .tab{font-size:10px;padding:10px 6px}
  .chat-log{font-size:12px;padding:6px}
  .chat-form input{padding:10px 12px;font-size:13px;min-height:44px}
  .chat-form button{min-height:44px;min-width:60px}
  .demo-bar{max-width:95vw;font-size:10px}
  .demo-btn{padding:8px 10px;font-size:10px;min-height:38px;flex:1}
  .bankroll-stats{grid-template-columns:1fr 1fr}
  .modal-card{padding:18px 16px;max-height:calc(100vh - 20px)}
  .modal-card h2{font-size:18px;letter-spacing:1px}
  .result-stats{grid-template-columns:1fr 1fr}
  .result-mult{font-size:42px}
  .result-label{font-size:26px}
  .btn-phantom{font-size:14px;padding:14px 16px;min-height:52px}
  .bet-quick button{min-height:44px;font-size:14px}
  .bet-amount-input input{font-size:24px;padding:16px}
  .bonus-stage{align-items:flex-start;padding-top:14%}
  #bonusCanvas{width:98%}
  .bonus-banner{font-size:20px;top:10px}
  .bonus-feed .bf-row{font-size:10px;padding:4px 7px}
}
@media (max-width: 480px) {
  .bank{gap:4px}
  .bank-cell{padding:3px 4px}
  .bank-cell .k{font-size:7px;letter-spacing:0}
  .bank-cell .v{font-size:11px}
  .btn-gold{padding:7px 10px;font-size:10px}
  .brand .name{font-size:18px}
  .bucket-grid{grid-template-columns:1fr 1fr;gap:8px}
  .bucket{padding:10px}
  .bucket .b-label{font-size:18px}
  .demo-bar{gap:4px;padding:6px 8px}
  .demo-btn{font-size:9px;padding:6px 8px;min-width:0}
  .demo-label{display:none}
  .side-area{min-height:360px}
  .result-mult{font-size:36px}
  .modal-card{padding:14px 12px}
  .bet-quick{gap:4px}
  .bet-quick button{padding:6px 4px;font-size:12px}
}

/* ─── Touch-friendly hover alternatives ───────────────────── */
@media (hover: none) {
  .bucket:hover{transform:none}
  .btn-gold:hover{transform:none}
}
