/*
Theme Name: luniversdelacapsule2
Theme URI: https://luniversdelacapsule.fr
Author: Stéphane Donchery
Author URI: https://luniversdelacapsule.fr
Description: Thème WordPress/WooCommerce pour boutique capsules de champagne. Design luxe, typographie Playfair Display, palette or champagne.
Version: 2.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
WC requires at least: 7.0
WC tested up to: 9.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: luniversdelacapsule2
Tags: e-commerce, woocommerce, custom-logo, full-width-template, sticky-post, threaded-comments, test
*/

/* ============================================================
   TABLE DES MATIÈRES
   1.  Reset & Base
   2.  Typographie / Fonts
   3.  Layout utilitaires
   4.  Header
   5.  Slider wrapper
   6.  Boutique – layout
   7.  Grille produits
   8.  Card produit (BEM)
   9.  Fiche produit single
   10. Footer info
   11. Footer principal
   12. Pages WooCommerce (panier, commande, compte)
   13. Page À propos
   14. Page Contact
   15. Page Mentions légales
   16. Section photo art
   17. Valentine Hearts
   18. Responsive global
============================================================ */


/* ============================================================
   1. RESET & BASE
============================================================ */

*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html,
body {
    font-family: 'Outfit', sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #333333;
    background-color: #f4f3f2;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
    height: auto;
}

input, button, textarea, select {
    font: inherit;
    border: none;
    background: none;
    outline: none;
    color: inherit;
}

button { cursor: pointer; }
ul, ol { list-style: none; }

h1, h2, h3, h4, h5, h6 {
    font-weight: 400;
    line-height: 1.2;
}

a {
    text-decoration: none;
    color: inherit;
    transition: color 300ms ease;
}

table { border-collapse: collapse; }
hr { border: none; border-top: 1px solid #e6dccf; }


/* ============================================================
   2. TYPOGRAPHIE / FONTS
============================================================ */

@font-face {
    font-family: 'Achemost';
    src: url('assets/fonts/ACHEMOST.OTF') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}


/* ============================================================
   3. LAYOUT UTILITAIRES
============================================================ */

.udlc-container {
    width: 100%;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    padding-right: 32px;
}


/* ============================================================
   4. HEADER
============================================================ */

.udlc-header {
    position: sticky;
    top: 0;
    z-index: 999;
    background: #1d2533;
    border-bottom: 1px solid rgba(191,160,84,0.15);
    box-shadow: 0 1px 24px rgba(0,0,0,0.18);
    transition: box-shadow 300ms ease;
}

.udlc-header .udlc-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 14px;
    padding-bottom: 14px;
    gap: 32px;
}

/* ── Logo ────────────────────────────────────────────────────*/
.udlc-logo img {
    max-height: 58px;
    width: auto;
    transition: opacity 200ms ease;
}

.udlc-logo img:hover { opacity: 0.85; }

/* ── Navigation principale ───────────────────────────────────*/
.udlc-nav { display: flex; flex: 1; justify-content: center; }

.udlc-menu {
    display: flex;
    align-items: center;
    gap: 0;
}

.udlc-menu li { position: relative; }

.udlc-menu > li > a {
    color: rgba(244,243,242,0.7);
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 8px 18px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    position: relative;
    transition: color 300ms ease;
}

/* Trait doré sous le lien actif / hover */
.udlc-menu > li > a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 18px;
    right: 18px;
    height: 1px;
    background: #bfa054;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 300ms ease;
}

.udlc-menu > li > a:hover,
.udlc-menu > li.current-menu-item > a,
.udlc-menu > li.current-menu-ancestor > a {
    color: #bfa054;
}

.udlc-menu > li > a:hover::after,
.udlc-menu > li.current-menu-item > a::after,
.udlc-menu > li.current-menu-ancestor > a::after {
    transform: scaleX(1);
}

/* Chevron sous-menu */
.udlc-menu .menu-item-has-children > a > span.udlc-chevron,
.udlc-menu .menu-item-has-children > a::before {
    display: none;
}

.udlc-menu .menu-item-has-children > a {
    padding-right: 28px;
}

.udlc-menu .menu-item-has-children > a::after {
    /* Override the hover underline for items with children — use chevron instead */
    display: none;
}

.udlc-menu .menu-item-has-children > a .chevron {
    display: inline-block;
}

/* On réutilise le ::after pour le chevron sur les parents */
.udlc-menu li.menu-item-has-children > a {
    position: relative;
}

.udlc-menu li.menu-item-has-children > a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 18px;
    right: 18px;
    height: 1px;
    background: #bfa054;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 300ms ease;
    display: block;
}

.udlc-menu li.menu-item-has-children > a:hover::after,
.udlc-menu li.current-menu-item.menu-item-has-children > a::after {
    transform: scaleX(1);
}

/* Flèche indicateur enfants */
.udlc-menu li.menu-item-has-children > a > span.arrow,
.udlc-header .udlc-menu li.menu-item-has-children > a {
    padding-right: 14px;
}

/* ── Sous-menus ──────────────────────────────────────────────*/
.udlc-menu .sub-menu {
    display: none;
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    min-width: 220px;
    background: #1d2533;
    border: 1px solid rgba(191,160,84,0.18);
    border-radius: 8px;
    padding: 8px;
    flex-direction: column;
    gap: 2px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.3);
    z-index: 1000;
}

/* Petit pont transparent entre le lien et le sous-menu */
.udlc-menu .sub-menu::before {
    content: '';
    position: absolute;
    top: -12px;
    left: 0;
    right: 0;
    height: 12px;
}

.udlc-menu li:hover > .sub-menu { display: flex; }

.udlc-menu .sub-menu li a {
    display: block;
    padding: 9px 14px;
    border-radius: 6px;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(244,243,242,0.6);
    white-space: nowrap;
    transition: background 200ms ease, color 200ms ease;
}

.udlc-menu .sub-menu li a:hover {
    background: rgba(191,160,84,0.1);
    color: #bfa054;
}

/* ── Actions : compte + panier ───────────────────────────────*/
.udlc-user-cart {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

.udlc-account,
.udlc-login {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding: 6px 14px;
    border-radius: 6px;
    color: rgba(244,243,242,0.6);
    font-size: 0.75rem;
    font-weight: 400;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: color 300ms ease, background 300ms ease;
    text-align: center;
    line-height: 1.3;
}

.udlc-account span,
.udlc-login span {
    font-size: 0.65rem;
    opacity: 0.6;
    text-transform: none;
    letter-spacing: 0;
}

.udlc-account:hover,
.udlc-login:hover {
    color: #bfa054;
    background: rgba(191,160,84,0.06);
}

/* Séparateur vertical */
.udlc-user-cart::before {
    content: '';
    display: block;
    width: 1px;
    height: 20px;
    background: rgba(191,160,84,0.2);
    margin-left: 8px;
    margin-right: 8px;
}

.udlc-cart {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border: 1px solid rgba(191,160,84,0.3);
    border-radius: 6px;
    color: rgba(244,243,242,0.7);
    font-size: 0.75rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    transition: border-color 300ms ease, color 300ms ease, background 300ms ease;
}

.udlc-cart:hover {
    border-color: #bfa054;
    color: #bfa054;
    background: rgba(191,160,84,0.06);
}

.udlc-cart-count {
    position: static;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding-left: 5px;
    padding-right: 5px;
    background: #bfa054;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 9999px;
    line-height: 1;
    transition: background 300ms ease;
}

.udlc-cart:hover .udlc-cart-count { background: #8c6e2f; }

/* ── Toggle mobile ───────────────────────────────────────────*/
.udlc-menu-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    background: none;
    border: 1px solid rgba(191,160,84,0.2);
    border-radius: 6px;
    cursor: pointer;
    transition: border-color 300ms ease;
}

.udlc-menu-toggle:hover { border-color: #bfa054; }

.udlc-menu-toggle span {
    display: block;
    width: 22px;
    height: 1.5px;
    background: rgba(244,243,242,0.7);
    border-radius: 2px;
    transition: background 300ms ease;
}

.udlc-menu-toggle:hover span { background: #bfa054; }

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

    .udlc-menu-toggle { display: flex; }

    .udlc-nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: #1d2533;
        border-bottom: 1px solid rgba(191,160,84,0.15);
        padding: 16px 24px 24px;
        box-shadow: 0 8px 24px rgba(0,0,0,0.2);
        flex-direction: column;
        justify-content: flex-start;
    }

    .udlc-nav.is-open { display: flex; }

    .udlc-menu {
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
        width: 100%;
    }

    .udlc-menu > li { width: 100%; }

    .udlc-menu > li > a {
        padding: 12px 8px;
        width: 100%;
        justify-content: space-between;
        border-bottom: 1px solid rgba(255,255,255,0.04);
        font-size: 0.82rem;
    }

    .udlc-menu > li > a::after { display: none; }

    .udlc-menu .sub-menu {
        position: static;
        border: none;
        background: transparent;
        box-shadow: none;
        padding: 4px 0 4px 16px;
        border-left: 1px solid rgba(191,160,84,0.2);
        margin-left: 8px;
    }

    .udlc-menu li:hover > .sub-menu { display: none; }
    .udlc-menu li.is-open > .sub-menu { display: flex; }

    .udlc-menu .sub-menu li a { font-size: 0.75rem; }
}


/* ============================================================
   5. SLIDER WRAPPER
============================================================ */

.udlc-slider-wrapper {
    position: relative;
}

.udlc-slider-wrapper::after {
    content: '';
    display: block;
    position: absolute;
    z-index: 99;
    bottom: -50px;
    inset-inline: 0;
    height: 100px;
    background-image: url('assets/img/formelandscape.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}


/* ============================================================
   6. BOUTIQUE – LAYOUT
============================================================ */

.udlc-shop {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 64px;
    padding-top: 96px;
    padding-bottom: 96px;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    padding-right: 32px;
}

/* Sidebar */
.udlc-shop__filters-title,
.udlc-shop .udlc-filters h2 {
    font-family: 'Achemost', serif;
    font-size: 2.625rem;
    padding-bottom: 24px;
    color: #333333;
}

.udlc-shop__filters .wpc-filter-title,
.udlc-shop .udlc-filters .wpc-filter-title { font-weight: 700; }

/* Zone produits */
.udlc-shop__products,
.udlc-shop .udlc-products { min-width: 0; }

.udlc-shop__empty {
    padding: 48px;
    text-align: center;
    color: #888888;
    font-style: italic;
}

/* Pagination */
.udlc-shop__pagination { margin-top: 64px; }

.udlc-shop__pagination .woocommerce-pagination { text-align: center; }

.udlc-shop__pagination .woocommerce-pagination ul {
    display: inline-flex;
    gap: 8px;
}

.udlc-shop__pagination .woocommerce-pagination a,
.udlc-shop__pagination .woocommerce-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    font-size: 0.875rem;
    border: 1px solid #e6dccf;
    transition: all 300ms ease;
}

.udlc-shop__pagination .woocommerce-pagination a:hover {
    background: #bfa054;
    color: #fff;
    border-color: #bfa054;
}

.udlc-shop__pagination .woocommerce-pagination .current {
    background: #bfa054;
    color: #fff;
    border-color: #bfa054;
    font-weight: 600;
}

/* Select2 fix */
.select2-container .select2-selection--single .select2-selection__arrow b {
    background: none !important;
}


/* ============================================================
   7. GRILLE PRODUITS
============================================================ */

.udlc-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 24px;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* Reset li issu du ul.products WooCommerce */
.udlc-grid > li {
    margin: 0;
    padding: 0;
    float: none;
    clear: none;
    width: auto;
}


/* ============================================================
   8. CARD PRODUIT (BEM)
============================================================ */

.udlc-card {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
    transition: box-shadow 300ms ease, transform 300ms ease;
}

.udlc-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.12), 0 16px 40px rgba(0,0,0,0.14);
    transform: translateY(-4px);
}

