*{-webkit-tap-highlight-color:transparent}
html,body{height:100%}
:root{
  --bg:#0f1115; --panel:#12161e; --card:#171b23; --line:#262b35;
  --text:#eaf0ff; --muted:#98a4be;
  --primary:#0a84ff; --primary2:#0a7af0;
  --success:#27c07d; --danger:#ff5b5b;
  --radius:16px; --blur:14px;
  --shadow-lg:0 22px 44px rgba(10,20,40,.35), 0 4px 10px rgba(0,0,0,.25);
  --shadow-sm:0 6px 16px rgba(10,20,40,.28), 0 1px 4px rgba(0,0,0,.2);
  --ios-ease:cubic-bezier(.25,1,.3,1);
  --sheet-h:72vh;
}
*{box-sizing:border-box}
body{
  margin:0;min-height:100vh;
  background:
    radial-gradient(1200px 700px at 20% -10%, #122036 0%, transparent 60%),
    radial-gradient(1000px 600px at 100% 0%, #1a2340 0%, transparent 55%),
    linear-gradient(180deg, #0f1115 0%, #0a0c10 100%);
  color:var(--text);
  font:15px/1.35 -apple-system,BlinkMacSystemFont,"SF Pro Text",Inter,system-ui,Segoe UI,Roboto,Arial;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
button{font:inherit;cursor:pointer;transition:transform .18s var(--ios-ease),filter .18s var(--ios-ease),background .24s var(--ios-ease),box-shadow .24s var(--ios-ease)}
img{display:block;max-width:100%}

/* стекло */
.glass{
  background:rgba(14,16,22,.6);
  border:1px solid rgba(150,170,220,.12);
  backdrop-filter:saturate(140%) blur(var(--blur));
  -webkit-backdrop-filter:saturate(140%) blur(var(--blur));
  box-shadow:var(--shadow-sm);
}

/* backdrop + toast */
#backdrop{position:fixed;inset:0;background:rgba(5,7,12,.45);opacity:0;visibility:hidden;transition:opacity .28s var(--ios-ease),visibility .28s var(--ios-ease);z-index:900}
#backdrop.show{opacity:1;visibility:visible}
body.lock{position:fixed;inset:0;width:100%;-webkit-overflow-scrolling:touch}

/* тост */
.toast{
  position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));
  transform:translate(-50%, 20px);opacity:0;pointer-events:none;
  background:rgba(12,16,24,.9);border:1px solid rgba(150,170,220,.15);
  color:#cfe0ff;border-radius:14px;padding:10px 14px;z-index:1300;
  transition:opacity .22s var(--ios-ease), transform .22s var(--ios-ease);
  backdrop-filter:blur(10px)
}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* тон иконка */
.ton-icon{width:16px;height:16px;object-fit:contain;vertical-align:-3px}
.icon{width:16px;height:16px;object-fit:contain}

/* страницы */
.page{display:none;min-height:calc(100vh - 72px)}
.page--active{display:block;animation:fadeIn .24s var(--ios-ease)}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* header */
.head-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px 6px;position:sticky;top:0;z-index:600}
.user-pill{display:flex;align-items:center;gap:8px}
.ava{width:34px;height:34px;border-radius:12px;background:#273042;object-fit:cover}
.balance-pill{display:flex;align-items:center;gap:8px;border:1px solid rgba(150,170,220,.12);padding:8px 10px;border-radius:14px;background:linear-gradient(180deg,rgba(16,22,30,.6),rgba(10,14,22,.5))}
.icon-btn{border:0;background:linear-gradient(180deg,#1f2a3d,#172134);color:#d5e2ff;border-radius:12px;padding:6px 10px;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.icon-btn.plus{margin-left:6px}
.pressable:active{transform:scale(.98);filter:saturate(120%)}

/* tabs */
.tabs{display:flex;gap:8px;padding:10px 14px}
.tab{flex:1;border:1px solid rgba(150,170,220,.12);background:linear-gradient(180deg,#131a24,#0e141e);color:#a8b4d0;border-radius:14px;padding:12px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04);min-height:46px}
.tab.active{background:linear-gradient(180deg,#0a84ff,#0a7af0);color:#fff;border-color:transparent;box-shadow:0 10px 24px rgba(10,132,255,.28)}

/* cases grid */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding:0 14px 120px}
.case{background:linear-gradient(180deg,#141a23,#0f141c);border:1px solid rgba(150,170,220,.12);border-radius:20px;padding:12px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.case .thumb{height:150px;border-radius:14px;background:#0f1622 url('/assets/case_stub.png') center/contain no-repeat}
.case .title{margin-top:10px;font-weight:800}
.case .badge{position:absolute;top:10px;left:10px;background:rgba(10,18,32,.65);border:1px solid rgba(130,160,255,.25);border-radius:999px;padding:6px 10px;display:flex;gap:6px;align-items:center;backdrop-filter:blur(6px)}

/* bottom nav */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;padding:10px 10px calc(10px + env(safe-area-inset-bottom));display:flex;gap:8px;border-top:1px solid rgba(150,170,220,.12);z-index:700;background:rgba(10,12,16,.55);backdrop-filter:blur(12px)}
.nav-btn{flex:1;border:0;border-radius:14px;background:linear-gradient(180deg,#141b26,#101621);color:#b8c7e6;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04);min-height:52px}
.nav-btn.active{background:linear-gradient(180deg,#172236,#121a2a);color:#fff;box-shadow:0 8px 20px rgba(20,40,80,.28)}

/* profile */
.profile{padding:8px 14px 120px}
.profile-top{display:flex;align-items:center;gap:12px}
.avatar{width:72px;height:72px;border-radius:22px;background:#273142;object-fit:cover;box-shadow:var(--shadow-sm)}
.user-line{display:flex;align-items:center;gap:10px;justify-content:space-between;flex:1}
.uname{font-size:20px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(70vw,260px)}
.bal{display:flex;align-items:center;gap:6px}
.card{border-radius:18px;padding:12px}
.wallet-card{margin-top:12px;margin-bottom:14px}
.wallet-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.muted{color:#a8b4d0}
.wallet-bound .wb-line{width:100%;display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid rgba(150,170,220,.14);border-radius:12px;padding:12px;background:linear-gradient(180deg,#121722,#0f151f);min-height:48px}
.wb-menu{margin-top:8px;position:relative;z-index:2}
.wb-menu.hidden{display:none}
.spin{display:inline-block;width:14px;height:14px;margin-left:6px;border:2px solid rgba(160,190,255,.3);border-top-color:#8fb0ff;border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(1turn)}}
.hidden{display:none}

/* inputs/buttons */
.ios-input{width:100%;border-radius:12px;border:1px solid rgba(150,170,220,.16);background:linear-gradient(180deg,#101621,#0b111a);color:#eaf0ff;padding:12px;min-height:44px;display:flex;align-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.ios-input::placeholder{color:#93a3c6}
.ios-input:focus{outline:none;border-color:rgba(10,132,255,.55);box-shadow:0 0 0 6px rgba(10,132,255,.15)}
.btn{border:1px solid rgba(150,170,220,.14);background:linear-gradient(180deg,#151b26,#121722);color:#cfe0ff;border-radius:14px;padding:10px 12px;min-height:44px;display:inline-flex;align-items:center;gap:8px;justify-content:center}
.btn.big{width:100%;margin-top:12px;margin-bottom:calc(8px + env(safe-area-inset-bottom))}
.btn-primary{background:linear-gradient(180deg,#0a84ff,#0a7af0);border-color:transparent;color:#fff;box-shadow:0 12px 26px rgba(10,132,255,.35)}
.btn-outline{background:transparent}
.btn-ghost{background:transparent;border-color:transparent;color:#a7bbdf}
.btn-ghost.danger{color:#ffb4b4}

/* inventory */
.inv-head{display:flex;justify-content:space-between;align-items:center;margin-top:16px}
.inv-grid{margin-top:10px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:360px){ .inv-grid{grid-template-columns:repeat(2,1fr)} }
.inv-item{background:linear-gradient(180deg,#161c28,#121722);border:1px solid rgba(150,170,220,.12);border-radius:16px;padding:12px;text-align:center;box-shadow:var(--shadow-sm)}
.inv-item .thumb{height:84px;border-radius:12px;background:#1c2433 url('/assets/gift_stub.png') center/contain no-repeat}
.inv-item .amt{margin-top:8px;display:flex;justify-content:center;gap:6px;font-size:16px;font-weight:700}

/* sheets */
.sheet{position:fixed;left:0;right:0;bottom:0;transform:translateY(100%);background:rgba(10,12,16,.72);backdrop-filter:saturate(140%) blur(var(--blur));-webkit-backdrop-filter:saturate(140%) blur(var(--blur));border-top-left-radius:18px;border-top-right-radius:18px;border:1px solid rgba(150,170,220,.12);z-index:1000;transition:transform .28s var(--ios-ease);touch-action:pan-y;overscroll-behavior:contain}
.sheet.open{transform:translateY(0)}
.sheet-body{max-height:68vh;overflow:auto;padding:18px 14px 20px;-webkit-overflow-scrolling:touch}
#caseSheet{height:var(--sheet-h)}
#caseSheet .sheet-body{max-height:100%}

/* крестик */
.close-btn{
  position:absolute; right:12px; top:6px;
  width:32px; height:32px; display:grid; place-items:center;
  border:0; background:transparent; font-size:22px; line-height:1;
  color:#cfe0ff; cursor:pointer; z-index:1500; opacity:.95
}
.close-btn:active{transform:scale(.96)}

/* case head */
.case-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding-right:56px}
.case-head .name{font-size:18px;font-weight:800;opacity:.92}
.chip{margin-left:auto;border:1px solid rgba(150,170,220,.14);background:transparent;color:#9fb3ff;border-radius:999px;padding:8px 12px}
.demo-note{margin:4px 0 6px;color:#9fb3ff;font-size:13px}
.demo-note.hidden{display:none}

/* rollers */
.roller-list{display:flex;flex-direction:column;gap:12px}
.roller{position:relative;background:linear-gradient(180deg,#0f141e,#0b1018);border:1px solid rgba(150,170,220,.12);border-radius:16px;padding:22px 0;overflow:hidden;box-shadow:var(--shadow-sm);will-change:transform}
.roller.prep{opacity:0}
.roller::before,.roller::after{content:"";position:absolute;top:0;bottom:0;width:48px;pointer-events:none;z-index:1}
.roller::before{left:0;background:linear-gradient(90deg,rgba(15,20,30,1),rgba(15,20,30,0))}
.roller::after{right:0;background:linear-gradient(-90deg,rgba(15,20,30,1),rgba(15,20,30,0))}
.marker{position:absolute;top:0;bottom:0;width:2px;background:#5ea0ff;box-shadow:0 0 16px rgba(94,160,255,.6), 0 0 2px #5ea0ff;z-index:10;left:50%;transform:translateX(-1px)}
.strip{display:flex;gap:12px;will-change:transform;transition:transform 6s cubic-bezier(.25,1,.3,1)}
.slot{flex:0 0 114px;height:114px;background:linear-gradient(180deg,#141a23,#111722);border:1px solid rgba(150,170,220,.12);border-radius:16px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.slot img{width:84%;height:84%;object-fit:contain;opacity:0;transform:scale(.92);animation:slotIn .22s var(--ios-ease) forwards}
@keyframes slotIn{to{opacity:1;transform:scale(1)}}

/* ценник в слоте */
.price{position:absolute;top:6px;left:6px;border-radius:12px;padding:4px 8px;font-size:12px;display:inline-flex;align-items:center;gap:6px;color:#eaf0ff;background:linear-gradient(180deg,rgba(15,23,36,.9),rgba(10,18,32,.85));border:1px solid rgba(130,160,255,.25);overflow:hidden;max-width:calc(100% - 12px)}
.price .ton-icon{width:14px;height:14px}
.price::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.22) 50%,transparent 100%);transform:translateX(-120%);animation:shimmer 2.8s infinite}
@keyframes shimmer{50%{transform:translateX(120%)}}

/* seg */
.seg{display:flex;gap:8px;margin:10px 0}
.seg-spins .seg-btn{flex:1}
.seg-mines{display:grid;grid-template-columns:repeat(2, minmax(48px, 1fr));gap:10px}
.seg-btn{border:0;border-radius:14px;padding:0;background:linear-gradient(180deg,#141a23,#101722);color:#9fb3d9;border:1px solid rgba(150,170,220,.12);min-height:44px}
.seg-mines .seg-btn{width:100%;aspect-ratio:1/1;min-width:48px;min-height:48px;font-weight:700}
.seg-btn.active{background:linear-gradient(180deg,#2d6df9,#255ee0);color:#fff;box-shadow:0 8px 18px rgba(45,109,249,.33)}
.seg-btn[disabled]{opacity:.6}

/* inside pool */
.whats{margin:10px 0 6px;font-size:20px;font-weight:900}
.pool{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pool .tile{position:relative;aspect-ratio:1/1;background:linear-gradient(180deg,#141a23,#121722);border:1px solid rgba(150,170,220,.12);border-radius:16px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.pool .tile img{width:78%;height:78%;object-fit:contain}
.pool .badge{position:absolute;top:8px;left:8px;background:rgba(10,18,32,.9);border:1px solid rgba(130,160,255,.25);border-radius:12px;padding:4px 8px;display:flex;gap:6px;align-items:center;color:#eaf0ff;font-size:12px;backdrop-filter:blur(6px)}

/* dialog */
.dialog{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:1200}
.dialog.open{display:flex;animation:fadeIn .22s var(--ios-ease)}
.dialog .box{position:relative;border:1px solid rgba(150,170,220,.12);border-radius:16px;padding:16px;min-width:280px;max-width:90vw;background:rgba(14,16,22,.92);backdrop-filter:blur(10px)}
.dialog .ttl{font-weight:900;margin-bottom:10px}
.winlist{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:10px;font-size:14px;color:#cfe0ff}
.row{display:flex}.gap{gap:10px}
.sell-amount{display:inline-flex;align-items:center;gap:8px;font-size:18px;font-weight:800;margin:6px 0 14px}
.sell-name{font-weight:800}

/* mines page */
.mines{padding:6px 14px 120px}
.mines-controls{
  display:grid;
  grid-template-columns: minmax(112px,150px) 1fr minmax(140px, 170px);
  grid-template-areas: "actions bet select";
  gap:10px;align-items:end;margin:6px 0 10px;
}
.mines-actions{grid-area:actions;display:flex;gap:8px;flex-wrap:nowrap}
.bet{grid-area:bet;min-width:120px}
.mines-select{grid-area:select}
.mines-select label{display:block;margin-bottom:6px;color:#a8b4d0;font-size:13px}
.mines-grid{margin-top:16px;display:grid;grid-template-columns:repeat(5, var(--cell, 56px));gap:10px;justify-content:center;min-height:300px;overflow:hidden}
.cell{width:var(--cell,56px);height:var(--cell,56px);background:linear-gradient(180deg,#141a23,#111722);border:1px solid rgba(150,170,220,.12);border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:800;color:#a9b6d6;user-select:none;transition:transform .05s, background .12s}
.cell:active{transform:scale(.98)}
.cell.safe{background:linear-gradient(180deg,#11241a,#0f1e16);border-color:#265a3e;color:#c9ffe5;box-shadow:inset 0 0 0 1px rgba(56,190,120,.18)}
.cell.mine{background:linear-gradient(180deg,#2b1212,#220e0e);border-color:#582020;color:#ffbbb4;box-shadow:inset 0 0 0 1px rgba(255,90,90,.18)}

/* HUD коэффициентов */
.mines-hud{position:sticky;top:52px;margin:6px 14px;border-radius:14px;padding:10px 12px;display:flex;align-items:center;justify-content:center;gap:14px}
.mines-hud span{font-variant-numeric:tabular-nums}
.hud-prev{opacity:.55}
.hud-current{font-size:20px;font-weight:900;color:#fff;transform-origin:center;animation:pop .18s var(--ios-ease)}
.hud-next{opacity:.8}
@keyframes pop{from{transform:scale(.92);opacity:.8}to{transform:scale(1);opacity:1}}
