.roulette-page {
  display: grid;
  gap: var(--space-4);
}

.roulette-hero {
  padding: var(--space-7) var(--space-8);
}

/* ── Back link — 전체 게임 페이지 공통 ── */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: var(--space-5);
  padding: 8px 16px 8px 12px;
  border-radius: 999px;
  background: rgba(23, 32, 51, 0.06);
  border: 1px solid rgba(23, 32, 51, 0.1);
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background 150ms ease;
}
.back-link::before {
  content: '';
  display: block;
  width: 7px;
  height: 7px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateX(1px);
}
.back-link:hover {
  background: rgba(23, 32, 51, 0.11);
}

.roulette-hero .hero-note {
  margin-bottom: var(--space-4);
}

.roulette-hero__title {
  margin: 0;
  font-size: clamp(1rem, 2vw, 1.3rem);
  letter-spacing: -0.04em;
  line-height: 1.2;
}

.roulette-hero__body {
  max-width: 600px;
  margin: var(--space-3) 0 0;
  font-size: 0.88rem;
  line-height: 1.7;
  color: var(--text-secondary);
}

.roulette-layout {
  display: grid;
  gap: var(--space-5);
}

.roulette-stage,
.control-panel,
.history-panel {
  padding: var(--space-5);
}

.roulette-stage__header,
.control-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.roulette-stage__eyebrow,
.control-panel__eyebrow {
  margin: 0 0 6px;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: #b36b00;
}

.roulette-stage__title,
.control-panel__title {
  margin: 0;
  font-size: 1.35rem;
  letter-spacing: -0.03em;
}

.roulette-wheel-wrap {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 340px;
  padding: var(--space-3) 0 var(--space-4);
}

.roulette-wheel__shadow {
  position: absolute;
  inset: auto;
  width: min(80vw, 340px);
  height: min(80vw, 340px);
  border-radius: 50%;
  background: radial-gradient(circle at center, rgba(255, 186, 102, 0.18), rgba(255, 255, 255, 0) 70%);
  filter: blur(10px);
}

.roulette-wheel__pointer {
  position: absolute;
  top: 6px;
  z-index: 3;
  width: 0;
  height: 0;
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 28px solid #172033;
  filter: drop-shadow(0 8px 10px rgba(23, 32, 51, 0.12));
}

.roulette-wheel__disk {
  position: relative;
  z-index: 2;
  width: min(80vw, 340px);
  height: min(80vw, 340px);
  border-radius: 50%;
  /* transition은 JS의 Web Animations API가 대신 제어 */
}

.roulette-wheel__svg {
  width: 100%;
  height: 100%;
}

.roulette-wheel__slice-path {
  stroke: rgba(255, 255, 255, 0.7);
  stroke-width: 2;
}

.roulette-result {
  padding: var(--space-4);
  display: grid;
  gap: var(--space-3);
}

.roulette-result__label {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--text-muted);
}

.roulette-result__value {
  margin: 0;
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
}

.roulette-spin {
  width: 100%;
}

.roulette-side {
  display: grid;
  gap: var(--space-5);
}

.preset-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: var(--space-4);
}

.preset-chip {
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(23, 32, 51, 0.08);
  background: #fff7ef;
  font-weight: 700;
  color: #8f5600;
}

.option-list {
  display: grid;
  gap: 10px;
}

.option-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.option-row__index {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff3dc;
  color: #9d6400;
  font-size: 0.85rem;
  font-weight: 800;
}

.option-row__input {
  width: 100%;
  min-width: 0;
  height: 46px;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid rgba(23, 32, 51, 0.08);
  background: #ffffff;
  font: inherit;
  color: var(--text-primary);
}

.option-row__input:focus {
  outline: 3px solid rgba(251, 191, 36, 0.22);
  border-color: rgba(245, 158, 11, 0.45);
}

.option-row__remove {
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(23, 32, 51, 0.08);
  color: var(--text-secondary);
  background: #f8fafc;
  font-weight: 700;
}

.control-panel__hint {
  margin: var(--space-4) 0 0;
  font-size: 0.84rem;
  color: var(--text-muted);
}

.roulette-history {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  max-height: 310px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(23,32,51,0.15) transparent;
}

