/* ─────────────────────────────────────────────────────────
   CEPSO Formations Display — Styles front-end
   ───────────────────────────────────────────────────────── */

/* ══════════════════════════════════════════════════════════
   [cepso_formation_details] — Tableau des attributs
   ══════════════════════════════════════════════════════════ */

.cepso-formation-details {
    margin: 0;
    margin-top: 1.5rem;
    overflow-x: auto;
}

.cepso-details-table {
    margin: 0;
    padding: 0;    
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95em;
    border: 1px solid var(--e-global-color-secondary);
    border-radius: 6px;
    background-color: rgb(46 49 136 / 10%);
    overflow: hidden;
}

.cepso-details-table th,
.cepso-details-table td {
    padding: 11px 16px;
    text-align: left;
    vertical-align: top;
    border-bottom: 1px solid var(--e-global-color-eedc059);
    line-height: 1.5;
    transition: .15s ease;
}

.cepso-details-table tbody tr:last-child th,
.cepso-details-table tbody tr:last-child td {
    border-bottom: none;
}

.cepso-details-table th {
    font-weight: 600;
    width: 170px;
    min-width: 140px;
    color: var(--e-global-color-primary);
    white-space: nowrap;
}

.cepso-attr-icon {
    display: inline-block;
    width: 1em;
    height: 1em;
    vertical-align: -0.1em;
    margin-right: 5px;
    fill: var(--e-global-color-accent, #2e3188);
    flex-shrink: 0;
}

.cepso-details-table td {
    color: var(--e-global-color-primary);
}

.cepso-details-table tbody tr:hover td, .cepso-details-table tbody tr:hover th {
    background-color: rgb(46 49 136 / 10%);
}

/* ══════════════════════════════════════════════════════════
   [cepso_formation_prix] — Tableau des tarifs (portrait)
   ══════════════════════════════════════════════════════════ */

.cepso-prix-wrap {
    margin: 0;
    margin-top: 1.5rem;
}

.cepso-prix-heading {
    font-size: 1.1em;
    font-weight: 700;
    margin: 0 0 12px;
    color: var(--e-global-color-primary);
}

.cepso-prix-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95em;
    border: 1px solid var(--e-global-color-secondary);
    border-radius: 6px;
    overflow: hidden;
}

.cepso-prix-table th,
.cepso-prix-table td {
    padding: 11px 16px;
    border-bottom: 1px solid var(--e-global-color-eedc059);
    line-height: 1.5;
    background-color: rgb(46 49 136 / 10%)!important;
    transition: .15s ease;
}

/* En-têtes de colonnes */
.cepso-prix-table thead th {
    background-color: rgb(46 49 136 / 10%);
    font-weight: 700;
    color: var(--e-global-color-primary);
    text-align: center;
    vertical-align: middle;
}

/* Colonne de gauche (libellé de ligne) */
.cepso-col-label {
    text-align: left !important;
    font-weight: 600;
    min-width: 110px;
    color: var(--e-global-color-primary);
    background-color: rgb(46 49 136 / 5%);
}

/* Colonnes de données : centrage */
.cepso-prix-table td:not(.cepso-col-label),
.cepso-prix-table th:not(.cepso-col-label) {
    text-align: center;
}

/* Colonnes montants */
.cepso-prix-table tbody td:not(.cepso-col-label) {
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    color: var(--e-global-color-primary);
}

/* Colonne Tarif standard — en-tête */
.cepso-col-std {
    background-color: rgb(46 49 136 / 10%);
}

/* Colonne Sociétaire SOCAF — en-tête */
.cepso-prix-table thead .cepso-col-socaf {
    background-color: #e8f5ec!important;
    color: #1a5c2a!important;
}

/* Colonne Sociétaire SOCAF — cellules de données */
.cepso-prix-table tbody td:nth-child(2) {
    background-color: #f0f7f2!important;
    color: #1a5c2a!important;
    font-weight: 600;
}

/* Ligne Commander */
.cepso-row-commander td,
.cepso-row-commander th {
    border-bottom: none;
}

/* Badge Sociétaire SOCAF */
.cepso-socaf-badge {
    display: inline-block;
    margin-top: 5px;
    padding: 2px 9px;
    background-color: #d1f0da;
    color: #155724;
    font-size: 10.5px;
    font-weight: 700;
    border-radius: 20px;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    white-space: nowrap;
}

