/* ================================================================
   Ménager Plus v9.1 — Industriel Premium Sombre
   Palette : Charbon #0E0F0D · Crème #F5F0E8 · Or #E8D84C · Brique #C24B2A
   Fonts   : Barlow Condensed (titres) · Lato (corps)
   Breakpoints : sm 480 · md 768 · lg 900 · xl 1060
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ────────────────────────────────
   VARIABLES
──────────────────────────────── */
:root {
  --coal   : #F7F5F0;
  --coal-2 : #FFFFFF;
  --coal-3 : #F0EDE6;
  --coal-4 : #E8E5DE;
  --coal-5 : #D5D2CB;
  --cream  : #1C1F18;
  --cream-2: #4A4E46;
  --yellow : #E8D84C;
  --yellow-dk: #C4B530;
  --brick  : #C24B2A;
  --line   : #E0DDD6;
  --hh     : 64px;
  --tb     : 32px; /* top-bar height */
  --cw     : 1280px;
  --t      : .2s ease;
  --pad    : clamp(16px, 3vw, 24px);
  --r      : 0px;         /* border-radius (industrial theme = sharp) */
  --white  : #FFFFFF;
  --coal-1 : #1C1F18;
  --slate  : rgba(28,31,24,.68);
  --g      : var(--yellow);
}

/* ────────────────────────────────
   RESET & BASE
──────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--coal); color: var(--cream);
  line-height: 1.72; overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  padding-top: calc(var(--hh) + var(--tb));
}
a { text-decoration: none; color: inherit; transition: color var(--t); }
ul, ol { list-style: none; }
img, video { max-width: 100%; display: block; }
button, input, select, textarea { font-family: inherit; }
h1,h2,h3,h4,h5 {
  font-family: 'Inter', sans-serif;
  font-weight: 800; line-height: 1.15; letter-spacing: -0.02em;
}
.container { max-width: var(--cw); margin: 0 auto; padding: 0 var(--pad); }
.section { padding: 56px 0; overflow: visible; }

/* ────────────────────────────────
   UTILITAIRES
──────────────────────────────── */
.eyebrow {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  color: var(--yellow); border: 1px solid var(--yellow);
  padding: .25rem .8rem; margin-bottom: 1rem;
}
.eyebrow--orange, .eyebrow--brick { color: var(--brick); border-color: var(--brick); }
.section-h { font-size: clamp(1.35rem, 2.4vw, 1.75rem); text-transform: none; letter-spacing: .01em; }
.text-center { text-align: center; }
.section-head, .sec-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 1.5rem; gap: .8rem; flex-wrap: wrap;
}
.section-head .section-h, .sec-head .section-h { margin: 0; }
.hl { color: var(--yellow); }
.ht { font-size: .71rem; font-weight: 400; color: rgba(28,31,24,.65); vertical-align: super; margin-left: .12rem; }
.surface-card { background: var(--coal-2); border: 1px solid var(--line); padding: 1.5rem; }

/* Alerts */
.alert { padding: .75rem 1rem; font-size: .9rem; margin-bottom: 1rem; border-left: 3px solid; display: flex; align-items: flex-start; gap: .6rem; }
.alert i { flex-shrink: 0; margin-top: .1rem; }
.alert-success { background: rgba(232,216,76,.07); color: #d4c53a; border-color: var(--yellow); }
.alert-error   { background: rgba(194,75,42,.08);  color: #f2917b; border-color: var(--brick);  }
.alert-info    { background: rgba(28,31,24,.04); color: rgba(28,31,24,.6); border-color: var(--coal-5); }
.suc-box { background: rgba(232,216,76,.07); color: #d4c53a; border: 1px solid rgba(232,216,76,.22); padding: .65rem .9rem; font-size: .9rem; margin-bottom: .75rem; }
.err-box { background: rgba(194,75,42,.09); color: #f2917b; border: 1px solid rgba(194,75,42,.3);  padding: .65rem .9rem; font-size: .9rem; margin-bottom: .75rem; }

/* ────────────────────────────────
   BOUTONS
──────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .45rem;
  padding: .62rem 1.4rem;
  font-family: 'Inter', sans-serif;
  font-size: .9rem; font-weight: 600; letter-spacing: .01em; text-transform: uppercase;
  border: 2px solid transparent; cursor: pointer; transition: var(--t); white-space: nowrap; line-height: 1;
}
.btn-primary       { background: var(--yellow);  color: var(--coal);  border-color: var(--yellow);  }
.btn-primary:hover { background: var(--yellow-dk); border-color: var(--yellow-dk); transform: translateY(-1px); }
.btn-brick         { background: var(--brick);   color: #fff;         border-color: var(--brick);   }
.btn-brick:hover   { background: #a83e22; }
.btn-outline       { background: transparent;    color: var(--cream-2); border-color: var(--cream-2); }
.btn-outline:hover { background: var(--cream);   color: var(--coal); border-color: var(--cream); }
.btn-outline-white,
.btn-outline-yellow       { background: transparent;  color: var(--yellow); border-color: rgba(232,216,76,.55); }
.btn-outline-white:hover,
.btn-outline-yellow:hover { background: var(--yellow); color: var(--coal);  border-color: var(--yellow); }
.btn-ghost         { background: var(--coal-3);  color: var(--cream-2); border-color: var(--line);  }
.btn-ghost:hover   { background: var(--coal-4);  color: var(--cream);  }
.btn-dark          { background: var(--coal-4);  color: var(--cream);  border-color: var(--coal-5); }
.btn-dark:hover    { background: var(--coal-5);  }
.btn-sm  { padding: .38rem .9rem;   font-size: .8rem; }
.btn-lg  { padding: .78rem 1.9rem;  font-size: 1rem; }
.btn-xl  { padding: .88rem 2.2rem;  font-size: 1.03rem; }
.btn-block { width: 100%; justify-content: center; }
@media (max-width: 480px) { .btn-xl { padding: .78rem 1.5rem; font-size: .96rem; } }

/* ────────────────────────────────
   TOP BAR
──────────────────────────────── */
.top-bar {
  background: var(--coal-2); border-bottom: 1px solid var(--line);
  padding: 6px 0; font-size: .75rem; letter-spacing: .02em; color: rgba(28,31,24,.68);
  position: fixed; top: 0; left: 0; right: 0; z-index: 1001;
  height: var(--tb);
}
.top-bar-flex { display: flex; align-items: center; justify-content: space-between; }
.contact-mini { display: flex; gap: 1.2rem; align-items: center; }
.contact-mini i { color: var(--yellow); margin-right: .2rem; font-size: .7rem; }
.sep { opacity: .2; }
.lang-switch { display: flex; gap: 1px; background: var(--coal-3); }
.lang-switch a {
  padding: 3px 9px;
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .02em; text-transform: uppercase;
  color: rgba(28,31,24,.45); transition: var(--t);
}
.lang-switch a.active,
.lang-switch a:hover { color: var(--coal); background: var(--yellow); }
@media (max-width: 600px) { .contact-mini { display: none; } }

/* ────────────────────────────────
   HEADER
──────────────────────────────── */
.main-header {
  position: fixed; top: var(--tb); left: 0; right: 0; z-index: 1000;
  background: rgba(247,245,240,.97); height: var(--hh); box-shadow: 0 1px 3px rgba(28,31,24,.08);
  border-bottom: 1px solid var(--line);
}
.header-inner { height: var(--hh); display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
/* Logo */
.logo a {
  display: flex; align-items: center; gap: .58rem;
  font-family: 'Inter', sans-serif;
  font-size: 1.5rem; font-weight: 900; letter-spacing: .02em; text-transform: uppercase;
  color: var(--cream); white-space: nowrap;
}
.logo-mark {
  width: 32px; height: 32px; background: var(--yellow); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--coal); font-size: .9rem;
}
/* Nav principale */
.main-nav ul { display: flex; }
.main-nav a {
  display: block; padding: .4rem .82rem;
  font-family: 'Inter', sans-serif;
  font-size: .93rem; font-weight: 600; letter-spacing: .01em; text-transform: uppercase;
  color: rgba(28,31,24,.78); transition: var(--t); position: relative;
}
.main-nav a::after {
  content: ''; position: absolute; bottom: -1px; left: .82rem; right: .82rem;
  height: 2px; background: var(--yellow); transform: scaleX(0); transition: transform var(--t);
}
.main-nav a:hover { color: var(--cream); }
.main-nav a:hover::after, .main-nav a.active::after { transform: scaleX(1); }
.main-nav a.active { color: var(--cream); }
/* Boutons header */
.header-actions { display: flex; align-items: center; gap: .3rem; flex-shrink: 0; }
.hdr-btn {
  position: relative; width: 37px; height: 37px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream-2); font-size: .96rem; gap: 2px; transition: var(--t); flex-shrink: 0;
}
.hdr-btn .lbl { font-size: .6rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; font-family: 'Inter', sans-serif; }
.hdr-btn:hover { background: var(--yellow); color: var(--coal); border-color: var(--yellow); }
.hdr-btn .badge {
  position: absolute; top: -5px; right: -5px;
  background: var(--brick); color: #fff;
  font-size: .6rem; font-weight: 800; width: 15px; height: 15px;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--coal);
}
.hdr-cta {
  padding: .46rem .95rem;
  background: var(--yellow); color: var(--coal);
  font-family: 'Inter', sans-serif;
  font-size: .74rem; font-weight: 700; letter-spacing: .01em; text-transform: uppercase;
  display: flex; align-items: center; gap: .38rem; cursor: pointer; transition: var(--t); white-space: nowrap;
}
.hdr-cta:hover { background: var(--yellow-dk); }
.menu-toggle {
  display: none; width: 37px; height: 37px;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream); font-size: 1.03rem; align-items: center; justify-content: center; cursor: pointer;
}
@media (max-width: 1060px) {
  .main-nav { display: none; }
  .menu-toggle { display: flex; }
  .hdr-cta .cta-label { display: none; }
  .hdr-cta { padding: .46rem .72rem; }
}
@media (max-width: 480px) {
  .hdr-btn { width: 33px; height: 33px; font-size: .98rem; }
  .hdr-btn .lbl { display: none; }
  .hdr-cta { display: none; }
  .header-actions { gap: .25rem; }
  .logo a { font-size: 1.3rem; }
  .logo-mark { width: 28px; height: 28px; font-size: .9rem; }
}

/* Nav Drawer mobile */
.nav-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.6); z-index: 998; }
.nav-overlay.open { display: block; }
.nav-drawer {
  position: fixed; top: 0; right: -300px; width: 280px; max-width: 85vw; height: 100%;
  background: var(--coal-2); z-index: 999;
  display: flex; flex-direction: column;
  border-left: 1px solid var(--line);
  transition: .3s cubic-bezier(.4,0,.2,1);
}
.nav-drawer.open { right: 0; }
.nav-drawer-hd {
  padding: 1rem 1.2rem; display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--line); flex-shrink: 0;
}
.nav-drawer-close {
  width: 32px; height: 32px; background: var(--coal-3); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--cream-2); cursor: pointer; font-size: .96rem;
}
.nav-drawer-close:hover { background: var(--yellow); color: var(--coal); border-color: var(--yellow); }
.nav-drawer ul { padding: 1rem 0; flex: 1; overflow-y: auto; }
.nav-drawer ul li a {
  display: flex; align-items: center; gap: .65rem;
  padding: .62rem 1.2rem;
  font-family: 'Inter', sans-serif;
  font-size: .96rem; font-weight: 600; letter-spacing: .01em; text-transform: uppercase;
  color: rgba(28,31,24,.6); transition: var(--t);
}
.nav-drawer ul li a:hover, .nav-drawer ul li a.active {
  color: var(--yellow); background: rgba(232,216,76,.04);
  border-left: 2px solid var(--yellow); padding-left: calc(1.2rem - 2px);
}
.nav-drawer-ft { padding: 1.2rem; border-top: 1px solid var(--line); flex-shrink: 0; }

/* ────────────────────────────────
   PAGE BANNER (titre + fil d'ariane)
──────────────────────────────── */
.page-banner {
  background: var(--coal-2); border-bottom: 1px solid var(--line);
  padding: 1.8rem 0 1.6rem;
}
.page-banner h1 { font-size: clamp(1.2rem, 3vw, 1.8rem); text-transform: none; color: var(--cream); margin-top: .3rem; }
.breadcrumb {
  display: flex; align-items: center; flex-wrap: wrap; gap: .3rem;
  list-style: none;
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 500; letter-spacing: .02em; text-transform: uppercase;
  color: rgba(28,31,24,.62);
}
.breadcrumb li { display: flex; align-items: center; gap: .3rem; }
.breadcrumb li + li::before { content: '›'; color: rgba(28,31,24,.25); }
.breadcrumb a { color: rgba(28,31,24,.62); transition: color var(--t); }
.breadcrumb a:hover { color: var(--yellow); }
.breadcrumb .active, .breadcrumb li.active { color: rgba(28,31,24,.65); }

/* ────────────────────────────────
   HERO SLIDER
──────────────────────────────── */
.hero-slider {
  position: relative; height: min(75vh, 620px);
  overflow: hidden; background: var(--coal-2);
}
.hero-slides { position: absolute; inset: 0; }
.hero-slide {
  position: absolute; inset: 0; opacity: 0;
  background-size: cover; background-position: center; transition: opacity .75s ease;
}
.hero-slide::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(100deg, rgba(14,15,13,.92) 0%, rgba(14,15,13,.52) 50%, rgba(14,15,13,.2) 100%);
}
.hero-slide.active { opacity: 1; }
.hero-slider::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 90px; z-index: 5;
  background: linear-gradient(transparent, var(--coal)); pointer-events: none;
}
.hero-content {
  position: absolute; inset: 0; z-index: 10;
  display: flex; flex-direction: column; justify-content: center;
  padding: 80px var(--pad) 60px;
  width: 100%; max-width: var(--cw); margin: 0 auto; left: 50%; transform: translateX(-50%);
}
.hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--yellow); border: 1px solid var(--yellow);
  padding: .26rem .75rem; margin-bottom: 1.3rem; width: fit-content;
}
.hero-badge .dot { width: 5px; height: 5px; background: var(--yellow); border-radius: 50%; animation: heroPulse 2s infinite; }
@keyframes heroPulse { 0%,100% { opacity: 1; } 50% { opacity: .25; } }
h1#hero-h1 {
  font-size: clamp(2rem, 6vw, 4.5rem); font-weight: 900;
  text-transform: none; letter-spacing: -0.03em;
  color: var(--cream); line-height: .95; margin-bottom: .8rem;
}
h1#hero-h1 .accent { color: var(--yellow); }
.hero-sub {
  font-size: clamp(.72rem, 1.2vw, .88rem); color: rgba(28,31,24,.65);
  max-width: 480px; margin-bottom: 1.4rem; font-weight: 300;
}
.hero-btns { display: flex; gap: .7rem; flex-wrap: wrap; margin-bottom: 2.2rem; }
.hero-trust {
  display: flex; gap: 2rem; flex-wrap: wrap;
  padding-top: 1.4rem; border-top: 1px solid rgba(28,31,24,.1);
}
.htrust-item { display: flex; flex-direction: column; gap: .1rem; }
.htrust-num { font-family: 'Inter', sans-serif; font-size: 1.5rem; font-weight: 800; color: var(--yellow); }
.htrust-lbl { font-size: .75rem; color: rgba(255,255,255,.72); text-transform: uppercase; letter-spacing: .01em; }
/* Flèches */
.hero-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 20;
  width: 46px; height: 46px;
  background: rgba(247,245,240,.85); border: 1px solid var(--line);
  color: var(--cream); font-size: .9rem;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--t);
}
.hero-arrow:hover { background: var(--yellow); color: var(--coal); border-color: var(--yellow); }
.hero-arrow-prev { left: 22px; }
.hero-arrow-next { right: 22px; }
/* Dots */
.hero-dots { position: absolute; bottom: 22px; right: 32px; z-index: 20; display: flex; gap: .42rem; align-items: center; }
.hero-dot { width: 18px; height: 2px; background: rgba(28,31,24,.25); border: none; cursor: pointer; transition: var(--t); padding: 0; }
.hero-dot.active { background: var(--yellow); width: 32px; }
/* Carte produit flottante */
.hero-prod-card {
  position: absolute; right: 22px; top: 50%; transform: translateY(-50%); z-index: 20;
  background: rgba(247,245,240,.95); border: 1px solid var(--line);
  padding: .82rem 1.1rem; max-width: 220px;
  display: flex; flex-direction: column; gap: .32rem; transition: var(--t);
}
.hero-prod-card:hover { border-color: var(--yellow); }
.hpc-cond {
  font-family: 'Inter', sans-serif;
  font-size: .65rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; padding: .16rem .52rem;
}
.hpc-new  { background: var(--yellow); color: var(--coal); }
.hpc-used { background: var(--coal-4); color: var(--cream-2); border: 1px solid var(--coal-5); }
.hpc-name { font-family: 'Inter', sans-serif; font-size: .92rem; font-weight: 700; color: var(--cream); line-height: 1.25; }
.hpc-arrow { color: var(--yellow); display: flex; align-items: center; gap: .28rem; margin-top: .1rem; }
.hpc-arrow::before { content: 'BEKIJK →'; font-family: 'Inter', sans-serif; font-size: .67rem; font-weight: 700; letter-spacing: .02em; }
/* Chevron décoration */
.hero-chevron { position: absolute; bottom: -1px; left: 0; right: 0; z-index: 6; pointer-events: none; }
.hero-chevron svg { display: block; width: 100%; }
/* Responsive hero */
@media (max-width: 768px) {
  .hero-slider { height: min(65vh, 480px); }
  h1#hero-h1 { font-size: clamp(1.8rem, 8vw, 3rem); }
  .hero-prod-card, .hero-arrow { display: none; }
  .hero-content { justify-content: flex-end; padding-bottom: 65px; }
  .hero-trust { gap: 1.2rem; }
}
@media (max-width: 480px) {
  h1#hero-h1 { font-size: clamp(1.5rem, 10vw, 2.4rem); }
  .hero-sub { display: none; }
  .hero-btns .btn { font-size: .94rem; padding: .65rem 1.1rem; }
}

