/* ============================================
   RESET & VARIABLES
   ============================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}

:root{
  /* Brand */
  --white:#fff;
  --off-white:#f5f7fa;
  --cream:#eef1f6;
  --light-gray:#dde2ea;
  --mid-gray:#8892a4;
  --dark:#1a1d2e;
  --darker:#12142a;
  --black:#0c0e1a;

  --fire:#ff4d1c;
  --fire-light:#ff6b3d;
  --fire-dark:#e0400f;
  --fire-glow:rgba(255,77,28,.12);
  --fire-glow-strong:rgba(255,77,28,.28);

  --electric:#2563eb;
  --electric-light:#3b82f6;

  --lime:#22c55e;
  --lime-soft:rgba(34,197,94,.12);

  --amber:#f59e0b;
  --red:#ef4444;
  --purple:#8b5cf6;
  --pink:#ec4899;

  /* Surface tokens for dark theme */
  --surface-1:rgba(255,255,255,.04);
  --surface-2:rgba(255,255,255,.07);
  --surface-3:rgba(255,255,255,.10);
  --border-1:rgba(255,255,255,.08);
  --border-2:rgba(255,255,255,.14);
  --text-1:#fff;
  --text-2:rgba(255,255,255,.72);
  --text-3:rgba(255,255,255,.5);
  --text-4:rgba(255,255,255,.32);

  /* Typography */
  --font-display:'Unbounded',sans-serif;
  --font-body:'Nunito Sans',sans-serif;

  /* Radii */
  --r-sm:8px;
  --r-md:14px;
  --r-lg:20px;
  --r-xl:28px;
  --r-full:9999px;

  /* Shadows */
  --shadow-sm:0 1px 3px rgba(0,0,0,.18),0 1px 2px rgba(0,0,0,.24);
  --shadow-md:0 4px 16px rgba(0,0,0,.22),0 2px 4px rgba(0,0,0,.18);
  --shadow-lg:0 12px 40px rgba(0,0,0,.32),0 4px 12px rgba(0,0,0,.22);
  --shadow-xl:0 24px 64px rgba(0,0,0,.4),0 8px 20px rgba(0,0,0,.25);
  --shadow-fire:0 8px 32px rgba(255,77,28,.35),0 2px 8px rgba(255,77,28,.18);

  /* Easing */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(0,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --ease-wheel:cubic-bezier(.18,.85,.18,1);

  /* Layout */
  --tab-h:64px;
  --header-h:60px;

  /* ─── REEL responsive sizing ───
     Барабан Колеса Фортуны адаптируется под высоту вьюпорта.
     Дефолт = 3 слота (как было; safety-net для маленьких экранов типа SE).
     На более высоких вьюпортах media queries ниже переопределяют:
       ≥ 720px  →  4 слота (centerSlotIdx=1, целевой слот вверху-середине)
       ≥ 820px  →  5 слотов (centerSlotIdx=2, истинный центр)
     JS (app.js → REEL.centerSlotIdx) читает --reel-center-idx и центрирует
     карточку приза в нужном слоте. CSS .reel-highlight тоже привязан к этой
     же переменной — гарантия, что подсветка ВСЕГДА совпадает со слотом-победителем.

     ⚠ Не меняй здесь без синхронного обновления JS. */
  --reel-card-h:96px;
  --reel-gap:8px;
  --reel-pad-y:4px;
  --reel-visible:3;
  --reel-center-idx:1;
}

/* Responsive — больше слотов на более высоких вьюпортах.
   720px нижняя граница ~ iPhone SE 3 (667px) → остаётся 3 слота.
   720-800px ~ iPhone 8/13 mini в expanded TG → 4 слота.
   ≥ 800px ~ iPhone 12+ / Android flagship в expanded TG → 5 слотов. */
@media (min-height: 720px) {
  :root { --reel-visible:4; --reel-center-idx:1; }
}
@media (min-height: 820px) {
  :root { --reel-visible:5; --reel-center-idx:2; }
}

html{scroll-behavior:smooth;background:var(--darker)}
body{
  font-family:var(--font-body);
  background:var(--darker);
  color:var(--text-1);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100vh;
  position:relative;
}
body::before{
  content:'';position:fixed;inset:0;
  background:
    radial-gradient(ellipse at top right,rgba(255,77,28,.10) 0%,transparent 55%),
    radial-gradient(ellipse at bottom left,rgba(37,99,235,.08) 0%,transparent 55%);
  pointer-events:none;
  z-index:0;
}
::selection{background:rgba(255,77,28,.3)}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}

.mi{
  font-family:'Material Symbols Rounded';
  font-weight:normal;font-style:normal;font-size:24px;
  display:inline-block;vertical-align:middle;line-height:1;
  font-variation-settings:'FILL' 1,'wght' 400,'GRAD' 0,'opsz' 24;
  -webkit-font-feature-settings:'liga';font-feature-settings:'liga';
  user-select:none;
}

/* ============================================
   LAYOUT
   ============================================ */
.container{padding:0 18px;max-width:560px;margin:0 auto}

