html{ background:#000; }
:root{
  --bg:#07070b;
  --card:#0f111a;
  --card2:#12162a;
  --text:#e9e9f2;
  --muted:#a7abbd;
  --gold:#f2c14e;
  --gold2:#ffe08a;
  --red:#ff4d6d;
  --green:#52ffa8;
  --shadow: 0 16px 60px rgba(0,0,0,.55);
}
*{box-sizing:border-box}
html,body{ background: transparent; position: relative; z-index: 1; overflow-x:hidden; }
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background: radial-gradient(1200px 800px at 30% 20%, rgba(242,193,78,.14), transparent 60%),
              radial-gradient(900px 600px at 80% 50%, rgba(82,255,168,.10), transparent 55%),
              linear-gradient(180deg, #06060b 0%, #04040a 100%);
  color:var(--text);
}

.app{width:min(1400px, 100%);margin:0 auto;padding:20px 16px 28px}

body.is-fullscreen .app{width:100%;max-width:none;padding:10px 10px 14px}
body.is-fullscreen .stage{min-height: calc(100dvh - 90px)}

.topbar{
  position:relative;
  display:flex;
  gap:16px;
  align-items:flex-end;
  justify-content:space-between;
  margin-bottom:16px;
}
.brand__title{
  font-family:Cinzel,serif;
  font-size:28px;
  letter-spacing:.6px;
  color:var(--gold2);
}
.brand__subtitle{color:var(--muted);font-size:13px;margin-top:2px}

.stats{
  position:absolute;
  top:6px;
  right:0;
  display:flex;
  gap:14px;
  flex-wrap:nowrap;
  justify-content:flex-end;
}
.pill{
  display:flex;gap:8px;align-items:baseline;
  padding:10px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  box-shadow:0 10px 26px rgba(0,0,0,.25);
}
.pill--w120{min-width:120px}
.pill--w90{min-width:90px}
.pill span{color:var(--muted);font-size:12px}
.pill strong{font-size:18px}
.pill--fs strong{color:var(--gold2)}

.stage{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:16px;
  align-items:start;
  min-height: calc(100dvh - 140px);
}

@media (max-width: 980px){
  .topbar{margin-bottom:10px}
  .stats{position:static; margin-left:auto; flex-wrap:wrap; gap:10px}
  .stage{grid-template-columns: 1fr;}
  .panel{order:2}
  .machine{order:1}
}

.machine{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.10);
  background:#0a0b12;
  width:100%;
  aspect-ratio: 3 / 2; /* fondmachine.png = 1536x1024 */
}
.machine__bg{
  position:absolute;inset:0;
  background-image:url('assets/symbols/fondmachine.png');
  background-size:cover;
  background-position:center;
  filter:saturate(1.05) contrast(1.05);
  transform:scale(1.02);
}
.machine::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.52) 100%);
  pointer-events:none;
}

/* --- Contrôles sur la machine (positions calées sur le fondmachine.png) --- */
.machineHud{
  position:absolute;
  inset:0;
  z-index:6;
  pointer-events:auto; /* click-safe */
}

.mh{
  position:absolute;
  pointer-events:none;
  font-weight:800;
  letter-spacing:.2px;
  font-size:clamp(12px, 1.05vw, 14px);
  color:rgba(233,233,242,.92);
  text-shadow:0 2px 10px rgba(0,0,0,.75);
}
.mh strong{color:var(--gold2)}

/* Zones (tweak faciles si tu veux du pixel-perfect) */
.mh--credits{left:20.5%; bottom:13.4%}
.mh--win{left:44.5%; bottom:13.4%}
.mh--fs{left:14.3%; bottom:6.6%}

.mh--bet{
  position:absolute;
  right:18.2%;
  bottom:12.2%;
  display:flex;
  align-items:center;
  gap:10px;
  pointer-events:auto;
}
.mhBet{font-weight:900; color:rgba(233,233,242,.92); text-shadow:0 2px 10px rgba(0,0,0,.75)}

.mhBtn{
  width:34px;height:30px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(0,0,0,.35);
  color:var(--text);
  font-weight:900;
  cursor:pointer;
  pointer-events:auto;
}
.mhBtn:active{transform:translateY(1px)}

.mhSpin{
  position:absolute;
  left:calc(47.2% + 30px);
  bottom:6.0%;
  transform:translateX(-50%);
  width:min(210px, 22%);
  height:42px;
  border-radius:14px;
  border:1px solid rgba(242,193,78,.75);
  background:linear-gradient(180deg, rgba(242,193,78,.95), rgba(242,193,78,.55));
  color:#15120a;
  font-weight:900;
  letter-spacing:.7px;
  cursor:pointer;
  pointer-events:auto;
  box-shadow:0 14px 40px rgba(0,0,0,.45);
}
.mhSpin:active{transform:translateX(-50%) translateY(1px)}

.mhSmall{
  position:absolute;
  bottom:5.3%;
  height:34px;
  padding:0 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.33);
  color:var(--text);
  font-weight:800;
  cursor:pointer;
  pointer-events:auto;
}
#maxBtn{right:18.3%}
#autoBtn{right:7.6%}
.mhSmall:active{transform:translateY(1px)}

.controls--model{display:flex;gap:10px}
.betRangeHidden{display:none}

.reels{
  position:absolute;
  z-index:2;
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  /* Zone “fenêtre” du fond: calée en % pour rester parfaite à toutes tailles */
  left:11.6%;
  right:11.6%;
  top:23.6%;
  bottom:19.8%;
  padding:clamp(10px, 1.6vw, 18px);
  gap:clamp(8px, 1.2vw, 12px);
  align-content:stretch;
}

/* Overlay pour l'affichage des gains (ways breakdown) */
.winlines{
  position:absolute;
  z-index:4;
  left:11.6%;
  right:11.6%;
  top:18.6%;
  pointer-events:none;
  display:flex;
  justify-content:flex-end;
}

