/* ============================================================
   roulette.css — Lanna Roulette  ·  Casino Felt Edition
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Space+Grotesk:wght@400;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#060f07; --bgd:#030805;
  --felt:#0a2010; --feltl:#0d2a16;
  --gold:#f4d03f; --goldd:#d4a017; --goldf:#fde68a;
  --cream:#f5fff6; --red:#ef4444; --redd:#dc2626;
  --green:#22c55e;
  --chip-red:#dc2626; --chip-blk:#1f2937; --chip-grn:#16a34a;
  --hud-h:48px; --nav-h:54px;
  --font-px:'Press Start 2P',monospace; --font-body:'Space Grotesk',sans-serif;
}
html,body{height:100%;background:var(--bg);color:var(--cream);font-family:var(--font-body);overflow:hidden;user-select:none;-webkit-tap-highlight-color:transparent;}
.px{font-family:var(--font-px)!important}

/* ── HUD ── */
.rh{position:fixed;top:0;left:0;right:0;height:var(--hud-h);background:rgba(3,8,5,.97);border-bottom:2px solid rgba(212,160,23,.45);display:flex;align-items:center;justify-content:space-between;padding:0 14px;z-index:100;gap:8px;box-shadow:0 2px 20px rgba(244,208,63,.1);}
.rh-back{color:var(--goldf);font-size:1rem;text-decoration:none;padding:6px;}
.rh-title{font-size:7px;color:var(--goldf);letter-spacing:2px;text-shadow:0 0 12px rgba(253,230,138,.4);}
.rh-coins{font-size:8px;color:var(--gold);display:flex;align-items:center;gap:4px;}

/* ── Hero buff badge ── */
.rh-hero-buff{display:flex;align-items:center;gap:3px;padding:2px 7px;border-radius:6px;background:rgba(212,160,23,.15);border:1px solid rgba(244,208,63,.35);flex-shrink:0;}
#rh-hero-emoji{font-size:.9rem;line-height:1;}
.rh-hero-buff-lbl{font-size:7px;color:var(--goldf);font-family:var(--font-px);white-space:nowrap;}

/* ── Layout ── */
.roulette-wrap{position:fixed;top:var(--hud-h);bottom:var(--nav-h);left:0;right:0;display:flex;flex-direction:column;align-items:center;overflow-y:auto;padding:12px 10px;background:radial-gradient(ellipse at 50% 20%, rgba(10,32,16,.8) 0%, var(--bg) 70%);}

/* ── Wheel ── */
.wheel-area{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0;position:relative;}
.wheel-area::before{
  content:'';position:absolute;inset:-36px;
  background:radial-gradient(circle at 50% 40%, rgba(212,160,23,.18) 0%, transparent 65%);
  pointer-events:none;
}
#roulette-canvas{
  border-radius:50%;
  box-shadow:0 0 50px rgba(244,208,63,.18), 0 0 100px rgba(244,208,63,.06),
             0 4px 30px rgba(0,0,0,.6);
  border:3px solid rgba(212,160,23,.4);
}
.wheel-result{font-size:8px;font-family:var(--font-px);color:var(--gold);min-height:22px;text-align:center;text-shadow:0 0 14px rgba(244,208,63,.5);}

/* ── Bet table ── */
.bet-table{width:100%;max-width:380px;margin-top:8px;flex-shrink:0;}
.bt-section{
  margin-bottom:8px;
  background:rgba(10,32,16,.5);
  border-radius:10px;
  padding:8px;
}
.bt-label{font-size:6px;font-family:var(--font-px);color:var(--goldf);letter-spacing:1px;margin-bottom:6px;opacity:.9;}
.bt-row{display:flex;gap:5px;flex-wrap:wrap;}

/* Chip buttons */
.bt-chip{
  padding:8px 10px;border-radius:8px;
  border:2px solid rgba(255,255,255,.12);
  background:rgba(10,32,16,.8);
  color:rgba(245,255,246,.7);font-size:.65rem;
  cursor:pointer;transition:all .15s;flex:1;text-align:center;min-width:52px;
  position:relative;overflow:hidden;
}
.bt-chip::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .15s;background:linear-gradient(180deg,rgba(255,255,255,.08),transparent);}
.bt-chip:hover::before{opacity:1;}
.bt-chip:hover{border-color:rgba(212,160,23,.4);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.3);}
.bt-chip.active{background:rgba(212,160,23,.2);border-color:var(--gold);color:var(--goldf);box-shadow:0 0 16px rgba(244,208,63,.2);}
.bt-chip.red{border-color:rgba(220,38,38,.4);}
.bt-chip.red:hover{border-color:rgba(239,68,68,.6);}
.bt-chip.red.active{background:rgba(220,38,38,.2);border-color:var(--red);color:#fca5a5;box-shadow:0 0 16px rgba(220,38,38,.2);}
.bt-chip.blk{border-color:rgba(255,255,255,.18);}
.bt-chip.blk.active{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.5);color:var(--cream);}

