/* ============================================
   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;
}

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;
}

/* ============================================
   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;
  height:312px; /* 3 слота × 104 */
  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-highlight{
  position:absolute;left:6px;right:6px;
  top:calc(50% - 48px);height:96px;
  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;
}

/* Стрелка-указатель слева (одна) */
.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;
}
.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}

/* ============================================
   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-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-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}
}

/* ============================================
   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}
.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;
}

.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}

.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)}
}