.wayshud{
  width:min(420px, 100%);
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:10px;
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  backdrop-filter: blur(6px);
}
.wayshud__line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 8px;
  border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  margin-bottom:8px;
}
.wayshud__line:last-child{margin-bottom:0}
.wayshud__left{display:flex;align-items:center;gap:10px;min-width:0}
.wayshud__icon{width:38px;height:38px;object-fit:contain;filter:drop-shadow(0 10px 10px rgba(0,0,0,.35))}
.wayshud__txt{min-width:0}
.wayshud__name{font-weight:800;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wayshud__sub{color:var(--muted);font-size:12px;margin-top:2px}
.wayshud__win{font-weight:900;color:var(--gold2)}
.wayshud__more{color:var(--muted);font-size:12px;padding:2px 6px}

.reel{
  display:grid;
  grid-template-rows: repeat(3, 1fr);
  gap:clamp(8px, 1.1vw, 12px);
  padding:clamp(8px, 1.1vw, 12px);
  border-radius:18px;
  background:rgba(0,0,0,.32);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.35);
}

.cell{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:center;
}

.cell img{
  width:88%;
  height:88%;
  object-fit:contain;
  filter:drop-shadow(0 10px 10px rgba(0,0,0,.45));
  transform:translateZ(0);
}

.cell.win{
  outline:3px solid rgba(242,193,78,.85);
  box-shadow:0 0 0 2px rgba(0,0,0,.55) inset, 0 0 22px rgba(242,193,78,.25);
}

.winline{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
}

.panel{display:flex;flex-direction:column;gap:14px}
.panel__card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  box-shadow:0 14px 40px rgba(0,0,0,.35);
  padding:14px;
}
.panel__title{font-family:Cinzel,serif;color:var(--gold2);font-size:18px;margin-bottom:10px}

.controls{display:grid;grid-template-columns: 1.2fr 1fr 1fr 1fr; gap:10px}
.btn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:var(--text);
  padding:12px 12px;
  border-radius:14px;
  cursor:pointer;
  font-weight:700;
  letter-spacing:.3px;
  transition:transform .08s ease, background .2s ease, border-color .2s ease;
}
.btn:active{transform:translateY(1px)}
.btn:hover{background:rgba(255,255,255,.09)}
.btn[disabled]{opacity:.55;cursor:not-allowed}
.btn--primary{
  background:linear-gradient(180deg, rgba(242,193,78,.95), rgba(242,193,78,.55));
  border-color:rgba(242,193,78,.75);
  color:#15120a;
}
.btn--primary:hover{background:linear-gradient(180deg, rgba(255,224,138,.98), rgba(242,193,78,.62))}
.btn--tiny{padding:10px 10px; border-radius:12px}

.betbar{display:flex;align-items:center;gap:10px;margin-top:12px}
.betbar input[type=range]{width:100%}

.micro{margin-top:10px}
.link{background:none;border:none;color:var(--gold2);cursor:pointer;padding:0;font-weight:700}
.link:hover{text-decoration:underline}
.hint{margin-top:8px;color:var(--muted);font-size:12px;line-height:1.35}

.log{max-height:210px;overflow:auto;border-radius:14px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08);padding:10px; font-size:13px;color:var(--muted)}
.log .entry{padding:6px 0;border-bottom:1px dashed rgba(255,255,255,.10)}
.log .entry:last-child{border-bottom:none}
.log .good{color:var(--green)}
.log .bad{color:var(--red)}

/* Modal */
.modal{position:fixed;inset:0;display:none;z-index:50}
.modal[aria-hidden="false"]{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.modal__content{
  position:relative;
  width:min(820px, 92vw);
  margin:6vh auto;
  background:linear-gradient(180deg, rgba(18,22,42,.98), rgba(12,14,24,.98));
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.modal__header{display:flex;justify-content:space-between;align-items:center;padding:14px 14px;border-bottom:1px solid rgba(255,255,255,.10)}
.modal__title{font-family:Cinzel,serif;color:var(--gold2);font-size:18px}
.x{border:none;background:rgba(255,255,255,.06);color:var(--text);border-radius:12px;padding:8px 10px;cursor:pointer}
.x:hover{background:rgba(255,255,255,.10)}
.modal__body{padding:14px}

.paytable{display:grid;grid-template-columns: repeat(2, 1fr); gap:12px}
.payitem{display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:10px}
.payitem img{width:52px;height:52px;object-fit:contain}
.payitem .lines{font-size:13px;color:var(--muted);line-height:1.4}
.payitem .name{color:var(--text);font-weight:800}

/* Bonus */
.bonus{display:grid;grid-template-columns: repeat(3, 1fr); gap:12px}
.temple{
  position:relative;
  border-radius:18px;
  padding:16px;
  min-height:140px;
  border:1px solid rgba(255,255,255,.12);
  background:radial-gradient(500px 200px at 30% 30%, rgba(242,193,78,.18), transparent 60%), rgba(255,255,255,.04);
  cursor:pointer;
  overflow:hidden;
}
.temple:hover{background:radial-gradient(500px 200px at 30% 30%, rgba(242,193,78,.24), transparent 62%), rgba(255,255,255,.05)}
.temple[disabled]{cursor:not-allowed;opacity:.55}
.temple__title{font-family:Cinzel,serif;color:var(--gold2)}
.temple__sub{margin-top:6px;color:var(--muted);font-size:12px}
.temple__reveal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:var(--gold2);background:rgba(0,0,0,.55)}

.bonus__footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px}

/* Plein écran / très petits écrans: on priorise la machine */
@media (max-width: 520px){
  .app{padding:14px 12px 20px}
  .brand__title{font-size:22px}
  .pill strong{font-size:16px}
  .panel__title{font-size:16px}
}




