/**
 * File: /sisme-games-editor/includes/cards/assets/cards-carousel.css
 * STYLES POUR LES CARROUSELS DE CARTES
 * 
 * CONTENU:
 * - Carrousels avec navigation
 * - Styles responsives pour mobile
 * - Boutons et pagination
 * - Mode infinite
 * 
 * DÉPENDANCES:
 * - cards.css (styles de base)
 */

/* ========================================
   🎠 CARROUSEL PRINCIPAL
======================================== */

.sisme-cards-carousel {
    position: relative;
    max-width: 1200px;
    margin: 0 auto var(--sisme-space-xl, 32px) auto;
    padding: 0 60px;
    touch-action: pan-x;
}

/* Container du carrousel */
.sisme-carousel__container {
    overflow: hidden;
    border-radius: var(--sisme-radius-lg, 12px);
    position: relative;
}

/* Track du carrousel */
.sisme-carousel__track {
    display: flex;
    transition: transform 0.3s ease;
    will-change: transform;
    backface-visibility: hidden;
    user-select: none;
}

/* ========================================
   🎯 SLIDES DU CARROUSEL
======================================== */

.sisme-carousel__slide {
    flex: 0 0 auto;
    padding: 0 10px;
    box-sizing: border-box;
    min-width: 0;
}

/* Largeur des slides selon le nombre de cartes par vue */
.sisme-cards-carousel[data-cards-per-view="1"] .sisme-carousel__slide {
    width: 100%;
}

.sisme-cards-carousel[data-cards-per-view="2"] .sisme-carousel__slide {
    width: 50%;
}

.sisme-cards-carousel[data-cards-per-view="3"] .sisme-carousel__slide {
    width: 33.333%;
}

.sisme-cards-carousel[data-cards-per-view="4"] .sisme-carousel__slide {
    width: 25%;
}

.sisme-cards-carousel[data-cards-per-view="5"] .sisme-carousel__slide {
    width: 20%;
}

/* ========================================
   🎴 CARTES DANS LE CARROUSEL
======================================== */

.sisme-carousel__slide .sisme-game-card {
    width: 100%;
    height: 100%;
    min-height: 400px;
    margin: 0;
}

.sisme-carousel__slide .sisme-card-image {
    height: 200px;
}

/* Ajustement des hauteurs selon le nombre de cartes */
.sisme-cards-carousel[data-cards-per-view="2"] .sisme-card-image {
    height: 240px;
}

.sisme-cards-carousel[data-cards-per-view="3"] .sisme-card-image {
    height: 200px;
}

.sisme-cards-carousel[data-cards-per-view="4"] .sisme-card-image {
    height: 180px;
}

.sisme-cards-carousel[data-cards-per-view="5"] .sisme-card-image {
    height: 160px;
}

/* Ajustement du contenu texte */
.sisme-cards-carousel[data-cards-per-view="4"] .sisme-card-title,
.sisme-cards-carousel[data-cards-per-view="5"] .sisme-card-title {
    font-size: var(--sisme-text-base, 16px);
}

.sisme-cards-carousel[data-cards-per-view="4"] .sisme-card-description,
.sisme-cards-carousel[data-cards-per-view="5"] .sisme-card-description {
    font-size: var(--sisme-text-sm, 14px);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ========================================
   ⬅️➡️ BOUTONS DE NAVIGATION
======================================== */

.sisme-carousel__btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.7);
    color: white;
    font-size: 18px;
    cursor: pointer;
    z-index: 10;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(10px);
}

.sisme-carousel__btn:hover {
    background: rgba(0, 0, 0, 0.9);
    transform: translateY(-50%) scale(1.1);
}

.sisme-carousel__btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
    transform: translateY(-50%) scale(0.9);
}

.sisme-carousel__btn--prev {
    left: 10px;
}

.sisme-carousel__btn--prev::after {
    content: '‹';
    font-size: 24px;
    font-weight: bold;
}

.sisme-carousel__btn--next {
    right: 10px;
}

