/* ============================================================
   Колесо подарков ANAGRAN — стили
   Тёмная премиальная палитра: чёрный + золото + синий
   ============================================================ */

/* ===== FONTS — ANAGRAN (Oksana Sans family) ===== */
@font-face { font-family:'Oksana Sans'; src:url('assets/fonts/OksanaSans.otf') format('opentype'); font-weight:400; font-display:swap; }
@font-face { font-family:'Oksana Sans'; src:url('assets/fonts/OksanaSansDemiBold.otf') format('opentype'); font-weight:600; font-display:swap; }
@font-face { font-family:'Oksana Sans'; src:url('assets/fonts/OksanaSans-Bold.otf') format('opentype'); font-weight:700; font-display:swap; }
@font-face { font-family:'Oksana Sans Fat'; src:url('assets/fonts/oksanasansfat.otf') format('opentype'); font-weight:900; font-display:swap; }
@font-face { font-family:'Oksana Sans Compressed'; src:url('assets/fonts/OksanaSansCompressedDemiBold.otf') format('opentype'); font-weight:600; font-display:swap; }

/* ===== TOKENS ===== */
:root {
  --bg:        #0E0E10;
  --bg-soft:   #161719;
  --bg-deep:   #08080A;

  --gold:      #C9A24B;
  --gold-soft: #E2C079;
  --gold-deep: #9A7A32;

  --blue:      #16243F;
  --blue-soft: #1E3358;
  --seg-blue:  #16243F;
  --seg-blue-2:#1E3358;

  --ink:       #F4ECDE;
  --ink-muted: #B9B09C;
  --cream:     #F7F1E6;

  --radius:    18px;
  --shadow:    0 24px 60px rgba(0,0,0,.55);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Oksana Sans',system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(201,162,75,.16), transparent 60%),
    radial-gradient(900px 600px at 90% 110%, rgba(30,51,88,.4), transparent 60%),
    var(--bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100dvh;
}
.gold { color:var(--gold); }
.gold-grad {
  background:linear-gradient(100deg,var(--gold-soft),var(--gold));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* ===== HEADER (закреплённая верхняя строка) ===== */
.header {
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:flex-end;
  gap:10px; padding:10px clamp(14px,4vw,48px);
  background:rgba(14,14,16,.86); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(201,162,75,.18);
}
.header__logo {
  position:absolute; left:50%; transform:translateX(-50%);
  height:clamp(38px,7vw,56px); width:auto;
}
.header__link {
  flex:none;
  text-decoration:none; font-size:14px; font-weight:600; color:var(--cream);
  background:var(--blue-soft); border:1.5px solid var(--gold);
  border-radius:999px; padding:8px 18px; white-space:nowrap;
  transition:filter .2s ease, transform .2s ease;
}
.header__link:hover { filter:brightness(1.2); transform:translateY(-1px); }
.header__badge {
  flex:none;
  font-size:13px; letter-spacing:.04em; color:var(--gold);
  border:1px solid rgba(201,162,75,.45); border-radius:999px;
  padding:7px 16px; white-space:nowrap;
  background:rgba(201,162,75,.06);
}

/* ===== HERO ===== */
.hero { text-align:center; padding:clamp(10px,3vw,28px) 20px 4px; position:relative; z-index:2; }
.hero__title {
  font-family:'Oksana Sans',sans-serif; font-weight:700;
  font-size:clamp(32px,6.5vw,62px); line-height:1.06; letter-spacing:.005em;
}
.hero__lead {
  max-width:620px; margin:16px auto 0; color:var(--ink-muted);
  font-size:clamp(15px,2.2vw,18px); line-height:1.5;
}

/* ===== WHEEL ===== */
.stage {
  display:flex; flex-direction:column; align-items:center;
  padding:clamp(10px,3vw,28px) 16px 40px; position:relative; z-index:2;
}
.wheel-box {
  position:relative;
  width:min(86vw,520px); aspect-ratio:1;
  display:flex; align-items:center; justify-content:center;
}
/* указатель — монограмма G ANAGRAN (золото на тёмном) */
.pointer {
  position:absolute; top:-18px; left:50%; transform:translateX(-50%);
  z-index:7; width:clamp(50px,12vw,62px); height:clamp(50px,12vw,62px);
  border-radius:50%;
  background:radial-gradient(circle at 50% 35%,var(--blue-soft),#0c1830);
  display:flex; align-items:center; justify-content:center;
  border:2px solid var(--gold);
  box-shadow:0 6px 16px rgba(0,0,0,.55), 0 0 22px rgba(226,192,121,.4);
}
.pointer img {
  width:62%; height:62%; object-fit:contain;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));
}
/* остриё указателя вниз, в колесо */
.pointer::after {
  content:''; position:absolute; bottom:-14px; left:50%; transform:translateX(-50%);
  width:0; height:0;
  border-left:11px solid transparent; border-right:11px solid transparent;
  border-top:15px solid var(--gold);
  filter:drop-shadow(0 3px 3px rgba(0,0,0,.4));
}

/* салют */
#confetti {
  position:fixed; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:60;
}
/* обод */
.wheel-rim {
  position:absolute; inset:0; border-radius:50%;
  padding:10px;
  background:linear-gradient(145deg,var(--gold-soft),var(--gold-deep));
  box-shadow:0 0 0 2px rgba(0,0,0,.4), var(--shadow), 0 0 50px rgba(201,162,75,.25);
}
/* само колесо (вращается) */
.wheel {
  position:absolute; inset:10px; border-radius:50%;
  overflow:hidden;
  transition:transform 5s cubic-bezier(.12,.66,.16,1);
  will-change:transform;
}
.seg-divider {
  position:absolute; top:0; left:50%; height:50%;
  width:2px; background:rgba(201,162,75,.55); transform-origin:bottom center;
}
.seg-label {
  position:absolute; top:0; left:50%; height:50%;
  transform-origin:bottom center;
  display:flex; justify-content:center;
  cursor:pointer;
}
.seg-inner {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding-top:14px; width:96px; text-align:center;
  transition:transform .15s ease;
}
.seg-label:hover .seg-inner { transform:scale(1.08); }