/* PlaynSpin footer */
.ps-footer{
  position: fixed;
  left: 0; right: 0;
  bottom: env(safe-area-inset-bottom, 0);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  pointer-events: none;
  z-index: 9999;
}
.ps-footer > *{ pointer-events: auto; }
.ps-footer-text{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 12px;
  opacity: .85;
  color: rgba(255,255,255,.86);
  background: rgba(10,10,14,.55);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  padding: 6px 10px;
  backdrop-filter: blur(10px);
}
.ps-home{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: rgba(255,255,255,.92);
  background: rgba(10,10,14,.55);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  padding: 6px 10px;
  backdrop-filter: blur(10px);
}
.ps-home:hover{ filter: brightness(1.1); }
.ps-home-icon{ font-size: 14px; line-height: 1; }
.ps-home-text{ font-size: 12px; font-weight: 600; }

/* In fullscreen, keep footer visible above UI chrome */
.is-fullscreen .ps-footer{
  bottom: 10px;
}
@media (max-width: 520px){
  .ps-home-text{ display:none; }
  .ps-footer{ padding: 8px 10px; }
  .ps-footer-text{ font-size: 11px; }
}


/* === Casino Bonus + Big Win === */
.bonusOverlay{
  position: fixed; inset: 0;
  background: radial-gradient(1200px 700px at 50% 20%, rgba(255,196,0,.18), rgba(0,0,0,.86));
  display: flex; align-items: center; justify-content: center;
  z-index: 9998;
}
.bonusOverlay.hidden{ display:none; }
.bonusFrame{
  width: min(960px, 96vw);
  height: min(620px, 88vh);
  background: rgba(10,10,14,.70);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  backdrop-filter: blur(16px);
  box-shadow: 0 22px 80px rgba(0,0,0,.55);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.bonusHeader{
  padding: 18px 18px 12px 18px;
  display:flex; align-items:flex-start; justify-content: space-between; gap: 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.bonusTitle{
  font-family: 'Cinzel', serif;
  font-weight: 800;
  font-size: 26px;
  letter-spacing: .5px;
  color: rgba(255,220,140,.95);
  text-shadow: 0 10px 24px rgba(0,0,0,.55);
}
.bonusSubtitle{ color: rgba(255,255,255,.82); font-size: 14px; margin-top: 4px; }
.bonusClose{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  color: rgba(255,255,255,.88);
  border-radius: 14px;
  padding: 10px 12px;
  cursor: pointer;
}
.bonusBoard{
  flex:1;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  padding: 18px;
  align-content: center;
}
.bonusPick{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(900px 240px at 50% -40%, rgba(255,200,60,.18), transparent),
    linear-gradient(180deg, rgba(40,32,18,.45), rgba(10,10,14,.55));
  overflow: hidden;
  cursor: pointer;
  min-height: 150px;
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
  transform: translateY(0);
  transition: transform .18s ease, filter .18s ease;
}
.bonusPick:hover{ transform: translateY(-3px); filter: brightness(1.06); }
.bonusPick.disabled{ opacity:.55; cursor: default; }
.bonusPick::before{
  content:"";
  position:absolute; inset:-40%;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 55%);
  transform: rotate(12deg);
}
.bonusPickInner{
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap: 10px;
  padding: 14px;
  text-align:center;
}
.bonusGlyph{
  font-size: 44px;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.6));
}
.bonusPickLabel{
  font-family: 'Cinzel', serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .4px;
  color: rgba(255,230,170,.92);
}
.bonusReveal{
  position:absolute; inset:0;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap: 8px;
  background: radial-gradient(600px 240px at 50% 10%, rgba(0,180,255,.22), rgba(0,0,0,.55));
  opacity:0;
  transform: scale(.98);
  transition: opacity .20s ease, transform .20s ease;
}
.bonusPick.revealed .bonusReveal{ opacity:1; transform: scale(1); }
.bonusReward{
  font-size: 28px;
  font-weight: 800;
  color: rgba(255,255,255,.95);
  text-shadow: 0 10px 24px rgba(0,0,0,.55);
}
.bonusRewardSub{ font-size: 12px; color: rgba(255,255,255,.78); }
.bonusFooter{
  padding: 14px 18px 18px 18px;
  display:flex; align-items:center; justify-content: space-between; gap: 12px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.bonusInfo{ display:flex; gap: 18px; color: rgba(255,255,255,.84); font-size: 13px; }
.bonusCollect{
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(255,205,80,.92), rgba(190,120,10,.92));
  color: rgba(0,0,0,.86);
  font-weight: 900;
  cursor:pointer;
  box-shadow: 0 14px 32px rgba(0,0,0,.35);
}
.bonusCollect:disabled{ opacity:.55; cursor: default; filter: grayscale(.3); }

/* Big win overlay */
.bigWinOverlay{
  position: fixed; inset: 0;
  background: radial-gradient(900px 540px at 50% 30%, rgba(255,210,70,.22), rgba(0,0,0,.78));
  display:flex; align-items:center; justify-content:center;
  z-index: 9999;
}
.bigWinOverlay.hidden{ display:none; }
.bigWinCard{
  width: min(520px, 92vw);
  background: rgba(10,10,14,.60);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 22px;
  padding: 24px 22px;
  text-align:center;
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 90px rgba(0,0,0,.55);
  animation: popIn .24s ease-out;
}
@keyframes popIn{
  from{ transform: scale(.96); opacity:0; }
  to{ transform: scale(1); opacity:1; }
}
.bigWinLabel{
  font-family: 'Cinzel', serif;
  font-weight: 900;
  letter-spacing: 1.2px;
  font-size: 34px;
  color: rgba(255,230,160,.98);
  text-shadow: 0 14px 40px rgba(0,0,0,.55);
}
.bigWinAmount{
  font-size: 54px;
  font-weight: 900;
  margin-top: 10px;
  color: rgba(255,255,255,.96);
  text-shadow: 0 18px 50px rgba(0,0,0,.6);
}
.bigWinHint{
  margin-top: 10px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
}

