/* ===================================================================
   GTACASINO — Vice City / GTA VI memecoin casino
   Palette: hot magenta + cyan neon over a sunset (orange→purple).
=================================================================== */
:root{
  --pink:#ff2bd6;        /* hot magenta */
  --pink-soft:#ff6fe3;
  --cyan:#22e7ff;
  --cyan-soft:#8af6ff;
  --gold:#ffd23f;
  --purple:#2a0d4f;
  --night:#120024;
  --ink:#06000f;
  --text:#ffe9fb;
  --muted:#c79fd6;
  --glass:rgba(28,6,48,.62);
  --glass-line:rgba(255,43,214,.35);
  --display:"Anton","Oswald",system-ui,sans-serif;
  --body:"Oswald",system-ui,sans-serif;
}

@font-face{
  font-family:"Pricedown";
  src:url("assets/fonts/pricedown.otf") format("opentype");
  font-weight:normal;font-style:normal;font-display:swap;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--body);
  color:var(--text);
  background:var(--ink);
  min-height:100vh;
  overflow-x:hidden;
  letter-spacing:.3px;
}
a{color:inherit;text-decoration:none}
img{user-select:none}

/* ─────────────────────── BACKGROUND ─────────────────────── */
.bg-sunset{
  position:fixed;inset:0;z-index:-5;
  background:
    linear-gradient(180deg,
      #1a0436 0%,
      #4b0f5e 26%,
      #9a1e6e 46%,
      #ff5a3c 66%,
      #ffb24d 80%,
      #2a0d4f 100%);
}
.bg-sun{
  position:fixed;left:50%;top:46%;transform:translate(-50%,-50%);z-index:-4;
  width:min(70vw,640px);height:min(70vw,640px);border-radius:50%;
  background:radial-gradient(circle,#ffe070 0%,#ff7a3d 42%,rgba(255,90,60,0) 70%);
  filter:blur(2px);opacity:.85;
  -webkit-mask-image:repeating-linear-gradient(180deg,#000 0 16px,transparent 16px 22px);
          mask-image:repeating-linear-gradient(180deg,#000 0 16px,transparent 16px 22px);
}
.bg-grid{
  position:fixed;left:-10%;right:-10%;bottom:-2%;height:46vh;z-index:-3;
  background-image:
    linear-gradient(90deg,rgba(34,231,255,.5) 1px,transparent 1px),
    linear-gradient(0deg,rgba(34,231,255,.45) 1px,transparent 1px);
  background-size:6vw 6vw;
  transform:perspective(40vh) rotateX(70deg);
  transform-origin:bottom;
  -webkit-mask-image:linear-gradient(0deg,#000 30%,transparent 92%);
          mask-image:linear-gradient(0deg,#000 30%,transparent 92%);
  opacity:.6;
}
.bg-palms{
  position:fixed;inset:0;bottom:auto;height:100vh;z-index:-2;pointer-events:none;
  background:
    radial-gradient(60px 120px at 6% 70%, #06000f 60%, transparent 62%),
    radial-gradient(70px 140px at 92% 66%, #06000f 60%, transparent 62%);
  opacity:0;
}
.bg-scan{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 1px,transparent 1px 3px);
  opacity:.4;mix-blend-mode:multiply;
}

/* ─────────────── HOW IT WORKS — inline drop-down under the logo ─────────────── */
.how-section{display:flex;flex-direction:column;align-items:flex-start;margin-top:-6px}
.how-toggle{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  font-family:var(--display);font-style:italic;letter-spacing:2px;font-size:14px;
  color:var(--cyan-soft);background:var(--glass);border:1px solid var(--glass-line);
  padding:10px 18px;border-radius:999px;transition:box-shadow .2s, color .2s;
}
.how-toggle:hover{color:#fff;box-shadow:0 0 16px rgba(34,231,255,.4)}
.how-chev{
  width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);margin-top:-3px;transition:transform .3s ease, margin-top .3s ease;
}
.how-toggle[aria-expanded="true"] .how-chev{transform:rotate(-135deg);margin-top:2px}
/* accordion: grid-rows 0fr -> 1fr pushes the page content down (caseopening-style) */
.how-acc{display:grid;grid-template-rows:0fr;width:100%;transition:grid-template-rows .4s ease}
.how-acc.is-open{grid-template-rows:1fr}
.how-acc-inner{overflow:hidden;min-height:0}
.how-card{
  margin-top:12px;background:var(--glass);border:1px solid var(--glass-line);border-radius:18px;
  padding:clamp(16px,3vw,24px);
}
.how-block{margin-bottom:14px}
.how-block:last-of-type{margin-bottom:8px}
.how-block h3{
  font-family:var(--display);font-style:italic;font-size:17px;letter-spacing:1px;
  color:var(--cyan);margin-bottom:5px;text-shadow:0 0 12px rgba(34,231,255,.4);
}
.how-block p{font-size:14.5px;line-height:1.55;color:var(--text)}
.how-block b{color:var(--gold)}
.how-foot{margin-top:6px;font-size:12px;color:var(--muted);letter-spacing:.5px;text-align:center}

/* ─────────────── tiny mute-all button (bottom-right) ─────────────── */
.sound-toggle{
  position:fixed;right:14px;bottom:14px;z-index:60;
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--glass);border:1px solid var(--glass-line);
  color:var(--cyan-soft);font-size:16px;line-height:1;cursor:pointer;
  backdrop-filter:blur(6px);transition:transform .12s ease, box-shadow .2s ease;
}
.sound-toggle:hover{transform:scale(1.08);box-shadow:0 0 14px rgba(34,231,255,.45)}

/* ─────────────── GTA-style loading slideshow ─────────────── */
.collage{
  position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;
  opacity:1;transition:opacity 1s ease;
}
.collage.dim{opacity:.16}                 /* steps aside while the heist plays */
.collage-slides{position:absolute;inset:0}
.collage-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transform:scale(1.04);
  transition:opacity 1.4s ease, transform 11s linear;
  will-change:opacity,transform;
}
/* transition-based Ken Burns: gentler zoom (sharper) that never snaps when a
   slide deactivates — it just keeps easing while it fades out underneath. */
.collage-slide.active{opacity:.74;transform:scale(1.1) translate(-1.2%,-0.8%)}
.collage-scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(6,0,15,.5) 0%,rgba(6,0,15,.05) 30%,rgba(6,0,15,.2) 60%,rgba(6,0,15,.92) 100%),
    radial-gradient(120% 80% at 50% 0%,transparent 40%,rgba(6,0,15,.6) 100%);
}
.collage-caption{
  position:absolute;left:clamp(16px,4vw,46px);bottom:clamp(74px,12vh,120px);
  max-width:min(80vw,520px);
}
.collage-loc{
  font-family:var(--display);font-style:italic;font-size:clamp(26px,5vw,52px);
  line-height:.95;color:#fff;letter-spacing:1px;
  text-shadow:0 0 16px var(--pink),0 2px 10px rgba(0,0,0,.7);
}
.collage-tip{
  font-family:var(--body);font-weight:500;font-size:clamp(13px,2vw,16px);
  color:var(--cyan-soft);letter-spacing:1px;margin-top:6px;text-shadow:0 2px 8px rgba(0,0,0,.8);
}
.collage-loading{
  font-family:var(--body);font-weight:700;letter-spacing:3px;font-size:13px;
  color:var(--gold);margin-top:14px;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.8);
}
.collage-loading .dots i{animation:blink 1.4s infinite both;font-style:normal}
.collage-loading .dots i:nth-child(2){animation-delay:.2s}
.collage-loading .dots i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,100%{opacity:.2}50%{opacity:1}}

/* ─────────────── INTRO (parallax: cut-out subject over a moving Vice City bg) ─────────────── */
.intro{
  position:fixed;inset:0;z-index:100;
  background:#05000c;overflow:hidden;cursor:pointer;
  transition:opacity .7s ease, visibility .7s ease;
}
.intro.gone{opacity:0;visibility:hidden;pointer-events:none}
/* full artwork as the static background plate */
.intro-bg-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;display:block;
}
/* the SAME woman, cut out of that artwork, sits 1:1 on top of herself and only
   she grows a little -> the still image looks alive */
