/* ════════════════════════════════════════
   KOCOON — Page Commande (Checkout)
   Charte : beige #F5F2EC, noir #1A1A1A, ocre #C9A96E
   Layout desktop : hero sidebar (240px) + form + order review
   ════════════════════════════════════════ */

/* ══════════════════════════════════════
   0) MASQUER LE TITRE ASTRA / BREADCRUMB
   ══════════════════════════════════════ */

body.woocommerce-checkout .entry-title,
body.woocommerce-checkout .ast-page-title-wrap,
body.woocommerce-checkout .ast-breadcrumbs-wrap {
    display: none !important;
}

body.woocommerce-checkout .entry-content,
body.woocommerce-checkout .entry-content.clear {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

body.woocommerce-checkout {
    overflow-x: hidden;
}

/* ══════════════════════════════════════
   1) LAYOUT PRINCIPAL — DESKTOP (≥1025px)
   Structure :
   .woocommerce → flex-row
     .kocoon-checkout-hero (240px)
     form.woocommerce-checkout (flex:1)
       #customer_details (col 1)
       #order_review_heading + #order_review (col 2)
   ══════════════════════════════════════ */

body.woocommerce-checkout .woocommerce {
    max-width: 1160px !important;
    margin: 0 auto !important;
    padding: 0 24px 40px !important;
    box-sizing: border-box !important;
}

@media (min-width: 1025px) {

    /* ── .woocommerce → CSS Grid 2 colonnes
       Col 1 (240px) : hero sidebar
       Col 2 (1fr)   : notice coupon + form (empilés verticalement)
       :not(.woocommerce-order-received) → évite que ces règles s'appliquent
       sur la page de confirmation (qui a aussi la classe woocommerce-checkout)
    ── */
    body.woocommerce-checkout:not(.woocommerce-order-received) .woocommerce {
        display: grid !important;
        grid-template-columns: 240px minmax(0, 1fr) !important;
        column-gap: 20px !important;
        align-items: start !important;
    }

    /* Hero → colonne 1, s'étend sur toutes les lignes */
    body.woocommerce-checkout:not(.woocommerce-order-received) .kocoon-checkout-hero {
        grid-column: 1 !important;
        grid-row: 1 / span 20 !important;
        align-self: stretch !important;
        margin-bottom: 0 !important;
    }

    /* Tout le reste (coupon toggle, coupon form, form checkout) → colonne 2 */
    body.woocommerce-checkout:not(.woocommerce-order-received) .woocommerce > *:not(.kocoon-checkout-hero) {
        grid-column: 2 !important;
        min-width: 0 !important;
    }

    /* ── Form checkout → grille interne 2 cols (billing | order review) ── */
    body.woocommerce-checkout form.woocommerce-checkout {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 300px !important;
        column-gap: 20px !important;
        row-gap: 0 !important;
        align-items: start !important;
        min-width: 0 !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout #customer_details {
        grid-column: 1 !important;
        grid-row: 1 / span 10 !important;
        min-width: 0 !important;
        overflow: visible !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout h3#order_review_heading {
        grid-column: 2 !important;
        grid-row: 1 !important;
        min-width: 0 !important;
        width: 100% !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout #order_review {
        grid-column: 2 !important;
        grid-row: 2 / span 5 !important;
        position: sticky !important;
        top: 20px !important;
        min-width: 0 !important;
        width: 100% !important;
        box-sizing: border-box !important;
        overflow: hidden !important;
        word-break: break-word !important;
        overflow-wrap: break-word !important;
    }

    /* Éléments inattendus dans le form → colonne billing */
    body.woocommerce-checkout form.woocommerce-checkout > *:not(#customer_details):not(#order_review):not(#order_review_heading) {
        grid-column: 1 !important;
        min-width: 0 !important;
    }
}

/* ══════════════════════════════════════
   1b) NOTICE & FORMULAIRE COUPON CHECKOUT
   Éléments avant le form (colonne 2 du grid woocommerce)
   ══════════════════════════════════════ */

body.woocommerce-checkout .woocommerce-form-coupon-toggle {
    margin-bottom: 12px !important;
    padding: 12px 16px !important;
    background: var(--k-beige) !important;
    border: 1px solid var(--k-border) !important;
    border-radius: 10px !important;
    font-size: 13px !important;
    color: var(--k-gris) !important;
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
    color: var(--k-gris) !important;
    border-radius: 0 !important;
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle a.showcoupon {
    color: var(--k-ocre) !important;
    font-weight: 500 !important;
    text-decoration: underline !important;
}

body.woocommerce-checkout .woocommerce-form-coupon {
    background: var(--k-beige) !important;
    border: 1px solid var(--k-border) !important;
    border-radius: 10px !important;
    padding: 16px !important;
    margin-bottom: 16px !important;
    display: none; /* masqué par défaut, WooCommerce JS le montre */
}

body.woocommerce-checkout .woocommerce-form-coupon.hidden {
    display: none !important;
}

body.woocommerce-checkout .woocommerce-form-coupon p.form-row {
    margin-bottom: 10px !important;
}

body.woocommerce-checkout .woocommerce-form-coupon .button {
    background: var(--k-noir) !important;
    color: var(--k-beige) !important;
    border-radius: 20px !important;
    border: none !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
}

body.woocommerce-checkout .woocommerce-form-coupon .button:hover {
    background: var(--k-ocre) !important;
}

/* ══════════════════════════════════════
   2) HERO SIDEBAR CHECKOUT
   Partage les classes .kch-* avec le panier
   mais ciblé via .kocoon-checkout-hero
   ══════════════════════════════════════ */

body.woocommerce-checkout .kocoon-checkout-hero {
    background: var(--k-hero-bg);
    border-radius: 16px;
    padding: 28px 22px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    box-sizing: border-box;
    margin-bottom: 24px;
}

@media (min-width: 1025px) {
    body.woocommerce-checkout .kocoon-checkout-hero {
        width: 240px !important;
        flex-shrink: 0 !important;
        align-self: stretch !important;
        margin-bottom: 0 !important;
    }
}

/* Breadcrumb */
body.woocommerce-checkout .kch-breadcrumb {
    display: flex;
    align-items: center;
    gap: 2px;
    font-size: 11px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(44, 44, 44, 0.55);
    flex-wrap: wrap;
}

body.woocommerce-checkout .kch-breadcrumb a {
    color: rgba(44, 44, 44, 0.55) !important;
    text-decoration: none !important;
    transition: color 0.15s;
}

body.woocommerce-checkout .kch-breadcrumb a:hover {
    color: #2C2C2C !important;
}

body.woocommerce-checkout .kch-sep {
    color: rgba(44, 44, 44, 0.3);
}

body.woocommerce-checkout .kch-current {
    color: #2C2C2C;
    font-weight: 500;
}

/* Titre */
body.woocommerce-checkout .kch-title {
    font-size: 24px !important;
    font-weight: 500 !important;
    color: #2C2C2C !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
    background: none !important;
    border: none !important;
}

/* Sous-titre */
body.woocommerce-checkout .kch-sub {
    font-size: 12px;
    color: rgba(44, 44, 44, 0.65);
    line-height: 1.6;
    margin: 0;
}

/* Stepper vertical sur desktop */
body.woocommerce-checkout .kch-steps {
    display: flex;
    align-items: center;
    gap: 0;
}

@media (min-width: 1025px) {
    body.woocommerce-checkout .kch-steps {
        flex-direction: column !important;
        align-items: flex-start !important;
    }
}

body.woocommerce-checkout .kch-step {
    display: flex;
    align-items: center;
    gap: 8px;
}

body.woocommerce-checkout .kch-step__dot {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 500;
    flex-shrink: 0;
    line-height: 1;
    background: rgba(44, 44, 44, 0.15);
    color: rgba(44, 44, 44, 0.5);
}

/* Étape active */
body.woocommerce-checkout .kch-step--active .kch-step__dot {
    background: #2C2C2C;
    color: #F5F2EC;
}

/* Étape terminée */
body.woocommerce-checkout .kch-step__dot--done {
    background: var(--k-ocre);
    color: #fff;
    font-size: 11px;
}

body.woocommerce-checkout .kch-step__label {
    font-size: 12px;
    color: #2C2C2C;
    font-weight: 500;
    white-space: nowrap;
}

body.woocommerce-checkout .kch-step__label--done {
    color: rgba(44, 44, 44, 0.55);
    font-weight: 400;
}

body.woocommerce-checkout .kch-step__label--todo {
    color: rgba(44, 44, 44, 0.45);
    font-weight: 400;
}

/* Ligne du stepper */
body.woocommerce-checkout .kch-step__line {
    display: inline-block;
    width: 32px;
    height: 1px;
    background: rgba(44, 44, 44, 0.2);
    margin: 0 6px;
    flex-shrink: 0;
}

@media (min-width: 1025px) {
    body.woocommerce-checkout .kch-step__line {
        display: block !important;
        width: 1px !important;
        height: 18px !important;
        margin: 0 0 0 13px !important;
    }
}

/* Colonne droite du hero (count + secure) */
body.woocommerce-checkout .kch-right {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-top: auto;
    width: 100%;
}

body.woocommerce-checkout .kch-count-card {
    background: rgba(255, 255, 255, 0.45);
    border: 1px solid rgba(255, 255, 255, 0.6);
    border-radius: 14px;
    padding: 12px 14px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    box-sizing: border-box;
}

body.woocommerce-checkout .kch-count-num {
    font-size: 22px;
    font-weight: 500;
    color: #2C2C2C;
    line-height: 1;
}

body.woocommerce-checkout .kch-count-lbl {
    font-size: 11px;
    color: rgba(44, 44, 44, 0.55);
    letter-spacing: 1px;
    text-transform: uppercase;
}

body.woocommerce-checkout .kch-secure {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: rgba(44, 44, 44, 0.55);
}

body.woocommerce-checkout .kch-secure__icon {
    width: 14px;
    height: 14px;
    border: 1.5px solid rgba(44, 44, 44, 0.4);
    border-radius: 3px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

body.woocommerce-checkout .kch-secure__icon::after {
    content: '';
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: rgba(44, 44, 44, 0.4);
}

/* ══════════════════════════════════════
   3) BILLING / SHIPPING — col2-set
   ══════════════════════════════════════ */

body.woocommerce-checkout #customer_details {
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* Sur desktop, empiler col-1 et col-2 verticalement */
body.woocommerce-checkout #customer_details .col-1,
body.woocommerce-checkout #customer_details .col-2 {
    float: none !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Titre des sections Facturation / Livraison */
body.woocommerce-checkout .woocommerce-billing-fields h3,
body.woocommerce-checkout .woocommerce-shipping-fields h3,
body.woocommerce-checkout .woocommerce-additional-fields h3 {
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: var(--k-ocre) !important;
    margin: 24px 0 16px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

body.woocommerce-checkout .woocommerce-billing-fields h3:first-child {
    margin-top: 0 !important;
}

/* ── Labels ── */
/* Labels couverts par forms-global.css — seul l'abbr * est spécifique au checkout */
body.woocommerce-checkout .woocommerce-checkout label abbr {
    color: #E24B4A !important;
    text-decoration: none !important;
    margin-left: 2px !important;
}

/* Inputs, focus, textarea, Select2 → couverts par forms-global.css */

/* ── Lignes de form ── */
body.woocommerce-checkout .form-row {
    margin: 0 0 14px !important;
    padding: 0 !important;
}

/* Lignes côte à côte (prénom / nom) */
body.woocommerce-checkout .form-row-first,
body.woocommerce-checkout .form-row-last {
    width: calc(50% - 6px) !important;
    display: inline-block !important;
    vertical-align: top !important;
}

body.woocommerce-checkout .form-row-first {
    margin-right: 12px !important;
}

body.woocommerce-checkout .form-row-wide {
    width: 100% !important;
    clear: both !important;
}

/* ── Checkbox (créer compte, livraison différente) ── */
body.woocommerce-checkout .woocommerce-checkout p.form-row.create-account,
body.woocommerce-checkout .woocommerce-checkout #ship-to-different-address {
    background: var(--k-beige) !important;
    border: 1px solid var(--k-border) !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    margin: 16px 0 !important;
}

/* Checkbox + erreurs de champ → couverts par forms-global.css */

/* ══════════════════════════════════════
   4) RÉCAPITULATIF COMMANDE (order_review)
   ══════════════════════════════════════ */

body.woocommerce-checkout h3#order_review_heading {
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: var(--k-ocre) !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

body.woocommerce-checkout #order_review {
    background: var(--k-beige) !important;
    border: 1px solid var(--k-border) !important;
    border-radius: 14px !important;
    padding: 18px 20px !important;
    box-sizing: border-box !important;
}

/* Table produits */
body.woocommerce-checkout .woocommerce-checkout-review-order-table {
    width: 100% !important;
    border-collapse: collapse !important;
    border: none !important;
    margin-bottom: 14px !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table thead {
    display: none !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item {
    border-bottom: 1px solid var(--k-border-light) !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table td {
    padding: 10px 0 !important;
    border: none !important;
    background: transparent !important;
    font-size: 13px !important;
    color: var(--k-noir) !important;
    vertical-align: middle !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table td.product-name {
    font-weight: 400 !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table td.product-name .product-quantity {
    color: var(--k-gris) !important;
    font-size: 12px !important;
    font-weight: 400 !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table td.product-total {
    text-align: right !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
}

/* Totaux */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr td {
    padding: 7px 0 !important;
    border: none !important;
    background: transparent !important;
    font-size: 13px !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr th {
    color: var(--k-gris) !important;
    font-weight: 400 !important;
    text-align: left !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr td {
    color: var(--k-noir) !important;
    text-align: right !important;
    font-weight: 400 !important;
}

/* Livraison gratuite */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.shipping th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.shipping td,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.shipping td * {
    color: var(--k-vert) !important;
    font-weight: 500 !important;
}

/* TVA masquée — montants affichés TTC */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.tax-total,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr[class*="tax-rate"] {
    display: none !important;
}

/* Ligne total */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.order-total th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot tr.order-total td {
    border-top: 1px solid var(--k-border) !important;
    padding-top: 12px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: var(--k-noir) !important;
}

/* Suppression pseudo-labels ::before */
body.woocommerce-checkout .woocommerce-checkout-review-order-table td::before,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tfoot td::before {
    display: none !important;
    content: none !important;
}

/* ══════════════════════════════════════
   5) PAIEMENT
   ══════════════════════════════════════ */

body.woocommerce-checkout #payment {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin-top: 16px !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

body.woocommerce-checkout #payment ul.payment_methods {
    list-style: none !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    width: 100% !important;
    min-width: 0 !important;
}

body.woocommerce-checkout #payment ul.payment_methods li {
    background: var(--k-beige-2) !important;
    border: 1px solid var(--k-border) !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    margin-bottom: 8px !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
}

body.woocommerce-checkout #payment ul.payment_methods li label {
    font-size: 13px !important;
    color: var(--k-noir) !important;
    font-weight: 400 !important;
    margin: 0 !important;
    cursor: pointer !important;
    flex: 1 !important;
    min-width: 0 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

body.woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
    accent-color: var(--k-ocre) !important;
    flex-shrink: 0 !important;
    width: auto !important;
    min-height: auto !important;
    height: auto !important;
}

body.woocommerce-checkout #payment .payment_box {
    background: var(--k-beige) !important;
    border: 1px solid var(--k-border-light) !important;
    border-radius: 8px !important;
    padding: 12px 14px !important;
    margin-top: 8px !important;
    font-size: 12px !important;
    color: var(--k-gris) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

/* Notice RGPD / politique de confidentialité */
body.woocommerce-checkout #payment .woocommerce-privacy-policy-text,
body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper,
body.woocommerce-checkout #payment p {
    font-size: 11px !important;
    color: var(--k-gris-clair) !important;
    line-height: 1.5 !important;
    margin-bottom: 12px !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
}

body.woocommerce-checkout #payment p a {
    color: var(--k-ocre) !important;
}

/* ── Bouton Passer la commande ── */
body.woocommerce-checkout #payment #place_order,
body.woocommerce-checkout #payment .woocommerce-checkout-payment .button#place_order {
    display: block !important;
    width: 100% !important;
    background: var(--k-noir) !important;
    background-color: var(--k-noir) !important;
    color: var(--k-beige) !important;
    border: none !important;
    border-radius: 20px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    padding: 13px 18px !important;
    text-align: center !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    box-sizing: border-box !important;
    min-height: auto !important;
    height: auto !important;
}

body.woocommerce-checkout #payment #place_order:hover {
    background: var(--k-ocre) !important;
    background-color: var(--k-ocre) !important;
    color: #fff !important;
}

/* Sous-texte paiement sécurisé (::after) */
body.woocommerce-checkout #payment .woocommerce-checkout-payment::after {
    content: "Paiement sécurisé" !important;
    display: block !important;
    text-align: center !important;
    font-size: 11px !important;
    color: var(--k-gris-clair) !important;
    margin-top: 8px !important;
    letter-spacing: 0.4px !important;
}

/* ══════════════════════════════════════
   6) MESSAGES WOOCOMMERCE
   ══════════════════════════════════════ */

body.woocommerce-checkout .woocommerce-info,
body.woocommerce-checkout .woocommerce-message,
body.woocommerce-checkout .woocommerce-error {
    border-radius: 8px !important;
    font-size: 13px !important;
    margin-bottom: 16px !important;
}

body.woocommerce-checkout .woocommerce-info {
    background: var(--k-beige) !important;
    border-top-color: var(--k-ocre) !important;
    color: var(--k-gris) !important;
}

body.woocommerce-checkout .woocommerce-message {
    background: var(--k-beige) !important;
    border-top-color: var(--k-ocre) !important;
    color: #8B7355 !important;
}

body.woocommerce-checkout .woocommerce-error {
    background: #FCEBEB !important;
    border-top-color: #E24B4A !important;
    color: #A32D2D !important;
}

/* ══════════════════════════════════════
   7) TABLETTE (768–1024px)
   ══════════════════════════════════════ */

@media (min-width: 768px) and (max-width: 1024px) {

    body.woocommerce-checkout .kocoon-checkout-hero {
        padding: 24px 20px;
        margin-bottom: 20px;
    }

    body.woocommerce-checkout .kch-title {
        font-size: 20px !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout {
        display: grid !important;
        grid-template-columns: 1fr 240px !important;
        column-gap: 16px !important;
        align-items: start !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout #customer_details {
        grid-column: 1 !important;
        grid-row: 1 / 4 !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout h3#order_review_heading {
        grid-column: 2 !important;
        grid-row: 1 !important;
    }

    body.woocommerce-checkout form.woocommerce-checkout #order_review {
        grid-column: 2 !important;
        grid-row: 2 !important;
    }
}

/* ══════════════════════════════════════
   8) MOBILE (<768px)
   ══════════════════════════════════════ */

@media (max-width: 767px) {

    body.woocommerce-checkout .woocommerce {
        padding: 0 16px 32px !important;
    }

    body.woocommerce-checkout .kocoon-checkout-hero {
        /* Pleine largeur avec 100vw comme le panier */
        margin-left: calc(-50vw + 50%) !important;
        margin-right: calc(-50vw + 50%) !important;
        width: 100vw !important;
        border-radius: 0 !important;
        margin-bottom: 20px !important;
        flex-direction: column !important;
        padding: 24px 20px !important;
    }

    body.woocommerce-checkout .kch-right {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
    }

    body.woocommerce-checkout .kch-count-card {
        flex-direction: row !important;
        width: auto !important;
        padding: 8px 14px !important;
    }

    body.woocommerce-checkout .form-row-first,
    body.woocommerce-checkout .form-row-last {
        width: 100% !important;
        display: block !important;
        margin-right: 0 !important;
    }

    body.woocommerce-checkout h3#order_review_heading {
        margin-top: 24px !important;
    }
}

/* ══════════════════════════════════════
   9) LAYOUT 1-COLONNE CENTRÉE (640px)
   Ordre : récap → adresse/formulaire → paiement
   Écrase le grid 2-colonnes pour le form interne.
   Le hero sidebar (grid externe) est conservé.
   ══════════════════════════════════════ */

body.woocommerce-checkout:not(.woocommerce-order-received) form.woocommerce-checkout {
    display: flex !important;
    flex-direction: column !important;
    max-width: 640px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100% !important;
    /* Annuler le grid interne hérité */
    grid-template-columns: unset !important;
    column-gap: unset !important;
}

/* ── Ordre des sections ── */
body.woocommerce-checkout form.woocommerce-checkout h3#order_review_heading {
    order: 1 !important;
    grid-column: unset !important;
    grid-row: unset !important;
}

