/* ═══════════════════════════════════════════════════════
   MapetitePara – Promo Slider v2.1  |  promo-slider.css
   ═══════════════════════════════════════════════════════ */

:root {
    --mpp-green:      #5a9e3a;
    --mpp-green-d:    #4a8a2e;
    --mpp-orange:     #e07a2b;
    --mpp-discount:   #e05a2b;
    --mpp-gap:        18px;
    --mpp-radius:     16px;
    --mpp-arrow-size: 44px;
}

/* ── Wrapper ── */
.mpp-ms-wrapper {
    position: relative;
    padding: 0 54px;
    box-sizing: border-box;
    font-family: 'Nunito', 'Poppins', 'Segoe UI', Arial, sans-serif;
    user-select: none;
    -webkit-user-select: none;
}

/* ── Viewport ── */
.mpp-ms-viewport {
    overflow: hidden;
    width: 100%;
}

/* ── Track ── */
.mpp-ms-track {
    display: flex;
    gap: var(--mpp-gap);
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

/* ══════════════════════════════════════════════════════
   CARTE
══════════════════════════════════════════════════════ */
.mpp-ms-card {
    /* 3 cartes par défaut */
    flex: 0 0 calc( (100% - 2 * var(--mpp-gap)) / 3 );
    min-width: 0;
    height: 360px;
    border-radius: var(--mpp-radius);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #e8c870; /* base dorée – le bokeh flou s'y superpose */
    box-sizing: border-box;
}

/* ── Fond bokeh photographique ──
   Technique : calque de dégradés FLOU (blur) étendu au-delà de la carte
   → l'overflow:hidden de .mpp-ms-card coupe les bords nets du blur.
   On obtient des taches lumineuses douces comme un vrai bokeh photo.
─────────────────────────────────────────────────────────────────────── */

/* Calque 1 : grands orbes flous (le bokeh principal) */
.mpp-ms-bokeh {
    position: absolute;
    inset: -40px;           /* déborde pour éviter les bords nets du blur */
    z-index: 0;
    pointer-events: none;
    filter: blur(28px);     /* ← c'est ça qui crée le vrai flou bokeh */
    background-color: #d4a94a; /* base dorée chaude */
    background-image:
        /* Taches blanches lumineuses (hauts-fonds) */
        radial-gradient(circle at 28% 22%, rgba(255,255,255,.98) 0%, rgba(255,255,230,.20) 22%, transparent 35%),
        radial-gradient(circle at 72% 18%, rgba(255,255,255,.90) 0%, rgba(255,255,220,.15) 18%, transparent 30%),
        radial-gradient(circle at 50% 52%, rgba(255,255,255,.80) 0%, rgba(255,245,200,.10) 20%, transparent 34%),
        radial-gradient(circle at 15% 78%, rgba(255,255,255,.75) 0%, transparent 26%),
        radial-gradient(circle at 85% 75%, rgba(255,255,255,.82) 0%, transparent 22%),
        radial-gradient(circle at 62% 85%, rgba(255,255,240,.70) 0%, transparent 20%),
        /* Orbes dorés-orangés (milieu de ton) */
        radial-gradient(circle at 10% 30%, rgba(255,210,80,.85)  0%, transparent 28%),
        radial-gradient(circle at 90% 40%, rgba(255,200,70,.80)  0%, transparent 25%),
        radial-gradient(circle at 40% 70%, rgba(255,185,60,.75)  0%, transparent 30%),
        radial-gradient(circle at 78% 58%, rgba(255,215,90,.70)  0%, transparent 22%),
        /* Petits accents lumineux */
        radial-gradient(circle at 55% 12%, rgba(255,240,160,.90) 0%, transparent 16%),
        radial-gradient(circle at 22% 55%, rgba(255,230,140,.80) 0%, transparent 18%),
        radial-gradient(circle at 68% 32%, rgba(255,245,180,.85) 0%, transparent 14%);
}

/* Calque 2 : petits orbes plus nets par-dessus (profondeur) */
.mpp-ms-bokeh::before {
    content: '';
    position: absolute;
    inset: 0;
    filter: blur(10px);
    background-image:
        radial-gradient(circle at 32% 28%, rgba(255,255,255,.70) 0%, transparent 10%),
        radial-gradient(circle at 68% 22%, rgba(255,255,255,.65) 0%, transparent  9%),
        radial-gradient(circle at 20% 65%, rgba(255,255,255,.60) 0%, transparent  8%),
        radial-gradient(circle at 80% 68%, rgba(255,255,255,.65) 0%, transparent  9%),
        radial-gradient(circle at 48% 48%, rgba(255,255,255,.55) 0%, transparent  7%),
        radial-gradient(circle at 58% 78%, rgba(255,240,180,.75) 0%, transparent 10%),
        radial-gradient(circle at 12% 42%, rgba(255,230,150,.70) 0%, transparent  9%);
}

/* Calque 3 : teinte globale chaude pour unifier */
.mpp-ms-bokeh::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        145deg,
        rgba(255,220,100,.15) 0%,
        rgba(255,180,50,.08)  50%,
        rgba(255,210,90,.12)  100%
    );
}

