/*
Theme Name: Blocksy Child OOBLIK
Theme URI: https://ooblik.com/
Description: Thème enfant personnalisé pour Blocksy avec logo OOBLIK
Author: Marc Tallec
Template: blocksy
Version: 3.26
*/

/* =================================================================
   1. UPLOAD WIDGET - Largeur et containment
   ================================================================= */

.single-product .ooblik-upload-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    margin: 20px 0 15px 0 !important;
    border-bottom: 2px solid #DC2626 !important;
    padding-bottom: 20px !important;
}

/* Empêcher le débordement des noms de fichiers longs */
.single-product .ooblik-file-info,
.single-product .ooblik-file-details {
    min-width: 0 !important;
    flex: 1 !important;
    overflow: hidden !important;
}

.single-product .ooblik-file-name,
.single-product .ooblik-file-size {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

/* =================================================================
   2. FORM.CART - Ordre des éléments dans le formulaire produit
   On ne touche PAS à .entry-summary (Blocksy gère le layout natif).
   On repositionne uniquement à l'intérieur de form.cart.

   IMPORTANT : div.wapf encapsule .wapf-wrapper ET .wapf-product-totals.
   display:contents l'aplatit pour que ses enfants deviennent des flex
   children directs de form.cart, permettant le réordonnancement.
   ================================================================= */

/* Aplatir le conteneur WAPF pour exposer ses enfants au flex parent */
.single-product form.cart > .wapf,
.single-product .variations_form > .wapf {
    display: contents;
}

/* Produits VARIABLES */
.single-product .variations_form {
    display: flex;
    flex-direction: column;
}

.single-product .variations_form table.variations       { order: 1; }
.single-product .variations_form .wapf-wrapper           { order: 2; }
.single-product .variations_form .ooblik-upload-wrapper  { order: 3; }
.single-product .variations_form .wapf-product-totals    { order: 4; }
.single-product .variations_form .single_variation_wrap  { order: 5; }
.single-product .variations_form .woocommerce-variation-add-to-cart { order: 6; }

/* Produits SIMPLES */
.single-product form.cart {
    display: flex;
    flex-direction: column;
}

.single-product form.cart .wapf-wrapper             { order: 1; }
.single-product form.cart .ooblik-upload-wrapper    { order: 2; }
.single-product form.cart .wapf-product-totals      { order: 3; }
.single-product form.cart .tooltip-container         { order: 3; } /* avec totals */
.single-product form.cart .ct-cart-actions           { order: 4; }

/* =================================================================
   3. WAPF (Advanced Product Fields) - Style cartouche brutaliste
   ================================================================= */

/* Reset arrondis WAPF pour style cartouche */
.single-product .wapf {
    --apf-radius: 0;
    --apf-card-radius: 0;
    --apf-cb-radius: 0;
    --apf-ts-radius: 0;
    --apf-radio-border: 2px solid #000;
    --apf-radio-bg-sel: #DC2626;
    --apf-radio-border-color-sel: #DC2626;
    --apf-cb-border: 2px solid #000;
    --apf-cb-bg-sel: #DC2626;
    --apf-input-border: 1px solid #000;
}

/* Titre du champ ("Choix du Carnet", "Papiers") : fond rouge, texte blanc */
.single-product .wapf-field-label label {
    border: 1px solid #000;
    padding: 8px 12px;
    background: #f15252;
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #ffffff;
    display: block;
    width: 100%;
    box-sizing: border-box;
}

/* Texte des options radio plus grand et lisible */
.single-product .wapf-label-text {
    font-size: 16px;
    font-weight: 500;
    padding-left: 10px;
    text-transform: uppercase;
}

/* Description des champs WAPF */
.wapf-field-description {
    font-size: 85%;
    padding: 0 0 20px;
    color: #000000;
}

/* Espacement entre les radios */
.single-product .wapf-radios {
    gap: 8px 1rem;
    padding: 12px 0;
}

/* Wrapper WAPF : espacement sans bordure (le trait rouge est sur .ooblik-upload-wrapper) */
.single-product .wapf-wrapper {
    padding-bottom: 15px;
    margin-bottom: 5px;
    width: 100%;
}

/* Total/prix : encadré noir, fond jaune, centré verticalement */
.single-product .wapf-product-totals .wapf--inner > div {
    border: 1px solid #000;
    padding: 16px 20px !important;
    font-size: 18px;
    font-weight: 700;
    background: #FEF9C3;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Neutraliser le float et margin/padding natifs des spans WAPF */
.single-product .wapf-product-totals .wapf--inner > div span {
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1;
}

/* Encadré spécifique message upload PDF */
.wapf-field-container.wapf-field-p.field-2e4ef0a {
    background-color: #eeedec;
    border: 2px solid #ff0000;
    padding: 15px;
    margin: 20px 0;
}

.wapf-field-container.wapf-field-p.field-2e4ef0a .wapf-field-label span {
    text-transform: uppercase;
    font-size: 0.9em;
    color: #ff0000;
    display: block;
    margin-bottom: 10px;
}

.wapf-field-container.wapf-field-p.field-2e4ef0a .wapf-field-input {
    font-size: 0.8em;
    text-align: justify;
    line-height: 1.5;
    color: #333;
}

/* =================================================================
   4. DESCRIPTION PRODUIT - Titres h3/h4 style cartouche
   ================================================================= */

#tab-description .entry-content h3,
#tab-description .entry-content h4 {
    border: 1px solid #000;
    padding: 8px 12px;
    margin-top: 24px;
    background: #fff;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 15px;
    letter-spacing: 0.5px;
}

/* =================================================================
   5. PAGE /print/ (SHOP ARCHIVE) - Espacement menu/contenu
   ================================================================= */

[data-prefix="woo_categories"] .ct-container {
    padding-top: 50px;
    padding-bottom: 50px;
}

/* =================================================================
   6. RESPONSIVE
   ================================================================= */

@media (max-width: 768px) {
    .single-product .ooblik-upload-wrapper {
        margin: 20px 0 !important;
        padding: 15px !important;
    }

    /* Boutons Gutenberg empilés en colonne sur mobile */
    div.wp-block-buttons {
        flex-direction: column !important;
    }

    div.wp-block-buttons > div {
        width: 100% !important;
        margin-bottom: 10px;
    }

    div.wp-block-buttons a {
        font-size: 13px;
        padding: 4px 16px;
        width: 100%;
        display: block !important;
        text-align: center;
    }

    /* Blocs Gutenberg Group : plafonner le padding inline (5rem → 30px) */
    .wp-block-group[style*="padding-left"],
    .wp-block-group[style*="padding-right"] {
        padding-left: 30px !important;
        padding-right: 30px !important;
    }

    /* Groupes flex (row) dans les covers : empiler en colonne sur mobile */
    .wp-block-cover .wp-block-group.is-layout-flex {
        flex-direction: column !important;
        flex-wrap: wrap !important;
    }

    .wp-block-cover .wp-block-group.is-layout-flex > .wp-block-buttons {
        width: 100% !important;
    }
}

/* =================================================================
   7. MEGA MENU (Max Mega Menu) - Style OOBLIK
   ================================================================= */

/* Images du mega menu : s'adaptent à leur conteneur */
.mega-menu-item img {
    max-width: 100%;
    height: auto;
}

/* Contenu carte mega menu */
.mm-card-content {
    padding: 10px 0;
}

.mm-card-content .mm-description {
    font-size: 14px;
    color: #4A4A4A;
    margin: 0 0 8px 0;
    line-height: 1.5;
}

.mm-card-content .mm-price {
    font-size: 15px;
    font-weight: 600;
    color: #cd0c19;
    margin: 0 0 12px 0;
}

.mm-card-content .mm-button {
    display: inline-block;
    background: #e30f1d;
    color: #ffffff !important;
    font-size: 13px;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 0;
    text-decoration: none;
    transition: all 0.2s ease;
}

.mm-card-content .mm-button:hover {
    background: #bb1520;
    color: #ffffff !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(196, 105, 74, 0.3);
}

/* Footer du mega menu - Besoin d'aide */
.mm-footer-help {
    width: 100%;
    padding: 16px 20px;
    margin-top: 10px;
    border-top: 1px solid rgba(26, 26, 26, 0.08);
    font-size: 13px;
    color: #7A7A7A;
    text-align: center;
}

.mm-footer-help a {
    color: #e30f1d;
    font-weight: 600;
    text-decoration: none;
}

.mm-footer-help a:hover {
    color: #bb1520;
}

/* Bordures entre les colonnes du mega menu (dédupliqué) */
#mega-menu-wrap-menu_2 .mega-menu-row .mega-menu-column {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    border-right: 1px solid rgba(26, 26, 26, 0.1) !important;
    padding-right: 15px !important;
    padding-left: 15px !important;
}