body.woocommerce-checkout form.woocommerce-checkout #order_review {
    order: 2 !important;
    grid-column: unset !important;
    grid-row: unset !important;
    position: static !important;
    margin-bottom: 24px !important;
}

/* Card adresse + formulaire facturation → même rang (DOM order les départage) */
body.woocommerce-checkout form.woocommerce-checkout .kocoon-billing-card,
body.woocommerce-checkout form.woocommerce-checkout #customer_details {
    order: 3 !important;
    grid-column: unset !important;
    grid-row: unset !important;
    width: 100% !important;
}

body.woocommerce-checkout form.woocommerce-checkout #payment {
    order: 4 !important;
    grid-column: unset !important;
    grid-row: unset !important;
}

/* Autres enfants (notice coupon, login…) → avant le récap */
body.woocommerce-checkout form.woocommerce-checkout > *:not(h3#order_review_heading):not(#order_review):not(.kocoon-billing-card):not(#customer_details):not(#payment) {
    order: 0 !important;
    grid-column: unset !important;
    grid-row: unset !important;
    width: 100% !important;
}

/* ══════════════════════════════════════
   10) MASQUAGE / AFFICHAGE #customer_details
   Piloté par les classes body :
     .kocoon-has-saved-address  → ajoutée par PHP si adresse sauvegardée
     .kocoon-show-form          → ajoutée/retirée par JS au clic "Modifier"
   ══════════════════════════════════════ */