/* Badges */
.udlc-card__badges {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.udlc-card__badge {
    display: inline-block;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1;
}

.udlc-card__badge--sale    { background: #e63946; color: #fff; }
.udlc-card__badge--featured { background: #bfa054; color: #fff; }

/* Image */
.udlc-card__image-link     { display: block; }

.udlc-card__image-wrapper {
    position: relative;
    aspect-ratio: 1 / 1;        /* carré parfait */
    width: 100%;
    background: #f4f3f2;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.udlc-card__img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;    /* jamais rogné, proportions conservées */
    object-position: center;
    padding: 12px;
    transition: transform 500ms ease;
    display: block;
}

/* Capsules et tous autres produits : même traitement */
.udlc-card__img:not(.cat-accessoires):not(.cat-livres) {
    border-radius: 0;
    padding: 12px;
    background: transparent;
}

/* Accessoires & livres */
.udlc-card__img.cat-accessoires,
.udlc-card__img.cat-livres {
    border-radius: 0;
    padding: 8px;
}

.udlc-card__img--placeholder {
    opacity: 0.4;
    padding: 32px;
}

.udlc-card:hover .udlc-card__img { transform: scale(1.06); }

/* Séparateur doré */
.udlc-card__image-link::after {
    content: '';
    display: block;
    height: 2px;
    background: linear-gradient(90deg, transparent, #bfa054, transparent);
    opacity: 0.6;
}

/* Corps */
.udlc-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 16px 20px 20px;
    gap: 8px;
}

/* Titre */
.udlc-card__title {
    font-family: 'Playfair Display', serif;
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.3;
    letter-spacing: 0.02em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.udlc-card__title-link { color: #333333; transition: color 300ms ease; }
.udlc-card__title-link:hover { color: #bfa054; }

/* Prix */
.udlc-card__price {
    margin-top: auto;
    padding-top: 8px;
}

.udlc-card__price .price {
    font-size: 0.875rem;
    font-weight: 600;
    color: #ff9879;
}

.udlc-card__price del { color: #888888; font-size: 0.75rem; font-weight: 400; }
.udlc-card__price ins { color: #e63946; font-weight: 700; text-decoration: none; }

/* CTA – toujours visible */
.udlc-card__actions {
    margin-top: 12px;
    opacity: 1;
    transform: translateY(0);
    transition: opacity 300ms ease, transform 300ms ease;
}

.udlc-card__actions:focus-within {
    opacity: 1;
    transform: translateY(0);
}

.udlc-card:hover .udlc-card__actions {
    opacity: 1;
    transform: translateY(0);
}

/* Bouton WooCommerce dans la card */
.udlc-card .button,
.udlc-card .added_to_cart,
.udlc-card__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 10px 12px;
    background: transparent;
    color: #ff9879;
    border: 1px solid #ff9879;
    border-radius: 9999px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 300ms ease, color 300ms ease, transform 150ms ease;
    text-decoration: none;
    white-space: nowrap;
}

.udlc-card .button:hover,
.udlc-card .added_to_cart:hover,
.udlc-card__btn:hover {
    background: #ff9879;
    color: #fff;
    transform: scale(1.03);
}

/* Compatibilité ancien markup .udlc-capsule */
.udlc-capsule { position: relative; text-align: center; }


/* ============================================================
   9. FICHE PRODUIT SINGLE – layout premium
============================================================ */

/* ── Breadcrumb ──────────────────────────────────────────────*/
.udlc-sp-breadcrumb {
    background: #fff;
    border-bottom: 1px solid #e6dccf;
    padding-top: 14px;
    padding-bottom: 14px;
    font-size: 0.8rem;
    color: #888888;
}

.udlc-sp-breadcrumb .udlc-container {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.udlc-sp-breadcrumb a {
    color: #888888;
    transition: color 300ms ease;
}

.udlc-sp-breadcrumb a:hover { color: #bfa054; }

.udlc-sp-breadcrumb span[aria-current] {
    color: #333333;
    font-weight: 500;
}

/* ── Wrapper page ────────────────────────────────────────────*/
.single-product .udlc-sp {
    background: #f4f3f2;
    padding: 60px 0;
}

.single-product .udlc-sp__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05), 0 16px 48px rgba(0,0,0,0.10);
    padding: 48px;
}

/* ── Galerie ─────────────────────────────────────────────────*/
.single-product .udlc-sp__gallery {
    display: grid;
    grid-template-columns: 1fr;   /* par défaut : image seule, pleine largeur */
    gap: 16px;
    position: sticky;
    top: 90px;
}

/* Avec vignettes : colonne 80px à gauche */
.single-product .udlc-sp__gallery.has-thumbs {
    grid-template-columns: 80px 1fr;
}

/* Vignettes verticales */
.single-product .udlc-sp__thumbs {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-height: 520px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #bfa054 #eeece9;
}

.single-product .udlc-sp__thumb {
    width: 72px;
    height: 72px;
    border-radius: 8px;
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    padding: 0;
    background: #f4f3f2;
    transition: border-color 300ms ease, transform 150ms ease;
    flex-shrink: 0;
}

.single-product .udlc-sp__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.single-product .udlc-sp__thumb:hover { transform: scale(1.04); border-color: #d4b27f; }
.single-product .udlc-sp__thumb.is-active { border-color: #bfa054; }

/* Zone image principale */
.single-product .udlc-sp__main-image {
    position: relative;
    border-radius: 12px;
    background: #f9f8f6;
}

/* Version sans vignettes : image prend toute la largeur */
.single-product .udlc-sp__main-image--full {
    grid-column: 1 / -1;
}

/* Badge promo */
.single-product .udlc-sp__badge {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 2;
    padding: 6px 14px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.single-product .udlc-sp__badge--sale { background: #e63946; color: #fff; }

/* Slides */
.single-product .udlc-sp__slides { position: relative; }

.single-product .udlc-sp__slide { display: none; }
.single-product .udlc-sp__slide.is-active { display: block; }

.single-product .udlc-sp__img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    object-position: center;
    padding: 16px;
    display: block;
    transition: opacity 250ms ease;
    cursor: crosshair;
}

/* ── Résumé ──────────────────────────────────────────────────*/
.single-product .udlc-sp__summary {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-top: 8px;
    padding-bottom: 8px;
    align-items: flex-start;
}

/* Badge catégorie */
.single-product .udlc-sp__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
}

.single-product .udlc-sp__cat-badge {
    display: inline-block;
    padding: 4px 14px;
    border: 1px solid #bfa054;
    border-radius: 9999px;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #bfa054;
    transition: background 300ms ease, color 300ms ease;
}

.single-product .udlc-sp__cat-badge:hover {
    background: #bfa054;
    color: #fff;
}

/* Titre */
.single-product .udlc-sp__title {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.02em;
    color: #1d2533;
    margin-bottom: 20px;
}

/* Séparateur doré */
.single-product .udlc-sp__divider {
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #bfa054, #d4b27f);
    border-radius: 2px;
    margin-bottom: 24px;
}

/* Prix */
.single-product .udlc-sp__price {
    margin-bottom: 16px;
}

.single-product .udlc-sp__price .price {
    font-family: 'Playfair Display', serif;
    font-size: 2.2rem;
    font-weight: 600;
    color: #bfa054;
    line-height: 1;
}

.single-product .udlc-sp__price .price del {
    font-size: 1.1rem;
    color: #aaa;
    font-weight: 400;
    margin-right: 8px;
}

.single-product .udlc-sp__price .price ins {
    text-decoration: none;
    color: #e63946;
}

/* Disponibilité */
.single-product .udlc-sp__stock {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.single-product .udlc-sp__stock-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.single-product .udlc-sp__stock--instock     { color: #2e7d32; }
.single-product .udlc-sp__stock--instock .udlc-sp__stock-dot { background: #2e7d32; box-shadow: 0 0 0 3px rgba(46,125,50,0.15); }
.single-product .udlc-sp__stock--onbackorder { color: #e65100; }
.single-product .udlc-sp__stock--onbackorder .udlc-sp__stock-dot { background: #e65100; box-shadow: 0 0 0 3px rgba(230,81,0,0.15); }
.single-product .udlc-sp__stock--outofstock  { color: #c62828; }
.single-product .udlc-sp__stock--outofstock .udlc-sp__stock-dot { background: #c62828; box-shadow: 0 0 0 3px rgba(198,40,40,0.15); }

/* Description courte */
.single-product .udlc-sp__excerpt {
    font-family: 'Outfit', sans-serif;
    font-size: 1.1rem;
    line-height: 1.85;
    color: #555;
    margin-bottom: 28px;
    padding-bottom: 28px;
    border-bottom: 1px solid #e6dccf;
}

/* ── Bouton panier : quantité + bouton sur une seule ligne ───*/
.single-product .udlc-sp__cart {
    margin-bottom: 24px;
}

.single-product .udlc-sp__cart form.cart {
    display: flex;
    align-items: stretch;
    gap: 12px;
}

.single-product .udlc-sp__cart .quantity {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    border: 1px solid #e6dccf;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
}

.single-product .udlc-sp__cart .qty {
    width: 56px;
    text-align: center;
    font-size: 1rem;
    font-weight: 600;
    background: #fff;
    padding: 0 8px;
    height: 52px;
    border: none;
    -moz-appearance: textfield;
}

.single-product .udlc-sp__cart .qty::-webkit-inner-spin-button,
.single-product .udlc-sp__cart .qty::-webkit-outer-spin-button {
    -webkit-appearance: none;
}

.single-product .udlc-sp__cart .single_add_to_cart_button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex: 1;
    height: 52px;
    padding: 0 32px;
    background: #bfa054;
    color: #fff;
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 700;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 300ms ease, transform 150ms ease, box-shadow 300ms ease;
}

.single-product .udlc-sp__cart .single_add_to_cart_button::before {
    content: '';
    display: inline-block;
    width: 18px;
    height: 18px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    flex-shrink: 0;
}

.single-product .udlc-sp__cart .single_add_to_cart_button:hover {
    background: #1d2533;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(191,160,84,0.35);
}

/* Bloc livraison */
.single-product .udlc-sp__delivery {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px 24px;
    background: #f9f8f6;
    border-radius: 10px;
    border: 1px solid #e6dccf;
    margin-bottom: 24px;
}

.single-product .udlc-sp__delivery-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.82rem;
    color: #555;
}

.single-product .udlc-sp__delivery-item svg {
    color: #bfa054;
    flex-shrink: 0;
}

/* Meta (SKU, cats) */
.single-product .udlc-sp__meta {
    font-size: 0.8rem;
    color: #888888;
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding-top: 16px;
    border-top: 1px solid #e6dccf;
}

.single-product .udlc-sp__meta strong { color: #555; }

/* Masquer les doublons WooCommerce */
.single-product .udlc-sp__meta .posted_in a,
.single-product .udlc-sp__meta .tagged_as a {
    color: #bfa054;
    transition: color 300ms ease;
}
.single-product .udlc-sp__meta .posted_in a:hover,
.single-product .udlc-sp__meta .tagged_as a:hover { color: #8c6e2f; }

/* ── Tabs description / avis ─────────────────────────────────*/
.udlc-sp__tabs-wrapper {
    background: #fff;
    padding-top: 56px;
    padding-bottom: 56px;
    margin-top: 0;
}

.udlc-sp__tabs-wrapper .woocommerce-tabs ul.tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid #e6dccf;
    margin-bottom: 36px;
    padding: 0;
}

.udlc-sp__tabs-wrapper .woocommerce-tabs ul.tabs li {
    margin: 0;
}

.udlc-sp__tabs-wrapper .woocommerce-tabs ul.tabs li a {
    display: block;
    padding: 14px 28px;
    font-family: 'Playfair Display', serif;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #888888;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: color 300ms ease, border-color 300ms ease;
}

.udlc-sp__tabs-wrapper .woocommerce-tabs ul.tabs li:hover a { color: #333333; }

.udlc-sp__tabs-wrapper .woocommerce-tabs ul.tabs li.active a {
    color: #1d2533;
    border-bottom-color: #bfa054;
    font-weight: 600;
}

.udlc-sp__tabs-wrapper .woocommerce-Tabs-panel {
    font-family: 'Outfit', sans-serif;
    font-size: 1.05rem;
    line-height: 1.85;
    color: #444;
    max-width: none;
}

/* Masquer les onglets nav et afficher les deux panels côte à côte */
.udlc-sp__tabs-wrapper .woocommerce-tabs ul.tabs {
    display: none !important;
}

.udlc-sp__tabs-wrapper .woocommerce-tabs {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 48px;
    align-items: start;
}

/* Forcer les deux panels à être visibles */
.udlc-sp__tabs-wrapper #tab-description,
.udlc-sp__tabs-wrapper #tab-additional_information {
    display: block !important;
    padding: 0;
    border: none;
    background: none;
}

/* Masquer les titres h2 générés automatiquement par WC */
.udlc-sp__tabs-wrapper #tab-description > h2:first-child,
.udlc-sp__tabs-wrapper #tab-additional_information > h2:first-child {
    display: none;
}

/* Titre de section au-dessus de chaque colonne */
.udlc-sp__tabs-wrapper #tab-description::before {
    content: 'Description';
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 1.3rem;
    color: #1d2533;
    font-weight: 400;
    margin-bottom: 24px;
    padding-bottom: 12px;
    border-bottom: 2px solid #e6dccf;
}

.udlc-sp__tabs-wrapper #tab-additional_information::before {
    content: 'Caractéristiques';
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 1.3rem;
    color: #1d2533;
    font-weight: 400;
    margin-bottom: 24px;
    padding-bottom: 12px;
    border-bottom: 2px solid #e6dccf;
}

@media (max-width: 768px) {
    .udlc-sp__tabs-wrapper .woocommerce-tabs {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}

.udlc-sp__tabs-wrapper .woocommerce-Tabs-panel h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.4rem;
    color: #1d2533;
    margin-bottom: 20px;
    font-weight: 400;
}

/* ── Tableau attributs produit ───────────────────────────────*/
.shop_attributes {
    width: 100%;
    border-collapse: collapse;
    font-family: 'Outfit', sans-serif;
    font-size: 0.9rem;
}

.shop_attributes tbody tr {
    display: grid;
    grid-template-columns: 180px 1fr;
    align-items: center;
    border-bottom: 1px solid #f0ede8;
    transition: background 200ms ease;
}

.shop_attributes tbody tr:first-child {
    border-top: 1px solid #f0ede8;
}

.shop_attributes tbody tr:hover {
    background: rgba(191,160,84,0.04);
}

.woocommerce-product-attributes-item__label {
    padding: 12px 16px 12px 0;
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #888;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Petite pastille dorée devant le label */
.woocommerce-product-attributes-item__label::before {
    content: '';
    display: block;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #bfa054;
    flex-shrink: 0;
}

.woocommerce-product-attributes-item__value {
    padding: 12px 0;
    color: #1d2533;
    font-size: 0.92rem;
}

.woocommerce-product-attributes-item__value p {
    margin: 0;
}

.woocommerce-product-attributes-item__value a {
    color: #1d2533;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color 200ms ease, border-color 200ms ease;
}

.woocommerce-product-attributes-item__value a:hover {
    color: #bfa054;
    border-bottom-color: rgba(191,160,84,0.4);
}

/* ── Produits similaires ──────────────────────────────────────*/
.udlc-sp__related {
    background: #f4f3f2;
    padding-top: 64px;
    padding-bottom: 64px;
}

.udlc-sp__related-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    font-weight: 400;
    color: #1d2533;
    margin-bottom: 36px;
    text-align: center;
    letter-spacing: 0.02em;
}

/* Dans la section "Vous aimerez aussi", le CTA est toujours visible */
.udlc-sp__related .udlc-card__actions {
    opacity: 1;
    transform: translateY(0);
}

.udlc-grid--4 {
    grid-template-columns: repeat(4, 1fr);
}

/* ── Responsive single product ───────────────────────────────*/
@media (max-width: 1024px) {
    .single-product .udlc-sp__inner {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 32px;
    }

    .single-product .udlc-sp__gallery {
        position: static;
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .single-product .udlc-sp__gallery.has-thumbs {
        grid-template-columns: 64px 1fr;
    }

    .single-product .udlc-sp__thumbs {
        max-height: 400px;
    }

    .udlc-grid--4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
    .single-product .udlc-sp__gallery {
        grid-template-columns: 1fr;
    }

    .single-product .udlc-sp__thumbs {
        flex-direction: row;
        max-height: none;
        overflow-x: auto;
        overflow-y: visible;
    }

    .single-product .udlc-sp__thumb {
        width: 60px;
        height: 60px;
    }

    .single-product .udlc-sp__title { font-size: 1.6rem; }

    .udlc-grid--4 { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   10. FOOTER INFO (bande)
============================================================ */

.udlc-footer-info {
    background: #1d2533;
    border-top: 1px solid rgba(191,160,84,0.2);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    padding-top: 28px;
    padding-bottom: 28px;
}

.udlc-footer-info .udlc-container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    padding-left: 32px;
    padding-right: 32px;
}

.udlc-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
    padding: 20px 24px;
    position: relative;
    transition: background 300ms ease;
}

/* Séparateurs verticaux entre blocs */
.udlc-block + .udlc-block::before {
    content: '';
    position: absolute;
    left: 0;
    top: 20%;
    height: 60%;
    width: 1px;
    background: rgba(191,160,84,0.15);
}

.udlc-block:hover { background: rgba(191,160,84,0.04); }

.udlc-block svg {
    color: #bfa054;
    stroke: #bfa054;
    fill: none;
    margin-bottom: 4px;
    transition: transform 300ms ease;
}

/* Les SVG fill solides (étoile, etc.) */
.udlc-block svg[fill="currentColor"] { fill: #bfa054; stroke: none; }

.udlc-block:hover svg { transform: translateY(-2px); }

.udlc-block a {
    color: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    width: 100%;
}

.udlc-title {
    font-family: 'Playfair Display', serif;
    font-size: 0.85rem;
    font-weight: 400;
    letter-spacing: 0.06em;
    color: #bfa054;
}

.udlc-subtitle {
    font-size: 0.78rem;
    color: rgba(244,243,242,0.5);
    line-height: 1.5;
}

.udlc-subtitle span { font-weight: 700; color: rgba(244,243,242,0.7); }

.udlc-payment img {
    margin-top: 6px;
    max-width: 90px;
    opacity: 0.6;
}

@media (max-width: 768px) {
    .udlc-footer-info .udlc-container {
        grid-template-columns: repeat(2, 1fr);
    }
    .udlc-block:nth-child(3)::before { display: none; }
}

@media (max-width: 480px) {
    .udlc-footer-info .udlc-container { grid-template-columns: 1fr; }
    .udlc-block + .udlc-block::before { display: none; }
    .udlc-block {
        border-bottom: 1px solid rgba(191,160,84,0.1);
        padding: 16px;
    }
}


/* ============================================================
   11. FOOTER PRINCIPAL – 4 colonnes
============================================================ */

.udlc-footer {
    background: #1d2533;
    color: #f4f3f2;
}

/* ── Top : 4 colonnes ────────────────────────────────────────*/
.udlc-footer__top {
    padding-top: 72px;
    padding-bottom: 56px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
}

.udlc-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
    gap: 48px;
}

/* Colonne générique */
.udlc-footer__col { display: flex; flex-direction: column; gap: 0; }

.udlc-footer__col-title {
    font-family: 'Playfair Display', serif;
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #bfa054;
    margin-bottom: 24px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(191,160,84,0.25);
}

/* ── Col 1 : Brand ───────────────────────────────────────────*/
.udlc-footer__col--brand { gap: 24px; }

.udlc-footer__logo img  { max-height: 54px; width: auto; }

.udlc-footer__desc {
    font-size: 0.82rem;
    line-height: 1.75;
    color: rgba(244,243,242,0.55);
}

/* Réseaux sociaux */
.udlc-footer__social {
    display: flex;
    gap: 10px;
    margin-top: 4px;
}

.udlc-footer__social-link {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(191,160,84,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(244,243,242,0.6);
    transition: background 300ms ease, border-color 300ms ease, color 300ms ease, transform 150ms ease;
}

.udlc-footer__social-link:hover {
    background: #bfa054;
    border-color: #bfa054;
    color: #fff;
    transform: translateY(-2px);
}

/* ── Col 2 : Navigation ──────────────────────────────────────*/
.udlc-footer__links {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.udlc-footer__links li a {
    font-size: 0.85rem;
    color: rgba(244,243,242,0.6);
    display: flex;
    align-items: center;
    gap: 8px;
    transition: color 300ms ease, gap 200ms ease;
}

.udlc-footer__links li a::before {
    content: '';
    display: inline-block;
    width: 14px;
    height: 1px;
    background: #bfa054;
    flex-shrink: 0;
    opacity: 0.5;
    transition: width 200ms ease, opacity 200ms ease;
}

.udlc-footer__links li a:hover {
    color: #bfa054;
    gap: 12px;
}

.udlc-footer__links li a:hover::before {
    width: 20px;
    opacity: 1;
}

/* ── Col 3 : Coordonnées ─────────────────────────────────────*/
.udlc-footer__address {
    font-style: normal;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.udlc-footer__contact-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.84rem;
    color: rgba(244,243,242,0.6);
    line-height: 1.5;
}

.udlc-footer__contact-item svg {
    color: #bfa054;
    flex-shrink: 0;
    margin-top: 2px;
}

.udlc-footer__contact-item a {
    color: rgba(244,243,242,0.6);
    transition: color 300ms ease;
}

.udlc-footer__contact-item a:hover { color: #bfa054; }

/* ── Col 4 : Newsletter ──────────────────────────────────────*/
.udlc-footer__newsletter-desc {
    font-size: 0.82rem;
    color: rgba(244,243,242,0.55);
    line-height: 1.65;
    margin-bottom: 16px;
}

.udlc-footer__newsletter-form { display: flex; flex-direction: column; gap: 10px; }

.udlc-footer__newsletter-field {
    display: flex;
    border: 1px solid rgba(191,160,84,0.3);
    border-radius: 6px;
    overflow: hidden;
    transition: border-color 300ms ease;
}

.udlc-footer__newsletter-field:focus-within {
    border-color: #bfa054;
    box-shadow: 0 0 0 3px rgba(191,160,84,0.1);
}

.udlc-footer__newsletter-field input {
    flex: 1;
    background: rgba(255,255,255,0.05);
    color: #f4f3f2;
    font-size: 0.82rem;
    padding: 11px 14px;
    border: none;
    outline: none;
}

.udlc-footer__newsletter-field input::placeholder { color: rgba(244,243,242,0.3); }

.udlc-footer__newsletter-field button {
    width: 44px;
    background: #bfa054;
    color: #fff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 300ms ease;
}

.udlc-footer__newsletter-field button:hover { background: #8c6e2f; }

.udlc-footer__newsletter-consent {
    font-size: 0.72rem;
    color: rgba(244,243,242,0.3);
    line-height: 1.5;
}

/* Moyens de paiement */
.udlc-footer__payment {
    margin-top: 28px;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.07);
}

.udlc-footer__payment-label {
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(244,243,242,0.35);
    margin-bottom: 10px;
}

.udlc-footer__payment-icons {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.udlc-footer__pay-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 10px;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 4px;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: rgba(244,243,242,0.5);
    background: rgba(255,255,255,0.04);
}

/* ── Bottom : copyright + légaux ─────────────────────────────*/
.udlc-footer__bottom {
    padding-top: 20px;
    padding-bottom: 20px;
}

.udlc-footer__bottom .udlc-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

.udlc-footer__copy {
    font-size: 0.78rem;
    color: rgba(244,243,242,0.3);
}

.udlc-footer__copy a {
    color: rgba(244,243,242,0.4);
    transition: color 300ms ease;
}

.udlc-footer__copy a:hover { color: #bfa054; }

.udlc-footer__legal {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.udlc-footer__legal a {
    font-size: 0.78rem;
    color: rgba(244,243,242,0.3);
    transition: color 300ms ease;
}

.udlc-footer__legal a:hover { color: #bfa054; }

/* ── Responsive footer ───────────────────────────────────────*/
@media (max-width: 1024px) {
    .udlc-footer__grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}

@media (max-width: 640px) {
    .udlc-footer__grid { grid-template-columns: 1fr; gap: 36px; }
    .udlc-footer__top  { padding-top: 48px;
    padding-bottom: 40px; }

    .udlc-footer__bottom .udlc-container { flex-direction: column; text-align: center; }
    .udlc-footer__legal { justify-content: center; }
}


/* ============================================================
   12. PAGES WOOCOMMERCE – PANIER & CHECKOUT
============================================================ */

/* Ancien wrapper rétrocompat */
.udlc-account-container {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    padding-right: 32px;
    padding-top: 96px;
    padding-bottom: 96px;
}


/* ────────────────────────────────────────────────────────────
   12a. PAGE PANIER
──────────────────────────────────────────────────────────── */

.udlc-cart-page {
    background: #f4f3f2;
    min-height: 80vh;
}

/* Hero */
.udlc-cart-page__hero {
    background: #1d2533;
    border-bottom: 1px solid rgba(191,160,84,0.2);
    padding-top: 40px;
    padding-bottom: 36px;
}

.udlc-cart-page__title {
    font-family: 'Achemost', serif;
    font-size: 2.2rem;
    color: #f4f3f2;
    margin-bottom: 6px;
}

.udlc-cart-page__subtitle {
    font-size: 0.82rem;
    color: rgba(244,243,242,0.45);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* Body */
.udlc-cart-page__body {
    padding-top: 56px;
    padding-bottom: 80px;
}

/* Tableau panier */
.udlc-cart-page .woocommerce-cart-form table.cart {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.07);
}

.udlc-cart-page .woocommerce-cart-form table.cart thead th {
    padding: 14px 20px;
    text-align: left;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #888;
    background: #faf9f7;
    border-bottom: 2px solid #e6dccf;
}

.udlc-cart-page .woocommerce-cart-form table.cart td {
    padding: 20px;
    border-bottom: 1px solid #f0ede8;
    vertical-align: middle;
    color: #444;
    font-size: 0.9rem;
}

.udlc-cart-page .woocommerce-cart-form table.cart tr:last-child td {
    border-bottom: none;
}

/* Image produit dans le panier */
.udlc-cart-page .woocommerce-cart-form table.cart td.product-thumbnail img {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid #e6dccf;
}

/* Nom produit */
.udlc-cart-page .woocommerce-cart-form table.cart td.product-name a {
    font-family: 'Playfair Display', serif;
    font-size: 1rem;
    color: #1d2533;
    transition: color 300ms ease;
}

.udlc-cart-page .woocommerce-cart-form table.cart td.product-name a:hover {
    color: #bfa054;
}

/* Prix */
.udlc-cart-page .woocommerce-cart-form table.cart td.product-price,
.udlc-cart-page .woocommerce-cart-form table.cart td.product-subtotal {
    font-weight: 600;
    color: #bfa054;
    font-size: 1rem;
}

/* Quantite */
.udlc-cart-page .woocommerce-cart-form table.cart td.product-quantity input {
    width: 60px;
    text-align: center;
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 0.9rem;
}

/* Bouton supprimer */
.udlc-cart-page .woocommerce-cart-form table.cart td.product-remove a.remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #f0ede8;
    color: #999;
    font-size: 1.1rem;
    line-height: 1;
    transition: background 200ms ease, color 200ms ease;
    text-decoration: none;
}

.udlc-cart-page .woocommerce-cart-form table.cart td.product-remove a.remove:hover {
    background: #e63946;
    color: #fff;
}

/* Bouton MAJ panier */
.udlc-cart-page .woocommerce-cart-form .actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-top: 20px;
}

.udlc-cart-page .woocommerce-cart-form .coupon {
    display: flex;
    gap: 10px;
    align-items: center;
}

.udlc-cart-page .woocommerce-cart-form .coupon input {
    padding: 10px 14px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 0.875rem;
    background: #fff;
}

.udlc-cart-page .woocommerce-cart-form .coupon input:focus {
    border-color: #bfa054;
    outline: none;
    box-shadow: 0 0 0 3px rgba(191,160,84,0.1);
}

/* Totaux panier */
.udlc-cart-page .cart-collaterals {
    display: flex;
    justify-content: flex-end;
    margin-top: 32px;
}

.udlc-cart-page .cart_totals {
    width: 100%;
    max-width: 420px;
    background: #fff;
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.07);
}

.udlc-cart-page .cart_totals h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.3rem;
    font-weight: 400;
    color: #1d2533;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid #e6dccf;
}

.udlc-cart-page .cart_totals table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 24px;
}

.udlc-cart-page .cart_totals table th,
.udlc-cart-page .cart_totals table td {
    padding: 10px 0;
    border-bottom: 1px solid #f0ede8;
    font-size: 0.875rem;
}

.udlc-cart-page .cart_totals table th {
    color: #555;
    font-weight: 400;
    text-align: left;
    width: 40%;
}

.udlc-cart-page .cart_totals table tr.order-total th,
.udlc-cart-page .cart_totals table tr.order-total td {
    font-size: 1.1rem;
    font-weight: 700;
    color: #1d2533;
    border-bottom: none;
    padding-top: 16px;
}

.udlc-cart-page .cart_totals table tr.order-total td .amount {
    color: #bfa054;
}

/* Bouton commande — classique */
.udlc-cart-page .wc-proceed-to-checkout .checkout-button,
.udlc-cart-page .button,
.udlc-cart-page input[type="submit"],
/* Bouton commande — WooCommerce Blocks */
.wc-block-cart__submit-button,
.wc-block-cart__submit-button.contained {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 16px !important;
    background: #bfa054 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    cursor: pointer;
    transition: background 300ms ease, transform 150ms ease, box-shadow 300ms ease;
    text-decoration: none;
}

.udlc-cart-page .wc-proceed-to-checkout .checkout-button:hover,
.udlc-cart-page .button:hover,
.udlc-cart-page input[type="submit"]:hover,
.wc-block-cart__submit-button:hover,
.wc-block-cart__submit-button.contained:hover {
    background: #1d2533 !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(191,160,84,0.3);
    color: #fff !important;
}

/* Responsive panier */
@media (max-width: 768px) {
    .udlc-cart-page .woocommerce-cart-form table.cart thead { display: none; }
    .udlc-cart-page .woocommerce-cart-form table.cart td {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 12px 16px;
        border-bottom: none;
    }
    .udlc-cart-page .woocommerce-cart-form table.cart tr { border-bottom: 1px solid #f0ede8; }
    .udlc-cart-page .cart-collaterals { justify-content: stretch; }
    .udlc-cart-page .cart_totals { max-width: 100%; }
}


/* ────────────────────────────────────────────────────────────
   12b-checkout. PAGE COMMANDER (Checkout)
──────────────────────────────────────────────────────────── */

.udlc-checkout-page {
    background: #f4f3f2;
    min-height: 80vh;
}

/* Hero + étapes */
.udlc-checkout-page__hero {
    background: #1d2533;
    border-bottom: 1px solid rgba(191,160,84,0.2);
    padding-top: 36px;
    padding-bottom: 36px;
}

.udlc-checkout-page__title {
    font-family: 'Achemost', serif;
    font-size: 2rem;
    color: #f4f3f2;
    margin-bottom: 20px;
}

.udlc-checkout-page__steps {
    display: flex;
    align-items: center;
    gap: 0;
}

.udlc-checkout-step {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.75rem;
    font-weight: 400;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(244,243,242,0.35);
}

.udlc-checkout-step--active {
    color: #bfa054;
    font-weight: 600;
}

.udlc-checkout-step--done {
    color: rgba(244,243,242,0.5);
}

.udlc-checkout-step__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    font-size: 0.7rem;
    font-weight: 700;
    background: rgba(244,243,242,0.1);
    color: rgba(244,243,242,0.35);
}

.udlc-checkout-step--active .udlc-checkout-step__num {
    background: #bfa054;
    color: #fff;
}

.udlc-checkout-step--done .udlc-checkout-step__num {
    background: rgba(191,160,84,0.2);
    color: #bfa054;
}

.udlc-checkout-step__sep {
    display: block;
    width: 32px;
    height: 1px;
    background: rgba(191,160,84,0.2);
    margin-left: 10px;
    margin-right: 10px;
}

/* Body checkout */
.udlc-checkout-page__body {
    padding-top: 56px;
    padding-bottom: 80px;
}

/* Layout 2 colonnes */
.udlc-checkout-page .woocommerce-checkout {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 40px;
    align-items: start;
}

/* Colonne gauche : formulaire */
.udlc-checkout-page .woocommerce-billing-fields,
.udlc-checkout-page .woocommerce-shipping-fields,
.udlc-checkout-page .woocommerce-additional-fields {
    background: #fff;
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.07);
    margin-bottom: 24px;
}

.udlc-checkout-page .woocommerce-billing-fields h3,
.udlc-checkout-page .woocommerce-shipping-fields h3,
.udlc-checkout-page .woocommerce-additional-fields h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.2rem;
    font-weight: 400;
    color: #1d2533;
    margin-bottom: 24px;
    padding-bottom: 14px;
    border-bottom: 1px solid #e6dccf;
}

/* Grille champs billing */
.udlc-checkout-page .woocommerce-checkout #billing_first_name_field,
.udlc-checkout-page .woocommerce-checkout #billing_last_name_field,
.udlc-checkout-page .woocommerce-checkout #shipping_first_name_field,
.udlc-checkout-page .woocommerce-checkout #shipping_last_name_field {
    width: 48%;
    display: inline-block;
}

.udlc-checkout-page .woocommerce-checkout .woocommerce-input-wrapper input,
.udlc-checkout-page .woocommerce-checkout .woocommerce-input-wrapper select,
.udlc-checkout-page .woocommerce-checkout .woocommerce-input-wrapper textarea {
    width: 100%;
    padding: 12px 14px;
    font-size: 0.9rem;
    border: 1px solid #ddd;
    border-radius: 8px;
    background: #fafafa;
    color: #333;
    transition: border-color 300ms ease, box-shadow 300ms ease;
}

.udlc-checkout-page .woocommerce-checkout .woocommerce-input-wrapper input:focus,
.udlc-checkout-page .woocommerce-checkout .woocommerce-input-wrapper select:focus,
.udlc-checkout-page .woocommerce-checkout .woocommerce-input-wrapper textarea:focus {
    border-color: #bfa054;
    box-shadow: 0 0 0 3px rgba(191,160,84,0.1);
    background: #fff;
    outline: none;
}

.udlc-checkout-page .woocommerce-checkout label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #555;
    margin-bottom: 6px;
}

/* Colonne droite : récap commande */
.udlc-checkout-page #order_review_heading {
    font-family: 'Playfair Display', serif;
    font-size: 1.2rem;
    font-weight: 400;
    color: #1d2533;
    margin-bottom: 20px;
}

.udlc-checkout-page #order_review {
    background: #fff;
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.07);
    position: sticky;
    top: 90px;
}

.udlc-checkout-page .woocommerce-checkout-review-order-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
    margin-bottom: 24px;
}

.udlc-checkout-page .woocommerce-checkout-review-order-table th {
    padding: 10px 0;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #888;
    border-bottom: 2px solid #e6dccf;
    text-align: left;
}

.udlc-checkout-page .woocommerce-checkout-review-order-table td {
    padding: 12px 0;
    border-bottom: 1px solid #f0ede8;
    color: #444;
    vertical-align: middle;
}

.udlc-checkout-page .woocommerce-checkout-review-order-table .order-total th,
.udlc-checkout-page .woocommerce-checkout-review-order-table .order-total td {
    font-weight: 700;
    font-size: 1rem;
    color: #1d2533;
    border-bottom: none;
    padding-top: 16px;
}

.udlc-checkout-page .woocommerce-checkout-review-order-table .order-total td .amount {
    color: #bfa054;
    font-size: 1.2rem;
}

/* Bouton passer commande */
.udlc-checkout-page #place_order {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 18px;
    background: #bfa054;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
    margin-top: 24px;
    transition: background 300ms ease, transform 150ms ease, box-shadow 300ms ease;
}

.udlc-checkout-page #place_order:hover {
    background: #1d2533;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(191,160,84,0.3);
}

/* Méthodes de paiement */
.udlc-checkout-page .woocommerce-checkout #payment {
    background: #fff;
    border-radius: 12px;
    padding: 28px 32px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    margin-top: 24px;
}

.udlc-checkout-page .woocommerce-checkout #payment .wc_payment_methods {
    list-style: none;
    margin-bottom: 20px;
}

.udlc-checkout-page .woocommerce-checkout #payment .wc_payment_methods li {
    padding: 12px 0;
    border-bottom: 1px solid #f0ede8;
}

.udlc-checkout-page .woocommerce-checkout #payment .wc_payment_methods li label {
    font-size: 0.9rem;
    color: #333;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
}