#mega-menu-wrap-menu_2 .mega-menu-row .mega-menu-column:last-child {
    border-right: none !important;
}

/* =================================================================
   8. BREADCRUMB CATEGORIES - Pages catégories WooCommerce
   (réplique le style ct-breadcrumbs de Blocksy sur pages produit)
   ================================================================= */

[data-prefix="woo_categories"] .ooblik-category-breadcrumb {
    color: var(--theme-text-color, #000);
    text-align: center;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: relative;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    margin-top: 0;
    margin-bottom: 1rem;
}

/* Le nav porte la couleur rouge = dernier item (texte brut sans <a>) */
[data-prefix="woo_categories"] .ooblik-category-breadcrumb .woocommerce-breadcrumb {
    color: #DC2626;
}

/* Les liens restent noirs */
[data-prefix="woo_categories"] .ooblik-category-breadcrumb .woocommerce-breadcrumb a {
    color: var(--theme-text-color, #000);
    text-decoration: none;
}

[data-prefix="woo_categories"] .ooblik-category-breadcrumb .woocommerce-breadcrumb a:hover {
    text-decoration: underline;
}

/* Séparateurs et trait noir */
[data-prefix="woo_categories"] .ooblik-category-breadcrumb .ct-separator {
    vertical-align: middle;
    margin: 0 4px;
    color: var(--theme-text-color, #000);
}

/* Trait noir pleine largeur */
[data-prefix="woo_categories"] .ooblik-category-breadcrumb::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 100vw;
    height: 1px;
    background-color: var(--theme-text-color, #000);
    transform: translateX(-50%);
}

/* =================================================================
   9. BREADCRUMB PRODUIT - Pages produit (override Blocksy ct-breadcrumbs)
   Fusionné : child theme (typo) + Customizer (position, trait noir)
   ================================================================= */

.ct-breadcrumbs {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    text-align: center;
    color: var(--theme-text-color);
    --has-link-decoration: var(--false);
    position: relative;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    margin-top: 0;
    margin-bottom: 1rem;
}

/* Dernier item en rouge (page courante) */
.ct-breadcrumbs .last-item {
    color: #DC2626;
}

/* Trait noir pleine largeur sous le breadcrumb */
.ct-breadcrumbs::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 100vw;
    height: 1px;
    background-color: currentColor;
    transform: translateX(-50%);
}

/* =================================================================
   10. ESPACEMENT GLOBAL CONTENU - Gap entre header et contenu
   Le réglage Blocksy est à 0 pour les pages hero (image plein bord).
   On rajoute un padding par défaut pour les pages sans hero.
   ================================================================= */

/* Par défaut : espacement pour toutes les pages WordPress standard */
[data-prefix="single_page"] main.site-main {
    padding-top: 50px;
    padding-bottom: 50px;
}

/* Exception haut : pages dont le premier bloc est un Cover (hero) */
[data-prefix="single_page"] main.site-main:has(.entry-content > .wp-block-cover:first-child) {
    padding-top: 0;
}

/* Exception bas : pages dont le dernier bloc est un Cover (CTA plein bord) */
[data-prefix="single_page"] main.site-main:has(.entry-content > .wp-block-cover:last-child) {
    padding-bottom: 0;
}

/* Pages produit WooCommerce : espacement bas uniquement (le haut est géré par Blocksy) */
[data-prefix="product"] main.site-main {
    padding-bottom: 50px;
}

/* =================================================================
   11. WPFORMS - Correction taille textarea
   WPForms applique max-width aux input.wpforms-field-medium mais pas
   aux textarea.wpforms-field-medium → le textarea déborde.
   ================================================================= */

.wpforms-form textarea.wpforms-field-medium {
    max-width: 60%;
}

/* reCAPTCHA et bouton Envoyer alignés à droite des champs (60%) */
.wpforms-form .wpforms-recaptcha-container,
.wpforms-form .wpforms-submit-container {
    max-width: 60%;
    display: flex;
    justify-content: flex-end;
}

@media (max-width: 768px) {
    .wpforms-container {
        padding-left: 15px;
        padding-right: 15px;
    }

    .wpforms-form textarea.wpforms-field-medium {
        max-width: 100%;
    }

    .wpforms-form .wpforms-recaptcha-container,
    .wpforms-form .wpforms-submit-container {
        max-width: 100%;
        justify-content: center;
    }
}

/* =================================================================
   12. LIGHTBOX PHOTOSWIPE
   ================================================================= */

.pswp__zoom-wrap,
.pswp__img {
    background-color: #f8f5f0 !important;
}

.pswp__img {
    box-shadow: 0 0 0 100vmax #f8f5f0;
}

.pswp__button--arrow--left,
.pswp__button--arrow--right {
    width: 60px;
    height: 60px;
    background-color: transparent !important;
    background-size: 60% auto;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 1 !important;
    filter: brightness(0);
}

/* =================================================================
   13. GALERIE PRODUIT WOOCOMMERCE
   ================================================================= */

/* Conteneur de la galerie */
.woocommerce div.product .woocommerce-product-gallery {
    max-width: 100% !important;
    width: 100% !important;
}

/* Image principale */
.woocommerce div.product .woocommerce-product-gallery__image img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
}

/* Vignettes */
.woocommerce div.product .flex-control-thumbs li {
    max-width: 100px !important;
}

.woocommerce div.product .flex-control-thumbs img {
    width: 100% !important;
    height: auto !important;
}

/* =================================================================
   14. PANIER & TUNNEL DE COMMANDE
   ================================================================= */

/* Labels page commande (page ID 1052408) */
body.page-id-1052408 .woocommerce-checkout .form-row label {
    color: #d50000;
    font-weight: 500;
    text-transform: uppercase;
    font-size: 0.95rem;
    letter-spacing: 0.5px;
}

/* Bloc fichiers dans le panier */
.woocommerce-cart .ooblik-cart-files,
.woocommerce-checkout .ooblik-cart-files,
.cart_item .ooblik-cart-files,
.product-name .ooblik-cart-files,
div.ooblik-cart-files {
    padding: 15px !important;
    box-sizing: border-box !important;
}

.ooblik-cart-files strong {
    margin-bottom: 8px !important;
    display: block !important;
}

.ooblik-cart-files li {
    padding: 5px 0 !important;
}

/* Bouton "Valider la commande" (page panier) + "Commander" (page commande) */
.woocommerce-cart .checkout-button,
.woocommerce-checkout #place_order {
    font-size: 1.1rem !important;
    padding: 18px 40px !important;
    box-shadow: 0 4px 12px rgba(209, 32, 58, 0.3) !important;
    transition: transform 0.2s, box-shadow 0.2s !important;
}

