/* ============================================================
   EVIER-2026 — Couche de redesign « Naturel & Artisanal »
   Réécrite le 2026-06-11 : header / nav / fiche produit / footer
   ont leur propre DOM (classes ev-*) calqué sur la maquette
   /maquette-evier-ceramique/. Les sections génériques restylent
   les pages encore servies par les templates communautaires
   (catégorie, panier, compte…).
   ============================================================ */

:root {
  --sand:      #FAF6F0;
  --cream:     #FFFFFF;
  --ink:       #3A352F;
  --muted:     #6E665B; /* taupe assombri : ≥ 4,5:1 sur sable et blanc (WCAG AA) */
  --clay:      #A8694B;
  --clay-dark: #8A5238;
  --rose:      #D9B8AC;
  --stone:     #C9BBA8;
  --line:      #EAE1D5;
  --line-2:    #DCD0BF;
  --bar:       #34302A;
  --price:     #8A5238;
  --ok:        #5E7A53;
  --radius:    10px;
  --radius-sm: 7px;
  --shadow:    0 6px 24px rgba(58,53,47,.08);
  --shadow-sm: 0 2px 10px rgba(58,53,47,.06);
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* ---------- Base & typographie ---------- */
body {
  font-family: var(--sans) !important;
  color: var(--ink) !important;
  background: var(--sand) !important;
  font-size: 15px !important;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, .h1, .h2, .h3, .h4,
.page-heading, .product-name, .productname {
  font-family: var(--serif) !important;
  font-weight: 600 !important;
  color: var(--ink);
  letter-spacing: .005em;
}
a { color: var(--clay); }
a:hover, a:focus { color: var(--clay-dark); text-decoration: none; }
.dark, .navigation_page { color: var(--muted); }
.ev-container { max-width: 1180px; margin: 0 auto; padding-left: 24px; padding-right: 24px; }

/* ---------- Boutons (nouveau DOM + pages legacy) ---------- */
.ev-btn, .btn, .button, .button-small, .button-medium,
input[type="submit"], button[type="submit"],
.btn-default, a.button, span.button {
  border-radius: 50px !important;
  font-family: var(--sans) !important;
  font-weight: 600 !important;
  border: 0;
  transition: background .15s, transform .12s, box-shadow .15s;
  text-transform: none;
}
.ev-btn-primary, .btn-default, .button, a.button, span.button,
.exclusive, .ajax_add_to_cart_button, #add_to_cart .button,
.btn-primary, .btn-success, a.btn-success, button.btn-success,
#button_order_cart, input[type="submit"], button.button-medium {
  background: var(--clay) !important;
  color: #fff !important;
  border-color: var(--clay) !important;
}
.ev-btn-primary:hover, .btn-default:hover, .button:hover, a.button:hover, .exclusive:hover,
.ajax_add_to_cart_button:hover, #add_to_cart .button:hover,
.btn-primary:hover, .btn-success:hover, #button_order_cart:hover,
input[type="submit"]:hover {
  background: var(--clay-dark) !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(168,105,75,.28);
}
.ev-btn-block { display: block; width: 100%; }
.lnk_view, .button.lnk_view { background: transparent !important; color: var(--ink) !important; }

/* ============================================================
   1. BARRE UTILITAIRE — fond #34302A, h 40px
   ============================================================ */
.ev-topbar { background: var(--bar); color: #e9e1d5; font-size: 13.12px; }
.ev-topbar .ev-container { display: flex; align-items: center; justify-content: space-between; min-height: 40px; }
.ev-topbar a { color: #e9e1d5; }
.ev-topbar a:hover { color: #fff; }
.ev-topbar-left { letter-spacing: .03em; opacity: .9; }
.ev-topbar-right { display: flex; gap: 22px; align-items: center; }
.ev-topbar-phone .phone { color: var(--rose) !important; font-weight: 600; }

/* ============================================================
   2. EN-TÊTE — logo / recherche / pilule panier
   ============================================================ */
#header { background: transparent; box-shadow: none; border: 0; }
#header-blocks { background: var(--cream); border-bottom: 1px solid var(--line); }
.ev-header { display: flex; align-items: center; gap: 32px; padding-top: 18px; padding-bottom: 18px; }
#shop-logo { flex-shrink: 0; }
#shop-logo img { height: 76px; width: auto !important; display: block; }

/* Recherche */
.ev-search { flex: 1; max-width: 560px; position: relative; }
.ev-search input[type="text"] {
  width: 100%; height: 50px; padding: 0 56px 0 20px;
  border: 1.5px solid var(--line-2); border-radius: 50px; background: var(--sand);
  font-family: var(--sans); font-size: 15.2px; color: var(--ink); outline: none; transition: border .15s;
}
.ev-search input[type="text"]:focus { border-color: var(--clay); background: #fff; }
.ev-search button {
  position: absolute; right: 5px; top: 5px; height: 40px; width: 44px;
  border: 0; border-radius: 50px !important; background: var(--clay) !important; color: #fff !important;
  cursor: pointer; font-size: 16px; padding: 0;
}
.ev-search button:hover { background: var(--clay-dark) !important; transform: none; box-shadow: none; }

/* Pilule panier */
.ev-header-actions { margin-left: auto; display: flex; align-items: center; gap: 26px; }
.ev-cart-pill, #blockcart-header {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--sand) !important; border: 1.5px solid var(--line-2) !important;
  padding: 9px 18px !important; border-radius: 50px !important;
  color: var(--ink) !important; font-weight: 500; white-space: nowrap;
}
.ev-cart-pill:hover { border-color: var(--clay) !important; }
.ev-cart-ico { font-size: 17.6px; line-height: 1; }
.ev-cart-count {
  background: var(--clay) !important; color: #fff !important; border-radius: 50px;
  font-size: 11.52px; font-weight: 700; padding: 1px 8px; line-height: 1.5;
}
.ev-cart-amount { font-weight: 700; }
.ev-cart-empty { color: var(--muted); font-size: 13.6px; }

/* ============================================================
   3. NAVIGATION PRINCIPALE — sticky, Fraunces uppercase
   ============================================================ */
.ev-nav {
  background: var(--cream); border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 30; box-shadow: var(--shadow-sm);
}
.ev-nav .ev-container { display: flex; align-items: center; gap: 6px; }
.ev-nav a {
  font-family: var(--serif); font-size: 16px; font-weight: 600; letter-spacing: .03em;
  color: var(--ink); text-transform: uppercase; padding: 17px 22px; position: relative;
  text-decoration: none;
}
.ev-nav a::after {
  content: ""; position: absolute; left: 22px; right: 22px; bottom: 11px; height: 2px;
  background: var(--clay); transform: scaleX(0); transition: transform .18s; transform-origin: left;
}
.ev-nav a:hover { color: var(--clay); }
.ev-nav a:hover::after, .ev-nav a.active::after { transform: scaleX(1); }
.ev-nav .ev-nav-promo { margin-left: auto; color: var(--clay); }

/* ============================================================
   4. FIL D'ARIANE — bande blanche pleine largeur
   ============================================================ */
.ev-crumbband { background: var(--cream); border-bottom: 1px solid var(--line); }
.ev-crumbband .breadcrumb {
  background: transparent !important; border: 0 !important; border-radius: 0;
  margin: 0; padding: 13px 0; font-size: 13.44px !important; color: var(--muted);
}
.ev-crumbband .breadcrumb a { color: var(--muted) !important; }
.ev-crumbband .breadcrumb a:hover { color: var(--clay) !important; }
.ev-crumbband .breadcrumb .navigation-pipe { margin: 0 9px; opacity: .55; color: var(--muted); }
/* l'ancien fil d'ariane inclus dans #columns sur les pages legacy */
#columns > .breadcrumb { background: transparent !important; border: 0 !important; font-size: 13.44px !important; padding-left: 0; }

/* ---------- Colonnes / rythme ---------- */
.columns-container { background: var(--sand); }
/* global.css pose un fond blanc + padding-bottom:50px sur #columns →
   bande blanche parasite entre les sections pleine largeur et le footer */
#columns { padding-top: 26px; background: transparent !important; }
#center_column { padding-bottom: 30px; }
#columns.container, #footer .container { max-width: 1180px; }
.page-heading, h1.page-heading {
  font-size: 32px; border: 0; padding-bottom: 8px; margin-bottom: 22px;
  border-bottom: 2px solid var(--line);
}
.block .title_block, .sidebar-block .title_block, h3.page-product-heading {
  font-family: var(--serif) !important; color: var(--ink) !important;
  text-transform: none; border-color: var(--line) !important;
}

/* ============================================================
   5. FICHE PRODUIT — DOM maquette (ev-product)
   ============================================================ */
body#product #columns { padding-top: 18px; }
.ev-product { padding: 26px 0 10px; }
.ev-product-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 50px; align-items: start; }

/* Galerie */
.ev-gallery-main {
  border: 1px solid var(--line) !important; border-radius: var(--radius) !important;
  overflow: hidden; background: #fff;
  padding: 12px;            /* fine bordure blanche (au lieu du gros cadre carré) */
  display: block;
}
.ev-gallery-main a { display: block; width: 100%; height: auto; }
.ev-gallery-main picture { display: block; width: 100%; height: auto; }
.ev-gallery-main img { width: 100%; height: auto; object-fit: contain; display: block; border-radius: 4px; }
.ev-thumbs { margin-top: 14px; }
.ev-thumbs #thumbs_list { width: auto; overflow: visible; }
.ev-thumbs #thumbs_list_frame {
  display: flex; gap: 12px; padding: 0; margin: 0; list-style: none; flex-wrap: wrap; width: auto !important;
}
.ev-thumbs #thumbs_list_frame li {
  float: none !important; width: 78px; height: 78px; margin: 0 !important;
  border: 2px solid var(--line); border-radius: var(--radius-sm); overflow: hidden; cursor: pointer;
  transition: border-color .15s;
}
.ev-thumbs #thumbs_list_frame li.active, .ev-thumbs #thumbs_list_frame li:hover { border-color: var(--clay); }
.ev-thumbs #thumbs_list_frame li a { display: block; width: 100%; height: 100%; }
.ev-thumbs #thumbs_list_frame img { width: 100%; height: 100%; object-fit: cover; }

/* Colonne infos */
.ev-pinfo .ev-ref { text-transform: uppercase; letter-spacing: .08em; font-size: 12.16px; color: var(--muted); margin-bottom: 8px; }
.ev-pinfo h1 { font-size: 33.6px; line-height: 1.15; margin: 0 0 12px; border: 0; padding: 0; }
.ev-stars { color: var(--clay); font-size: 15.2px; margin-bottom: 18px; }

/* Note livraison (description courte) */
.ev-note {
  background: var(--sand); border-left: 3px solid var(--rose);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 14px 18px; font-size: 14.4px; color: #6b6258; margin-bottom: 22px;
}
.ev-note p { margin: 0 0 6px; } .ev-note p:last-child { margin: 0; }

/* Prix */
.ev-price-block { display: flex; align-items: baseline; gap: 14px; margin-bottom: 6px; flex-wrap: wrap; }
.ev-price-block .our_price_display { margin: 0; display: flex; align-items: baseline; gap: 10px; }
.ev-price-now, #our_price_display {
  font-family: var(--serif) !important; font-size: 40px !important;
  font-weight: 600 !important; color: var(--price) !important; line-height: 1.1;
}
.ev-price-ttc { color: var(--muted); font-size: 13.6px; font-family: var(--sans); font-weight: 400; }
#old_price { margin: 0; }
#old_price .price { color: var(--muted) !important; text-decoration: line-through; font-size: 17.6px !important; font-family: var(--sans) !important; }
#old_price.hidden { display: none; }
#reduction_percent, #reduction_amount {
  background: var(--price); color: #fff; border-radius: 50px; padding: 2px 10px;
  font-size: 12.8px; font-weight: 700; margin: 0; align-self: center;
}
.ev-installments { color: var(--muted); font-size: 14.4px; margin: 0 0 22px; }
.ev-installments b { color: var(--ink); }