/* Winning symbol premium effects */
.cell.win{
  outline: 2px solid rgba(255,210,80,.55);
  box-shadow: 0 0 0 2px rgba(0,0,0,.2) inset, 0 0 24px rgba(255,210,80,.22);
  animation: winPulse .55s ease-in-out infinite alternate;
}
@keyframes winPulse{
  from{ transform: translateZ(0) scale(1); filter: brightness(1.02); }
  to{ transform: translateZ(0) scale(1.02); filter: brightness(1.12); }
}
.cell.win::after{
  content:"";
  position:absolute; inset:-10%;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.22), transparent 55%),
              radial-gradient(circle at 70% 65%, rgba(255,200,60,.18), transparent 58%);
  opacity: .55;
  pointer-events:none;
  animation: sparkDrift 1.1s ease-in-out infinite alternate;
}
@keyframes sparkDrift{
  from{ transform: translate(-2px,-2px); opacity:.35; }
  to{ transform: translate(2px,2px); opacity:.65; }
}

/* Reel stop bounce */
.reelCol.stop-bounce{
  animation: reelBounce .18s ease-out;
}
@keyframes reelBounce{
  0%{ transform: translateY(-4px); }
  70%{ transform: translateY(2px); }
  100%{ transform: translateY(0); }
}

@media (max-width: 720px){
  .bonusBoard{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .bonusFrame{ height: min(720px, 92vh); }
}

/* Bonus images */
.bonusTempleImg{
  width: 100%;
  height: 120px;
  object-fit: contain; /* pas de découpe */
  background: rgba(0,0,0,.15);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  padding: 6px;
}
.bonusRewardImg{
  width: 170px;
  max-width: 78%;
  height: 130px;
  object-fit: contain; /* pas de découpe */
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.55));
}


/* Bonus: hide textual labels under symbols (icons only) */
.bonusPickLabel,
.bonusReward,
.bonusRewardSub{
  display: none !important;
}


/* Bonus: fire/light glow behind temples & rewards */
.bonusPick,
.bonusPickInner,
.bonusReveal{
  position: relative;
}

.bonusPickInner::after{
  content:"";
  position:absolute;
  inset: -18px -10px -12px -10px;
  z-index: 0;
  background:
    radial-gradient(120px 90px at 25% 65%, rgba(255,120,0,.32), transparent 60%),
    radial-gradient(140px 110px at 70% 70%, rgba(255,200,60,.22), transparent 62%),
    radial-gradient(260px 160px at 50% 85%, rgba(255,60,0,.18), transparent 70%);
  filter: blur(10px);
  opacity: 1;
  animation: bonusFire 1.15s ease-in-out infinite alternate;
  pointer-events:none;
}

.bonusPickInner > *{
  position: relative;
  z-index: 1;
}

.bonusReveal::before{
  content:"";
  position:absolute;
  inset: -22px -14px -16px -14px;
  z-index: 0;
  background:
    radial-gradient(140px 100px at 35% 70%, rgba(255,140,0,.34), transparent 62%),
    radial-gradient(180px 120px at 70% 72%, rgba(255,220,90,.22), transparent 66%),
    radial-gradient(320px 190px at 50% 88%, rgba(255,40,0,.18), transparent 72%);
  filter: blur(12px);
  opacity: .92;
  animation: bonusFire 1.05s ease-in-out infinite alternate;
  pointer-events:none;
}

.bonusReveal > *{
  position: relative;
  z-index: 1;
}

@keyframes bonusFire{
  from{ transform: translateY(2px) scale(0.99); opacity: .78; }
  to{ transform: translateY(-2px) scale(1.01); opacity: .98; }
}

/* Add a soft ember edge on revealed cards */
.bonusPick.revealed{
  box-shadow: 0 0 0 2px rgba(255,170,60,.22) inset, 0 20px 60px rgba(0,0,0,.45), 0 0 28px rgba(255,140,0,.20);
}


/* === Bonus: enhanced animated fire (flame + embers) === */
.bonusPickInner::after,
.bonusReveal::before{
  mix-blend-mode: screen;
}

.bonusPickInner::after{
  background:
    radial-gradient(120px 90px at 25% 70%, rgba(255,120,0,.36), transparent 62%),
    radial-gradient(140px 110px at 70% 72%, rgba(255,220,90,.24), transparent 66%),
    radial-gradient(260px 160px at 50% 90%, rgba(255,40,0,.20), transparent 72%),
    radial-gradient(180px 120px at 50% 82%, rgba(255,255,255,.08), transparent 70%);
  filter: blur(10px) saturate(1.15);
  animation: bonusFlame 1.0s ease-in-out infinite alternate;
}

.bonusReveal::before{
  background:
    radial-gradient(140px 100px at 35% 72%, rgba(255,140,0,.38), transparent 64%),
    radial-gradient(180px 120px at 70% 74%, rgba(255,220,90,.26), transparent 68%),
    radial-gradient(320px 190px at 50% 92%, rgba(255,30,0,.22), transparent 74%),
    radial-gradient(220px 140px at 50% 84%, rgba(255,255,255,.10), transparent 72%);
  filter: blur(12px) saturate(1.18);
  animation: bonusFlame 0.9s ease-in-out infinite alternate;
}

/* Ember particles layer */
.bonusPick::after{
  content:"";
  position:absolute;
  inset: -10px;
  pointer-events:none;
  z-index: 1;
  background:
    radial-gradient(circle at 10% 85%, rgba(255,210,90,.55) 0 2px, transparent 3px),
    radial-gradient(circle at 22% 90%, rgba(255,120,0,.55) 0 1.6px, transparent 3px),
    radial-gradient(circle at 35% 88%, rgba(255,200,60,.50) 0 1.8px, transparent 3px),
    radial-gradient(circle at 52% 92%, rgba(255,120,0,.50) 0 1.6px, transparent 3px),
    radial-gradient(circle at 70% 88%, rgba(255,210,90,.55) 0 2px, transparent 3px),
    radial-gradient(circle at 84% 90%, rgba(255,120,0,.52) 0 1.7px, transparent 3px);
  opacity: .0;
  transform: translateY(6px);
}

