/* =============================================================
   EBENEIS - Maison de Beauté
   Custom CSS Override - Charte graphique EBENEIS
   Loaded AFTER style.css to override REINE template defaults
   ============================================================= */

/* -----------------------------------------------------------
   GOOGLE FONTS OVERRIDE
   Cormorant Garamond (titres) + Montserrat (body)
   Alex Brush conservé pour éléments décoratifs
   ----------------------------------------------------------- */

/* -----------------------------------------------------------
   1. PALETTE DE COULEURS
   ----------------------------------------------------------- */

/* -- Fonds principaux -- */
.bg--ivory   { background-color: #F4EFEA !important; }
.bg--smoke   { background-color: #E7DED3 !important; }
.bg--stone   { background-color: #D8C9BE !important; }
.bg--blush   { background-color: #C6AFA6 !important; }
.bg--poudre  { background-color: #C6AFA6 !important; }
.bg--peanut  { background-color: #A79A92 !important; }

/* -- Fond body -- */
body.bg--ivory { background-color: #F4EFEA !important; }

/* -- Couleurs d'accent -- */
.color--gold    { color: #C6A46C !important; }
.color--yellow  { color: #C6A46C !important; }

/* -- Shapes -- */
.ivory--shape:after  { background-color: #F4EFEA; }
.white--shape:after  { background-color: #fff; }
.smoke--shape:after  { background-color: #E7DED3; }
.stone--shape:after  { background-color: #D8C9BE; }
.blush--shape:after  { background-color: #C6AFA6; }
.poudre--shape:after { background-color: #C6AFA6; }

/* -----------------------------------------------------------
   2. TYPOGRAPHIE
   ----------------------------------------------------------- */

/* Headings : Cormorant Garamond (serif élégante) */
h1, h2, h3, h4, h5, h6,
.h2-title, .h2-md, .h3-md, .h3-lg, .h4-md, .h5-lg, .h5-md {
    font-family: 'Cormorant Garamond', serif !important;
    letter-spacing: 0.08em;
    color: #4E4743;
}

h1 { letter-spacing: 0.15em; }
h2 { letter-spacing: 0.12em; }

/* Body text : Montserrat (sans-serif moderne) */
body,
p,
.wsmenu-list > li > a,
.sub-menu li a,
.link-list li a,
table,
.form-control,
.btn,
input,
textarea,
select,
.pricing-1-item .price-name p,
.pricing-1-item .price-txt p,
.pricing-1-item .price-number p,
.accordion-thumb p,
.accordion-panel p,
.review-txt p,
.blog-post-txt p,
.post-tag,
.footer-copyright p,
.footer-contacts p,
.footer-info p,
.section-id,
.simple-list p,
ul, li {
    font-family: 'Montserrat', sans-serif;
}

body {
    font-weight: 300;
    line-height: 1.8;
    color: #4E4743;
}

p {
    color: #4E4743;
    font-weight: 300;
    line-height: 1.8;
}

/* Section ID (petits titres) */
.section-id {
    font-family: 'Cormorant Garamond', serif !important;
    font-style: italic;
    font-weight: 400;
    letter-spacing: 0.1em;
    color: #C6A46C;
    font-size: 1.125rem;
}

/* Decorative cursive text */
.tra-title {
    font-family: 'Cormorant Garamond', serif !important;
    font-style: italic;
}

/* Heading colors */
h1, h2, h3, h4, h5, h6 { color: #4E4743; }
.color--white h1, .color--white h2, .color--white h3,
.color--white h4, .color--white h5, .color--white h6,
.color--white p, .color--white { color: #fff; }
.color--black { color: #4E4743 !important; }

/* Link colors */
a { color: #4E4743; }
a:hover { color: #C6A46C; }

/* -----------------------------------------------------------
   3. BOUTONS - Accent Champagne
   ----------------------------------------------------------- */

/* Bouton principal champagne (CTA) */
.btn--gold,
.btn--champagne {
    background-color: #C6A46C !important;
    border-color: #C6A46C !important;
    color: #fff !important;
    letter-spacing: 0.1em;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    transition: all 0.4s ease;
}
.btn--gold:hover,
.btn--champagne:hover {
    background-color: #b8944f !important;
    border-color: #b8944f !important;
    color: #fff !important;
}

/* Bouton transparent champagne */
.btn--tra-gold {
    border-color: #C6A46C !important;
    color: #C6A46C !important;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    letter-spacing: 0.1em;
    transition: all 0.4s ease;
}
.btn--tra-gold:hover {
    background-color: #C6A46C !important;
    border-color: #C6A46C !important;
    color: #fff !important;
}

/* Hover gold pour boutons transparents */
.hover--gold:hover {
    background-color: #C6A46C !important;
    border-color: #C6A46C !important;
    color: #fff !important;
}

/* Bouton noir EBENEIS */
.btn--black {
    background-color: #4E4743 !important;
    border-color: #4E4743 !important;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    letter-spacing: 0.1em;
}
.btn--black:hover {
    background-color: transparent !important;
    border-color: #4E4743 !important;
    color: #4E4743 !important;
}

.btn--tra-black {
    border-color: #4E4743 !important;
    color: #4E4743 !important;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    letter-spacing: 0.08em;
}
.btn--tra-black:hover {
    background-color: #4E4743 !important;
    color: #fff !important;
}

/* Bouton blanc */
.btn--tra-white {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    letter-spacing: 0.08em;
}

/* Tous les boutons - ralentir transition */
.btn {
    transition: all 0.4s ease;
    border-radius: 0;
}

/* -----------------------------------------------------------
   4. NAVIGATION - Glass Effect + Sticky
   ----------------------------------------------------------- */

/* Navigation glass/blur quand sticky */
.tra-menu.scroll,
.tra-menu.white-scroll.scroll {
    background-color: rgba(244, 239, 234, 0.92) !important;
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    box-shadow: 0 2px 20px rgba(78, 71, 67, 0.06);
}

/* Navigation liens */
.wsmenu-list > li > a.h-link {
    font-family: 'Montserrat', sans-serif !important;
    font-weight: 400;
    letter-spacing: 0.12em;
    font-size: 0.8125rem;
    text-transform: uppercase;
}

/* Bouton CTA header */
.wsmenu-list > li > a.last-link.btn--champagne,
.wsmenu-list > li > a.last-link.btn--gold {
    background-color: #C6A46C !important;
    border-color: #C6A46C !important;
    color: #fff !important;
    font-weight: 500;
    letter-spacing: 0.1em;
}
.wsmenu-list > li > a.last-link.btn--champagne:hover,
.wsmenu-list > li > a.last-link.btn--gold:hover {
    background-color: #b8944f !important;
    border-color: #b8944f !important;
}

/* Sub-menu styling */
.sub-menu li a,
.link-list li a {
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    letter-spacing: 0.05em;
}

/* Logo sizing */
.desktoplogo img {
    max-height: 50px;
}
.smllogo img {
    max-height: 40px;
}

/* -----------------------------------------------------------
   5. HERO SECTION - Style luxe doux
   ----------------------------------------------------------- */

/* Hero-5 style (logo centré + images) */
.hero-5-txt {
    padding: 6rem 0 3rem;
}

.hero-5-txt h1 {
    color: #c6a46c;
    font-size: 3rem;
    text-transform: uppercase;
    margin: 100px 0 0;
}

.hero-7-txt h1 {
    color: #c6a46c;
    font-size: 3rem;
    text-transform: uppercase;
}

.hero-5-txt p {
    font-family: 'Cormorant Garamond', serif !important;
    font-weight: 400;
    letter-spacing: 0.12em;
    color: #4E4743;
    font-size: 1.5rem;
    line-height: 1.4;
    margin-top: 1rem;
}

.hero-logo img {
    max-height: 120px;
}

/* Filets décoratifs autour du sous-titre */
.hero-tagline {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    margin: 1.5rem 0 2rem;
}
.hero-tagline::before,
.hero-tagline::after {
    content: '';
    width: 60px;
    height: 1px;
    background-color: #C6A46C;
}
.hero-tagline span {
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    font-size: 0.75rem;
    color: #A79A92;
}

/* Hero fullscreen background */
.hero-section.hero-ebeneis {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
     overflow: hidden;
}

/* -----------------------------------------------------------
   5b. HERO-7 - EBENEIS (index-2)
   ----------------------------------------------------------- */

.hero-7-ebeneis {
    background-color: #F4EFEA;
}

.hero-7-ebeneis .hero-7-txt h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 4rem;
    font-weight: 500;
    color: #4E4743;
    letter-spacing: 0.04em;
    line-height: 1.2;
}

.hero-7-ebeneis .hero-7-txt p {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem;
    font-style: italic;
    color: #A79A92;
    letter-spacing: 0.05em;
    margin-top: 10px;
}

.hero-7-ebeneis .hero-7-btn .btn {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
}

.hero-7-ebeneis .hero-7-img {
    margin-top: 50px;
}

.hero-7-ebeneis .hero-7-img img {
    height: 600px;
    width: 100%;
    max-width: inherit;
    object-fit: cover;
}

.hero-7-ebeneis .tra-header {
    top: 18%;
    opacity: 0.04;
}

.hero-7-ebeneis .tra-header h2 {
    font-family: 'Alex Brush', cursive !important;
    font-size: 13rem;
    font-weight: 600;
    color: #C6A46C;
    letter-spacing: 0.05em;
    font-style: italic;
}

#ct-parcours{
        background: linear-gradient(160deg, #E7DED3 0%, #E7DED3 40%, #E7DED3 70%, #E7DED3 100%);
}

/* -----------------------------------------------------------
   5c. HERO VIDEO - EBENEIS (index-3)
   ----------------------------------------------------------- */

.hero-video-ebeneis {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.hero-video-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.hero-video-bg video,
.hero-bg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-bg-image {
    animation: heroZoom 12s ease-in-out infinite alternate;
}

@keyframes heroZoom {
    0% { transform: scale(1); }
    100% { transform: scale(1.05); }
}

.hero-video-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(78,71,67,0.55) 0%, rgba(78,71,67,0.40) 50%, rgba(78,71,67,0.60) 100%);
}

.hero-video-txt {
    position: relative;
    z-index: 2;
    padding: 8rem 0 4rem;
}

.hero-video-txt .section-id {
    color: #fff;
    font-size: 1rem;
    letter-spacing: 0.2em;
    margin-bottom: 1.5rem;
    display: inline-block;
}

.hero-video-txt h1,
.hero-video-txt h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 4.5rem;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.04em;
    line-height: 1.15;
    margin-bottom: 1.25rem;
}

.hero-video-subtitle {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.5rem;
    font-style: italic;
    font-weight: 400;
    color: rgba(244, 239, 234, 0.85);
    letter-spacing: 0.06em;
    margin-bottom: 2.5rem;
}

.hero-video-txt .btn {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    padding: 14px 40px;
}

/* -----------------------------------------------------------
   5d. NAV BLANCHE - Toutes les pages
   ----------------------------------------------------------- */

/* Liens nav blancs sur fond transparent */
.tra-menu.navbar-light .wsmenu > .wsmenu-list > li > a.h-link {
    color: #fff;
}
.tra-menu.navbar-light .wsmenu-list > li > a.h-link:hover {
    color: #C6A46C !important;
}

/* Au scroll : retour aux couleurs normales */
.tra-menu .scroll .wsmenu > .wsmenu-list > li > a.h-link {
    color: #4E4743 !important;
}
.tra-menu .scroll .wsmenu > .wsmenu-list > li > a.h-link:hover {
    color: #C6A46C !important;
}

/* Hamburger mobile en blanc */
.wsmobileheader {
    background-color: #4e4743;
}
.wsanimated-arrow span,
.wsanimated-arrow span::before,
.wsanimated-arrow span::after {
    background: #4e4743;
}

/* -----------------------------------------------------------
   Bouton Panier dans la barre mobile
   ----------------------------------------------------------- */
.mobile-cart-trigger {
    position: absolute !important;
    right: 55px;
    top: 15px  !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center;
    height: 54px;
    width: 44px;
    z-index: 103;
    text-decoration: none;
}
.mobile-cart-trigger .flaticon-shopping-bag:before {
    font-size: 20px !important;
    color: #50463c;
}
.mobile-cart-trigger .cart-count {
    position: absolute;
    top: 10px;
    right: 2px;
    background: #C6A46C;
    color: #fff;
    font-size: 9px;
    font-weight: 600;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    font-family: 'Montserrat', sans-serif;
}
/* Masquer le panier mobile sur desktop */
@media (min-width: 992px) {
    .mobile-cart-trigger {
        display: none;
    }
}

/* -----------------------------------------------------------
   5e. NAV SOMBRE - Pages sans hero (classe .nav-dark sur body)
   ----------------------------------------------------------- */
body.nav-dark .tra-menu.navbar-light .wsmenu > .wsmenu-list > li > a.h-link {
    color: #4E4743;
}
body.nav-dark .tra-menu.navbar-light .wsmenu-list > li > a.h-link:hover {
    color: #C6A46C !important;
}
body.nav-dark .tra-menu.navbar-light .wsmenu-list li a.h-link.active-link {
    color: #C6A46C !important;
}
/* Logo : afficher noir par défaut, blanc masqué */
body.nav-dark .navbar-light .logo-white {
    display: none;
}
body.nav-dark .navbar-light .logo-black {
    display: block;
}

/* -----------------------------------------------------------
   6. SECTIONS CONTENT - Espaces généreux
   ----------------------------------------------------------- */

/* Plus d'espacement vertical entre sections */
.content-section,
.services-section,
.pricing-section,
.reviews-section,
.gallery-section,
.blog-section,
.newsletter-section,
.banner-section {
    padding-top: 6rem;
    padding-bottom: 6rem;
}

/* Interlignage généreux dans les blocs texte */
.txt-block p {
    line-height: 1.9;
    font-weight: 300;
}

/* -----------------------------------------------------------
   6b. PARCOURS SIGNATURE - Layout about-8 immersif
   ----------------------------------------------------------- */

#parcours-signature {
   background: linear-gradient(180deg, #ffefda 0%, #ededeb 20%, #ffffff 40%, #f7e8e9 60%, #e7d9c2 80%, #e3dad3 100%);
    
}

#parcours-signature .about-8-txt .parcours-label {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 0.6875rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #C6A46C;
    display: inline-block;
    margin-bottom: 0.5rem;
}

#parcours-signature .about-8-txt h3 {
    margin-bottom: 0.75rem;
}

#parcours-signature .about-8-txt .parcours-price {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 1.125rem;
    color: #C6A46C;
    letter-spacing: 0.05em;
    display: inline-block;
    margin-bottom: 0.25rem;
}

#parcours-signature .about-8-txt .tra-link a {
    color: #4E4743;
    padding-bottom: 2px;
    transition: color 0.3s ease;
}
#parcours-signature .about-8-txt .tra-link a:hover {
    color: #C6A46C;
}

.la-maison .ct-05-img img {
    height: 600px;
    width: 100%;
    object-fit: cover;

}
.about-8-img img {
    height: 700px;
    width: 100%;
    object-fit: cover;
}
#parcours-signature .about-8-img img {
    transition: transform 0.8s ease;
    
}
#parcours-signature .about-8-img:hover img {
    transform: scale(1.03);
}

#parcours-signature [id^="a8-"] {
    padding: 2rem 0 0;
}

/* -----------------------------------------------------------
   6c. PROMESSE - Section émotionnelle
   ----------------------------------------------------------- */

#promesse {
    background: #fff;
    height: 80vh;
    align-items: center;
    display: flex;
    padding: 0;
}
#promesse h2 {
    font-size: 2.25rem;
    line-height: 1.5;
    color: #4E4743;
}
#promesse h2.typewrite {
    min-height: 3.6em;
    opacity: 0;
    transition: opacity 0.3s ease;
}
#promesse h2.typewrite.is-typing { opacity: 1; }

/* Typewriter cursor */
.typewrite-cursor {
    display: inline-block;
    width: 2px;
    height: 0.9em;
    background: #C6A46C;
    margin-left: 3px;
    vertical-align: baseline;
    animation: blink-cursor 0.7s step-end infinite;
}
@keyframes blink-cursor {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

/* Subtitle fade after typing */
.promesse-subtitle {
    opacity: 0;
    transition: opacity 1.2s ease;
}
.promesse-subtitle.is-visible { opacity: 1; }

#promesse p {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.25rem;
    font-style: italic;
    color: #A79A92;
    letter-spacing: 0.05em;
}

/* -----------------------------------------------------------
   6d. BOUTIQUE - Fond smoke
   ----------------------------------------------------------- */

#boutique.bg--smoke .sbox-2 {
    background-color: #fff;
    padding: 2.5rem 1.5rem;
}

/* -----------------------------------------------------------
   6e. CTA RDV FINAL
   ----------------------------------------------------------- */

.banner-section .banner-2-txt .section-id {
    color: #F4EFEA;
}
.banner-section.bg--03 {
  background-repeat: no-repeat;
  background-position: center center;   
  background-size: cover;
  background-attachment: scroll!important;
  position: relative;
}
.banner-section.bg--03::before {
    content: "";
    position: absolute;
    background-color: #4E4743;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.7;
    z-index: 0;
}

/* CTA spécifique page expérience */
.banner-section.bg--experience-cta {
    background: url(../images/hero-5-1.jpg) center center / cover no-repeat;
    position: relative;
}
.banner-section.bg--experience-cta::before {
    content: "";
    position: absolute;
    background-color: #4E4743;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.65;
    z-index: 0;
}

/* Harmonisation images sections étapes */
.ct-03 .img-block img {
    border-radius: 6px;
    height: 420px;
    object-fit: cover;
    width: 100%;
}


/* -----------------------------------------------------------
   7a. SOINS CAROUSEL — Carrousel draggable bleed-right
   ----------------------------------------------------------- */

/* Section : masque le débordement horizontal */
.soins-section {
    overflow: hidden;
}

/* Header : titre à gauche, flèches à droite */
.soins-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
}
.soins-header__text {
    flex: 1;
}
.soins-header__text p {
    max-width: 600px;
}

/* Flèches navigation */
.soins-header__nav {
    display: flex;
    gap: 12px;
    flex-shrink: 0;
    padding-bottom: 6px;
}
.soins-nav-btn {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 1px solid #c6a46c;
    background: transparent;
    color: #c6a46c;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.35s ease;
}
.soins-nav-btn:hover {
    border-color: #C6A46C;
    color: #C6A46C;
    background: rgba(198, 164, 108, 0.06);
}
.soins-nav-btn:active {
    transform: scale(0.92);
}
.soins-nav-btn.disabled {
    opacity: 0.3;
    pointer-events: none;
}

/* Trait décoratif doré */
.soins-separator {
    height: 2rem;
}

/* Wrapper bleed-right : déborde du container vers le bord droit du viewport */
.soins-carousel-bleed {
    margin-right: calc(-50vw + 50%);
    margin-left: -50px;
}

/* Compenser le stagePadding gauche pour aligner au bord du container */
.soins-carousel .owl-stage-outer {
    overflow: visible;
}

/* Curseur grab/grabbing pour indiquer le drag */
.soins-carousel .owl-stage {
    display: flex;
    align-items: stretch;
    cursor: grab;
}
.soins-carousel .owl-stage:active {
    cursor: grabbing;
}

/* Désactiver les dots et nav générés par Owl (on utilise les custom) */
.soins-carousel .owl-nav,
.soins-carousel .owl-dots {
    display: none !important;
}

/* Chaque item prend toute la hauteur */
.soins-carousel .owl-item {
    display: flex;
}
.soins-carousel .item {
    display: flex;
    width: 100%;
}

/* ---- Carte de soin ---- */
.soins-card {
    background: #fff;
    border: 1px solid #EDEBE8;
    border-radius: 8px;
    padding: 2.25rem 1.75rem 2rem;
    text-align: center;
    transition: all 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    height: 100%;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
}

/* Pilier Signature */
.soins-card--signature {
    background: linear-gradient(160deg, #FDFBF8 0%, #F7F2EC 100%);
    border: 1.5px solid #C6A46C;
    padding: 2.5rem 2rem;
}
.soins-card--signature::after {
    width: 40%;
    background: linear-gradient(90deg, transparent, #C6A46C, transparent);
}
.soins-card--signature:hover::after {
    width: 80%;
}

.soins-card__badge {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #C6A46C;
    background: transparent;
    border: 1px solid #C6A46C;
    padding: 5px 16px;
    border-radius: 20px;
    margin-bottom: 1.25rem;
}

.soins-card__icon {
    font-size: 40px;
    color: #C6A46C;
    margin-bottom: 0.5rem;
    line-height: 1;
    transition: transform 0.4s ease;
}
.soins-card:hover .soins-card__icon {
    transform: scale(1.1);
}
.soins-card__icon span[class^="flaticon-"]:before, 
.soins-card__icon span[class*=" flaticon-"]:before {
    font-size: 48px;
}

/* Séparateur doré sous l'icône */
.soins-card__icon::after {
    content: '';
    display: block;
    width: 30px;
    height: 1px;
    background: #C6A46C;
    margin: 0.6rem auto 0;
    opacity: 0.5;
}

.soins-card__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: #4E4743;
    margin-bottom: 0.6rem;
    letter-spacing: 0.02em;
}

.soins-card__desc {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.82rem;
    color: #A79A92;
    line-height: 1.65;
    margin-bottom: 5rem;
    flex-grow: 1;
}

.soins-card__price {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem;
    font-weight: 600;
    color: #C6A46C;
    margin-bottom: 1rem;
}
.soins-card__price small {
    font-size: 0.75rem;
    font-weight: 400;
    color: #A79A92;
}

.soins-card__link {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #4E4743;
    position: relative;
    padding-bottom: 3px;
    transition: color 0.3s ease;
}
.soins-card__link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: #C6A46C;
    transform: scaleX(0.4);
    transform-origin: center;
    transition: transform 0.35s ease;
}
.soins-card__link:hover {
    color: #C6A46C;
}
.soins-card__link:hover::after {
    transform: scaleX(1);
}

/* CTA élégant en bas de section */
.soins-cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #4E4743;
    transition: all 0.35s ease;
}
.soins-cta svg {
    transition: transform 0.35s ease;
}
.soins-cta:hover {
    color: #C6A46C;
}
.soins-cta:hover svg {
    transform: translateX(4px);
}

/* -----------------------------------------------------------
   7. CARDS HOVER - Filet doré + soulèvement
   ----------------------------------------------------------- */

.sbox-2 {
    transition: all 0.4s ease;
    border-bottom: 2px solid transparent;
}
.sbox-2:hover {
    transform: translateY(-6px);
}

/* Services icons color */
.sbox-2 .sbox-ico span {
    color: #C6A46C !important;
}
.sbox-2 .shape-ico svg path {
    fill: #F4EFEA;
}

/* Blog post hover */
.blog-post {
    transition: all 0.4s ease;
}
.blog-post .post-tag {
    color: #A79A92;
}
.blog-post .post-link a {
    color: #4E4743;
}
.blog-post .post-link a:hover {
    color: #C6A46C;
}

/* -----------------------------------------------------------
   8. TÉMOIGNAGES
   ----------------------------------------------------------- */

.review-2 .review-txt {
    border-color: #E7DED3;
}
.star-rating .flaticon-star-1,
.star-rating .flaticon-star-half-empty {
    color: #C6A46C !important;
}
.review-author p {
    color: #4E4743;
    font-weight: 500;
}

/* -----------------------------------------------------------
   9. BANNER / PROMO
   ----------------------------------------------------------- */

.banner-section.bg--ebeneis {
    background-color: #C6AFA6;
}
.banner-2-txt h2 span {
    color: #C6A46C !important;
}

/* -----------------------------------------------------------
   10. NEWSLETTER
   ----------------------------------------------------------- */

.newsletter-wrapper {
    background-color: #4E4743;
    border-radius: 0;
}
.newsletter-form .form-control {
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    letter-spacing: 0.05em;
}

/* CF7 wrapper override : CF7 enveloppe les inputs dans des <span class="wpcf7-form-control-wrap">
   ce qui casse le .input-group Bootstrap. On force le span à se comporter
   comme l'input direct attendu par .input-group. */
.newsletter-form--cf7 .input-group .wpcf7-form-control-wrap {
    flex: 1 1 auto;
    width: 1%;
    margin-bottom: 0;
}
.newsletter-form--cf7 .input-group .wpcf7-form-control-wrap .form-control {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    height: 100%;
}
.newsletter-form--cf7 .input-group .wpcf7-form-control-wrap input.form-control {
    height: 50px;
}
.newsletter-section .form-notification{
    display: none !important;
}
.newsletter-form--cf7 .input-group .input-group-btn .btn {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.newsletter-form--cf7 .wpcf7-not-valid-tip {
    display: block;
    margin-top: .5rem;
    color: #ffd9d9;
    text-align: left;
    font-size: .85rem;
}
.newsletter-form--cf7 .wpcf7-response-output {
    margin: 1rem 0 0;
    padding: .65rem 1rem;
    border-radius: 4px;
    color: #fff;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .25);
    font-size: .9rem;
}
.newsletter-form--cf7 .wpcf7 form.invalid .wpcf7-response-output,
.newsletter-form--cf7 .wpcf7 form.unaccepted .wpcf7-response-output {
    border-color: #ffb3b3;
    color: #ffd9d9;
}
.newsletter-form--cf7 .wpcf7 form.sent .wpcf7-response-output {
    border-color: #c6e2c6;
    color: #d6f5d6;
}

/* -----------------------------------------------------------
   11. FOOTER - Fond taupe profond
   ----------------------------------------------------------- */

#footer-3 {
    background-color: #4E4743;
    color: #E7DED3;
}
#footer-3 h5 {
    color: #F4EFEA !important;
    font-family: 'Cormorant Garamond', serif !important;
    letter-spacing: 0.1em;
}
#footer-3 p,
#footer-3 a {
    color: #D8C9BE;
}
#footer-3 a:hover {
    color: #C6A46C;
}
#footer-3 .footer-copyright p {
    color: #A79A92;
    font-size: 15px;
}
#footer-3 hr {
    border-color: rgba(231, 222, 211, 0.2);
}
#footer-3 .foo-socials a {
    color: #D8C9BE;
}
#footer-3 .foo-socials a:hover {
    color: #C6A46C;
}