/* Disponibilité */
.ev-stock-line { margin: 0 0 22px; }
.ev-stock { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; font-size: 14.4px; }
.ev-stock .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--ok); flex-shrink: 0; }
.ev-stock-ok, .ev-stock-ok .label { color: var(--ok) !important; }
.ev-stock-later, .ev-stock-later .label { color: #a8842b !important; }
.ev-stock-later .dot { background: #a8842b; }
.ev-stock-out, .ev-stock-out .label { color: #a04b3a !important; }
.ev-stock-out .dot { background: #a04b3a; }
.ev-stock .label { background: transparent !important; padding: 0 !important; font-size: 14.4px !important; border-radius: 0 !important; font-weight: 600; }
#last_quantities { background: var(--rose) !important; color: var(--ink) !important; border-radius: 50px !important; padding: 3px 11px !important; font-size: 12.48px !important; margin-left: 10px; }

/* Déclinaisons */
.ev-attributes { margin-bottom: 18px; }
.ev-attributes .attribute_fieldset { border: 0; padding: 0; margin: 0 0 12px; }
.ev-attributes .attribute_label { font-weight: 600; font-size: 14.08px; display: block; margin-bottom: 6px; }
.ev-attributes select.attribute_select {
  height: 46px; border: 1.5px solid var(--line-2); border-radius: var(--radius-sm);
  background: #fff; padding: 0 14px; font-family: var(--sans); color: var(--ink); max-width: 320px;
}
.ev-attributes select.attribute_select:focus { border-color: var(--clay); outline: none; box-shadow: none; }

/* Rangée quantité + ajout panier */
.ev-buy-row { display: flex; gap: 14px; align-items: stretch; margin-bottom: 10px; flex-wrap: wrap; }
.ev-qty {
  display: inline-flex; align-items: center;
  border: 1.5px solid var(--line-2); border-radius: 50px; overflow: hidden; background: #fff;
  height: 56px;
}
.ev-qty a.button-minus, .ev-qty a.button-plus {
  width: 44px; height: 100%; display: flex; align-items: center; justify-content: center;
  background: var(--sand); color: var(--ink); font-size: 20px; text-decoration: none;
  user-select: none;
}
.ev-qty a.button-minus:hover, .ev-qty a.button-plus:hover { background: var(--line); color: var(--ink); }
.ev-qty input#quantity_wanted {
  width: 52px; height: 100%; text-align: center; border: 0; font-size: 16px;
  font-family: var(--sans); background: #fff; color: var(--ink); outline: none;
  -moz-appearance: textfield; appearance: textfield;
}
.ev-qty input::-webkit-outer-spin-button, .ev-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
#minimal_quantity_label { font-size: 12.8px; color: var(--muted); align-self: center; }
#minimal_quantity_label.hidden { display: none; }
.ev-buy-row .box-cart-bottom { flex: 1; min-width: 230px; }
.ev-buy-row .box-cart-bottom.unvisible { display: none; }
#add_to_cart { margin: 0; height: 100%; }
.ev-btn-cart, #add_to_cart button.exclusive {
  width: 100%; height: 56px;
  background: var(--clay) !important; color: #fff !important;
  border: 0 !important; border-radius: 50px !important;
  font-family: var(--sans) !important; font-weight: 600 !important; font-size: 16.8px !important;
  cursor: pointer; letter-spacing: .01em;
  transition: background .15s, transform .12s, box-shadow .15s;
}
.ev-btn-cart:hover, #add_to_cart button.exclusive:hover {
  background: var(--clay-dark) !important; transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(168,105,75,.28);
}
.ev-product-actions { margin-bottom: 14px; }

/* Réassurance 2×2 */
.ev-reassure {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  border-top: 1px solid var(--line); padding-top: 22px; margin-top: 22px;
}
.ev-reassure .r { display: flex; gap: 11px; align-items: center; font-size: 13.76px; }
.ev-reassure .ico { font-size: 20.8px; color: var(--clay); line-height: 1; }
.ev-reassure a { color: var(--ink); font-weight: 600; }
.ev-reassure a:hover { color: var(--clay); }

/* ---------- Onglets ---------- */
.ev-tabs { margin-top: 56px; }
.ev-tab-heads.nav-tabs { display: flex; gap: 8px; border-bottom: 1px solid var(--line) !important; margin: 0; }
.ev-tab-heads.nav-tabs > li { float: none; margin-bottom: -1px; }
.ev-tab-heads.nav-tabs > li > a {
  font-family: var(--serif) !important; font-weight: 600; font-size: 16px;
  padding: 14px 22px; color: var(--muted) !important;
  background: transparent !important; border: 0 !important;
  border-bottom: 2px solid transparent !important; border-radius: 0; margin: 0;
}
.ev-tab-heads.nav-tabs > li > a:hover { color: var(--ink) !important; }
.ev-tab-heads.nav-tabs > li.active > a {
  color: var(--ink) !important; border-bottom: 2px solid var(--clay) !important;
  background: transparent !important;
}
.ev-tab-body { padding: 28px 2px; max-width: 860px; color: #564f47; background: transparent; border: 0; }
.ev-tab-body p { margin: 0 0 14px; }

/* Tableau caractéristiques */
.ev-datasheet { width: 100%; max-width: 640px; border-collapse: collapse; }
.ev-datasheet td { padding: 11px 16px; border: 1px solid var(--line); font-size: 14.72px; }
.ev-datasheet tr:nth-child(odd) td { background: var(--sand); }
.ev-datasheet td:first-child { font-weight: 600; width: 40%; }

/* ---------- Neutralisation du HTML legacy stocké en base ----------
   (bandeaux bleus .pageTitle, photos stock homme/femme, tampon MIF,
   encart transport bannat.jpg — cf. PLAN-REFONTE-2026.md §7.3) */
.product-description .blockImg,
.product-description .blockImghm,
.product-description img[src*="homme.png"],
.product-description img[src*="femme.png"],
.product-description img[src*="bannat"] { display: none !important; }
.product-description .imgmif img, .product-description .imgmif { max-width: 180px; margin: 10px auto; }
.product-description .pageTitle, .product-description .pagetitle,
.product-description [class*="pageTitle"] {
  background: transparent !important; color: var(--ink) !important;
  font-family: var(--serif) !important; font-size: 20.8px !important; font-weight: 600 !important;
  border: 0 !important; border-bottom: 2px solid var(--clay) !important; border-radius: 0 !important;
  padding: 0 0 8px !important; margin: 26px 0 14px !important; text-align: left !important;
  text-transform: none !important; letter-spacing: 0 !important; box-shadow: none !important;
}
.product-description .blockDeco, .product-description .inner, .product-description .row {
  background: transparent !important; border: 0 !important; padding: 0 !important; margin: 0 0 10px !important;
  width: auto !important; float: none !important;
}
.product-description [class*="col-"] { width: auto !important; float: none !important; padding: 0 !important; }
.product-description .title { font-weight: 700; color: var(--ink); }
.product-description .job { color: var(--muted); font-style: italic; font-size: 14.08px; }
.product-description [style*="background"] { background: transparent !important; color: inherit !important; }
.product-description h2, .product-description h3 {
  font-family: var(--serif) !important; color: var(--ink) !important; font-size: 20.8px !important;
  background: transparent !important; text-align: left !important; margin: 26px 0 12px;
}
.product-description img { max-width: 100%; height: auto; border-radius: var(--radius-sm); }
.product-description iframe { max-width: 100%; }

/* ============================================================
   6. CROSS-SELL « Vous aimerez aussi » + cartes produit
   ============================================================ */
.ev-crosssell { padding: 56px 0 10px; }
.ev-crosssell h2 { font-size: 25.6px; margin: 0 0 28px; }
.ev-products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.ev-product-card {
  background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; transition: box-shadow .2s, transform .2s, border-color .2s;
  display: flex; flex-direction: column;
}
.ev-product-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); border-color: var(--line-2); }
.ev-product-thumb { display: block; aspect-ratio: 1; background: var(--sand); overflow: hidden; }
.ev-product-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ev-product-body { padding: 16px 18px 18px; display: flex; flex-direction: column; flex: 1; }
.ev-product-body h3 { font-size: 16.32px !important; margin: 0 0 10px; line-height: 1.35; }
.ev-product-body h3 a { color: var(--ink); }
.ev-product-body h3 a:hover { color: var(--clay); }
.ev-price-row { margin-top: auto; display: flex; align-items: baseline; gap: 10px; }
.ev-card-price { font-family: var(--serif); font-size: 23.2px; font-weight: 600; color: var(--price); }