.app-header{
  position:sticky;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:max(env(safe-area-inset-top),8px) 16px 8px;
  background:rgba(18,20,42,.85);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-1);
  height:calc(var(--header-h) + env(safe-area-inset-top));
}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--fire),var(--fire-dark));
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  box-shadow:var(--shadow-fire);
}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-name{font-family:var(--font-display);font-size:13px;font-weight:800;color:#fff}
.brand-sub{font-size:10px;color:var(--text-3);font-weight:500;letter-spacing:.4px}

.settings-btn{
  width:38px;height:38px;border-radius:50%;
  background:var(--surface-2);
  border:1px solid var(--border-1);
  color:var(--text-2);
  display:flex;align-items:center;justify-content:center;
  transition:all .25s var(--ease);
}
.settings-btn:hover,.settings-btn:active{background:var(--surface-3);color:var(--fire-light);border-color:var(--fire-glow-strong)}
.settings-btn .mi{font-size:20px}

/* ============================================
   SCREENS / TABS
   ============================================ */
.screens{
  position:relative;z-index:1;
  padding-top:24px;
  padding-bottom:calc(var(--tab-h) + env(safe-area-inset-bottom) + 24px);
  min-height:calc(100vh - var(--header-h));
}
.screen{display:none;animation:fadeUp .45s var(--ease-out) both}
.screen--active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.screen-head{margin-bottom:24px;text-align:left}
.eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-size:10px;font-weight:700;
  letter-spacing:1.8px;text-transform:uppercase;
  color:var(--fire-light);
  background:var(--fire-glow);
  border:1px solid var(--fire-glow-strong);
  padding:5px 11px;border-radius:var(--r-full);
  margin-bottom:14px;
}
.eyebrow .mi{font-size:14px}
.heading{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(22px,6vw,28px);line-height:1.2;letter-spacing:-.5px;
  color:#fff;margin-bottom:10px;
}
.heading-sm{
  font-family:var(--font-display);font-weight:800;
  font-size:20px;line-height:1.25;letter-spacing:-.3px;
  color:#fff;margin-bottom:8px;
}
.heading .hl,.heading-sm .hl{color:var(--fire)}
.subtext{font-size:14px;color:var(--text-3);line-height:1.65;max-width:520px}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-display);font-size:13px;font-weight:700;
  border-radius:var(--r-full);padding:14px 22px;
  letter-spacing:.3px;white-space:nowrap;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease);
  -webkit-user-select:none;user-select:none;
}
.btn .mi{font-size:18px;transition:transform .25s var(--ease)}
.btn:active{transform:scale(.97)}
.btn-fire{
  background:var(--fire);color:#fff;
  box-shadow:var(--shadow-fire);
}
.btn-fire:hover{background:var(--fire-dark)}
.btn-outline{
  background:transparent;color:var(--text-1);
  border:1.5px solid var(--border-2);
}
.btn-outline:hover{border-color:var(--fire);color:var(--fire-light)}
.btn-ghost{
  background:var(--surface-2);color:var(--text-2);
  border:1px solid var(--border-1);
}
.btn-ghost:hover{background:var(--surface-3);color:#fff}
.btn-sm{padding:10px 16px;font-size:11.5px}
.btn-full{width:100%}
.btn-spin{
  width:100%;
  padding:18px 28px;font-size:14px;
  letter-spacing:1px;text-transform:uppercase;
  /* AUDIT-FIX 2026-05-27: разрешаем перенос на узких viewports (≤380px),
     иначе длинный текст «Крутить (последняя попытка)» вылезает за viewport. */
  white-space:normal;line-height:1.15;
}
/* На узких экранах (iPhone SE/мини и Android 360px) сжимаем кнопку:
   меньше padding/letter-spacing, чтобы текст уверенно помещался. */
@media (max-width:400px){
  .btn-spin{
    padding:16px 14px;
    font-size:12.5px;
    letter-spacing:.4px;
  }
}

/* Disabled-состояние любой кнопки (.btn) — opacity + not-allowed cursor,
   отменяем :active transform чтобы не было «нажимается» при клике.
   Главный кейс — кнопка «Крутить колесо» во время крутки (4-й слой защиты
   от двойного клика, верхний — JS State.spinning, Idempotency-Key, server tx). */
.btn:disabled,
.btn:disabled:hover,
.btn:disabled:active{
  opacity:.6;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}
/* Крутящаяся иконка ⟳ на .btn-spin когда колесо вращается. Анимация
   независима от :is-spinning у .reel — оба активируются JS одновременно. */
.btn-spin.is-spinning .mi{
  animation:btnSpinIcon 1.1s linear infinite;
}
@keyframes btnSpinIcon{
  to{transform:rotate(360deg)}
}

/* ============================================
   ATTEMPTS BAR (счётчик-цифра)
   ============================================ */
.attempts-bar{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:linear-gradient(135deg,rgba(255,77,28,.14),rgba(255,77,28,.04));
  border:1px solid var(--fire-glow-strong);
  border-radius:var(--r-lg);
  padding:12px 18px;margin-bottom:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.attempts-label{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:12px;font-weight:700;
  color:#fff;letter-spacing:.4px;
}
.attempts-label .mi{font-size:18px;color:var(--fire-light)}
.attempts-counter{
  display:flex;align-items:baseline;gap:2px;
  font-family:var(--font-display);font-variant-numeric:tabular-nums;
  letter-spacing:-.5px;
}
.att-num{
  font-size:28px;font-weight:900;color:#fff;
  text-shadow:0 0 14px rgba(255,77,28,.5);
  transition:transform .35s var(--ease-spring),color .25s var(--ease);
}
.att-num.is-pop{animation:numPop .45s var(--ease-spring)}
@keyframes numPop{0%{transform:scale(1)}40%{transform:scale(1.4);color:var(--fire-light)}100%{transform:scale(1)}}
.att-num.is-zero{color:var(--text-4);text-shadow:none}
.att-sep{font-size:18px;font-weight:700;color:var(--text-3)}
.att-max{font-size:18px;font-weight:700;color:var(--text-3)}

/* ============================================
   REEL (вертикальный слот-ролик)
   ============================================ */
.reel{
  position:relative;
  margin:4px 0 22px;
  display:flex;align-items:center;gap:8px;
  padding-left:0;
}
.reel-window{
  position:relative;flex:1;
  /* Высота = (visible × card-h) + ((visible-1) × gap) + (2 × pad-y).
     При --reel-visible=3 → 3×96 + 2×8 + 2×4 = 312px (legacy default).
     При --reel-visible=4 → 4×96 + 3×8 + 2×4 = 416px (medium).
     При --reel-visible=5 → 5×96 + 4×8 + 2×4 = 520px (large). */
  height:calc(
    var(--reel-visible) * var(--reel-card-h)
    + (var(--reel-visible) - 1) * var(--reel-gap)
    + 2 * var(--reel-pad-y)
  );
  border-radius:var(--r-xl);
  background:
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02)),
    var(--darker);
  border:1px solid var(--border-2);
  overflow:hidden;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    inset 0 30px 40px -20px rgba(0,0,0,.6),
    inset 0 -30px 40px -20px rgba(0,0,0,.6),
    0 18px 40px rgba(0,0,0,.4);
  /* Маска для затемнения краёв — эффект «колесо» */
  -webkit-mask-image:linear-gradient(180deg,transparent 0%,#000 18%,#000 82%,transparent 100%);
  mask-image:linear-gradient(180deg,transparent 0%,#000 18%,#000 82%,transparent 100%);
}
.reel-strip{
  position:absolute;top:0;left:0;right:0;
  display:flex;flex-direction:column;
  padding:4px 10px;gap:8px;
  transform:translateY(0);
  will-change:transform;
}
.reel.is-spinning .reel-strip{filter:blur(.6px)}
.reel.is-stopping .reel-strip{filter:none;transition:filter .25s ease}

/* Подсветка центрального слота — позиционирована ТОЧНО над слотом,
   чьим индексом является --reel-center-idx (0-based от верха страйпа).
   Это гарантирует, что подсветка всегда совпадает со слотом-победителем
   при любом количестве видимых слотов (3, 4 или 5).
   Формула: top = center-idx × (card-h + gap) + pad-y. */
.reel-highlight{
  position:absolute;left:6px;right:6px;
  top:calc(
    var(--reel-center-idx) * (var(--reel-card-h) + var(--reel-gap))
    + var(--reel-pad-y)
  );
  height:var(--reel-card-h);
  border-radius:var(--r-lg);
  border:2px solid var(--fire);
  box-shadow:
    0 0 0 4px rgba(255,77,28,.18),
    0 0 24px rgba(255,77,28,.45),
    inset 0 0 24px rgba(255,77,28,.08);
  pointer-events:none;
  z-index:3;
}

/* Стрелка-указатель слева (одна).
   Должна указывать ИМЕННО на центр слота-победителя (slot index = --reel-center-idx).
   Через align-self/margin-top отвязываемся от align-items:center родительского .reel,
   которое раньше центрировало стрелку по середине ВСЕГО окна — для 3-слотного режима
   это совпадало с центром победителя, но при 4/5 слотах стрелка съезжала.

   Формула margin-top = центр-слота-Y минус половина-высоты-стрелки:
     center-Y  = center-idx × (card-h + gap) + pad-y + card-h/2
     margin-top = center-Y - 34/2
                = center-idx × 104 + 4 + (96 - 34)/2
                = center-idx × 104 + 35
   Проверка:
     3-слот (center=1) → 139px → центр стрелки на y=156 = центр slot 1 ✓
     4-слот (center=1) → 139px → центр стрелки на y=156 = центр slot 1 ✓
     5-слот (center=2) → 243px → центр стрелки на y=260 = центр slot 2 ✓ */
.reel-pointer{
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--fire),var(--fire-dark));
  border-radius:50%;
  box-shadow:0 4px 16px rgba(255,77,28,.55),inset 0 -2px 4px rgba(0,0,0,.2);
  flex-shrink:0;
  z-index:5;position:relative;
  animation:pointerPulse 1.6s ease-in-out infinite;
  align-self:flex-start;
  margin-top:calc(
    var(--reel-center-idx) * (var(--reel-card-h) + var(--reel-gap))
    + var(--reel-pad-y)
    + (var(--reel-card-h) - 34px) / 2
  );
}
.reel-pointer .mi{font-size:22px;color:#fff;font-variation-settings:'FILL' 1;margin-left:2px}
@keyframes pointerPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.14)}
}
.reel.is-spinning .reel-pointer{animation:none;opacity:.6}