/* Formulaire caché par défaut quand adresse disponible */
body.kocoon-has-saved-address #customer_details {
    display: none !important;
}

/* Formulaire visible après clic "Modifier" */
body.kocoon-has-saved-address.kocoon-show-form #customer_details {
    display: block !important;
}

/* ══════════════════════════════════════
   11) CARD ADRESSE SAUVEGARDÉE
   (utilisateur connecté — injectée PHP via
    woocommerce_checkout_before_customer_details)
   ══════════════════════════════════════ */

.kocoon-billing-card {
    background: #F5F2EC;
    border-left: 4px solid #4A6B52;
    border-radius: 8px;
    padding: 16px 20px;
    margin-bottom: 16px;
    font-size: 13px;
    line-height: 1.6;
    color: #1A1A1A;
}

.kocoon-billing-card__name {
    font-weight: 600;
    margin-bottom: 2px;
    margin-top: 0;
}

.kocoon-billing-card__line {
    color: #5A5550;
    margin: 0;
}

.kocoon-billing-card__actions {
    margin-top: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.kocoon-billing-card__edit-btn {
    display: inline-block;
    padding: 6px 16px;
    border: 1.5px solid #4A6B52;
    border-radius: 20px;
    background: transparent;
    color: #4A6B52;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    text-decoration: none;
}

.kocoon-billing-card__edit-btn:hover {
    background: #4A6B52;
    color: #F5F2EC;
}

/* Lien connexion (utilisateur non connecté) */
.kocoon-checkout-login-notice {
    font-size: 13px;
    color: #5A5550;
    margin-bottom: 12px;
    padding: 10px 14px;
    background: #F5F2EC;
    border-radius: 6px;
    border: 1px solid #D4CFC4;
}

.kocoon-checkout-login-notice a {
    color: #4A6B52 !important;
    font-weight: 500;
    text-decoration: underline;
}
