/**
 * Pricing Cards — eltdf_pricing_table avec design Pranazen unifié
 *
 * Scope : .prz-pricing-eltdf  (classe à ajouter sur le [vc_row] ou [vc_section])
 *
 * Desktop  (≥768px) : flex-row 3 colonnes, même design que prz-pricing-slide
 * Mobile   (<768px) : scroll-snap carousel swipeable + dots + hint
 *
 * Classes HTML produites par eltdf_pricing_table :
 *   .eltdf-pricing-tables  → conteneur outer
 *   .eltdf-pt-wrapper      → track (scroll container mobile)
 *   .eltdf-price-table     → carte individuelle
 *   .eltdf-pt-inner        → inner flex
 *   .eltdf-pt-title-holder → li titre + sous-titre
 *   .eltdf-pt-badge        → badge Populaire (injecté par le template override)
 *   .eltdf-pt-title        → titre
 *   .eltdf-pt-subtitle     → sous-titre (injecté par le template override)
 *   .eltdf-pt-prices       → li prix
 *   .eltdf-pt-value        → devise (€)
 *   .eltdf-pt-price        → montant
 *   .eltdf-pt-mark         → période (/ 1 an)
 *   .eltdf-pt-content      → li features
 *   .eltdf-pt-button       → li bouton
 *   .eltdf-btn-solid       → bouton plein
 *   .eltdf-btn-outline     → bouton contour
 */

/* ============================================================
   RESET — annuler les styles eltdf par défaut dans ce contexte
   ============================================================ */

.prz-pricing-eltdf .eltdf-pricing-tables {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ============================================================
   TRACK — Desktop : flex-row | Mobile : scroll-snap
   ============================================================ */

.prz-pricing-eltdf .eltdf-pt-wrapper {
    display: flex !important;
    gap: 24px;
    padding: 8px 20px 12px;
    box-sizing: border-box;
    align-items: stretch;
    width: 100%;
}

/* ============================================================
   CARTE INDIVIDUELLE
   ============================================================ */

.prz-pricing-eltdf .eltdf-price-table {
    flex: 1 1 0 !important;
    min-width: 0;
    box-sizing: border-box;
    background: #ffffff !important;
    border: 1px solid #e8e8e0 !important;
    border-radius: 12px !important;
    padding: 0 !important;
    max-width: none !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06) !important;
    display: flex !important;
    flex-direction: column;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
    position: relative;
    margin: 0 !important;
    overflow: visible !important;
}

.prz-pricing-eltdf .eltdf-price-table:hover {
    box-shadow: 0 6px 24px rgba(62, 119, 126, 0.14) !important;
    transform: translateY(-2px);
}