.woocommerce-cart .checkout-button:hover,
.woocommerce-checkout #place_order:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 16px rgba(209, 32, 58, 0.4) !important;
}

/* 100% de largeur sur mobile pour les boutons panier/commande */
@media (max-width: 768px) {
    .woocommerce-cart .checkout-button,
    .woocommerce-checkout #place_order {
        width: 100% !important;
        padding: 20px 30px !important;
        font-size: 1.2rem !important;
    }
}

/* =================================================================
   15. LAYOUT PAGE PRODUIT - RESPONSIVE
   ================================================================= */

/* MOBILE FIRST : Layout vertical par défaut */
body.single-product .ct-container {
    max-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
}

body.single-product .product-entry-wrapper {
    max-width: 100%;
    display: block;
    padding-bottom: 60px;
}

body.single-product .product-entry-wrapper > div:first-child {
    max-width: 100%;
    width: 100%;
    margin-bottom: 30px;
}

body.single-product .product-entry-wrapper .entry-summary {
    max-width: 100%;
    width: 100%;
}

/* TABLETTE (768px+) : Layout 2 colonnes équilibrées */
@media (min-width: 768px) {
    body.single-product .ct-container {
        max-width: 1150px;
        margin: 0 auto;
    }

    body.single-product .product-entry-wrapper {
        display: grid;
        grid-template-columns: 50% 1fr;
        gap: 40px;
        max-width: 1150px;
        margin-left: 0 !important;
        margin-right: auto !important;
        padding-left: 20px;
    }

    body.single-product .product-entry-wrapper > div:first-child {
        max-width: 100%;
        width: 100%;
        margin-bottom: 0;
    }
}

