/**
Theme Name: Astra Child � Sunu Engrais
Theme URI: https://eco-diamba-ndaye.sn/
Author: Eco-Diamba Ndaye
Author URI: https://eco-diamba-ndaye.sn/
Description: Child theme of Astra for the Eco-Diamba Ndaye / Sunu Engrais website. Carries the brand design tokens (colors, fonts, radius) derived from the prototype.
Template: astra
Version: 1.2.6
Requires at least: 5.3
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astra-child
*/

/*
==============================================
  ECO-DIAMBA NDAYE � DESIGN TOKENS
  Fichier de variables CSS officiel
  � coller dans : Th�me enfant Astra > style.css
  Pr�fixe obligatoire : .eco-diamba
==============================================
*/

/* ============================================
   1. COULEURS PRINCIPALES
   ============================================ */
:root {
  /* Couleurs de marque */
  --ed-color-primary:          #1A3A2A;   /* Vert for�t � couleur principale */
  --ed-color-primary-hover:    #2D5A40;   /* Vert interm�diaire � hover/actif */
  --ed-color-primary-light:    #E8F0EB;   /* Vert tr�s p�le � fonds secondaires */
  --ed-color-accent:           #C8A84B;   /* Or sah�lien � CTA secondaires, badges */
  --ed-color-accent-hover:     #A8883B;   /* Or fonc� � hover sur accent */

  /* Fonds */
  --ed-color-bg:               #F5F0E8;   /* Beige cr�me � fond g�n�ral */
  --ed-color-bg-alt:           #EDE8DC;   /* Beige l�g�rement fonc� � sections altern�es */
  --ed-color-surface:          #FFFFFF;   /* Blanc pur � cartes, modals */
  --ed-color-surface-dark:     #1A3A2A;   /* Vert fonc� � sections sombres */

  /* Textes */
  --ed-color-text:             #1C1C1C;   /* Texte principal */
  --ed-color-text-muted:       #6B6B5A;   /* Texte secondaire / labels */
  --ed-color-text-light:       #FFFFFF;   /* Texte sur fonds sombres */
  --ed-color-text-accent:      #C8A84B;   /* Texte accent / r�les �quipe */

  /* Bordures */
  --ed-color-border:           #D4CEBC;   /* Bordures subtiles */
  --ed-color-border-focus:     #1A3A2A;   /* Bordure focus input */

  /* �tats */
  --ed-color-success:          #2E7D32;
  --ed-color-warning:          #F9A825;
  --ed-color-error:            #B71C1C;

  /* WhatsApp */
  --ed-color-whatsapp:         #25D366;
  --ed-color-whatsapp-hover:   #1DA851;

  /* ============================================
     CODE COULEUR SALINSMART
     NE PAS MODIFIER � Standard OMS salinit�
     ============================================ */
  --salin-green:               #2E7D32;   /* Sol sain      � CE < 2 dS/m */
  --salin-green-bg:            #E8F5E9;   /* Fond vert p�le */
  --salin-yellow:              #F9A825;   /* Tol�rable     � CE 2�4 dS/m */
  --salin-yellow-bg:           #FFF8E1;   /* Fond jaune p�le */
  --salin-orange:              #E65100;   /* Critique      � CE 4�8 dS/m */
  --salin-orange-bg:           #FBE9E7;   /* Fond orange p�le */
  --salin-red:                 #B71C1C;   /* Danger urgent � CE > 8 dS/m */
  --salin-red-bg:              #FFEBEE;   /* Fond rouge p�le */
}


/* ============================================
   2. TYPOGRAPHIE
   ============================================ */
:root {
  /* Familles de polices */
  --ed-font-heading:    'Playfair Display', Georgia, serif;
  --ed-font-body:       'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --ed-font-mono:       'JetBrains Mono', 'Space Mono', monospace; /* Chiffres SalinSmart */

  /* Tailles de police � Desktop */
  --ed-text-hero:       72px;    /* H1 hero uniquement */
  --ed-text-h1:         48px;    /* Titres de page */
  --ed-text-h2:         36px;    /* Titres de section */
  --ed-text-h3:         24px;    /* Titres de carte */
  --ed-text-h4:         20px;    /* Sous-titres */
  --ed-text-body-lg:    18px;    /* Corps large */
  --ed-text-body:       16px;    /* Corps standard */
  --ed-text-sm:         14px;    /* Labels, badges */
  --ed-text-xs:         12px;    /* Mentions, sous-labels */

  /* Tailles de police � Mobile (< 768px) */
  --ed-text-hero-mobile:  38px;
  --ed-text-h1-mobile:    32px;
  --ed-text-h2-mobile:    28px;
  --ed-text-h3-mobile:    20px;

  /* Graisse */
  --ed-font-regular:    400;
  --ed-font-medium:     500;
  --ed-font-semibold:   600;
  --ed-font-bold:       700;

  /* Hauteur de ligne */
  --ed-leading-tight:   1.2;
  --ed-leading-normal:  1.6;
  --ed-leading-loose:   1.8;

  /* Espacement lettres */
  --ed-tracking-tight:  -0.02em;  /* Grands titres */
  --ed-tracking-normal:  0em;
  --ed-tracking-wide:    0.05em;  /* Badges, labels uppercase */
  --ed-tracking-wider:   0.1em;   /* Labels section uppercase */
}


/* ============================================
   3. ESPACEMENTS
   ============================================ */
:root {
  /* �chelle d'espacements */
  --ed-space-1:    4px;
  --ed-space-2:    8px;
  --ed-space-3:    12px;
  --ed-space-4:    16px;
  --ed-space-5:    20px;
  --ed-space-6:    24px;
  --ed-space-8:    32px;
  --ed-space-10:   40px;
  --ed-space-12:   48px;
  --ed-space-16:   64px;
  --ed-space-20:   80px;
  --ed-space-24:   96px;

  /* Padding des sections */
  --ed-section-py:         80px;   /* Padding vertical sections desktop */
  --ed-section-py-mobile:  48px;   /* Padding vertical sections mobile */
  --ed-section-px:         24px;   /* Padding horizontal sections mobile */

  /* Padding des composants */
  --ed-btn-py:             16px;   /* Bouton � padding vertical */
  --ed-btn-px:             32px;   /* Bouton � padding horizontal */
  --ed-btn-py-sm:          10px;
  --ed-btn-px-sm:          20px;

  --ed-card-p:             24px;   /* Padding interne des cartes */
  --ed-card-p-mobile:      16px;

  --ed-input-py:           12px;   /* Input � padding vertical */
  --ed-input-px:           16px;   /* Input � padding horizontal */

  /* Largeur maximale du contenu */
  --ed-container-max:      1200px;
  --ed-container-md:       900px;
  --ed-container-sm:       600px;
}


/* ============================================
   4. BORDURES ET ARRONDIS
   ============================================ */
:root {
  --ed-radius-sm:      6px;    /* Petits �l�ments : badges texte, tags */
  --ed-radius-md:      8px;    /* Boutons, inputs */
  --ed-radius-lg:      12px;   /* Cartes produits, blocs */
  --ed-radius-xl:      16px;   /* Grandes cartes, modals */
  --ed-radius-2xl:     24px;   /* Badges pilule, encarts */
  --ed-radius-full:    9999px; /* Bouton WhatsApp, avatars */

  --ed-border-width:   1px;
  --ed-border-style:   solid;
}


/* ============================================
   5. OMBRES
   ============================================ */
:root {
  --ed-shadow-xs:  0 1px 3px rgba(26, 58, 42, 0.08);
  --ed-shadow-sm:  0 2px 8px rgba(26, 58, 42, 0.10);
  --ed-shadow-md:  0 4px 24px rgba(26, 58, 42, 0.12);  /* Cartes produits */
  --ed-shadow-lg:  0 8px 40px rgba(26, 58, 42, 0.16);  /* Modals, dropdowns */
  --ed-shadow-xl:  0 16px 64px rgba(26, 58, 42, 0.20); /* Hero �l�ments flottants */

  /* Ombre bouton principal au hover */
  --ed-shadow-btn: 0 4px 16px rgba(26, 58, 42, 0.30);
}


/* ============================================
   6. TRANSITIONS ET ANIMATIONS
   ============================================ */
:root {
  --ed-transition-fast:    0.15s ease;
  --ed-transition-normal:  0.3s ease;
  --ed-transition-slow:    0.5s ease;

  /* Hover scale sur cartes */
  --ed-hover-scale:        scale(1.03);

  /* Dur�e animation compteur (chiffres cl�s accueil) */
  --ed-counter-duration:   2000ms;
}


/* ============================================
   7. BREAKPOINTS (pour r�f�rence commentaires)
   ============================================ */
/*
  Mobile small :  < 480px
  Mobile :        < 768px   ? @media (max-width: 767px)
  Tablette :      768�1024px ? @media (max-width: 1024px)
  Desktop :       > 1024px
  Large :         > 1280px
*/


/* ============================================
   8. COMPOSANTS � STYLES DE BASE
   ============================================ */

/* --- Conteneur g�n�ral --- */
.eco-diamba .ed-container {
  max-width: var(--ed-container-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--ed-space-6);
  padding-right: var(--ed-space-6);
}

/* --- Typographie --- */
.eco-diamba h1,
.eco-diamba h2,
.eco-diamba h3,
.eco-diamba h4 {
  font-family: var(--ed-font-heading);
  color: var(--ed-color-text);
  line-height: var(--ed-leading-tight);
  letter-spacing: var(--ed-tracking-tight);
}

.eco-diamba p,
.eco-diamba span,
.eco-diamba li {
  font-family: var(--ed-font-body);
  font-size: var(--ed-text-body);
  line-height: var(--ed-leading-normal);
  color: var(--ed-color-text);
}

/* --- Bouton principal --- */
.eco-diamba .ed-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ed-space-2);
  padding: var(--ed-btn-py) var(--ed-btn-px);
  background-color: var(--ed-color-primary);
  color: var(--ed-color-text-light);
  font-family: var(--ed-font-body);
  font-size: var(--ed-text-body);
  font-weight: var(--ed-font-semibold);
  border: none;
  border-radius: var(--ed-radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: background-color var(--ed-transition-normal),
              box-shadow var(--ed-transition-normal),
              transform var(--ed-transition-fast);
}
.eco-diamba .ed-btn-primary:hover {
  background-color: var(--ed-color-primary-hover);
  box-shadow: var(--ed-shadow-btn);
  transform: translateY(-1px);
}

/* --- Bouton accent (or) --- */
.eco-diamba .ed-btn-accent {
  background-color: var(--ed-color-accent);
  color: var(--ed-color-primary);
  font-weight: var(--ed-font-bold);
  padding: var(--ed-btn-py) var(--ed-btn-px);
  border-radius: var(--ed-radius-md);
  border: none;
  cursor: pointer;
  transition: background-color var(--ed-transition-normal);
}
.eco-diamba .ed-btn-accent:hover {
  background-color: var(--ed-color-accent-hover);
}

/* --- Bouton outline (contour) --- */
.eco-diamba .ed-btn-outline {
  background-color: transparent;
  color: var(--ed-color-primary);
  border: var(--ed-border-width) var(--ed-border-style) var(--ed-color-primary);
  padding: var(--ed-btn-py) var(--ed-btn-px);
  border-radius: var(--ed-radius-md);
  cursor: pointer;
  transition: all var(--ed-transition-normal);
}
.eco-diamba .ed-btn-outline:hover {
  background-color: var(--ed-color-primary);
  color: var(--ed-color-text-light);
}

/* --- Bouton WhatsApp flottant --- */
.eco-diamba .ed-btn-whatsapp-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  padding: 0;
  background-color: var(--ed-color-whatsapp);
  border-radius: 50%;
  box-shadow: var(--ed-shadow-md);
  text-decoration: none;
  cursor: pointer;
  animation: ed-pulse 4s infinite;
}
.eco-diamba .ed-btn-whatsapp-float svg {
  width: 32px;
  height: 32px;
  stroke: #FFFFFF;
  fill: none;
}
.eco-diamba .ed-btn-whatsapp-float:hover {
  background-color: var(--ed-color-whatsapp-hover);
  color: #FFFFFF;
}

/* --- Carte produit --- */
.eco-diamba .ed-product-card {
  background-color: var(--ed-color-surface);
  border-radius: var(--ed-radius-lg);
  box-shadow: var(--ed-shadow-sm);
  overflow: hidden;
  transition: transform var(--ed-transition-normal),
              box-shadow var(--ed-transition-normal);
}
.eco-diamba .ed-product-card:hover {
  transform: var(--ed-hover-scale);
  box-shadow: var(--ed-shadow-md);
}
.eco-diamba .ed-product-card-body {
  padding: var(--ed-card-p);
}

/* --- Badge produit --- */
.eco-diamba .ed-badge {
  display: inline-block;
  padding: var(--ed-space-1) var(--ed-space-3);
  border-radius: var(--ed-radius-sm);
  font-family: var(--ed-font-body);
  font-size: var(--ed-text-xs);
  font-weight: var(--ed-font-semibold);
  letter-spacing: var(--ed-tracking-wide);
  text-transform: uppercase;
}
.eco-diamba .ed-badge-primary {
  background-color: var(--ed-color-primary);
  color: var(--ed-color-text-light);
}
.eco-diamba .ed-badge-accent {
  background-color: var(--ed-color-accent);
  color: var(--ed-color-primary);
}

/* --- Badges SalinSmart --- */
.eco-diamba .ed-badge-salin-green {
  background-color: var(--salin-green-bg);
  color: var(--salin-green);
  border: 1px solid var(--salin-green);
}
.eco-diamba .ed-badge-salin-yellow {
  background-color: var(--salin-yellow-bg);
  color: var(--salin-yellow);
  border: 1px solid var(--salin-yellow);
}
.eco-diamba .ed-badge-salin-orange {
  background-color: var(--salin-orange-bg);
  color: var(--salin-orange);
  border: 1px solid var(--salin-orange);
}
.eco-diamba .ed-badge-salin-red {
  background-color: var(--salin-red-bg);
  color: var(--salin-red);
  border: 1px solid var(--salin-red);
}

/* --- Input / Select --- */
.eco-diamba .ed-input {
  width: 100%;
  padding: var(--ed-input-py) var(--ed-input-px);
  background-color: var(--ed-color-surface);
  border: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
  border-radius: var(--ed-radius-md);
  font-family: var(--ed-font-body);
  font-size: var(--ed-text-body);
  color: var(--ed-color-text);
  transition: border-color var(--ed-transition-fast);
  outline: none;
}
.eco-diamba .ed-input:focus {
  border-color: var(--ed-color-border-focus);
  box-shadow: 0 0 0 3px rgba(26, 58, 42, 0.12);
}

/* --- Section g�n�rique --- */
.eco-diamba .ed-section {
  padding-top: var(--ed-section-py);
  padding-bottom: var(--ed-section-py);
}
.eco-diamba .ed-section-dark {
  background-color: var(--ed-color-surface-dark);
  color: var(--ed-color-text-light);
}
.eco-diamba .ed-section-alt {
  background-color: var(--ed-color-bg-alt);
}

/* --- Chiffres SalinSmart (monospace) --- */
.eco-diamba .ed-salin-value {
  font-family: var(--ed-font-mono);
  font-size: 48px;
  font-weight: var(--ed-font-bold);
  color: var(--ed-color-text-light);
  line-height: 1;
}

/* ============================================
   9. ANIMATIONS
   ============================================ */

/* Pulse WhatsApp */
@keyframes ed-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.4); }
  50%       { box-shadow: 0 0 0 12px rgba(37, 211, 102, 0); }
}

/* Fade-up au scroll (ajouter la classe .ed-fade-up via JS IntersectionObserver) */
.eco-diamba .ed-fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.eco-diamba .ed-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Compteur anim� (JS requis) */
.eco-diamba .ed-counter {
  font-family: var(--ed-font-heading);
  font-size: var(--ed-text-h1);
  font-weight: var(--ed-font-bold);
  color: var(--ed-color-primary);
}


/* ============================================
   10. OVERRIDES ASTRA � RESET CONFLITS
   � placer APR�S les styles Astra dans style.css
   ============================================ */
.eco-diamba a {
  color: inherit;
  text-decoration: none;
}
.eco-diamba button {
  font-family: var(--ed-font-body);
}
.eco-diamba img {
  max-width: 100%;
  height: auto;
  display: block;
}
/* Emp�che Astra d'�craser les couleurs de boutons */
.eco-diamba .ed-btn-primary,
.eco-diamba .ed-btn-accent,
.eco-diamba .ed-btn-outline {
  box-sizing: border-box;
  line-height: normal;
}


/* ============================================
   11. RESPONSIVE � AJUSTEMENTS MOBILE
   ============================================ */
@media (max-width: 767px) {
  .eco-diamba .ed-section {
    padding-top: var(--ed-section-py-mobile);
    padding-bottom: var(--ed-section-py-mobile);
  }
  .eco-diamba .ed-product-card-body {
    padding: var(--ed-card-p-mobile);
  }
  .eco-diamba .ed-salin-value {
    font-size: 36px;
  }
  .eco-diamba .ed-counter {
    font-size: var(--ed-text-h2);
  }
  /* Le bouton WhatsApp flottant reste en bas droite sur mobile */
  .eco-diamba .ed-btn-whatsapp-float {
    bottom: 16px;
    right: 16px;
    width: 50px;
    height: 50px;
    padding: 0;
  }
  .eco-diamba .ed-btn-whatsapp-float svg {
    width: 26px;
    height: 26px;
  }
}

/* =============================================================
   Brand design tokens � Eco-Diamba Ndaye / Sunu Engrais
   Source: prototype eco-diamanay.lovable.app (OKLCH, exact)
   Hex fallbacks provided for older browsers.
   ============================================================= */
:root {
    /* Core */
    --edn-background: oklch(98.5% .012 100);   /* #FAF8F0 */
    --edn-foreground: oklch(22% .03 75);       /* #2E2619 */
    --edn-surface: oklch(100% 0 0);            /* #FFFFFF */
    --edn-surface-muted: oklch(95% .025 130);  /* #EDF0E6 */
    --edn-border: oklch(86% .03 130);          /* #D2D6C7 */
    --edn-muted: oklch(94% .02 130);           /* #EBEDE4 */
    --edn-muted-foreground: oklch(42% .04 130);/* #5E6450 */

    /* Brand */
    --edn-primary: oklch(52% .11 145);         /* #3A7A4E */
    --edn-primary-foreground: oklch(98.5% .012 100); /* #FAF8F0 */
    --edn-primary-deep: oklch(32% .08 145);    /* #214D30 */
    --edn-gold: oklch(78% .14 90);             /* #D9A627 */
    --edn-gold-foreground: oklch(22% .03 75);  /* #2E2619 */
    --edn-earth: oklch(35% .07 60);            /* #5C4327 */
    --edn-ink: oklch(22% .04 130);             /* #272B1E */

    /* SalinSmart status */
    --edn-status-green: oklch(62% .15 145);    /* #419A5F */
    --edn-status-yellow: oklch(82% .16 95);    /* #E6C02E */
    --edn-status-orange: oklch(70% .18 55);    /* #E2823A */
    --edn-status-red: oklch(58% .22 27);       /* #D63B2D */

    /* Payments */
    --edn-wave: oklch(55% .2 245);             /* #2C6FD6 */
    --edn-orange-money: oklch(70% .18 50);     /* #E27D33 */
    --edn-free-money: oklch(55% .22 27);       /* #CF2E22 */
    --edn-whatsapp: oklch(62% .17 150);        /* #25A35A */

    /* Typography */
    --edn-font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --edn-font-display: "Anton", Impact, sans-serif;
    --edn-font-mono: "JetBrains Mono", ui-monospace, monospace;

    /* Shape */
    --edn-radius: 16px;

    /* Header */
    --edn-banner-h: var(--ed-space-10);
}

