/* ══════════════════════════════════════════════════════════════
   SPIN screen — 1:1 with the SPINCHAIN wheel-card artwork.
   ══════════════════════════════════════════════════════════════ */
.sp-screen {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: var(--s-3) var(--s-4) var(--s-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-4);
}

/* the wheel card — deep neon panel like the document */
.sp-card {
  width: 100%;
  position: relative;
  border-radius: var(--r-xl);
  padding: var(--s-4) var(--s-4) var(--s-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-2);
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in srgb, var(--tier-now) 26%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, #1a1146 0%, #0d0826 100%);
  border: 1px solid color-mix(in srgb, var(--tier-now) 45%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 0 34px -6px color-mix(in srgb, var(--tier-now) 55%, transparent),
    var(--shadow-card);
  overflow: hidden;
}
.sp-card::before { /* corner sparkles */
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(2px 2px at 12% 22%, rgba(255,255,255,0.8), transparent),
    radial-gradient(2px 2px at 85% 30%, rgba(255,255,255,0.6), transparent),
    radial-gradient(1.5px 1.5px at 70% 14%, rgba(255,255,255,0.7), transparent);
  opacity: 0.5; pointer-events: none;
}

/* metallic tier badge */
.sp-badge {
  position: relative;
  padding: 5px 20px;
  border-radius: var(--r-pill);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.16em;
  color: #fff;
  background: linear-gradient(180deg, #5a5f7a, #2a2d44);
  border: 1px solid rgba(255,255,255,0.25);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.4), 0 3px 8px rgba(0,0,0,0.5);
}
.sp-badge span {
  background: linear-gradient(180deg, #ffffff, #c8ccea);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* 3D gold wheel name */
.sp-name {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(26px, 8.5vw, 38px);
  line-height: 1;
  margin: 2px 0 0;
  text-align: center;
}
.sp-sub {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.22em;
  color: color-mix(in srgb, var(--tier-now) 70%, #fff 30%);
  text-transform: uppercase;
}

.sp-wheel { margin: var(--s-2) 0 var(--s-3); width: 100%; display: grid; place-items: center; }

/* avg-value / unlock chips */
.sp-chips { display: flex; flex-wrap: wrap; gap: var(--s-2); justify-content: center; }
.sp-chip {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.06em;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.28);
  color: var(--text-2);
}
.sp-chip--gold {
  color: #2a1c00;
  background: var(--grad-gold);
  border-color: rgba(255,255,255,0.4);
  box-shadow: var(--glow-gold);
}
.sp-chip--tier {
  color: #fff;
  border-color: color-mix(in srgb, var(--tier-now) 60%, transparent);
  background: color-mix(in srgb, var(--tier-now) 22%, transparent);
}

/* spins balance */
.sp-balance {
  display: flex; align-items: center; gap: var(--s-2);
  font-family: var(--font-display); font-weight: 800;
}
.sp-balance-ico { font-size: 22px; }
.sp-balance-num {
  font-size: 26px;
  background: var(--grad-gold); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.sp-balance-txt { color: var(--text-2); font-weight: 600; font-family: var(--font-body); font-size: 13px; }
.sp-balance-break {
  margin: 4px 0 0; text-align: center;
  font-family: var(--font-body); font-size: 12px; color: var(--text-3);
}
.sp-balance-break b { font-weight: 700; }

/* SPIN NOW button — gold, beveled */
.sp-go {
  width: 100%;
  border: none;
  border-radius: var(--r-pill);
  padding: 17px;
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 900; font-style: italic;
  font-size: 19px; letter-spacing: 0.06em;
  color: #4a2c00;
  background: var(--grad-gold-sheen);
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,0.7),
    inset 0 -5px 10px rgba(120,60,0,0.5),
    0 10px 26px -6px rgba(255,170,40,0.6),
    var(--glow-gold);
  transition: transform var(--t-fast) var(--ease-spring), filter var(--t-fast);
  position: relative; overflow: hidden;
}
.sp-go::after {
  content: ''; position: absolute; top: 0; left: -60%; width: 40%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.7), transparent);
  transform: skewX(-18deg); animation: spSheen 3.2s ease-in-out infinite;
}
@keyframes spSheen { 0%,60% { left: -60%; } 100% { left: 140%; } }
.sp-go:active { transform: scale(0.97); }
.sp-go.is-spinning { filter: saturate(0.85) brightness(0.95); cursor: default; }

/* empty + how-it-works */
.sp-empty[hidden] { display: none; }
.sp-empty {
  width: 100%; text-align: center;
  background: rgba(0,0,0,0.3); border: 1px solid var(--stroke);
  border-radius: var(--r-lg); padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3);
}
.sp-empty p { margin: 0; }
.sp-how { width: 100%; display: flex; flex-direction: column; gap: var(--s-2); margin-top: var(--s-2); }
.sp-how-row {
  display: flex; align-items: center; gap: var(--s-3);
  font-size: 13px; color: var(--text-2);
  background: rgba(255,255,255,0.03); border: 1px solid var(--stroke);
  border-radius: var(--r-md); padding: 10px 12px;
}
.sp-how-row span {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  display: grid; place-items: center; font-weight: 800; font-size: 12px;
  color: #2a1c00; background: var(--grad-gold);
}

/* ── Change Your Life Wheel banner (only for a drawn winner) ──────────────── */
.sp-clw {
  position: relative; overflow: hidden;
  margin: 0 0 16px; padding: 18px 16px; border-radius: 18px; text-align: center;
  background: linear-gradient(150deg, #2a1c00 0%, #1a0f2e 60%, #07060d 100%);
  border: 1px solid rgba(255, 208, 85, .5);
  box-shadow: 0 0 40px -8px rgba(255, 200, 80, .55), inset 0 0 30px rgba(255,200,80,.08);
}
.sp-clw-glow {
  position: absolute; inset: -40% -10% auto -10%; height: 120%;
  background: radial-gradient(circle at 50% 0%, rgba(255,200,80,.35), transparent 60%);
  pointer-events: none; animation: scWheelGlow 3s ease-in-out infinite;
}
.sp-clw-badge {
  display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: .12em;
  color: #0b0f2a; background: var(--grad-gold, linear-gradient(90deg,#ffe89a,#f5b942));
  padding: 3px 10px; border-radius: 999px; margin-bottom: 8px;
}
.sp-clw-title {
  font-family: var(--font-display); font-weight: 900; font-size: clamp(20px, 6vw, 30px);
  margin: 2px 0 4px; line-height: 1.02;
  background: var(--grad-gold, linear-gradient(90deg,#ffe89a,#f5b942));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  position: relative;
}
.sp-clw-sub { font-size: 13px; color: var(--text-2, #ccd); margin: 0 0 14px; position: relative; }
.sp-clw-sub b { color: #ffcf5b; }
.sp-clw-go { position: relative; font-size: 15px; }

.sp-clw-wheel { width: 260px; max-width: 80%; margin: 6px auto 14px; }