.bonusPick:hover::after,
.bonusPick.revealed::after{
  opacity: .55;
  animation: bonusEmbers 1.2s ease-in-out infinite;
}

@keyframes bonusFlame{
  0%{
    transform: translateY(3px) scale(0.99);
    opacity: .75;
  }
  45%{
    transform: translateY(-2px) scale(1.01);
    opacity: .92;
  }
  100%{
    transform: translateY(1px) scale(1.02);
    opacity: .98;
  }
}

@keyframes bonusEmbers{
  0%{ transform: translateY(10px); filter: blur(0px); opacity:.0; }
  15%{ opacity:.55; }
  60%{ opacity:.45; }
  100%{ transform: translateY(-8px); filter: blur(0.3px); opacity:.0; }
}


/* === Bonus: INTENSE flames + embers + reveal burst sparks === */
.bonusPickInner::after{
  opacity: 1 !important;
  filter: blur(12px) saturate(1.35) contrast(1.05) !important;
}

.bonusReveal::before{
  opacity: 1 !important;
  filter: blur(14px) saturate(1.40) contrast(1.06) !important;
}

/* Stronger flame motion */
@keyframes bonusFlame{
  0%{
    transform: translateY(6px) scale(0.98) rotate(-0.3deg);
    opacity: .68;
    filter: hue-rotate(-6deg);
  }
  40%{
    transform: translateY(-5px) scale(1.03) rotate(0.3deg);
    opacity: .96;
    filter: hue-rotate(8deg);
  }
  100%{
    transform: translateY(3px) scale(1.06) rotate(-0.2deg);
    opacity: 1;
    filter: hue-rotate(-2deg);
  }
}

/* More embers, stronger rise */
.bonusPick::after{
  background:
    radial-gradient(circle at 8% 92%, rgba(255,230,120,.70) 0 2px, transparent 3.2px),
    radial-gradient(circle at 14% 88%, rgba(255,120,0,.72) 0 1.8px, transparent 3.2px),
    radial-gradient(circle at 22% 95%, rgba(255,210,90,.65) 0 2.2px, transparent 3.6px),
    radial-gradient(circle at 30% 90%, rgba(255,120,0,.65) 0 1.9px, transparent 3.4px),
    radial-gradient(circle at 38% 96%, rgba(255,240,160,.60) 0 2px, transparent 3.4px),
    radial-gradient(circle at 46% 92%, rgba(255,150,30,.70) 0 2.1px, transparent 3.6px),
    radial-gradient(circle at 54% 96%, rgba(255,230,120,.62) 0 2px, transparent 3.4px),
    radial-gradient(circle at 62% 90%, rgba(255,120,0,.66) 0 1.9px, transparent 3.4px),
    radial-gradient(circle at 70% 97%, rgba(255,210,90,.62) 0 2.2px, transparent 3.6px),
    radial-gradient(circle at 78% 92%, rgba(255,150,30,.68) 0 2px, transparent 3.4px),
    radial-gradient(circle at 86% 95%, rgba(255,240,160,.58) 0 2px, transparent 3.4px),
    radial-gradient(circle at 92% 90%, rgba(255,120,0,.70) 0 1.8px, transparent 3.2px);
  opacity: 0;
  transform: translateY(14px);
}

.bonusPick:hover::after,
.bonusPick.revealed::after{
  opacity: .75;
  animation: bonusEmbers 0.95s ease-in-out infinite;
}

@keyframes bonusEmbers{
  0%{ transform: translateY(18px); filter: blur(0px); opacity:.0; }
  15%{ opacity:.80; }
  55%{ opacity:.60; }
  100%{ transform: translateY(-16px); filter: blur(0.4px); opacity:.0; }
}

/* Reveal burst sparks (one-shot) */
.bonusPick{
  overflow: visible; /* allow sparks outside */
}
.bonusPick .sparkBurst{
  position:absolute;
  left: 50%;
  top: 55%;
  width: 10px;
  height: 10px;
  transform: translate(-50%,-50%);
  pointer-events:none;
  z-index: 4;
  opacity: 0;
}
.bonusPick.revealed .sparkBurst{
  opacity: 1;
  animation: sparkBurst 420ms ease-out 1;
}
.bonusPick .sparkBurst::before,
.bonusPick .sparkBurst::after{
  content:"";
  position:absolute;
  inset:-34px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.90) 0 2px, transparent 3px),
    radial-gradient(circle at 30% 40%, rgba(255,220,110,.80) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 35%, rgba(255,160,30,.85) 0 2px, transparent 3px),
    radial-gradient(circle at 20% 70%, rgba(255,120,0,.80) 0 2px, transparent 3px),
    radial-gradient(circle at 80% 72%, rgba(255,240,160,.75) 0 2px, transparent 3px),
    radial-gradient(circle at 45% 85%, rgba(255,160,30,.85) 0 2px, transparent 3px),
    radial-gradient(circle at 60% 20%, rgba(255,240,160,.75) 0 2px, transparent 3px);
  filter: blur(.2px);
}
.bonusPick .sparkBurst::after{
  inset:-48px;
  background:
    radial-gradient(circle at 10% 50%, rgba(255,220,110,.65) 0 1.8px, transparent 3px),
    radial-gradient(circle at 90% 48%, rgba(255,120,0,.70) 0 1.8px, transparent 3px),
    radial-gradient(circle at 50% 10%, rgba(255,255,255,.65) 0 1.8px, transparent 3px),
    radial-gradient(circle at 52% 92%, rgba(255,160,30,.70) 0 1.8px, transparent 3px);
}
@keyframes sparkBurst{
  0%{ transform: translate(-50%,-50%) scale(.65) rotate(0deg); opacity: 0; }
  15%{ opacity: 1; }
  100%{ transform: translate(-50%,-50%) scale(1.25) rotate(18deg); opacity: 0; }
}