/* =============================================================
   HEADER � adapt� aux tokens --ed-* (�TAPE 2)
   Cible le markup Astra Header Footer Builder (HFB).
   ============================================================= */

/* --- Header sticky : la barre blanche se fige tout en haut --- */
#masthead {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 1000;
    background-color: var(--ed-color-surface);
}

/* Barre header translucide + ombre subtile */
.site-header .ast-primary-header-bar,
.site-header .main-header-bar,
.site-header .ast-mobile-header-wrap .ast-primary-header-bar {
    background-color: rgba(255, 255, 255, 0.95);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
    box-shadow: var(--ed-shadow-xs);
}

/* Hauteur header desktop */
.site-header .ast-primary-header-bar .site-primary-header-wrap {
    min-height: 72px;
}

/* --- Logo : titre du site --- */
.site-header .site-title,
.site-header .site-title a {
    font-family: var(--ed-font-heading);
    letter-spacing: var(--ed-tracking-tight);
    font-weight: var(--ed-font-bold);
    line-height: var(--ed-leading-tight);
    color: var(--ed-color-primary);
}

.site-header .site-title a:hover,
.site-header .site-title a:focus {
    color: var(--ed-color-primary-hover);
}

.site-header .site-description {
    font-family: var(--ed-font-body);
    text-transform: none;
    letter-spacing: var(--ed-tracking-wide);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-medium);
    color: var(--ed-color-text-muted);
    margin-top: var(--ed-space-1);
}

/* --- Navigation: centered, brand colors --- */
.site-header-primary-section-center {
    justify-content: center;
}

.main-header-menu .menu-link,
.main-header-bar .main-header-menu > .menu-item > .menu-link {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-medium);
    color: var(--ed-color-text-muted);
    transition: color var(--ed-transition-fast);
}

.main-header-menu .menu-item:hover > .menu-link,
.main-header-menu .menu-item:focus-within > .menu-link,
.main-header-menu .current-menu-item > .menu-link,
.main-header-menu .current_page_item > .menu-link {
    color: var(--ed-color-primary);
}

/* Sous-menus */
.main-header-menu .sub-menu {
    border-top: 3px solid var(--ed-color-primary);
    border-radius: 0 0 var(--ed-radius-md) var(--ed-radius-md);
    box-shadow: var(--ed-shadow-lg);
}

/* --- Panier WooCommerce (droite) --- */
#ast-site-header-cart a,
#ast-site-header-cart .ast-cart-menu-wrap {
    color: var(--ed-color-text-muted);
}

#ast-site-header-cart a:hover,
#ast-site-header-cart .ast-cart-menu-wrap:hover {
    color: var(--ed-color-primary);
}

#ast-site-header-cart .ast-cart-menu-wrap .count,
.ast-site-header-cart .ast-cart-menu-wrap .count,
.ast-cart-menu-wrap .count {
    background-color: var(--ed-color-primary);
    color: var(--ed-color-text-light);
    border-color: var(--ed-color-primary);
}

/* --- Mobile : burger + panneau --- */
.ast-header-break-point .main-header-menu-toggle,
.ast-mobile-menu-trigger-minimal,
.ast-mobile-menu-trigger-fill,
.menu-toggle {
    color: var(--ed-color-primary);
}

.ast-mobile-menu-trigger-fill {
    background-color: var(--ed-color-primary);
    color: var(--ed-color-text-light);
    border-radius: var(--ed-radius-md);
}

.ast-button-wrap .menu-toggle .ast-mobile-svg,
.ast-mobile-svg.ast-menu-svg,
.mobile-menu-toggle-icon .ast-mobile-svg {
    fill: currentColor;
}

.ast-mobile-popup-drawer .main-header-menu .menu-link,
.ast-mobile-header-wrap .main-header-menu .menu-link {
    font-family: var(--ed-font-body);
    font-weight: var(--ed-font-medium);
    color: var(--ed-color-text);
}

/* --- S�lecteur de langue FR | EN --- */
.edn-lang-item {
    display: flex;
    align-items: center;
}

.edn-lang-switch {
    display: inline-flex;
    align-items: center;
    border: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
    border-radius: var(--ed-radius-full);
    overflow: hidden;
    font-family: var(--ed-font-mono);
    font-size: var(--ed-text-xs);
    line-height: 1;
}

.edn-lang-switch .edn-lang {
    appearance: none;
    -webkit-appearance: none;
    background: transparent;
    border: 0;
    margin: 0;
    padding: var(--ed-space-1) var(--ed-space-3);
    cursor: pointer;
    color: var(--ed-color-text-muted);
    font-family: inherit;
    font-size: inherit;
    letter-spacing: var(--ed-tracking-wide);
    line-height: 1;
    transition: background-color var(--ed-transition-fast), color var(--ed-transition-fast);
}

.edn-lang-switch .edn-lang.is-active {
    background-color: var(--ed-color-primary);
    color: var(--ed-color-text-light);
}

/* Masquer le pill FR|EN sur mobile */
@media (max-width: 767px) {
    .edn-lang-item {
        display: none;
    }
}

/* --- Cart link (right) --- */
.edn-cart-item,
.edn-account-item {
    display: flex;
    align-items: center;
    margin-left: var(--ed-space-4); /* Ajout d'espacement */
}

.edn-cart {
    position: relative;
    display: inline-flex;
    align-items: center;
    color: var(--ed-color-text-muted);
    transition: color var(--ed-transition-fast);
}

.edn-cart:hover,
.edn-cart:focus {
    color: var(--ed-color-primary);
}

.edn-cart svg {
    width: 20px;
    height: 20px;
    display: block;
}

.edn-cart-count {
    position: absolute;
    top: -5px;
    right: -6px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 3px;
    border-radius: var(--ed-radius-full);
    background-color: var(--ed-color-accent);
    color: white !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1;
    font-family: var(--ed-font-body);
}

.edn-cart-label {
    color: inherit;
}

@media (max-width: 767px) {
    .edn-cart-label {
        display: none;
    }
}

/* =============================================================
   FOOTER � prototype layout (brand / navigation / paiements)
   Rendered via astra_footer_content (priority 5), above the
   existing Astra copyright bar.
   ============================================================= */
.edn-footer-main {
    background-color: var(--ed-color-surface-dark);
    color: var(--ed-color-text-light);
    padding: var(--ed-space-16) var(--ed-space-5) var(--ed-space-10);
    /* border-top supprim� pour �viter le double trait avec .site-below-footer-wrap */
}

/* --- Barre copyright : liens l�gaux � gauche, copyright � droite --- */
.eco-diamba .site-below-footer-wrap,
.edn-home-transparent .site-below-footer-wrap,
body .site-below-footer-wrap[data-section="section-below-footer-builder"] {
    border-top: 1px solid rgba(255, 255, 255, 0.10);
    margin-top: 0;
}

.ast-footer-copyright p {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--ed-space-3);
    width: 100%;
    margin: 0;
}

.edn-legal {
    display: inline-flex;
    align-items: center;
    gap: var(--ed-space-2);
    font-size: var(--ed-text-xs);
}

.edn-legal a {
    color: rgba(255, 255, 255, 0.50);
    text-decoration: none;
    transition: color var(--ed-transition-fast);
}

.edn-legal a:hover,
.edn-legal a:focus {
    color: rgba(255, 255, 255, 0.85);
}

.edn-legal-sep {
    color: rgba(255, 255, 255, 0.30);
}

.edn-footer-inner {
    max-width: var(--ed-container-max);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: var(--ed-space-10);
}

.edn-footer-logo {
    font-family: var(--ed-font-heading);
    letter-spacing: var(--ed-tracking-tight);
    font-size: 20px;
    font-weight: bold;
    line-height: var(--ed-leading-tight);
    color: #ffffff !important;
    margin-bottom: var(--ed-space-4);
}

.edn-footer-logo span {
    color: #ffffff !important;
}

.edn-footer-desc {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    line-height: var(--ed-leading-normal);
    color: rgba(255, 255, 255, 0.60) !important;
    margin: 0 0 var(--ed-space-6);
    max-width: 42ch;
}

.edn-footer-loc {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: rgba(255, 255, 255, 0.55);
    margin: 0;
}

/* Ic�nes sociales (colonne marque) */
.edn-footer-social {
    display: flex;
    align-items: center;
    gap: var(--ed-space-3);
    margin: 0 0 var(--ed-space-4);
}

.edn-footer-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.1);
    color: #ffffff;
    transition: background-color var(--ed-transition-fast), color var(--ed-transition-fast);
}

.edn-footer-social-link.wa:hover,
.edn-footer-social-link.wa:focus {
    background-color: #25D366;
}

.edn-footer-social-link.li:hover,
.edn-footer-social-link.li:focus {
    background-color: #0077B5;
}

.edn-footer-social-link svg {
    width: 20px;
    height: 20px;
    display: block;
}

.edn-footer-col h4 {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    text-transform: uppercase;
    letter-spacing: var(--ed-tracking-wider);
    color: #ffffff;
    margin: 0 0 var(--ed-space-4);
}

.edn-footer-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.edn-footer-col li {
    margin: 0 0 var(--ed-space-2);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: rgba(255, 255, 255, 0.70);
}

.edn-footer-col a {
    color: #ffffff;
    text-decoration: none;
    transition: color var(--ed-transition-fast);
}

.edn-footer-col a:hover,
.edn-footer-col a:focus {
    color: #C8A84B; /* Couleur dor�e au survol comme dans Base44 */
}

.edn-footer-pay-pills span {
    padding: 4px 12px;
    border-radius: 4px;
    background-color: rgba(255, 255, 255, 0.1);
    color: #ffffff !important;
    white-space: nowrap;
}

/* Barre copyright Astra harmonis�e avec le footer sombre */
.site-footer .site-below-footer-wrap {
    background-color: var(--ed-color-surface-dark);
    border-top: var(--ed-border-width) var(--ed-border-style) rgba(255, 255, 255, 0.10);
}

.site-footer .ast-footer-copyright {
    background-color: transparent;
    border-top: none;
}

.site-footer .ast-footer-copyright p {
    color: rgba(255, 255, 255, 0.40);
    font-family: var(--ed-font-body);
    font-size: 12px;
}

.site-footer .ast-footer-copyright a {
    color: rgba(255, 255, 255, 0.40);
    transition: color 0.2s;
}
.site-footer .ast-footer-copyright a:hover {
    color: rgba(255, 255, 255, 0.60);
}

@media (max-width: 1024px) {
    .edn-footer-inner {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 767px) {
    .edn-footer-inner {
        grid-template-columns: 1fr;
        gap: var(--ed-space-8);
    }
}

/* =============================================================
   PAGE ACCUEIL � sections (.eco-diamba .edn-accueil)
   ============================================================= */

/* ---------- ACCUEIL : casser le conteneur Astra (pleine largeur) ---------- */
.eco-diamba.edn-accueil,
body .eco-diamba.edn-accueil {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* ---------- SECTION 1 : HERO ---------- */
.eco-diamba .ed-hero {
    position: relative;
    display: flex;
    align-items: center;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    min-height: 100vh;
    overflow: hidden;
    background-color: var(--ed-color-surface-dark);
    background-image: url('https://images.unsplash.com/photo-1625246333195-78d9c38ad449');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.eco-diamba .ed-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(26, 58, 42, 0.65);
}

.eco-diamba .ed-hero-inner {
    position: relative;
    z-index: 1;
    padding-top: var(--ed-space-24);
    padding-bottom: var(--ed-space-24);
    text-align: center;
}

.eco-diamba .ed-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--ed-space-2);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
    background-color: rgba(255, 255, 255, 0.95);
    padding: var(--ed-space-2) var(--ed-space-4);
    border-radius: var(--ed-radius-full);
    margin-bottom: var(--ed-space-8);
    box-shadow: var(--ed-shadow-lg);
}

.eco-diamba .ed-pulse-icon {
    animation: ed-bounce-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes ed-bounce-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .5; }
}

.eco-diamba .ed-hero-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-hero);
    font-weight: var(--ed-font-bold);
    line-height: var(--ed-leading-tight);
    letter-spacing: var(--ed-tracking-tight);
    color: var(--ed-color-text-light);
    max-width: 800px;
    margin: 0 auto var(--ed-space-6) auto;
}

.eco-diamba .ed-hero-subtitle {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    line-height: var(--ed-leading-normal);
    color: rgba(255, 255, 255, 0.80);
    max-width: 600px;
    margin: 0 auto var(--ed-space-8) auto;
}

.eco-diamba .ed-hero-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--ed-space-4);
    margin-bottom: var(--ed-space-10);
}

/* Boutons Hero (plus grands) */
.eco-diamba .ed-btn-hero {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--ed-space-2);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    font-weight: var(--ed-font-semibold);
    padding: var(--ed-space-4) var(--ed-space-8);
    border-radius: var(--ed-radius-md);
    cursor: pointer;
    text-decoration: none;
    transition: background-color var(--ed-transition-normal),
                border-color var(--ed-transition-normal),
                box-shadow var(--ed-transition-normal),
                transform var(--ed-transition-fast);
}

/* CTA 1 � or plein (action principale sur fond sombre) */
.eco-diamba .ed-hero .ed-btn-accent.ed-btn-hero {
    background: var(--ed-color-accent);
    color: var(--ed-color-primary);
    border: var(--ed-border-width) var(--ed-border-style) transparent;
}
.eco-diamba .ed-hero .ed-btn-accent.ed-btn-hero:hover {
    background: var(--ed-color-accent-hover);
    transform: translateY(-1px);
    box-shadow: var(--ed-shadow-md);
}

/* CTA 2 � contour clair */
.eco-diamba .ed-hero .ed-btn-outline.ed-btn-hero {
    background: transparent;
    color: var(--ed-color-text-light);
    border: var(--ed-border-width) var(--ed-border-style) rgba(255, 255, 255, 0.55);
}
.eco-diamba .ed-hero .ed-btn-outline.ed-btn-hero:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: var(--ed-color-text-light);
}

.eco-diamba .ed-hero-pay {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--ed-space-3);
}

.eco-diamba .ed-hero-pay-label {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: rgba(255, 255, 255, 0.65);
}

.eco-diamba .ed-pay-badge {
    display: inline-block;
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-xs);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-text-light);
    background: rgba(255, 255, 255, 0.10);
    border: var(--ed-border-width) var(--ed-border-style) rgba(255, 255, 255, 0.18);
    border-radius: var(--ed-radius-sm);
    padding: var(--ed-space-1) var(--ed-space-3);
}

@media (max-width: 767px) {
    .eco-diamba .ed-hero-inner {
        padding-top: var(--ed-space-20);
        padding-bottom: var(--ed-space-16);
    }
    .eco-diamba .ed-hero-title {
        font-size: var(--ed-text-hero-mobile);
    }
    .eco-diamba .ed-hero-subtitle {
        font-size: var(--ed-text-body);
    }
    .eco-diamba .ed-hero-actions .ed-btn-hero {
        width: 100%;
        font-size: var(--ed-text-body);
    }
}

/* =============================================================
   HEADER DYNAMIQUE � Accueil (transparent en haut, solide au scroll)
/* Header en overlay sur le Hero (hors flux) tant qu'on est en haut */
#masthead .site-title a {
    display: inline-flex;
    align-items: center;
}

/* Ajout dynamique du logo via CSS (s'il n'est pas d�fini dans le Customizer) */
#masthead .site-title a::before {
    content: "";
    display: inline-block;
    width: 48px;
    height: 48px;
    background-image: url('https://media.base44.com/images/public/6a35a30c2cb30f7f9eea1d17/5c43f7355_image.png');
    background-size: cover;
    background-position: center;
    border-radius: var(--ed-radius-full);
    margin-right: var(--ed-space-3);
    box-shadow: var(--ed-shadow-sm);
    flex-shrink: 0;
}

#masthead .custom-logo-link img {
    width: 48px !important;
    height: 48px !important;
    max-width: 48px !important;
    border-radius: var(--ed-radius-full);
    object-fit: cover;
    box-shadow: var(--ed-shadow-sm);
}

#masthead .site-title,
#masthead .site-title a {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h4) !important;
    font-weight: var(--ed-font-bold) !important;
    letter-spacing: var(--ed-tracking-tight);
    margin: 0 !important;
    padding: 0 !important;
}

#masthead .main-header-menu .menu-link {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm) !important;
    font-weight: var(--ed-font-medium) !important;
}

#masthead .ast-builder-grid-row {
    align-items: center !important;
}

#masthead .ast-primary-header-bar,
#masthead .main-header-bar {
    height: auto !important;
    min-height: 0 !important;
}

.edn-home-transparent #masthead {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background-color: transparent;
    transition: all var(--ed-transition-normal);
}

/* �tat TOP : barre transparente, pas d'ombre */
.edn-home-transparent:not(.ed-header-scrolled) #masthead .ast-primary-header-bar,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .main-header-bar,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .ast-mobile-header-wrap .ast-primary-header-bar {
    background-color: transparent;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    border-bottom-color: transparent;
    box-shadow: none;
    padding-top: var(--ed-space-4);
    padding-bottom: var(--ed-space-4);
    transition: all var(--ed-transition-normal);
}

/* �tat TOP : textes/liens/ic�nes en blanc */
.edn-home-transparent:not(.ed-header-scrolled) #masthead .site-title,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .site-title a,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .site-description,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .menu-link,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .main-header-bar .main-header-menu > .menu-item > .menu-link,
.edn-home-transparent:not(.ed-header-scrolled) #masthead #ast-site-header-cart a,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .edn-cart,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .edn-cart .edn-cart-label,
.edn-home-transparent:not(.ed-header-scrolled) #masthead .menu-toggle {
    color: var(--ed-color-text-light) !important;
}

/* Rendre le selecteur de langue visible sur le fond sombre (header transparent) */
.edn-home-transparent:not(.ed-header-scrolled) #masthead .edn-lang-switch {
    border-color: rgba(255, 255, 255, 0.3);
}
.edn-home-transparent:not(.ed-header-scrolled) #masthead .edn-lang:not(.is-active) {
    color: rgba(255, 255, 255, 0.7);
}

.edn-home-transparent:not(.ed-header-scrolled) #masthead .main-header-menu .menu-item:hover > .menu-link,
.edn-home-transparent:not(.ed-header-scrolled) #masthead #ast-site-header-cart a:hover {
    color: var(--ed-color-accent);
}

/* �tat SCROLL� : barre fixe blanche translucide + ombre, textes sombres */
.ed-header-scrolled.edn-home-transparent #masthead {
    position: fixed;
    top: 0;
}

.ed-header-scrolled.edn-home-transparent #masthead .ast-primary-header-bar,
.ed-header-scrolled.edn-home-transparent #masthead .main-header-bar,
.ed-header-scrolled.edn-home-transparent #masthead .ast-mobile-header-wrap .ast-primary-header-bar {
    background-color: rgba(255, 255, 255, 0.90);
    -webkit-backdrop-filter: blur(24px);
    backdrop-filter: blur(24px);
    box-shadow: var(--ed-shadow-sm);
    padding-top: var(--ed-space-4);
    padding-bottom: var(--ed-space-4);
    transition: all var(--ed-transition-normal);
}

.ed-header-scrolled.edn-home-transparent #masthead .site-title,
.ed-header-scrolled.edn-home-transparent #masthead .site-title a {
    color: var(--ed-color-primary);
}

.ed-header-scrolled.edn-home-transparent #masthead .main-header-menu .menu-link,
.ed-header-scrolled.edn-home-transparent #masthead #ast-site-header-cart a,
.ed-header-scrolled.edn-home-transparent #masthead .edn-cart,
.ed-header-scrolled.edn-home-transparent #masthead .menu-toggle {
    color: var(--ed-color-text);
}

/* 
 * FIX: Rendre la navbar visible sur la page Compte, Panier et Commande 
 * (où il n'y a pas d'image hero sombre en dessous).
 * On lui donne un fond vert foncé pour que le texte blanc soit lisible. 
 */