/* ────────────────────────────────
   SERVICES BAND
──────────────────────────────── */
.services-band { background: var(--coal-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.services-scroll { display: flex; overflow-x: auto; scrollbar-width: none; }
.services-scroll::-webkit-scrollbar { display: none; }
.svc-item {
  flex: 1 0 175px; display: flex; align-items: center; gap: .85rem;
  padding: 1.1rem 1.3rem; border-right: 1px solid var(--line); transition: background var(--t);
}
.svc-item:last-child { border-right: none; }
.svc-item:hover { background: var(--coal-3); }
.svc-icon {
  width: 36px; height: 36px; flex-shrink: 0;
  background: var(--coal-3); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--yellow); font-size: .96rem;
}
.svc-label strong {
  display: block; font-family: 'Inter', sans-serif;
  font-size: .9rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--cream);
}
.svc-label span { font-size: .71rem; color: rgba(28,31,24,.68); }

/* ────────────────────────────────
   CATÉGORIES — CARROUSEL
──────────────────────────────── */
.cats-section { background: var(--coal); }
/* ── CATEGORY CAROUSEL ── */
.cats-carousel-wrap { position: relative; padding: 0 .5rem; }
.cats-track-outer { overflow: hidden; padding: .5rem 0 .75rem; }
.cats-track { display: flex; gap: 14px; transition: transform .36s cubic-bezier(.4,0,.2,1); }
.cat-card {
  flex: 0 0 calc(100%/6 - 12px); min-width: 130px;
  display: flex; flex-direction: column; align-items: center;
  gap: .75rem; padding: 1.6rem 1rem 1.4rem;
  background: var(--coal-2); border: 1px solid var(--line);
  border-radius: 10px;
  transition: var(--t), transform .22s ease, box-shadow .22s ease;
  position: relative; overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.cat-card::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
  background: var(--yellow); transform: scaleX(0); transition: transform var(--t);
  border-radius: 0 0 10px 10px;
}
.cat-card:hover {
  border-color: var(--yellow); background: var(--coal-3);
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,.22);
}
.cat-card:hover::after { transform: scaleX(1); }
.cat-icon {
  width: 72px; height: 72px;
  background: var(--coal-3); border: 1px solid var(--line);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  transition: border-color var(--t);
}
.cat-card:hover .cat-icon { border-color: var(--yellow); }
.cat-icon img { width: 52px; height: 52px; object-fit: contain; }
.cat-icon .fas { font-size: 1.5rem; color: var(--yellow); }
.cat-name {
  font-family: 'Inter', sans-serif;
  font-size: .9rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  color: var(--cream-2); text-align: center; line-height: 1.2;
}
.cat-count {
  font-family: 'Inter', sans-serif;
  font-size: .7rem; font-weight: 700; letter-spacing: .02em;
  background: var(--yellow); color: var(--coal); padding: .12rem .52rem;
  border-radius: 20px;
}
.cats-carousel-btn {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 40px; height: 40px;
  background: var(--coal-2); border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--cream); cursor: pointer; font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
  transition: var(--t);
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
}
.cats-carousel-btn.prev { left: -20px; }
.cats-carousel-btn.next { right: -20px; }
.cats-carousel-btn:hover { background: var(--yellow); color: var(--coal); border-color: var(--yellow); transform: translateY(-50%) scale(1.08); }
@media (max-width: 768px) { .cat-card { flex: 0 0 calc(33.33% - 10px); min-width: 0; } }
@media (max-width: 480px) { .cat-card { flex: 0 0 calc(50% - 8px); min-width: 0; padding: 1.2rem .75rem 1rem; } .cat-icon { width: 58px; height: 58px; } }

/* ────────────────────────────────
   PRODUCT CARDS
──────────────────────────────── */
.products-grid, .products-grid-3 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem; background: transparent; border: none;
}
.pcard {
  position: relative; background: var(--coal-2);
  display: flex; flex-direction: column;
  transition: background var(--t), box-shadow .28s ease, transform .22s ease;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
}
.pcard:hover {
  background: var(--coal-3);
  box-shadow: 0 8px 28px rgba(0,0,0,.25);
  transform: translateY(-4px);
}
.pcard-link-overlay { position: absolute; inset: 0; z-index: 1; }

/* Image */
.pcard-img {
  position: relative; overflow: hidden;
  aspect-ratio: 4/3; background: var(--coal-3);
  border-radius: 14px 14px 0 0;
}
.pcard-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }
.pcard:hover .pcard-img img { transform: scale(1.06); }

/* Badge */
.pcard-badge {
  position: absolute; top: .85rem; left: .85rem; z-index: 2;
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  padding: .22rem .65rem; border-radius: 4px;
}
.badge-new  { background: var(--yellow); color: var(--coal); }
.badge-used { background: var(--coal-4); color: var(--cream-2); border: 1px solid var(--coal-5); }
.pcard-badge-promo { background: #e53935; color: #fff; }

/* Body */
.pcard-body { flex: 1; padding: 1.1rem 1.1rem .8rem; display: flex; flex-direction: column; gap: .4rem; }
.pcard-brand {
  font-family: 'Inter', sans-serif;
  font-size: .78rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  color: var(--yellow); margin-bottom: 0;
}
.pcard-name {
  font-family: 'Inter', sans-serif;
  font-size: 1.05rem; font-weight: 700; color: var(--cream);
  text-transform: none; line-height: 1.2;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* Spec chips */
.pcard-specs { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .1rem; }
.spec-chip {
  font-size: .66rem; font-weight: 700;
  background: var(--coal-3); border: 1px solid var(--line);
  padding: .22rem .58rem; border-radius: 20px;
  color: var(--cream-2);
  display: flex; align-items: center; gap: .3rem;
}
.spec-chip i { color: var(--yellow); font-size: .65rem; }

/* Price */
.pcard-price {
  font-family: 'Inter', sans-serif;
  font-size: 1.3rem; font-weight: 800; color: var(--cream);
  margin-top: auto; padding-top: .4rem;
}
.pcard-price .ht { font-size: .78rem; font-weight: 600; opacity: .65; }

/* Actions */
.pcard-actions {
  display: flex; border-top: 1px solid var(--line);
  position: relative; z-index: 2;
  margin-top: .2rem;
}
.pcard-actions form { position: relative; z-index: 2; flex: 1; display: flex; }
.btn-pcard {
  flex: 1; padding: .75rem .5rem;
  font-family: 'Inter', sans-serif;
  font-size: .8rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  border: none; cursor: pointer; transition: var(--t);
  display: flex; align-items: center; justify-content: center; gap: .38rem;
}
.btn-pcard-buy { background: var(--yellow); color: var(--coal); border-right: 1px solid rgba(14,15,13,.12); }
.btn-pcard-buy:hover { background: var(--yellow-dk); }
.btn-pcard-ask { background: var(--coal-3); color: var(--cream-2); border-left: 1px solid var(--line); }
.btn-pcard-ask:hover { background: var(--coal-4); color: var(--cream); }
@media (max-width: 900px) { .products-grid, .products-grid-3 { gap: 1.1rem; } }
@media (max-width: 768px) { .products-grid, .products-grid-3 { grid-template-columns: repeat(2, 1fr); gap: .85rem; } }

/* ── Mobile : cartes horizontales pleine largeur ── */
@media (max-width: 560px) {
  .products-grid.mobile-1col, .products-grid-3.mobile-1col {
    grid-template-columns: 1fr !important;
    gap: .65rem;
  }

  /* La card devient horizontale */
  .pcard {
    display: grid;
    grid-template-columns: 120px 1fr;
    grid-template-rows: 1fr auto;
    grid-template-areas:
      "img body"
      "acts acts";
    border-radius: 10px;
    overflow: hidden;
    min-height: 0;
  }
  .pcard:hover { transform: none; }

  /* Image */
  .pcard-img {
    grid-area: img;
    aspect-ratio: unset !important;
    height: 100%;
    min-height: 115px;
    border-right: 1px solid var(--line);
    border-radius: 10px 0 0 0;
  }
  .pcard-img img { width: 100%; height: 100%; object-fit: cover; }

  .pcard-badge { top: .5rem; left: .5rem; font-size: .63rem; padding: .14rem .42rem; }

  /* Corps */
  .pcard-body {
    grid-area: body;
    padding: .8rem .85rem .55rem;
    display: flex; flex-direction: column; justify-content: center;
    gap: .28rem; min-width: 0;
  }
  .pcard-brand { font-size: .7rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .pcard-name { font-size: 1rem; margin-bottom: 0; line-height: 1.1; -webkit-line-clamp: 2; }
  .pcard-specs { gap: .22rem; flex-wrap: nowrap; overflow: hidden; margin-top: 0; }
  .spec-chip { font-size: .7rem; padding: .12rem .38rem; white-space: nowrap; }
  .pcard-price { font-size: 1.15rem; padding-top: .2rem; }
  .pcard-price .ht { font-size: .71rem; }

  /* Actions */
  .pcard-actions { grid-area: acts; border-top: 1px solid var(--line); }
  .pcard-actions form { flex: 1; display: flex; position: relative; z-index: 2; }
  .btn-pcard { flex: 1; font-size: .64rem; padding: .6rem .3rem; letter-spacing: .01em; }
  .btn-pcard i { display: inline !important; font-size: .7rem; }
}

/* ────────────────────────────────
   SHOP PAGE
──────────────────────────────── */
.btn-filter-mobile {
  display: none; width: 100%; margin: 1rem 0 0;
  padding: .68rem 1rem;
  background: var(--coal-2); border: 1px solid var(--line);
  color: var(--cream);
  font-family: 'Inter', sans-serif;
  font-size: .9rem; font-weight: 700; letter-spacing: .01em; text-transform: uppercase;
  cursor: pointer; text-align: left; align-items: center; gap: .7rem;
}
.filter-count { background: var(--yellow); color: var(--coal); font-size: .65rem; font-weight: 800; padding: .1rem .42rem; margin-left: auto; }
.filter-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 498; }
.filter-overlay.open { display: block; }
/* Layout shop */
.shop-layout { display: grid; grid-template-columns: 245px 1fr; gap: 0; align-items: start; margin-top: 1.5rem; border: 1px solid var(--line); }
.shop-sidebar {
  background: var(--coal-2); border-right: 1px solid var(--line);
  position: sticky; top: 1rem;
  max-height: calc(100vh - 2rem); overflow-y: auto;
}
.mobile-sidebar-head {
  display: none; padding: .85rem 1.2rem;
  border-bottom: 1px solid var(--line); background: var(--coal-3);
  align-items: center; justify-content: space-between;
}
.mobile-sidebar-title {
  font-size: .9rem; font-weight: 800; text-transform: uppercase; letter-spacing: .02em;
}
.filter-reset-link { font-size: .75rem; font-weight: 600; color: var(--or, var(--yellow)); }
.price-separator { color: var(--silver, rgba(28,31,24,.42)); font-size: .875rem; }
.no-results-box h3 { font-size: 1.1rem; margin-bottom: .4rem; }
.no-results-btn { margin-top: 1rem; }
.mobile-sidebar-head #close-filter-btn {
  width: 28px; height: 28px;
  background: var(--coal-4); border: 1px solid var(--line);
  color: var(--cream-2); cursor: pointer; font-size: .94rem;
  display: flex; align-items: center; justify-content: center;
}
.mobile-sidebar-head #close-filter-btn:hover { background: var(--yellow); color: var(--coal); border-color: var(--yellow); }
.sidebar-title {
  display: flex; align-items: center; justify-content: space-between;
  padding: .82rem 1.15rem .7rem;
  border-bottom: 1px solid var(--line);
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .01em; text-transform: uppercase; color: var(--yellow);
}
.sidebar-title a { color: var(--brick); font-size: .71rem; font-weight: 700; }
.filter-group { padding: .82rem 1.15rem; border-bottom: 1px solid var(--line); }
.filter-group:last-of-type { border-bottom: none; }
.filter-group h4 {
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .01em; text-transform: uppercase;
  color: rgba(28,31,24,.75); margin-bottom: .58rem;
}
.search-group { display: flex; }
.search-group input {
  flex: 1; padding: .48rem .65rem;
  background: var(--coal-3); border: 1px solid var(--line); border-right: none;
  color: var(--cream); font-size: .94rem; outline: none;
}
.search-group input:focus { border-color: var(--yellow); }
.search-group button {
  padding: .48rem .7rem; background: var(--yellow); color: var(--coal);
  border: none; cursor: pointer; font-size: .94rem; transition: var(--t);
}
.search-group button:hover { background: var(--yellow-dk); }
.radio-list { display: flex; flex-direction: column; gap: .28rem; }
.custom-check {
  display: flex; align-items: center; gap: .48rem; cursor: pointer;
  font-size: .93rem; color: rgba(28,31,24,.6); transition: color var(--t);
}
.custom-check:hover { color: var(--cream); }
.custom-check input[type=radio],
.custom-check input[type=checkbox] { accent-color: var(--yellow); width: 13px; height: 13px; flex-shrink: 0; }
.price-inputs { display: flex; align-items: center; gap: .5rem; }
.price-inputs input,
.filter-group input[type=text],
.filter-group input[type=number] {
  flex: 1; padding: .46rem .62rem;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream); font-size: .93rem; outline: none;
}
.price-inputs input:focus,
.filter-group input[type=text]:focus,
.filter-group input[type=number]:focus { border-color: var(--yellow); }
.filter-group select,
.filter-group .form-control {
  width: 100%; padding: .46rem .62rem;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream); font-size: 1rem; outline: none;
}
.filter-group select:focus { border-color: var(--yellow); }
.filter-group select option { background: var(--coal-2); }
.sidebar-submit { margin-top: .7rem; width: 100%; justify-content: center; padding: .58rem 1rem; font-size: .98rem; }
/* Résultats */
.shop-results { padding: 1.2rem; }
.results-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: .82rem 1rem; border-bottom: 1px solid var(--line);
  flex-wrap: wrap; gap: .5rem; margin-bottom: 1.2rem;
}
.results-count { font-family: 'Inter', sans-serif; font-size: .9rem; color: rgba(28,31,24,.72); }
.results-count strong { color: var(--cream); font-size: 1.08rem; margin-right: .15rem; }
.no-results-box { padding: 3rem 2rem; text-align: center; }
.no-results-box i { font-size: 2.2rem; margin-bottom: 1rem; display: block; color: rgba(28,31,24,.22); }
.no-results-box h3, .no-results { font-family: 'Inter', sans-serif; font-size: 1.08rem; color: rgba(28,31,24,.5); }
/* Pagination */
.pagination-wrap { padding: 1.5rem 0; border-top: 1px solid var(--line); }
.pagination-info {
  text-align: center; font-size: .875rem; color: rgba(28,31,24,.45);
  font-family: 'Inter', sans-serif; margin-bottom: .7rem; letter-spacing: .02em;
}
.pagination-info strong { color: var(--coal); }
.pagination { display: flex; justify-content: center; gap: .35rem; flex-wrap: wrap; }
.page-link {
  width: 34px; height: 34px; display: flex; align-items: center; justify-content: center;
  background: var(--coal-3); border: 1px solid var(--line); border-radius: 4px;
  font-family: 'Inter', sans-serif; font-size: .9rem; font-weight: 700;
  color: var(--cream-2); transition: var(--t);
}
.page-link:hover, .page-link.active { background: var(--yellow); color: var(--coal); border-color: var(--yellow); }
.page-link-edge { font-size: .78rem; opacity: .7; }
.page-link-edge:hover { opacity: 1; }
.page-ellipsis { display: flex; align-items: center; padding: 0 .25rem; color: rgba(28,31,24,.3); font-size: .9rem; }
/* Responsive shop */
@media (max-width: 860px) {
  .btn-filter-mobile { display: flex; }
  .shop-layout { grid-template-columns: 1fr; border: none; }
  .shop-sidebar {
    position: fixed; top: 0; left: -100%; width: 290px; max-width: 85vw; height: 100%;
    z-index: 499; max-height: 100%; overflow-y: auto;
    border-right: 1px solid var(--line);
    transition: .3s cubic-bezier(.4,0,.2,1);
  }
  .shop-sidebar.open { left: 0; }
  .mobile-sidebar-head { display: flex; }
  .shop-results { padding: .9rem; }
  .results-bar { padding: .72rem .9rem; margin-bottom: .9rem; }
}