/* Footer logo */
.footer-logo img {
    max-height: 60px;
    margin-bottom: 1.5rem;
}

/* -----------------------------------------------------------
   12. LOADER - Champagne
   ----------------------------------------------------------- */

.loading-ebeneis .loader {
    border-color: #C6A46C;
}
.loading-ebeneis .loader::after {
    border-top-color: #C6A46C;
}

/* -----------------------------------------------------------
   13. GALERIE - Overlay subtil
   ----------------------------------------------------------- */

.gallery-image .item-overlay {
    background: rgba(78, 71, 67, 0.25);
}
.gallery-image .hover-overlay:hover .item-overlay {
    background: rgba(78, 71, 67, 0.45);
}

/* Grille Instagram uniforme (la-maison) */
.row-cols-lg-6 .gallery-image .hover-overlay,
.gallery-slider .gallery-image .hover-overlay {
    aspect-ratio: 1 / 1;
    overflow: hidden;
}
.row-cols-lg-6 .gallery-image .hover-overlay img,
.gallery-slider .gallery-image .hover-overlay img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Gallery Slider - dots mobile */
.owl-dots {
    margin-top: 1rem;
    text-align: center;
}

/* Owl Dots - Style EBENEIS global */
.owl-dots .owl-dot span {
    width: 10px;
    height: 10px;
    margin: 0 6px;
    background: #D8C9BE;
    border-radius: 50%;
    transition: all 0.4s ease;
    display: inline-block;
}
.owl-dots .owl-dot:hover span {
    background: #C6AFA6;
}
.owl-dots .owl-dot.active span {
    background: #C6A46C;
    width: 28px;
    border-radius: 5px;
}

