
/* ─── SPLASH SCREEN ─────────────────────────────────────────── */
#splash{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(50px);
  -webkit-backdrop-filter:blur(50px);
  transition:opacity .7s cubic-bezier(.4,0,.2,1);
  will-change:opacity;
}
#splash.splash-hide{opacity:0;pointer-events:none;}
#splash.splash-gone{display:none;}

.splash-bg{display:none;}

.splash-inner{
  display:flex;flex-direction:column;
  align-items:center;gap:0;
}

/* logo — fixed at top, very large */
.splash-logo{
  position:absolute;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  height:180px;
  opacity:0;
  animation:splashDown .55s .05s cubic-bezier(.2,.8,.3,1) forwards;
  filter:drop-shadow(0 4px 32px rgba(0,0,0,.8));
}
@keyframes splashDown{
  from{opacity:0;transform:translateX(-50%) translateY(-24px)}
  to{opacity:1;transform:translateX(-50%) translateY(0)}
}

/* spinning rings */
.splash-wheel-wrap{position:relative;width:130px;height:130px;display:flex;align-items:center;justify-content:center;}
.splash-ring{position:absolute;border-radius:50%;border:1.5px solid transparent;}
.splash-ring1{
  width:124px;height:124px;
  border-color:rgba(255,105,35,.45) rgba(255,105,35,.06) rgba(255,105,35,.45) rgba(255,105,35,.06);
  animation:splashRing1 2s linear infinite;
}
.splash-ring2{
  width:106px;height:106px;
  border-color:rgba(255,200,80,.25) rgba(255,200,80,.04) rgba(255,200,80,.25) rgba(255,200,80,.04);
  animation:splashRing2 3.2s linear infinite reverse;
}
@keyframes splashRing1{to{transform:rotate(360deg)}}
@keyframes splashRing2{to{transform:rotate(360deg)}}

/* main wheel emoji */
.splash-wheel{
  font-size:72px;line-height:1;
  animation:splashSpin 1.4s linear infinite;
  filter:drop-shadow(0 0 20px rgba(255,105,35,.8)) drop-shadow(0 0 50px rgba(255,105,35,.4));
  will-change:transform;
}
@keyframes splashSpin{to{transform:rotate(360deg)}}

/* shimmer bar */
.splash-bar{
  width:180px;height:3px;border-radius:3px;
  background:rgba(255,255,255,.08);
  margin-top:28px;overflow:hidden;
  opacity:0;animation:splashUp .4s .4s ease forwards;
}
.splash-bar-fill.splash-fill-green{
  background:linear-gradient(90deg,#30d158,#1fa843) !important;
  box-shadow:0 0 10px rgba(48,209,88,.7) !important;
  transition:width .4s cubic-bezier(.4,0,.2,1), background .5s ease, box-shadow .5s ease !important;
}
.splash-bar-fill{
  height:100%;width:10%;border-radius:3px;
  background:linear-gradient(90deg,#ff6422,#ffb347);
  box-shadow:0 0 8px rgba(255,100,34,.6);
  transition:width .5s cubic-bezier(.4,0,.2,1);
  animation:splashBarAuto 4s cubic-bezier(.1,0,.3,1) forwards;
}
@keyframes splashBarAuto{
  0%{width:8%}
  40%{width:45%}
  70%{width:65%}
  100%{width:80%}
}
.splash-status{
  font-size:11px;font-weight:500;letter-spacing:.8px;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-top:10px;
  opacity:0;animation:splashUp .4s .5s ease forwards;
  transition:opacity .3s;
  font-family:system-ui;
}
@keyframes splashUp{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:none}
}
/* ─── BLOCKED OVERLAY ────────────────────────────────────────── */
#blockedOverlay{
  position:fixed;inset:0;z-index:10000;
  display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(60px);
  -webkit-backdrop-filter:blur(60px);
  opacity:0;pointer-events:none;
  transition:opacity .5s ease;
}
#blockedOverlay.visible{opacity:1;pointer-events:all;}
.blocked-card{
  max-width:420px;width:100%;
  background:rgba(20,10,10,.85);
  border:1px solid rgba(255,69,58,.25);
  border-radius:24px;
  padding:40px 32px 36px;
  text-align:center;
  box-shadow:0 0 60px rgba(255,69,58,.18), 0 24px 60px rgba(0,0,0,.5);
}
.blocked-icon{font-size:52px;margin-bottom:16px;}
.blocked-title{font-size:22px;font-weight:900;color:#fff;margin-bottom:14px;letter-spacing:-.3px;}
.blocked-text{font-size:14px;line-height:1.7;color:rgba(255,255,255,.65);margin-bottom:24px;}
.blocked-footer{font-size:12px;color:rgba(255,69,58,.8);font-weight:600;letter-spacing:.3px;}
/* ─────────────────────────────────────────────────────────────── */
/* ─── RECONNECT OVERLAY ──────────────────────────────────────── */
#reconnectOverlay{
  position:fixed;inset:0;z-index:9998;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(50px);
  -webkit-backdrop-filter:blur(50px);
  opacity:0;pointer-events:none;
  transition:opacity .4s ease;
}
#reconnectOverlay.visible{opacity:1;pointer-events:all;}
#reconnectOverlay .splash-bar{opacity:1;animation:none;}
#reconnectOverlay .splash-status{opacity:1;animation:none;}
/* ─────────────────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;touch-action:manipulation}
input,textarea{user-select:text;-webkit-user-select:text}
:root{
  --blur:saturate(180%) blur(24px);
  --green:#30d158;--red:#ff453a;--gold:#ffd60a;--orange:#ff9f0a;
  --r-sm:10px;--r-md:14px;--r-lg:20px;--r-xl:26px;
}

/* DARK THEME (default) */
body{
  --glass:rgba(255,255,255,0.06);
  --glass-b:rgba(255,255,255,0.10);
  --text:rgba(255,255,255,0.92);
  --text2:rgba(255,255,255,0.48);
  --text3:rgba(255,255,255,0.28);
  --bg-base:#151515;
  --bg-panel:rgba(255,255,255,0.05);
  --bg-card:rgba(255,255,255,0.06);
  --bg-input:rgba(0,0,0,0.3);
  --border-card:rgba(255,255,255,0.10);
  --row-hover:rgba(255,255,255,0.04);
  --sd-bg:rgba(22,22,22,0.99);
}

/* LIGHT THEME */
body.light{
  --glass:rgba(0,0,0,0.04);
  --glass-b:rgba(0,0,0,0.09);
  --text:rgba(0,0,0,0.88);
  --text2:rgba(0,0,0,0.45);
  --text3:rgba(0,0,0,0.28);
  --bg-base:#eef0f4;
  --bg-panel:#ffffff;
  --bg-card:#ffffff;
  --bg-input:rgba(0,0,0,0.05);
  --border-card:rgba(0,0,0,0.09);
  --row-hover:rgba(0,0,0,0.04);
  --sd-bg:#f5f6fa;
}

