/* ═══════════════════════════════════════════════════════════
   TheVegasLab Roulette — style.css
   Casino Royale dark theme
═══════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --gold:       #d4a843;
  --gold-dim:   #8a7a5a;
  --gold-faint: rgba(212,168,67,0.12);
  --red:        #c41e3a;
  --green-felt: #0d5a30;
  --bg:         #080808;
  --bg2:        #0c0c0c;
  --text:       #f5f0e8;
  --font-d: 'Playfair Display', serif;
  --font-b: 'DM Sans', sans-serif;
  --font-n: 'Oswald', sans-serif;
  --chip-rack-size: clamp(36px, 2.81vw, 54px);
  --bet-chip-size:  clamp(22px, 1.7vw, 32px);
  --icon-btn-size:  clamp(26px, 1.77vw, 34px);
  --bar-height:     clamp(42px, 2.92vw, 56px);
  --spin-btn-w:     clamp(120px, 8.85vw, 170px);
  --qb-btn-w:       clamp(44px, 3.33vw, 64px);
}

html, body { width:100%; height:100%; overflow:hidden; overscroll-behavior:none; background:var(--bg); color:var(--text); font-family:var(--font-b); -webkit-font-smoothing:antialiased; -webkit-tap-highlight-color:transparent; -webkit-touch-callout:none; }

/* ═══ LOADING SCREEN ═══ */
#loading-screen { position:fixed; inset:0; z-index:99999; background:#080808; display:flex; align-items:center; justify-content:center; transition:opacity 0.5s ease, visibility 0.5s ease; }
#loading-screen.fade-out { opacity:0; visibility:hidden; pointer-events:none; }
.loading-content { display:flex; flex-direction:column; align-items:center; gap:12px; }
.loading-wheel { font-size:clamp(48px, 6vw, 72px); color:#d4a843; animation:wheelSpin 2s linear infinite; }
@keyframes wheelSpin { 0%{transform:rotate(0)} 100%{transform:rotate(360deg)} }
.loading-title { font-family:var(--font-d); font-size:clamp(24px, 4vw, 44px); font-weight:900; color:#d4a843; letter-spacing:0.12em; text-shadow:0 0 30px rgba(212,168,67,0.3); }
.loading-sub { font-family:var(--font-n); font-size:clamp(10px, 1.5vw, 16px); font-weight:700; color:rgba(212,168,67,0.5); letter-spacing:0.3em; }
.loading-bar-track { width:clamp(180px, 30vw, 320px); height:3px; background:rgba(212,168,67,0.12); border-radius:2px; overflow:hidden; margin-top:8px; }
.loading-bar-fill { height:100%; width:0%; background:linear-gradient(90deg, #d4a843, #e8c46a); border-radius:2px; transition:width 0.3s ease; }
.loading-text { font-family:var(--font-n); font-size:clamp(9px, 1.2vw, 13px); letter-spacing:0.15em; color:rgba(255,255,255,0.25); text-transform:uppercase; }

/* ═══ SCREENS ═══ */
.screen { position:fixed; inset:0; display:none; }
.screen.active { display:flex; }

/* ═══ SETUP SCREEN ═══ */
#setup-screen { align-items:stretch; justify-content:stretch; background:radial-gradient(ellipse at center, #1a2a1a 0%, #0a0a0a 70%); overflow:hidden; }
.setup-overlay { position:absolute; inset:0; background:rgba(0,0,0,0.45); pointer-events:none; }
.setup-scroll { position:relative; z-index:2; width:100%; height:100%; overflow-y:auto; display:flex; align-items:flex-start; justify-content:center; padding:clamp(10px, 1.04vw, 20px) clamp(10px, 0.83vw, 16px) clamp(16px, 1.67vw, 32px); scrollbar-width:thin; scrollbar-color:rgba(212,168,67,0.3) transparent; }
.setup-content { width:100%; max-width:clamp(540px, 44.8vw, 860px); display:flex; flex-direction:column; align-items:center; margin:auto 0; }
.setup-content--3col { max-width:clamp(720px, 62vw, 1200px); display:grid; grid-template-columns:1fr minmax(140px, 0.6fr); grid-template-rows:1fr auto; gap:0 clamp(16px, 1.5vw, 28px); align-items:stretch; }
.setup-brand-col { grid-row:1/2; order:2; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:clamp(16px, 1.5vw, 28px) clamp(10px, 1vw, 18px); background:linear-gradient(180deg, rgba(20,15,10,0.7), rgba(10,8,5,0.85)); border:1px solid rgba(212,168,67,0.2); border-radius:16px; text-align:center; position:relative; overflow:hidden; }
.setup-brand-col::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 30%, rgba(212,168,67,0.06) 0%, transparent 70%); pointer-events:none; }
.setup-brand-inner { display:flex; flex-direction:column; align-items:center; gap:clamp(4px, 0.4vw, 8px); flex:1; justify-content:center; position:relative; z-index:1; }
.setup-brand-logo { width:clamp(80px, 9vw, 160px); height:auto; filter:drop-shadow(0 0 20px rgba(212,168,67,0.2)); margin-bottom:clamp(4px, 0.5vw, 10px); }
.setup-brand-title { font-family:var(--font-d); font-size:clamp(28px, 3.2vw, 52px); font-weight:900; color:var(--gold); text-shadow:0 0 40px rgba(212,168,67,0.3), 0 2px 4px rgba(0,0,0,0.6); line-height:1; letter-spacing:0.08em; }
.setup-brand-divider { width:60%; display:flex; align-items:center; margin:clamp(4px, 0.3vw, 8px) 0; }
.divider-line { flex:1; height:1px; background:linear-gradient(90deg, transparent, rgba(212,168,67,0.5), transparent); }
.setup-brand-site { font-family:var(--font-b); font-size:clamp(8px, 0.6vw, 12px); letter-spacing:0.35em; text-transform:uppercase; color:var(--gold); white-space:nowrap; }
.setup-brand-sub { font-family:var(--font-b); font-size:clamp(7px, 0.45vw, 9px); letter-spacing:0.3em; text-transform:uppercase; color:rgba(212,168,67,0.45); line-height:1.5; margin-top:clamp(2px, 0.2vw, 4px); }
.setup-brand-disclaimer { display:none; margin-top:clamp(6px, 1vh, 10px); position:relative; z-index:1; }
.setup-brand-disclaimer p { font-family:var(--font-b); font-size:clamp(5px, 0.7vw, 7px); line-height:1.5; color:rgba(255,255,255,0.4); text-align:center; }
.setup-brand-disclaimer strong { color:rgba(200,168,74,0.6); font-weight:600; }
.setup-content--3col .setup-card { grid-row:1/2; order:1; }
.setup-content--3col .setup-disclaimer { grid-column:1/-1; max-width:100%; }
.setup-start-btn { display:flex; align-items:center; justify-content:center; gap:clamp(6px, 0.5vw, 10px); width:100%; padding:clamp(10px, 0.73vw, 14px); margin-top:auto; border-radius:12px; border:1px solid var(--gold); background:linear-gradient(135deg, var(--gold), #b89030, var(--gold)); color:#1a1a1a; font-family:var(--font-d); font-size:clamp(13px, 0.83vw, 16px); font-weight:700; text-transform:uppercase; letter-spacing:0.1em; cursor:pointer; transition:all 0.3s; box-shadow:0 4px 20px rgba(212,168,67,0.3), inset 0 1px 0 rgba(255,255,255,0.2); position:relative; z-index:1; }
.setup-start-btn:hover { transform:scale(1.03); box-shadow:0 6px 30px rgba(212,168,67,0.5); }
.setup-start-btn--brand { margin-top:clamp(10px, 1vw, 18px); }
.start-btn-icon { flex-shrink:0; width:clamp(16px, 1vw, 22px); height:clamp(16px, 1vw, 22px); }
.setup-card { width:100%; background:linear-gradient(135deg, rgba(20,15,10,0.95), rgba(10,8,5,0.95)); border:1px solid rgba(212,168,67,0.3); border-radius:16px; padding:clamp(12px, 1.04vw, 20px); box-shadow:0 20px 60px rgba(0,0,0,0.5), inset 0 1px 0 rgba(212,168,67,0.1); display:grid; grid-template-columns:1fr 1fr 1fr; gap:0 clamp(12px, 1.25vw, 24px); }
.setup-col { display:flex; flex-direction:column; }
.setup-col:not(:last-child) { border-right:1px solid rgba(212,168,67,0.1); padding-right:clamp(10px, 1.04vw, 20px); }
.setup-col:not(:first-child) { padding-left:4px; }
.setup-group { margin-bottom:clamp(10px, 0.83vw, 16px); }
.setup-label { display:block; font-size:clamp(9px, 0.57vw, 11px); font-weight:600; text-transform:uppercase; letter-spacing:0.15em; color:var(--gold); margin-bottom:clamp(6px, 0.42vw, 8px); }
.setup-sub-label { font-size:clamp(8px, 0.52vw, 10px); font-weight:500; text-transform:uppercase; letter-spacing:0.1em; color:var(--gold-dim); margin-bottom:clamp(4px, 0.31vw, 6px); margin-top:clamp(6px, 0.52vw, 10px); }
.btn-group { display:grid; grid-template-columns:repeat(3, 1fr); gap:6px; }
.btn-group.two-col { grid-template-columns:repeat(2, 1fr); }
.btn-group.four-col { grid-template-columns:repeat(4, 1fr); }
.variant-btn, .preset-btn { padding:clamp(5px, 0.42vw, 8px) clamp(4px, 0.31vw, 6px); border-radius:8px; border:1px solid rgba(212,168,67,0.2); background:rgba(255,255,255,0.05); color:var(--gold); font-family:var(--font-b); font-size:clamp(9px, 0.57vw, 11px); font-weight:500; cursor:pointer; transition:all 0.2s; }
.variant-btn:hover, .preset-btn:hover { background:rgba(212,168,67,0.1); border-color:rgba(212,168,67,0.4); }
.variant-btn.active, .preset-btn.active { background:linear-gradient(135deg, var(--gold), #a07830); color:#1a1a1a; font-weight:700; border-color:var(--gold); transform:scale(1.04); }
.preset-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:6px; }
.preset-btn { font-family:var(--font-n); font-size:clamp(10px, 0.68vw, 13px); }
.variant-desc { font-size:clamp(9px, 0.57vw, 11px); color:rgba(255,255,255,0.5); margin-top:clamp(3px, 0.31vw, 6px); line-height:1.5; text-align:center; min-height:clamp(20px, 1.67vw, 32px); }
.custom-input-row { display:flex; align-items:center; gap:0; margin-bottom:4px; }
.custom-input { flex:1; padding:clamp(7px, 0.52vw, 10px) clamp(10px, 0.73vw, 14px); border-radius:8px 0 0 8px; border:1px solid rgba(212,168,67,0.3); background:rgba(255,255,255,0.05); color:var(--text); font-family:var(--font-n); font-size:clamp(12px, 0.78vw, 15px); text-align:center; outline:none; min-width:0; -moz-appearance:textfield; }
.custom-input::-webkit-outer-spin-button, .custom-input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.custom-input:focus { border-color:var(--gold); }
.custom-input-btn { height:clamp(30px, 2.1vw, 38px); width:clamp(30px, 2.1vw, 38px); min-width:clamp(30px, 2.1vw, 38px); border:none; background:rgba(255,255,255,0.04); color:var(--gold); font-size:clamp(12px, 0.78vw, 16px); font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.15s; padding:0; border-radius:0; }
.custom-input-btn:last-child { border-radius:0 8px 8px 0; }
.custom-input-confirm { color:#6ddb6d; background:rgba(109,219,109,0.06); }
.custom-input-confirm:hover { background:rgba(109,219,109,0.18); }
.custom-input-clear { color:#f07070; background:rgba(240,112,112,0.06); }
.custom-input-clear:hover { background:rgba(240,112,112,0.18); }
.link-btn { background:none; border:none; color:var(--gold-dim); font-family:var(--font-b); font-size:clamp(9px, 0.57vw, 11px); cursor:pointer; text-decoration:underline; padding:0; display:inline-flex; align-items:center; gap:4px; }
.link-btn:hover { color:var(--gold); }
.link-btn .custom-check { color:#6ddb6d; font-size:clamp(10px, 0.68vw, 13px); font-weight:700; text-decoration:none; display:none; }
.setup-disclaimer { display:flex; align-items:flex-start; gap:clamp(8px, 0.63vw, 12px); margin-top:clamp(8px, 0.73vw, 14px); padding:clamp(12px, 0.94vw, 18px) clamp(14px, 1.04vw, 20px); background:rgba(200,168,74,0.06); border:1px solid rgba(212,168,67,0.28); border-radius:12px; width:100%; }
.setup-disclaimer-icon { flex-shrink:0; font-size:clamp(14px, 1.04vw, 18px); line-height:1.5; opacity:0.9; }
.setup-disclaimer p { font-family:var(--font-n); font-size:clamp(12px, 0.83vw, 14px); line-height:1.65; color:rgba(255,255,255,0.72); margin:0; }
.setup-disclaimer strong { color:#c8a84a; font-weight:700; }

@media (max-width: 580px) {
  .setup-content--3col { grid-template-columns:1fr; max-width:96vw; }
  .setup-brand-col { order:-1; flex-direction:row; padding:10px 16px; gap:12px; border-radius:12px; margin-bottom:8px; }
  .setup-brand-inner { flex-direction:row; gap:10px; }
  .setup-brand-logo { width:48px; margin-bottom:0; }
  .setup-brand-title { font-size:22px; }
  .setup-brand-divider, .setup-brand-sub, .setup-brand-disclaimer { display:none; }
  .setup-start-btn--brand { display:none; }
  .setup-card { grid-template-columns:1fr; gap:0; }
  .setup-col:not(:last-child) { border-right:none; padding-right:0; border-bottom:1px solid rgba(212,168,67,0.1); padding-bottom:16px; margin-bottom:16px; }
}

/* ═══ GAME SCREEN ═══ */
#game-screen { flex-direction:column; background:var(--bg); }
#game-screen.active { display:flex; }
#main-content { flex:1; display:flex; overflow:hidden; position:relative; z-index:1; min-height:0; }
#right-column { flex:1; display:flex; flex-direction:column; overflow:hidden; min-width:0; }

/* ═══ INFO BAR ═══ */
#info-bar { flex-shrink:0; height:clamp(32px, 2.2vw, 44px); background:linear-gradient(180deg, rgba(12,10,6,0.98), rgba(8,6,4,0.98)); border-bottom:1px solid rgba(212,168,67,0.12); box-shadow:0 2px 12px rgba(0,0,0,0.3); display:flex; align-items:center; z-index:5; }
#info-bar-inner { display:flex; align-items:center; gap:clamp(8px, 0.8vw, 16px); width:100%; padding:0 clamp(8px, 0.8vw, 16px); }
.info-stat { display:flex; flex-direction:column; gap:1px; flex-shrink:0; }
.info-lbl { font-size:clamp(5px, 0.36vw, 7px); letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.4); font-family:var(--font-n); white-space:nowrap; line-height:1; }
.info-val { font-size:clamp(11px, 0.73vw, 15px); font-weight:700; font-family:var(--font-n); color:rgba(255,255,255,0.9); white-space:nowrap; line-height:1.1; }
.info-gold { color:#d4a843; }
.result-badge { display:inline-flex; align-items:center; justify-content:center; min-width:clamp(20px, 1.4vw, 28px); height:clamp(18px, 1.2vw, 24px); padding:0 4px; border-radius:4px; font-size:clamp(10px, 0.68vw, 14px); }
.result-red { background:rgba(196,30,58,0.3); color:#ff8888; }
.result-black { background:rgba(40,40,50,0.5); color:#cccccc; }
.result-green { background:rgba(26,138,58,0.3); color:#88ff88; }
.info-phase { font-family:var(--font-n); font-size:clamp(7px, 0.47vw, 9px); font-weight:700; letter-spacing:0.12em; padding:3px clamp(5px, 0.42vw, 8px); border-radius:6px; text-transform:uppercase; white-space:nowrap; flex-shrink:0; margin-left:auto; }
.phase-open { background:rgba(120,120,140,0.15); color:rgba(255,255,255,0.5); border:1px solid rgba(255,255,255,0.15); }
.phase-placed { background:rgba(34,197,94,0.15); color:#22c55e; border:1px solid rgba(34,197,94,0.3); }
.phase-spinning { background:rgba(245,158,11,0.15); color:#f59e0b; border:1px solid rgba(245,158,11,0.3); }

/* ═══ HISTORY STRIP ═══ */
#history-strip { display:flex; gap:3px; align-items:center; overflow-x:auto; flex:1; margin:0 clamp(6px, 0.5vw, 12px); scrollbar-width:none; min-height:0; }
#history-strip::-webkit-scrollbar { display:none; }
.hist-result { width:clamp(20px, 1.4vw, 28px); height:clamp(20px, 1.4vw, 28px); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-n); font-size:clamp(7px, 0.52vw, 10px); font-weight:700; flex-shrink:0; }
.hist-red { background:linear-gradient(135deg, #c41e3a, #a01830); color:#fff; border:1px solid rgba(255,255,255,0.15); }
.hist-black { background:linear-gradient(135deg, #2a2a2a, #1a1a1a); color:#ccc; border:1px solid rgba(255,255,255,0.12); }
.hist-green { background:linear-gradient(135deg, #1a8a3a, #0d6a2c); color:#fff; border:1px solid rgba(255,255,255,0.15); }
.hist-result.latest { box-shadow:0 0 8px rgba(212,168,67,0.4); border-color:rgba(212,168,67,0.5); }

/* ═══ TABLE CONTAINER ═══ */
#table-container { flex:1; display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; min-height:0; touch-action:none; }
#table-scaler { transform-origin:center center; touch-action:none; }

/* ═══ ROULETTE TABLE FELT ═══ */
#roulette-table { position:relative; user-select:none; touch-action:none; background:linear-gradient(160deg, #1a6b35 0%, #228b3a 30%, #1a6b35 60%, #228b3a 100%); border:1px solid #d4a843; border-radius:10px; padding:clamp(6px, 0.5vw, 10px); box-shadow:0 0 4px 1px rgba(255,255,255,0.45), 0 0 12px 2px rgba(220,220,230,0.25), inset 0 0 40px rgba(0,0,0,0.3); }

.rt-wrap { display:grid; grid-template-columns:auto 1fr auto; grid-template-rows:auto auto auto; gap:clamp(2px, 0.2vw, 4px); font-family:var(--font-n); min-width:clamp(550px, 55vw, 1000px); }

/* Zero column */
.rt-zero-col { grid-row:1/2; grid-column:1/2; display:flex; flex-direction:column; gap:2px; position:relative; }
.rt-zero { min-width:clamp(36px, 3vw, 56px); display:flex; align-items:center; justify-content:center; font-size:clamp(18px, 1.5vw, 28px); font-weight:700; color:#fff; background:linear-gradient(135deg, #1a8a3a, #0d6a2c); border:1px solid rgba(255,255,255,0.25); border-radius:6px; cursor:pointer; transition:filter 0.14s; text-shadow:0 1px 3px rgba(0,0,0,0.5); position:relative; overflow:visible; }
.rt-zero:not(.rt-zero-top):not(.rt-zero-bot) { flex:1; }
.rt-zero-top, .rt-zero-bot { flex:1; }
.rt-zero:hover { filter:brightness(1.3); box-shadow:0 0 0 1px rgba(255,255,255,0.5) inset; }
.rt-zero-split { position:absolute; z-index:20; cursor:pointer; border-radius:2px; }
.rt-zero-split:hover { background:rgba(212,168,67,0.4); box-shadow:0 0 8px rgba(212,168,67,0.5); }
.rt-trio-zone { position:absolute; width:12px; height:12px; z-index:25; cursor:pointer; border-radius:50%; }
.rt-trio-zone:hover { background:rgba(212,168,67,0.5); box-shadow:0 0 10px rgba(212,168,67,0.6); }
.rt-basket-zone { position:absolute; bottom:-6px; right:-6px; width:14px; height:14px; z-index:25; cursor:pointer; border-radius:50%; }
.rt-basket-zone:hover { background:rgba(212,168,67,0.5); box-shadow:0 0 10px rgba(212,168,67,0.6); }
.rt-topline-zone { position:absolute; bottom:-6px; right:-6px; width:14px; height:14px; z-index:25; cursor:pointer; border-radius:50%; }
.rt-topline-zone:hover { background:rgba(212,168,67,0.5); box-shadow:0 0 10px rgba(212,168,67,0.6); }

/* Main grid area */
.rt-main { grid-row:1/2; grid-column:2/3; display:flex; flex-direction:column; gap:0; position:relative; }

.rt-grid { display:grid; grid-template-columns:repeat(12, 1fr); grid-template-rows:repeat(3, 1fr); gap:0; }

.rt-cell { position:relative; display:flex; align-items:center; justify-content:center; min-width:clamp(36px, 3vw, 56px); min-height:clamp(36px, 3vw, 56px); border:1px solid rgba(255,255,255,0.18); cursor:pointer; transition:filter 0.14s; overflow:visible; }
.rt-cell:hover { filter:brightness(1.35); z-index:10; }
.rt-cell.rt-red { background:linear-gradient(135deg, #c41e3a, #a01830); }
.rt-cell.rt-black { background:linear-gradient(135deg, #2a2d33, #1a1d23); }
.rt-num { font-size:clamp(14px, 1.2vw, 22px); font-weight:700; color:#fff; text-shadow:0 1px 3px rgba(0,0,0,0.5); pointer-events:none; position:relative; z-index:1; }
.rt-cell.result-number-highlight { box-shadow:0 0 0 3px #d4a843 inset, 0 0 20px rgba(212,168,67,0.6); z-index:50; filter:brightness(1.5) !important; }

/* Split zones */
.rt-split-h { position:absolute; right:-5px; top:8%; width:10px; height:84%; z-index:20; cursor:pointer; border-radius:2px; }
.rt-split-v { position:absolute; bottom:-5px; left:8%; width:84%; height:10px; z-index:20; cursor:pointer; border-radius:2px; }
.rt-split-h:hover, .rt-split-v:hover { background:rgba(212,168,67,0.4); box-shadow:0 0 8px rgba(212,168,67,0.5); }

/* Corner zones */
.rt-corner { position:absolute; right:-6px; bottom:-6px; width:12px; height:12px; z-index:25; cursor:pointer; border-radius:50%; }
.rt-corner:hover { background:rgba(212,168,67,0.5); box-shadow:0 0 10px rgba(212,168,67,0.6); }

/* Street zones */
.rt-street-row { display:grid; grid-template-columns:repeat(12, 1fr); height:clamp(10px, 0.8vw, 14px); }
.rt-street-zone { cursor:pointer; border-radius:2px; transition:background 0.14s; }
.rt-street-zone:hover { background:rgba(212,168,67,0.4); box-shadow:0 0 8px rgba(212,168,67,0.5); }
.rt-street { position:absolute; left:-6px; top:8%; width:12px; height:84%; z-index:20; cursor:pointer; border-radius:2px; }
.rt-street:hover { background:rgba(212,168,67,0.4); box-shadow:0 0 8px rgba(212,168,67,0.5); }

/* Sixline zones */
.rt-sixline-row { position:relative; height:clamp(10px, 0.8vw, 14px); }
.rt-sixline-zone { position:absolute; top:-3px; width:12px; height:12px; z-index:25; cursor:pointer; border-radius:50%; }
.rt-sixline-zone:hover { background:rgba(212,168,67,0.5); box-shadow:0 0 10px rgba(212,168,67,0.6); }

/* Column bets */
.rt-col-bets { grid-row:1/2; grid-column:3/4; display:flex; flex-direction:column; gap:0; }
.rt-col-btn { flex:1; display:flex; align-items:center; justify-content:center; min-width:clamp(30px, 2.5vw, 48px); font-size:clamp(10px, 0.8vw, 15px); font-weight:700; letter-spacing:1px; color:rgba(255,255,255,0.7); background:linear-gradient(135deg, rgba(0,0,0,0.5), rgba(0,0,0,0.3)); border:1px solid rgba(255,255,255,0.18); border-radius:4px; cursor:pointer; transition:filter 0.14s; position:relative; overflow:visible; }
.rt-col-btn:hover { filter:brightness(1.3); box-shadow:0 0 0 1px rgba(255,255,255,0.4) inset; }

/* Dozen bets */
.rt-dozen-row { grid-row:2/3; grid-column:1/4; display:grid; grid-template-columns:1fr 1fr 1fr; gap:clamp(2px, 0.2vw, 4px); }
.rt-dozen { display:flex; align-items:center; justify-content:center; min-height:clamp(28px, 2.2vw, 40px); font-size:clamp(10px, 0.8vw, 15px); font-weight:700; letter-spacing:2px; color:rgba(255,255,255,0.7); background:linear-gradient(135deg, rgba(0,0,0,0.5), rgba(0,0,0,0.3)); border:1px solid rgba(255,255,255,0.18); border-radius:4px; cursor:pointer; transition:filter 0.14s; position:relative; overflow:visible; }
.rt-dozen:hover { filter:brightness(1.3); box-shadow:0 0 0 1px rgba(255,255,255,0.4) inset; }

/* Even-money bets */
.rt-even-row { grid-row:3/4; grid-column:1/4; display:grid; grid-template-columns:repeat(6, 1fr); gap:clamp(2px, 0.2vw, 4px); }
.rt-even-btn { display:flex; align-items:center; justify-content:center; gap:4px; min-height:clamp(28px, 2.2vw, 40px); font-size:clamp(9px, 0.73vw, 14px); font-weight:700; letter-spacing:1.5px; color:rgba(255,255,255,0.7); background:linear-gradient(135deg, rgba(0,0,0,0.5), rgba(0,0,0,0.3)); border:1px solid rgba(255,255,255,0.18); border-radius:4px; cursor:pointer; transition:filter 0.14s; position:relative; overflow:visible; }
.rt-even-btn:hover { filter:brightness(1.3); box-shadow:0 0 0 1px rgba(255,255,255,0.4) inset; }
.rt-red-zone { background:linear-gradient(135deg, rgba(196,30,58,0.6), rgba(160,24,48,0.4)); color:#ff9999; }
.rt-black-zone { background:linear-gradient(135deg, rgba(30,30,40,0.8), rgba(20,20,30,0.6)); color:#cccccc; }
.rt-diamond { font-size:0.8em; }

/* ═══ BET ZONE HIGHLIGHTS ═══ */
.bet-zone { position:relative; overflow:visible; }
.bet-zone.win-highlight { filter:brightness(2) !important; box-shadow:0 0 20px rgba(212,168,67,1) inset, 0 0 30px rgba(212,168,67,0.6) !important; z-index:8; animation:zoneWinPulse 0.12s ease-in-out 3; }
@keyframes zoneWinPulse { 0%,100%{filter:brightness(2)} 50%{filter:brightness(2.8)} }
.bet-zone.lose-highlight { filter:brightness(0.38) saturate(0.3) !important; }

/* ═══ BET CHIPS ═══ */
.bet-chip { position:absolute !important; z-index:30; top:50% !important; left:50% !important; transform:translate(-50%, -50%); width:var(--bet-chip-size) !important; height:var(--bet-chip-size) !important; min-width:var(--bet-chip-size) !important; min-height:var(--bet-chip-size) !important; max-width:var(--bet-chip-size) !important; max-height:var(--bet-chip-size) !important; border-radius:50% !important; display:flex !important; align-items:center !important; justify-content:center !important; pointer-events:all; cursor:default; border:none; overflow:visible !important; box-sizing:border-box !important; flex-shrink:0 !important; margin:0 !important; padding:0 !important; }
.bet-chip .chip-edge-ring { position:absolute; inset:0; border-radius:50%; background:repeating-conic-gradient(from 4deg, var(--chip-edge, #fff) 0deg 12deg, var(--chip-edge2, #c41e3a) 12deg 24deg); box-shadow:0 2px 8px rgba(0,0,0,0.9), inset 0 1px 1px rgba(255,255,255,0.12); }
.bet-chip .chip-face { position:absolute; inset:3px; border-radius:50%; background:radial-gradient(circle at 38% 32%, color-mix(in srgb, var(--chip-color, #c41e3a), white 14%) 0%, var(--chip-color, #c41e3a) 45%, var(--chip-border, #8b1528) 100%); z-index:1; }
.bet-chip .chip-face::before { content:''; position:absolute; inset:16%; border-radius:50%; border:1px solid rgba(255,255,255,0.16); box-shadow:inset 0 0 3px rgba(0,0,0,0.3); z-index:2; }
.bet-chip .chip-face::after { content:''; position:absolute; inset:0; border-radius:50%; background:radial-gradient(ellipse 55% 45% at 35% 28%, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.04) 40%, transparent 70%); z-index:3; pointer-events:none; }
.bet-chip span { font-family:var(--font-n); font-size:clamp(7px, 0.5vw, 10px) !important; font-weight:700; line-height:1 !important; pointer-events:none; display:flex !important; align-items:center !important; justify-content:center !important; width:100% !important; height:100% !important; text-align:center; z-index:4; position:relative; text-shadow:0 1px 1px rgba(0,0,0,0.6), 0 -1px 0 rgba(255,255,255,0.1); }

/* ═══ BOTTOM BAR ═══ */
#bottom-bar { position:relative; z-index:20; height:var(--bar-height); flex-shrink:0; background:linear-gradient(180deg, rgba(15,12,8,0.98), rgba(8,6,4,0.98)); border-top:1px solid rgba(212,168,67,0.12); box-shadow:0 -4px 30px rgba(0,0,0,0.4); display:flex; align-items:center; width:100%; overflow:hidden; }
#bottom-inner { display:flex; align-items:center; justify-content:center; gap:clamp(3px, 0.26vw, 5px); padding:0 clamp(8px, 0.83vw, 16px); width:100%; overflow-x:auto; overflow-y:hidden; scrollbar-width:none; }
#bottom-inner::-webkit-scrollbar { display:none; }
#chip-rack { display:flex; flex-direction:row; align-items:flex-end; gap:clamp(3px, 0.31vw, 6px); flex-shrink:0; padding-top:12px; }
.chip-btn { position:relative; border:none; background:none; cursor:pointer; padding:0; transition:transform 0.2s; flex-shrink:0; width:var(--chip-rack-size); height:var(--chip-rack-size); }
.chip-btn:not(.disabled):hover { transform:scale(1.15); }
.chip-btn.selected { transform:scale(1.1); }
.chip-btn.disabled { opacity:0.35; cursor:not-allowed; }
.chip-inner { width:100%; height:100%; border-radius:50%; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.chip-edge-ring { position:absolute; inset:0; border-radius:50%; background:repeating-conic-gradient(from 4deg, var(--chip-edge, #fff) 0deg 12deg, var(--chip-edge2, #c41e3a) 12deg 24deg); box-shadow:0 2px 6px rgba(0,0,0,0.6), 0 4px 12px rgba(0,0,0,0.35), inset 0 1px 1px rgba(255,255,255,0.15); }
.chip-face { position:absolute; inset:4px; border-radius:50%; background:radial-gradient(circle at 38% 32%, color-mix(in srgb, var(--chip-color, #c41e3a), white 14%) 0%, var(--chip-color, #c41e3a) 45%, var(--chip-border, #8b1528) 100%); z-index:1; }
.chip-face::before { content:''; position:absolute; inset:18%; border-radius:50%; border:1.5px solid rgba(255,255,255,0.18); box-shadow:inset 0 0 4px rgba(0,0,0,0.3), 0 0 2px rgba(255,255,255,0.06); z-index:2; }
.chip-face::after { content:''; position:absolute; inset:0; border-radius:50%; background:radial-gradient(ellipse 55% 45% at 35% 28%, rgba(255,255,255,0.2) 0%, rgba(255,255,255,0.05) 40%, transparent 70%); z-index:3; pointer-events:none; }
.chip-label { font-family:var(--font-n); font-weight:700; position:relative; z-index:4; text-shadow:0 1px 0 rgba(255,255,255,0.12), 0 -1px 0 rgba(0,0,0,0.7), 1px 1px 2px rgba(0,0,0,0.55); letter-spacing:0.02em; font-size:clamp(8px, 0.63vw, 12px); pointer-events:none; }
.chip-label.chip-label-sm { font-size:clamp(7px, 0.52vw, 10px); }
.chip-ring { position:absolute; inset:-4px; border-radius:50%; border:2px solid rgba(212,168,67,0.7); animation:pulse 1.5s ease-in-out infinite; display:none; }
.chip-btn.selected .chip-ring { display:block; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.5} }
.bar-sep { width:1px; height:clamp(22px, 1.67vw, 32px); background:rgba(212,168,67,0.15); flex-shrink:0; }
#game-controls { display:flex; align-items:center; gap:clamp(3px, 0.31vw, 6px); flex-shrink:0; }
.btn-spin { padding:4px clamp(8px, 0.73vw, 14px); border-radius:10px; width:var(--spin-btn-w); font-family:var(--font-d); font-size:clamp(10px, 0.68vw, 13px); font-weight:700; text-transform:uppercase; letter-spacing:0.05em; cursor:pointer; transition:all 0.3s; border:2px solid rgba(212,168,67,0.15); background:rgba(212,168,67,0.08); color:#444; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; min-height:clamp(34px, 2.19vw, 42px); }
.btn-spin:not(:disabled) { background:linear-gradient(135deg, var(--gold), #e8c060, var(--gold)); color:#1a1a1a; border-color:var(--gold); box-shadow:0 4px 25px rgba(212,168,67,0.5), inset 0 1px 0 rgba(255,255,255,0.3); animation:pulseGlow 2s ease-in-out infinite; }
@keyframes pulseGlow { 0%,100%{box-shadow:0 4px 25px rgba(212,168,67,0.5),inset 0 1px 0 rgba(255,255,255,0.3),0 0 0 0 rgba(255,215,0,0.45)} 50%{box-shadow:0 4px 40px rgba(212,168,67,0.8),inset 0 1px 0 rgba(255,255,255,0.3),0 0 0 8px rgba(255,215,0,0)} }
.btn-spin:not(:disabled):hover { transform:scale(1.05); }
.btn-roll-main { font-family:var(--font-d); font-size:clamp(11px, 0.78vw, 15px); font-weight:700; letter-spacing:0.05em; line-height:1.1; }
.icon-btn { width:var(--icon-btn-size); height:var(--icon-btn-size); border-radius:8px; border:1.5px solid; background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; position:relative; }
.icon-btn:not(:disabled):hover { transform:scale(1.1); }
.icon-btn:not(:disabled):active { transform:scale(0.9); }
.icon-btn:disabled { opacity:0.22; cursor:not-allowed; }
.icon-btn.gold { color:var(--gold); border-color:rgba(212,168,67,0.3); background:rgba(212,168,67,0.07); }
.icon-btn.gold:not(:disabled):hover { background:rgba(212,168,67,0.15); }
.icon-btn.grey { color:#aaa; border-color:rgba(180,180,180,0.3); background:rgba(180,180,180,0.07); font-family:var(--font-n); font-size:clamp(7px, 0.47vw, 9px); font-weight:700; letter-spacing:0.5px; }
.icon-btn.grey:not(:disabled):hover { background:rgba(180,180,180,0.15); color:#fff; }
.qb-unified { width:var(--qb-btn-w) !important; padding:0 !important; justify-content:center; flex-shrink:0; }
#btn-repeat, #btn-double { width:var(--qb-btn-w) !important; height:var(--icon-btn-size); padding:0 !important; border-radius:8px; border:1.5px solid rgba(212,168,67,0.3); background:rgba(212,168,67,0.07); color:var(--gold); font-family:var(--font-n); font-size:clamp(6px, 0.42vw, 8px); font-weight:700; letter-spacing:0.5px; line-height:1.15; text-align:center; cursor:pointer; display:flex; flex-direction:column; align-items:center; justify-content:center; flex-shrink:0; transition:all 0.2s; }
#btn-repeat:not(:disabled):hover, #btn-double:not(:disabled):hover { background:rgba(212,168,67,0.2); transform:scale(1.1); }
#btn-repeat:disabled, #btn-double:disabled { opacity:0.22; cursor:not-allowed; }

/* ═══ RESULT OVERLAY ═══ */
#result-overlay { position:fixed; inset:0; z-index:5000; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.result-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.6); backdrop-filter:blur(4px); }
.result-display { display:flex; flex-direction:column; align-items:center; gap:clamp(8px, 0.8vw, 16px); transform:scale(0.3); opacity:0; transition:transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease; position:relative; z-index:1; }
.result-display.active { transform:scale(1); opacity:1; }
.result-number { width:clamp(80px, 8vw, 140px); height:clamp(80px, 8vw, 140px); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-d); font-size:clamp(36px, 4vw, 64px); font-weight:900; color:#fff; box-shadow:0 8px 40px rgba(0,0,0,0.6), inset 0 2px 0 rgba(255,255,255,0.2); text-shadow:0 2px 4px rgba(0,0,0,0.5); }
.rn-red { background:linear-gradient(135deg, #e02040, #b01830); border:3px solid rgba(255,255,255,0.3); }
.rn-black { background:linear-gradient(135deg, #333, #111); border:3px solid rgba(255,255,255,0.2); }
.rn-green { background:linear-gradient(135deg, #2a9a4a, #1a7a3a); border:3px solid rgba(255,255,255,0.3); }
.result-win-amount { font-family:var(--font-d); font-size:clamp(24px, 3vw, 48px); font-weight:900; background:linear-gradient(180deg, #fff5a0, #ffe040, #f0c030); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; filter:drop-shadow(0 3px 6px rgba(0,0,0,0.8)); }
.result-loss-amount { font-family:var(--font-n); font-size:clamp(16px, 2vw, 28px); font-weight:700; color:rgba(255,100,100,0.7); }

/* ═══ TOOLTIP ═══ */
#rt-body-tip { position:fixed; background:linear-gradient(135deg, rgba(8,5,1,0.98), rgba(18,12,2,0.98)); color:var(--gold); font-family:var(--font-n); font-size:clamp(12px, 0.83vw, 16px); font-weight:500; letter-spacing:0.07em; white-space:nowrap; padding:7px clamp(10px, 0.78vw, 16px); border-radius:7px; border:1px solid rgba(212,168,67,0.4); box-shadow:0 4px 24px rgba(0,0,0,0.8); pointer-events:none; opacity:0; transition:opacity 0.15s ease; z-index:2147483647; }
#rt-body-tip.visible { opacity:1; }

/* ═══ TOAST ═══ */
#game-toast { position:fixed; bottom:clamp(60px, 5vw, 90px); left:50%; transform:translateX(-50%); background:#1e1e2a; color:#e8c46a; font-family:var(--font-n); font-size:clamp(10px, 0.68vw, 13px); letter-spacing:1px; padding:clamp(5px, 0.42vw, 8px) clamp(12px, 1.04vw, 20px); border-radius:8px; border:1px solid rgba(212,168,67,0.3); box-shadow:0 8px 30px rgba(0,0,0,0.5); z-index:9999; opacity:0; transition:opacity 0.3s; pointer-events:none; max-width:90vw; text-align:center; }

/* ═══ WIN FLASH ═══ */
#win-flash { position:fixed; inset:0; background:rgba(255,200,50,0); pointer-events:none; z-index:9998; transition:background 0.07s; }

/* ═══ DISCLAIMER OVERLAY ═══ */
#disclaimer-overlay { position:fixed; inset:0; z-index:100000; display:flex; align-items:center; justify-content:center; }
.disc-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.8); backdrop-filter:blur(10px); }
.disc-panel { position:relative; z-index:1; background:linear-gradient(160deg, #16141e, #0e0c14); border:1px solid rgba(212,168,67,0.25); border-radius:20px; padding:clamp(20px, 2vw, 36px) clamp(24px, 2.5vw, 44px); width:min(560px, 92vw); max-height:90vh; overflow-y:auto; box-shadow:0 30px 80px rgba(0,0,0,0.7); }
.disc-header { text-align:center; margin-bottom:clamp(14px, 1.5vw, 24px); }
.disc-logo { width:clamp(60px, 5vw, 100px); height:auto; filter:drop-shadow(0 0 16px rgba(212,168,67,0.2)); margin-bottom:clamp(8px, 0.8vw, 14px); }
.disc-badge { display:inline-block; font-family:var(--font-n); font-size:clamp(14px, 1.1vw, 20px); font-weight:700; letter-spacing:2px; color:#1a1a1a; background:linear-gradient(135deg, #d4a843, #b89030); padding:clamp(4px, 0.4vw, 8px) clamp(12px, 1.1vw, 20px); border-radius:8px; margin-bottom:clamp(8px, 0.8vw, 14px); }
.disc-title { font-family:var(--font-n); font-size:clamp(14px, 1.1vw, 20px); font-weight:700; letter-spacing:4px; color:#e8c46a; }
.disc-body p { font-family:var(--font-b); font-size:clamp(11px, 0.73vw, 14px); line-height:1.7; color:rgba(255,255,255,0.65); margin:0 0 clamp(10px, 0.9vw, 16px) 0; }
.disc-body strong { color:rgba(255,255,255,0.9); font-weight:600; }
.disc-body ul { list-style:none; padding:0; margin:clamp(10px, 0.9vw, 16px) 0; display:flex; flex-direction:column; gap:clamp(8px, 0.7vw, 14px); }
.disc-body li { font-family:var(--font-b); font-size:clamp(10px, 0.68vw, 13px); line-height:1.65; color:rgba(255,255,255,0.55); padding-left:clamp(14px, 1.1vw, 20px); position:relative; }
.disc-body li::before { content:'◦'; position:absolute; left:0; color:rgba(212,168,67,0.5); font-size:0.7em; top:0.25em; }
.disc-body li strong { color:rgba(255,255,255,0.8); }
.disc-closing { font-style:italic; color:rgba(255,255,255,0.45) !important; font-size:clamp(10px, 0.63vw, 12px) !important; border-top:1px solid rgba(212,168,67,0.1); padding-top:clamp(10px, 0.9vw, 16px); }
.disc-accept-btn { width:100%; padding:clamp(12px, 1vw, 18px) 0; border-radius:12px; border:1px solid rgba(212,168,67,0.5); background:linear-gradient(135deg, #d4a843, #b89030); color:#0a0a0f; font-family:var(--font-n); font-size:clamp(12px, 0.83vw, 16px); font-weight:700; letter-spacing:3px; cursor:pointer; transition:all 0.25s; box-shadow:0 4px 20px rgba(212,168,67,0.25); }
.disc-accept-btn:hover { transform:scale(1.02); box-shadow:0 6px 30px rgba(212,168,67,0.45); }

/* ═══ RESUME TOAST ═══ */
#resume-toast-overlay { position:fixed; inset:0; z-index:9500; display:flex; align-items:center; justify-content:center; pointer-events:all; }
.rt-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.72); backdrop-filter:blur(8px); cursor:pointer; }
.rt-panel { position:relative; z-index:1; background:linear-gradient(160deg, #1a1a2e, #12121e, #0e0e1a); border:1px solid rgba(212,168,67,0.28); border-radius:24px; padding:clamp(28px, 2.6vw, 48px); width:min(520px, 94vw); text-align:center; box-shadow:0 32px 90px rgba(0,0,0,0.75); opacity:0; transform:translateY(18px) scale(0.97); transition:opacity 0.32s ease, transform 0.32s cubic-bezier(0.34, 1.38, 0.64, 1); }
#resume-toast-overlay.rt-visible .rt-panel { opacity:1; transform:translateY(0) scale(1); }
#resume-toast-overlay.rt-hiding .rt-panel { opacity:0; transform:translateY(-10px) scale(0.97); transition:opacity 0.28s ease, transform 0.28s ease; }
.rt-title { font-family:var(--font-n); font-size:clamp(20px, 1.88vw, 30px); font-weight:700; letter-spacing:4px; color:#e8c46a; margin-bottom:8px; text-transform:uppercase; }
.rt-subtitle { font-family:var(--font-b); font-size:clamp(13px, 1.04vw, 16px); color:#9090b0; margin-bottom:clamp(18px, 1.67vw, 28px); }
.rt-balance-row { display:inline-flex; align-items:center; gap:10px; background:rgba(212,168,67,0.07); border:1px solid rgba(212,168,67,0.18); border-radius:40px; padding:clamp(8px, 0.73vw, 12px) clamp(16px, 1.46vw, 24px); margin-bottom:clamp(18px, 1.67vw, 28px); }
.rt-balance-label { font-family:var(--font-n); font-size:clamp(11px, 0.83vw, 13px); letter-spacing:2.5px; color:#a0a0c0; text-transform:uppercase; }
.rt-balance-val { font-family:var(--font-n); font-size:clamp(22px, 2.08vw, 36px); font-weight:700; color:#f0d080; }
.rt-btn-group { display:flex; flex-direction:column; gap:10px; }
.rt-btn { width:100%; padding:clamp(13px, 1.15vw, 20px); border-radius:14px; font-family:var(--font-n); font-size:clamp(13px, 1.04vw, 17px); font-weight:700; letter-spacing:3px; text-transform:uppercase; cursor:pointer; transition:transform 0.15s, box-shadow 0.15s; }
.rt-btn-resume { background:linear-gradient(135deg, #d4a843, #b89030); border:1px solid rgba(212,168,67,0.5); color:#0a0a0f; box-shadow:0 6px 20px rgba(212,168,67,0.28); }
.rt-btn-resume:hover { transform:scale(1.025); box-shadow:0 8px 28px rgba(212,168,67,0.42); }
.rt-btn-new { background:transparent; border:1px solid rgba(255,255,255,0.12); color:#8080a0; }
.rt-btn-new:hover { border-color:rgba(255,255,255,0.24); color:#b0b0cc; }

/* ═══ STATS POPUP ═══ */
#stats-popup-overlay { position:fixed; inset:0; z-index:9000; display:flex; align-items:center; justify-content:center; }
#stats-popup-backdrop { position:absolute; inset:0; background:rgba(0,0,0,0.6); backdrop-filter:blur(6px); }
#stats-popup-panel { position:relative; z-index:1; background:linear-gradient(180deg, #18182a, #12121e); border:1px solid #2a2a3a; border-radius:22px; padding:0; width:min(720px, 94vw); max-height:90vh; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 24px 80px rgba(0,0,0,0.7); }
.sp-scroll-body { flex:1 1 auto; overflow-y:auto; min-height:0; }
.sp-header { display:flex; align-items:center; justify-content:space-between; padding:clamp(16px, 1.46vw, 28px) clamp(18px, 1.77vw, 34px) 0; margin-bottom:clamp(14px, 1.25vw, 24px); flex-shrink:0; }
.sp-header-title { font-family:var(--font-n); font-size:clamp(14px, 1.04vw, 20px); letter-spacing:3px; color:#d4a843; text-transform:uppercase; }
.sp-close { width:clamp(28px, 1.98vw, 38px); height:clamp(28px, 1.98vw, 38px); border-radius:10px; border:1px solid rgba(212,168,67,0.2); background:rgba(212,168,67,0.06); color:#d4a843; font-size:clamp(12px, 0.89vw, 17px); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.15s; }
.sp-close:hover { background:rgba(212,168,67,0.15); }
.sp-stat-cards { display:grid; grid-template-columns:repeat(4, 1fr); gap:clamp(8px, 0.73vw, 14px); padding:0 clamp(18px, 1.77vw, 34px); margin-bottom:clamp(14px, 1.25vw, 24px); }
.sp-card { background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06); border-radius:16px; padding:clamp(14px, 1.25vw, 24px) clamp(8px, 0.73vw, 14px) clamp(10px, 0.94vw, 18px); text-align:center; }
.sp-card-green { border-color:rgba(74,222,128,0.18); background:rgba(74,222,128,0.04); }
.sp-card-val { font-family:var(--font-n); font-size:clamp(20px, 2vw, 36px); font-weight:700; color:#e8e8f0; line-height:1; }
.sp-card-green .sp-card-val { color:#4ade80; }
.sp-card-label { font-size:clamp(10px, 0.73vw, 14px); letter-spacing:0.5px; color:#9a9ab8; margin-top:clamp(6px, 0.52vw, 10px); text-transform:uppercase; font-weight:600; }
.sp-section-title { font-family:var(--font-n); font-size:clamp(11px, 0.78vw, 15px); letter-spacing:2px; color:#9a9ab8; margin:4px clamp(18px, 1.77vw, 34px) clamp(8px, 0.73vw, 14px); text-transform:uppercase; }
#sp-distro-chart { display:flex; gap:clamp(2px, 0.2vw, 4px); align-items:flex-end; height:clamp(70px, 6.25vw, 120px); margin:0 clamp(18px, 1.77vw, 34px) clamp(8px, 0.73vw, 14px); }
.db-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; height:100%; min-width:0; }
.db-bar { flex:1; width:100%; position:relative; border-radius:2px 2px 0 0; overflow:hidden; background:rgba(255,255,255,0.03); display:flex; align-items:flex-end; }
.db-bar-fill { width:100%; border-radius:2px 2px 0 0; min-height:1px; transition:height 0.3s; }
.db-grey { background:rgba(255,255,255,0.12); }
.db-green { background:#4ade80; }
.db-red { background:#f87171; }
.db-label { font-family:var(--font-n); font-size:clamp(6px, 0.42vw, 9px); color:#9a9ab8; }
.sp-footer { padding:clamp(10px, 0.94vw, 18px) clamp(18px, 1.77vw, 34px) clamp(16px, 1.46vw, 28px); flex-shrink:0; }
.sp-done-btn { width:100%; padding:clamp(10px, 0.94vw, 18px) 0; border-radius:14px; border:1px solid rgba(212,168,67,0.4); background:linear-gradient(135deg, #d4a843, #b89030); color:#0a0a0f; font-family:var(--font-n); font-size:clamp(12px, 0.89vw, 17px); font-weight:700; letter-spacing:3px; text-transform:uppercase; cursor:pointer; transition:all 0.2s; box-shadow:0 4px 16px rgba(212,168,67,0.25); }
.sp-done-btn:hover { transform:scale(1.02); box-shadow:0 6px 24px rgba(212,168,67,0.4); }
.popup-hist-row { display:flex; align-items:center; gap:4px; }
.popup-hist-latest .hist-result { box-shadow:0 0 8px rgba(212,168,67,0.5); }

/* ═══ LANDSCAPE PROMPT ═══ */
#rotate-prompt { display:none; position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,0.95); flex-direction:column; align-items:center; justify-content:center; gap:clamp(16px, 3vw, 28px); color:var(--gold); }
.rotate-icon { font-size:clamp(56px, 12vw, 80px); animation:rotate-phone 2s ease-out infinite; }
@keyframes rotate-phone { 0%{transform:rotate(0)} 40%{transform:rotate(90deg)} 100%{transform:rotate(90deg)} }
.rotate-msg { font-family:var(--font-b); font-size:clamp(13px, 3.5vw, 18px); text-align:center; padding:0 32px; }
@media (orientation: portrait) { #rotate-prompt { display:flex !important; } }

/* ═══ SCROLLBARS ═══ */
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(212,168,67,0.2); border-radius:2px; }

/* ═══ MOBILE LANDSCAPE ═══ */
@media (max-height: 520px) and (orientation: landscape) {
  #info-bar { height:clamp(26px, 1.8vw, 36px); }
  .info-val { font-size:clamp(10px, 0.68vw, 14px); }
  .rt-cell { min-width:clamp(28px, 2.5vw, 44px); min-height:clamp(28px, 2.5vw, 44px); }
  .rt-num { font-size:clamp(11px, 1vw, 18px); }
  .rt-zero { font-size:clamp(14px, 1.2vw, 22px); min-width:clamp(28px, 2.5vw, 44px); }
  .rt-wrap { min-width:clamp(440px, 50vw, 800px); }
  .rt-col-btn, .rt-dozen, .rt-even-btn { min-height:clamp(22px, 1.8vw, 32px); font-size:clamp(8px, 0.68vw, 12px); }
  #bottom-bar { height:clamp(36px, 2.5vw, 48px); }
  :root { --chip-rack-size:clamp(28px, 2.2vw, 40px); --bet-chip-size:clamp(18px, 1.4vw, 26px); --icon-btn-size:clamp(22px, 1.5vw, 30px); --spin-btn-w:clamp(90px, 7vw, 130px); --qb-btn-w:clamp(36px, 2.8vw, 52px); }
}

/* ═══ 2K DISPLAYS ═══ */
@media (min-width: 2000px) {
  :root { --chip-rack-size:clamp(54px, 2.81vw, 80px); --bet-chip-size:clamp(32px, 1.7vw, 48px); --icon-btn-size:clamp(34px, 1.77vw, 50px); --bar-height:clamp(56px, 2.92vw, 80px); --spin-btn-w:clamp(170px, 8.85vw, 260px); }
  .rt-cell { min-width:clamp(56px, 3.5vw, 80px); min-height:clamp(56px, 3.5vw, 80px); }
  .rt-num { font-size:clamp(22px, 1.5vw, 32px); }
  .rt-zero { min-width:clamp(56px, 3.5vw, 80px); font-size:clamp(28px, 1.8vw, 40px); }
  .rt-wrap { min-width:clamp(1000px, 60vw, 1500px); }
  .rt-col-btn, .rt-dozen, .rt-even-btn { min-height:clamp(40px, 2.5vw, 56px); font-size:clamp(15px, 0.95vw, 22px); }
}