/* ────────────────────────────────
   PAGE PRODUIT
──────────────────────────────── */
.prod-page-wrap { padding-top: 2.5rem; padding-bottom: 3.5rem; }

/* ── Product layout: gallery left, info right ── */
.product-layout {
  display: grid; grid-template-columns: 1fr 390px;
  gap: 0; border: 1px solid var(--line);
  margin-bottom: 0;
  align-items: start;      /* cells don't stretch to each other's height */
}
/* Prevent grid cells from overflowing */
.product-layout > * { min-width: 0; min-height: 0; }

.gallery-sticky { position: sticky; top: 1rem; }

/* ── Gallery component ── */
.prod-gallery {
  display: flex; flex-direction: column;
  background: var(--coal-3);
  width: 100%;              /* fill grid column exactly */
  overflow: hidden;         /* never spill out */
}

/* Main image viewer — fixed frame, all images same size regardless of ratio */
.gal-viewer {
  position: relative;
  width: 100%;
  height: 420px;
  background: #fff;
  cursor: zoom-in;
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gal-viewer img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  transition: transform .35s ease;
  flex-shrink: 0;
}
.gal-viewer:hover img { transform: scale(1.06); }

/* Nav arrows */
.gal-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(0,0,0,.52); border: 1px solid rgba(255,255,255,.12);
  color: #fff; font-size: .9rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .18s, transform .18s;
  z-index: 3;
}
.gal-nav:hover { background: var(--yellow); color: var(--coal); transform: translateY(-50%) scale(1.1); }
.gal-prev { left: .65rem; }
.gal-next { right: .65rem; }

/* Counter pill */
.gal-counter {
  position: absolute; bottom: .65rem; right: .75rem;
  background: rgba(0,0,0,.52); color: rgba(255,255,255,.85);
  font-size: .7rem; font-family: 'Inter', sans-serif;
  font-weight: 700; letter-spacing: .01em; padding: .22rem .65rem;
  border-radius: 99px; z-index: 3;
  pointer-events: none;
}

/* Thumbnails strip — strictly sized, horizontal, never wraps */
.gal-thumbs {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 2px;
  background: var(--coal-4);
  border-top: 1px solid var(--line);
  overflow-x: auto;
  overflow-y: hidden;
  padding: 4px;
  height: 68px;             /* fixed strip height */
  flex-shrink: 0;
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
}
.gal-thumb {
  flex: 0 0 80px;
  height: 60px;
  overflow: hidden;
  background: #fff;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color .15s;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gal-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  flex-shrink: 0;
}
.gal-thumb.active,
.gal-thumb:hover { border-color: var(--yellow); }

.cond-badge-lg {
  position: absolute; top: .75rem; left: .75rem; z-index: 2;
  font-family: 'Inter', sans-serif;
  font-size: .67rem; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase; padding: .2rem .62rem;
}

/* ── Info column ── */
.prod-info-col {
  padding: 1.6rem; background: var(--coal-2);
  border-left: 1px solid var(--line);
  overflow-y: auto;         /* scroll if taller than viewport */
}
.prod-eyebrow { display: flex; gap: .45rem; flex-wrap: wrap; margin-bottom: .58rem; }
.prod-brand-pill, .prod-cat-pill {
  font-family: 'Inter', sans-serif;
  font-size: .67rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; padding: .16rem .68rem;
}
.prod-brand-pill { background: var(--yellow); color: var(--coal); }
.prod-cat-pill { background: var(--coal-4); color: var(--cream-2); border: 1px solid var(--coal-5); }
.prod-name { font-size: clamp(1.3rem, 2.5vw, 1.65rem); text-transform: none; color: var(--cream); margin-bottom: .7rem; line-height: 1.1; }
.prod-price-row {
  display: flex; align-items: baseline; gap: .55rem;
  padding: .95rem 1.1rem; margin-bottom: 1.1rem;
  background: var(--coal-3); border: 1px solid var(--line);
}
.prod-price { font-family: 'Inter', sans-serif; font-size: 1.5rem; font-weight: 800; color: var(--yellow); }
.prod-price-note { font-size: .8rem; color: rgba(28,31,24,.68); }
.specs-box { border: 1px solid var(--line); margin-bottom: 1.1rem; overflow: hidden; }
.specs-box-head {
  background: var(--coal-3); padding: .62rem 1rem;
  font-family: 'Inter', sans-serif;
  font-size: .73rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--yellow);
  border-bottom: 1px solid var(--line);
}
.spec-row { display: grid; grid-template-columns: 1fr 1fr; padding: .58rem 1rem; border-bottom: 1px solid var(--line); }
.spec-row:last-child { border-bottom: none; }
.spec-row .lbl { font-size: .73rem; color: rgba(28,31,24,.68); align-self: center; }
.spec-row .val { font-family: 'Inter', sans-serif; font-size: .93rem; font-weight: 600; color: var(--cream); text-align: right; }
.prod-actions { display: flex; flex-direction: column; gap: .55rem; margin-bottom: 1.1rem; }
.prod-actions input[type=number] {
  padding: .52rem .65rem; width: 65px;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream); font-size: .96rem; outline: none; text-align: center;
}
.prod-actions input[type=number]:focus { border-color: var(--yellow); }
.prod-trust-row { display: flex; flex-wrap: wrap; gap: .55rem; padding-top: .95rem; border-top: 1px solid var(--line); }
.prod-trust-item { display: flex; align-items: center; gap: .38rem; font-size: .66rem; color: rgba(28,31,24,.72); }
.prod-trust-item i { color: var(--yellow); font-size: .67rem; }

/* ── Description — full width section below top block ── */
.prod-desc-section {
  border: 1px solid var(--line); border-top: none;
  padding: 2rem 2.4rem; background: var(--coal-2);
  margin-bottom: 0;
}
.prod-desc-title {
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  color: var(--yellow); margin-bottom: 1rem;
  display: flex; align-items: center; gap: .5rem;
}
.prod-desc { font-size: .92rem; color: rgba(28,31,24,.78); line-height: 1.755; }

/* ── Related ── */
.prod-related-section { margin-top: 3.5rem; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .product-layout { grid-template-columns: 1fr; }
  .gallery-sticky { position: static; }
  .gal-viewer { height: 320px; }
  .prod-info-col { border-left: none; border-top: 1px solid var(--line); overflow-y: visible; }
  .prod-desc-section { padding: 1.4rem 1.2rem; }
}
@media (max-width: 480px) {
  .gal-viewer { height: 240px; }
  .gal-thumbs { height: 58px; }
  .gal-thumb { flex: 0 0 64px; height: 50px; }
}

/* ────────────────────────────────
   FORMULAIRES (global)
──────────────────────────────── */
.form-group { margin-bottom: .95rem; }
.form-group:last-child { margin-bottom: 0; }
.form-group label {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .02em; text-transform: uppercase;
  color: rgba(28,31,24,.5); margin-bottom: .38rem;
}
.form-group input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=number]),
.form-group select,
.form-group textarea,
.form-control {
  display: block; width: 100%;
  padding: .6rem .82rem;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream); font-size: .92rem; outline: none;
  transition: border-color var(--t); font-family: 'Inter', sans-serif;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus, .form-control:focus { border-color: var(--yellow); }
.form-group textarea { resize: vertical; min-height: 88px; }
.form-group input::placeholder, .form-group textarea::placeholder { color: rgba(28,31,24,.25); }
.form-group select option { background: var(--coal-2); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .82rem; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }

/* ────────────────────────────────
   CART
──────────────────────────────── */
.cart-layout { display: grid; grid-template-columns: 1fr 315px; gap: 1.5rem; align-items: start; margin-top: 1.5rem; }
.cart-table-wrap { background: var(--coal-2); border: 1px solid var(--line); overflow-x: auto; }
.cart-table { width: 100%; border-collapse: collapse; min-width: 480px; }
.cart-table th {
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  padding: .78rem .95rem; background: var(--coal-3); color: rgba(28,31,24,.5);
  text-align: left; border-bottom: 1px solid var(--line); white-space: nowrap;
}
.cart-table td { padding: .82rem .95rem; border-bottom: 1px solid var(--line); font-size: .98rem; color: rgba(28,31,24,.85); vertical-align: middle; }
.cart-table tr:last-child td { border-bottom: none; }
.cart-table tr:hover td { background: var(--coal-3); }
.cart-thumb img { width: 54px; height: 40px; object-fit: cover; border: 1px solid var(--line); }
.cart-prod { display: flex; align-items: center; gap: .75rem; }
.cart-item-name { font-family: 'Inter', sans-serif; font-size: .9rem; font-weight: 700; color: var(--cream); }
.cart-ref { font-size: .71rem; color: rgba(28,31,24,.65); }
.qty-input {
  width: 54px; padding: .4rem .5rem; text-align: center;
  background: var(--coal-3); border: 1px solid var(--line);
  color: var(--cream); font-size: .9rem; outline: none;
}
.qty-input:focus { border-color: var(--yellow); }
.btn-del { background: none; border: none; cursor: pointer; color: rgba(194,75,42,.55); font-size: .98rem; padding: .28rem; transition: color var(--t); }
.btn-del:hover { color: var(--brick); }
.cart-actions-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: .82rem .95rem; border-top: 1px solid var(--line); flex-wrap: wrap; gap: .55rem;
}
/* Résumé panier */
.cart-summary { background: var(--coal-2); border: 1px solid var(--line); position: sticky; top: 1rem; }
.cart-summary-head {
  background: var(--coal-3); padding: .75rem 1.15rem;
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--yellow);
  border-bottom: 1px solid var(--line);
}
.cart-summary-body { padding: 1.15rem; }
.sum-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: .52rem 0; border-bottom: 1px solid var(--line);
  font-size: .9rem; color: rgba(28,31,24,.62);
}
.sum-row:last-child { border-bottom: none; }
.sum-row.total { font-family: 'Inter', sans-serif; font-size: 1.1rem; font-weight: 700; color: var(--cream); }
.promo-row { display: flex; margin: .72rem 0; }
.promo-row input {
  flex: 1; padding: .52rem .75rem;
  background: var(--coal-3); border: 1px solid var(--line); border-right: none;
  color: var(--cream); font-size: .9rem; outline: none;
}
.promo-row input:focus { border-color: var(--yellow); }
.promo-row button {
  padding: .52rem .88rem; background: var(--yellow); color: var(--coal); border: none; cursor: pointer;
  font-family: 'Inter', sans-serif; font-size: .8rem; font-weight: 700; letter-spacing: .03em;
  transition: var(--t);
}
.promo-row button:hover { background: var(--yellow-dk); }
.cart-cta-wrap { padding: 0 1.15rem 1.15rem; display: flex; flex-direction: column; gap: .45rem; }
.cart-secure { display: flex; align-items: center; justify-content: center; gap: .38rem; font-size: .71rem; color: rgba(28,31,24,.32); margin-top: .35rem; }
.cart-secure i { font-size: .7rem; }
@media (max-width: 900px) { .cart-layout { grid-template-columns: 1fr; } .cart-summary { position: static; } }

