

.slide-up-element {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--transition-normal) ease, transform var(--transition-normal) ease;
}

.slide-up-element.reveal-active {
  opacity: 1;
  transform: translateY(0);
}


.skeleton-pulse {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: loadingPulse 1.5s infinite;
}

@keyframes loadingPulse {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}


.spinner {
  width: 24px;
  height: 24px;
  border: 3px solid rgba(255, 107, 53, 0.2);
  border-radius: 50%;
  border-top-color: var(--color-secondary);
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}


.search-dropdown-anim {
  animation: dropdownFade 0.2s forwards cubic-bezier(0.16, 1, 0.3, 1);
}

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


.toast-slide-in {
  animation: toastIn 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}

@keyframes toastIn {
  from { transform: translateX(120%); }
  to { transform: translateX(0); }
}

.toast-slide-out {
  animation: toastOut 0.3s ease forwards;
}

@keyframes toastOut {
  from { transform: translateX(0); opacity: 1; }
  to { transform: translateX(120%); opacity: 0; }
}


.heart-pop {
  animation: heartPopEffect 0.3s ease;
}

@keyframes heartPopEffect {
  0% { transform: scale(1); }
  50% { transform: scale(1.3); }
  100% { transform: scale(1); }
}


.live-pulse {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--color-success);
  box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.4);
  animation: pulseEffect 2s infinite;
}

@keyframes pulseEffect {
  0% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 8px rgba(16, 185, 129, 0);
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0);
  }
}