.woocommerce-account.edn-home-transparent:not(.ed-header-scrolled) #masthead .ast-primary-header-bar,
.woocommerce-account.edn-home-transparent:not(.ed-header-scrolled) #masthead .main-header-bar,
.woocommerce-cart.edn-home-transparent:not(.ed-header-scrolled) #masthead .ast-primary-header-bar,
.woocommerce-cart.edn-home-transparent:not(.ed-header-scrolled) #masthead .main-header-bar,
.woocommerce-checkout.edn-home-transparent:not(.ed-header-scrolled) #masthead .ast-primary-header-bar,
.woocommerce-checkout.edn-home-transparent:not(.ed-header-scrolled) #masthead .main-header-bar {
    background-color: var(--ed-color-primary) !important;
}

/* Hide native Astra Account icon / Old menu item */
.ast-header-account-wrap,
.ast-header-account {
    display: none !important;
}

/* =============================================================
   SECTION 2  CHIFFRES CLS
   ============================================================= */
.eco-diamba .ed-stats {
    background-color: var(--ed-color-bg);
    padding-top: var(--ed-section-py);
    padding-bottom: var(--ed-section-py);
}

.eco-diamba .ed-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ed-space-8);
    text-align: center;
}

.eco-diamba .ed-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--ed-space-2);
}

.eco-diamba .ed-stat-number {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h1); /* 48px */
    font-weight: var(--ed-font-bold);
    line-height: var(--ed-leading-tight);
    color: var(--ed-color-primary);
}

.eco-diamba .ed-stat-label {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
    text-transform: uppercase;
    letter-spacing: var(--ed-tracking-wide);
}

/* =============================================================
   SECTION 3 � PROBL�ME / SOLUTION
   ============================================================= */
.eco-diamba .ed-ps {
    background-color: var(--ed-color-bg-alt);
    padding-top: var(--ed-section-py);
    padding-bottom: var(--ed-section-py);
}

.eco-diamba .ed-ps-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ed-space-8);
}

.eco-diamba .ed-ps-card {
    padding: var(--ed-card-p);
    border-radius: var(--ed-radius-lg);
}

.eco-diamba .ed-ps-problem {
    border-left: 3px solid var(--ed-color-error);
    background: rgba(183, 28, 28, 0.05);
}

.eco-diamba .ed-ps-solution {
    border-left: 3px solid var(--ed-color-success);
    background: rgba(46, 125, 50, 0.05);
}

.eco-diamba .ed-ps-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h3);
    color: var(--ed-color-text);
    margin: 0 0 var(--ed-space-4);
}

.eco-diamba .ed-ps-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ed-space-3);
}

.eco-diamba .ed-ps-list li {
    position: relative;
    padding-left: var(--ed-space-6);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body);
    line-height: var(--ed-leading-normal);
    color: var(--ed-color-text);
}

.eco-diamba .ed-ps-problem .ed-ps-list li::before {
    content: "�";
    position: absolute;
    left: 0;
    color: var(--ed-color-error);
    font-weight: var(--ed-font-bold);
}

.eco-diamba .ed-ps-solution .ed-ps-list li::before {
    content: "�";
    position: absolute;
    left: 0;
    color: var(--ed-color-success);
    font-weight: var(--ed-font-bold);
}

.eco-diamba .ed-ps-cta {
    text-align: center;
    margin-top: var(--ed-space-10);
}

.eco-diamba .ed-ps-link {
    font-family: var(--ed-font-body);
    font-weight: var(--ed-font-bold);
    font-size: var(--ed-text-body-lg);
    color: var(--ed-color-primary);
    text-decoration: none;
    transition: color var(--ed-transition-fast);
}

.eco-diamba .ed-ps-link:hover {
    color: var(--ed-color-primary-hover);
}

/* Grand titre Section 3 */
.eco-diamba .ed-ps-heading {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h2);
    color: var(--ed-color-text);
    text-align: center;
    margin: 0 0 var(--ed-space-8);
}

/* Titre de section g�n�rique � tous les H2 de section */
.eco-diamba .ed-section-title,
.eco-diamba section > .ed-container > h2,
.eco-diamba .ed-ps-heading,
.eco-diamba .ed-salin-title,
.eco-diamba .ed-newsletter-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h2);
}

.eco-diamba .ed-section-title {
    color: var(--ed-color-text);
    text-align: center;
    margin: 0 0 var(--ed-space-3);
}

/* Sous-titre de section */
.eco-diamba .ed-section-sub {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    color: var(--ed-color-text-muted);
    text-align: center;
    max-width: var(--ed-container-md);
    margin: 0 auto var(--ed-space-10);
    line-height: var(--ed-leading-normal);
}

/* =============================================================
   SECTION 4 � PRODUITS EN VEDETTE
   ============================================================= */
.eco-diamba .ed-products {
    background-color: var(--ed-color-bg);
    padding-top: var(--ed-section-py);
    padding-bottom: var(--ed-section-py);
}

.eco-diamba .ed-products-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ed-space-6);
    max-width: var(--ed-container-max);
    margin-left: auto;
    margin-right: auto;
}

.eco-diamba .ed-product-card {
    background-color: var(--ed-color-surface);
    border-radius: var(--ed-radius-lg);
    overflow: hidden;
    box-shadow: var(--ed-shadow-sm);
    transition: all var(--ed-transition-normal);
}

.eco-diamba .ed-product-card:hover {
    box-shadow: var(--ed-shadow-xl);
    transform: translateY(-4px);
}

.eco-diamba .ed-product-card-body {
    padding: var(--ed-space-5);
}

.eco-diamba .ed-product-media {
    position: relative;
    overflow: hidden;
}

.eco-diamba .ed-product-card img {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    transition: transform var(--ed-transition-normal);
}

.eco-diamba .ed-product-card:hover .ed-product-media img {
    transform: scale(1.05);
}

.eco-diamba .ed-product-fmt {
    position: absolute;
    top: var(--ed-space-3);
    left: var(--ed-space-3);
}

.eco-diamba .ed-product-flag {
    position: absolute;
    top: var(--ed-space-3);
    right: var(--ed-space-3);
}

.eco-diamba .ed-product-name {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-body-lg);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-text);
    margin: 0 0 var(--ed-space-1);
    transition: color var(--ed-transition-fast);
}

.eco-diamba .ed-product-name:hover {
    color: var(--ed-color-primary-hover);
}

.eco-diamba .ed-product-desc {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
    line-height: var(--ed-leading-normal);
    margin: 0 0 var(--ed-space-3);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.eco-diamba .ed-product-rating {
    display: flex;
    align-items: center;
    gap: var(--ed-space-1);
    margin-bottom: var(--ed-space-3);
}

.eco-diamba .ed-product-stars {
    color: var(--ed-color-accent);
    font-size: 14px;
    letter-spacing: 2px;
}

.eco-diamba .ed-product-review-count {
    font-size: var(--ed-text-xs);
    color: var(--ed-color-text-muted);
    margin-left: var(--ed-space-1);
}

.eco-diamba .ed-product-price-wrapper {
    display: flex;
    align-items: baseline;
    gap: var(--ed-space-2);
    margin-bottom: var(--ed-space-4);
}

.eco-diamba .ed-product-price {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-h4);
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-text);
}

.eco-diamba .ed-product-kg {
    font-size: var(--ed-text-xs);
    color: var(--ed-color-text-muted);
}

.eco-diamba .ed-product-add {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ed-space-2);
    width: 100%;
    padding-top: var(--ed-space-3) !important;
    padding-bottom: var(--ed-space-3) !important;
    font-size: var(--ed-text-sm) !important;
    font-weight: var(--ed-font-semibold);
    border-radius: var(--ed-radius-md);
}

.eco-diamba .ed-products-cta {
    text-align: center;
    margin-top: var(--ed-space-10);
}

/* =============================================================
   SECTION 5 � SALINSMART APER�U (fond sombre)
   ============================================================= */
.eco-diamba .ed-salin {
    background-color: var(--ed-color-surface-dark);
    padding-top: var(--ed-section-py);
    padding-bottom: var(--ed-section-py);
}

.eco-diamba .ed-salin-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h2);
    color: var(--ed-color-text-light);
    text-align: center;
    margin: 0 0 var(--ed-space-10);
}

.eco-diamba .ed-salin-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--ed-space-6);
}

.eco-diamba .ed-salin-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--ed-space-2);
    border-radius: var(--ed-radius-xl);
    padding: var(--ed-space-6);
}

.eco-diamba .ed-salin-emoji {
    font-size: 30px;
    line-height: 1;
    display: block;
    margin-bottom: var(--ed-space-3);
}

.eco-diamba .ed-salin-status {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-body-lg);
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-text-light);
    margin: 0 0 var(--ed-space-1);
}

.eco-diamba .ed-salin-ce {
    font-family: var(--ed-font-mono);
    font-size: var(--ed-text-xs);
    font-weight: var(--ed-font-semibold);
    color: rgba(255, 255, 255, 0.60);
    margin-bottom: var(--ed-space-3);
}

.eco-diamba .ed-salin-desc {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: rgba(255, 255, 255, 0.80);
}

.eco-diamba .ed-salin-green {
    background-color: rgba(46, 125, 50, 0.15);
    border: 1px solid rgba(46, 125, 50, 0.30);
    color: var(--ed-color-text-light);
}

.eco-diamba .ed-salin-yellow {
    background-color: rgba(249, 168, 37, 0.15);
    border: 1px solid rgba(249, 168, 37, 0.30);
    color: var(--ed-color-text-light);
}

.eco-diamba .ed-salin-orange {
    background-color: rgba(230, 81, 0, 0.15);
    border: 1px solid rgba(230, 81, 0, 0.30);
    color: var(--ed-color-text-light);
}

.eco-diamba .ed-salin-red {
    background-color: rgba(183, 28, 28, 0.15);
    border: 1px solid rgba(183, 28, 28, 0.30);
    color: var(--ed-color-text-light);
}

.eco-diamba .ed-salin-cta {
    text-align: center;
    margin-top: var(--ed-space-10);
}

/* =============================================================
   SECTION 6 � T�MOIGNAGES (carousel)
   ============================================================= */
.eco-diamba .ed-testimonials {
    background-color: var(--ed-color-bg-alt);
    padding-top: var(--ed-section-py);
    padding-bottom: var(--ed-section-py);
}

.eco-diamba .ed-testi-viewport {
    overflow: hidden;
    max-width: var(--ed-container-md);
    margin: 0 auto;
}

.eco-diamba .ed-testi-track {
    display: flex;
    transition: transform var(--ed-transition-normal);
}

.eco-diamba .ed-testi-slide {
    flex: 0 0 100%;
    min-width: 100%;
    box-sizing: border-box;
    padding: var(--ed-space-2);
}

.eco-diamba .ed-testi-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--ed-space-3);
    background-color: var(--ed-color-surface);
    border-radius: var(--ed-radius-lg);
    box-shadow: var(--ed-shadow-sm);
    padding: var(--ed-card-p);
    margin: 0;
}

.eco-diamba .ed-testi-avatar {
    width: 56px;
    height: 56px;
    border-radius: var(--ed-radius-full);
    background-color: var(--ed-color-primary);
    color: var(--ed-color-text-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--ed-font-heading);
    font-weight: var(--ed-font-bold);
}

.eco-diamba .ed-testi-stars {
    color: var(--ed-color-accent);
    letter-spacing: 2px;
}

.eco-diamba .ed-testi-text {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    font-style: italic;
    line-height: var(--ed-leading-normal);
    color: var(--ed-color-text);
    margin: 0;
    max-width: none;
}

.eco-diamba .ed-testi-name {
    display: block;
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h4);
    color: var(--ed-color-text);
}

.eco-diamba .ed-testi-meta {
    display: block;
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
}

.eco-diamba .ed-testi-dots {
    display: flex;
    justify-content: center;
    gap: var(--ed-space-2);
    margin-top: var(--ed-space-8);
}

.eco-diamba .ed-testi-dot {
    width: 10px;
    height: 10px;
    padding: 0;
    border: none;
    border-radius: var(--ed-radius-full);
    background-color: var(--ed-color-border);
    cursor: pointer;
    transition: background-color var(--ed-transition-fast);
}

.eco-diamba .ed-testi-dot.is-active {
    background-color: var(--ed-color-primary);
}

/* =============================================================
   SECTION 7 � PARTENAIRES
   ============================================================= */
.eco-diamba .ed-partners {
    background-color: var(--ed-color-bg);
    padding: var(--ed-space-12) 0;
}

.eco-diamba .ed-partners-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: var(--ed-space-12);
}

.eco-diamba .ed-partner {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--ed-space-3) var(--ed-space-6);
    background-color: rgba(255, 255, 255, 0.60);
    border: 1px solid rgba(212, 206, 188, 0.50);
    border-radius: var(--ed-radius-lg);
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-body-lg);
    font-weight: var(--ed-font-bold);
    color: rgba(26, 58, 42, 0.50);
    cursor: default;
    transition: all var(--ed-transition-normal);
}

.eco-diamba .ed-partner:hover {
    color: var(--ed-color-primary);
    box-shadow: var(--ed-shadow-md);
    border-color: var(--ed-color-border);
}

/* =============================================================
   SECTION 8 � NEWSLETTER (fond beige)
   ============================================================= */
.eco-diamba .ed-newsletter {
    background-color: var(--ed-color-bg-alt);
    padding-top: var(--ed-section-py);
    padding-bottom: var(--ed-section-py);
}

.eco-diamba .ed-newsletter-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 700px;
    margin: 0 auto;
}

.eco-diamba .ed-newsletter-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h2);
    color: var(--ed-color-text);
    margin: 0 0 var(--ed-space-2);
}

.eco-diamba .ed-newsletter-sub {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    color: var(--ed-color-text-muted);
    margin: 0 auto var(--ed-space-8) auto;
    max-width: 520px;
}

.eco-diamba .ed-newsletter-form {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ed-space-3);
    width: 100%;
    max-width: 480px;
}

.eco-diamba .ed-newsletter-input {
    flex: 1 1 auto;
    height: 48px;
}

.eco-diamba .ed-newsletter-btn {
    height: 48px;
    white-space: nowrap;
}

@media (max-width: 767px) {
    .eco-diamba .ed-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--ed-space-6);
    }
    .eco-diamba .ed-ps-grid {
        grid-template-columns: 1fr;
    }
    .eco-diamba .ed-products-grid {
        grid-template-columns: 1fr;
    }
    .eco-diamba .ed-salin-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .eco-diamba .ed-newsletter-inner {
        flex-direction: column;
        align-items: flex-start;
    }
    .eco-diamba .ed-newsletter-form {
        width: 100%;
        max-width: none;
    }
    .eco-diamba .ed-stats,
    .eco-diamba .ed-ps,
    .eco-diamba .ed-products,
    .eco-diamba .ed-salin,
    .eco-diamba .ed-testimonials,
    .eco-diamba .ed-partners,
    .eco-diamba .ed-newsletter {
        padding-top: var(--ed-section-py-mobile);
        padding-bottom: var(--ed-section-py-mobile);
    }
}

/* =============================================================
   PAGE 2 � BOUTIQUE WOOCOMMERCE
   ============================================================= */

/* --- LAYOUT : forcer une seule colonne pleine largeur --- */
.eco-diamba.edn-shop #content .ast-container {
    display: block;
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
    margin: 0;
}

/* Masquer toute sidebar h�rit�e */
.eco-diamba.edn-shop #secondary,
.eco-diamba.edn-shop .widget-area {
    display: none !important;
}

/* La zone principale prend toute la largeur */
.eco-diamba.edn-shop #primary,
.eco-diamba.edn-shop #main,
.eco-diamba.edn-shop .ast-woocommerce-container {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
    float: none;
}

/* Re-contraindre le contenu (toolbar, grille) dans un conteneur centr� */
.eco-diamba.edn-shop .ed-shop-toolbar,
.eco-diamba.edn-shop ul.products {
    max-width: var(--ed-container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--ed-space-6);
    padding-right: var(--ed-space-6);
    box-sizing: border-box;
}

/* Masquer le fil d'Ariane "Home / Boutique" */
.eco-diamba.edn-shop .woocommerce-breadcrumb {
    display: none !important;
}

/* Masquer le compteur de r�sultats et le tri par d�faut de WooCommerce en g�n�ral */
.eco-diamba.edn-shop .woocommerce-result-count,
.eco-diamba.edn-shop .woocommerce-ordering {
    display: none !important;
}

/* --- Banni�re du haut (fond vert sombre pleine largeur, texte centr�) --- */
.eco-diamba.edn-shop .ed-shop-banner {
    width: 100%;
    background-color: var(--ed-color-primary);
    padding: var(--ed-space-16) var(--ed-space-6) var(--ed-space-12); /* Mobile: pt-16 pb-12 */
    text-align: center;
    margin-bottom: 0;
}

@media (min-width: 1024px) {
    .eco-diamba.edn-shop .ed-shop-banner {
        padding: 96px var(--ed-space-6) var(--ed-space-16); /* Desktop: pt-24 pb-16 */
    }
}

.eco-diamba.edn-shop .ed-shop-banner-inner {
    max-width: var(--ed-container-max);
    margin: 0 auto;
}

.eco-diamba.edn-shop .ed-shop-banner-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h1);
    color: #ffffff;
    margin: 0 0 var(--ed-space-3);
}

.eco-diamba.edn-shop .ed-shop-banner-sub {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    color: rgba(255, 255, 255, 0.80);
    margin: 0 auto;
    max-width: 600px;
}

/* --- Promo centr�e sous la banni�re --- */
.eco-diamba.edn-shop .ed-shop-promo-wrap {
    max-width: var(--ed-container-max);
    margin: 0 auto var(--ed-space-10) auto;
    padding: 0 var(--ed-space-6);
    margin-top: -24px;
    position: relative;
    z-index: 10;
}

.eco-diamba.edn-shop .ed-shop-promo {
    background-color: #C8A84B1A; /* rgba(200,168,75,0.1) */
    border: 1px solid #C8A84B4D; /* rgba(200,168,75,0.3) */
    border-radius: var(--ed-radius-lg);
    padding: var(--ed-space-4) var(--ed-space-6);
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--ed-space-3);
}

.eco-diamba.edn-shop .ed-shop-promo-text {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
}

.eco-diamba.edn-shop .ed-shop-promo-text strong {
    font-family: var(--ed-font-mono);
    background-color: var(--ed-color-surface);
    padding: 2px var(--ed-space-2);
    border-radius: var(--ed-radius-sm);
    font-weight: normal;
}

.eco-diamba.edn-shop .ed-shop-promo-btn {
    background: transparent;
    border: none;
    padding: 0;
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-xs);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-accent);
    cursor: pointer;
    transition: color var(--ed-transition-fast);
}

.eco-diamba.edn-shop .ed-shop-promo-btn:hover {
    opacity: 0.85;
}

/* --- Barre d'outils : recherche + pills --- */
.eco-diamba.edn-shop .ed-shop-toolbar {
    display: flex;
    align-items: center;
    gap: var(--ed-space-4);
    flex-wrap: wrap;
    margin-bottom: var(--ed-space-6);
}

.eco-diamba.edn-shop .ed-shop-search {
    flex: 1 1 280px;
    max-width: 384px; /* max-w-sm in tailwind */
    position: relative;
}

/* Dropdown de tri int�gr� � la toolbar */
.eco-diamba.edn-shop .ed-shop-toolbar .woocommerce-ordering {
    display: block !important;
    margin: 0;
}