/* DESKTOP (1024px+) : Layout optimisé - largeur modérée */
@media (min-width: 1024px) {
    body.single-product .ct-container {
        max-width: 1280px;
        margin: 0 auto;
    }

    body.single-product .product-entry-wrapper {
        max-width: 1280px;
        grid-template-columns: 600px 1fr;
        gap: 50px;
        margin-left: 0 !important;
        margin-right: auto !important;
        padding-left: 20px;
    }

    body.single-product .product-entry-wrapper > div:first-child {
        max-width: 600px;
        width: 600px;
    }
}

/* GRAND ECRAN (1400px+) : Layout large contrôlé */
@media (min-width: 1400px) {
    body.single-product .ct-container {
        max-width: 1350px;
        margin: 0 auto;
    }

    body.single-product .product-entry-wrapper {
        max-width: 1350px;
        grid-template-columns: 650px 1fr;
        gap: 60px;
        margin-left: 0 !important;
        margin-right: auto !important;
    }

    body.single-product .product-entry-wrapper > div:first-child {
        max-width: 650px;
        width: 650px;
    }
}

/* =================================================================
   16. FOOTER WIDGETS & PARTENAIRES
   ================================================================= */

/* Footer Legal menu widget - harmoniser avec la colonne L'Atelier */
[data-column="widget-area-3"] .widget_nav_menu .widget-title {
    font-size: 1.25em;
    font-weight: 700;
    color: #000 !important;
}

