:root {
  --brand: #27BDBE;
  --bg: #f5f7fb;
  --text: #17212b;
  --muted: #687384;
  --card: #ffffff;
  --border: #e7ebf0;
  --danger: #b42318;
  --warning: #b54708;
  --success: #067647;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text);
}
a { color: inherit; text-decoration: none; }
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 22px;
  background: #111827;
  color: #fff;
  position: sticky;
  top: 0;
  z-index: 5;
}
.brand { font-weight: 800; letter-spacing: .2px; }
.topbar nav { display: flex; gap: 12px; align-items: center; }
.topbar nav a { color: rgba(255,255,255,.82); font-weight: 650; font-size: 14px; }
.container { width: min(1180px, calc(100% - 32px)); margin: 28px auto 60px; }
.footer { text-align: center; color: var(--muted); padding: 24px; font-size: 13px; }
h1 { font-size: clamp(30px, 4vw, 52px); margin: 0 0 8px; line-height: 1.05; }
h2 { margin: 0 0 8px; }
p { line-height: 1.55; }
.muted { color: var(--muted); }
.inverse { color: rgba(255,255,255,.75); }
.login-card, .customer-card, .panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 22px;
  box-shadow: 0 16px 50px rgba(15,23,42,.08);
  padding: 24px;
}
.login-card { max-width: 460px; margin: 70px auto; }
.form-stack { display: grid; gap: 14px; }
label { display: grid; gap: 7px; font-weight: 750; font-size: 14px; }
input, select, textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 13px;
  font: inherit;
  background: #fff;
}
textarea { min-height: 130px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 13px; }
.checkbox { display: flex; grid-template-columns: auto 1fr; align-items: flex-start; gap: 9px; font-weight: 600; }
.checkbox input { width: auto; margin-top: 3px; }
.btn, button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: 999px;
  padding: 12px 18px;
  font: inherit;
  font-weight: 850;
  cursor: pointer;
  background: #e9eef5;
  color: #111827;
}
.btn.primary, button.primary { background: var(--brand); color: #fff; }
.play-shell .btn.primary { background: var(--button); color: var(--button-text); }
.btn.ghost { border: 1px solid rgba(255,255,255,.4); background: rgba(255,255,255,.16); color: inherit; }
button:disabled { opacity: .65; cursor: wait; }
.alert { border-radius: 14px; padding: 13px 15px; margin: 12px 0; background: #ecfdf3; color: var(--success); border: 1px solid #abefc6; }
.alert.danger { background: #fef3f2; color: var(--danger); border-color: #fecdca; }
.alert.warning { background: #fffaeb; color: var(--warning); border-color: #fedf89; }
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; margin-top: 18px; }
.card {
  display: block;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 22px;
  min-height: 170px;
  box-shadow: 0 12px 40px rgba(15,23,42,.06);
  transition: transform .16s ease, box-shadow .16s ease;
}
.card:hover { transform: translateY(-2px); box-shadow: 0 18px 55px rgba(15,23,42,.1); }
.site-card { border-top: 6px solid var(--brand); }
.wheel-card { overflow: hidden; }
.pill {
  display: inline-flex;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: rgba(255,255,255,.2);
  color: inherit;
  border: 1px solid rgba(255,255,255,.3);
  margin-bottom: 12px;
}
.site-card .pill, .panel .pill, .customer-card .pill { background: #eef7f7; color: #116466; border-color: transparent; }
.tabs { display: flex; gap: 8px; flex-wrap: wrap; margin: 0 0 22px; }
.tabs a { background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: 9px 13px; font-weight: 800; font-size: 14px; }
.backlink { display: inline-block; margin-bottom: 14px; color: var(--muted); font-weight: 750; }
.table-wrap { overflow-x: auto; background: #fff; border: 1px solid var(--border); border-radius: 18px; }
table { width: 100%; border-collapse: collapse; min-width: 820px; }
th, td { text-align: left; padding: 12px 13px; border-bottom: 1px solid var(--border); vertical-align: top; }
th { font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); background: #f8fafc; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.metric { background: #fff; border: 1px solid var(--border); border-radius: 18px; padding: 18px; }
.metric strong { display: block; font-size: 34px; line-height: 1; margin-top: 8px; }
.play-shell {
  width: min(1200px, 100%);
  margin: -12px auto 0;
  border-radius: 32px;
  background: var(--page-bg);
  color: var(--text);
  padding: clamp(18px, 4vw, 42px);
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: clamp(18px, 4vw, 40px);
  min-height: 680px;
  align-items: center;
  box-shadow: 0 24px 80px rgba(15,23,42,.15);
}
.play-panel { display: grid; gap: 24px; align-items: center; }
.wheel-wrap { position: relative; width: min(520px, 90vw); margin: 0 auto; aspect-ratio: 1; }
#wheelCanvas { width: 100%; height: 100%; filter: drop-shadow(0 24px 35px rgba(0,0,0,.22)); }
.wheel-pointer { position: absolute; left: 50%; top: -13px; transform: translateX(-50%); font-size: 42px; color: var(--button); text-shadow: 0 4px 12px rgba(0,0,0,.25); z-index: 2; }
.customer-card { color: var(--text); background: rgba(255,255,255,.94); backdrop-filter: blur(8px); }
.result-box { margin-top: 16px; border-radius: 18px; padding: 18px; background: #ecfdf3; border: 1px solid #abefc6; color: #054f31; }
.result-box.error { background: #fef3f2; border-color: #fecdca; color: #912018; }
.hidden { display: none; }
.small-actions { display: flex; gap: 8px; flex-wrap: wrap; }
code { background: rgba(15,23,42,.08); padding: 2px 6px; border-radius: 6px; }
@media (max-width: 850px) {
  .play-shell, .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .container { width: min(100% - 22px, 1180px); margin-top: 18px; }
  .topbar { padding: 12px 14px; }
  .topbar nav { gap: 8px; }
}
.compact-grid { gap: 12px; }
details { border: 1px solid var(--border); border-radius: 14px; padding: 12px 14px; background: #fbfcfe; }
summary { cursor: pointer; font-weight: 850; }
.play-logo { max-width: 170px; max-height: 78px; object-fit: contain; margin-bottom: 18px; display: block; }
.play-shell .customer-card { border-radius: var(--card-radius); }

/* Premium UX wheel layer */
.premium-play {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.premium-play::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(circle at 18% 20%, rgba(255,255,255,.28), transparent 24%),
    radial-gradient(circle at 82% 76%, rgba(255,255,255,.16), transparent 30%);
  pointer-events: none;
  z-index: 0;
}
.premium-play > * { position: relative; z-index: 1; }
.confetti-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 5;
}
.hero-panel { align-self: stretch; align-content: center; }
.hero-copy { max-width: 620px; }
.site-pill { backdrop-filter: blur(8px); }
.wheel-stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 480px;
}
.wheel-glow {
  position: absolute;
  width: min(560px, 88vw);
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--button), transparent 50%), transparent 62%);
  filter: blur(24px);
  opacity: .86;
}
.premium-play .wheel-wrap {
  width: min(620px, 92vw);
  z-index: 1;
}
.premium-play #wheelCanvas {
  filter: drop-shadow(0 34px 55px rgba(0,0,0,.34));
  transform-origin: center;
}
.premium-play #wheelCanvas.is-spinning {
  animation: wheelPulse .7s ease-in-out infinite alternate;
}
@keyframes wheelPulse {
  from { transform: scale(1); }
  to { transform: scale(1.015); }
}
.premium-play .wheel-pointer {
  font-size: 54px;
  top: -21px;
  color: var(--button);
  filter: drop-shadow(0 8px 12px rgba(0,0,0,.25));
}
.game-card {
  display: grid;
  gap: 16px;
  align-content: start;
  min-height: 420px;
}
.game-step {
  animation: stepIn .35s ease both;
}
.game-step.active { display: block; }
.game-step.soft-hidden {
  opacity: .42;
  filter: grayscale(.25);
  transform: scale(.985);
  pointer-events: none;
}
@keyframes stepIn {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.mini-label {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 10px;
  background: color-mix(in srgb, var(--button), transparent 84%);
  color: color-mix(in srgb, var(--button), #111 40%);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.mega-spin {
  width: 100%;
  min-height: 58px;
  font-size: 18px;
  letter-spacing: .03em;
  box-shadow: 0 18px 45px color-mix(in srgb, var(--button), transparent 72%);
  position: relative;
  overflow: hidden;
}
.mega-spin::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.32), transparent);
  transform: translateX(-120%);
  animation: shine 2.4s ease-in-out infinite;
}
@keyframes shine {
  0%, 55% { transform: translateX(-120%); }
  100% { transform: translateX(120%); }
}
.micro-note {
  margin-top: 12px;
  color: var(--muted);
  font-size: 12px;
}
.result-hero {
  text-align: center;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.9), transparent 48%),
    linear-gradient(135deg, color-mix(in srgb, var(--button), white 80%), #fff);
  border-color: color-mix(in srgb, var(--button), white 62%);
  color: #17212b;
  box-shadow: 0 18px 50px rgba(15,23,42,.12);
}
.result-hero .reward-icon {
  font-size: 64px;
  line-height: 1;
  margin-bottom: 10px;
  animation: rewardPop .65s cubic-bezier(.18,.89,.32,1.28) both;
}
.result-hero h2 { font-size: clamp(28px, 4vw, 44px); }
.celebration-grand {
  border-width: 2px;
  background:
    radial-gradient(circle at 50% -10%, rgba(255,255,255,.98), transparent 45%),
    linear-gradient(135deg, #fff7d1, #fff, #f4e3b2);
}
.celebration-small .reward-icon { font-size: 50px; }
@keyframes rewardPop {
  0% { opacity: 0; transform: scale(.45) rotate(-10deg); }
  70% { opacity: 1; transform: scale(1.14) rotate(5deg); }
  100% { transform: scale(1) rotate(0); }
}
.final-reward {
  background: #ecfdf3;
  border-color: #abefc6;
  color: #054f31;
}
.clap-pop {
  position: fixed;
  left: 50%;
  top: 42%;
  transform: translate(-50%, -50%);
  z-index: 100;
  font-size: clamp(42px, 8vw, 86px);
  pointer-events: none;
  animation: clapPop 1.15s ease both;
  filter: drop-shadow(0 12px 24px rgba(0,0,0,.22));
}
@keyframes clapPop {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.5); }
  20% { opacity: 1; transform: translate(-50%, -50%) scale(1.12); }
  75% { opacity: 1; transform: translate(-50%, -68%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -92%) scale(.92); }
}
@media (max-width: 850px) {
  .premium-play .wheel-wrap { width: min(560px, 92vw); }
  .wheel-stage { min-height: 360px; }
  .game-card { min-height: auto; }
}
.media-preview {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 14px;
}
.media-preview img {
  max-width: 160px;
  max-height: 88px;
  object-fit: contain;
  border-radius: 10px;
  background: #fff;
  padding: 8px;
  border: 1px solid var(--border);
}
.media-preview.wide {
  align-items: flex-start;
  flex-direction: column;
}
.media-preview.wide img {
  width: 100%;
  max-width: 520px;
  max-height: 180px;
  object-fit: cover;
}
.table-logo {
  width: 54px;
  height: 34px;
  object-fit: contain;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--border);
  padding: 4px;
}
input[type="file"] {
  border: 1px dashed var(--border);
  background: #f8fafc;
  padding: 12px;
}

