/* CSS para el carrusel paralaje 3D */
.parallax-carousel-container {
    position: relative;
    height: auto; /* Adaptarse al contenido */
    display: flex;
    align-items: flex-start; /* Alinear al inicio para eliminar espacio superior */
    justify-content: center;
    overflow: visible; /* No cortar las imágenes */
    padding: 10px 20px 25px 20px; /* Reducir padding inferior para subir navegación */
    min-height: auto; /* Eliminar altura mínima fija */
}

.cards-container {
    position: relative;
    width: 100%;
    max-width: 350px; /* Hacer las fotos más grandes */
    height: 440px; /* Aumentar altura proporcionalmente */
    perspective: 1000px;
    margin: 0 auto; /* Centrar horizontalmente sin margen superior */
}

.card {
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 20px; /* Bordes redondeados de 20px como solicitado */
    overflow: hidden;
    transform-origin: center center;
    will-change: transform, opacity;
    /* Mantener proporción sin forzar aspect-ratio que puede causar problemas */
}

.card-image {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Mantiene la proporción de la imagen y cubre el contenedor */
    object-position: center; /* Centra la imagen */
}

.carousel-nav {
    position: absolute;
    bottom: -15px; /* Subir los puntos mucho más cerca de las fotos */
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    gap: 10px;
}

.nav-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: rgba(0, 0, 0, 0.15);
    border: none;
    cursor: pointer;
    transition: all 0.3s;
}

.nav-dot.active {
    width: 24px;
    border-radius: 6px;
    background-color: #3C70C4;
}

.nav-arrow {
    position: absolute;
    top: 50%; /* Centrar verticalmente */
    transform: translateY(-50%);
    width: 40px; /* Reducir tamaño */
    height: 40px;
    border-radius: 50%;
    background-color: rgba(0,0,0,0.2);
    color: white;
    border: none;
    font-size: 20px; /* Reducir tamaño del texto */
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.3s, background-color 0.3s;
    z-index: 100;
}

.nav-arrow:not([disabled]):hover {
    background-color: rgba(255,255,255,0.3);
}

.nav-arrow[disabled] {
    cursor: default;
}

.nav-arrow.prev { left: 145px; } /* Acercar las flechas más a las fotos */
.nav-arrow.next { right: 145px; }

/* Responsive adjustments */
@media (max-width: 768px) {
    .parallax-carousel-container {
        padding: 5px 10px 20px 10px; /* Reducir padding inferior en móvil */
    }
    
    .cards-container {
        max-width: 280px; /* Más grande en móvil también */
        height: 350px;
    }
    
    .nav-arrow.prev { left: -30px; } /* Flechas más cerca en móvil */
    .nav-arrow.next { right: -30px; }
    
    .carousel-nav {
        bottom: -10px; /* Más cerca en móvil */
    }
}

@media (min-width: 1024px) {
    .parallax-carousel-container {
        padding: 15px 30px 30px 30px; /* Reducir padding inferior en desktop */
    }
    
    .cards-container {
        max-width: 380px; /* Aún más grande en desktop */
        height: 480px;
    }
    
    .nav-arrow.prev { left: 145px; } /* Flechas más cerca en desktop */
    .nav-arrow.next { right: 75px; }
}