.eco-diamba.edn-shop .ed-shop-toolbar .woocommerce-ordering select.orderby {
    appearance: none;
    -webkit-appearance: none;
    padding: var(--ed-space-2) 32px var(--ed-space-2) var(--ed-space-4);
    height: 34px; /* M�me hauteur stricte que les pills */
    border-radius: var(--ed-radius-full); /* M�me forme arrondie que les pills */
    border: 1px solid var(--ed-color-border);
    background-color: var(--ed-color-surface);
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236B6B5A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 16px;
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-xs); /* text-xs */
    font-weight: var(--ed-font-medium); /* font-medium */
    color: var(--ed-color-text-muted); /* text-[#6B6B5A] */
    outline: none;
    cursor: pointer;
    box-shadow: none;
    transition: all var(--ed-transition-fast);
}

.eco-diamba.edn-shop .ed-shop-toolbar .woocommerce-ordering select.orderby:focus {
    border-color: var(--ed-color-primary);
    box-shadow: 0 0 0 2px rgba(26, 58, 42, 0.2);
}

.eco-diamba.edn-shop .ed-search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    color: var(--ed-color-text-muted);
    pointer-events: none;
}

.eco-diamba.edn-shop .ed-shop-search-input {
    width: 100%;
    padding: 10px var(--ed-space-4) 10px 40px;
    border-radius: var(--ed-radius-md); /* rounded-lg */
    border: 1px solid var(--ed-color-border);
    background-color: var(--ed-color-surface);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text);
    transition: all var(--ed-transition-fast);
}

.eco-diamba.edn-shop .ed-shop-search-input:focus {
    outline: none;
    border-color: var(--ed-color-primary);
    box-shadow: 0 0 0 2px rgba(26, 58, 42, 0.2);
}

.eco-diamba.edn-shop .ed-shop-pills {
    display: flex;
    gap: var(--ed-space-2);
    flex-wrap: wrap;
    margin-left: auto; /* Pousse les filtres et le dropdown vers la droite */
}

.eco-diamba.edn-shop .ed-shop-pill {
    display: inline-block;
    padding: var(--ed-space-2) var(--ed-space-4);
    border-radius: var(--ed-radius-full);
    background-color: var(--ed-color-surface);
    border: 1px solid var(--ed-color-border);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-xs); /* text-xs */
    font-weight: var(--ed-font-semibold); /* font-semibold */
    color: var(--ed-color-text-muted); /* text-[#6B6B5A] */
    text-decoration: none;
    transition: all var(--ed-transition-fast);
}

.eco-diamba.edn-shop .ed-shop-pill:hover {
    border-color: var(--ed-color-primary);
}

.eco-diamba.edn-shop .ed-shop-pill.is-active {
    background-color: var(--ed-color-primary);
    border-color: var(--ed-color-primary);
    color: var(--ed-color-text-light); /* text-white */
    color: var(--ed-color-text-light);
}

/* --- Tri WooCommerce styl� comme un input --- */
.eco-diamba.edn-shop .woocommerce-ordering select,
.eco-diamba.edn-shop select.orderby {
    padding: var(--ed-input-py) var(--ed-input-px);
    border: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
    border-radius: var(--ed-radius-md);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    background-color: var(--ed-color-surface);
    color: var(--ed-color-text);
}

.eco-diamba.edn-shop .woocommerce-result-count {
    color: var(--ed-color-text-muted);
    font-size: var(--ed-text-sm);
}

/* --- Grille produits (centr�e, marges �gales) --- */
.eco-diamba.edn-shop ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ed-space-6);
    max-width: var(--ed-container-max);
    margin: 0 auto var(--ed-space-12) !important;
    padding: 0 var(--ed-space-6) !important;
    list-style: none;
}

.eco-diamba.edn-shop ul.products::before,
.eco-diamba.edn-shop ul.products::after {
    display: none !important;
}

.eco-diamba.edn-shop ul.products li.product {
    width: auto !important;
    float: none !important;
    margin: 0 !important;
    position: relative;
    display: flex;
    flex-direction: column;
    background: var(--ed-color-surface);
    border-radius: var(--ed-radius-lg);
    box-shadow: var(--ed-shadow-sm);
    padding-bottom: var(--ed-card-p);
    overflow: hidden;
    transition: transform var(--ed-transition-normal),
                box-shadow var(--ed-transition-normal);
}

/* Bouton ajouter au panier en bas de carte (push vers le bas) */
.eco-diamba.edn-shop ul.products li.product .ed-shop-add-btn {
    margin-top: auto;
}

.eco-diamba.edn-shop ul.products li.product:hover {
    transform: var(--ed-hover-scale);
    box-shadow: var(--ed-shadow-md);
}

/* Zone image (wrapper pour coins arrondis en haut seulement) */
.eco-diamba.edn-shop ul.products li.product .ed-product-img-wrap {
    position: relative;
    overflow: hidden;
    border-radius: var(--ed-radius-lg) var(--ed-radius-lg) 0 0;
    height: 260px;
}

/* Image carr�e */
.eco-diamba.edn-shop ul.products li.product a img,
.eco-diamba.edn-shop ul.products li.product img {
    display: block;
    width: 100%;
    height: 260px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: var(--ed-radius-lg) var(--ed-radius-lg) 0 0;
    margin: 0;
    transition: transform var(--ed-transition-normal);
}

/* Image produit � flush avec la carte, coins haut arrondis, z�ro marge/padding */
.woocommerce ul.products li.product .woocommerce-loop-product__link img {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: var(--ed-radius-lg) var(--ed-radius-lg) 0 0 !important;
    display: block !important;
    object-fit: cover !important;
}

.eco-diamba.edn-shop ul.products li.product:hover img {
    transform: scale(1.05);
}

/* Badges dans .edn-badges : conteneur flex HORS image, entre le <li> et le <a> image */
.eco-diamba.edn-shop ul.products li.product .edn-badges {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--ed-space-2);
    padding: var(--ed-space-3) var(--ed-space-3) 0;
    min-height: 32px;
}

.eco-diamba.edn-shop ul.products li.product .edn-badges .ed-product-fmt {
    /* badge gauche � Format */
    position: static;
    margin-right: auto;
    font-size: 0.65rem;
    padding: 4px 10px;
    letter-spacing: 0.04em;
}

.eco-diamba.edn-shop ul.products li.product .edn-badges .ed-product-flag {
    /* badge droite � Populaire / Meilleure vente */
    position: static;
    margin-left: auto;
    font-size: 0.65rem;
    padding: 4px 10px;
    letter-spacing: 0.04em;
}

/* Contenu texte des cartes (padding lat�ral) */
.eco-diamba.edn-shop ul.products li.product > a:not(.button),
.eco-diamba.edn-shop ul.products li.product {
    position: relative;
    overflow: hidden; /* Garantit que l'image �pouse les coins arrondis en haut */
}

/* Positionnement des badges SUR l'image */
.eco-diamba.edn-shop ul.products li.product .edn-badges {
    position: absolute;
    top: 12px; /* top-3 */
    left: 12px; /* left-3 */
    right: 12px; /* right-3 */
    display: flex;
    justify-content: space-between;
    z-index: 10;
    pointer-events: none;
}

/* Red�finition du style exact des badges sur la carte produit (prototype React) */
.eco-diamba.edn-shop ul.products li.product .ed-badge {
    padding: 4px 12px; /* Un peu plus de padding pour l'effet pilule */
    font-size: 11px;
    line-height: 1.2;
    border-radius: 9999px; /* Forme de pilule (arrondi total) */
    text-transform: none; /* Pas de majuscules automatiques */
    font-weight: var(--ed-font-semibold);
    letter-spacing: normal;
}

/* L'image doit remplir l'espace sans marge ni padding */
.eco-diamba.edn-shop ul.products li.product a img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    width: 100%;
    display: block;
    margin: 0;
}

.eco-diamba.edn-shop ul.products li.product .woocommerce-loop-product__title,
.eco-diamba.edn-shop ul.products li.product .ed-product-desc,
.eco-diamba.edn-shop ul.products li.product .ed-product-rating,
.eco-diamba.edn-shop ul.products li.product .ed-product-price-row,
.eco-diamba.edn-shop ul.products li.product .price,
.eco-diamba.edn-shop ul.products li.product .ed-product-kg,
.eco-diamba.edn-shop ul.products li.product .star-rating,
.eco-diamba.edn-shop ul.products li.product .ed-product-link {
    padding-left: var(--ed-card-p);
    padding-right: var(--ed-card-p);
}

/* Description courte (2 lignes, gris) */
.eco-diamba.edn-shop ul.products li.product .ed-product-desc {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    line-height: var(--ed-leading-normal);
    color: var(--ed-color-text-muted);
    margin: 0 0 var(--ed-space-3);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: normal;
    min-height: 2.8em;
}

/* Notation : �toiles + score + nb d'avis, align�es � gauche sur une ligne */
.eco-diamba.edn-shop ul.products li.product .ed-product-rating {
    display: flex;
    align-items: center;
    gap: var(--ed-space-1);
    margin: var(--ed-space-2) 0;
    font-family: var(--ed-font-body);
    font-size: 14px;
    line-height: 1;
    color: var(--ed-color-text-muted);
}

.edn-ss-slider-current {
    font-weight: 700;
    color: var(--ed-color-text);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.edn-ss-input {
    width: 60px;
    padding: 2px 4px;
    border: 1px solid transparent;
    border-radius: 4px;
    text-align: center;
    font-weight: bold;
    font-size: 1rem;
    font-family: inherit;
    color: var(--ed-color-primary);
    background-color: rgba(0,0,0,0.03);
    transition: all 0.3s ease;
}

.edn-ss-input:hover {
    background-color: rgba(0,0,0,0.06);
}

.edn-ss-input:focus {
    outline: none;
    border-color: var(--ed-color-primary);
    background-color: #fff;
    box-shadow: 0 0 0 2px rgba(45, 106, 79, 0.2);
}

/* Cacher les fl�ches du champ number */
.edn-ss-input::-webkit-outer-spin-button,
.edn-ss-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.edn-ss-input[type=number] {
    -moz-appearance: textfield;
}

.eco-diamba.edn-shop ul.products li.product .ed-stars {
    display: inline-flex;
    align-items: center;
    color: var(--ed-color-accent);
}

.eco-diamba.edn-shop ul.products li.product .ed-star-wrap {
    display: inline-flex;
    color: rgba(200, 168, 75, 0.30);
}

.eco-diamba.edn-shop ul.products li.product .ed-star-wrap.is-full {
    color: var(--ed-color-accent);
}

.eco-diamba.edn-shop ul.products li.product .ed-rating-score {
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-text);
    margin-left: var(--ed-space-1);
}

.eco-diamba.edn-shop ul.products li.product .ed-rating-count {
    color: var(--ed-color-text-muted);
}

.eco-diamba.edn-shop ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h4); /* text-xl dans Tailwind = 20px */
    font-weight: var(--ed-font-medium);
    color: var(--ed-color-text);
    padding-top: var(--ed-space-4); /* Espace au-dessus du titre */
    padding-bottom: var(--ed-space-2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: normal;
    min-height: 2.6em;
}

.eco-diamba.edn-shop ul.products li.product .star-rating {
    color: var(--ed-color-accent);
    margin-bottom: var(--ed-space-2);
}

.eco-diamba.edn-shop ul.products li.product .price {
    display: inline-block;
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-h3);
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-primary);
    margin-bottom: var(--ed-space-4);
    vertical-align: baseline;
}

/* Prix au kg : petit, gris, sur la m�me ligne que le prix principal */
.eco-diamba.edn-shop ul.products li.product .ed-product-kg {
    display: inline-block;
    padding-left: var(--ed-space-2) !important;
    padding-right: 0 !important;
    font-size: var(--ed-text-xs);
    color: var(--ed-color-text-muted);
    margin-bottom: var(--ed-space-4);
    vertical-align: baseline;
}

/* Masquer le bouton WC natif + le bouton "on-card" d'Astra (remplac�s par ed-shop-add-btn) */
.eco-diamba.edn-shop ul.products li.product .button,
.eco-diamba.edn-shop ul.products li.product .added_to_cart,
.eco-diamba.edn-shop ul.products li.product .ast-on-card-button,
.eco-diamba.edn-shop ul.products li.product .ahfb-svg-iconset {
    display: none !important;
}

/* Bouton "Ajouter au panier" : vert primary pleine largeur, ic�ne panier � gauche */
.eco-diamba.edn-shop ul.products li.product .ed-shop-add-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ed-space-2);
    margin: var(--ed-space-4) auto var(--ed-space-4);
    width: calc(100% - var(--ed-card-p) * 2);
    padding: 10px 16px; /* R�duit par rapport � 12px 16px */
    background-color: var(--ed-color-primary) !important;
    color: #ffffff !important;
    font-family: var(--ed-font-body);
    font-weight: var(--ed-font-semibold);
    font-size: 13px; /* R�duit par rapport � sm (14px) */
    line-height: 1;
    border: none;
    border-radius: var(--ed-radius-md);
    text-decoration: none;
    transition: background-color var(--ed-transition-normal);
}

.eco-diamba.edn-shop ul.products li.product .ed-shop-add-btn svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    stroke: #ffffff !important;
}

.eco-diamba.edn-shop ul.products li.product .ed-shop-add-btn span {
    color: #ffffff !important;
}

.eco-diamba.edn-shop ul.products li.product .ed-shop-add-btn:hover {
    background-color: var(--ed-color-primary-hover, #15291f);
}

/* --- Encart "Pas s�r de votre dose ?" (centr�, fond #1e3d2f, coins arrondis importants) --- */
.eco-diamba.edn-shop .ed-shop-dose {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--ed-space-5);
    background-color: #1e3d2f;
    border-radius: 2rem;
    padding: var(--ed-space-12) var(--ed-space-10);
    margin: var(--ed-space-12) 0;
}

.eco-diamba.edn-shop .ed-shop-dose-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-h2);
    color: #ffffff;
    margin: 0;
}

.eco-diamba.edn-shop .ed-shop-dose-sub {
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-body-lg);
    color: rgba(255, 255, 255, 0.80);
    margin: 0;
    max-width: 560px;
}

.eco-diamba.edn-shop .ed-shop-dose-btn {
    align-self: center;
}

/* --- Animation fade au filtrage AJAX --- */
@keyframes edFadeUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

.eco-diamba.edn-shop ul.products.ed-fade-up {
    animation: edFadeUp 0.3s ease both;
}

.eco-diamba.edn-shop ul.products {
    transition: opacity var(--ed-transition-fast);
}

.eco-diamba.edn-shop .ed-shop-empty {
    grid-column: 1 / -1;
    list-style: none;
    padding: var(--ed-space-8);
    text-align: center;
    color: var(--ed-color-text-muted);
}

@media (max-width: 767px) {
    .eco-diamba.edn-shop ul.products {
        grid-template-columns: 1fr !important;
    }
    .woocommerce[class*="columns-"] ul.products {
        grid-template-columns: 1fr !important;
    }
    .eco-diamba.edn-shop .ed-shop-toolbar,
    .eco-diamba.edn-shop .ed-shop-dose,
    .eco-diamba.edn-shop .ed-shop-promo {
        flex-direction: column;
        align-items: flex-start;
    }
    .eco-diamba.edn-shop .ed-shop-search {
        max-width: none;
        width: 100%;
        flex: none;
        position: relative;
        margin-bottom: var(--ed-space-4);
    }
    .eco-diamba.edn-shop .ed-shop-search-input {
        margin-bottom: 0 !important;
    }
}

/* =============================================================
   POINT 3 � Neutraliser le fond blanc Astra entre footer
   principal et barre copyright (barre blanche parasite).
   Les deux zones doivent rester sur --ed-color-primary.
   ============================================================= */
.site-footer,
.site-footer .site-below-footer-wrap,
.site-footer .footer-bottom,
.site-footer .ast-site-footer-wrap,
.site-footer .ast-builder-grid-row-container,
.site-footer .ast-builder-grid-row-container-inner {
    background-color: var(--ed-color-surface-dark) !important;
    border-top: none !important;
}

/* Garantir que la barre copyright Astra reste coll�e sans s�paration blanche */
body .site-footer .site-below-footer-wrap[data-section="section-below-footer-builder"] {
    background-color: var(--ed-color-surface-dark) !important;
    border-top: var(--ed-border-width) var(--ed-border-style) rgba(255, 255, 255, 0.10) !important;
    margin-top: 0 !important;
}

/* =============================================================
   POINT 5 � Bouton "Ajouter au panier" � variante .edn-add-to-cart-btn
   Applique le style arrondi complet demand� dans le design guide.
   ============================================================= */
.edn-add-to-cart-btn {
    background: var(--ed-color-primary);
    color: var(--ed-color-text-light);
    border-radius: var(--ed-radius-full);
    padding: var(--ed-btn-py) var(--ed-btn-px);
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--ed-space-2);
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: background-color var(--ed-transition-normal),
                box-shadow var(--ed-transition-normal),
                transform var(--ed-transition-fast);
    box-sizing: border-box;
}

.edn-add-to-cart-btn:hover {
    background: var(--ed-color-primary-hover);
    box-shadow: var(--ed-shadow-btn);
    transform: translateY(-1px);
    color: var(--ed-color-text-light);
}

/* ============================================================
   SALINSMART WIDGET � Calculateur de dose fiche produit
   Toutes les valeurs sont des variables --ed-* ou --salin-*
   ============================================================ */

/* Wrapper de section */
.ed-product-salinsmart-section {
    margin-top: var(--ed-space-10);
}

/* Carte principale */
.ed-salinsmart-card {
    background:    var(--ed-color-surface-dark);
    border-radius: var(--ed-radius-xl);
    padding:       var(--ed-space-8);
    color:         var(--ed-color-text-light);
}

/* En-t�te */
.ed-salinsmart-header {
    margin-bottom: var(--ed-space-6);
}

.ed-salinsmart-badge {
    display:          inline-block;
    padding:          var(--ed-space-1) var(--ed-space-3);
    background:       var(--ed-color-accent);
    color:            var(--ed-color-surface-dark);
    font-size:        var(--ed-text-xs);
    font-weight:      var(--ed-font-bold);
    font-family:      var(--ed-font-mono);
    letter-spacing:   0.08em;
    border-radius:    var(--ed-radius-full);
    text-transform:   uppercase;
    margin-bottom:    var(--ed-space-3);
}

.ed-salinsmart-title {
    font-family:    var(--ed-font-heading);
    font-size:      var(--ed-text-h3);
    font-weight:    var(--ed-font-bold);
    color:          var(--ed-color-text-light);
    margin:         0 0 var(--ed-space-2) 0;
    line-height:    var(--ed-leading-tight);
}

.ed-salinsmart-subtitle {
    font-size:   var(--ed-text-sm);
    color:       rgba(255, 255, 255, 0.6);
    margin:      0;
    line-height: var(--ed-leading-normal);
}

/* Grille sliders (2 colonnes sur desktop) */
.ed-salinsmart-sliders {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--ed-space-6);
    margin-bottom:         var(--ed-space-6);
}

.ed-salinsmart-slider-label-row {
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    margin-bottom:   var(--ed-space-2);
}

.ed-salinsmart-slider-label {
    font-size:   var(--ed-text-xs);
    font-weight: var(--ed-font-semibold);
    color:       rgba(255, 255, 255, 0.7);
    cursor:      pointer;
}

.ed-salinsmart-slider-val {
    font-family: var(--ed-font-mono);
    font-size:   var(--ed-text-sm);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-accent);
}

/* Input range */
.ed-salinsmart-range {
    width:      100%;
    cursor:     pointer;
    accent-color: var(--ed-color-accent);
    height:     4px;
}

.ed-salinsmart-range-limits {
    display:         flex;
    justify-content: space-between;
    font-size:       var(--ed-text-xs);
    color:           rgba(255, 255, 255, 0.35);
    margin-top:      var(--ed-space-1);
}