/* Notices WooCommerce */
.udlc-checkout-page .woocommerce-info,
.udlc-checkout-page .woocommerce-message,
.udlc-checkout-page .woocommerce-error {
    padding: 14px 18px;
    border-radius: 8px;
    font-size: 0.875rem;
    margin-bottom: 20px;
    border-left: 3px solid #bfa054;
    background: rgba(191,160,84,0.06);
    color: #555;
}

/* Bouton "Retour au panier" — WooCommerce Blocks */
.wc-block-components-checkout-return-to-cart-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    background: transparent;
    color: #bfa054;
    border: 2px solid #bfa054;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    cursor: pointer;
    transition: background 250ms ease, color 250ms ease;
}

.wc-block-components-checkout-return-to-cart-button:hover {
    background: #bfa054;
    color: #fff;
    text-decoration: none;
}

.wc-block-components-checkout-return-to-cart-button svg {
    fill: currentColor;
    flex-shrink: 0;
}

/* Bouton "Commander" — WooCommerce Blocks */
.wc-block-components-checkout-place-order-button,
.wc-block-components-checkout-place-order-button.contained {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    padding: 16px 32px !important;
    background: #bfa054 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    cursor: pointer;
    transition: background 300ms ease, transform 150ms ease, box-shadow 300ms ease;
    text-decoration: none;
}

