/* ============================================================================
    Carousel CPT - Styles de base
    ============================================================================ */

/* Surcharge des styles Elementor par défaut qui interfèrent */
.elementor-element.elementor-arrows-position-outside .swiper,
.elementor-element.elementor-arrows-position-tablet-outside .swiper,
.elementor-element.elementor-arrows-position-mobile-outside .swiper {
    width: 100% !important;
}

.elementor-carousel-cpt-wrapper {
    position: relative;
    width: 100%;
    --swiper-slide-gap: 20px; /* Valeur par défaut */
    --dots-margin-top: 20px; /* Margin-top de la pagination */
    --dots-height: 10px; /* Hauteur par défaut des dots */
}

.elementor-carousel-cpt {
    display: flex;
    align-items: stretch;
}

.elementor-carousel-cpt .swiper-slide {
    /* Largeur calculée en déduisant les gaps : pour n slides, il y a n-1 gaps */
    max-width: calc((100% - (var(--e-carousel-slides-to-show, 3) - 1) * var(--swiper-slide-gap, 20px)) / var(--e-carousel-slides-to-show, 3));
    height: auto;
    display: flex;
}

.elementor-carousel-cpt .swiper-slide > .s4-cpt-card,
.elementor-carousel-cpt .swiper-slide > * > .s4-cpt-card {
    width: 100%;
    height: 100%;
}

.elementor-carousel-cpt-wrapper .s4-cpt-card .s4-cpt-card__terms {
    margin-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: unset;
}

.elementor-carousel-cpt-wrapper .s4-cpt-card .s4-cpt-card__terms .s4-cpt-card__term {
    color: #9B0112;
    padding: 0;
    font-weight: 500;
    font-size: max(1rem, 13px);
    background: transparent;
}

.elementor-carousel-cpt-wrapper .s4-cpt-card .s4-cpt-card__date {
    color: #D6BB81;
    font-size: max(1.1rem, 14px);
    font-family: "melindaevania", sans-serif;
}

.elementor-carousel-cpt-wrapper .s4-cpt-card .s4-cpt-card__title {
    font-size: 1.85rem;
    margin-bottom: 10px;
}

.elementor-carousel-cpt-wrapper .s4-cpt-card .s4-cpt-card__excerpt {
    font-size: max(1.1rem, 14px);
    color: #848890;
}

.elementor-carousel-cpt-wrapper .s4-cpt-card__excerpt {
    display: none;
}

/* ============================================================================
   STYLE: Arrière-plan blanc
   ============================================================================ */

.carousel-cpt-style-white .s4-cpt-card {
    background: #FFFFFF;
    color: #000000;
}

/* ============================================================================
   STYLE: Arrière-plan noir
   ============================================================================ */

.carousel-cpt-style-black .s4-cpt-card {
    background: #000000;
    color: #FFFFFF;
}

/* ============================================================================
   Type de fond des vignettes
   ============================================================================ */

/* Opaque (défaut) - 100% opacité */
.carousel-cpt-bg-opaque.carousel-cpt-style-white .s4-cpt-card {
    background: #FFFFFF;
    opacity: 1;
}

.carousel-cpt-bg-opaque.carousel-cpt-style-black .s4-cpt-card {
    background: #000000;
    opacity: 1;
}

/* Semi-transparent - ~70% opacité */
.carousel-cpt-bg-semi-transparent.carousel-cpt-style-white .s4-cpt-card {
    background: rgba(255, 255, 255, 0.7);
}

.carousel-cpt-bg-semi-transparent.carousel-cpt-style-black .s4-cpt-card {
    background: rgba(0, 0, 0, 0.7);
}

/* Flou (blur + brightness) avec backdrop-filter */
.carousel-cpt-bg-blur.carousel-cpt-style-white .s4-cpt-card {
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(23px) brightness(115%);
    -webkit-backdrop-filter: blur(23px) brightness(115%);
}

.carousel-cpt-bg-blur.carousel-cpt-style-black .s4-cpt-card {
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(23px) brightness(115%);
    -webkit-backdrop-filter: blur(23px) brightness(115%);
}


/* ============================================================================
   Navigation - Flèches
   ============================================================================ */

.elementor-carousel-cpt-wrapper .elementor-swiper-button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 2px solid #FFFFFF;
    transition: all 0.3s ease;
}