html,body{height:100%;overflow:hidden;background:#151515}
body.light{background:#eef0f4}
body{font-family:-apple-system,'Helvetica Neue',sans-serif;color:var(--text);display:flex;flex-direction:column;transition:background .3s}

/* BG */
.bg{position:fixed;inset:0;z-index:0;transition:background .3s,opacity .3s;background:#151515}
body.light .bg{background:#eef0f4}
.bg-g{display:none}
.orb{display:none}

.app{position:relative;z-index:1;height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* ── TOP BAR ── */
.topbar{
  flex-shrink:0;
  position:relative;
  padding:10px 14px 8px;
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-panel);
  backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
  border-bottom:.5px solid var(--glass-b);
}
.tb-left{display:flex;align-items:center;gap:8px}
.tb-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center}
.logo-img{height:78px;width:auto;display:block;margin-top:7px}
.tb-right{display:flex;align-items:center;gap:6px}
.online-pill{display:flex;align-items:center;gap:4px;background:var(--glass);border:.5px solid var(--glass-b);border-radius:20px;padding:4px 10px;font-size:14px;font-weight:700;color:var(--text)}
.odot{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 5px var(--green);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.bal-wrap{background:rgba(255,255,255,0.09);border:.5px solid rgba(255,255,255,0.13);border-radius:999px;padding:3px;display:flex;align-items:center;gap:0}
.bal-n{font-size:14px;font-weight:700;color:var(--green);padding:0 4px 0 10px}
.bal-c{font-size:14px;font-weight:700;color:var(--green);padding-right:12px}

/* ── HISTORY BAR ── */
.hbar{flex-shrink:0;padding:5px 12px;display:flex;gap:5px;overflow-x:auto;background:var(--bg-panel);border-bottom:.5px solid var(--glass-b)}
.hbar::-webkit-scrollbar{display:none}
.hp{padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;flex-shrink:0}
.hp1{background:rgba(255,69,58,.15);color:#ff6b61;border:.5px solid rgba(255,69,58,.3)}
.hp2{background:rgba(48,209,88,.1);color:#30d158;border:.5px solid rgba(48,209,88,.2)}
.hp3{background:rgba(94,92,230,.16);color:#a78bfa;border:.5px solid rgba(94,92,230,.28)}
.hp4{background:rgba(255,214,10,.12);color:#ffd60a;border:.5px solid rgba(255,214,10,.25)}

/* ── PAGES ── */
.pages{flex:1;overflow:hidden;position:relative;min-height:0}
.page{position:absolute;inset:0;display:flex;flex-direction:column;opacity:0;pointer-events:none;transition:opacity .2s}
.page.active{opacity:1;pointer-events:all}

/* ── GAME PAGE ── */
#pgGame{overflow:hidden}
.cwrap{position:relative;flex:1;min-height:0;overflow:hidden}
#gc{width:100%;height:100%;display:block}

/* pgBets scroll */
#pgBets{overflow:hidden}
#pgBets .bets-hdr-wrap{flex-shrink:0}
#pgBets .bhdr{flex-shrink:0}
#pgSidebar .bhdr,#pgSidebar .brow{grid-template-columns:minmax(0,1fr) 30px 50px 60px}
#pgBets #bBody{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0}

/* pgSettings scroll */
#pgSettings{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 14px 56px}
#pgSettings::-webkit-scrollbar{width:2px}
#pgSettings::-webkit-scrollbar-thumb{background:var(--glass-b);border-radius:1px}

.moverlay{
  position:absolute;
  top:12%;
  left:50%;
  transform:translateX(-50%);
  text-align:center;
  pointer-events:none;
  z-index:5
}
.bigx{font-size:72px;font-weight:900;line-height:1;letter-spacing:-2px;font-variant-numeric:tabular-nums;transition:color .1s;text-shadow:0 2px 20px rgba(0,0,0,.7)}
.bigx.fly{color:#fff;text-shadow:0 0 60px rgba(255,255,255,.2)}
.bigx.wait{color:var(--text3);font-size:20px;font-weight:500;letter-spacing:0}
.bigx.crash{color:var(--red);text-shadow:0 0 34px rgba(255,69,58,.42),0 0 64px rgba(255,69,58,.24);animation:shk .22s,crashZoom 3.6s .04s cubic-bezier(.2,.76,.24,1) forwards}
@keyframes crashZoom{
  0%{transform:scale(.74) translateY(11%);opacity:.55}
  22%{transform:scale(0.98) translateY(12%);opacity:.92}
  100%{transform:scale(1.28) translateY(13%);opacity:.72}
}
.subx{display:none}
.blowout-txt{
  display:none;
  position:absolute;top:61%;left:50%;
  transform:translate(-50%,-50%) scale(0.74);
  font-size:clamp(44px,5vh,96px);font-weight:900;font-family:system-ui;
  letter-spacing:-1px;text-transform:uppercase;
  color:#fff;opacity:1;

  pointer-events:none;z-index:6;white-space:nowrap;
}
.blowout-txt.show{display:block;animation:blowoutCrash 3.6s .04s cubic-bezier(.2,.76,.24,1) forwards}
@keyframes blowoutCrash{
  0%  {opacity:1;transform:translate(-50%,-50%) scale(0.74)}
  22% {opacity:1;transform:translate(-50%,-50%) scale(0.98)}
  100%{opacity:.85;transform:translate(-50%,-50%) scale(1.28)}
}
.cdx{display:none}
@keyframes shk{0%,100%{transform:translateX(-50%)}25%{transform:translateX(calc(-50% - 7px))}75%{transform:translateX(calc(-50% + 7px))}}

.flew{display:none!important;position:absolute;top:20%;left:50%;transform:translateX(-50%);
  background:rgba(255,69,58,.08);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border:.5px solid rgba(255,69,58,.35);border-radius:var(--r-xl);
  padding:14px 36px;text-align:center;display:none;z-index:8}
.flew.show{display:block;animation:popin .25s cubic-bezier(.34,1.56,.64,1)}
.flew-t{font-size:10px;color:rgba(255,69,58,.7);letter-spacing:3px;text-transform:uppercase;margin-bottom:3px;font-weight:600}
.flew-v{font-size:44px;font-weight:900;color:var(--red);line-height:1;letter-spacing:-2px;text-shadow:0 0 28px rgba(255,69,58,.5)}
@keyframes popin{from{opacity:0;transform:translateX(-50%) scale(.8)}to{opacity:1;transform:translateX(-50%) scale(1)}}

/* ── CONTROLS (2 slots) ── */
.controls{
  flex-shrink:0;
  padding:10px 12px 10px;
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  background:var(--bg-panel);
  backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
  border-top:.5px solid var(--glass-b);
}
/* Mobile: stack slots */
@media(max-width:540px){
  .controls{grid-template-columns:1fr;gap:8px}
}
/* Desktop: sidebar layout */
@media(min-width:900px){
  .pages{display:grid;grid-template-columns:280px 1fr;overflow:hidden}
  #pgGame{grid-column:2;display:flex;flex-direction:column}
  /* Sidebar = bets panel always visible */
  .sidebar{
    grid-column:1;grid-row:1;
    background:var(--bg-panel);
    backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
    border-right:.5px solid var(--glass-b);
    display:flex!important;flex-direction:column;overflow:hidden;
    position:relative;opacity:1;pointer-events:all;
  }
  /* hide bottom nav on desktop */
  .bnav{display:none}
  /* other pages go on top of sidebar area on desktop */
  #pgBets,#pgSettings{grid-column:2;grid-row:1}
}
.slot{background:var(--bg-card);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:.5px solid var(--border-card);border-radius:var(--r-lg);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.slot.active-bet{border-color:rgba(48,209,88,.4);box-shadow:0 0 18px rgba(48,209,88,.08)}
.slot.active-co{border-color:rgba(255,159,10,.4);box-shadow:0 0 18px rgba(255,159,10,.08)}
.sbody{padding:9px}

.amtrow{display:flex;align-items:center;gap:5px;margin-bottom:7px;background:var(--bg-input);border-radius:var(--r-md);border:.5px solid var(--glass-b);padding:3px}
.amtrow.locked,.qrow.locked{opacity:.3;pointer-events:none}
.badj{width:28px;height:28px;border-radius:9px;background:var(--glass);border:none;color:var(--text);font-size:17px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s;line-height:1}
.badj:active{transform:scale(.9)}
.binp{flex:1;background:none;border:none;color:var(--text);font-size:16px;font-weight:700;text-align:center;outline:none;min-width:0;font-family:inherit;letter-spacing:-.3px;-moz-appearance:textfield;appearance:textfield}
.binp::-webkit-outer-spin-button,.binp::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.binp:disabled{opacity:.3}

.qrow{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-bottom:7px}
.qb{background:var(--glass);border:.5px solid var(--glass-b);border-radius:8px;padding:5px 2px;text-align:center;font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .12s}
.qb:active{transform:scale(.92)}

.bmain{width:100%;padding:12px;border-radius:var(--r-md);border:.5px solid transparent;font-size:14px;font-weight:700;cursor:pointer;transition:all .18s;font-family:inherit;line-height:1.25}
.bmain.bet{background:linear-gradient(135deg,#1ea83c,#30d158);color:#fff;box-shadow:0 3px 14px rgba(48,209,88,.28),inset 0 1px 0 rgba(255,255,255,.18)}
.bmain.bet:active{transform:scale(.97)}
.bmain.cashout{background:linear-gradient(135deg,#bf4800,#ff9f0a);color:#fff;box-shadow:0 3px 14px rgba(255,159,10,.28);animation:copulse .9s ease-in-out infinite}
@keyframes copulse{0%,100%{box-shadow:0 3px 14px rgba(255,159,10,.28)}50%{box-shadow:0 3px 24px rgba(255,159,10,.55)}}
.bmain.cashout:active{transform:scale(.97);animation:none}
.bmain.queued{background:rgba(48,209,88,.1);color:var(--green);border:.5px solid rgba(48,209,88,.3);cursor:pointer}
.bmain.won{background:rgba(48,209,88,.12);color:var(--green);border:.5px solid rgba(48,209,88,.35);cursor:pointer}
.bmain.cancel{background:rgba(255,69,58,.1);color:var(--red);border:.5px solid rgba(255,69,58,.28);cursor:default}

.bsub{font-size:9px;color:var(--text3);text-align:center;margin-top:3px;min-height:12px;letter-spacing:.3px}

/* AUTO ROW */
.arow{display:flex;align-items:center;gap:5px;border-top:.5px solid var(--glass-b);padding-top:7px;margin-top:1px}

/* Slot1 hide/show */
.slot-hide-btn{display:none;margin-left:auto;flex-shrink:0;background:none;border:.5px solid var(--glass-b);border-radius:6px;color:var(--text3);font-size:10px;font-weight:600;padding:2px 8px;cursor:pointer;font-family:inherit}
.slot-hide-btn:active{opacity:.6}
.slot1-collapsed-bar{display:none;align-items:center;justify-content:space-between;padding:8px 10px;cursor:pointer}
.slot1-collapsed-bar span{font-size:12px;font-weight:600;color:var(--text2)}
.slot-show-btn{background:none;border:.5px solid var(--glass-b);border-radius:6px;color:var(--text3);font-size:10px;font-weight:600;padding:2px 8px;cursor:pointer;font-family:inherit}
@media(max-width:540px){
  .slot-hide-btn{display:block}
  #slot1.collapsed .sbody{display:none}
  #slot1.collapsed .slot1-collapsed-bar{display:flex}
  #slot1.collapsed .slot-hide-btn{display:none}
}
.al{font-size:10px;color:var(--text2);white-space:nowrap}
.tog{width:34px;height:18px;background:var(--glass-b);border-radius:9px;cursor:pointer;position:relative;transition:background .22s;flex-shrink:0;border:.5px solid var(--glass-b)}
.tog.on{background:var(--green);border-color:var(--green)}
.tog::after{content:'';position:absolute;top:1.5px;left:1.5px;width:13px;height:13px;background:#fff;border-radius:50%;transition:transform .22s;box-shadow:0 1px 4px rgba(0,0,0,.35)}
.tog.on::after{transform:translateX(16px)}
.acv{background:var(--bg-input);border:.5px solid var(--glass-b);border-radius:7px;padding:2px 5px;color:var(--text);font-size:11px;width:69px;outline:none;text-align:center;font-family:inherit;flex-shrink:0}

/* ── ALL BETS PAGE ── */
#pgBets::-webkit-scrollbar{width:2px}
#pgBets::-webkit-scrollbar-thumb{background:var(--glass-b)}
.bets-hdr-wrap{padding:10px 14px 6px;position:sticky;top:0;background:var(--bg-panel);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:2;border-bottom:.5px solid var(--glass-b)}
.ptabs{display:flex;gap:2px;margin-bottom:8px}
.ptab{flex:1;padding:7px 4px;text-align:center;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:1.5px solid transparent;transition:all .18s}
.ptab.active{color:var(--text);border-bottom-color:var(--red)}
.pstats{display:flex;justify-content:space-between;align-items:center}
.ps-l{display:flex;flex-direction:column;gap:3px}
.ps-cnt{font-size:11px;color:var(--text2)}
.ps-cnt b{color:var(--text);font-weight:600}
.ps-bar{width:120px;height:2px;background:var(--glass-b);border-radius:1px;overflow:hidden}
.ps-fill{height:100%;background:var(--green);border-radius:1px;transition:width .4s;box-shadow:0 0 5px var(--green)}
.ps-r{text-align:right}
.ps-mid{text-align:center}
.ps-rl{font-size:10px;color:var(--text3)}
.ps-ra{font-size:13px;font-weight:700}
.ps-rr{font-size:13px;font-weight:700}
.top-subtabs{display:flex;gap:2px;margin-top:6px}
.tsub{flex:1;padding:6px 4px;text-align:center;font-size:12px;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:1.5px solid transparent;transition:all .18s}
.tsub.active{color:var(--text);border-bottom-color:var(--red)}
.bhdr{display:grid;grid-template-columns:minmax(0,1fr) 32px 58px 68px;padding:5px 12px;font-size:9px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;border-bottom:.5px solid var(--glass-b)}
.bhdr>div:nth-child(2){text-align:right}
.bhdr>div:nth-child(3){text-align:center}
.bhdr>div:nth-child(4){text-align:right}
.brow{display:grid;grid-template-columns:minmax(0,1fr) 32px 58px 68px;padding:5px 12px;align-items:center;transition:background .1s}
.brow:hover{background:var(--row-hover)}
.brow.co{background:rgba(48,209,88,.05)}
.brow.my-bet{background:rgba(48,209,88,.10);border-left:2px solid #30d158;}

.bpl{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden;position:relative;width:100%}
.bav{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}
.bpl::after{content:;position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(to right,transparent,var(--card));pointer-events:none}
.bav-flag{font-size:15px;background:none!important}
.bnm{font-size:11px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.bbet{font-size:11px;font-weight:700;color:var(--text);text-align:right}
.bx{font-size:11px;font-weight:700;text-align:center}
.bx.live{color:var(--gold)}.bx.won{color:var(--green)}
.bwin{font-size:11px;font-weight:700;color:var(--green);text-align:right}

/* ── SETTINGS PAGE ── */
.scard{background:var(--bg-card);border:.5px solid var(--border-card);border-radius:var(--r-lg);margin-bottom:10px}
.scard-title{padding:12px 14px 4px;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:1px}
.srow{display:flex;align-items:center;justify-content:space-between;padding:14px 14px;border-bottom:.5px solid var(--glass-b)}
.srow:last-child{border-bottom:none}
.srow-l{display:flex;flex-direction:column;gap:2px}
.srow-label{font-size:15px;font-weight:500;color:var(--text)}
.srow-sub{font-size:11px;color:var(--text3)}
.sval{font-size:14px;color:var(--text2);font-weight:400}
.s-tog{width:51px;height:28px;background:var(--glass-b);border-radius:14px;cursor:pointer;position:relative;transition:background .22s;flex-shrink:0;border:.5px solid var(--glass-b)}
.s-tog.on{background:var(--green);border-color:var(--green)}
.s-tog::after{content:'';position:absolute;top:2px;left:2px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .22s;box-shadow:0 2px 6px rgba(0,0,0,.25)}
.s-tog.on::after{transform:translateX(23px)}
.version-txt{text-align:center;color:var(--text3);font-size:11px;padding:20px 16px 8px}

/* ── BOTTOM NAV ── */
.bnav{
  flex-shrink:0;
  display:flex;
  align-items:center;
  padding:6px 16px calc(6px + env(safe-area-inset-bottom,0px)) 16px;
  gap:4px;
}
.bni{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:7px 8px;cursor:pointer;
  border-radius:22px;
  transition:all .18s;
}
.bni.active{background:rgba(255,255,255,.1)}
body.light .bni.active{background:rgba(0,0,0,.08)}
.bni:active{opacity:.6}
.bni-icon{font-size:18px;line-height:1}
.bni-label{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.1px;white-space:nowrap}
.bni.active .bni-label{color:var(--green)}
.bni-dot{display:none}

/* SETTINGS BTN (desktop topbar) */
.settings-btn{
  display:none;width:34px;height:34px;border-radius:10px;
  background:none;border:none;
  cursor:pointer;font-size:18px;align-items:center;justify-content:center;
  transition:opacity .15s,background .15s;flex-shrink:0;opacity:.7;
}
.settings-btn:hover{opacity:1}
.settings-btn.open{opacity:1}
body.light .settings-btn{opacity:1}
body.light .settings-btn:hover{opacity:.75}
body.light .settings-btn.open{opacity:.75}

/* SETTINGS DROPDOWN */
.settings-dropdown{
  position:absolute;
  width:260px;
  max-height:min(88vh, 860px);
  background:var(--sd-bg);
  border:.5px solid var(--glass-b);border-radius:18px;
  z-index:9999;
  opacity:0;pointer-events:none;transform:translateY(-6px) scale(.96);
  transition:opacity .18s ease, transform .18s cubic-bezier(.34,1.4,.64,1);
  box-shadow:0 24px 60px rgba(0,0,0,.5), inset 0 0 0 .5px rgba(255,255,255,.04);
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
.settings-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}

.sd-section{padding:6px 0}
.sd-section+.sd-section{border-top:.5px solid var(--glass-b)}
.sd-title{padding:8px 14px 4px;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:1px}
.sd-row{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;transition:background .12s;cursor:pointer}
.sd-row:hover{background:var(--row-hover)}
.sd-row-l{display:flex;flex-direction:column;gap:1px}
.sd-row-label{font-size:13px;font-weight:500;color:var(--text)}
.sd-row-sub{font-size:11px;color:var(--text3)}
.sd-val{font-size:12px;color:var(--text2);font-weight:500}
.sd-footer{padding:10px 14px;font-size:10px;color:var(--text3);text-align:center;border-top:.5px solid var(--glass-b)}

/* iOS toggle for dropdown */
.sd-tog{width:38px;height:22px;background:var(--glass-b);border-radius:11px;position:relative;transition:background .22s;flex-shrink:0;border:.5px solid var(--glass-b)}
.sd-tog.on{background:#30d158;border-color:#30d158}
.sd-tog::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .22s;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.sd-tog.on::after{transform:translateX(17px)}

@media(min-width:900px){
  .settings-btn{display:flex}
  .bnav{display:none!important}
}
.notifs{position:fixed;top:96px;right:14px;z-index:20000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.notif{display:flex;align-items:center;gap:9px;border-radius:50px;padding:9px 16px 9px 10px;font-size:13px;font-weight:600;border:.5px solid;opacity:0;transform:translateX(26px) scale(.9);transition:all .28s cubic-bezier(.34,1.56,.64,1);max-width:230px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 8px 28px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.08)}
.notif-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;line-height:1}
.notif-msg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif.win{background:rgba(48,209,88,.22);border-color:rgba(48,209,88,.5);color:rgba(0,0,0,.85)}
.notif.win .notif-icon{background:rgba(48,209,88,.35);color:#1a9940}
.notif.loss{background:rgba(255,69,58,.2);border-color:rgba(255,69,58,.45);color:rgba(0,0,0,.85)}
.notif.loss .notif-icon{background:rgba(255,69,58,.3);color:#d93025}
body.light .notif{box-shadow:0 8px 28px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.6)}
body.light .notif.win{background:rgba(48,209,88,.22);border-color:rgba(48,209,88,.5);color:rgba(0,0,0,.85)}
body.light .notif.win .notif-icon{background:rgba(48,209,88,.35);color:#1a9940}
body.light .notif.loss{background:rgba(255,69,58,.2);border-color:rgba(255,69,58,.45);color:rgba(0,0,0,.85)}
body.light .notif.loss .notif-icon{background:rgba(255,69,58,.3);color:#d93025}
.notif.show{opacity:1;transform:translateX(0) scale(1)}

/* FUN MODE banner */
.fun-banner{background:linear-gradient(90deg,#b56a00,#e67e22,#b56a00);padding:5px 14px;text-align:center;font-size:12px;font-weight:700;letter-spacing:1.5px;flex-shrink:0}
/* ── AGE GATE ── */


/* --- iOS dark-theme fallback fixes for betting panel --- */
:root[data-theme="dark"] #bet-card,
body:not(.light) #bet-card,
html body:not(.light) #bet-card {
  background: rgba(11,15,22,0.94) !important;
  background-color: rgba(11,15,22,0.94) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.95) !important;
}

:root[data-theme="dark"] .slot,
body:not(.light) .slot,
html body:not(.light) .slot {
  background: rgba(11,15,22,0.94) !important;
  background-color: rgba(11,15,22,0.94) !important;
  border-color: rgba(255,255,255,0.08) !important;
}

:root[data-theme="dark"] .amtrow,
:root[data-theme="dark"] .binp,
:root[data-theme="dark"] .acv,
body:not(.light) .amtrow,
body:not(.light) .binp,
body:not(.light) .acv,
html body:not(.light) .amtrow,
html body:not(.light) .binp,
html body:not(.light) .acv {
  background-color: rgba(7,11,18,0.96) !important;
  color: rgba(255,255,255,0.96) !important;
  -webkit-text-fill-color: rgba(255,255,255,0.96) !important;
}

:root[data-theme="dark"] .qb,
body:not(.light) .qb,
html body:not(.light) .qb {
  background: rgba(255,255,255,0.05) !important;
  color: rgba(255,255,255,0.82) !important;
  border-color: rgba(255,255,255,0.10) !important;
}

:root[data-theme="dark"] input,
:root[data-theme="dark"] button,
body:not(.light) input,
body:not(.light) button,
html body:not(.light) input,
html body:not(.light) button {
  -webkit-appearance: none;
  appearance: none;
}


/* --- neutral dark betting panel style (like iOS settings cards) --- */
:root[data-theme="dark"] #bet-card,
body:not(.light) #bet-card,
html body:not(.light) #bet-card,
:root[data-theme="dark"] .slot,
body:not(.light) .slot,
html body:not(.light) .slot {
  background: #252525 !important;
  background-color: #252525 !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03) !important;
}

:root[data-theme="dark"] .amtrow,
:root[data-theme="dark"] .acv,
:root[data-theme="dark"] .binp,
body:not(.light) .amtrow,
body:not(.light) .acv,
body:not(.light) .binp,
html body:not(.light) .amtrow,
html body:not(.light) .acv,
html body:not(.light) .binp {
  background: #1f1f1f !important;
  background-color: #1f1f1f !important;
  border-color: rgba(255,255,255,0.06) !important;
  color: rgba(255,255,255,0.96) !important;
  -webkit-text-fill-color: rgba(255,255,255,0.96) !important;
}

:root[data-theme="dark"] .qb,
body:not(.light) .qb,
html body:not(.light) .qb {
  background: #2c2c2e !important;
  border-color: rgba(255,255,255,0.06) !important;
  color: rgba(255,255,255,0.82) !important;
}


/* --- iOS callout/context-menu suppression --- */
html, body, .app, canvas, img, .topbar, .hbar, .hp, .logo-img {
  -webkit-touch-callout: none !important;
  -webkit-user-select: none !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}


.bigx.wait.loading{
  font-family: Inter, ui-rounded, "SF Pro Rounded", "SF Pro Display", system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: 0.2px;
  color: rgba(255,255,255,0.78);
}
.bigx.wait.loading .loading-dots{
  display:inline-flex;
  min-width: 0.9em;
  justify-content:flex-start;
}
.bigx.wait.loading .loading-dots span{
  display:inline-block;
  width: 0.3em;
  text-align:center;
  animation: loadingDotPulse 1.2s infinite ease-in-out;
}
.bigx.wait.loading .loading-dots span:nth-child(2){animation-delay:.16s}
.bigx.wait.loading .loading-dots span:nth-child(3){animation-delay:.32s}
@keyframes loadingDotPulse{
  0%, 80%, 100%{opacity:.18; transform:translateY(0)}
  40%{opacity:1; transform:translateY(-1px)}
}


/* --- boot gating: show overlay first, avoid app flash before JS init --- */
html.preboot-html .app,
body.preboot .app {
  visibility: hidden !important;
}


.acwrap{position:relative;display:flex;align-items:center;flex-shrink:0}
.acwrap .acv{padding-left:18px;padding-right:6px}
.acx{position:absolute;left:7px;top:50%;transform:translateY(-50%);font-size:11px;line-height:1;color:var(--green);pointer-events:none;font-weight:700}

.sbtn-wrap{padding:12px 14px 14px}
.sbtn-primary{width:100%;border:none;border-radius:14px;padding:14px 16px;background:linear-gradient(135deg,#30d158,#1fa843);color:#fff;font-size:15px;font-weight:800;font-family:inherit;cursor:pointer}
.sd-btn-wrap{padding:12px 16px 16px}
.sd-btn-primary{width:100%;border:none;border-radius:14px;padding:14px 16px;background:linear-gradient(135deg,#30d158,#1fa843);color:#fff;font-size:14px;font-weight:800;font-family:inherit;cursor:pointer}

html, body {
  touch-action: manipulation;
  overscroll-behavior: none;
}

.mobile-game-stats{position:absolute;left:10px;right:10px;bottom:10px;display:flex;justify-content:space-between;gap:10px;pointer-events:none;z-index:6}
.mgs-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:2px;min-width:92px;max-width:44%;padding:8px 10px;border-radius:14px;background:rgba(8,12,20,0.48);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:.5px solid rgba(255,255,255,0.08);box-shadow:0 8px 24px rgba(0,0,0,.18);pointer-events:auto}
.mgs-label{font-size:10px;font-weight:700;letter-spacing:.3px;color:var(--text3);text-transform:uppercase}
.mgs-val{font-size:13px;font-weight:800;color:#fff;white-space:nowrap}
@media (min-width:900px){.mobile-game-stats{display:none}}
body.light .mgs-pill{background:rgba(255,255,255,0.72);border-color:rgba(0,0,0,0.06)}
body.light .mgs-val{color:#111}

.auth-modal{position:fixed;inset:0;background:rgba(0,0,0,.46);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:none;align-items:center;justify-content:center;padding:20px;z-index:10020}
.auth-modal.open{display:flex}
.auth-card{width:min(100%,420px);background:var(--bg-card);border:.5px solid var(--border-card);border-radius:22px;padding:18px;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.auth-title{font-size:22px;font-weight:900;color:var(--text);margin-bottom:4px}
.auth-sub{font-size:14px;color:rgba(255,255,255,0.82);margin-bottom:14px}
.auth-input{width:100%;border:none;outline:none;background:var(--bg-input, rgba(255,255,255,.06));color:var(--text);border-radius:14px;padding:14px 16px;font-size:15px;margin-bottom:10px}
.auth-note{min-height:18px;font-size:12px;color:var(--text3);margin-bottom:10px}
.auth-actions{display:flex;gap:10px}
.auth-btn{flex:1;border:none;border-radius:14px;padding:13px 16px;font-weight:800;font-family:inherit;cursor:pointer}
.auth-btn-primary{background:linear-gradient(135deg,#30d158,#1fa843);color:#fff}
.auth-btn-secondary{background:rgba(255,255,255,.08);color:var(--text)}
body.light .auth-btn-secondary{background:rgba(0,0,0,.06)}

.auth-code-wrap{display:flex;gap:8px;justify-content:center;margin-bottom:10px}
.auth-code-digit{width:46px;height:54px;border:none;outline:none;background:var(--bg-input, rgba(255,255,255,.06));color:var(--text);border-radius:14px;text-align:center;font-size:24px;font-weight:900}
.auth-btn[disabled]{opacity:.55;cursor:default}

body.light .auth-sub{color:rgba(17,24,39,0.72)}
.auth-note.success{color:#30d158}
.auth-note.error{color:#ff453a}

.auth-user{display:flex;align-items:center;gap:8px;margin:0 0 10px;padding:12px 14px;border-radius:16px 16px 0px 0px;background:rgba(255,255,255,0.06);color:var(--text);font-size:14px;font-weight:800}.auth-user-desktop{margin:-6px 0 12px}.auth-user span{opacity:.92}body.light .auth-user{background:rgba(0,0,0,0.05)}

#signOutMobileRow:hover,#signOutMobileRow:active,#signOutDesktopRow:hover,#signOutDesktopRow:active{background:transparent !important;box-shadow:none !important}
#signOutMobileRow .srow-label:hover,#signOutDesktopRow .sd-row-label:hover{text-decoration:none}

.auth-close-zone{position:absolute;left:0;right:0;top:0;height:42vh;z-index:0}
.auth-card{position:relative;z-index:1}








/* ── BALANCE BADGE ── */

.bal-badge {
  font-size:9px; font-weight:800; letter-spacing:.8px;
  padding:5px 9px; border-radius:999px;
  background:rgba(0,0,0,0.45); color:rgba(255,255,255,0.75);
  text-transform:uppercase; flex-shrink:0;
}
body.light .bal-wrap {
  background:rgba(0,0,0,0.07); border-color:rgba(0,0,0,0.1);
}
body.light .bal-n, body.light .bal-c { color:#1db954; }
body.light .bal-badge {
  background:rgba(0,0,0,0.6); color:rgba(255,255,255,0.9);
}
.bal-badge.real {
  background:rgba(48,209,88,0.2); color:#30d158;
}
body.light .bal-badge.real {
  background:rgba(0,180,60,0.15); color:#1a9940;
}

/* ── DEPOSIT MODAL ── */
.dep-modal {
  display: none; position: fixed; inset: 0; z-index: 10000;
  align-items: flex-end; justify-content: center;
}
.dep-modal.open { display: flex; }

.dep-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(50px); -webkit-backdrop-filter: blur(50px);
}

.dep-card {
  position: relative; z-index: 1;
  width: 100%; max-width: 460px;
  background: var(--bg-card);
  border: .5px solid var(--border-card);
  border-radius: 24px 24px 0 0;
  padding: 0 0 env(safe-area-inset-bottom);
  box-shadow: 0 -8px 40px rgba(0,0,0,.28);
  max-height: 92vh; overflow-y: auto;
}
@media (min-height: 700px) {
  .dep-modal { align-items: center; padding: 20px; }
  .dep-card { border-radius: 24px; max-height: 88vh; }
}

/* Header */
.dep-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 18px 0;
}
.dep-hdr-title {
  font-size: 18px; font-weight: 900; color: var(--text); letter-spacing: -.3px;
}
.dep-hdr-close {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--bg-input); border: none;
  color: var(--text2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s;
}
.dep-hdr-close:hover { background: var(--glass-b); color: var(--text); }

/* Steps */
.dep-step { padding: 6px 18px 22px; }

/* Field label */
.dep-field-label {
  font-size: 11px; font-weight: 700; letter-spacing: .6px;
  text-transform: uppercase; color: var(--text2); margin-bottom: 10px;
}

/* Coin grid */
.dep-coins { display: flex; flex-wrap: wrap; gap: 6px; }
.dep-coin {
  display: flex; align-items: center; gap: 4px;
  padding: 6px 11px; border-radius: 20px;
  background: var(--bg-input); border: 1px solid transparent;
  color: var(--text2); font-size: 12px; font-weight: 700;
  cursor: pointer; transition: all .15s; font-family: inherit;
  white-space: nowrap;
}
.dep-coin:hover { color: var(--text); background: var(--glass-b); }
.dep-coin.active {
  background: rgba(48,209,88,.12);
  border-color: rgba(48,209,88,.35);
  color: var(--green);
}
.dep-coin-icon { font-size: 11px; opacity: .8; }
.dep-coin-net {
  font-size: 9px; font-weight: 800; letter-spacing: .3px;
  opacity: .65; margin-left: 1px;
}

/* Amount input */
.dep-amount-row {
  display: flex; align-items: center;
  background: var(--bg-input); border-radius: var(--r-md);
  padding: 0 14px; margin-bottom: 10px;
  border: 1px solid transparent; transition: border-color .15s;
}
.dep-amount-row:focus-within { border-color: rgba(48,209,88,.4); }
.dep-usd-sign { font-size: 22px; font-weight: 900; color: var(--text2); margin-right: 4px; }
.dep-amount-input {
  flex: 1; border: none; outline: none; background: transparent;
  color: var(--text); font-size: 28px; font-weight: 900;
  padding: 14px 0; font-family: inherit;
}
.dep-amount-input::placeholder { color: var(--text3); }

/* Preset buttons */
.dep-presets { display: flex; gap: 6px; margin-bottom: 18px; }
.dep-preset {
  flex: 1; padding: 8px 4px; border-radius: 10px;
  background: var(--bg-input); border: .5px solid var(--border-card);
  color: var(--text2); font-size: 13px; font-weight: 700;
  cursor: pointer; transition: all .15s; font-family: inherit;
}
.dep-preset:hover { color: var(--text); background: var(--glass-b); }

/* Primary action button */
.dep-action-btn {
  width: 100%; padding: 15px; border-radius: var(--r-md);
  background: linear-gradient(135deg, #30d158, #1fa843);
  border: none; color: #fff; font-size: 15px; font-weight: 800;
  cursor: pointer; margin-bottom: 10px; font-family: inherit;
  transition: opacity .15s; letter-spacing: -.1px;
}
.dep-action-btn:hover { opacity: .88; }
.dep-action-btn:disabled { opacity: .55; cursor: default; }

/* Powered note */
.dep-powered {
  text-align: center; font-size: 11px; color: var(--text3);
}

/* Address step */
.dep-addr-top {
  display: flex; align-items: center;
  justify-content: space-between; gap: 12px;
  margin-bottom: 18px;
}
.dep-addr-meta { flex: 1; }
.dep-addr-coin-name { font-size: 13px; font-weight: 800; color: var(--text2); margin-bottom: 4px; }
.dep-addr-send-amt { font-size: 22px; font-weight: 900; color: var(--text); line-height: 1.1; }
.dep-addr-fiat { font-size: 13px; color: var(--text2); margin-top: 4px; }

.dep-qr-wrap {
  flex-shrink: 0;
  background: #fff; border-radius: 12px; padding: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,.12);
}
.dep-qr { display: block; width: 100px; height: 100px; }

/* Address copy row */
.dep-copy-row {
  display: flex; align-items: center;
  background: var(--bg-input); border-radius: var(--r-sm);
  padding: 10px 10px 10px 14px; gap: 8px; margin-bottom: 14px;
}
.dep-addr-text {
  flex: 1; font-size: 12px; font-family: 'SF Mono', 'Fira Mono', monospace;
  color: var(--text); word-break: break-all; line-height: 1.5;
  user-select: text; -webkit-user-select: text;
}
.dep-copy-btn {
  flex-shrink: 0; display: flex; align-items: center; gap: 5px;
  padding: 7px 11px; border-radius: 8px;
  background: var(--glass-b); border: .5px solid var(--border-card);
  color: var(--text2); font-size: 12px; font-weight: 700;
  cursor: pointer; transition: all .15s; font-family: inherit;
  white-space: nowrap;
}
.dep-copy-btn:hover { color: var(--text); background: var(--glass); }

/* Status bar */
.dep-status-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; border-radius: var(--r-sm);
  background: var(--bg-input); margin-bottom: 10px;
}
.dep-status-pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--green); flex-shrink: 0;
  box-shadow: 0 0 6px var(--green);
  animation: dep-pulse 1.6s infinite;
}
@keyframes dep-pulse { 0%,100%{opacity:1} 50%{opacity:.35} }
.dep-status-txt { font-size: 13px; font-weight: 600; color: var(--text2); }

/* Hint */
.dep-hint {
  font-size: 11px; color: var(--text3); line-height: 1.4;
}

/* Done step */
.dep-done-step { text-align: center; padding: 28px 18px 28px; }
.dep-done-ring { margin-bottom: 16px; }
.dep-done-circle { animation: dep-draw 0.6s ease forwards; }
@keyframes dep-draw { from { stroke-dashoffset: 163; } to { stroke-dashoffset: 0; } }
.dep-done-title { font-size: 20px; font-weight: 900; color: var(--text); margin-bottom: 8px; }
.dep-done-amount { font-size: 40px; font-weight: 900; color: var(--green); letter-spacing: -1px; }
.dep-done-sub { font-size: 14px; color: var(--text2); margin: 6px 0 24px; }

/* Light theme overrides */
body.light .dep-card { box-shadow: 0 -8px 40px rgba(0,0,0,.12); }
body.light .dep-powered { color: rgba(0,0,0,.3); }
body.light .dep-hint { color: rgba(0,0,0,.35); }
body.light .dep-qr-wrap { box-shadow: 0 2px 12px rgba(0,0,0,.08); }

.dep-clickcopy { cursor: pointer; }
.dep-clickcopy:hover { opacity: .75; }

/* Bonus banner */
.dep-bonus-banner {
  display: flex; align-items: center; gap: 14px;
  margin: 14px 18px;
  background: linear-gradient(135deg, rgba(255,214,10,.13), rgba(255,159,10,.10));
  border: 1px solid rgba(255,214,10,.3);
  border-radius: 18px; padding: 14px 16px;
  position: relative; overflow: hidden;
}
.dep-bonus-badge {
  width: 44px; height: 44px; border-radius: 14px; flex-shrink: 0;
  background: linear-gradient(135deg, #ffd60a, #ff9f0a);
  color: #000; font-size: 15px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(255,214,10,.4);
}
.dep-bonus-text { flex: 1; }
.dep-bonus-title { font-size: 13px; font-weight: 800; color: var(--text); }
.dep-bonus-sub { font-size: 11px; margin-top: 2px; }
.dep-bonus-sub b { color: #ffd60a; font-weight: 800; }
.dep-bonus-preview {
  display: flex; align-items: center; gap: 6px;
  flex-shrink: 0;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,214,10,.25);
  border-radius: 14px;
  padding: 8px 14px;
}
body.light .dep-bonus-preview {
  background: rgba(255,255,255,.5);
  border-color: rgba(255,159,10,.35);
}
.dep-bp-col { display: flex; flex-direction: column; align-items: center; gap: 0; }
.dep-bp-label {
  font-size: 9px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--text2); opacity: .7; line-height: 1;
}
.dep-bp-val {
  font-size: 18px; font-weight: 900; color: var(--text); line-height: 1.15;
}
.dep-bp-val-green { color: #30d158; }
body.light .dep-bp-val-green { color: #1fa83c; }
.dep-bp-sep {
  font-size: 18px; color: #ffd60a;
  margin: 0 2px; padding-top: 10px;
}
/* Done bonus row */
.dep-done-bonus {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  margin: 4px 0 2px;
}
.dep-done-bonus-label { font-size: 12px; color: var(--text2); }
.dep-done-bonus-val { font-size: 13px; font-weight: 800; color: #ffd60a; }

/* balance long-press flash */
.bal-hold-flash { animation: balFlash .4s ease; }
@keyframes balFlash {
  0%,100% { opacity:1; }
  40% { opacity:.3; transform:scale(.95); }
}

/* Cancel deposit button */
.dep-cancel-btn {
  width:100%; margin-top:10px;
  background:none; border:1px solid rgba(255,69,58,.3);
  border-radius:12px; padding:10px;
  color:rgba(255,69,58,.7); font-size:13px; font-weight:600;
  cursor:pointer; transition:all .2s;
}
.dep-cancel-btn:hover { background:rgba(255,69,58,.08); color:#ff453a; border-color:rgba(255,69,58,.5); }
body.light .dep-cancel-btn { border-color:rgba(200,50,40,.3); color:rgba(180,40,30,.7); }
body.light .dep-cancel-btn:hover { background:rgba(200,50,40,.07); color:#c0392b; }

/* ── Mobile topbar: logo left, hide online pill ── */
@media(max-width:700px){
  .online-pill { display:none; }
  .tb-center { display:none; }
  .tb-left { flex:1; }
  .tb-left::after {
    content:'';
    display:block;
    position:absolute;
    left:14px;
    top:50%;
    transform:translateY(-50%);
    background:url('./assets/images/logo.png') left center / contain no-repeat;
    width:120px;
    height:70px;
    margin-top:2px;
  }
}

/* ── Withdraw modal ── */
.wd-addr-input {
  width:100%; background:var(--bg-input); border:.5px solid var(--glass-b);
  border-radius:12px; padding:11px 14px; color:var(--text);
  font-size:13px; font-family:inherit; outline:none;
  transition:border-color .2s; margin-top:6px;
}
.wd-addr-input:focus { border-color:rgba(48,209,88,.4); }
.wd-addr-input::placeholder { color:var(--text3); }
.wd-preview {
  display:flex; align-items:center; justify-content:space-between;
  margin-top:12px; padding:10px 14px;
  background:rgba(48,209,88,.07); border:1px solid rgba(48,209,88,.2);
  border-radius:12px;
  font-size:13px; color:var(--text2);
}
.wd-preview-val { font-weight:800; color:var(--green); font-size:15px; }
body.light .wd-preview { background:rgba(48,209,88,.06); }

/* ── Auth modal perks ── */
.auth-perks {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.auth-perk {
  display: flex; align-items: center; gap: 6px;
  background: var(--glass); border: .5px solid var(--glass-b);
  border-radius: 999px; padding: 5px 12px;
  font-size: 11px; font-weight: 600; color: var(--text2);
}
.auth-perk-dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  box-shadow: 0 0 5px currentColor;
}
#authPerks { display: flex; }
#authCodeWrap ~ #authPerks,
#authActionsCode:not([style*='none']) ~ * #authPerks { display: none; }

/* About collapsible */
.about-chevron {
  font-size: 16px; color: var(--text3);
  transition: transform .2s; display: inline-block;
}
.about-body { overflow: hidden; }

/* Let's Go button */
.dep-letsgo-btn {
  background: linear-gradient(135deg, #30d158, #25a244) !important;
  font-size: 16px !important;
  letter-spacing: .02em;
}
.dep-letsgo-btn:hover { opacity: .9; }

/* ── Admin Panel ── */
.admin-tabs { display:flex; gap:6px; padding:0 18px 12px; border-bottom:1px solid rgba(255,255,255,.07); flex-shrink:0; }
body.light .admin-tabs { border-color:rgba(0,0,0,.08); }
.admin-tab { background:rgba(255,255,255,.07); border:none; border-radius:20px; padding:6px 14px; font-size:12px; font-weight:700; color:var(--text2); cursor:pointer; transition:background .15s,color .15s; }
body.light .admin-tab { background:rgba(0,0,0,.06); }
.admin-tab.active { background:#30d158; color:#fff; box-shadow:0 0 10px rgba(48,209,88,.35); }
body.light .admin-tab.active { color:#fff; }
.admin-row { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.06); }
body.light .admin-row { border-color:rgba(0,0,0,.06); }
.admin-row:last-child { border-bottom:none; }
.admin-row-info { flex:1; min-width:0; }
.admin-row-email { font-size:13px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.admin-row-sub { font-size:11px; color:var(--text2); margin-top:2px; }
.admin-row-btns { display:flex; gap:6px; flex-shrink:0; }
.admin-btn-approve { background:#30d158; border:none; border-radius:10px; padding:6px 12px; font-size:12px; font-weight:700; color:#000; cursor:pointer; }
.admin-btn-reject { background:rgba(255,69,58,.2); border:1px solid rgba(255,69,58,.4); border-radius:10px; padding:6px 12px; font-size:12px; font-weight:700; color:#ff453a; cursor:pointer; }
.admin-table { width:100%; border-collapse:collapse; font-size:12px; }
.admin-table th { text-align:left; color:var(--text2); font-weight:700; font-size:10px; text-transform:uppercase; letter-spacing:.05em; padding:0 6px 8px; }
.admin-table td { padding:8px 6px; border-bottom:1px solid rgba(255,255,255,.05); color:var(--text); }
body.light .admin-table td { border-color:rgba(0,0,0,.05); }
.admin-stats-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.admin-stat { background:rgba(255,255,255,.06); border-radius:14px; padding:16px; text-align:center; }
body.light .admin-stat { background:rgba(0,0,0,.04); }
.admin-stat-val { font-size:22px; font-weight:900; color:var(--text); }
.admin-stat-lbl { font-size:11px; color:var(--text2); margin-top:4px; }

/* Withdrawal submit button */
.wd-submit-btn {
  width: 100%;
  border: none;
  border-radius: 14px;
  padding: 15px 16px;
  background: linear-gradient(135deg, #30d158, #1fa843);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  font-family: inherit;
  cursor: pointer;
  margin-top: 16px;
  box-shadow: 0 4px 18px rgba(48,209,88,.3), inset 0 1px 0 rgba(255,255,255,.15);
  transition: opacity .15s, transform .1s;
  letter-spacing: .01em;
}
.wd-submit-btn:hover { opacity: .92; transform: translateY(-1px); }
.wd-submit-btn:active { transform: translateY(0); opacity: 1; }
.wd-submit-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; }

/* Withdrawal amount controls */
.wd-controls {
  display: flex;
  gap: 8px;
  margin-bottom: 18px;
}
.wd-ctrl-btn {
  flex: 1;
  height: 42px;
  border: 1px solid var(--glass-b);
  border-radius: 12px;
  background: var(--glass);
  color: var(--text);
  font-size: 15px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background .12s, transform .1s, color .12s;
  user-select: none;
  -webkit-user-select: none;
}
.wd-ctrl-btn:hover  { background: var(--glass-b); }
.wd-ctrl-btn:active { transform: scale(.94); }
.wd-ctrl-pm {
  flex: 0 0 52px;
  font-size: 22px;
  font-weight: 400;
  color: var(--green);
  border-color: rgba(48,209,88,.25);
}
.wd-ctrl-pm:hover { background: rgba(48,209,88,.1); }
body.light .wd-ctrl-btn { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); }
body.light .wd-ctrl-btn:hover { background: rgba(0,0,0,.1); }
body.light .wd-ctrl-pm { background: rgba(48,209,88,.07); }


/* Withdrawal stats row */
.wd-stats-row {
  display: flex;
  align-items: center;
  gap: 0;
  background: rgba(48,209,88,.1);
  border: 1px solid rgba(48,209,88,.28);
  border-radius: 14px;
  padding: 10px 16px;
  flex-shrink: 0;
}
.wd-stat-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.wd-stat-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--text2);
  opacity: .7;
  line-height: 1;
  white-space: nowrap;
}
.wd-stat-val {
  font-size: 17px;
  font-weight: 900;
  color: var(--text);
  line-height: 1.2;
  letter-spacing: -.01em;
  white-space: nowrap;
}
.wd-stat-val.green { color: #30d158; }
body.light .wd-stat-val.green { color: #1fa83c; }
.wd-stat-sep {
  display: flex;
  align-items: center;
  gap: 0;
}
.wd-stat-vline {
  width: 1px;
  height: 32px;
  background: rgba(48,209,88,.25);
  margin: 0 14px;
}
body.light .wd-stats-row {
  background: rgba(48,209,88,.07);
  border-color: rgba(48,209,88,.3);
}

/* Hide withdrawal icon on mobile when available balance is shown */
@media (max-width: 480px) {
  .dep-bonus-banner.wd-has-avail .dep-bonus-left { display: none; }
}

@media (max-width: 480px) {
  .dep-bonus-banner.dep-has-preview .dep-bonus-left { display: none; }
}

/* Field shake + red highlight */
@keyframes fieldShake {
  0%,100% { transform: translateX(0); }
  15%      { transform: translateX(-6px); }
  35%      { transform: translateX(6px); }
  55%      { transform: translateX(-4px); }
  75%      { transform: translateX(4px); }
  90%      { transform: translateX(-2px); }
}
.field-error {
  animation: fieldShake .4s ease;
  border-color: #ff3b30 !important;
  box-shadow: 0 0 0 3px rgba(255,59,48,.18) !important;
  transition: border-color .3s, box-shadow .3s;
}

/* Withdrawal summary rows */
.wd-summary {
  background: var(--glass);
  border: 1px solid var(--glass-b);
  border-radius: 14px;
  padding: 12px 16px;
  margin-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.wd-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.wd-summary-label {
  font-size: 13px;
  color: var(--text2);
}
.wd-summary-val {
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
}
.wd-summary-val.green { color: #30d158; }
body.light .wd-summary-val.green { color: #1fa83c; }
body.light .wd-summary { background: rgba(0,0,0,.04); }
.hist-list{padding:8px 0 8px;max-height:62vh;overflow-y:auto;}
.hist-item{display:grid;grid-template-columns:24px 72px 1fr 1fr 62px;align-items:center;gap:0 5px;padding:10px 12px;margin:4px 8px;border-radius:3px;background:rgba(255,255,255,.04);transition:background .15s;}
.hist-item:active{background:rgba(255,255,255,.07);}
.hist-won{border-left:3px solid var(--green);}
.hist-lost{border-left:3px solid var(--red);}
.hist-dep{border-left:3px solid #0a84ff;}
.hist-wd{border-left:3px solid #ffd60a;}
.hist-col-icon{font-size:17px;line-height:1;}
.hist-col-result{font-size:15px;font-weight:800;white-space:nowrap;}
.hist-col-result.green{color:var(--green);}
.hist-col-result.red{color:var(--red);}
.hist-col-result.wd-color{color:#ffd60a;}
.hist-col-mid{display:flex;flex-direction:column;gap:2px;min-width:0;}
.hist-badge{font-size:12px;font-weight:700;color:var(--text2);white-space:nowrap;display:inline-block;}
.hist-won .hist-badge{color:var(--green);}
.hist-sub{font-size:10px;color:var(--text2);padding-left:2px;}
.dep-badge{color:#0a84ff;}
.hist-col-result.dep-color{color:#0a84ff;}
.wd-badge{color:#ffd60a;}
.lost-badge{color:var(--red);}
.hist-col-date{font-size:10px;color:var(--text2);white-space:nowrap;text-align:right;}
.hist-col-bal{font-size:12px;font-weight:700;color:rgba(255,255,255,.55);white-space:nowrap;text-align:right;}
.hist-empty{text-align:center;padding:40px 16px;color:var(--text2);font-size:15px;}