/* Carte mise en avant */
.prz-pricing-eltdf .eltdf-price-table--featured {
    border-color: var(--pranazen-primary, #3e777e) !important;
    box-shadow: 0 4px 20px rgba(62, 119, 126, 0.18) !important;
}
.prz-pricing-eltdf .eltdf-price-table--featured:hover {
    box-shadow: 0 8px 32px rgba(62, 119, 126, 0.28) !important;
}

/* Layout intérieur — Grid sur ul pour éviter tout conflit flex sur les listes imbriquées */
.prz-pricing-eltdf .eltdf-pt-inner {
    display: flex !important;
    flex-direction: column;
    flex: 1;
    background: transparent !important;
}

/*
 * Spécificité renforcée pour battre
 * .pranazen-section .eltdf-price-table .eltdf-pt-inner > ul { display: flex !important }
 * défini dans pranazen-formation-style.css (spécificité 0,3,1).
 * Sans ce préfixe, le UL reste en flex-column, ce qui fait que
 * `align-self: end` sur .eltdf-pt-button décale le bouton à droite.
 */
.prz-pricing-eltdf .eltdf-pt-inner > ul,
.pranazen-section .prz-pricing-eltdf .eltdf-pt-inner > ul,
.vc_section.pranazen-section .prz-pricing-eltdf .eltdf-pt-inner > ul {
    /*
     * CSS Grid : 4 lignes explicites.
     * La 3e ligne (eltdf-pt-content) prend tout l'espace restant (1fr).
     * Chaque cellule est un contexte de bloc indépendant — aucune
     * interférence avec les <ul>/<li> imbriqués dans les features.
     */
    display: grid !important;
    grid-template-rows: auto auto 1fr auto;
    flex: 1;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ============================================================
   BADGE "POPULAIRE"
   ============================================================ */

.prz-pricing-eltdf .eltdf-pt-badge {
    position: absolute;
    top: -13px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--pranazen-primary, #3e777e);
    color: #ffffff;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    padding: 4px 16px;
    border-radius: 20px;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(62, 119, 126, 0.35);
    z-index: 1;
}

/* ============================================================
   EN-TÊTE — titre + sous-titre
   ============================================================ */

.prz-pricing-eltdf .eltdf-pt-title-holder {
    background: transparent !important;
    padding: 28px 24px 8px !important;
    border-bottom: none !important;
    margin: 0 !important;
    text-align: center;
}

/* Annuler le trait décoratif du thème enfant (pranazen-formation-style) */
.prz-pricing-eltdf .eltdf-price-table .eltdf-pt-title-holder::after {
    display: none !important;
}

/* Titre */
.prz-pricing-eltdf .eltdf-pt-title {
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    color: var(--pranazen-primary, #3e777e) !important;
    line-height: 1.25 !important;
    display: block !important;
    margin: 4px 0 8px !important;
    text-align: center !important;
    font-family: inherit !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    border-bottom: none !important;
}

/* Sous-titre */
.prz-pricing-eltdf .eltdf-pt-subtitle {
    font-size: 0.85rem;
    color: var(--pranazen-secondary, #626365);
    margin: 0 0 18px;
    font-style: italic;
    line-height: 1.4;
    text-align: center;
    padding: 0;
}

/* ============================================================
   BLOC PRIX
   ============================================================ */

.prz-pricing-eltdf .eltdf-pt-prices {
    display: flex !important;
    align-items: baseline !important;
    justify-content: center !important;
    padding: 0 24px 20px !important;
    margin: 0 !important;
    background: transparent !important;
    border-bottom: none !important;
    gap: 2px;
    line-height: 1 !important;
}

/* Devise */
.prz-pricing-eltdf .eltdf-pt-value {
    font-size: 1.3rem !important;
    font-weight: 700 !important;
    color: var(--pranazen-primary, #3e777e) !important;
    line-height: 1 !important;
    vertical-align: baseline !important;
    font-family: inherit !important;
    position: static !important;
    top: auto !important;
}

/* Montant */
.prz-pricing-eltdf .eltdf-pt-price {
    font-size: 2.4rem !important;
    font-weight: 800 !important;
    color: var(--pranazen-primary, #3e777e) !important;
    line-height: 1 !important;
    font-family: inherit !important;
    display: inline !important;
    margin: 0 !important;
}

/* Période — annule le display:none global */
.prz-pricing-eltdf .eltdf-price-table .eltdf-pt-inner ul li.eltdf-pt-prices .eltdf-pt-mark {
    display: inline !important;
    font-size: 0.75rem !important;
    font-weight: 400 !important;
    color: #aaa !important;
    margin-left: 5px !important;
    align-self: flex-end;
    padding-bottom: 5px;
    font-family: inherit !important;
    line-height: 1 !important;
}

/* ============================================================
   FEATURES (contenu)
   ============================================================ */

.prz-pricing-eltdf .eltdf-pt-content {
    padding: 0 24px 20px !important;
    margin: 0 !important;
    border-top: 1px solid #f0f0ea !important;
    border-bottom: none !important;
    /* flex: 1 remplacé par grid-template-rows: 1fr sur le parent */
}

.prz-pricing-eltdf .eltdf-pt-content ul {
    /* Force bloc strict — neutralise column-count/float hérités */
    display: block !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
    width: 100%;
    column-count: 1 !important;
    column-width: auto !important;
    column-fill: auto !important;
}

.prz-pricing-eltdf .eltdf-pt-content ul li {
    display: block !important;
    float: none !important;
    clear: none !important;
    position: relative !important;
    /* Reset legacy WPBakery custom CSS: bottom:55px on last-child causes top:-55px
       when position switches from absolute/static to relative */
    top: auto !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    font-size: 0.82rem !important;
    color: var(--pranazen-secondary, #626365) !important;
    padding: 5px 0 5px 20px !important;
    line-height: 1.4 !important;
    border-bottom: 1px solid #f5f5f0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    /* Evite toute contrainte de hauteur héritée */
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

.prz-pricing-eltdf .eltdf-pt-content ul li:last-child {
    border-bottom: none !important;
}

.prz-pricing-eltdf .eltdf-pt-content ul li::before {
    content: '✓' !important;
    position: absolute !important;
    left: 0 !important;
    top: 5px !important;
    color: var(--pranazen-primary, #3e777e) !important;
    font-weight: 700 !important;
    font-size: 0.78rem !important;
    line-height: 1.4 !important;
}

/* ============================================================
   BOUTON CTA
   ============================================================ */

.prz-pricing-eltdf .eltdf-pt-button {
    padding: 0 24px 24px !important;
    margin: 0 !important;
    border-bottom: none !important;
    text-align: center !important;
    /* margin-top: auto non nécessaire — grid-row positionne le bouton en bas */
    align-self: end;
}

.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    text-align: center !important;
    padding: 11px 20px !important;
    border-radius: 6px !important;
    font-size: 0.88rem !important;
    font-weight: 600 !important;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease !important;
    box-sizing: border-box !important;
}

/* Bouton outline */
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn.eltdf-btn-outline {
    border: 2px solid var(--pranazen-primary, #3e777e) !important;
    color: var(--pranazen-primary, #3e777e) !important;
    background: transparent !important;
    box-shadow: none !important;
}
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn.eltdf-btn-outline:hover,
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn.eltdf-btn-outline:focus {
    background: var(--pranazen-primary, #3e777e) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(62, 119, 126, 0.3) !important;
}

/* Bouton solid */
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn.eltdf-btn-solid {
    background: var(--pranazen-primary, #3e777e) !important;
    color: #ffffff !important;
    border: 2px solid var(--pranazen-primary, #3e777e) !important;
    box-shadow: none !important;
}
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn.eltdf-btn-solid:hover,
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn.eltdf-btn-solid:focus {
    background: #2f5f65 !important;
    border-color: #2f5f65 !important;
    box-shadow: 0 4px 12px rgba(62, 119, 126, 0.4) !important;
    color: #ffffff !important;
}

/* Texte dans le bouton */
.prz-pricing-eltdf .eltdf-pt-button .eltdf-btn .eltdf-btn-text {
    color: inherit !important;
}

/* ============================================================
   DOTS + HINT — masqués sur desktop (≥1025px)
   ============================================================ */

.prz-pricing-eltdf .prz-pricing-slider__dots {
    display: none;
}

.prz-pricing-eltdf .prz-pricing-slider__hint {
    display: none;
}

/* ============================================================
   CAROUSEL ≤1024px (tablette + mobile)

   On active le carousel dès que les cartes ne peuvent plus tenir
   confortablement côte à côte.

   Problème de spécificité : .pranazen-section (présent sur les sections
   "tarifs" des pages formation) impose via son CSS :
     .vc_section.pranazen-section .eltdf-pricing-tables .eltdf-pt-wrapper
       { flex-direction: column !important }   → spécificité (0,4,0)

   On le contrecarre avec (0,5,0) :
     .vc_section.pranazen-section .prz-pricing-eltdf .eltdf-pricing-tables .eltdf-pt-wrapper

   et (0,4,0) pour les sections sans .vc_section :
     .pranazen-section .prz-pricing-eltdf .eltdf-pricing-tables .eltdf-pt-wrapper
   ============================================================ */

@media (max-width: 1024px) {

    /* ── Conteneur outer : column pour que dots/hint passent en dessous ── */
    .prz-pricing-eltdf .eltdf-pricing-tables {
        flex-direction: column !important;
    }

    /* ── Wrapper : forcer flex-row horizontal + scroll-snap ── */
    .vc_section.pranazen-section .prz-pricing-eltdf .eltdf-pricing-tables .eltdf-pt-wrapper,
    .pranazen-section .prz-pricing-eltdf .eltdf-pricing-tables .eltdf-pt-wrapper,
    .prz-pricing-eltdf .eltdf-pt-wrapper {
        flex-direction: row !important;
        justify-content: flex-start !important;
        overflow-x: auto !important;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scroll-behavior: smooth;
        gap: 14px;
        padding: 4px 20px 16px;
        scrollbar-width: none;
        -ms-overflow-style: none;
        align-items: stretch;
    }

    .prz-pricing-eltdf .eltdf-pt-wrapper::-webkit-scrollbar {
        display: none;
    }

    /* ── Cartes : taille fixe, scroll-snap, annule width:100% du pranazen-section ── */
    .vc_section.pranazen-section .prz-pricing-eltdf .eltdf-price-table,
    .pranazen-section .prz-pricing-eltdf .eltdf-price-table,
    .prz-pricing-eltdf .eltdf-price-table {
        flex: 0 0 42vw !important;   /* ~2 cartes + peek de la 3ème */
        max-width: 380px !important;
        min-width: 240px;
        width: auto !important;      /* annule width:100% du pranazen-section */
        scroll-snap-align: center;
    }

    .prz-pricing-eltdf .eltdf-pt-price {
        font-size: 2rem !important;
    }

    /* ── Dots ── */
    .prz-pricing-eltdf .prz-pricing-slider__dots {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 8px;
        margin: 4px 0 0;
        padding: 0;
        list-style: none;
    }

    .prz-pricing-eltdf .prz-pricing-slider__dot {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #d0d0c8;
        cursor: pointer;
        transition: background 0.25s ease, transform 0.25s ease;
        padding: 0;
        border: none;
        display: inline-block;
        flex-shrink: 0;
    }

    .prz-pricing-eltdf .prz-pricing-slider__dot--active {
        background: var(--pranazen-primary, #3e777e);
        transform: scale(1.35);
    }

    /* ── Hint swipe ── */
    .prz-pricing-eltdf .prz-pricing-slider__hint {
        display: flex;
        text-align: center;
        font-size: 0.7rem;
        color: #bbb;
        margin: 6px 0 0;
        align-items: center;
        justify-content: center;
        gap: 4px;
    }

    .prz-pricing-eltdf .prz-pricing-slider__hint svg {
        width: 14px;
        height: 14px;
        fill: none;
        stroke: #bbb;
        stroke-width: 2;
        stroke-linecap: round;
        stroke-linejoin: round;
    }
}

/* ============================================================
   MOBILE (<600px) — 1 carte dominante par écran
   ============================================================ */

@media (max-width: 599px) {

    .vc_section.pranazen-section .prz-pricing-eltdf .eltdf-price-table,
    .pranazen-section .prz-pricing-eltdf .eltdf-price-table,
    .prz-pricing-eltdf .eltdf-price-table {
        flex: 0 0 82vw !important;
        max-width: 300px !important;
    }
}