.sisme-carousel__btn--next::after {
    content: '›';
    font-size: 24px;
    font-weight: bold;
}

/* ========================================
   🔘 PAGINATION (DOTS)
======================================== */

.sisme-carousel__pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-top: var(--sisme-space-lg, 20px);
}

.sisme-carousel__dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
}

.sisme-carousel__dot:hover {
    background: rgba(255, 255, 255, 0.6);
    transform: scale(1.2);
}

.sisme-carousel__dot.active {
    background: var(--sisme-gaming-accent, #64ffda);
    transform: scale(1.3);
}

/* ========================================
   🔄 MODE INFINITE
======================================== */

.sisme-cards-carousel--infinite .sisme-carousel__track {
    transition: transform 0.5s ease;
}

.sisme-cards-carousel--infinite .sisme-carousel__pagination {
    display: none;
}

.sisme-cards-carousel--infinite .sisme-carousel__btn:disabled {
    opacity: 1;
    cursor: pointer;
}

/* Slides clones pour infinite */
.sisme-carousel__slide--clone-start,
.sisme-carousel__slide--clone-end {
    /* Même style que les slides normaux */
}

.sisme-carousel__slide--original {
    /* Slides originaux - pas de style spécifique */
}

/* ========================================
   🚫 ÉTATS SPÉCIAUX
======================================== */

/* Carrousel vide */
.sisme-cards-carousel--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 300px;
    background: var(--sisme-gaming-dark-light, #1a1a1a);
    border: 2px dashed var(--sisme-white-alpha, rgba(255, 255, 255, 0.1));
    border-radius: var(--sisme-radius-lg, 12px);
    color: var(--sisme-gaming-text-muted, #999999);
    font-size: var(--sisme-text-lg, 18px);
}

.sisme-cards-carousel--empty::after {
    content: '🎮 Aucun jeu à afficher';
    text-align: center;
}

/* ========================================
   📱 RESPONSIVE CARROUSEL
======================================== */

/* Tablet */
@media (max-width: 1024px) {
    .sisme-cards-carousel {
        padding: 0 50px;
    }
    
    .sisme-carousel__btn {
        width: 45px;
        height: 45px;
        font-size: 16px;
    }
    
    .sisme-carousel__slide .sisme-card-image {
        height: 180px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .sisme-cards-carousel {
        padding: 0 40px;
    }
    
    /* Force 1 carte TOUJOURS sur mobile */
    .sisme-cards-carousel[data-cards-per-view="2"] .sisme-carousel__slide,
    .sisme-cards-carousel[data-cards-per-view="3"] .sisme-carousel__slide,
    .sisme-cards-carousel[data-cards-per-view="4"] .sisme-carousel__slide,
    .sisme-cards-carousel[data-cards-per-view="5"] .sisme-carousel__slide {
        width: 100%;
    }
    
    .sisme-carousel__btn {
        width: 40px;
        height: 40px;
        font-size: 14px;
    }
    
    .sisme-carousel__btn--prev {
        left: 5px;
    }
    
    .sisme-carousel__btn--next {
        right: 5px;
    }
    
    .sisme-carousel__slide .sisme-card-image {
        height: 180px;
    }
    
    .sisme-carousel__slide .sisme-game-card {
        min-height: 380px;
    }
}

/* Très petit mobile */
@media (max-width: 480px) {
    .sisme-cards-carousel {
        padding: 0 15px;
    }
    
    /* Déjà 1 carte sur mobile, pas besoin de forcer */
    .sisme-carousel__btn {
        width: 36px;
        height: 36px;
        font-size: 12px;
    }
    
    .sisme-carousel__btn--prev {
        left: -5px;
    }
    
    .sisme-carousel__btn--next {
        right: -5px;
    }
    
    .sisme-carousel__slide .sisme-card-image {
        height: 160px;
    }
    
    .sisme-carousel__slide .sisme-game-card {
        min-height: 350px;
    }
}

/* ========================================
   🐛 MODE DEBUG
======================================== */

.sisme-cards-carousel--debug {
    border: 2px solid #17a2b8;
    position: relative;
}

.sisme-cards-carousel--debug::before {
    content: '🔧 CARROUSEL: ' attr(data-cards-per-view) ' cartes par vue';
    position: absolute;
    top: -30px;
    left: 0;
    background: #17a2b8;
    color: white;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: bold;
    z-index: 999;
    white-space: nowrap;
}

.sisme-cards-carousel--debug .sisme-carousel__slide {
    outline: 2px solid #17a2b8;
    outline-offset: 2px;
    position: relative;
}

.sisme-cards-carousel--debug .sisme-carousel__slide::before {
    content: counter(slide-counter);
    counter-increment: slide-counter;
    position: absolute;
    top: 5px;
    left: 5px;
    background: #17a2b8;
    color: white;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 10px;
    z-index: 999;
}

.sisme-cards-carousel--debug {
    counter-reset: slide-counter;
}

.sisme-cards-carousel--debug .sisme-game-card {
    outline: 2px solid #28a745;
    outline-offset: -2px;
}

/* Debug infinite mode */
.sisme-cards-carousel--debug.sisme-cards-carousel--infinite::before {
    content: '🔄 INFINITE: ' attr(data-cards-per-view) ' cartes | ' attr(data-cards-count) ' originales';
    background: #e74c3c;
}

.sisme-cards-carousel--debug .sisme-carousel__slide--clone-start {
    outline: 3px solid orange;
}

.sisme-cards-carousel--debug .sisme-carousel__slide--clone-end {
    outline: 3px solid purple;
}

.sisme-cards-carousel--debug .sisme-carousel__slide--original {
    outline: 2px solid green;
}

/* ========================================
   ♿ ACCESSIBILITÉ
======================================== */

/* Respecter les préférences de mouvement */
@media (prefers-reduced-motion: reduce) {
    .sisme-carousel__track,
    .sisme-carousel__btn,
    .sisme-carousel__dot {
        transition: none !important;
    }
}

/* Focus visible */
.sisme-carousel__btn:focus-visible,
.sisme-carousel__dot:focus-visible {
    outline: 2px solid var(--sisme-gaming-accent, #64ffda);
    outline-offset: 2px;
}

/* Contraste élevé */
@media (prefers-contrast: high) {
    .sisme-carousel__btn {
        background: black;
        border: 2px solid white;
    }
    
    .sisme-carousel__dot {
        border: 2px solid white;
    }
}

/* ========================================
   🎨 VARIANTES DE CARROUSEL
======================================== */

/* Carrousel compact */
.sisme-cards-carousel--compact {
    padding: 0 40px;
    margin-bottom: var(--sisme-space-lg, 24px);
}

.sisme-cards-carousel--compact .sisme-carousel__slide .sisme-card-image {
    height: 140px;
}

.sisme-cards-carousel--compact .sisme-carousel__slide .sisme-game-card {
    min-height: 280px;
}

/* Carrousel large */
.sisme-cards-carousel--large {
    padding: 0 80px;
    margin-bottom: var(--sisme-space-xxl, 48px);
}

.sisme-cards-carousel--large .sisme-carousel__slide .sisme-card-image {
    height: 280px;
}

.sisme-cards-carousel--large .sisme-carousel__slide .sisme-game-card {
    min-height: 520px;
}

/* ========================================
   🔄 ANIMATIONS
======================================== */

@keyframes carouselAppear {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.sisme-cards-carousel {
    animation: carouselAppear 0.6s ease-out;
}

/* Animation des slides */
@keyframes slideAppear {
    0% {
        opacity: 0;
        transform: scale(0.9);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.sisme-carousel__slide .sisme-game-card {
    animation: slideAppear 0.4s ease-out;
}

/* Désactiver animations si reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .sisme-cards-carousel,
    .sisme-carousel__slide .sisme-game-card {
        animation: none !important;
    }
}