/* Basic Setup */
:root {
  --primary: #7c3aed;
  --primary-hover: #6d28d9;
  --app-bg: #0f0e17;
  --app-card: #1e1c2e;
  --app-accent: #8b5cf6;
  --app-success: #4ade80;
  --app-error: #f87171;
}

body {
  font-family: 'Inter', sans-serif;
}

/* Hide scrollbar for clean UI in demos */
.no-scrollbar::-webkit-scrollbar {
  display: none;
}
.no-scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

/* Animation Classes (Replacements for Framer Motion) */

/* Fade In Up */
.fade-in-up {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fade-in-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Fade In Right */
.fade-in-right {
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fade-in-right.visible {
  opacity: 1;
  transform: translateX(0);
}

/* Scale Up */
.scale-up {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

.scale-up.visible {
  opacity: 1;
  transform: scale(1);
}

/* Pulse Animation (for Nudge Button) */
@keyframes pulse-shadow {
  0% { box-shadow: 0 0 0px rgba(139, 92, 246, 0); }
  50% { box-shadow: 0 0 20px rgba(139, 92, 246, 0.5); }
  100% { box-shadow: 0 0 0px rgba(139, 92, 246, 0); }
}

.pulse-animation {
  animation: pulse-shadow 2s infinite;
}

/* Hover Scale */
.hover-scale {
  transition: transform 0.2s;
}
.hover-scale:hover {
  transform: scale(1.05);
}
.hover-scale:active {
  transform: scale(0.95);
}

/* Rotation Animation for Rota Demo */
@keyframes pulse-scale {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

.animate-pulse-scale {
    animation: pulse-scale 2s infinite;
}