.roulette-history__item,
.roulette-history__empty {
  min-height: 52px;
  padding: 0 16px;
  border-radius: 18px;
  border: 1px solid rgba(23, 32, 51, 0.06);
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.roulette-history__item span,
.roulette-history__empty {
  color: var(--text-secondary);
  font-size: 0.88rem;
}

.roulette-history__item strong {
  font-size: 1rem;
  letter-spacing: -0.02em;
}

@media (min-width: 980px) {
  .roulette-layout {
    grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.75fr);
    align-items: start;
  }

  .roulette-wheel-wrap {
    min-height: 400px;
  }
}

@media (max-width: 560px) {
  .roulette-stage__header,
  .control-panel__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .option-row {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .option-row__remove {
    grid-column: 1 / -1;
  }
}


/* ── 포인터 드라마 반응 ── */
@keyframes pointer-drama {
  0%, 100% { transform: rotate(0deg) translateY(0); }
  20%       { transform: rotate(-12deg) translateY(-3px); }
  50%       { transform: rotate(12deg)  translateY(-1px); }
  75%       { transform: rotate(-7deg)  translateY(-2px); }
}

@keyframes pointer-reverse {
  0%        { transform: rotate(0deg)   translateY(0)    scaleX(1); }
  25%       { transform: rotate(-20deg) translateY(-8px) scaleX(0.85); }
  55%       { transform: rotate(20deg)  translateY(-6px) scaleX(1.15); }
  80%       { transform: rotate(-10deg) translateY(-3px) scaleX(0.95); }
  100%      { transform: rotate(0deg)   translateY(0)    scaleX(1); }
}

@keyframes pointer-celebrate {
  0%   { transform: scale(1)    translateY(0); }
  30%  { transform: scale(1.35) translateY(-10px); }
  55%  { transform: scale(0.9)  translateY(0); }
  75%  { transform: scale(1.15) translateY(-4px); }
  100% { transform: scale(1)    translateY(0); }
}

.roulette-wheel__pointer.is-drama {
  animation: pointer-drama 0.22s ease-in-out infinite;
  transform-origin: top center;
}
.roulette-wheel__pointer.is-reverse {
  animation: pointer-reverse 0.28s ease-in-out infinite;
  transform-origin: top center;
}
.roulette-wheel__pointer.is-celebrating {
  animation: pointer-celebrate 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  transform-origin: top center;
}

/* ── 결과 패널: 페이즈별 스타일 ── */
.roulette-result {
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease, background-color 220ms ease;
}

.roulette-result[data-spin-phase="spinning"] {
  border-color: rgba(245, 158, 11, 0.2);
  background: linear-gradient(180deg, rgba(255, 248, 232, 0.9), rgba(255, 255, 255, 0.85));
}

.roulette-result[data-spin-phase="fake"] {
  border-color: rgba(245, 158, 11, 0.38);
  background: linear-gradient(180deg, rgba(255, 241, 200, 0.95), rgba(255, 255, 255, 0.9));
  box-shadow: 0 12px 28px rgba(245, 158, 11, 0.1);
}

.roulette-result[data-spin-phase="reverse"] {
  border-color: rgba(239, 68, 68, 0.35);
  background: linear-gradient(180deg, rgba(255, 235, 235, 0.95), rgba(255, 255, 255, 0.9));
  box-shadow: 0 12px 28px rgba(239, 68, 68, 0.12);
  transform: translateY(-1px);
}

.roulette-result[data-spin-phase="settling"] {
  border-color: rgba(16, 185, 129, 0.3);
  background: linear-gradient(180deg, rgba(220, 252, 231, 0.92), rgba(255, 255, 255, 0.9));
  box-shadow: 0 12px 28px rgba(16, 185, 129, 0.1);
}

.roulette-result.is-celebrating,
.roulette-result.is-spinning {
  border-color: rgba(245, 158, 11, 0.26);
  background: linear-gradient(180deg, rgba(255, 240, 213, 0.96), rgba(255, 255, 255, 0.9));
  box-shadow: 0 18px 32px rgba(245, 158, 11, 0.14);
  transform: translateY(-1px);
}

/* 결과값 텍스트: 페이즈별 색상 */
.roulette-result[data-spin-phase="reverse"] .roulette-result__value {
  color: #dc2626;
}
.roulette-result[data-spin-phase="settling"] .roulette-result__value {
  color: #059669;
}
.roulette-result__value {
  transition: color 200ms ease;
}