/* Gallery mobile carousel : caché par défaut, grille visible */
.gallery-mobile-carousel {
    display: none;
}

@media (max-width: 767.98px) {
    .gallery-4-wrapper {
        display: none;
    }
    .gallery-mobile-carousel {
        display: block;
        padding: 0 15px;
    }
     .gallery-image img {
        width: 100%;
        height: 400px;
        object-fit: cover;
        border-radius: 2px;
    }
     .owl-dots {
        margin-top: 1.5rem;
        text-align: center;
    }
}

/* -----------------------------------------------------------
   14. ANIMATIONS - Plus lentes, plus organiques
   ----------------------------------------------------------- */

.wow {
    animation-duration: 1.2s !important;
}

/* Scroll reveal doux */
.fadeInUp { animation-duration: 1.2s; }
.fadeInRight { animation-duration: 1.2s; }
.fadeInLeft { animation-duration: 1.2s; }

/* Soins carousel responsive */
@media (max-width: 575.98px) {
    .soins-header { flex-direction: column; align-items: flex-start; gap: 1rem; text-align: left; }
    .soins-header__nav { align-self: flex-end; }
    .soins-nav-btn { width: 40px; height: 40px; }
    .soins-separator { margin: 1.5rem 0 2rem; }
    .soins-carousel-bleed { margin-left: -30px; }
    .soins-card { padding: 1.75rem 1.25rem 1.5rem; }
    .soins-card--signature { padding: 2rem 1.5rem; }
    .soins-card__title { font-size: 1.2rem; }
    .soins-card__desc { font-size: 0.8rem; }
}
@media (min-width: 576px) and (max-width: 991.98px) {
    .soins-carousel-bleed { margin-left: -40px; }
}

/* -----------------------------------------------------------
   15. BANDEAU SENSORIEL
   ----------------------------------------------------------- */

.bandeau-sensoriel {
    background: linear-gradient(135deg, #c6a46c 0%, #D8C9BE 50%, #c6a46c 100%);
    padding: 5rem 0;
    text-align: center;
}
.bandeau-sensoriel .keywords {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    flex-wrap: wrap;
}
.bandeau-sensoriel .keywords span {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 1.5rem;
    color: #4E4743;
    letter-spacing: 0.15em;
}
.bandeau-sensoriel .keywords .sep {
    width: 6px;
    height: 6px;
    background-color: #C6A46C;
    border-radius: 50%;
    display: inline-block;
    font-size: 0;
}

/* -----------------------------------------------------------
   16. SECTION EXPÉRIENCE - Rose poudré + halos
   ----------------------------------------------------------- */

.section-experience {
    background-color: #C6AFA6;
    position: relative;
    overflow: hidden;
}
.section-experience::before {
    content: '';
    position: absolute;
    top: 10%;
    right: -5%;
    width: 40%;
    height: 60%;
    background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}
.section-experience::after {
    content: '';
    position: absolute;
    bottom: 5%;
    left: 10%;
    width: 30%;
    height: 40%;
    background: radial-gradient(circle, rgba(244,239,234,0.12) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

.fbox-3 .fbox-ico span[class^="flaticon-"]:before {
    font-size: 52px;
    color: #C6A46C;
}

.owl-dots .owl-dot {
    border: 0;
}
/* -----------------------------------------------------------
   17. RESPONSIVE ADJUSTMENTS
   ----------------------------------------------------------- */

@media (max-width: 991.98px) {
    .hero-section.hero-ebeneis {
        min-height: 80vh;
    }
    .hero-logo img {
        max-height: 90px;
    }
    .hero-5-txt h2 {
        font-size: 1.625rem;
    }
    .bandeau-sensoriel .keywords span {
        font-size: 1.25rem;
    }
    #promesse h2 {
        font-size: 1.75rem;
    }
    .hero-7-ebeneis .hero-7-txt h2 {
        font-size: 2.75rem;
    }
    .hero-7-ebeneis .hero-7-img img {
        max-height: 380px;
    }
    .hero-7-ebeneis .tra-header h2 {
        font-size: 8rem;
    }
    .hero-video-txt h2 {
        font-size: 3rem;
    }
    .hero-video-subtitle {
        font-size: 1.25rem;
    }
    .hero-video-ebeneis {
        min-height: 80vh;
    }
}

@media (max-width: 767.98px) {
    .hero-section.hero-ebeneis {
        min-height: 70vh;
    }
    .hero-logo img {
        max-height: 70px;
    }
    .hero-5-txt {
        padding: 4rem 0 2rem;
    }
    .hero-5-txt h2 {
        font-size: 1.375rem;
    }
    .hero-tagline::before,
    .hero-tagline::after {
        width: 40px;
    }
    .bandeau-sensoriel .keywords {
        gap: 1rem;
    }
    .bandeau-sensoriel .keywords span {
        font-size: 1.125rem;
    }
    .content-section,
    .services-section,
    .pricing-section,
    .reviews-section,
    .gallery-section,
    .blog-section,
    .newsletter-section,
    .banner-section {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }
    .desktoplogo img {
        max-height: 40px;
    }
    #promesse h2 {
        font-size: 1.5rem;
    }
    .hero-7-ebeneis .hero-7-txt h2 {
        font-size: 2rem;
    }
    .hero-7-ebeneis .hero-7-txt p {
        font-size: 1.125rem;
    }
    .hero-7-ebeneis .hero-7-img img {
        max-height: 300px;
    }
    .hero-7-ebeneis .tra-header h2 {
        font-size: 5rem;
    }
    .hero-video-txt h2 {
        font-size: 2.25rem;
    }
    .hero-video-subtitle {
        font-size: 1.125rem;
    }
    .hero-video-ebeneis {
        min-height: 70vh;
    }
    .hero-video-txt {
        padding: 6rem 0 3rem;
    }
    /* Images étapes expérience - responsive */
    .ct-03 .img-block img {
        height: 280px;
    }
    /* Inner pages responsive */
    .ebeneis-page-hero .page-hero-txt h2 {
        font-size: 2.5rem;
    }
    .soin-detail-txt {
        padding-top: 2rem;
    }
}


/* ===================================================================
   §18 - PAGES INTÉRIEURES EBENEIS
   =================================================================== */

/* -----------------------------------------------------------
   18a. HERO PAGES INTÉRIEURES
   ----------------------------------------------------------- */

.ebeneis-page-hero {
    position: relative;
}

/* Overlay sombre sur les inner-page-hero EBENEIS */
.ebeneis-page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(78, 71, 67, 0.55);
    z-index: 1;
}
.ebeneis-page-hero .container {
    position: relative;
    z-index: 2;
}
.ebeneis-page-hero .page-hero-txt .section-id {
    font-family: 'Alex Brush', cursive;
    font-size: 1.5rem;
    color: #fff;
    display: block;
    margin-bottom: 0.5rem;
}

/* Background images : gérées par ACF (style inline) ou fallback CSS */
.ebeneis-page-hero:not([style*="background-image"]) {
    background: url(../images/woman_03.jpg) center center / cover no-repeat;
}

/* -----------------------------------------------------------
   18b. LIEN ACTIF NAVIGATION
   ----------------------------------------------------------- */

.wsmenu-list li a.h-link.active-link {
    color: #C6A46C !important;
}
.scroll .wsmenu-list li a.h-link.active-link {
    color: #C6A46C !important;
}

/* -----------------------------------------------------------
   18c. PAGE SOINS - Pricing overrides
   ----------------------------------------------------------- */

.pricing-5-category h3 {
    font-family: 'Cormorant Garamond', serif;
    font-weight: 600;
    font-size: 1.5rem;
    color: #4E4743;
    letter-spacing: 0.05em;
}

.pricing-list .pricing-5-item .price-name p {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
    color: #4E4743;
}
.pricing-list .pricing-5-item .price-number  {
    width: 140px;
    padding: 0 0 0 10px;
    white-space: nowrap;
    display: flex;
    justify-content: end;
}
.pricing-list .pricing-5-item .price-number p {
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    color: #C6A46C;
}
.pricing-list .pricing-5-item .price-number p del {
    font-size: 80%;
    color: #a59186;
}
.pricing-list .pricing-5-item .price-txt p {
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    font-size: 0.875rem;
    color: #A79A92;
}

/* -----------------------------------------------------------
   18c-bis. PRIX RÉDUITS BOOKLY (Discounts addon)
   ----------------------------------------------------------- */
.ebeneis-price--discounted {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.45rem;
    line-height: 1.2;
}
.ebeneis-price__original,
.ebeneis-price__original del {
    color: #A79A92;
    font-weight: 400;
    text-decoration: line-through;
    text-decoration-thickness: 1px;
    font-size: 0.9em;
}
.ebeneis-price__current {
    color: #C6A46C;
    font-weight: 600;
}
/* Soins à la carte : on garde le style price-number sur le prix réduit */
.pricing-list .pricing-5-item .price-number .ebeneis-price--discounted {
    justify-content: flex-end;
}
.pricing-list .pricing-5-item .price-number .ebeneis-price__current {
    font-family: 'Montserrat', sans-serif;
}
/* Carrousel soins : badge prix réduit reste lisible sur fond clair */
.soins-card__price.ebeneis-price--discounted {
    display: inline-flex;
}
/* Parcours immersifs : prix sur fond sombre/photo */
.parcours-card__tarif-item.ebeneis-price--discounted .ebeneis-price__original,
.parcours-card__tarif-item.ebeneis-price--discounted .ebeneis-price__original del {
    color: rgba(255, 255, 255, 0.65);
}
.parcours-card__tarif-item.ebeneis-price--discounted .ebeneis-price__current {
    color: #C6A46C;
}

/* -----------------------------------------------------------
   18d. PAGE SOIN DÉTAIL
   ----------------------------------------------------------- */

.soin-detail-img img {
    border-radius: 4px;
}

