/*!
 * CSS Común Funcional - Carruseles LPR
 * Solo estructura, layout, animaciones y responsive
 */

/* ===== FUNCIONALIDAD COMÚN ===== */
.swiper-posts-error,
.swiper-posts-no-content {
    padding: 15px;
    margin: 20px 0;
    text-align: center;
}

/* Navegación - solo estructura y animaciones */
.swiper-button-next,
.swiper-button-prev {
    width: 35px;
    height: 35px;
    margin-top: -17.5px;
    transition: all 0.3s ease;
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
    transform: scale(1.1);
}

.swiper-button-next:after,
.swiper-button-prev:after {
    font-size: 14px;
    font-weight: bold;
}

.swiper-button-disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.swiper-button-disabled:hover {
    transform: none;
}

/* Paginación - solo estructura */
.swiper-pagination {
    position: relative;
    margin-top: 20px;
}

.swiper-pagination-bullet {
    opacity: 0.5;
    width: 12px;
    height: 12px;
    margin: 0 6px;
    transition: all 0.3s ease;
}

.swiper-pagination-bullet:hover {
    opacity: 0.7;
    transform: scale(1.2);
}

.swiper-pagination-bullet-active {
    opacity: 1;
    transform: scale(1.3);
}

/* Transiciones generales */
a {
    transition: color 0.3s ease;
}

/* Animaciones de entrada */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.swiper-slide {
    animation: fadeInUp 0.5s ease-out;
}

/* Estados de carga */
.swiper-loading {
    position: relative;
    min-height: 200px;
}

.swiper-loading::after {
    content: "Cargando...";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* Accesibilidad - solo outline funcional */
.swiper-button-next:focus,
.swiper-button-prev:focus,
.swiper-pagination-bullet:focus {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

/* Optimización de renderizado */
* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Responsive estructural */
@media (max-width: 768px) {
    .swiper-button-next,
    .swiper-button-prev {
        display: none;
    }
    
    .swiper-pagination-bullet {
        width: 10px;
        height: 10px;
        margin: 0 4px;
    }
}

@media (max-width: 480px) {
    .swiper-pagination {
        margin-top: 15px;
    }
    
    .swiper-pagination-bullet {
        width: 8px;
        height: 8px;
        margin: 0 3px;
    }
}

/* Performance */
.swiper-slide img {
    will-change: transform;
}

.swiper-container {
    overflow: hidden;
}