@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
     background:#11131a;color:#e8e8e8;line-height:1.55;min-height:100vh}

/* ===== Новая тема в стиле booster ===== */
.page--roulette{
  --nt-bg: #121212;
  --nt-surface: #15172b;
  --nt-surface-2: #1b1f34;
  --nt-surface-3: #1f2340;
  --nt-text: #ffffff;
  --nt-muted: #b8bded;
  --nt-border: rgba(255,255,255,.08);
  --nt-border-strong:#3a4263;
  --nt-accent: #7709ff;
  --nt-accent-2: #9d64ff;
  --nt-accent-warm:#f7c945;
  --nt-shadow: rgba(0,0,0,.45);
  --content-max: 1654px;
  --page-gutter: max(16px, calc((100vw - var(--content-max)) / 2));
  background: var(--nt-bg);
  color: var(--nt-text);
  min-height:100vh;
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* Контейнер */
.roulette-wrap{
  /* было: max-width: var(--content-max); */
  width:100%;
  margin:34px 0 60px;
  padding:0 var(--page-gutter) 40px;
  display:flex;
  flex-direction:column;
  gap:40px;
}

/* Верхний блок (карточка со спином) */
.spin-card{
  background: var(--nt-surface-2);
  border:1px solid var(--nt-border);
  border-radius:20px;
  padding: 28px 32px 32px;
  box-shadow:0 14px 42px var(--nt-shadow);
  display:flex;
  flex-direction:column;
  gap:18px;
  transition:box-shadow .25s, border-color .25s;
}
.spin-card:hover{
  border-color: var(--nt-border-strong);
  box-shadow:0 18px 50px rgba(119,9,255,.25);
}

.spin-top{
  display:flex;
  flex-wrap:wrap;
  gap:22px;
  align-items:flex-end;
  justify-content:space-between;
}
.spin-top h2{
  font-size: clamp(22px,2.4vw,30px);
  font-weight:800;
  letter-spacing:.01em;
  margin:0 0 6px 0;
  color: var(--nt-text);
}
#state.cooldown{
  font-size: .95rem;
  color: var(--nt-muted);
  font-weight:500;
}

/* Кнопка спина в общей стилистике */
.spin-btn{
  --btn-pad-x: 26px;
  --btn-pad-y: 14px;
  background: linear-gradient(180deg,var(--nt-accent),var(--nt-accent-2));
  border:none;
  outline:1px solid rgba(255,255,255,.07);
  color:#fff;
  padding: var(--btn-pad-y) var(--btn-pad-x);
  font-weight:800;
  font-size:1.05rem;
  border-radius:14px;
  cursor:pointer;
  letter-spacing:.03em;
  position:relative;
  box-shadow:0 10px 28px rgba(119,9,255,.35);
  transition:transform .18s, box-shadow .18s, filter .18s;
}
.spin-btn:hover:not([disabled]){
  box-shadow:0 14px 40px rgba(119,9,255,.45);
  transform:translateY(-2px);
  filter:brightness(1.05);
}
.spin-btn:active:not([disabled]){
  transform:translateY(0);
  box-shadow:0 8px 22px rgba(119,9,255,.35);
}
.spin-btn[disabled]{
  opacity:.5;
  cursor:not-allowed;
  box-shadow:none;
  filter:grayscale(.35);
}

/* Рулетка */
.reel-wrap{
  background: var(--nt-surface);
  border:1px solid var(--nt-border);
  border-radius:18px;
  padding:20px 1px 28px;
  position:relative;
  overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.015);
  /* размеры карточки рулетки как CSS-переменные */
  --item-w: 170px;
  --item-gap: 12px;
}
.reel-viewport{
  overflow:hidden;
  position:relative;
  padding:4px 0;
}
.reel{
  display:flex;
  will-change:transform;
}
.reel-item{
  width:var(--item-w);
  flex:0 0 var(--item-w);
  margin-right:var(--item-gap);
  background: var(--nt-surface-3);
  border:1px solid var(--nt-border);
  border-radius:14px;
  padding:10px 10px 12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  box-shadow:0 6px 22px rgba(0,0,0,.4), inset 0 0 0 1px rgba(255,255,255,.02);
  transition:transform .25s, border-color .25s, box-shadow .25s;
  position:relative;
}
.reel-item::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(145deg,rgba(255,255,255,.04),rgba(255,255,255,0));
  opacity:.65;
}
.reel-item:hover{
  border-color: var(--nt-border-strong);
  transform:translateY(-4px);
  box-shadow:0 10px 28px rgba(119,9,255,.22);
}
/* reel (общий список призов) — строго 1×1 */
.reel-item img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:10px;
  background:#0d0e18;
  box-shadow:0 4px 14px rgba(0,0,0,.45);
}
.reel-item .t{
  font-weight:700;
  font-size:.87rem;
  letter-spacing:.02em;
  color:var(--nt-text);
}
.reel-item .d{
  font-size:.7rem;
  color:var(--nt-muted);
}
/* когда идёт спин — никаких hover/переходов/кликов по ленте */
.reel-wrap.is-spinning .reel-viewport{ pointer-events: none; }     /* ховер не прилетит */
.reel-wrap.is-spinning .reel-item{
  transition: none !important;       /* приподнятия/тени отключаем */
  transform: none !important;
  box-shadow: none !important;
}
/* если у тебя есть явные :hover-правила, подстрахуемся */
.reel-wrap.is-spinning .reel-item:hover{
  transform: none !important;
  box-shadow: none !important;
}
/* Pointer */
.reel-pointer{
  position:absolute;
  left:50%;top:0;
  transform:translate(-50%,-6px);
  width:0;height:0;
  border-left:12px solid transparent;
  border-right:12px solid transparent;
  border-top:16px solid var(--nt-accent);
  filter:drop-shadow(0 4px 4px rgba(0,0,0,.6)) drop-shadow(0 0 6px rgba(119,9,255,.5));
  z-index:30;
}
.reel-center-line{
  position:absolute;
  top:0;bottom:0;left:50%;
  transform:translateX(-50%);
  width:2px;
  background:linear-gradient(to bottom, transparent, rgba(119,9,255,.45), transparent);
  pointer-events:none;
  z-index:20;
}