[data-column="widget-area-3"] .widget_nav_menu .widget-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

[data-column="widget-area-3"] .widget_nav_menu .widget-menu li {
    margin-bottom: 2px;
}

[data-column="widget-area-3"] .widget_nav_menu .widget-menu a {
    color: #000 !important;
    text-decoration: none !important;
    font-size: var(--wp--preset--font-size--small, 13px);
}

[data-column="widget-area-3"] .widget_nav_menu .widget-menu a:hover {
    color: #fa4d5e !important;
}

/* Widget area 6 : logos partenaires en ligne */
[data-column="widget-area-6"] {
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 30px;
    justify-content: center;
}

[data-column="widget-area-6"] .ct-widget {
    margin: 0 !important;
    padding: 0 !important;
}

[data-column="widget-area-6"] figure {
    margin: 0 !important;
    padding: 0 !important;
    text-align: center;
}

[data-column="widget-area-6"] figcaption {
    margin-top: 5px;
}

/* Logos partenaires footer : taille uniforme */
footer a[href*="luju.fr"] img,
footer a[href*="lesardents.fr"] img {
    object-fit: contain !important;
    width: 100%;
    height: 60px;
}

/* =================================================================
   17. ACCORDEONS & TABLE DES MATIERES
   ================================================================= */

/* Titres des accordéons */
.accordion-content__heading {
    border-bottom: 1px solid var(--wp--preset--color--vivid-red);
    padding-bottom: 0.5em;
    margin-bottom: 1em;
}

/* Table des matières sticky */
.toc-sticky {
    font-size: 0.95rem;
    background: #efefef !important;
    border: 1px solid #d7d2cc !important;
    box-shadow: 0 2px 12px rgba(180, 170, 160, 0.07);
}

.toc-sticky a {
    color: #444;
    text-decoration: none;
    transition: color 0.2s;
}

.toc-sticky a:hover,
.toc-sticky a:focus {
    color: #d1203a;
}

/* Masquer la TOC sticky sur mobile */
@media (max-width: 768px) {
    .wp-block-group.is-position-sticky:has(.toc-sticky) {
        display: none;
    }
}

/* =================================================================
   18. MON COMPTE (/mon-compte/) - RESPONSIVE
   Navigation horizontale scrollable, contenu pleine largeur,
   adresses empilées, boutons tactiles, formulaires mobile.
   ================================================================= */