/* Note de bas de tableau */
.cepso-prix-note {
    margin-top: 10px;
    font-size: 0.83em;
    color: #888;
    font-style: italic;
}

/* ── Formation complète (stock à 0) ────────────────────── */

.cepso-col-complet {
    text-align: center !important;
    padding: 10px 16px !important;
}

.cepso-badge-complet {
    display: inline-block;
    padding: 5px 14px;
    background-color: #fde8e8;
    color: #9b1c1c;
    font-size: 0.9em;
    font-weight: 700;
    border-radius: 20px;
    letter-spacing: 0.3px;
    border: 1px solid #f5c2c2;
    white-space: nowrap;
}

/* ── Responsive ─────────────────────────────────────────── */
@media ( max-width: 600px ) {

    .cepso-details-table th {
        width: 120px;
        min-width: 100px;
        font-size: 0.88em;
    }

    .cepso-prix-table th,
    .cepso-prix-table td {
        padding: 9px 10px;
        font-size: 0.88em;
    }

    .cepso-col-label {
        min-width: 80px;
    }

    .cepso-cart-row {
        flex-direction: column;
        gap: 4px;
    }

    .cepso-btn-cart {
        width: 100%;
    }
}

/* ══════════════════════════════════════════════════════════
   [version_imprimable] — Lien de téléchargement PDF
   ══════════════════════════════════════════════════════════ */

.cepso-version-imprimable {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin: 0;
    margin-top: 1rem;    
    padding: 8px 14px;
    background-color: var(--e-global-color-eedc059)!important;
    border: 1px solid var(--e-global-color-16494fa);
    border-radius: 5px;
    color: var(--e-global-color-16494fa)!important;
    font-size: 0.9em;
    font-weight: 600;
    text-decoration: none!important;
    transition: background-color .15s ease, color .15s ease;
}

.cepso-version-imprimable:hover {
    background-color: var(--e-global-color-16494fa)!important;
    color: var(--e-global-color-eedc059)!important;
}

.cepso-pdf-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* ══════════════════════════════════════════════════════════
   [cepso_formation_prix] — Cellules Commander
   ══════════════════════════════════════════════════════════ */

.cepso-col-commander {
    text-align: center !important;
    white-space: nowrap;
    padding: 8px 12px !important;
}

.cepso-cart-form {
    display: inline-block;
    margin: 0;
    padding: 0;
}

.cepso-cart-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