/* Карточка приза в страйпе */
.reel-card{
  display:flex;align-items:center;gap:12px;
  height:96px;flex-shrink:0;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border-1);
  border-radius:var(--r-lg);
  padding:12px 14px;
  position:relative;overflow:hidden;
}
.reel-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--card-tint,transparent) 0%,transparent 60%);
  opacity:.5;pointer-events:none;
}
.reel-icon{
  width:64px;height:64px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:#fff;
  box-shadow:0 6px 16px rgba(0,0,0,.3),inset 0 -3px 6px rgba(0,0,0,.18);
  position:relative;z-index:1;
}
.reel-icon .mi{font-size:30px}
.reel-body{flex:1;min-width:0;position:relative;z-index:1}
.reel-title{
  font-family:var(--font-display);font-size:13.5px;font-weight:800;
  color:#fff;line-height:1.25;margin-bottom:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:-.2px;
}
.reel-desc{
  font-size:11.5px;color:var(--text-3);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.reel-badge{
  font-family:var(--font-display);font-size:10px;font-weight:800;
  padding:5px 10px;border-radius:var(--r-full);
  letter-spacing:.6px;flex-shrink:0;
  position:relative;z-index:1;
  border:1px solid currentColor;
  align-self:flex-start;
}

.wheel-actions{margin-bottom:24px}

/* ============================================
   WHEEL SCREEN — ULTRA-COMPACT HERO (fits in viewport)
   Заменяет старые screen-head + attempts-bar одним 50px-блоком.
   Цель: на 360×640 viewport (минимум для мобилы в TG) reel + кнопка
   видны без скролла. Считалось так: hero 50px + reel 312px + gap 18px
   + button 58px + main padding 16+24px ≈ 478px. Запас ~150px на bottom
   nav и safe-area.
   ============================================ */
.wheel-container{padding-top:0} /* main.padding-top уже даёт сверху */
.wheel-hero{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  padding:10px 16px 10px 14px;
  margin-bottom:14px;
  background:linear-gradient(135deg,rgba(255,77,28,.14),rgba(255,77,28,.03));
  border:1px solid var(--fire-glow-strong);
  border-radius:var(--r-lg);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  min-height:50px;
}
.wheel-hero-title{
  display:flex;align-items:center;gap:9px;
  font-family:var(--font-display);
  font-size:14px;font-weight:800;
  color:#fff;
  letter-spacing:.4px;
  text-transform:uppercase;
  min-width:0;
}
.wheel-hero-title .mi{
  font-size:22px;color:var(--fire-light);
  flex-shrink:0;
  font-variation-settings:'FILL' 1;
}
.wheel-hero-title>span:last-child{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.wheel-hero-attempts{
  display:flex;align-items:baseline;gap:3px;
  font-family:var(--font-display);
  font-variant-numeric:tabular-nums;
  flex-shrink:0;
}
.wheel-hero-attempts .mi{
  font-size:18px;color:var(--fire-light);
  margin-right:4px;align-self:center;
  font-variation-settings:'FILL' 1;
}
/* .att-num уже стилизован выше — используем тот же CSS для consistent animation */
.wheel-hero .att-num{
  font-size:22px;font-weight:900;color:#fff;
  text-shadow:0 0 12px rgba(255,77,28,.5);
  transition:transform .35s var(--ease-spring),color .25s var(--ease);
}
.wheel-hero .att-sep{font-size:15px;font-weight:700;color:var(--text-3)}
.wheel-hero .att-max{font-size:15px;font-weight:700;color:var(--text-3)}

/* Сжимаем margin'ы wheel-блоков внутри wheel-container */
.wheel-container .reel{margin:0 0 16px}
.wheel-container .wheel-actions{margin-bottom:8px}

/* AUDIT-FIX 2026-05-27: на 360-400px (большинство Android) hero-блок упирался —
   текст «КОЛЕСО ФОРТУНЫ» с uppercase+letter-spacing+иконкой+счётчиком не помещался
   в одну строку → срабатывал text-overflow:ellipsis → юзер видел «КОЛЕСО ФОРТУН...».
   Уменьшаем font-size + gap + letter-spacing, чтобы заголовок умещался целиком. */
@media(max-width:400px){
  .wheel-hero{padding:8px 12px;gap:8px}
  .wheel-hero-title{font-size:12px;letter-spacing:.2px;gap:7px}
  .wheel-hero-title .mi{font-size:18px}
  .wheel-hero-attempts{gap:2px}
  .wheel-hero-attempts .mi{font-size:16px;margin-right:2px}
  .wheel-hero .att-num{font-size:18px}
  .wheel-hero .att-sep,.wheel-hero .att-max{font-size:13px}
}
/* На совсем узких (<340px iPhone SE 1st gen) — переносим attempts ниже title */
@media(max-width:340px){
  .wheel-hero{flex-direction:column;align-items:flex-start;gap:4px;padding:10px 14px}
  .wheel-hero-title{font-size:13px}
  .wheel-hero-attempts{align-self:flex-end;margin-top:-22px}
}

/* ============================================
   FREEBIES LIST
   ============================================ */
.freebies-list{display:flex;flex-direction:column;gap:12px}
.freebie-card{
  display:flex;align-items:center;gap:14px;
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-lg);
  padding:16px;
  transition:all .25s var(--ease);
  position:relative;overflow:hidden;
}
.freebie-card::before{
  content:'';position:absolute;top:0;left:0;width:4px;height:100%;
  background:var(--accent,var(--lime));
}
.freebie-card:hover,.freebie-card:active{
  background:var(--surface-2);
  border-color:var(--border-2);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.freebie-icon{
  width:60px;height:60px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.3);
}
.freebie-icon .mi{font-size:30px}
.freebie-image{
  width:60px;height:60px;border-radius:var(--r-md);
  flex-shrink:0;overflow:hidden;
  background:var(--surface-2);
  box-shadow:0 6px 18px rgba(0,0,0,.3);
}
.freebie-image img{width:100%;height:100%;object-fit:cover;display:block}
.freebie-body{flex:1;min-width:0}
.freebie-tag{
  display:inline-block;
  font-family:var(--font-display);font-size:9px;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;
  padding:3px 8px;border-radius:var(--r-full);
  color:var(--accent,var(--lime));
  background:var(--accent-bg,rgba(34,197,94,.15));
  margin-bottom:4px;
}
.freebie-title{font-family:var(--font-display);font-size:14px;font-weight:800;color:#fff;line-height:1.25;margin-bottom:3px}
.freebie-desc{font-size:12px;color:var(--text-3);line-height:1.45}
.freebie-btn{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--font-display);font-size:11px;font-weight:800;
  padding:10px 14px;border-radius:var(--r-full);
  background:var(--fire);color:#fff;
  letter-spacing:.4px;text-transform:uppercase;
  box-shadow:var(--shadow-fire);
  transition:transform .2s var(--ease),background .25s var(--ease);
  white-space:nowrap;
}
.freebie-btn .mi{font-size:14px}
.freebie-btn:active{transform:scale(.95)}
.freebie-btn:hover{background:var(--fire-dark)}

@media(max-width:380px){
  .freebie-card{flex-wrap:wrap}
  .freebie-btn{width:100%;justify-content:center;margin-top:6px}
}


/* ============================================
   PRODUCTS
   ============================================ */
.products-list{display:flex;flex-direction:column;gap:14px}
.product-card{
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-lg);
  padding:14px;
  display:flex;gap:14px;align-items:stretch;
  transition:all .3s var(--ease);
  position:relative;overflow:hidden;
}
.product-card:hover,.product-card:active{
  background:var(--surface-2);
  border-color:var(--border-2);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

/* Обложка-постер курса */
.product-cover{
  width:104px;height:104px;flex-shrink:0;
  border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--cover-1,#ff4d1c),var(--cover-2,#ff8a50));
  position:relative;overflow:hidden;
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:10px;
  box-shadow:0 8px 22px rgba(0,0,0,.35),inset 0 -3px 8px rgba(0,0,0,.18);
}
.product-cover::before{
  content:'';position:absolute;
  width:90px;height:90px;border-radius:50%;
  background:rgba(255,255,255,.18);
  top:-34px;right:-32px;
}
.product-cover::after{
  content:'';position:absolute;
  width:42px;height:42px;border-radius:50%;
  border:2px solid rgba(255,255,255,.28);
  bottom:-12px;right:18px;
}
.product-cover-icon{
  position:absolute;top:14px;left:12px;
  font-family:'Material Symbols Rounded';
  font-size:38px;color:#fff;line-height:1;z-index:1;
  font-variation-settings:'FILL' 1;
  text-shadow:0 4px 14px rgba(0,0,0,.3);
}
.product-cover-emoji{
  position:absolute;bottom:8px;left:10px;
  font-size:22px;line-height:1;z-index:1;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));
}
.product-cover-tag{
  position:absolute;top:8px;right:8px;
  font-family:var(--font-display);font-size:8.5px;font-weight:800;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(6px);
  color:#fff;letter-spacing:.6px;
  padding:3px 7px;border-radius:var(--r-full);
  z-index:2;text-transform:uppercase;
}
/* Обложка-картинка (опц.) — рендерится поверх градиента и скрывает декоративные круги */
.product-cover-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:0;border-radius:var(--r-md);
}
.product-cover.has-image::before,
.product-cover.has-image::after{display:none}
.product-cover.has-image .product-cover-tag{
  background:rgba(0,0,0,.6);
}