@media (max-width: 768px) {
    /* --- Container : zéro padding, collé au header (connecté uniquement) --- */

    .woocommerce-account:has(.ct-acount-nav) main.site-main {
        padding-top: 0 !important;
    }

    .woocommerce-account:has(.ct-acount-nav) .ct-container,
    .woocommerce-account:has(.ct-acount-nav) .ct-container-full {
        padding-left: 0 !important;
        padding-right: 0 !important;
        max-width: 100% !important;
    }

    /* Réduire le padding inline 5rem du bloc Gutenberg Group */
    .woocommerce-account .entry-content > .wp-block-group {
        padding-left: 30px !important;
        padding-right: 30px !important;
    }

    /* Page connexion : bouton centré, "se souvenir de moi" à droite */
    .woocommerce-account .woocommerce-form-login .form-row:not(.form-row-wide) {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-end;
    }

    .woocommerce-account .woocommerce-form-login .woocommerce-form__label-for-checkbox {
        display: flex;
        flex-direction: row-reverse;
        align-items: baseline;
        gap: 6px;
    }

    .woocommerce-account .woocommerce-form-login .form-row:not(.form-row-wide) .woocommerce-form-login__submit {
        width: 100%;
        text-align: center;
    }

    /* Connecté : zéro (le contenu gère son propre padding) */
    .woocommerce-account:has(.ct-acount-nav) .entry-content > .wp-block-group {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Forcer le wrapper .woocommerce pleine largeur (connecté uniquement) */
    .woocommerce-account:has(.ct-acount-nav) .woocommerce {
        max-width: 100% !important;
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* --- Navigation horizontale scrollable, bord à bord --- */

    .woocommerce-account .ct-acount-nav {
        border-right: none;
        border-radius: 0 !important;
        overflow: visible !important;
        margin-bottom: 0;
        padding: 0;
    }

    /* Masquer le nom du client (redondant avec le "Bonjour X") */
    .woocommerce-account .ct-account-welcome {
        display: none;
    }


    .woocommerce-account .woocommerce-MyAccount-navigation {
        border-top: 1px solid #000;
        border-bottom: 1px solid #000;
        width: 100vw;
        position: relative;
        left: 50%;
        transform: translateX(-50%);
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        display: flex;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
        display: none;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li {
        border-right: 1px solid #000;
        flex-shrink: 0;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li:last-child {
        border-right: none;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li a {
        display: block;
        padding: 10px 14px;
        font-size: 13px;
        white-space: nowrap;
        color: #000;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li a::before {
        display: none;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li.is-active {
        background: #DC2626;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
        color: #fff;
        background: transparent !important;
        border-radius: 0 !important;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation li a {
        border-radius: 0 !important;
    }

    /* --- Contenu pleine largeur, petit padding texte --- */

    .woocommerce-account .woocommerce-MyAccount-content {
        width: 100%;
        padding: 15px;
        font-size: 15px;
        line-height: 1.6;
        box-sizing: border-box;
    }

    /* --- Projets : réduire colonne vignettes à zéro --- */

    .woocommerce-account .woocommerce-MyAccount-content table td:first-child:has(img) {
        width: 0 !important;
        max-width: 0 !important;
        padding: 0 !important;
        border: none !important;
        overflow: hidden !important;
        font-size: 0 !important;
        line-height: 0 !important;
    }

    .woocommerce-account .woocommerce-MyAccount-content table td:first-child:has(img) img {
        display: none;
    }

    /* --- Adresses empilées --- */

    .woocommerce-account .col2-set {
        grid-template-columns: 1fr !important;
        gap: 20px;
    }

    .woocommerce-account .woocommerce-Address-title {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .woocommerce-account .woocommerce-Address-title h2 {
        font-size: 16px;
        margin: 0;
    }

    /* --- Boutons commandes tactiles --- */

    .woocommerce-account .woocommerce-orders-table .woocommerce-button,
    .woocommerce-account .woocommerce-orders-table .button {
        display: block;
        width: 100%;
        min-height: 44px;
        padding: 10px 16px;
        font-size: 14px;
        text-align: center;
        box-sizing: border-box;
    }

    /* --- Formulaires mobile --- */

    .woocommerce-account .woocommerce-MyAccount-content input[type="text"],
    .woocommerce-account .woocommerce-MyAccount-content input[type="email"],
    .woocommerce-account .woocommerce-MyAccount-content input[type="password"],
    .woocommerce-account .woocommerce-MyAccount-content input[type="tel"],
    .woocommerce-account .woocommerce-MyAccount-content select {
        width: 100%;
        min-height: 44px;
        font-size: 16px;
        padding: 8px 12px;
        border: 1px solid #000;
        border-radius: 0;
        box-sizing: border-box;
    }

    .woocommerce-account .woocommerce-MyAccount-content button[type="submit"],
    .woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button {
        width: 100%;
        min-height: 48px;
        font-size: 16px;
        padding: 12px 20px;
        background: #DC2626;
        color: #fff;
        border: 1px solid #000;
        border-radius: 0;
    }
}