.wc-block-components-checkout-place-order-button:hover,
.wc-block-components-checkout-place-order-button.contained:hover {
    background: #1d2533 !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(191,160,84,0.3);
}

/* Ligne d'actions */
.wc-block-checkout__actions_row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 24px;
    flex-wrap: wrap;
}

/* ── Logos transporteurs — méthodes de livraison ── */

/* Layout commun : logo | nom+prix répartis */
label[for*="lpc_nosign"] .wc-block-components-radio-control__option-layout,
label[for*="lpc_sign"] .wc-block-components-radio-control__option-layout,
label[for*="flexible_shipping_single"] .wc-block-components-radio-control__option-layout {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 14px;
    width: 100%;
}

/* Le label-group prend tout l'espace et place nom + prix en space-between */
label[for*="lpc_nosign"] .wc-block-components-radio-control__label-group,
label[for*="lpc_sign"] .wc-block-components-radio-control__label-group,
label[for*="flexible_shipping_single"] .wc-block-components-radio-control__label-group {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    flex: 1;
}

/* Logo Colissimo */
label[for*="lpc_nosign"] .wc-block-components-radio-control__option-layout::before,
label[for*="lpc_sign"] .wc-block-components-radio-control__option-layout::before {
    content: '';
    display: block;
    width: 48px;
    height: 48px;
    background-image: var(--logo-colissimo);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    flex-shrink: 0;
    mix-blend-mode: multiply; /* efface le fond noir */
}

