/* Animaciones modernas y formales para services - SOLO header y tarjetas */

/* Estados iniciales - elementos ocultos */
.services_header {
    opacity: 0;
    transform: translateY(40px);
    transition: none;
}

.services_header h2 {
    opacity: 0;
    transform: translateY(20px);
    transition: none;
}

.services_header p {
    opacity: 0;
    transform: translateY(15px);
    transition: none;
}

.services_grid .grid_item {
    opacity: 0;
    transform: translateY(25px);
    transition: none;
}

/* Estados visibles - animaciones modernas activadas */
.services_header.animate {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), 
                transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.services_header.animate h2 {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s;
}

.services_header.animate p {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
}

/* Animaciones escalonadas para grid items - entrada secuencial */
.services_content.animate .services_grid .grid_item:nth-child(1) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s;
}

.services_content.animate .services_grid .grid_item:nth-child(2) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.3s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.3s;
}

.services_content.animate .services_grid .grid_item:nth-child(3) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s;
}

.services_content.animate .services_grid .grid_item:nth-child(4) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.5s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.5s;
}

.services_content.animate .services_grid .grid_item:nth-child(5) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.6s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.6s;
}

.services_content.animate .services_grid .grid_item:nth-child(6) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.7s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.7s;
}

.services_content.animate .services_grid .grid_item:nth-child(7) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.8s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.8s;
}

.services_content.animate .services_grid .grid_item:nth-child(8) {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.9s, 
                transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.9s;
}

/* Responsive - ajustes sutiles para móvil */
@media (max-width: 768px) {
    .services_header {
        transform: translateY(30px);
    }
    
    .services_header h2 {
        transform: translateY(15px);
    }
    
    .services_header p {
        transform: translateY(10px);
    }
    
    .services_grid .grid_item {
        transform: translateY(15px);
    }
}