:root{--bg:#06110b;--bg2:#0a1810;--card:#0e1d14;--card2:#13271b;--stroke:rgba(110,255,180,.12);--txt:#eafff2;--dim:#84a894;--dim2:#4d6b58;--green:#22e584;--green2:#5cffa6;--mint:#7affc4;--gold:#ffd45c;--pink:#ff5d6c;--ton:#2bd17e;--r:18px;--st:env(safe-area-inset-top,0px);--sb:env(safe-area-inset-bottom,0px)}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;min-width:0}
html{height:100%;overscroll-behavior:none}
body{margin:0;min-height:100%;background:var(--bg);color:var(--txt);font-family:-apple-system,"SF Pro Display","Inter","Segoe UI",system-ui,sans-serif;-webkit-user-select:none;user-select:none;overscroll-behavior:none;position:fixed;inset:0;overflow:hidden}
body::before{content:"";position:fixed;inset:0 0 auto 0;height:46%;background:radial-gradient(80% 100% at 50% 0%,rgba(34,229,132,.2),transparent 70%);pointer-events:none;z-index:0}
#app{position:relative;z-index:1;max-width:480px;margin:0 auto;height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden;padding-top:max(var(--st),var(--tg-top,0px))}
.ton{flex:0 0 auto;vertical-align:-2px}
.title{font-size:24px;font-weight:800;letter-spacing:-.4px;margin:18px 18px 4px}
.subtitle{color:var(--dim);margin:0 18px 16px;font-size:13.5px;line-height:1.45}

.subbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px}
.subbar__left{display:flex;align-items:center;gap:9px}
.vg-brand{font-weight:800;font-size:17px;letter-spacing:.3px;background:linear-gradient(90deg,#fff,var(--green2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-right:4px}
.pill{border:1px solid var(--stroke);border-radius:999px;background:var(--card);color:var(--txt);font-size:14px;font-weight:650;padding:8px 14px;display:inline-flex;align-items:center;gap:7px}
.pill--online{background:rgba(34,229,132,.14);color:var(--green);border-color:rgba(34,229,132,.25);font-size:13.5px}
.dot{width:7px;height:7px;border-radius:999px;background:var(--green);display:inline-block;box-shadow:0 0 8px var(--green)}
.circle-btn{border:1px solid var(--stroke);width:40px;height:40px;border-radius:13px;background:var(--card);color:var(--txt);display:inline-flex;align-items:center;justify-content:center}
.circle-btn--plus{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--green),var(--mint));border:none;color:#04150c}
.circle-btn svg{width:20px;height:20px}.circle-btn--plus svg{width:17px;height:17px}.pill svg{width:15px;height:15px}
.balance{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--stroke);border-radius:999px;padding:5px 6px 5px 14px;font-weight:750;font-size:16px}
.balance svg.ton{vertical-align:-3px}

