@import url('https://fonts.googleapis.com/css2?family=Boogaloo&family=Orbitron:wght@700&display=swap');

.smc-machine{display:flex;flex-direction:column;align-items:center;padding:20px;font-family:'Boogaloo',cursive;position:relative}
.smc-cabinet{position:relative;background:linear-gradient(160deg,#1a0a2e,#2d0a4a 50%,#1a0a2e);background-size:cover;background-position:center;border-radius:24px 24px 32px 32px;padding:24px 28px 28px;width:100%;max-width:560px;box-shadow:0 0 0 4px #7c3aed,0 0 0 7px #4c1d95,0 8px 40px rgba(124,58,237,.6),inset 0 2px 0 rgba(255,255,255,.08);text-align:center;box-sizing:border-box}
.smc-top-light{height:12px;border-radius:6px;background:linear-gradient(90deg,#ff0080,#ff6600,#ffcc00,#00ff88,#00ccff,#aa00ff,#ff0080);background-size:200% 100%;animation:smc-rainbow 2s linear infinite;margin-bottom:16px;box-shadow:0 0 12px rgba(255,255,255,.4)}
@keyframes smc-rainbow{0%{background-position:0 0}100%{background-position:200% 0}}
.smc-title{font-family:'Orbitron',monospace;color:#ffd700;font-size:1.9rem;letter-spacing:3px;margin:0 0 16px;text-shadow:0 0 16px rgba(255,215,0,.8)}
.smc-screen{position:relative;background:#0d0020;border-radius:12px;padding:12px 8px;border:3px solid #7c3aed;box-shadow:inset 0 0 30px rgba(124,58,237,.4);margin-bottom:14px;overflow:hidden}
.smc-win-line{position:absolute;top:50%;left:0;right:0;height:3px;transform:translateY(-50%);background:rgba(255,215,0,.5);pointer-events:none}
.smc-reels{display:flex;justify-content:center;align-items:center;gap:6px}
.smc-reel-wrap{flex:1 1 0;overflow:hidden;border-radius:8px;height:130px;min-height:130px;max-height:130px;background:rgba(255,255,255,.03);border:1px solid rgba(124,58,237,.3);display:flex;align-items:center;justify-content:center}
.smc-reel{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.smc-symbol{font-size:clamp(2rem,11vw,3.8rem);line-height:1;display:flex;align-items:center;justify-content:center;width:100%;max-width:112px;aspect-ratio:1;user-select:none}
.smc-symbol img{width:100%;height:100%;max-width:104px;max-height:104px;object-fit:contain;border-radius:8px}
.smc-symbol-init{color:rgba(255,255,255,.2);font-size:2rem}
.smc-sep{color:rgba(124,58,237,.5);font-size:1.7rem;line-height:130px;flex:0 0 auto}
.smc-reel-wrap.spinning .smc-symbol{animation:smc-spin .08s steps(1) infinite}
@keyframes smc-spin{0%{filter:blur(2px);transform:translateY(0)}33%{filter:blur(4px);transform:translateY(-8px)}66%{filter:blur(2px);transform:translateY(8px)}100%{filter:blur(0);transform:translateY(0)}}
.smc-reel-wrap.landing .smc-symbol{animation:smc-land .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes smc-land{0%{transform:translateY(-24px);opacity:0}60%{transform:translateY(6px);opacity:1}100%{transform:translateY(0);opacity:1}}
.smc-reel-wrap.jackpot-win{animation:smc-jp .5s ease-in-out infinite alternate}
@keyframes smc-jp{from{box-shadow:0 0 8px #ffd700;border-color:#ffd700}to{box-shadow:0 0 28px #ffd700,0 0 50px #ff6600;border-color:#ff6600}}
.smc-result{min-height:36px;font-size:1.7rem;font-weight:bold;color:#ffd700;text-shadow:0 0 12px rgba(255,215,0,.6);margin-bottom:16px;letter-spacing:1px}
.smc-controls{display:flex;align-items:center;justify-content:space-between;gap:12px}
.smc-credits-box{flex:1;background:rgba(0,0,0,.4);border:1px solid rgba(124,58,237,.5);border-radius:10px;padding:8px 10px}
.smc-credits-label{display:block;font-family:'Orbitron',monospace;font-size:.55rem;letter-spacing:2px;color:rgba(255,215,0,.6);margin-bottom:4px}
.smc-credits-value{display:block;font-family:'Orbitron',monospace;font-size:1.5rem;color:#ffd700;text-shadow:0 0 8px rgba(255,215,0,.5)}
.smc-spin-btn{flex:0 0 auto;background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;border:none;border-radius:50%;width:110px;height:110px;font-family:'Orbitron',monospace;font-size:.6rem;letter-spacing:1.5px;cursor:pointer;box-shadow:0 4px 0 #4c1d95,0 6px 20px rgba(124,58,237,.5);transition:transform .1s,box-shadow .1s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0}
.smc-spin-btn.smc-spin-img{background:none;box-shadow:none;width:120px;height:120px;border-radius:50%;overflow:hidden}
.smc-spin-img img{width:100%;height:100%;object-fit:contain}
.smc-spin-btn:hover:not(:disabled){filter:brightness(1.1)}
.smc-spin-btn:active:not(:disabled){transform:translateY(4px)}
.smc-spin-btn:disabled{opacity:.5;cursor:not-allowed}
.smc-lever-icon{font-size:1.4rem}
.smc-login-note{margin-top:14px;color:#7c3aed;font-family:sans-serif;font-size:13px;text-align:center}
#smc-confetti{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:99999}

/* overlays */
.smc-overlay{position:fixed;inset:0;background:rgba(10,0,30,.82);display:flex;align-items:center;justify-content:center;z-index:100000;font-family:sans-serif;padding:20px}
.smc-overlay-box,.smc-celebrate-box{background:linear-gradient(160deg,#241040,#160a2e);border:2px solid #7c3aed;border-radius:18px;padding:28px 26px;max-width:380px;width:100%;text-align:center;color:#fff;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.smc-overlay-box h3{margin:0 0 8px;font-size:1.3rem;color:#ffd700}
.smc-overlay-box p{margin:0 0 16px;color:#cbb8e8;font-size:14px;line-height:1.5}
.smc-refill-timer{background:rgba(0,0,0,.3);border-radius:10px;padding:12px;margin-bottom:14px;color:#ffd700;font-weight:700;font-size:15px}
.smc-buy-btn{display:block;background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;text-decoration:none;padding:13px;border-radius:10px;font-weight:700;font-size:15px;margin-bottom:10px}
.smc-buy-btn:hover{filter:brightness(1.1)}
.smc-overlay-close{background:none;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.6);border-radius:8px;padding:8px 18px;cursor:pointer;font-size:13px}
.smc-overlay-close:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.smc-collection-btn{display:inline-flex;align-items:center;margin:0;background:rgba(255,215,0,.12);border:1px solid rgba(255,215,0,.5);color:#ffd700;border-radius:999px;padding:7px 18px;font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.02em}
.smc-collection-btn:hover{background:rgba(255,215,0,.2)}
.smc-collection-btn.smc-collection-done{background:rgba(29,158,117,.2);border-color:#1d9e75;color:#7fe9c4}
.smc-collection-count{opacity:.85;font-weight:600;margin-left:4px}
.smc-coll-msg{grid-column:1/-1;text-align:center;color:#cbb8e8;font-size:14px;padding:24px 0}
.smc-heists-btn{margin:0}
.smc-pills-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;margin-top:14px}
.smc-heists-list{max-height:52vh;overflow:auto;margin-bottom:4px}
.smc-heists-empty{text-align:center;color:#cbb8e8;font-size:14px;padding:24px 8px}
.smc-heists-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px}
.smc-heists-row + .smc-heists-row{margin-top:4px}
.smc-heists-row:nth-child(odd){background:rgba(255,255,255,.05)}
.smc-heists-mine{background:rgba(255,215,0,.16);outline:1px solid rgba(255,215,0,.5)}
.smc-heists-rank{min-width:34px;text-align:center;font-weight:800;font-size:15px;color:#ffd700}
.smc-heists-av{width:30px;height:30px;border-radius:50%;object-fit:cover;flex:0 0 auto}
.smc-heists-av-ph{display:inline-flex;align-items:center;justify-content:center;background:#5a4ad1;color:#fff;font-weight:700;font-size:13px}
.smc-heists-name{flex:1;color:#fff;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.smc-heists-name em{color:#ffd700;font-style:normal;font-size:12px}
.smc-heists-cr{font-weight:800;color:#7fe9c4;font-size:14px}
.smc-heists-you{margin-top:10px;padding-top:12px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:#cbb8e8;text-align:center}
.smc-heists-you strong{color:#ffd700}
.smc-collection-box{max-width:480px}
.smc-collection-progresswrap{height:9px;background:rgba(255,255,255,.12);border-radius:999px;overflow:hidden;margin:10px 0 6px}
.smc-collection-bar{height:100%;width:0;background:linear-gradient(90deg,#f59e0b,#ffd700);border-radius:999px;transition:width .5s ease}
.smc-collection-count-line{font-size:13px;color:#cbb8e8}
.smc-collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:8px;max-height:46vh;overflow:auto;padding:2px;margin-bottom:4px}
.smc-coll-tile{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 6px 8px;text-align:center}
.smc-coll-tile.got{background:rgba(29,158,117,.16);border-color:rgba(29,158,117,.5)}
.smc-coll-tile.locked{opacity:.6}
.smc-coll-media{height:42px;display:flex;align-items:center;justify-content:center;margin-bottom:5px}
.smc-coll-media img{max-width:42px;max-height:42px;border-radius:8px}
.smc-coll-emoji{font-size:30px}
.smc-coll-combo{display:flex;gap:2px;align-items:center;justify-content:center}
.smc-coll-combo img{max-width:22px;max-height:22px;border-radius:4px}
.smc-coll-combo span{font-size:18px}
.smc-coll-tile.locked .smc-coll-media{filter:grayscale(1) brightness(.7)}
.smc-coll-label{font-size:11px;color:#cbb8e8;line-height:1.2}
.smc-coll-check{position:absolute;top:4px;right:5px;font-size:12px;color:#7fe9c4;font-weight:900}
.smc-coll-lock{position:absolute;top:4px;right:5px;font-size:11px;opacity:.7}
.smc-collection-reward{display:flex;align-items:center;gap:10px;margin-top:6px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);text-align:left}
.smc-coll-reward-badge img{width:40px;height:40px;border-radius:50%;object-fit:cover}
.smc-coll-reward-ph{font-size:32px}
.smc-coll-reward-text{font-size:13px;color:#cbb8e8}
.smc-coll-reward-text strong{color:#ffd700}
.smc-mastered-burst{font-size:64px;animation:smc-td-startpulse 1s ease-in-out infinite}
.smc-mastered-sub{color:#cbb8e8;font-size:14px;margin:6px 0 14px}
.smc-mastered-sub strong{color:#fff}
.smc-mastered-badge img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid #ffd700}
.smc-mastered-badge-name{font-size:14px;color:#ffd700;font-weight:700;margin:8px 0 16px}

/* celebration */
.smc-celebrate-box{max-width:440px;border-color:#ffd700;box-shadow:0 0 40px rgba(255,215,0,.4),0 20px 60px rgba(0,0,0,.5)}
.smc-celebrate-headline{font-family:'Boogaloo',cursive;font-size:1.8rem;color:#ffd700;text-shadow:0 0 16px rgba(255,215,0,.7);margin-bottom:16px;line-height:1.1}
.smc-celebrate-media{margin-bottom:18px}
.smc-celebrate-img,.smc-celebrate-video{max-width:100%;border-radius:12px;max-height:280px}
.smc-celebrate-fallback{font-size:64px}
.smc-celebrate-loading{font-size:40px;padding:28px 0;opacity:.65;animation:smc-celebloadpulse 1s ease-in-out infinite}
@keyframes smc-celebloadpulse{0%,100%{opacity:.35}50%{opacity:.8}}
.smc-btn-hold{opacity:.45;pointer-events:none;cursor:default}
.smc-claim-btn{background:linear-gradient(135deg,#ffd700,#ff9500);color:#3a1d00;border:none;border-radius:12px;padding:14px 28px;font-size:16px;font-weight:800;cursor:pointer;box-shadow:0 4px 16px rgba(255,180,0,.4)}
.smc-claim-btn:hover{filter:brightness(1.05)}
.smc-claim-form{margin-top:18px;text-align:left}
.smc-claim-label{display:block;font-size:12px;font-weight:700;color:#cbb8e8;margin:10px 0 4px;text-transform:uppercase;letter-spacing:.5px}
.smc-claim-input{width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:rgba(255,255,255,.06);color:#fff;font-size:14px;box-sizing:border-box}
textarea.smc-claim-input{resize:vertical}
.smc-claim-submit{margin-top:16px;width:100%;background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:700;cursor:pointer}
.smc-claim-status{margin-top:10px;color:#ff8080;font-size:13px;min-height:18px}
.smc-claim-done p{color:#cbb8e8;margin:10px 0 16px}

/* payout chart */
.smc-chart{margin:24px auto;max-width:560px;font-family:-apple-system,BlinkMacSystemFont,sans-serif}
.smc-chart-title{font-size:1.15rem;color:#333;font-weight:700}
h3.smc-chart-title{margin-bottom:12px;display:flex;align-items:center;gap:6px}
/* collapsible toggle button */
.smc-chart-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;cursor:pointer;padding:0 0 12px;margin:0;text-align:left;font-family:inherit}
.smc-chart-toggle .smc-chart-title{margin:0}
.smc-chart-arrow{color:#7c3aed;font-size:18px;transition:transform .25s ease;flex-shrink:0;margin-left:10px}
.smc-chart.smc-open .smc-chart-arrow{transform:rotate(180deg)}
/* collapse animation: body hidden unless .smc-open */
.smc-collapsible .smc-chart-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease;overflow:hidden}
.smc-collapsible.smc-open .smc-chart-body{grid-template-rows:1fr}
.smc-collapsible .smc-chart-body>#smc-chart-inner{min-height:0;overflow:hidden}
.smc-chart-scroll{border-radius:12px;border:1px solid rgba(124,58,237,.18);box-shadow:0 2px 12px rgba(124,58,237,.08);overflow:hidden}
.smc-chart-table{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}
.smc-chart-table th{background:#1a0a2e;color:#ffd700;padding:12px 10px;text-align:left;font-size:12px;letter-spacing:.3px}
.smc-chart-table td{padding:10px;border-bottom:1px solid #f0ecfa;vertical-align:middle;background:#fff}
.smc-chart-table tr:last-child td{border-bottom:none}
.smc-row-prize td{background:#fffaf0}
.smc-col-sym{width:auto}
.smc-chart-table th:not(.smc-col-sym):not(.smc-col-prize),
.smc-chart-table td.smc-pay{width:84px;text-align:left}
.smc-col-prize{width:110px}
.smc-chart-sym{display:flex;align-items:center;gap:10px;min-width:0}
.smc-chart-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid #eee}
.smc-chart-emoji{font-size:34px;line-height:1;flex-shrink:0;width:44px;text-align:center}
.smc-chart-name{font-weight:600;font-size:14px;white-space:normal;word-break:break-word;line-height:1.2;min-width:0}
.smc-pay{font-weight:600}
.smc-pay-big{color:#b45309;font-size:15px}
.smc-prize-cell{font-weight:600;color:#7c3aed;word-break:break-word;line-height:1.2}

/* leaderboard */
.smc-leaderboard{max-width:380px;margin:24px auto;font-family:-apple-system,sans-serif}
.smc-lb-title{font-size:1.1rem;margin-bottom:12px;color:#333}
.smc-lb-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:#faf8ff;margin-bottom:6px}
.smc-lb-rank{font-weight:800;color:#7c3aed;width:22px;text-align:center}
.smc-lb-av{width:32px;height:32px;border-radius:50%;object-fit:cover}
.smc-lb-av-ph{display:flex;align-items:center;justify-content:center;background:#7c3aed;color:#fff;font-weight:700}
.smc-lb-name{flex:1;font-weight:600;font-size:14px}
.smc-lb-val{font-size:13px;color:#888;font-weight:600}
.smc-lb-loading,.smc-lb-empty{color:#aaa;font-size:13px}

@media(max-width:460px){
  .smc-machine{padding:10px}
  .smc-cabinet{padding:16px 10px 20px}
  .smc-reels{gap:4px}
  .smc-reel-wrap{height:auto;min-height:0;max-height:none;aspect-ratio:1}
  .smc-spin-btn{width:72px;height:72px}
  .smc-chart-thumb,.smc-chart-emoji{width:38px;height:38px;font-size:28px}
  .smc-chart-table th:not(.smc-col-sym):not(.smc-col-prize),
  .smc-chart-table td.smc-pay{width:64px}
  .smc-col-prize{width:80px}
  .smc-chart-table{font-size:13px}
}

/* badge reward in celebration overlay */
.smc-badge-reward{display:flex;align-items:center;gap:14px;justify-content:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,215,0,.3);border-radius:14px;padding:14px 18px;margin-bottom:16px}
.smc-badge-img{width:72px;height:72px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 0 20px rgba(255,215,0,.5)}
.smc-badge-ph{display:flex;align-items:center;justify-content:center;font-size:34px}
.smc-badge-text{text-align:left}
.smc-badge-won{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:#ffd700;font-weight:700}
.smc-badge-name{font-size:1.2rem;font-weight:800;color:#fff;line-height:1.1}

/* ── Size variants (default base = large 560px) ── */
.smc-size-medium .smc-cabinet{max-width:460px}
.smc-size-medium .smc-reel-wrap{height:108px;min-height:108px;max-height:108px}
.smc-size-medium .smc-symbol{width:100%;max-width:92px;aspect-ratio:1;font-size:clamp(1.8rem,10vw,3.1rem)}
.smc-size-medium .smc-symbol img{width:100%;height:100%;max-width:86px;max-height:86px}
.smc-size-medium .smc-sep{line-height:108px}
.smc-size-medium .smc-title{font-size:1.6rem}
.smc-size-medium .smc-spin-btn{width:96px;height:96px}

.smc-size-small .smc-cabinet{max-width:380px}
.smc-size-small .smc-reel-wrap{height:90px;min-height:90px;max-height:90px}
.smc-size-small .smc-symbol{width:100%;max-width:74px;aspect-ratio:1;font-size:clamp(1.6rem,9vw,2.6rem)}
.smc-size-small .smc-symbol img{width:100%;height:100%;max-width:68px;max-height:68px}
.smc-size-small .smc-sep{line-height:90px}
.smc-size-small .smc-title{font-size:1.3rem}
.smc-size-small .smc-spin-btn{width:84px;height:84px}

/* wild + combos in payout chart */
.smc-wild-tag{display:inline-block;background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;font-size:9px;font-weight:800;letter-spacing:.06em;padding:2px 6px;border-radius:6px;vertical-align:middle;margin-left:4px}
.smc-chart-extras{padding:12px 4px 0;border-top:1px solid rgba(255,255,255,.12);margin-top:8px}
.smc-chart-subhead{font-weight:800;font-size:14px;margin:6px 0 8px;color:inherit}
.smc-combo-chart-row{display:flex;align-items:center;gap:10px;padding:6px 0}
.smc-combo-chart-seq{display:inline-flex;gap:3px;align-items:center}
.smc-combo-chart-seq .smc-chart-thumb-sm{width:26px;height:26px;border-radius:5px;object-fit:cover}
.smc-combo-chart-seq .smc-chart-emoji{font-size:22px}
.smc-combo-chart-name{flex:1;font-weight:600}
.smc-combo-chart-pay{font-weight:800}
.smc-chart-note{font-size:12px;opacity:.8;margin-top:8px;line-height:1.4}
.smc-wild-note{display:flex;align-items:flex-start;gap:6px;flex-wrap:wrap}

/* play disclaimer */
.smc-machine{position:relative}
.smc-machine.smc-locked{pointer-events:none}
.smc-machine.smc-locked .smc-disc-overlay{pointer-events:auto}
.smc-disc-overlay{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(10,8,20,.82);backdrop-filter:blur(3px);border-radius:inherit}
.smc-disc-box{background:#fff;color:#1a1226;border-radius:16px;max-width:380px;width:100%;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.5);text-align:center}
.smc-disc-title{margin:0 0 12px;font-size:1.3rem;font-weight:800;color:#1a1226}
.smc-disc-msg{font-size:14px;line-height:1.55;color:#444;margin-bottom:18px;white-space:pre-wrap;max-height:40vh;overflow:auto}
.smc-disc-agree{background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;padding:13px 22px;cursor:pointer;width:100%;box-shadow:0 6px 18px rgba(124,58,237,.4);transition:filter .15s}
.smc-disc-agree:hover{filter:brightness(1.08)}

/* ── Multi-machine tabs ── */
.smc-machine-tabs{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:12px}
.smc-mtab-btn{font-family:inherit;font-weight:800;font-size:13px;letter-spacing:.02em;padding:9px 16px;border-radius:12px 12px 0 0;border:none;cursor:pointer;background:rgba(124,58,237,.18);color:#cbb5f5;transition:background .15s,color .15s,transform .12s}
.smc-mtab-btn:hover{background:rgba(124,58,237,.32);color:#fff;transform:translateY(-1px)}
.smc-mtab-on{background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;box-shadow:0 -2px 12px rgba(124,58,237,.5)}
.smc-mtab-locked{opacity:.6;background:rgba(255,255,255,.08);color:#9a9aa6}
.smc-mtab-locked:hover{background:rgba(255,255,255,.12);color:#bbb;transform:none}

/* ── Unlock fanfare overlay ── */
.smc-unlock-overlay{position:absolute;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(10,8,20,.85);backdrop-filter:blur(4px);border-radius:inherit;opacity:0;transition:opacity .25s}
.smc-unlock-overlay.smc-unlock-show{opacity:1}
.smc-unlock-box{background:linear-gradient(160deg,#241636,#160e22);border:2px solid #a855f7;border-radius:18px;padding:28px 24px;text-align:center;max-width:340px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 40px rgba(168,85,247,.4);transform:scale(.92);transition:transform .25s}
.smc-unlock-show .smc-unlock-box{transform:scale(1)}
.smc-unlock-key{font-size:48px;animation:smc-key-pop .6s ease}
@keyframes smc-key-pop{0%{transform:scale(0) rotate(-30deg)}60%{transform:scale(1.3) rotate(10deg)}100%{transform:scale(1) rotate(0)}}
.smc-unlock-title{font-size:1.4rem;font-weight:800;color:#ffd700;margin:8px 0 6px;letter-spacing:.03em}
.smc-unlock-msg{font-size:14px;color:#e8e0f5;line-height:1.5;margin-bottom:18px}
.smc-unlock-go{display:block;width:100%;background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;padding:13px;cursor:pointer;margin-bottom:8px;box-shadow:0 6px 18px rgba(124,58,237,.4)}
.smc-unlock-go:hover{filter:brightness(1.1)}
.smc-unlock-close{background:none;border:none;color:#9a9aa6;font-size:13px;cursor:pointer;padding:4px}
.smc-unlock-close:hover{color:#fff}

/* ── Bonus Wheel ── */
.smc-wheel-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:14px;background:linear-gradient(160deg,#3b2a6d,#5b3aa8 55%,#3b2a6d);backdrop-filter:blur(4px);opacity:0;transition:opacity .25s;overflow:auto}
.smc-wheel-overlay.smc-wheel-show{opacity:1}
.smc-wheel-box{text-align:center;max-width:340px;width:100%}
.smc-wheel-headline{font-size:1.4rem;font-weight:900;color:#ffd700;margin-bottom:14px;letter-spacing:.03em;text-shadow:0 2px 8px rgba(0,0,0,.5);animation:smc-wheel-pulse 1s ease-in-out infinite}
@keyframes smc-wheel-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.smc-wheel-stage{position:relative;display:inline-block;margin:0 auto;padding-top:18px}
.smc-wheel-pointer{position:absolute;top:4px;left:50%;transform:translateX(-50%);z-index:5;width:0;height:0;border-left:15px solid transparent;border-right:15px solid transparent;border-top:30px solid #ffd700;filter:drop-shadow(0 3px 4px rgba(0,0,0,.6))}
.smc-wheel-disc-wrap{position:relative;width:280px;height:280px;border-radius:50%;margin:0 auto}
.smc-wheel-disc{position:absolute;inset:0;border-radius:50%;transform:rotate(0deg);will-change:transform}
/* Radial labels: each label is a vertical strip from the wheel center to the top edge,
   rotated to its wedge-center angle. The text sits near the outer end and is rotated
   90° so it reads outward along the slice. */
.smc-wheel-label{position:absolute;left:50%;top:0;width:0;height:50%;transform-origin:bottom center;pointer-events:none}
.smc-wheel-label>span{position:absolute;top:24px;left:0;transform:translateX(-50%) rotate(90deg);display:block;color:#fff;font-weight:800;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.8);white-space:nowrap;letter-spacing:.02em}
.smc-wheel-hub{position:absolute;top:50%;left:50%;width:78px;height:78px;margin:-39px 0 0 -39px;border-radius:50%;background:#1a1226;border:4px solid #7c3aed;display:flex;align-items:center;justify-content:center;z-index:3;overflow:hidden;cursor:pointer;padding:0;transition:transform .15s,box-shadow .15s;box-shadow:0 0 0 0 rgba(255,215,0,0)}
.smc-wheel-hub:not(:disabled):hover{transform:scale(1.07);box-shadow:0 0 0 4px rgba(255,215,0,.5)}
.smc-wheel-hub:not(:disabled){animation:smc-hub-invite 1.1s ease-in-out infinite}
@keyframes smc-hub-invite{0%,100%{box-shadow:0 0 0 0 rgba(255,215,0,.5)}50%{box-shadow:0 0 0 7px rgba(255,215,0,0)}}
.smc-wheel-hub-spun{animation:none!important}
.smc-wheel-hub img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.smc-wheel-hub span{color:#fff;font-weight:900;font-size:14px;text-align:center;line-height:1.1;padding:4px}
.smc-wheel-prompt{margin-top:14px;color:#ffd700;font-weight:800;font-size:15px;animation:smc-wheel-pulse 1.1s ease-in-out infinite}
.smc-wheel-disc-wrap.smc-wheel-landed{animation:smc-wheel-bounce .5s ease}
@keyframes smc-wheel-bounce{0%{transform:scale(1)}40%{transform:scale(1.05)}100%{transform:scale(1)}}
.smc-wheel-result{min-height:24px;margin-top:16px;font-size:1.05rem;color:#fff;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.smc-wheel-result-show{opacity:1;transform:translateY(0)}
.smc-wheel-video{display:block;width:100%;max-width:260px;margin:0 auto 14px;border-radius:14px;box-shadow:0 8px 28px rgba(0,0,0,.45);background:#000}
.smc-wheel-badge{animation:smc-badge-pop .5s cubic-bezier(.2,1.3,.4,1)}
.smc-wheel-badge-sub{font-size:.8rem;color:#ffe9a8;margin-top:2px}
.smc-wheel-winlines{font-size:1.05rem;color:#fff;line-height:1.5}
@keyframes smc-badge-pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.smc-wheel-result strong{color:#ffd700}
.smc-wheel-close{margin-top:14px;background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;padding:12px 28px;cursor:pointer;box-shadow:0 6px 18px rgba(124,58,237,.4)}
.smc-wheel-close:hover{filter:brightness(1.1)}

/* bonus trigger note in payout chart */
.smc-bonus-tag{display:inline-block;background:linear-gradient(135deg,#ffd700,#f59e0b);color:#1a1226;font-size:9px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;vertical-align:middle;margin-left:4px;white-space:nowrap}
.smc-bonus-note{display:flex;align-items:flex-start;gap:8px;flex-wrap:wrap}
.smc-bonus-note .smc-chart-thumb-sm{width:22px;height:22px;border-radius:5px;object-fit:cover;vertical-align:middle;margin:0 2px}
.smc-bonus-note .smc-chart-emoji{font-size:18px;vertical-align:middle;margin:0 2px}

/* credit packs in out-of-credits popup */
.smc-packs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin:14px 0;width:100%}
.smc-pack-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;background:linear-gradient(160deg,#2a1f42,#1a1226);border:2px solid rgba(124,58,237,.5);border-radius:14px;padding:16px 12px 14px;text-decoration:none;color:#fff;transition:transform .12s,border-color .12s,box-shadow .12s}
.smc-pack-card:hover{transform:translateY(-3px);border-color:#a855f7;box-shadow:0 8px 24px rgba(124,58,237,.4)}
.smc-pack-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#ffd700,#f59e0b);color:#1a1226;font-size:10px;font-weight:800;letter-spacing:.04em;padding:3px 10px;border-radius:10px;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.smc-pack-name{font-size:12px;font-weight:700;color:#cbb5f5;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.smc-pack-credits{font-size:18px;font-weight:900;color:#ffd700}
.smc-pack-price{display:flex;flex-direction:column;align-items:center;gap:1px;margin-top:2px}
.smc-pack-compare{font-size:12px;color:#9a8bc0;text-decoration:line-through}
.smc-pack-now{font-size:15px;font-weight:800;color:#fff}

/* ── Top Dollar bonus ── */
.smc-td-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:14px;background:linear-gradient(160deg,#3b2a6d,#5b3aa8 55%,#3b2a6d);backdrop-filter:blur(4px);opacity:0;transition:opacity .25s;overflow:auto}
.smc-td-overlay.smc-td-show{opacity:1}
.smc-td-box{text-align:center;max-width:380px;width:100%}
.smc-td-headline{font-size:1.6rem;font-weight:900;color:#ffd700;margin-bottom:10px;letter-spacing:.03em;text-shadow:0 2px 10px rgba(255,215,0,.4);animation:smc-wheel-pulse 1s ease-in-out infinite}
.smc-td-logo img{max-width:90px;max-height:90px;margin:0 auto 8px;display:block;border-radius:12px}
.smc-td-offerwrap{background:linear-gradient(160deg,#241a3e,#140d24);border:2px solid #ffd700;border-radius:18px;padding:22px 18px;margin:6px 0 16px;box-shadow:0 8px 30px rgba(0,0,0,.5),inset 0 0 30px rgba(255,215,0,.08)}
.smc-td-offerlabel{font-size:12px;font-weight:700;color:#cbb5f5;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.smc-td-amount{font-size:2.6rem;font-weight:900;color:#fff;line-height:1.1;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.smc-td-amount-unit{display:block;font-size:1rem;font-weight:800;color:#ffd700;letter-spacing:.04em;margin-top:2px;text-shadow:none}
.smc-td-amount.smc-td-pop{animation:smc-td-pop .4s cubic-bezier(.2,1.3,.5,1)}
@keyframes smc-td-pop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
.smc-td-mult{margin-top:8px;font-size:1.1rem;color:#ffd700;font-weight:700}
.smc-td-mult strong{color:#fff}
.smc-td-buttons{display:flex;gap:12px;justify-content:center;margin-bottom:12px}
.smc-td-take,.smc-td-try{flex:1;max-width:160px;border:none;border-radius:14px;font-size:15px;font-weight:800;padding:16px 10px;cursor:pointer;font-family:inherit;letter-spacing:.02em;transition:transform .12s,filter .12s}
.smc-td-take{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;box-shadow:0 6px 18px rgba(34,197,94,.4)}
.smc-td-try{background:linear-gradient(135deg,#7c3aed,#db2777);color:#fff;box-shadow:0 6px 18px rgba(124,58,237,.4)}
.smc-td-take:not(:disabled):hover,.smc-td-try:not(:disabled):hover{transform:translateY(-2px);filter:brightness(1.1)}
.smc-td-take:disabled,.smc-td-try:disabled{opacity:.55;cursor:default}
.smc-td-try-disabled{background:linear-gradient(135deg,#555,#777)!important}
.smc-td-history{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:8px;min-height:0}
.smc-td-rejected{font-size:12px;color:#9a8bc0;background:rgba(255,255,255,.06);border-radius:8px;padding:2px 8px;text-decoration:line-through}
.smc-td-result{min-height:24px;font-size:1.15rem;color:#fff;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.smc-td-result-show{opacity:1;transform:translateY(0)}
.smc-td-result strong{color:#ffd700}
.smc-td-collect{margin-top:14px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;padding:12px 32px;cursor:pointer;box-shadow:0 6px 18px rgba(34,197,94,.4)}
.smc-td-collect:hover{filter:brightness(1.1)}
.smc-td-tag{display:inline-block;background:linear-gradient(135deg,#16a34a,#facc15);color:#1a1226;font-size:9px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;vertical-align:middle;margin-left:4px;white-space:nowrap}

/* Top Dollar intro screen */
.smc-td-intro{padding:8px 0 4px;animation:smc-td-fadein .35s ease}
.smc-td-intro.smc-td-intro-out{opacity:0;transform:translateY(-8px);transition:opacity .25s,transform .25s}
.smc-td-introtext{color:#cbb5f5;font-size:14px;line-height:1.5;margin:4px 0 18px;padding:0 6px}
.smc-td-start{background:linear-gradient(135deg,#ffd700,#f59e0b);color:#1a1226;border:none;border-radius:14px;font-size:17px;font-weight:900;letter-spacing:.04em;padding:16px 36px;cursor:pointer;box-shadow:0 8px 24px rgba(255,215,0,.4);animation:smc-td-startpulse 1.1s ease-in-out infinite}
.smc-td-start:hover{filter:brightness(1.08);transform:translateY(-2px)}
@keyframes smc-td-startpulse{0%,100%{box-shadow:0 8px 24px rgba(255,215,0,.4),0 0 0 0 rgba(255,215,0,.5)}50%{box-shadow:0 8px 24px rgba(255,215,0,.4),0 0 0 12px rgba(255,215,0,0)}}
@keyframes smc-td-fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.smc-td-play{opacity:0;transform:scale(.96)}
.smc-td-play.smc-td-play-in{opacity:1;transform:scale(1);transition:opacity .35s,transform .35s}

/* ── Mystery Box bonus ── */
.smc-mb-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:14px;background:linear-gradient(160deg,#3b2a6d,#5b3aa8 55%,#3b2a6d);backdrop-filter:blur(4px);opacity:0;transition:opacity .25s;overflow:auto}
.smc-mb-overlay.smc-mb-show{opacity:1}
.smc-mb-box-wrap{text-align:center;max-width:420px;width:100%}
.smc-mb-headline{font-size:1.5rem;font-weight:900;color:#ffd700;margin-bottom:6px;letter-spacing:.03em;text-shadow:0 2px 10px rgba(255,215,0,.4);animation:smc-wheel-pulse 1s ease-in-out infinite}
.smc-mb-total{font-size:1.1rem;color:#fff;margin-bottom:8px;display:inline-block;padding:4px 14px;border-radius:12px;background:rgba(255,215,0,.12)}
.smc-mb-total strong{color:#ffd700;font-size:1.25rem}
.smc-mb-total.smc-mb-pop{animation:smc-td-pop .4s cubic-bezier(.2,1.3,.5,1)}
.smc-mb-intro{color:#cbb5f5;font-size:13px;margin:4px 0 12px;padding:0 8px;line-height:1.4}
.smc-mb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:8px 0 14px}
.smc-mb-box{aspect-ratio:1;border:none;background:linear-gradient(160deg,#2a1f42,#160d24);border:2px solid rgba(124,58,237,.5);border-radius:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:transform .12s,border-color .12s,box-shadow .12s;padding:8px}
.smc-mb-box:not(.smc-mb-opened):not(.smc-mb-dim):hover{transform:translateY(-3px) scale(1.03);border-color:#ffd700;box-shadow:0 8px 24px rgba(124,58,237,.45)}
.smc-mb-box-face{font-size:2.4rem;display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.smc-mb-box-face img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}
.smc-mb-box.smc-mb-opened{cursor:default;background:linear-gradient(160deg,#1a3a2a,#0d2418);border-color:#22c55e;animation:smc-td-pop .35s ease}
.smc-mb-box.smc-mb-stop{background:linear-gradient(160deg,#3a1a1a,#240d0d);border-color:#ef4444}
.smc-mb-box.smc-mb-dim{opacity:.4;cursor:default}
.smc-mb-amt{position:absolute;bottom:4px;left:0;right:0;font-size:13px;font-weight:800;color:#ffd700;text-shadow:0 1px 3px rgba(0,0,0,.7)}
.smc-mb-result{min-height:22px;font-size:1.1rem;color:#fff;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;margin-top:4px}
.smc-mb-result-show{opacity:1;transform:translateY(0)}
.smc-mb-result strong{color:#ffd700}
.smc-mb-collect{margin-top:14px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;padding:12px 32px;cursor:pointer;box-shadow:0 6px 18px rgba(34,197,94,.4)}
.smc-mb-collect:hover{filter:brightness(1.1)}
.smc-mb-tag{display:inline-block;background:linear-gradient(135deg,#ec4899,#8b5cf6);color:#fff;font-size:9px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;vertical-align:middle;margin-left:4px;white-space:nowrap}
.smc-mb-grid{transition:opacity .2s}
.smc-mb-grid.smc-mb-refilling{opacity:0}

/* ── Kingdom Heist board game ── */
.smc-kh-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:12px;background:linear-gradient(160deg,#3b2a6d,#5b3aa8 55%,#3b2a6d);backdrop-filter:blur(4px);opacity:0;transition:opacity .25s;overflow:hidden}
.smc-kh-overlay.smc-kh-show{opacity:1}
.smc-kh-overlay.kh-flash-good{animation:kh-flashg .6s}
.smc-kh-overlay.kh-flash-bad{animation:kh-flash .5s}
.smc-kh-wrap{text-align:center;width:100%;max-width:min(96vw, calc(100vh - 24px));max-height:100%;position:relative;display:flex;flex-direction:column;align-items:center}
.smc-kh-boardwrap{position:relative;width:100%;flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center}
.smc-kh-board{position:relative;display:grid;gap:4px;width:min(100%, calc(100vh - 190px));aspect-ratio:1;margin:0 auto}
@keyframes kh-flash{0%,100%{filter:none}40%{filter:saturate(1.4) brightness(.7) sepia(.4) hue-rotate(-40deg)}}
@keyframes kh-flashg{0%,100%{filter:none}40%{filter:saturate(1.5) brightness(1.2)}}
.smc-kh-headline{font-size:clamp(1.05rem,4vw,1.6rem);font-weight:900;color:#ffd700;margin-bottom:2px;flex:0 0 auto;letter-spacing:.02em;text-shadow:0 2px 10px rgba(255,215,0,.4)}
.smc-kh-loot{font-size:clamp(.85rem,3vw,1.2rem);color:#fff;margin-bottom:6px;flex:0 0 auto;display:inline-block;padding:4px 16px;border-radius:12px;background:rgba(255,255,255,.18);font-weight:700}
.smc-kh-loot strong{color:#ffe680;font-size:clamp(1.05rem,3.6vw,1.5rem)}
.smc-kh-loot.kh-pop{animation:smc-td-pop .4s cubic-bezier(.2,1.3,.5,1)}
.kh-sp{position:relative;background:linear-gradient(160deg,#fffef9,#f3edff);border:3px solid #c9b6f0;border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden;min-width:0}
.kh-sp.kh-has-img{padding:0}
.kh-sp-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.kh-sp-chip{position:absolute;top:3px;right:3px;background:#16a34a;color:#fff;font-size:13px;font-weight:900;line-height:1;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,.4);z-index:2}
.kh-sp-face{font-size:clamp(1.1rem,4.2vw,2.2rem);line-height:1;display:flex;align-items:center;justify-content:center}
.kh-sp-face img{width:100%;height:auto;max-height:clamp(26px,9vw,60px);object-fit:contain;border-radius:4px}
.kh-sp-icon{font-size:clamp(1.1rem,4.2vw,2.2rem)}
.kh-sp-label{font-size:clamp(7px,1.7vw,13px);font-weight:800;color:#5b3aa8;line-height:1.05;margin-top:1px;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.kh-sp-amt{font-size:clamp(9px,2vw,15px);font-weight:900;margin-top:1px;color:#16a34a}
.kh-sp-start{border-color:#2dd4bf;box-shadow:0 0 0 0 rgba(45,212,191,.5)}
.kh-sp-jackpot{border-color:#ff2d95;animation:kh-pulse-pink 1.5s ease-in-out infinite}
.kh-sp-mult{border-color:#38bdf8;animation:kh-pulse-blue 1.6s ease-in-out infinite}
.kh-sp-half{border-color:#facc15;animation:kh-pulse-yellow 1.5s ease-in-out infinite}
.kh-sp-caught{border-color:#ef4444;animation:kh-pulse-red 1.3s ease-in-out infinite}
.kh-sp-heist{border-color:#22c55e;animation:kh-pulse-green 2s ease-in-out infinite}
.kh-sp-safe{border-color:#cbd5e1}
.kh-sp.kh-landed{animation:kh-land .6s ease;border-color:#ffd700;box-shadow:0 0 0 2px #ffd700,0 0 18px rgba(255,215,0,.6);z-index:3}
@keyframes kh-land{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}
/* center area (fills the interior of the loop) */
.smc-kh-center{grid-row:2 / -2;grid-column:2 / -2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%);border-radius:12px}
.smc-kh-dice{display:flex;gap:10px;font-size:2.4rem;line-height:1}
.smc-kh-dice.kh-rolling{animation:kh-shake .25s infinite}
@keyframes kh-shake{0%,100%{transform:translateX(0) rotate(0)}25%{transform:translateX(-3px) rotate(-8deg)}75%{transform:translateX(3px) rotate(8deg)}}
.kh-die{filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}
.smc-kh-msg{color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);line-height:1.4;padding:0 14px;max-width:min(80vw,560px);display:flex;flex-direction:column;align-items:center;justify-content:center}
.smc-kh-msg strong{color:#ffd700}
/* token */
.smc-kh-token{position:absolute;top:0;left:0;width:clamp(38px,11vw,58px);height:clamp(38px,11vw,58px);z-index:6;display:flex;align-items:center;justify-content:center;font-size:clamp(30px,9vw,46px);pointer-events:none;will-change:transform;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}
.smc-kh-token img{width:100%;height:100%;object-fit:contain}
/* actions */
.smc-kh-actions{display:flex;gap:10px;justify-content:center;margin-top:8px;flex-wrap:wrap;flex:0 0 auto}
.smc-kh-roll,.smc-kh-cashout,.smc-kh-keep,.smc-kh-collect{border:none;border-radius:12px;font-size:14px;font-weight:800;padding:11px 18px;cursor:pointer;font-family:inherit;letter-spacing:.02em;transition:transform .12s,filter .12s}
.smc-kh-roll{background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;box-shadow:0 6px 18px rgba(124,58,237,.45);font-size:16px;padding:12px 36px}
.smc-kh-cashout{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;box-shadow:0 6px 18px rgba(34,197,94,.4)}
.smc-kh-keep{background:linear-gradient(135deg,#ea580c,#f59e0b);color:#fff;box-shadow:0 6px 18px rgba(245,158,11,.4)}
.smc-kh-roll:hover,.smc-kh-cashout:hover,.smc-kh-keep:hover,.smc-kh-collect:hover{transform:translateY(-2px);filter:brightness(1.1)}
.smc-kh-result{min-height:0;font-size:1rem;color:#fff;margin-top:6px;flex:0 0 auto;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;padding:0 10px}
.smc-kh-result-show{opacity:1;transform:translateY(0)}
.smc-kh-result strong{color:#ffd700}
.smc-kh-collect{margin-top:12px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}
/* multiplier spin overlay */
.smc-kh-multspin{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,6,20,.6);border-radius:inherit;z-index:8}
.kh-mult-num{font-size:4rem;font-weight:900;color:#ffd700;text-shadow:0 4px 20px rgba(255,215,0,.6)}
.kh-mult-num.kh-mult-final{animation:smc-td-pop .5s cubic-bezier(.2,1.5,.4,1);font-size:5rem}
.smc-kh-tag{display:inline-block;background:linear-gradient(135deg,#7c3aed,#ffd700);color:#1a1226;font-size:9px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;vertical-align:middle;margin-left:4px;white-space:nowrap}
/* admin board space rows */

/* ── Kingdom Heist BIG DICE reveal ── */
.smc-kh-dicereveal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:20;pointer-events:none;opacity:0;transition:opacity .2s}
.smc-kh-dicereveal.kh-dr-in{opacity:1}
.smc-kh-dicereveal.kh-dr-out{opacity:0;transform:scale(.7);transition:opacity .3s,transform .3s}
.kh-dice-row{display:flex;gap:22px}
.kh-bigdie{width:88px;height:88px;background:linear-gradient(150deg,#ff4d4d,#c81e1e);border-radius:16px;box-shadow:0 10px 30px rgba(200,30,30,.55),inset 0 3px 0 rgba(255,255,255,.35),inset 0 -4px 8px rgba(0,0,0,.3);display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:12px;gap:2px;border:2px solid #fff}
.kh-pip{display:block;border-radius:50%;background:transparent;align-self:center;justify-self:center;width:16px;height:16px}
.kh-pip.on{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.4)}
.kh-bigdie.kh-tumble{animation:kh-tumble .18s linear infinite}
@keyframes kh-tumble{0%{transform:rotate(-12deg) scale(1.04)}50%{transform:rotate(10deg) scale(.97)}100%{transform:rotate(-12deg) scale(1.04)}}
.kh-bigdie.kh-landed-die{animation:kh-die-land .5s cubic-bezier(.2,1.4,.4,1)}
@keyframes kh-die-land{0%{transform:scale(1.4) rotate(8deg)}60%{transform:scale(.92)}100%{transform:scale(1) rotate(0)}}

/* Kingdom Heist stacked center message + bigger token */
.kh-msg-line{font-size:clamp(15px,3.6vw,24px);font-weight:800;line-height:1.3}
.kh-msg-big{font-size:clamp(34px,11vw,72px);font-weight:900;line-height:1.05;margin-top:6px;color:#fff;text-shadow:0 3px 14px rgba(0,0,0,.5);animation:smc-td-pop .45s cubic-bezier(.2,1.4,.4,1)}
.kh-msg-big.kh-msg-good{color:#7CFFB2;text-shadow:0 3px 16px rgba(34,197,94,.5)}
.kh-msg-big.kh-msg-bad{color:#ff9a9a;text-shadow:0 3px 16px rgba(239,68,68,.5)}
.kh-msg-big.kh-msg-sentence{font-size:clamp(18px,5vw,30px);line-height:1.25;overflow-wrap:break-word;word-break:break-word;max-width:100%}
.smc-kh-token{filter:drop-shadow(0 3px 6px rgba(0,0,0,.7));transition:transform .18s ease}
.smc-kh-token img{width:100%;height:100%;object-fit:contain}


/* Kingdom Heist pulsing outlines */
@keyframes kh-pulse-green{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.0)}50%{box-shadow:0 0 8px 1px rgba(34,197,94,.7)}}
@keyframes kh-pulse-yellow{0%,100%{box-shadow:0 0 0 0 rgba(250,204,21,.0)}50%{box-shadow:0 0 10px 2px rgba(250,204,21,.85)}}
@keyframes kh-pulse-red{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.0)}50%{box-shadow:0 0 12px 3px rgba(239,68,68,.9)}}
@keyframes kh-pulse-gold{0%,100%{box-shadow:0 0 0 0 rgba(245,197,24,.0)}50%{box-shadow:0 0 10px 2px rgba(245,197,24,.85)}}
@keyframes kh-pulse-pink{0%,100%{box-shadow:0 0 0 0 rgba(255,45,149,.0)}50%{box-shadow:0 0 12px 3px rgba(255,45,149,.9)}}
@keyframes kh-pulse-amber{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.0)}50%{box-shadow:0 0 10px 2px rgba(245,158,11,.85)}}
@keyframes kh-pulse-blue{0%,100%{box-shadow:0 0 0 0 rgba(56,189,248,.0)}50%{box-shadow:0 0 11px 2px rgba(56,189,248,.9)}}

/* Kingdom Heist START THE HEIST intro screen */
.smc-kh-intro{position:absolute;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:18px;background:linear-gradient(160deg,#3b2a6d,#5b3aa8 55%,#3b2a6d);transition:opacity .3s,transform .3s}
.smc-kh-intro.kh-intro-out{opacity:0;transform:scale(1.06);pointer-events:none}
.smc-kh-intro-inner{text-align:center;max-width:440px}
.smc-kh-intro-hl{font-size:clamp(1.4rem,6vw,2.4rem);font-weight:900;color:#ffd700;text-shadow:0 3px 14px rgba(255,215,0,.45);margin-bottom:14px;animation:smc-wheel-pulse 1.1s ease-in-out infinite}
.smc-kh-introimg{margin:0 auto 14px}
.smc-kh-introimg img{max-width:min(60vw,240px);max-height:30vh;border-radius:14px;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.smc-kh-introvid{position:relative;display:inline-block}
.smc-kh-introvid video{max-width:min(70vw,300px);max-height:34vh;border-radius:14px;box-shadow:0 8px 30px rgba(0,0,0,.4);display:block;background:#000}
.smc-kh-intro-text{color:#e9e0ff;font-size:clamp(13px,3.4vw,17px);line-height:1.5;margin:0 0 22px;padding:0 10px}
.smc-kh-startbtn{background:linear-gradient(135deg,#ffd700,#f59e0b);color:#1a1226;border:none;border-radius:16px;font-size:clamp(16px,4.5vw,21px);font-weight:900;letter-spacing:.03em;padding:16px 40px;cursor:pointer;box-shadow:0 8px 28px rgba(255,215,0,.45);animation:smc-td-startpulse 1.1s ease-in-out infinite}
.smc-kh-startbtn:hover{filter:brightness(1.08);transform:translateY(-2px)}
.smc-kh-startbtn.kh-btn-wait{opacity:.5;cursor:default;animation:none;box-shadow:0 4px 14px rgba(255,215,0,.25)}
.smc-kh-startbtn.kh-btn-wait:hover{filter:none;transform:none}

/* Kingdom Heist landing reveal image (space img + overlay PNG) */
.smc-kh-revealimg{position:relative;display:none;align-items:center;justify-content:center;margin-bottom:8px}
.smc-kh-revealimg.kh-ri-pop{animation:kh-ri-pop .45s cubic-bezier(.2,1.4,.4,1)}
@keyframes kh-ri-pop{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}
.kh-ri-space{width:min(clamp(140px,34vw,300px),38vh);height:min(clamp(140px,34vw,300px),38vh);object-fit:cover;border-radius:20px;box-shadow:0 12px 38px rgba(0,0,0,.6);border:4px solid rgba(255,255,255,.65)}
.smc-kh-escvid{width:min(clamp(160px,40vw,340px),42vh);max-width:100%;border-radius:20px;box-shadow:0 12px 38px rgba(0,0,0,.6);border:4px solid rgba(127,233,196,.8);background:#000}
.smc-kh-escemoji{font-size:min(clamp(70px,20vw,140px),22vh);line-height:1}
.kh-ri-overlay{position:absolute;right:-12%;bottom:-10%;width:min(clamp(120px,30vw,260px),34vh);height:auto;filter:drop-shadow(0 6px 14px rgba(0,0,0,.6));animation:kh-ov-pop .5s cubic-bezier(.2,1.5,.4,1) .1s both}
@keyframes kh-ov-pop{0%{transform:scale(.2) rotate(-14deg);opacity:0}60%{transform:scale(1.12) rotate(4deg)}100%{transform:scale(1) rotate(0);opacity:1}}

/* Kingdom Heist solo overlay (e.g. Clean Getaway on cash-out) — centered, full-size, not corner */
.kh-ri-overlay.kh-ri-solo{position:static;left:auto;right:auto;top:auto;bottom:auto;transform:none;width:min(clamp(150px,36vw,300px),40vh);height:auto;border-radius:18px;box-shadow:0 12px 38px rgba(0,0,0,.5)}

/* Mystery Box start screen */
.smc-mb-intro-screen{position:absolute;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:18px;background:linear-gradient(160deg,#241040,#160a2e);border-radius:inherit;transition:opacity .3s,transform .3s}
.smc-mb-intro-screen.smc-mb-intro-out{opacity:0;transform:scale(1.06);pointer-events:none}
.smc-mb-intro-inner{text-align:center;max-width:420px}
.smc-mb-intro-hl{font-size:clamp(1.4rem,6vw,2.2rem);font-weight:900;color:#ffd700;text-shadow:0 3px 14px rgba(255,215,0,.45);margin-bottom:16px;font-family:'Boogaloo',cursive}
.smc-mb-intro-gift{font-size:96px;line-height:1;margin:0 auto 16px;animation:smc-mb-giftbob 1.6s ease-in-out infinite}
.smc-mb-intro-gift img{width:min(48vw,180px);height:auto;border-radius:16px;filter:drop-shadow(0 10px 26px rgba(0,0,0,.5))}
@keyframes smc-mb-giftbob{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(2deg)}}
.smc-mb-intro-text{color:#e9e0ff;font-size:clamp(13px,3.4vw,16px);line-height:1.5;margin:0 0 22px;padding:0 10px}
.smc-mb-startbtn{background:linear-gradient(135deg,#ffd700,#f59e0b);color:#1a1226;border:none;border-radius:16px;font-size:clamp(16px,4.5vw,20px);font-weight:900;letter-spacing:.03em;padding:16px 38px;cursor:pointer;box-shadow:0 8px 28px rgba(255,215,0,.45);font-family:'Boogaloo',cursive;animation:smc-td-startpulse 1.1s ease-in-out infinite}
.smc-mb-startbtn:hover{filter:brightness(1.08);transform:translateY(-2px)}

/* Spin button when out of credits — clickable, gently pulses to invite a tap (opens buy prompt) */
.smc-spin-btn.smc-needs-credits{filter:grayscale(.35) brightness(.92);animation:smc-needs-pulse 1.6s ease-in-out infinite;cursor:pointer}
@keyframes smc-needs-pulse{0%,100%{box-shadow:0 4px 0 #4c1d95,0 6px 20px rgba(124,58,237,.5)}50%{box-shadow:0 4px 0 #4c1d95,0 0 22px 4px rgba(219,39,119,.6)}}

/* ── Locked-machine prompt: earn the badge OR buy access ── */
.smc-lock-overlay{position:absolute;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:18px;background:rgba(10,8,20,.85);backdrop-filter:blur(4px);border-radius:inherit;opacity:0;transition:opacity .25s}
.smc-lock-overlay.smc-lock-show{opacity:1}
.smc-lock-box{position:relative;background:linear-gradient(160deg,#241636,#160e22);border:2px solid #a855f7;border-radius:18px;padding:24px 22px;text-align:center;max-width:360px;width:100%;color:#fff;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 40px rgba(168,85,247,.35);transform:scale(.92);transition:transform .25s}
.smc-lock-overlay.smc-lock-show .smc-lock-box{transform:scale(1)}
.smc-lock-x{position:absolute;top:10px;right:12px;background:none;border:none;color:#8a7fc0;font-size:17px;cursor:pointer;line-height:1}
.smc-lock-x:hover{color:#fff}
.smc-lock-title{font-size:19px;font-weight:800;margin-bottom:6px}
.smc-lock-sub{font-size:13px;color:#b9b0e0;margin-bottom:12px}
.smc-lock-badge{display:flex;align-items:center;gap:10px;text-align:left;background:#241a40;border:1px solid #3a2f63;border-radius:12px;padding:12px;margin:12px 0;font-size:14px;font-weight:700}
.smc-lock-badge-ic{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#ffd27a,#d59320);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px}
.smc-lock-badge b{color:#ffd27a}
.smc-lock-or{display:flex;align-items:center;gap:10px;color:#6f649c;font-size:11px;font-weight:700;letter-spacing:.5px;margin:10px 0}
.smc-lock-or span{flex:1;height:1px;background:#3a2f63}
.smc-lock-buys{display:flex;flex-direction:column;gap:10px}
.smc-lock-buy{display:block;width:100%;box-sizing:border-box;border-radius:12px;padding:12px;font-size:14px;font-weight:800;cursor:pointer;text-decoration:none}
.smc-lock-buy-perm{background:linear-gradient(180deg,#ffd27a,#e0a020);color:#3a2600;box-shadow:0 4px 14px rgba(224,160,32,.35)}
.smc-lock-buy-perm:hover{filter:brightness(1.05)}
.smc-lock-buy-timed{background:#2a2150;color:#e7e0ff;border:1px solid #4a3f7d}
.smc-lock-buy-timed:hover{background:#332863}
.smc-lock-fine{font-size:11px;color:#7a6fae;margin-top:10px}

/* Cost-per-spin indicator */
.smc-cost-line{text-align:center;margin-top:12px}
.smc-cost-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#ffd700;background:rgba(255,215,0,.10);border:1px solid rgba(255,215,0,.32);border-radius:999px;padding:5px 14px}
.smc-cost-amt{font-size:13px}