/* Logo La Poste (Lettre suivie via Flexible Shipping) */
label[for*="flexible_shipping_single"] .wc-block-components-radio-control__option-layout::before {
    content: '';
    display: block;
    width: 40px;
    height: 40px;
    background-image: var(--logo-la-poste);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    flex-shrink: 0;
}

/* Masquer le doublon de description injecté par Flexible Shipping */
label[for*="flexible_shipping_single"] .wc-block-components-radio-control__description-group {
    display: none;
}


/* Responsive checkout */
@media (max-width: 900px) {
    .udlc-checkout-page .woocommerce-checkout {
        grid-template-columns: 1fr;
    }

    .udlc-checkout-page #order_review {
        position: static;
    }
}

@media (max-width: 600px) {
    .udlc-checkout-page__title { font-size: 1.6rem; }
    .udlc-checkout-page__steps { flex-wrap: wrap; gap: 8px; }
    .udlc-checkout-step__sep { display: none; }
}


/* ============================================================
   12b. PAGE MON COMPTE
============================================================ */

/* ── Hero ────────────────────────────────────────────────────*/
.udlc-account-page {
    background: #f4f3f2;
    min-height: 80vh;
}

.udlc-account-hero {
    background: #1d2533;
    border-bottom: 1px solid rgba(191,160,84,0.2);
    padding-top: 48px;
    padding-bottom: 40px;
}

.udlc-account-hero .udlc-container {
    display: flex;
    align-items: center;
    gap: 24px;
}

.udlc-account-hero__avatar { flex-shrink: 0; }

.udlc-account-hero__img {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: 2px solid rgba(191,160,84,0.4);
    object-fit: cover;
    display: block;
}

.udlc-account-hero__info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.udlc-account-hero__label {
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(244,243,242,0.45);
}

.udlc-account-hero__name {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    font-weight: 400;
    color: #f4f3f2;
    line-height: 1.2;
}

.udlc-account-hero__email {
    font-size: 0.82rem;
    color: rgba(244,243,242,0.45);
    margin-top: 2px;
}

.udlc-account-hero__title {
    font-family: 'Achemost', serif;
    font-size: 2.2rem;
    color: #f4f3f2;
}

/* ── Body ────────────────────────────────────────────────────*/
.udlc-account-body {
    padding-top: 56px;
    padding-bottom: 80px;
}

/* ── Navigation WooCommerce (onglets) ────────────────────────*/
.udlc-account-page .woocommerce-MyAccount-navigation {
    width: 240px;
    flex-shrink: 0;
}

.udlc-account-page .woocommerce-MyAccount-navigation ul {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.udlc-account-page .woocommerce-MyAccount-navigation ul li a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 0.85rem;
    color: #555;
    transition: background 200ms ease, color 200ms ease;
    text-decoration: none;
}