/* Prize admin UX */
.prize-toolbar {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 16px;
  align-items: end;
  margin-bottom: 18px;
}
.inline-filter {
  display: flex;
  gap: 12px;
  align-items: end;
  flex-wrap: wrap;
}
.inline-filter label { min-width: min(520px, 100%); }
.prize-help {
  background: #f8fafc;
  border: 1px dashed var(--border);
  border-radius: 16px;
  padding: 13px 15px;
  color: var(--muted);
  line-height: 1.45;
}
.admin-prize-layout { align-items: start; }
.prize-list-panel { position: sticky; top: 78px; max-height: calc(100vh - 100px); overflow: auto; }
.prize-card-list { display: grid; gap: 12px; }
.prize-admin-card {
  display: grid;
  grid-template-columns: 84px 1fr auto;
  gap: 14px;
  align-items: stretch;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 20px;
  padding: 12px;
  box-shadow: 0 10px 28px rgba(15,23,42,.06);
}
.prize-admin-card.is-off { opacity: .55; filter: grayscale(.25); }
.prize-swatch {
  border-radius: 17px;
  background: var(--swatch);
  background-size: cover;
  background-position: center;
  display: grid;
  place-items: center;
  min-height: 84px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.5), 0 10px 24px color-mix(in srgb, var(--swatch), transparent 72%);
}
.prize-swatch span { font-size: 34px; filter: drop-shadow(0 4px 8px rgba(0,0,0,.15)); }
.prize-card-main { display: grid; gap: 10px; min-width: 0; }
.prize-card-title { display: grid; gap: 2px; }
.prize-card-title strong { font-size: 16px; }
.prize-card-title span { color: var(--muted); font-size: 13px; }
.prize-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.prize-meta-grid span {
  background: #f8fafc;
  border: 1px solid #edf1f6;
  border-radius: 12px;
  padding: 8px 9px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.25;
}
.prize-meta-grid b { color: var(--text); font-size: 14px; }
.prize-meta-grid em { font-style: normal; color: var(--success); font-weight: 850; margin-left: 4px; }
.slice-preview { display: flex; gap: 4px; flex-wrap: wrap; min-height: 11px; }
.slice-preview i { display: block; width: 22px; height: 10px; border-radius: 999px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.55); }
.prize-card-actions { display: flex; align-items: center; }
.field-note { color: var(--muted); font-weight: 550; font-size: 12px; }
.section-gap { margin-top: 12px; }
.media-preview {
  display: flex;
  gap: 12px;
  align-items: center;
  margin: 12px 0;
  padding: 12px;
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid var(--border);
}
.media-preview img { width: 96px; height: 72px; object-fit: cover; border-radius: 12px; border: 1px solid var(--border); background: #fff; }
@media (max-width: 1050px) {
  .prize-toolbar { grid-template-columns: 1fr; }
  .prize-list-panel { position: static; max-height: none; }
}
@media (max-width: 760px) {
  .prize-admin-card { grid-template-columns: 64px 1fr; }
  .prize-card-actions { grid-column: 1 / -1; justify-content: flex-end; }
  .prize-meta-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .prize-swatch { min-height: 64px; }
}

.import-panel { margin: 18px 0; }
.import-actions { display: grid; grid-template-columns: 220px 1fr; gap: 16px; align-items: start; }
.excel-import-form { display: grid; grid-template-columns: minmax(220px, 1fr) minmax(260px, 1.2fr) auto; gap: 12px; align-items: end; }
.excel-import-form label { margin: 0; }
@media (max-width: 880px) { .import-actions, .excel-import-form { grid-template-columns: 1fr; } }

/* Preview helpers */
.preview-toolbar {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 6px;
}
.wheel-theme-preview {
  margin-top: 6px;
}
.wheel-theme-preview__shell {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  min-height: 310px;
  padding: 22px;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items: center;
  color: #fff;
  background: linear-gradient(135deg,#111111,#3A2C10);
  box-shadow: 0 18px 46px rgba(15,23,42,.14);
}
.wheel-theme-preview__shell::before {
  content: "";
  position: absolute;
  inset: -20%;
  background: radial-gradient(circle at 15% 20%, rgba(255,255,255,.18), transparent 20%), radial-gradient(circle at 88% 80%, rgba(255,255,255,.12), transparent 24%);
  pointer-events: none;
}
.wheel-theme-preview__hero,
.wheel-theme-preview__visual {
  position: relative;
  z-index: 1;
}
.wheel-theme-preview__logo {
  max-width: 150px;
  max-height: 64px;
  object-fit: contain;
  background: rgba(255,255,255,.82);
  border-radius: 12px;
  padding: 8px 10px;
  margin-bottom: 12px;
}
.wheel-theme-preview__hero h3 {
  font-size: clamp(26px, 3vw, 36px);
  margin: 0 0 8px;
  line-height: 1.05;
}
.wheel-theme-preview__hero p {
  margin: 0 0 16px;
  max-width: 46ch;
  opacity: .92;
}
.wheel-theme-preview__actions .btn {
  min-width: 180px;
  box-shadow: 0 14px 30px rgba(0,0,0,.18);
}
.wheel-theme-preview__visual {
  display: grid;
  place-items: center;
}
.wheel-theme-preview__disc {
  position: relative;
  width: min(260px, 54vw);
  aspect-ratio: 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  filter: drop-shadow(0 18px 32px rgba(0,0,0,.24));
}
.wheel-theme-preview__disc::before {
  content: "▼";
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 28px;
  text-shadow: 0 8px 18px rgba(0,0,0,.18);
}
.wheel-theme-preview__disc-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}
.wheel-theme-preview__center {
  position: relative;
  z-index: 1;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 900;
  letter-spacing: .06em;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
}
.prize-segment-preview {
  margin-top: 8px;
}
.prize-segment-preview__card {
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 14px;
  display: grid;
  gap: 14px;
}
.prize-segment-preview__segment {
  min-height: 118px;
  border-radius: 18px;
  padding: 16px;
  display: grid;
  align-items: end;
  background: #27BDBE;
  background-size: cover;
  background-position: center center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.42), 0 16px 34px rgba(15,23,42,.12);
}
.prize-segment-preview__content {
  display: flex;
  align-items: center;
  gap: 12px;
}
.prize-segment-preview__icon {
  font-size: 34px;
  line-height: 1;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.18));
}
.prize-segment-preview__label {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: .01em;
  text-shadow: 0 2px 10px rgba(0,0,0,.16);
}
.prize-segment-preview__meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.prize-segment-preview__meta div {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px 12px;
}
.prize-segment-preview__meta strong {
  display: block;
  font-size: 20px;
}
.prize-segment-preview__meta span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.prize-segment-preview__bars {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.prize-segment-preview__bars i {
  display: block;
  height: 12px;
  border-radius: 999px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
}
@media (max-width: 850px) {
  .wheel-theme-preview__shell { grid-template-columns: 1fr; }
  .prize-segment-preview__meta { grid-template-columns: 1fr; }
}

/* Celebration V2 */
.jackpot-pop, .fireworks-pop, .luxury-pop, .effect-preview-pop {
  position: fixed;
  left: 50%;
  top: 42%;
  transform: translate(-50%, -50%);
  z-index: 120;
  pointer-events: none;
  font-weight: 1000;
  letter-spacing: .08em;
  text-align: center;
  filter: drop-shadow(0 18px 34px rgba(0,0,0,.28));
}
.jackpot-pop {
  font-size: clamp(44px, 9vw, 110px);
  color: #ffd76a;
  text-shadow: 0 0 10px rgba(255,255,255,.9), 0 0 32px rgba(201,162,39,.75);
  animation: jackpotPop 1.7s ease both;
}
.fireworks-pop, .luxury-pop, .effect-preview-pop {
  font-size: clamp(52px, 10vw, 124px);
  animation: rewardPop 1.45s ease both;
}
.luxury-pop {
  color: #ffe7a6;
  text-shadow: 0 0 20px rgba(255,231,166,.72);
}
.celebration-flash {
  position: fixed;
  inset: 0;
  z-index: 110;
  pointer-events: none;
  background: radial-gradient(circle at 50% 42%, rgba(255,244,195,.70), transparent 38%), rgba(255,255,255,.16);
  animation: flashFade .9s ease both;
}
.celebration-balloon {
  position: fixed;
  left: 50%;
  top: 8%;
  transform: translateX(-50%);
  z-index: 121;
  pointer-events: none;
  width: 260px;
  height: 220px;
  display: grid;
  place-items: center;
}
.celebration-balloon span {
  font-size: 96px;
  animation: balloonDrop .75s cubic-bezier(.2,.9,.22,1.05) both;
}
.celebration-balloon b,
.celebration-balloon i {
  position: absolute;
  opacity: 0;
  font-style: normal;
  font-size: 76px;
}
.celebration-balloon.burst span { animation: balloonPop .48s ease both; }
.celebration-balloon.burst b { animation: ribbonBurst 1.1s ease both; }
.celebration-balloon.burst i { animation: ribbonBurst 1.1s ease .05s both reverse; }
.celebration-jackpot, .celebration-fireworks, .celebration-balloon_burst, .celebration-luxury_gold, .celebration-confetti_rich {
  position: relative;
  overflow: hidden;
}
.celebration-jackpot::after, .celebration-luxury_gold::after {
  content: "";
  position: absolute;
  inset: -30%;
  pointer-events: none;
  background: conic-gradient(from 0deg, transparent, rgba(255,215,106,.42), transparent, rgba(255,255,255,.38), transparent);
  animation: prizeShimmer 2.2s linear infinite;
  opacity: .42;
}
@keyframes jackpotPop {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.35) rotate(-8deg); }
  24% { opacity: 1; transform: translate(-50%, -50%) scale(1.16) rotate(2deg); }
  62% { opacity: 1; transform: translate(-50%, -58%) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -76%) scale(.95); }
}
@keyframes flashFade { from { opacity: 1; } to { opacity: 0; } }
@keyframes balloonDrop {
  from { opacity: 0; transform: translateY(-80px) scale(.74); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes balloonPop {
  0% { opacity: 1; transform: scale(1); }
  60% { opacity: .75; transform: scale(1.45); }
  100% { opacity: 0; transform: scale(.1); }
}
@keyframes ribbonBurst {
  0% { opacity: 0; transform: scale(.2) translate(0,0) rotate(0); }
  28% { opacity: 1; }
  100% { opacity: 0; transform: scale(1.8) translate(80px,-40px) rotate(35deg); }
}
@keyframes prizeShimmer { to { transform: rotate(1turn); } }
.effect-preview-pop {
  background: rgba(17,24,39,.86);
  color: #fff;
  border-radius: 28px;
  padding: 20px 28px;
  box-shadow: 0 22px 80px rgba(0,0,0,.28);
}
.effect-preview-pop.effect-jackpot { color: #ffd76a; }
.effect-preview-pop.effect-luxury_gold { color: #ffe7a6; }

/* Patch: chance calculator + improved effects */
.chance-calc-panel { margin: 18px 0; }
.chance-calc-output {
  display: grid;
  gap: 8px;
  align-content: center;
}
.chance-calc-output span,
.chance-calc-output strong {
  display: block;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 8px 10px;
}
.chance-calc-output em { color: var(--success); font-style: normal; font-weight: 900; }
.celebration-flash-strong {
  background:
    radial-gradient(circle at 50% 44%, rgba(255,244,195,.92), transparent 30%),
    radial-gradient(circle at 50% 50%, rgba(255,215,106,.38), transparent 56%),
    rgba(255,255,255,.20);
  animation: flashFade 1.4s ease both;
}
.jackpot-stage {
  position: fixed;
  inset: 0;
  z-index: 130;
  pointer-events: none;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.jackpot-rays {
  position: absolute;
  width: min(92vw, 760px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: repeating-conic-gradient(from 0deg, rgba(255,215,106,.42) 0 7deg, transparent 7deg 15deg);
  filter: blur(.2px) drop-shadow(0 0 30px rgba(255,215,106,.45));
  animation: jackpotRays 2.2s linear both;
  opacity: .82;
}
.jackpot-title {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  text-align: center;
  transform-origin: center;
  animation: jackpotTitle 2.25s cubic-bezier(.16,.98,.22,1) both;
}
.jackpot-title span {
  display: block;
  color: #ffd76a;
  font-size: clamp(56px, 12vw, 150px);
  line-height: .9;
  font-weight: 1000;
  letter-spacing: .08em;
  -webkit-text-stroke: 2px rgba(95,63,0,.42);
  text-shadow:
    0 0 6px rgba(255,255,255,.95),
    0 0 24px rgba(255,215,106,.90),
    0 18px 46px rgba(0,0,0,.32);
}
.jackpot-title small {
  display: inline-flex;
  margin-top: 10px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(17,24,39,.72);
  color: #fff8d3;
  font-weight: 950;
  letter-spacing: .18em;
  box-shadow: 0 12px 34px rgba(0,0,0,.24);
}
.jackpot-coins i {
  position: absolute;
  left: var(--left);
  top: -12vh;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff7b5, #ffd76a 42%, #b88400 100%);
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.35), 0 10px 20px rgba(0,0,0,.18);
  animation: coinFall 2.3s ease-in var(--delay) both;
}
.celebration-balloon-v2 {
  position: fixed;
  left: 50%;
  top: 11%;
  width: 330px;
  height: 300px;
  transform: translateX(-50%);
  z-index: 131;
  pointer-events: none;
  display: grid;
  place-items: center;
}
.balloon-core {
  position: relative;
  width: 150px;
  height: 150px;
  animation: balloonV2Drop .72s cubic-bezier(.2,.9,.22,1.05) both;
}
.balloon-core .half {
  position: absolute;
  top: 0;
  width: 76px;
  height: 150px;
  background: radial-gradient(circle at 58% 24%, #fff 0 5%, #ff7aa2 16%, #e84173 78%);
  box-shadow: inset -10px -16px 28px rgba(0,0,0,.16), 0 18px 32px rgba(0,0,0,.20);
}
.balloon-core .half.left { left: 0; border-radius: 76px 0 0 76px; transform-origin: right center; }
.balloon-core .half.right { right: 0; border-radius: 0 76px 76px 0; transform-origin: left center; }
.balloon-core b {
  position: absolute;
  left: 50%;
  bottom: -11px;
  width: 22px;
  height: 18px;
  background: #e84173;
  transform: translateX(-50%) rotate(45deg);
  border-radius: 3px;
}
.celebration-balloon-v2.burst .balloon-core .half.left { animation: balloonHalfLeft .78s ease both; }
.celebration-balloon-v2.burst .balloon-core .half.right { animation: balloonHalfRight .78s ease both; }
.celebration-balloon-v2.burst .balloon-core b { animation: balloonKnot .55s ease both; }
.balloon-ribbons i {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 9px;
  height: 42px;
  border-radius: 999px;
  background: var(--c);
  opacity: 0;
  box-shadow: 0 8px 18px rgba(0,0,0,.15);
}
.celebration-balloon-v2.burst .balloon-ribbons i {
  animation: ribbonExplode 1.35s ease var(--d) both;
}
@keyframes jackpotRays {
  0% { opacity: 0; transform: scale(.2) rotate(0deg); }
  18% { opacity: .95; transform: scale(1) rotate(45deg); }
  100% { opacity: 0; transform: scale(1.35) rotate(230deg); }
}
@keyframes jackpotTitle {
  0% { opacity: 0; transform: scale(.28) rotate(-7deg); }
  22% { opacity: 1; transform: scale(1.17) rotate(1deg); }
  55% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.08) translateY(-40px); }
}
@keyframes coinFall {
  0% { opacity: 0; transform: translate(0,0) rotateY(0deg) scale(.65); }
  10% { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--drift), 118vh) rotateY(920deg) rotate(180deg) scale(1); }
}
@keyframes balloonV2Drop {
  from { opacity: 0; transform: translateY(-105px) scale(.74); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes balloonHalfLeft {
  0% { opacity: 1; transform: rotate(0) translate(0,0) scale(1); }
  100% { opacity: 0; transform: rotate(-36deg) translate(-92px,-36px) scale(.72); }
}
@keyframes balloonHalfRight {
  0% { opacity: 1; transform: rotate(0) translate(0,0) scale(1); }
  100% { opacity: 0; transform: rotate(36deg) translate(92px,-36px) scale(.72); }
}
@keyframes balloonKnot {
  to { opacity: 0; transform: translate(-50%, 70px) rotate(80deg) scale(.45); }
}
@keyframes ribbonExplode {
  0% { opacity: 0; transform: translate(-50%,-50%) rotate(var(--r)) scale(.2); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: translate(calc(-50% + var(--x)), calc(-50% + var(--y))) rotate(calc(var(--r) + 260deg)) scale(1.06); }
}


/* Bulk chance/inventory editor */
.prize-bulk-panel { margin: 18px 0; }
.bulk-head {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
}
.bulk-prize-table { min-width: 980px; }
.bulk-prize-table td { vertical-align: middle; }
.bulk-prize-table input[type="number"] {
  min-width: 86px;
  padding: 9px 10px;
  border-radius: 10px;
}
.bulk-prize-name {
  display:flex;
  align-items:center;
  gap:10px;
  min-width: 220px;
}
.bulk-prize-name small {
  display:block;
  color: var(--muted);
  font-size: 12px;
  margin-top: 2px;
}
.bulk-dot {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display:grid;
  place-items:center;
  color:#fff;
  font-size: 19px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.45);
  flex: 0 0 auto;
}
.actual-pct { color: var(--success); }
.piece-pct { color: var(--muted); font-weight: 800; }
.toggle-mini {
  display:flex;
  align-items:center;
  gap:8px;
  font-size: 13px;
  font-weight: 800;
}
.toggle-mini input { width:auto; }
.bulk-actions {
  white-space: nowrap;
}
.bulk-actions .btn {
  padding: 9px 12px;
  font-size: 13px;
}
.bulk-footer {
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
  margin-top: 14px;
}

/* Patch 3: no-refresh admin UX, clearer color blocks, persistent award effects */
.color-field {
  display: grid;
  grid-template-columns: 64px 1fr;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}
.color-field input[type="color"],
input[type="color"] {
  width: 64px;
  height: 44px;
  padding: 3px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  cursor: pointer;
}
.color-field b {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #f8fafc;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
.inline-play-field {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 8px;
  align-items: center;
}
.bulk-save-status,
#prizeSaveStatus {
  font-weight: 850;
  color: var(--success);
}
.bulk-prize-form.is-saving,
#prizeForm.is-saving {
  opacity: .82;
}
.bulk-actions .btn[disabled],
#prizeSaveBtn[disabled] {
  opacity: .58;
  cursor: wait;
}
.bulk-dot {
  position: relative;
  overflow: hidden;
  min-width: 38px;
  min-height: 38px;
  border: 1px solid rgba(15,23,42,.08);
}
.bulk-dot::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.45), transparent 52%);
  pointer-events: none;
}
.prize-swatch {
  border: 1px solid rgba(15,23,42,.08);
}
.slice-preview i {
  min-width: 24px;
  height: 13px;
}
.result-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 14px;
}
.result-hero .mini-label {
  margin-bottom: 8px;
}
.result-hero h2 {
  margin-top: 8px;
}
.award-rain-canvas {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  z-index: 126;
  opacity: 0;
  transition: opacity .25s ease;
}
.award-rain-canvas.is-active { opacity: 1; }
.award-rain-stage,
.jackpot-moment {
  position: fixed;
  inset: 0;
  z-index: 127;
  pointer-events: none;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.award-rain-stage { z-index: 128; }
.award-rain-rays,
.jackpot-moment-rays {
  position: absolute;
  width: min(98vw, 900px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: repeating-conic-gradient(from 0deg, rgba(255,215,106,.5) 0 6deg, transparent 6deg 14deg);
  filter: drop-shadow(0 0 34px rgba(255,215,106,.52));
  opacity: .72;
  animation: awardRaysSpin 4.8s linear infinite;
}
.jackpot-moment-rays { animation: awardRaysBurst 2.05s ease both; }
.award-rain-title,
.jackpot-moment-title {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  text-align: center;
}
.award-rain-title span,
.jackpot-moment-title {
  display: block;
  color: #ffd76a;
  font-size: clamp(58px, 13vw, 170px);
  line-height: .88;
  font-weight: 1000;
  letter-spacing: .075em;
  -webkit-text-stroke: 2px rgba(83,55,0,.42);
  text-shadow:
    0 0 8px rgba(255,255,255,.95),
    0 0 28px rgba(255,215,106,.94),
    0 20px 54px rgba(0,0,0,.36);
}
.award-rain-title small {
  display: inline-flex;
  margin-top: 12px;
  padding: 9px 16px;
  border-radius: 999px;
  background: rgba(17,24,39,.78);
  color: #fff8d3;
  font-weight: 950;
  letter-spacing: .18em;
  box-shadow: 0 14px 40px rgba(0,0,0,.28);
}
.jackpot-moment-title {
  animation: jackpotMomentTitle 2.1s cubic-bezier(.16,.98,.22,1) both;
}
.celebration-balloon-real {
  position: fixed;
  left: 50%;
  top: 9%;
  width: 360px;
  height: 330px;
  transform: translateX(-50%);
  z-index: 132;
  pointer-events: none;
  display: grid;
  place-items: center;
}
.real-ball {
  position: relative;
  width: 166px;
  height: 166px;
  animation: realBallDrop .72s cubic-bezier(.2,.9,.22,1.05) both;
}
.real-ball .left,
.real-ball .right {
  position: absolute;
  top: 0;
  width: 84px;
  height: 166px;
  background: radial-gradient(circle at 60% 23%, #fff 0 5%, #ff7aa2 16%, #e84173 78%);
  box-shadow: inset -10px -16px 28px rgba(0,0,0,.16), 0 18px 32px rgba(0,0,0,.20);
}
.real-ball .left { left: 0; border-radius: 84px 0 0 84px; transform-origin: right center; }
.real-ball .right { right: 0; border-radius: 0 84px 84px 0; transform-origin: left center; }
.real-ball b {
  position: absolute;
  left: 50%;
  bottom: -11px;
  width: 24px;
  height: 19px;
  background: #e84173;
  transform: translateX(-50%) rotate(45deg);
  border-radius: 4px;
}
.celebration-balloon-real.burst .real-ball .left { animation: realBallLeft .82s ease both; }
.celebration-balloon-real.burst .real-ball .right { animation: realBallRight .82s ease both; }
.celebration-balloon-real.burst .real-ball b { animation: realBallKnot .58s ease both; }
.real-ribbons i {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  height: 48px;
  border-radius: 999px;
  background: var(--c);
  opacity: 0;
  box-shadow: 0 8px 18px rgba(0,0,0,.16);
}
.celebration-balloon-real.burst .real-ribbons i { animation: realRibbonExplode 1.35s ease var(--delay) both; }
@keyframes awardRaysSpin { to { transform: rotate(1turn); } }
@keyframes awardRaysBurst {
  0% { opacity: 0; transform: scale(.22) rotate(0); }
  25% { opacity: .96; transform: scale(1) rotate(55deg); }
  100% { opacity: 0; transform: scale(1.32) rotate(245deg); }
}
@keyframes jackpotMomentTitle {
  0% { opacity: 0; transform: scale(.28) rotate(-7deg); }
  18% { opacity: 1; transform: scale(1.17) rotate(1deg); }
  60% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.08) translateY(-42px); }
}
@keyframes realBallDrop {
  from { opacity: 0; transform: translateY(-110px) scale(.74); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes realBallLeft {
  0% { opacity: 1; transform: rotate(0) translate(0,0) scale(1); }
  100% { opacity: 0; transform: rotate(-38deg) translate(-105px,-42px) scale(.7); }
}
@keyframes realBallRight {
  0% { opacity: 1; transform: rotate(0) translate(0,0) scale(1); }
  100% { opacity: 0; transform: rotate(38deg) translate(105px,-42px) scale(.7); }
}
@keyframes realBallKnot {
  to { opacity: 0; transform: translate(-50%, 76px) rotate(80deg) scale(.45); }
}
@keyframes realRibbonExplode {
  0% { opacity: 0; transform: translate(-50%,-50%) rotate(var(--r)) scale(.2); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: translate(calc(-50% + var(--x)), calc(-50% + var(--y))) rotate(calc(var(--r) + 290deg)) scale(1.08); }
}

/* Admin UX patch: sound picker, clearer color blocks, chance helper */
.color-field {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}
.color-field input[type="color"] {
  width: 76px !important;
  min-width: 76px;
  height: 48px !important;
  padding: 4px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(15,23,42,.16) !important;
  background: #fff !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.08);
  cursor: pointer;
}
.color-field input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; }
.color-field input[type="color"]::-webkit-color-swatch { border: 0; border-radius: 10px; }
.color-field input[type="color"]::-moz-color-swatch { border: 0; border-radius: 10px; }
.sound-picker {
  display: grid;
  gap: 8px;
}
.sound-picker select {
  width: 100%;
}
.sound-custom-row.is-muted input {
  background: #f8fafc;
  color: var(--muted);
}
.inline-preview-field {
  grid-template-columns: minmax(0, 1fr) auto;
}
.chance-balance-tools {
  display: grid;
  gap: 10px;
  padding: 12px;
  margin: 12px 0;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(39,189,190,.07), rgba(201,162,39,.06));
}
.chance-total-status {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  border-radius: 999px;
  padding: 8px 12px;
  background: #eef2ff;
  color: #334155;
  font-weight: 900;
  letter-spacing: .01em;
}
.chance-total-status.is-ok {
  background: rgba(34,197,94,.12);
  color: #166534;
}
.chance-total-status.is-warn {
  background: rgba(245,158,11,.14);
  color: #92400e;
}
.chance-total-status.is-danger {
  background: rgba(239,68,68,.12);
  color: #991b1b;
}
.chance-tool-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.compact-check {
  margin: 0;
  min-height: 38px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
}
.bulk-color-block {
  display: grid;
  place-items: center;
  min-width: 48px;
  width: 48px;
  height: 42px;
  border-radius: 14px;
  background: var(--bulk-color);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.35), 0 10px 22px rgba(15,23,42,.10);
  border: 1px solid rgba(15,23,42,.10);
  position: relative;
  overflow: hidden;
}
.bulk-color-block::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.48), transparent 54%);
}
.bulk-color-block i {
  position: relative;
  z-index: 1;
  display: block;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.85);
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
}
@media (max-width: 760px) {
  .inline-preview-field,
  .inline-play-field {
    grid-template-columns: 1fr;
  }
  .color-field {
    grid-template-columns: 1fr;
  }
}