.product-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.product-title{font-family:var(--font-display);font-size:14px;font-weight:800;color:#fff;line-height:1.25;letter-spacing:-.2px}
.product-desc{font-size:12px;color:var(--text-3);line-height:1.45;margin-bottom:6px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.product-actions{display:flex;align-items:center;gap:10px;margin-top:auto}
.product-link{
  font-family:var(--font-display);font-size:11px;font-weight:700;
  color:var(--fire-light);
  display:inline-flex;align-items:center;gap:4px;
  letter-spacing:.4px;
}
.product-link .mi{font-size:14px;transition:transform .2s var(--ease)}
.product-link:hover .mi{transform:translateX(3px)}
.product-soon{
  font-size:10.5px;color:var(--text-4);
  font-style:italic;
  display:inline-flex;align-items:center;gap:4px;
}
.product-soon .mi{font-size:14px}

@media(max-width:380px){
  .product-cover{width:88px;height:88px}
  .product-cover-icon{font-size:30px}
}

/* ============================================
   PERSONAL WORK (1-on-1 premium)
   ============================================ */
.personal-tiers{
  display:flex;flex-direction:column;gap:14px;
}
.personal-tier{
  --tier-color:#ff4d1c;
  --tier-color-light:#ff8a50;
  position:relative;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,rgba(255,255,255,.025) 100%);
  border:1px solid var(--border-1);
  border-radius:var(--r-xl);
  overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.personal-tier::before{
  content:'';position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--tier-color),var(--tier-color-light));
  opacity:.85;
}
.personal-tier:hover,.personal-tier:active{
  transform:translateY(-2px);
  box-shadow:0 14px 38px rgba(0,0,0,.32);
  border-color:var(--border-2);
}
.personal-tier--featured{
  border-color:var(--fire-glow-strong);
  box-shadow:0 10px 36px rgba(255,77,28,.22),0 2px 6px rgba(255,77,28,.12);
}
.personal-tier--featured::before{
  height:4px;
  box-shadow:0 0 18px rgba(255,77,28,.55);
}
.personal-tier-cover{
  position:relative;
  padding:18px 18px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.personal-tier-cover .mi{
  font-size:38px;
  color:var(--tier-color-light);
  filter:drop-shadow(0 6px 16px rgba(0,0,0,.4));
  flex-shrink:0;
}
.personal-tier-tag{
  font-family:var(--font-display);
  font-size:10.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.6px;
  padding:6px 10px;
  border-radius:var(--r-full);
  background:rgba(255,255,255,.08);
  color:var(--text-2);
  border:1px solid var(--border-1);
  white-space:nowrap;
}
.personal-tier--featured .personal-tier-tag{
  background:linear-gradient(135deg,var(--fire),var(--fire-light));
  color:#fff;
  border-color:transparent;
  box-shadow:0 4px 14px rgba(255,77,28,.4);
}
.personal-tier-body{
  padding:0 18px 18px;
  display:flex;flex-direction:column;gap:10px;
}
.personal-tier-title{
  font-family:var(--font-display);
  font-size:18px;font-weight:800;
  color:#fff;line-height:1.2;letter-spacing:-.3px;
}
.personal-tier-desc{
  font-size:13.5px;color:var(--text-3);line-height:1.55;
}
.personal-tier-features{
  list-style:none;display:flex;flex-direction:column;gap:7px;
  padding:10px 0 4px;
}
.personal-tier-features li{
  display:flex;align-items:flex-start;gap:9px;
  font-size:13px;color:var(--text-2);line-height:1.45;
}
.personal-tier-features .mi{
  font-size:18px;
  color:var(--tier-color-light);
  flex-shrink:0;margin-top:1px;
}
.personal-tier-meta{
  display:flex;align-items:center;gap:6px;
  margin-top:6px;padding-top:12px;
  border-top:1px dashed var(--border-1);
  font-size:11.5px;color:var(--text-4);
  font-weight:600;
}
.personal-tier-meta .mi{font-size:14px}

/* Steps */
.personal-steps{
  list-style:none;
  display:flex;flex-direction:column;gap:0;
  padding:4px 0;
  counter-reset:step;
  position:relative;
}
.personal-step{
  display:flex;gap:14px;
  padding:10px 0;
  position:relative;
}
.personal-step:not(:last-child)::before{
  content:'';position:absolute;
  left:21px;top:48px;bottom:-4px;
  width:2px;
  background:linear-gradient(180deg,var(--border-2) 0%,var(--border-1) 60%,transparent 100%);
  border-radius:2px;
}
.personal-step-num{
  position:relative;flex-shrink:0;
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,rgba(255,77,28,.18),rgba(255,77,28,.06));
  border:1px solid var(--fire-glow-strong);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(255,77,28,.18);
}
.personal-step-n{
  font-family:var(--font-display);
  font-size:16px;font-weight:900;color:#fff;
}
.personal-step-icon{
  position:absolute;
  bottom:-6px;right:-6px;
  width:22px;height:22px;border-radius:50%;
  background:var(--fire);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:13px !important;
  box-shadow:0 3px 10px rgba(255,77,28,.45);
  border:2px solid var(--darker);
}
.personal-step-body{padding-top:4px;flex:1;min-width:0}
.personal-step-title{
  font-family:var(--font-display);
  font-size:15px;font-weight:800;color:#fff;
  line-height:1.25;letter-spacing:-.2px;
  margin-bottom:3px;
}
.personal-step-desc{
  font-size:13px;color:var(--text-3);line-height:1.5;
}

/* CTA */
.personal-cta{
  margin-top:28px;
  padding:20px 18px;
  background:
    radial-gradient(ellipse at top right,rgba(255,77,28,.16) 0%,transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid var(--fire-glow-strong);
  border-radius:var(--r-xl);
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 10px 36px rgba(0,0,0,.3);
}
.personal-cta-head{
  display:flex;align-items:flex-start;gap:12px;
}
.personal-cta-head > .mi{
  flex-shrink:0;
  font-size:30px;
  color:var(--fire-light);
  filter:drop-shadow(0 4px 12px rgba(255,77,28,.35));
}
.personal-cta-title{
  font-family:var(--font-display);
  font-size:18px;font-weight:800;color:#fff;
  line-height:1.2;letter-spacing:-.3px;
  margin-bottom:4px;
}
.personal-cta-sub{
  font-size:13px;color:var(--text-3);line-height:1.5;
}
.personal-cta-note{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;color:var(--text-4);
  font-weight:600;letter-spacing:.1px;
  justify-content:center;
}
.personal-cta-note .mi{font-size:14px;color:var(--lime)}

@media(prefers-reduced-motion:reduce){
  .personal-tier,.personal-tier:hover,.personal-tier:active{transition:none;transform:none}
}

/* ============================================
   PROFILE
   ============================================ */
.profile-card{
  text-align:center;
  padding:24px 16px 20px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid var(--border-1);
  border-radius:var(--r-xl);
  position:relative;overflow:hidden;
  margin-bottom:16px;
}
.profile-card::before{
  content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,77,28,.18),transparent 65%);
  pointer-events:none;
}
.profile-avatar{
  width:96px;height:96px;border-radius:50%;
  margin:0 auto 14px;
  background:linear-gradient(135deg,var(--fire),var(--fire-light));
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
  box-shadow:var(--shadow-fire),inset 0 -4px 8px rgba(0,0,0,.18);
  border:3px solid rgba(255,255,255,.12);
  overflow:hidden;
}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.profile-initial{
  font-family:var(--font-display);font-size:38px;font-weight:900;
  color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.3);
  text-transform:uppercase;
}
.profile-name{
  font-family:var(--font-display);font-size:20px;font-weight:900;
  color:#fff;line-height:1.2;letter-spacing:-.4px;
  position:relative;z-index:1;
}
.profile-username{
  font-size:12.5px;color:var(--text-3);margin-top:4px;
  position:relative;z-index:1;
}

.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pstat{
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:14px 10px;text-align:center;
}
.pstat-icon{
  width:38px;height:38px;border-radius:10px;
  margin:0 auto 8px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  box-shadow:0 4px 12px rgba(0,0,0,.25);
}
.pstat-icon .mi{font-size:20px}
.pstat-num{
  font-family:var(--font-display);font-size:22px;font-weight:900;
  color:#fff;line-height:1;letter-spacing:-.4px;
  font-variant-numeric:tabular-nums;
}
.pstat-label{font-size:10px;color:var(--text-4);margin-top:5px;text-transform:uppercase;letter-spacing:.7px;font-weight:700}