/* Grille r�sultats (3 colonnes) */
.ed-salinsmart-results {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   var(--ed-space-3);
    background:            rgba(255, 255, 255, 0.06);
    border-radius:         var(--ed-radius-lg);
    padding:               var(--ed-space-4);
    margin-bottom:         var(--ed-space-4);
}

.ed-salinsmart-result-cell {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            var(--ed-space-2);
    text-align:     center;
}

.ed-salinsmart-result-label {
    font-size:  var(--ed-text-xs);
    color:      rgba(255, 255, 255, 0.5);
    display:    block;
}

.ed-salinsmart-result-value {
    font-family: var(--ed-font-mono);
    font-size:   var(--ed-text-h4);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-text-light);
    line-height: 1;
}

.ed-salinsmart-result-value--accent {
    color: var(--ed-color-accent);
}

/* Badge statut de salinit� */
.ed-salinsmart-status-badge {
    display:       inline-flex;
    align-items:   center;
    gap:           var(--ed-space-1);
    padding:       var(--ed-space-1) var(--ed-space-3);
    border-radius: var(--ed-radius-full);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-bold);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background:    var(--salin-green);
    color:         var(--ed-color-text-light);
    transition:    background-color var(--ed-transition-normal),
                   color            var(--ed-transition-normal);
}

/* Variantes par statut (classes pos�es par JS) */
.ed-salinsmart-status-badge.is-sain {
    background: var(--salin-green);
    color:      var(--ed-color-text-light);
}

.ed-salinsmart-status-badge.is-tolerable {
    background: var(--salin-yellow);
    color:      var(--ed-color-surface-dark);
}

.ed-salinsmart-status-badge.is-critique {
    background: var(--salin-orange);
    color:      var(--ed-color-text-light);
}

.ed-salinsmart-status-badge.is-danger {
    background: var(--salin-red);
    color:      var(--ed-color-text-light);
}

/* D�composition en sacs */
.ed-salinsmart-bags-desc {
    font-size:   var(--ed-text-sm);
    color:       rgba(255, 255, 255, 0.55);
    margin:      0 0 var(--ed-space-4) 0;
    font-style:  italic;
    min-height:  var(--ed-text-body); /* �vite le saut de mise en page */
}

/* CTA � Bouton d'ajout au panier */
.ed-salinsmart-cta-wrap {
    margin-top: var(--ed-space-2);
}

.ed-salinsmart-add-btn {
    display:         inline-flex;
    align-items:     center;
    gap:             var(--ed-space-2);
    padding:         var(--ed-space-3) var(--ed-space-5);
    background:      var(--ed-color-accent);
    color:           var(--ed-color-surface-dark);
    border-radius:   var(--ed-radius-lg);
    font-family:     var(--ed-font-body);
    font-size:       var(--ed-text-sm);
    font-weight:     var(--ed-font-bold);
    text-decoration: none;
    transition:      background-color var(--ed-transition-normal),
                     transform        var(--ed-transition-fast),
                     box-shadow       var(--ed-transition-normal);
    cursor:          pointer;
}

.ed-salinsmart-add-btn:hover {
    background:  var(--ed-color-accent-hover);
    transform:   translateY(-1px);
    box-shadow:  var(--ed-shadow-btn);
    color:       var(--ed-color-surface-dark);
    text-decoration: none;
}

/* Responsive � mobile : sliders en colonne unique */
@media (max-width: 640px) {
    .ed-salinsmart-sliders {
        grid-template-columns: 1fr;
    }

    .ed-salinsmart-results {
        grid-template-columns: 1fr;
        gap:                   var(--ed-space-2);
    }

    .ed-salinsmart-result-cell {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }

    .ed-salinsmart-card {
        padding: var(--ed-space-5);
    }
}

/* ============================================================
   SECTION AVIS CLIENTS � Mise � niveau Base44
   5 nouveaux �l�ments : avatar, m�ta, badge produit,
   r�ponse �quipe bordure accent, bouton "Laisser un avis"
   ============================================================ */

/* En-t�te de carte : auteur (avatar + meta) + �toiles c�te � c�te */
.ed-review-header {
    display:         flex;
    align-items:     flex-start;
    justify-content: space-between;
    gap:             var(--ed-space-3);
    margin-bottom:   var(--ed-space-3);
}

.ed-review-author-row {
    display:     flex;
    align-items: center;
    gap:         var(--ed-space-3);
}

/* 1. Avatar cercle avec initiale */
.ed-review-avatar {
    width:            40px;
    height:           40px;
    border-radius:    var(--ed-radius-full);
    background:       var(--ed-color-primary);
    color:            var(--ed-color-text-light);
    font-family:      var(--ed-font-heading);
    font-size:        var(--ed-text-body-lg);
    font-weight:      var(--ed-font-bold);
    display:          flex;
    align-items:      center;
    justify-content:  center;
    flex-shrink:      0;
    line-height:      1;
    user-select:      none;
}

/* Bloc nom + m�ta */
.ed-review-author-meta {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-1);
}

.ed-review-author {
    font-size:   var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    color:       var(--ed-color-primary);
    display:     block;
}

/* 2. Ligne r�gion � date */
.ed-review-meta-line {
    font-size: var(--ed-text-xs);
    color:     var(--ed-color-text-muted);
}

/* �toiles � droite du header */
.ed-review-rating {
    display:    flex;
    gap:        2px;
    flex-shrink: 0;
}

/* 3. Badge "Produit achet�" */
.ed-review-badge-product {
    display:          inline-block;
    padding:          var(--ed-space-1) var(--ed-space-2);
    background:       var(--ed-color-primary-light);
    color:            var(--ed-color-primary);
    font-size:        var(--ed-text-xs);
    font-weight:      var(--ed-font-semibold);
    border-radius:    var(--ed-radius-sm);
    margin-bottom:    var(--ed-space-3);
}

/* Texte de l'avis */
.ed-review-text {
    font-size:   var(--ed-text-sm);
    color:       var(--ed-color-text-muted);
    line-height: var(--ed-leading-relaxed);
    margin:      0 0 var(--ed-space-3) 0;
}

/* 4. R�ponse �quipe � bordure gauche 4px accent + fond surface */
.ed-review-reply {
    border-left:    4px solid var(--ed-color-accent);
    background:     var(--ed-color-surface);
    border-radius:  0 var(--ed-radius-md) var(--ed-radius-md) 0;
    padding:        var(--ed-space-3) var(--ed-space-4);
    margin-top:     var(--ed-space-3);
}

.ed-review-reply-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             var(--ed-space-2);
    margin-bottom:   var(--ed-space-2);
}

.ed-review-reply-author {
    font-size:   var(--ed-text-xs);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
}

.ed-review-reply-date {
    font-size: var(--ed-text-xs);
    color:     var(--ed-color-text-muted);
}

.ed-review-reply-text {
    font-size:   var(--ed-text-xs);
    color:       var(--ed-color-text-muted);
    line-height: var(--ed-leading-relaxed);
    margin:      0;
}

/* 5. CTA bouton "Laisser un avis" */
.ed-review-cta {
    margin-top:    var(--ed-space-8);
    padding-top:   var(--ed-space-6);
    border-top:    var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
}

.ed-btn-leave-review {
    display:         inline-flex;
    align-items:     center;
    gap:             var(--ed-space-2);
    padding:         var(--ed-space-3) var(--ed-space-5);
    border:          2px solid var(--ed-color-primary);
    border-radius:   var(--ed-radius-lg);
    color:           var(--ed-color-primary);
    background:      transparent;
    font-family:     var(--ed-font-body);
    font-size:       var(--ed-text-sm);
    font-weight:     var(--ed-font-semibold);
    text-decoration: none;
    cursor:          pointer;
    transition:      background-color var(--ed-transition-normal),
                     color            var(--ed-transition-normal),
                     transform        var(--ed-transition-fast);
}

.ed-btn-leave-review:hover {
    background:      var(--ed-color-primary);
    color:           var(--ed-color-text-light);
    transform:       translateY(-1px);
    text-decoration: none;
}

/* Responsive � mobile */
@media (max-width: 640px) {
    .ed-review-header {
        flex-direction: column;
        align-items:    flex-start;
    }

    .ed-review-rating {
        margin-left: calc(40px + var(--ed-space-3)); /* aligne sous le nom */
    }
}

/* ============================================================
   PRODUITS ASSOCI�S � Layout horizontal Base44
   image carr�e | infos (format, titre, prix, prix/kg) | bouton
   ============================================================ */

.ed-product-related-section {
    margin-top:  var(--ed-space-10);
    padding-top: var(--ed-space-8);
    border-top:  var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
}

.ed-related-products-list {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-4);
}

/* Carte horizontale */
.ed-related-card {
    display:       flex;
    align-items:   center;
    gap:           var(--ed-space-4);
    background:    var(--ed-color-surface);
    border-radius: var(--ed-radius-xl);
    padding:       var(--ed-space-4);
    box-shadow:    var(--ed-shadow-card);
    transition:    box-shadow var(--ed-transition-normal);
}

.ed-related-card:hover {
    box-shadow: var(--ed-shadow-card-hover);
}

/* Image carr�e 80�80 */
.ed-related-image-link {
    flex-shrink: 0;
    display:     block;
    line-height: 0;
}

.ed-related-image-wrap {
    width:         80px;
    height:        80px;
    border-radius: var(--ed-radius-lg);
    overflow:      hidden;
    flex-shrink:   0;
    background:    var(--ed-color-bg);
}

.ed-related-image {
    width:      100%;
    height:     100%;
    object-fit: cover;
    display:    block;
}

/* Colonne infos � s'�tire pour remplir l'espace */
.ed-related-infos {
    flex:           1;
    min-width:      0;
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-1);
}

.ed-related-badge-format {
    display:       inline-block;
    padding:       2px var(--ed-space-2);
    background:    var(--ed-color-primary-light);
    color:         var(--ed-color-primary);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-semibold);
    border-radius: var(--ed-radius-sm);
    width:         fit-content;
}

.ed-related-title-link {
    text-decoration: none;
}

.ed-related-title {
    font-family:     var(--ed-font-heading);
    font-size:       var(--ed-text-sm);
    font-weight:     var(--ed-font-semibold);
    color:           var(--ed-color-primary);
    margin:          0;
    white-space:     nowrap;
    overflow:        hidden;
    text-overflow:   ellipsis;
    transition:      color var(--ed-transition-fast);
}

.ed-related-title-link:hover .ed-related-title {
    color: var(--ed-color-accent);
}

.ed-related-price {
    font-weight: var(--ed-font-bold);
    font-size:   var(--ed-text-sm);
    color:       var(--ed-color-primary);
    margin:      0;
}

.ed-related-price-unit {
    font-size: var(--ed-text-xs);
    color:     var(--ed-color-text-muted);
    margin:    0;
}

/* Formulaire add-to-cart inline */
.ed-related-add-form {
    flex-shrink: 0;
    margin:      0;
}

/* Bouton "Ajouter" compact */
.ed-related-add-btn {
    display:       inline-flex;
    align-items:   center;
    gap:           var(--ed-space-1);
    padding:       var(--ed-space-2) var(--ed-space-3);
    background:    var(--ed-color-primary);
    color:         var(--ed-color-text-light);
    border:        none;
    border-radius: var(--ed-radius-lg);
    font-family:   var(--ed-font-body);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-bold);
    cursor:        pointer;
    white-space:   nowrap;
    transition:    background-color var(--ed-transition-normal),
                   transform        var(--ed-transition-fast),
                   box-shadow       var(--ed-transition-normal);
}

.ed-related-add-btn:hover {
    background: var(--ed-color-primary-hover);
    transform:  translateY(-1px);
    box-shadow: var(--ed-shadow-btn);
    color:      var(--ed-color-text-light);
}

.ed-related-add-btn:active {
    transform: translateY(0);
}

/* Responsive � mobile : on r�duit l'image, bouton pleine largeur */
@media (max-width: 480px) {
    .ed-related-image-wrap {
        width:  60px;
        height: 60px;
    }

    .ed-related-card {
        flex-wrap: wrap;
    }

    .ed-related-add-form {
        flex-basis: 100%;
    }

    .ed-related-add-btn {
        width:           100%;
        justify-content: center;
        padding:         var(--ed-space-2) var(--ed-space-4);
    }
}

/* ============================================================
   FICHE PRODUIT � single-product.php
   Grille 2 colonnes : image gauche | r�sum� droite
   Toutes les valeurs sont des variables --ed-*
   ============================================================ */

/* Wrapper page produit */
.eco-diamba-product-page-wrap {
    background:   var(--ed-color-bg);
    padding-top:  var(--ed-space-8);
    padding-bottom: var(--ed-space-16);
    min-height:   70vh;
    width:        100vw !important;
    max-width:    100vw !important;
    margin-left:  calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.eco-diamba-product-page-wrap .ed-container {
    max-width:     var(--ed-container-max);
    margin-left:   auto;
    margin-right:  auto;
    padding-left:  var(--ed-space-6);
    padding-right: var(--ed-space-6);
}

/* -- Breadcrumb ----------------------------------------------- */
.ed-product-breadcrumb {
    display:     flex;
    align-items: center;
    flex-wrap:   wrap;
    gap:         var(--ed-space-1);
    margin-bottom: var(--ed-space-6);
    font-size:   var(--ed-text-sm);
    color:       var(--ed-color-text-muted);
}

.ed-product-breadcrumb a {
    color:           var(--ed-color-text-muted);
    text-decoration: none;
    transition:      color var(--ed-transition-fast);
}

.ed-product-breadcrumb a:hover {
    color: var(--ed-color-primary);
}

.ed-product-breadcrumb span[aria-current="page"] {
    color:       var(--ed-color-primary);
    font-weight: var(--ed-font-semibold);
}

.ed-breadcrumb-separator {
    color:      var(--ed-color-border);
    flex-shrink: 0;
}

/* -- Grille principale 2 colonnes ----------------------------- */
.ed-product-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--ed-space-12);
    align-items:           start;
    margin-bottom:         var(--ed-space-12);
}

/* -- Colonne gauche � Galerie image --------------------------- */
.ed-product-gallery {
    position: relative;
}

.ed-product-main-image-wrap {
    position:      relative;
    border-radius: var(--ed-radius-xl);
    overflow:      hidden;
    aspect-ratio:  1 / 1;
    background:    var(--ed-color-surface);
    box-shadow:    var(--ed-shadow-md);
}

.ed-product-main-image {
    width:      100%;
    height:     100%;
    object-fit: cover;
    display:    block;
}

/* Badge "Certifi� biologique" � superpos� en haut-gauche */
.ed-badge-bio {
    position:      absolute;
    top:           var(--ed-space-4);
    left:          var(--ed-space-4);
    display:       inline-block;
    padding:       var(--ed-space-2) var(--ed-space-4);
    background:    var(--ed-color-success);
    color:         var(--ed-color-text-light);
    font-family:   var(--ed-font-body);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-bold);
    border-radius: var(--ed-radius-full);
    z-index:       2;
    pointer-events: none;
}

/* -- Colonne droite � R�sum� produit -------------------------- */
.ed-product-summary {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-4);
}

/* Badges format + sp�cial */
.ed-product-summary-badges {
    display:  flex;
    gap:      var(--ed-space-2);
    flex-wrap: wrap;
}

.ed-badge-format {
    display:       inline-block;
    padding:       var(--ed-space-1) var(--ed-space-3);
    background:    var(--ed-color-primary-light);
    color:         var(--ed-color-primary);
    font-family:   var(--ed-font-body);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-semibold);
    border-radius: var(--ed-radius-full);
}

.ed-badge-special {
    display:       inline-block;
    padding:       var(--ed-space-1) var(--ed-space-3);
    background:    rgba(200, 168, 75, 0.18);
    color:         var(--ed-color-accent);
    font-family:   var(--ed-font-body);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-bold);
    border-radius: var(--ed-radius-full);
}

/* Titre H1 */
.ed-product-title {
    font-family:    var(--ed-font-heading);
    font-size:      var(--ed-text-h1);
    font-weight:    var(--ed-font-bold);
    color:          var(--ed-color-primary);
    line-height:    var(--ed-leading-tight);
    letter-spacing: var(--ed-tracking-tight);
    margin:         0;
}

/* Rating � �toiles + texte */
.ed-product-rating-row {
    display:     flex;
    align-items: center;
    gap:         var(--ed-space-2);
}

.ed-stars {
    display: flex;
    gap:     2px;
}

.ed-star {
    display: block;
}

.ed-star.star-filled {
    color: var(--ed-color-accent);
    fill:  var(--ed-color-accent);
}

.ed-star.star-half {
    color: var(--ed-color-accent);
    fill:  var(--ed-color-accent);
    opacity: 0.6;
}

.ed-star.star-empty {
    color: var(--ed-color-border);
    fill:  var(--ed-color-border);
}

.ed-rating-text {
    font-size:  var(--ed-text-sm);
    color:      var(--ed-color-text-muted);
    font-family: var(--ed-font-body);
}

/* Prix + prix/unit� */
.ed-product-price-row {
    display:     flex;
    align-items: baseline;
    gap:         var(--ed-space-3);
    flex-wrap:   wrap;
}

.ed-price-amount {
    font-family:  var(--ed-font-heading);
    font-size:    var(--ed-text-h2);
    font-weight:  var(--ed-font-bold);
    color:        var(--ed-color-primary);
    line-height:  1;
}

.ed-currency {
    font-size: var(--ed-text-h3);
}

.ed-price-per-unit {
    font-family: var(--ed-font-body);
    font-size:   var(--ed-text-sm);
    color:       var(--ed-color-text-muted);
}

/* Stock */
.ed-product-stock {
    font-family: var(--ed-font-body);
    font-size:   var(--ed-text-sm);
    color:       var(--ed-color-text-muted);
    margin-top:  calc(-1 * var(--ed-space-2));
}

/* -- Formulaire quantit� + boutons ---------------------------- */
.ed-product-action-form {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-3);
}

.ed-product-action-form .cart {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-3);
    margin:         0;
}

/* Ligne quantit� + total */
.ed-qty-total-row {
    display:     flex;
    align-items: center;
    gap:         var(--ed-space-4);
}

/* S�lecteur -  n  + */
.ed-qty-selector {
    display:       flex;
    align-items:   center;
    border:        var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
    border-radius: var(--ed-radius-lg);
    background:    var(--ed-color-surface);
    overflow:      hidden;
    flex-shrink:   0;
}

.ed-qty-btn {
    width:       40px;
    height:      44px;
    background:  transparent;
    border:      none;
    cursor:      pointer;
    font-size:   var(--ed-text-body-lg);
    color:       var(--ed-color-text-muted);
    transition:  background-color var(--ed-transition-fast),
                 color var(--ed-transition-fast);
    line-height: 1;
    display:     flex;
    align-items: center;
    justify-content: center;
}

.ed-qty-btn:hover {
    background: var(--ed-color-bg);
    color:      var(--ed-color-primary);
}

.ed-qty-value {
    min-width:   40px;
    text-align:  center;
    font-family: var(--ed-font-mono);
    font-size:   var(--ed-text-body);
    font-weight: var(--ed-font-semibold);
    color:       var(--ed-color-primary);
    padding:     0 var(--ed-space-2);
    display:     block;
}

/* Affichage total = X FCFA */
.ed-total-display {
    display:     flex;
    align-items: center;
    gap:         var(--ed-space-2);
}

.ed-total-label {
    font-size:  var(--ed-text-body-lg);
    color:      var(--ed-color-text-muted);
    font-family: var(--ed-font-body);
}

.ed-total-value {
    font-family: var(--ed-font-heading);
    font-size:   var(--ed-text-h4);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
}