.screen{display:none;min-height:0;padding:0 16px 120px}
.screen--active{display:block;flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;animation:fade .26s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.stage{position:relative;height:40vh;min-height:236px;border-radius:24px;overflow:hidden;border:1px solid var(--stroke);background:radial-gradient(120% 80% at 50% 0%,#0f2417,#0a160e 55%,#06100a 100%);touch-action:none}
#graph{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.multiplier{position:absolute;top:0;left:0;right:0;text-align:center;padding-top:22px;font-size:50px;font-weight:850;letter-spacing:-2px;color:#fff;text-shadow:0 0 30px rgba(34,229,132,.55);z-index:3}
.multiplier.crashed{color:var(--pink);text-shadow:0 0 30px rgba(255,93,108,.5)}
.rocket{position:absolute;left:24%;bottom:14%;width:96px;height:96px;z-index:2;transition:transform .08s linear;will-change:transform}
.rocket__lottie{width:100%;height:100%;transform:rotate(34deg);filter:drop-shadow(0 8px 18px rgba(255,140,40,.4))}
.rocket.crashed{opacity:0;transform:translateY(30px) scale(.5) rotate(120deg);transition:all .35s ease}
.rocket .rocket__lottie{animation:rockFloat 2.6s ease-in-out infinite}
.rocket.flying .rocket__lottie{animation:rockShake .1s linear infinite}
@keyframes rockFloat{0%,100%{transform:rotate(34deg) translateY(0)}50%{transform:rotate(34deg) translateY(-9px)}}
@keyframes rockShake{0%{transform:rotate(34deg) translate(0,0)}25%{transform:rotate(33deg) translate(-1px,1px)}50%{transform:rotate(35deg) translate(1px,-1px)}75%{transform:rotate(33.5deg) translate(-1px,0)}100%{transform:rotate(34deg) translate(1px,0)}}
.rocket__trail{position:absolute;left:50%;bottom:2px;width:16px;height:60px;transform:translateX(-50%) rotate(214deg);transform-origin:top center;background:linear-gradient(to top,rgba(120,255,180,0),rgba(34,229,132,.9));filter:blur(7px);opacity:0;transition:opacity .25s;z-index:-1}
.rocket.flying .rocket__trail{opacity:1;animation:trailPulse .14s linear infinite alternate}
@keyframes trailPulse{from{height:48px;opacity:.7}to{height:78px;opacity:1}}
.countdown{position:absolute;left:0;right:0;bottom:16px;text-align:center;font-size:14px;font-weight:650;color:var(--dim);z-index:3}
.bet-overlay{position:absolute;left:14px;bottom:14px;background:rgba(34,229,132,.14);border:1px solid rgba(34,229,132,.4);backdrop-filter:blur(16px);border-radius:16px;padding:9px 13px;z-index:4;display:none;min-width:118px}
.bet-overlay.on{display:block;animation:pop .25s ease}
.bet-overlay__label{font-size:11px;color:var(--dim)}
.bet-overlay__stake{font-size:14px;font-weight:700;display:flex;gap:5px;align-items:center}
.bet-overlay__gift{display:none;align-items:center;gap:6px;margin:4px 0}
.bet-overlay__gift img{width:28px;height:28px;object-fit:contain}
.bet-overlay__gift span{font-size:12px;font-weight:750;max-width:96px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--mint)}
.bet-overlay__win{font-size:24px;font-weight:850;color:var(--green2);transform-origin:left center}
@keyframes pop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.stage__flash{position:absolute;inset:0;display:none;align-items:center;justify-content:center;font-size:44px;font-weight:900;color:var(--pink);letter-spacing:1px;text-shadow:0 0 40px rgba(255,93,108,.6);z-index:5}
.stage__flash.on{display:flex;animation:pop .3s ease}
.history{display:flex;gap:8px;overflow-x:auto;padding:14px 2px;scrollbar-width:none}
.history::-webkit-scrollbar{display:none}
.hp{flex:0 0 auto;padding:7px 13px;border-radius:11px;font-weight:750;font-size:14px;border:1px solid var(--stroke);background:var(--card)}
.hp.lo{color:var(--mint)}.hp.mid{color:var(--green)}.hp.hi{color:var(--gold)}
.hp.cur{background:linear-gradient(135deg,var(--green),var(--mint));color:#04150c;border:none}


.bet-panel{margin-bottom:12px}
.stake-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.stake-step{width:52px;height:52px;border-radius:15px;border:1px solid var(--stroke);background:var(--card);color:#fff}
.stake-step svg{width:22px;height:22px}
.stake-field{flex:1;display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--stroke);border-radius:15px;padding:0 16px;height:52px;font-size:20px;font-weight:750}
.stake-field input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:20px;font-weight:750;width:100%;font-family:inherit}
.stake-quick{display:flex;gap:6px}
.stake-quick button{flex:1;min-width:0;height:38px;border-radius:11px;border:1px solid var(--stroke);background:var(--card);color:var(--dim);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;padding:0 4px;line-height:1;touch-action:manipulation}
.stake-quick .q-gift{flex:1.8;color:var(--mint);border-color:rgba(34,229,132,.3)}
.stake-quick button svg{flex:0 0 auto;width:15px;height:15px}
.picked-gift{display:none;align-items:center;gap:10px;margin-top:10px;padding:8px 12px;background:var(--card);border:1px solid rgba(34,229,132,.4);border-radius:13px}
.picked-gift.on{display:flex}
.picked-gift img{width:34px;height:34px;object-fit:contain}
.picked-gift .pg-name{font-weight:700;font-size:14px;flex:1}
.picked-gift .pg-x{color:var(--dim);font-size:13px;display:inline-flex;align-items:center;gap:4px}

.action-btn{width:100%;border:none;border-radius:var(--r);background:linear-gradient(135deg,var(--green),var(--mint));color:#04150c;font-size:17px;font-weight:800;padding:17px;touch-action:manipulation;display:flex;align-items:center;justify-content:center;gap:7px}
.action-btn:active{transform:scale(.985)}
.action-btn--cashout{background:linear-gradient(135deg,#19c37d,#7affc4);color:#04241a}
.action-btn--wait{background:var(--card2);color:var(--dim);border:1px solid var(--stroke)}
.action-btn--half{flex:1}
.action-btn--outline{background:transparent;border:1.5px solid rgba(34,229,132,.5);color:var(--green2)}
.cashout-btn{animation:cashPulse 1.1s ease-in-out infinite}
@keyframes cashPulse{0%,100%{box-shadow:0 0 0 0 rgba(34,229,132,.4)}50%{box-shadow:0 0 0 8px rgba(34,229,132,0)}}

.bets-list{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.bet-item{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--stroke);border-radius:14px;padding:8px 12px}
.bet-item.me{border-color:rgba(34,229,132,.5)}
.bet-item__ava{width:38px;height:38px;border-radius:11px;overflow:hidden;background:#0a1a11;flex:0 0 auto}
.bet-item__ava img{width:100%;height:100%;object-fit:cover;display:block}
.bet-item__mid{flex:1;min-width:0}
.bet-item__name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bet-item__sub{font-size:13px;color:var(--dim);display:flex;gap:6px;align-items:center;margin-top:2px}
.sub-gift{width:18px;height:18px;object-fit:contain;vertical-align:middle}
.bet-item__mult{color:var(--mint);font-weight:700}
.bet-item__win{font-weight:800;font-size:15px;flex:0 0 auto}
.bet-item__win.win{color:var(--green2)}.bet-item__win.lose{color:var(--pink)}

.games-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 18px}
.game-card{border:1px solid var(--stroke);border-radius:18px;padding:15px;text-align:left;color:#fff;background:linear-gradient(160deg,rgba(34,229,132,.2),rgba(120,255,196,.08));position:relative;overflow:hidden}
.game-card:active{transform:scale(.985)}
.game-card--slot{background:linear-gradient(160deg,rgba(120,255,196,.2),rgba(34,229,132,.1))}
.game-card__ic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--green),var(--mint));margin-bottom:10px;color:#04150c}
.game-card__ic svg{width:22px;height:22px;stroke:currentColor}
.game-card__t{font-weight:800;font-size:16px}
.game-card__s{font-size:12px;color:var(--dim);margin-top:2px}

.gifts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gift-card{border-radius:16px;padding:12px 8px 10px;background:var(--card);border:1px solid var(--stroke);text-align:center;position:relative;overflow:hidden;touch-action:manipulation}
.gift-card .glow{position:absolute;inset:0;opacity:.55;pointer-events:none}
.gift-card img{width:60px;height:60px;object-fit:contain;position:relative;z-index:1}
.gift-card .gname{font-size:11px;font-weight:650;margin-top:6px;position:relative;z-index:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--dim)}
.gift-card .gprice{margin-top:3px;font-size:13px;font-weight:800;display:inline-flex;gap:4px;align-items:center;position:relative;z-index:1}
.gift-card[data-r="mythic"] .glow{background:radial-gradient(circle at 50% 0,rgba(255,93,108,.4),transparent 70%)}
.gift-card[data-r="legendary"] .glow{background:radial-gradient(circle at 50% 0,rgba(255,212,92,.38),transparent 70%)}
.gift-card[data-r="epic"] .glow{background:radial-gradient(circle at 50% 0,rgba(120,255,196,.34),transparent 70%)}
.gift-card[data-r="rare"] .glow{background:radial-gradient(circle at 50% 0,rgba(34,229,132,.32),transparent 70%)}
.gift-card[data-r="uncommon"] .glow{background:radial-gradient(circle at 50% 0,rgba(43,209,126,.26),transparent 70%)}
.gift-card[data-r="common"] .glow{background:radial-gradient(circle at 50% 0,rgba(255,255,255,.08),transparent 70%)}


.leaderboard{display:flex;flex-direction:column;gap:8px}
.lb-row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--stroke);border-radius:14px;padding:11px 14px}
.lb-rank{font-weight:850;width:24px;color:var(--dim)}.lb-rank.top{color:var(--green2)}
.lb-ava{width:36px;height:36px;border-radius:10px;overflow:hidden;flex:0 0 auto;background:#0a1a11}
.lb-ava img{width:100%;height:100%;object-fit:cover}
.lb-name{flex:1;font-weight:650}
.lb-amount{font-weight:800;color:var(--green2);display:inline-flex;gap:4px;align-items:center}

.profile-toggles{display:flex;gap:8px;padding-top:6px}
.profile-head{text-align:center;margin-top:14px}
.avatar{width:104px;height:104px;border-radius:28px;margin:0 auto;background:#0a1a11;border:1px solid var(--stroke);background-size:cover;background-position:center;box-shadow:0 16px 40px -12px rgba(34,229,132,.5)}
.profile-name{font-size:23px;font-weight:800;margin-top:14px}
.profile-progress-text{color:var(--dim);margin-top:4px;font-size:14px}
.progress{height:8px;border-radius:999px;background:var(--card2);margin:12px auto 0;max-width:240px;overflow:hidden}
.progress__bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--mint))}
.profile-actions{display:flex;gap:10px;margin-top:18px}
.wallet-card{margin-top:14px;border-radius:16px;padding:14px;background:var(--card);border:1px solid var(--stroke);display:flex;align-items:center;gap:12px}
.wallet-card__ic{width:40px;height:40px;border-radius:11px;background:rgba(34,229,132,.16);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.wallet-card__ic svg{width:22px;height:22px;color:var(--green)}
.wallet-card__mid{flex:1;min-width:0}
.wallet-card__t{font-weight:750;font-size:14px}
.wallet-card__s{font-size:12.5px;color:var(--dim);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wallet-card__btn{border:none;background:linear-gradient(135deg,var(--green),var(--mint));color:#04150c;font-weight:750;font-size:13px;padding:9px 14px;border-radius:11px;flex:0 0 auto}
.wallet-card__btn.ghost{background:transparent;border:1px solid var(--stroke);color:var(--dim)}
.ref-card{margin-top:14px;border-radius:16px;padding:16px;background:var(--card);border:1px solid var(--stroke)}
.ref-card__title{font-size:18px;font-weight:800}
.ref-card__desc{font-size:13px;color:var(--dim);margin-top:4px;line-height:1.35}
.ref-card__links{display:flex;gap:10px;margin-top:14px}
.ref-card__links button{flex:1;background:var(--card2);border:1px solid var(--stroke);color:var(--green2);font-weight:700;font-size:13.5px;padding:10px;border-radius:11px}
.inv-title{font-size:17px;font-weight:800;margin:18px 4px 12px}
.inventory{min-height:120px;border-radius:16px;border:1px solid var(--stroke);background:var(--card);display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px}
.inventory.empty{display:flex;align-items:center;justify-content:center;color:var(--dim2);font-size:15px}

.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(10px + var(--sb));width:calc(100% - 24px);max-width:456px;display:flex;background:rgba(10,22,14,.86);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--stroke);border-radius:20px;padding:7px 6px;z-index:50;box-shadow:0 16px 40px -14px rgba(0,0,0,.7)}
.tab{flex:1;background:none;border:none;color:var(--dim2);display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:650;padding:6px 2px;border-radius:13px;touch-action:manipulation;transition:color .2s,background .2s}
.tab__ic{width:23px;height:23px;display:block;margin:0 auto}
.tab svg{stroke:currentColor}
.tab--active{color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint))}