/* === Bonus: heat haze distortion behind temples (CSS-only) === */
.bonusPickInner::before{
  content:"";
  position:absolute;
  inset: -10px;
  z-index: 0;
  border-radius: 18px;
  background:
    radial-gradient(220px 140px at 50% 65%, rgba(255,180,60,.10), transparent 70%),
    radial-gradient(280px 180px at 50% 88%, rgba(255,90,0,.08), transparent 72%);
  opacity: .0;
  filter: blur(6px);
  transform: translateY(0) scale(1);
  pointer-events:none;
}
.bonusPick:hover .bonusPickInner::before,
.bonusPick.revealed .bonusPickInner::before{
  opacity: .85;
  animation: heatHaze 1.6s ease-in-out infinite;
}

/* Wavy shimmer */
@keyframes heatHaze{
  0%   { transform: translateY(2px) scale(1.01) skewX(-0.6deg); filter: blur(6px) saturate(1.05); }
  35%  { transform: translateY(-2px) scale(1.02) skewX(0.7deg); filter: blur(7px) saturate(1.15); }
  70%  { transform: translateY(1px) scale(1.03) skewX(-0.4deg); filter: blur(6px) saturate(1.10); }
  100% { transform: translateY(2px) scale(1.01) skewX(0.5deg); filter: blur(7px) saturate(1.12); }
}


/* === Bonus FX: coin rain + lightning === */
#bonusFxLayer{
  position:absolute;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index: 6;
}
.coin{
  position:absolute;
  top:-20px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.75), transparent 45%),
    radial-gradient(circle at 60% 60%, rgba(255,210,90,.85), rgba(255,140,0,.65));
  box-shadow: 0 10px 20px rgba(0,0,0,.35);
  opacity: .0;
  transform: translateY(0) rotate(0deg);
  animation: coinFall var(--dur) linear forwards;
}
@keyframes coinFall{
  0%{ opacity: 0; transform: translateY(-30px) rotate(0deg) scale(.9); }
  10%{ opacity: 1; }
  100%{ opacity: 0; transform: translateY(720px) rotate(540deg) scale(1.05); }
}

.lightning{
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(500px 260px at 65% 30%, rgba(120,200,255,.18), transparent 70%),
    linear-gradient(115deg, transparent 0 35%, rgba(255,255,255,.95) 38%, rgba(120,220,255,.75) 42%, transparent 48% 100%);
  opacity:0;
  filter: blur(0.4px);
  transform: rotate(-6deg);
  animation: lightningFlash 420ms ease-out forwards;
}
@keyframes lightningFlash{
  0%{ opacity:0; transform: scale(1) rotate(-6deg); }
  10%{ opacity:1; }
  25%{ opacity:.25; }
  35%{ opacity:1; }
  100%{ opacity:0; transform: scale(1.02) rotate(-6deg); }
}

/* Free spins multiplier badge */
.free-spins .fs-mult{
  display:inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(255,200,60,.20);
  border: 1px solid rgba(255,220,120,.22);
  color: rgba(255,240,190,.95);
  font-weight: 800;
  font-size: 12px;
}

/* Sticky wild (free spins) premium glow */
.cell.sticky-wild{
  outline: 2px solid rgba(120,220,255,.55);
  box-shadow: 0 0 0 2px rgba(0,0,0,.18) inset, 0 0 26px rgba(120,220,255,.22);
  animation: stickyWildPulse .65s ease-in-out infinite alternate;
}
@keyframes stickyWildPulse{
  from{ transform: translateZ(0) scale(1); filter: brightness(1.05) saturate(1.05); }
  to{ transform: translateZ(0) scale(1.03); filter: brightness(1.18) saturate(1.2); }
}
.cell.sticky-wild::before{
  content:"";
  position:absolute;
  inset:-12%;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,255,255,.22), transparent 55%),
    radial-gradient(circle at 55% 70%, rgba(120,220,255,.18), transparent 60%);
  opacity: .7;
  filter: blur(2px);
  pointer-events:none;
  animation: stickyWildSpark 1.1s ease-in-out infinite;
}
@keyframes stickyWildSpark{
  0%{ transform: translate(-2px,-1px); opacity:.45; }
  50%{ transform: translate(2px,1px); opacity:.75; }
  100%{ transform: translate(-1px,2px); opacity:.55; }
}


  .cell.win, .cell.sticky-wild{ animation:none !important; }
}


/* === Casino background (subtle, does NOT affect right menu) === */
.casino-bg{
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  /* Nuit bleue */
  background: radial-gradient(1400px 900px at 45% 18%, rgba(80,150,255,.18), rgba(2,6,18,1) 70%);
}