/* ────────────────────────────────
   CHECKOUT
──────────────────────────────── */
.checkout-layout { display: grid; grid-template-columns: 1fr 345px; gap: 1.5rem; align-items: start; }
.form-card { background: var(--coal-2); border: 1px solid var(--line); margin-bottom: 1.1rem; }
.form-card-head {
  background: var(--coal-3); padding: .75rem 1.15rem;
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--yellow);
  border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: .48rem;
}
.form-card-body { padding: 1.2rem; }
/* Modes de paiement */
.pay-card {
  border: 2px solid var(--line); padding: .95rem 1.05rem; margin-bottom: .65rem;
  cursor: pointer; transition: border-color var(--t);
  display: flex; align-items: flex-start; gap: .85rem;
}
.pay-card:hover { border-color: var(--coal-5); }
.pay-card.active { border-color: var(--yellow); }
.pay-card input[type=radio] { accent-color: var(--yellow); margin-top: .15rem; flex-shrink: 0; }
.pay-name { font-family: 'Inter', sans-serif; font-size: .9rem; font-weight: 700; color: var(--cream); display: block; }
.pay-sub { font-size: .8rem; color: rgba(28,31,24,.5); margin-top: .12rem; }
/* Versements */
.inst-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .45rem; margin-top: .65rem; }
.inst-opt { border: 2px solid var(--line); padding: .58rem .5rem; cursor: pointer; text-align: center; transition: border-color var(--t); }
.inst-opt input[type=radio] { display: none; }
.inst-opt.active, .inst-opt:hover { border-color: var(--yellow); }
.inst-n { font-family: 'Inter', sans-serif; font-size: 1.1rem; font-weight: 800; color: var(--yellow); display: block; }
.inst-m { font-size: .71rem; color: rgba(28,31,24,.5); text-transform: uppercase; letter-spacing: .03em; }
/* Résumé commande */
.quote-box { background: var(--coal-2); border: 1px solid var(--line); }
.quote-box-head {
  background: var(--coal-3); padding: .75rem 1.15rem;
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--yellow);
  border-bottom: 1px solid var(--line);
}
.quote-table { width: 100%; border-collapse: collapse; }
.quote-table td { padding: .68rem 1.15rem; border-bottom: 1px solid var(--line); font-size: .9rem; color: rgba(28,31,24,.85); }
.quote-table tr:last-child td { border-bottom: none; }
.ci-item { display: flex; gap: .58rem; align-items: center; }
.ci-item img { width: 46px; height: 34px; object-fit: cover; border: 1px solid var(--line); flex-shrink: 0; }
.price-col { text-align: right; font-family: 'Inter', sans-serif; font-weight: 700; color: var(--cream); }
.qty-col { text-align: center; font-size: .9rem; color: rgba(28,31,24,.58); }
.total-col { text-align: right; }
.action-col { text-align: right; }
@media (max-width: 860px) { .checkout-layout { grid-template-columns: 1fr; } .inst-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 480px) { .inst-grid { grid-template-columns: repeat(3, 1fr); } }

/* ────────────────────────────────
   QUOTE PAGE
──────────────────────────────── */
.quote-layout { display: grid; grid-template-columns: 1fr 360px; gap: 1.5rem; align-items: start; }
@media (max-width: 860px) { .quote-layout { grid-template-columns: 1fr; } }

/* ────────────────────────────────
   CONTACT
──────────────────────────────── */
.contact-layout { display: grid; grid-template-columns: 1fr 300px; gap: 1.5rem; align-items: start; }
.contact-info { background: var(--coal-2); border: 1px solid var(--line); padding: 1.6rem; }
.contact-info h3 { font-size: 1.05rem; text-transform: uppercase; color: var(--cream); margin-bottom: 1.1rem; }
.contact-info p,
.contact-info a { font-size: .9rem; color: rgba(28,31,24,.80); margin-bottom: .75rem; display: flex; align-items: flex-start; gap: .55rem; }
.contact-info a:hover { color: var(--yellow); }
.contact-info i { color: var(--yellow); font-size: .8rem; margin-top: .15rem; flex-shrink: 0; width: 14px; }
@media (max-width: 768px) { .contact-layout { grid-template-columns: 1fr; } }

/* ────────────────────────────────
   ABOUT
──────────────────────────────── */
.about-section { background: var(--coal-2); overflow: hidden; }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; }
.about-grid > div:first-child { padding: 3.5rem 3.5rem 3.5rem 0; }
.about-grid > div:first-child p { color: rgba(28,31,24,.82); font-size: .9rem; line-height: 1.75; margin-bottom: 1.7rem; }
.about-kpis { display: flex; border: 1px solid var(--line); margin: 1.7rem 0; }
.kpi-box { flex: 1; padding: 1.2rem 1.1rem; border-right: 1px solid var(--line); }
.kpi-box:last-child { border-right: none; }
.kpi-box .num { display: block; font-family: 'Inter', sans-serif; font-size: 2.1rem; font-weight: 800; color: var(--yellow); }
.kpi-box .lbl { font-size: .7rem; color: rgba(28,31,24,.68); text-transform: uppercase; letter-spacing: .02em; }
.about-visual { position: relative; overflow: hidden; background: var(--coal-3); }
.about-visual img { width: 100%; height: 100%; object-fit: cover; opacity: .7; }
.about-tag {
  position: absolute; bottom: 1.6rem; left: 1.6rem; right: 1.6rem;
  background: rgba(247,245,240,.97); border: 1px solid var(--line);
  padding: .88rem 1.1rem; display: flex; align-items: center; gap: .78rem;
}
.about-tag i { color: var(--yellow); font-size: 1.05rem; flex-shrink: 0; }
.about-tag strong { font-family: 'Inter', sans-serif; font-size: .98rem; font-weight: 700; text-transform: uppercase; color: var(--cream); display: block; }
.about-tag span { font-size: .73rem; color: rgba(28,31,24,.5); }
@media (max-width: 860px) { .about-grid { grid-template-columns: 1fr; } .about-grid > div:first-child { padding: 2.2rem 0; } .about-visual { height: 260px; } }

/* ────────────────────────────────
   BRANDS
──────────────────────────────── */
.brands-section { background: var(--coal); border-top: 1px solid var(--line); }
.brands-wrap { display: flex; flex-wrap: wrap; gap: .38rem; justify-content: center; }
.brand-pill {
  font-family: 'Inter', sans-serif;
  font-size: .78rem; font-weight: 600; letter-spacing: .02em; text-transform: uppercase;
  padding: .42rem 1.05rem; border: 1px solid var(--line); color: rgba(28,31,24,.75); transition: var(--t);
}
.brand-pill:hover { border-color: var(--yellow); color: var(--yellow); }

/* ────────────────────────────────
   TESTIMONIALS
──────────────────────────────── */
.testi-section { background: var(--coal-2); border-top: 1px solid var(--line); }
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; background: transparent; border: none; }
.testi-card { background: var(--coal-2); padding: 1.3rem 1.2rem; border: 1px solid var(--line); border-radius: 2px; }
.testi-stars { color: var(--yellow); font-size: .92rem; letter-spacing: .02em; margin-bottom: .85rem; }
.testi-text { font-size: .9rem; color: rgba(28,31,24,.82); line-height: 1.75; margin-bottom: 1.2rem; font-style: italic; font-weight: 400; }
.testi-author { display: flex; align-items: center; gap: .8rem; }
.testi-av {
  width: 38px; height: 38px; flex-shrink: 0;
  background: var(--yellow); color: var(--coal);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Inter', sans-serif; font-size: .94rem; font-weight: 800;
}
.testi-name { font-family: 'Inter', sans-serif; font-size: .98rem; font-weight: 700; color: var(--cream); letter-spacing: .02em; }
.testi-loc { font-size: .71rem; color: rgba(28,31,24,.62); text-transform: uppercase; letter-spacing: .01em; }
@media (max-width: 768px) { .testi-grid { grid-template-columns: 1fr; } }

/* ────────────────────────────────
   NEWSLETTER
──────────────────────────────── */
.newsletter-section { background: var(--coal-2); border-top: 1px solid var(--line); }
.newsletter-inner { display: grid; grid-template-columns: 1fr auto; gap: 2.5rem; align-items: center; padding: 2.8rem 0; }
.newsletter-text h2 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); text-transform: uppercase; color: var(--cream); }
.newsletter-text p { color: rgba(28,31,24,.75); font-size: .93rem; margin-top: .38rem; }
.newsletter-form { display: flex; width: 370px; max-width: 100%; }
.newsletter-form input {
  flex: 1; padding: .68rem .95rem;
  background: var(--coal-3); border: 1px solid var(--line); border-right: none;
  color: var(--cream); font-size: .98rem; outline: none;
}
.newsletter-form input::placeholder { color: rgba(28,31,24,.28); }
.newsletter-form input:focus { border-color: var(--yellow); }
.newsletter-form button {
  padding: .68rem 1.25rem;
  background: var(--yellow); color: var(--coal); border: none;
  font-family: 'Inter', sans-serif;
  font-size: .9rem; font-weight: 700; letter-spacing: .01em; text-transform: uppercase;
  cursor: pointer; transition: var(--t); white-space: nowrap;
  display: flex; align-items: center; gap: .42rem;
}
.newsletter-form button:hover { background: var(--yellow-dk); }
@media (max-width: 800px) { .newsletter-inner { grid-template-columns: 1fr; gap: 1.1rem; padding: 2.2rem 0; } .newsletter-form { width: 100%; } }

/* ────────────────────────────────
   FOOTER
──────────────────────────────── */
.main-footer { background: var(--coal-2); border-top: 2px solid var(--yellow); padding: 3.2rem 0 0; }
.footer-grid { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1fr; gap: 0; border: 1px solid var(--line); }
.footer-grid > div { padding: 1.7rem 1.5rem; border-right: 1px solid var(--line); }
.footer-grid > div:last-child { border-right: none; }
.footer-logo {
  display: flex; align-items: center; gap: .5rem;
  font-family: 'Inter', sans-serif;
  font-size: 1.1rem; font-weight: 900; text-transform: uppercase; color: var(--cream); margin-bottom: .65rem;
}
.footer-logo .mark {
  width: 32px; height: 32px; background: var(--yellow);
  display: flex; align-items: center; justify-content: center;
  color: var(--coal); font-size: .9rem; flex-shrink: 0;
}
.footer-desc { font-size: .93rem; color: rgba(28,31,24,.72); line-height: 1.7; margin-bottom: 1.2rem; }
.footer-contacts { display: flex; flex-direction: column; gap: .42rem; }
.footer-contacts a { font-size: .74rem; color: rgba(28,31,24,.72); display: flex; align-items: center; gap: .52rem; transition: color var(--t); }
.footer-contacts a:hover { color: var(--yellow); }
.footer-contacts i { color: var(--yellow); font-size: .7rem; width: 12px; flex-shrink: 0; }
.footer-h { font-family: 'Inter', sans-serif; font-size: .73rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: var(--yellow); margin-bottom: 1rem; }
.footer-nav { display: flex; flex-direction: column; gap: .35rem; }
.footer-nav a { font-size: .93rem; color: rgba(28,31,24,.72); transition: color var(--t); }
.footer-nav a:hover { color: var(--cream); }
.footer-bottom {
  padding: 1.1rem 0; display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .65rem; border-top: 1px solid var(--line);
}
.footer-bottom span, .footer-bottom a { font-size: .73rem; color: rgba(28,31,24,.68); transition: color var(--t); }
.footer-bottom a:hover { color: var(--yellow); }
.footer-bottom div { display: flex; gap: .95rem; }
@media (max-width: 860px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > div:nth-child(2n) { border-right: none; }
  .footer-grid > div:nth-child(n+3) { border-top: 1px solid var(--line); }
}
@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-grid > div { border-right: none; border-bottom: 1px solid var(--line); }
  .footer-grid > div:last-child { border-bottom: none; }
}

/* ────────────────────────────────
   CHATBOT
──────────────────────────────── */
/* ── Chatbot Widget ── */
#chatbot-fab { position: fixed; bottom: 1.2rem; right: 1.2rem; z-index: 900; font-family: 'Inter', sans-serif; }
#chat-toggle {
  width: 50px; height: 50px; background: var(--chat-color, var(--yellow)); color: var(--coal);
  border: none; border-radius: 50%; font-size: 1.15rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center; position: relative;
  box-shadow: 0 4px 16px rgba(0,0,0,.2); transition: transform .2s, box-shadow .2s;
}
#chat-toggle:hover { transform: scale(1.08); box-shadow: 0 6px 24px rgba(0,0,0,.3); }
#chat-win {
  position: absolute; bottom: 60px; right: 0; width: 340px;
  background: #fff; border-radius: 12px;
  display: none; flex-direction: column;
  box-shadow: 0 8px 40px rgba(0,0,0,.18); max-height: 480px;
  overflow: hidden;
}
#chat-win.open { display: flex; }

/* ────────────────────────────────
   PAGES LÉGALES / STATIQUES
──────────────────────────────── */
.page-layout {
  max-width: 840px; margin: 2.5rem auto;
  background: var(--coal-2); border: 1px solid var(--line); padding: 2.5rem;
}
.page-title { font-size: clamp(1.2rem, 3vw, 1.8rem); text-transform: none; color: var(--cream); margin-bottom: .4rem; }
.page-section { margin-top: 2rem; padding-top: 2rem; border-top: 1px solid var(--line); }
.page-section:first-child { margin-top: 0; padding-top: 0; border-top: none; }
.page-section h2 {
  font-family: 'Inter', sans-serif;
  font-size: 1.03rem; font-weight: 700; text-transform: none; letter-spacing: .01em;
  color: var(--yellow); margin-bottom: .72rem;
}
.page-section p { font-size: .9rem; color: rgba(28,31,24,.82); line-height: 1.75; margin-bottom: .45rem; }
.page-section ul { padding-left: .9rem; margin-bottom: .45rem; }
.page-section ul li { font-size: .9rem; color: rgba(28,31,24,.82); line-height: 1.75; margin-bottom: .18rem; list-style: none; }
.page-section ul li::before { content: '— '; color: var(--yellow); font-weight: 700; }
@media (max-width: 600px) { .page-layout { padding: 1.3rem; margin: .8rem; } }

