/*
Theme Name: Hello Elementor Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.4.4.1755351453
Updated: 2025-08-16 13:37:33

*/
/* ==== RESET LEGER ==== 
*,
*::before,
*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: "Work Sans", system-ui, -apple-system, "Segoe UI",
               Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  color: #111;
  line-height: 1.6;
  background: #fff;
}

/* ==== VARIABLES FLUIDES ==== 
:root{
  /* Titres (Georgia) 
  --ff-heading: Georgia, "Times New Roman", Times, serif;
  --ff-heading2: "Work Sans", system-ui, -apple-system, "Segoe UI",
               Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;

  /* Tailles fluides (H1 desktop = 58px)
  --fs-h1: clamp(44px, calc(1.5909vw + 38.91px), 58px);
  --fs-h2: clamp(35px, calc(1.25vw + 31px), 46px);
  --fs-h3: clamp(25px, calc(1.0227vw + 24.73px), 37px);
  --fs-h4: clamp(23px, calc(0.7955vw + 20.45px), 30px);
  --fs-h5: clamp(19px, calc(0.5682vw + 17.18px), 24px);
  --fs-h6: clamp(16px, calc(0.3409vw + 14.91px), 19px);

  /* Corps de texte 
  --fs-body:  clamp(16px, calc(0.2273vw + 15.27px), 18px);
  --fs-small: clamp(14px, calc(0.1705vw + 13.45px), 16px);

  /* Line-height & weights 
  --lh-h1: 1.15; --lh-h2: 1.15;
  --lh-h3: 1.30; --lh-h4: 1.20;
  --lh-h5: 1.30; --lh-h6: 1.30;
  --fw-h1: 700; --fw-h2: 700;
  --fw-h3: 300; --fw-h4: 600;
  --fw-h5: 600; --fw-h6: 600;

  /* Espacements & conteneur 
  --space-1: clamp(8px, 1vw, 12px);
  --space-2: clamp(12px, 1.5vw, 18px);
  --space-3: clamp(20px, 2.5vw, 32px);
  --space-4: clamp(32px, 4vw, 56px);
  --container-max: clamp(320px, 90vw, 1200px);
}

/* ==== TITRES (HTML + Elementor) ==== 
h1,h2 { font-family: var(--ff-heading); margin: 0 0 0.6em; letter-spacing:-0.01em; }
h1, .elementor h1.elementor-heading-title { font-size:var(--fs-h1); line-height:var(--lh-h1); font-weight:var(--fw-h1); }
h2, .elementor h2.elementor-heading-title { font-size:var(--fs-h2); line-height:var(--lh-h2); font-weight:var(--fw-h2); }

/* ==== TITRES (HTML + Elementor) ==== 
h3,h4,h5,h6 { font-family: var(--ff-heading2); margin: 0 0 0.6em; letter-spacing:-0.01em; }
h3, .elementor h3.elementor-heading-title { font-size:var(--fs-h3); line-height:var(--lh-h3); font-weight:var(--fw-h3); }
h4, .elementor h4.elementor-heading-title { font-size:var(--fs-h4); line-height:var(--lh-h4); font-weight:var(--fw-h4); }
h5, .elementor h5.elementor-heading-title { font-size:var(--fs-h5); line-height:var(--lh-h5); font-weight:var(--fw-h5); letter-spacing:-0.005em; }
h6, .elementor h6.elementor-heading-title { font-size:var(--fs-h6); line-height:var(--lh-h6); font-weight:var(--fw-h6); letter-spacing:0; }

/* Texte courant 
p{ font-size: var(--fs-body); }
small,.small{ font-size: var(--fs-small); }

/* Conteneurs Elementor 
.elementor .elementor-container,
.elementor .e-con { max-width: var(--container-max); margin-inline:auto; padding-inline:16px; }*/

/* Utilitaires sections 
.section { padding-block: var(--space-4); }
.section--tight { padding-block: var(--space-3); }
.stack > * + * { margin-top: var(--space-2); }*/