/* ============================================================
   7. PIED DE PAGE — 4 colonnes + bandeau bas
   ============================================================ */
#footer { background: var(--bar) !important; color: #cfc6ba !important; padding: 56px 0 0; border: 0; }
#footer a { color: #cfc6ba !important; }
#footer a:hover { color: #fff !important; }
.ev-footer-cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.3fr; gap: 36px; padding-bottom: 40px; }
#footer h4 { color: #fff !important; font-size: 16.8px; margin: 0 0 16px; }
#footer ul { list-style: none; padding: 0; margin: 0; border: 0 !important; }
#footer li { padding: 5px 0; font-size: 14.4px; border: 0 !important; }
.ev-footer-brand p { font-size: 14.4px; line-height: 1.7; opacity: .85; }
.ev-pay { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.ev-pay span { background: rgba(255,255,255,.1); border-radius: 5px; padding: 4px 9px; font-size: 11.52px; font-weight: 600; }
.ev-newsletter-input {
  width: 100%; height: 44px; border-radius: 50px; border: 0; padding: 0 18px;
  margin-bottom: 10px; font-family: var(--sans); font-size: 14.4px; color: var(--ink);
}
.ev-newsletter-msg { font-size: 13.12px; margin: 0 0 8px; }
.ev-newsletter-msg.error { color: #e8b4a4; }
.ev-newsletter-msg.ok { color: #b5cba8; }
.ev-footer-contact { margin-top: 14px; font-size: 14.08px; }
.ev-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.12); padding: 18px 0; font-size: 13.12px;
  background: transparent !important; color: #a89e90 !important;
}
.ev-footer-bottom .ev-container { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.ev-footer-bottom a { color: var(--rose) !important; }

/* ============================================================
   8. PAGES LEGACY (catégorie, listing, panier, compte…)
   ============================================================ */
.product_list .product-container, #product_list .product-container, .product-container {
  background: var(--cream) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius) !important;
  overflow: hidden;
  transition: box-shadow .2s, transform .2s, border-color .2s;
}
.product-container:hover { box-shadow: var(--shadow) !important; transform: translateY(-3px); border-color: var(--line-2) !important; }
.product-image-container { border: 0 !important; background: var(--sand); }
.product-name, .product-name a, .product_list .product-name {
  font-family: var(--serif) !important; color: var(--ink) !important;
  font-size: 15px !important; font-weight: 600 !important;
}
.product-name a:hover { color: var(--clay) !important; }
.product-desc, .product-list-reviews { color: var(--muted) !important; }
.content_price .price, .price, .product-price, span.price {
  font-family: var(--serif) !important; color: var(--price) !important; font-weight: 600 !important;
}
.old-price, .product-price-old { color: var(--muted) !important; }
.product-label-container .label, .new-box .new-label, .sale-box .sale-label, .discount {
  background: var(--clay) !important; color: #fff !important;
  border-radius: 50px !important; font-weight: 700; letter-spacing: .02em;
}
.availability .label-success, .available-now { color: var(--ok) !important; }