.soin-meta span {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.9375rem;
    color: #A79A92;
}
.soin-meta span strong {
    color: #4E4743;
    font-weight: 500;
}

.soin-protocol-list,
.soin-benefits-list {
    list-style: none;
    padding-left: 0;
}
.soin-protocol-list li,
.soin-benefits-list li {
    position: relative;
    padding-left: 1.5rem;
    margin-bottom: 0.5rem;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    font-size: 0.9375rem;
    color: #4E4743;
}
.soin-protocol-list li::before {
    content: '-';
    position: absolute;
    left: 0;
    color: #C6A46C;
}
.soin-benefits-list li::before {
    content: '✦';
    position: absolute;
    left: 0;
    color: #C6A46C;
    font-size: 0.75rem;
    top: 2px;
}

/* Soins recommandés cards */
.soin-card img {
    border-radius: 4px;
    width: 100%;
    height: 260px;
    object-fit: cover;
}


/* -----------------------------------------------------------
   18f. FIL D'ARIANE (BREADCRUMB)
   ----------------------------------------------------------- */

/* Variante hero : centré, dans le hero */
.breadcrumb-hero {
    margin-top: 1rem;
}
.breadcrumb-hero .breadcrumb {
    justify-content: center;
    background: none;
    padding: 0;
    margin: 0;
}
.breadcrumb-hero .breadcrumb-item,
.breadcrumb-hero .breadcrumb-item a {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.5px;
    color: rgba(255,255,255,0.7);
    text-decoration: none;
}
.breadcrumb-hero .breadcrumb-item a:hover {
    color: #C6A46C;
}
.breadcrumb-hero .breadcrumb-item.active {
    color: rgba(255,255,255,0.95);
}
.breadcrumb-hero .breadcrumb-item + .breadcrumb-item::before {
    color: rgba(255,255,255,0.5);
    content: "›";
    font-size: 0.9rem;
}

/* Variante standalone : après le header, à gauche, avec icône */
.breadcrumb-bar {
    padding: 0.85rem 0;
    background: #F4EFEA;
}
.breadcrumb-bar .breadcrumb {
    background: none;
    padding: 0;
    margin: 0;
    align-items: center;
}
.breadcrumb-bar .breadcrumb-icon {
    color: #C6A46C;
    font-size: 0.85rem;
    margin-right: 0.5rem;
}
.breadcrumb-bar .breadcrumb-item,
.breadcrumb-bar .breadcrumb-item a {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.5px;
    color: #A79A92;
    text-decoration: none;
}
.breadcrumb-bar .breadcrumb-item a:hover {
    color: #C6A46C;
}
.breadcrumb-bar .breadcrumb-item.active {
    color: #4E4743;
}
.breadcrumb-bar .breadcrumb-item + .breadcrumb-item::before {
    color: #D8C9BE;
    content: "›";
    font-size: 0.9rem;
}


/* ═══════════════════════════════════════════════════════════
   §19 - PAGE LES SOINS : RESTRUCTURATION CDC
   Sous-nav, Parcours immersifs, Soins à la carte, Abonnements
   ═══════════════════════════════════════════════════════════ */

/* --- 19a. Sous-navigation sticky --- */
.soins-subnav-wrapper {
    padding: 1rem 0;
    background: #fff;
    z-index: 990;
    transition: box-shadow 0.3s ease, background 0.3s ease;
}
.soins-subnav-wrapper.is-stuck {
    position: fixed;
    top: 70px;
    left: 0;
    width: 100%;
    background: rgba(255,255,255,0.97);
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.soins-subnav {
    display: flex;
    justify-content: center;
    gap: 2rem;
    flex-wrap: wrap;
}
.subnav-link {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 0.85rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #4E4743;
    padding: 0.5rem 1.5rem;
    border: 1px solid #D8C9BE;
    border-radius: 30px;
    transition: all 0.3s ease;
    text-decoration: none;
}
.subnav-link:hover,
.subnav-link.active {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
}


/* --- 19b. Section Parcours Signature - blocs immersifs --- */
.parcours-section {
    background-color: #F4EFEA;
}

/* Card commune */
.parcours-card {
    position: relative;
    overflow: hidden;
    border-radius: 6px;
}
.parcours-card__img {
    width: 100%;
    height: 100%;
}
.parcours-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.8s ease;
}
.parcours-card:hover .parcours-card__img img {
    transform: scale(1.05);
}
.parcours-card__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(78,71,67,0.1) 0%, rgba(78,71,67,0.75) 100%);
    z-index: 1;
}
.parcours-card__content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 2.5rem;
    z-index: 2;
    color: #fff;
}

/* HERO card - pleine largeur */
.parcours-card--hero {
    height: 520px;
}
.parcours-card--hero .parcours-card__content {
    max-width: 700px;
}
.parcours-card--hero .parcours-card__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.4rem;
    font-weight: 400;
    margin-bottom: 0.75rem;
    color: #fff;
}
.parcours-card--hero .parcours-card__desc {
    font-size: 1rem;
    line-height: 1.7;
    opacity: 0.92;
    margin-bottom: 1rem;
    color: #fff;
}

/* GRID cards - 2 colonnes */
.parcours-card--grid {
    height: 420px;
}
.parcours-card--grid .parcours-card__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem;
    font-weight: 400;
    margin-bottom: 0.5rem;
    color: #fff;
}
.parcours-card--grid .parcours-card__desc {
    font-size: 0.92rem;
    line-height: 1.6;
    opacity: 0.9;
    margin-bottom: 0.75rem;
    color: #fff;
}
.parcours-card--grid .parcours-card__content {
    padding: 2rem;
}

/* Badge */
.parcours-card__badge {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    background: #C6A46C;
    color: #fff;
    padding: 0.35rem 1rem;
    border-radius: 20px;
    margin-bottom: 0.75rem;
}

/* Meta : durée + prix */
.parcours-card__meta {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-top: 0.5rem;
}
.parcours-card__duration {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.85rem;
    opacity: 0.85;
}
.parcours-card__duration .flaticon-clock {
    margin-right: 4px;
}
.parcours-card__price {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: #C6A46C;
}

/* Boutons dans les cards */
.parcours-card .btn--gold {
    background: #C6A46C;
    color: #fff;
    border: 1px solid #C6A46C;
    padding: 0.6rem 1.8rem;
    font-size: 0.8rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    border-radius: 0;
}
.parcours-card .btn--gold:hover {
    background: transparent;
    color: #fff;
    border-color: #fff;
}
.parcours-card .btn--tra-white {
    border: 1px solid rgba(255,255,255,0.6);
    color: #fff;
    padding: 0.5rem 1.5rem;
    font-size: 0.75rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    border-radius: 0;
    background: transparent;
}
.parcours-card .btn--tra-white:hover,
.parcours-card .btn--tra-white.hover--gold:hover {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
}


/* --- 19c. Soins à la carte --- */
.soins-carte-section {
    background: #F4EFEA;
}

/* Bannières catégorie avec image */
.carte-category__banner {
    position: relative;
    overflow: hidden;
    border-radius: 6px;
    height: 180px;
}
.carte-category__banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.carte-category__banner-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(78,71,67,0.15) 0%, rgba(78,71,67,0.55) 100%);
    display: flex;
    align-items: flex-end;
    padding: 1.5rem 2rem;
}
.carte-category__banner-overlay .carte-category__title {
    color: #fff;
    margin-bottom: 0;
    font-size: 1.8rem;
}
.carte-category__banner-overlay .carte-category__title span[class^="flaticon-"] {
    color: #C6A46C;
}

.carte-category__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.6rem;
    font-weight: 400;
    color: #4E4743;
    letter-spacing: 1px;
}
.carte-category__title span[class^="flaticon-"] {
    color: #C6A46C;
    margin-right: 8px;
    font-size: 1.2rem;
}


/* --- 19d. Abonnements --- */
.abonnements-section {
    background: #F4EFEA;
}
.abo-card {
    padding: 1rem 1.25rem;
    background: #fff;
    border-radius: 6px;
    border-left: 3px solid #C6A46C;
}
.abo-card__icon .flaticon-natural-product,
.abo-card__icon .flaticon-lotus,
.abo-card__icon .flaticon-gift {
    color: #C6A46C;
}
.abo-card__txt h5 {
    font-family: 'Cormorant Garamond', serif;
    color: #4E4743;
}
.abo-card__txt p {
    font-size: 0.92rem;
    color: #6c6c6c;
    margin-bottom: 0;
}
.abo-card__txt strong {
    color: #C6A46C;
    font-weight: 600;
}


/* --- 19e. Responsive Parcours + Subnav --- */
@media (max-width: 991.98px) {
    .soins-subnav-wrapper.is-stuck {
        top: 70px;
    }
    .parcours-card--hero {
        height: 400px;
    }
    .parcours-card--hero .parcours-card__title {
        font-size: 1.8rem;
    }
    .parcours-card--grid {
        height: 360px;
    }
    .soins-subnav {
        gap: 0.75rem;
    }
    .subnav-link {
        font-size: 0.75rem;
        padding: 0.4rem 1rem;
    }
    .carte-category__banner {
        height: 140px;
    }
}
@media (max-width: 575.98px) {
    .soins-subnav-wrapper.is-stuck {
        top: 60px;
    }
    .parcours-card--hero {
        height: 480px;
    }
    .parcours-card--hero .parcours-card__content {
        padding: 1.5rem;
    }
    .parcours-card--hero .parcours-card__title {
        font-size: 1.5rem;
    }
    .parcours-card--grid {
        height: 380px;
    }
    .parcours-card--grid .parcours-card__content {
        padding: 1.25rem;
    }
    .parcours-card__meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
    }
    .soins-subnav {
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
    }
    .carte-category__banner {
        height: 120px;
    }
    .carte-category__banner-overlay {
        padding: 1rem 1.25rem;
    }
    .carte-category__banner-overlay .carte-category__title {
        font-size: 1.4rem;
    }
}


/* --- 19f. Parcours - sous-titres et tarifs multiples --- */
.parcours-card__subtitle {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.5px;
    opacity: 0.85;
    color: #fff;
    margin-bottom: 0.75rem;
}
.parcours-card__tarifs {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 0.75rem;
}
.parcours-card__tarif-item {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.82rem;
    color: #fff;
    opacity: 0.9;
}
.parcours-card__tarif-item strong {
    font-weight: 600;
    color: #C6A46C;
    font-size: 1.1rem;
}
@media (max-width: 575.98px) {
    .parcours-card__tarifs {
        flex-direction: column;
        gap: 0.25rem;
    }
}


/* --- 19g. Abonnements page - cartes premium --- */
.abonnements-page-section {
    background: #F4EFEA;
}
.abo-page-card {
    background: #fff;
    border-radius: 8px;
    padding: 2.5rem 1.5rem 2rem;
    height: 100%;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid rgba(216,201,190,0.4);
    display: flex;
    flex-direction: column;
    align-items: center;
}
.abo-page-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 32px rgba(78,71,67,0.1);
}
.abo-page-card--featured {
    background: #4E4743;
    border-color: #4E4743;
    color: #fff;
}
.abo-page-card--featured .abo-page-card__title,
.abo-page-card--featured .abo-page-card__details p {
    color: #fff;
}
.abo-page-card--featured .abo-page-card__amount {
    color: #fff;
}
.abo-page-card--featured .abo-page-card__period {
    color: rgba(255,255,255,0.7);
}
.abo-page-card__badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: #C6A46C;
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 0.3rem 1rem;
    border-radius: 20px;
    white-space: nowrap;
}
.abo-page-card__icon {
    margin-bottom: 1.25rem;
}
.abo-page-card__icon span[class^="flaticon-"] {
    color: #C6A46C;
}
.abo-page-card--featured .abo-page-card__icon span[class^="flaticon-"] {
    color: #fff;
}
.abo-page-card__title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.6rem;
    font-weight: 400;
    color: #4E4743;
    margin-bottom: 0.75rem;
}
.abo-page-card__price {
    margin-bottom: 1.25rem;
}
.abo-page-card__amount {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.4rem;
    font-weight: 600;
    color: #C6A46C;
    line-height: 1;
}
.abo-page-card__period {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.85rem;
    color: #A79A92;
}
.abo-page-card__details {
    margin-bottom: 1.5rem;
    flex-grow: 1;
}
.abo-page-card__details p {
    font-size: 0.92rem;
    color: #6c6c6c;
    margin-bottom: 0.25rem;
}
@media (max-width: 767.98px) {
    .abo-page-card {
        padding: 2rem 1.25rem 1.5rem;
    }
    .abo-page-card__amount {
        font-size: 2rem;
    }
}

