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

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

@keyframes slideInLeft {
	from {
		opacity: 0;
		transform: translateX(-40px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(40px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes scaleIn {
	from {
		opacity: 0;
		transform: scale(0.9);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

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

.animate-on-scroll {
	opacity: 0;
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.animate-on-scroll.animated {
	opacity: 1;
}

.fade-in-up {
	animation: fadeInUp 0.8s ease-out forwards;
}

.fade-in {
	animation: fadeIn 0.8s ease-out forwards;
}

.slide-in-left {
	animation: slideInLeft 0.8s ease-out forwards;
}

.slide-in-right {
	animation: slideInRight 0.8s ease-out forwards;
}

.scale-in {
	animation: scaleIn 0.6s ease-out forwards;
}

.delay-1 {
	animation-delay: 0.1s;
}

.delay-2 {
	animation-delay: 0.2s;
}

.delay-3 {
	animation-delay: 0.3s;
}

.delay-4 {
	animation-delay: 0.4s;
}

@media (prefers-reduced-motion: reduce) {
	.animate-on-scroll,
	.fade-in-up,
	.fade-in,
	.slide-in-left,
	.slide-in-right,
	.scale-in {
		animation: none;
		opacity: 1;
		transform: none;
	}
}