.wins-list{display:flex;flex-direction:column;gap:8px}
.win-item{
  display:flex;align-items:center;gap:12px;
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:12px 14px;
}
.win-icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;
}
.win-icon .mi{font-size:22px}
.win-body{flex:1;min-width:0}
.win-title{font-family:var(--font-display);font-size:12.5px;font-weight:700;color:#fff;line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.win-date{font-size:10.5px;color:var(--text-4);margin-top:2px;font-variant-numeric:tabular-nums}

/* ── Дедлайн ссылки приза — отображается только если урл с TTL ── */
.win-expiry{
  display:inline-flex;align-items:center;gap:4px;
  margin-top:4px;
  font-size:10.5px;font-weight:600;
  color:var(--text-3);
  background:var(--surface-2);
  border:1px solid var(--border-1);
  border-radius:var(--r-full);
  padding:3px 8px 3px 6px;
  font-variant-numeric:tabular-nums;
  letter-spacing:.1px;
}
.win-expiry .mi{font-size:13px;color:var(--text-3)}
.win-expiry--soon{
  /* < 4 часов до истечения — оранжевый акцент. Не паника, мягкое внимание. */
  color:#ffb347;
  background:rgba(255,77,28,.1);
  border-color:rgba(255,77,28,.25);
}
.win-expiry--soon .mi{color:var(--fire-light)}
.win-expiry--expired{
  /* Уже истекла — серый, заметно «выключенный» стиль. */
  color:var(--text-4);
  background:transparent;
  border-color:var(--border-1);
}
.win-expiry--expired .mi{color:var(--text-4)}
/* Сама карточка истёкшего приза — приглушённая (но видна, чтобы юзер
 * понимал что это его прошлый выигрыш, можно посмотреть). */
.win-item--expired{opacity:.55}
.win-item--expired:hover{opacity:.85}
.win-badge{
  font-family:var(--font-display);font-size:9.5px;font-weight:800;
  padding:4px 9px;border-radius:var(--r-full);
  flex-shrink:0;letter-spacing:.4px;
}

/* ── Кликабельные win-карточки: hover + active + visual hint ──
 * Если у приза есть Prize.url и ссылка не истекла — карточка becomes button.
 * Стрелка справа подсказывает «тапни», hover/active даёт обратную связь.
 * Истёкшие карточки НЕ кликабельны (см. .win-item--expired выше). */
.win-item--clickable{
  cursor:pointer;
  position:relative;
  -webkit-tap-highlight-color:transparent;
  transition:background .15s ease, border-color .15s ease, transform .1s ease;
}
.win-item--clickable:hover{
  background:var(--surface-2);
  border-color:var(--border-2);
}
.win-item--clickable:active{
  transform:scale(.98);
  background:var(--surface-2);
}
.win-item--clickable:focus-visible{
  outline:2px solid var(--fire);
  outline-offset:2px;
}
.win-go{
  flex-shrink:0;
  width:28px;height:28px;
  display:flex;align-items:center;justify-content:center;
  color:var(--fire-light);
  background:var(--fire-glow);
  border-radius:50%;
  margin-left:-2px;
  transition:transform .2s ease, background .2s ease;
}
.win-go .mi{font-size:16px;font-variation-settings:'FILL' 0,'wght' 600}
.win-item--clickable:hover .win-go{
  background:var(--fire-glow-strong);
  transform:translateX(2px);
}

.wins-empty{
  text-align:center;
  padding:36px 18px;
  background:var(--surface-1);
  border:1px dashed var(--border-2);
  border-radius:var(--r-lg);
  color:var(--text-3);
}
.wins-empty>.mi{font-size:48px;color:var(--fire);opacity:.6;display:block;margin:0 auto 10px}
.wins-empty-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:#fff;margin-bottom:4px}
.wins-empty-sub{font-size:12px;color:var(--text-3);line-height:1.5;max-width:280px;margin:0 auto}

/* ============================================
   ABOUT
   ============================================ */
.about-card{
  border-radius:var(--r-xl);
  overflow:hidden;
  margin-bottom:20px;
  position:relative;
  border:1px solid var(--border-1);
  box-shadow:var(--shadow-lg);
}
.about-photo{position:relative;aspect-ratio:4/5;background:var(--dark)}
.about-photo img{width:100%;height:100%;object-fit:cover;display:block}
.about-photo-overlay{
  position:absolute;left:0;right:0;bottom:0;
  padding:40px 20px 20px;
  background:linear-gradient(to top,rgba(12,14,26,.96),rgba(12,14,26,.5) 60%,transparent);
}
.about-name{font-family:var(--font-display);font-size:22px;font-weight:900;color:#fff;line-height:1.15}
.about-role{font-size:12px;color:var(--text-3);margin-top:4px;font-weight:500}

.about-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
.stat-card{
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:14px 8px;text-align:center;
}
.stat-num{
  font-family:var(--font-display);font-weight:900;
  font-size:22px;color:#fff;line-height:1;
}
.stat-num span{color:var(--fire-light)}
.stat-label{font-size:10px;color:var(--text-4);margin-top:5px;text-transform:uppercase;letter-spacing:.7px;font-weight:600}

.creds{display:flex;flex-direction:column;gap:10px}
.cred-item{
  display:flex;gap:12px;align-items:flex-start;
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:14px 16px;
}
.cred-item .mi{color:var(--fire-light);font-size:22px;flex-shrink:0;margin-top:1px}
.cred-title{font-family:var(--font-display);font-size:12.5px;font-weight:700;color:#fff;line-height:1.3}
.cred-sub{font-size:11.5px;color:var(--text-3);margin-top:2px;line-height:1.45}

/* ════════════════════════════════════════════════════════════════════
   TRAINER CTA — премиум-карточка-переход «Тренер → Персональные тренировки»
   Логика: размещается ПОСЛЕ блока «О тренере + кредиты» и ПЕРЕД
   «Соцсетями». Психологически: юзер уже познакомился с Евгением →
   следующий шаг — поработать с ним. Это не реклама, это естественное
   продолжение воронки внутри вкладки «Тренер».

   Дизайн (10/10):
   • Тёмная стеклянная карточка с тонкой fire-обводкой
   • Слева — иконка `school` в круглом контейнере с fire-glow
   • Центр — eyebrow + title (Unbounded) + sub
   • Справа — стрелка-индикатор (arrow_forward) в мягкой плашке
   • Hover/active — карточка приподнимается, fire-обводка ярче,
     стрелка сдвигается на 4px вправо (signal «куда идём»)
   ════════════════════════════════════════════════════════════════════ */
.trainer-cta{
  display:flex;align-items:center;gap:14px;
  width:100%;margin-top:18px;
  padding:16px 16px 16px 14px;
  background:
    linear-gradient(135deg, rgba(255,77,28,.08), rgba(255,77,28,.02)),
    var(--surface-1);
  border:1px solid var(--fire-glow-strong);
  border-radius:var(--r-lg);
  color:var(--text-1);
  text-align:left;
  cursor:pointer;
  font:inherit;
  position:relative;
  overflow:hidden;
  transition:transform .22s var(--ease), border-color .22s var(--ease), background .22s var(--ease), box-shadow .22s var(--ease);
}
/* Декоративный «свет» в правом верхнем углу — премиум-нюанс */
.trainer-cta::before{
  content:'';
  position:absolute;
  top:-40px;right:-40px;width:160px;height:160px;
  background:radial-gradient(circle, rgba(255,77,28,.16), transparent 65%);
  pointer-events:none;
  opacity:.85;
  transition:opacity .22s var(--ease);
}
.trainer-cta:hover,
.trainer-cta:active{
  transform:translateY(-1px);
  border-color:var(--fire);
  background:
    linear-gradient(135deg, rgba(255,77,28,.14), rgba(255,77,28,.04)),
    var(--surface-2);
  box-shadow:0 8px 24px -8px rgba(255,77,28,.35);
}
.trainer-cta:hover::before,
.trainer-cta:active::before{opacity:1}
.trainer-cta:active{transform:translateY(0)}

.trainer-cta-icon-wrap{
  flex-shrink:0;
  width:46px;height:46px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--fire), var(--fire-dark));
  box-shadow:0 4px 12px -2px rgba(255,77,28,.5);
  position:relative;z-index:1;
}
.trainer-cta-icon{font-size:24px;color:#fff}

.trainer-cta-body{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:2px;
  position:relative;z-index:1;
}
.trainer-cta-eyebrow{
  font-family:var(--font-display);
  font-size:10px;font-weight:700;
  letter-spacing:.7px;text-transform:uppercase;
  color:var(--fire-light);
}
.trainer-cta-title{
  font-family:var(--font-display);
  font-size:15px;font-weight:800;
  color:#fff;
  line-height:1.25;
  letter-spacing:-.2px;
  margin-top:1px;
}
.trainer-cta-sub{
  font-size:12px;color:var(--text-3);
  line-height:1.4;margin-top:2px;
}

.trainer-cta-arrow{
  flex-shrink:0;
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--surface-3);
  color:var(--fire-light);
  transition:transform .22s var(--ease), background .22s var(--ease);
  position:relative;z-index:1;
}
.trainer-cta-arrow .mi{font-size:20px}
.trainer-cta:hover .trainer-cta-arrow,
.trainer-cta:active .trainer-cta-arrow{
  transform:translateX(4px);
  background:var(--fire-glow);
}

.socials{display:flex;flex-direction:column;gap:10px}
.social-card{
  display:flex;align-items:center;gap:14px;
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:14px 16px;
  transition:all .25s var(--ease);
}
.social-card:hover,.social-card:active{
  background:var(--surface-2);
  border-color:var(--fire-glow-strong);
}
.social-card>.mi{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:var(--fire-glow);color:var(--fire-light);
  font-size:22px;flex-shrink:0;
}
.social-card>div{flex:1;min-width:0}
.social-title{font-family:var(--font-display);font-size:13px;font-weight:700;color:#fff}
.social-sub{font-size:11.5px;color:var(--text-3);margin-top:2px}
.mi-arr{color:var(--text-4);font-size:18px}

/* ============================================
   TAB BAR
   ============================================ */
.tab-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:40;
  display:flex;
  background:rgba(12,14,26,.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--border-1);
  padding-bottom:env(safe-area-inset-bottom);
}
.tab{
  flex:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  padding:8px 2px;
  height:var(--tab-h);
  color:var(--text-3);
  position:relative;
  transition:color .25s var(--ease);
  min-width:0;
}
.tab .mi{font-size:21px}
.tab-label{font-size:9.5px;font-weight:700;letter-spacing:.1px;white-space:nowrap}
.tab--active{color:var(--fire-light)}
.tab--active::after{
  content:'';position:absolute;top:6px;left:50%;transform:translateX(-50%);
  width:24px;height:3px;border-radius:3px;
  background:var(--fire);
  box-shadow:0 0 10px rgba(255,77,28,.7);
}

/* ============================================
   MODAL
   ============================================ */
.modal{
  position:fixed;inset:0;z-index:100;
  display:none;
  align-items:flex-end;justify-content:center;
}
.modal.is-open{display:flex;animation:modalFade .25s ease}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,.65);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.modal-box{
  position:relative;z-index:1;
  width:100%;max-width:560px;
  max-height:88vh;
  background:linear-gradient(180deg,#1a1d3a,#12142a);
  border-top:1px solid var(--border-2);
  border-radius:24px 24px 0 0;
  padding:24px 20px calc(20px + env(safe-area-inset-bottom));
  box-shadow:0 -20px 60px rgba(0,0,0,.6);
  animation:modalUp .35s var(--ease-spring);
  overflow-y:auto;
}
@keyframes modalUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-tall{max-height:92vh}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}
.modal-title{font-family:var(--font-display);font-size:17px;font-weight:800;color:#fff;line-height:1.25}
.modal-sub{font-size:12px;color:var(--text-3);margin-top:3px}
.modal-x{
  width:36px;height:36px;border-radius:50%;
  background:var(--surface-2);
  border:1px solid var(--border-1);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);flex-shrink:0;
  transition:all .2s var(--ease);
}
.modal-x:hover{background:var(--surface-3);color:#fff}
.modal-x .mi{font-size:18px}

/* Prize modal */
.modal-prize{text-align:center;padding-top:0}
.modal-prize-burst{
  margin:-30px auto 16px;
  width:120px;height:120px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.modal-prize-burst::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle,rgba(255,77,28,.5) 0%,transparent 70%);
  filter:blur(14px);
  animation:glowPulse 1.4s ease-in-out infinite alternate;
}
.prize-icon{
  width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,var(--fire),var(--fire-light));
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
  box-shadow:var(--shadow-fire),inset 0 -4px 8px rgba(0,0,0,.2);
  animation:prizePop .5s var(--ease-spring);
}
@keyframes prizePop{from{transform:scale(.6) rotate(-25deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.prize-icon .mi{font-size:48px;color:#fff}
.prize-eyebrow{
  font-family:var(--font-display);font-size:10.5px;font-weight:800;
  color:var(--fire-light);letter-spacing:2px;text-transform:uppercase;
  margin-bottom:6px;
}
.prize-title{font-family:var(--font-display);font-size:22px;font-weight:900;color:#fff;line-height:1.2;margin-bottom:6px;letter-spacing:-.4px}
.prize-subtitle{font-size:13px;color:var(--text-2);line-height:1.5;margin-bottom:22px;max-width:380px;margin-left:auto;margin-right:auto}
.prize-actions{display:flex;flex-direction:column;gap:8px}

/* Lead items */
.lead-item{
  display:flex;align-items:center;gap:12px;
  padding:14px;
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  margin-bottom:8px;
  transition:all .25s var(--ease);
}
.lead-item:hover,.lead-item:active{background:var(--surface-2)}
.lead-icon{
  width:42px;height:42px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;
}
.lead-icon .mi{font-size:22px}
.lead-body{flex:1;min-width:0}
.lead-title{font-family:var(--font-display);font-size:13px;font-weight:700;color:#fff}
.lead-desc{font-size:11.5px;color:var(--text-3);margin-top:2px}

/* Settings (probabilities) */
.settings-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.weight-row{
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:12px 14px;
}
.weight-row-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.weight-swatch{width:14px;height:14px;border-radius:4px;flex-shrink:0}
.weight-name{font-family:var(--font-display);font-size:11.5px;font-weight:700;color:#fff;flex:1;line-height:1.3}
.weight-value{
  font-family:var(--font-display);font-size:13px;font-weight:800;
  color:var(--fire-light);min-width:42px;text-align:right;
  font-variant-numeric:tabular-nums;
}
.weight-slider{
  width:100%;-webkit-appearance:none;appearance:none;
  height:5px;border-radius:3px;background:var(--surface-3);
  outline:none;
}
.weight-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:var(--fire);
  border:2px solid #fff;
  cursor:pointer;
  box-shadow:var(--shadow-fire);
}
.weight-slider::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:var(--fire);border:2px solid #fff;
  cursor:pointer;
}
.settings-total{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px;
  background:var(--fire-glow);
  border:1px solid var(--fire-glow-strong);
  border-radius:var(--r-md);
  font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--text-2);
  text-transform:uppercase;letter-spacing:.8px;
  margin-bottom:14px;
}
.settings-total strong{color:var(--fire-light);font-size:18px;font-weight:900}
.settings-total.is-bad strong{color:var(--red)}
.settings-actions{display:flex;flex-wrap:wrap;gap:8px}
.settings-actions .btn{flex:1;min-width:120px}

/* Confetti */
.confetti{
  position:fixed;inset:0;z-index:200;pointer-events:none;
  display:none;
}
.confetti.is-active{display:block}

/* ============================================
   SHAKE
   ============================================ */
.shake{animation:shake .5s ease}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-7px)}
  40%,80%{transform:translateX(7px)}
}

/* ============================================
   REFERRAL CARD — приглашение друга на профиле
   ============================================ */
.referral-card{
  margin-top:24px;
  background:linear-gradient(135deg, rgba(255,77,28,.10), rgba(255,138,80,.04));
  border:1px solid rgba(255,77,28,.22);
  border-radius:var(--r-lg);
  padding:18px 18px 14px;
  position:relative;overflow:hidden;
}
.referral-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,77,28,.22) 0%, transparent 70%);
  pointer-events:none;
}
.referral-head{position:relative;z-index:1;margin-bottom:12px}
.referral-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-size:10px;font-weight:800;
  letter-spacing:1.4px;text-transform:uppercase;
  color:var(--fire-light);
  background:rgba(255,77,28,.12);
  border:1px solid rgba(255,77,28,.28);
  padding:4px 10px;border-radius:var(--r-full);
  margin-bottom:10px;
}
.referral-eyebrow .mi{font-size:13px}
.referral-title{
  font-family:var(--font-display);font-size:16px;font-weight:800;
  color:#fff;margin-bottom:6px;letter-spacing:-.2px;line-height:1.25;
}
.referral-sub{
  font-size:12.5px;color:var(--text-3);line-height:1.5;
}
.referral-link{
  font-family:'SF Mono',Menlo,Consolas,monospace;
  font-size:11.5px;color:var(--text-2);
  background:var(--surface-2);
  border:1px solid var(--border-1);
  border-radius:var(--r-md);
  padding:10px 12px;
  margin-bottom:10px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  user-select:all;
  position:relative;z-index:1;
}
.referral-actions{display:flex;gap:8px;position:relative;z-index:1;flex-wrap:wrap}
.referral-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:var(--font-display);font-size:12px;font-weight:700;
  padding:10px 14px;border-radius:var(--r-md);border:none;cursor:pointer;
  transition:all .2s var(--ease);
  letter-spacing:.2px;flex:1;min-width:120px;
}
.referral-btn .mi{font-size:15px}
.referral-btn--primary{
  background:linear-gradient(135deg,var(--fire),var(--fire-dark));
  color:#fff;box-shadow:var(--shadow-fire);
}
.referral-btn--primary:hover,.referral-btn--primary:active{
  background:var(--fire-dark);box-shadow:0 10px 28px rgba(255,77,28,.38);
}
.referral-btn--ghost{
  background:var(--surface-2);color:var(--text-2);
  border:1px solid var(--border-1);
  flex:0 0 auto;
}
.referral-btn--ghost:hover,.referral-btn--ghost:active{
  background:var(--surface-3);color:#fff;border-color:var(--border-2);
}
@media(max-width:380px){
  .referral-actions{flex-direction:column}
  .referral-btn{flex:1 1 100%}
}