.modal{position:fixed;inset:0;z-index:100;background:rgba(3,8,5,.62);display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.modal.open{display:flex}
.modal__sheet{width:100%;max-width:480px;background:var(--bg2);border:1px solid var(--stroke);border-radius:24px 24px 0 0;padding:12px 16px calc(18px + var(--sb));max-height:82vh;overflow-y:auto;animation:up .3s ease}
@keyframes up{from{transform:translateY(100%)}to{transform:none}}
.modal__handle{width:38px;height:5px;border-radius:999px;background:rgba(255,255,255,.2);margin:4px auto 14px}
.modal__title{font-size:18px;font-weight:800;text-align:center;margin-bottom:14px}
.modal .gifts-grid{margin-bottom:14px}
.dep-amount{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--stroke);border-radius:15px;padding:0 16px;height:54px;font-size:22px;font-weight:800;margin-bottom:12px}
.dep-amount input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:22px;font-weight:800;width:100%;font-family:inherit}
.dep-quick{display:flex;gap:8px;margin-bottom:14px}
.dep-quick button{flex:1;height:40px;border-radius:11px;border:1px solid var(--stroke);background:var(--card2);color:var(--dim);font-weight:700}
.dep-note{font-size:12.5px;color:var(--dim);line-height:1.45;margin:0 2px 14px;text-align:center}
.vg-row{display:flex;align-items:center;justify-content:space-between;padding:14px 2px;font-weight:650;font-size:16px;border-bottom:1px solid var(--stroke)}
.vg-sw{position:relative;width:50px;height:30px;display:inline-block;flex:0 0 auto}
.vg-sw input{position:absolute;opacity:0;width:100%;height:100%;margin:0;z-index:2}
.vg-sw i{position:absolute;inset:0;background:var(--card2);border:1px solid var(--stroke);border-radius:999px;transition:.2s}
.vg-sw i::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:999px;background:#fff;transition:.2s}
.vg-sw input:checked + i{background:linear-gradient(135deg,var(--green),var(--mint));border-color:transparent}
.vg-sw input:checked + i::after{transform:translateX(20px)}
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:rgba(14,29,20,.97);backdrop-filter:blur(20px);border:1px solid var(--stroke);color:#fff;padding:12px 18px;border-radius:13px;font-weight:650;z-index:200;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;max-width:90%;text-align:center}
.toast.on{opacity:1;transform:translateX(-50%) translateY(-6px)}