/* Carte abonnement solo (seule carte affichée) */
.abo-page-card--solo {
    padding: 3rem 2.5rem 2.5rem;
}
.abo-page-card--solo .abo-page-card__title {
    font-size: 2rem;
    margin-bottom: 0.5rem;
}
.abo-page-card--solo .abo-page-card__amount {
    font-size: 3rem;
}
.abo-page-card--solo .abo-page-card__details {
    border-top: 1px solid rgba(216,201,190,0.4);
    padding-top: 1.25rem;
    margin-top: 0.5rem;
}
.abo-page-card--solo .abo-page-card__details p {
    display: inline;
}
.abo-page-card--solo .abo-page-card__details p + p::before {
    content: ' · ';
    color: #C6A46C;
    font-weight: 600;
}

/* Sous-titre carte abonnement */
.abo-page-card__subtitle {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.9rem;
    font-weight: 500;
    color: #C6A46C;
    margin-bottom: 1rem;
    letter-spacing: 0.02em;
}
.abo-page-card--featured .abo-page-card__subtitle {
    color: #E7DED3;
}

/* Ligne avantages abonnements homepage */
.abo-avantages-line {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.8rem;
    font-weight: 500;
    color: #A79A92;
    letter-spacing: 0.04em;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
    margin: 0;
}
.abo-avantages-line span {
    white-space: nowrap;
}


.soin-card h5 {
    color: #4E4743;
}
.soin-card p {
    font-size: 0.875rem;
    color: #A79A92;
}
.soin-card-price {
    font-family: 'Montserrat', sans-serif;
    color: #C6A46C;
    font-size: 1rem;
}

/* -----------------------------------------------------------
   18e. PAGE JOURNAL - Blog styles
   ----------------------------------------------------------- */

.blog-post-txt .post-tag {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #C6A46C;
    display: block;
    margin-bottom: 0.5rem;
}

.blog-post-txt h4 a,
.blog-post-txt h5 a {
    color: #4E4743;
    transition: color 0.3s ease;
}
.blog-post-txt h4 a:hover,
.blog-post-txt h5 a:hover {
    color: #C6A46C;
}

.blog-post-txt .read-more {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #C6A46C;
    border-bottom: 1px solid transparent;
    transition: border-color 0.3s ease;
}
.blog-post-txt .read-more:hover {
    border-bottom-color: #C6A46C;
}

.blog-post-img {
    overflow: hidden;
    border-radius: 4px;
}
.blog-post-img img {
    border-radius: 4px;
    width: 100%;
    height: 580px;
    object-fit: cover;
    transition: transform 0.6s ease;
}
.blog-section .blog-post-img img{
    height: 340px;
}
.blog-post:hover .blog-post-img img {
    transform: scale(1.03);
}
.featured-post .blog-post-img img {
    height: 380px;
}

/* Sidebar */
.blog-sidebar .sidebar-widget h5 {
    font-family: 'Cormorant Garamond', serif;
    color: #4E4743;
}

.blog-category-list {
    list-style: none;
    padding-left: 0;
}
.blog-category-list li {
    padding: 0.5rem 0;
    border-bottom: 1px solid #E7DED3;
}
.blog-category-list li a {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.875rem;
    color: #4E4743;
    transition: color 0.3s ease;
}
.blog-category-list li a:hover {
    color: #C6A46C;
}

.sidebar-newsletter {
    background: #E7DED3;
    padding: 1.5rem;
    border-radius: 4px;
}
.sidebar-newsletter .form-control {
    border: 1px solid #D8C9BE;
    background: #F4EFEA;
    font-size: 0.875rem;
}

/* -----------------------------------------------------------
   18e-2. SINGLE POST - Article détail
   ----------------------------------------------------------- */

.single-post-header .post-tag {
    margin-bottom: 1rem;
}
.single-post-header .h2-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.2rem;
    font-weight: 400;
    color: #4E4743;
    line-height: 1.3;
}
.single-post-img img {
    border-radius: 6px;
    width: 100%;
    height: auto;
}
.single-post-txt p {
    margin-bottom: 1.25rem;
}
.single-post-txt .h4-md {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem;
    font-weight: 500;
    color: #4E4743;
    margin-top: 2rem;
    margin-bottom: 1rem;
}
.single-post-txt .simple-list {
    list-style: none;
    padding-left: 0;
    margin-bottom: 1.5rem;
}
.single-post-txt .simple-list .list-item {
    position: relative;
    padding-left: 1.25rem;
    margin-bottom: 0.5rem;
}
.single-post-txt .simple-list .list-item::before {
    content: '-';
    position: absolute;
    left: 0;
    color: #C6A46C;
}
.single-post-txt .simple-list .list-item p {
    margin-bottom: 0;
}
.post-inner-img img {
    border-radius: 4px;
    width: 100%;
}

/* -----------------------------------------------------------
   18e-3. SINGLE POST — Composants éditoriaux GEO
   (TL;DR, phrases-réponses, tableaux, FAQ, encadré "À lire aussi")
   Compatibles avec un copier-coller du HTML dans l'éditeur WordPress.
   ----------------------------------------------------------- */

/* Bloc TL;DR (résumé en tête d'article) */
.single-post-txt .tldr,
.single-post-txt aside.tldr {
    background: #E7DED3;
    border-left: 4px solid #C6A46C;
    padding: 1.25rem 1.5rem;
    margin: 1.5rem 0 2rem;
    border-radius: 2px;
    font-size: 0.95rem;
}
.single-post-txt .tldr > strong:first-child {
    display: block;
    color: #4E4743;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 0.78rem;
    font-weight: 600;
    margin-bottom: 0.6rem;
    font-family: 'Montserrat', sans-serif;
}
.single-post-txt .tldr ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}
.single-post-txt .tldr ul li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: 0.4rem;
}
.single-post-txt .tldr ul li::before {
    content: '·';
    color: #C6A46C;
    position: absolute;
    left: 0;
    font-weight: 700;
}

/* Phrase-réponse (Answer-First — début de chaque H2) */
.single-post-txt .answer {
    font-style: italic;
    color: #4E4743;
    border-left: 2px solid #C6A46C;
    padding: 0.4rem 0 0.4rem 1rem;
    margin: 0.5rem 0 1.25rem;
    font-size: 1.05rem;
    line-height: 1.65;
}

/* Tableaux comparatifs (prix, prestations, équipe) */
.single-post-txt table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.25rem 0 1.75rem;
    background: #FFFFFF;
    font-size: 0.95rem;
    box-shadow: 0 1px 0 rgba(78, 71, 67, 0.04);
}
.single-post-txt table th,
.single-post-txt table td {
    padding: 0.75rem 1rem;
    text-align: left;
    border-bottom: 1px solid #E7DED3;
    vertical-align: top;
}
.single-post-txt table th {
    background: #D8C9BE;
    color: #4E4743;
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.85rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}
.single-post-txt table tr:last-child td {
    border-bottom: none;
}
.single-post-txt table tr:hover td {
    background: #F4EFEA;
}

/* Citations / blockquote dans l'article */
.single-post-txt blockquote {
    border-left: 3px solid #C6A46C;
    padding: 0.5rem 0 0.5rem 1.25rem;
    margin: 1.5rem 0;
    color: #A79A92;
    font-style: italic;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem;
    line-height: 1.6;
}

/* H2 / H3 dans le contenu de l'article */
.single-post-txt h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.85rem;
    font-weight: 500;
    color: #4E4743;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    line-height: 1.3;
}
.single-post-txt h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem;
    font-weight: 500;
    color: #A79A92;
    margin-top: 1.75rem;
    margin-bottom: 0.75rem;
    line-height: 1.35;
}

/* Listes à puces standard */
.single-post-txt ul:not(.simple-list):not(.tldr ul) {
    padding-left: 1.25rem;
    margin-bottom: 1.25rem;
}
.single-post-txt ul:not(.simple-list):not(.tldr ul) li {
    margin-bottom: 0.4rem;
}

/* Encadré "À lire aussi" en fin d'article */
.single-post-txt .related,
.single-post-txt aside.related {
    background: #FFFFFF;
    border: 1px solid #E7DED3;
    padding: 1.25rem 1.5rem;
    margin-top: 2.5rem;
    border-radius: 2px;
}
.single-post-txt .related h3 {
    margin-top: 0;
    margin-bottom: 0.75rem;
    color: #C6A46C;
    font-size: 1.2rem;
}
.single-post-txt .related ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}
.single-post-txt .related ul li {
    padding: 0.35rem 0;
    border-bottom: 1px dotted #E7DED3;
}
.single-post-txt .related ul li:last-child {
    border-bottom: none;
}
.single-post-txt .related ul li a {
    color: #4E4743;
    transition: color 0.3s ease;
}
.single-post-txt .related ul li a:hover {
    color: #C6A46C;
}

/* Responsive : tableaux scrollables sur mobile */
@media (max-width: 600px) {
    .single-post-txt table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
    .single-post-txt .tldr {
        padding: 1rem 1.1rem;
        font-size: 0.9rem;
    }
    .single-post-txt h2 { font-size: 1.55rem; }
    .single-post-txt h3 { font-size: 1.2rem; }
}

/* Tags */
.single-post-tags span {
    display: inline-block;
    margin: 0 0.25rem 0.5rem;
}
.single-post-tags span a {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #4E4743;
    padding: 0.4rem 1rem;
    border: 1px solid #D8C9BE;
    border-radius: 20px;
    transition: all 0.3s ease;
}
.single-post-tags span a:hover {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
}

/* Share */
.single-post-share {
    border-top: 1px solid #E7DED3;
    padding-top: 1.5rem;
}
.share-social-icons {
    list-style: none;
    padding: 0;
    display: flex;
    justify-content: center;
    gap: 1rem;
}
.share-social-icons li a {
    color: #4E4743;
    transition: color 0.3s ease;
}
.share-social-icons li a:hover {
    color: #C6A46C;
}

/* Related posts */
.related-posts {
    border-top: 1px solid #E7DED3;
}
.related-posts .blog-post-img img {
    height: 220px;
}

/* -----------------------------------------------------------
   18e-4. SINGLE POST — Adaptation Gutenberg (blocs natifs WP)
   Le copier-coller via l'éditeur Gutenberg transforme le HTML en blocs
   natifs : .wp-block-list, .wp-block-table, .wp-block-quote,
   .wp-block-heading. Cette section restitue le rendu éditorial GEO.
   ----------------------------------------------------------- */

/* Titres Gutenberg : harmonisation avec h2/h3 du thème */
.single-post-txt h2.wp-block-heading {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.85rem;
    font-weight: 500;
    color: #4E4743;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    line-height: 1.3;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid #D8C9BE;
}
.single-post-txt h3.wp-block-heading {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem;
    font-weight: 500;
    color: #A79A92;
    margin-top: 1.75rem;
    margin-bottom: 0.75rem;
    line-height: 1.35;
}

/* TL;DR détecté : <p><strong>En bref</strong></p> + <ul class="wp-block-list"> */
.single-post-txt p:has(> strong:only-child) {
    display: block;
    color: #4E4743;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-size: 0.78rem;
    font-weight: 600;
    font-family: 'Montserrat', sans-serif;
    background: #E7DED3;
    border-left: 4px solid #C6A46C;
    padding: 1rem 1.5rem 0.5rem;
    margin: 1.5rem 0 0;
    border-radius: 2px 2px 0 0;
}
.single-post-txt p:has(> strong:only-child) + ul.wp-block-list {
    background: #E7DED3;
    border-left: 4px solid #C6A46C;
    padding: 0.25rem 1.5rem 1.25rem 2.25rem;
    margin: 0 0 2rem;
    border-radius: 0 0 2px 2px;
    list-style: none;
    font-family: 'Montserrat', sans-serif;
    text-transform: none;
    letter-spacing: normal;
    font-size: 0.95rem;
    font-weight: 400;
    color: #4E4743;
}
.single-post-txt p:has(> strong:only-child) + ul.wp-block-list li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: 0.4rem;
    list-style: none;
}
.single-post-txt p:has(> strong:only-child) + ul.wp-block-list li::before {
    content: '·';
    color: #C6A46C;
    position: absolute;
    left: 0;
    font-weight: 700;
}

/* Phrase-réponse (Answer-First) : 1er <p> après chaque H2 Gutenberg */
.single-post-txt h2.wp-block-heading + p {
    font-style: italic;
    color: #4E4743;
    border-left: 2px solid #C6A46C;
    padding: 0.4rem 0 0.4rem 1rem;
    margin: 0.75rem 0 1.25rem;
    font-size: 1.05rem;
    line-height: 1.65;
    background: rgba(244, 239, 234, 0.5);
}