/* Bandeaux de titres des modules (ex-bleu acier) */
.title_block, h4.title_block, .block .title_block, section.block > h4,
#home-page-tabs .title_block, .category-block .title_block, .featured-products .title_block {
  background: transparent !important;
  color: var(--ink) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--line) !important;
  border-radius: 0 !important;
  padding: 4px 2px 14px !important;
  margin-bottom: 22px !important;
  font-family: var(--serif) !important;
  font-size: 24.8px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  text-align: left;
  box-shadow: none !important;
}
.title_block a, h4.title_block a { color: var(--ink) !important; }

/* Étiquettes de disponibilité legacy (hors fiche produit ev-) */
.availability .label, .availability span.label, span.available-now, .content_price .availability span {
  background: var(--ok) !important; color: #fff !important; border: 0 !important;
  border-radius: 50px !important; font-weight: 600; padding: 3px 11px !important;
}

/* Badges produit legacy */
.product-label { border-radius: 50px !important; border: 0 !important; font-weight: 700 !important; letter-spacing: .02em; text-transform: none; }
.product-label-online { background: var(--clay-dark) !important; color: #fff !important; }
.product-label-sale, .price-percent-reduction, .reduction, .discount-percentage, .price-percent-reduction.small {
  background: var(--price) !important; color: #fff !important; border-radius: 50px !important; border: 0 !important;
}
.product-label-new { background: var(--rose) !important; color: var(--ink) !important; }
.badge-sale, .badge.badge-sale, .badge-free-shipping, span.badge {
  background: var(--ok) !important; color: #fff !important; border: 0 !important;
  border-radius: 50px !important; font-weight: 700; letter-spacing: .02em;
}

/* Divers */
.alert-success { background: #eef3ea !important; border-color: #cfe0c5 !important; color: #3f5536 !important; }
.alert { border-radius: var(--radius-sm); }
hr { border-color: var(--line); }
.pagination > li > a, .pagination > li > span { color: var(--ink); }
.pagination > .active > a, .pagination > .active > span { background: var(--clay) !important; border-color: var(--clay) !important; }

/* Popup « produit ajouté au panier » (layer_cart) */
#layer_cart { border-radius: var(--radius) !important; border: 1px solid var(--line) !important; box-shadow: var(--shadow) !important; }
#layer_cart .layer_cart_product .title, #layer_cart .layer_cart_cart .title { font-family: var(--serif) !important; color: var(--ink) !important; }
#layer_cart .crossseling-content h2 { font-family: var(--serif) !important; }

/* ============================================================
   9. PAGE D'ACCUEIL SUR-MESURE (sections ev-*)
   ============================================================ */
.columns-container { overflow-x: hidden; }
body.index #columns { padding-top: 0 !important; padding-bottom: 0 !important; }
body.index #center_column { padding-bottom: 0; }
#homepage-slider, #homeslider, #home-slider, .homeslider-container { display: none !important; }

.ev-section { padding: 60px 0; }
.ev-hero, .ev-trust, .ev-editorial, .ev-quote {
  position: relative; left: 50%; right: 50%;
  width: 100vw; margin-left: -50vw; margin-right: -50vw;
}
.ev-eyebrow { font-family: var(--sans); text-transform: uppercase; letter-spacing: .2em; font-size: 12.16px; font-weight: 700; color: var(--rose); margin-bottom: 12px; }
.ev-eyebrow-c { color: var(--clay); }
.ev-head { text-align: center; max-width: 620px; margin: 0 auto 40px; }
.ev-head h2 { font-family: var(--serif); font-size: 30.4px; margin: 0 0 .35em; }
.ev-head p { color: var(--muted); margin: 0; }

.ev-hero-media { height: 470px; background-size: cover; background-position: center; position: relative; }
.ev-hero-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(40,36,31,.7) 0%, rgba(40,36,31,.25) 55%, rgba(40,36,31,.05) 100%); }
.ev-hero-inner { position: absolute; inset: 0; display: flex; align-items: center; }
.ev-hero-inner .ev-container { width: 100%; }
.ev-hero-content { max-width: 545px; color: #fff; position: relative; z-index: 2; }
.ev-hero-content .ev-eyebrow { color: var(--rose); }
.ev-hero-content h1 { font-family: var(--serif); color: #fff; font-size: 48px; line-height: 1.1; margin: 0 0 18px; }
.ev-hero-content p { font-size: 17.92px; color: #f1e9df; margin: 0 0 26px; max-width: 440px; }
.ev-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; }
.ev-btn-light { background: #fff !important; color: var(--ink) !important; border-color: #fff !important; }
.ev-btn-light:hover { background: #f3ece2 !important; color: var(--ink) !important; }

.ev-trust { background: var(--cream); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.ev-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding-top: 22px; padding-bottom: 22px; }
.ev-trust-item { display: flex; align-items: center; gap: 13px; padding: 4px 10px; }
.ev-trust-item .ev-ico { font-size: 24.8px; color: var(--clay); line-height: 1; }
.ev-trust-item .ev-t { font-weight: 600; font-size: 14.4px; }
.ev-trust-item .ev-s { color: var(--muted); font-size: 12.8px; }

.ev-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.ev-cat { position: relative; display: block; border-radius: var(--radius); overflow: hidden; aspect-ratio: 3/4; box-shadow: var(--shadow-sm); }
.ev-cat .ev-ph { width: 100%; height: 100%; background-size: cover; background-position: center; transition: transform .45s; }
.ev-cat:hover .ev-ph { transform: scale(1.05); }
.ev-cat-label { position: absolute; left: 0; right: 0; bottom: 0; padding: 24px 18px 18px; background: linear-gradient(transparent, rgba(40,36,31,.82)); }
.ev-cat-label h3 { font-family: var(--serif); color: #fff !important; margin: 0; font-size: 19.2px; }
.ev-cat-label span { font-size: 13.12px; color: #e9d9cf; }

.ev-editorial { background: var(--cream); }
.ev-editorial-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; padding-top: 64px; padding-bottom: 64px; }
.ev-editorial-img { aspect-ratio: 4/3; border-radius: var(--radius); background-size: cover; background-position: center; box-shadow: var(--shadow); }
.ev-editorial-text h2 { font-family: var(--serif); font-size: 30.4px; margin: 0 0 .4em; }
.ev-editorial-text p { color: #564f47; }
.ev-checklist { list-style: none; padding: 0; margin: 22px 0 28px; }
.ev-checklist li { padding: 7px 0 7px 30px; position: relative; }
.ev-checklist li::before { content: "✓"; position: absolute; left: 0; color: var(--clay); font-weight: 700; }

.ev-quote { background: var(--sand); text-align: center; padding-top: 58px; padding-bottom: 58px; }
.ev-quote blockquote { font-family: var(--serif); font-style: italic; font-size: 27.2px; line-height: 1.5; max-width: 760px; margin: 0 auto 18px; color: var(--ink); border: 0; padding: 0; }
.ev-who { color: var(--muted); font-weight: 600; }

/* ============================================================
   10. BANDEAU COOKIES (eucookieconsent — couleurs aussi en BDD)
   ============================================================ */
#eu-cookie-consent, .eupopup-container, #cookieNotification, .cookie-notification, #lgcookieslaw_banner {
  background: var(--bar) !important; color: #e9e1d5 !important;
  border-top: 2px solid var(--clay) !important; font-size: 13.44px;
}
#eu-cookie-consent a.btn, .eupopup-button, #cookieNotification a.btn, #lgcookieslaw_accept {
  background: var(--clay) !important; color: #fff !important; border: 0 !important; border-radius: 50px !important;
}

/* ============================================================
   10bis. CORRECTIFS POST-RECETTE (2026-06-11)
   ============================================================ */
/* Note livraison : le HTML en base contient étoile bleue + 19 drapeaux
   + tableau tarifs → on ne garde que le texte et un tableau discret */
.ev-note img { display: none !important; }
.ev-note table { width: 100%; border-collapse: collapse; margin: 10px 0 0; font-size: 12.8px; }
.ev-note table td { border: 1px solid var(--line-2); padding: 4px 10px; background: #fff; color: #6b6258; }
.ev-note p { text-align: left !important; }

/* Bloc displayProductButtons : logos paiement cassés + partage social
   absents de la maquette */
.ev-product-actions { display: none !important; }

/* Titres de la description legacy : neutralise la couleur/centrage hérités */
.ev-tab-body .product-description h1,
.ev-tab-body .product-description h2,
.ev-tab-body .product-description h3,
.ev-tab-body .product-description h4 {
  color: var(--ink) !important;
  font-family: var(--serif) !important;
  font-size: 20.8px !important;
  text-align: left !important;
  text-decoration: none !important;
  background: transparent !important;
  border: 0 !important;
  margin: 26px 0 12px !important;
  padding: 0 !important;
}
.ev-tab-body .product-description h1 span,
.ev-tab-body .product-description h2 span,
.ev-tab-body .product-description h3 span,
.ev-tab-body .product-description h2 strong,
.ev-tab-body .product-description h3 strong { color: var(--ink) !important; }
.ev-tab-body .product-description [style*="color"] { color: inherit !important; }
.ev-tab-body .product-description table { max-width: 100%; }

/* Bandeau cookies (lib cookieconsent : .cc-window) */
.cc-window, .cc-banner {
  background: var(--bar) !important; color: #e9e1d5 !important;
  border-top: 2px solid var(--clay) !important;
  font-family: var(--sans) !important; font-size: 13.44px !important;
}
.cc-window .cc-message { color: #e9e1d5 !important; }
.cc-btn, .cc-window .cc-btn, .cc-compliance .cc-btn {
  background: var(--clay) !important; color: #fff !important;
  border: 0 !important; border-radius: 50px !important; font-weight: 600;
}
.cc-btn:hover { background: var(--clay-dark) !important; }
.cc-link, .cc-window a { color: var(--rose) !important; }

/* ============================================================
   11. RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .ev-product-grid { grid-template-columns: 1fr; gap: 30px; }
  .ev-products { grid-template-columns: repeat(2, 1fr); }
  .ev-footer-cols { grid-template-columns: 1fr 1fr; }
  .ev-trust-grid, .ev-cats { grid-template-columns: repeat(2, 1fr); }
  .ev-editorial-grid { grid-template-columns: 1fr; gap: 28px; }
  .ev-hero-content h1 { font-size: 36.8px; }
  .ev-hero-media { height: 420px; }
}
@media (max-width: 620px) {
  .ev-header { flex-wrap: wrap; gap: 14px; }
  .ev-search { order: 3; max-width: 100%; flex-basis: 100%; }
  #shop-logo img { height: 58px; }
  .ev-nav .ev-container { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .ev-nav a { white-space: nowrap; padding: 14px 14px; }
  .ev-nav a::after { left: 14px; right: 14px; }
  .ev-pinfo h1 { font-size: 27.2px; }
  .ev-price-now, #our_price_display { font-size: 32px !important; }
  .ev-buy-row { flex-direction: column; align-items: stretch; }
  .ev-qty { justify-content: center; }
  .ev-reassure { grid-template-columns: 1fr; }
  .ev-products, .ev-footer-cols, .ev-cats, .ev-trust-grid { grid-template-columns: 1fr; }
  .ev-footer-bottom .ev-container { flex-direction: column; text-align: center; }
  .ev-hero-content h1 { font-size: 30.4px; }
  .ev-quote blockquote { font-size: 20.8px; }
  .ev-tab-heads.nav-tabs { overflow-x: auto; }
}

/* Partage social (HOOK_EXTRA_RIGHT) : absent de la maquette */
.ev-pinfo .socialsharing_product { display: none !important; }

/* Popup RGPD (gdprcompliancy) aux couleurs du thème */
.gdprcompliancy .gdprcompliancy-header, #modal-pop .gdprcompliancy-header {
  background: var(--bar) !important; color: #e9e1d5 !important;
  font-family: var(--sans) !important; border: 0 !important;
}
#modal-pop.gdpr-content, #modal-pop { border-radius: var(--radius) !important; overflow: hidden; }
.gdprcompliancy .btn-info { background: var(--clay) !important; color: #fff !important; border: 0 !important; border-radius: 50px !important; font-weight: 600; }
.gdprcompliancy .btn-info:hover { background: var(--clay-dark) !important; }
.gdprcompliancy .btn-warning { background: transparent !important; color: var(--ink) !important; border: 1.5px solid var(--line-2) !important; border-radius: 50px !important; }
.gdprcompliancy .btn-warning:hover { border-color: var(--clay) !important; color: var(--clay) !important; }

/* L'ancien thème applique un text-shadow bleuté sur les titres → suppression */
h1, h2, h3, h4, h5, h6, .page-heading, .product-name,
.ev-tab-body .product-description h1, .ev-tab-body .product-description h2,
.ev-tab-body .product-description h3, .ev-tab-body .product-description strong {
  text-shadow: none !important;
}

/* Sous-titres « métier » des encarts legacy (orange hors palette → taupe) */
.product-description .job, .product-description .job *,
.product-description .title em, .product-description em[style] {
  color: var(--muted) !important; font-style: italic;
}

/* Pages catégorie : bandeaux bleu acier hérités → titres sobres maquette */
.page-heading, h1.page-heading, h2.page-heading, .page-heading.product-listing {
  background: transparent !important;
  color: var(--ink) !important;
  border: 0 !important;
  border-bottom: 2px solid var(--line) !important;
  border-radius: 0 !important;
  padding: 4px 0 10px !important;
  text-shadow: none !important;
}
.page-heading .heading-counter { float: right; background: var(--ok) !important; border-radius: 50px !important; font-size: 12px; }
li.ajax_block_product { border: 0 !important; background: transparent !important; box-shadow: none !important; }
#subcategories { border: 0 !important; }
#subcategories .subcategory-name { font-family: var(--serif) !important; color: var(--clay) !important; }

/* Header : alignement vertical de la pilule panier (global.css impose
   margin-top:30px sur .shopping_cart) + caret FontAwesome hérité */
#blockcart.shopping_cart, .ev-header-actions .shopping_cart {
  margin: 0 !important; padding: 0 !important; display: flex; align-items: center;
}
#blockcart-header::after, #blockcart-header::before,
.shopping_cart > a::after, .shopping_cart > a::before {
  content: none !important; display: none !important;
}
/* Loupe du bouton recherche : glyphe plus grand et parfaitement centré */
.ev-search button {
  font-size: 19px !important; line-height: 1 !important;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--sans) !important;
}

/* ============================================================
   ACCESSIBILITÉ — contrastes WCAG AA (audit PageSpeed 2026-06-11)
   ============================================================ */
/* Lien promo de la nav : terracotta clair (4,4:1) → foncé (6,2:1) */
.ev-nav .ev-nav-promo { color: var(--clay-dark); }
/* Bouton « J'accepte » du bandeau cookies : petit texte → fond foncé */
.cc-btn, .cc-window .cc-btn, .cc-compliance .cc-btn { background: var(--clay-dark) !important; }
.cc-btn:hover { background: var(--clay) !important; }
/* Liens texte dans les contenus (onglets, notes) : ratio ≥ 4,5:1 */
.ev-tab-body a, .ev-note a, .breadcrumb a { color: var(--clay-dark); }

/* ============================================================
   12. ACCUEIL — cartes produits vedettes & boutons autonomes
   ============================================================ */
.ev-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 26px; font-size: 15.2px; cursor: pointer; text-decoration: none;
  line-height: 1.2;
}
.ev-btn-lg { padding: 16px 34px; font-size: 16.8px; }
.ev-btn-block { display: flex; width: 100%; }
.ev-btn-ghost {
  background: transparent !important; color: var(--ink) !important;
  border: 1.5px solid var(--line-2) !important;
}
.ev-btn-ghost:hover { border-color: var(--clay) !important; color: var(--clay-dark) !important; transform: none; box-shadow: none; }
.ev-more { text-align: center; margin-top: 40px; }

.ev-product-thumb-wrap { position: relative; }
.ev-badge {
  position: absolute; top: 12px; left: 12px; z-index: 2;
  background: var(--clay); color: #fff; font-size: 11.5px; font-weight: 700;
  padding: 4px 11px; border-radius: 50px; letter-spacing: .02em;
}
.ev-badge-soft { background: var(--rose); color: var(--ink); }
.ev-card-ref { font-size: 11.5px; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 6px; }
.ev-card-price-old { color: var(--muted); text-decoration: line-through; font-size: 15.2px; }
.ev-product-body .ev-btn { margin-top: 14px; }
.ev-home-products .ev-product-card h3 { min-height: 44px; }
.ev-footer-newsintro { font-size: 14px; opacity: .85; margin: -6px 0 12px; }

/* Sécurité : aucun effet de survol hérité sur les cartes et tuiles accueil */
.ev-product-card:hover img, .ev-cat:hover { filter: none !important; }
.ev-product-card a:hover img { opacity: 1 !important; }

/* ============================================================
   13. PAGE CATÉGORIE / LISTINGS (maquette categorie.html)
   ============================================================ */
body#category #columns, body#best-sales #columns, body#new-products #columns,
body#prices-drop #columns, body#search #columns, body#manufacturer #columns { padding-top: 0; }

/* Bande d'en-tête de catégorie, pleine largeur */
.ev-cathead {
  background: var(--cream); border-bottom: 1px solid var(--line);
  padding: 34px 0 30px;
  position: relative; left: 50%; right: 50%;
  width: 100vw; margin-left: -50vw; margin-right: -50vw;
}
.ev-cathead-row { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; }
.ev-cathead-row h1 { margin: 0; font-size: 35px; border: 0; padding: 0; }
.ev-cathead-count { color: var(--muted); font-size: 14.5px; font-weight: 600; }
.ev-cathead-intro { color: #6b6258; max-width: 720px; margin: 10px 0 0; font-size: 15.2px; }

/* Sous-catégories en pilules */
.ev-subcats { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }
.ev-subcat {
  display: inline-flex; align-items: center; gap: 10px;
  border: 1.5px solid var(--line-2); border-radius: 50px;
  padding: 10px 20px; background: var(--sand);
  font-weight: 600; font-size: 14.7px; color: var(--ink);
  transition: border-color .15s, color .15s; text-decoration: none;
}
.ev-subcat:hover { border-color: var(--clay); color: var(--clay-dark); }

/* Corps : barre d'outils + grille */
.ev-catbody { padding: 34px 0 26px; }
.ev-cattoolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 26px; }
.ev-catresults { color: var(--muted); font-size: 14.5px; }
.ev-catresults b { color: var(--ink); }
.ev-catsort .productsSortForm { margin: 0; display: flex; align-items: center; gap: 10px; float: none !important; width: auto !important; }
.ev-catsort label { color: var(--muted); font-size: 14.5px; font-weight: 400; margin: 0; }
.ev-catsort select.selectProductSort {
  height: 42px; border: 1.5px solid var(--line-2); border-radius: 50px;
  background: #fff; padding: 0 16px; font-family: var(--sans); font-size: 14.5px;
  color: var(--ink); outline: none; cursor: pointer; width: auto; box-shadow: none;
}
.ev-catsort select.selectProductSort:focus { border-color: var(--clay); }

/* La grille listing hérite de .ev-products (4 colonnes) */
.ev-listing { margin-top: 0; }

/* Pagination en pastilles */
.ev-catpagination { margin-top: 40px; }
.ev-catpagination .pagination { display: flex; justify-content: center; gap: 8px; margin: 0; flex-wrap: wrap; }
.ev-catpagination .pagination > li { display: inline-flex; }
.ev-catpagination .pagination > li > a, .ev-catpagination .pagination > li > span {
  min-width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--line-2) !important; border-radius: 50px !important; padding: 0 12px;
  color: var(--ink) !important; font-weight: 600; font-size: 14.7px; background: #fff !important;
  margin: 0; transition: border-color .15s, color .15s;
}
.ev-catpagination .pagination > li > a:hover { border-color: var(--clay) !important; color: var(--clay-dark) !important; }
.ev-catpagination .pagination > li.active > a, .ev-catpagination .pagination > li.active > span,
.ev-catpagination .pagination > li.current > a, .ev-catpagination .pagination > li.current > span {
  background: var(--clay) !important; border-color: var(--clay) !important; color: #fff !important;
}
.ev-catpagination .pagination > li.disabled > a, .ev-catpagination .pagination > li.disabled > span { opacity: .4; pointer-events: none; }
/* éléments parasites de l'ancienne barre (compteur produits / page, "afficher tout") */
.ev-catpagination .compare-form, .ev-catpagination #productsNbPerPage,
.ev-catpagination .showall, .ev-catpagination .product-count { display: none !important; }

/* Texte SEO complet en bas de page */
.ev-catseo {
  background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 30px 34px; margin-top: 48px; color: #564f47; font-size: 14.7px;
}
.ev-catseo h1, .ev-catseo h2, .ev-catseo h3 { font-size: 20px !important; margin: 0 0 .6em !important; color: var(--ink) !important; text-align: left !important; background: transparent !important; border: 0 !important; }
.ev-catseo p { margin: 0 0 12px; }
.ev-catseo p:last-child { margin-bottom: 0; }
.ev-catseo img { max-width: 100%; height: auto; border-radius: var(--radius-sm); }

@media (max-width: 980px) {
  .ev-cathead-row h1 { font-size: 29px; }
  .ev-listing.ev-products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
  .ev-cattoolbar { flex-direction: column; align-items: flex-start; }
  .ev-catseo { padding: 20px; }
  .ev-listing.ev-products { grid-template-columns: 1fr; }
}

/* Sélecteur grille/liste hérité de product-sort.tpl : hors maquette */
.ev-catsort .btn-group, .ev-catsort #grid, .ev-catsort #list,
.ev-catsort label.visible-xs { display: none !important; }
.ev-catsort .productsSortForm label { display: inline-flex; }
/* Le label et le select du tri vivent dans le <form> interne */
.ev-catsort .productsSortForm form { display: flex; align-items: center; gap: 10px; }
/* L'intro de catégorie peut contenir du HTML (champ Description du BO) */
.ev-cathead-intro p { margin: 0 0 8px; }
.ev-cathead-intro p:last-child { margin-bottom: 0; }
.ev-cathead-intro h2, .ev-cathead-intro h3 { font-size: 18px !important; margin: 12px 0 6px; }
