/* ZeMassage Booking Extension - Styles */
.zmb-notice {padding:15px;border-radius:8px;margin:20px 0;}
.zmb-error {background:#fee;border-left:4px solid #d32f2f;color:#532354;}
.zmb-success {background:#e8f5e9;border-left:4px solid #43e97b;color:#532354;}

/* ===================================
   SECTION MES CRÉDITS - 3 COLONNES
   =================================== */

/* Forcer 3 colonnes côte à côte */
.zm-credits .zm-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 25px !important;
    margin: 30px 0 !important;
    width: 100% !important;
}

.zm-credits .zm-card {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    float: none !important;
    display: block !important;
}

/* Responsive */
@media (max-width: 1200px) {
    .zm-credits .zm-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 768px) {
    .zm-credits .zm-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ===================================
   TABLEAU DES COMMANDES
   =================================== */

/* Container du tableau */
.woocommerce-MyAccount-orders {
    background: white;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(83, 35, 84, 0.1);
    border: none !important;
    margin: 20px 0;
}

/* En-tête du tableau */
.woocommerce-MyAccount-orders thead {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%);
}

.woocommerce-MyAccount-orders thead th {
    color: white !important;
    padding: 20px 15px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-align: left !important;
    border: none !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Lignes du tableau */
.woocommerce-MyAccount-orders tbody tr {
    border-bottom: 1px solid #E6DFD9 !important;
    transition: all 0.3s ease;
}

.woocommerce-MyAccount-orders tbody tr:last-child {
    border-bottom: none !important;
}

.woocommerce-MyAccount-orders tbody tr:hover {
    background: rgba(252, 142, 65, 0.05) !important;
    transform: translateX(5px);
}

/* Cellules du tableau */
.woocommerce-MyAccount-orders tbody td,
.woocommerce-MyAccount-orders tbody th {
    padding: 18px 15px !important;
    color: #333 !important;
    border: none !important;
    font-size: 14px;
    vertical-align: middle;
}

/* Numéro de commande */
.woocommerce-orders-table__cell-order-number a {
    color: #532354 !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    font-size: 15px;
    transition: color 0.3s ease;
}

.woocommerce-orders-table__cell-order-number a:hover {
    color: #FC8E41 !important;
}

/* Date */
.woocommerce-orders-table__cell-order-date time {
    color: #666;
    font-weight: 500;
}

/* Badge de statut */
.woocommerce-orders-table__cell-order-status {
    font-weight: 600 !important;
}

/* Statut "En attente" */
.woocommerce-orders-table__row--status-on-hold .woocommerce-orders-table__cell-order-status {
    color: #F57F17 !important;
    position: relative;
    padding-left: 30px !important;
}

.woocommerce-orders-table__row--status-on-hold .woocommerce-orders-table__cell-order-status::before {
    content: '⏳';
    position: absolute;
    left: 15px;
    font-size: 16px;
}

/* Statut "En cours" */
.woocommerce-orders-table__row--status-processing .woocommerce-orders-table__cell-order-status {
    color: #1565C0 !important;
    position: relative;
    padding-left: 30px !important;
}

.woocommerce-orders-table__row--status-processing .woocommerce-orders-table__cell-order-status::before {
    content: '🔄';
    position: absolute;
    left: 15px;
    font-size: 16px;
}

/* Statut "Terminé" */
.woocommerce-orders-table__row--status-completed .woocommerce-orders-table__cell-order-status {
    color: #2E7D32 !important;
    position: relative;
    padding-left: 30px !important;
}

.woocommerce-orders-table__row--status-completed .woocommerce-orders-table__cell-order-status::before {
    content: '✅';
    position: absolute;
    left: 15px;
    font-size: 16px;
}

/* Statut "Annulé" */
.woocommerce-orders-table__row--status-cancelled .woocommerce-orders-table__cell-order-status {
    color: #d32f2f !important;
    position: relative;
    padding-left: 30px !important;
}

.woocommerce-orders-table__row--status-cancelled .woocommerce-orders-table__cell-order-status::before {
    content: '❌';
    position: absolute;
    left: 15px;
    font-size: 16px;
}

/* Total */
.woocommerce-orders-table__cell-order-total {
    font-weight: 600 !important;
    color: #532354 !important;
}

.woocommerce-orders-table__cell-order-total .woocommerce-Price-amount {
    font-size: 16px;
    font-weight: 700;
    color: #FC8E41 !important;
}

/* Bouton "Voir" */
.woocommerce-orders-table__cell-order-actions .button {
    display: inline-block !important;
    background: linear-gradient(135deg, #FC8E41 0%, #FF6B35 100%) !important;
    color: white !important;
    padding: 10px 25px !important;
    border-radius: 25px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 3px 10px rgba(252, 142, 65, 0.3) !important;
    border: none !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.woocommerce-orders-table__cell-order-actions .button:hover {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 15px rgba(83, 35, 84, 0.4) !important;
}

/* ===================================
   UNIFORMISATION GLOBALE MON COMPTE
   =================================== */

/* Tous les tableaux */
.woocommerce-MyAccount-content table {
    background: white;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(83, 35, 84, 0.1);
    border: none !important;
    margin: 20px 0;
}

/* Tous les en-têtes de tableaux */
.woocommerce-MyAccount-content table thead {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%);
}

.woocommerce-MyAccount-content table thead th {
    color: white !important;
    padding: 18px 15px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-align: left !important;
    border: none !important;
}

/* Toutes les lignes */
.woocommerce-MyAccount-content table tbody tr {
    border-bottom: 1px solid #E6DFD9 !important;
    transition: all 0.3s ease;
}

.woocommerce-MyAccount-content table tbody tr:hover {
    background: rgba(252, 142, 65, 0.05) !important;
}

/* Toutes les cellules */
.woocommerce-MyAccount-content table tbody td {
    padding: 16px 15px !important;
    border: none !important;
}

/* Tous les boutons dans les tableaux */
.woocommerce-MyAccount-content table .button,
.woocommerce-MyAccount-content table a.button,
.woocommerce-MyAccount-content table button {
    background: linear-gradient(135deg, #FC8E41 0%, #FF6B35 100%) !important;
    color: white !important;
    padding: 10px 25px !important;
    border-radius: 25px !important;
    font-weight: 600 !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 3px 10px rgba(252, 142, 65, 0.3) !important;
    border: none !important;
}

.woocommerce-MyAccount-content table .button:hover,
.woocommerce-MyAccount-content table a.button:hover,
.woocommerce-MyAccount-content table button:hover {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 15px rgba(83, 35, 84, 0.4) !important;
}

/* ===================================
   MES RÉSERVATIONS
   =================================== */

.zmb-bookings-list {margin:20px 0;}
.zmb-booking-card {background:white;border:2px solid #E2BDA0;border-radius:12px;padding:20px;margin-bottom:15px;transition:all 0.3s ease;}
.zmb-booking-card:hover {border-color:#FC8E41;box-shadow:0 4px 15px rgba(252,142,65,0.15);}
.zmb-booking-header {display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;}
.zmb-booking-title {color:#532354;font-size:18px;font-weight:700;margin:0;}
.zmb-booking-status {padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;}
.zmb-status-upcoming {background:#FC8E41;color:white;}
.zmb-status-past {background:#E6DFD9;color:#532354;}
.zmb-booking-details p {margin:8px 0;color:#532354;}
.zmb-booking-details strong {color:#532354;}

/* ===================================
   CALENDRIER
   =================================== */

.zmb-calendar-wrapper {max-width:1200px;margin:30px auto;padding:20px;}
.zmb-event-list {display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px;}
.zmb-event-card {background:white;border:2px solid #E2BDA0;border-radius:12px;padding:25px;transition:all 0.3s ease;cursor:pointer;}
.zmb-event-card:hover {border-color:#FC8E41;transform:translateY(-3px);box-shadow:0 6px 20px rgba(252,142,65,0.2);}
.zmb-event-card h3 {color:#532354;margin:0 0 15px 0;font-size:18px;}
.zmb-event-info p {margin:8px 0;color:#532354;}
.zmb-btn-book {background:linear-gradient(135deg,#FC8E41 0%,#ff9d5c 100%);color:white;padding:12px 30px;border:none;border-radius:8px;font-weight:700;cursor:pointer;width:100%;margin-top:15px;}
.zmb-btn-book:hover {transform:translateY(-2px);box-shadow:0 4px 15px rgba(252,142,65,0.4);}

/* ===================================
   MODAL
   =================================== */

.zmb-modal {display:none;position:fixed;z-index:9999;left:0;top:0;width:100%;height:100%;background:rgba(83,35,84,0.8);}
.zmb-modal-content {background:white;margin:10% auto;padding:30px;border-radius:16px;max-width:500px;box-shadow:0 8px 30px rgba(0,0,0,0.3);}
.zmb-modal h2 {color:#532354;margin:0 0 20px 0;}
.zmb-close {float:right;font-size:28px;font-weight:bold;color:#532354;cursor:pointer;}
.zmb-close:hover {color:#FC8E41;}
.zmb-gender-select {display:flex;gap:15px;margin:20px 0;}
.zmb-gender-option {flex:1;padding:15px;border:2px solid #E2BDA0;border-radius:8px;text-align:center;cursor:pointer;transition:all 0.3s ease;}
.zmb-gender-option:hover,.zmb-gender-option.selected {border-color:#FC8E41;background:rgba(252,142,65,0.1);}

/* ===================================
   LAYOUT MON COMPTE - SOLUTION ULTRA FORCÉE
   =================================== */

/* Reset COMPLET de tous les floats WooCommerce */
body.woocommerce-account.logged-in .woocommerce,
body.woocommerce-account.logged-in .woocommerce::before,
body.woocommerce-account.logged-in .woocommerce::after {
    float: none !important;
    clear: both !important;
}

/* Forcer le Grid Layout */
body.woocommerce-account.logged-in .woocommerce {
    display: grid !important;
    grid-template-columns: 300px 1fr !important;
    gap: 30px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 30px 20px !important;
}

/* Navigation - ANNULER TOUS LES FLOATS */
.woocommerce-MyAccount-navigation {
    grid-column: 1 !important;
    position: sticky !important;
    top: 100px !important;
    background: transparent !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 300px !important;
    float: none !important;
    clear: none !important;
}

/* Contenu - ANNULER TOUS LES FLOATS */
.woocommerce-MyAccount-content {
    grid-column: 2 !important;
    width: 100% !important;
    min-width: 0 !important;
    float: none !important;
    clear: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* PAS de grid sur la page login */
body.woocommerce-account:not(.logged-in) .woocommerce {
    display: block !important;
    grid-template-columns: none !important;
}

/* ===================================
   STYLE DU MENU LATÉRAL
   =================================== */

.woocommerce-MyAccount-navigation ul {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: white;
    border-radius: 15px;
    box-shadow: 0 4px 20px rgba(83, 35, 84, 0.1);
    overflow: hidden;
}

.woocommerce-MyAccount-navigation ul li {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    list-style-type: none !important;
    border-bottom: 1px solid #E6DFD9;
    position: relative;
}

.woocommerce-MyAccount-navigation ul li::before,
.woocommerce-MyAccount-navigation ul li::marker {
    display: none !important;
    content: none !important;
}

.woocommerce-MyAccount-navigation ul li:last-child {
    border-bottom: none;
}

/* Liens du menu */
.woocommerce-MyAccount-navigation ul li a {
    display: flex !important;
    align-items: center;
    padding: 18px 25px !important;
    color: #532354 !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    font-size: 15px !important;
    transition: all 0.3s ease;
    border-left: 4px solid transparent;
    background: transparent !important;
    width: 100%;
    box-sizing: border-box;
}

/* Masquer icônes/emojis existants sauf pour Mes Réservations */
.woocommerce-MyAccount-navigation ul li:not(.woocommerce-MyAccount-navigation-link--mes-reservations) a svg,
.woocommerce-MyAccount-navigation ul li:not(.woocommerce-MyAccount-navigation-link--mes-reservations) a img,
.woocommerce-MyAccount-navigation ul li:not(.woocommerce-MyAccount-navigation-link--mes-reservations) a .icon {
    display: none !important;
}

/* Ajouter emojis propres AVANT le texte */
.woocommerce-MyAccount-navigation-link--dashboard a::before {
    content: '📊 ';
    margin-right: 12px;
}

.woocommerce-MyAccount-navigation-link--orders a::before {
    content: '🛍️ ';
    margin-right: 12px;
}

.woocommerce-MyAccount-navigation-link--downloads a::before {
    content: '📥 ';
    margin-right: 12px;
}

.woocommerce-MyAccount-navigation-link--edit-address a::before {
    content: '📍 ';
    margin-right: 12px;
}

.woocommerce-MyAccount-navigation-link--edit-account a::before {
    content: '👤 ';
    margin-right: 12px;
}

.woocommerce-MyAccount-navigation-link--giftcard a::before {
    content: '🎁 ';
    margin-right: 12px;
}

.woocommerce-MyAccount-navigation-link--customer-logout a::before {
    content: '🚪 ';
    margin-right: 12px;
}

/* Hover state */
.woocommerce-MyAccount-navigation ul li a:hover {
    background: linear-gradient(90deg, rgba(252, 142, 65, 0.1) 0%, transparent 100%) !important;
    color: #FC8E41 !important;
    border-left-color: #FC8E41 !important;
    padding-left: 30px !important;
}

/* Active state */
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a[aria-current="page"] {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    color: white !important;
    border-left-color: #FC8E41 !important;
    font-weight: 600 !important;
}

.woocommerce-MyAccount-navigation ul li.is-active a::after,
.woocommerce-MyAccount-navigation ul li a[aria-current="page"]::after {
    content: '→';
    margin-left: auto;
    font-size: 18px;
    animation: slideRight 0.6s ease-in-out infinite alternate;
}

@keyframes slideRight {
    from { transform: translateX(0); }
    to { transform: translateX(5px); }
}

/* Déconnexion en rouge */
.woocommerce-MyAccount-navigation-link--customer-logout {
    margin-top: 10px !important;
    border-top: 2px solid #E6DFD9 !important;
}

.woocommerce-MyAccount-navigation-link--customer-logout a {
    color: #d32f2f !important;
    font-weight: 600 !important;
}

.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
    background: rgba(211, 47, 47, 0.1) !important;
    border-left-color: #d32f2f !important;
}

/* ===================================
   RESPONSIVE
   =================================== */

@media (max-width: 768px) {
    body.woocommerce-account.logged-in .woocommerce {
        grid-template-columns: 1fr !important;
        padding: 20px 15px !important;
    }
    
    .woocommerce-MyAccount-navigation {
        position: relative !important;
        top: auto !important;
        margin-bottom: 30px !important;
        max-width: 100%;
    }
    
    .woocommerce-MyAccount-navigation ul li a {
        padding: 15px 20px !important;
        font-size: 14px !important;
    }
    
    .woocommerce-MyAccount-navigation ul li a:hover {
        padding-left: 25px !important;
    }
}

/* ===================================
   STYLE DU CONTENU - MESSAGE INFO
   =================================== */

.woocommerce-MyAccount-content .woocommerce-info {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    color: white !important;
    border: none !important;
    border-left: 4px solid #FC8E41 !important;
    border-radius: 12px !important;
    padding: 20px 25px !important;
    margin-bottom: 30px !important;
    box-shadow: 0 4px 15px rgba(83, 35, 84, 0.2) !important;
}

.woocommerce-MyAccount-content .woocommerce-info::before {
    color: #FC8E41 !important;
}

/* Texte du dashboard */
.woocommerce-MyAccount-content > p {
    background: white;
    padding: 20px;
    border-radius: 10px;
    line-height: 1.8;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    margin-bottom: 20px;
}

.woocommerce-MyAccount-content > p strong {
    color: #532354;
}

.woocommerce-MyAccount-content > p a {
    color: #FC8E41 !important;
    text-decoration: none;
    font-weight: 600;
}

.woocommerce-MyAccount-content > p a:hover {
    color: #532354 !important;
    text-decoration: underline;
}

/* ===================================
   SECTION MES CRÉDITS DE COURS
   =================================== */

.zm-credits {
    background: linear-gradient(135deg, #E6DFD9 0%, #E2BDA0 100%) !important;
    padding: 40px !important;
    border-radius: 15px !important;
    margin: 30px 0 !important;
    box-shadow: 0 4px 20px rgba(83, 35, 84, 0.1) !important;
}

.zm-credits h2 {
    color: #532354 !important;
    margin-top: 0 !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    margin-bottom: 30px !important;
    text-align: center;
}

.zm-credits h3 {
    color: #532354 !important;
    font-size: 22px !important;
    font-weight: 600 !important;
    border-bottom: 2px solid #FC8E41 !important;
    padding-bottom: 10px !important;
    margin: 40px 0 20px 0 !important;
}

/* Cartes de crédits */
.zm-card {
    background: white !important;
    padding: 35px 25px !important;
    border-radius: 12px !important;
    text-align: center !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08) !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    overflow: hidden !important;
}

.zm-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 5px;
    background: linear-gradient(90deg, #FC8E41 0%, #532354 100%);
}

.zm-card:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 8px 25px rgba(83, 35, 84, 0.2) !important;
}

.zm-card.solo::before {
    background: linear-gradient(90deg, #532354 0%, #6B2C5C 100%) !important;
}

.zm-card.duo::before {
    background: linear-gradient(90deg, #FC8E41 0%, #FF6B35 100%) !important;
}

.zm-card.ateliers::before {
    background: linear-gradient(90deg, #E2BDA0 0%, #D4A574 100%) !important;
}

/* Icônes */
.zm-icon {
    font-size: 56px !important;
    margin-bottom: 15px !important;
    transition: transform 0.3s ease !important;
}

.zm-card:hover .zm-icon {
    transform: scale(1.1);
}

/* Titres des cartes */
.zm-card h3 {
    color: #532354 !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    margin: 15px 0 !important;
    border: none !important;
    padding: 0 !important;
}

/* Compteur de crédits */
.zm-count {
    font-size: 56px !important;
    font-weight: 800 !important;
    background: linear-gradient(135deg, #532354 0%, #FC8E41 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin: 15px 0 !important;
    line-height: 1;
}

.zm-card p {
    color: #666 !important;
    margin-bottom: 20px !important;
    font-size: 14px !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 500;
}

/* Boutons Recharger */
.zm-btn {
    display: inline-block !important;
    background: linear-gradient(135deg, #FC8E41 0%, #FF6B35 100%) !important;
    color: white !important;
    padding: 14px 32px !important;
    border-radius: 25px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(252, 142, 65, 0.3) !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: none !important;
}

.zm-btn:hover {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(83, 35, 84, 0.4) !important;
}

/* Section Historique */
.zm-credits > p {
    background: white !important;
    padding: 20px !important;
    border-radius: 8px !important;
    color: #532354 !important;
    font-style: italic !important;
    text-align: center !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05) !important;
}

/* ===================================
   PAGE CONNEXION/INSCRIPTION
   =================================== */

/* Forcer la structure en 2 colonnes */
#customer_login.u-columns.col2-set {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 40px !important;
    max-width: 1200px !important;
    margin: 40px auto !important;
    width: 100% !important;
}

/* Reset des colonnes */
#customer_login .u-column1,
#customer_login .u-column2,
#customer_login .col-1,
#customer_login .col-2 {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    margin: 0 !important;
    padding: 35px !important;
    background: white !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 20px rgba(83, 35, 84, 0.1) !important;
}

/* Titres */
#customer_login h2 {
    color: #532354 !important;
    font-size: 26px !important;
    font-weight: 700 !important;
    margin-bottom: 25px !important;
    padding-bottom: 15px !important;
    border-bottom: 3px solid #FC8E41 !important;
}

/* Champs */
#customer_login input[type="text"],
#customer_login input[type="email"],
#customer_login input[type="password"] {
    width: 100% !important;
    padding: 12px 15px !important;
    border: 2px solid #E6DFD9 !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    margin-top: 5px !important;
}

#customer_login input:focus {
    border-color: #FC8E41 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(252, 142, 65, 0.1) !important;
}

/* Labels */
#customer_login label {
    color: #532354 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    display: block !important;
    margin-bottom: 5px !important;
}

/* Boutons Se connecter / S'inscrire */
#customer_login .woocommerce-button,
#customer_login .woocommerce-Button,
#customer_login button[type="submit"] {
    background: linear-gradient(135deg, #FC8E41 0%, #FF6B35 100%) !important;
    color: white !important;
    padding: 14px 30px !important;
    border-radius: 25px !important;
    border: none !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(252, 142, 65, 0.3) !important;
    width: 100% !important;
    margin-top: 10px !important;
}

#customer_login .woocommerce-button:hover,
#customer_login .woocommerce-Button:hover,
#customer_login button[type="submit"]:hover {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(83, 35, 84, 0.4) !important;
}

/* Lien mot de passe perdu */
#customer_login .lost_password a {
    color: #FC8E41 !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

#customer_login .lost_password a:hover {
    color: #532354 !important;
    text-decoration: underline !important;
}

/* Case à cocher */
#customer_login .woocommerce-form__input-checkbox {
    width: auto !important;
    margin-right: 8px !important;
}

/* Texte politique de confidentialité */
#customer_login .woocommerce-privacy-policy-text {
    background: rgba(230, 223, 217, 0.3) !important;
    padding: 15px !important;
    border-radius: 8px !important;
    margin: 20px 0 !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
}

#customer_login .woocommerce-privacy-policy-text a {
    color: #FC8E41 !important;
}

/* ===================================
   RESPONSIVE GLOBAL
   =================================== */

@media (max-width: 768px) {
    /* Mon compte */
    .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation),
    body.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
        grid-template-columns: 1fr !important;
        padding: 20px 15px !important;
    }
    
    .woocommerce-MyAccount-navigation {
        position: relative !important;
        top: auto !important;
        margin-bottom: 30px !important;
        max-width: 100%;
    }
    
    .woocommerce-MyAccount-navigation ul li a {
        padding: 15px 20px !important;
        font-size: 14px !important;
    }
    
    .woocommerce-MyAccount-navigation ul li a:hover {
        padding-left: 25px !important;
    }
    
    /* Page connexion */
    #customer_login.u-columns.col2-set {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
        padding: 0 15px !important;
    }
    
    #customer_login .u-column1,
    #customer_login .u-column2 {
        padding: 25px 20px !important;
    }
    
    /* Crédits */
    .zm-credits {
        padding: 25px 15px !important;
    }
    
    .zm-credits h2 {
        font-size: 24px !important;
    }
    
    .zm-count {
        font-size: 48px !important;
    }
    
    .zm-icon {
        font-size: 48px !important;
    }
    
    /* Calendrier et réservations */
    .zmb-event-list {
        grid-template-columns: 1fr;
    }
    
    .zmb-modal-content {
        margin: 20% auto;
        padding: 20px;
    }
    
    /* Tableaux responsive */
    .woocommerce-MyAccount-orders thead {
        display: none;
    }
    
    .woocommerce-MyAccount-orders tbody tr {
        display: block;
        margin-bottom: 20px;
        border-radius: 10px;
        border: 1px solid #E6DFD9 !important;
        overflow: hidden;
    }
    
    .woocommerce-MyAccount-orders tbody tr:hover {
        transform: none;
    }
    
    .woocommerce-MyAccount-orders tbody td,
    .woocommerce-MyAccount-orders tbody th {
        display: flex;
        justify-content: space-between;
        padding: 15px !important;
        border-bottom: 1px solid #E6DFD9 !important;
    }
    
    .woocommerce-MyAccount-orders tbody td:last-child,
    .woocommerce-MyAccount-orders tbody th:last-child {
        border-bottom: none !important;
    }
    
    .woocommerce-MyAccount-orders tbody td::before,
    .woocommerce-MyAccount-orders tbody th::before {
        content: attr(data-title);
        font-weight: 600;
        color: #532354;
        margin-right: 10px;
    }
    
    .woocommerce-orders-table__cell-order-actions .button {
        width: 100%;
        text-align: center;
    }
}


/* ===================================
   FIX PAGE CONNEXION - APPROCHE DIVI
   =================================== */

/* Cibler le conteneur Divi qui entoure #customer_login */
.et_pb_section .et_pb_row .et_pb_column #customer_login.u-columns.col2-set,
.et_pb_text_inner #customer_login.u-columns.col2-set,
.woocommerce #customer_login.u-columns.col2-set {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 40px !important;
    max-width: 1200px !important;
    margin: 40px auto !important;
    width: 100% !important;
}

/* Forcer les colonnes à 50% chacune */
.et_pb_section .et_pb_row .et_pb_column #customer_login .u-column1,
.et_pb_section .et_pb_row .et_pb_column #customer_login .u-column2,
.et_pb_text_inner #customer_login .u-column1,
.et_pb_text_inner #customer_login .u-column2,
.woocommerce #customer_login .u-column1,
.woocommerce #customer_login .u-column2 {
    flex: 1 1 calc(50% - 20px) !important;
    width: calc(50% - 20px) !important;
    max-width: calc(50% - 20px) !important;
    min-width: 300px !important;
    float: none !important;
    margin: 0 !important;
    padding: 35px !important;
    background: white !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 20px rgba(83, 35, 84, 0.1) !important;
}

/* Annuler tous les floats */
#customer_login::after,
#customer_login::before,
#customer_login .u-column1::after,
#customer_login .u-column2::after {
    content: none !important;
    display: none !important;
}

/* Titres */
#customer_login h2 {
    color: #532354 !important;
    font-size: 26px !important;
    font-weight: 700 !important;
    margin-bottom: 25px !important;
    padding-bottom: 15px !important;
    border-bottom: 3px solid #FC8E41 !important;
}

/* Champs */
#customer_login input[type="text"],
#customer_login input[type="email"],
#customer_login input[type="password"] {
    width: 100% !important;
    padding: 12px 15px !important;
    border: 2px solid #E6DFD9 !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    margin-top: 5px !important;
    box-sizing: border-box !important;
}

#customer_login input:focus {
    border-color: #FC8E41 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(252, 142, 65, 0.1) !important;
}

/* Labels */
#customer_login label {
    color: #532354 !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    display: block !important;
    margin-bottom: 5px !important;
}

/* Boutons */
#customer_login .woocommerce-button,
#customer_login .woocommerce-Button,
#customer_login button[type="submit"] {
    background: linear-gradient(135deg, #FC8E41 0%, #FF6B35 100%) !important;
    color: white !important;
    padding: 14px 30px !important;
    border-radius: 25px !important;
    border: none !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(252, 142, 65, 0.3) !important;
    width: 100% !important;
    margin-top: 10px !important;
}

#customer_login .woocommerce-button:hover,
#customer_login .woocommerce-Button:hover,
#customer_login button[type="submit"]:hover {
    background: linear-gradient(135deg, #532354 0%, #6B2C5C 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(83, 35, 84, 0.4) !important;
}

/* Lien mot de passe perdu */
#customer_login .lost_password a {
    color: #FC8E41 !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

#customer_login .lost_password a:hover {
    color: #532354 !important;
    text-decoration: underline !important;
}

/* Case à cocher */
#customer_login .woocommerce-form__input-checkbox {
    width: auto !important;
    margin-right: 8px !important;
}

/* Politique de confidentialité */
#customer_login .woocommerce-privacy-policy-text {
    background: rgba(230, 223, 217, 0.3) !important;
    padding: 15px !important;
    border-radius: 8px !important;
    margin: 20px 0 !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
}

#customer_login .woocommerce-privacy-policy-text a {
    color: #FC8E41 !important;
}

/* Responsive */
@media (max-width: 768px) {
    .et_pb_section .et_pb_row .et_pb_column #customer_login.u-columns.col2-set,
    .et_pb_text_inner #customer_login.u-columns.col2-set,
    .woocommerce #customer_login.u-columns.col2-set {
        flex-direction: column !important;
        gap: 25px !important;
        padding: 0 15px !important;
    }
    
    .et_pb_section .et_pb_row .et_pb_column #customer_login .u-column1,
    .et_pb_section .et_pb_row .et_pb_column #customer_login .u-column2,
    .et_pb_text_inner #customer_login .u-column1,
    .et_pb_text_inner #customer_login .u-column2,
    .woocommerce #customer_login .u-column1,
    .woocommerce #customer_login .u-column2 {
        flex: 1 1 100% !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 25px 20px !important;
    }
}