/* ── Variables ───────────────────────────────────────────────────────────── */
:root {
  --bg:        #060a14;
  --bg1:       #0b1424;
  --bg2:       #0f1c33;
  --bg3:       #152340;
  --border:    #1a2e50;
  --border2:   #1e3d6e;
  --acc:       #1d6ef5;
  --acc2:      #4d94ff;
  --acc-glow:  rgba(29,110,245,.3);
  --txt:       #e8eeff;
  --txt2:      #7a94ba;
  --txt3:      #3a5070;
  --green:     #0ec97a;
  --green2:    rgba(14,201,122,.12);
  --gold:      #f0a830;
  --red:       #f04848;
  --hdr:       52px;
  --nav:       58px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;background:var(--bg);color:var(--txt);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;overscroll-behavior:none}
#app{display:flex;flex-direction:column;height:100%;height:100dvh}

/* ── Header ──────────────────────────────────────────────────────────────── */
.hdr{position:fixed;top:0;left:0;right:0;height:var(--hdr);background:rgba(6,10,20,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:8px;z-index:200}
.back{width:36px;height:36px;border:none;background:var(--bg2);border-radius:10px;color:var(--acc2);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.back.hidden{display:none}
.hdr-title{flex:1;font-size:15px;font-weight:700;color:var(--acc2)}
.hdr-user{font-size:12px;color:var(--txt2);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── Main ────────────────────────────────────────────────────────────────── */
#main{flex:1;overflow-y:auto;padding:calc(var(--hdr) + 12px) 12px calc(var(--nav) + 12px);-webkit-overflow-scrolling:touch}
#main.bj-active{padding:calc(var(--hdr) + 8px) 8px calc(var(--nav) + 8px);overflow:hidden}

/* ── Bottom nav ──────────────────────────────────────────────────────────── */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav);background:rgba(6,10,20,.97);backdrop-filter:blur(14px);border-top:1px solid var(--border);display:flex;padding-bottom:env(safe-area-inset-bottom,0);z-index:200}
.nb{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;position:relative;padding:6px 0}
.nb-ico{font-size:18px;color:var(--txt3);line-height:1}
.nb-lbl{font-size:10px;font-weight:500;color:var(--txt3)}
.nb.active .nb-ico,.nb.active .nb-lbl{color:var(--acc2)}
.soon{position:absolute;top:5px;right:calc(50% - 22px);font-size:7px;font-weight:800;font-style:normal;background:var(--acc);color:#fff;padding:1px 5px;border-radius:8px}

/* ── Spinner ─────────────────────────────────────────────────────────────── */
.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:14px;color:var(--txt2);font-size:14px}
.spin{width:36px;height:36px;border:3px solid var(--border2);border-top-color:var(--acc2);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Common ──────────────────────────────────────────────────────────────── */
.hidden{display:none!important}
.sec-label{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.8px;padding:0 2px 6px}
.btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}
.btn:active{opacity:.8;transform:scale(.97)}
.btn-primary{background:var(--acc);color:#fff}
.badge{font-size:9px;font-weight:700;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.badge-budget{background:rgba(14,201,122,.15);color:var(--green);border:1px solid rgba(14,201,122,.3)}
.badge-sport{background:rgba(77,148,255,.15);color:var(--acc2);border:1px solid rgba(77,148,255,.3)}
.badge-super{background:rgba(240,72,72,.15);color:var(--red);border:1px solid rgba(240,72,72,.3)}

/* ── Groups ──────────────────────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.stat-c{background:var(--bg1);border:1px solid var(--border2);border-radius:14px;padding:14px;text-align:center}
.stat-v{font-size:20px;font-weight:800;color:var(--acc2);margin-bottom:3px}
.stat-l{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--txt2)}
.groups-grid{display:flex;flex-direction:column;gap:10px}
.group-card{background:var(--bg1);border:1px solid var(--border);border-radius:18px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .15s}
.group-card:active{transform:scale(.985)}
.gc-head{padding:14px 16px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.gc-dot{width:8px;height:8px;border-radius:50%;background:var(--acc2);box-shadow:0 0 8px var(--acc-glow);flex-shrink:0}
.gc-name{font-size:15px;font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gc-body{padding:12px 16px;display:flex;flex-direction:column;gap:8px}
.gc-row{display:flex;align-items:center;justify-content:space-between;font-size:13px}
.gc-lbl{color:var(--txt2);display:flex;align-items:center;gap:5px}
.gc-val{font-weight:600}
.gc-val.money{color:var(--green);font-size:15px;font-weight:700}
.hp-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:3px}
.hp-fill{height:100%;background:linear-gradient(90deg,var(--acc),var(--acc2));border-radius:2px}
.biz-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}
.biz-chip{font-size:11px;padding:2px 8px;background:var(--bg2);border:1px solid var(--border2);border-radius:20px;color:var(--txt2)}

/* ── Group menu ──────────────────────────────────────────────────────────── */
.gm-balance{background:linear-gradient(135deg,var(--bg2),var(--bg1));border:1px solid var(--border2);border-radius:18px;padding:20px;text-align:center;margin-bottom:10px}
.gm-bal-lbl{font-size:11px;color:var(--txt2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.gm-bal-val{font-size:34px;font-weight:800;color:var(--green)}
.gm-bal-hrly{font-size:12px;color:var(--gold);margin-top:4px}
.gm-car{background:var(--bg1);border:1px solid var(--border);border-radius:16px;padding:14px 16px;margin-bottom:10px}
.gm-car-name{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:8px}
.gm-hp-info{display:flex;justify-content:space-between;font-size:11px;color:var(--txt2);margin-bottom:4px}
.gm-daily{border-radius:14px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;border:none;width:100%;text-align:left;transition:opacity .15s}
.gm-daily:active{opacity:.8}
.gm-daily.ready{background:linear-gradient(135deg,rgba(14,201,122,.18),rgba(14,201,122,.08));border:1px solid rgba(14,201,122,.4)}
.gm-daily.wait{background:var(--bg1);border:1px solid var(--border);cursor:default}
.gm-daily-l{display:flex;flex-direction:column;gap:3px}
.gm-daily-t{font-size:14px;font-weight:700;color:var(--txt)}
.gm-daily-s{font-size:12px;color:var(--txt2)}
.gm-daily-ico{font-size:28px}
.gm-vpn{background:linear-gradient(135deg,rgba(240,168,48,.15),rgba(240,168,48,.05));border:1px solid rgba(240,168,48,.35);border-radius:14px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;width:100%;transition:opacity .15s}
.gm-vpn:active{opacity:.8}

/* Tile grid — 2×2 + BJ full-width */
.gm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.gm-tile{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:border-color .2s,transform .15s}
.gm-tile:active{transform:scale(.95)}
.gm-tile-ico{font-size:24px}
.gm-tile-lbl{font-size:12px;font-weight:600;color:var(--txt);text-align:center}

/* BJ entry tile — full width, prominent */
.gm-bj-tile{
  background:linear-gradient(135deg,#0a2e12 0%,#071a0a 100%);
  border:2px solid #2d7040;
  border-radius:16px;
  padding:0;
  cursor:pointer;
  transition:transform .15s,border-color .2s;
  overflow:hidden;
  display:flex;
  align-items:stretch;
  min-height:80px;
  margin-bottom:10px;
  width:100%;
}
.gm-bj-tile:active{transform:scale(.97)}
.gm-bj-tile:hover{border-color:#3d9e5a}
.gm-bj-left{flex:1;padding:16px;display:flex;flex-direction:column;justify-content:center;gap:4px}
.gm-bj-title{font-size:20px;font-weight:900;color:#7fff9a;letter-spacing:.5px}
.gm-bj-sub{font-size:12px;color:#4a8f60}
.gm-bj-suits{padding:16px;font-size:36px;display:flex;align-items:center;gap:2px;color:#1d5c30;text-shadow:0 0 12px rgba(125,255,154,.3)}

/* ── Garage ──────────────────────────────────────────────────────────────── */
.car-list{display:flex;flex-direction:column;gap:8px}
.car-item{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px}
.car-item.owned{border-color:var(--acc);background:linear-gradient(135deg,rgba(29,110,245,.08),var(--bg1))}
.car-icon{font-size:28px;flex-shrink:0}
.car-info{flex:1;min-width:0}
.car-name{font-size:14px;font-weight:700;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.car-sub{font-size:12px;color:var(--txt2);margin-top:3px}
.car-btn{flex-shrink:0}

/* ── Businesses ──────────────────────────────────────────────────────────── */
.biz-list{display:flex;flex-direction:column;gap:8px}
.biz-item{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;align-items:center;gap:12px}
.biz-item.owned{border-color:rgba(14,201,122,.4);background:linear-gradient(135deg,rgba(14,201,122,.06),var(--bg1))}
.biz-ico{font-size:26px;flex-shrink:0}
.biz-info{flex:1;min-width:0}
.biz-name{font-size:13px;font-weight:700}
.biz-sub{font-size:11px;color:var(--txt2);margin-top:3px}

/* ── Tuning ──────────────────────────────────────────────────────────────── */
.tune-card{background:var(--bg1);border:1px solid var(--border);border-radius:16px;padding:18px;margin-bottom:10px}
.tune-stat{display:flex;justify-content:space-between;font-size:13px;color:var(--txt2);margin-bottom:10px}
.tune-input-row{display:flex;gap:8px}
.tune-input{flex:1;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;padding:10px 14px;color:var(--txt);font-size:14px;font-weight:600}
.tune-input:focus{outline:none;border-color:var(--acc)}
.tune-cost-preview{font-size:12px;color:var(--txt2);text-align:center;padding:8px 0 2px}

/* ── Top ─────────────────────────────────────────────────────────────────── */
.top-list{display:flex;flex-direction:column;gap:6px}
.top-item{background:var(--bg1);border:1px solid var(--border);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px}
.top-item.gold{border-color:#f0a830;background:linear-gradient(135deg,rgba(240,168,48,.1),var(--bg1))}
.top-item.silver{border-color:#90a0b0;background:linear-gradient(135deg,rgba(144,160,176,.08),var(--bg1))}
.top-item.bronze{border-color:#cd7f32;background:linear-gradient(135deg,rgba(205,127,50,.08),var(--bg1))}
.top-rank{font-size:22px;width:32px;text-align:center;flex-shrink:0}
.top-info{flex:1}
.top-name{font-size:14px;font-weight:700}
.top-sub{font-size:11px;color:var(--txt2);margin-top:2px}
.top-bal{font-size:15px;font-weight:800;color:var(--green);flex-shrink:0}

/* ── Placeholder ─────────────────────────────────────────────────────────── */
.ph{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:14px}
.ph-ico{font-size:52px}
.ph-t{font-size:18px;font-weight:700}
.ph-s{font-size:13px;color:var(--txt2);line-height:1.6;max-width:260px}
.ph-badge{background:var(--acc);color:#fff;font-size:11px;font-weight:700;padding:4px 16px;border-radius:20px}

/* ── Toast ───────────────────────────────────────────────────────────────── */
.toast{position:fixed;top:calc(var(--hdr) + 8px);left:12px;right:12px;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;z-index:999;animation:toast-in .25s ease,toast-out .25s ease 2s both;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.toast.ok{background:#0d4020;border:1px solid #2d9e50;color:#7fff9a}
.toast.err{background:#401010;border:1px solid #9e2d2d;color:#ff9a9a}
@keyframes toast-in{from{transform:translateY(-10px);opacity:0}to{transform:none;opacity:1}}
@keyframes toast-out{from{opacity:1}to{opacity:0;pointer-events:none}}

/* ═══════════════════════════════════════════════════════════════════════════
   DONATE
   ═══════════════════════════════════════════════════════════════════════════ */
.donate-hero{background:linear-gradient(135deg,#1a1200,#0d0a00);border:1px solid #8a6820;border-radius:18px;padding:24px;text-align:center;margin-bottom:10px}
.donate-hero-ico{font-size:48px;margin-bottom:8px}
.donate-hero-title{font-size:22px;font-weight:900;color:var(--gold);letter-spacing:.5px}
.donate-hero-sub{font-size:12px;color:#8a7040;margin-top:4px}
.donate-rate{background:rgba(240,168,48,.08);border:1px solid rgba(240,168,48,.2);border-radius:10px;padding:10px 14px;font-size:12px;color:var(--gold);text-align:center;margin-bottom:12px}
.donate-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.donate-card{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:border-color .2s}
.donate-card-left{display:flex;align-items:center;gap:12px}
.donate-emoji{font-size:28px;flex-shrink:0}
.donate-info{display:flex;flex-direction:column;gap:3px}
.donate-name{font-size:14px;font-weight:700;color:var(--txt)}
.donate-amount{font-size:12px;color:var(--green);font-weight:600}
.donate-btn{background:linear-gradient(135deg,#3a2800,#1a1200);border:2px solid #8a6820;border-radius:10px;padding:10px 16px;color:var(--gold);font-size:13px;font-weight:800;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:transform .1s}
.donate-btn:active{transform:scale(.95)}
.donate-btn:disabled{opacity:.5;cursor:default}
.donate-prembot{background:linear-gradient(135deg,rgba(240,168,48,.1),rgba(240,168,48,.03));border:1px solid rgba(240,168,48,.25);border-radius:14px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.donate-prembot-btn{background:var(--gold);color:#000;font-size:12px;font-weight:800;padding:8px 14px;border-radius:8px;text-decoration:none;white-space:nowrap;flex-shrink:0}

/* ── Donate custom card ──────────────────────────────────────────────────── */
.donate-custom-card{background:var(--bg1);border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:12px;display:flex;flex-direction:column;gap:12px}
.donate-stars-row{display:flex;flex-direction:column;gap:6px}
.donate-stars-lbl{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.5px}
.donate-stars-input{background:var(--bg2);border:2px solid rgba(240,168,48,.3);border-radius:10px;padding:12px 16px;color:var(--gold);font-size:22px;font-weight:800;text-align:center;-moz-appearance:textfield}
.donate-stars-input::-webkit-outer-spin-button,.donate-stars-input::-webkit-inner-spin-button{-webkit-appearance:none}
.donate-stars-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 12px rgba(240,168,48,.2)}
.donate-preview{text-align:center;font-size:22px;font-weight:800;color:var(--green);min-height:32px}
.donate-pay-btn{width:100%;background:linear-gradient(135deg,#3a2800,#1a1200);border:2px solid #8a6820;border-radius:12px;padding:14px;color:var(--gold);font-size:15px;font-weight:800;cursor:pointer;transition:transform .1s;letter-spacing:.3px}
.donate-pay-btn:active{transform:scale(.97)}
.donate-pay-btn:disabled{opacity:.4;cursor:default}

/* ═══════════════════════════════════════════════════════════════════════════
   POKER GATE (entry screen)
   ═══════════════════════════════════════════════════════════════════════════ */
.poker-gate{display:flex;flex-direction:column;gap:12px}
.poker-gate-bg{background:radial-gradient(ellipse at 50% 40%,#1a0d2e 0%,#0d0618 60%,#040208 100%);border:2px solid #6a3a9a;border-radius:20px;padding:28px 20px;text-align:center}
.poker-suits{font-size:24px;color:rgba(160,100,220,.5);letter-spacing:8px;margin-bottom:12px}
.poker-club-name{font-size:28px;font-weight:900;color:#c084f0;letter-spacing:3px;line-height:1.2;text-shadow:0 0 30px rgba(192,132,240,.4)}
.poker-club-sub{font-size:12px;color:#6a3a7a;margin-top:8px;letter-spacing:.3px}
.poker-stats-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.poker-stat{background:linear-gradient(135deg,#0d0618,#080412);border:1px solid #3a1a5a;border-radius:12px;padding:14px;text-align:center}
.poker-stat-v{font-size:22px;font-weight:900;color:#c084f0;margin-bottom:3px}
.poker-stat-l{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:#6a3a7a}
.poker-entry-block{background:linear-gradient(135deg,#0d0618,#080412);border:1px solid #3a1a5a;border-radius:16px;padding:18px}
.poker-entry-title{font-size:15px;font-weight:800;color:#c084f0;margin-bottom:14px;text-align:center;letter-spacing:.3px}
.poker-entry-opts{display:flex;flex-direction:column;gap:0}
.poker-opt{display:flex;flex-direction:column;gap:8px;padding:14px 0}
.poker-opt-label{font-size:11px;font-weight:700;color:#6a3a9a;text-transform:uppercase;letter-spacing:.6px}
.poker-opt-divider{text-align:center;font-size:11px;color:#3a1a5a;padding:4px 0;position:relative}
.poker-opt-divider::before,.poker-opt-divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:#2a0a4a}
.poker-opt-divider::before{left:0}.poker-opt-divider::after{right:0}
.poker-code-input{flex:1;background:#080412;border:2px solid #3a1a5a;border-radius:10px;padding:12px 14px;color:#c084f0;font-size:18px;font-weight:800;text-align:center;letter-spacing:4px;text-transform:uppercase;font-family:'Courier New',monospace}
.poker-code-input:focus{outline:none;border-color:#6a3a9a;box-shadow:0 0 12px rgba(106,58,154,.3)}
.poker-code-btn{background:linear-gradient(135deg,#6a3a9a,#3a1a5a);border:none;border-radius:10px;padding:12px 18px;color:#fff;font-size:18px;font-weight:800;cursor:pointer;transition:transform .1s;flex-shrink:0}
.poker-code-btn:active{transform:scale(.93)}
.poker-code-btn:disabled{opacity:.5}
.poker-stars-btn{width:100%;background:linear-gradient(135deg,#4a1a7a,#2a0a4a);border:2px solid #7a3aaa;border-radius:12px;padding:16px;color:#c084f0;font-size:15px;font-weight:800;cursor:pointer;letter-spacing:.3px;transition:transform .1s}
.poker-stars-btn:active{transform:scale(.97)}
.poker-stars-btn:disabled{opacity:.5}

/* ── Poker Lobby ─────────────────────────────────────────────────────────── */
.poker-lobby-header{background:radial-gradient(ellipse at 50% 0%,#1a0d2e,#080412);border:1px solid #3a1a5a;border-radius:16px;padding:18px;text-align:center;margin-bottom:10px}
.poker-lobby-suits{font-size:18px;color:rgba(160,100,220,.4);letter-spacing:6px;margin-bottom:6px}
.poker-lobby-title{font-size:20px;font-weight:900;color:#c084f0;letter-spacing:2px;margin-bottom:8px}
.poker-lobby-stats{display:flex;justify-content:center;gap:20px;font-size:13px;color:#6a3a9a}
.poker-tables-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.poker-table-row{background:linear-gradient(135deg,#0d0618,#080412);border:1px solid #3a1a5a;border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:14px;transition:border-color .2s}
.poker-table-row.active{border-color:#5a2a8a}
.poker-table-blind{font-size:17px;font-weight:900;color:#c084f0;min-width:60px;text-align:center;flex-shrink:0}
.poker-table-mid{flex:1}
.poker-table-label{font-size:10px;color:#6a3a7a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.poker-seats{display:flex;gap:5px}
.poker-seat{width:14px;height:14px;border-radius:50%;background:#1a0a2a;border:1px solid #3a1a5a}
.poker-seat.taken{background:#6a3a9a;border-color:#c084f0;box-shadow:0 0 6px rgba(192,132,240,.4)}
.poker-table-players{font-size:14px;font-weight:800;color:#6a3a9a;flex-shrink:0}
.poker-table-row.active .poker-table-players{color:#c084f0}
.poker-table-row{cursor:pointer}
.poker-table-row:active{transform:scale(.98)}
.pk-names-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.pk-name-chip{font-size:9px;font-weight:600;color:#6a3a9a;background:rgba(106,58,154,.12);border:1px solid #2a0a4a;border-radius:8px;padding:2px 6px}

/* ═══════════════════════════════════════════════════════════════════════════
   BLACKJACK — full immersive table
   ═══════════════════════════════════════════════════════════════════════════ */

.bj-page{display:flex;flex-direction:column;gap:14px}

/* ── Bet screen ──────────────────────────────────────────────────────────── */
.bj-bet-screen{
  background:linear-gradient(160deg,#071f0e 0%,#051209 100%);
  border:2px solid #1d5c30;border-radius:20px;padding:28px 20px;text-align:center
}
.bj-logo{font-size:56px;margin-bottom:6px;line-height:1}
.bj-title{font-size:26px;font-weight:900;color:#7fff9a;letter-spacing:2px;margin-bottom:4px;text-shadow:0 0 20px rgba(127,255,154,.3)}
.bj-subtitle{font-size:11px;color:#3a7a50;margin-bottom:18px;letter-spacing:.3px}
.bj-bal-row{font-size:14px;color:var(--txt2);margin-bottom:14px}
.bj-bal-row strong{color:var(--green);font-size:16px}
.bj-quick-bets{display:flex;gap:6px;margin-bottom:10px}
.bj-qb{flex:1;background:rgba(14,201,122,.08);border:1px solid rgba(14,201,122,.22);border-radius:8px;padding:9px 4px;color:#7fff9a;font-size:12px;font-weight:700;cursor:pointer;transition:background .15s}
.bj-qb:active{background:rgba(14,201,122,.22)}
.bj-input-row{display:flex;gap:8px;margin-bottom:14px}
.bj-input{
  flex:1;background:rgba(0,0,0,.45);border:2px solid #1d5c30;border-radius:12px;
  padding:12px 16px;color:#7fff9a;font-size:20px;font-weight:800;text-align:center;
  -moz-appearance:textfield
}
.bj-input::-webkit-outer-spin-button,.bj-input::-webkit-inner-spin-button{-webkit-appearance:none}
.bj-input:focus{outline:none;border-color:#3d9e5a;box-shadow:0 0 16px rgba(61,158,90,.3)}
.bj-input::placeholder{color:#2a5c3a;font-size:15px;font-weight:400}
.bj-start-btn{
  width:100%;background:linear-gradient(135deg,#1d7038,#0d4020);
  border:2px solid #2d9e50;border-radius:14px;padding:16px;
  color:#7fff9a;font-size:17px;font-weight:900;cursor:pointer;
  letter-spacing:.5px;transition:transform .1s,box-shadow .1s
}
.bj-start-btn:active{transform:scale(.97)}
.bj-start-btn:disabled{opacity:.5;cursor:default}
.bj-hint{font-size:11px;color:#2a5c3a;margin-top:10px}

/* ── Game wrap — fills all available height ──────────────────────────────── */
.bj-game-wrap{
  display:flex;flex-direction:column;
  height:calc(100dvh - var(--hdr) - var(--nav) - 24px);
  min-height:460px;
  gap:0;
}

/* ── Felt table ──────────────────────────────────────────────────────────── */
.bj-table{
  flex:1;
  background:
    radial-gradient(ellipse at 50% 35%,#1e7a38 0%,#114022 50%,#071a0d 100%);
  border:3px solid #8a6820;
  border-bottom:none;
  border-radius:20px 20px 0 0;
  display:flex;flex-direction:column;
  overflow:hidden;position:relative;
}
/* subtle dot pattern */
.bj-table::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg width='8' height='8' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='1' height='1' x='0' y='0' fill='%23fff' fill-opacity='0.02'/%3E%3Crect width='1' height='1' x='4' y='4' fill='%23fff' fill-opacity='0.02'/%3E%3C/svg%3E");
}

/* ── Dealer zone (top) ───────────────────────────────────────────────────── */
.bj-dzone{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding:16px 12px 10px;position:relative;z-index:1;
}
.bj-zone-label{
  font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;
  color:rgba(255,255,255,.45);display:flex;align-items:center;gap:8px;margin-bottom:10px;
}
.bj-score{
  background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.18);
  border-radius:8px;padding:2px 10px;font-size:13px;font-weight:800;color:#fff;
  min-width:28px;text-align:center;
}

/* ── Table center rail ───────────────────────────────────────────────────── */
.bj-rail{
  height:36px;position:relative;z-index:1;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.bj-rail::before{
  content:'';position:absolute;left:20px;right:20px;top:50%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,215,100,.35),transparent);
}
.bj-rail-chip{
  width:34px;height:34px;border-radius:50%;
  background:radial-gradient(#9a7828,#6a4a10);
  border:2px solid #c8a040;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:#ffe080;font-weight:900;position:relative;z-index:1;
  box-shadow:0 2px 8px rgba(0,0,0,.5);
}

/* ── Player zone (bottom) ────────────────────────────────────────────────── */
.bj-pzone{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:10px 12px 14px;position:relative;z-index:1;
}

/* ── Hands ───────────────────────────────────────────────────────────────── */
.bj-hand{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;min-height:80px}

/* ── Result overlay ──────────────────────────────────────────────────────── */
.bj-overlay{
  position:absolute;inset:0;border-radius:inherit;
  background:rgba(0,0,0,.82);backdrop-filter:blur(2px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;z-index:10;animation:bjFadeIn .3s ease;
}
@keyframes bjFadeIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:none}}
.bj-res-ico{font-size:60px;line-height:1;animation:bjPop .4s ease .1s both}
@keyframes bjPop{from{transform:scale(.5)}to{transform:scale(1)}}
.bj-res-title{font-size:28px;font-weight:900;letter-spacing:.5px;text-align:center}
.bj-res-sub{font-size:15px;color:rgba(255,255,255,.7);font-weight:600}
.bj-res-win   .bj-res-title{color:#7fff9a;text-shadow:0 0 20px rgba(127,255,154,.5)}
.bj-res-lose  .bj-res-title{color:#ff6b6b;text-shadow:0 0 20px rgba(255,107,107,.5)}
.bj-res-push  .bj-res-title{color:#ffe88a}
.bj-res-bj    .bj-res-title{color:#ffd700;text-shadow:0 0 30px rgba(255,215,0,.7)}

/* ── Controls panel ──────────────────────────────────────────────────────── */
.bj-controls{
  background:#061208;
  border:3px solid #8a6820;border-top:1px solid #3a5028;
  border-radius:0 0 20px 20px;
  padding:12px;flex-shrink:0;
}
.bj-info-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--txt2);margin-bottom:10px;padding:0 2px;
}
.bj-info-row strong{color:var(--txt);font-size:13px}
.bj-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.bj-actions.three{grid-template-columns:1fr 1fr 1fr}
.bj-btn{
  padding:16px 8px;border-radius:12px;font-size:13px;font-weight:800;
  cursor:pointer;border:none;transition:transform .1s,opacity .15s;
  letter-spacing:.2px;line-height:1.2;
}
.bj-btn:active{transform:scale(.93)}
.bj-btn.hit  {background:linear-gradient(160deg,#1a6e34,#0d4020);color:#7fff9a;border:2px solid #2d9e50}
.bj-btn.stand{background:linear-gradient(160deg,#6e1a1a,#401010);color:#ff9a9a;border:2px solid #9e2d2d}
.bj-btn.dbl  {background:linear-gradient(160deg,#6e5a1a,#403010);color:#ffe07a;border:2px solid #9e832d}
.bj-btn.again{background:linear-gradient(160deg,#1d6ef5,#0d4aaa);color:#fff;border:2px solid #4d94ff;grid-column:1/-1;font-size:15px;padding:18px}
.bj-btn:disabled{opacity:.35;cursor:default}

/* ── Pixel playing cards ─────────────────────────────────────────────────── */
@keyframes dealD{from{transform:translateY(-24px) rotate(-6deg);opacity:0}to{transform:none;opacity:1}}
@keyframes dealP{from{transform:translateY(24px) rotate(6deg);opacity:0} to{transform:none;opacity:1}}

.pc{
  background:#fefef0;border:2px solid #222;border-radius:5px;
  box-shadow:3px 3px 0 rgba(0,0,0,.7);
  position:relative;flex-shrink:0;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:3px 4px;
  font-family:'Courier New',monospace;font-weight:900;
}
/* dealer cards — slightly smaller (across the table) */
.bj-dzone .pc{width:54px;height:76px;animation:dealD .2s ease-out both}
.bj-dzone .pc .tl{font-size:11px;line-height:1.1;display:flex;flex-direction:column;align-items:flex-start}
.bj-dzone .pc .cm{font-size:22px;text-align:center;align-self:center}
.bj-dzone .pc .br{font-size:11px;line-height:1.1;display:flex;flex-direction:column;align-items:flex-end;transform:rotate(180deg)}
/* player cards — bigger (in your hands) */
.bj-pzone .pc{width:64px;height:90px;animation:dealP .2s ease-out both}
.bj-pzone .pc .tl{font-size:13px;line-height:1.1;display:flex;flex-direction:column;align-items:flex-start}
.bj-pzone .pc .cm{font-size:26px;text-align:center;align-self:center}
.bj-pzone .pc .br{font-size:13px;line-height:1.1;display:flex;flex-direction:column;align-items:flex-end;transform:rotate(180deg)}

.pc.red{color:#cc0000}
.pc.blk{color:#111}
.pc-back{
  background:repeating-linear-gradient(45deg,#1a237e 0,#1a237e 5px,#283593 5px,#283593 10px);
  border-color:#0d1547;
}
.pc-back .tl,.pc-back .cm,.pc-back .br{display:none}

/* ═══════════════════════════════════════════════════════════════════════════
   POKER SIT
   ═══════════════════════════════════════════════════════════════════════════ */
.pksit-page{display:flex;flex-direction:column;gap:12px}
.pksit-header{background:radial-gradient(ellipse at 50% 40%,#1a0d2e 0%,#0d0618 60%,#040208 100%);border:2px solid #6a3a9a;border-radius:18px;padding:20px;text-align:center}
.pksit-suits{font-size:18px;color:rgba(160,100,220,.4);letter-spacing:8px;margin-bottom:8px}
.pksit-table-name{font-size:20px;font-weight:900;color:#c084f0;letter-spacing:1px}
.pksit-table-blind{font-size:12px;color:#6a3a7a;margin-top:4px}
.pksit-card{background:linear-gradient(135deg,#0d0618,#080412);border:1px solid #3a1a5a;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:8px}
.pksit-label{font-size:11px;font-weight:700;color:#6a3a9a;text-transform:uppercase;letter-spacing:.6px}
.pksit-select{background:#080412;border:2px solid #3a1a5a;border-radius:10px;padding:12px 14px;color:#c084f0;font-size:14px;font-weight:700;width:100%;-webkit-appearance:none;appearance:none}
.pksit-select:focus{outline:none;border-color:#6a3a9a}
.pksit-group-fixed{background:#080412;border:1px solid #3a1a5a;border-radius:10px;padding:12px 14px;color:#c084f0;font-size:14px;font-weight:700}
.pksit-group-bal{font-size:12px;color:var(--green);font-weight:800}
.pksit-amount-row{display:flex;gap:8px}
.pksit-amount{flex:1;background:#080412;border:2px solid rgba(192,132,240,.3);border-radius:10px;padding:12px 14px;color:#c084f0;font-size:22px;font-weight:800;text-align:center;-moz-appearance:textfield}
.pksit-amount::-webkit-outer-spin-button,.pksit-amount::-webkit-inner-spin-button{-webkit-appearance:none}
.pksit-amount:focus{outline:none;border-color:#c084f0;box-shadow:0 0 12px rgba(192,132,240,.2)}
.pksit-max-btn{background:linear-gradient(135deg,#4a1a7a,#2a0a4a);border:2px solid #7a3aaa;border-radius:10px;padding:10px 14px;color:#c084f0;font-size:12px;font-weight:800;cursor:pointer;flex-shrink:0;transition:transform .1s}
.pksit-max-btn:active{transform:scale(.93)}
.pksit-min-hint{font-size:11px;color:#3a1a5a;text-align:center}
.pksit-preview{font-size:14px;font-weight:700;text-align:center;min-height:20px;transition:color .2s}
.pksit-preview.pksit-ok{color:var(--green)}
.pksit-preview.pksit-warn{color:var(--red)}
.pksit-btn{width:100%;background:linear-gradient(135deg,#4a1a7a,#2a0a4a);border:2px solid #7a3aaa;border-radius:14px;padding:16px;color:#c084f0;font-size:16px;font-weight:900;cursor:pointer;letter-spacing:.3px;transition:transform .1s}
.pksit-btn:active{transform:scale(.97)}
.pksit-btn:disabled{opacity:.4;cursor:default}

/* ═══════════════════════════════════════════════════════════════════════════
   POKER CARDS (pkc) — clean cards for poker table
   ═══════════════════════════════════════════════════════════════════════════ */
.pkc{
  background:#fefef0;border:2px solid #222;border-radius:6px;
  box-shadow:2px 2px 0 rgba(0,0,0,.7);flex-shrink:0;
  display:grid;grid-template-rows:auto 1fr auto;padding:3px;
  font-family:'Courier New',monospace;font-weight:900;user-select:none;
}
.pkc-red{color:#cc0000}
.pkc-blk{color:#111}
.pkc-tl{display:flex;flex-direction:column;align-items:flex-start;line-height:1.05}
.pkc-br{display:flex;flex-direction:column;align-items:flex-end;line-height:1.05;transform:rotate(180deg);align-self:end;justify-self:end}
.pkc-cm{display:flex;align-items:center;justify-content:center}
.pkc-rank{display:block;font-weight:900}
.pkc-suit{display:block}
.pkc-com{width:48px;height:70px}
.pkc-com .pkc-rank{font-size:12px}
.pkc-com .pkc-suit{font-size:10px}
.pkc-com .pkc-cm{font-size:24px}
.pkc-hole{width:58px;height:84px}
.pkc-hole .pkc-rank{font-size:14px}
.pkc-hole .pkc-suit{font-size:12px}
.pkc-hole .pkc-cm{font-size:28px}
.pkc-opp{width:20px;height:30px;border-radius:3px;border-width:1px}
.pkc-back{background:repeating-linear-gradient(45deg,#1a237e 0,#1a237e 5px,#283593 5px,#283593 10px);border-color:#0d1547}

/* ═══════════════════════════════════════════════════════════════════════════
   POKER TABLE
   ═══════════════════════════════════════════════════════════════════════════ */

.ptable-page{height:calc(100dvh - var(--hdr) - var(--nav));overflow:hidden}
.ptable-page-inner{display:flex;flex-direction:column;height:100%}

/* ── Opponents row (top) ─────────────────────────────────────────────────── */
.ptable-opponents{
  display:flex;gap:6px;padding:6px 8px;overflow-x:auto;scrollbar-width:none;
  background:rgba(0,0,0,.35);border-bottom:1px solid #1a3a20;
  flex-shrink:0;min-height:86px;align-items:center;
}
.ptable-opponents::-webkit-scrollbar{display:none}

.pk-opp{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:5px 7px;border-radius:10px;border:1px solid #1a3a1a;
  background:rgba(0,0,0,.4);min-width:62px;flex-shrink:0;position:relative;
  transition:border-color .2s;
}
.pk-opp.pk-acting{border-color:#c084f0;box-shadow:0 0 10px rgba(192,132,240,.3)}
.pk-opp.pk-fold{opacity:.35}
.pk-avatar{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,#3a1a5a,#1a0d2e);border:2px solid #4a2a7a;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:800;color:#c084f0;flex-shrink:0;
}
.pk-opp-name{font-size:9px;font-weight:600;color:var(--txt2);max-width:58px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
.pk-opp-chips{font-size:9px;font-weight:700;color:var(--green)}
.pk-opp-cards{display:flex;gap:2px;margin-top:1px}
.pk-opp-cards .pc{width:18px;height:26px;border-radius:3px;border-width:1px;box-shadow:1px 1px 0 rgba(0,0,0,.5);animation:none}
.pk-badge{font-size:8px;font-weight:700;color:#c084f0;background:rgba(192,132,240,.12);border:1px solid rgba(192,132,240,.25);border-radius:5px;padding:1px 4px;white-space:nowrap;margin-top:1px}
.pk-d-btn{position:absolute;top:-6px;right:-6px;width:16px;height:16px;border-radius:50%;background:var(--gold);color:#000;font-size:7px;font-weight:900;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.5)}

/* ── Felt (community) ────────────────────────────────────────────────────── */
.ptable-felt{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:6px 8px;gap:6px;
  background:radial-gradient(ellipse at 50% 50%,#0d3a1a 0%,#061508 100%);
  border:2px solid #1a5a30;border-left:none;border-right:none;
}
.ptable-felt-info{display:flex;gap:10px;font-size:11px;align-items:center;flex-wrap:wrap;justify-content:center}
.ptable-phase{color:#c084f0;font-weight:700}
.ptable-pot{color:var(--gold);font-weight:800;font-size:13px}
.ptable-curbet{color:var(--txt2);font-size:10px}
.ptable-community{display:flex;gap:5px;align-items:center;justify-content:center}
.ptable-community .pc,.ptable-my-hole .pc{display:none} /* replaced by .pkc */
.pk-winner-msg{background:linear-gradient(135deg,rgba(192,132,240,.15),rgba(192,132,240,.05));border:1px solid rgba(192,132,240,.4);border-radius:10px;padding:7px 12px;font-size:11px;font-weight:700;color:#c084f0;text-align:center;max-width:280px}

/* ── Bottom (my area + controls) ────────────────────────────────────────── */
.ptable-bottom{flex-shrink:0;padding:6px 8px;display:flex;flex-direction:column;gap:5px;background:rgba(0,0,0,.4);border-top:1px solid #1a3a20}
.ptable-me-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ptable-my-hole{display:flex;gap:8px}
.pk-placeholder{width:48px;height:70px;border:2px dashed rgba(255,255,255,.1);border-radius:6px;flex-shrink:0}
.ptable-my-info{text-align:right;flex:1}
.ptable-my-chips{font-size:15px;font-weight:800;color:var(--green);display:flex;align-items:center;justify-content:flex-end;gap:5px}
.ptable-my-hand{font-size:11px;color:var(--gold);font-weight:600;margin-top:2px}
.pk-wait-txt{font-size:11px;color:var(--txt3);padding:20px 0}

/* ── Actions ─────────────────────────────────────────────────────────────── */
.ptable-actions{display:flex;flex-direction:column;gap:5px}
.pk-timer-wrap{display:flex;align-items:center;gap:8px}
.pk-timer-bar{flex:1;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.pk-timer-fill{height:100%;background:linear-gradient(90deg,#c084f0,#7a3aaa);border-radius:2px;transition:width 1s linear}
.pk-timer-wrap.pk-timer-urgent .pk-timer-fill{background:linear-gradient(90deg,var(--red),#aa2a2a)}
.pk-timer-num{font-size:10px;font-weight:800;color:var(--txt2);min-width:22px;text-align:right}
.pk-actions{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.pk-raise-row{display:flex;gap:5px}
.pk-raise-input{flex:1;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:8px 10px;color:var(--txt);font-size:12px;font-weight:600;-moz-appearance:textfield}
.pk-raise-input::-webkit-outer-spin-button,.pk-raise-input::-webkit-inner-spin-button{-webkit-appearance:none}
.pk-raise-input:focus{outline:none;border-color:var(--acc)}
.pk-btn{padding:10px 6px;border-radius:9px;font-size:12px;font-weight:800;cursor:pointer;border:none;transition:transform .1s;letter-spacing:.1px}
.pk-btn:active{transform:scale(.92)}
.pk-btn:disabled{opacity:.35;cursor:default}
.pk-fold {background:linear-gradient(160deg,#4a0a0a,#2a0505);color:#ff8888;border:1px solid #7a2a2a}
.pk-check{background:linear-gradient(160deg,#0a3a1a,#051a0d);color:#7fff9a;border:1px solid #1a7a3a}
.pk-call {background:linear-gradient(160deg,#1a3a7a,#0d1a4a);color:#88aaff;border:1px solid #2a5aaa}
.pk-raise{background:linear-gradient(160deg,#4a3a0a,#2a2005);color:#ffd070;border:1px solid #8a6a1a}
.ptable-stand-btn{width:100%;background:transparent;border:1px solid #2a1a3a;border-radius:8px;padding:7px;color:#4a2a5a;font-size:11px;font-weight:600;cursor:pointer;transition:border-color .15s}
.ptable-stand-btn:active{border-color:#6a3a9a;color:#c084f0}
.pk-info-msg{text-align:center;font-size:11px;color:var(--txt2);padding:5px 0}
