@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@600&family=Nunito:wght@400;600;700&display=swap');

:root {
  --violet: #7a2fb6;
  --violet-deep: #4b1f73;
  --violet-soft: #caa3e6;
  --gold: #f6d78b;
  --cream: #fff7ee;
  --ink: #2b0f3a;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  display: grid;
  place-items: center;
  background:
    radial-gradient(1200px 800px at 10% 10%, #ffe5ff 0%, transparent 55%),
    radial-gradient(900px 600px at 90% 10%, #f3d9ff 0%, transparent 50%),
    radial-gradient(700px 600px at 50% 90%, #f9e7ff 0%, transparent 60%),
    linear-gradient(135deg, #fff6fb 0%, #f6e7ff 45%, #f8f1ff 100%);
  font-family: "Nunito", "Segoe UI", sans-serif;
  color: var(--ink);
  position: relative;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(43, 15, 58, 0.35);
  opacity: 0;
  transition: opacity 0.6s ease;
  pointer-events: none;
  z-index: 1;
}

body.dim::before {
  opacity: 1;
}

body.strobe::before {
  animation: strobe 0.35s linear infinite;
}

body.strobe-slow::before {
  animation: strobeSlow 0.7s ease-in-out infinite;
}

body.strobe .stage,
body.strobe-slow .stage {
  filter: blur(0.6px);
}

body.strobe .stage,
body.strobe-slow .stage {
  animation: stagePulse 0.9s ease-in-out infinite;
}

.stage {
  width: min(680px, 92vw);
  padding: 36px 30px 40px;
  border-radius: 28px;
  background: rgba(255, 247, 238, 0.9);
  box-shadow:
    0 30px 60px rgba(89, 32, 120, 0.18),
    inset 0 0 30px rgba(255, 255, 255, 0.7);
  position: relative;
  text-align: center;
  overflow: hidden;
  z-index: 2;
  animation: stageIdlePulse 5.5s ease-in-out infinite;
}

.stage::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #0b0b10;
  opacity: 0;
  transition: opacity 0.9s ease;
  pointer-events: none;
  z-index: 1;
}

.stage.darken::after {
  opacity: 0.92;
}

.stage > * {
  position: relative;
  z-index: 2;
}

#flash {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 45%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 65%),
    radial-gradient(circle at 30% 35%, rgba(255, 248, 255, 0.9) 0%, rgba(255, 255, 255, 0) 55%);
  opacity: 0;
  transform: scale(1);
  filter: blur(2px);
  pointer-events: none;
  z-index: 2;
}

#flash.active {
  animation: flashPop 0.45s ease-out;
}

.orb {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  margin: 0 auto 10px;
  background:
    radial-gradient(circle at 30% 30%, #ffffff 0%, #f8d5ff 45%, #b36bf7 70%, #6b2a9d 100%);
  box-shadow:
    0 0 40px rgba(122, 47, 182, 0.5),
    inset 0 0 20px rgba(255, 255, 255, 0.8);
  animation: shimmer 4s ease-in-out infinite, glowPulse 3.8s ease-in-out infinite;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.orb.bright {
  box-shadow:
    0 0 70px rgba(188, 120, 255, 0.95),
    0 0 120px rgba(255, 245, 255, 0.6),
    inset 0 0 30px rgba(255, 255, 255, 0.95);
}

#sparkles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 4;
}

.sparkle {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: radial-gradient(circle, #ffffff 0%, #ffd7ff 55%, rgba(255, 255, 255, 0) 70%);
  box-shadow: 0 0 12px rgba(255, 230, 255, 0.9);
  opacity: 0;
  animation: sparklePop 0.9s ease-out forwards;
}

.orb::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 35% 30%, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0) 55%),
    linear-gradient(120deg, rgba(255, 255, 255, 0) 38%, rgba(255, 255, 255, 0.85) 50%, rgba(255, 255, 255, 0) 62%);
  mix-blend-mode: screen;
  opacity: 0;
  border-radius: 50%;
  animation: shineSweep 5s ease-in-out infinite;
  pointer-events: none;
}

.orb::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: linear-gradient(110deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0) 38%,
    rgba(255, 255, 255, 0.95) 50%,
    rgba(255, 255, 255, 0) 62%,
    rgba(255, 255, 255, 0) 100%);
  filter: blur(6px);
  opacity: 0;
  mix-blend-mode: screen;
  animation: lightSweep 4.8s ease-in-out infinite;
  pointer-events: none;
}

h1 {
  font-family: "Cinzel", "Times New Roman", serif;
  color: var(--violet);
  margin: 6px 0 6px;
  font-size: clamp(2rem, 2.4vw + 1.4rem, 2.8rem);
  letter-spacing: 0.03em;
}

.tagline {
  margin: 0 0 18px;
  color: var(--violet-deep);
  font-weight: 600;
}

.prompt {
  display: block;
  text-align: left;
  font-weight: 600;
  color: var(--violet);
  margin: 14px 0 8px;
}

