/* --- Animación de Carga de Página --- */
.fade-in-on-load {
    animation: fadeIn 0.8s ease-in-out forwards;
}

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

/* --- Animaciones de Scroll --- */
/* Estado inicial de los elementos que se animarán al hacer scroll */
.fade-in-section {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* Estado final (visible) que se aplicará con JavaScript */
.fade-in-section.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Efecto de delay para elementos en una misma sección */
.service-card:nth-child(2) {
    transition-delay: 0.2s;
}
.service-card:nth-child(3) {
    transition-delay: 0.4s;
}
.prop-item:nth-child(2) {
    transition-delay: 0.2s;
}
.prop-item:nth-child(3) {
    transition-delay: 0.4s;
}