/* V2 sound/effect patch: category sound folders, clap icon, award-blast style grand prize */
.award-rain-content {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  text-align: center;
  gap: 8px;
  transform: translateY(-2vh);
}
.award-rain-trophy {
  font-size: clamp(92px, 13vw, 172px);
  line-height: .8;
  filter: drop-shadow(0 0 5px rgba(0,0,0,.55)) drop-shadow(0 22px 35px rgba(0,0,0,.25));
  animation: awardTrophyPulse 2s linear infinite;
}
.award-rain-stage .award-rain-title span {
  text-transform: uppercase;
  color: #222324;
  -webkit-text-stroke: 0;
  text-shadow: 8px 0 0 #FABE2C, 0 10px 35px rgba(255,215,106,.55), 0 25px 60px rgba(0,0,0,.34);
}
.award-rain-jackpot .award-rain-title span {
  color: #1b1b1b;
  text-shadow: 8px 0 0 #FABE2C, 0 0 24px rgba(255,255,255,.72), 0 28px 64px rgba(0,0,0,.35);
}
.clap-moment {
  position: fixed;
  inset: 0;
  z-index: 133;
  pointer-events: none;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.clap-hands {
  position: relative;
  width: 1px;
  height: 1px;
}
.clap-hands i {
  position: absolute;
  left: 0;
  top: 0;
  font-style: normal;
  font-size: clamp(34px, 6vw, 64px);
  transform: translate(var(--x), var(--y)) scale(.4) rotate(-8deg);
  opacity: 0;
  filter: drop-shadow(0 12px 22px rgba(0,0,0,.18));
  animation: clapHandsPop 1.18s ease var(--d) both;
}
@keyframes awardTrophyPulse {
  0% { transform: scale(1) rotate(-1deg); }
  25% { transform: scale(1.1) rotate(1deg); }
  50% { transform: scale(1); }
  75% { transform: scale(1.18) rotate(-1deg); }
  100% { transform: scale(1.06) rotate(1deg); }
}
@keyframes clapHandsPop {
  0% { opacity: 0; transform: translate(var(--x), calc(var(--y) + 45px)) scale(.38) rotate(-16deg); }
  18% { opacity: 1; transform: translate(var(--x), var(--y)) scale(1.08) rotate(8deg); }
  54% { opacity: 1; transform: translate(var(--x), calc(var(--y) - 18px)) scale(.98) rotate(-8deg); }
  100% { opacity: 0; transform: translate(var(--x), calc(var(--y) - 78px)) scale(.78) rotate(14deg); }
}


/* Claim-mode layout fix: keep grand-prize rain but stop it from covering form fields */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}
body.award-claim-mode .award-rain-stage,
body.award-claim-mode .jackpot-moment {
  opacity: 0 !important;
  visibility: hidden !important;
}
body.award-claim-mode .award-rain-canvas.is-active {
  opacity: .18 !important;
}
.premium-play.claim-mode {
  overflow: hidden;
}
.premium-play.claim-mode .hero-panel {
  overflow: hidden;
  align-content: start;
}
.premium-play.claim-mode .wheel-stage {
  min-height: 240px;
  max-height: 260px;
  overflow: hidden;
  transform: translateX(-18%) scale(.72);
  transform-origin: center;
  opacity: .46;
  pointer-events: none;
  transition: transform .28s ease, opacity .28s ease, max-height .28s ease;
}
.premium-play.claim-mode .wheel-glow {
  opacity: .22;
}
.premium-play.claim-mode .wheel-pointer {
  opacity: .5;
}
.premium-play.claim-mode .hero-copy {
  max-height: 205px;
  overflow: hidden;
}
.premium-play.claim-mode .customer-card {
  position: relative;
  z-index: 8;
}
.premium-play.claim-mode #claimForm {
  position: relative;
  z-index: 9;
}
@media (max-width: 850px) {
  .premium-play.claim-mode {
    padding-bottom: 18px;
  }
  .premium-play.claim-mode .wheel-stage {
    display: none;
  }
  .premium-play.claim-mode .hero-copy {
    max-height: 160px;
  }
  body.award-claim-mode .award-rain-canvas.is-active {
    opacity: .10 !important;
  }
}