/* ═══ Subscription Gate (колесо для подписчиков) ═══ */
.sub-gate{
  margin:16px 0 20px;
  padding:18px;
  border-radius:18px;
  background:linear-gradient(160deg,rgba(255,77,28,.10),rgba(255,77,28,.04));
  border:1px solid rgba(255,77,28,.35);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.sub-gate::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at 20% 30%,rgba(255,77,28,.18),transparent 50%);
  pointer-events:none;
}
.sub-gate-icon{
  width:46px;height:46px;margin:0 auto 10px;
  border-radius:50%;
  background:rgba(255,77,28,.18);
  display:flex;align-items:center;justify-content:center;
  color:var(--fire);
  position:relative;
}
.sub-gate-icon .mi{font-size:22px}
.sub-gate-title{
  font-family:'Unbounded',sans-serif;
  font-weight:700;font-size:18px;
  color:#fff;margin-bottom:8px;
  position:relative;
}
.sub-gate-text{
  font-size:13px;line-height:1.55;
  color:rgba(255,255,255,.72);
  max-width:440px;margin:0 auto 16px;
  position:relative;
}
.sub-gate-text b{color:var(--fire-light,#ff8a5c)}
.sub-gate-actions{
  display:flex;flex-direction:column;gap:8px;
  max-width:340px;margin:0 auto;
  position:relative;
}
.sub-gate-actions .btn{justify-content:center;width:100%}
.sub-gate-note{
  margin-top:12px;
  padding:10px 12px;
  border-radius:10px;
  font-size:12px;line-height:1.5;
  position:relative;
}
.sub-gate-note.is-error{
  background:rgba(239,68,68,.10);
  border:1px solid rgba(239,68,68,.30);
  color:#ffb3b3;
}
.sub-gate-note.is-info{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.75);
}
.sub-gate-spin .mi{animation:rotate 1s linear infinite}
@keyframes rotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* Когда gate активен — приглушаем reel чтобы был ясный фокус на подписке */
.wheel-gated .reel,.wheel-gated .attempts-bar,.wheel-gated .wheel-actions{
  opacity:.35;pointer-events:none;filter:saturate(.5);
}

/* ════════════════════════════════════════════════════════════════════
   PERSONAL WORK — sales-style mini-landing
   Цель: воспроизвести самые сильные блоки полного лендинга
   (evgenyksenchenko.ru) в формате Mini App, заканчиваясь большим CTA
   на полный лендинг. Mobile-first, тёмная тема + fire-accent.
   ════════════════════════════════════════════════════════════════════ */

/* ── 0. PAGE HEAD — «ты сейчас в разделе ПЕРСОНАЛЬНЫЕ ТРЕНИРОВКИ» ──
   Премиум-шапка раздела. Объясняет вкладку «Лично» внятным заголовком,
   чтобы юзер не гадал что значит «Лично». Стилистически отделена от
   sales-hero (eyebrow + display-title + sub), не дублирует копирайт.

   Дизайн-решения:
   • Тёмная панель сверху-вниз: чуть-чуть глубже основного фона
     (var(--surface-1) с лёгким fire-tint) — выделяется без шумности
   • Иконка `school` в круглой fire-плашке с лёгкой тенью —
     визуальный якорь, премиум-нюанс
   • Eyebrow с пульсирующей точкой — намёк «активно, открыто»
   • Title — Unbounded 900, чёткий, читаемый, не вылазящий по ширине
   • Sub — Nunito, тонкий пояснитель (Москва · клуб АртТТ · техника)
   • Тонкая нижняя линия — отделяет от pw-hero без жирной границы
   • Responsive: иконка не сжимается, текст под ней умещается
   ─────────────────────────────────────────────────────────────────── */
.pw-pagehead{
  padding:18px 0 16px;
  background:
    linear-gradient(180deg, rgba(255,77,28,.04), transparent 80%),
    var(--surface-1);
  border-bottom:1px solid var(--border-1);
  position:relative;
}
.pw-pagehead-inner{
  display:flex;align-items:flex-start;gap:14px;
}
.pw-pagehead-icon-wrap{
  flex-shrink:0;
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--fire), var(--fire-dark));
  box-shadow:0 4px 14px -3px rgba(255,77,28,.5);
  margin-top:4px;
}
.pw-pagehead-icon{font-size:24px;color:#fff}

.pw-pagehead-content{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:4px;
}
.pw-pagehead-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);
  font-size:10px;font-weight:700;
  letter-spacing:.7px;text-transform:uppercase;
  color:var(--fire-light);
}
.pw-pagehead-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--fire);box-shadow:0 0 8px var(--fire-light);
  animation:pwBlink 1.6s ease infinite;
}
.pw-pagehead-title{
  font-family:var(--font-display);
  font-size:clamp(22px, 5.5vw, 26px);
  font-weight:900;
  line-height:1.15;
  letter-spacing:-.4px;
  color:var(--text-1);
  margin:0;
}
.pw-pagehead-sub{
  font-size:12.5px;
  color:var(--text-3);
  line-height:1.45;
  margin:2px 0 0;
  font-weight:500;
}

