/* Fade In Animations */
.fade-in {
    opacity: 0;
    animation: fadeIn 1.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.fade-in-delay {
    opacity: 0;
    animation: fadeIn 1.2s cubic-bezier(0.4, 0, 0.2, 1) 0.3s forwards;
}

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

/* Slide Up Animations */
.slide-up {
    opacity: 0;
    animation: slideUp 1s cubic-bezier(0.2, 0.8, 0.2, 1) 0.5s forwards;
}

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

/* Floating Orb Animations */
.orb-1 {
    animation: floatOrb1 15s ease-in-out infinite;
}

.orb-2 {
    animation: floatOrb2 20s ease-in-out infinite;
}

.orb-3 {
    animation: floatOrb3 18s ease-in-out infinite;
}

@keyframes floatOrb1 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(50px, 30px) scale(1.1); }
}

@keyframes floatOrb2 {
    0%, 100% { transform: translate(0, 0) rotate(0deg); }
    50% { transform: translate(-40px, -20px) rotate(180deg); }
}

@keyframes floatOrb3 {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(-25px, 20px) scale(1.05); }
}

/* Hover Effects */
.btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.service-card:hover h3 {
    color: var(--primary-color);
}

.modal-content {
    animation: modalSlideDown 0.4s cubic-bezier(0.1, 0.9, 0.2, 1);
}

@keyframes modalSlideDown {
    from { opacity: 0; transform: translateY(-50px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes shakeInput {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-8px); }
    40% { transform: translateX(8px); }
    60% { transform: translateX(-6px); }
    80% { transform: translateX(6px); }
}

.search-modal-input.shake,
#modalLocationFilter.shake {
    animation: shakeInput 0.5s ease;
}

@media (prefers-reduced-motion: reduce) {
    .fade-in,
    .fade-in-delay,
    .slide-up {
        opacity: 1;
        animation: none;
    }

    .orb-1,
    .orb-2,
    .orb-3 {
        animation: none;
    }

    .section-reveal {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .modal-content {
        animation: none;
    }

    .modal-region-row {
        transition: none;
    }

    .modal-region-row:hover {
        transform: none;
    }

    .btn:hover,
    .btn-primary:hover {
        transform: none;
    }
}