.casino-bg::before{
  content:"";
  position:absolute;
  inset:-25%;
  /* Nuages lumineux + lueurs */
  background:
    radial-gradient(520px 340px at 22% 28%, rgba(90,170,255,.26), transparent 70%),
    radial-gradient(680px 420px at 55% 55%, rgba(140,220,255,.10), transparent 72%),
    radial-gradient(520px 340px at 45% 78%, rgba(255,120,0,.06), transparent 75%),
    radial-gradient(420px 260px at 78% 30%, rgba(120,180,255,.12), transparent 72%);
  filter: blur(18px) saturate(1.2);
  opacity: 1;
  animation: nightDrift 10s ease-in-out infinite alternate;
  /* Fade-out vers la droite (menu propre) */
  -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,1) 0 70%, rgba(0,0,0,.22) 86%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(90deg, rgba(0,0,0,1) 0 70%, rgba(0,0,0,.22) 86%, rgba(0,0,0,0) 100%);
}
.casino-bg::after{
  content:"";
  position:absolute;
  inset:-30%;
  /* Etoiles + balayage très léger + éclairs */
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.12) 0 1px, transparent 2px),
    radial-gradient(circle at 28% 32%, rgba(255,255,255,.10) 0 1px, transparent 2px),
    radial-gradient(circle at 46% 22%, rgba(255,255,255,.09) 0 1px, transparent 2px),
    radial-gradient(circle at 62% 18%, rgba(255,255,255,.10) 0 1px, transparent 2px),
    radial-gradient(circle at 70% 36%, rgba(255,255,255,.08) 0 1px, transparent 2px),
    radial-gradient(circle at 18% 52%, rgba(255,255,255,.07) 0 1px, transparent 2px),
    radial-gradient(circle at 40% 60%, rgba(255,255,255,.07) 0 1px, transparent 2px),
    radial-gradient(circle at 58% 64%, rgba(255,255,255,.06) 0 1px, transparent 2px),
    radial-gradient(900px 600px at 45% 55%, rgba(255,255,255,.025), transparent 70%),
    linear-gradient(110deg, transparent 0 42%, rgba(255,255,255,.0) 43%, rgba(140,220,255,.0) 46%, transparent 52% 100%);
  opacity: .55;
  transform: rotate(6deg);
  animation: lightningCycle 8s ease-in-out infinite;
  pointer-events:none;
  -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,1) 0 70%, rgba(0,0,0,.16) 86%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(90deg, rgba(0,0,0,1) 0 70%, rgba(0,0,0,.16) 86%, rgba(0,0,0,0) 100%);
}

@keyframes nightDrift{
  0%{ transform: translate(-2%, -1%) scale(1); opacity:.70; }
  50%{ transform: translate(2%, 1%) scale(1.03); opacity:.96; }
  100%{ transform: translate(1%, -2%) scale(1.05); opacity:.78; }
}

/* Eclairs: flashs brefs (sans gêner l'UI) */
@keyframes lightningCycle{
  0%, 10%, 28%, 55%, 80%, 100%{
    opacity: .40;
    filter: blur(0px);
  }
  12%{
    opacity: 1;
    background-position: 0 0;
    filter: brightness(1.25) blur(0px);
  }
  13%{
    opacity: .28;
  }
  30%{
    opacity: 1;
    filter: brightness(1.35);
  }
  31%{
    opacity: .32;
  }
  58%{
    opacity: .98;
    filter: brightness(1.3);
  }
  59%{
    opacity: .30;
  }
  83%{
    opacity: 1;
    filter: brightness(1.32);
  }
  84%{
    opacity: .34;
  }
}

  50%{ transform: translate(1.5%, 1%) scale(1.02); opacity:.82; }
  100%{ transform: translate(1%, -1.5%) scale(1.03); opacity:.62; }
}
  to{ transform: translateX(1.5%) rotate(8deg); }
}

/* Keep right menu readable */
.side-panel, .right-panel, .panel-right{
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
}

/* Performance mode: disable background + reduce effects */
.perf-low .bonusPickInner::after,
.perf-low .bonusReveal::before{ filter: blur(6px) !important; }
.perf-low .bonusPick::after{ display:none !important; }
.perf-low .cell.win::after,
.perf-low .cell.sticky-wild::before{ display:none !important; }
.perf-low .bigWinCard{ animation: none !important; }

@media (prefers-reduced-motion: reduce){
  .casino-bg::before, .casino-bg::after{ animation:none !important; }
  .cell.win, .cell.sticky-wild{ animation:none !important; }
}

.btn--icon.is-active{
  box-shadow: 0 0 0 2px rgba(255,220,120,.18) inset, 0 0 18px rgba(255,200,60,.12);
  filter: brightness(1.08);
}

body > :not(.casino-bg){ position: relative; z-index: 2; }

/* perf-low reduce background (keep visible) */
.perf-low .casino-bg::before,
.perf-low .casino-bg::after{
  animation: none !important;
  filter: blur(10px) saturate(1.0) !important;
  opacity: .55 !important;
}


/* === Spin button: transparent (no label) + pulse === */
#spinBtn.mhSpin{
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: transparent !important;
  text-shadow: none !important;
}
#spinBtn.mhSpin::before,
#spinBtn.mhSpin::after{ content:"" !important; }

#spinBtn.mhSpin:not(:disabled){
  animation: spinPulse 1.35s ease-in-out infinite;
}
@keyframes spinPulse{
  0%{ transform: translateZ(0) scale(1); filter: drop-shadow(0 0 0 rgba(140,220,255,0)); }
  50%{ transform: translateZ(0) scale(1.015); filter: drop-shadow(0 0 16px rgba(140,220,255,.22)); }
  100%{ transform: translateZ(0) scale(1); filter: drop-shadow(0 0 0 rgba(140,220,255,0)); }
}

/* Zeus glow when Auto is OFF */
body.auto-off #spinBtn.mhSpin:not(:disabled){
  filter: drop-shadow(0 0 18px rgba(120,220,255,.38)) drop-shadow(0 0 38px rgba(120,220,255,.18));
}

/* === Animated night background canvas === */
#bgCanvas{
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: .95;
}
/* perf mode */

/* Bg canvas stays visible even in perf mode (lighter) */
.perf-low #bgCanvas{ opacity: .45; }
@media (prefers-reduced-motion: reduce){
  #bgCanvas{ opacity: .25; }
}

body > :not(.casino-bg):not(#bgCanvas){ position: relative; z-index: 3; }


/* === Bonus overlay: always above the machine === */
#bonusOverlay{
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
}
#bonusOverlay.hidden{ display:none !important; }
#bonusOverlay .bonusFrame{
  position: relative;
  z-index: 10000;
}


