* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  background: linear-gradient(135deg, #0a0a0f 0%, #1a0a2e 50%, #0f0a1a 100%);
  min-height: 100vh;
  font-family: 'Space Grotesk', sans-serif;
  overflow-x: hidden;
}

.font-bangers {
  font-family: 'Bangers', cursive;
}

@keyframes gradientShift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes pulse {
  0%, 100% { box-shadow: 0 0 20px rgba(255, 0, 110, 0.5), 0 0 40px rgba(255, 0, 110, 0.3); }
  50% { box-shadow: 0 0 30px rgba(0, 245, 255, 0.6), 0 0 60px rgba(0, 245, 255, 0.4); }
}

@keyframes wobble {
  0%, 100% { transform: rotate(0deg); }
  25% { transform: rotate(-10deg) scale(1.1); }
  75% { transform: rotate(10deg) scale(1.1); }
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70%, 90% { transform: translateX(-5px); }
  20%, 40%, 60%, 80% { transform: translateX(5px); }
}

@keyframes typewriter {
  from { width: 0; }
  to { width: 100%; }
}

@keyframes floatUp {
  0% { opacity: 1; transform: translateY(0) scale(1); }
  100% { opacity: 0; transform: translateY(-100px) scale(1.5); }
}

@keyframes neonPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

@keyframes slideIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.gradient-text {
  background: linear-gradient(90deg, #9b4dca, #FF006E, #00F5FF, #39FF14, #9b4dca);
  background-size: 300% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 4s ease-in-out infinite;
}

.shake-effect {
  animation: shake 0.5s ease-in-out;
}

.dice-wobble:hover {
  animation: wobble 0.5s ease-in-out;
}

.neon-glow-pink {
  box-shadow: 0 0 10px #FF006E, 0 0 20px rgba(255, 0, 110, 0.5), inset 0 0 10px rgba(255, 0, 110, 0.2);
}

.neon-glow-blue {
  box-shadow: 0 0 10px #00F5FF, 0 0 20px rgba(0, 245, 255, 0.5), inset 0 0 10px rgba(0, 245, 255, 0.2);
}

.neon-glow-green {
  box-shadow: 0 0 10px #39FF14, 0 0 20px rgba(57, 255, 20, 0.5), inset 0 0 10px rgba(57, 255, 20, 0.2);
}

.glass-card {
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.chaos-button {
  animation: pulse 2s infinite;
  transition: all 0.3s ease;
}

.chaos-button:hover {
  transform: scale(1.05);
}

.chaos-button:active {
  transform: scale(0.95);
}

.confetti-particle {
  position: fixed;
  pointer-events: none;
  animation: floatUp 1s ease-out forwards;
  font-size: 24px;
  z-index: 1000;
}

.category-chip {
  transition: all 0.2s ease;
}

.category-chip:hover {
  transform: translateY(-2px);
}

.prompt-reveal {
  animation: slideIn 0.5s ease-out;
}

.slider-container input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 8px;
  border-radius: 4px;
  background: linear-gradient(90deg, #FF006E, #00F5FF);
  outline: none;
}

.slider-container input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  cursor: pointer;
  box-shadow: 0 0 10px #00F5FF;
}

.saved-drawer {
  transition: max-height 0.3s ease-out;
  overflow: hidden;
}

::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #FF006E, #00F5FF);
  border-radius: 4px;
}