/* Grand prize photo mode: full-viewport award rays + prize name frame */
.award-rain-stage,
.jackpot-moment {
  overflow: visible;
}
.award-rain-rays,
.jackpot-moment-rays {
  left: 50%;
  top: 50%;
  width: 260vmax;
  max-width: none;
  min-width: 2200px;
  transform: translate(-50%, -50%) rotate(0deg);
  opacity: .9;
  background: repeating-conic-gradient(from 0deg,
    rgba(255,215,106,.62) 0 5deg,
    rgba(255,255,255,.18) 5deg 8deg,
    transparent 8deg 14deg);
  filter: drop-shadow(0 0 64px rgba(255,215,106,.68));
}
.award-rain-content {
  width: min(94vw, 1180px);
  padding: clamp(18px, 3vw, 42px);
}
.award-rain-title {
  gap: 10px;
}
.award-rain-title small {
  order: -1;
  font-size: clamp(14px, 1.6vw, 24px);
}
.award-rain-prize {
  margin-top: clamp(8px, 1.4vw, 18px);
  padding: clamp(10px, 1.7vw, 20px) clamp(16px, 3vw, 42px);
  border-radius: 999px;
  background: rgba(17, 24, 39, .72);
  color: #fff8d3;
  font-weight: 950;
  font-size: clamp(24px, 4vw, 68px);
  line-height: 1.05;
  letter-spacing: .02em;
  text-align: center;
  max-width: min(92vw, 980px);
  box-shadow: 0 18px 70px rgba(0,0,0,.34), inset 0 0 0 1px rgba(255,255,255,.24);
  backdrop-filter: blur(8px);
}
.grand-photo-btn {
  width: 100%;
  border: 1px solid rgba(201,162,39,.52);
  background: linear-gradient(135deg, rgba(255,215,106,.2), rgba(255,255,255,.72));
  color: #1f2937;
  font-weight: 900;
  box-shadow: 0 10px 28px rgba(201,162,39,.16);
}
@keyframes awardRaysSpin {
  to { transform: translate(-50%, -50%) rotate(1turn); }
}
@keyframes awardRaysBurst {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(.18) rotate(0); }
  25% { opacity: .98; transform: translate(-50%, -50%) scale(1) rotate(55deg); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(1.18) rotate(245deg); }
}
@media (max-width: 640px) {
  .award-rain-rays,
  .jackpot-moment-rays {
    width: 300vmax;
    min-width: 1600px;
  }
  .award-rain-trophy { font-size: clamp(70px, 22vw, 130px); }
  .award-rain-title span { font-size: clamp(42px, 15vw, 96px); }
  .award-rain-prize { border-radius: 24px; }
}