/* ── Corps de la carte ── */
.mpp-ms-card__body {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 28px 18px 14px;
    width: 100%;
    flex-shrink: 0;
}

/* ── Texte remise ── */
.mpp-ms-discount {
    font-size: 58px; /* overridé par Elementor si taille définie */
    font-weight: 900;
    line-height: 1;
    color: var(--mpp-discount);
    letter-spacing: -0.02em;
    margin-bottom: 10px;
    text-shadow: 0 2px 8px rgba(0,0,0,.08);
}

/* ── Label ── */
.mpp-ms-label {
    font-size: 12px; /* overridé par Elementor si taille définie */
    font-weight: 700;
    letter-spacing: .10em;
    text-transform: uppercase;
    color: #555;
    margin: 0 0 16px;
    line-height: 1.4;
}

/* ── Bouton ── */
.mpp-ms-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 28px;
    border-radius: 50px;                   /* border-radius 50 */
    background-color: var(--mpp-green);
    border: 2.5px solid var(--mpp-orange); /* bordure orange */
    color: #fff;
    font-size: 13px; /* overridé par Elementor si taille définie */
    font-weight: 800;
    letter-spacing: .07em;
    text-transform: uppercase;
    text-decoration: none;
    cursor: pointer;
    font-family: inherit;
    box-shadow: 0 4px 14px rgba(90,158,58,.28);
    transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease;
    white-space: nowrap;
}
.mpp-ms-btn:hover {
    background-color: var(--mpp-green-d);
    transform: translateY(-2px);
    box-shadow: 0 7px 20px rgba(90,158,58,.40);
    color: #fff;
    text-decoration: none;
}

/* ── Image produit ── */
.mpp-ms-img-wrap {
    position: relative;
    z-index: 1;
    flex: 1 1 auto;
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 0 14px 18px;
    overflow: hidden;
    min-height: 0;
}
.mpp-ms-img {
    max-height: 150px; /* overridé par Elementor si taille définie */
    max-width: 88%;    /* overridé par Elementor si taille définie */
    object-fit: contain;
    filter: drop-shadow(0 6px 16px rgba(0,0,0,.13));
    transition: transform .4s ease;
    display: block;
}
.mpp-ms-card:hover .mpp-ms-img {
    transform: translateY(-6px) scale(1.04);
}

/* ══════════════════════════════════════════════════════
   FLÈCHES
══════════════════════════════════════════════════════ */
.mpp-ms-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-60%);
    width: var(--mpp-arrow-size);
    height: var(--mpp-arrow-size);
    border-radius: 50%;
    background-color: var(--mpp-green);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 20;
    padding: 0;
    box-shadow: 0 4px 14px rgba(90,158,58,.38);
    transition: background-color .2s ease, transform .2s ease;
    line-height: 1;
}
.mpp-ms-arrow--prev { left: 0; }
.mpp-ms-arrow--next { right: 0; }
.mpp-ms-arrow:hover { background-color: var(--mpp-green-d); }
.mpp-ms-arrow--prev:hover { transform: translateY(-60%) scale(1.08); }
.mpp-ms-arrow--next:hover { transform: translateY(-60%) scale(1.08); }
.mpp-ms-arrow:disabled {
    opacity: .35;
    cursor: default;
    pointer-events: none;
}

/* ══════════════════════════════════════════════════════
   DOTS
══════════════════════════════════════════════════════ */
.mpp-ms-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 18px;
}
.mpp-ms-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: transparent;
    border: 2px solid var(--mpp-green);
    cursor: pointer;
    padding: 0;
    transition: background-color .3s ease, transform .2s ease;
}
.mpp-ms-dot.active {
    background-color: var(--mpp-green);
    transform: scale(1.25);
}
.mpp-ms-dot:hover:not(.active) {
    background-color: rgba(90,158,58,.25);
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */

/* Desktop + tablette paysage : 3 cartes (déjà par défaut) */

/* Tablette portrait + mobile : 2 cartes */
@media (max-width: 1023px) {
    .mpp-ms-card {
        flex-basis: calc( (100% - var(--mpp-gap)) / 2 );
    }
    .mpp-ms-wrapper { padding: 0 48px; }
}

/* Tablette paysage (override → revient à 3 cartes) */
@media (min-width: 768px) and (max-width: 1023px) and (orientation: landscape) {
    .mpp-ms-card {
        flex-basis: calc( (100% - 2 * var(--mpp-gap)) / 3 );
    }
}

/* Petit mobile */
@media (max-width: 479px) {
    .mpp-ms-wrapper { padding: 0 42px; }
    .mpp-ms-arrow { width: 36px; height: 36px; }
}

/* Accessibilité */
@media (prefers-reduced-motion: reduce) {
    .mpp-ms-track,
    .mpp-ms-btn,
    .mpp-ms-img {
        transition: none;
    }
}
