:root {
  --bg-primary: #FFF8E7;
  --bg-secondary: #FFF0C8;
  --text-primary: #2D1B00;
  --text-secondary: #6B4F2D;
  --card-bg: #FFFFFF;
  --card-shadow: rgba(255, 165, 0, 0.15);
  --accent-1: #FF6B35;
  --accent-2: #FFD23F;
  --accent-3: #06D6A0;
  --accent-4: #118AB2;
  --accent-5: #EF476F;
  --modal-overlay: rgba(0,0,0,0.5);
}

[data-theme="dark"] {
  --bg-primary: #1A0A2E;
  --bg-secondary: #16213E;
  --text-primary: #F0E6FF;
  --text-secondary: #B8A9D4;
  --card-bg: #251749;
  --card-shadow: rgba(128, 0, 255, 0.2);
  --accent-1: #FF6B35;
  --accent-2: #FFD23F;
  --accent-3: #06D6A0;
  --accent-4: #4CC9F0;
  --accent-5: #F72585;
  --modal-overlay: rgba(0,0,0,0.7);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: 'Nunito', sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  min-height: 100vh;
  transition: background 0.4s ease, color 0.4s ease;
}

.font-fredoka { font-family: 'Fredoka', cursive; }

@keyframes wobble {
  0%, 100% { transform: rotate(0deg); }
  15% { transform: rotate(-5deg); }
  30% { transform: rotate(3deg); }
  45% { transform: rotate(-3deg); }
  60% { transform: rotate(2deg); }
  75% { transform: rotate(-1deg); }
}

@keyframes bounceIn {
  0% { transform: scale(0.3); opacity: 0; }
  50% { transform: scale(1.05); }
  70% { transform: scale(0.9); }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-10px); }
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

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

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

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes vibeNeedle {
  0% { transform: rotate(-90deg); }
  100% { transform: rotate(var(--vibe-angle)); }
}

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

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

.card-hover:hover {
  animation: wobble 0.6s ease-in-out;
  transform: scale(1.03);
  z-index: 10;
}

.card-hover {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card-hover:hover {
  box-shadow: 0 12px 40px var(--card-shadow);
}

.bounce-icon {
  animation: float 3s ease-in-out infinite;
}

.stagger-1 { animation-delay: 0.05s; }
.stagger-2 { animation-delay: 0.1s; }
.stagger-3 { animation-delay: 0.15s; }
.stagger-4 { animation-delay: 0.2s; }
.stagger-5 { animation-delay: 0.25s; }
.stagger-6 { animation-delay: 0.3s; }
.stagger-7 { animation-delay: 0.35s; }

.animate-in {
  animation: bounceIn 0.6s ease-out forwards;
  opacity: 0;
}

.gradient-chaos {
  background: linear-gradient(135deg, #FF6B35 0%, #FFD23F 25%, #06D6A0 50%, #4CC9F0 75%, #F72585 100%);
  background-size: 300% 300%;
  animation: gradientShift 8s ease infinite;
}

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

.modal-overlay {
  background: var(--modal-overlay);
  backdrop-filter: blur(8px);
  animation: fadeIn 0.2s ease;
}

.modal-content {
  animation: bounceIn 0.4s ease;
}

.vibe-gauge {
  background: conic-gradient(
    #EF476F 0%,
    #FF6B35 20%,
    #FFD23F 40%,
    #06D6A0 60%,
    #118AB2 80%,
    #4CC9F0 100%
  );
}

.scrollbar-hide::-webkit-scrollbar { display: none; }
.scrollbar-hide { -ms-overflow-style: none; scrollbar-width: none; }

.weather-icon-shadow {
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15));
}

@media (max-width: 768px) {
  .card-grid {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 16px;
    padding: 16px;
  }
  .card-grid > * {
    scroll-snap-align: center;
    flex: 0 0 280px;
  }
}

.loading-dots::after {
  content: '';
  animation: dots 1.5s steps(4, end) infinite;
}

@keyframes dots {
  0% { content: ''; }
  25% { content: '.'; }
  50% { content: '..'; }
  75% { content: '...'; }
  100% { content: ''; }
}