/* Héritage si un widget Titre a des tailles forcées
.elementor .elementor-heading-title { font-size: inherit; line-height: inherit; font-weight: inherit; }

/* ==== GARDE-FOUS ULTRA-LARGES ==== 
@media (min-width: 2400px){
  :root{
    --fs-h1: clamp(58px, 1.2vw, 64px);
    --fs-h2: clamp(46px, 1.0vw, 51px);
    --fs-h3: clamp(37px, 0.8vw, 41px);
    --fs-h4: clamp(30px, 0.7vw, 33px);
    --fs-h5: clamp(24px, 0.6vw, 26px);
    --fs-h6: clamp(19px, 0.5vw, 21px);
    --fs-body: clamp(18px, 0.5vw, 20px);
    --container-max: 70vw;
  }
  p { max-width: 70ch; }
}

/* ==== PETITS ECRANS (≤360px) ==== 
@media (max-width: 360px){
  :root{ --fs-body: 15px; }
}

/* Accessibilité
@media (prefers-reduced-motion: reduce){
  * { animation: none !important; transition: none !important; }
}
*/
/* Supprime marges et padding des <p> sur tout le site */
p {
  margin: 0;
  padding: 0;
}
/* ----------- ÉTAT NORMAL ----------- */
#nav-sticky{
  /* tailles par défaut (faciles à ajuster) */
  --menu-fz: 25px;
  --icon-size: 22px;


  background: transparent;
  transition: background-color .25s ease, padding .25s ease, box-shadow .25s ease;
  padding: 14px 0;
}
/* ==== PETITS ECRANS (≤360px) ==== */
@media (min-width: 1024px){
  #nav-sticky{
  /* tailles par défaut (faciles à ajuster) */
  --menu-fz: 16px;
  --icon-size: 22px;


  background: transparent;
  transition: background-color .25s ease, padding .25s ease, box-shadow .25s ease;
  padding: 0px 0;
}
}
@media (max-width: 770px){
  #nav-sticky{
  /* tailles par défaut (faciles à ajuster) */
  --menu-fz: 16px;
  --icon-size: 22px;
  --logo-size: 50px;

  transition: background-color .25s ease, padding .25s ease, box-shadow .25s ease;
  padding: 20px;
}
}
/* Logo par défaut : clair visible, foncé caché */
#nav-sticky .logo--dark{ display:none; }

/* Tailles + transitions */
#nav-sticky .elementor-nav-menu--main .elementor-item{
  font-size: var(--menu-fz);
  transition: font-size .2s ease, padding .2s ease;
  padding: 0px;
}

/* Groupe d’icônes à droite */
#nav-sticky .header-icons{
  display:inline-flex; align-items:center; gap:18px;
  transition: gap .2s ease;
}

/* Icônes (Elementor Icon, Search toggle, Cart toggle, SVG…) */
#nav-sticky .header-icons a,
#nav-sticky .elementor-search-form__toggle,
#nav-sticky .elementor-menu-cart__toggle{

  line-height:1;
  transition: font-size .2s ease, transform .2s ease;
}
#nav-sticky .header-icons svg{ width: var(--icon-size); height: var(--icon-size); transition: width .2s ease, height .2s ease; }

/* Logo tailles */
#nav-sticky .logo--light img,
#nav-sticky .logo--dark img{
  height: var(--logo-size);
  transition: height .25s ease, opacity .2s ease;
}

/* Badge panier (Elementor Pro Menu Cart OU votre shortcode .count) */
#nav-sticky .elementor-button-icon-qty,
#nav-sticky .cart-contents .count{
  min-width:18px; height:18px; font-size:12px;
  transition: all .2s ease;
}

/* ----------- ÉTAT STICKY (au scroll) ----------- */
#nav-sticky.elementor-sticky--active{
  /* réductions */
  --menu-fz: 14px;
  --icon-size: 18px;
  --logo-size: 70px;

  background:#000;               /* nav devient noire */
  box-shadow:0 2px 12px rgba(0,0,0,.60);
  padding: 0px 20px 0px 20px;                /* plus compacte */
}

/* swap de logos */
#nav-sticky.elementor-sticky--active .logo--light{ display:none; }
#nav-sticky.elementor-sticky--active .logo--dark{ display:block; }

/* compacter un peu le menu */
#nav-sticky.elementor-sticky--active .elementor-nav-menu--main .elementor-item{ padding:10px 12px; }

/* icônes + espacements */
#nav-sticky.elementor-sticky--active .header-icons{ gap:12px; }

/* badge plus petit */
#nav-sticky.elementor-sticky--active .elementor-button-icon-qty,
#nav-sticky.elementor-sticky--active .cart-contents .count{
  min-width:14px; height:14px; font-size:10px;
  top:-6px; right:-8px; /* ajustez si besoin */
}