/* ────────────────────────────────
   STATUTS COMMANDES
──────────────────────────────── */
[class^="badge-status-"] {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: .65rem; font-weight: 700; letter-spacing: .02em; text-transform: uppercase; padding: .2rem .62rem;
}
.badge-status-pending    { background: rgba(232,216,76,.1);  color: #d4c53a; border: 1px solid rgba(232,216,76,.22); }
.badge-status-paid,
.badge-status-delivered  { background: rgba(74,180,90,.1);   color: #52c464; border: 1px solid rgba(74,180,90,.22);  }
.badge-status-processing,
.badge-status-shipped    { background: rgba(66,133,244,.1);  color: #7aacf8; border: 1px solid rgba(66,133,244,.22); }
.badge-status-cancelled  { background: rgba(194,75,42,.1);   color: #f2917b; border: 1px solid rgba(194,75,42,.22);  }

/* ────────────────────────────────
   DATA TABLE (track / commandes)
──────────────────────────────── */
.data-table { width: 100%; border-collapse: collapse; background: var(--coal-2); border: 1px solid var(--line); }
.data-table th {
  font-family: 'Inter', sans-serif;
  font-size: .78rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  padding: .75rem .95rem; background: var(--coal-3); color: rgba(28,31,24,.5);
  text-align: left; border-bottom: 1px solid var(--line);
}
.data-table td { padding: .8rem .95rem; border-bottom: 1px solid var(--line); font-size: .95rem; color: rgba(28,31,24,.75); vertical-align: middle; }
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: var(--coal-3); }

/* ────────────────────────────────
   SECTION RESPONSIVE GLOBALE
──────────────────────────────── */
@media (max-width: 768px) { .section { padding: 40px 0; } }
@media (max-width: 480px) { .section { padding: 28px 0; } }

/* ────────────────────────────────
   CLASSES UTILITAIRES MANQUANTES
──────────────────────────────── */
/* Wrapper interne du banner (breadcrumb + titre) */
.page-banner-content { /* hérite du container, pas de style supplémentaire requis */ }

/* form-group pleine largeur dans un form-row */
.form-group.full { grid-column: 1 / -1; }

/* ═══════════════════════════════════════════
   LIGHT THEME OVERRIDES & FIXES
═══════════════════════════════════════════ */

/* Hero stays dark-overlay (text on images needs to stay white) */
.hero-content, h1#hero-h1, .hero-sub, .hero-badge,
.htrust-num, .hero-trust { color: #F5F0E8 !important; }
.hero-sub { color: rgba(245,240,232,.75) !important; }
.htrust-lbl { color: rgba(245,240,232,.78) !important; }
.hero-arrow {
  background: rgba(14,15,13,.55) !important;
  border-color: rgba(245,240,232,.18) !important;
  color: #F5F0E8 !important;
}
.hero-arrow:hover { background: var(--yellow) !important; color: var(--coal) !important; }
.hero-dot { background: rgba(245,240,232,.28) !important; }
.hero-dot.active { background: var(--yellow) !important; }
.hero-prod-card {
  background: rgba(14,15,13,.82) !important;
  border-color: rgba(245,240,232,.15) !important;
}
.hpc-name { color: #F5F0E8 !important; }

/* Header light */
.main-header { border-bottom: 1px solid var(--line) !important; }
.main-nav a { color: rgba(28,31,24,.5) !important; }
.main-nav a:hover, .main-nav a.active { color: var(--cream) !important; }
.hdr-btn .badge { border-color: var(--bg-2, #F7F5F0) !important; }

/* Nav drawer light */
.nav-drawer ul li a { color: rgba(28,31,24,.55) !important; }

/* Services band */
.svc-label span { color: rgba(28,31,24,.52) !important; }

/* Product card improvements mobile */
.pcard { border: 1px solid var(--line); }
.pcard-name { font-size: 1.05rem; color: var(--cream); }
.pcard-brand { color: var(--fg-2, #4A4E46); }
.btn-pcard-ask { background: var(--coal-3) !important; color: var(--cream) !important; }
.btn-pcard-ask:hover { background: var(--coal-4) !important; }

/* Mobile catalog - 1 col on small screens */
@media (max-width: 480px) {
  .products-grid, .products-grid-3 { grid-template-columns: 1fr !important; gap: 0; }
  .pcard { display: grid; grid-template-columns: 120px 1fr; grid-template-rows: auto auto; }
  .pcard-img { aspect-ratio: 1/1; grid-row: span 2; }
  .pcard-body { padding: .75rem .85rem .4rem; }
  .pcard-specs { gap: .2rem; }
  .pcard-price { font-size: 1.15rem; }
  .pcard-actions { grid-column: 2; border-top: 1px solid var(--line); position: relative; z-index: 2; }
  .btn-pcard { font-size: .73rem; padding: .55rem .5rem; gap: .3rem; }
  .btn-pcard i { display: inline !important; font-size: .73rem; }
  .btn-pcard-buy { flex: 3; }
  .btn-pcard-ask { flex: 2; }
}

/* Breadcrumb light */
.breadcrumb { color: rgba(28,31,24,.38) !important; }
.breadcrumb li + li::before { color: rgba(28,31,24,.2) !important; }
.breadcrumb a { color: rgba(28,31,24,.38) !important; }
.breadcrumb .active { color: rgba(28,31,24,.65) !important; }

/* Forms light */
.form-group label { color: rgba(28,31,24,.5) !important; }
.form-group input::placeholder, .form-group textarea::placeholder { color: rgba(28,31,24,.28) !important; }
.form-control { color: var(--cream) !important; background: var(--coal-3) !important; }

/* Cart table text */
.cart-table td { color: rgba(28,31,24,.75) !important; }
.cart-table th { color: rgba(28,31,24,.55) !important; }
.sum-row { color: rgba(28,31,24,.62) !important; }
.cart-secure { color: rgba(28,31,24,.35) !important; }
.cart-ref { color: rgba(28,31,24,.45) !important; }

/* Checkout / Pay cards */
.pay-card { background: var(--coal-2) !important; border: 1.5px solid var(--line) !important; }

/* Footer specific (needs to stay dark) */
.site-footer {
  background: var(--coal-3) !important;
  border-top: 2px solid var(--line) !important;
}

/* Alerts light adjustments */
.alert-info { color: rgba(28,31,24,.65) !important; }
.suc-box { color: #3a7d35 !important; }

/* Top bar */
.top-bar { background: var(--coal-3) !important; color: rgba(28,31,24,.55) !important; }
.lang-switch { background: var(--coal-4) !important; }
.lang-switch a { color: rgba(28,31,24,.52) !important; }
.lang-switch a.active, .lang-switch a:hover { color: var(--coal) !important; background: var(--yellow) !important; }

/* --or and --silver aliases */
:root { --or: var(--yellow); --silver: rgba(28,31,24,.42); }

/* Admin product form - mobile responsive */
@media (max-width: 900px) {
  div[style*="grid-template-columns:1fr 360px"] {
    display: block !important;
  }
}

/* Pagination */
.page-link { background: var(--coal-2); border: 1px solid var(--line); color: var(--cream); }
.page-link.active { background: var(--yellow); color: var(--coal); border-color: var(--yellow); }
.page-link:hover { background: var(--coal-3); }

/* No-results box */
.no-results-box { background: var(--coal-2); border: 1px solid var(--line); }

/* Hero chevron fill matches new bg */
.hero-chevron path { fill: var(--coal) !important; }

/* ═══════════════════════════════════════════
   THÈME DYNAMIQUE — CORRECTIONS LISIBILITÉ
   Garantit le contraste texte/fond sur tous les packs
═══════════════════════════════════════════ */

/* Avatar témoignages : fond = couleur secondaire, texte auto-contrasté */
.testi-av {
  background: var(--brick) !important;
  color: var(--secondary-text, #fff) !important;
}

/* Étoiles témoignages = couleur secondaire */
.testi-stars { color: var(--brick) !important; }

/* Eyebrow orange/brick = couleur secondaire dynamique */
.eyebrow--orange, .eyebrow--brick {
  color: var(--brick) !important;
  border-color: var(--brick) !important;
}

/* Bouton btn-brick = couleur secondaire */
.btn-brick {
  background: var(--brick) !important;
  color: var(--secondary-text, #fff) !important;
  border-color: var(--brick) !important;
}
.btn-brick:hover { background: var(--brick-dk, #a83e22) !important; border-color: var(--brick-dk, #a83e22) !important; }

/* Texte témoignages — contraste assuré */
.testi-text { color: rgba(28,31,24,.72) !important; }

/* Texte nom auteur témoignage */
.testi-name { color: var(--cream) !important; } /* var(--cream) = dark text in light theme */

/* Brand pills : texte visible */
.brand-pill { color: rgba(28,31,24,.6) !important; border-color: var(--line) !important; }
.brand-pill:hover { border-color: var(--yellow) !important; color: var(--yellow) !important; }

/* Logo-mark utilise la couleur primaire */
.logo-mark { background: var(--yellow) !important; color: var(--primary-text, #1C1F18) !important; }

/* Footer bottom text */
.footer-bottom span, .footer-bottom a { color: rgba(28,31,24,.45) !important; }
.footer-bottom a:hover { color: var(--yellow) !important; }

/* Footer headers */
.footer-h { color: var(--yellow) !important; }

/* Pcard badge - état produit */
.pcard-badge.badge-new  { background: var(--yellow); color: var(--primary-text, #1C1F18); }
.pcard-badge.badge-used { background: var(--coal-4); color: var(--cream); }

/* Chatbot dot */
.chat-dot { background: var(--brick) !important; }
.chat-close:hover { background: var(--brick) !important; color: var(--secondary-text,#fff) !important; }

/* Sidebar filter reset link */
.sidebar-title a { color: var(--brick) !important; }

/* Bouton header CTA */
.hdr-cta { background: var(--yellow) !important; color: var(--primary-text, #1C1F18) !important; }
.hdr-cta:hover { background: var(--yellow-dk) !important; }

/* Hdr-btn hover */
.hdr-btn:hover { background: var(--yellow) !important; color: var(--primary-text, #1C1F18) !important; border-color: var(--yellow) !important; }

/* Pagination */
.page-link.active { background: var(--yellow) !important; color: var(--primary-text,#1C1F18) !important; }

/* Badge count header */
.hdr-btn .badge { background: var(--brick) !important; }

/* Nav drawer icons */
.nav-drawer ul li a.active, .nav-drawer ul li a:hover {
  color: var(--yellow) !important;
  border-left-color: var(--yellow) !important;
}

/* Cat card accent bottom */
.cat-card::after { background: var(--yellow) !important; }
.cat-card:hover { border-color: var(--yellow) !important; }
.cat-count { background: var(--yellow) !important; color: var(--primary-text,#1C1F18) !important; }

/* Hero dots */
.hero-dot.active { background: var(--yellow) !important; }

/* Prod brand pill */
.prod-brand-pill { background: var(--yellow) !important; color: var(--primary-text,#1C1F18) !important; }

/* Promo input button */
.promo-row button { background: var(--yellow) !important; color: var(--primary-text,#1C1F18) !important; }
.promo-row button:hover { background: var(--yellow-dk) !important; }

/* Cart summary head */
.cart-summary-head { color: var(--yellow) !important; }

/* Input focus */
.form-group input:focus, .form-group select:focus, .form-group textarea:focus, .form-control:focus {
  border-color: var(--yellow) !important;
}

/* Lang switch active */
.lang-switch a.active, .lang-switch a:hover {
  background: var(--yellow) !important;
  color: var(--primary-text, #1C1F18) !important;
}

/* Footer contacts hover */
.footer-contacts a:hover { color: var(--yellow) !important; }
.footer-contacts i { color: var(--yellow) !important; }

/* Main nav underline */
.main-nav a::after { background: var(--yellow) !important; }

/* Btn primary = couleur primaire avec texte auto-contrasté */
.btn-primary {
  background: var(--yellow) !important;
  color: var(--primary-text, #1C1F18) !important;
  border-color: var(--yellow) !important;
}
.btn-primary:hover { background: var(--yellow-dk) !important; border-color: var(--yellow-dk) !important; }

/* Btn pcard buy */
.btn-pcard-buy { background: var(--yellow) !important; color: var(--primary-text,#1C1F18) !important; }
.btn-pcard-buy:hover { background: var(--yellow-dk) !important; }

/* Carousel buttons hover */
.cats-carousel-btn:hover { background: var(--yellow) !important; color: var(--primary-text,#1C1F18) !important; }

/* HL spans */
.hl { color: var(--yellow) !important; }

/* ═══════════════════════════════════════════
   MOBILE BOUTIQUE — améliorations complémentaires
═══════════════════════════════════════════ */

/* Barre résultats + bouton filtre : côte à côte */
@media (max-width: 860px) {
  .results-bar {
    display: flex; align-items: center; justify-content: space-between;
    gap: .5rem; flex-wrap: wrap;
  }
  .results-count { font-size: .8rem; }
  .results-count strong { font-size: .9rem; }
}

/* Sur <560px la liste passe en cartes horizontales (déjà géré),
   mais on optimise aussi la barre tout en haut */
@media (max-width: 560px) {
  /* Éviter que les specs dépassent de la carte */
  .pcard .pcard-specs {
    overflow-x: hidden;
    flex-wrap: nowrap;
  }
  /* 3 chips max visibles */
  .pcard .spec-chip:nth-child(n+4) { display: none; }

  /* Padding général de la grille */
  .shop-results { padding: .6rem !important; }
  .results-bar { padding: .55rem .6rem !important; margin-bottom: .55rem !important; }

  /* Bouton filtre plus compact */
  .btn-filter-mobile { font-size: .78rem; padding: .38rem .7rem; }
}

/* ═══════════════════════════════════════════
   LISIBILITÉ GLOBALE — Textes renforcés
   Toutes les opacités basses remontées à ≥ .68
═══════════════════════════════════════════ */

/* Témoignages */
.testi-text  { color: rgba(28,31,24,.82) !important; font-weight: 400 !important; }
.testi-loc   { color: rgba(28,31,24,.65) !important; }
.testi-name  { color: var(--coal) !important; font-weight: 700 !important; }

/* Footer */
.footer-desc      { color: rgba(28,31,24,.75) !important; }
.footer-nav a     { color: rgba(28,31,24,.72) !important; }
.footer-contacts a { color: rgba(28,31,24,.72) !important; }
.footer-bottom span, .footer-bottom a { color: rgba(28,31,24,.68) !important; }
.footer-h { font-weight: 700 !important; }

/* Marques partenaires */
.brand-pill { color: rgba(28,31,24,.75) !important; }

/* Chips de specs */
.spec-chip { color: rgba(28,31,24,.80) !important; }

/* Textes secondaires */
.results-count { color: rgba(28,31,24,.75) !important; }
.results-count strong { color: var(--coal) !important; }
.pcard-brand   { color: var(--yellow) !important; }
.prod-desc     { color: rgba(28,31,24,.82) !important; }
.cart-ref      { color: rgba(28,31,24,.68) !important; }
.pay-sub       { color: rgba(28,31,24,.70) !important; }
.inst-m        { color: rgba(28,31,24,.68) !important; }
.ht            { color: rgba(28,31,24,.68) !important; }
.svc-label span { color: rgba(28,31,24,.72) !important; }
/* kpi-lbl reset */
.prod-trust-item { color: rgba(28,31,24,.75) !important; }
.prod-price-note { color: rgba(28,31,24,.72) !important; }
.contact-info a  { color: rgba(28,31,24,.82) !important; }
.page-section p, .page-section ul li { color: rgba(28,31,24,.82) !important; }
.about-grid > div:first-child p { color: rgba(28,31,24,.82) !important; }

/* Nav bar */
.main-nav a { color: rgba(28,31,24,.80) !important; }

/* Topbar */
.topbar { color: rgba(28,31,24,.72) !important; }
.topbar a { color: rgba(28,31,24,.72) !important; }

/* ══════════════════════════════════════════════
   TRUST BANNER — Homepage
══════════════════════════════════════════════ */
.trust-banner-section {
  background: var(--cream);
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 2rem 0;
}
.trust-banner-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: .8rem;
  align-items: stretch;
}
.trust-banner-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .9rem 1rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r);
  transition: background .2s;
}
.trust-banner-item:hover { background: rgba(255,255,255,.1); }
.trust-banner-item > i {
  font-size: 1.45rem;
  color: var(--yellow);
  flex-shrink: 0;
}
.trust-banner-item strong {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.3;
}
.trust-banner-item span {
  font-size: .875rem;
  color: rgba(255,255,255,.72);
  line-height: 1.4;
}
@media (max-width: 900px) {
  .trust-banner-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .trust-banner-section { padding: 1.2rem 0; }
  .trust-banner-grid { grid-template-columns: repeat(2, 1fr); gap: .5rem; }
  .trust-banner-item { padding: .7rem .8rem; gap: .55rem; }
  .trust-banner-item > i { font-size: 1.2rem; }
  .trust-banner-item strong { font-size: .9rem; }
  .trust-banner-item span { font-size: .8rem; }
}
@media (max-width: 380px) {
  .trust-banner-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════════════ */
.about-page-hero {
  background: var(--cream);
  padding: 4rem 0 3.5rem;
}
.about-page-intro {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 3.5rem;
  align-items: center;
}
.about-page-img {
  position: relative;
  border-radius: var(--r);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
}
.about-page-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.value-card {
  background: var(--white);
  border: 1.5px solid var(--line);
  border-radius: var(--r);
  padding: 1.8rem 1.5rem;
  transition: box-shadow .2s, transform .2s;
}
.value-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,.09);
  transform: translateY(-2px);
}
.value-icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.35rem;
  margin-bottom: 1rem;
}
.value-card h3 {
  font-size: 1.03rem;
  font-weight: 800;
  text-transform: none;
  letter-spacing: .02em;
  margin-bottom: .6rem;
  color: var(--coal-1);
}
.value-card p {
  font-size: .96rem;
  color: var(--slate);
  line-height: 1.7;
  margin: 0;
}

/* Steps grid */
.steps-grid {
  display: flex;
  align-items: center;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.step-card {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--r);
  padding: 1.8rem 1.4rem;
  text-align: center;
  flex: 1 1 190px;
  max-width: 210px;
  position: relative;
}
.step-num {
  position: absolute;
  top: -14px; left: 50%;
  transform: translateX(-50%);
  background: var(--yellow);
  color: var(--coal-1);
  font-weight: 900;
  font-size: .9rem;
  width: 28px; height: 28px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.step-icon {
  font-size: 1.7rem;
  color: var(--yellow);
  margin: .4rem 0 .9rem;
}
.step-card h3 {
  font-size: .96rem;
  font-weight: 800;
  color: #fff;
  text-transform: none;
  letter-spacing: .02em;
  margin-bottom: .5rem;
}
.step-card p {
  font-size: .98rem;
  color: rgba(255,255,255,.62);
  line-height: 1.7;
  margin: 0;
}
.step-arrow {
  color: rgba(255,255,255,.3);
  font-size: 1.1rem;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════
   RESPONSIVE — new sections
══════════════════════════════════════════════ */
@media (max-width: 900px) {
  .about-page-intro { grid-template-columns: 1fr; }
  .about-page-img { max-width: 100%; aspect-ratio: 16/9; }
  .values-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
  .values-grid { grid-template-columns: 1fr; }
  .trust-banner-grid { gap: .8rem; }
  .trust-banner-item { max-width: 100%; flex: 1 1 45%; min-width: 150px; }
  .steps-grid { flex-direction: column; align-items: stretch; }
  .step-arrow { display: none; }
  .step-card { max-width: 100%; }
}

/* ══════════════════════════════════════════════
   ABOUT PAGE — STEPS SECTION FIX
══════════════════════════════════════════════ */
.about-steps-section {
  background: #1C1F18 !important;
}
.about-eyebrow-light {
  border-color: var(--yellow) !important;
  color: var(--yellow) !important;
  background: rgba(255,255,255,.05);
}

/* KPI boxes in about hero */
.about-kpis {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
}
.kpi-box {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  padding: .9rem 1.3rem;
  min-width: 110px;
  flex: 1 1 100px;
}
.kpi-box .num {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 1.8rem;
  font-weight: 900;
  color: var(--yellow);
  line-height: 1;
}
.kpi-box .lbl {
  display: block;
  font-size: .98rem;
  color: rgba(255,255,255,.65);
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-top: .25rem;
}

/* brand pills */
.brands-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  justify-content: center;
  margin-top: 1.5rem;
}
.brand-pill {
  background: var(--coal-3);
  border: 1px solid var(--line);
  border-radius: 30px;
  padding: .45rem 1.1rem;
  font-size: .98rem;
  font-weight: 600;
  color: var(--cream-2);
  transition: background .18s, border-color .18s;
}
.brand-pill:hover {
  background: var(--yellow);
  border-color: var(--yellow);
  color: #1C1F18;
}

/* About page image tag */
.about-tag {
  position: absolute;
  bottom: 1.2rem;
  left: 1.2rem;
  background: rgba(28,31,24,.82);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  padding: .7rem 1rem;
  display: flex;
  align-items: center;
  gap: .7rem;
  color: #fff;
  font-size: .98rem;
  line-height: 1.35;
}
.about-tag i { color: var(--yellow); font-size: 1.2rem; }
.about-tag strong { display: block; font-weight: 700; }

/* Steps grid responsive */
@media (max-width: 768px) {
  .steps-grid {
    flex-direction: column;
    align-items: stretch;
  }
  .step-arrow { display: none; }
  .step-card { max-width: 100%; }
  .about-kpis { gap: .5rem; }
  .kpi-box { min-width: 80px; padding: .7rem 1rem; }
}

.about-page-hero .kpi-box .num{color:var(--yellow)!important;font-size:1.9rem!important;font-weight:900!important;}
.about-page-hero .kpi-box .lbl{color:rgba(255,255,255,.82)!important;font-size: .8rem !important;}
.about-page-hero .kpi-box{background:rgba(255,255,255,.06)!important;border:1px solid rgba(255,255,255,.15)!important;border-radius:8px!important;}



/* ═══════════════════════════════════════════════
   TYPOGRAPHY SCALE — Refined & Compact
═══════════════════════════════════════════════ */
html { font-size: 16px; }
body { font-size: 1rem; line-height: 1.72; }
p, li { font-size: 1rem; }

/* Headings — tighter, more refined */
.section-h  { font-size: clamp(1.35rem, 2.4vw, 1.75rem) !important; letter-spacing: .01em; }
h1          { font-size: clamp(1.6rem, 3.5vw, 2.25rem); }
h2          { font-size: clamp(1.25rem, 2.5vw, 1.75rem); }
h3          { font-size: clamp(1.1rem, 1.8vw, 1.3rem); }
h4          { font-size: 1.05rem; }
h5          { font-size: 0.95rem; }
.page-banner h1 { font-size: clamp(1.2rem, 3vw, 1.8rem); }

/* Nav */
.main-nav a           { font-size: .9rem !important; }
.top-bar              { font-size: .8rem !important; }
.breadcrumb, .breadcrumb a, .breadcrumb li { font-size: .8rem !important; }

/* Footer */
.footer-h             { font-size: .82rem !important; font-weight: 700; }
.footer-desc          { font-size: .95rem !important; line-height: 1.65; }
.footer-nav a         { font-size: .95rem !important; }
.footer-copy          { font-size: .82rem !important; }

/* Buttons */
.btn     { font-size: .875rem !important; }
.btn-sm  { font-size: .8rem !important; }
.btn-lg  { font-size: .88rem !important; }

/* Forms */
.form-control, input, select, textarea { font-size: 1rem !important; }
label, .form-group label               { font-size: .875rem !important; }

/* Product cards */
.pcard-name   { font-size: 1rem !important; line-height: 1.3; }
.pcard-price  { font-size: 1.15rem !important; font-weight: 700; }
.pcard-cond   { font-size: .8rem !important; }
.pcard-cat    { font-size: .75rem !important; }
.pcard-brand  { font-size: .67rem !important; }

/* Product page */
.product-title  { font-size: clamp(1.1rem, 2.5vw, 1.5rem) !important; }
.product-price  { font-size: 1.35rem !important; }
.spec-table td,
.spec-table th  { font-size: .9rem !important; }
.product-desc p { font-size: .88rem  !important; }

/* Shop filters */
.filter-group label   { font-size: .875rem !important; }
.filter-group h4      { font-size: .8rem !important; }
.sidebar-h            { font-size: .875rem !important; }

/* Trust banner */
.trust-banner-item strong { font-size: .9rem !important; }
.trust-banner-item span   { font-size: .8rem !important; }

/* Services band */
.svc-item .svc-title  { font-size: .875rem !important; }
.svc-item .svc-sub    { font-size: .75rem !important; }

/* Eyebrow tags */
.eyebrow { font-size: .73rem !important; letter-spacing: .03em; }

/* Cart & checkout */
.cart-table td, .cart-table th { font-size: .9rem !important; }
.sum-row          { font-size: .9rem !important; }
.sum-row.total    { font-size: .95rem !important; font-weight: 700; }
.pay-card label   { font-size: .9rem !important; }

/* KPI boxes */
.kpi-box .num { font-size: 1.65rem !important; font-weight: 800; }
.kpi-box .lbl { font-size: .75rem !important; letter-spacing: .02em; }

/* Step & value cards */
.step-card h3   { font-size: .88rem !important; }
.step-card p    { font-size: .875rem !important; }
.value-card h3  { font-size: .88rem !important; }
.value-card p   { font-size: .875rem !important; }

/* Testimonials */
.testi-text   { font-size: .9rem !important; line-height: 1.65; }
.testi-name   { font-size: .9rem !important; font-weight: 700; }
.testi-loc    { font-size: .75rem !important; }

/* Alert / info boxes */
.alert        { font-size: .9rem !important; }

/* Admin */
.admin-sidebar a { font-size: .9rem; }

/* Brand pills */
.brand-pill { font-size: .82rem !important; }

/* ── Chatbot Widget — Assistance Directe ── */
#chat-win {
  font-size: .95rem; flex-direction: column; color: #333;
}
#chat-head {
  padding: .7rem 1rem;
  display: flex; align-items: center; justify-content: space-between;
  background: #000;
  border-radius: 12px 12px 0 0;
}
.chat-head-left {
  display: flex; align-items: center; gap: .6rem;
}
.chat-head-avatar {
  width: 34px; height: 34px;
  background: var(--chat-color, #E8D84C);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
}
.chat-head-info { display: flex; flex-direction: column; }
.chat-head-info strong {
  font-family: 'Inter', sans-serif; font-weight: 700;
  font-size: .95rem; color: #fff;
}
.chat-head-status {
  font-size: .73rem; color: rgba(255,255,255,.6);
  display: flex; align-items: center; gap: .3rem;
}
.status-dot {
  width: 7px; height: 7px; border-radius: 50%; display: inline-block;
}
.status-dot.online { background: #22c55e; box-shadow: 0 0 4px rgba(34,197,94,.5); }
.status-dot.offline { background: #999; }
.chat-head-close {
  background: none; border: none; color: rgba(255,255,255,.6);
  cursor: pointer; font-size: .85rem; padding: .25rem;
  transition: color .2s;
}
.chat-head-close:hover { color: #fff; }

/* Messages */
#chat-msgs {
  flex: 1; padding: .75rem .85rem;
  overflow-y: auto; display: flex; flex-direction: column; gap: .35rem;
  min-height: 200px; max-height: 340px;
  background: #f8f9fa;
}
.cm {
  font-size: .875rem !important; line-height: 1.6;
  max-width: 82%; padding: .5rem .8rem;
  word-wrap: break-word; border-radius: 10px;
  animation: cmFadeIn .2s ease;
}
@keyframes cmFadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
.cm-bot {
  background: #fff; color: #333;
  align-self: flex-start;
  border-radius: 10px 10px 10px 2px;
  border: 1px solid #e9ecef;
}
.cm-user {
  background: var(--chat-color, #E8D84C); color: var(--coal);
  align-self: flex-end; font-weight: 600;
  border-radius: 10px 10px 2px 10px;
}
.cm-typing { opacity: .6; font-style: italic; }

/* Input bar */
#chat-bar {
  display: flex; gap: .35rem; padding: .6rem .75rem;
  border-top: 1px solid #eee; background: #fff;
  border-radius: 0 0 12px 12px;
}
#chat-bar input {
  flex: 1; padding: .5rem .75rem;
  border: 1px solid #e0e0e0; background: #f8f9fa;
  color: #333; font-size: .95rem; outline: none;
  border-radius: 20px; transition: border-color .2s, box-shadow .2s;
}
#chat-bar input:focus {
  border-color: var(--chat-color, #E8D84C);
  box-shadow: 0 0 0 2px rgba(232,216,76,.15);
  background: #fff;
}
#chat-bar button {
  background: var(--chat-color, #E8D84C); color: var(--coal);
  border: none; border-radius: 50%;
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  font-size: .875rem; cursor: pointer;
  transition: transform .15s, box-shadow .15s;
}
#chat-bar button:hover {
  transform: scale(1.08);
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

/* Badge notification */
.chat-badge {
  position: absolute; top: -3px; right: -3px;
  background: #ef4444; color: #fff;
  font-size: .63rem; font-weight: 800;
  width: 16px; height: 16px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid #fff;
  animation: badgePulse 1.5s infinite;
}
@keyframes badgePulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }

/* Chat toggle styles */
.chat-style-pill #chat-toggle {
  width: auto; border-radius: 28px; padding: .55rem 1.1rem .55rem .78rem; gap: .42rem;
}
.chat-pill-label { font-family: 'Inter', sans-serif; font-size: .875rem; font-weight: 700; }
.chat-style-minimal #chat-toggle { width: 44px; height: 44px; font-size: 1.1rem; }


/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE MOBILE — COMPREHENSIVE FIXES
   Breakpoints: 480px (small phones), 600px (large phones), 768px (tablets)
══════════════════════════════════════════════════════════════════ */

/* ── Trust Banner — 2 col on mobile ── */
@media (max-width: 600px) {
  .trust-banner-section { padding: 1.2rem 0; }
  .trust-banner-grid { gap: .6rem; }
  .trust-banner-item {
    flex: 1 1 calc(50% - .3rem);
    min-width: 0; max-width: none;
    padding: .75rem .9rem;
    gap: .6rem;
  }
  .trust-banner-item > i { font-size: 1.25rem; }
  .trust-banner-item strong { font-size: .9rem; }
  .trust-banner-item span { font-size: .8rem; }
}
@media (max-width: 360px) {
  .trust-banner-item { flex: 1 1 100%; }
}

/* ── Hero slider mobile ── */
@media (max-width: 600px) {
  .hero-slider { min-height: 380px; }
  .hero-slide { min-height: 380px; }
  .hero-content { padding: 70px 1rem 60px; }
  .hero-badge { font-size: .73rem; padding: .2rem .55rem; }
  .hero-title { font-size: 1.75rem !important; line-height: 1.2; }
  .hero-sub { font-size: 1rem !important; }
  .hero-btns { flex-direction: column; gap: .5rem; }
  .hero-btns .btn { width: 100%; justify-content: center; text-align: center; }
  .hero-trust { gap: .6rem; }
  .htrust-num { font-size: 1.1rem; }
  .htrust-lbl { font-size: .7rem; }
  .hero-arrow { display: none; }
}

/* ── Products grid — 2 col on small, toggle-aware ── */
@media (max-width: 600px) {
  .products-grid,
  .products-grid-3 {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: .4rem;
  }
  /* Mobile column toggle: 1-col mode */
  .products-grid.mobile-1col,
  .products-grid-3.mobile-1col {
    grid-template-columns: 1fr !important;
  }
  .pcard-body { padding: .55rem .65rem .5rem; }
  .pcard-name { font-size: .95rem; line-height: 1.3; }
  .pcard-price { font-size: .88rem; }
  .pcard-actions { flex-wrap: wrap; gap: 0; }
  .btn-pcard { font-size: .73rem; padding: .35rem .5rem; }
}
@media (max-width: 380px) {
  .products-grid:not(.mobile-2col),
  .products-grid-3:not(.mobile-2col) {
    grid-template-columns: 1fr !important;
  }
}

/* ── Category cards ── */
@media (max-width: 600px) {
  .categories-section .products-grid,
  .cat-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .cat-card { padding: .9rem .7rem; }
}

/* ── Cart page ── */
@media (max-width: 650px) {
  .cart-layout { grid-template-columns: 1fr !important; }
  .cart-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .cart-table { min-width: 420px; font-size: .9rem; }
  .cart-table th, .cart-table td { padding: .55rem .6rem; }
  .cart-summary { margin-top: 0; }
}
@media (max-width: 480px) {
  .cart-table th:nth-child(3),
  .cart-table td:nth-child(3) { display: none; }
  .cart-table { min-width: 320px; }
}

/* ── Checkout ── */
@media (max-width: 860px) {
  .checkout-layout { grid-template-columns: 1fr !important; }
  .checkout-summary { order: -1; }
}
@media (max-width: 480px) {
  .form-card { padding: .9rem !important; }
  .form-row { flex-direction: column; gap: 0; }
  .form-group { min-width: 0; }
}

/* ── Product page ── */
@media (max-width: 860px) {
  .product-layout { grid-template-columns: 1fr !important; }
  .gallery-sticky { position: static; }
  .product-info { border-left: none !important; border-top: 1px solid var(--line); }
}
@media (max-width: 600px) {
  .product-price { font-size: 1.4rem !important; }
  .product-actions { flex-direction: column; gap: .5rem; }
  .product-actions .btn { width: 100%; justify-content: center; }
  .spec-table td, .spec-table th { padding: .45rem .6rem; font-size: .9rem; }
  .tab-btn-group { overflow-x: auto; white-space: nowrap; gap: 0; }
}

/* ── Top bar ── */
@media (max-width: 480px) {
  .top-bar { display: none; }
}
/* Masquer la topbar sur mobile si une seule langue active (pas de sélecteur de langue utile) */
@media (max-width: 768px) {
  .top-bar--single-lang { display: none; }
  body:has(.top-bar--single-lang) { padding-top: var(--hh); }
  body:has(.top-bar--single-lang) .main-header { top: 0; }
}

/* ── Main header on mobile ── */
@media (max-width: 600px) {
  .main-header { padding: .6rem 0; }
  .hdr-btn .lbl { display: none; }
  .hdr-cta { font-size: .875rem; padding: .38rem .75rem; }
}

/* ── Quote page ── */
@media (max-width: 768px) {
  .quote-layout { grid-template-columns: 1fr !important; }
  .quote-summary { order: -1; }
}

/* ── Contact page ── */
@media (max-width: 600px) {
  .contact-layout { grid-template-columns: 1fr !important; }
  .contact-info { order: -1; }
}

/* ── Section padding ── */
@media (max-width: 480px) {
  .section { padding: 2rem 0 !important; }
  .section-head { flex-direction: column; align-items: flex-start; gap: .6rem; margin-bottom: 1.2rem; }
  .section-h { font-size: 1.45rem !important; }
}

/* ── Order tracking ── */
@media (max-width: 600px) {
  .track-steps { flex-direction: column; gap: .5rem; }
  .track-steps .step-arrow { transform: rotate(90deg); }
  .order-items-table { overflow-x: auto; display: block; }
}

/* ── Page banner ── */
@media (max-width: 480px) {
  .page-banner { padding: 2rem 0 1.5rem !important; }
  .page-banner-content h1 { font-size: 1.4rem !important; }
}

/* ── About page ── */
@media (max-width: 600px) {
  .about-page-intro { grid-template-columns: 1fr !important; }
  .about-values-grid { grid-template-columns: 1fr !important; }
  .about-certs { flex-wrap: wrap; gap: .5rem; }
}

/* ── Admin responsive ── */
@media (max-width: 600px) {
  .set-card-head { flex-wrap: wrap; gap: .6rem; }
  .form-row { flex-direction: column; }
  .admin-table { font-size: .875rem; }
  .admin-table td, .admin-table th { padding: .45rem .5rem; }
  .page-bar { flex-wrap: wrap; gap: .5rem; }
}

/* ── Prevent horizontal overflow ── */
* { box-sizing: border-box; }
img, video, iframe { max-width: 100%; }
@media (max-width: 768px) {
  .container { overflow-x: hidden; }
}

/* ══ Dynamic grid columns (admin-controlled) ══ */
.products-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.products-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.products-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }

/* List view mode */
.products-grid.view-list {
  grid-template-columns: 1fr !important;
}
.products-grid.view-list .pcard {
  flex-direction: row;
  min-height: 140px;
}
.products-grid.view-list .pcard-img {
  width: 180px;
  flex-shrink: 0;
  aspect-ratio: auto;
}
.products-grid.view-list .pcard-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.products-grid.view-list .pcard-specs { display: flex; flex-wrap: wrap; gap: .3rem; margin-bottom: .4rem; }
@media (max-width: 600px) {
  .products-grid.view-list .pcard { flex-direction: column; }
  .products-grid.view-list .pcard-img { width: 100%; aspect-ratio: 16/9; }
}

/* View toggle buttons */
.view-toggle { display:flex; gap:.3rem; }
.view-btn {
  width:34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line); border-radius:6px;
  background:var(--coal-2); color:#888;
  cursor:pointer; transition:.15s; font-size:.85rem;
  text-decoration:none;
}
.view-btn.active,
.view-btn:hover { border-color:var(--g); color:var(--g); background:rgba(184,166,60,.08); }

/* ══════════════════════════════════════════════
   VALUE ICON COLOR CLASSES (About page)
══════════════════════════════════════════════ */
.value-icon--blue   { background: rgba(59,130,246,.12); color: #3B82F6; }
.value-icon--green  { background: rgba(34,197,94,.12);  color: #22C55E; }
.value-icon--amber  { background: rgba(245,158,11,.12); color: #F59E0B; }
.value-icon--purple { background: rgba(139,92,246,.12);  color: #8B5CF6; }
.value-icon--red    { background: rgba(239,68,68,.12);   color: #EF4444; }
.value-icon--grey   { background: rgba(107,114,128,.12); color: #6B7280; }

/* ══════════════════════════════════════════════
   CTA BANNER (About page bottom)
══════════════════════════════════════════════ */
.cta-banner {
  background: var(--coal-3);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 3.5rem 0;
  text-align: center;
}
.cta-banner h2 {
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  text-transform: none;
  color: var(--cream);
  margin-bottom: .5rem;
}
.cta-banner p {
  max-width: 480px;
  margin: 0 auto 1.8rem;
  font-size: 1rem;
  line-height: 1.7;
}
.btn-cta-dark {
  background: var(--cream);
  color: var(--coal);
  border: 2px solid var(--cream);
  padding: .72rem 1.8rem;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  transition: var(--t);
  cursor: pointer;
}
.btn-cta-dark:hover {
  background: var(--yellow);
  color: var(--coal);
  border-color: var(--yellow);
  transform: translateY(-1px);
}
@media (max-width: 600px) {
  .cta-banner { padding: 2.5rem 0; }
  .cta-banner .container { max-width: 100% !important; }
}

/* ══════════════════════════════════════════════
   ABOUT PAGE — Remaining inline style cleanup
══════════════════════════════════════════════ */
.about-page-intro-text p {
  font-size: 1.08rem;
  line-height: 1.75;
  color: rgba(255,255,255,.82);
  margin-bottom: 1.4rem;
}
.about-page-intro-text p:last-of-type {
  font-size: 1rem;
  color: rgba(255,255,255,.75);
  margin-bottom: 0;
}
.about-page-intro-text .about-kpis {
  margin-top: 2rem;
}
.about-section-centered {
  text-align: center;
  margin-bottom: 2.8rem;
}
.about-values-section {
  background: var(--coal-2);
}
.about-brands-section {
  background: var(--coal-2);
}
.about-brands-sub {
  color: var(--cream-2);
  max-width: 540px;
  margin: .8rem auto 0;
}

/* ══════════════════════════════════════════════
   CART PAGE — crt-* classes
══════════════════════════════════════════════ */
.cart-empty-text { color: rgba(28,31,24,.5); margin-bottom: 1.8rem; }
.crt-section { padding-bottom: 3rem; }
.crt-pill {
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .02em;
  background: var(--yellow); color: var(--coal);
  padding: .12rem .55rem; margin-left: .35rem; vertical-align: middle;
}
.crt-empty {
  text-align: center; padding: 3.5rem 1.5rem;
  background: var(--coal-2); border: 1px solid var(--line);
}
.crt-empty-ico { font-size: 2.5rem; color: rgba(28,31,24,.18); margin-bottom: 1.2rem; }
.crt-empty h2 { font-size: 1.3rem; text-transform: none; color: var(--cream); margin-bottom: .6rem; }

.crt-toast {
  background: rgba(232,216,76,.07); color: #d4c53a;
  border: 1px solid rgba(232,216,76,.22);
  padding: .6rem 1rem; font-size: .9rem; margin-bottom: 1rem;
  display: flex; align-items: center; gap: .5rem;
}

.crt-layout {
  display: grid; grid-template-columns: 1fr 320px;
  gap: 1.5rem; align-items: start;
}
.crt-left { min-width: 0; }

/* Table desktop */
.crt-table-wrap {
  background: var(--coal-2); border: 1px solid var(--line);
  overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.crt-table { width: 100%; border-collapse: collapse; min-width: 520px; }
.crt-table th {
  font-family: 'Inter', sans-serif;
  font-size: .71rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  padding: .72rem .9rem; background: var(--coal-3); color: rgba(28,31,24,.5);
  text-align: left; border-bottom: 1px solid var(--line); white-space: nowrap;
}
.crt-table td {
  padding: .78rem .9rem; border-bottom: 1px solid var(--line);
  font-size: .88rem; color: rgba(28,31,24,.82); vertical-align: middle;
}
.crt-table tr:last-child td { border-bottom: none; }
.crt-table tr:hover td { background: var(--coal-3); }
.th-u, .th-q, .th-t, .th-x { text-align: center; }
.td-u, .td-q, .td-t, .td-x { text-align: center; }
.td-t strong { font-family: 'Inter', sans-serif; font-weight: 700; color: var(--cream); font-size: 1rem; }

/* Product cell */
.crt-prod { display: flex; align-items: center; gap: .75rem; }
.crt-thumb { flex-shrink: 0; width: 60px; height: 45px; overflow: hidden; border: 1px solid var(--line); display: block; }
.crt-thumb img { width: 100%; height: 100%; object-fit: cover; }
.crt-name {
  font-family: 'Inter', sans-serif;
  font-size: .92rem; font-weight: 700; color: var(--cream); text-transform: none; line-height: 1.2;
  display: block; transition: color .2s;
}
.crt-name:hover { color: var(--yellow); }
.crt-ref { font-size: .75rem; color: rgba(28,31,24,.55); margin-top: .12rem; }
.crt-badge {
  display: inline-block; margin-top: .25rem;
  font-family: 'Inter', sans-serif;
  font-size: .63rem; font-weight: 700; letter-spacing: .02em; text-transform: uppercase;
  padding: .1rem .42rem;
}
.crt-badge--new { background: var(--yellow); color: var(--coal); }
.crt-badge--used { background: var(--coal-4); color: var(--cream-2); border: 1px solid var(--coal-5); }

/* Qty control */
.qty-ctrl { display: inline-flex; align-items: center; border: 1px solid var(--line); }
.qty-ctrl--sm { transform: scale(.9); }
.qty-b {
  width: 30px; height: 30px; background: var(--coal-3); border: none;
  color: var(--cream); font-size: .92rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center; transition: background .15s;
}
.qty-b:hover { background: var(--yellow); color: var(--coal); }
.qty-n {
  width: 38px; height: 30px; text-align: center;
  background: var(--coal-2); border: none; border-left: 1px solid var(--line); border-right: 1px solid var(--line);
  color: var(--cream); font-size: .9rem; font-weight: 700; outline: none;
  -moz-appearance: textfield;
}
.qty-n::-webkit-inner-spin-button,
.qty-n::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }

/* Delete button */
.btn-x {
  background: none; border: none; cursor: pointer;
  color: rgba(194,75,42,.5); font-size: .88rem; padding: .3rem;
  transition: color .2s;
}
.btn-x:hover { color: var(--brick); }

/* Cards (mobile view) */
.crt-cards { display: none; }
.crt-card {
  display: flex; gap: .75rem; padding: .9rem;
  background: var(--coal-2); border: 1px solid var(--line);
  margin-bottom: -1px;
}
.crt-card-img { flex-shrink: 0; width: 80px; height: 80px; overflow: hidden; border: 1px solid var(--line); display: block; }
.crt-card-img img { width: 100%; height: 100%; object-fit: cover; }
.crt-card-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .3rem; }
.crt-card-row {
  display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; margin-top: .35rem;
}
.crt-unit { font-size: .875rem; color: rgba(28,31,24,.55); }
.crt-line { font-family: 'Inter', sans-serif; font-size: 1rem; font-weight: 700; color: var(--cream); }

/* Actions bar */
.crt-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: .82rem .9rem; border-top: 1px solid var(--line);
  background: var(--coal-2); border: 1px solid var(--line); border-top: none;
  flex-wrap: wrap; gap: .5rem;
}
.crt-clear { color: var(--brick) !important; border-color: rgba(194,75,42,.3) !important; }
.crt-clear:hover { background: rgba(194,75,42,.08) !important; }

/* Aside / Summary */
.crt-aside { position: sticky; top: 1rem; }
.crt-box { background: var(--coal-2); border: 1px solid var(--line); }
.crt-box-head {
  background: var(--coal-3); padding: .72rem 1.1rem;
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase;
  color: var(--yellow); border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: .45rem;
}
.crt-box-body { padding: 1.1rem; }
.crt-rows { margin: .8rem 0; }
.crt-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: .48rem 0; border-bottom: 1px solid var(--line);
  font-size: .9rem; color: rgba(28,31,24,.62);
}
.crt-row:last-child { border-bottom: none; }
.crt-row--disc { color: #22c55e; }
.crt-row--total {
  font-family: 'Inter', sans-serif;
  font-size: 1.08rem; font-weight: 700; color: var(--cream);
  padding-top: .62rem; border-top: 2px solid var(--line); margin-top: .2rem;
}
.crt-cta { width: 100%; justify-content: center; margin-top: .6rem; }
.crt-secure {
  display: flex; align-items: center; justify-content: center; gap: .38rem;
  font-size: .71rem; color: rgba(28,31,24,.32); margin-top: .45rem;
}
.crt-icons {
  display: flex; justify-content: center; gap: .65rem; margin-top: .55rem;
  font-size: 1.15rem; color: rgba(28,31,24,.22);
}

/* Promo */
.promo-form { display: flex; margin-bottom: .55rem; }
.promo-inp {
  flex: 1; padding: .48rem .72rem;
  background: var(--coal-3); border: 1px solid var(--line); border-right: none;
  color: var(--cream); font-size: .9rem; outline: none;
}
.promo-inp:focus { border-color: var(--yellow); }
.promo-inp--err { border-color: var(--brick); }
.promo-go {
  padding: .48rem .82rem; background: var(--yellow); color: var(--coal); border: none;
  font-family: 'Inter', sans-serif;
  font-size: .75rem; font-weight: 700; letter-spacing: .03em; cursor: pointer; transition: var(--t);
}
.promo-go:hover { background: var(--yellow-dk); }
.promo-ok {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(34,197,94,.06); border: 1px solid rgba(34,197,94,.2);
  padding: .48rem .72rem; margin-bottom: .55rem; font-size: .875rem; color: #22c55e;
}
.promo-rm { color: rgba(194,75,42,.6); font-size: 1rem; text-decoration: none; }
.promo-rm:hover { color: var(--brick); }
.promo-msg { font-size: .8rem; margin-bottom: .5rem; display: flex; align-items: center; gap: .3rem; }
.promo-msg--err { color: var(--brick); }
.promo-msg--ok { color: #22c55e; }

/* Trust bar */
.crt-trust {
  display: flex; gap: .45rem; margin-top: .85rem; flex-wrap: wrap;
}
.crt-trust-item {
  flex: 1; min-width: 120px;
  display: flex; align-items: center; gap: .42rem;
  background: var(--coal-2); border: 1px solid var(--line);
  padding: .55rem .72rem; font-size: .75rem; color: rgba(28,31,24,.62);
}
.crt-trust-item i { color: var(--yellow); font-size: .71rem; }

/* Cart responsive */
@media (max-width: 900px) {
  .crt-layout { grid-template-columns: 1fr; }
  .crt-aside { position: static; }
}
@media (max-width: 650px) {
  .crt-table-wrap { display: none; }
  .crt-cards { display: block; }
  .crt-trust { flex-direction: column; }
  .crt-trust-item { min-width: 0; }
}

/* ══════════════════════════════════════════════
   SMOOTH SCROLL-TO-TOP BUTTON
══════════════════════════════════════════════ */
.scroll-top-btn {
  position: fixed;
  bottom: 5.5rem;
  right: 1.5rem;
  z-index: 899;
  width: 42px;
  height: 42px;
  background: var(--coal-3);
  border: 1px solid var(--line);
  color: var(--cream);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s, background .2s;
}
.scroll-top-btn.visible {
  opacity: 1;
  pointer-events: auto;
}
.scroll-top-btn:hover {
  background: var(--yellow);
  color: var(--coal);
  border-color: var(--yellow);
}

/* ══════════════════════════════════════════════
   LOADING / SKELETON ANIMATIONS
══════════════════════════════════════════════ */
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.skeleton {
  background: linear-gradient(90deg, var(--coal-3) 25%, var(--coal-4) 50%, var(--coal-3) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
}

/* ══════════════════════════════════════════════
   FOCUS / ACCESSIBILITY IMPROVEMENTS
══════════════════════════════════════════════ */
:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ══════════════════════════════════════════════
   TRANSITION & HOVER IMPROVEMENTS
══════════════════════════════════════════════ */
.pcard { transition: box-shadow .25s ease, background .2s ease; }
.pcard:hover { box-shadow: 0 4px 16px rgba(0,0,0,.08); }
.value-card { transition: box-shadow .25s ease, transform .25s ease; }
.testi-card { transition: background .2s ease; }
.testi-card:hover { background: var(--coal-3); }

/* ── Chatbot mobile responsiveness ── */
@media (max-width: 480px) {
  #chatbot-fab { bottom: .8rem; right: .8rem; }
  #chat-toggle { width: 46px; height: 46px; font-size: 1.05rem; }
  #chat-win {
    position: fixed; bottom: 0; right: 0; left: 0;
    width: 100% !important; max-height: 85vh;
    border-radius: 14px 14px 0 0;
  }
  #chat-head { border-radius: 14px 14px 0 0; }
  #chat-bar { border-radius: 0; }
  #chat-msgs { max-height: 55vh; }
}

/* ══════════════════════════════════════════════
   PRINT STYLES
══════════════════════════════════════════════ */
@media print {
  .top-bar, .main-header, .main-footer,
  #chatbot-fab, .scroll-top-btn,
  .hero-arrow, .hero-dots, .cats-carousel-btn,
  .btn-filter-mobile, .nav-overlay, .nav-drawer { display: none !important; }
  body { padding-top: 0 !important; background: #fff !important; color: #000 !important; }
  .section { padding: 1rem 0 !important; }
  .pcard, .surface-card, .form-card, .cart-summary { border: 1px solid #ccc !important; box-shadow: none !important; }
}

/* ══════════════════════════════════════════════
   MOBILE COLUMN TOGGLE (1 col / 2 col)
══════════════════════════════════════════════ */
.grid-col-toggle {
  display: none;
  align-items: center;
  gap: .25rem;
  margin-left: auto;
}
.grid-col-toggle .col-btn {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  background: var(--coal-2); border: 1px solid var(--line);
  color: rgba(28,31,24,.45); cursor: pointer;
  transition: var(--t); font-size: .78rem; border-radius: 2px;
}
.grid-col-toggle .col-btn.active {
  border-color: var(--yellow); color: var(--yellow);
  background: rgba(232,216,76,.06);
}
.grid-col-toggle .col-btn:hover { border-color: var(--yellow); color: var(--yellow); }
.grid-col-toggle .col-btn svg { width: 14px; height: 14px; fill: currentColor; }
@media (max-width: 768px) {
  .grid-col-toggle { display: flex; }
}

/* ══════════════════════════════════════════════
   CHATBOT REDESIGN — Email + Live Agent
══════════════════════════════════════════════ */

/* Chat action menu (before conversation starts) */
.chat-actions-menu {
  padding: .85rem;
  display: flex; flex-direction: column;
  gap: .5rem;
  background: #fff;
  overflow-y: auto;
}
/* (Old chat panels removed — unified into direct assistance mode) */


/* ══════════════════════════════════════════════
   LISIBILITÉ PREMIUM — Inter Typography System
   Améliorations finales de lisibilité et confort
══════════════════════════════════════════════ */

/* Font inter smoothing */
body, * {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Body base — 16px minimum, comfortable reading */
html { font-size: 16px; }
body { font-size: 1rem; line-height: 1.72; }
p, li { font-size: 1rem; line-height: 1.72; }

/* Headings — Inter with refined sizes */
h1, h2, h3, h4, h5 {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
}
h1 { font-size: clamp(1.65rem, 3.5vw, 2.25rem); }
h2 { font-size: clamp(1.3rem, 2.5vw, 1.8rem); }
h3 { font-size: clamp(1.1rem, 1.8vw, 1.3rem); }
h4 { font-size: 1.05rem; }
h5 { font-size: 0.95rem; }

/* Section heading — readable without uppercase screaming */
.section-h {
  font-size: clamp(1.35rem, 2.5vw, 1.75rem) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  text-transform: none !important;
  line-height: 1.25 !important;
}

/* Hero h1 — impactful but not fatiguing */
h1#hero-h1 {
  font-size: clamp(2.1rem, 6vw, 4.5rem) !important;
  letter-spacing: -0.03em !important;
  line-height: 1.05 !important;
  font-weight: 800 !important;
  text-transform: none !important;
}
.hero-sub {
  font-size: clamp(1rem, 1.4vw, 1.1rem) !important;
  line-height: 1.7 !important;
  font-weight: 400 !important;
}

/* Product names — sentence case, readable size */
.pcard-name {
  font-size: 1rem !important;
  font-weight: 600 !important;
  text-transform: none !important;
  line-height: 1.4 !important;
  letter-spacing: -0.01em !important;
}
.prod-name {
  font-size: clamp(1.3rem, 2.5vw, 1.65rem) !important;
  font-weight: 700 !important;
  text-transform: none !important;
  line-height: 1.25 !important;
}

/* Product card price */
.pcard-price {
  font-size: 1.15rem !important;
  font-weight: 700 !important;
}

/* Buttons — Inter semibold, proper size */
.btn {
  font-family: 'Inter', sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  line-height: 1.4 !important;
}
.btn-sm { font-size: 0.8rem !important; }
.btn-lg { font-size: 1rem !important; }
.btn-xl { font-size: 1.05rem !important; }

/* Forms — full 16px for mobile zoom prevention */
.form-control,
input:not([type=checkbox]):not([type=radio]):not([type=range]),
select,
textarea {
  font-size: 1rem !important;
  line-height: 1.6 !important;
}
.form-group label { font-size: 0.82rem !important; font-weight: 500 !important; }

/* Navigation */
.main-nav a { font-size: 0.9rem !important; font-weight: 500 !important; letter-spacing: 0.01em !important; }
.top-bar { font-size: 0.8rem !important; }
.breadcrumb, .breadcrumb a, .breadcrumb li { font-size: 0.82rem !important; font-weight: 400 !important; letter-spacing: 0 !important; }

/* Footer */
.footer-desc { font-size: 0.95rem !important; line-height: 1.72 !important; }
.footer-nav a { font-size: 0.9rem !important; }
.footer-h { font-size: 0.78rem !important; font-weight: 600 !important; letter-spacing: 0.05em !important; }

/* Testimonials */
.testi-text { font-size: 0.95rem !important; line-height: 1.72 !important; }
.testi-name { font-size: 0.9rem !important; font-weight: 600 !important; }
.testi-loc  { font-size: 0.78rem !important; }

/* Value & Step cards */
.value-card h3 { font-size: 1.05rem !important; font-weight: 700 !important; text-transform: none !important; letter-spacing: -0.01em !important; }
.value-card p  { font-size: 0.95rem !important; line-height: 1.7 !important; }
.step-card h3  { font-size: 1rem !important; font-weight: 700 !important; text-transform: none !important; }
.step-card p   { font-size: 0.9rem !important; line-height: 1.7 !important; }

/* Cart table */
.crt-table th { font-size: 0.75rem !important; letter-spacing: 0.04em !important; }
.crt-table td, .cart-table td, .data-table td { font-size: 0.9rem !important; }
.crt-row { font-size: 0.9rem !important; }
.crt-row--total { font-size: 1.1rem !important; }

/* Spec chips */
.spec-chip { font-size: 0.75rem !important; font-weight: 500 !important; }

/* Eyebrow — keep uppercase, just more refined */
.eyebrow { font-size: 0.7rem !important; font-weight: 600 !important; letter-spacing: 0.1em !important; }

/* Alerts */
.alert { font-size: 0.9rem !important; }

/* Page section content */
.page-section p, .page-section ul li { font-size: 0.95rem !important; line-height: 1.75 !important; }
.page-section h2 { font-size: 1.1rem !important; font-weight: 700 !important; text-transform: none !important; letter-spacing: -0.01em !important; }
.page-title { text-transform: none !important; }

/* Sidebar filter labels */
.filter-group h4 { font-size: 0.75rem !important; letter-spacing: 0.04em !important; }
.filter-group label, .custom-check { font-size: 0.9rem !important; }
.sidebar-title { font-size: 0.73rem !important; font-weight: 600 !important; letter-spacing: 0.06em !important; }

/* Trust banner */
.trust-banner-item strong { font-size: 0.9rem !important; font-weight: 600 !important; }
.trust-banner-item span   { font-size: 0.78rem !important; }

/* Chatbot */
.cm { font-size: 0.9rem !important; line-height: 1.6 !important; }

/* Mobile section heading floor */
@media (max-width: 480px) {
  .section-h { font-size: 1.45rem !important; }
  h1#hero-h1 { font-size: clamp(1.65rem, 10vw, 2.5rem) !important; }
  .hero-sub { font-size: 0.95rem !important; }
  body { font-size: 1rem; }
  .pcard-name { font-size: 0.9rem !important; }
}

/* AUTRE */

/* ════════════════════════════════════════════════════════════════
   PATCH — Services Band + Catégories : Responsive Mobile Premium
   À coller à la FIN de votre style.css (après le patch pcard).
   ════════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────────
   1. BANDE DE SERVICES
   Desktop  : 4 colonnes côte à côte (inchangé, juste amélioré)
   Tablette : 2×2 grille
   Mobile   : 2×2 grille compacte
──────────────────────────────────────────────────────────────── */

.services-band {
  background: var(--coal-2) !important;
  border-top: 1px solid var(--line) !important;
  border-bottom: 1px solid var(--line) !important;
}

/* Remplace le flex scroll par une grille propre */
.services-scroll {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  overflow-x: unset !important;
  scrollbar-width: unset !important;
}

/* Item service — layout horizontal icône + texte */
.svc-item {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 16px 20px !important;
  border-right: 1px solid var(--line) !important;
  border-bottom: none !important;
  flex: unset !important;
  transition: background .18s !important;
}
.svc-item:last-child { border-right: none !important; }
.svc-item:hover { background: var(--coal-3) !important; }

/* Icône — ronde et douce, fond ambré léger */
.svc-icon {
  width: 42px !important;
  height: 42px !important;
  flex-shrink: 0 !important;
  background: rgba(232, 160, 32, .09) !important;
  border: none !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--yellow) !important;
  font-size: 18px !important;
}

/* Texte service */
.svc-label strong {
  display: block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;   /* supprime uppercase */
  color: var(--cream) !important;
  line-height: 1.3 !important;
}
.svc-label span {
  font-size: 11.5px !important;
  color: var(--cream-2) !important;
  opacity: .65 !important;
  display: block !important;
  margin-top: 1px !important;
  line-height: 1.3 !important;
}

/* ── Tablette ≤ 860px : 2×2 ── */
@media (max-width: 860px) {
  .services-scroll {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .svc-item {
    border-right: 1px solid var(--line) !important;
    border-bottom: 1px solid var(--line) !important;
    padding: 14px 16px !important;
  }
  /* 2 items par ligne → supprimer border droite sur les items pairs */
  .svc-item:nth-child(2n) {
    border-right: none !important;
  }
  /* Supprimer border-bottom sur les 2 derniers */
  .svc-item:nth-last-child(-n+2) {
    border-bottom: none !important;
  }
}

/* ── Mobile ≤ 480px : 2×2 compact ── */
@media (max-width: 480px) {
  .services-scroll {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .svc-item {
    flex-direction: column !important;   /* icône au-dessus du texte sur petit mobile */
    align-items: flex-start !important;
    gap: 8px !important;
    padding: 14px 14px !important;
  }
  .svc-icon {
    width: 38px !important;
    height: 38px !important;
    font-size: 16px !important;
  }
  .svc-label strong { font-size: 12px !important; }
  .svc-label span   { font-size: 11px !important; }
}

/* ── Très petit mobile ≤ 360px : 1 colonne ── */
@media (max-width: 360px) {
  .services-scroll {
    grid-template-columns: 1fr !important;
  }
  .svc-item {
    flex-direction: row !important;
    border-right: none !important;
    border-bottom: 1px solid var(--line) !important;
  }
  .svc-item:last-child { border-bottom: none !important; }
  .svc-item:nth-child(2n) { border-right: none !important; }
}


/* ────────────────────────────────────────────────────────────────
   2. CAROUSEL DE CATÉGORIES
   Desktop  : 6 cartes visibles, carousel JS (inchangé)
   Tablette : 3 cartes
   Mobile   : grille 3×N sans carousel (tout visible)
──────────────────────────────────────────────────────────────── */

/* Nom de catégorie — sentence case, plus lisible */
.cat-name {
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;   /* supprime uppercase */
  color: var(--cream-2) !important;
  text-align: center !important;
  line-height: 1.3 !important;
}

/* Compteur de produits — badge sobre */
.cat-count {
  font-family: 'Inter', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  background: var(--yellow) !important;
  color: #fff !important;
  padding: 2px 8px !important;
  border-radius: 20px !important;
}

/* Carte catégorie desktop — légèrement affinée */
.cat-card {
  border-radius: 12px !important;
  padding: 20px 12px 16px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.07) !important;
}

/* Icône catégorie */
.cat-icon {
  width: 64px !important;
  height: 64px !important;
  border-radius: 50% !important;
  background: var(--coal-3) !important;
  border: 1px solid var(--line) !important;
}

/* ── Tablette ≤ 860px ── */
@media (max-width: 860px) {
  .cat-card {
    flex: 0 0 calc(33.33% - 10px) !important;
    min-width: 0 !important;
    padding: 16px 10px 14px !important;
  }
  .cat-icon { width: 56px !important; height: 56px !important; }
  .cat-name  { font-size: 11.5px !important; }
}

/* ── Mobile ≤ 640px : grille 3 colonnes, tout visible, pas de carousel ── */
@media (max-width: 640px) {

  /* Le carousel perd son overflow caché → grille normale */
  .cats-carousel-wrap {
    padding: 0 !important;
  }
  .cats-track-outer {
    overflow: visible !important;
    padding: 0 !important;
  }
  .cats-track {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 10px !important;
    transform: none !important;    /* annule la translation JS du carousel */
    transition: none !important;
  }

  /* Cacher les boutons prev/next inutiles sur mobile */
  .cats-carousel-btn {
    display: none !important;
  }

  /* Chaque carte prend toute la largeur de la cellule */
  .cat-card {
    flex: unset !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 14px 8px 12px !important;
    border-radius: 10px !important;
    box-shadow: none !important;
  }

  .cat-icon {
    width: 52px !important;
    height: 52px !important;
  }
  .cat-icon img { width: 34px !important; height: 34px !important; }
  .cat-icon .fas { font-size: 1.25rem !important; }
  .cat-name  { font-size: 11px !important; }
  .cat-count { font-size: 9.5px !important; padding: 2px 6px !important; }
}

/* ── Petit mobile ≤ 400px : 2 colonnes ── */
@media (max-width: 400px) {
  .cats-track {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
  .cat-card  { padding: 14px 8px 12px !important; }
  .cat-icon  { width: 48px !important; height: 48px !important; }
  .cat-name  { font-size: 11px !important; }
}