/* Bouton "Ajouter au panier" */
.ed-btn-add-to-cart {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--ed-space-2);
    width:           100%;
    padding:         var(--ed-space-4) var(--ed-space-6);
    background:      var(--ed-color-primary);
    color:           var(--ed-color-text-light);
    border:          none;
    border-radius:   var(--ed-radius-lg);
    font-family:     var(--ed-font-body);
    font-size:       var(--ed-text-body);
    font-weight:     var(--ed-font-bold);
    cursor:          pointer;
    text-decoration: none;
    transition:      background-color var(--ed-transition-normal),
                     transform var(--ed-transition-fast),
                     box-shadow var(--ed-transition-normal);
}

.ed-btn-add-to-cart:hover {
    background:  var(--ed-color-primary-hover);
    transform:   translateY(-1px);
    box-shadow:  var(--ed-shadow-btn);
    color:       var(--ed-color-text-light);
}

/* Bouton "Commander via WhatsApp" */
.ed-btn-whatsapp {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--ed-space-2);
    width:           100%;
    padding:         var(--ed-space-4) var(--ed-space-6);
    background:      var(--ed-color-whatsapp);
    color:           var(--ed-color-text-light);
    border-radius:   var(--ed-radius-lg);
    font-family:     var(--ed-font-body);
    font-size:       var(--ed-text-body);
    font-weight:     var(--ed-font-bold);
    text-decoration: none;
    transition:      background-color var(--ed-transition-normal),
                     transform var(--ed-transition-fast);
}

.ed-btn-whatsapp:hover {
    background:  var(--ed-color-whatsapp-hover);
    transform:   translateY(-1px);
    color:       var(--ed-color-text-light);
}

.ed-btn-icon {
    flex-shrink: 0;
}

/* Badges paiement */
.ed-payment-badges {
    display:   flex;
    flex-wrap: wrap;
    gap:       var(--ed-space-2);
}

.ed-payment-badge {
    display:       inline-block;
    padding:       var(--ed-space-1) var(--ed-space-3);
    background:    var(--ed-color-bg-alt);
    color:         var(--ed-color-text-muted);
    font-family:   var(--ed-font-body);
    font-size:     var(--ed-text-xs);
    font-weight:   var(--ed-font-medium);
    border-radius: var(--ed-radius-sm);
    border:        var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
}

/* -- Accord�on ------------------------------------------------ */
.ed-product-accordion {
    border-top: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
    margin-top: var(--ed-space-2);
}

.ed-accordion-item {
    border-bottom: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
}

.ed-accordion-trigger {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    width:           100%;
    padding:         var(--ed-space-4) 0;
    background:      transparent;
    border:          none;
    cursor:          pointer;
    font-family:     var(--ed-font-heading);
    font-size:       var(--ed-text-sm);
    font-weight:     var(--ed-font-semibold);
    color:           var(--ed-color-primary);
    text-align:      left;
    transition:      color var(--ed-transition-fast);
}

.ed-accordion-trigger:hover {
    color: var(--ed-color-accent);
}

.ed-accordion-chevron {
    flex-shrink:  0;
    transition:   transform var(--ed-transition-normal);
    color:        var(--ed-color-text-muted);
}

/* Contenu accord�on � ferm� par d�faut */
.ed-accordion-content {
    max-height:  0;
    overflow:    hidden;
    transition:  max-height var(--ed-transition-normal);
}

/* Ouvert */
.ed-accordion-item.is-open .ed-accordion-content {
    max-height: 800px;
}

.ed-accordion-item.is-open .ed-accordion-chevron {
    transform: rotate(180deg);
}

.ed-accordion-inner {
    padding-bottom: var(--ed-space-4);
    font-family:    var(--ed-font-body);
    font-size:      var(--ed-text-sm);
    color:          var(--ed-color-text-muted);
    line-height:    var(--ed-leading-normal);
}

/* Tables accord�on */
.ed-table-composition,
.ed-table-dosage {
    width:           100%;
    border-collapse: collapse;
    font-size:       var(--ed-text-sm);
}

.ed-table-composition td,
.ed-table-dosage td,
.ed-table-dosage th {
    padding:       var(--ed-space-2) var(--ed-space-3);
    border-bottom: var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
    color:         var(--ed-color-text);
}

.ed-table-dosage th {
    font-weight: var(--ed-font-semibold);
    color:       var(--ed-color-primary);
    background:  var(--ed-color-bg);
    text-align:  left;
}

.ed-table-composition td:last-child,
.ed-table-dosage td:last-child {
    font-family: var(--ed-font-mono);
    font-weight: var(--ed-font-semibold);
    color:       var(--ed-color-primary);
    text-align:  right;
}

/* -- Section titre g�n�rique ---------------------------------- */
.ed-section-title {
    font-family:  var(--ed-font-heading);
    font-size:    var(--ed-text-h2);
    font-weight:  var(--ed-font-bold);
    color:        var(--ed-color-primary);
    margin:       0 0 var(--ed-space-6) 0;
    line-height:  var(--ed-leading-tight);
}

/* -- Cartes avis ---------------------------------------------- */
.ed-product-reviews-section {
    margin-top:  var(--ed-space-10);
    padding-top: var(--ed-space-8);
    border-top:  var(--ed-border-width) var(--ed-border-style) var(--ed-color-border);
}

.ed-reviews-summary-grid {
    display:               grid;
    grid-template-columns: auto 1fr;
    gap:                   var(--ed-space-8);
    align-items:           center;
    background:            var(--ed-color-bg);
    border-radius:         var(--ed-radius-xl);
    padding:               var(--ed-space-6);
    margin-bottom:         var(--ed-space-8);
}

.ed-reviews-global-score {
    text-align: center;
}

.ed-global-number {
    font-family: var(--ed-font-heading);
    font-size:   64px;
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
    line-height: 1;
    margin-bottom: var(--ed-space-2);
}

.ed-reviews-total-text {
    font-size: var(--ed-text-sm);
    color:     var(--ed-color-text-muted);
    margin-top: var(--ed-space-1);
}

.ed-reviews-distribution {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-2);
}

.ed-dist-row {
    display:     flex;
    align-items: center;
    gap:         var(--ed-space-3);
}

.ed-dist-label {
    font-size:  var(--ed-text-xs);
    color:      var(--ed-color-text-muted);
    width:      56px;
    text-align: right;
    flex-shrink: 0;
}

.ed-dist-bar-wrap {
    flex:          1;
    height:        8px;
    background:    var(--ed-color-border);
    border-radius: var(--ed-radius-full);
    overflow:      hidden;
}

.ed-dist-bar-fill {
    height:        100%;
    background:    var(--ed-color-accent);
    border-radius: var(--ed-radius-full);
    transition:    width var(--ed-transition-slow);
}

.ed-dist-percentage {
    font-size:   var(--ed-text-xs);
    color:       var(--ed-color-text-muted);
    width:       32px;
    flex-shrink: 0;
}

.ed-reviews-list {
    display:        flex;
    flex-direction: column;
    gap:            var(--ed-space-6);
    margin-bottom:  var(--ed-space-6);
}

.ed-review-card {
    background:    var(--ed-color-surface);
    border-radius: var(--ed-radius-xl);
    padding:       var(--ed-space-6);
    box-shadow:    var(--ed-shadow-xs);
}

/* -- Responsive fiche produit --------------------------------- */
@media (max-width: 1024px) {
    .ed-product-grid {
        gap: var(--ed-space-8);
    }
}

@media (max-width: 767px) {
    .ed-product-grid {
        grid-template-columns: 1fr;
        gap:                   var(--ed-space-6);
    }

    .ed-product-title {
        font-size: var(--ed-text-h1-mobile);
    }

    .ed-price-amount {
        font-size: var(--ed-text-h2-mobile);
    }

    .ed-reviews-summary-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   PAGE SALINSMART � page-salinsmart.php
   ============================================================ */

/* --- Layout pleine largeur (casser le conteneur Astra) --- */
.eco-diamba.edn-salinsmart-page {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    overflow-x: hidden;
}

/* --- 1. Hero Section --- */
.edn-ss-hero {
    background-color: var(--ed-color-primary);
    padding-top:      var(--ed-space-24);
    padding-bottom:   var(--ed-space-16);
    text-align:       center;
}

.edn-ss-hero__inner h1 {
    color:         #FFFFFF;
    font-size:     var(--ed-text-h1);
    margin-bottom: var(--ed-space-4);
}

.edn-ss-hero__inner p {
    color:         rgba(255, 255, 255, 0.70);
    font-size:     var(--ed-text-body-lg);
    max-width:     600px;
    margin:        0 auto var(--ed-space-8) auto;
}

.edn-ss-hero__badge {
    display:         inline-flex;
    align-items:     center;
    gap:             var(--ed-space-2);
    background:      rgba(46, 125, 50, 0.20);
    border:          1px solid rgba(46, 125, 50, 0.40);
    color:           #2E7D32;
    padding:         var(--ed-space-2) var(--ed-space-4);
    border-radius:   var(--ed-radius-full);
    font-weight:     var(--ed-font-semibold);
    font-size:       var(--ed-text-sm);
}

.edn-ss-hero__badge svg {
    flex-shrink: 0;
}

/* --- 2. Dashboard Section --- */
.edn-ss-dashboard {
    background-color: var(--ed-color-primary);
    padding-bottom:   var(--ed-space-16);
}

.edn-ss-dashboard__panel {
    background:    #0f2119;
    border:        1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--ed-radius-2xl);
    padding:       var(--ed-space-8);
}

.edn-ss-dashboard__header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    flex-wrap:       wrap;
    gap:             var(--ed-space-4);
    margin-bottom:   var(--ed-space-8);
}

.edn-ss-dashboard__title {
    display:     flex;
    align-items: center;
    gap:         var(--ed-space-2);
    color:       #FFFFFF !important;
    font-size:   var(--ed-text-h2);
    margin:      0;
}

.edn-ss-icon-accent {
    color: var(--ed-color-accent);
}

.edn-ss-dashboard__select {
    background:    rgba(255, 255, 255, 0.1);
    border:        1px solid rgba(255, 255, 255, 0.2);
    color:         #FFFFFF !important;
    padding:       var(--ed-space-2) var(--ed-space-4);
    border-radius: var(--ed-radius-md);
    font-size:     var(--ed-text-sm);
    outline:       none;
    cursor:        pointer;
    width:         auto !important;
    max-width:     100%;
}

.edn-ss-dashboard__select option {
    color: #000;
}

.edn-ss-alert {
    display:       flex;
    align-items:   flex-start;
    gap:           var(--ed-space-3);
    background:    var(--salin-red);
    padding:       var(--ed-space-4);
    border-radius: var(--ed-radius-xl);
    margin-bottom: var(--ed-space-6);
}

.edn-ss-alert-icon {
    color:       #FFFFFF;
    flex-shrink: 0;
}

.edn-ss-alert-text {
    flex:        1;
    color:       #FFFFFF;
    font-size:   var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    margin:      0;
}

.edn-ss-dashboard__grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--ed-space-8);
}

/* Dashboard Gauche */
.edn-ss-gauge-wrap {
    position: relative;
    width:    192px;
    height:   112px;
    margin:   0 auto var(--ed-space-4) auto;
}

.edn-ss-gauge-svg {
    width: 100%;
}

.edn-ss-gauge-value {
    position:  absolute;
    bottom:    0;
    left:      50%;
    transform: translateX(-50%);
}

.edn-ss-gauge-number {
    display:     block;
    font-family: var(--ed-font-mono);
    font-size:   36px;
    font-weight: var(--ed-font-bold);
    color:       #FFFFFF !important;
    line-height: 1;
}

.edn-ss-gauge-unit {
    display:   block;
    font-size: var(--ed-text-xs);
    color:     rgba(255, 255, 255, 0.6) !important;
}

.edn-ss-badge-status {
    display:         inline-flex;
    align-items:     center;
    gap:             var(--ed-space-2);
    padding:         var(--ed-space-2) var(--ed-space-4);
    border-radius:   var(--ed-radius-full);
    margin-bottom:   var(--ed-space-4);
    font-size:       var(--ed-text-sm);
    font-weight:     var(--ed-font-bold);
    color:           #FFFFFF !important;
}

.edn-ss-badge-status span {
    color: #FFFFFF !important;
}

.edn-ss-stats-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--ed-space-4);
    margin-top:            var(--ed-space-4);
}

.edn-ss-stat-card {
    background:    rgba(255, 255, 255, 0.05);
    border-radius: var(--ed-radius-xl);
    padding:       var(--ed-space-4);
}

.edn-ss-stat-label {
    display:   block;
    font-size: var(--ed-text-xs);
    color:     rgba(255, 255, 255, 0.5) !important;
}

.edn-ss-stat-value {
    display:     block;
    font-family: var(--ed-font-mono);
    font-size:   24px;
    font-weight: var(--ed-font-bold);
    color:       #FFFFFF !important;
}

.edn-ss-rec-text {
    font-size:     var(--ed-text-sm);
    color:         rgba(255, 255, 255, 0.7) !important;
    background:    rgba(255, 255, 255, 0.05);
    border-radius: var(--ed-radius-lg);
    padding:       var(--ed-space-3);
    margin:        var(--ed-space-4) 0;
}

.edn-ss-cmd-btn {
    display:         inline-flex;
    align-items:     center;
    gap:             var(--ed-space-2);
    justify-content: center;
    width:           100%;
}

/* Dashboard Droite */
.edn-ss-chart-title {
    font-size:     var(--ed-text-sm);
    font-weight:   var(--ed-font-semibold);
    color:         rgba(255, 255, 255, 0.6) !important;
    margin-bottom: var(--ed-space-4);
}

.edn-ss-chart-container {
    height: 224px;
}

.edn-ss-chart-legend {
    display:   flex;
    flex-wrap: wrap;
    gap:       var(--ed-space-2);
    margin-top: var(--ed-space-4);
}

.edn-ss-legend-item {
    display:     inline-flex;
    align-items: center;
    gap:         6px;
    font-size:   var(--ed-text-xs);
    color:       rgba(255, 255, 255, 0.5) !important;
}

.edn-ss-dot {
    width:         10px;
    height:        10px;
    border-radius: 50%;
}

@media (max-width: 767px) {
    .edn-ss-dashboard__grid {
        grid-template-columns: 1fr;
    }
    .edn-ss-dashboard__header {
        flex-direction: column;
        align-items:    flex-start;
    }
}

/* --- 3. Simulateur Section --- */
.edn-ss-simulator {
    background-color: #F5F0E8;
    padding-top:      var(--ed-space-16);
    padding-bottom:   var(--ed-space-16);
}

.edn-ss-simulator__header {
    margin-bottom: var(--ed-space-10);
}

.edn-ss-simulator__header h2 {
    font-family: var(--ed-font-heading);
    font-size:   var(--ed-text-h2);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
    margin:      0 0 var(--ed-space-3) 0;
}

.edn-ss-simulator__header p {
    font-size: var(--ed-text-sm);
    color:     var(--ed-color-text-muted);
    margin:    0;
}

.edn-ss-simulator__card {
    background:    #FFFFFF;
    border-radius: var(--ed-radius-2xl);
    padding:       var(--ed-space-8);
    box-shadow:    var(--ed-shadow-sm);
}

.edn-ss-simulator__sliders {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--ed-space-8);
    margin-bottom:         var(--ed-space-8);
}

.edn-ss-slider-group label {
    display:       block;
    font-size:     var(--ed-text-sm);
    font-weight:   var(--ed-font-semibold);
    color:         var(--ed-color-primary);
    margin-bottom: var(--ed-space-2);
}

.edn-ss-range {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 8px;
    border-radius: 4px;
    background: #e0e0e0;
    outline: none;
    cursor: pointer;
    margin: 15px 0;
}

.edn-ss-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--ed-color-primary);
    cursor: pointer;
    border: none;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.edn-ss-range::-moz-range-thumb {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--ed-color-primary);
    cursor: pointer;
    border: none;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.edn-ss-range::-moz-range-track {
    background: transparent;
    border-color: transparent;
    color: transparent;
}

.edn-ss-slider-labels {
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    font-size:       var(--ed-text-xs);
    color:           var(--ed-color-text-muted);
    margin-top:      var(--ed-space-1);
}

.edn-ss-slider-current {
    font-family: var(--ed-font-mono);
    font-size:   var(--ed-text-lg);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
}

.edn-ss-simulator__results {
    display:               grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap:                   var(--ed-space-4);
    background:            #F5F0E8;
    border-radius:         var(--ed-radius-xl);
    padding:               var(--ed-space-4);
    text-align:            center;
}

.edn-ss-res-block {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            var(--ed-space-1);
}

.edn-ss-res-label {
    font-size: var(--ed-text-xs);
    color:     var(--ed-color-text-muted);
}

.edn-ss-res-value {
    font-family: var(--ed-font-mono);
    font-size:   var(--ed-text-xl);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
}

.edn-ss-res-value.ed-color-accent {
    color: var(--ed-color-accent);
}

.edn-ss-simulator__action {
    margin-top: var(--ed-space-6);
}

@media (max-width: 767px) {
    .edn-ss-simulator__sliders {
        grid-template-columns: 1fr;
    }
    .edn-ss-simulator__results {
        grid-template-columns: 1fr;
    }
}

/* --- 4. Comment �a fonctionne Section --- */
.edn-ss-how-it-works {
    background-color: #EDE8DC;
    padding-top:      var(--ed-space-16);
    padding-bottom:   var(--ed-space-20);
}

.edn-ss-how-it-works__header {
    margin-bottom: var(--ed-space-12);
}

.edn-ss-how-it-works__header h2 {
    font-family: var(--ed-font-heading);
    font-size:   var(--ed-text-h2);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
    margin:      0;
}

.edn-ss-steps-grid {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--ed-space-6);
}

.edn-ss-step-card {
    background:    #FFFFFF;
    border-radius: var(--ed-radius-xl);
    padding:       var(--ed-space-6);
    text-align:    center;
    box-shadow:    var(--ed-shadow-xs);
}

.edn-ss-step-icon {
    display:       block;
    font-size:     32px;
    margin-bottom: var(--ed-space-3);
    line-height:   1;
}

.edn-ss-step-card h3 {
    font-family:   var(--ed-font-heading);
    font-size:     var(--ed-text-lg);
    font-weight:   var(--ed-font-semibold);
    color:         var(--ed-color-primary);
    margin-bottom: var(--ed-space-2);
}

.edn-ss-step-card p {
    font-size: var(--ed-text-sm);
    color:     var(--ed-color-text-muted);
    margin:    0;
}

.edn-ss-how-it-works__footer {
    text-align: center;
    font-size:  var(--ed-text-sm);
    color:      var(--ed-color-text-muted);
    margin-top: var(--ed-space-6);
}

@media (max-width: 1024px) {
    .edn-ss-steps-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 767px) {
    .edn-ss-steps-grid {
        grid-template-columns: 1fr;
    }
}

/* --- 5. Abonnements Section --- */
.edn-ss-pricing {
    background-color: #F5F0E8;
    padding-top:      var(--ed-space-16);
    padding-bottom:   var(--ed-space-24);
}

.edn-ss-pricing__header {
    margin-bottom: var(--ed-space-12);
}

.edn-ss-pricing__header h2 {
    font-family: var(--ed-font-heading);
    font-size:   var(--ed-text-h2);
    font-weight: var(--ed-font-bold);
    color:       var(--ed-color-primary);
    margin:      0;
}

.edn-ss-pricing__grid {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   var(--ed-space-6);
}

.edn-ss-pricing-card {
    position:      relative;
    background:    #FFFFFF;
    border-radius: var(--ed-radius-2xl);
    padding:       var(--ed-space-6);
    text-align:    center;
    box-shadow:    var(--ed-shadow-sm);
    display:       flex;
    flex-direction: column;
}

.edn-ss-pricing-card--popular {
    box-shadow: 0 0 0 2px var(--ed-color-accent);
}

.edn-ss-badge-popular {
    position:         absolute;
    top:              -12px;
    left:             50%;
    transform:        translateX(-50%);
    background-color: var(--ed-color-accent);
    color:            var(--ed-color-primary);
    font-size:        var(--ed-text-xs);
    font-weight:      var(--ed-font-bold);
    padding:          var(--ed-space-1) var(--ed-space-3);
    border-radius:    var(--ed-radius-full);
    white-space:      nowrap;
}