/* Number grid */
.num-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:8px;}
@media(min-width:400px){.num-grid{grid-template-columns:repeat(9,1fr);}}
.num-cell{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border-radius:5px;font-size:.52rem;font-weight:700;
  cursor:pointer;border:1px solid transparent;transition:all .12s;
}
.num-cell.red-n{background:rgba(220,38,38,.35);color:#fca5a5;}
.num-cell.blk-n{background:rgba(255,255,255,.1);color:rgba(245,255,246,.8);}
.num-cell.grn-n{background:rgba(22,163,74,.35);color:#86efac;}
.num-cell.active,.num-cell:hover{outline:2px solid var(--gold);transform:scale(1.12);z-index:1;}

/* Bet amount */
.amt-row{display:flex;flex-direction:column;gap:6px;margin-bottom:10px;}
.amt-lbl{font-size:7px;font-family:var(--font-px);color:var(--goldf);}
.bet-btns-scroll{display:flex;gap:5px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;}
.bet-btns-scroll::-webkit-scrollbar{display:none;}
.amt-btn{padding:5px 8px;border-radius:6px;border:1px solid rgba(212,160,23,.25);background:rgba(10,32,16,.8);color:rgba(245,255,246,.65);font-size:.65rem;cursor:pointer;transition:all .15s;font-family:var(--font-body);white-space:nowrap;flex-shrink:0;}
.amt-btn.active,.amt-btn:hover{background:rgba(212,160,23,.18);border-color:rgba(244,208,63,.6);color:var(--goldf);}
.bet-custom-wrap{display:flex;gap:5px;}
.bet-custom-input{flex:1;background:rgba(10,32,16,.8);border:1px solid rgba(212,160,23,.25);border-radius:6px;color:rgba(245,255,246,.9);font-size:.72rem;padding:5px 9px;font-family:var(--font-body);outline:none;}
.bet-custom-input::placeholder{color:rgba(245,255,246,.3);}
.bet-custom-input:focus{border-color:rgba(244,208,63,.6);}
.bet-custom-ok{padding:5px 12px;border-radius:6px;border:1px solid rgba(244,208,63,.4);background:rgba(212,160,23,.12);color:var(--goldf);font-size:.8rem;cursor:pointer;transition:all .15s;}
.bet-custom-ok:hover{background:rgba(212,160,23,.25);}

/* Current bets */
.current-bets{font-size:.62rem;color:rgba(245,255,246,.45);min-height:16px;margin-bottom:8px;}
.current-bets span{color:var(--gold);}

/* Spin button */
.spin-btn{
  width:100%;max-width:380px;padding:14px;border-radius:13px;
  background:linear-gradient(135deg,#d4a017,#f4d03f,#fde68a);
  border:none;color:#030805;font-family:var(--font-px);
  font-size:8px;letter-spacing:2px;cursor:pointer;
  transition:all .2s;margin-bottom:4px;
  box-shadow:0 4px 20px rgba(212,160,23,.4),0 0 40px rgba(244,208,63,.12);
  font-weight:700;
}
.spin-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(212,160,23,.5),0 0 60px rgba(244,208,63,.18);}
.spin-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none;}
.free-info{font-size:.6rem;color:rgba(245,255,246,.35);text-align:center;max-width:380px;}
.free-info .ok{color:var(--green);}

/* ── Bottom nav ── */
.game-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:rgba(3,8,5,.98);border-top:1px solid rgba(212,160,23,.15);display:flex;align-items:center;justify-content:space-around;z-index:50;}
.gbn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:rgba(245,255,246,.32);font-size:1.1rem;text-decoration:none;transition:color .15s;}
.gbn span{font-size:.62rem;font-family:var(--font-body);}
.gbn:hover,.gbn-active{color:var(--goldf);}
button.gbn{background:none;border:none;cursor:pointer;}
.ghp-backdrop{position:fixed;inset:0;z-index:200;background:rgba(3,8,5,.72);backdrop-filter:blur(6px);}
.games-hub-popup{position:fixed;bottom:calc(var(--nav-h)+8px);left:50%;transform:translateX(-50%);width:min(340px,calc(100vw - 24px));background:rgba(6,15,7,.98);border:1px solid rgba(212,160,23,.32);border-radius:18px;padding:16px;z-index:201;box-shadow:0 -4px 40px rgba(212,160,23,.12);}
.ghp-title{font-size:8px;color:var(--goldf);text-align:center;margin-bottom:14px;letter-spacing:2px;font-family:var(--font-px);}
.ghp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.ghp-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:12px 6px;border-radius:10px;background:rgba(212,160,23,.05);border:1px solid rgba(212,160,23,.1);color:rgba(245,255,246,.65);text-decoration:none;font-size:1.4rem;transition:all .15s;}
.ghp-item span{font-size:.52rem;font-family:var(--font-body);color:rgba(245,255,246,.5);}
.ghp-item:hover,.ghp-item.ghp-active{background:rgba(212,160,23,.15);border-color:rgba(244,208,63,.4);color:var(--goldf);}
.ghp-close{display:block;width:100%;margin-top:12px;padding:8px;background:rgba(255,255,255,.05);border:none;border-radius:8px;color:rgba(245,255,246,.4);cursor:pointer;font-size:.75rem;font-family:var(--font-body);}
.game-login-wall{position:fixed;inset:0;background:rgba(3,8,5,.97);display:flex;align-items:center;justify-content:center;z-index:999;}
.glw-card{text-align:center;padding:32px 24px;background:rgba(6,15,7,.9);border:1px solid rgba(212,160,23,.32);border-radius:22px;max-width:280px;}
.glw-icon{font-size:3rem;margin-bottom:12px;}
.glw-title{font-size:10px;color:var(--goldf);line-height:1.8;margin-bottom:10px;font-family:var(--font-px);}
.glw-sub{font-size:.8rem;color:rgba(245,255,246,.5);margin-bottom:20px;}
.glw-btn{display:inline-block;padding:12px 28px;background:linear-gradient(135deg,#d4a017,#f4d03f);color:#030805;border-radius:10px;font-weight:700;text-decoration:none;font-size:.85rem;}