.udlc-account-page .woocommerce-MyAccount-navigation ul li a::before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 14px;
    background: transparent;
    border-radius: 2px;
    flex-shrink: 0;
    transition: background 200ms ease;
}

.udlc-account-page .woocommerce-MyAccount-navigation ul li a:hover {
    background: #fff;
    color: #1d2533;
}

.udlc-account-page .woocommerce-MyAccount-navigation ul li.is-active a,
.udlc-account-page .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--active a {
    background: #fff;
    color: #1d2533;
    font-weight: 600;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.udlc-account-page .woocommerce-MyAccount-navigation ul li.is-active a::before,
.udlc-account-page .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--active a::before {
    background: #bfa054;
}

/* ── Layout nav + contenu ────────────────────────────────────*/
.udlc-account-page .woocommerce {
    display: flex;
    align-items: flex-start;
    gap: 40px;
}

.udlc-account-page .woocommerce-MyAccount-content {
    flex: 1;
    min-width: 0;
    background: #fff;
    border-radius: 12px;
    padding: 36px 40px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05), 0 8px 24px rgba(0,0,0,0.07);
}

/* ── Titres dans le contenu ──────────────────────────────────*/
.udlc-account-page .woocommerce-MyAccount-content h2,
.udlc-account-page .woocommerce-MyAccount-content h3 {
    font-family: 'Playfair Display', serif;
    font-weight: 400;
    color: #1d2533;
    margin-bottom: 20px;
}

.udlc-account-page .woocommerce-MyAccount-content h2 { font-size: 1.5rem; }
.udlc-account-page .woocommerce-MyAccount-content h3 { font-size: 1.15rem; }

/* ── Tableaux de commandes ───────────────────────────────────*/
.udlc-account-page .woocommerce-orders-table,
.udlc-account-page .woocommerce-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.udlc-account-page .woocommerce-orders-table th,
.udlc-account-page .woocommerce-table th {
    text-align: left;
    padding: 12px 16px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #888;
    border-bottom: 2px solid #e6dccf;
    background: #faf9f7;
}

.udlc-account-page .woocommerce-orders-table td,
.udlc-account-page .woocommerce-table td {
    padding: 14px 16px;
    border-bottom: 1px solid #f0ede8;
    color: #444;
    vertical-align: middle;
}

.udlc-account-page .woocommerce-orders-table tr:last-child td,
.udlc-account-page .woocommerce-table tr:last-child td {
    border-bottom: none;
}

.udlc-account-page .woocommerce-orders-table tr:hover td {
    background: #faf9f7;
}

/* Statut commande */
.udlc-account-page .woocommerce-orders-table .woocommerce-orders-table__cell-order-status mark {
    background: transparent;
    font-weight: 600;
    font-size: 0.75rem;
    padding: 3px 10px;
    border-radius: 9999px;
    display: inline-block;
}

.udlc-account-page mark.processing { background: rgba(59,130,246,0.1); color: #1d4ed8; }
.udlc-account-page mark.completed  { background: rgba(46,125,50,0.1);  color: #2e7d32; }
.udlc-account-page mark.cancelled  { background: rgba(198,40,40,0.1);  color: #c62828; }
.udlc-account-page mark.on-hold    { background: rgba(230,81,0,0.1);   color: #e65100; }
.udlc-account-page mark.pending    { background: rgba(88,88,88,0.1);   color: #555; }

/* ── Boutons WooCommerce ─────────────────────────────────────*/
.udlc-account-page .button,
.udlc-account-page .woocommerce-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    background: #bfa054;
    color: #fff;
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    transition: background 300ms ease, transform 150ms ease;
    text-decoration: none;
}

.udlc-account-page .button:hover,
.udlc-account-page .woocommerce-button:hover {
    background: #1d2533;
    color: #fff;
    transform: translateY(-1px);
}

/* Bouton secondaire */
.udlc-account-page .button.alt {
    background: transparent;
    border: 1px solid #bfa054;
    color: #bfa054;
}

.udlc-account-page .button.alt:hover {
    background: #bfa054;
    color: #fff;
}

/* ── Formulaires (adresses, infos perso) ─────────────────────*/
.udlc-account-page .woocommerce-address-fields input,
.udlc-account-page .woocommerce-EditAccountForm input,
.udlc-account-page .woocommerce-address-fields select,
.udlc-account-page .woocommerce-EditAccountForm select,
.udlc-account-page .woocommerce-address-fields textarea,
.udlc-account-page .woocommerce-EditAccountForm textarea {
    width: 100%;
    padding: 12px 14px;
    font-size: 0.9rem;
    border: 1px solid #ddd;
    border-radius: 8px;
    background: #fafafa;
    color: #333;
    transition: border-color 300ms ease, box-shadow 300ms ease;
}

.udlc-account-page .woocommerce-address-fields input:focus,
.udlc-account-page .woocommerce-EditAccountForm input:focus,
.udlc-account-page .woocommerce-address-fields select:focus,
.udlc-account-page .woocommerce-EditAccountForm select:focus {
    border-color: #bfa054;
    box-shadow: 0 0 0 3px rgba(191,160,84,0.1);
    background: #fff;
    outline: none;
}

.udlc-account-page .woocommerce-address-fields label,
.udlc-account-page .woocommerce-EditAccountForm label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #555;
    margin-bottom: 6px;
}

/* Grille 2 colonnes pour les formulaires d'adresse */
.udlc-account-page .woocommerce-address-fields .woocommerce-address-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.udlc-account-page .woocommerce-address-fields .form-row-wide {
    grid-column: 1 / -1;
}

/* ── Formulaire de connexion ─────────────────────────────────*/
.udlc-account-page .woocommerce-form-login,
.udlc-account-page .woocommerce-form-register {
    background: #fff;
    border-radius: 12px;
    padding: 40px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    max-width: 480px;
}

.udlc-account-page .u-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    align-items: start;
}

.udlc-account-page .woocommerce-form-login h2,
.udlc-account-page .woocommerce-form-register h2 {
    font-family: 'Playfair Display', serif;
    font-size: 1.5rem;
    font-weight: 400;
    color: #1d2533;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid #e6dccf;
}

/* ── Messages / notices ──────────────────────────────────────*/
.udlc-account-page .woocommerce-message,
.udlc-account-page .woocommerce-error,
.udlc-account-page .woocommerce-info {
    padding: 14px 18px;
    border-radius: 8px;
    font-size: 0.875rem;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.udlc-account-page .woocommerce-message { background: rgba(46,125,50,0.08);  color: #2e7d32; border-left: 3px solid #2e7d32; }
.udlc-account-page .woocommerce-error   { background: rgba(198,40,40,0.08);  color: #c62828; border-left: 3px solid #c62828; }
.udlc-account-page .woocommerce-info    { background: rgba(191,160,84,0.08); color: #8c6e2f; border-left: 3px solid #bfa054; }

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

    .udlc-account-page .woocommerce {
        flex-direction: column;
        gap: 24px;
    }

    .udlc-account-page .woocommerce-MyAccount-navigation {
        width: 100%;
    }

    .udlc-account-page .woocommerce-MyAccount-navigation ul {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 6px;
    }

    .udlc-account-page .woocommerce-MyAccount-navigation ul li a {
        padding: 8px 14px;
        font-size: 0.78rem;
        border: 1px solid #e6dccf;
    }

    .udlc-account-page .woocommerce-MyAccount-navigation ul li a::before {
        display: none;
    }

    .udlc-account-page .woocommerce-MyAccount-content {
        padding: 24px 20px;
    }

    .udlc-account-page .u-columns {
        grid-template-columns: 1fr;
    }

    .udlc-account-page .woocommerce-address-fields .woocommerce-address-fields__field-wrapper {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .udlc-account-hero .udlc-container {
        flex-direction: column;
        text-align: center;
    }
}


/* ============================================================
   13. PAGE À PROPOS
============================================================ */

/* ── Hero ──────────────────────────────────────────────────── */
.ap-hero {
    position: relative;
    min-height: 60vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.ap-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.05);
    transition: transform 8s ease;
}

.ap-hero:hover .ap-hero__bg { transform: scale(1); }

.ap-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(29,37,51,0.82) 0%, rgba(29,37,51,0.5) 100%);
}

.ap-hero__content {
    position: relative;
    z-index: 2;
    padding-top: 120px;
    padding-bottom: 80px;
    text-align: center;
}

.ap-hero__eyebrow {
    display: inline-block;
    font-family: 'Outfit', sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #bfa054;
    border: 1px solid rgba(191,160,84,0.4);
    padding: 6px 18px;
    border-radius: 999px;
    margin-bottom: 24px;
}

.ap-hero__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.4rem, 6vw, 4.5rem);
    color: #f4f3f2;
    font-weight: 400;
    line-height: 1.15;
    margin-bottom: 16px;
}

.ap-hero__subtitle {
    font-family: 'Outfit', sans-serif;
    font-size: 1.15rem;
    color: rgba(244,243,242,0.7);
    font-style: italic;
    letter-spacing: 0.04em;
}

.ap-hero__scroll {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}
.ap-hero__scroll span {
    display: block;
    width: 1px;
    height: 48px;
    background: linear-gradient(to bottom, rgba(191,160,84,0.8), transparent);
    margin: 0 auto;
    animation: ap-scroll-line 2s ease infinite;
}
@keyframes ap-scroll-line {
    0%   { transform: scaleY(0); transform-origin: top; }
    50%  { transform: scaleY(1); transform-origin: top; }
    51%  { transform: scaleY(1); transform-origin: bottom; }
    100% { transform: scaleY(0); transform-origin: bottom; }
}

/* ── Blocs alternés image / texte ──────────────────────────── */
.ap-bloc {
    padding-top: 96px;
    padding-bottom: 96px;
    background: #fff;
}

.ap-bloc:nth-child(even) {
    background: #f9f8f6;
}

.ap-bloc__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.ap-bloc--reverse .ap-bloc__inner {
    direction: rtl;
}
.ap-bloc--reverse .ap-bloc__inner > * {
    direction: ltr;
}

/* Image */
.ap-bloc__media {
    position: relative;
}

.ap-bloc__img-wrapper {
    border-radius: 16px;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    box-shadow: 0 24px 64px rgba(0,0,0,0.12);
}

.ap-bloc__img-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 600ms ease;
}

.ap-bloc__media:hover .ap-bloc__img-wrapper img {
    transform: scale(1.04);
}

/* Numéro décoratif */
.ap-bloc__num {
    position: absolute;
    bottom: -24px;
    right: -24px;
    font-family: 'Playfair Display', serif;
    font-size: 7rem;
    font-weight: 700;
    line-height: 1;
    color: rgba(191,160,84,0.1);
    pointer-events: none;
    user-select: none;
}

/* Contenu texte */
.ap-bloc__content {
    padding: 16px 0;
}

.ap-bloc__tag {
    display: inline-block;
    font-family: 'Outfit', sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #bfa054;
    margin-bottom: 16px;
}