/* Результат */
.prize-result{
  margin-top:10px;
  padding:16px 20px;
  display:none;
  background: var(--nt-surface-3);
  border:1px solid var(--nt-border);
  border-radius:14px;
  gap:18px;
  align-items:center;
  box-shadow:0 8px 26px rgba(0,0,0,.4);
  animation:prizePop .5s cubic-bezier(.16,.82,.19,1);
}
@keyframes prizePop{
  0%{transform:translateY(12px) scale(.92);opacity:0}
  60%{transform:translateY(-4px) scale(1.02);opacity:1}
  100%{transform:translateY(0) scale(1)}
}
.prize-result img{
  width:70px;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:12px;
  box-shadow:0 6px 18px rgba(0,0,0,.55);
  background:#0e0f18;
}
#prizeTitle{
  font-size:1rem;
  font-weight:800;
  margin-bottom:4px;
  letter-spacing:.02em;
}
#prizeCode{
  font-weight:700;
  color:var(--nt-accent-warm);
}

/* Список побед */
.wins{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.wins h3{
  font-size: clamp(20px,2vw,26px);
  font-weight:800;
  letter-spacing:.01em;
  margin:0;
  color:var(--nt-text);
}
.wins-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:18px;
}
.win-item{
  background: var(--nt-surface-2);
  border:1px solid var(--nt-border);
  border-radius:18px;
  padding:14px 16px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  position:relative;
  overflow:hidden;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.win-item::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 80% 15%, rgba(119,9,255,.22), transparent 60%);
  opacity:.65;
  pointer-events:none;
}
.win-item:hover{
  transform:translateY(-4px);
  border-color: var(--nt-border-strong);
  box-shadow:0 16px 40px rgba(119,9,255,.25);
}
.win-item img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:12px;
  background:#0d0e18;
  box-shadow:0 6px 18px rgba(0,0,0,.5);
}
.win-item > div:first-of-type{
  font-size:.95rem;
  font-weight:700;
  letter-spacing:.02em;
}
.win-item .muted{
  font-size:.7rem;
  letter-spacing:.04em;
}

/* muted */
.muted{ color:var(--nt-muted); opacity:.85; }

