:root{
  --bg1:#fff7cc;
  --bg2:#ffe1f2;
  --bg3:#dffff3;
  --accent:#ff6f61;
  --accent2:#ffdb4d;
  --accent3:#6a5acd;
  --ok:#00c853;
  --warn:#ff7043;
  --text:#1b1b1b;
  --muted:#6b7280;
  --shadow: 0 10px 30px rgba(0,0,0,.15);
  --radius:18px;
  --radius-sm:12px;
  --symbol-size: 96px; /* CSS mirror of CONFIG.SYMBOL_SIZE */
}
*{box-sizing:border-box}
html,body{
  margin:0;padding:0;height:100%;
  background: radial-gradient(1200px 800px at 20% 10%, var(--bg2) 0%, #ffffff 50%),
              radial-gradient(900px 700px at 80% 20%, var(--bg1) 0%, rgba(255,255,255,0) 60%),
              radial-gradient(700px 500px at 50% 100%, var(--bg3) 0%, rgba(255,255,255,0) 60%);
  color:var(--text);
  font: 16px/1.4 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, "Helvetica Neue", Arial, "Noto Color Emoji", "Apple Color Emoji", sans-serif;
}
.topbar{
  padding:12px 16px 0;
}
.brand{
  display:flex; align-items:center; gap:10px;
}
.brand-logo{font-size:28px}
.brand-title{
  margin:0; font-weight:800; font-size:22px; letter-spacing:.3px; color:#2a2a2a;
  background: linear-gradient(45deg,var(--accent), var(--accent3));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.disclaimer{
  margin:6px 0 0;
  color:#444; background:#fff; border-radius:12px; padding:8px 12px; box-shadow: var(--shadow);
  display:inline-block;
}

.game{
  display:flex; flex-direction:column; gap:16px; padding:16px; max-width:980px; margin:0 auto;
}
.hud{
  display:grid; grid-template-columns: 1fr 1fr; gap:12px; align-items:center;
}
@media (min-width:720px){
  .hud{ grid-template-columns: 1fr 1fr 1fr; }
}
.stat{
  background:#ffffff; border-radius:var(--radius); box-shadow:var(--shadow); padding:12px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.stat-label{ color:var(--muted); font-size:14px;}
.stat-value{ font-weight:800; font-size:22px; color:#212121;}
.bet-controls{ display:flex; align-items:center; gap:10px;}
.controls{ display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap }

.btn{
  border:none; border-radius:14px; padding:10px 14px; font-weight:700; cursor:pointer;
  background:#ffffff; color:#1f1f1f; box-shadow: var(--shadow); transition: transform .06s ease, filter .2s;
}
.btn:hover{ filter:brightness(1.03) }
.btn:active{ transform: translateY(1px) }
.btn[disabled], .btn[aria-disabled="true"]{ opacity:.5; cursor:not-allowed; filter:grayscale(30%) }
.btn.primary{ background: linear-gradient(135deg, var(--accent), var(--accent2)); color:white }
.btn.warn{ background: linear-gradient(135deg, #ff8a65, #ffd180); color:#4a2c2a }
.btn.big{ font-size:18px; padding:14px 18px; border-radius:18px }
.btn.pill{ border-radius:999px; width:44px; height:44px; padding:0; display:inline-grid; place-items:center; font-size:22px }

.machine{
  position:relative;
  background: linear-gradient(180deg, #ffffff, #fffde7);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding:16px;
}
.frame{
  border-radius: var(--radius);
  background: linear-gradient(135deg,#fff,#fff9e6);
  box-shadow: inset 0 0 0 4px #ffe082, inset 0 0 30px rgba(255,214,64,.35);
  padding:14px;
}
.reels{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:10px;
  align-items:center; justify-items:center;
}
.reel{
  width: 100%;
  max-width: 220px;
  height: calc(var(--symbol-size) * 3 + 8px);
  border-radius: 18px;
  background: linear-gradient(180deg, #e3f2fd, #fff);
  box-shadow: inset 0 0 0 4px #bbdefb, inset 0 -12px 20px rgba(0,0,0,.06);
  overflow:hidden;
  position:relative;
}
.reel::before, .reel::after{
  content:""; position:absolute; left:0; right:0; height:22%; pointer-events:none;
}
.reel::before{ top:0; background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,0)); }
.reel::after{ bottom:0; background: linear-gradient(0deg, rgba(255,255,255,.9), rgba(255,255,255,0)); }
.track{
  will-change: transform;
}
.symbol{
  width:100%; height: var(--symbol-size);
  display:grid; place-items:center;
  transform: translateZ(0);
}
.symbol svg{
  width: 64px; height:64px; filter: drop-shadow(0 4px 8px rgba(0,0,0,.15));
}
.payline{
  position:absolute; left:14px; right:14px; top:50%; transform:translateY(-50%);
  height:4px; border-radius:4px;
  background: linear-gradient(90deg, transparent 0 6%, #ff6f61 6% 94%, transparent 94% 100%);
  box-shadow: 0 0 10px rgba(255,111,97,.6), 0 0 2px rgba(255,111,97,1);
  opacity:.7;
}

.win-overlay{
  position:absolute; inset:0; pointer-events:none; opacity:0;
  background:
    radial-gradient(200px 200px at 20% 30%, rgba(255,214,102,.6), transparent 60%),
    radial-gradient(180px 180px at 80% 60%, rgba(255,111,97,.5), transparent 60%),
    radial-gradient(250px 250px at 50% 50%, rgba(106,90,205,.35), transparent 60%);
  transition: opacity .35s ease;
  mix-blend-mode: screen;
}
.win-overlay.show{ opacity:1 }

.announce{
  text-align:center; font-weight:800; font-size:18px; margin-top:10px; min-height:28px;
  color:#2e2e2e;
}

.help{
  background:#ffffff; border-radius: var(--radius); box-shadow: var(--shadow);
  padding:12px 16px;
}
.footer{
  display:flex; flex-direction:column; gap:8px; align-items:center; justify-content:center; padding:12px 0 24px;
  color:#5c5c5c;
}
.links{ display:flex; gap:14px; flex-wrap:wrap }
.links a{
  color:#2b6cb0; text-decoration:none; font-weight:700; background:#fff; padding:6px 10px; border-radius:12px; box-shadow: var(--shadow);
}
.links a:hover{ text-decoration:underline }

.cookie-banner{
  position:fixed; left:0; right:0; bottom:0; z-index:9999;
  transform: translateY(100%); opacity:0; transition:.35s ease; pointer-events:none;
}
.cookie-banner.show{ transform: translateY(0); opacity:1; pointer-events:auto }
.cookie-content{
  margin: 0 auto 12px; max-width:900px;
  background:#ffffff; border-radius:16px; box-shadow: var(--shadow); padding:12px 14px;
  display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap;
}
.cookie-actions{ display:flex; gap:10px }

@keyframes spinBtn {
  0% { transform: translateY(0) rotate(0deg) }
  50% { transform: translateY(-2px) rotate(-2deg) }
  100% { transform: translateY(0) rotate(0deg) }
}
.btn.spinning { animation: spinBtn .5s ease infinite }

.win-glow{
  animation: winPulse 1.2s ease-in-out infinite;
}
@keyframes winPulse{
  0%{ box-shadow: inset 0 0 0 4px #ffd166, 0 0 0 rgba(0,0,0,0) }
  50%{ box-shadow: inset 0 0 0 4px #ffd166, 0 0 40px rgba(255,214,102,.7) }
  100%{ box-shadow: inset 0 0 0 4px #ffd166, 0 0 0 rgba(0,0,0,0) }
}