.intro-subject{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;display:block;
  transform-origin:50% 44%;
  filter:drop-shadow(0 10px 30px rgba(0,0,0,.45));
  /* grows from the very start, subtle 1.04 zoom */
  animation:introPop 3.4s cubic-bezier(.16,.7,.3,1) both;
}
@keyframes introPop{0%{transform:scale(1)}100%{transform:scale(1.04)}}

/* ─────────────────────── HEADER ─────────────────────── */
.top-bar{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px clamp(14px,4vw,40px);
  background:linear-gradient(180deg,rgba(6,0,15,.85),rgba(6,0,15,.2));
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--glass-line);
}
.brand-logo{
  height:clamp(40px,6vw,54px);width:auto;display:block;
  filter:drop-shadow(0 0 10px rgba(255,43,214,.45));
}
.top-right{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.chip{
  font-family:var(--body);font-weight:600;letter-spacing:1.5px;font-size:12.5px;
  padding:9px 14px;border-radius:999px;cursor:pointer;
  background:var(--glass);color:var(--cyan-soft);
  border:1px solid rgba(34,231,255,.35);
  transition:transform .12s ease, box-shadow .2s ease, color .2s;
}
.chip:hover{transform:translateY(-1px);box-shadow:0 0 16px rgba(34,231,255,.4)}
.chip-ca{color:var(--gold);border-color:rgba(255,210,63,.45)}
.chip-link{color:var(--pink-soft);border-color:rgba(255,43,214,.4)}
.btn-connect{
  font-family:var(--body);font-weight:700;letter-spacing:1px;font-size:12.5px;
  padding:9px 16px;border-radius:999px;cursor:pointer;color:#fff;border:0;
  background:linear-gradient(90deg,#9a55ff,#6a3df0);box-shadow:0 0 16px rgba(122,61,240,.5);
  transition:transform .12s ease, box-shadow .2s ease, filter .2s;
}
.btn-connect:hover{transform:translateY(-1px);box-shadow:0 0 24px rgba(122,61,240,.8)}
.btn-connect.connected{background:linear-gradient(90deg,#62ffa6,#22e7ff);color:#06000f}

/* ─────────────────────── LAYOUT ─────────────────────── */
.site{
  max-width:1040px;margin:0 auto;
  padding:clamp(20px,5vw,52px) clamp(16px,4vw,28px) 60px;
  display:flex;flex-direction:column;gap:clamp(22px,4vw,40px);
}

/* HERO / COUNTDOWN */
.hero{text-align:center}
.hero-kicker{
  font-family:var(--body);font-weight:700;letter-spacing:5px;font-size:14px;
  color:var(--cyan-soft);text-transform:uppercase;
}
.hero-kicker.live{color:var(--gold)}
.countdown{
  font-family:var(--display);font-size:clamp(64px,16vw,168px);line-height:.9;
  color:#fff;font-style:italic;margin:6px 0 14px;
  text-shadow:0 0 22px var(--pink),0 0 60px rgba(255,43,214,.55);
}
.countdown.live{
  color:var(--gold);text-shadow:0 0 22px var(--gold),0 0 70px rgba(255,210,63,.6);
  animation:livePulse 1s ease-in-out infinite;
}
.countdown.dead{color:#ff506e;text-shadow:0 0 22px #ff506e,0 0 70px rgba(255,80,110,.55)}
@keyframes livePulse{50%{opacity:.7}}
.hero-meta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.meta-pill{
  background:var(--glass);border:1px solid var(--glass-line);
  padding:8px 16px;border-radius:999px;font-size:13px;letter-spacing:1.5px;color:var(--muted);
}
.meta-pill b{color:#fff}

/* JOIN CARD */
.join-card{
  background:var(--glass);border:1px solid var(--glass-line);
  border-radius:22px;padding:clamp(20px,4vw,34px);
  box-shadow:0 0 0 1px rgba(34,231,255,.08),0 24px 60px rgba(0,0,0,.45);
  position:relative;overflow:hidden;
}
.join-card::before{
  content:"";position:absolute;inset:0;border-radius:22px;pointer-events:none;
  background:linear-gradient(120deg,rgba(255,43,214,.12),transparent 40%,rgba(34,231,255,.12));
}
.join-title{
  font-family:var(--display);font-style:italic;font-size:clamp(22px,4vw,34px);
  letter-spacing:1px;color:#fff;text-shadow:0 0 14px rgba(255,43,214,.6);
}
.join-sub{color:var(--muted);margin:6px 0 18px;font-size:15px}
.join-sub b{color:var(--gold)}
.join-row{display:flex;gap:12px;flex-wrap:wrap}
.wallet-input{
  flex:1;min-width:220px;
  font-family:var(--body);font-size:16px;letter-spacing:.5px;color:#fff;
  background:rgba(6,0,15,.7);border:1px solid rgba(34,231,255,.35);
  border-radius:14px;padding:15px 18px;outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.wallet-input::placeholder{color:#9a78ad}
.wallet-input:focus{border-color:var(--cyan);box-shadow:0 0 18px rgba(34,231,255,.35)}
.wallet-input[readonly]{cursor:default;color:var(--cyan-soft);font-size:14px}
.join-btn{
  font-family:var(--display);font-style:italic;font-size:20px;letter-spacing:2px;
  color:#06000f;cursor:pointer;border:0;padding:0 32px;border-radius:14px;
  background:linear-gradient(90deg,var(--gold),var(--pink));
  box-shadow:0 0 22px rgba(255,43,214,.55);
  transition:transform .15s ease, box-shadow .2s, filter .2s;
}
.join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 34px rgba(255,43,214,.8)}
.join-btn:disabled{filter:grayscale(.6) brightness(.7);cursor:not-allowed}
.join-status{margin-top:14px;font-size:14.5px;letter-spacing:.5px;color:var(--cyan-soft);min-height:20px}
.join-status.ok{color:#62ffa6}
.join-status.err{color:#ff708a}

/* ARENA — breaks out wider than the page so the heist picture is big */
.arena{width:min(98vw,1440px);margin-left:50%;transform:translateX(-50%)}
.arena-frame{
  position:relative;border-radius:22px;overflow:hidden;
  border:1px solid var(--glass-line);
  background:radial-gradient(120% 100% at 50% 0%,rgba(74,15,94,.6),rgba(6,0,15,.92));
  min-height:340px;display:flex;align-items:center;justify-content:center;
}
.arena-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 30%,rgba(34,231,255,.16),transparent 70%);
}
.arena-content{position:relative;z-index:1;width:100%;padding:14px;text-align:center}
.arena-placeholder{
  font-family:var(--display);font-style:italic;font-size:clamp(18px,3vw,26px);
  color:#fff;line-height:1.5;letter-spacing:1px;text-shadow:0 0 14px rgba(34,231,255,.5);
}
.arena-placeholder span{
  display:block;margin-top:8px;font-family:var(--body);font-style:normal;
  font-size:14px;color:var(--muted);letter-spacing:1px;
}

/* ─────────────────────── MONEY PRINTER (last-to-lock crash) ─────────────────────── */
.printer-game{width:100%;display:flex;flex-direction:column;align-items:center;gap:14px;padding:6px 0}
.pg-leader{
  font-family:var(--body);font-weight:600;letter-spacing:1.5px;font-size:14.5px;
  color:var(--cyan-soft);min-height:20px;text-align:center;
}
.pg-leader b{color:var(--gold)}
.printer-stage{
  position:relative;width:100%;max-width:480px;aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
}
.printer{
  position:relative;width:92%;height:92%;
  display:flex;align-items:center;justify-content:center;
  filter:drop-shadow(0 10px 26px rgba(0,0,0,.5));
}
.printer-img{width:100%;height:100%;object-fit:contain;display:block}
.printer .printer-emoji{display:none;font-size:clamp(80px,20vw,140px);line-height:1}
.printer.noimg .printer-img{display:none}
.printer.noimg .printer-emoji{display:block;filter:drop-shadow(0 0 18px rgba(34,231,255,.5))}
.printer.printing{animation:rumble .1s linear infinite}
@keyframes rumble{0%,100%{transform:translate(0,0)}25%{transform:translate(-1.5px,1px)}75%{transform:translate(1.5px,-1px)}}
.printer.dead{animation:none;filter:drop-shadow(0 6px 18px rgba(255,80,110,.5)) saturate(.65)}
/* multiplier shown on the printer's screen (position tuned to the art via --sx/--sy) */
.printer-screen{
  position:absolute;left:var(--sx,49.3%);top:var(--sy,66.6%);transform:translate(-50%,-50%);
  width:30%;text-align:center;pointer-events:none;overflow:hidden;
}
.printer.noimg .printer-screen{position:static;transform:none;width:auto;margin-top:10px}
/* dead printer art already shows "ERR 404" on its screen — hide our overlay */
.printer.dead .printer-screen{display:none}
#pg-mult{
  font-family:var(--display);font-style:italic;font-size:clamp(16px,4.4vw,34px);line-height:1;
  white-space:nowrap;color:var(--cyan);text-shadow:0 0 10px var(--cyan),0 0 22px rgba(34,231,255,.6);
}
.printer.dead #pg-mult{color:#ff506e;text-shadow:0 0 14px #ff506e,0 0 34px rgba(255,80,110,.6)}

/* cash spray out of the printer */
.money-spew{position:absolute;left:0;right:0;top:6%;bottom:0;pointer-events:none;z-index:2}
.bill{
  position:absolute;top:34%;width:clamp(28px,5.5vw,46px);aspect-ratio:306/274;
  background:url("assets/money.png") no-repeat;background-size:400% 100%;
  filter:drop-shadow(0 0 6px rgba(0,0,0,.5));
  will-change:transform,opacity;animation:fly 1.4s ease-out forwards;
}
@keyframes fly{
  0%{opacity:0;transform:translate(0,0) scale(.6) rotate(0)}
  15%{opacity:1}
  100%{opacity:0;transform:translate(calc(var(--x)*130px),-160px) scale(1.1) rotate(var(--r))}
}

.lock-btn{
  font-family:var(--display);font-style:italic;font-size:clamp(20px,4vw,30px);
  letter-spacing:2px;color:#06000f;cursor:pointer;border:0;
  padding:14px 46px;border-radius:14px;
  background:linear-gradient(90deg,var(--gold),#ff8a3d);
  box-shadow:0 0 26px rgba(255,210,63,.6);
  transition:transform .12s, box-shadow .2s, filter .2s;
}
.lock-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.02);box-shadow:0 0 40px rgba(255,210,63,.9)}
.lock-btn:disabled{filter:grayscale(.7) brightness(.55);cursor:not-allowed}
.lock-btn.locked{background:linear-gradient(90deg,#62ffa6,#22e7ff);filter:none}
.pg-msg{color:var(--muted);font-size:14.5px;letter-spacing:.5px;text-align:center;min-height:20px}
.winner-row .lost{color:#ff708a}

/* ─────────────────────── HEIST (thief + cash counter + BUSTED + leaderboard) ─────────────────────── */
.heist-game{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:14px;padding:4px 0}
.heist-row{display:flex;gap:14px;align-items:stretch;width:100%}
.heist-row .thief-stage{flex:1 1 auto;min-width:0}

/* live cash-out leaderboard */
.leaderboard{
  flex:0 0 clamp(150px,18%,224px);display:flex;flex-direction:column;
  background:var(--glass);border:1px solid var(--glass-line);border-radius:16px;
  padding:12px 12px 8px;overflow:hidden;
}
.lb-title{
  font-family:var(--display);font-style:italic;font-size:15px;letter-spacing:2px;
  color:var(--cyan-soft);text-align:center;margin-bottom:10px;text-transform:uppercase;
}
.lb-rows{display:flex;flex-direction:column;gap:6px;overflow-y:auto;flex:1}
.lb-empty{color:var(--muted);font-size:13px;text-align:center;margin-top:8px}
.lb-row{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  background:rgba(6,0,15,.55);border:1px solid rgba(34,231,255,.18);
  border-radius:9px;padding:7px 10px;font-size:13.5px;letter-spacing:.5px;
  animation:lbIn .18s ease both;
}
@keyframes lbIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.lb-tag{font-family:var(--body);font-weight:600;color:var(--muted);text-transform:uppercase}
.lb-amt{font-family:"Pricedown",var(--display);color:#5dec4e;font-size:16px;-webkit-text-stroke:1px #061a02}
.lb-row.mine{border-color:var(--cyan);box-shadow:0 0 12px rgba(34,231,255,.3)}
.lb-row.mine .lb-tag{color:var(--cyan-soft)}
.lb-row.winner{
  border-color:var(--gold);background:rgba(255,210,63,.14);
  box-shadow:0 0 18px rgba(255,210,63,.5);animation:winnerPulse 1s ease-in-out infinite;
}
.lb-row.winner .lb-tag{color:var(--gold)}
@keyframes winnerPulse{50%{box-shadow:0 0 26px rgba(255,210,63,.8)}}

/* jackpot box (left of the image) */
.jackpot-box{
  flex:0 0 clamp(132px,13.5%,178px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  background:var(--glass);border:1px solid var(--glass-line);border-radius:16px;padding:14px 12px;text-align:center;
}
.jp-label{font-family:var(--display);font-style:italic;letter-spacing:1.5px;font-size:13px;color:var(--gold);text-transform:uppercase;line-height:1.2}
.jp-amount{display:flex;align-items:center;gap:8px;font-family:"Pricedown",var(--display);font-size:clamp(30px,5vw,52px);line-height:1;color:#fff;text-shadow:0 0 16px rgba(34,231,255,.5)}
.sol-logo{width:clamp(22px,3.4vw,34px);height:auto;display:block;filter:drop-shadow(0 0 6px rgba(0,255,163,.4))}
/* Pricedown digits sit low in their box — nudge the logo down to match */
.jp-amount .sol-logo{transform:translateY(0.14em)}
.jp-sub{font-family:var(--body);font-size:11.5px;letter-spacing:.5px;color:var(--muted)}

/* jackpot spin reel (caseopening-style), shown over the stage during the spin */
.spin-overlay{
  position:absolute;inset:0;z-index:5;display:none;
  flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:rgba(6,0,15,.86);backdrop-filter:blur(2px);
}
.spin-overlay.on{display:flex}
.spin-title{font-family:var(--display);font-style:italic;letter-spacing:3px;font-size:clamp(16px,3vw,24px);color:var(--gold);text-shadow:0 0 16px rgba(255,210,63,.6)}
.reel-window{position:relative;width:min(86%,560px);height:clamp(90px,16vw,120px);overflow:hidden;border-radius:14px;border:1px solid var(--glass-line);background:rgba(0,0,0,.5)}
.reel-pointer{position:absolute;left:50%;top:0;bottom:0;width:3px;transform:translateX(-50%);background:var(--gold);box-shadow:0 0 14px var(--gold);z-index:2}
.reel-window::before,.reel-window::after{content:"";position:absolute;top:0;bottom:0;width:60px;z-index:1;pointer-events:none}
.reel-window::before{left:0;background:linear-gradient(90deg,rgba(0,0,0,.85),transparent)}
.reel-window::after{right:0;background:linear-gradient(270deg,rgba(0,0,0,.85),transparent)}
.reel-strip{display:flex;height:100%;will-change:transform}
.reel-item{
  flex:0 0 clamp(150px,26vw,190px);height:100%;margin-right:8px;border-radius:12px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  font-family:"Pricedown",var(--display);text-align:center;padding:6px;
}
.reel-item.jp{background:linear-gradient(160deg,rgba(0,255,163,.18),rgba(220,31,255,.18));border:1px solid rgba(0,255,163,.5);color:#fff;font-size:clamp(18px,3.4vw,26px)}
.reel-item.jp .sol-logo{width:30px}
.reel-item.no{background:rgba(20,6,36,.85);border:1px solid var(--glass-line);color:var(--muted);font-size:clamp(13px,2.4vw,17px);letter-spacing:1px}

.thief-stage{
  position:relative;width:100%;max-width:none;aspect-ratio:16/9;
  border-radius:16px;overflow:hidden;
  background:radial-gradient(120% 100% at 50% 0%,#2a0d4f,#06000f);
}
/* the two looting frames, cross-fading; edges fade out on each side */
.thief-imgs{
  position:absolute;inset:0;
  transition:filter 7s linear;        /* desaturates to B&W over 7s on bust */
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 11%,#000 89%,transparent 100%);
          mask-image:linear-gradient(to right,transparent 0,#000 11%,#000 89%,transparent 100%);
}
.thief-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;
  opacity:0;transition:opacity .6s ease;
}
.thief-img.show{opacity:1}
.thief-stage.busted .thief-imgs{filter:grayscale(1) brightness(.55) contrast(1.05)}

/* GTA money counter */
.cash-counter{
  position:absolute;top:7%;left:50%;transform:translateX(-50%);
  font-family:"Pricedown",var(--display);font-size:clamp(34px,8vw,78px);line-height:1;
  color:#5dec4e;-webkit-text-stroke:3px #061a02;
  text-shadow:0 4px 0 #0c2e06,0 0 20px rgba(93,236,78,.45);
  white-space:nowrap;z-index:3;pointer-events:none;letter-spacing:1px;
}
.cash-counter.busted{color:#9aa0a6;-webkit-text-stroke-color:#111}

/* GTA BUSTED overlay: dark band + desaturate + blue word */
.busted-overlay{
  position:absolute;inset:0;z-index:4;opacity:0;transition:opacity .5s ease;
  display:flex;align-items:center;justify-content:center;pointer-events:none;
}
.thief-stage.busted .busted-overlay{opacity:1}
.busted-overlay::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.28)}
/* full-width stripe, sized to the (unchanged) text — extends across the bigger picture */
.busted-band{
  position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
  height:clamp(100px,17vw,190px);background:rgba(0,0,0,.66);
  box-shadow:0 0 48px 24px rgba(0,0,0,.5);
}
.busted-stack{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px}
.busted-word{
  font-family:"Pricedown",var(--display);text-transform:lowercase;
  font-size:clamp(44px,11vw,104px);line-height:1;color:#2eb6ff;letter-spacing:2px;
  text-shadow:0 3px 16px rgba(0,0,0,.85);
  animation:bustedIn .5s ease both;
}
.busted-winner{
  font-family:var(--body);font-weight:700;letter-spacing:1.5px;
  font-size:clamp(13px,2.2vw,20px);color:var(--gold);text-shadow:0 2px 10px rgba(0,0,0,.9);
}
.busted-winner b{color:#fff}
@keyframes bustedIn{from{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}

@media (max-width:560px){.thief-stage{aspect-ratio:4/3}}
@media (max-width:760px){
  .heist-row{flex-direction:column}
  .leaderboard{flex:1 1 auto;max-height:200px}
  .jackpot-box{flex:1 1 auto;flex-direction:row;gap:14px}
}

/* WINNERS */
.winners-title{
  font-family:var(--display);font-style:italic;font-size:clamp(18px,3vw,26px);
  letter-spacing:1px;color:#fff;text-align:center;margin-bottom:14px;
  text-shadow:0 0 14px rgba(255,210,63,.5);
}
.winners-feed{display:flex;flex-direction:column;gap:8px}
.winners-empty{text-align:center;color:var(--muted);font-size:14px}
.winner-row{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:var(--glass);border:1px solid var(--glass-line);
  border-radius:12px;padding:12px 16px;font-size:14px;
}
.winner-row b{color:var(--gold)}

/* FOOTER */
.site-footer{
  text-align:center;color:var(--muted);font-size:12.5px;letter-spacing:1px;
  padding:26px 16px 40px;border-top:1px solid rgba(255,43,214,.15);
}
.site-footer .sep{margin:0 8px;color:var(--pink)}

@media (max-width:560px){
  .join-btn{flex:1;padding:14px 0}
}