/* ===== СЛОТ (зелёный) ===== */
.slot-wrap{position:fixed;inset:0;z-index:150;display:none;flex-direction:column;background:radial-gradient(90% 60% at 50% 0%,rgba(34,229,132,.18),transparent 60%),linear-gradient(180deg,#08160e,#050b07);padding:calc(max(var(--st),var(--tg-top,0px)) + 12px) 8px calc(var(--sb) + 16px);max-width:480px;margin:0 auto;overflow:hidden}
.slot-wrap.open{display:flex;animation:fade .25s ease}
.slot-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 8px}
.slot-close{background:var(--card);border:1px solid var(--stroke);color:#fff;border-radius:12px;padding:9px 14px;font-weight:700;font-size:14px}
.slot-headtitle{font-weight:800;font-size:16px}
.slot-bal{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--stroke);border-radius:999px;padding:7px 13px;font-weight:750;font-size:15px}
.slot-banner{margin:14px 8px;border-radius:16px;padding:11px;text-align:center;background:var(--card);border:1px solid var(--stroke);display:flex;flex-direction:column;gap:2px}
.slot-banner__t{font-size:10.5px;letter-spacing:1.5px;color:var(--dim)}
.slot-banner__v{font-size:26px;font-weight:850;color:#fff}
.slot-banner.win .slot-banner__v{color:var(--green2);text-shadow:0 0 22px rgba(34,229,132,.5)}
.slot-banner.win{animation:slotBannerWin .5s ease;border-color:rgba(34,229,132,.4)}
@keyframes slotBannerWin{0%{transform:scale(1)}50%{transform:scale(1.05)}100%{transform:scale(1)}}
.slot-banner.nowin{opacity:.55}
.slot-stage{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding:6px}
.slot-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(5,1fr);aspect-ratio:6 / 5;width:100%;gap:6px;padding:8px;background:rgba(4,16,10,.55);border:1px solid rgba(34,229,132,.16);border-radius:18px;box-sizing:border-box}
.scell{position:relative;min-width:0;min-height:0;border-radius:11px;background:linear-gradient(160deg,rgba(34,229,132,.16),rgba(120,255,196,.06));border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;overflow:visible}
.scell img{width:80%;height:80%;object-fit:contain;pointer-events:none}
.scell.spin{overflow:hidden}
.scell.spin img{animation:reelRoll .16s linear infinite}
@keyframes reelRoll{0%{transform:translateY(-115%)}100%{transform:translateY(115%)}}
.scell.land{animation:tileLand .34s cubic-bezier(.2,1.25,.3,1) both}
@keyframes tileLand{0%{transform:translateY(-14%);opacity:.5}100%{transform:translateY(0);opacity:1}}
.scell.win{z-index:3}
.scell.win::after{content:"";position:absolute;inset:-3px;border-radius:13px;border:2px solid var(--green2);box-shadow:0 0 16px var(--green2),inset 0 0 10px rgba(120,255,196,.5)}
.scell.win img{animation:winPulse .45s ease-in-out infinite alternate}
@keyframes winPulse{from{transform:scale(1)}to{transform:scale(1.12)}}
.scell.pop{z-index:6;animation:cellPop .45s ease forwards}
@keyframes cellPop{0%{transform:scale(1)}35%{transform:scale(1.32)}100%{transform:scale(0);opacity:0}}
.scell.pop::after{content:"";position:absolute;inset:-4px;border-radius:16px;border:2px solid var(--mint);animation:popRing .45s ease forwards}
@keyframes popRing{0%{transform:scale(.6);opacity:.9}100%{transform:scale(1.9);opacity:0}}
.slot-fx{position:absolute;inset:0;z-index:9;pointer-events:none}
.sfly{position:absolute;object-fit:contain;transition:left .55s cubic-bezier(.25,.9,.3,1),top .55s cubic-bezier(.25,.9,.3,1),transform .55s ease;filter:drop-shadow(0 8px 18px rgba(34,229,132,.65))}
.slot-burst{position:absolute;left:50%;top:50%;width:10px;height:10px;border-radius:999px;transform:translate(-50%,-50%);pointer-events:none;opacity:0;z-index:9}
.slot-burst.show{animation:slotBurst .65s ease-out}
@keyframes slotBurst{0%{opacity:1;box-shadow:0 0 0 0 rgba(120,255,196,.95),0 0 0 0 rgba(34,229,132,.6)}100%{opacity:0;box-shadow:0 0 0 130px rgba(120,255,196,0),0 0 0 220px rgba(34,229,132,0)}}
.slot-foot{margin-top:12px;display:flex;flex-direction:column;gap:10px;padding:0 8px}
.slot-spin{border:none;border-radius:16px;padding:16px;font-size:18px;font-weight:850;color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint));box-shadow:0 12px 30px -10px rgba(34,229,132,.6);letter-spacing:.4px;display:flex;align-items:center;justify-content:center;gap:6px}
.slot-spin:active{transform:scale(.985)}.slot-spin:disabled{opacity:.55}
.slot-reveal{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:rgba(5,11,7,.78);backdrop-filter:blur(6px);z-index:12}
.slot-reveal.show{display:flex;animation:fade .3s ease}
.slot-reveal__card{position:relative;text-align:center;background:linear-gradient(160deg,#102a1b,#08160e);border:1px solid var(--stroke);border-radius:22px;padding:24px 30px;animation:pop .4s cubic-bezier(.2,1.3,.3,1)}
.slot-reveal__glow{position:absolute;inset:0;border-radius:22px;box-shadow:0 0 60px rgba(34,229,132,.45);pointer-events:none}
.slot-reveal__card img{width:116px;height:116px;object-fit:contain;filter:drop-shadow(0 8px 20px rgba(34,229,132,.5))}
.slot-reveal__name{font-weight:800;font-size:18px;margin-top:8px}
.slot-reveal__price{font-size:13px;color:var(--dim);margin-top:2px}
.slot-reveal__mults{font-size:15px;font-weight:850;color:var(--gold);margin-top:6px}
.slot-reveal__win{font-weight:850;font-size:20px;color:var(--green2);margin-top:6px}
.slot-reveal__inv{font-size:12px;color:var(--dim);margin-top:6px}
.slot-reveal__btn{margin-top:16px;border:none;border-radius:14px;padding:12px 30px;font-weight:800;color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint))}
.mbub{position:absolute;left:50%;top:44%;transform:translate(-50%,-50%) scale(0);display:flex;align-items:center;justify-content:center;width:104px;height:104px;border-radius:50%;background:radial-gradient(circle at 50% 32%,#eafff2,#22e584 58%,#0a8f57);box-shadow:0 0 46px rgba(34,229,132,.85),inset 0 -6px 16px rgba(0,40,20,.5),inset 0 6px 14px rgba(255,255,255,.6);pointer-events:none;z-index:12;animation:xPunch 1.1s cubic-bezier(.2,1.5,.3,1) forwards}
.mbub span{font-weight:900;font-size:36px;color:#04150c;text-shadow:0 1px 4px rgba(255,255,255,.4)}
.mbub::before{content:"";position:absolute;inset:-12px;border-radius:50%;border:3px solid rgba(120,255,196,.7);animation:xRing 1.1s ease forwards}
@keyframes xPunch{0%{transform:translate(-50%,-50%) scale(0) rotate(-18deg);opacity:0}18%{transform:translate(-50%,-50%) scale(1.28) rotate(6deg);opacity:1}42%{transform:translate(-50%,-54%) scale(1) rotate(0)}78%{transform:translate(-50%,-92%) scale(1);opacity:1}100%{transform:translate(-50%,-150%) scale(.7);opacity:0}}
@keyframes xRing{0%{transform:scale(.5);opacity:.9}70%{opacity:.35}100%{transform:scale(2.1);opacity:0}}


/* ===== АПГРЕЙД (зелёный) ===== */
.up-wrap{position:fixed;inset:0;z-index:150;display:none;flex-direction:column;background:radial-gradient(90% 60% at 50% 12%,rgba(34,229,132,.2),transparent 60%),linear-gradient(180deg,#08160e,#05090a);padding:calc(max(var(--st),var(--tg-top,0px)) + 12px) 16px calc(var(--sb) + 14px);max-width:480px;margin:0 auto;overflow-y:auto}
.up-wrap.open{display:flex;animation:fade .25s ease}
.up-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.up-close{background:var(--card);border:1px solid var(--stroke);color:#fff;border-radius:12px;padding:9px 14px;font-weight:700;font-size:14px}
.up-title{font-weight:800;font-size:16px;display:flex;align-items:center;gap:6px}
.up-demo{display:flex;align-items:center;gap:10px;margin:14px 2px 6px;font-weight:700}
.up-stage{position:relative;display:flex;align-items:center;justify-content:center;margin:6px 0 4px}
.up-wheel{position:relative;width:min(76vw,290px);aspect-ratio:1;border-radius:50%}
.up-spiral{position:absolute;inset:-12%;border-radius:50%;background:conic-gradient(from 0deg,rgba(34,229,132,0),rgba(34,229,132,.4),rgba(120,255,196,.4),rgba(34,229,132,0));filter:blur(16px);animation:upSpin 9s linear infinite}
@keyframes upSpin{to{transform:rotate(360deg)}}
.up-arc{position:absolute;inset:0;border-radius:50%;background:conic-gradient(#7affc4 0deg,#22e584 0deg,rgba(255,255,255,.06) 0deg 360deg);-webkit-mask:radial-gradient(circle,transparent 56%,#000 57%);mask:radial-gradient(circle,transparent 56%,#000 57%);transition:background .35s ease}
.up-center{position:absolute;inset:22%;border-radius:50%;background:#08130d;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 30px rgba(34,229,132,.25)}
.up-chance{font-size:30px;font-weight:850;color:#fff;letter-spacing:-1px}
.up-needle{position:absolute;inset:0;transform:rotate(0deg);will-change:transform}
.up-needle.spinning{transition:transform 3.4s cubic-bezier(.1,.62,.12,1)}
.up-needle::after{content:"";position:absolute;top:-3px;left:50%;transform:translateX(-50%);border-left:11px solid transparent;border-right:11px solid transparent;border-top:20px solid #fff;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5))}
.up-label{text-align:center;font-size:20px;font-weight:850;margin-top:12px}
.up-sub{text-align:center;color:var(--dim);font-size:13px;margin-top:2px}
.up-slots{display:flex;gap:12px;margin-top:14px}
.up-slot{flex:1;height:120px;border-radius:18px;border:1px dashed var(--stroke);background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;position:relative;color:var(--dim)}
.up-slot.filled{border-style:solid;border-color:rgba(34,229,132,.5)}
.up-slot__plus{font-size:34px;color:var(--dim2);font-weight:300}
.up-slot__cap{font-size:13px;font-weight:700}
.up-slot img{width:62px;height:62px;object-fit:contain}
.up-slot .pr{font-size:13px;font-weight:800;display:inline-flex;gap:4px;align-items:center}
.up-slot .rm{position:absolute;top:6px;right:8px;color:var(--dim);font-size:16px}
.up-mults{display:flex;gap:8px;margin-top:14px;background:var(--card);border:1px solid var(--stroke);border-radius:14px;padding:5px}
.up-mults button{flex:1;height:38px;border-radius:10px;border:none;background:transparent;color:var(--dim);font-weight:800;font-size:14px}
.up-mults button.on{background:linear-gradient(135deg,var(--green),var(--mint));color:#04150c}
.up-go{margin-top:16px;border:none;border-radius:18px;padding:17px;font-size:18px;font-weight:850;color:#04150c;background:linear-gradient(135deg,#22e584,#7affc4,#19c37d);background-size:200% 100%;box-shadow:0 12px 30px -8px rgba(34,229,132,.6)}
.up-go:disabled{opacity:.5}
.up-result{position:absolute;left:0;right:0;top:0;bottom:0;display:none;align-items:center;justify-content:center;background:rgba(5,11,7,.8);backdrop-filter:blur(6px);z-index:20}
.up-result.show{display:flex;animation:fade .3s ease}
.up-result__card{text-align:center;background:linear-gradient(160deg,#102a1b,#08130d);border:1px solid var(--stroke);border-radius:22px;padding:24px 30px;animation:pop .4s cubic-bezier(.2,1.3,.3,1)}
.up-result__card img{width:120px;height:120px;object-fit:contain}
.up-result__t{font-size:20px;font-weight:850;margin-top:8px}
.up-result__s{font-size:13px;color:var(--dim);margin-top:4px}
.up-result.win .up-result__t{color:var(--green2)}
.up-result.lose .up-result__t{color:var(--pink)}
.up-result__btn{margin-top:16px;border:none;border-radius:14px;padding:12px 30px;font-weight:800;color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint))}


/* ===== ЛОАДЕР ===== */
#loader{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:radial-gradient(80% 60% at 50% 40%,#0a2016,#05100a);transition:opacity .5s ease}
#loader.hide{opacity:0;pointer-events:none}
.loader__glow{position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(34,229,132,.4),transparent 70%);filter:blur(30px);animation:ldPulse 1.8s ease-in-out infinite}
@keyframes ldPulse{0%,100%{transform:scale(.9);opacity:.6}50%{transform:scale(1.15);opacity:1}}
.loader__logo{width:84px;height:84px;position:relative;z-index:1;animation:ldFloat 2.4s ease-in-out infinite;filter:drop-shadow(0 0 24px rgba(34,229,132,.7))}
@keyframes ldFloat{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(3deg)}}
.loader__name{position:relative;z-index:1;font-size:26px;font-weight:850;letter-spacing:.5px;background:linear-gradient(90deg,#fff,#7affc4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.loader__bar{position:relative;z-index:1;width:160px;height:6px;border-radius:999px;background:rgba(255,255,255,.1);overflow:hidden}
.loader__bar i{display:block;height:100%;width:38%;border-radius:999px;background:linear-gradient(90deg,#22e584,#7affc4);animation:ldBar 1.1s ease-in-out infinite}
@keyframes ldBar{0%{transform:translateX(-130%)}100%{transform:translateX(360%)}}
.loader__sub{position:relative;z-index:1;color:var(--dim);font-size:13px}

.subbar__right{display:flex;align-items:center;gap:8px}
.back-btn{display:inline-flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--stroke);color:#fff;border-radius:12px;padding:8px 13px 8px 10px;font-weight:700;font-size:14px;margin:8px 0 12px}
.back-btn svg{width:18px;height:18px}

/* ===== ХАБ (Главная) ===== */
.hub{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hub-card{position:relative;overflow:hidden;border:1px solid var(--stroke);border-radius:20px;padding:16px 14px 14px;min-height:142px;display:flex;flex-direction:column;align-items:flex-start;text-align:left;color:#fff;background:linear-gradient(160deg,rgba(34,229,132,.16),rgba(10,29,20,.55));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 14px 30px -16px rgba(34,229,132,.5)}
.hub-card:active{transform:scale(.98)}
.hub-card--soon{opacity:.55;background:linear-gradient(160deg,rgba(120,160,140,.1),rgba(10,29,20,.5))}
.hub-card__sheen{position:absolute;top:0;left:-60%;width:50%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.16),transparent);transform:skewX(-18deg);animation:sheen 4.5s ease-in-out infinite;pointer-events:none}
@keyframes sheen{0%{left:-60%}35%{left:150%}100%{left:150%}}
.hub-card__on{font-size:11px;font-weight:700;color:var(--green2);display:inline-flex;align-items:center;gap:5px;background:rgba(0,0,0,.25);padding:4px 9px;border-radius:999px}
.hub-card__art{margin:14px 0 auto;width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--green),var(--mint));color:#04150c;box-shadow:0 8px 20px -6px rgba(34,229,132,.7)}
.hub-card__art svg{width:30px;height:30px}
.hub-card__t{font-size:18px;font-weight:850;margin-top:10px}
.hub-card__cta{font-size:13px;color:var(--dim);font-weight:700;margin-top:2px}

/* ===== ИНВЕНТАРЬ ===== */
.inv-head{text-align:center;margin-top:10px}
.inv-ava{width:96px;height:96px;border-radius:26px;margin:0 auto}
.inv-name{font-size:22px;font-weight:800;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px}
.inv-badge{font-size:12px;font-weight:700;color:var(--green2);background:rgba(34,229,132,.15);border:1px solid rgba(34,229,132,.3);padding:3px 8px;border-radius:999px}
.connect-card{margin:14px auto 0;max-width:330px}
.connect-card__t{font-weight:750;font-size:14px}
.connect-card__s{font-size:12.5px;color:var(--dim);margin-top:2px}
.connect-btn{position:relative;overflow:hidden;margin-top:12px;border:none;border-radius:14px;padding:12px 18px;font-weight:800;font-size:15px;color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint));display:inline-flex;align-items:center;gap:7px;box-shadow:0 10px 24px -8px rgba(34,229,132,.6)}
.connect-btn.ghost{background:transparent;border:1px solid var(--stroke);color:var(--dim);box-shadow:none}
.inv-tabs{display:flex;gap:18px;justify-content:center;margin-top:20px;font-weight:800;font-size:16px}
.inv-tab{background:none;border:none;color:var(--dim2);padding:4px 2px;border-bottom:2px solid transparent}
.inv-tab--active{color:#fff;border-bottom-color:var(--green)}
.inv-empty{text-align:center;margin-top:24px}
.mascot{width:130px;height:130px;filter:drop-shadow(0 12px 28px rgba(34,229,132,.4));animation:ldFloat 3s ease-in-out infinite}
.inv-empty__t{font-size:19px;font-weight:850;margin-top:10px}
.inv-empty__s{font-size:13px;color:var(--dim);margin-top:6px;max-width:260px;margin-left:auto;margin-right:auto;line-height:1.4}
.inv-actions{display:flex;gap:12px;justify-content:center;margin-top:18px}
.inv-act{border:1px solid var(--stroke);background:var(--card);color:#fff;font-weight:800;font-size:15px;padding:13px 22px;border-radius:14px}
.inv-act--grad{position:relative;overflow:hidden;border:none;color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint))}

/* ===== глянец и сверкание ===== */
.balance,.pill,.circle-btn{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.gift-card,.bet-item,.lb-row,.ref-card,.wallet-card,.game-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.action-btn,.slot-spin,.up-go,.connect-btn,.inv-act--grad{position:relative;overflow:hidden}
.action-btn::after,.slot-spin::after,.up-go::after,.connect-btn::after,.inv-act--grad::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);animation:sheen 3.6s ease-in-out infinite;pointer-events:none}


/* фикс: окно выбора подарка в апгрейде поверх ===== */
#upPick{z-index:200}
#giftModal,#depModal{z-index:200}
/* плавные переходы экранов */
.screen--active{animation:screenIn .34s cubic-bezier(.2,.7,.2,1)}
@keyframes screenIn{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:none}}
/* слот-карточка на главной */
.hub-card[data-go="slot"]{background:linear-gradient(160deg,rgba(120,255,196,.26),rgba(34,229,132,.08))}
.hub-card[data-go="slot"] .hub-card__art{background:linear-gradient(135deg,#7affc4,#19c37d);box-shadow:0 8px 22px -4px rgba(120,255,196,.8)}
/* меньше размеры краша на телефоне */
@media (max-width:440px){
.stage{height:33vh;min-height:198px;border-radius:20px}
.multiplier{font-size:40px;padding-top:16px}
.rocket{width:78px;height:78px}
.stake-step{width:46px;height:46px}
.stake-field{height:46px;font-size:18px}.stake-field input{font-size:18px}
.action-btn{padding:15px;font-size:16px}
.bet-item{padding:7px 10px}
.bet-item__ava{width:34px;height:34px}
.history{padding:10px 2px}.hp{padding:6px 11px;font-size:13px}
.title{font-size:22px}
}


/* ===== КЕЙСЫ ===== */
.cases-head{font-weight:850;font-size:16px;margin:4px 2px 12px;color:#fff}
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.case-card{position:relative;overflow:hidden;border:1px solid var(--stroke);border-radius:20px;padding:12px;min-height:158px;display:flex;flex-direction:column;align-items:center;background:var(--cg,linear-gradient(160deg,#19c37d,#0a5234));box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 14px 30px -16px rgba(0,0,0,.6)}
.case-card:active{transform:scale(.98)}
.case-card__badges{display:flex;justify-content:space-between;width:100%;gap:6px;z-index:4}
.cb{font-size:12px;font-weight:800;color:#fff;background:rgba(0,0,0,.38);border-radius:999px;padding:4px 9px;display:inline-flex;align-items:center;gap:4px}
.cb--star{color:#ffd45c}
.case-card__art{position:relative;flex:1;width:100%;display:flex;align-items:center;justify-content:center;margin:4px 0}
.case-box{position:absolute;width:60px;height:46px;border-radius:9px;background:rgba(0,0,0,.32);box-shadow:0 10px 20px rgba(0,0,0,.45);transform:translateY(16px)}
.cc-g{position:absolute;width:48px;height:48px;object-fit:contain;filter:drop-shadow(0 6px 12px rgba(0,0,0,.55))}
.cc-g0{transform:translate(0,-12px) scale(1.15);z-index:3}
.cc-g1{transform:translate(-32px,4px) rotate(-12deg);z-index:2}
.cc-g2{transform:translate(32px,4px) rotate(12deg);z-index:2}
.case-card__name{font-weight:850;font-size:15px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.45)}
.case-wrap{position:fixed;inset:0;z-index:150;display:none;flex-direction:column;background:radial-gradient(90% 60% at 50% 0%,rgba(34,229,132,.18),transparent 60%),linear-gradient(180deg,#08160e,#05090a);padding:calc(max(var(--st),var(--tg-top,0px)) + 12px) 14px calc(var(--sb) + 16px);max-width:480px;margin:0 auto;overflow-y:auto}
.case-wrap.open{display:flex;animation:fade .25s ease}
.case-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:16px}
.case-reelwrap{position:relative;height:104px;border-radius:16px;border:1px solid var(--stroke);background:rgba(4,16,10,.6);overflow:hidden;display:flex;align-items:center}
.case-marker{position:absolute;left:50%;top:0;bottom:0;width:3px;transform:translateX(-50%);background:linear-gradient(180deg,var(--green),var(--mint));z-index:3;box-shadow:0 0 14px var(--green)}
.case-marker::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);border-left:7px solid transparent;border-right:7px solid transparent;border-top:9px solid var(--mint)}
.case-marker::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:9px solid var(--mint)}
.case-reel{display:flex;gap:10px;padding-left:8px;will-change:transform}
.case-cell{flex:0 0 84px;width:84px;height:84px;border-radius:12px;background:linear-gradient(160deg,rgba(34,229,132,.16),rgba(120,255,196,.05));border:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center}
.case-cell img{width:78%;height:78%;object-fit:contain}
.case-sub{text-align:center;color:var(--dim);font-size:12.5px;margin:16px 0 8px}
.case-pool{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.cp-item{background:var(--card);border:1px solid var(--stroke);border-radius:12px;padding:8px 4px;text-align:center}
.cp-item img{width:40px;height:40px;object-fit:contain}
.cp-item span{display:flex;align-items:center;justify-content:center;gap:3px;font-size:11px;font-weight:700;color:var(--dim);margin-top:2px}


/* ===== анимации: сердцебиение апгрейда + плавность ===== */
.up-center{animation:upHeart 1.5s ease-in-out infinite}
@keyframes upHeart{0%,100%{transform:scale(1)}10%{transform:scale(1.07)}20%{transform:scale(1)}32%{transform:scale(1.045)}44%{transform:scale(1)}}
.up-wheel{animation:upWheelPulse 2.6s ease-in-out infinite}
@keyframes upWheelPulse{0%,100%{filter:drop-shadow(0 0 0 rgba(34,229,132,0))}50%{filter:drop-shadow(0 0 22px rgba(34,229,132,.45))}}
.up-go{animation:goGlow 1.8s ease-in-out infinite}
@keyframes goGlow{0%,100%{box-shadow:0 12px 30px -8px rgba(34,229,132,.5)}50%{box-shadow:0 12px 38px -6px rgba(34,229,132,.9)}}

/* мягкое появление карточек */
.hub-card,.case-card,.gift-card,.bet-item,.lb-row,.cp-item{animation:popIn .42s cubic-bezier(.2,.85,.25,1) backwards}
@keyframes popIn{from{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:none}}
.hub-card:nth-child(2){animation-delay:.04s}.hub-card:nth-child(3){animation-delay:.08s}.hub-card:nth-child(4){animation-delay:.12s}.hub-card:nth-child(5){animation-delay:.16s}.hub-card:nth-child(6){animation-delay:.2s}
.cases-grid .case-card:nth-child(2){animation-delay:.04s}.cases-grid .case-card:nth-child(3){animation-delay:.08s}.cases-grid .case-card:nth-child(4){animation-delay:.12s}.cases-grid .case-card:nth-child(5){animation-delay:.16s}.cases-grid .case-card:nth-child(6){animation-delay:.2s}.cases-grid .case-card:nth-child(7){animation-delay:.24s}.cases-grid .case-card:nth-child(8){animation-delay:.28s}

/* плавность нажатий и переходов */
button,.tab,.hub-card,.case-card,.gift-card,.up-slot,.connect-btn,.action-btn,.slot-spin,.up-go{transition:transform .14s cubic-bezier(.2,.8,.2,1),box-shadow .2s ease,background .2s ease,color .2s ease}
.hub-card:active,.case-card:active,.gift-card:active,.up-slot:active{transform:scale(.96)}
.tab:active{transform:scale(.92)}
.tab__ic{transition:transform .2s ease,filter .2s ease}
.tab--active .tab__ic{transform:translateY(-1px) scale(1.05)}
.modal__sheet,.slot-reveal__card,.up-result__card{will-change:transform}
.bet-item{transition:transform .14s ease}
.bet-item__win.win{animation:winPop .35s ease}
@keyframes winPop{0%{transform:scale(.7);opacity:.4}100%{transform:scale(1);opacity:1}}



/* ===== Живые зелёные иконки игр ===== */
.hub-card{background:linear-gradient(160deg,rgba(34,229,132,.13),rgba(9,26,18,.55))}
.hub-card__art{position:relative;overflow:hidden;background:linear-gradient(135deg,#7affc4,#15a866);box-shadow:0 10px 26px -6px rgba(34,229,132,.55),inset 0 1px 0 rgba(255,255,255,.45);animation:artFloat 3.4s ease-in-out infinite}
.hub-card__art::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 75% at 30% 16%,rgba(255,255,255,.6),transparent 56%);pointer-events:none}
.hub-card__art svg{width:32px;height:32px;color:#05271a;filter:drop-shadow(0 2px 3px rgba(0,40,20,.4));position:relative;z-index:1}
@keyframes artFloat{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-5px) rotate(2deg)}}
.hub-card[data-go="crash"]{background:linear-gradient(160deg,rgba(120,255,196,.2),rgba(9,34,22,.55))}
.hub-card[data-go="crash"] .hub-card__art{background:linear-gradient(135deg,#9bffd0,#10b069)}
.hub-card[data-go="slot"]{background:linear-gradient(160deg,rgba(34,229,132,.22),rgba(9,34,22,.5))}
.hub-card[data-go="slot"] .hub-card__art{background:linear-gradient(135deg,#7affc4,#0f9f63);animation-delay:.15s}
.hub-card[data-go="upgrade"]{background:linear-gradient(160deg,rgba(180,255,150,.18),rgba(11,34,20,.55))}
.hub-card[data-go="upgrade"] .hub-card__art{background:linear-gradient(135deg,#caff8f,#34c06a);animation-delay:.3s}
.hub-card[data-go="cases"]{background:linear-gradient(160deg,rgba(90,255,214,.2),rgba(7,34,26,.55))}
.hub-card[data-go="cases"] .hub-card__art{background:linear-gradient(135deg,#7affd6,#10b87f);animation-delay:.45s}
.hub-card[data-go="season"]{background:linear-gradient(160deg,rgba(206,255,140,.16),rgba(13,34,17,.55))}
.hub-card[data-go="season"] .hub-card__art{background:linear-gradient(135deg,#e2ff9b,#69d24a);animation-delay:.6s}
.hub-card__t{text-shadow:0 1px 10px rgba(34,229,132,.3)}
.hub-card__sheen{animation:cardSheen 5.5s ease-in-out infinite}
@keyframes cardSheen{0%,55%{left:-60%}100%{left:150%}}

/* ===== Неоновый зелёный стиль иконок (как на фото) ===== */
.hub-card[data-go]{background:linear-gradient(165deg,rgba(12,34,22,.9),rgba(4,10,7,.94))!important}
.hub-card__art{background:radial-gradient(circle at 50% 42%,rgba(34,229,132,.22),rgba(4,12,8,.5))!important;box-shadow:0 0 24px rgba(34,229,132,.5),inset 0 0 16px rgba(34,229,132,.25)!important;border:1px solid rgba(122,255,196,.4)}
.hub-card__art::after{opacity:.22}
.hub-card__art svg{color:#5cff9f!important;filter:drop-shadow(0 0 6px rgba(92,255,159,.95)) drop-shadow(0 0 13px rgba(34,229,132,.6))!important;stroke-width:2.3}
.hub-card__art{animation:artFloat 3.6s ease-in-out infinite, artGlow 2.8s ease-in-out infinite}
@keyframes artGlow{0%,100%{filter:brightness(1)}50%{filter:brightness(1.18)}}

/* ===== Модалка NFT (продать/вывести) ===== */
.ii-img{width:124px;height:124px;margin:8px auto 14px;border-radius:22px;overflow:hidden;background:radial-gradient(circle at 50% 40%,rgba(34,229,132,.2),rgba(4,12,8,.5));box-shadow:0 0 26px rgba(34,229,132,.45),inset 0 0 16px rgba(34,229,132,.22);display:flex;align-items:center;justify-content:center}
.ii-img img{width:90%;height:90%;object-fit:contain;filter:drop-shadow(0 4px 10px rgba(0,0,0,.4))}
.ii-name{text-align:center;font-size:20px;font-weight:850;margin-bottom:4px}
.ii-price{text-align:center;color:#5cff9f;font-weight:800;margin-bottom:16px;font-size:15px}
.gift-card{cursor:pointer}
/* ==== доработки: пустой пикер, выбор в слотах, промокоды, пополнение ==== */
.gift-empty{grid-column:1/-1;text-align:center;color:var(--dim);font-size:13.5px;line-height:1.5;padding:26px 12px}
.slot-reveal__btn{display:block;width:min(260px,82%);margin-left:auto;margin-right:auto}
.slot-reveal__btn--sell{margin-top:10px;background:linear-gradient(135deg,#0098EA,#33aaf0);color:#fff}
.slot-reveal__choice{font-size:12.5px;color:var(--dim);margin-top:14px;margin-bottom:2px}
.promo-card{margin-top:14px;border-radius:16px;padding:16px;background:var(--card);border:1px solid var(--stroke)}
.promo-row{display:flex;gap:10px;margin-top:14px}
.promo-input{flex:1;min-width:0;background:var(--card2);border:1px solid var(--stroke);border-radius:12px;color:#eafff2;font-size:15px;font-weight:700;padding:12px 14px;outline:none;text-transform:uppercase}
.promo-input::placeholder{color:var(--dim);text-transform:none;font-weight:600}
.promo-btn{border:none;border-radius:12px;padding:12px 18px;font-weight:800;font-size:14px;color:#04150c;background:linear-gradient(135deg,var(--green),var(--mint));white-space:nowrap}
.promo-btn:disabled{opacity:.6}
.dep-choice{display:flex;flex-direction:column;gap:12px;margin:8px 0 14px}
.dep-choice__btn{display:flex;align-items:center;gap:14px;text-align:left;background:var(--card2);border:1px solid var(--stroke);border-radius:16px;padding:14px 16px;color:#eafff2;width:100%}
.dep-choice__ic{width:42px;height:42px;border-radius:12px;background:var(--card);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.dep-choice__tx{display:flex;flex-direction:column}
.dep-choice__t{font-size:15.5px;font-weight:800}
.dep-choice__s{font-size:12.5px;color:var(--dim);margin-top:2px}
.dep-nft__steps{margin:6px 0 12px;padding-left:20px;color:#dfeee7;font-size:13.5px;line-height:1.55}
.dep-nft__steps li{margin-bottom:8px}
.dep-nft__steps b{color:var(--green2)}
.dep-nft__note{font-size:12px;color:var(--dim);line-height:1.45;margin-bottom:12px}

.cashout-btn:disabled{opacity:.5;animation:none;filter:grayscale(.35)}

.lb-empty{text-align:center;color:var(--dim);font-size:13.5px;padding:26px 12px;line-height:1.5}
.case-cell .cc-amt{display:flex;align-items:center;justify-content:center;gap:4px;font-weight:800;font-size:15px;color:var(--green2)}.cp-item .cp-ton{display:flex;align-items:center;justify-content:center;gap:4px;font-size:12px;font-weight:800;color:var(--mint)}.case-card__max{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;gap:3px;font-size:11px;font-weight:800;color:var(--mint);z-index:4}.case-prize{display:flex;align-items:center;justify-content:center;gap:6px;font-size:30px;font-weight:900;color:var(--green2);margin-top:6px}