/* Tableaux Gutenberg */
.single-post-txt figure.wp-block-table {
    margin: 1.5rem 0 2rem;
    overflow-x: auto;
}
.single-post-txt figure.wp-block-table table,
.single-post-txt figure.wp-block-table table.has-fixed-layout {
    width: 100%;
    border-collapse: collapse;
    background: #FFFFFF;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.95rem;
    box-shadow: 0 1px 0 rgba(78, 71, 67, 0.04);
    table-layout: auto;
}
.single-post-txt figure.wp-block-table thead {
    background: #C6A46C;
}
.single-post-txt figure.wp-block-table thead th {
    color: #FFFFFF;
    font-weight: 500;
    text-align: left;
    padding: 0.85rem 1rem;
    font-size: 0.85rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border: none;
}
.single-post-txt figure.wp-block-table tbody td {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #E7DED3;
    color: #4E4743;
    vertical-align: top;
}
.single-post-txt figure.wp-block-table tbody tr:last-child td {
    border-bottom: none;
}
.single-post-txt figure.wp-block-table tbody tr:hover td {
    background: #F4EFEA;
}

/* Citations Gutenberg */
.single-post-txt .wp-block-quote,
.single-post-txt blockquote.wp-block-quote {
    background: #F4EFEA;
    border-left: 4px solid #C6A46C;
    padding: 1.25rem 1.75rem;
    margin: 1.75rem 0;
    border-radius: 2px;
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 1.2rem;
    line-height: 1.6;
    color: #4E4743;
}
.single-post-txt .wp-block-quote p {
    margin: 0;
    color: #4E4743;
}

/* Listes Gutenberg classiques (hors TL;DR) */
.single-post-txt ul.wp-block-list {
    padding-left: 1.5rem;
    margin: 1rem 0 1.5rem;
}
.single-post-txt ul.wp-block-list li {
    margin-bottom: 0.5rem;
    line-height: 1.65;
}
.single-post-txt ul.wp-block-list li::marker {
    color: #C6A46C;
}

/* Responsive Gutenberg */
@media (max-width: 600px) {
    .single-post-txt h2.wp-block-heading { font-size: 1.55rem; }
    .single-post-txt h3.wp-block-heading { font-size: 1.2rem; }
    .single-post-txt figure.wp-block-table table { font-size: 0.85rem; }
    .single-post-txt figure.wp-block-table thead th,
    .single-post-txt figure.wp-block-table tbody td { padding: 0.55rem 0.7rem; }
    .single-post-txt .wp-block-quote { font-size: 1.05rem; padding: 1rem 1.25rem; }
}

/* -----------------------------------------------------------
   18f. PAGE CONTACT - Form + Info
   ----------------------------------------------------------- */
.contact-form .wpcf7-form-control.form-select,
.contact-form select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%234E4743' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 14px;
    padding-right: 2.5rem;
}
.google-map iframe {
    display: block;
    width: 100%;
}

.contact-info-block .cbox-ico span {
    color: #C6A46C;
}
.contact-info-block h5 {
    font-family: 'Cormorant Garamond', serif;
    color: #4E4743;
        margin-bottom: 15px;
}

.contact-form .form-control,
.contact-form .form-select {
    border: 1px solid #D8C9BE;
    background: #F4EFEA;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.875rem;
    color: #4E4743;
    padding: 0.75rem 1rem;
    border-radius: 2px;
    transition: border-color 0.3s ease;
}
.contact-form .form-control:focus,
.contact-form .form-select:focus {
    border-color: #C6A46C;
    box-shadow: 0 0 0 0.15rem rgba(198, 164, 108, 0.15);
}
.contact-form .form-label {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.8125rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #4E4743;
}

.contact-socials .foo-socials li a span {
    color: #4E4743;
    transition: color 0.3s ease;
}
.contact-socials .foo-socials li a:hover span {
    color: #C6A46C;
}
.wpcf7 form.wpcf7-form {
  display: flex;
  flex-direction: column;
}

.wpcf7 form.wpcf7-form > .row {
  order: 1;
}

.wpcf7 form.wpcf7-form > .wpcf7-turnstile {
  order: 2;
  margin-top: 12px;
  margin-bottom: 12px;
}

.wpcf7 form.wpcf7-form > .wpcf7-response-output {
  order: 3;
}


/* =============================================================
   §20 — BOUTIQUE & PANIER
   ============================================================= */

/* -----------------------------------------------------------
   20a. HERO BOUTIQUE
   ----------------------------------------------------------- */
#boutique-page {
    background: url(../images/hero-5-1.jpg) center center / cover no-repeat;
}

/* -----------------------------------------------------------
   20b. ICÔNE PANIER (Nav)
   ----------------------------------------------------------- */
.cart-trigger {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.cart-trigger .flaticon-shopping-bag:before {
    font-size: 18px;
}

.left-column .img-fluid{
    height: 930px;
    object-fit: cover;
}

/* Icône Mon Compte (SVG inline) */
.account-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.account-trigger .account-icon {
    width: 20px;
    height: 20px;
    stroke: currentColor;
    transition: opacity .2s ease;
}
.account-trigger:hover .account-icon {
    opacity: .75;
}
.cart-count {
    position: absolute;
    top: 15px;
    right: 0;
    background: #C6A46C;
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    font-family: 'Montserrat', sans-serif;
    text-align: center;
    line-height: 18px;
    padding: 0 !important;
}

/* -----------------------------------------------------------
   20c. PANIER LATÉRAL (Side Cart)
   ----------------------------------------------------------- */
.cart-overlay {
    position: fixed;
    inset: 0;
    background: rgba(78,71,67,.5);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: opacity .35s ease, visibility .35s ease;
}
.cart-overlay.open {
    opacity: 1;
    visibility: visible;
}

.side-cart {
    position: fixed;
    top: 0;
    right: 0;
    width: 400px;
    max-width: 90vw;
    height: 100%;
    background: #fff;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
    box-shadow: -4px 0 30px rgba(0,0,0,.12);
}
.side-cart.open {
    transform: translateX(0);
}
body.cart-open {
    overflow: hidden;
}

.side-cart__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid #E7DED3;
}
.side-cart__header h5 {
    margin: 0;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    color: #4E4743;
    letter-spacing: .08em;
}
.side-cart__close {
    background: none;
    border: none;
    font-size: 1.75rem;
    color: #4E4743;
    cursor: pointer;
    line-height: 1;
    padding: 0;
}
.side-cart__close:hover { color: #C6A46C; }

.side-cart__body {
    flex: 1;
    overflow-y: auto;
    padding: 1.25rem 1.5rem;
}

.side-cart__item {
    display: flex;
    gap: .75rem;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid #F4EFEA;
    position: relative;
}
.side-cart__item-img {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: 4px;
    flex-shrink: 0;
}
.side-cart__item-info {
    flex: 1;
    min-width: 0;
}
.side-cart__item-title {
    font-size: .875rem;
    margin-bottom: .35rem;
    color: #4E4743;
}
.side-cart__item-price {
    font-weight: 500;
    color: #C6A46C;
    font-size: .875rem;
}
.side-cart__item-qty {
    display: inline-flex;
    align-items: center;
    gap: 0;
    margin-bottom: .35rem;
}
.side-cart__item-remove {
    position: absolute;
    top: 0;
    right: 0;
    background: none;
    border: none;
    color: #A79A92;
    font-size: 1.25rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}
.side-cart__item-remove:hover { color: #C6A46C; }

/* Quantity buttons (shared) */
.quantity {
    display: inline-flex;
    align-items: center;
}
.qty-btn {
    width: 36px;
    height: 36px;
    border: 1px solid #E7DED3;
    background: #fff;
    color: #4E4743;
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .25s ease;
    flex-shrink: 0;
    line-height: 1;
    padding: 0;
}
.qty-btn:hover { border-color: #C6A46C; color: #C6A46C; }
.qty-input {
    width: 44px;
    height: 36px;
    border: 1px solid #E7DED3;
    border-left: 0;
    border-right: 0;
    text-align: center;
    font-size: .875rem;
    font-family: 'Montserrat', sans-serif;
    color: #4E4743;
    background: #fff;
    -moz-appearance: textfield;
    padding: 0;
}
.qty-input::-webkit-inner-spin-button,
.qty-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Smaller qty in side-cart */
.side-cart__item-qty .qty-btn {
    width: 26px;
    height: 26px;
    font-size: .8125rem;
}
.side-cart__item-qty .qty-input {
    width: 32px;
    height: 26px;
    font-size: .75rem;
}

.side-cart__footer {
    padding: 1.25rem 1.5rem;
    border-top: 1px solid #E7DED3;
    background: #F4EFEA;
}
.side-cart__subtotal {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    color: #4E4743;
}
.side-cart__subtotal-amount { color: #C6A46C; font-size: 1.1rem; }

.side-cart__empty {
    text-align: center;
    padding: 3rem 1rem;
}
.side-cart__empty-icon:before {
    font-size: 48px;
    color: #D8C9BE;
    display: block;
    margin-bottom: 1rem;
}

/* -----------------------------------------------------------
   20d. BOUTIQUE — SIDEBAR
   ----------------------------------------------------------- */
.shop-search-form{
    display: flex;
}
.shop-sidebar { padding-right: 2rem; }
.shop-sidebar__close { display: none; }
.mobile-filter-btn { display: none; }
.filter-overlay { display: none; }

.shop-widget__title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.125rem;
    font-weight: 600;
    color: #4E4743;
    letter-spacing: .06em;
    padding-bottom: .75rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid #E7DED3;
}

/* Search */
.shop-search-form .form-control {
    border: 1px solid #E7DED3;
    border-right: none;
    font-size: .8125rem;
    padding: .5rem .75rem;
    background: #fff;
}
.shop-search-form .form-control:focus {
    border-color: #C6A46C;
    box-shadow: none;
}
.shop-search-form .btn {
    border-radius: 0 .375rem .375rem 0;
    padding: .5rem .75rem;
}

/* Filter list (categories) */
.shop-filter-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.shop-filter-list li {
    padding: .4rem 0;
    font-size: .875rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.shop-filter-list li a {
    color: #4E4743;
    transition: color .25s ease;
}
.shop-filter-list li a:hover,
.shop-filter-list li.active a {
    color: #C6A46C;
}
.shop-filter-list .count {
    font-size: .75rem;
    color: #A79A92;
}

/* Price slider — dual range */
.dual-range {
    position: relative;
    height: 30px;
    display: flex;
    align-items: center;
}
.dual-range__track {
    position: absolute;
    left: 0;
    right: 0;
    height: 4px;
    background: #E7DED3;
    border-radius: 2px;
    pointer-events: none;
}
.dual-range__fill {
    position: absolute;
    height: 4px;
    background: #C6A46C;
    border-radius: 2px;
    pointer-events: none;
}
.dual-range__input {
    position: absolute;
    width: 100%;
    margin: 0;
    pointer-events: none;
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
    height: 4px;
}
.dual-range__input::-webkit-slider-thumb {
    -webkit-appearance: none;
    pointer-events: all;
    width: 18px;
    height: 18px;
    margin-top: -7px;
    border-radius: 50%;
    background: #C6A46C;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(78,71,67,.25);
    cursor: pointer;
    position: relative;
    z-index: 2;
}
.dual-range__input::-moz-range-thumb {
    pointer-events: all;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #C6A46C;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(78,71,67,.25);
    cursor: pointer;
}
.dual-range__input::-webkit-slider-runnable-track {
    background: transparent;
}
.dual-range__input::-moz-range-track {
    background: transparent;
}
.dual-range .thumb {
    display: none;
}
.price-range-labels {
    display: flex;
    justify-content: space-between;
    font-size: .8125rem;
    color: #4E4743;
    margin-top: .25rem;
}

/* Select */
.shop-orderby {
    border: 1px solid #E7DED3;
    font-size: .8125rem;
    color: #4E4743;
    padding: .5rem .75rem;
}
.shop-orderby:focus {
    border-color: #C6A46C;
    box-shadow: none;
}

/* Tags */
.shop-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.shop-tag {
    display: inline-block;
    padding: .25rem .75rem;
    border: 1px solid #E7DED3;
    border-radius: 20px;
    font-size: .75rem;
    font-family: 'Montserrat', sans-serif;
    color: #4E4743;
    transition: all .25s ease;
}
.shop-tag:hover {
    border-color: #C6A46C;
    color: #C6A46C;
    background: rgba(198,164,108,.08);
}

/* -----------------------------------------------------------
   20e. BOUTIQUE — TOOLBAR & PRODUCT GRID
   ----------------------------------------------------------- */
.shop-toolbar {
    padding-bottom: 1rem;
    border-bottom: 1px solid #E7DED3;
}
.woocommerce-result-count {
    font-size: .8125rem;
    color: #A79A92;
}
.view-btn {
    background: none;
    border: 1px solid #E7DED3;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: .25rem;
    cursor: pointer;
    transition: all .25s ease;
    color: #A79A92;
}
.view-btn.active,
.view-btn:hover {
    border-color: #C6A46C;
    color: #C6A46C;
}

/* Product Card */
.product-card {
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    transition: box-shadow .35s ease, transform .35s ease;
}
.product-card:hover {
    box-shadow: 0 8px 30px rgba(78,71,67,.1);
    transform: translateY(-4px);
}
.product-card__image {
    position: relative;
    overflow: hidden;
    aspect-ratio: 3/4;
}
.product-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.product-card:hover .product-card__img {
    transform: scale(1.05);
}

/* Badges */
.product-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: .2rem .65rem;
    font-size: .7rem;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    border-radius: 3px;
    z-index: 2;
}
.product-badge.new {
    background: #C6A46C;
    color: #fff;
}
.product-badge.onsale {
    background: #C6AFA6;
    color: #fff;
}

/* Action buttons on hover */
.product-card__actions {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    gap: .5rem;
    padding: .75rem;
    background: linear-gradient(transparent, rgba(78,71,67,.4));
    transform: translateY(100%);
    transition: transform .35s ease;
}
.product-card:hover .product-card__actions {
    transform: translateY(0);
}
.action-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all .25s ease;
    color: #4E4743;
}
.action-btn:hover {
    background: #C6A46C;
    color: #fff;
}
.action-btn.added {
    background: #C6A46C;
    color: #fff;
}
.action-btn span[class^="flaticon-"]:before {
    font-size: 16px;
}

/* Product Info */
.product-card__info {
    padding: 1rem 1.25rem 1.25rem;
}
.product-card__cat {
    display: block;
    font-size: .7rem;
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #A79A92;
    margin-bottom: .25rem;
}
.product-card__title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.05rem;
    font-weight: 600;
    margin-bottom: .4rem;
}
.product-card__title a {
    color: #4E4743;
    transition: color .25s ease;
}
.product-card__title a:hover { color: #C6A46C; }

.product-card__price {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    color: #C6A46C;
    font-size: .95rem;
}
.product-card__price del {
    color: #A79A92;
    font-weight: 300;
    margin-right: .4rem;
    font-size: .85rem;
}
.product-card__price ins {
    text-decoration: none;
    color: #C6A46C;
    font-weight: 500;
}

/* Pagination */
.shop-pagination {
    margin-top: 2rem;
    text-align: center;
}
.shop-pagination .page-numbers {
    display: flex;
    justify-content: center;
    gap: .5rem;
    list-style: none;
    padding: 0;
    margin: 0;
}
.shop-pagination .page-numbers li a,
.shop-pagination .page-numbers li span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid #E7DED3;
    border-radius: 4px;
    font-size: .875rem;
    font-family: 'Montserrat', sans-serif;
    color: #4E4743;
    transition: all .25s ease;
}
.shop-pagination .page-numbers li a:hover,
.shop-pagination .page-numbers li span.current {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
}

/* -----------------------------------------------------------
   20f. SINGLE PRODUCT
   ----------------------------------------------------------- */

/* Gallery */
.product-gallery__main { border-radius: 6px; overflow: hidden; }
.product-gallery__main-img {
    width: 100%;
    height: 500px;
    object-fit: cover;
}
.product-gallery__thumb {
    width: 80px;
    height: 80px;
    border-radius: 4px;
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    transition: border-color .25s ease;
}
.product-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.product-gallery__thumb.active,
.product-gallery__thumb:hover {
    border-color: #C6A46C;
}

/* Summary */
.product-summary__cat {
    display: block;
    font-size: .75rem;
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #A79A92;
    margin-bottom: .5rem;
}
.product-summary__title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 2rem;
    font-weight: 600;
    color: #4E4743;
    letter-spacing: .06em;
    margin-bottom: .75rem;
}
.product-summary__rating .star-rating span[class^="flaticon-"]:before {
    font-size: 16px;
    color: #C6A46C;
}
.product-summary__rating .star-rating span.flaticon-star-1:before,
.product-summary__rating .star-rating span.flaticon-star-half-empty:before {
    color: #D8C9BE;
}
.product-summary__rating .star-rating span.flaticon-star-half-empty:before {
    color: #C6A46C;
}
.woocommerce-review-link {
    font-size: .8125rem;
    color: #A79A92;
    margin-left: .5rem;
}
.product-summary__price {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.5rem;
    font-weight: 500;
    color: #C6A46C;
}