/* Pseudo-élément pour le background avec opacité au hover */
.elementor-carousel-cpt-wrapper .elementor-swiper-button::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 50%;
    background-color: var(--arrow-hover-bg, #FFFFFF);
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: -1;
}

.elementor-carousel-cpt-wrapper .elementor-swiper-button:hover::before {
    opacity: 0.5;
}

.elementor-carousel-cpt-wrapper .elementor-swiper-button-prev {
    left: 20px;
}

.elementor-carousel-cpt-wrapper .elementor-swiper-button-next {
    right: 20px;
}

/* ============================================================================
   Position des flèches - Desktop (défaut)
   ============================================================================ */

/* Position "Outside" pour les flèches - Desktop par défaut */
.elementor-arrows-position-outside .elementor-carousel-cpt-wrapper {
    position: static;
}

/* Position "Inside" - Desktop par défaut */
.elementor-arrows-position-inside .elementor-carousel-cpt-wrapper {
    padding-top: 0 !important;
}

.elementor-arrows-position-inside > .elementor-widget-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Position "Above" - Desktop par défaut */
.elementor-arrows-position-above > .elementor-widget-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.elementor-arrows-position-above .elementor-swiper-button {
    top: 0 !important;
    transform: unset !important;
}

/* ============================================================================
   Position des flèches - Responsive
   ============================================================================ */