.ap-bloc__divider {
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #bfa054, #d4b27f);
    margin-bottom: 24px;
    border-radius: 2px;
}

.ap-bloc__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 400;
    color: #1d2533;
    line-height: 1.3;
    margin-bottom: 24px;
}

.ap-bloc__text {
    font-family: 'Outfit', sans-serif;
    font-size: 1.05rem;
    line-height: 1.85;
    color: #555;
    margin-bottom: 16px;
}

.ap-bloc__text--light {
    color: #888;
    font-size: 0.97rem;
}

/* ── Section valeurs ────────────────────────────────────────── */
.ap-values {
    background: #1d2533;
    padding-top: 96px;
    padding-bottom: 96px;
}

.ap-values__header {
    text-align: center;
    margin-bottom: 64px;
}

.ap-values__title {
    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    color: #f4f3f2;
    font-weight: 400;
    margin-bottom: 20px;
}

.ap-values__divider {
    width: 56px;
    height: 2px;
    background: linear-gradient(90deg, transparent, #bfa054, transparent);
    margin: 0 auto;
}

.ap-values__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
}

.ap-value {
    text-align: center;
    padding: 40px 24px;
    border-radius: 12px;
    border: 1px solid rgba(191,160,84,0.15);
    background: rgba(255,255,255,0.03);
    transition: border-color 300ms ease, background 300ms ease, transform 300ms ease;
}

.ap-value:hover {
    border-color: rgba(191,160,84,0.4);
    background: rgba(191,160,84,0.06);
    transform: translateY(-4px);
}

.ap-value__icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(191,160,84,0.12);
    border: 1px solid rgba(191,160,84,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    color: #bfa054;
}

.ap-value__title {
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
    color: #f4f3f2;
    font-weight: 400;
    margin-bottom: 12px;
}

.ap-value__text {
    font-family: 'Outfit', sans-serif;
    font-size: 0.88rem;
    line-height: 1.75;
    color: rgba(244,243,242,0.55);
}

/* ── CTA final ──────────────────────────────────────────────── */
.ap-cta {
    position: relative;
    min-height: 420px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.ap-cta__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.ap-cta__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(29,37,51,0.88), rgba(191,160,84,0.3));
}

.ap-cta__content {
    position: relative;
    z-index: 2;
    text-align: center;
    padding-top: 80px;
    padding-bottom: 80px;
}

.ap-cta__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.8rem, 4vw, 3rem);
    color: #f4f3f2;
    font-weight: 400;
    margin-bottom: 16px;
}

.ap-cta__text {
    font-family: 'Outfit', sans-serif;
    font-size: 1.05rem;
    color: rgba(244,243,242,0.75);
    margin-bottom: 40px;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

.ap-cta__btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 36px;
    background: #bfa054;
    color: #fff;
    border-radius: 8px;
    font-family: 'Outfit', sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 300ms ease, transform 150ms ease, box-shadow 300ms ease;
}

.ap-cta__btn:hover {
    background: #1d2533;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(191,160,84,0.3);
    color: #fff;
    text-decoration: none;
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .ap-values__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .ap-bloc__inner {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .ap-bloc--reverse .ap-bloc__inner {
        direction: ltr;
    }
    .ap-bloc__num {
        display: none;
    }
    .ap-values__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
}


/* ============================================================
   14. PAGE CONTACT
============================================================ */

.udlc-video-section {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
}

.udlc-video-wrapper {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.udlc-video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.udlc-page-content {
    position: relative;
    z-index: 1;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    padding-right: 32px;
    padding-top: 96px;
    padding-bottom: 96px;
}

.udlc-page-content h1 {
    font-family: 'Achemost', serif;
    font-size: 2.625rem;
    text-align: center;
    color: #f4f3f2;
    margin-bottom: 24px;
}

.udlc-page-content > p {
    text-align: center;
    font-size: 1rem;
    color: #f4f3f2;
    margin-bottom: 24px;
    line-height: 1.7;
    font-style: italic;
}

.udlc-page-content .wpforms-container {
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    background: #fff;
    padding: 48px 40px;
    border-radius: 20px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18);
}

.udlc-page-content .wpforms-field-label {
    font-weight: 600;
    color: #333;
    margin-bottom: 8px;
    display: block;
    font-size: 0.875rem;
}

.udlc-page-content .wpforms-field input:not([type='checkbox']),
.udlc-page-content .wpforms-field textarea,
.udlc-page-content .wpforms-field select {
    width: 100%;
    padding: 16px;
    font-size: 1rem;
    border: 1px solid #ccc;
    border-radius: 8px;
    background: #fafafa;
    color: #333;
    transition: all 300ms ease;
}

.udlc-page-content .wpforms-field input:focus,
.udlc-page-content .wpforms-field textarea:focus,
.udlc-page-content .wpforms-field select:focus {
    border-color: #b1875f;
    box-shadow: 0 0 0 3px rgba(177,135,95,0.12);
    background: #fff;
}

.udlc-page-content .wpforms-field textarea { resize: vertical; min-height: 140px; }

.udlc-page-content .wpforms-submit {
    width: 100%;
    padding: 16px;
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: 8px;
    background: linear-gradient(90deg, #b1875f, #d4b27f);
    color: #fff;
    border: none;
    cursor: pointer;
    transition: all 300ms ease;
    margin-top: 20px;
}

.udlc-page-content .wpforms-submit:hover {
    background: linear-gradient(90deg, #d4b27f, #b1875f);
    box-shadow: 0 6px 20px rgba(177,135,95,0.3);
}

.udlc-page-content .wpforms-error {
    color: #c33;
    font-size: 0.875rem;
    margin-top: 4px;
}

/* Ancienne classe contact (rétrocompat) */
.page-id-124 main { position: relative; }


/* ============================================================
   14b. PAGE PERSONNALISATION
============================================================ */

/* ── Tokens locaux ───────────────────────────────────────────*/
.perso-hero,
.perso-intro,
.perso-process,
.perso-gallery,
.perso-form,
.perso-faq {
    --perso-gold:       #bfa054;
    --perso-gold-light: #d4b27f;
    --perso-dark:       #1d2533;
    --perso-cream:      #f4f3f2;
    --perso-border:     #e6dccf;
}

/* ── Boutons partagés ────────────────────────────────────────*/
.perso-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 32px;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    cursor: pointer;
    border: none;
    transition: background 300ms ease, transform 150ms ease, box-shadow 300ms ease;
    text-decoration: none;
}

.perso-btn--gold {
    background: var(--perso-gold);
    color: #fff;
}

.perso-btn--gold:hover {
    background: var(--perso-dark);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(191,160,84,0.3);
    color: #fff;
}

.perso-btn--submit { width: 100%; justify-content: center; margin-top: 8px; }

/* ── En-têtes de section partagés ───────────────────────────*/
.perso-section-header {
    text-align: center;
    margin-bottom: 56px;
}

.perso-section-title {
    font-family: 'Playfair Display', serif;
    font-size: 2.2rem;
    font-weight: 400;
    color: var(--perso-dark);
    letter-spacing: 0.02em;
    line-height: 1.2;
}

.perso-section-title--light { color: #fff; }

.perso-section-divider {
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, var(--perso-gold), var(--perso-gold-light));
    border-radius: 2px;
    margin: 20px auto;
}

.perso-section-subtitle {
    font-family: 'Outfit', sans-serif;
    font-size: 1.15rem;
    color: #666;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.7;
}

.perso-section-subtitle--light { color: rgba(255,255,255,0.75); }

/* ── 1. HERO ─────────────────────────────────────────────────*/
.perso-hero {
    position: relative;
    min-height: 80vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.perso-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.05);
    transition: transform 8s ease;
}

.perso-hero:hover .perso-hero__bg { transform: scale(1); }

.perso-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(29,37,51,0.85) 0%, rgba(29,37,51,0.5) 60%, rgba(29,37,51,0.2) 100%);
    z-index: 1;
}

.perso-hero__content {
    position: relative;
    z-index: 2;
    padding-top: 120px;
    padding-bottom: 120px;
    max-width: 700px;
}

.perso-hero__eyebrow {
    display: inline-block;
    padding: 6px 16px;
    border: 1px solid var(--perso-gold);
    border-radius: 9999px;
    color: var(--perso-gold);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    margin-bottom: 24px;
}

.perso-hero__title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2.2rem, 5vw, 3.8rem);
    font-weight: 400;
    color: #fff;
    line-height: 1.1;
    letter-spacing: 0.02em;
    margin-bottom: 24px;
}

.perso-hero__subtitle {
    font-family: 'Outfit', sans-serif;
    font-size: 1.2rem;
    color: rgba(255,255,255,0.82);
    line-height: 1.75;
    margin-bottom: 40px;
    max-width: 560px;
}

/* Flèche scroll */
.perso-hero__scroll {
    position: absolute;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}

.perso-hero__scroll span {
    display: block;
    width: 24px;
    height: 24px;
    border-right: 2px solid rgba(255,255,255,0.5);
    border-bottom: 2px solid rgba(255,255,255,0.5);
    transform: rotate(45deg);
    animation: perso-scroll 1.6s ease infinite;
}

@keyframes perso-scroll {
    0%   { opacity: 0; transform: rotate(45deg) translate(-6px,-6px); }
    50%  { opacity: 1; }
    100% { opacity: 0; transform: rotate(45deg) translate(6px,6px); }
}

/* ── 2. INTRO ────────────────────────────────────────────────*/
.perso-intro {
    background: #fff;
    padding-top: 80px;
    padding-bottom: 80px;
}

.perso-intro__inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 80px;
    align-items: center;
}

.perso-intro__text h2 { text-align: left; }
.perso-intro__text .perso-section-divider { margin-left: 0;
    margin-right: 0; }

.perso-intro__text p {
    font-family: 'Outfit', sans-serif;
    font-size: 1.1rem;
    line-height: 1.85;
    color: #555;
    margin-bottom: 16px;
}

.perso-intro__stats {
    display: flex;
    flex-direction: column;
    gap: 32px;
    flex-shrink: 0;
}

.perso-stat {
    text-align: center;
    padding: 24px 32px;
    border: 1px solid var(--perso-border);
    border-radius: 12px;
    min-width: 140px;
    background: var(--perso-cream);
    transition: border-color 300ms ease, box-shadow 300ms ease;
}

.perso-stat:hover {
    border-color: var(--perso-gold);
    box-shadow: 0 4px 16px rgba(191,160,84,0.12);
}

.perso-stat__number {
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 2.4rem;
    color: var(--perso-gold);
    line-height: 1;
    margin-bottom: 8px;
}

.perso-stat__label {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #888;
}

/* ── 3. PROCESSUS ────────────────────────────────────────────*/
.perso-process {
    background: var(--perso-cream);
    padding-top: 96px;
    padding-bottom: 96px;
}

.perso-steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    list-style: none;
    counter-reset: steps;
    position: relative;
}

