/* --- Variables de taille (en dur) --- */
.lerno-hero-carousel-widget {
    --card-width: 240px;
    --card-height: 340px;
    --card-gap-fixed: 15px; 
    position: relative;
    width: 100%;
}
@media (max-width: 1024px) {
    .lerno-hero-carousel-widget {
        --card-width: 220px;
        --card-height: 320px;
    }
}
@media (max-width: 768px) {
    .lerno-hero-carousel-widget {
        --card-width: 240px;
        --card-height: 340px;
    }
}


/* --- Header (Logo + Texte) --- */
.lerno-carousel-header {
    text-align: center;
    margin-bottom: 16px; /* Contrôlé par Elementor */
}
.lerno-carousel-logo {
    height: 32px; /* Contrôlé par Elementor */
    margin-left: auto;
    margin-right: auto;
}
.lerno-carousel-subtext {
    font-size: 0.875rem; /* 14px */
    color: #64748b; /* Contrôlé par Elementor */
    margin-top: 0.5rem; /* 8px */
}


/* --- Styles du Carrousel --- */
.lerno-hero-carousel-widget .slider-wrapper {
    width: 100%;
    max-width: 1200px;
    position: relative;
    margin: auto;
}

/* --- NOUVELLE MÉTHODE POUR LE FONDU (PLUS FIABLE) --- */
.lerno-hero-carousel-widget .slider-wrapper::before,
.lerno-hero-carousel-widget .slider-wrapper::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 15%; /* Largeur du fondu */
    z-index: 9; /* CORRIGÉ: Au-dessus des cartes */
    pointer-events: none; /* N'intercepte pas la souris */
}
/* NOTE: Changez #F8FAFC pour la couleur de fond de votre page si elle est différente */
.lerno-hero-carousel-widget .slider-wrapper::before {
    left: 0;
    background: linear-gradient(to right, #F8FAFC 0%, transparent 100%); 
}
.lerno-hero-carousel-widget .slider-wrapper::after {
    right: 0;
    background: linear-gradient(to left, #F8FAFC 0%, transparent 100%);
}
/* --- FIN DE LA NOUVELLE MÉTHODE --- */


.lerno-hero-carousel-widget .slider-container {
    overflow: hidden; /* --- CORRIGÉ: Remis pour "couper" les cartes --- */
    padding: 40px 0;
    position: relative;
}

.lerno-hero-carousel-widget .slider-track {
    display: flex;
    align-items: center;
    position: relative;
}
.lerno-hero-carousel-widget .slide {
    flex-shrink: 0;
    width: var(--card-width);
    height: var(--card-height);
    margin: 0 var(--card-gap-fixed);
    position: relative;
    overflow: hidden; /* Garder overflow:hidden sur la slide elle-même pour les bordures */
    background-size: cover;
    background-position: center;
    border-radius: 24px;
    border: 7px solid white;
    color: white;
    display: flex;
    align-items: flex-end;
    text-decoration: none;
    transform: scale(0.65);
    box-shadow: 0 10px 30px -5px rgba(189, 197, 210, 0);
    transition: transform 0.6s cubic-bezier(0.25, 0.8, 0.25, 1),
                box-shadow 0.6s cubic-bezier(0.25, 0.8, 0.25, 1);
}
.lerno-hero-carousel-widget .slide.active { transform: scale(1); box-shadow: 0 25px 50px -12px rgba(189, 197, 210, 0.67); }
.lerno-hero-carousel-widget .slide.neighbor { transform: scale(0.85); box-shadow: 0 20px 40px -12px rgba(189, 197, 210, 0.67); }
.lerno-hero-carousel-widget .slide.outer { transform: scale(0.7); box-shadow: 0 15px 30px -12px rgba(189, 197, 210, 0.67); }

/* Overlay */
.lerno-hero-carousel-widget .slide::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 75%;
    z-index: 1;
    -webkit-mask-image: linear-gradient(to top, black 40%, transparent 100%);
    mask-image: linear-gradient(to top, black 40%, transparent 100%);
}
.lerno-hero-carousel-widget .slide-content {
    position: relative;
    z-index: 2;
    padding: 24px;
    width: 100%;
    box-sizing: border-box;
}
.lerno-hero-carousel-widget .slide-content h3 { 
    margin: 0 0 8px 0; 
    font-size: 1.5rem; 
    line-height: 1.2; 
    font-weight: 700; 
    color: #fff;
}
.lerno-hero-carousel-widget .slide-content p { 
    margin: 0; 
    font-size: 0.9rem; 
    font-weight: 600; 
    color: #fff;
}

/* --- Flèches de Navigation --- */
.lerno-hero-carousel-widget .arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10; /* Au-dessus du fondu (z-index: 9) */
    width: 40px;
    height: 40px;
    background-color: white;
    border: none;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    color: #333;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease, box-shadow 0.2s ease,
                left 0.3s ease, right 0.3s ease, bottom 0.3s ease;
}
.lerno-hero-carousel-widget .arrow:hover { 
    transform: translateY(-50%) scale(1.1); 
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15); 
}
/* Réinitialisation pour le hover quand "below" */
.pagination-desktop-below .arrow:hover,
.pagination-tablet-below .arrow:hover,
.pagination-mobile-below .arrow:hover {
    transform: scale(1.1); 
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15); 
}

/* --- Positionnement de la pagination --- */

/* --- CORRIGÉ : Position de base pour les flèches (mode "côtés") --- */
.lerno-hero-carousel-widget .arrow.prev { left: 20px; }
.lerno-hero-carousel-widget .arrow.next { right: 20px; }
/* --- FIN CORRECTION --- */


/* --- Règles pour "Dessous" (écrasent la position de base) --- */
/* Dessous (Desktop) */
.pagination-desktop-below .slider-wrapper { padding-bottom: 60px; }
.pagination-desktop-below .arrow { top: auto; bottom: 0; transform: none; }
.pagination-desktop-below .arrow.prev { left: 50%; margin-left: -50px; }
.pagination-desktop-below .arrow.next { right: 50%; margin-right: -50px; }

/* Dessous (Tablet) */
.pagination-tablet-below .slider-wrapper { padding-bottom: 60px; }
.pagination-tablet-below .arrow { top: auto; bottom: 0; transform: none; }
.pagination-tablet-below .arrow.prev { left: 50%; margin-left: -50px; }
.pagination-tablet-below .arrow.next { right: 50%; margin-right: -50px; }

/* Dessous (Mobile) */
.pagination-mobile-below .slider-wrapper { padding-bottom: 60px; }
.pagination-mobile-below .arrow { top: auto; bottom: 0; transform: none; }
.pagination-mobile-below .arrow.prev { left: 50%; margin-left: -50px; }
.pagination-mobile-below .arrow.next { right: 50%; margin-right: -50px; }