.cepso-qty {
    width: 56px;
    padding: 6px 8px;
    border: 1px solid var(--e-global-color-secondary, #d0d5dd);
    border-radius: 4px;
    font-size: 0.9em;
    text-align: center;
    -moz-appearance: textfield;
}
.cepso-qty::-webkit-inner-spin-button,
.cepso-qty::-webkit-outer-spin-button {
    opacity: 1;
}

.cepso-btn-cart {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.cepso-btn-cart svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    flex-shrink: 0;
}

.cepso-btn-std, .cepso-btn-socaf {
    padding: .5rem 1rem!important;
    background-color: var(--e-global-color-accent)!important;
    color: var(--e-global-color-eedc059)!important;
    border: none!important;
}
.cepso-btn-std:hover, .cepso-btn-socaf:hover {
    background-color: var(--e-global-color-secondary)!important;
    color: var(--e-global-color-eedc059)!important;
}


/* ── Double prix panier (Non Sociétaire / Sociétaire SOCAF) ────── */

.cepso-panier-prix-actif,
.cepso-panier-prix-ref {
    display: block;
    line-height: 1.4;
}

.cepso-panier-prix-actif {
    font-weight: 600;
    color: #1a1a1a;
}

.cepso-panier-prix-ref {
    font-weight: 400;
    color: #888;
    font-size: .875em;
    margin-top: 2px;
}

.cepso-panier-prix-label {
    display: block;
    font-weight: 400;
    font-size: .8em;
    color: inherit;
    opacity: .75;
    text-transform: uppercase;
    letter-spacing: .03em;
}

/* ═══════════════════════════════════════════════════════════════
   TABLEAU PANIER — CEPSO
   Couleurs :
     #5D1854  violet foncé  → en-têtes, accents
     #FF0054  rouge vif     → bouton "Valider la commande"
     #2E3188  bleu indigo   → bordures arrondies
   ═══════════════════════════════════════════════════════════════ */


/* ── Colonne miniature masquée (pas d'image produit) ───────── */

.woocommerce-cart-form .shop_table th.product-thumbnail,
.woocommerce-cart-form .shop_table td.product-thumbnail {
    display: none;
}

/* ── Conteneur du tableau ──────────────────────────────────── */

.woocommerce-cart-form .shop_table {
    border: 2px solid #2E3188;
    border-radius: 14px;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
    width: 100%;
}

/* ── En-tête ───────────────────────────────────────────────── */

.woocommerce-cart-form .shop_table thead tr {
    background-color: #5D1854;
}

.woocommerce-cart-form .shop_table thead th {
    color: #fff;
    font-weight: 600;
    font-size: .875rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: 14px 16px;
    border: none;
}

/* ── Lignes du corps ───────────────────────────────────────── */

.woocommerce-cart-form .shop_table tbody tr.cart_item {
    transition: background-color .15s ease;
}

.woocommerce-cart-form .shop_table tbody tr.cart_item:hover {
    background-color: rgba(46, 49, 136, .04);
}

.woocommerce-cart-form .shop_table tbody td {
    padding: 14px 16px;
    border-top: 1px solid rgba(46, 49, 136, .15);
    vertical-align: middle;
}

/* ── Ligne d'actions (bas du tableau) ──────────────────────── */

.woocommerce-cart-form .shop_table td.actions {
    border-top: 2px solid rgba(46, 49, 136, .2);
    background-color: rgba(93, 24, 84, .03);
}

/* ── Bouton "Mettre à jour le panier" ──────────────────────── */

.woocommerce-cart-form .shop_table .button[name="update_cart"] {
    background-color: transparent;
    color: #2E3188;
    border: 2px solid #2E3188;
    border-radius: 8px;
    font-weight: 600;
    padding: 10px 20px;
    transition: background-color .2s, color .2s;
}

.woocommerce-cart-form .shop_table .button[name="update_cart"]:hover:not(:disabled) {
    background-color: #2E3188;
    color: #fff;
}

/* ── Récapitulatif totaux ──────────────────────────────────── */

.cart_totals {
    border: 2px solid #2E3188;
    border-radius: 14px;
    overflow: hidden;
}

.cart_totals h2 {
    background-color: #5D1854;
    color: #fff!important;
    margin: 0;
    padding: 14px 20px;
    font-size: 1rem!important;
    letter-spacing: .05em;
}

.cart_totals .shop_table {
    border: none;
    border-radius: 0;
    margin: 0;
}

.cart_totals .shop_table th,
.cart_totals .shop_table td {
    padding: 12px 20px;
    border-top: 1px solid rgba(46, 49, 136, .12);
}

/* ── Bouton "Valider la commande" ──────────────────────────── */

.wc-proceed-to-checkout .checkout-button,
a.checkout-button {
    display: table!important;
    text-align: center!important;
    margin: auto!important;
    font-size: 1.1em!important;
    padding: 1em!important;    
    background-color: #FF0054 !important;
    border-color: #FF0054 !important;
    border-radius: 10px !important;
    color: #fff !important;
    font-weight: 700 !important;
    letter-spacing: .03em;
    transition: background-color .2s, transform .1s;
}

.wc-proceed-to-checkout .checkout-button:hover,
a.checkout-button:hover {
    background-color: #cc0044 !important;
    border-color: #cc0044 !important;
    transform: translateY(-1px);
}

/* ── Responsive ────────────────────────────────────────────── */

@media ( max-width: 768px ) {
    .woocommerce-cart-form .shop_table,
    .cart_totals {
        border-radius: 10px;
    }

    .woocommerce-cart-form .shop_table tbody td {
        padding: 10px 12px;
    }

    /* WooCommerce affiche le label de colonne via data-title en mobile */
    .woocommerce-cart-form .shop_table tbody td::before {
        color: #5D1854;
        font-weight: 600;
    }
}

/* ── Double prix (Non Sociétaire / Sociétaire SOCAF) ───────── */

.cepso-panier-prix-actif,
.cepso-panier-prix-ref {
    display: block;
    line-height: 1.5;
}

.cepso-panier-prix-actif {
    font-weight: 700;
    color: #5D1854;
}

.cepso-panier-prix-ref {
    font-weight: 400;
    color: #999;
    font-size: .85em;
    margin-top: 2px;
}

.cepso-panier-prix-label {
    display: block;
    font-weight: 400;
    font-size: .75em;
    text-transform: uppercase;
    letter-spacing: .04em;
    opacity: .8;
}
/* ═══════════════════════════════════════════════════════════════
   PANIER — Nouvelles fonctionnalités (v1.2.0)
   ═══════════════════════════════════════════════════════════════ */

/* ── Date de formation ─────────────────────────────────────── */
.woocommerce-cart-form .wc-item-meta .wc-item-meta-label {
    font-weight: 600;
    color: var(--e-global-color-primary);
}

/* ── Champ Participants ────────────────────────────────────── */
.cepso-participants-wrap {
    margin-top: 10px;
}

.cepso-participants-label {
    display: block;
    font-weight: 600;
    font-size: .85em;
    margin-bottom: 4px;
    color: var(--e-global-color-primary);
    text-transform: uppercase;
    letter-spacing: .03em;
}

.cepso-participants-input {
    width: 100%;
    min-height: 60px;
    padding: 6px 8px;
    border: 1px solid var(--e-global-color-secondary, #d0d5dd);
    border-radius: 4px;
    font-size: .875em;
    line-height: 1.5;
    color: var(--e-global-color-primary);
    background: #fafafa;
    resize: vertical;
    box-sizing: border-box;
    transition: border-color .15s ease;
}

.cepso-participants-input:focus {
    outline: none;
    border-color: var(--e-global-color-accent, #2e3188);
    background: #fff;
}

/* ── Icône poubelle dans la cellule quantité ───────────────── */
.woocommerce a.remove {
    height: 1.25em!important;
    width: 1.25em!important;    
}
.cepso-trash-icon {
    width: 18px;
    height: 18px;
    display: inline-block;
    vertical-align: bottom;
    flex-shrink: 0;
}

/* Cellule quantité en flex pour aligner input + poubelle */
.woocommerce-cart-form .shop_table td.product-quantity {

}

.woocommerce-cart-form .product-quantity a.remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 6px;
    color: #c0392b;
    background: transparent;
    text-decoration: none;
    transition: background-color .15s ease, color .15s ease;
    flex-shrink: 0;
}

.woocommerce-cart-form .product-quantity a.remove:hover {
    background: rgba(192, 57, 43, .1);
    color: #922b21;
}

/* ── Prix panier — SOCAF en avant ──────────────────────────── */
.cepso-panier-prix-actif {
    display: block;
    font-weight: 700;
    color: var(--e-global-color-primary);
    line-height: 1.5;
}

.cepso-panier-prix-actif--socaf {
    color: #1a5c2a !important;
}

.cepso-panier-prix-ref--socaf {
    display: block;
    margin-top: 5px;
    font-weight: 600;
    font-size: .9em;
    color: #1a5c2a;
    line-height: 1.4;
}

.cepso-panier-prix-ref--socaf .cepso-socaf-badge {
    vertical-align: middle;
}

/* ── Totaux double tarif ────────────────────────────────────── */

/* Masquer les lignes par défaut WooCommerce */
.cart_totals .cart-subtotal,
.cart_totals .order-total,
.cart_totals tr[class*="tax-rate"],
.cart_totals .tax-total {
    display: none !important;
}

/* Lignes personnalisées */
.cepso-total-row th,
.cepso-total-row td {
    padding: 14px 20px;
    border-top: 1px solid rgba(46, 49, 136, .15);
    vertical-align: middle;
}

.cepso-total-std th {
    font-weight: 600;
    color: var(--e-global-color-primary);
}

.cepso-total-std td {
    text-align: right;
    font-weight: 700;
    font-size: 1em;
    color: var(--e-global-color-primary);
}

.cepso-total-socaf {
    background: #f0f7f2;
}

.cepso-total-socaf th {
    font-weight: 600;
    color: #1a5c2a;
}

.cepso-total-socaf td {
    text-align: right;
    font-weight: 700;
    font-size: 1.08em;
    color: #1a5c2a;
}

.cepso-ttc-label {
    font-weight: 400;
    font-size: .8em;
    opacity: .7;
    margin-left: 3px;
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 768px) {
    .woocommerce-cart-form .shop_table td.product-quantity {
        flex-wrap: wrap;
    }
    .cepso-participants-input {
        min-height: 50px;
    }
}