#question {
  width: 100%;
  border: 2px solid var(--violet-soft);
  border-radius: 14px;
  padding: 12px 14px;
  font-size: 1rem;
  background: #fff;
  color: var(--ink);
  box-shadow: 0 6px 12px rgba(109, 36, 173, 0.08);
}

#voiceSelect {
  width: 100%;
  border: 2px solid var(--violet-soft);
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 0.98rem;
  background: #fff;
  color: var(--ink);
  box-shadow: 0 6px 12px rgba(109, 36, 173, 0.08);
}

.voice-row {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 6px;
}

.small {
  padding: 9px 14px;
  font-size: 0.9rem;
}

.actions {
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

button {
  border: none;
  border-radius: 999px;
  padding: 12px 22px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

button:active {
  transform: scale(0.98);
}

.primary {
  background: linear-gradient(135deg, var(--violet) 0%, #9d5bd9 100%);
  color: white;
  box-shadow: 0 10px 20px rgba(122, 47, 182, 0.35);
}

.ghost {
  background: #fff;
  color: var(--violet);
  border: 2px solid var(--violet-soft);
}

.answer {
  margin-top: 22px;
  padding: 16px;
  border-radius: 18px;
  background: linear-gradient(135deg, #fff1ff 0%, #f8eaff 100%);
  border: 1px solid #e7c7ff;
  opacity: 0;
  transform: translateY(6px);
}

.answer.reveal {
  animation: answerRise 1.2s ease forwards;
}

.answer-label {
  font-weight: 600;
  color: var(--violet-deep);
  margin-bottom: 6px;
}

.answer-text {
  font-family: "Cinzel", "Times New Roman", serif;
  color: var(--violet);
  font-size: 1.3rem;
  letter-spacing: 0.02em;
}

.answer.reveal .answer-text {
  animation: textGlow 2.6s ease-in-out forwards;
}

.hint {
  margin-top: 16px;
  font-size: 0.95rem;
  color: var(--violet-deep);
}

.fade-out {
  animation: fadeOut 0.6s ease forwards;
}

@keyframes shimmer {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.03); }
}

@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 40px rgba(122, 47, 182, 0.5), inset 0 0 20px rgba(255, 255, 255, 0.8); }
  50% { box-shadow: 0 0 55px rgba(138, 72, 196, 0.75), inset 0 0 26px rgba(255, 255, 255, 0.95); }
}

@keyframes shineSweep {
  0% { opacity: 0; transform: rotate(0deg) scale(0.9); }
  20% { opacity: 0.9; }
  50% { opacity: 0.2; transform: rotate(30deg) scale(1.05); }
  100% { opacity: 0; transform: rotate(60deg) scale(0.95); }
}

@keyframes lightSweep {
  0% { opacity: 0; transform: translateX(-25%) rotate(-18deg); }
  18% { opacity: 0.15; }
  40% { opacity: 0.9; }
  60% { opacity: 0.2; transform: translateX(10%) rotate(6deg); }
  100% { opacity: 0; transform: translateX(25%) rotate(18deg); }
}

@keyframes fadeOut {
  to { opacity: 0; transform: translateY(10px); }
}

@keyframes flashPop {
  0% { opacity: 0; transform: scale(0.98); }
  20% { opacity: 1; transform: scale(1.02); }
  45% { opacity: 0.7; transform: scale(1.01); }
  100% { opacity: 0; transform: scale(1); }
}

@keyframes sparklePop {
  0% { opacity: 0; transform: scale(0.6); }
  20% { opacity: 1; transform: scale(1.1); }
  100% { opacity: 0; transform: scale(0.2); }
}

@keyframes strobe {
  0% { opacity: 0.2; }
  25% { opacity: 0.7; }
  50% { opacity: 0.35; }
  75% { opacity: 0.9; }
  100% { opacity: 0.2; }
}

@keyframes strobeSlow {
  0% { opacity: 0.25; }
  40% { opacity: 0.6; }
  70% { opacity: 0.35; }
  100% { opacity: 0.2; }
}

@keyframes stagePulse {
  0% { opacity: 0.9; }
  50% { opacity: 0.7; }
  100% { opacity: 0.9; }
}

@keyframes stageIdlePulse {
  0% { opacity: 0.95; }
  50% { opacity: 0.88; }
  100% { opacity: 0.95; }
}

@keyframes answerRise {
  0% { opacity: 0; transform: translateY(10px); }
  100% { opacity: 1; transform: translateY(0); }
}

@keyframes textGlow {
  0% { text-shadow: 0 0 0 rgba(122, 47, 182, 0); }
  40% { text-shadow: 0 0 18px rgba(160, 90, 220, 0.65), 0 0 32px rgba(122, 47, 182, 0.55); }
  100% { text-shadow: 0 0 10px rgba(122, 47, 182, 0.45); }
}

@media (max-width: 520px) {
  .stage {
    padding: 28px 22px 32px;
  }

  .actions {
    flex-direction: column;
  }
}
