/* LTE4D Bonus page (Lucky Spin) — scoped .ls-* prefix */
/* === LUCKY SPIN STYLES (scoped to .ls-* prefixes) === */
.ls-jp-sign{
  text-align:center;margin:8px auto 6px;
  font-family:'Impact','Arial Black',sans-serif;
  font-size:clamp(2rem,7vw,3.4rem);font-weight:900;
  letter-spacing:.06em;line-height:1;perspective:600px;
}
.ls-jp-letter{
  display:inline-block;color:#ffd700;
  text-shadow:0 0 8px #ffd700,0 0 18px #ff8c00,0 0 30px #ff1744,0 0 50px #ff1744,0 4px 8px rgba(0,0,0,.6);
  animation:ls-jp-flash 1.4s ease-in-out infinite;transform-style:preserve-3d;
}
.ls-jp-letter:nth-child(1){animation-delay:0s;color:#ff1744;text-shadow:0 0 8px #ff1744,0 0 18px #ff5577,0 0 30px #ff1744,0 0 50px #ff8c00}
.ls-jp-letter:nth-child(2){animation-delay:.1s;color:#ff8c00}
.ls-jp-letter:nth-child(3){animation-delay:.2s;color:#ffd700}
.ls-jp-letter:nth-child(4){animation-delay:.3s;color:#39ff14;text-shadow:0 0 8px #39ff14,0 0 18px #22c55e,0 0 30px #39ff14,0 0 50px #00f0ff}
.ls-jp-letter:nth-child(5){animation-delay:.4s;color:#00f0ff}
.ls-jp-letter:nth-child(6){animation-delay:.5s;color:#b537ff}
.ls-jp-letter:nth-child(7){animation-delay:.6s;color:#ff00ea;text-shadow:0 0 8px #ff00ea,0 0 18px #b537ff,0 0 30px #ff00ea,0 0 50px #ff1744}
@keyframes ls-jp-flash{
  0%,100%{transform:scale(1) rotateX(0deg);filter:brightness(1)}
  50%{transform:scale(1.12) rotateX(-15deg);filter:brightness(1.5)}
}

.ls-slot-reels{
  display:flex;justify-content:center;gap:6px;
  max-width:280px;margin:0 auto 14px;padding:6px;
  background:linear-gradient(180deg,#2a1a3a 0%,#1a0530 50%,#2a1a3a 100%);
  border:2px solid #ffd700;border-radius:10px;
  box-shadow:0 0 20px rgba(255,215,0,.5),inset 0 0 12px rgba(0,0,0,.6);
}
.ls-reel{
  flex:1;height:62px;overflow:hidden;
  background:linear-gradient(180deg,#000 0%,#1a0530 50%,#000 100%);
  border:1px solid rgba(255,215,0,.3);border-radius:6px;
  box-shadow:inset 0 0 8px rgba(0,0,0,.8);position:relative;
}
.ls-reel::before{
  content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.6) 0%,transparent 30%,transparent 70%,rgba(0,0,0,.6) 100%);
}
.ls-reel-track{display:flex;flex-direction:column;align-items:center;animation:ls-reel-spin 1.8s linear infinite;will-change:transform}
.ls-reel:nth-child(2) .ls-reel-track{animation-duration:2.1s}
.ls-reel:nth-child(3) .ls-reel-track{animation-duration:2.4s}
.ls-reel-symbol{height:62px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ls-reel-symbol img{width:44px;height:44px;object-fit:contain;filter:drop-shadow(0 0 8px rgba(255,215,0,.5)) drop-shadow(0 2px 4px rgba(0,0,0,.6))}
@keyframes ls-reel-spin{from{transform:translateY(0)}to{transform:translateY(-100%)}}
.ls-slot-reels.ls-frenzy .ls-reel-track{animation-duration:.5s !important}
.ls-slot-reels.ls-frenzy{animation:ls-reels-shake .15s ease infinite;box-shadow:0 0 35px #ffd700,inset 0 0 18px rgba(255,215,0,.4)}
@keyframes ls-reels-shake{0%,100%{transform:translateX(0)}50%{transform:translateX(1px)}}

.ls-wheel-section{
  background:
    radial-gradient(ellipse at 20% 0%, rgba(181,55,255,.35) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 30%, rgba(255,23,68,.3) 0%, transparent 50%),
    linear-gradient(180deg, #0a0014 0%, #1a0530 50%, #050010 100%);
  padding:20px 14px 30px;
  position:relative;overflow:hidden;
}
.ls-stars{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.ls-star{position:absolute;width:3px;height:3px;background:#fff;border-radius:50%;opacity:0;box-shadow:0 0 6px #fff,0 0 12px rgba(255,255,255,.8);animation:ls-twinkle linear infinite}
@keyframes ls-twinkle{0%{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1.5)}100%{opacity:0;transform:scale(0)}}

.ls-stage-wrap{position:relative;z-index:1}
.ls-wheel-stage{position:relative;width:min(94vw,440px);aspect-ratio:1/1;margin:8px auto 24px;transition:transform .4s ease}
.ls-wheel-stage.ls-idle{animation:ls-stage-breathe 3s ease-in-out infinite}
@keyframes ls-stage-breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.015)}}
.ls-wheel-stage.ls-windup{animation:ls-stage-shake .35s ease}
@keyframes ls-stage-shake{
  0%,100%{transform:translate(0) rotate(0)}
  20%{transform:translate(2px,-1px) rotate(1deg)}
  40%{transform:translate(3px,-2px) rotate(1.5deg)}
  60%{transform:translate(2px,-1px) rotate(1deg)}
  80%{transform:translate(1px,0) rotate(.5deg)}
}
.ls-wheel-stage.ls-zoom{transform:scale(1.06)}

.ls-wheel-halo{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.4) 0%,rgba(255,23,68,.2) 50%,transparent 70%);animation:ls-halo-pulse 3s ease-in-out infinite;filter:blur(20px)}
@keyframes ls-halo-pulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}
.ls-pulse-ring{position:absolute;inset:-6px;border-radius:50%;border:3px solid rgba(255,215,0,.4);pointer-events:none;animation:ls-pulse-ring 2.2s ease-out infinite;z-index:0}
@keyframes ls-pulse-ring{0%{transform:scale(.95);opacity:.8}100%{transform:scale(1.2);opacity:0}}

.ls-led-ring{position:absolute;inset:-12px;pointer-events:none}
.ls-led{position:absolute;top:50%;left:50%;width:10px;height:10px;border-radius:50%;transform-origin:0 0;background:#ffd700;box-shadow:0 0 10px #ffd700;animation:ls-led-chase 1.2s linear infinite}
@keyframes ls-led-chase{0%,100%{opacity:.25;transform:translate(-50%,-50%) translate(var(--lx),var(--ly)) scale(.8)}50%{opacity:1;transform:translate(-50%,-50%) translate(var(--lx),var(--ly)) scale(1.3)}}

.ls-pointer{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  width:48px;height:56px;z-index:20;
  filter:drop-shadow(0 0 8px rgba(255,23,68,.8)) drop-shadow(0 4px 12px rgba(0,0,0,.6));
  animation:ls-pointer-glow 1.4s ease-in-out infinite;
}
@keyframes ls-pointer-glow{0%,100%{filter:drop-shadow(0 0 8px rgba(255,23,68,.8)) drop-shadow(0 4px 12px rgba(0,0,0,.6))}50%{filter:drop-shadow(0 0 16px rgba(255,23,68,1))}}
.ls-pointer.ls-shake{animation:ls-pointer-shake .08s ease infinite}
@keyframes ls-pointer-shake{0%,100%{transform:translateX(-50%) rotate(0deg)}25%{transform:translateX(-50%) rotate(-8deg)}75%{transform:translateX(-50%) rotate(8deg)}}

.ls-rim{
  position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg,#ffd700,#ff8c00,#ff1744,#b537ff,#00f0ff,#39ff14,#ffd700,#ff8c00,#ff1744,#b537ff,#00f0ff,#39ff14,#ffd700);
  box-shadow:0 0 40px rgba(255,215,0,.5),0 0 80px rgba(255,23,68,.3),inset 0 0 30px rgba(0,0,0,.6);
  animation:ls-rim-spin 12s linear infinite;z-index:1;
}
.ls-rim::after{content:'';position:absolute;inset:10px;border-radius:50%;background:#0a0014;box-shadow:inset 0 0 40px rgba(0,0,0,.8)}
@keyframes ls-rim-spin{to{transform:rotate(360deg)}}

.ls-wheel{position:absolute;inset:10px;border-radius:50%;overflow:hidden;transform:rotate(0deg);will-change:transform;z-index:2}
@keyframes ls-shine-rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.ls-hub{
  position:absolute;top:50%;left:50%;
  width:clamp(64px,18%,90px);height:clamp(64px,18%,90px);
  border-radius:50%;
  background:#000;
  transform:translate(-50%,-50%);z-index:6;
  border:3px solid #ffd700;
  box-shadow:
    0 0 25px rgba(255,215,0,.8),
    0 0 50px rgba(255,140,0,.5),
    inset 0 0 12px rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  animation:ls-hub-glow 2s ease-in-out infinite;
}
.ls-hub img{
  width:88%;height:88%;object-fit:contain;border-radius:50%;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.6));
}
@keyframes ls-hub-glow{
  0%,100%{box-shadow:0 0 25px rgba(255,215,0,.8),0 0 50px rgba(255,140,0,.4),inset 0 0 12px rgba(0,0,0,.6)}
  50%{box-shadow:0 0 40px rgba(255,215,0,1),0 0 80px rgba(255,140,0,.7),inset 0 0 12px rgba(0,0,0,.6)}
}
@keyframes ls-hub-rotate{
  from{transform:translate(-50%,-50%) rotate(0deg)}
  to{transform:translate(-50%,-50%) rotate(360deg)}
}

.ls-good-luck{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);z-index:30;pointer-events:none;
  font-size:1.6rem;font-weight:900;color:#39ff14;
  text-shadow:0 0 12px #39ff14,0 0 24px #39ff14;letter-spacing:.1em;opacity:0;
}
.ls-good-luck.ls-show{animation:ls-gl-popup 1.4s ease}
@keyframes ls-gl-popup{
  0%{opacity:0;transform:translate(-50%,-50%) scale(0) rotate(-15deg)}
  20%{opacity:1;transform:translate(-50%,-50%) scale(1.3) rotate(8deg)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(.8) rotate(0)}
}

/* === KUPON INPUT FORM === */
.ls-kupon-box{
  max-width:min(94vw,440px);margin:0 auto;
  background:linear-gradient(135deg,rgba(181,55,255,.12),rgba(255,23,68,.08));
  border:1px solid rgba(255,215,0,.3);border-radius:14px;padding:16px;
  backdrop-filter:blur(10px);
}
.ls-kupon-label{display:block;font-size:.72rem;color:#ffd700;font-weight:900;text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px;text-align:center}
.ls-kupon-input{
  width:100%;background:rgba(0,0,0,.7);color:#fff;
  border:2px solid rgba(255,215,0,.35);border-radius:10px;
  padding:12px 14px;font-size:1rem;font-family:'Courier New',monospace;font-weight:700;
  letter-spacing:.05em;text-align:center;text-transform:uppercase;
  transition:border-color .2s,box-shadow .2s;
}
.ls-kupon-input:focus{outline:none;border-color:#ffd700;box-shadow:0 0 16px rgba(255,215,0,.3)}
.ls-kupon-input::placeholder{color:rgba(255,215,0,.4);letter-spacing:.1em}
.ls-kupon-hint{font-size:.68rem;color:#94a3b8;text-align:center;margin-top:6px;line-height:1.4}
.ls-kupon-hint a{color:#ffd700;text-decoration:none}

.ls-spin-btn{
  position:relative;width:100%;padding:18px 24px;border:none;
  background:linear-gradient(135deg,#ff1744 0%,#ff8c00 50%,#ff1744 100%);
  background-size:200% 100%;color:#fff;font-size:1.05rem;font-weight:900;
  letter-spacing:.06em;text-transform:uppercase;cursor:pointer;
  border-radius:14px;overflow:hidden;margin-top:12px;
  box-shadow:0 0 30px rgba(255,23,68,.5),0 8px 24px rgba(255,23,68,.4),inset 0 -3px 8px rgba(0,0,0,.3),inset 0 3px 8px rgba(255,255,255,.3);
  transition:transform .12s;
  animation:ls-btn-gradient 3s ease infinite,ls-btn-pulse 1.6s ease-in-out infinite;
}
@keyframes ls-btn-gradient{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes ls-btn-pulse{0%,100%{box-shadow:0 0 30px rgba(255,23,68,.5)}50%{box-shadow:0 0 50px rgba(255,23,68,.8)}}
.ls-spin-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);animation:ls-btn-shine 2.5s ease infinite}
@keyframes ls-btn-shine{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.ls-spin-btn:active:not(:disabled){transform:scale(.98)}
.ls-spin-btn:disabled{opacity:.5;cursor:not-allowed;animation:none}
.ls-spin-btn .ls-ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.55);transform:scale(0);opacity:1;animation:ls-ripple .7s ease-out forwards;pointer-events:none}
@keyframes ls-ripple{to{transform:scale(4);opacity:0}}

/* === COUNTDOWN === */
.ls-countdown{position:fixed;inset:0;z-index:500;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);pointer-events:none}
.ls-countdown.ls-show{display:flex}
.ls-countdown-num{
  font-size:14rem;font-weight:900;
  background:linear-gradient(180deg,#fff,#ffd700,#ff1744);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 80px rgba(255,215,0,.6);
  animation:ls-cd-zoom .7s ease forwards;
}
@keyframes ls-cd-zoom{0%{transform:scale(.3);opacity:0}40%{transform:scale(1.2);opacity:1}80%{transform:scale(1);opacity:1}100%{transform:scale(2);opacity:0}}

/* === WINNER MODAL === */
.ls-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(14px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;animation:ls-fade-in .25s ease}
.ls-modal-overlay.ls-show{display:flex}
.ls-modal{
  background:radial-gradient(circle at 50% 0%,rgba(255,215,0,.25) 0%,transparent 50%),linear-gradient(180deg,#1a0530 0%,#0a0014 100%);
  border:2px solid rgba(255,215,0,.5);border-radius:18px;padding:16px 18px 14px;text-align:center;
  max-width:360px;width:100%;max-height:92vh;overflow-y:auto;
  box-shadow:0 0 80px rgba(255,215,0,.5);
  animation:ls-modal-pop .5s cubic-bezier(.34,1.56,.64,1);position:relative;
}
.ls-modal::-webkit-scrollbar{width:4px}
.ls-modal::-webkit-scrollbar-thumb{background:rgba(255,215,0,.3);border-radius:2px}
@keyframes ls-modal-pop{from{transform:scale(.5) rotate(-5deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
@keyframes ls-fade-in{from{opacity:0}to{opacity:1}}
.ls-modal-headline{font-size:.7rem;color:#39ff14;font-weight:900;text-transform:uppercase;letter-spacing:.25em;margin-bottom:2px;text-shadow:0 0 10px #39ff14}
.ls-modal h2{
  font-size:1.7rem;font-weight:900;
  background:linear-gradient(180deg,#fff 0%,#ffd700 50%,#ff8c00 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  letter-spacing:-.02em;line-height:1;margin-bottom:4px;
  animation:ls-title-bounce 1.5s ease infinite;
}
@keyframes ls-title-bounce{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.ls-modal-icon-big{width:70px;height:70px;object-fit:contain;margin:4px auto;display:block;animation:ls-icon-spin 2s ease infinite;filter:drop-shadow(0 0 16px rgba(255,215,0,.8))}
@keyframes ls-icon-spin{0%,100%{transform:rotate(-8deg) scale(1)}50%{transform:rotate(8deg) scale(1.12)}}
.ls-modal-prize{font-size:1.4rem;font-weight:900;color:#fff;margin:4px 0 10px;padding:8px 14px;border-radius:10px;background:linear-gradient(135deg,rgba(255,215,0,.15),rgba(255,23,68,.12));border:1px solid rgba(255,215,0,.4);text-shadow:0 2px 12px rgba(255,215,0,.6)}
.ls-modal-sub{color:#cbd5e1;font-size:.72rem;margin:8px 0 10px;line-height:1.4;padding:7px;background:rgba(255,255,255,.04);border-radius:8px}
.ls-modal-close{flex:1;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font-size:.78rem;font-weight:800;cursor:pointer;letter-spacing:.03em;text-transform:uppercase}
.ls-modal-close:active{transform:scale(.96)}

/* === BRAND HEADER (compact) === */
.ls-modal-brand{
  display:flex;align-items:center;gap:8px;justify-content:center;
  margin-bottom:8px;padding-bottom:8px;
  border-bottom:1px dashed rgba(255,215,0,.3);
}
.ls-modal-logo{
  width:auto;height:42px;max-width:120px;
  object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 0 8px rgba(255,215,0,.5));
}
.ls-brand-sub{
  font-size:.78rem;color:#ffd700;font-weight:900;
  letter-spacing:.12em;text-transform:uppercase;line-height:1.1;
  text-shadow:0 0 8px rgba(255,215,0,.4);
}

/* === RECEIPT (compact) === */
.ls-modal-receipt{
  background:rgba(0,0,0,.5);border:1px dashed rgba(255,215,0,.4);
  border-radius:9px;padding:8px 10px;margin:10px 0;text-align:left;
}
.ls-receipt-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:3px 0;font-size:.7rem;
  border-bottom:1px dotted rgba(255,255,255,.08);
}
.ls-receipt-row:last-child{border-bottom:none}
.ls-receipt-row span{color:#94a3b8;font-weight:600}
.ls-receipt-row b{color:#ffd700;font-weight:800;font-family:'Courier New',monospace;font-size:.72rem}

/* === SCREENSHOT WARNING (compact) === */
.ls-modal-ss-warn{
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,rgba(255,140,0,.18),rgba(255,23,68,.12));
  border:1.5px solid #ff8c00;border-radius:9px;padding:8px 10px;margin:8px 0;
  box-shadow:0 0 14px rgba(255,140,0,.3);
  animation:ls-ss-pulse 1.8s ease-in-out infinite;
}
@keyframes ls-ss-pulse{
  0%,100%{box-shadow:0 0 14px rgba(255,140,0,.3)}
  50%{box-shadow:0 0 22px rgba(255,140,0,.6)}
}
.ls-ss-icon{
  font-size:1.4rem;flex-shrink:0;
  animation:ls-ss-shake 1.2s ease-in-out infinite;
}
@keyframes ls-ss-shake{
  0%,100%{transform:rotate(0deg) scale(1)}
  25%{transform:rotate(-8deg) scale(1.1)}
  75%{transform:rotate(8deg) scale(1.1)}
}
.ls-ss-text{flex:1;text-align:left;line-height:1.25}
.ls-ss-text b{display:block;color:#ff8c00;font-size:.76rem;font-weight:900}
.ls-ss-text small{display:block;color:#cbd5e1;font-size:.62rem;font-weight:600;margin-top:1px}
.ls-ss-text small b{display:inline;color:#39ff14;font-size:inherit;margin:0;font-weight:800}

/* === ACTIONS (compact) === */
.ls-modal-actions{display:flex;gap:6px;margin-top:8px}
.ls-modal-cs{
  flex:1;padding:10px 12px;border-radius:10px;
  background:linear-gradient(135deg,#39ff14,#22c55e);color:#003311;
  font-size:.78rem;font-weight:900;cursor:pointer;letter-spacing:.03em;
  text-transform:uppercase;text-decoration:none;text-align:center;
  box-shadow:0 0 14px rgba(57,255,20,.4);
}
.ls-modal-cs:active{transform:scale(.96)}

/* === CONFETTI + COIN RAIN === */
.ls-confetti{position:fixed;top:-20px;width:12px;height:18px;z-index:999;pointer-events:none;animation:ls-confetti-fall linear forwards}
@keyframes ls-confetti-fall{to{transform:translateY(110vh) rotate(720deg);opacity:0}}
.ls-coin{position:fixed;top:-40px;z-index:998;pointer-events:none;animation:ls-coin-drop linear forwards;filter:drop-shadow(0 0 8px rgba(255,215,0,.8))}
@keyframes ls-coin-drop{0%{transform:translateY(0) rotate(0);opacity:1}100%{transform:translateY(110vh) rotate(1080deg);opacity:0}}

/* === COIN MASTER JACKPOT MOMENT === */
.ls-screen-flash{position:fixed;inset:0;background:#fff;z-index:996;pointer-events:none;opacity:0}
.ls-screen-flash.ls-fire{animation:ls-flash .9s ease-out forwards}
@keyframes ls-flash{
  0%{opacity:0}
  15%{opacity:.85}
  100%{opacity:0}
}

.ls-jackpot-text{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);
  z-index:997;pointer-events:none;
  font-family:'Impact','Arial Black',sans-serif;
  font-size:clamp(4rem,15vw,9rem);font-weight:900;letter-spacing:.04em;
  background:linear-gradient(180deg,#fff 0%,#ffd700 40%,#ff8c00 70%,#ff1744 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px rgba(255,215,0,.8);
  filter:drop-shadow(0 8px 24px rgba(0,0,0,.8));
  opacity:0;
}
.ls-jackpot-text.ls-fire{animation:ls-jp-text 1.4s cubic-bezier(.34,1.7,.64,1) forwards}
@keyframes ls-jp-text{
  0%{opacity:0;transform:translate(-50%,-50%) scale(0) rotate(-30deg)}
  20%{opacity:1;transform:translate(-50%,-50%) scale(1.4) rotate(10deg)}
  40%{transform:translate(-50%,-50%) scale(1) rotate(-3deg)}
  70%{opacity:1;transform:translate(-50%,-50%) scale(1.1) rotate(2deg)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(.6) rotate(0)}
}

/* Winning slice highlight (pulse glow) */
.ls-winning-slice{
  position:absolute;top:0;left:50%;
  width:32px;height:50%;
  transform:translateX(-50%) rotate(0deg);
  transform-origin:50% 100%;
  pointer-events:none;
  z-index:5;
}
.ls-winning-slice.ls-fire{
  animation:ls-slice-glow 1.6s ease-in-out 3;
}
@keyframes ls-slice-glow{
  0%,100%{filter:drop-shadow(0 0 0 rgba(255,215,0,0))}
  50%{filter:drop-shadow(0 0 30px rgba(255,215,0,1)) drop-shadow(0 0 60px rgba(255,215,0,.8))}
}

/* Hub burst explosion */
.ls-hub-burst{
  position:absolute;top:50%;left:50%;
  width:0;height:0;border-radius:50%;
  transform:translate(-50%,-50%);
  pointer-events:none;z-index:7;
  background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,215,0,.6) 40%,transparent 80%);
}
.ls-hub-burst.ls-fire{animation:ls-hub-burst .9s ease-out forwards}
@keyframes ls-hub-burst{
  0%{width:0;height:0;opacity:1}
  100%{width:300%;height:300%;opacity:0}
}

/* Pointer celebration bounce */
.ls-pointer.ls-celebrate{animation:ls-pointer-celebrate .25s ease infinite}
@keyframes ls-pointer-celebrate{
  0%,100%{transform:translateX(-50%) translateY(0) rotate(0deg)}
  50%{transform:translateX(-50%) translateY(-12px) rotate(0deg)}
}

/* Reels result match animation */
.ls-reel.ls-result{
  animation:ls-reel-bounce .5s ease;
  box-shadow:0 0 22px #ffd700, 0 0 40px rgba(255,140,0,.5), inset 0 0 10px rgba(255,215,0,.35);
  border-color:#ffd700;
}
@keyframes ls-reel-bounce{
  0%,100%{transform:translateY(0) scale(1)}
  30%{transform:translateY(-10px) scale(1.08)}
  60%{transform:translateY(0) scale(.96)}
}

/* Win symbol golden glow + pulse */
.ls-win-symbol img{
  filter:drop-shadow(0 0 12px #ffd700) drop-shadow(0 0 20px #ff8c00) !important;
  animation:ls-win-pulse 1.4s ease-in-out infinite;
}
@keyframes ls-win-pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.12)}
}

/* DING flash when reel stops */
.ls-reel.ls-reel-ding::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(255,215,0,.4) 40%,transparent 70%);
  pointer-events:none;
  animation:ls-ding-flash .6s ease-out forwards;
  z-index:3;
}
@keyframes ls-ding-flash{
  0%{opacity:1}
  100%{opacity:0}
}

/* === PRIZE PREVIEW PREMIUM 3D CARDS === */
.ls-prizes{max-width:min(96vw,520px);margin:28px auto 0;position:relative}
.ls-prizes-title{
  font-size:.78rem;color:#ffd700;font-weight:900;text-transform:uppercase;letter-spacing:.18em;
  margin-bottom:6px;text-align:center;
  text-shadow:0 0 12px rgba(255,215,0,.5);
}
.ls-prizes-sub{text-align:center;font-size:.68rem;color:#cbd5e1;margin-bottom:14px;font-weight:600;letter-spacing:.04em}

/* Marquee horizontal scrolling carousel */
.ls-prizes-marquee{
  overflow:hidden;
  margin:0 -10px;
  padding:12px 0;
  position:relative;
}
.ls-prizes-marquee::before,
.ls-prizes-marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:36px;z-index:5;pointer-events:none;
}
.ls-prizes-marquee::before{left:0;background:linear-gradient(90deg,#0a0014 0%,transparent 100%)}
.ls-prizes-marquee::after{right:0;background:linear-gradient(270deg,#0a0014 0%,transparent 100%)}

.ls-prizes-track{
  display:flex;gap:12px;
  animation:ls-prizes-scroll 28s linear infinite;
  will-change:transform;
  width:max-content;
}
.ls-prizes-track:hover{animation-play-state:paused}
@keyframes ls-prizes-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

.ls-prize-card{
  position:relative;
  flex:0 0 110px;
  height:130px;
  padding:12px 8px;
  border-radius:16px;
  background:linear-gradient(160deg, var(--card-light,#444) 0%, var(--card-base,#222) 50%, var(--card-dark,#000) 100%);
  border:2px solid rgba(255,215,0,.4);
  box-shadow:
    0 8px 24px rgba(0,0,0,.6),
    inset 0 2px 8px rgba(255,255,255,.15),
    inset 0 -2px 8px rgba(0,0,0,.3);
  text-align:center;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
  cursor:pointer;
}
/* Glossy shine sweep */
.ls-prize-card::before{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  animation:ls-card-shine 4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes ls-card-shine{
  0%{left:-100%}
  50%{left:140%}
  100%{left:140%}
}
.ls-prize-card:nth-child(odd)::before{animation-delay:1.2s}
.ls-prize-card:nth-child(3n)::before{animation-delay:2.4s}

.ls-prize-card:hover{
  transform:translateY(-6px) scale(1.05);
  box-shadow:0 14px 32px rgba(255,215,0,.4),0 0 24px rgba(255,215,0,.3),inset 0 2px 8px rgba(255,255,255,.25);
}

.ls-prize-card-img{
  width:54px;height:54px;object-fit:contain;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.7)) drop-shadow(0 0 8px rgba(255,215,0,.3));
  transition:transform .3s cubic-bezier(.34,1.7,.64,1);
}
.ls-prize-card:hover .ls-prize-card-img{transform:scale(1.18) rotate(-8deg) translateY(-2px)}

.ls-prize-card-label{
  font-size:.72rem;font-weight:900;color:#fff;line-height:1.1;
  text-shadow:0 1px 3px rgba(0,0,0,.8), 0 0 4px rgba(255,215,0,.3);
  background:rgba(0,0,0,.55);
  padding:3px 8px;border-radius:6px;
  border:1px solid rgba(255,215,0,.4);
  letter-spacing:-.01em;
}

/* No REAL distinction in user-facing display (dummy mechanic) */
.ls-prize-card-badge-mega{
  position:absolute;top:6px;left:6px;
  font-size:.55rem;font-weight:900;
  background:linear-gradient(135deg,#ff1744,#ff8c00);color:#fff;
  padding:2px 6px;border-radius:8px;
  letter-spacing:.05em;
  box-shadow:0 2px 6px rgba(255,23,68,.6);
  animation:ls-badge-pulse 1.5s ease-in-out infinite;
}
@keyframes ls-badge-pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.1)}
}

/* Sparkle dots floating around hover */
.ls-prize-card:hover::after{
  content:'✨';position:absolute;top:-8px;right:-2px;
  font-size:1.2rem;
  animation:ls-sparkle-float 1.2s ease infinite;
  pointer-events:none;
}
@keyframes ls-sparkle-float{
  0%,100%{transform:translate(0,0) rotate(0deg);opacity:.7}
  50%{transform:translate(4px,-4px) rotate(180deg);opacity:1}
}

/* === INFO BLOCK === */
.ls-info{max-width:min(94vw,480px);margin:14px auto 0;background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 16px}
.ls-info h3{font-size:.88rem;color:#ffd700;margin-bottom:10px;font-weight:900;letter-spacing:.04em;text-shadow:0 0 8px rgba(255,215,0,.3)}
.ls-info ol{padding-left:20px;color:#cbd5e1;font-size:.78rem;line-height:1.6}
.ls-info ol li{margin-bottom:4px}
.ls-info ol li b{color:#fff}

/* Terms list with icons */
.ls-terms{
  background:linear-gradient(135deg,rgba(255,140,0,.08),rgba(255,23,68,.05));
  border-color:rgba(255,140,0,.35);
}
.ls-terms h3{color:#ff8c00;text-shadow:0 0 8px rgba(255,140,0,.4)}
.ls-terms-list{list-style:none;padding:0;margin:0}
.ls-terms-list li{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 0;border-bottom:1px dashed rgba(255,140,0,.15);
  color:#e4e4e7;font-size:.78rem;line-height:1.45;
}
.ls-terms-list li:last-child{border-bottom:none}
.ls-terms-list li b{color:#ffd700}
.ls-tk-icon{
  flex-shrink:0;width:32px;height:32px;
  background:linear-gradient(135deg,rgba(255,215,0,.18),rgba(255,140,0,.12));
  border:1px solid rgba(255,215,0,.3);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}