/* «живая» пульсация банок на сенсорных экранах (где нет :hover) */
@keyframes segBreath {
  0%, 100% { transform:scale(1);    filter:brightness(1); }
  50%      { transform:scale(1.07); filter:brightness(1.14); }
}
@media (hover:none) {
  .seg-inner {
    animation:segBreath 2.6s ease-in-out infinite;
    animation-delay:var(--seg-d, 0s);
  }
  .seg-label:active .seg-inner { animation:none; transform:scale(1.12); filter:brightness(1.2); }
}
.seg-can {
  width:46px; height:60px; display:flex; align-items:center; justify-content:center;
}
.seg-can img { max-width:100%; max-height:100%; object-fit:contain;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.4)); }
.seg-can-ph {
  display:flex; align-items:center; justify-content:center;
  width:40px; height:54px; border-radius:6px;
  background:linear-gradient(160deg,#0c1526,#1b2f52);
  border:1px solid rgba(201,162,75,.5);
  font-size:9px; color:var(--gold-soft); font-weight:700; padding:3px; line-height:1.1;
}
.seg-name {
  font-size:10px; line-height:1.1; color:var(--cream); font-weight:600;
  max-width:92px; text-shadow:0 1px 2px rgba(0,0,0,.6);
}
.seg-badge {
  font-size:10px; font-weight:700; color:#0E0E10;
  background:var(--gold-soft); border-radius:999px; padding:1px 7px;
}
/* ступица + кнопка */
.hub {
  position:absolute; z-index:6;
  width:clamp(96px,22%,120px); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 50% 35%,var(--gold-soft),var(--gold-deep));
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.5), inset 0 0 0 3px rgba(0,0,0,.18);
  border:none; cursor:pointer; color:#0E0E10;
  font-family:'Oksana Sans',sans-serif; font-weight:700;
  font-size:clamp(13px,3.4vw,16px); line-height:1.1; text-align:center;
  padding:10px; transition:transform .15s ease, filter .15s ease;
}
.hub:hover:not(:disabled) { transform:scale(1.04); filter:brightness(1.06); }
.hub:active:not(:disabled) { transform:scale(.97); }
.hub:disabled { cursor:default; filter:grayscale(.4) brightness(.85); }

.spins {
  margin-top:22px; font-size:15px; color:var(--ink-muted);
}
.spins b { color:var(--gold-soft); font-size:18px; }