/* ── 1. HERO — фон, бейдж, заголовок-hook, авторитет ── */
.pw-hero{
  position:relative;
  padding:32px 0 28px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,77,28,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,77,28,.03), transparent);
  border-bottom:1px solid var(--border-1);
  overflow:hidden;
}
.pw-hero::before{
  content:'';
  position:absolute;
  top:-100px;right:-80px;width:280px;height:280px;
  background:radial-gradient(circle,rgba(255,77,28,.12),transparent 65%);
  border-radius:50%;
  pointer-events:none;
}
.pw-availability{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--fire-glow);
  border:1px solid var(--fire-glow-strong);
  border-radius:var(--r-full);
  padding:7px 14px 7px 12px;
  font-family:var(--font-display);
  font-size:11px;font-weight:700;
  color:var(--fire-light);
  letter-spacing:.5px;text-transform:uppercase;
  margin-bottom:18px;
}
.pw-availability-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--fire);box-shadow:0 0 8px var(--fire);
  animation:pwBlink 1.6s ease infinite;
  flex-shrink:0;
}
@keyframes pwBlink{0%,100%{opacity:1}50%{opacity:.35}}
.pw-hero-title{
  font-family:var(--font-display);
  font-size:clamp(26px,6.5vw,34px);
  font-weight:900;
  line-height:1.15;
  letter-spacing:-.6px;
  color:var(--text-1);
  margin-bottom:14px;
}
.pw-hero-accent{
  display:block;
  background:linear-gradient(135deg,#ff4d1c,#ff8a50,#ffb347);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  margin-top:2px;
}
.pw-hero-sub{
  font-size:15px;
  line-height:1.6;
  color:var(--text-2);
  font-style:italic;
  margin-bottom:22px;
  max-width:520px;
}
.pw-creds{
  display:flex;flex-wrap:wrap;gap:7px;
}
.pw-cred{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--surface-2);
  border:1px solid var(--border-1);
  border-radius:var(--r-full);
  padding:6px 12px;
  font-size:12px;font-weight:700;
  color:var(--text-2);
}
.pw-cred .mi{font-size:14px;color:var(--fire-light)}