.edn-ss-pricing-card h3 {
    font-family:   var(--ed-font-heading);
    font-size:     var(--ed-text-lg);
    font-weight:   var(--ed-font-bold);
    color:         var(--ed-color-primary);
    margin-bottom: var(--ed-space-2);
}

.edn-ss-price {
    font-family:   var(--ed-font-mono);
    font-size:     var(--ed-text-h2);
    font-weight:   var(--ed-font-bold);
    color:         var(--ed-color-primary);
    margin-bottom: var(--ed-space-4);
}

.edn-ss-features {
    list-style: none;
    padding:    0;
    margin:     0 0 var(--ed-space-6) 0;
    font-size:  var(--ed-text-sm);
    color:      var(--ed-color-text-muted);
    flex-grow:  1;
}

.edn-ss-features li {
    margin-bottom: var(--ed-space-2);
}

.edn-ss-btn-solid {
    display:         block;
    width:           100%;
    padding:         var(--ed-space-3);
    background-color: var(--ed-color-primary);
    color:           #FFFFFF;
    font-weight:     var(--ed-font-semibold);
    font-size:       var(--ed-text-sm);
    border-radius:   var(--ed-radius-md);
    text-decoration: none;
    transition:      background-color var(--ed-transition-fast);
}

.edn-ss-btn-solid:hover {
    background-color: var(--ed-color-primary-hover);
    color:            #FFFFFF;
}

.edn-ss-btn-outline {
    display:         block;
    width:           100%;
    padding:         var(--ed-space-3);
    background-color: transparent;
    color:           var(--ed-color-primary);
    border:          1px solid var(--ed-color-primary);
    font-weight:     var(--ed-font-semibold);
    font-size:       var(--ed-text-sm);
    border-radius:   var(--ed-radius-md);
    text-decoration: none;
    transition:      background-color var(--ed-transition-fast), color var(--ed-transition-fast);
}

.edn-ss-btn-outline:hover {
    background-color: var(--ed-color-primary);
    color:            #FFFFFF;
}

@media (max-width: 1024px) {
    .edn-ss-pricing__grid {
        grid-template-columns: 1fr;
        max-width:             500px;
        margin:                0 auto;
        gap:                   var(--ed-space-8);
    }
}



/* ============================================================
   PAGE CONTACT � page-contact.php
   ============================================================ */
.eco-diamba.edn-contact-page {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 0 !important;
    background-color: var(--ed-color-bg);
}

.edn-contact-hero {
    background-color: var(--ed-color-primary);
    padding: var(--ed-space-24) 0 var(--ed-space-16);
    color: #fff;
    text-align: center;
}

.edn-contact-hero h1 {
    color: #fff;
    font-size: var(--ed-text-h1);
    margin-bottom: var(--ed-space-4);
}

.edn-contact-hero p {
    color: rgba(255,255,255,0.7);
    font-size: var(--ed-text-lg);
    max-width: 600px;
    margin: 0 auto;
}

.edn-contact-main {
    padding: var(--ed-space-16) 0 var(--ed-space-24);
}

.edn-contact-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--ed-space-8);
}

.edn-contact-wa-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--ed-space-2);
    background-color: #25D366;
    color: #fff !important;
    padding: var(--ed-space-4) var(--ed-space-6);
    border-radius: var(--ed-radius-xl);
    font-weight: var(--ed-font-bold);
    text-decoration: none;
    margin-bottom: var(--ed-space-8);
    width: 100%;
    transition: opacity 0.2s;
}
.edn-contact-wa-btn:hover {
    opacity: 0.9;
    color: #fff !important;
}

.edn-contact-wa-btn svg {
    color: #fff !important;
}

.edn-contact-form {
    background: #fff;
    padding: var(--ed-space-8);
    border-radius: var(--ed-radius-2xl);
    box-shadow: var(--ed-shadow-sm);
}

.edn-form-row {
    display: flex;
    gap: var(--ed-space-4);
    margin-bottom: var(--ed-space-4);
}
.edn-form-row .edn-form-group {
    flex: 1;
    margin-bottom: 0;
}

.edn-form-group {
    margin-bottom: var(--ed-space-4);
}

.edn-form-group label {
    display: block;
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
    margin-bottom: var(--ed-space-2);
}

.edn-form-group input,
.edn-form-group select,
.edn-form-group textarea {
    width: 100%;
    padding: var(--ed-space-3);
    border: 1px solid var(--ed-color-border);
    border-radius: var(--ed-radius-md);
    font-size: var(--ed-text-sm);
    outline: none;
    background: #fff;
    color: var(--ed-color-primary);
}

.edn-form-group input:focus,
.edn-form-group select:focus,
.edn-form-group textarea:focus {
    border-color: var(--ed-color-primary);
}

.edn-contact-form button[type="submit"] {
    width: 100%;
    background-color: var(--ed-color-primary);
    color: #fff;
    padding: var(--ed-space-4);
    border: none;
    border-radius: var(--ed-radius-md);
    font-weight: var(--ed-font-bold);
    cursor: pointer;
    font-size: var(--ed-text-base);
    transition: background-color 0.2s;
}
.edn-contact-form button[type="submit"]:hover {
    background-color: var(--ed-color-primary-hover);
}

.edn-contact-form button[disabled] {
    opacity: 0.7;
    cursor: not-allowed;
}

.edn-contact-info-card {
    background: #fff;
    padding: var(--ed-space-8);
    border-radius: var(--ed-radius-2xl);
    box-shadow: var(--ed-shadow-sm);
    display: flex;
    flex-direction: column;
    gap: var(--ed-space-6);
}

.edn-info-item {
    display: flex;
    gap: var(--ed-space-4);
    align-items: flex-start;
}

.edn-info-icon {
    color: var(--ed-color-accent);
    flex-shrink: 0;
    margin-top: 2px;
}

.edn-info-label {
    display: block;
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
    margin-bottom: 2px;
}

.edn-info-val {
    display: block;
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
    text-decoration: none;
}
.edn-info-val:hover {
    color: var(--ed-color-accent);
}

@media(max-width: 991px) {
    .edn-contact-grid {
        grid-template-columns: 1fr;
    }
}
@media(max-width: 767px) {
    .edn-form-row {
        flex-direction: column;
    }
}

/* ============================================================
   PAGE T�MOIGNAGES � page-temoignages.php
   ============================================================ */
.eco-diamba.edn-reviews-page {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 0 !important;
    background-color: #ffffff;
}

.edn-reviews-hero {
    background-color: var(--ed-color-primary);
    padding: var(--ed-space-24) 0 var(--ed-space-16);
    color: #fff;
}

.edn-reviews-hero h1 {
    color: #fff;
    font-size: var(--ed-text-h1);
    margin-bottom: var(--ed-space-4);
}

.edn-reviews-hero-stars {
    display: flex;
    justify-content: center;
    gap: var(--ed-space-2);
    margin-bottom: var(--ed-space-4);
}

.edn-reviews-hero p {
    color: rgba(255,255,255,0.7);
    font-size: var(--ed-text-lg);
    margin: 0;
}

.edn-reviews-main {
    padding: var(--ed-space-16) 0 var(--ed-space-24);
}

.edn-reviews-header-block {
    display: flex;
    flex-direction: column;
    gap: var(--ed-space-8);
    margin-bottom: var(--ed-space-16);
}

/* Stats Card */
.edn-reviews-stats-card {
    display: flex;
    align-items: center;
    gap: var(--ed-space-12);
    background: #fff;
    padding: var(--ed-space-8);
    border-radius: var(--ed-radius-2xl);
    box-shadow: var(--ed-shadow-sm);
    border: 1px solid var(--ed-color-border);
    max-width: 800px;
    margin: 0 auto;
    width: 100%;
}

.edn-reviews-global {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.edn-global-score {
    font-family: var(--ed-font-heading);
    font-size: 64px;
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-primary);
    line-height: 1;
    margin-bottom: var(--ed-space-2);
}

.edn-global-stars {
    display: flex;
    gap: var(--ed-space-1);
    margin-bottom: var(--ed-space-2);
}

.edn-global-count {
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
}

.edn-reviews-bars {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--ed-space-3);
}

.edn-review-bar-row {
    display: flex;
    align-items: center;
    gap: var(--ed-space-4);
}

.edn-bar-label {
    width: 60px;
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
}

.edn-bar-track {
    flex: 1;
    height: 8px;
    background: rgba(0,0,0,0.05);
    border-radius: var(--ed-radius-full);
    overflow: hidden;
}

.edn-bar-fill {
    height: 100%;
    background: var(--ed-color-accent);
    border-radius: var(--ed-radius-full);
}

.edn-bar-pct {
    width: 40px;
    font-size: var(--ed-text-sm);
    color: var(--ed-color-primary);
    font-weight: var(--ed-font-bold);
    text-align: right;
}

/* Filters & Actions */
.edn-reviews-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--ed-space-4);
}

.edn-reviews-filters {
    display: flex;
    gap: var(--ed-space-2);
    flex-wrap: wrap;
}

.edn-filter-btn {
    background: rgba(26,58,42,0.05);
    border: none;
    padding: var(--ed-space-2) var(--ed-space-4);
    border-radius: var(--ed-radius-full);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
    cursor: pointer;
    transition: all 0.2s;
}

.edn-filter-btn:hover {
    background: rgba(26,58,42,0.1);
}

.edn-filter-btn.active {
    background: var(--ed-color-primary);
    color: #fff;
}

/* Grid */
.edn-reviews-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--ed-space-6);
}

.edn-review-card {
    background: #fff;
    padding: var(--ed-space-6);
    border-radius: var(--ed-radius-xl);
    border: 1px solid var(--ed-color-border);
    box-shadow: var(--ed-shadow-sm);
}

.edn-review-header {
    display: flex;
    align-items: center;
    gap: var(--ed-space-4);
    margin-bottom: var(--ed-space-4);
}

.edn-review-avatar {
    width: 48px;
    height: 48px;
    background: var(--ed-color-primary);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-lg);
    font-weight: var(--ed-font-bold);
    flex-shrink: 0;
}

.edn-review-meta {
    display: flex;
    flex-direction: column;
}

.edn-review-name {
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-primary);
}

.edn-review-region {
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
}

.edn-review-stars {
    display: flex;
    gap: var(--ed-space-1);
    margin-bottom: var(--ed-space-4);
}

.edn-review-text {
    font-size: var(--ed-text-base);
    color: var(--ed-color-primary);
    margin-bottom: var(--ed-space-6);
    line-height: 1.6;
}

.edn-review-badge {
    display: inline-block;
    background: rgba(26,58,42,0.05);
    color: var(--ed-color-primary);
    padding: var(--ed-space-1) var(--ed-space-3);
    border-radius: var(--ed-radius-md);
    font-size: var(--ed-text-xs);
    font-weight: var(--ed-font-bold);
}

@media(max-width: 991px) {
    .edn-reviews-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .edn-reviews-stats-card {
        flex-direction: column;
        gap: var(--ed-space-6);
    }
}
@media(max-width: 767px) {
    .edn-reviews-grid {
        grid-template-columns: 1fr;
    }
    .edn-reviews-actions {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ============================================================
   PAGE A PROPOS � page-apropos.php
   ============================================================ */
.eco-diamba.edn-about-page {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 0 !important;
}

/* Background Utility Classes */
.bg-sand { background-color: #F5F0E8; }
.bg-beige { background-color: #EDE8DC; }

/* Hero */
.edn-about-hero {
    position: relative;
    background-color: var(--ed-color-primary);
    padding: var(--ed-space-24) 0 var(--ed-space-20);
    overflow: hidden;
    text-align: center;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}
.edn-about-hero-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center bottom;
    opacity: 0.2;
}
.edn-about-hero h1 {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-3xl);
    font-weight: var(--ed-font-bold);
    color: #fff;
    margin: 0 auto var(--ed-space-4);
    line-height: 1.2;
    max-width: 800px;
}
@media (min-width: 1024px) {
    .edn-about-hero {
        padding: 100px 0 60px;
    }
    .edn-about-hero h1 { 
        font-size: 40px; 
    }
}
.edn-about-hero p {
    font-size: var(--ed-text-lg);
    color: rgba(255,255,255,0.8);
    max-width: 600px;
    margin: 0 auto;
}

/* Utilities for section widths */
.max-w-3xl { max-width: 768px !important; margin-left: auto !important; margin-right: auto !important; }
.max-w-4xl { max-width: 896px !important; margin-left: auto !important; margin-right: auto !important; }
.max-w-5xl { max-width: 1024px !important; margin-left: auto !important; margin-right: auto !important; }
.text-center { text-align: center !important; }

/* Sections */
.edn-about-section {
    padding: var(--ed-space-16) 0;
}
@media (min-width: 1024px) {
    .edn-about-section { padding: var(--ed-space-24) 0; }
}

.edn-section-title {
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-2xl);
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-primary);
    margin-bottom: var(--ed-space-8);
    text-align: center;
}

/* Story */
.edn-about-story p {
    font-size: var(--ed-text-lg);
    color: var(--ed-color-text);
    margin-bottom: var(--ed-space-4);
    line-height: 1.6;
}

/* Timeline */
.edn-timeline {
    position: relative;
    margin-top: var(--ed-space-8);
}
.edn-timeline-line {
    position: absolute;
    left: 1rem;
    top: 0;
    bottom: 0;
    width: 2px;
    background-color: #D4CEBC;
}
@media (min-width: 1024px) {
    .edn-timeline-line { left: 50%; }
}

.edn-timeline-item {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: var(--ed-space-6);
    margin-bottom: var(--ed-space-8);
}
.edn-timeline-item:last-child {
    margin-bottom: 0;
}

.edn-timeline-dot {
    position: absolute;
    left: 1rem;
    transform: translateX(-50%);
    width: 12px;
    height: 12px;
    background-color: var(--ed-color-accent);
    border: 4px solid #EDE8DC;
    border-radius: 50%;
    z-index: 10;
    margin-top: 6px;
}
@media (min-width: 1024px) {
    .edn-timeline-dot { left: 50%; }
}

.edn-timeline-content {
    flex: 1;
    margin-left: 2.5rem;
    background: #fff;
    border-radius: var(--ed-radius-xl);
    padding: var(--ed-space-5);
    box-shadow: var(--ed-shadow-sm);
}

@media (min-width: 1024px) {
    .edn-timeline-content {
        margin-left: 0;
        width: 45%;
        flex: none;
    }
    .edn-timeline-item-left .edn-timeline-content {
        margin-right: auto;
    }
    .edn-timeline-item-right {
        flex-direction: row-reverse;
    }
    .edn-timeline-item-right .edn-timeline-content {
        margin-left: auto;
    }
}

.edn-timeline-year {
    display: block;
    font-family: var(--ed-font-mono);
    font-size: var(--ed-text-sm);
    font-weight: var(--ed-font-bold);
    color: var(--ed-color-accent);
    margin-bottom: var(--ed-space-1);
}
.edn-timeline-text {
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
    margin: 0;
}

/* Team Grid */
.edn-team-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ed-space-6);
}
@media (min-width: 640px) {
    .edn-team-grid { grid-template-columns: repeat(3, 1fr); }
}

.edn-team-card {
    background: #fff;
    border-radius: var(--ed-radius-xl);
    padding: var(--ed-space-6);
    text-align: center;
    box-shadow: var(--ed-shadow-sm);
}
.edn-team-avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background-color: var(--ed-color-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--ed-font-heading);
    font-size: var(--ed-text-2xl);
    font-weight: var(--ed-font-bold);
    margin: 0 auto var(--ed-space-4);
}
.edn-team-name {
    font-family: var(--ed-font-heading);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
    margin-bottom: 2px;
}
.edn-team-role {
    font-size: var(--ed-text-xs);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-accent);
    margin-bottom: var(--ed-space-2);
}
.edn-team-desc {
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
    margin: 0;
}

/* Values Grid */
.edn-values-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--ed-space-6);
}
@media (min-width: 640px) {
    .edn-values-grid { grid-template-columns: repeat(3, 1fr); }
}

.edn-value-card {
    background: #fff;
    border-radius: var(--ed-radius-xl);
    padding: var(--ed-space-6);
    text-align: center;
    box-shadow: var(--ed-shadow-sm);
}
.edn-value-icon {
    display: block;
    font-size: 30px;
    margin-bottom: var(--ed-space-3);
}
.edn-value-title {
    font-family: var(--ed-font-heading);
    font-weight: var(--ed-font-semibold);
    color: var(--ed-color-primary);
    margin-bottom: var(--ed-space-2);
}
.edn-value-desc {
    font-size: var(--ed-text-sm);
    color: var(--ed-color-text-muted);
    margin: 0;
}

/* ============================================================
   HARMONISATION DES BANNIERES HERO
   ============================================================ */
.edn-ss-hero,
.edn-contact-hero,
.edn-reviews-hero,
.edn-about-hero {
    min-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--ed-space-16) 0 var(--ed-space-12) !important;
    text-align: center;
    position: relative;
    overflow: hidden;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.edn-ss-hero > div,
.edn-contact-hero > div,
.edn-reviews-hero > div,
.edn-about-hero > div {
    width: 100%;
}

.edn-ss-hero h1,
.edn-contact-hero h1,
.edn-reviews-hero h1,
.edn-about-hero h1 {
    font-family: var(--ed-font-heading) !important;
    font-size: var(--ed-text-3xl) !important;
    font-weight: var(--ed-font-bold) !important;
    color: #fff !important;
    margin: 0 auto var(--ed-space-4) !important;
    line-height: 1.2 !important;
    max-width: 800px;
}

@media (min-width: 1024px) {
    .edn-ss-hero,
    .edn-contact-hero,
    .edn-reviews-hero,
    .edn-about-hero {
        min-height: 350px;
        padding: 80px 0 40px !important;
    }
    
    .edn-ss-hero h1,
    .edn-contact-hero h1,
    .edn-reviews-hero h1,
    .edn-about-hero h1 {
        font-size: 40px !important;
    }
}

/**
 * -----------------------------------------------------------------------------
 * PANIER (BASE44 DESIGN)
 * -----------------------------------------------------------------------------
 */

/* 1. Header de page & Fond */
.woocommerce-cart .entry-header { display: none !important; }
.woocommerce-cart .site-content,
.woocommerce-cart .ast-plain-container,
.woocommerce-cart #primary {
    background-color: transparent !important;
    padding-top: var(--ed-space-12) !important;
}
body.woocommerce-cart {
    background-color: var(--ed-color-bg) !important;
}