/* ===== HEADER transparent au-dessus du hero ===== */
#site-header{
  /* hauteur unique pour tous les breakpoints (modifiable) */
  --header-h: clamp(64px, 0vh, 96px);

  position: absolute;    /* se pose par-dessus le contenu */
  inset: 0 0 auto 0;     /* top:0; left:0; right:0 */
  z-index: 100;
  background: transparent;
  box-shadow: none;
}

/* Garde une hauteur stable du header et centre le contenu verticalement */
#site-header > .e-con, /* conteneur enfant principal */
#site-header .nav      /* ta barre de nav si tu as un sous-conteneur */
{
  min-height: var(--header-h);
  display: flex; align-items: center;
}

/* Compense sous le header pour que le texte du hero ne passe pas dessous */
.hero{ padding-top: var(--header-h); }

/* ===== HERO plein écran stable (sans “saut” mobile) ===== */
.hero{ min-height: 100vh; display:flex; align-items:center; }
@supports (height: 100svh){
  .hero{ min-height: 100svh; }   /* viewport stable sur mobile */
}

/* (optionnel) si tu as la barre d’admin WP visible 
@media (min-width: 782px){
  body.admin-bar #site-header{ top: 32px; }
}*/

/*FLUX INSTAGRAM MOBILE*/
/* --- Carrousel mobile pour Smash Balloon (FREE) --- */
@media (max-width: 767px){
  /* La "piste" (selon versions : #sbi_images / .sbi_images / .sbi_feed / .sbi_items) */
  #sb_instagram #sbi_images,
  .sbi #sbi_images,
  .sbi .sbi_images,
  .sbi .sbi_feed,
  .sbi .sbi_items{
    display: flex !important;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 14px;
    padding-inline: 16px;
    scroll-snap-type: x proximity;   /* snap doux → le scroll vertical passe */
    scroll-padding-inline: 16px;
    -webkit-overflow-scrolling: touch;
    touch-action: auto;              /* autorise pan-x ET pan-y */
    scrollbar-width: none;
  }
  /* cacher la barre de scroll (WebKit) */
  #sb_instagram #sbi_images::-webkit-scrollbar,
  .sbi #sbi_images::-webkit-scrollbar,
  .sbi .sbi_images::-webkit-scrollbar,
  .sbi .sbi_feed::-webkit-scrollbar,
  .sbi .sbi_items::-webkit-scrollbar{ display:none; }

  /* Chaque carte/élément */
  #sb_instagram #sbi_images .sbi_item,
  .sbi .sbi_item{
    flex: 0 0 85% !important;        /* largeur d’une “slide” (70–95% si tu veux) */
    max-width: 85% !important;
    width: auto !important;          /* annule les % imposés par le grid */
    scroll-snap-align: start;
  }

  /* Optionnel : que la photo remplisse bien la carte */
  #sb_instagram .sbi_photo_wrap,
  #sb_instagram .sbi_photo{ height: 100%; }
}

/*************** VARIANTE A — UNE SEULE COUCHE ****************
   Parent = .grid2carousel
   Items  = .grid2carousel > * 
***************************************************************/