/* Ligne de connexion entre étapes */
.perso-steps::before {
    content: '';
    position: absolute;
    top: 44px;
    left: calc(12.5% + 20px);
    right: calc(12.5% + 20px);
    height: 1px;
    background: linear-gradient(90deg, var(--perso-gold), var(--perso-gold-light), var(--perso-gold));
    opacity: 0.4;
    z-index: 0;
}

.perso-step {
    background: #fff;
    border-radius: 16px;
    padding: 36px 28px 32px;
    position: relative;
    z-index: 1;
    border: 1px solid var(--perso-border);
    transition: border-color 300ms ease, box-shadow 300ms ease, transform 300ms ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.perso-step:hover {
    border-color: var(--perso-gold);
    box-shadow: 0 8px 32px rgba(191,160,84,0.14);
    transform: translateY(-4px);
}

.perso-step__number {
    font-family: 'Achemost', serif;
    font-size: 3.5rem;
    color: var(--perso-gold);
    opacity: 0.18;
    line-height: 1;
    position: absolute;
    top: 16px;
    right: 20px;
}

.perso-step__icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--perso-cream);
    border: 1px solid var(--perso-border);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    color: var(--perso-gold);
    flex-shrink: 0;
    transition: background 300ms ease, border-color 300ms ease;
}

.perso-step:hover .perso-step__icon {
    background: var(--perso-gold);
    border-color: var(--perso-gold);
    color: #fff;
}

.perso-step__title {
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
    font-weight: 400;
    color: var(--perso-dark);
    margin-bottom: 12px;
    letter-spacing: 0.02em;
}

.perso-step__desc {
    font-size: 0.875rem;
    line-height: 1.7;
    color: #666;
}

/* ── 4. GALERIE ──────────────────────────────────────────────*/
.perso-gallery {
    background: #fff;
    padding-top: 96px;
    padding-bottom: 96px;
}

.perso-gallery__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.perso-gallery__item {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: var(--perso-cream);
    cursor: zoom-in;
}

.perso-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 500ms ease;
    display: block;
}

.perso-gallery__item:hover img { transform: scale(1.06); }

.perso-gallery__item figcaption {
    position: absolute;
    bottom: 0;
    inset-inline: 0;
    background: linear-gradient(transparent, rgba(29,37,51,0.85));
    color: #fff;
    font-size: 0.82rem;
    padding: 32px 16px 16px;
    opacity: 0;
    transition: opacity 300ms ease;
    font-style: italic;
}

.perso-gallery__item:hover figcaption { opacity: 1; }

/* Placeholder */
.perso-gallery__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--perso-cream);
    border: 2px dashed var(--perso-border);
    border-radius: 12px;
}

.perso-gallery__item--placeholder figcaption {
    position: static;
    background: none;
    color: #aaa;
    text-align: center;
    padding: 8px;
    opacity: 1;
    font-size: 0.75rem;
}

.perso-gallery__notice {
    text-align: center;
    margin-top: 24px;
    font-size: 0.82rem;
    color: #aaa;
    font-style: italic;
}

/* ── 5. FORMULAIRE ───────────────────────────────────────────*/
.perso-form {
    background: var(--perso-dark);
    padding-top: 96px;
    padding-bottom: 96px;
}

.perso-form__wrapper {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    background: #fff;
    border-radius: 20px;
    padding: 56px 48px;
    box-shadow: 0 24px 64px rgba(0,0,0,0.25);
}

/* Formulaire natif */
.perso-form__native {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.perso-form__row { display: flex; gap: 20px; }
.perso-form__row--2 > * { flex: 1; }

.perso-form__field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.perso-form__field label {
    font-size: 0.8rem;
    font-weight: 600;
    color: #444;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.perso-form__field input,
.perso-form__field select,
.perso-form__field textarea {
    width: 100%;
    padding: 14px 16px;
    font-size: 0.95rem;
    border: 1px solid #ddd;
    border-radius: 8px;
    background: #fafafa;
    color: #333;
    transition: border-color 300ms ease, box-shadow 300ms ease, background 300ms ease;
    -webkit-appearance: none;
}

.perso-form__field input:focus,
.perso-form__field select:focus,
.perso-form__field textarea:focus {
    border-color: var(--perso-gold);
    box-shadow: 0 0 0 3px rgba(191,160,84,0.12);
    background: #fff;
    outline: none;
}

.perso-form__field textarea { resize: vertical; min-height: 120px; }

/* Select arrow custom */
.perso-form__field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23bfa054' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 40px;
    cursor: pointer;
}

/* Checkbox consentement */
.perso-form__field--consent { flex-direction: row; align-items: flex-start; }

.perso-form__checkbox {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
    font-size: 0.82rem;
    color: #666;
    line-height: 1.5;
}

.perso-form__checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    min-width: 18px;
    padding: 0;
    border: 1px solid #ccc;
    border-radius: 4px;
    cursor: pointer;
    background: #fff;
    accent-color: var(--perso-gold);
    margin-top: 2px;
}

/* WPForms / CF7 intégration */
.perso-form__wrapper .wpforms-container,
.perso-form__wrapper .wpcf7 { padding: 0 !important; box-shadow: none !important; border-radius: 0 !important; }

.perso-form__notice {
    text-align: center;
    color: #aaa;
    font-style: italic;
    font-size: 0.875rem;
    padding: 32px;
}

/* ── 6. FAQ ──────────────────────────────────────────────────*/
.perso-faq {
    background: var(--perso-cream);
    padding-top: 96px;
    padding-bottom: 96px;
}

.perso-faq__list {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.perso-faq__item {
    border-bottom: 1px solid var(--perso-border);
}

.perso-faq__item:first-child { border-top: 1px solid var(--perso-border); }

.perso-faq__question { margin: 0; }

.perso-faq__toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 0;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: 'Playfair Display', serif;
    font-size: 1.05rem;
    color: var(--perso-dark);
    transition: color 300ms ease;
}

.perso-faq__toggle:hover { color: var(--perso-gold); }

.perso-faq__toggle[aria-expanded="true"] { color: var(--perso-gold); }

.perso-faq__icon {
    flex-shrink: 0;
    color: var(--perso-gold);
    transition: transform 300ms ease;
}

.perso-faq__toggle[aria-expanded="true"] .perso-faq__icon {
    transform: rotate(180deg);
}

.perso-faq__answer {
    padding-bottom: 22px;
    margin: 0;
}

.perso-faq__answer p {
    font-family: 'Outfit', sans-serif;
    font-size: 1.05rem;
    line-height: 1.8;
    color: #555;
}

/* ── RESPONSIVE page personnalisation ───────────────────────*/
@media (max-width: 1024px) {
    .perso-steps { grid-template-columns: repeat(2, 1fr); }
    .perso-steps::before { display: none; }

    .perso-intro__inner {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .perso-intro__stats { flex-direction: row; justify-content: center; }
}

@media (max-width: 768px) {
    .perso-hero__content { padding-top: 80px;
    padding-bottom: 80px; }
    .perso-hero__title   { font-size: 2rem; }

    .perso-gallery__grid { grid-template-columns: repeat(2, 1fr); }

    .perso-form__wrapper { padding: 40px 24px; }
    .perso-form__row { flex-direction: column; }

    .perso-steps { grid-template-columns: 1fr; }

    .perso-intro__stats { flex-direction: column; align-items: center; }
    .perso-stat { width: 100%; max-width: 280px; }
}

@media (max-width: 480px) {
    .perso-gallery__grid { grid-template-columns: 1fr; }
    .perso-section-title { font-size: 1.7rem; }
}

/* ============================================================
   15. PAGE MENTIONS LÉGALES
============================================================ */

.page-template-page-mentions main.udlc-page {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 32px;
    padding-right: 32px;
    padding-top: 48px;
    padding-bottom: 48px;
}

.page-template-page-mentions main.udlc-page h1 {
    font-size: 2rem;
    font-weight: 700;
    padding-top: 24px;
    padding-bottom: 48px;
}

.page-template-page-mentions main.udlc-page h3 {
    font-size: 1.5rem;
    font-weight: 700;
    padding-top: 24px;
    padding-bottom: 8px;
}


/* ============================================================
   16. SECTION PHOTO ART
============================================================ */

section#photoart {
    background-image: url('https://luniversdelacapsule.fr/wp-content/uploads/2026/01/vueart01.webp');
    background-size: cover;
    background-position: center;
    height: 400px;
}


/* ============================================================
   18. RESPONSIVE GLOBAL
============================================================ */

/* Tablette large – 4 colonnes */
@media (max-width: 1280px) {
    .udlc-grid { grid-template-columns: repeat(4, 1fr); }
}

/* Tablette – 3 colonnes + sidebar collapse */
@media (max-width: 1024px) {

    .udlc-shop {
        grid-template-columns: 1fr;
        gap: 32px;
        padding-top: 48px;
    padding-bottom: 48px;
    }

    .udlc-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }

}

/* Mobile – 2 colonnes */
@media (max-width: 768px) {
    .udlc-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }

    .udlc-footer-info .udlc-container { flex-direction: column; align-items: center; }

    .udlc-page-content .wpforms-container { padding: 40px 20px; }
}

/* Mobile – 1 colonne */
@media (max-width: 480px) {
    .udlc-grid { grid-template-columns: 1fr; gap: 16px; }

    .udlc-container { padding-left: 16px;
    padding-right: 16px; }
}

/* ── Loupe au survol (zoom produit) ─────────────────────────────── */

/* Le slide devient le point d'ancrage de la loupe */
.single-product .udlc-sp__slide {
    position: relative;
}

/* Curseur loupe sur l'image */
.single-product .udlc-sp__img {
    cursor: crosshair;
}

/* Box de zoom : apparaît à droite de la galerie */
.udlc-zoom-box {
    display: none;
    position: absolute;
    top: 0;
    left: calc(100% + 20px);
    width: 400px;
    height: 400px;
    border-radius: 12px;
    border: 1px solid rgba(191,160,84,0.35);
    background: #f9f8f6 no-repeat;
    background-size: auto;   /* mis à jour par JS */
    box-shadow: 0 12px 48px rgba(0,0,0,0.18);
    overflow: hidden;
    pointer-events: none;
    z-index: 100;
}

/* Lentille : petit carré qui suit la souris sur l'image */
.udlc-zoom-lens {
    display: none;
    position: absolute;
    width: 240px;
    height: 240px;
    border: 2px solid rgba(191,160,84,0.7);
    background: rgba(191,160,84,0.08);
    border-radius: 4px;
    pointer-events: none;
    z-index: 10;
    box-shadow: 0 0 0 9999px rgba(0,0,0,0.06);
}

/* Actifs au survol (classe ajoutée par JS) */
.udlc-sp__slide.zoom-active .udlc-zoom-box  { display: block; }
.udlc-sp__slide.zoom-active .udlc-zoom-lens { display: block; }

/* Mobile : pas de loupe (pas de survol) */
@media (max-width: 900px) {
    .udlc-zoom-box,
    .udlc-zoom-lens { display: none !important; }
}