/* === Big Win overlay: same positioning as Bonus overlay === */
#bigWinOverlay{
  position: fixed !important;
  inset: 0 !important;
  z-index: 9998 !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
#bigWinOverlay.hidden{ display:none !important; }
#bigWinOverlay .bigWinCard{
  position: relative;
  z-index: 9999;
  margin: 0 !important;
}

/* === Spin button premium glow === */
.mhSpin{
  position: relative;
  isolation: isolate;
}

/* base glow */
.mhSpin::after{
  content:"";
  position:absolute;
  inset:-14px;
  border-radius:50%;
  background: radial-gradient(circle,
    rgba(120,220,255,.45) 0%,
    rgba(120,220,255,.18) 35%,
    rgba(120,220,255,.08) 55%,
    rgba(120,220,255,0) 70%);
  filter: blur(10px);
  opacity:.75;
  z-index:-1;
  animation: spinGlowBreath 2.4s ease-in-out infinite;
  pointer-events:none;
}

/* subtle electric sparks */
.mhSpin::before{
  content:"";
  position:absolute;
  inset:-22px;
  border-radius:50%;
  background:
    radial-gradient(circle at 20% 30%, rgba(180,240,255,.35) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 25%, rgba(180,240,255,.25) 0 2px, transparent 3px),
    radial-gradient(circle at 60% 70%, rgba(180,240,255,.30) 0 2px, transparent 3px),
    radial-gradient(circle at 30% 75%, rgba(180,240,255,.28) 0 2px, transparent 3px);
  opacity:.55;
  animation: spinSparkRotate 6s linear infinite;
  pointer-events:none;
}

@keyframes spinGlowBreath{
  0%{ transform: scale(.96); opacity:.55; }
  50%{ transform: scale(1.04); opacity:.95; }
  100%{ transform: scale(.96); opacity:.55; }
}
@keyframes spinSparkRotate{
  from{ transform: rotate(0deg); }
  to{ transform: rotate(360deg); }
}

/* stronger glow on hover */
.mhSpin:hover::after{
  opacity:1;
  filter: blur(12px);
}

/* disable effects when spinning / disabled */
.mhSpin:disabled::after,
.mhSpin:disabled::before{
  animation:none;
  opacity:.15;
}

/* Spin FX states */
body.is-spinning .mhSpin::after,
body.is-spinning .mhSpin::before{
  animation: none !important;
  opacity: .25 !important;
  filter: blur(6px) !important;
}

/* Zeus random lightning flash */
12%{ opacity:1; }
  28%{ opacity:.25; }
  42%{ opacity:1; }
  100%{ transform: rotate(14deg) scale(1.02); opacity:0; }
}


/* === Spin button: ensure clickable and above machine layers === */
#spinBtn.mhSpin{
  z-index: 5000 !important;
  pointer-events: auto !important;
  touch-action: manipulation;
}
#spinBtn.mhSpin::before,
#spinBtn.mhSpin::after{
  z-index: -1; /* stays behind button but above page */
}

/* Safety: background layers must not block clicks */
.casino-bg, #bgCanvas{ pointer-events: none !important; }

.machineHud .mh{ pointer-events:none; }

/* Ensure Spin glow always visible */
#spinBtn.mhSpin{
  z-index: 80 !important;
}
#spinBtn.mhSpin::after{
  z-index: -1; /* within isolated context */
  mix-blend-mode: screen;
}
#spinBtn.mhSpin::before{
  z-index: -1;
  mix-blend-mode: screen;
}


/* === FINAL OVERRIDE: Spin button hitbox + glow (click-safe) === */
#spinBtn{
  position: absolute !important;
  left: calc(47.2% + 30px) !important;
  bottom: calc(6.0% - 50px) !important;
  transform: translateX(-50%) !important;

  width: min(170px, 20vw) !important;
  height: min(170px, 20vw) !important;
  aspect-ratio: 1 / 1 !important;

  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: transparent !important;
  text-shadow: none !important;

  cursor: pointer !important;
  pointer-events: auto !important;
  touch-action: manipulation !important;

  z-index: 9997 !important;
  border-radius: 50% !important;
  isolation: isolate !important;
}

/* Make sure no pseudo-labels appear */
#spinBtn::before, #spinBtn::after{ content:"" !important; }

/* Premium glow layer */
#spinBtn > span{ display:none !important; }

#spinBtn.glow::after{
  content:"";
  position:absolute;
  inset:-16px;
  border-radius:50%;
  background: radial-gradient(circle,
    rgba(120,220,255,.55) 0%,
    rgba(120,220,255,.22) 40%,
    rgba(120,220,255,.10) 58%,
    rgba(120,220,255,0) 72%);
  filter: blur(10px);
  opacity:.85;
  z-index:-1;
  pointer-events:none;
  animation: spinGlowBreath 2.2s ease-in-out infinite;
}

#spinBtn.glow::before{
  content:"";
  position:absolute;
  inset:-26px;
  border-radius:50%;
  background:
    radial-gradient(circle at 18% 28%, rgba(200,245,255,.38) 0 2px, transparent 3px),
    radial-gradient(circle at 72% 22%, rgba(200,245,255,.30) 0 2px, transparent 3px),
    radial-gradient(circle at 64% 74%, rgba(200,245,255,.34) 0 2px, transparent 3px),
    radial-gradient(circle at 28% 78%, rgba(200,245,255,.32) 0 2px, transparent 3px);
  opacity:.55;
  z-index:-1;
  pointer-events:none;
  animation: spinSparkRotate 6s linear infinite;
}

#spinBtn.glow:hover::after{
  opacity: 1;
  filter: blur(12px);
}

  12%{ opacity:1; }
  28%{ opacity:.25; }
  42%{ opacity:1; }
  100%{ transform: rotate(14deg) scale(1.02); opacity:0; }
}