/* Desktop/Tablet : grille 3 colonnes */
.grid2carousel{
  --gap: 24px;        /* écart desktop */
  display: grid;
  gap: var(--gap);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Mobile : carrousel tactile + scroll vertical possible */
@media (max-width: 767px){
  .grid2carousel{
    --gap-m: 14px;    /* écart mobile */
    --slide: 100%;     /* largeur d’une “slide” (70–95%) */

    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: var(--gap-m);
    padding-inline: 16px;

    /* Swipe horizontal doux, mais laisse passer le scroll vertical */
    scroll-snap-type: x proximity;
    scroll-padding-inline: 16px;
    -webkit-overflow-scrolling: touch;
    touch-action: auto;                 /* <-- autorise le scroll vertical */
    overscroll-behavior-x: contain;     /* pas d'effet “rebond” latéral */
  }

  .grid2carousel > *{
    flex: 0 0 var(--slide) !important;  /* force la largeur des cartes */
    max-width: var(--slide) !important;
    scroll-snap-align: start;
  }

  /* Option : cacher la barre de scroll */
  .grid2carousel{ scrollbar-width: none; }
  .grid2carousel::-webkit-scrollbar{ display: none; }
}


/*************** VARIANTE B — AVEC PISTE **********************
   Parent = .g2c
   Piste  = .g2c-track
   Items  = .g2c-item (enfants direct de .g2c-track)
***************************************************************/

/* Desktop/Tablet : grille 3 colonnes */
.g2c-track{
  --gap: 24px;
  display: grid;
  gap: var(--gap);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Mobile : carrousel tactile + scroll vertical possible */
@media (max-width: 767px){
  .g2c{ overflow: visible; } /* évite que des parents bloquent le scroll */

  .g2c-track{
    --gap-m: 14px;
    --slide: 100%;

    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: var(--gap-m);
    padding-inline: 16px;

    scroll-snap-type: x proximity;   /* snap moins “agressif” */
    scroll-padding-inline: 16px;
    -webkit-overflow-scrolling: touch;
    touch-action: auto;              /* <-- autorise le scroll vertical */
    overscroll-behavior-x: contain;
  }

  .g2c-track::-webkit-scrollbar{ display: none; }
  .g2c-track{ scrollbar-width: none; }

  .g2c-track > .g2c-item{
    flex: 0 0 var(--slide) !important;
    max-width: var(--slide) !important;
    scroll-snap-align: start;
  }
}

/*CONTACT FORM*/
:root{ --gold:#D4AF37; }

/* spacing & grille */
.form-gold .row{ margin-bottom:20px; }
.form-gold .grid-2{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
@media (max-width:768px){
  .form-gold .grid-2{ grid-template-columns:1fr; }
}

/* champs */
.form-gold .field .wpcf7-form-control{
  width:100%;
  background:#fff; color:#000;
  border:0; border-radius:10px;
  padding:18px 22px; line-height:1.2;
  box-shadow:none; outline:none;
  display:block;
}
.form-gold textarea.wpcf7-form-control{ min-height:260px; resize:vertical; }
.form-gold ::placeholder{ color:#BDBDBD; opacity:1; }

/* acceptance (consentement) */
.form-gold .consent .wpcf7-list-item{ margin:0; }
.form-gold .consent label{
  display:inline-flex; align-items:center; gap:12px; cursor:pointer; color:#fff;
}
.form-gold .consent input[type="checkbox"]{
  appearance:none; -webkit-appearance:none;
  width:22px; height:22px; border:1px solid var(--gold);
  border-radius:4px; background:transparent; position:relative;
}
.form-gold .consent input[type="checkbox"]:checked{ background:var(--gold); }
.form-gold .consent input[type="checkbox"]:checked::after{
  content:""; position:absolute; left:5px; top:3px; width:10px; height:6px;
  border:2px solid #111; border-left:0; border-top:0; transform:rotate(45deg);
}
.form-gold .consent a{ color:#fff; text-decoration:underline; }
.form-gold .consent a:hover{ color:var(--gold); }

/* bouton submit */
.form-gold .submit input[type="submit"]{
  background:var(--gold); color:#111; border:0;
  padding:14px 22px; border-radius:999px;
  font-weight:500; letter-spacing:.02em; text-transform:uppercase;
  cursor:pointer;
}

/* messages d'erreur/succès CF7 */
.form-gold .wpcf7-not-valid-tip{ color:#ffdddd; margin-top:6px; }
.form-gold .wpcf7-response-output{ border-color:var(--gold); }

.wpcf7 form.sent .wpcf7-response-output {
    border-color: var(--gold);
    background-color: var(--gold);
    border-radius: 10px;
    color: #000;
    text-align: center;
}
.btn-submit [type=submit]:focus, [type=submit]:hover {
    background-color: #000;
    color: #fff;
    text-decoration: none;
}

/* -----------------------------------------------------------
   Huilerie des 5 Saveurs — STYLE COMPLET MINI-CART ELEMENTOR
   ----------------------------------------------------------- */


/* 1. CONTENEUR GLOBAL DU MINI CART */
.elementor-menu-cart__main {
    background: #f8f5ef;
    padding: 26px 22px 26px;
    border-radius: 18px 0 0 18px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.12);
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: relative; /* pour positionner la croix de fermeture */
}


/* 2. BOUTON FERMETURE (CROIX EN HAUT À DROITE, REDESCENDUE) */
.elementor-menu-cart__close-button {
    position: absolute;
    top: 18px;       /* ↓ baisse la croix : augmente cette valeur si besoin */
    right: 18px;
    z-index: 10;
}

/* Si l’icône est un simple span / i */
.elementor-menu-cart__close-button i,
.elementor-menu-cart__close-button svg,
.elementor-menu-cart__close-button span {
    font-size: 18px;
}


/* 3. CONTENU INTERNE (LÉGÈRE MARGE EN HAUT) */
.elementor-menu-cart__main .widget_shopping_cart_content {
    margin-top: 10px;
}


/* 4. LISTE DES PRODUITS + SCROLL */
.elementor-menu-cart__products {
    max-height: 55vh;
    overflow-y: auto;
    padding-right: 6px;
}

/* Scrollbar */
.elementor-menu-cart__products::-webkit-scrollbar {
    width: 6px;
}
.elementor-menu-cart__products::-webkit-scrollbar-track {
    background: transparent;
}
.elementor-menu-cart__products::-webkit-scrollbar-thumb {
    background: #d0c7b6;
    border-radius: 20px;
}
.elementor-menu-cart__products::-webkit-scrollbar-thumb:hover {
    background: #b3a894;
}


/* 5. LIGNE PRODUIT */
.elementor-menu-cart__product {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    column-gap: 14px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid #e4ded1;
}

.elementor-menu-cart__product:last-child {
    border-bottom: none;
}


/* 6. IMAGE PRODUIT — PLUS GRANDE */
.elementor-menu-cart__product-image img {
    width: 80px;      /* agrandi */
    height: 80px;     /* agrandi */
    border-radius: 14px;
    object-fit: cover;
    border: 1px solid #e4ded1;
}


/* 7. NOM DU PRODUIT — TYPO PLUS FINE (400) */
.elementor-menu-cart__product-name {
    font-size: 13px;         /* un peu plus petit */
    line-height: 1.5;
}

.elementor-menu-cart__product-name a {
    font-weight: 400;        /* normal, pas trop gras */
    color: #252525;
    text-decoration: none;
    transition: color 0.2s ease;
}

.elementor-menu-cart__product-name a:hover {
    color: #000000;
}


/* 8. PRIX + QUANTITÉ */
.elementor-menu-cart__product-price {
    font-size: 13px;
    text-align: right;
    white-space: nowrap;
    color: #4b4b4b;
}

.elementor-menu-cart__product-price .product-quantity {
    font-weight: 400;
    margin-right: 3px;
}

.elementor-menu-cart__product-price .amount {
    font-weight: 600;
    color: #000000;
}


/* 9. BOUTON SUPPRIMER (CROIX) */
.elementor-menu-cart__product-remove {
    margin-left: 8px;
}

.elementor-menu-cart__product-remove a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #e4ded1;
    text-decoration: none;
    transition: background 0.2s ease, transform 0.1s ease;
}

/* Icône X */
.elementor_remove_from_cart_button:before,
.remove_from_cart_button:before {
    content: "×";
    font-size: 14px;
    line-height: 1;
    color: #5c5245;
}

.elementor-menu-cart__product-remove a:hover {
    background: #c93b3b;
    transform: translateY(-1px);
}

.elementor-menu-cart__product-remove a:hover:before {
    color: #ffffff;
}


/* 10. SOUS-TOTAL */
.elementor-menu-cart__subtotal {
    padding-top: 16px;
    margin-top: 6px;
    border-top: 1px solid #e4ded1;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 15px;
    font-weight: 600;
    color: #252525;
}

.elementor-menu-cart__subtotal .amount {
    color: #000000;
    font-weight: 700;
}


/* 11. BOUTONS — PLUS PETITS, DORÉS, COHÉRENTS */
.elementor-menu-cart__footer-buttons {
    margin-top: 4px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* Base boutons mini-cart : plus compacts */
.elementor-menu-cart__footer-buttons .elementor-button {
    display: block;
    width: 100%;
    padding: 9px 18px;              /* boutons un peu plus petits */
    border-radius: 20px;            /* arrondi doux, moins massif */
    font-size: 13px;                /* typo un peu réduite */
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-align: center;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

/* Bouton "Voir le panier" — doré contour */
.elementor-menu-cart__footer-buttons .elementor-button--view-cart {
    background: #D4AF37;
    border-radius: 100px !important;
    font-size: 14px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    border-color: #D4AF37;
    align-items: center;
    padding: 10px 0 !important;
    border-bottom: 1px solid #e4ded1;
}

.elementor-menu-cart__footer-buttons .elementor-button--view-cart:hover {
  background:#E6C456;
    border-radius: 100px !important;
    font-size: 14px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    border-color: #E6C456;
    align-items: center;
    padding: 10px 0 !important;
    border-bottom: 1px solid #e4ded1;
}

/* Bouton "Commander" — doré plein */
.elementor-menu-cart__footer-buttons .elementor-button--checkout {
 background: #D4AF37;
    border-radius: 100px !important;
    font-size: 14px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    border-color: #D4AF37;
    align-items: center;
    padding: 10px 0 !important;
    border-bottom: 1px solid #e4ded1;
}

.elementor-menu-cart__footer-buttons .elementor-button--checkout:hover {
    background: #E6C456  !important;
    border-radius: 100px !important;
    font-size: 14px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    border-color: #E6C456  !important;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid #e4ded1;
}

.elementor-menu-cart__product:last-child {
    border-bottom: none;
}

/* 3. IMAGE PRODUIT */
.elementor-menu-cart__product-image img {
    width: 60px;
    height: 60px;
    border-radius: 14px;
    object-fit: cover;
    border: 1px solid #e4ded1;
}

/* 4. NOM PRODUIT */
.elementor-menu-cart__product-name {
    font-size: 14px;
    line-height: 1.5;
}

.elementor-menu-cart__product-name a {
    font-weight: 600;
    color: #252525;
    text-decoration: none;
    transition: color 0.2s ease;
}

.elementor-menu-cart__product-name a:hover {
    color: #D4AF37; /* vert Huilerie */
}

/* 5. PRIX + QUANTITÉ */
.elementor-menu-cart__product-price {
    font-size: 13px;
    text-align: right;
    white-space: nowrap;
    color: #4b4b4b;
}

.elementor-menu-cart__product-price .product-quantity {
    font-weight: 500;
    margin-right: 3px;
}

.elementor-menu-cart__product-price .amount {
    font-weight: 600;
    color: #D4AF37;
}

/* 6. BOUTON SUPPRIMER (icône ronde style sobre) */
.elementor-menu-cart__product-remove {
    margin-left: 8px;
}

.elementor-menu-cart__product-remove a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #e4ded1;
    text-decoration: none;
    transition: background 0.2s ease, transform 0.1s ease;
}

/* Icône X */
.elementor_remove_from_cart_button:before,
.remove_from_cart_button:before {
    content: "×";
    font-size: 14px;
    line-height: 1;
    color: #5c5245;
}

.elementor-menu-cart__product-remove a:hover {
    background: #c93b3b;
    transform: translateY(-1px);
}

.elementor-menu-cart__product-remove a:hover:before {
    color: #ffffff;
}

/* 7. SOUS-TOTAL */
.elementor-menu-cart__subtotal {
    padding-top: 14px;
    margin-top: 4px;
    border-top: 1px solid #e4ded1;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 15px;
    font-weight: 600;
    color: #252525;
}

.elementor-menu-cart__subtotal .amount {
    color: #D4AF37;
    font-weight: 700;
}

/* 8. BOUTONS — forme + couleur cohérentes avec le site */
.elementor-menu-cart__footer-buttons {
    margin-top: 4px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Base boutons mini-cart */
.elementor-menu-cart__footer-buttons .elementor-button {
    display: block;
    width: 100%;
    padding: 12px 18px;
    border-radius: 999px;              /* forme pilule */
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    text-align: center;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

/* Bouton "Voir le panier" – contour vert, fond clair */
.elementor-menu-cart__footer-buttons .elementor-button--view-cart {
    background: transparent !important;
    color: #D4AF37 !important;
    border-color: #D4AF37 !important;
}

.elementor-menu-cart__footer-buttons .elementor-button--view-cart:hover {
    background: #D4AF37 !important;
    color: #ffffff !important;
}

/* Bouton "Commander" – vert plein */
.elementor-menu-cart__footer-buttons .elementor-button--checkout {
    background: #D4AF37 !important;
    color: #ffffff !important;
    border-color: #D4AF37 !important;

}

.elementor-menu-cart__footer-buttons .elementor-button--checkout:hover {
    background: #D4AF37 !important;
    border-color: #D4AF37 !important;

}

/* 9. SCROLLBAR DANS LA LISTE PRODUITS (discret) */
.elementor-menu-cart__products::-webkit-scrollbar {
    width: 6px;
}
.elementor-menu-cart__products::-webkit-scrollbar-track {
    background: transparent;
}
.elementor-menu-cart__products::-webkit-scrollbar-thumb {
    background: #d0c7b6;
    border-radius: 20px;
}
.elementor-menu-cart__products::-webkit-scrollbar-thumb:hover {
    background: #b3a894;
}