.back-link {
  display:inline-block; margin-top:16px;
  color:var(--cream); text-decoration:none; font-size:15px; font-weight:600;
  background:var(--blue-soft); border:1.5px solid var(--gold);
  border-radius:999px; padding:11px 26px;
  box-shadow:0 4px 14px rgba(0,0,0,.35);
  transition:filter .2s ease, transform .2s ease;
}
.back-link:hover {
  filter:brightness(1.2); transform:translateY(-1px);
}

/* ===== PRIZES ===== */
.prizes {
  max-width:760px; margin:0 auto; padding:0 16px 60px; position:relative; z-index:2;
}
.prizes__title {
  font-family:'Oksana Sans',sans-serif; font-weight:700; text-align:center;
  font-size:clamp(22px,4vw,32px); margin-bottom:20px;
}
.prizes__list { display:grid; gap:16px; }

/* ===== RESULT CARD (modal + prizes) ===== */
.result {
  display:flex; gap:18px; align-items:center;
  background:var(--cream); color:var(--blue);
  border-radius:var(--radius); padding:18px;
  border:1px solid rgba(201,162,75,.5);
}
.result--big { flex-direction:column; text-align:center; padding:24px; }
.result__can {
  flex:none; display:flex; align-items:center; justify-content:center;
  width:110px; height:140px;
}
.result--big .result__can { width:170px; height:210px; }
.result__can img { max-width:100%; max-height:100%; object-fit:contain;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.25)); }
.result__can .can-ph {
  display:flex; align-items:center; justify-content:center; text-align:center;
  width:100%; height:100%; border-radius:10px; padding:8px;
  background:linear-gradient(160deg,#0c1526,#1b2f52);
  color:var(--gold-soft); font-weight:700; font-size:13px; line-height:1.2;
}
.result__info { flex:1; min-width:0; }
.result--big .result__info { display:flex; flex-direction:column; align-items:center; }
.result__discount {
  display:inline-block; font-weight:700; font-size:14px; color:#0E0E10;
  background:linear-gradient(100deg,var(--gold-soft),var(--gold));
  border-radius:999px; padding:4px 14px; margin-bottom:8px;
}
.result__name { font-family:'Oksana Sans',sans-serif; font-size:clamp(19px,3vw,26px); font-weight:700; }
.result--big .result__name { font-size:clamp(22px,4vw,30px); }
.result__desc { color:#41506b; font-size:14px; line-height:1.45; margin:8px 0 14px; }
.result--big .result__desc { max-width:420px; }

.result__code {
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  background:#fff; border:1px dashed var(--gold-deep); border-radius:12px;
  padding:10px 12px; margin-bottom:12px;
}
.result__code-label { font-size:12px; color:#8a7a55; }
.result__code code {
  font-family:'Oksana Sans',monospace; font-weight:700; font-size:18px;
  letter-spacing:.06em; color:var(--blue);
}
.copy-btn {
  margin-left:auto; cursor:pointer; border:none; border-radius:8px;
  background:var(--gold); color:#0E0E10; font-weight:700; font-size:13px;
  padding:8px 14px; transition:filter .15s ease, background .2s ease;
  font-family:'Oksana Sans',sans-serif;
}
.copy-btn:hover { filter:brightness(1.06); }
.copy-btn.copied { background:#2e7d4f; color:#fff; }

.card-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background:var(--blue); color:var(--cream); text-decoration:none;
  font-weight:600; font-size:15px; border-radius:12px; padding:13px 22px;
  border:1px solid rgba(201,162,75,.55); transition:filter .15s ease, transform .15s ease;
}
.card-btn:hover { filter:brightness(1.18); transform:translateY(-1px); }
.result__terms { font-size:12px; color:#8a7a55; margin-top:12px; }

/* ===== MODAL ===== */
.modal {
  position:fixed; inset:0; z-index:50; display:none;
  align-items:center; justify-content:center; padding:18px;
  background:rgba(8,8,10,.78); backdrop-filter:blur(4px);
}
.modal.open { display:flex; animation:fade .25s ease; }
@keyframes fade { from{opacity:0} to{opacity:1} }
.modal__inner {
  position:relative; width:min(440px,96vw);
  background:var(--cream); border-radius:22px; padding:26px 22px 24px;
  box-shadow:var(--shadow); border:1px solid rgba(201,162,75,.6);
  animation:pop .3s cubic-bezier(.2,.8,.25,1);
}
@keyframes pop { from{transform:scale(.92);opacity:0} to{transform:scale(1);opacity:1} }
.modal__win {
  text-align:center; font-family:'Oksana Sans',sans-serif; font-weight:700; color:var(--gold-deep);
  font-size:clamp(20px,4vw,26px); margin-bottom:6px;
}
.modal__inner .result { border:none; background:transparent; padding:6px 0 0; }
.modal__close {
  position:absolute; top:10px; right:12px; cursor:pointer;
  width:34px; height:34px; border-radius:50%; border:none;
  background:rgba(22,36,63,.08); color:var(--blue); font-size:20px; line-height:1;
}
.modal__close:hover { background:rgba(22,36,63,.16); }

/* ===== PREVIEW (клик по сектору) ===== */
.preview { text-align:center; color:var(--blue); display:flex; flex-direction:column; align-items:center; }
.preview__can {
  width:150px; height:185px; display:flex; align-items:center; justify-content:center; margin:4px 0 10px;
}
.preview__can img { max-width:100%; max-height:100%; object-fit:contain;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.25)); }
.preview__can .can-ph {
  display:flex; align-items:center; justify-content:center; text-align:center;
  width:100%; height:100%; border-radius:10px; padding:8px;
  background:linear-gradient(160deg,#0c1526,#1b2f52);
  color:var(--gold-soft); font-weight:700; font-size:13px;
}
.preview__title {
  font-family:'Oksana Sans',sans-serif; font-weight:700;
  font-size:clamp(18px,3.4vw,22px); line-height:1.25; margin-bottom:6px;
}
.preview__spin {
  color:var(--gold-deep); font-weight:700; font-size:15px; margin-bottom:10px;
}
.preview__desc { color:#41506b; font-size:14px; line-height:1.45; max-width:420px; margin-bottom:16px; }

/* ===== FAQ ===== */
.faq {
  max-width:760px; margin:0 auto; padding:10px 16px 50px; position:relative; z-index:2;
}
.faq__title {
  font-family:'Oksana Sans',sans-serif; font-weight:700; text-align:center;
  font-size:clamp(24px,4.5vw,34px); margin-bottom:22px;
}
.faq__item {
  border:1px solid rgba(201,162,75,.28); border-radius:14px;
  background:rgba(255,255,255,.03);
  margin-bottom:12px; overflow:hidden;
  transition:border-color .2s ease, background .2s ease;
}
.faq__item[open] { border-color:rgba(201,162,75,.6); background:rgba(201,162,75,.05); }
.faq__item summary {
  list-style:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:16px 20px; font-size:clamp(15px,2.4vw,17px); font-weight:600; color:var(--ink);
}
.faq__item summary::-webkit-details-marker { display:none; }
.faq__item summary::after {
  content:'+'; flex:none;
  font-size:24px; line-height:1; color:var(--gold-soft);
  transition:transform .25s ease;
}
.faq__item[open] summary::after { content:'–'; }
.faq__a {
  padding:0 20px 18px; color:var(--ink-muted); font-size:15px; line-height:1.55;
}
.faq__item a, .faq__a a { color:var(--gold-soft); }

/* ===== FOOTER ===== */
.footer {
  border-top:1px solid rgba(201,162,75,.18);
  padding:28px clamp(16px,4vw,48px) 40px; color:var(--ink-muted);
  font-size:13px; line-height:1.6; max-width:900px; margin:0 auto;
}
.footer b { color:var(--ink); }

/* ===== RESPONSIVE ===== */
@media (max-width:560px) {
  .header { gap:6px; padding:8px 12px; }
  .header__badge { font-size:11px; letter-spacing:0; padding:5px 9px; }
  .header__link { font-size:12px; padding:6px 12px; }
  .header__logo { height:32px; }
  .result { flex-direction:column; text-align:center; }
  .result__info { align-items:center; display:flex; flex-direction:column; }
  .copy-btn { margin-left:0; }
  /* на мобильном — только банки, без подписей (чтобы не налезали у центра) */
  .seg-name { display:none; }
  .seg-inner { width:64px; padding-top:18px; }
  .seg-can { width:50px; height:64px; }
}