/* Fireworks preset update + softer award rays */
.award-rain-rays,
.jackpot-moment-rays {
  opacity: .38;
  background: repeating-conic-gradient(from 0deg,
    rgba(255,215,106,.34) 0 5deg,
    rgba(255,255,255,.09) 5deg 8deg,
    transparent 8deg 15deg);
  filter: drop-shadow(0 0 38px rgba(255,215,106,.34));
}
.award-rain-luxury_gold .award-rain-rays {
  opacity: .30;
  background: repeating-conic-gradient(from 0deg,
    rgba(255,215,106,.26) 0 5deg,
    rgba(255,255,255,.07) 5deg 8deg,
    transparent 8deg 16deg);
  filter: drop-shadow(0 0 30px rgba(255,215,106,.25));
}
.award-rain-jackpot .award-rain-rays {
  opacity: .42;
}
.jackpot-moment-rays {
  opacity: .34;
}
.firework-show {
  position: fixed;
  inset: 0;
  z-index: 129;
  pointer-events: none;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at 50% 45%, rgba(255,255,255,.07), transparent 25%), linear-gradient(rgba(0,0,0,.10), rgba(0,0,0,.28));
  animation: fireworkShowIn .22s ease both;
}
.firework-sky {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.firework-show .firework,
.firework-show .firework::before,
.firework-show .firework::after {
  --initialSize: .55vmin;
  --finalSize: 48vmin;
  --particleSize: .28vmin;
  --color1: #fff7ad;
  --color2: #ffd76a;
  --color3: #ffffff;
  --color4: #67e8f9;
  --color5: #ff7aa2;
  --color6: #a7f3d0;
  --x: -50%;
  --y: -34vmin;
  --initialY: 58vmin;
  content: "";
  position: absolute;
  left: 50%;
  top: 54%;
  width: var(--initialSize);
  aspect-ratio: 1;
  transform: translate(var(--x), var(--initialY));
  animation: thdFireworkBurst 2.05s infinite;
  background:
    radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 50% 0%,
    radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 100% 50%,
    radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 50% 100%,
    radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 0% 50%,
    radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 80% 90%,
    radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 95% 90%,
    radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 90% 70%,
    radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 100% 60%,
    radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 55% 80%,
    radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 70% 77%,
    radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 22% 90%,
    radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 45% 90%,
    radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 33% 70%,
    radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 10% 60%,
    radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 31% 80%,
    radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 28% 77%,
    radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 13% 72%,
    radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 80% 10%,
    radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 95% 14%,
    radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 90% 23%,
    radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 100% 43%,
    radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 85% 27%,
    radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 77% 37%,
    radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 60% 7%,
    radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 22% 14%,
    radial-gradient(circle, var(--color2) var(--particleSize), #0000 0) 45% 20%,
    radial-gradient(circle, var(--color3) var(--particleSize), #0000 0) 33% 34%,
    radial-gradient(circle, var(--color4) var(--particleSize), #0000 0) 10% 29%,
    radial-gradient(circle, var(--color5) var(--particleSize), #0000 0) 31% 37%,
    radial-gradient(circle, var(--color6) var(--particleSize), #0000 0) 28% 7%,
    radial-gradient(circle, var(--color1) var(--particleSize), #0000 0) 13% 42%;
  background-size: var(--initialSize) var(--initialSize);
  background-repeat: no-repeat;
  filter: drop-shadow(0 0 12px rgba(255,255,255,.58));
}
.firework-show .firework::before {
  --x: -50%;
  --y: -50%;
  --initialY: -50%;
  transform: translate(-50%, -50%) rotate(40deg) scale(1.3) rotateY(40deg);
}
.firework-show .firework::after {
  --x: -50%;
  --y: -50%;
  --initialY: -50%;
  transform: translate(-50%, -50%) rotate(170deg) scale(1.15) rotateY(-30deg);
}
.firework-show .firework:nth-child(2),
.firework-show .firework:nth-child(2)::before,
.firework-show .firework:nth-child(2)::after {
  --color1: #f9a8d4;
  --color2: #f0abfc;
  --color3: #ffffff;
  --color4: #c084fc;
  --color5: #fb7185;
  --color6: #fde68a;
  --finalSize: 42vmin;
  left: 28%;
  top: 60%;
  animation-delay: -.25s;
}
.firework-show .firework:nth-child(3),
.firework-show .firework:nth-child(3)::before,
.firework-show .firework:nth-child(3)::after {
  --color1: #67e8f9;
  --color2: #bae6fd;
  --color3: #ffffff;
  --color4: #93c5fd;
  --color5: #a7f3d0;
  --color6: #e0f2fe;
  --finalSize: 38vmin;
  left: 72%;
  top: 60%;
  animation-delay: -.42s;
}
.firework-show .firework:nth-child(4),
.firework-show .firework:nth-child(4)::before,
.firework-show .firework:nth-child(4)::after {
  --finalSize: 34vmin;
  left: 18%;
  top: 38%;
  animation-delay: -.74s;
}
.firework-show .firework:nth-child(5),
.firework-show .firework:nth-child(5)::before,
.firework-show .firework:nth-child(5)::after {
  --color1: #fde68a;
  --color2: #fbbf24;
  --color3: #ffffff;
  --color4: #fef3c7;
  --color5: #fb923c;
  --color6: #facc15;
  --finalSize: 40vmin;
  left: 82%;
  top: 36%;
  animation-delay: -1.05s;
}
.firework-copy {
  position: relative;
  z-index: 2;
  display: grid;
  justify-items: center;
  gap: 9px;
  width: min(94vw, 1100px);
  padding: clamp(18px, 3vw, 44px);
  text-align: center;
  color: #fff;
  transform: translateY(-1vh);
}
.firework-copy small {
  display: inline-flex;
  padding: 9px 16px;
  border-radius: 999px;
  background: rgba(17,24,39,.70);
  color: #fff8d3;
  font-weight: 950;
  letter-spacing: .18em;
  box-shadow: 0 14px 40px rgba(0,0,0,.28);
}
.firework-copy strong {
  color: #ffffff;
  font-size: clamp(48px, 11vw, 150px);
  line-height: .9;
  font-weight: 1000;
  letter-spacing: .06em;
  text-shadow: 0 0 14px rgba(255,255,255,.85), 0 0 46px rgba(103,232,249,.65), 0 25px 70px rgba(0,0,0,.42);
}
.firework-prize {
  margin-top: 6px;
  padding: clamp(10px, 1.7vw, 20px) clamp(16px, 3vw, 42px);
  border-radius: 999px;
  background: rgba(17,24,39,.68);
  color: #fff8d3;
  font-weight: 950;
  font-size: clamp(24px, 4vw, 66px);
  line-height: 1.05;
  max-width: min(92vw, 980px);
  box-shadow: 0 18px 70px rgba(0,0,0,.34), inset 0 0 0 1px rgba(255,255,255,.20);
  backdrop-filter: blur(8px);
}
body.award-claim-mode .firework-show {
  opacity: 0 !important;
  visibility: hidden !important;
}
@keyframes thdFireworkBurst {
  0% { transform: translate(var(--x), var(--initialY)); width: var(--initialSize); opacity: 1; }
  50% { width: .55vmin; opacity: 1; }
  100% { width: var(--finalSize); opacity: 0; }
}
@keyframes fireworkShowIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@media (max-width: 640px) {
  .firework-copy strong { font-size: clamp(44px, 15vw, 92px); }
  .firework-prize { border-radius: 24px; }
}

/* Grand-prize availability/social-proof messaging */
.wheel-story-card {
  margin-top: 18px;
  max-width: 520px;
  border-radius: 22px;
  padding: 16px 18px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.12);
  color: inherit;
  box-shadow: 0 18px 40px rgba(0,0,0,.14);
  backdrop-filter: blur(12px);
}
.wheel-story-card strong,
.wheel-story-card span,
.wheel-story-card em { display: block; }
.wheel-story-card strong { font-size: .9rem; letter-spacing: .06em; text-transform: uppercase; }
.wheel-story-card span { margin-top: 4px; font-size: 1.1rem; font-weight: 850; }
.wheel-story-card em { margin-top: 7px; font-style: normal; opacity: .86; font-size: .92rem; }
.wheel-story-card.grand-available {
  background: linear-gradient(135deg, rgba(255,226,136,.28), rgba(255,255,255,.12));
  border-color: rgba(255,226,136,.42);
}
.wheel-story-card.grand-claimed {
  background: linear-gradient(135deg, rgba(20,20,20,.38), rgba(255,255,255,.10));
  border-color: rgba(255,255,255,.22);
}
.wheel-story-card.premium-available {
  background: linear-gradient(135deg, rgba(201,162,39,.20), rgba(255,255,255,.10));
  border-color: rgba(201,162,39,.34);
}
.next-best-note {
  margin: 12px 0 4px;
  padding: 11px 13px;
  border-radius: 14px;
  background: rgba(201,162,39,.12);
  border: 1px solid rgba(201,162,39,.22);
  font-size: .94rem;
}
.next-best-note strong { color: var(--primary, #27BDBE); }
@media (max-width: 760px) {
  .wheel-story-card { max-width: none; margin-top: 14px; }
}

/* Asset Library / Mascot support */
.asset-upload-grid { align-items: stretch; }
.asset-upload-card { min-height: 100%; }
.asset-table code { font-size: .82rem; word-break: break-all; }
.asset-preview-box {
  min-height: 180px;
  border: 1px dashed rgba(0,0,0,.16);
  border-radius: 18px;
  background: rgba(255,255,255,.55);
  display: grid;
  place-items: center;
  padding: 16px;
  margin: 12px 0 16px;
  overflow: hidden;
}
.asset-preview-image { max-width: min(220px, 100%); max-height: 180px; object-fit: contain; }
.asset-notes { margin: 0; padding-left: 20px; }
.asset-notes li { margin: 8px 0; }
.compact-checks { gap: 6px; align-self: end; }
.label-like { display: block; font-weight: 850; color: var(--muted-strong, #334155); }
.mascot-admin-preview { min-height: 140px; }

.mascot-mount {
  --mascot-size: 140px;
  position: fixed;
  width: var(--mascot-size);
  height: var(--mascot-size);
  z-index: 34;
  pointer-events: none;
  display: grid;
  place-items: center;
  filter: drop-shadow(0 18px 30px rgba(0,0,0,.22));
  animation: mascotFloat 3.4s ease-in-out infinite;
  transition: opacity .22s ease, transform .22s ease;
}
.mascot-mount.hidden { opacity: 0 !important; visibility: hidden; }
.mascot-mount img,
.mascot-mount svg { width: 100%; height: 100%; object-fit: contain; display: block; }
.mascot-pos-bottom_right { right: clamp(12px, 3vw, 42px); bottom: clamp(12px, 3vw, 42px); }
.mascot-pos-bottom_left { left: clamp(12px, 3vw, 42px); bottom: clamp(12px, 3vw, 42px); }
.mascot-pos-top_right { right: clamp(12px, 3vw, 42px); top: clamp(80px, 10vh, 130px); }
.mascot-pos-top_left { left: clamp(12px, 3vw, 42px); top: clamp(80px, 10vh, 130px); }
.mascot-intensity-subtle { opacity: .82; transform: scale(.92); }
.mascot-intensity-playful { opacity: .96; }
.mascot-intensity-full { opacity: 1; transform: scale(1.12); }
.mascot-mount[data-state="grand"] { transform: scale(1.16); animation-duration: 2.4s; }
.mascot-mount[data-state="spinning"] { transform: scale(.82); opacity: .64; animation-duration: 1.6s; }
.mascot-lottie-placeholder {
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  color: #111;
  font-weight: 900;
  border: 1px solid rgba(0,0,0,.12);
}
body.award-claim-mode .mascot-mount:not([data-state="claim"]) { opacity: 0 !important; visibility: hidden; }
@keyframes mascotFloat {
  0%, 100% { translate: 0 0; rotate: -1.5deg; }
  50% { translate: 0 -12px; rotate: 1.5deg; }
}
@media (max-width: 760px) {
  .mascot-mount { --mascot-size: 92px; }
  .mascot-pos-top_right, .mascot-pos-top_left { top: 72px; }
}
.asset-actions { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.asset-actions .btn { white-space: nowrap; }
.btn.is-copied { border-color: rgba(22,163,74,.35); background: rgba(22,163,74,.10); color: #166534; }
.asset-table td:last-child { min-width: 210px; }
.inline-form { display: inline; margin: 0; }
.btn.danger { border-color: rgba(180,35,24,.28); color: var(--danger); background: rgba(180,35,24,.06); }
.btn.danger:hover { background: rgba(180,35,24,.12); }

/* Asset library quick upload improvements */
.asset-jumpbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0 18px;
}
.asset-upload-feature {
  display: grid;
  grid-template-columns: minmax(220px, .85fr) minmax(320px, 1.15fr);
  gap: 18px;
  align-items: start;
  border: 1px solid rgba(184, 132, 46, .25);
  background: linear-gradient(135deg, rgba(255, 248, 232, .92), rgba(255, 255, 255, .96));
}
.asset-inline-upload input[type="file"],
.asset-library-upload-row input[type="file"] {
  padding: 10px;
  border: 1px dashed rgba(17, 24, 39, .24);
  border-radius: 12px;
  background: rgba(255,255,255,.8);
}
.asset-inline-details {
  margin: 12px 0 16px;
  border: 1px solid rgba(17, 24, 39, .08);
  border-radius: 14px;
  padding: 12px;
  background: rgba(248, 250, 252, .9);
}
.asset-inline-details summary {
  cursor: pointer;
  font-weight: 750;
  margin-bottom: 10px;
}
.asset-library-upload-row {
  display: grid;
  grid-template-columns: minmax(160px, .75fr) minmax(220px, 1.2fr) auto;
  gap: 10px;
  align-items: end;
}
.asset-library-upload-row input[name="lottie_category"] { min-height: 44px; }
@media (max-width: 800px) {
  .asset-upload-feature,
  .asset-library-upload-row { grid-template-columns: 1fr; }
}


.asset-empty-hint{margin-top:8px;padding:10px 12px;border:1px dashed rgba(201,162,39,.5);border-radius:12px;background:rgba(201,162,39,.08);font-size:.88rem;color:#4b3a12;line-height:1.45}
.asset-empty-hint code{background:rgba(0,0,0,.08);padding:1px 5px;border-radius:6px}

/* Lottie player status badges */
.status-pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 10px;font-size:.82rem;font-weight:700;border:1px solid rgba(17,24,39,.14);background:rgba(17,24,39,.06);color:#1f2937;vertical-align:middle}
.status-pill.success{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.28);color:#047857}
.status-pill.warning{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.32);color:#92400e}
.lottie-player-status code{white-space:nowrap}

/* Wheel v2 readability fixes: card text and full-piece image labels */
.play-shell .customer-card,
.play-shell .game-card {
  color: var(--card-text, #17212b);
}
.play-shell .customer-card h1,
.play-shell .customer-card h2,
.play-shell .customer-card h3,
.play-shell .game-card h1,
.play-shell .game-card h2,
.play-shell .game-card h3 {
  color: var(--card-text, #17212b);
}
.play-shell .customer-card .muted,
.play-shell .customer-card .micro-note,
.play-shell .customer-card .field-note,
.play-shell .game-card .muted,
.play-shell .game-card .micro-note,
.play-shell .game-card .field-note {
  color: var(--card-muted, #687384);
}
.play-shell .hero-copy,
.play-shell .hero-copy h1,
.play-shell .hero-copy p,
.play-shell .hero-copy .inverse {
  color: var(--text, #ffffff);
}
.prize-segment-preview__segment.has-image-bg .prize-segment-preview__content {
  color: #fff;
  filter: drop-shadow(0 3px 12px rgba(0,0,0,.58));
}
.prize-segment-preview__segment.has-image-bg .prize-segment-preview__label {
  text-shadow: 0 2px 16px rgba(0,0,0,.78), 0 0 12px rgba(0,0,0,.45);
}
.email-settings-note { line-height: 1.7; }
.panel .inline-form { display: grid; grid-template-columns: minmax(220px, 1fr) auto; gap: 12px; align-items: end; margin-top: 14px; }
.panel .inline-form label { margin: 0; }
.info-box { background: rgba(255,255,255,.72); border: 1px solid rgba(148,163,184,.25); border-radius: 18px; padding: 16px; }
.info-box h3 { margin-top: 0; }
@media (max-width: 720px) { .panel .inline-form { grid-template-columns: 1fr; } }

/* Email template library */
.mini-fieldset{border:1px solid rgba(148,163,184,.28);border-radius:16px;padding:14px;margin:12px 0;background:rgba(248,250,252,.68)}
.mini-fieldset legend{font-weight:800;padding:0 8px;color:#334155}
.email-preview-frame{width:100%;min-height:720px;border:1px solid rgba(148,163,184,.35);border-radius:18px;background:#fff;box-shadow:0 12px 34px rgba(15,23,42,.08)}

/* Theme preset controls */
.preset-toolbar{
  display:grid;
  grid-template-columns:minmax(260px,1fr) auto minmax(240px,1.2fr);
  gap:12px;
  align-items:end;
  margin:12px 0 16px;
  padding:14px;
  border:1px solid rgba(148,163,184,.28);
  border-radius:18px;
  background:rgba(248,250,252,.72);
}
.preset-toolbar label{margin:0}
.preset-toolbar .field-note{align-self:center;margin:0;line-height:1.45}
@media (max-width: 860px){.preset-toolbar{grid-template-columns:1fr}.preset-toolbar .btn{width:100%}}

/* Redemption / reports */
.status-pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;background:#eef2ff;color:#27346f;white-space:nowrap}
.status-redeemed{background:#e9f9ee;color:#106b31}.status-issued{background:#fff7df;color:#875800}.status-approval_pending,.status-approval-pending{background:#fff0f0;color:#9c2f2f}.status-cancelled{background:#f3f4f6;color:#6b7280}.status-expired{background:#f6e7ff;color:#6c2c91}.status-pending_claim,.status-pending-claim{background:#e0f7fa;color:#075763}
.stacked-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.stacked-actions form{margin:0}.stacked-actions .btn{width:100%;justify-content:center}
.report-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin:18px 0}.report-kpi-card{background:#fff;border:1px solid #e7ebf2;border-radius:22px;padding:18px;box-shadow:0 12px 30px rgba(15,23,42,.06)}.report-kpi-card>strong{display:block;margin-bottom:12px;font-size:16px}.kpi-row{display:flex;justify-content:space-between;border-top:1px dashed #edf0f5;padding:9px 0}.kpi-row span{color:#687384}.kpi-row b{font-size:18px}.bar-chart{display:flex;gap:8px;align-items:flex-end;min-height:170px;overflow-x:auto;padding:16px 4px 4px}.bar-col{min-width:34px;text-align:center;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:6px}.bar-col .bar{width:24px;border-radius:8px 8px 3px 3px;background:linear-gradient(180deg,var(--primary,#27bdbe),#111827);display:flex;align-items:flex-start;justify-content:center;color:#fff;font-size:10px;font-weight:800;padding-top:3px}.bar-col small{font-size:10px;color:#687384;white-space:nowrap}.horizontal-bars{display:flex;flex-direction:column;gap:10px}.hbar-row{display:grid;grid-template-columns:minmax(120px,1fr) 2fr 44px;gap:10px;align-items:center}.hbar-row span{font-size:13px;color:#273142;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hbar-row b{height:14px;border-radius:99px;background:linear-gradient(90deg,var(--primary,#27bdbe),#c9a227);min-width:4px}.hbar-row em{font-style:normal;font-weight:800;text-align:right}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.status-tile{border:1px solid #e7ebf2;border-radius:18px;padding:14px;background:#fbfdff}.status-tile strong{display:block;color:#64748b}.status-tile span{font-size:24px;font-weight:900;color:#111827}


/* Intro / attract screen before wheel play */
.play-shell.has-intro.intro-active {
  display: block;
}
.play-shell.has-intro.intro-active > .hero-panel,
.play-shell.has-intro.intro-active > .customer-card {
  display: none;
}
.intro-screen {
  min-height: min(780px, calc(100vh - 150px));
  display: grid;
  place-items: center;
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  padding: clamp(24px, 6vw, 72px);
  color: var(--text, #ffffff);
}
.intro-bg-layer {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 12%, rgba(255,255,255,.32), transparent 24%),
    radial-gradient(circle at 86% 82%, rgba(255,255,255,.18), transparent 32%),
    linear-gradient(135deg, rgba(0,0,0,.18), rgba(0,0,0,.30));
  pointer-events: none;
}
.intro-lucky-icon {
  position: absolute;
  right: clamp(18px, 5vw, 64px);
  top: clamp(18px, 5vw, 56px);
  z-index: 1;
  display: grid;
  place-items: center;
  width: clamp(92px, 14vw, 168px);
  height: clamp(92px, 14vw, 168px);
  border-radius: 999px;
  background: radial-gradient(circle at 35% 28%, rgba(255,255,255,.94), rgba(255,255,255,.35) 45%, rgba(255,255,255,.12));
  border: 1px solid rgba(255,255,255,.36);
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
  backdrop-filter: blur(10px);
  transform: rotate(4deg);
  animation: introLuckyFloat 3.8s ease-in-out infinite;
}
.intro-lucky-icon span {
  font-size: clamp(38px, 7vw, 78px);
  line-height: 1;
  filter: drop-shadow(0 8px 12px rgba(0,0,0,.22));
}
.intro-lucky-icon small {
  margin-top: -8px;
  color: rgba(17,24,39,.82);
  font-size: clamp(10px, 1.3vw, 13px);
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.intro-lucky-icon-lotto { background: radial-gradient(circle at 35% 26%, #fff8d7, rgba(255,255,255,.34) 48%, rgba(201,162,39,.22)); }
.intro-lucky-icon-sparkle { background: radial-gradient(circle at 35% 26%, #ffffff, rgba(255,247,214,.42) 48%, rgba(255,255,255,.16)); }
.intro-actions { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-top: 22px; }
.intro-actions .intro-start { margin-top: 0; }
.intro-sound-toggle {
  color: #fff;
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.28);
  box-shadow: 0 14px 32px rgba(0,0,0,.14);
}
.intro-sound-toggle:hover,
.intro-sound-toggle.is-playing {
  background: rgba(255,255,255,.26);
  border-color: rgba(255,255,255,.42);
}
.intro-sound-toggle.is-trying {
  opacity: .86;
}
.intro-sound-toggle.is-blocked {
  background: rgba(255,255,255,.22);
  border-color: rgba(255,255,255,.52);
  animation: introSoundNudge 1.35s ease-in-out infinite;
}
@keyframes introSoundNudge {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-2px); }
}
@keyframes introLuckyFloat {
  0%, 100% { translate: 0 0; rotate: 4deg; }
  50% { translate: 0 -12px; rotate: -3deg; }
}
.intro-content {
  position: relative;
  z-index: 1;
  width: min(1060px, 100%);
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, .85fr);
  gap: clamp(20px, 5vw, 54px);
  align-items: center;
}
.intro-layout-hero_only .intro-content,
.intro-layout-hero_rules .intro-content { grid-template-columns: 1fr; max-width: 820px; }
.intro-copy h1 {
  margin: 18px 0 14px;
  font-size: clamp(42px, 8vw, 96px);
  line-height: .94;
  letter-spacing: -.055em;
  color: inherit;
  text-shadow: 0 12px 32px rgba(0,0,0,.34);
}
.intro-copy p {
  max-width: 720px;
  font-size: clamp(17px, 2.3vw, 24px);
  line-height: 1.45;
  color: inherit;
  opacity: .95;
}
.intro-logo { max-width: 190px; max-height: 92px; object-fit: contain; margin-bottom: 16px; display: block; }
.intro-start { margin-top: 22px; font-size: 1.1rem; padding: 15px 26px; }
.intro-rules {
  margin-top: 18px;
  max-width: 720px;
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.24);
  backdrop-filter: blur(10px);
  color: inherit;
}
.intro-prize-teaser {
  display: grid;
  gap: 12px;
  padding: clamp(16px, 3vw, 24px);
  border-radius: 28px;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.26);
  box-shadow: 0 24px 70px rgba(0,0,0,.20);
  backdrop-filter: blur(14px);
}
.intro-prize-teaser > strong {
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .86rem;
  opacity: .88;
}
.intro-prize-pill {
  padding: 15px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.88);
  color: #17212b;
  box-shadow: 0 10px 26px rgba(0,0,0,.11);
}
.intro-prize-pill small { display: block; color: #64748b; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; font-size: .76rem; }
.intro-prize-pill span { display: block; margin-top: 3px; font-weight: 950; font-size: 1.04rem; }
.intro-prize-grand { background: linear-gradient(135deg, #fff3b0, #ffffff); }
.intro-prize-claimed { background: rgba(17,24,39,.86); color: #fff; }
.intro-prize-claimed small { color: rgba(255,255,255,.72); }
.intro-prize-premium { background: linear-gradient(135deg, #fff7d6, #f8fbff); }
.intro-screen.intro-exit { opacity: 0; transform: scale(.985); transition: opacity .22s ease, transform .22s ease; }
.staff-launch-card { display: grid; gap: 10px; }
.staff-launch-form { display: grid; gap: 10px; margin-top: 8px; }
.staff-launch-form label { color: inherit; }
.staff-launch-form select { margin-top: 6px; }
@media (max-width: 850px) {
  .intro-content { grid-template-columns: 1fr; }
  .intro-screen { min-height: calc(100vh - 110px); padding: 26px 18px; }
  .intro-prize-teaser { width: 100%; }
  .intro-lucky-icon { right: 14px; top: 14px; width: 76px; height: 76px; }
  .intro-lucky-icon small { display: none; }
  .intro-actions { align-items: stretch; }
  .intro-actions .btn { width: 100%; justify-content: center; }
}

/* Fix intro close: keep original two-column wheel layout after Start */
.intro-screen.hidden,
.play-shell.has-intro:not(.intro-active) > .intro-screen {
  display: none !important;
}


/* THD Wheel flow lock + full wheel shrink during claim/reward pending */
.play-shell.reward-pending #reSpinButton {
  display: none !important;
}
.premium-play.claim-mode .wheel-stage {
  display: grid;
  min-height: clamp(220px, 30vw, 320px);
  max-height: none;
  overflow: visible;
  transform: none;
  transform-origin: center;
  opacity: .62;
  pointer-events: none;
}
.premium-play.claim-mode .wheel-wrap {
  width: min(300px, 42vw);
}
.premium-play.claim-mode .wheel-glow {
  width: min(340px, 48vw);
  opacity: .22;
}
.premium-play.claim-mode .wheel-pointer {
  top: -14px;
  font-size: 36px;
  opacity: .55;
}
@media (max-width: 850px) {
  .premium-play.claim-mode .wheel-stage {
    display: grid;
    min-height: min(320px, 76vw);
    margin-bottom: 10px;
    opacity: .54;
  }
  .premium-play.claim-mode .wheel-wrap {
    width: min(300px, 72vw);
  }
  .premium-play.claim-mode .wheel-glow {
    width: min(340px, 78vw);
  }
  .premium-play.claim-mode .hero-copy {
    max-height: none;
  }
}


/* THD Wheel hard flow lock: Step 1 and restart must not show between spin and confirmed claim */
.game-step.hidden,
.game-step.active.hidden {
  display: none !important;
}
#reSpinButton,
.play-shell.reward-pending #reSpinButton,
.play-shell:not(.reward-confirmed) #reSpinButton {
  display: none !important;
}


/* Intro UI polish: reduce visual noise and make the start action dominant */
.footer.play-footer {
  display: none;
}
.play-shell.has-intro.intro-active {
  width: min(1160px, calc(100% - 28px));
  min-height: auto;
  padding: clamp(10px, 1.8vw, 18px);
  margin-top: 16px;
  box-shadow: 0 18px 60px rgba(15,23,42,.12);
}
.play-shell.has-intro.intro-active .mascot-mount {
  display: none !important;
}
.play-shell.has-intro.intro-active::before {
  opacity: .45;
}
.intro-screen {
  min-height: min(680px, calc(100vh - 92px));
  padding: clamp(26px, 5vw, 58px);
  border-radius: 26px;
}
.intro-bg-layer {
  background:
    linear-gradient(90deg, rgba(0,0,0,.64) 0%, rgba(0,0,0,.50) 44%, rgba(0,0,0,.30) 100%),
    radial-gradient(circle at 18% 14%, rgba(255,255,255,.24), transparent 24%),
    radial-gradient(circle at 88% 78%, rgba(255,255,255,.14), transparent 32%);
}
.intro-lucky-icon {
  display: none !important;
}
.intro-content {
  width: min(980px, 100%);
  grid-template-columns: minmax(0, 1.28fr) minmax(230px, .58fr);
  gap: clamp(18px, 4vw, 42px);
}
.intro-eyebrow {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.intro-eyebrow .intro-logo {
  flex: 0 0 auto;
  max-width: 86px;
  max-height: 66px;
  margin: 0 8px 0 0;
  padding: 7px;
  border-radius: 10px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
}
.intro-tier-pill {
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.26);
  color: rgba(255,255,255,.92);
  letter-spacing: .08em;
}
.intro-tier-premium .intro-tier-pill {
  background: rgba(255, 214, 102, .24);
  border-color: rgba(255, 214, 102, .38);
}
.intro-copy h1 {
  margin: 10px 0 12px;
  max-width: 680px;
  font-size: clamp(42px, 6.5vw, 78px);
  letter-spacing: -.052em;
}
.intro-copy p {
  max-width: 580px;
  font-size: clamp(16px, 2vw, 22px);
  line-height: 1.42;
}
.intro-actions {
  gap: 10px;
  margin-top: 20px;
}
.intro-start {
  margin-top: 0;
  padding: 14px 26px;
  font-size: 1.03rem;
  box-shadow: 0 14px 32px rgba(0,0,0,.22);
}
.intro-sound-toggle {
  min-height: 44px;
  padding: 10px 13px;
  font-size: .92rem;
  font-weight: 800;
  opacity: .76;
  box-shadow: none;
}
.intro-sound-toggle:hover,
.intro-sound-toggle.is-playing,
.intro-sound-toggle.is-blocked {
  opacity: 1;
}
.intro-sound-toggle.is-blocked {
  animation: none;
}
.intro-prize-teaser {
  justify-self: end;
  width: min(320px, 100%);
  gap: 9px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(17,24,39,.42);
  border-color: rgba(255,255,255,.20);
  box-shadow: 0 18px 46px rgba(0,0,0,.18);
  backdrop-filter: blur(12px);
}
.intro-prize-teaser > strong {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .78rem;
  letter-spacing: .075em;
}
.intro-teaser-icon {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(255,255,255,.90);
  color: #17212b;
  font-size: 17px;
  line-height: 1;
}
.intro-motion-badge {
  --intro-motion-size: 140px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
}
.intro-motion-badge img,
.intro-motion-badge svg {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}
.intro-motion-badge.intro-motion-lottie svg {
  transform: scale(1.18);
}
.intro-motion-badge.intro-motion-playful {
  width: 48px;
  height: 48px;
}
.intro-motion-badge.intro-motion-full {
  width: 54px;
  height: 54px;
}
.intro-motion-placeholder {
  color: #17212b;
  font-size: 20px;
  font-weight: 950;
}
.intro-prize-pill {
  padding: 11px 13px;
  border-radius: 14px;
  background: rgba(255,255,255,.91);
  box-shadow: none;
}
.intro-prize-pill small {
  font-size: .68rem;
  letter-spacing: .055em;
}
.intro-prize-pill span {
  margin-top: 2px;
  font-size: .96rem;
}
@media (max-width: 850px) {
  .play-shell.has-intro.intro-active {
    width: min(100% - 18px, 680px);
    margin-top: 10px;
    padding: 8px;
    border-radius: 24px;
  }
  .intro-screen {
    min-height: calc(100vh - 84px);
    padding: 22px;
    border-radius: 20px;
  }
  .intro-content {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .intro-eyebrow {
    margin-bottom: 12px;
  }
  .intro-eyebrow .intro-logo {
    max-width: 70px;
    max-height: 56px;
  }
  .intro-copy h1 {
    max-width: 100%;
    font-size: clamp(34px, 13vw, 58px);
  }
  .intro-copy p {
    max-width: 100%;
    font-size: 16px;
  }
  .intro-actions {
    align-items: center;
  }
  .intro-actions .intro-start {
    flex: 1 1 180px;
    width: auto;
  }
  .intro-actions .intro-sound-toggle {
    flex: 0 0 auto;
    width: auto;
    padding-inline: 12px;
  }
  .intro-prize-teaser {
    justify-self: stretch;
    width: 100%;
    padding: 14px;
    gap: 8px;
  }
  .intro-prize-teaser .intro-prize-pill:nth-of-type(n+4) {
    display: none;
  }
}

/* Intro reward teaser: show briefly, then let staff reopen on demand */
.intro-screen {
  overflow: hidden;
}
.intro-screen .intro-content {
  grid-template-columns: minmax(0, 1fr);
  position: relative;
  z-index: 2;
}
.intro-screen .intro-copy {
  max-width: 660px;
  position: relative;
  z-index: 3;
}
.intro-screen .intro-prize-teaser {
  position: absolute;
  right: clamp(22px, 6vw, 74px);
  top: 50%;
  transform: translateY(-50%);
  transition: transform .34s ease, opacity .24s ease, filter .24s ease;
  z-index: 4;
}
.intro-screen.intro-rewards-collapsed .intro-prize-teaser {
  transform: translate(calc(100% + 72px), -50%);
  opacity: 0;
  pointer-events: none;
  filter: blur(1px);
}
.intro-rewards-toggle {
  min-height: 42px;
  padding: 9px 13px;
  font-size: .88rem;
  font-weight: 900;
  border-radius: 999px;
  color: rgba(255,255,255,.88);
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.20);
  box-shadow: none;
  opacity: .74;
}
.intro-rewards-toggle:hover,
.intro-screen.intro-rewards-collapsed .intro-rewards-toggle {
  opacity: 1;
  background: rgba(255,255,255,.18);
}
.intro-screen:not(.intro-rewards-collapsed) .intro-rewards-toggle {
  opacity: .62;
}
.intro-screen:not(.intro-rewards-collapsed) .intro-rewards-toggle:hover {
  opacity: .92;
}
@media (min-width: 851px) {
  .intro-screen .intro-copy {
    padding-right: min(28vw, 330px);
  }
}
@media (max-width: 850px) {
  .intro-screen .intro-content {
    display: block;
  }
  .intro-screen .intro-copy {
    max-width: 100%;
  }
  .intro-screen .intro-prize-teaser {
    position: static;
    width: 100%;
    margin-top: 16px;
    transform: none;
    transition: max-height .28s ease, opacity .22s ease, margin .22s ease, padding .22s ease;
    overflow: hidden;
    max-height: 360px;
  }
  .intro-screen.intro-rewards-collapsed .intro-prize-teaser {
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin-top: 0;
    opacity: 0;
    transform: none;
    filter: none;
  }
  .intro-rewards-toggle {
    flex: 0 0 auto;
    width: auto;
    padding-inline: 12px;
  }
}


/* Hard guard for intro rewards slide-out. Added after main rules so stale/earlier rules cannot keep the teaser visible. */
.intro-screen.intro-rewards-collapsed .intro-prize-teaser,
.intro-screen .intro-prize-teaser.is-hard-hidden {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
@media (min-width: 851px) {
  .intro-screen.intro-rewards-collapsed .intro-prize-teaser,
  .intro-screen .intro-prize-teaser.is-hard-hidden {
    transform: translate3d(calc(100% + 120px), -50%, 0) !important;
  }
}
@media (max-width: 850px) {
  .intro-screen.intro-rewards-collapsed .intro-prize-teaser,
  .intro-screen .intro-prize-teaser.is-hard-hidden {
    max-height: 0 !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    transform: none !important;
  }
}