/* Scrollbar легкая кастомизация */
.reel-viewport::-webkit-scrollbar,
body::-webkit-scrollbar{height:10px;width:10px}
body::-webkit-scrollbar-track{background:var(--nt-surface)}
body::-webkit-scrollbar-thumb{background:#2a2f4a;border-radius:6px}
body::-webkit-scrollbar-thumb:hover{background:#3a4363}

/* ===== Инфо-блок ===== */
.about-card{
  background: var(--nt-surface-2);
  border:1px solid var(--nt-border);
  border-radius:20px;
  padding:24px 28px;
  box-shadow:0 12px 36px var(--nt-shadow);
}
.about-grid{
  display:grid;
  grid-template-columns: 360px 1fr; /* картинка слева, текст справа */
  gap:22px;
  align-items:center;
}
.about-hero{
  display:block;
  width:100%;
  aspect-ratio: 4 / 3;        /* устойчивые пропорции, без скачков */
  object-fit:cover;
  border-radius:14px;
}
.about-card h3{
  margin:0 0 10px 0;
  font-size: clamp(20px,2vw,26px);
  font-weight:800;
  letter-spacing:.01em;
  color:var(--nt-text);
}
.about-card p{ margin:8px 0; }
.about-list{
  margin:10px 0 6px 1.1em;
  display:grid; gap:6px;
  list-style: disc;
}
.about-hint{ margin-top:6px; }

/* Адаптив */
@media (max-width:1000px){
  .spin-card{padding:24px 24px 30px;}
  .about-card{padding:20px 20px;}
  .about-grid{grid-template-columns: 320px 1fr;}
  .reel-wrap{padding:18px 20px 26px;}
  .booster-icon-btn--stack{height:64px}
}
@media (max-width:760px){
  .spin-top{flex-direction:column;align-items:flex-start}
  .spin-btn{align-self:flex-start}
  .about-grid{
    grid-template-columns: 1fr;   /* на мобилках — в столбик */
    gap:14px;
  }
  .about-hero{ margin-bottom: 0; } 
  .reel-wrap{ --item-w: 150px; --item-gap: 12px; }
  .reel-item img{height:100px;} /* ок оставить фикс h для стабильной сетки */
  .wins-list{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
  .prize-result{flex-direction:row;align-items:center;}
}
@media (max-width:520px){
  .spin-card{padding:20px 18px 26px;}
  .reel-wrap{padding:16px 16px 22px;}
  .reel-wrap{ --item-w: 138px; --item-gap: 10px; }
  .reel-item img{height:88px;}
  .win-item{padding:12px 14px 14px;}
}
@media (max-width:410px){
  .reel-wrap{ --item-w: 126px; --item-gap: 10px; }
}

/* ===== Конец нового оформления ===== */

/* УДАЛЕНО: старый блок (ломал отступы/цвет кнопки)
   Было:
   .roulette-wrap{max-width:1060px;margin:32px auto;padding:16px}
   .spin-card{background:#161622;...}
   .spin-btn{background:#f7c945;...}
   ... и прочее наследие
*/

/* Защитный override (на случай если старый CSS где-то ещё кэширован) */
.page--roulette .spin-btn{
  background:linear-gradient(180deg,var(--nt-accent),var(--nt-accent-2)) !important;
  color:#fff !important;
  outline:1px solid rgba(255,255,255,.07);
  box-shadow:0 10px 28px rgba(119,9,255,.35);
}
.page--roulette .roulette-wrap{
  max-width:none !important;
  width:100% !important;
  padding:0 var(--page-gutter) 40px !important;
  margin:34px 0 60px !important;
}
/* Центральный индикатор */
.reel-pointer{
  position:absolute;
  left:50%;
  top:-2px;                 /* выносим над лентой */
  transform:translateX(-50%);
  width:0;height:0;
  border-left:10px solid transparent;
  border-right:10px solid transparent;
  border-top:12px solid #f7c945; /* теперь стрелка смотрит ВНИЗ */
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.5));
  z-index:20; /* поверх всего в wrap */
}
.reel-center-line{
  position:absolute;top:0;bottom:0;left:50%;
  transform:translateX(-50%);
  width:2px;
  background:linear-gradient(to bottom, transparent, rgba(247,201,69,.35), transparent);
  z-index:15; pointer-events:none;
}

.reel-center-line{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:2px;background:linear-gradient(to bottom, transparent, rgba(247,201,69,.35), transparent)}

/* Результат */
.prize-result{margin-top:14px;padding:12px;border-radius:12px;background:#1d1d2e;display:none;align-items:center;gap:12px}
.prize-result img{width:60px;height:60px;object-fit:cover;border-radius:10px}

/* Список побед */
.wins{margin-top:24px}
.wins h3{margin:0 0 10px 0}
.wins-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.win-item{background:#121223;border:1px solid #2b2b41;border-radius:12px;padding:12px}
.win-item img{width:100%; object-fit:cover;border-radius:8px;}
.muted{opacity:.7}


/* Copy button (reuse across prize/wins) */
.copy-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;margin-left:8px;
  border:1px solid var(--nt-border);border-radius:8px;
  background:var(--nt-surface);cursor:pointer;
  transition:transform .15s, border-color .15s, box-shadow .15s;
}
.copy-btn:hover{ border-color:var(--nt-border-strong); box-shadow:0 4px 14px rgba(119,9,255,.18); transform:translateY(-1px) }
.copy-btn img{ width:24px;height:24px; display:block }
.copy-btn.copied{ transform:translateY(-1px) scale(1.03) }
.prize-code-row{ display:flex; align-items:center; gap:6px; }

/* Wins pagination (2 rows per page) */
.wins-pag{
  display:flex; gap:8px; justify-content:center; margin-top:8px;
}
.wins-pag button{
  min-width:32px;height:32px;border-radius:8px;
  border:1px solid var(--nt-border); background:var(--nt-surface); color:#fff;
  cursor:pointer; font-weight:700;
}
.wins-pag button.is-active{ background:linear-gradient(180deg,var(--nt-accent),var(--nt-accent-2)); border-color:transparent }
.wins-pag button:disabled{ opacity:.5; cursor:not-allowed }
.wins-pag .ellipsis{
  padding:0 4px;
  color:var(--nt-muted);
  font-weight:600;
  user-select:none;
  line-height:32px;
}

/* Toasts */
.nt-toast{
  position:fixed; top:18px; left:50%;
  transform:translateX(-50%) translateY(-10px);
  background:rgba(27,30,40,.98); color:#fff;
  border:1px solid var(--nt-border); border-radius:12px;
  padding:10px 14px; font-weight:800; z-index:10000;
  opacity:0; transition:opacity .2s ease, transform .2s ease;
  box-shadow:0 10px 30px rgba(0,0,0,.4);
}
.nt-toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
.nt-toast--ok{ outline:2px solid rgba(81,207,102,.4); }
.nt-toast--err{ outline:2px solid rgba(255,107,107,.4); }