/* 2. Layout Grille */
.ed-cart-grid {
    display: grid;
    gap: var(--ed-space-8);
    grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
    .ed-cart-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

/* 7. Image produit */
.ed-cart-item-image img {
    width: 80px !important;
    height: 80px !important;
    object-fit: cover;
    border-radius: var(--ed-radius-lg);
}

/* 8. Badge Variation (Format/Volume) */
.ed-cart-item dl.variation {
    display: block;
    background-color: transparent !important;
    color: var(--ed-color-text-muted) !important;
    padding: 0 !important;
    border-radius: 0;
    font-size: var(--ed-text-sm);
    font-weight: normal;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.ed-cart-item dl.variation dt,
.ed-cart-item dl.variation dd,
.ed-cart-item dl.variation p {
    display: inline;
    margin: 0 !important;
    padding: 0 !important;
    font-weight: normal;
}

/* Bouton Supprimer (Poubelle) */
.ed-cart-item .ed-btn-remove {
    background-color: transparent;
    color: #ef4444 !important; /* Rouge par d�faut comme dans l'image */
}
.ed-cart-item .ed-btn-remove:hover {
    background-color: rgba(239, 68, 68, 0.1) !important;
}

/* 5. S�lecteur de Quantit� */
.ed-cart-item .quantity {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--ed-color-border);
    border-radius: var(--ed-radius-full) !important;
    overflow: hidden;
    background: transparent;
}
.ed-cart-item .quantity input.qty {
    width: 32px;
    height: 36px;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    text-align: center;
    font-family: var(--ed-font-body);
    font-size: var(--ed-text-sm);
    font-weight: 600;
    color: var(--ed-color-text);
    padding: 0;
    -moz-appearance: textfield;
    background: transparent !important;
    pointer-events: none; /* Le champ est intouchable, on ne voit que les chiffres */
}
.ed-cart-item .quantity input.qty::-webkit-outer-spin-button,
.ed-cart-item .quantity input.qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.ed-qty-btn {
    background: transparent;
    border: none;
    width: 30px;
    height: 36px;
    font-size: 18px;
    cursor: pointer;
    color: var(--ed-color-text);
    transition: background 0.2s;
}
.ed-qty-btn:hover {
    background: var(--ed-color-surface);
}

/* Cacher les boutons natifs Astra +/- */
.ed-cart-item .quantity .ast-stock-detail,
.ed-cart-item .quantity .ast-plus-minus {
    display: none !important;
}

/* 3. R�capitulatif Table (Collaterals) */
.cart_totals h2 {
    display: none !important;
}

/* Forcer la pleine largeur sur les �l�ments du r�capitulatif (Astra les compresse par d�faut) */
.ed-cart-sidebar .cart_totals,
.ed-cart-sidebar .cart-collaterals {
    width: 100% !important;
    float: none !important;
}
.ed-cart-sidebar .cart_totals table {
    width: 100% !important;
    border: none !important;
}
.ed-cart-sidebar .cart_totals td,
.ed-cart-sidebar .cart_totals th {
    padding: var(--ed-space-4) 0 !important;
    border: none !important;
    font-size: var(--ed-text-sm);
}
.ed-cart-sidebar .cart_totals tr {
    border-bottom: none !important;
}
.ed-cart-sidebar .cart_totals tr.order-total {
    border-top: 1px solid var(--ed-color-text-muted) !important;
}
.ed-cart-sidebar .cart_totals tr.order-total th,
.ed-cart-sidebar .cart_totals tr.order-total td {
    font-size: var(--ed-text-lg) !important;
    color: var(--ed-color-text) !important;
}

/* 4. Bouton Checkout - Pleine largeur */
.ed-cart-sidebar .wc-proceed-to-checkout {
    width: 100% !important;
    padding: 0 !important;
}
.ed-cart-sidebar .wc-proceed-to-checkout a {
    width: 100% !important;
    display: block !important;
    text-align: center !important;
}

/* ============================================================
   TOAST NOTIFICATIONS (WooCommerce Messages)
   ============================================================ */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
    position: fixed !important;
    top: 20px !important;
    right: 20px !important;
    z-index: 999999 !important;
    max-width: 400px;
    width: calc(100% - 40px);
    margin: 0 !important;
    padding: var(--ed-space-4) var(--ed-space-5) !important;
    border-radius: var(--ed-radius-xl) !important;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1) !important;
    background: white !important;
    color: var(--ed-color-text) !important;
    border: none !important;
    border-left: 5px solid var(--ed-color-primary) !important;
    font-size: var(--ed-text-sm) !important;
    line-height: 1.5 !important;
    animation: edn-slide-in-right 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
    display: flex;
    align-items: center;
    gap: var(--ed-space-3);
}

.woocommerce-error {
    border-left-color: #ef4444 !important;
}
.woocommerce-info {
    border-left-color: #3b82f6 !important;
}

/* Override default icons/buttons inside the toast */
.woocommerce-message::before,
.woocommerce-error::before,
.woocommerce-info::before {
    display: none !important; /* Hide native WC icon */
}
.woocommerce-message a.button.wc-forward {
    background: transparent !important;
    color: var(--ed-color-primary) !important;
    border: 1px solid var(--ed-color-primary) !important;
    padding: var(--ed-space-1) var(--ed-space-3) !important;
    border-radius: var(--ed-radius-full) !important;
    font-size: var(--ed-text-xs) !important;
    font-weight: 600 !important;
    margin-left: auto !important;
    float: right !important;
    white-space: nowrap;
}
.woocommerce-message a.button.wc-forward:hover {
    background: var(--ed-color-primary) !important;
    color: white !important;
}

/* Hide the toast automatically after 5 seconds via CSS animation hack */
@keyframes edn-slide-in-right {
    0% { transform: translateX(100%); opacity: 0; }
    10% { transform: translateX(0); opacity: 1; }
    90% { transform: translateX(0); opacity: 1; }
    100% { transform: translateX(100%); opacity: 0; pointer-events: none; }
}
.woocommerce-message, .woocommerce-error, .woocommerce-info {
    animation: edn-slide-in-right 5s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
}

/* Correction du Sous-Menu (Dropdown) */
.main-header-menu .sub-menu, .ast-builder-menu-1 .sub-menu, 
.ast-desktop .main-header-menu .sub-menu {
    background-color: rgba(10, 30, 20, 0.85) !important; /* Transparent et �l�gant */
    backdrop-filter: blur(10px); /* Effet flou premium (Glassmorphism) */
    box-shadow: 0 10px 30px rgba(0,0,0,0.2) !important;
    border-radius: 8px !important;
    padding: 10px 0 !important;
}
.main-header-menu .sub-menu .menu-item a, 
.ast-builder-menu-1 .sub-menu .menu-item a,
.main-header-menu .sub-menu .menu-item a *,
.ast-builder-menu-1 .sub-menu .menu-item a * {
    color: #ffffff !important; /* Texte blanc lisible */
    font-weight: 500 !important;
}
.main-header-menu .sub-menu .menu-item:hover > a, 
.ast-builder-menu-1 .sub-menu .menu-item:hover > a,
.main-header-menu .sub-menu .menu-item:hover > a * {
    color: #27ae60 !important; /* Vert primaire au survol */
    background-color: rgba(255,255,255,0.1) !important; /* L�ger fond transparent au survol */
}







/* R?duction de la taille de l'ic?ne du panier pour l'harmoniser */
.ast-header-woo-cart .ast-cart-menu-wrap .count-half,
.ast-header-woo-cart .ast-cart-menu-wrap .ast-site-header-cart-icon {
    transform: scale(0.9);
}

/* Centrer le nombre dans le s?lecteur de quantit? WooCommerce */
.woocommerce .quantity input.qty, 
.woocommerce-page .quantity input.qty,
.ast-quantity-btn input.qty,
.woocommerce form .quantity.buttons_added .qty {
    text-align: center !important;
}

/* FORCE CENTER QUANTITY */
.quantity input, .quantity input.qty, .quantity input[type='number'], form.cart div.quantity input, .ast-quantity-btn input {
    text-align: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    text-indent: 0 !important;
}

/* CORRECTION SELECTEURS ET CHAMPS DE SAISIE COUP?S */
select, .woocommerce select, .woocommerce-page select, .woocommerce form .form-row select {
    min-height: 45px !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    line-height: 1.5 !important;
    height: auto !important;
    vertical-align: middle !important;
}

.select2-container .select2-selection--single {
    height: 45px !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 45px !important;
}

/* DESIGN BOX TOTAL PANIER */
.woocommerce-cart .cart-collaterals .cart_totals {
    border-radius: 16px !important;
    border: 1px solid rgba(0,0,0,0.1) !important;
    padding: 30px !important;
    background-color: #ffffff;
    box-shadow: 0 4px 15px rgba(0,0,0,0.03);
}

.woocommerce-cart .cart-collaterals .cart_totals table {
    margin-bottom: 0px !important;
}

.woocommerce-cart .wc-proceed-to-checkout {
    padding-top: 5px !important;
    padding-bottom: 5px !important;
    margin-bottom: 0 !important;
}

/* CORRECTION ALIGNEMENT MOBILE DES PACKS (PRODUITS) */
@media (max-width: 768px) {
    .eco-diamba.edn-shop ul.products,
    .woocommerce ul.products {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
        padding-left: 15px !important;
        padding-right: 15px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        justify-content: center !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    .eco-diamba.edn-shop ul.products li.product,
    .woocommerce ul.products li.product {
        width: 100% !important;
        margin: 0 !important;
    }
}

@media (max-width: 480px) {
    .eco-diamba.edn-shop ul.products,
    .woocommerce ul.products {
        grid-template-columns: repeat(1, 1fr) !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
        max-width: 400px !important;
    }
}


/* =============================================================
   PAGE "MON COMPTE" WOOCOMMERCE
   ============================================================= */
/* Isoler toutes les modifications sur la page compte uniquement */
body.woocommerce-account .site-content {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
}

body.woocommerce-account .woocommerce {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    background: #ffffff;
    border-radius: var(--ed-radius-xl, 16px);
    box-shadow: var(--ed-shadow-md);
    padding: 30px;
    max-width: 1200px;
    margin: 0 auto;
}

/* Navigation lat�rale (Sidebar) */
body.woocommerce-account .woocommerce-MyAccount-navigation {
    flex: 0 0 250px;
    width: 250px;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
    margin-bottom: 8px;
    border: none;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 12px 20px;
    background-color: rgba(10, 30, 20, 0.03);
    color: var(--ed-color-text);
    border-radius: var(--ed-radius-md, 8px);
    font-weight: 500;
    transition: all 0.3s ease;
    text-decoration: none;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
    background-color: var(--ed-color-primary);
    color: #ffffff;
    transform: translateX(5px);
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    background-color: var(--ed-color-primary);
    color: #ffffff;
    box-shadow: var(--ed-shadow-sm);
}

/* Zone de contenu (� droite) */
body.woocommerce-account .woocommerce-MyAccount-content {
    flex: 1;
    min-width: 0;
    background: rgba(10, 30, 20, 0.01);
    padding: 30px;
    border-radius: var(--ed-radius-lg, 12px);
    border: 1px solid rgba(10, 30, 20, 0.05);
}

/* Champs de formulaires dans la page compte */
body.woocommerce-account .woocommerce form .form-row input.input-text,
body.woocommerce-account .woocommerce form .form-row textarea {
    padding: 12px 15px;
    border-radius: var(--ed-radius-md, 8px);
    border: 1px solid #ddd;
    background-color: #fcfcfc;
    transition: border-color 0.3s ease;
}

body.woocommerce-account .woocommerce form .form-row input.input-text:focus,
body.woocommerce-account .woocommerce form .form-row textarea:focus {
    border-color: var(--ed-color-primary);
    outline: none;
    background-color: #fff;
    box-shadow: 0 0 0 2px rgba(10, 30, 20, 0.1);
}

/* Boutons d'action */
body.woocommerce-account .woocommerce .button {
    background-color: var(--ed-color-primary) !important;
    color: #ffffff !important;
    border-radius: var(--ed-radius-lg, 12px) !important;
    padding: 12px 24px !important;
    font-weight: 600 !important;
    border: none !important;
    transition: all 0.3s ease !important;
    box-shadow: var(--ed-shadow-sm) !important;
}

body.woocommerce-account .woocommerce .button:hover {
    background-color: var(--ed-color-accent) !important;
    transform: translateY(-2px);
}

/* En-t�tes (h2, h3) dans le compte */
body.woocommerce-account .woocommerce-MyAccount-content h2,
body.woocommerce-account .woocommerce-MyAccount-content h3 {
    color: var(--ed-color-primary);
    font-weight: 800;
    margin-bottom: 20px;
    border-bottom: 2px solid rgba(10, 30, 20, 0.1);
    padding-bottom: 10px;
}

/* Responsive */
@media (max-width: 768px) {
    body.woocommerce-account .woocommerce {
        flex-direction: column;
    }
    body.woocommerce-account .woocommerce-MyAccount-navigation,
    body.woocommerce-account .woocommerce-MyAccount-content {
        width: 100%;
    }
    body.woocommerce-account .woocommerce-MyAccount-content {
        padding: 20px;
    }
    body.woocommerce-account .site-content {
        padding: 30px 15px !important;
    }
}

/* Mettre le titre de la page en blanc (pour qu'il soit visible sur la banni�re sombre) */
body.woocommerce-account .entry-title,
body.woocommerce-cart .entry-title,
body.woocommerce-checkout .entry-title,
body.woocommerce-page .ast-archive-title {
    color: #ffffff !important;
}

/* =============================================================
   CORRECTION DU TRAIT BLANC (UNIQUEMENT HEADERS TRANSPARENTS)
   ============================================================= */
/* Force le contenu � se coller en haut, sous le menu transparent, 
   sans affecter les pages normales qui n'ont pas de menu transparent. */
.ast-theme-transparent-header .site-content,
.ast-theme-transparent-header .ast-container,
.ast-theme-transparent-header .site-main,
.edn-home-transparent .site-content,
.edn-home-transparent .ast-container,
.edn-home-transparent .site-main {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* Corrige les marges fantômes générées par Elementor ou Gutenberg en haut de page */
.ast-theme-transparent-header .entry-content > *:first-child,
.edn-home-transparent .entry-content > *:first-child {
    margin-top: 0 !important;
}

/* ============================================================
   HERO CAROUSEL
   ============================================================ */
.ed-hero-carousel {
    position: relative;
    width: 100%;
    min-height: 100vh;
    overflow: hidden;
}

.ed-hero-carousel-track {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 100vh;
}

.ed-hero-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    min-height: 100vh;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    opacity: 0;
    transition: opacity 1s ease-in-out;
    z-index: 0;
}

.ed-hero-slide.is-active {
    opacity: 1;
    z-index: 1;
}

.ed-hero-slide .ed-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(10,46,21,0.82) 0%, rgba(20,60,30,0.65) 50%, rgba(10,46,21,0.75) 100%);
    z-index: 1;
}

.ed-hero-slide .ed-hero-inner {
    position: relative;
    z-index: 2;
    padding: 8rem 2rem 6rem;
    max-width: 900px;
}

.ed-hero-slide .ed-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--ed-color-accent, #E8B931);
    background: rgba(232,185,49,0.12);
    padding: 0.5rem 1.25rem;
    border-radius: 50px;
    margin-bottom: 1.5rem;
    backdrop-filter: blur(6px);
    animation: fadeInUp 0.8s ease-out both;
}

.ed-hero-slide .ed-hero-title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 800;
    line-height: 1.15;
    color: #fff;
    margin-bottom: 1.5rem;
    animation: fadeInUp 0.8s 0.15s ease-out both;
}

.ed-hero-slide .ed-hero-subtitle {
    font-size: 1.1rem;
    line-height: 1.7;
    color: rgba(255,255,255,0.85);
    max-width: 680px;
    margin-bottom: 2rem;
    animation: fadeInUp 0.8s 0.3s ease-out both;
}

.ed-hero-slide .ed-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    animation: fadeInUp 0.8s 0.45s ease-out both;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(25px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Carousel dots */
.ed-hero-carousel-dots {
    position: absolute;
    bottom: 6rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    gap: 0.75rem;
}

.ed-hero-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.6);
    background: transparent;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 0;
}

.ed-hero-dot.is-active {
    background: var(--ed-color-accent, #E8B931);
    border-color: var(--ed-color-accent, #E8B931);
    transform: scale(1.2);
}

.ed-hero-dot:hover {
    border-color: #fff;
    background: rgba(255,255,255,0.3);
}

/* Payment badges floating at bottom of carousel */
.ed-hero-pay-float {
    position: absolute;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: rgba(0,0,0,0.35);
    backdrop-filter: blur(10px);
    padding: 0.75rem 1.5rem;
    border-radius: 50px;
    font-size: 0.8rem;
    color: rgba(255,255,255,0.75);
}

.ed-hero-pay-float .ed-pay-badge {
    background: rgba(255,255,255,0.12);
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #fff;
}

/* ============================================================
   NOS PACKS SECTION
   ============================================================ */
.ed-packs {
    padding: var(--ed-space-20, 5rem) 0;
    background: linear-gradient(180deg, #f8faf5 0%, #edf5e2 100%);
}

.ed-packs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    max-width: 1000px;
    margin: 0 auto;
}

.ed-pack-card {
    position: relative;
    background: #fff;
    border-radius: 20px;
    padding: 2.5rem 2rem 2rem;
    box-shadow: 0 4px 24px rgba(0,0,0,0.06);
    border: 1px solid rgba(10,46,21,0.08);
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    overflow: hidden;
}

.ed-pack-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 40px rgba(10,46,21,0.12);
}

.ed-pack-card-accent {
    border-color: var(--ed-color-primary, #0A2E15);
    background: linear-gradient(180deg, #fff 0%, #f0f7ed 100%);
}

.ed-pack-card-accent::before {
    content: '⭐ Recommandé';
    position: absolute;
    top: 16px;
    right: -32px;
    background: var(--ed-color-accent, #E8B931);
    color: #1a1a1a;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 4px 40px;
    transform: rotate(45deg);
}

.ed-pack-badge {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ed-color-primary, #0A2E15);
    background: rgba(10,46,21,0.08);
    padding: 0.35rem 1rem;
    border-radius: 50px;
    margin-bottom: 1rem;
    align-self: flex-start;
}

.ed-pack-header {
    margin-bottom: 1.5rem;
}

.ed-pack-title {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--ed-color-primary, #0A2E15);
    margin: 0 0 0.75rem;
    line-height: 1.3;
}

.ed-pack-price {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
}

.ed-pack-amount {
    font-size: 2rem;
    font-weight: 800;
    color: var(--ed-color-primary, #0A2E15);
}

.ed-pack-amount small {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--ed-color-text-muted, #6b7280);
}

.ed-pack-content {
    flex: 1;
    margin-bottom: 1.5rem;
}

.ed-pack-includes {
    list-style: none;
    padding: 0;
    margin: 0 0 1.25rem;
}

.ed-pack-includes li {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.92rem;
    line-height: 1.5;
    color: var(--ed-color-text, #1a1a1a);
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(0,0,0,0.05);
}

.ed-pack-includes li:last-child {
    border-bottom: none;
}

.ed-pack-icon {
    font-size: 1.1rem;
    flex-shrink: 0;
}

.ed-pack-desc {
    font-size: 0.88rem;
    line-height: 1.65;
    color: var(--ed-color-text-muted, #6b7280);
}

.ed-pack-specs {
    display: flex;
    gap: 0.75rem;
    margin-top: 1rem;
}

.ed-pack-spec {
    background: rgba(10,46,21,0.06);
    padding: 0.35rem 0.9rem;
    border-radius: 8px;
    font-size: 0.8rem;
    color: var(--ed-color-primary, #0A2E15);
}

.ed-pack-spec strong {
    font-weight: 800;
}

.ed-pack-btn {
    width: 100%;
    text-align: center;
    padding: 0.9rem 1.5rem;
    border-radius: 12px;
    font-weight: 700;
    font-size: 1rem;
    text-decoration: none;
    transition: all 0.3s ease;
}

/* ============================================================
   RESPONSIVE — CAROUSEL + PACKS
   ============================================================ */
@media (max-width: 768px) {
    .ed-hero-slide .ed-hero-inner {
        padding: 6rem 1.5rem 5rem;
    }

    .ed-hero-slide .ed-hero-title {
        font-size: 1.8rem;
    }

    .ed-hero-carousel-dots {
        bottom: 5rem;
    }

    .ed-hero-pay-float {
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.5rem;
        padding: 0.5rem 1rem;
        max-width: 90%;
    }

    .ed-packs-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    .ed-pack-card-accent::before {
        font-size: 0.6rem;
        padding: 3px 30px;
        top: 12px;
        right: -28px;
    }
}

/* ============================================================
   FOOTER SOCIAL — TikTok icon style
   ============================================================ */
.edn-footer-social-link.tk {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.edn-footer-social-link.tk svg {
    width: 24px;
    height: 24px;
}