/* Variations */
.variation-label {
    font-size: .8125rem;
    font-weight: 500;
    color: #4E4743;
    white-space: nowrap;
}
.variation-select {
    border: 1px solid #E7DED3;
    font-size: .8125rem;
    padding: .4rem .75rem;
    max-width: 250px;
}
.variation-select:focus {
    border-color: #C6A46C;
    box-shadow: none;
}

/* Add to cart button */
.single_add_to_cart_button span[class^="flaticon-"]:before {
    font-size: 14px;
    margin-right: .25rem;
    vertical-align: middle;
}

/* Meta */
.product-summary__meta {
    border-top: 1px solid #E7DED3;
    padding-top: 1rem;
    font-size: .8125rem;
    color: #A79A92;
}
.product-summary__meta span {
    display: block;
    margin-bottom: .25rem;
}
.product-summary__meta a {
    color: #4E4743;
    transition: color .25s ease;
}
.product-summary__meta a:hover { color: #C6A46C; }

/* Share */
.product-summary__share {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.share-label {
    font-size: .8125rem;
    color: #A79A92;
}
.product-summary__share a span[class^="flaticon-"]:before {
    font-size: 18px;
    color: #4E4743;
    transition: color .25s ease;
}
.product-summary__share a:hover span:before { color: #C6A46C; }

/* -----------------------------------------------------------
   20g. PRODUCT TABS
   ----------------------------------------------------------- */
.product-tabs.nav-tabs {
    border-bottom: 2px solid #E7DED3;
}
.product-tabs .nav-link {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 1.05rem;
    font-weight: 600;
    letter-spacing: .06em;
    color: #A79A92;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    padding: .75rem 1.5rem;
    transition: color .25s ease, border-color .25s ease;
}
.product-tabs .nav-link:hover { color: #4E4743; }
.product-tabs .nav-link.active {
    color: #C6A46C;
    border-bottom-color: #C6A46C;
    background: transparent;
}

/* Ingredients list */
.product-ingredients li {
    padding: .35rem 0;
    font-size: .9rem;
    color: #4E4743;
}

/* Attributes table */
.shop_attributes th {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: .875rem;
    color: #4E4743;
    padding: .75rem 1rem;
    background: #F4EFEA;
    width: 35%;
}
.shop_attributes td {
    font-size: .875rem;
    color: #4E4743;
    padding: .75rem 1rem;
}

/* Reviews */
.avatar-circle {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #C6A46C;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    font-weight: 600;
    flex-shrink: 0;
}
.review-body .star-rating span[class^="flaticon-"]:before {
    font-size: 14px;
    color: #C6A46C;
}
.review-body .star-rating span.flaticon-star-1:before {
    color: #D8C9BE;
}
.woocommerce-review__published-date {
    font-size: .75rem;
    color: #A79A92;
}

/* Star select (review form) */
.stars .star-select {
    cursor: pointer;
    transition: color .2s ease;
}
.stars .star-select:before {
    font-size: 20px;
    color: #D8C9BE;
}
.stars .star-select:hover:before,
.stars .star-select.selected:before {
    color: #C6A46C;
}
.review-rating-select label {
    font-size: .875rem;
    font-weight: 500;
    color: #4E4743;
    margin-right: .5rem;
}

/* -----------------------------------------------------------
   20h. BOUTIQUE — RESPONSIVE
   ----------------------------------------------------------- */
@media (max-width: 991.98px) {
    
    .left-column .img-fluid{
        height: auto;
        object-fit: cover;
    }
    .shop-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        width: 320px;
        max-width: 85vw;
        height: 100%;
        background: #fff;
        z-index: 10000;
        padding: 1.5rem;
        padding-top: 3.5rem;
        overflow-y: auto;
        transform: translateX(-100%);
        transition: transform .35s cubic-bezier(.4,0,.2,1);
        box-shadow: 4px 0 20px rgba(0,0,0,.15);
        margin-bottom: 0;
    }
    .shop-sidebar.open {
        transform: translateX(0);
    }
    .shop-sidebar__close {
        display: block;
        position: absolute;
        top: 12px;
        right: 14px;
        background: none;
        border: none;
        font-size: 1.75rem;
        line-height: 1;
        color: #4E4743;
        cursor: pointer;
    }
    .filter-overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(78,71,67,.5);
        z-index: 9999;
        opacity: 0;
        visibility: hidden;
        transition: opacity .35s ease, visibility .35s ease;
    }
    .filter-overlay.open {
        opacity: 1;
        visibility: visible;
    }
    .mobile-filter-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: .5rem;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        z-index: 9990;
        background: #4E4743;
        color: #fff;
        border: none;
        padding: 14px 0;
        font-family: 'Montserrat', sans-serif;
        font-size: .875rem;
        font-weight: 600;
        letter-spacing: .08em;
        text-transform: uppercase;
        cursor: pointer;
        box-shadow: 0 -2px 10px rgba(0,0,0,.15);
    }
    .mobile-filter-btn .flaticon-magnifying-glass:before {
        font-size: 14px;
    }
    .product-gallery__main-img {
        height: 380px;
    }
    .product-summary__title {
        font-size: 1.6rem;
    }
}
@media (max-width: 575.98px) {
    .product-gallery__main-img {
        height: 300px;
    }
    .product-gallery__thumb {
        width: 60px;
        height: 60px;
    }
    .side-cart { width: 100%; }
    .product-tabs .nav-link {
        padding: .6rem .75rem;
        font-size: .95rem;
    }
}

/* ============================================
   SOIN DETAIL — Sélecteur durée / tarif
   ============================================ */
.soin-tarifs {
    background: #F4EFEA;
    border-radius: 8px;
    padding: 1.25rem 1.5rem;
}
.soin-tarifs__selector label {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem;
    color: #4E4743;
    margin-bottom: 0;
}
.soin-tarifs__select {
    appearance: none;
    -webkit-appearance: none;
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234E4743' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 14px center;
    border: 1px solid #D8C9BE;
    border-radius: 6px;
    padding: .55rem 2.5rem .55rem 1rem;
    font-family: 'Montserrat', sans-serif;
    font-size: .95rem;
    color: #4E4743;
    cursor: pointer;
    transition: border-color .3s ease;
    min-width: 120px;
}
.soin-tarifs__select:focus {
    outline: none;
    border-color: #C6A46C;
    box-shadow: 0 0 0 3px rgba(198, 164, 108, .15);
}
.soin-tarifs__prix {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.1rem;
    color: #4E4743;
}
.soin-tarifs__montant {
    font-size: 1.4rem;
    font-weight: 700;
    color: #C6A46C;
    margin-left: .35rem;
}

/* Soin card prix "à partir de" */
.soin-card-price {
    display: inline-block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: #C6A46C;
}



.powered-by-bookly {
  display: none;
}


/* ============================================
   WooCommerce — Mon Compte / Panier / Checkout
   ============================================ */

/* Base wrappers */
.woocommerce-account .woocommerce,
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
    font-family: 'Montserrat', sans-serif;
    color: #4E4743;
}

.woocommerce .woocommerce-info,
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-error {
    border-radius: 8px;
    border: 1px solid #D8C9BE;
    background: #F9F5F1;
    color: #4E4743;
    padding: .9rem 1.1rem;
    margin-bottom: 1rem;
}

/* ---------- Mon compte ---------- */
.woocommerce-account .woocommerce-MyAccount-navigation {
    background: #fff;
    border: 1px solid #E7DED3;
    border-radius: 10px;
    padding: .8rem;
    margin-bottom: 1.25rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    margin: 0;
    border-bottom: 1px solid #F1E9DF;
}

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

.woocommerce-account .woocommerce-MyAccount-navigation-link a {
    display: block;
    padding: .75rem .85rem;
    text-decoration: none;
    color: #4E4743;
    border-radius: 6px;
    transition: background .2s ease, color .2s ease;
    font-size: .92rem;
    font-weight: 500;
}

.woocommerce-account .woocommerce-MyAccount-navigation-link.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation-link a:hover {
    background: #4E4743;
    color: #fff;
}

.woocommerce-account .woocommerce-MyAccount-content {
    background: #fff;
    border: 1px solid #E7DED3;
    border-radius: 10px;
    padding: 1.2rem;
}