/* Écran large (à partir de 2000px) */
@media (min-width: 2000px) {
    /* Position Inside */
    .elementor-arrows-position-widescreen-inside .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-widescreen-inside > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-widescreen-inside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Outside */
    .elementor-arrows-position-widescreen-outside .elementor-carousel-cpt-wrapper {
        position: static;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-widescreen-outside > .elementor-widget-container {
        padding-left: calc(max(50px, var(--arrows-size-widescreen, 50px)) + 20px) !important;
        padding-right: calc(max(50px, var(--arrows-size-widescreen, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-widescreen-outside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Above */
    .elementor-arrows-position-widescreen-above > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-widescreen-above .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: calc(max(50px, var(--arrows-size-widescreen, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-widescreen-above .elementor-swiper-button {
        top: 0 !important;
        transform: unset !important;
    }
    
    .elementor-arrows-position-widescreen-above .elementor-swiper-button-prev {
        left: unset !important;
        right: calc(max(50px, var(--arrows-size-widescreen, 50px)) + 10px) !important;
    }
    
    .elementor-arrows-position-widescreen-above .elementor-swiper-button-next {
        left: unset !important;
        right: 0 !important;
    }
    
    /* Ajustement du positionnement des flèches quand dots activés en position outside */
    .elementor-arrows-position-widescreen-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-widescreen-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
    .elementor-arrows-position-widescreen-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-widescreen-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
        top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
    }
}

/* Portable (jusqu'à 1549px) */
@media (max-width: 1549px) {
    /* Position Inside */
    .elementor-arrows-position-laptop-inside .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-laptop-inside > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-laptop-inside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Outside */
    .elementor-arrows-position-laptop-outside .elementor-carousel-cpt-wrapper {
        position: static;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-laptop-outside > .elementor-widget-container {
        padding-left: calc(max(50px, var(--arrows-size-laptop, 50px)) + 20px) !important;
        padding-right: calc(max(50px, var(--arrows-size-laptop, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-laptop-outside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Above */
    .elementor-arrows-position-laptop-above > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-laptop-above .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: calc(max(50px, var(--arrows-size-laptop, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-laptop-above .elementor-swiper-button {
        top: 0 !important;
        transform: unset !important;
    }
    
    .elementor-arrows-position-laptop-above .elementor-swiper-button-prev {
        left: unset !important;
        right: calc(max(50px, var(--arrows-size-laptop, 50px)) + 10px) !important;
    }
    
    .elementor-arrows-position-laptop-above .elementor-swiper-button-next {
        left: unset !important;
        right: 0 !important;
    }
    
    /* Ajustement du positionnement des flèches quand dots activés en position outside */
    .elementor-arrows-position-laptop-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-laptop-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
    .elementor-arrows-position-laptop-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-laptop-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
        top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
    }
}

/* Tablette en mode paysage (jusqu'à 1199px) */
@media (max-width: 1199px) {
    /* Position Inside */
    .elementor-arrows-position-tablet_extra-inside .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-tablet_extra-inside > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-tablet_extra-inside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Outside */
    .elementor-arrows-position-tablet_extra-outside .elementor-carousel-cpt-wrapper {
        position: static;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-tablet_extra-outside > .elementor-widget-container {
        padding-left: calc(max(50px, var(--arrows-size-tablet-extra, 50px)) + 20px) !important;
        padding-right: calc(max(50px, var(--arrows-size-tablet-extra, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-tablet_extra-outside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Above */
    .elementor-arrows-position-tablet_extra-above > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-tablet_extra-above .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: calc(max(50px, var(--arrows-size-tablet-extra, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-tablet_extra-above .elementor-swiper-button {
        top: 0 !important;
        transform: unset !important;
    }
    
    .elementor-arrows-position-tablet_extra-above .elementor-swiper-button-prev {
        left: unset !important;
        right: calc(max(50px, var(--arrows-size-tablet-extra, 50px)) + 10px) !important;
    }
    
    .elementor-arrows-position-tablet_extra-above .elementor-swiper-button-next {
        left: unset !important;
        right: 0 !important;
    }
    
    /* Ajustement du positionnement des flèches quand dots activés en position outside */
    .elementor-arrows-position-tablet_extra-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-tablet_extra-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
    .elementor-arrows-position-tablet_extra-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-tablet_extra-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
        top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
    }
}

/* Tablette en mode portrait (jusqu'à 991px) */
@media (max-width: 991px) {
    /* Position Inside */
    .elementor-arrows-position-tablet-inside .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-tablet-inside > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-tablet-inside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Outside */
    .elementor-arrows-position-tablet-outside .elementor-carousel-cpt-wrapper {
        position: static;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-tablet-outside > .elementor-widget-container {
        padding-left: calc(max(50px, var(--arrows-size-tablet, 50px)) + 20px) !important;
        padding-right: calc(max(50px, var(--arrows-size-tablet, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-tablet-outside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Above */
    .elementor-arrows-position-tablet-above > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-tablet-above .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: calc(max(50px, var(--arrows-size-tablet, 50px)) + 20px) !important;
    }
    
    .elementor-arrows-position-tablet-above .elementor-swiper-button {
        top: 0 !important;
        transform: unset !important;
    }
    
    .elementor-arrows-position-tablet-above .elementor-swiper-button-prev {
        left: unset !important;
        right: calc(max(50px, var(--arrows-size-tablet, 50px)) + 10px) !important;
    }
    
    .elementor-arrows-position-tablet-above .elementor-swiper-button-next {
        left: unset !important;
        right: 0 !important;
    }
    
    /* Ajustement du positionnement des flèches quand dots activés en position outside */
    .elementor-arrows-position-tablet-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-tablet-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
    .elementor-arrows-position-tablet-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-tablet-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
        top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
    }
}

/* Mobile Paysage (jusqu'à 767px) */
@media (max-width: 767px) {
    /* Position Inside */
    .elementor-arrows-position-mobile_extra-inside .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-mobile_extra-inside > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-mobile_extra-inside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Outside */
    .elementor-arrows-position-mobile_extra-outside .elementor-carousel-cpt-wrapper {
        position: static;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-mobile_extra-outside > .elementor-widget-container {
        padding-left: calc(max(50px, var(--arrows-size-mobile-extra, 40px)) + 20px) !important;
        padding-right: calc(max(50px, var(--arrows-size-mobile-extra, 40px)) + 20px) !important;
    }
    
    .elementor-arrows-position-mobile_extra-outside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Above */
    .elementor-arrows-position-mobile_extra-above > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-mobile_extra-above .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: calc(max(40px, var(--arrows-size-mobile-extra, 40px)) + 20px) !important;
    }
    
    .elementor-arrows-position-mobile_extra-above .elementor-swiper-button {
        top: 0 !important;
        transform: unset !important;
    }
    
    .elementor-arrows-position-mobile_extra-above .elementor-swiper-button-prev {
        left: unset !important;
        right: calc(max(50px, var(--arrows-size-mobile-extra, 50px)) + 10px) !important;
    }
    
    .elementor-arrows-position-mobile_extra-above .elementor-swiper-button-next {
        left: unset !important;
        right: 0 !important;
    }
    
    /* Ajustement du positionnement des flèches quand dots activés en position outside */
    .elementor-arrows-position-mobile_extra-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-mobile_extra-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
    .elementor-arrows-position-mobile_extra-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-mobile_extra-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
        top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
    }
}

/* Mobile Portrait (par défaut, jusqu'à 575px) */
@media (max-width: 575px) {
    /* Position Inside */
    .elementor-arrows-position-mobile-inside .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-mobile-inside > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-mobile-inside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Outside */
    .elementor-arrows-position-mobile-outside .elementor-carousel-cpt-wrapper {
        position: static;
        padding-top: 0 !important;
    }
    
    .elementor-arrows-position-mobile-outside > .elementor-widget-container {
        padding-left: calc(max(40px, var(--arrows-size-mobile, 40px)) + 20px) !important;
        padding-right: calc(max(40px, var(--arrows-size-mobile, 40px)) + 20px) !important;
    }
    
    .elementor-arrows-position-mobile-outside .elementor-swiper-button {
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    
    /* Position Above */
    .elementor-arrows-position-mobile-above > .elementor-widget-container {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
    
    .elementor-arrows-position-mobile-above .elementor-carousel-cpt-wrapper {
        position: relative;
        padding-top: calc(max(40px, var(--arrows-size-mobile, 40px)) + 20px) !important;
    }
    
    .elementor-arrows-position-mobile-above .elementor-swiper-button {
        top: 0 !important;
        transform: unset !important;
    }
    
    .elementor-arrows-position-mobile-above .elementor-swiper-button-prev {
        left: unset !important;
        right: calc(max(50px, var(--arrows-size-mobile, 50px)) + 10px) !important;
    }
    
    .elementor-arrows-position-mobile-above .elementor-swiper-button-next {
        left: unset !important;
        right: 0 !important;
    }
    
    /* Ajustement du positionnement des flèches quand dots activés en position outside */
    .elementor-arrows-position-mobile-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-mobile-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
    .elementor-arrows-position-mobile-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-mobile-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
        top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
    }
}

/* ============================================================================
   Pagination (dots)
   ============================================================================ */

.elementor-carousel-cpt-wrapper .swiper-pagination {
    position: relative;
    margin-top: var(--dots-margin-top, 20px);
    text-align: center;
}

/* Ajustement du positionnement des flèches quand dots activés en position outside */
/* Pour les positions Inside et Outside (pas Above), quand pagination est présente et en position outside */
.elementor-arrows-position-inside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-widescreen-above):not(.elementor-arrows-position-laptop-above):not(.elementor-arrows-position-tablet_extra-above):not(.elementor-arrows-position-tablet-above):not(.elementor-arrows-position-mobile_extra-above):not(.elementor-arrows-position-mobile-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button,
.elementor-arrows-position-outside:not(.elementor-pagination-position-inside):not(.elementor-arrows-position-widescreen-above):not(.elementor-arrows-position-laptop-above):not(.elementor-arrows-position-tablet_extra-above):not(.elementor-arrows-position-tablet-above):not(.elementor-arrows-position-mobile_extra-above):not(.elementor-arrows-position-mobile-above) .elementor-carousel-cpt-wrapper:has(.swiper-pagination) .elementor-swiper-button {
    top: calc(50% - (var(--dots-height, 10px) + var(--dots-margin-top, 20px) + 30px) / 2) !important;
}

.elementor-pagination-position-inside .swiper-pagination {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
    margin-top: 0;
}

.elementor-carousel-cpt-wrapper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #CCCCCC;
    opacity: 1;
    transition: all 0.3s ease;
}

.elementor-carousel-cpt-wrapper .swiper-pagination-bullet-active {
    background: #BF930D;
}

/* ============================================================================
   Responsive
   ============================================================================ */

@media (max-width: 768px) {
    .s4-cpt-card {
        padding: 0;
    }
    
    .s4-cpt-card__text {
        font-size: 14px;
        -webkit-line-clamp: 6;
        line-clamp: 6;
    }
    
    .elementor-carousel-cpt-wrapper .elementor-swiper-button {
        width: 50px;
        height: 50px;
        font-size: 14px;
    }
}

/* ============================================================================
   Messages d'erreur
   ============================================================================ */

.carousel-cpt-error {
    padding: 20px;
    background: #FFF3CD;
    border: 1px solid #FFE69C;
    /* border-radius: 5px; */
    color: #856404;
    text-align: center;
}