/* ── 2. STORY — эмоциональный hook ── */
.pw-story{
  padding:36px 0 8px;
}
.pw-story .eyebrow{margin-bottom:10px}
.pw-story .heading-sm{
  font-size:clamp(20px,4.5vw,26px);
  margin-bottom:18px;
}
.pw-story-p{
  font-size:15px;line-height:1.7;
  color:var(--text-2);
  margin-bottom:14px;
}
.pw-story-p strong{color:var(--text-1);font-weight:700}
.pw-quote{
  position:relative;
  background:linear-gradient(135deg,rgba(255,77,28,.08),rgba(255,77,28,.03));
  border-left:3px solid var(--fire);
  border-radius:0 var(--r-md) var(--r-md) 0;
  padding:18px 20px;
  margin:18px 0;
  font-size:16px;
  line-height:1.55;
  color:var(--text-1);
  font-style:italic;
  font-weight:500;
}
.pw-quote-icon{
  display:block;font-size:24px;color:var(--fire);margin-bottom:4px;font-style:normal;
}
.pw-keypoint{
  display:flex;gap:14px;align-items:flex-start;
  background:linear-gradient(135deg,rgba(255,77,28,.1),rgba(255,77,28,.04));
  border:1px solid rgba(255,77,28,.22);
  border-radius:var(--r-lg);
  padding:18px 18px 18px 16px;
  margin:18px 0;
}
.pw-keypoint-icon{
  flex-shrink:0;
  width:44px;height:44px;
  background:linear-gradient(135deg,var(--fire),var(--fire-dark));
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(255,77,28,.35);
}
.pw-keypoint-icon .mi{font-size:24px;color:#fff}
.pw-keypoint-title{
  font-family:var(--font-display);
  font-size:15px;font-weight:800;
  color:var(--text-1);
  line-height:1.35;
  margin-bottom:4px;
}
.pw-keypoint-sub{
  font-size:13px;line-height:1.55;
  color:var(--text-2);
}
.pw-highlight{
  display:inline;
  color:var(--text-1);
  font-weight:600;
  background:linear-gradient(180deg,transparent 60%,rgba(255,77,28,.18) 60%);
  padding:0 2px;
}

/* ── 3. SECTIONS общий разметка ── */
.pw-section{
  padding:36px 0 12px;
  border-top:1px solid var(--border-1);
}
.pw-section .eyebrow{margin-bottom:10px}
.pw-section .heading-sm{
  font-size:clamp(20px,4.5vw,26px);
  margin-bottom:8px;
}
.pw-subtext-tight{
  margin-bottom:22px;
  font-size:14px;
}

/* ── Includes (what's in the offer) ── */
.pw-includes{
  display:flex;flex-direction:column;gap:10px;
}
.pw-inc{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-lg);
  padding:16px 18px;
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
}
.pw-inc:active{transform:scale(.99)}
.pw-inc-icon{
  flex-shrink:0;
  width:42px;height:42px;
  background:linear-gradient(135deg,var(--fire),var(--fire-light));
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(255,77,28,.28);
}
.pw-inc-icon .mi{font-size:22px;color:#fff}
.pw-inc-body h4{
  font-family:var(--font-display);
  font-size:14px;font-weight:800;
  color:var(--text-1);
  line-height:1.35;
  margin-bottom:4px;
}
.pw-inc-body p{
  font-size:13px;
  line-height:1.55;
  color:var(--text-2);
}

/* ── Cases ── */
.pw-cases{
  display:flex;flex-direction:column;gap:14px;
}
.pw-case{
  background:var(--surface-1);
  border:1px solid var(--border-1);
  border-radius:var(--r-lg);
  padding:20px;
  transition:border-color .25s ease;
}
.pw-case:hover{border-color:var(--fire-glow-strong)}
.pw-case-head{
  display:flex;justify-content:space-between;gap:14px;
  align-items:flex-start;
  margin-bottom:12px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border-1);
}
.pw-case-name{
  font-family:var(--font-display);
  font-size:15px;font-weight:800;
  color:var(--text-1);
  line-height:1.3;
}
.pw-case-meta{
  font-size:12px;
  color:var(--text-3);
  margin-top:3px;
}
.pw-case-stat{flex-shrink:0;text-align:right}
.pw-case-num{
  font-family:var(--font-display);
  font-size:20px;font-weight:900;
  line-height:1;
  background:linear-gradient(135deg,var(--fire),var(--fire-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  white-space:nowrap;
}
.pw-case-label{
  font-size:10px;
  color:var(--text-3);
  text-transform:uppercase;
  letter-spacing:1px;
  font-weight:700;
  margin-top:3px;
}
.pw-case p{
  font-size:13.5px;
  line-height:1.65;
  color:var(--text-2);
}
.pw-case p strong{color:var(--text-1);font-weight:700}

/* ── Guarantee ── */
.pw-guarantee{
  margin-top:32px;
  display:flex;gap:16px;align-items:flex-start;
  background:linear-gradient(135deg,rgba(34,197,94,.12),rgba(34,197,94,.04));
  border:1px solid rgba(34,197,94,.25);
  border-radius:var(--r-lg);
  padding:22px 20px;
}
.pw-guar-icon{
  flex-shrink:0;
  width:48px;height:48px;
  background:var(--lime);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(34,197,94,.35);
}
.pw-guar-icon .mi{font-size:26px;color:#fff}
.pw-guar-body h3{
  font-family:var(--font-display);
  font-size:16px;font-weight:800;
  color:var(--text-1);
  line-height:1.35;
  margin-bottom:8px;
}
.pw-guar-body p{
  font-size:13.5px;
  line-height:1.6;
  color:var(--text-2);
  margin-bottom:6px;
}
.pw-guar-body p:last-child{margin-bottom:0}
.pw-guar-body strong{color:#86efac;font-weight:700}
.pw-guar-punch{font-weight:600;color:#bbf7d0 !important}

/* ── Final CTA — fire-styled ── */
.pw-cta{
  margin-top:36px;
  margin-bottom:32px;
  position:relative;
  background:linear-gradient(135deg, rgba(255,77,28,.14), rgba(255,77,28,.04));
  border:2px solid rgba(255,77,28,.4);
  border-radius:var(--r-xl);
  padding:28px 22px 24px;
  text-align:center;
  overflow:hidden;
}
.pw-cta::before{
  content:'';
  position:absolute;
  top:-60px;left:50%;
  transform:translateX(-50%);
  width:300px;height:120px;
  background:radial-gradient(ellipse,rgba(255,77,28,.4),transparent 70%);
  pointer-events:none;
}
/* ── Scarcity-карточка: премиум-формат, не chip-бейдж ── */
.pw-scarcity{
  position:relative;
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,
    rgba(255,77,28,.12),
    rgba(255,77,28,.04) 60%,
    rgba(255,255,255,.03)
  );
  border:1px solid rgba(255,77,28,.3);
  border-radius:var(--r-lg);
  padding:14px 16px 14px 14px;
  margin-bottom:24px;
  text-align:left;
  overflow:hidden;
}
.pw-scarcity::before{
  /* Декоративная заливка слева — premium feel */
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--fire),var(--fire-dark));
}
.pw-scarcity-icon{
  flex-shrink:0;
  width:42px;height:42px;
  background:rgba(255,77,28,.18);
  border:1px solid rgba(255,77,28,.35);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
}
.pw-scarcity-icon .mi{font-size:22px;color:var(--fire-light)}
.pw-scarcity-body{
  flex:1;min-width:0;
}
.pw-scarcity-title{
  font-family:var(--font-display);
  font-size:14px;font-weight:800;
  color:var(--text-1);
  line-height:1.25;
  letter-spacing:-.2px;
  margin-bottom:2px;
}
.pw-scarcity-sub{
  font-size:12px;
  line-height:1.45;
  color:var(--text-2);
}
.pw-scarcity-pulse{
  flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:6px 10px;
  background:rgba(255,77,28,.14);
  border-radius:var(--r-md);
  min-width:54px;
}
.pw-scarcity-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--fire);
  box-shadow:0 0 10px var(--fire),0 0 4px var(--fire);
  animation:pwBlink 1.4s ease infinite;
}
.pw-scarcity-label{
  font-family:var(--font-display);
  font-size:9px;font-weight:800;
  color:var(--fire-light);
  text-transform:uppercase;
  letter-spacing:1px;
}
@media(max-width:380px){
  .pw-scarcity{padding:12px 14px 12px 12px;gap:10px}
  .pw-scarcity-icon{width:38px;height:38px}
  .pw-scarcity-icon .mi{font-size:20px}
  .pw-scarcity-title{font-size:13px}
  .pw-scarcity-sub{font-size:11.5px}
  .pw-scarcity-pulse{min-width:48px;padding:5px 8px}
}

/* Legacy — оставляем класс для backwards-compat если ссылается ещё что-то */
.pw-cta-scarcity{display:none}
.pw-cta-title{
  font-family:var(--font-display);
  font-size:clamp(20px,5vw,26px);
  font-weight:900;
  line-height:1.3;
  color:var(--text-1);
  letter-spacing:-.4px;
  margin-bottom:12px;
  position:relative;
}
.pw-cta-sub{
  font-size:14px;
  line-height:1.6;
  color:var(--text-2);
  margin-bottom:22px;
  position:relative;
}
/**
 * Mega-CTA — кастомная двухстрочная кнопка с большой иконкой слева.
 * Решает проблему «текст не входит» — никакого white-space:nowrap,
 * текст разбит на 2 строки явно, иконка в фиксированном flex-блоке.
 * Без `font-family:Unbounded` — Nunito Sans на больших размерах в
 * мобильных вьюпортах читается лучше.
 */
.pw-mega-btn{
  position:relative;
  display:flex;align-items:center;gap:14px;
  width:100%;
  padding:18px 20px 18px 16px;
  background:linear-gradient(135deg,var(--fire),var(--fire-dark));
  border:none;border-radius:var(--r-lg);
  cursor:pointer;
  text-align:left;
  color:#fff;
  box-shadow:0 10px 32px rgba(255,77,28,.4),0 4px 12px rgba(255,77,28,.2);
  transition:transform .15s ease, box-shadow .25s ease;
  animation:pwCtaPulse 2.4s ease-in-out infinite;
  overflow:hidden;
}
.pw-mega-btn::before{
  /* Глянцевая полоса как у iOS кнопок — premium feel */
  content:'';
  position:absolute;
  top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transition:left .8s ease;
}
.pw-mega-btn:hover::before,
.pw-mega-btn:active::before{left:100%}
.pw-mega-btn:active{
  transform:scale(.98);
  box-shadow:0 6px 20px rgba(255,77,28,.45),0 2px 8px rgba(255,77,28,.3);
}
.pw-mega-btn-icon{
  flex-shrink:0;
  width:46px;height:46px;
  background:rgba(255,255,255,.22);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(4px);
}
.pw-mega-btn-icon .mi{font-size:24px;color:#fff}
.pw-mega-btn-text{
  flex:1;min-width:0;
  display:flex;flex-direction:column;
  line-height:1.25;
}
.pw-mega-btn-line1{
  font-family:var(--font-display);
  font-size:15px;
  font-weight:800;
  color:#fff;
  letter-spacing:-.2px;
}
.pw-mega-btn-line2{
  font-size:13px;
  font-weight:600;
  color:rgba(255,255,255,.92);
  margin-top:2px;
}
@keyframes pwCtaPulse{
  0%,100%{box-shadow:0 10px 32px rgba(255,77,28,.4),0 4px 12px rgba(255,77,28,.2)}
  50%{box-shadow:0 14px 40px rgba(255,77,28,.55),0 6px 16px rgba(255,77,28,.3)}
}
@media(max-width:380px){
  .pw-mega-btn{padding:16px 16px 16px 14px;gap:12px}
  .pw-mega-btn-icon{width:42px;height:42px}
  .pw-mega-btn-icon .mi{font-size:22px}
  .pw-mega-btn-line1{font-size:14px}
  .pw-mega-btn-line2{font-size:12.5px}
}
.pw-cta-note{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin-top:14px;
  font-size:11.5px;
  color:var(--text-3);
  position:relative;
}
.pw-cta-note .mi{font-size:13px;color:var(--text-3)}

/* ── Responsive — mobile-first уже, тут мелкие правки ── */
@media (max-width: 380px){
  .pw-hero-title{font-size:24px}
  .pw-creds{gap:5px}
  .pw-cred{font-size:11px;padding:5px 10px}
  .pw-case-head{flex-direction:column;gap:8px}
  .pw-case-stat{text-align:left}
  .pw-cta{padding:24px 18px 20px}
}