/* Mon compte en 2 colonnes (desktop) */
@media (min-width: 992px) {
    .woocommerce-account .woocommerce {
        display: grid;
        grid-template-columns: 260px 1fr;
        gap: 1.5rem;
        align-items: start;
    }

    .woocommerce-account .woocommerce:before,
    .woocommerce-account .woocommerce:after {
        display: none;
    }

    .woocommerce-account .woocommerce > .woocommerce-notices-wrapper,
    .woocommerce-account .woocommerce > .woocommerce-info,
    .woocommerce-account .woocommerce > .woocommerce-message,
    .woocommerce-account .woocommerce > .woocommerce-error {
        grid-column: 1 / -1;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation,
    .woocommerce-account .woocommerce-MyAccount-content {
        float: none;
        width: auto;
        margin: 0;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        position: sticky;
        top: 110px;
    }
}

.woocommerce-account .myaccount-nav-toggle {
    display: none;
}

.woocommerce-account .woocommerce-Addresses .woocommerce-Address,
.woocommerce-account .woocommerce-EditAccountForm,
.woocommerce-account .woocommerce-form,
.woocommerce-account .woocommerce-table,
.woocommerce-account .shop_table {
    background: #fff;
}

/* ---------- Tables (account/cart/checkout) ---------- */
.woocommerce table.shop_table {
    border: 1px solid #E7DED3;
    border-radius: 10px;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
}

.woocommerce table.shop_table thead th {
    background: #F4EFEA;
    color: #4E4743;
    font-family: 'Montserrat', sans-serif;
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    border-bottom: 1px solid #E7DED3;
    padding: .85rem .9rem;
}

.woocommerce table.shop_table td,
.woocommerce table.shop_table th {
    border-color: #EFE6DD;
    padding: .9rem;
}

.woocommerce table.shop_table tbody tr:nth-child(even) {
    background: #FCFAF8;
}

/* ---------- Form fields ---------- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce .select2-container--default .select2-selection--single {
    border: 1px solid #D8C9BE;
    border-radius: 8px;
    background: #fff;
    color: #4E4743;
    min-height: 44px;
    padding: .55rem .8rem;
    transition: border-color .2s ease, box-shadow .2s ease;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    border-color: #C6A46C;
    box-shadow: 0 0 0 3px rgba(198, 164, 108, .12);
    outline: none;
}

.woocommerce .select2-container--default .select2-selection--single {
    display: flex;
    align-items: center;
    height: 44px;
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 1.2;
    color: #4E4743;
}

/* ---------- Boutons ---------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    background: #4E4743;
    color: #fff;
    border: 1px solid #4E4743;
    border-radius: 999px;
    padding: .72rem 1.2rem;
    font-family: 'Montserrat', sans-serif;
    font-size: .82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    transition: all .2s ease;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
    background: #4E4743;
    border-color: #4E4743;
}

/* ---------- Panier ---------- */
.woocommerce-cart .cart_totals {
    background: #fff;
    border: 1px solid #E7DED3;
    border-radius: 10px;
    padding: 1rem;
}

.woocommerce-cart .cart_totals h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem;
    color: #4E4743;
    margin-bottom: .75rem;
}

.woocommerce-cart table.cart td.actions {
    background: #F9F5F1;
}

.woocommerce-cart table.cart img {
    border-radius: 8px;
    border: 1px solid #EFE6DD;
}

.woocommerce-cart .quantity .qty {
    border: 1px solid #D8C9BE;
    border-radius: 7px;
    min-height: 40px;
    padding: .25rem .45rem;
}

/* ---------- Checkout ---------- */
.woocommerce-checkout .col2-set,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
    background: #fff;
    border: 1px solid #E7DED3;
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 1rem;
}

.woocommerce-checkout #order_review_heading {
    margin-bottom: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.woocommerce-checkout #order_review {
    margin-top: 0;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.woocommerce-checkout #payment {
    background: #F9F5F1;
    border-radius: 8px;
    border: 1px solid #E7DED3;
}

.woocommerce-checkout #payment ul.payment_methods {
    border-bottom: 1px solid #E7DED3;
}

.woocommerce-checkout #payment div.payment_box {
    background: #fff;
    border: 1px solid #E7DED3;
    border-radius: 8px;
    color: #4E4743;
}

.woocommerce-checkout #payment div.payment_box:before {
    border-bottom-color: #fff;
}

/* ---------- Responsive ---------- */
@media (max-width: 991.98px) {
    .woocommerce-account .woocommerce-MyAccount-content,
    .woocommerce-account .woocommerce-MyAccount-navigation,
    .woocommerce-cart .cart_totals,
    .woocommerce-checkout .col2-set,
    .woocommerce-checkout #order_review_heading,
    .woocommerce-checkout #order_review {
        padding: .9rem;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        margin-bottom: 1rem;
        padding: .6rem;
    }

    .woocommerce-account .myaccount-nav-toggle {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: .8rem;
        border: 1px solid #D8C9BE;
        border-radius: 8px;
        background: #F9F5F1;
        color: #4E4743;
        padding: .72rem .9rem;
        font-family: 'Montserrat', sans-serif;
        font-size: .84rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: .06em;
        cursor: pointer;
    }

    .woocommerce-account .myaccount-nav-toggle:after {
        content: '';
        width: 8px;
        height: 8px;
        border-right: 2px solid #4E4743;
        border-bottom: 2px solid #4E4743;
        transform: rotate(45deg);
        transition: transform .2s ease;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation.is-open .myaccount-nav-toggle:after {
        transform: rotate(-135deg);
        margin-top: 4px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        max-height: 0;
        overflow: hidden;
        opacity: 0;
        margin-top: 0;
        transition: max-height .25s ease, opacity .2s ease, margin-top .2s ease;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation.is-open ul {
        max-height: 600px;
        opacity: 1;
        margin-top: .55rem;
    }
}

/* ============================================
   WooCommerce — Page Mon compte (déconnecté)
   Login + Register (#customer_login)
   ============================================ */
.woocommerce #customer_login {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin: 0 auto;
    max-width: 1040px;
}

@media (min-width: 768px) {
    .woocommerce #customer_login {
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
    }
}

.woocommerce #customer_login::before,
.woocommerce #customer_login::after {
    content: none !important;
    display: none !important;
}

.woocommerce #customer_login > .u-column1,
.woocommerce #customer_login > .u-column2 {
    float: none;
    width: 100%;
    margin: 0;
    background: #fff;
    border: 1px solid #E7DED3;
    border-radius: 12px;
    padding: 2rem 1.75rem;
    box-shadow: 0 6px 24px rgba(78, 71, 67, .04);
}

.woocommerce #customer_login h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.85rem;
    font-weight: 500;
    color: #4E4743;
    margin: 0 0 1.4rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid #E7DED3;
    text-align: center;
    letter-spacing: .02em;
}

/* Form rows */
.woocommerce #customer_login .form-row {
    margin-bottom: 1.1rem;
}

.woocommerce #customer_login .form-row label {
    display: block;
    margin-bottom: .4rem;
    font-size: .82rem;
    font-weight: 500;
    color: #6B635D;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.woocommerce #customer_login .form-row .required {
    color: #C6A46C;
    text-decoration: none;
    margin-left: 2px;
}

.woocommerce #customer_login .form-row input.input-text {
    width: 100%;
    border: 1px solid #D8C9BE;
    border-radius: 8px;
    background: #FCFAF8;
    color: #4E4743;
    min-height: 46px;
    padding: .6rem .9rem;
    font-family: 'Montserrat', sans-serif;
    font-size: .92rem;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.woocommerce #customer_login .form-row input.input-text:focus {
    border-color: #C6A46C;
    background: #fff;
    box-shadow: 0 0 0 3px rgba(198, 164, 108, .15);
    outline: none;
}

/* Password input + toggle */
.woocommerce #customer_login .password-input {
    position: relative;
    display: block;
    width: 100%;
}

.woocommerce #customer_login .password-input input {
    padding-right: 3rem;
}

.woocommerce #customer_login .show-password-input {
    position: absolute;
    top: 50%;
    right: .8rem;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    background: transparent;
    border: 0;
    padding: 0;
    cursor: pointer;
    opacity: .55;
    transition: opacity .2s ease;
}

.woocommerce #customer_login .show-password-input:hover,
.woocommerce #customer_login .show-password-input.display-password {
    opacity: 1;
}

.woocommerce #customer_login .show-password-input::before {
    content: '\f06e';
    font-family: 'Font Awesome 5 Free', 'FontAwesome';
    font-weight: 900;
    color: #4E4743;
    font-size: 1rem;
}

.woocommerce #customer_login .show-password-input.display-password::before {
    content: '\f070';
}

/* Remember me checkbox */
.woocommerce #customer_login .woocommerce-form-login__rememberme {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    font-size: .88rem;
    color: #6B635D;
    cursor: pointer;
    margin-bottom: 1rem;
}

.woocommerce #customer_login .woocommerce-form-login__rememberme input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: #4E4743;
    cursor: pointer;
}

/* Submit buttons */
.woocommerce #customer_login button.woocommerce-button,
.woocommerce #customer_login button.button {
    display: block;
    width: 100%;
    background: #4E4743;
    color: #fff;
    border: 1px solid #4E4743;
    border-radius: 999px;
    padding: .85rem 1.4rem;
    font-family: 'Montserrat', sans-serif;
    font-size: .82rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .12em;
    cursor: pointer;
    margin-top: .4rem;
    transition: background .25s ease, color .25s ease, border-color .25s ease, transform .15s ease;
}

.woocommerce #customer_login button.woocommerce-button:hover,
.woocommerce #customer_login button.button:hover {
    background: #C6A46C;
    border-color: #C6A46C;
    color: #fff;
    transform: translateY(-1px);
}

/* Lost password link */
.woocommerce #customer_login .lost_password {
    text-align: center;
    margin: 1rem 0 0;
}

.woocommerce #customer_login .lost_password a {
    color: #6B635D;
    font-size: .85rem;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color .2s ease, border-color .2s ease;
}

.woocommerce #customer_login .lost_password a:hover {
    color: #C6A46C;
    border-bottom-color: #C6A46C;
}

/* Helper paragraph (info "un lien permettant…") */
.woocommerce #customer_login .woocommerce-form-register > p:not(.form-row) {
    font-size: .85rem;
    color: #6B635D;
    background: #F9F5F1;
    border-left: 3px solid #C6A46C;
    padding: .7rem .9rem;
    border-radius: 4px;
    margin-bottom: 1.1rem;
}

/* Privacy policy text */
.woocommerce #customer_login .woocommerce-privacy-policy-text p {
    font-size: .78rem;
    color: #8A827C;
    line-height: 1.55;
    margin-bottom: 1rem;
}

.woocommerce #customer_login .woocommerce-privacy-policy-text a {
    color: #4E4743;
    text-decoration: underline;
}

.woocommerce #customer_login .woocommerce-privacy-policy-text a:hover {
    color: #C6A46C;
}



/* --- Footer � menu liens l�gaux sous les r�seaux sociaux --- */
.footer .footer-nav { margin-top: 18px; }
.footer .footer-nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px 22px;
}
.footer .footer-nav-list li { margin: 0; padding: 0; }
.footer .footer-nav-list a {
    font-size: 13px;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: inherit;
    opacity: .85;
    transition: opacity .25s ease, color .25s ease;
}
.footer .footer-nav-list a:hover,
.footer .footer-nav-list .current-menu-item > a {
    opacity: 1;
    color: var(--ebeneis-champagne, #c8a96a);
    text-decoration: none;
}

/* --- Parcours signature � hauteur d'image uniforme --- */
.parcours-immersifs .about-8-img,
#a8-1 .about-8-img,
#a8-2 .about-8-img,
#a8-3 .about-8-img,
#a8-4 .about-8-img {
    overflow: hidden;
    border-radius: 4px;
}
.parcours-immersifs .about-8-img img,
#a8-1 .about-8-img img,
#a8-2 .about-8-img img,
#a8-3 .about-8-img img,
#a8-4 .about-8-img img {
    width: 100%;
    height: 600px;
    object-fit: cover;
    object-position: center;
    display: block;
}
@media (max-width: 991.98px) {
    .parcours-immersifs .about-8-img img,
    #a8-1 .about-8-img img,
    #a8-2 .about-8-img img,
    #a8-3 .about-8-img img,
    #a8-4 .about-8-img img { height: 500px; }
}
@media (max-width: 575.98px) {
    .parcours-immersifs .about-8-img img,
    #a8-1 .about-8-img img,
    #a8-2 .about-8-img img,
    #a8-3 .about-8-img img,
    #a8-4 .about-8-img img { height: 380px; }
    
    .modal-body {
        padding: 50px 0 !important;
    }  
}
