/* ============================================================
   L'essentiel par A&C — V3 — style.css
   Fusion v1 (clarté) + v2 (éditorial magazine)
   Base esthétique : V2 · Blocs portés : V1
   Charte : logos du zip (forêt / crème / vert feuille / sable)
   ============================================================ */

/* ---------- @font-face ---------- */
@font-face {
  font-family: 'Bentoga';
  src: url('../fonts/Bentoga-Thin.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'MontserratLocal';
  src: url('../fonts/Montserrat-ExtraLight.ttf') format('truetype');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'MontserratLocal';
  src: url('../fonts/Montserrat-300.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'MontserratLocal';
  src: url('../fonts/Montserrat-400.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'MontserratLocal';
  src: url('../fonts/Montserrat-500.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

/* ---------- Tokens (fusion v1 + v2) ---------- */
:root {
  --color-foret           : #2C3830;
  --color-sauge           : #4A5D4E;
  --color-vert            : #7DB87D;
  --color-vert-soft       : #9ec99e;
  --color-terracotta      : #C67B5C;
  --color-terracotta-deep : #a85f44;
  --color-terracotta-soft : #e3a78d;
  --color-creme           : #F5F0E1;
  --color-creme-deep      : #ede5d0;
  --color-creme-soft      : #fbf7ec;
  --color-sable           : #D4C4A8;
  --color-sable-light     : #e7dcc6;

  --color-primary       : var(--color-terracotta);
  --color-primary-light : var(--color-vert-soft);
  --color-secondary     : var(--color-sauge);
  --color-accent        : var(--color-sable);
  --color-surface       : var(--color-creme);
  --color-surface-alt   : var(--color-creme-soft);
  --color-surface-deep  : var(--color-creme-deep);
  --color-surface-warm  : var(--color-sable-light);
  --color-surface-dark  : var(--color-foret);
  --color-surface-mid   : var(--color-sauge);

  --color-ink           : #2a2520;
  --color-ink-soft      : #5a5048;
  --color-ink-muted     : #847a6e;
  --color-ink-on-dark   : #f5f0e1;
  --color-ink-on-dark-soft : #c8c0a8;

  --font-display : 'Bentoga', 'Cormorant Garamond', serif;
  --font-body    : 'MontserratLocal', 'Montserrat', system-ui, sans-serif;

  --radius-sm    : 6px;
  --radius-card  : 4px;
  --radius-btn   : 999px;
  --radius-pill  : 999px;
  --shadow-soft  : 0 12px 38px rgba(74, 56, 40, 0.10);
  --shadow-warm  : 0 30px 70px rgba(168, 95, 68, 0.18);
  --shadow-card  : 0 4px 22px rgba(44, 56, 48, 0.10);
  --shadow-hover : 0 18px 38px rgba(44, 56, 48, 0.18);
}

/* ---------- Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  margin: 0;
  background: var(--color-creme);
  color: var(--color-ink);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.7;
  font-size: 16px;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
button { font-family: inherit; }

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(198, 123, 92, 0.05), transparent 50%),
    radial-gradient(circle at 85% 75%, rgba(125, 184, 125, 0.04), transparent 45%);
}
main, header, footer, .topbar { position: relative; z-index: 1; }

/* ---------- Typographie éditoriale ---------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 300;
  letter-spacing: -0.015em;
  line-height: 1.05;
  color: var(--color-foret);
  margin: 0 0 0.6em;
}
h1 { font-size: clamp(3.4rem, 9vw, 8rem); line-height: 0.95; }
h2 { font-size: clamp(2.2rem, 5.5vw, 4.4rem); line-height: 1.05; }
h3 { font-size: clamp(1.3rem, 2.2vw, 1.8rem); }
h4 { font-size: 0.78rem; font-family: var(--font-body); font-weight: 400; letter-spacing: 0.32em; text-transform: uppercase; color: var(--color-terracotta); margin: 0 0 1em; }

p { margin: 0 0 1em; color: var(--color-ink-soft); font-weight: 300; }
em.serif { font-family: var(--font-display); font-style: italic; color: var(--color-terracotta); font-weight: 300; }
strong { font-weight: 500; color: var(--color-foret); }
a { color: inherit; text-decoration: none; }

/* Surtitre éditorial centré (blocs V2) */
.eyebrow {
  font-family: var(--font-body);
  font-size: 0.72rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-terracotta);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 1.5em;
}
.eyebrow::before, .eyebrow::after {
  content: "";
  width: 24px;
  height: 1px;
  background: currentColor;
  opacity: 0.6;
}
.eyebrow.left::after, .eyebrow.left::before { display: none; }

/* Surtitre filet gauche (blocs V1) */
.surtitre {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-vert);
  margin: 0 0 1.2em;
  position: relative;
  padding-left: 38px;
}
.surtitre::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 28px;
  height: 1px;
  background: var(--color-vert);
}
.surtitre--terracotta { color: var(--color-terracotta); }
.surtitre--terracotta::before { background: var(--color-terracotta); }
.surtitre--cream { color: var(--color-creme); }
.surtitre--cream::before { background: var(--color-creme); }

.container { max-width: 1320px; margin: 0 auto; padding: 0 24px; }
.container-wide { max-width: 1500px; margin: 0 auto; padding: 0 24px; }
@media (min-width: 768px) { .container, .container-wide { padding: 0 48px; } }
section { padding: clamp(80px, 11vw, 160px) 0; }

/* ============================================================
   NAV — éditoriale, transparente sur le hero (V2)
   ============================================================ */
.site-header {
  position: absolute;
  top: 38px;
  left: 0;
  right: 0;
  z-index: 50;
  transition: all .4s ease;
}
.site-header.is-stuck {
  position: fixed;
  top: 0;
  background: rgba(245, 240, 225, 0.95);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(44, 56, 48, 0.08);
  padding-top: 12px;
  padding-bottom: 12px;
}
.site-header.dark .nav-link,
.site-header.dark .nav-logo span,
.site-header.dark .icon-btn { color: var(--color-creme); border-color: rgba(245, 240, 225, 0.3); }
.site-header.dark .icon-btn:hover { background: var(--color-creme); color: var(--color-foret); }
.site-header.dark .burger-lines span { background: var(--color-creme); }
.site-header.is-stuck.dark .nav-link,
.site-header.is-stuck.dark .nav-logo span,
.site-header.is-stuck.dark .icon-btn { color: var(--color-foret); border-color: rgba(44, 56, 48, 0.2); }
.site-header.is-stuck.dark .burger-lines span { background: var(--color-foret); }
.site-header.is-stuck.dark .icon-btn:hover { background: var(--color-foret); color: var(--color-creme); }

.nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  max-width: 1500px;
  margin: 0 auto;
  gap: 24px;
}
@media (min-width: 768px) { .nav-row { padding: 0 56px; } }

.nav-logo { display: inline-flex; align-items: center; gap: 14px; }
.nav-logo img {
  height: 74px;
  width: auto;
  object-fit: contain;
  transition: opacity .3s ease, height .3s ease;
}
.site-header.is-stuck .nav-logo img,
.site-header.mega-open .nav-logo img { height: 58px; }
.nav-logo:hover img { opacity: 0.85; }
/* Swap logo : clair sur le hero sombre / foncé quand le header est collé (fond crème) */
.nav-logo .logo-on-light { display: none; }
.site-header.is-stuck .nav-logo .logo-on-dark { display: none; }
.site-header.is-stuck .nav-logo .logo-on-light { display: block; }

.nav-links-desktop { display: none; }
.nav-actions-desktop { display: none; }
.burger { display: inline-flex; }
@media (min-width: 1024px) {
  .nav-links-desktop  { display: flex; }
  .nav-actions-desktop { display: inline-flex; }
  .burger              { display: none; }
}

.nav-links-desktop {
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
  gap: 28px;
  width: max-content;
  max-width: none;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.nav-link {
  font-family: var(--font-body);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-foret);
  position: relative;
  padding: 6px 0;
  white-space: nowrap;
  transition: color .3s ease;
}
@media (min-width: 1024px) and (max-width: 1400px) {
  .nav-links-desktop { gap: 20px; }
  .nav-link { letter-spacing: 0.13em; }
}
.nav-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .35s cubic-bezier(.6,.05,.3,1);
}
.nav-link:hover, .nav-link:focus-visible { color: var(--color-terracotta); }
.nav-link:hover::after, .nav-link:focus-visible::after, .nav-link.active::after { transform: scaleX(1); }
.nav-link.active { color: var(--color-terracotta); }
.nav-link:focus-visible { outline: none; }

.nav-actions-desktop { align-items: center; gap: 14px; }
.icon-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid rgba(44, 56, 48, 0.2);
  color: var(--color-foret);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: relative;
  transition: all .3s ease;
}
.icon-btn:hover { background: var(--color-foret); color: var(--color-creme); border-color: var(--color-foret); }
.icon-btn .badge {
  position: absolute;
  top: -3px;
  right: -3px;
  background: var(--color-terracotta);
  color: var(--color-creme);
  font-size: 0.6rem;
  border-radius: 999px;
  min-width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 5px;
  border: 2px solid var(--color-creme);
  font-family: var(--font-body);
}

.burger {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(44, 56, 48, 0.2);
  background: transparent;
  align-items: center; justify-content: center;
  cursor: pointer; padding: 0;
}
.burger-lines { display: inline-flex; flex-direction: column; gap: 4px; }
.burger-lines span { display: block; width: 18px; height: 1.5px; background: var(--color-foret); transition: transform .3s ease, opacity .3s ease; }
.burger[aria-expanded="true"] .burger-lines span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.burger[aria-expanded="true"] .burger-lines span:nth-child(2) { opacity: 0; }
.burger[aria-expanded="true"] .burger-lines span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--color-creme);
  z-index: 100;
  padding: 100px 32px 60px;
  overflow-y: auto;
  transform: translateY(-100%);
  transition: transform .5s cubic-bezier(.6,.05,.3,1);
}
.mobile-menu[aria-hidden="false"] { transform: translateY(0); }
.mobile-menu ul { list-style: none; padding: 0; margin: 0; }
.mobile-menu li { border-bottom: 1px solid rgba(44, 56, 48, 0.08); }
.mobile-menu li a {
  display: block;
  padding: 22px 0;
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--color-foret);
  font-weight: 300;
}
.mobile-menu li a:hover { color: var(--color-terracotta); font-style: italic; }

/* ============================================================
   MÉGA-MENU BOUTIQUE
   ============================================================ */
/* Header en mode clair quand le méga est ouvert (même au-dessus du hero) */
.site-header.mega-open { background: rgba(245, 240, 225, 0.98); backdrop-filter: blur(20px); padding-top: 12px; padding-bottom: 12px; border-bottom: 1px solid rgba(44, 56, 48, 0.08); }
.site-header.mega-open .nav-link,
.site-header.mega-open .icon-btn { color: var(--color-foret); border-color: rgba(44, 56, 48, 0.2); }
.site-header.mega-open .icon-btn:hover { background: var(--color-foret); color: var(--color-creme); }
.site-header.mega-open .burger-lines span { background: var(--color-foret); }
.site-header.mega-open .nav-logo .logo-on-dark { display: none; }
.site-header.mega-open .nav-logo .logo-on-light { display: block; }

.mega {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-creme);
  border-top: 1px solid rgba(44, 56, 48, 0.08);
  box-shadow: 0 32px 60px rgba(44, 56, 48, 0.14);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-12px);
  transition: opacity .3s ease, transform .3s ease, visibility .3s;
  z-index: 60;
}
.mega.open { opacity: 1; visibility: visible; transform: translateY(0); }
@media (max-width: 1023px) { .mega { display: none; } }

/* Bandeau d'accès rapide (Notre gamme) */
.mega-quick {
  max-width: 1500px;
  margin: 0 auto;
  padding: 22px 56px;
  display: flex;
  flex-wrap: wrap;
  gap: 48px;
  border-bottom: 1px solid rgba(44, 56, 48, 0.1);
}
.mega-quick-link { display: flex; flex-direction: column; gap: 2px; }
.mega-quick-link strong { font-family: var(--font-display); font-weight: 300; font-size: 1.1rem; color: var(--color-foret); transition: color .2s ease; }
.mega-quick-link span { font-size: 0.74rem; color: var(--color-ink-muted); }
.mega-quick-link:hover strong { color: var(--color-terracotta); }
.mega-quick-link.is-destock strong { color: var(--color-vert); }
.mega-quick-link.is-destock:hover strong { color: var(--color-sauge); }

/* Panneaux simples (Gamme créative · Qui sommes-nous) */
.mega-inner--simple { grid-template-columns: minmax(280px, 360px) 1fr 320px; align-items: center; }
.mega-lead { padding-right: 28px; border-right: 1px solid rgba(44, 56, 48, 0.1); }
.mega-lead h4 { font-family: var(--font-display); font-style: normal; font-size: 1.5rem; color: var(--color-foret); text-transform: none; letter-spacing: 0; margin: 6px 0 12px; }
.mega-lead p { font-size: 0.92rem; color: var(--color-ink-soft); line-height: 1.7; margin: 0 0 18px; max-width: 340px; }
.mega-simple-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.mega-simple-list a { display: inline-flex; align-items: center; gap: 12px; font-family: var(--font-display); font-style: normal; font-size: 1.3rem; color: var(--color-foret); padding: 9px 0; transition: color .2s ease; }
.mega-simple-list a::before { content: ""; width: 12px; height: 1px; background: var(--color-sable); flex-shrink: 0; transition: width .25s ease, background .2s ease; }
.mega-simple-list a:hover { color: var(--color-terracotta); }
.mega-simple-list a:hover::before { width: 22px; background: var(--color-terracotta); }

/* Familles à venir */
.mega-soon { font-size: 0.96rem; color: var(--color-ink-muted); line-height: 1.75; max-width: 440px; font-style: italic; margin: 0; }

.mega-inner {
  max-width: 1500px;
  margin: 0 auto;
  padding: 44px 56px;
  display: grid;
  grid-template-columns: 280px 1fr 300px;
  gap: 52px;
  align-items: start;
}
.mega-label {
  display: block;
  font-size: 0.64rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-ink-muted);
  margin-bottom: 20px;
}

.mega-cats { display: flex; flex-direction: column; border-right: 1px solid rgba(44, 56, 48, 0.1); padding-right: 36px; }
.mega-cat {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  font-family: var(--font-display);
  font-size: 1.08rem;
  color: var(--color-foret);
  padding: 9px 0;
  border-bottom: 1px solid rgba(44, 56, 48, 0.08);
  transition: color .2s ease, padding-left .25s ease;
}
.mega-cat:last-of-type { border-bottom: none; }
.mega-cat svg { opacity: 0; transform: translateX(-6px); transition: opacity .25s ease, transform .25s ease; color: var(--color-terracotta); flex-shrink: 0; }
.mega-cat:hover, .mega-cat.active { color: var(--color-terracotta); padding-left: 8px; }
.mega-cat:hover svg, .mega-cat.active svg { opacity: 1; transform: translateX(0); }
.mega-allshop { margin-top: 24px; align-self: flex-start; }

.mega-products { min-height: 240px; }
.mega-panel { display: none; }
.mega-panel.active { display: block; animation: megaFade .3s ease; }
@keyframes megaFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.mega-panel-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 22px; padding-bottom: 14px; border-bottom: 1px solid rgba(44, 56, 48, 0.08); }
.mega-panel-head h4 { font-family: var(--font-display); font-style: italic; font-size: 1.4rem; color: var(--color-foret); text-transform: none; letter-spacing: 0; margin: 0; }
.mega-viewcat { font-size: 0.66rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-terracotta); white-space: nowrap; transition: color .2s ease; }
.mega-viewcat:hover { color: var(--color-foret); }
.mega-list { list-style: none; margin: 0; padding: 0; columns: 3; column-gap: 28px; }
.mega-list li { break-inside: avoid; margin-bottom: 11px; }
.mega-list a { display: inline-flex; align-items: center; gap: 10px; font-size: 0.92rem; color: var(--color-ink-soft); transition: color .2s ease; }
.mega-list a::before { content: ""; width: 9px; height: 1px; background: var(--color-sable); flex-shrink: 0; transition: width .25s ease, background .2s ease; }
.mega-list a:hover { color: var(--color-terracotta); }
.mega-list a:hover::before { width: 18px; background: var(--color-terracotta); }

.mega-feature {
  display: block;
  position: relative;
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--color-foret);
  isolation: isolate;
}
.mega-feature img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; opacity: 0.9; transition: transform .6s ease; }
.mega-feature:hover img { transform: scale(1.05); }
.mega-feature::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(44, 56, 48, 0.85) 100%); z-index: 1; }
.mega-feature-body { position: absolute; inset: auto 0 0 0; z-index: 2; padding: 22px; display: flex; flex-direction: column; gap: 4px; }
.mega-feature-eyebrow { font-size: 0.6rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--color-vert-soft); }
.mega-feature-body strong { font-family: var(--font-display); font-weight: 300; font-size: 1.2rem; color: var(--color-creme); font-style: italic; }
.mega-feature-link { font-size: 0.68rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-creme); margin-top: 8px; }

.mega a:focus-visible { outline: 2px solid var(--color-terracotta); outline-offset: 3px; border-radius: 2px; }

/* ============================================================
   BUTTONS — base éditoriale V2 (sharp) + variantes unifiées
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 32px;
  font-family: var(--font-body);
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 400;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all .35s cubic-bezier(.6,.05,.3,1);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}
.btn .arrow { transition: transform .35s ease; display: inline-block; }
.btn:hover .arrow { transform: translateX(6px); }

.btn--terracotta { background: var(--color-terracotta); color: var(--color-creme); }
.btn--terracotta:hover { background: var(--color-terracotta-deep); }

.btn--foret { background: var(--color-foret); color: var(--color-creme); }
.btn--foret:hover { background: var(--color-sauge); }

/* alias V1 → mappés sur le système V2 */
.btn--primary { background: var(--color-foret); color: var(--color-creme); }
.btn--primary:hover { background: var(--color-sauge); }

.btn--cream { background: var(--color-creme); color: var(--color-foret); }
.btn--cream:hover { background: var(--color-creme-deep); }

.btn--outline-dark, .btn--ghost { background: transparent; color: var(--color-foret); border-color: var(--color-foret); }
.btn--outline-dark:hover, .btn--ghost:hover { background: var(--color-foret); color: var(--color-creme); }

.btn--outline-light, .btn--ghost-light { background: transparent; color: var(--color-creme); border-color: rgba(245, 240, 225, 0.5); }
.btn--outline-light:hover, .btn--ghost-light:hover { background: var(--color-creme); color: var(--color-foret); border-color: var(--color-creme); }

.link-underline {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-body);
  font-size: 0.72rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-foret);
  border-bottom: 1px solid var(--color-terracotta);
  padding-bottom: 6px;
  transition: gap .3s ease, color .3s ease;
}
.link-underline:hover { gap: 18px; color: var(--color-terracotta); }

.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-vert);
  border-bottom: 1px solid currentColor;
  padding-bottom: 4px;
  transition: gap .3s ease, color .3s ease;
}
.link-arrow:hover { gap: 14px; color: var(--color-foret); }

/* ============================================================
   HERO — typographique full-bleed (V2)
   ============================================================ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--color-foret);
  color: var(--color-creme);
  overflow: hidden;
  isolation: isolate;
  padding: 180px 0 100px;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../images/hero-botanic.jpg') center/cover;
  opacity: 0.55;
  z-index: 0;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(44, 56, 48, 0.55) 0%, rgba(44, 56, 48, 0.85) 100%);
  z-index: 1;
}
.hero-emblem {
  position: absolute;
  right: -3%;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(300px, 38vw, 560px);
  height: auto;
  opacity: 0.18;
  z-index: 2;
  pointer-events: none;
}
@media (max-width: 900px) { .hero-emblem { opacity: 0.10; right: -25%; } }

.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}
@media (min-width: 768px) { .hero-inner { padding: 0 48px; } }

.hero .eyebrow { color: var(--color-vert-soft); margin-bottom: 36px; }
.hero .eyebrow::before, .hero .eyebrow::after { background: var(--color-vert-soft); }

.hero h1 {
  color: var(--color-creme);
  font-size: clamp(2.4rem, 5.2vw, 4.6rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0 0 0.4em;
  max-width: 900px;
}
.hero h1 .it { font-style: normal; color: var(--color-vert); }
.hero h1 .deco { display: inline-block; vertical-align: middle; margin: 0 8px; }
.hero h1 .deco svg { width: clamp(40px, 5vw, 80px); height: auto; }

.hero-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: space-between;
  gap: 32px 40px;
  margin-top: 44px;
  padding-top: 36px;
  border-top: 1px solid rgba(245, 240, 225, 0.18);
}
.hero-lede {
  max-width: 460px;
  font-size: 1rem;
  line-height: 1.75;
  color: rgba(245, 240, 225, 0.85);
}
.hero-cta { display: flex; gap: 16px; flex-wrap: wrap; }

/* Stats — en ligne, dans le flux (plus de chevauchement) */
.hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(32px, 5vw, 72px);
  margin-top: 44px;
}
.hero-stats .stat { display: flex; flex-direction: column; gap: 6px; }
.hero-stats .stat strong {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3vw, 2.8rem);
  color: var(--color-vert);
  font-weight: 300;
  line-height: 1;
  order: -1;
}
.hero-stats .stat span {
  font-size: 0.66rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: rgba(245, 240, 225, 0.7);
}

/* ============================================================
   STORY STRIP — réassurance éditoriale (V2)
   ============================================================ */
.story-strip {
  background: var(--color-creme-deep);
  padding: 32px 0;
  border-bottom: 1px solid rgba(44, 56, 48, 0.08);
}
.story-strip-inner {
  display: flex;
  gap: 56px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  font-size: 0.74rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-foret);
}
.story-strip-inner span { display: inline-flex; align-items: center; gap: 12px; }
.story-strip-inner svg { color: var(--color-terracotta); }

/* ============================================================
   EDITORIAL INTRO — À propos split (V2)
   ============================================================ */
.editorial-intro { background: linear-gradient(215deg, var(--color-sable) 0%, var(--color-creme) 60%); position: relative; }
.intro-grid { display: grid; grid-template-columns: 1fr; gap: 56px; align-items: center; }
@media (min-width: 1024px) { .intro-grid { grid-template-columns: 1fr 1.02fr; gap: 80px; align-items: stretch; } }
.intro-visual { position: relative; aspect-ratio: 4 / 5; overflow: hidden; }
@media (min-width: 1024px) { .intro-visual { aspect-ratio: auto; height: 100%; min-height: 560px; } }
.intro-visual img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9); }
.intro-visual::after {
  content: "";
  position: absolute;
  bottom: -40px; left: -40px; right: 40px; top: 40px;
  border: 1px solid var(--color-terracotta);
  z-index: -1;
}
.intro-visual .badge-floating {
  position: absolute;
  top: 24px; right: 24px;
  background: var(--color-creme);
  padding: 18px 24px;
  font-size: 0.68rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-foret);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.intro-visual .badge-floating strong {
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--color-terracotta);
  letter-spacing: -0.01em;
  text-transform: none;
  font-weight: 300;
}
.intro-text { display: flex; flex-direction: column; justify-content: center; }
.intro-text h2 { font-size: clamp(1.9rem, 3.1vw, 2.9rem); line-height: 1.1; margin-bottom: 26px; }
.intro-text .quote {
  position: relative;
  margin: 44px 0;
  padding: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.3rem, 1.9vw, 1.6rem);
  color: var(--color-foret);
  line-height: 1.55;
}
.intro-text .quote .quote-mark {
  display: block;
  font-family: var(--font-display);
  font-style: normal;
  font-size: 4.6rem;
  line-height: 0;
  height: 34px;
  color: var(--color-terracotta);
}
.intro-text .quote::after {
  content: "";
  display: block;
  width: 60px;
  height: 2px;
  background: var(--color-terracotta);
  margin-top: 28px;
}
.intro-cta-row { display: flex; gap: 32px; align-items: center; margin-top: 36px; flex-wrap: wrap; }

/* ============================================================
   CATÉGORIES — bento mosaïque asymétrique (V2, photos plein cadre)
   ============================================================ */
.bento { background: var(--color-surface-warm); position: relative; }
.bento-head { text-align: center; max-width: 760px; margin: 0 auto 80px; }
.bento-head h2 { margin: 0; }
.bento-head p { margin-top: 18px; }

.bento-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 900px) {
  .bento-grid {
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(4, 300px);
    gap: 20px;
  }
  .bento-grid .bento-item { min-height: 0; }
  /* Bande 1 : portrait · 2 empilées · portrait */
  .bento-item:nth-child(1) { grid-column: 1 / 3; grid-row: 1 / 3; }
  .bento-item:nth-child(2) { grid-column: 3 / 5; grid-row: 1; }
  .bento-item:nth-child(3) { grid-column: 3 / 5; grid-row: 2; }
  .bento-item:nth-child(4) { grid-column: 5 / 7; grid-row: 1 / 3; }
  /* Bande 2 : 2 empilées · portrait · 2 empilées */
  .bento-item:nth-child(5) { grid-column: 1 / 3; grid-row: 3; }
  .bento-item:nth-child(6) { grid-column: 1 / 3; grid-row: 4; }
  .bento-item:nth-child(7) { grid-column: 3 / 5; grid-row: 3 / 5; }
  .bento-item:nth-child(8) { grid-column: 5 / 7; grid-row: 3; }
  .bento-item:nth-child(9) { grid-column: 5 / 7; grid-row: 4; }
}

.bento-item {
  position: relative;
  overflow: hidden;
  background: var(--color-creme-deep);
  display: flex;
  align-items: end;
  color: var(--color-creme);
  isolation: isolate;
  min-height: 320px;
  border-radius: var(--radius-card);
  transition: transform .4s ease;
}
.bento-item:hover { transform: scale(1.01); }
.bento-item img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; transition: transform 1s ease; }
.bento-item:hover img { transform: scale(1.07); }
.bento-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(170deg, transparent 30%, rgba(44, 56, 48, 0.85) 100%); z-index: 1; }
.bento-item .body { position: relative; z-index: 2; padding: 32px; width: 100%; display: flex; flex-direction: column; gap: 4px; }
.bento-item .tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.62rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--color-creme);
  margin-bottom: 8px;
}
.bento-item .tag::before { content: "•"; color: var(--color-terracotta); }
.bento-item h3 { color: var(--color-creme); font-size: clamp(1.5rem, 2.2vw, 2.1rem); font-style: italic; margin: 0; }
.bento-item .meta { font-size: 0.92rem; color: rgba(245, 240, 225, 0.82); margin: 6px 0 0; max-width: 46ch; }
.bento-go {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  font-size: 0.7rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-creme);
}
.bento-go svg { transition: transform .3s ease; }
.bento-item:hover .bento-go svg { transform: translateX(4px); }

/* ============================================================
   E-COMMERCE — Best-sellers / Nouveautés (V1, vignettes robustes)
   ============================================================ */
.bestsellers { background: var(--color-creme); }
.section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 56px;
}
.section-head .lead { max-width: 620px; }
.section-head h2 { margin-bottom: 0; }
.nouveautes .section-head .lead { max-width: none; }

.products-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (min-width: 768px) { .products-grid { grid-template-columns: repeat(3, 1fr); gap: 32px; } }
@media (min-width: 1100px) { .products-grid { grid-template-columns: repeat(4, 1fr); } }

.product-card {
  background: var(--color-creme-soft);
  border-radius: var(--radius-card);
  overflow: hidden;
  position: relative;
  transition: transform .35s ease, box-shadow .35s ease;
  display: flex;
  flex-direction: column;
}
.product-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-hover); }
.product-card .media { position: relative; aspect-ratio: 1 / 1.1; overflow: hidden; background: var(--color-sable); }
.product-card .media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.product-card .media-link { display: block; width: 100%; height: 100%; }
.product-card:hover .media img { transform: scale(1.06); }
.product-card .name a { color: inherit; text-decoration: none; transition: color .2s ease; }
.product-card .name a:hover { color: var(--color-terracotta); }
.product-card .tag {
  position: absolute;
  top: 14px; left: 14px;
  padding: 5px 10px;
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--color-vert);
  color: var(--color-foret);
  border-radius: 4px;
  z-index: 2;
}
.product-card .tag--new { background: var(--color-foret); color: var(--color-creme); }
.product-card .tag--promo { background: var(--color-terracotta); }
.product-card .quick-btn {
  position: absolute;
  bottom: 14px; right: 14px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--color-creme);
  color: var(--color-foret);
  border: none;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease, background .25s ease;
  box-shadow: var(--shadow-soft);
}
.product-card:hover .quick-btn { opacity: 1; transform: translateY(0); }
.product-card .quick-btn:hover { background: var(--color-foret); color: var(--color-creme); }
.product-card .body { padding: 22px 22px 26px; display: flex; flex-direction: column; gap: 8px; }
.product-card .category { font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-vert); }
.product-card .name { font-family: var(--font-display); font-size: 1.18rem; color: var(--color-foret); margin: 0; }
.product-card .meta { font-size: 0.82rem; color: var(--color-ink-muted); }
.product-card .price-row { display: flex; align-items: baseline; gap: 10px; margin-top: 4px; }
.product-card .price { font-family: var(--font-display); font-size: 1.35rem; color: var(--color-foret); }
.product-card .price-old { font-size: 0.85rem; color: var(--color-ink-muted); text-decoration: line-through; }
.product-card .price-ht { font-size: 0.72rem; color: var(--color-ink-muted); letter-spacing: 0.04em; }

/* ============================================================
   TIMELINE / MÉTHODE — frise éditoriale (V2)
   ============================================================ */
.timeline { background: var(--color-creme); position: relative; }
.timeline-head { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: end; margin-bottom: 80px; }
@media (min-width: 1024px) { .timeline-head { grid-template-columns: 1.1fr 0.9fr; gap: 80px; } }
.timeline-head .lead-text { color: var(--color-ink-soft); font-size: 1.05rem; line-height: 1.85; }
.timeline-grid { display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1px solid rgba(44, 56, 48, 0.15); }
@media (min-width: 768px) { .timeline-grid { grid-template-columns: repeat(3, 1fr); border-top: none; } }
.timeline-step { padding: 56px 24px; border-bottom: 1px solid rgba(44, 56, 48, 0.1); position: relative; transition: background .35s ease; }
@media (min-width: 768px) {
  .timeline-step { border-bottom: none; border-right: 1px solid rgba(44, 56, 48, 0.15); padding: 56px 36px; }
  .timeline-step:last-child { border-right: none; padding-right: 0; }
  .timeline-step:first-child { padding-left: 0; }
}
.timeline-step::before { content: ""; position: absolute; top: -1px; left: 0; width: 60px; height: 1px; background: var(--color-terracotta); }
.timeline-step .step-num {
  font-family: var(--font-display);
  font-size: 5.5rem;
  color: var(--color-terracotta);
  line-height: 1;
  font-weight: 300;
  font-style: italic;
  margin-bottom: 28px;
  display: block;
}
.timeline-step h3 { font-size: 1.6rem; margin: 0 0 16px; color: var(--color-foret); }
.timeline-step p { color: var(--color-ink-soft); font-size: 0.96rem; margin: 0; }

/* ============================================================
   PROMO BANNER (V1)
   ============================================================ */
.promo-banner { background: linear-gradient(120deg, var(--color-sable) 0%, var(--color-creme) 60%); position: relative; overflow: hidden; }
.promo-grid { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center; }
@media (min-width: 900px) { .promo-grid { grid-template-columns: 1fr 1.1fr; gap: 56px; } }
.promo-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--color-terracotta);
  color: var(--color-creme);
  padding: 8px 14px;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border-radius: 4px;
  margin-bottom: 20px;
}
.promo-banner h2 { color: var(--color-foret); margin-bottom: 18px; }
.promo-banner p { color: var(--color-ink-soft); font-size: 1.02rem; max-width: 480px; }
.promo-visual { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.promo-visual img { width: 100%; aspect-ratio: 1 / 1.3; object-fit: cover; border-radius: var(--radius-card); }
.promo-visual img:nth-child(2) { transform: translateY(24px); }

/* ============================================================
   DUO PROS / PARTICULIERS — bande sombre (V1)
   ============================================================ */
.duo { background: var(--color-sauge); color: var(--color-creme); }
.duo h2 { color: var(--color-creme); }
.duo .section-head .lead { max-width: none; }
.duo .section-head p { max-width: 600px; }
.duo .duo-grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 900px) { .duo .duo-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; } }
.duo-card { background: var(--color-sauge); border-radius: var(--radius-card); padding: 44px 36px 40px; position: relative; overflow: hidden; transition: transform .35s ease; }
.duo-card:hover { transform: translateY(-6px); }
.duo-card::before { content: ""; position: absolute; top: -40px; right: -40px; width: 180px; height: 180px; border-radius: 50%; background: rgba(125, 184, 125, 0.12); }
.duo-card .num { font-family: var(--font-display); font-size: 0.9rem; letter-spacing: 0.2em; color: var(--color-vert); margin-bottom: 18px; display: block; text-transform: uppercase; }
.duo-card h3 { color: var(--color-creme); font-size: 1.7rem; margin: 0 0 16px; }
.duo-card p { color: var(--color-ink-on-dark-soft); margin: 0 0 24px; }
.duo-card.is-pro { background: var(--color-foret); }
.duo-card.is-particulier { background: var(--color-terracotta); }
.duo-card.is-particulier p { color: var(--color-creme); }
.duo-card.is-particulier .num { background: transparent; color: var(--color-creme); }
.duo-card.is-particulier::before { background: rgba(245, 240, 225, 0.15); }

/* ============================================================
   ENGAGEMENTS — grille 5 colonnes (V1)
   ============================================================ */
.commitments { background: var(--color-foret); color: var(--color-creme); }
.commitments h2 { color: var(--color-creme); margin-bottom: 14px; }
.commitments .lead-text { color: var(--color-ink-on-dark-soft); max-width: 620px; margin-bottom: 56px; }
.commitments-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: rgba(245, 240, 225, 0.1);
  border-radius: var(--radius-card);
  overflow: hidden;
}
@media (min-width: 768px) { .commitments-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .commitments-grid { grid-template-columns: repeat(5, 1fr); } }
.commit-item { background: var(--color-foret); padding: 36px 28px; display: flex; flex-direction: column; gap: 12px; position: relative; transition: background .3s ease; }
.commit-item:hover { background: var(--color-sauge); }
.commit-item .num { font-family: var(--font-display); font-size: 0.85rem; color: var(--color-vert); letter-spacing: 0.2em; }
.commit-item h4 { font-family: var(--font-display); font-size: 1.25rem; color: var(--color-creme); text-transform: none; letter-spacing: 0; margin: 0 0 6px; font-weight: 300; }
.commit-item p { font-size: 0.86rem; color: var(--color-ink-on-dark-soft); margin: 0; line-height: 1.55; }

/* ============================================================
   PRODUCERS — polaroïd éditorial (V2)
   ============================================================ */
.producers { background: linear-gradient(45deg, var(--color-sable) 0%, var(--color-creme) 60%); position: relative; }
.producers-grid { display: grid; grid-template-columns: 1fr; gap: 56px; align-items: center; }
@media (min-width: 1024px) { .producers-grid { grid-template-columns: 1fr 0.95fr; gap: 80px; align-items: stretch; } }
.producers-text { display: flex; flex-direction: column; justify-content: center; }
.producers-text h2 { font-style: italic; font-size: clamp(1.9rem, 3.1vw, 2.9rem); line-height: 1.1; margin-bottom: 24px; }
.producers-text .signature {
  font-family: var(--font-display);
  font-size: 1rem;
  font-style: italic;
  color: var(--color-terracotta);
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(44, 56, 48, 0.15);
  display: inline-block;
}
.producers-visual { position: relative; aspect-ratio: 4 / 5; }
@media (min-width: 1024px) { .producers-visual { aspect-ratio: auto; height: 100%; min-height: 560px; } }
.producers-visual img { width: 100%; height: 100%; object-fit: cover; }
.producers-visual .polaroid-tape {
  position: absolute;
  top: -18px; left: 50%;
  transform: translateX(-50%) rotate(-3deg);
  width: 180px; height: 36px;
  background: rgba(245, 240, 225, 0.7);
  border: 1px dashed rgba(44, 56, 48, 0.2);
}
.producers-visual .caption-tag {
  position: absolute;
  bottom: -32px; right: -24px;
  background: var(--color-foret);
  color: var(--color-creme);
  padding: 14px 24px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  z-index: 3;
}

/* ============================================================
   NEWSLETTER — 2 colonnes (V1)
   ============================================================ */
.newsletter { background: var(--color-creme); position: relative; overflow: hidden; }
.newsletter-inner { display: block; }
.newsletter-head { margin-bottom: 44px; }
.newsletter-body { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center; }
@media (min-width: 900px) { .newsletter-body { grid-template-columns: 1fr 1fr; gap: 80px; } }
.newsletter h2 { color: var(--color-foret); margin-bottom: 0; }
.newsletter-body p { margin-bottom: 0; }
.newsletter form {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: var(--color-creme-soft);
  border: 1px solid rgba(44, 56, 48, 0.15);
  border-radius: var(--radius-card);
  overflow: hidden;
  padding: 0;
}
.newsletter input[type="email"] {
  flex: 1;
  border: none;
  background: transparent;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-foret);
  padding: 16px 24px;
  min-width: 160px;
  outline: none;
}
.newsletter form .btn { border-radius: 0; flex-shrink: 0; }
.newsletter input[type="email"]::placeholder { color: var(--color-ink-muted); }
.newsletter .form-note { font-size: 0.78rem; color: var(--color-ink-muted); margin-top: 14px; }

/* ============================================================
   FAQ — accordéon côte-à-côte (V1)
   ============================================================ */
.faq { background: var(--color-surface-warm); }
.faq-wrap { display: grid; grid-template-columns: 1fr; gap: 44px; }
@media (min-width: 1024px) { .faq-wrap { grid-template-columns: 0.9fr 1.1fr; gap: 72px; } }
.faq-side h2 { margin-bottom: 18px; }
.faq-side p { color: var(--color-ink-soft); margin-bottom: 28px; }
.accordion { display: flex; flex-direction: column; gap: 12px; }
.acc-item { background: var(--color-creme-soft); border-radius: 14px; border: 1px solid rgba(44, 56, 48, 0.06); overflow: hidden; transition: border-color .25s ease; }
.acc-item.is-open { border-color: var(--color-vert); }
.acc-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: left;
  padding: 22px 24px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 1.1rem;
  color: var(--color-foret);
  font-weight: 300;
}
.acc-trigger .icon {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--color-foret);
  color: var(--color-creme);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-left: 16px;
  transition: transform .3s ease, background .25s ease;
}
.acc-item.is-open .acc-trigger .icon { transform: rotate(45deg); background: var(--color-vert); }
.acc-content { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.acc-content > div { padding: 0 24px 24px; color: var(--color-ink-soft); font-size: 0.95rem; line-height: 1.7; }

/* ============================================================
   FOOTER — éditorial enrichi
   ============================================================ */
.site-footer {
  position: relative;
  background: var(--color-foret);
  color: rgba(245, 240, 225, 0.72);
  padding: clamp(72px, 9vw, 120px) 0 28px;
  overflow: hidden;
}
.footer-emblem {
  position: absolute;
  top: -70px; right: -90px;
  width: clamp(260px, 30vw, 460px);
  opacity: 0.05;
  pointer-events: none;
  z-index: 0;
}
.site-footer .container { position: relative; z-index: 1; }

/* TOP — marque + prise de contact */
.footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(245, 240, 225, 0.12);
}
@media (min-width: 900px) { .footer-top { grid-template-columns: 1.5fr 1fr; gap: 80px; align-items: start; } }
.footer-logo { height: 68px; width: auto; margin-bottom: 26px; }
.footer-intro p { color: rgba(245, 240, 225, 0.68); max-width: 460px; line-height: 1.8; font-size: 0.96rem; }
.footer-reach { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; }
@media (min-width: 900px) { .footer-reach { align-items: flex-end; text-align: right; } }
.footer-reach .eyebrow { color: var(--color-vert-soft); margin-bottom: 10px; }
.footer-reach .eyebrow::before, .footer-reach .eyebrow::after { background: var(--color-vert-soft); }
.footer-bigmail {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  color: var(--color-creme);
  line-height: 1.2;
  transition: color .25s ease;
}
.footer-bigmail:hover { color: var(--color-vert); }
.footer-phone { font-size: 1.05rem; color: rgba(245, 240, 225, 0.8); letter-spacing: 0.04em; transition: color .25s ease; }
.footer-phone:hover { color: var(--color-creme); }
.footer-contact-btn { margin-top: 20px; }

/* GRID — colonnes de liens */
.footer-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 24px;
  padding: 56px 0;
}
@media (min-width: 900px) { .footer-grid { grid-template-columns: repeat(4, 1fr); gap: 48px; } }
.footer-col h5 { font-family: var(--font-body); font-size: 0.68rem; letter-spacing: 0.34em; text-transform: uppercase; color: var(--color-creme); margin: 0 0 22px; font-weight: 400; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 13px; }
.footer-col a { font-size: 0.9rem; color: rgba(245, 240, 225, 0.72); transition: color .2s ease; }
.footer-col a:hover { color: var(--color-vert); }
.footer-contact p { margin: 0 0 8px; font-size: 0.9rem; line-height: 1.65; color: rgba(245, 240, 225, 0.72); }
.footer-contact strong { color: var(--color-creme); font-weight: 500; }
.footer-hours { margin-top: 14px; }
/* Picots discrets devant les infos (adresse, horaires) de la colonne « Nous trouver » */
.footer-contact p + p { position: relative; padding-left: 16px; }
.footer-contact p + p::before {
  content: ""; position: absolute; left: 0; top: 0.62em;
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--color-vert); opacity: 0.65;
}

.footer-socials { display: flex; gap: 12px; margin-top: 24px; }
.footer-socials a {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(245, 240, 225, 0.08);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-creme);
  transition: background .25s ease;
}
.footer-socials a:hover { background: var(--color-terracotta); }

/* Réassurance */
.footer-reassurance {
  display: flex; flex-wrap: wrap; gap: 16px 40px;
  align-items: center; justify-content: center;
  padding: 30px 0;
  border-top: 1px solid rgba(245, 240, 225, 0.12);
  border-bottom: 1px solid rgba(245, 240, 225, 0.12);
  font-size: 0.72rem; letter-spacing: 0.26em; text-transform: uppercase;
  color: rgba(245, 240, 225, 0.72);
}
.footer-reassurance span { display: inline-flex; align-items: center; gap: 12px; }
.footer-reassurance svg { color: var(--color-vert); flex-shrink: 0; }

/* Bottom */
.footer-bottom {
  margin-top: clamp(40px, 5vw, 64px);
  padding-top: 28px;
  border-top: 1px solid rgba(245, 240, 225, 0.1);
  display: flex; flex-direction: column; gap: 18px;
  align-items: center; text-align: center;
}
@media (min-width: 900px) { .footer-bottom { flex-direction: row; justify-content: space-between; text-align: left; } }
.footer-bottom .legal-links { display: flex; gap: 24px; flex-wrap: wrap; justify-content: center; font-size: 0.82rem; }
.footer-bottom .legal-links a:hover { color: var(--color-vert); }
.footer-bottom .copy { font-size: 0.82rem; margin: 0; color: rgba(245, 240, 225, 0.72); }
.footer-pay { display: flex; align-items: center; gap: 8px; }
.footer-pay .chip {
  min-width: 40px; height: 26px; padding: 0 6px; border-radius: 4px;
  background: rgba(245, 240, 225, 0.1);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.56rem; letter-spacing: 0.06em; color: rgba(245, 240, 225, 0.78);
  font-family: var(--font-body);
}

.readyup-credit {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  font-size: 12px;
  color: rgba(245, 240, 225, 0.55);
  text-align: center;
  margin: 22px 0 0;
  padding-top: 16px;
  border-top: 1px solid rgba(245, 240, 225, 0.08);
}
.readyup-label { letter-spacing: 0.02em; }
.readyup-credit-link { display: inline-flex; align-items: center; color: var(--color-creme); opacity: 0.8; transition: opacity .2s ease; }
.readyup-credit-link:hover, .readyup-credit-link:focus-visible { opacity: 1; }
.readyup-credit-link svg { height: 15px; width: auto; display: block; }
.photo-credits { font-size: 11px; color: rgba(245, 240, 225, 0.4); text-align: center; margin: 10px 0 0; }

.site-footer a:focus-visible { outline: 2px solid var(--color-vert); outline-offset: 3px; border-radius: 2px; }

/* ============================================================
   MENTIONS LÉGALES
   ============================================================ */
.mentions-legales { padding: 180px 0 100px; background: var(--color-creme); }
.mentions-legales h1 { font-size: clamp(2.4rem, 5vw, 4rem); margin-bottom: 48px; font-style: italic; }
.mentions-legales h2 { font-size: clamp(1.4rem, 2vw, 1.8rem); margin: 56px 0 16px; color: var(--color-foret); }
.mentions-legales p, .mentions-legales li { color: var(--color-ink-soft); line-height: 1.85; font-size: 0.96rem; }
.mentions-legales ul { padding-left: 22px; }
.mentions-legales a { color: var(--color-terracotta); text-decoration: underline; }
.mentions-legales a:hover { color: var(--color-foret); }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal { opacity: 0; transform: translateY(40px); transition: opacity 1s ease, transform 1s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-stagger > * { opacity: 0; transform: translateY(30px); transition: opacity .8s ease, transform .8s ease; }
.reveal-stagger.is-visible > * { opacity: 1; transform: translateY(0); }
.reveal-stagger.is-visible > *:nth-child(1) { transition-delay: 0s; }
.reveal-stagger.is-visible > *:nth-child(2) { transition-delay: .12s; }
.reveal-stagger.is-visible > *:nth-child(3) { transition-delay: .24s; }
.reveal-stagger.is-visible > *:nth-child(4) { transition-delay: .36s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal, .reveal-stagger > * { opacity: 1; transform: none; }
}

/* ============================================================
   HEADER SOLIDE — pages sans hero (catalogue, etc.)
   ============================================================ */
.site-header.is-solid {
  position: sticky;
  top: 0;
  background: rgba(245, 240, 225, 0.97);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(44, 56, 48, 0.08);
  padding-top: 12px;
  padding-bottom: 12px;
}
.site-header.is-solid .nav-link,
.site-header.is-solid .icon-btn { color: var(--color-foret); border-color: rgba(44, 56, 48, 0.2); }
.site-header.is-solid .icon-btn:hover { background: var(--color-foret); color: var(--color-creme); }
.site-header.is-solid .burger-lines span { background: var(--color-foret); }
.site-header.is-solid .nav-logo .logo-on-dark { display: none; }
.site-header.is-solid .nav-logo .logo-on-light { display: block; }
.site-header.is-solid .nav-logo img { height: 58px; }

/* ============================================================
   PAGE CATALOGUE / BOUTIQUE (archive WooCommerce)
   ============================================================ */
.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; }

.cat-hero { background: linear-gradient(135deg, var(--color-sable) 0%, var(--color-creme) 60%); padding: clamp(36px, 5vw, 56px) 0 clamp(32px, 4vw, 44px); border-bottom: 1px solid rgba(44, 56, 48, 0.08); position: relative; }
.breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-ink-muted); margin-bottom: 22px; }
.breadcrumb a { color: var(--color-ink-soft); transition: color .2s ease; }
.breadcrumb a:hover { color: var(--color-terracotta); }
.breadcrumb > span[aria-hidden] { color: var(--color-sable); }
.breadcrumb span[aria-current] { color: var(--color-foret); }

.cat-hero-row { display: grid; grid-template-columns: 1fr; gap: 22px; align-items: end; }
@media (min-width: 920px) { .cat-hero-row { grid-template-columns: 1fr 1fr; gap: 56px; } }
.cat-hero h1 { font-size: clamp(2.3rem, 5vw, 3.6rem); font-style: italic; margin: 10px 0 0; }
.cat-hero p { color: var(--color-ink-soft); max-width: 520px; margin: 0; font-size: 0.96rem; line-height: 1.75; }
@media (min-width: 920px) { .cat-intro { padding-bottom: 6px; } }

.cat-search { display: flex; align-items: stretch; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.18); border-radius: var(--radius-card); overflow: hidden; }
.cat-search input { flex: 1; min-width: 0; border: none; background: transparent; padding: 16px 20px; font-family: var(--font-body); font-size: 0.92rem; color: var(--color-foret); outline: none; }
.cat-search input::placeholder { color: var(--color-ink-muted); }
.cat-search button { flex-shrink: 0; background: var(--color-foret); color: var(--color-creme); border: none; padding: 0 22px; cursor: pointer; display: inline-flex; align-items: center; transition: background .25s ease; }
.cat-search button:hover { background: var(--color-sauge); }

.shop { padding: clamp(40px, 5vw, 56px) 0 100px; }
.shop-grid { display: grid; grid-template-columns: 1fr; gap: 40px; }
@media (min-width: 1024px) { .shop-grid { grid-template-columns: 270px 1fr; gap: 56px; align-items: start; } }

/* Sidebar filtres */
.shop-filters { display: flex; flex-direction: column; gap: 28px; }
@media (min-width: 1024px) { .shop-filters { position: sticky; top: 120px; } }
.filter-group { border-bottom: 1px solid rgba(44, 56, 48, 0.1); padding-bottom: 26px; }
.filter-group:last-child { border-bottom: none; padding-bottom: 0; }
.filter-group h3 { font-family: var(--font-body); font-size: 0.68rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--color-foret); margin: 0 0 16px; font-weight: 500; }
.filter-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.filter-list label { display: flex; align-items: center; gap: 11px; font-size: 0.9rem; color: var(--color-ink-soft); cursor: pointer; transition: color .2s ease; }
.filter-list label:hover { color: var(--color-foret); }
.filter-list input[type="checkbox"] { appearance: none; -webkit-appearance: none; width: 17px; height: 17px; border: 1px solid rgba(44, 56, 48, 0.3); border-radius: 3px; flex-shrink: 0; cursor: pointer; position: relative; transition: background .2s ease, border-color .2s ease; }
.filter-list input[type="checkbox"]:checked { background: var(--color-terracotta); border-color: var(--color-terracotta); }
.filter-list input[type="checkbox"]:checked::after { content: ""; position: absolute; left: 5px; top: 2px; width: 4px; height: 8px; border: solid var(--color-creme); border-width: 0 2px 2px 0; transform: rotate(45deg); }
.filter-list input[type="checkbox"]:focus-visible { outline: 2px solid var(--color-terracotta); outline-offset: 2px; }
.filter-list .count { margin-left: auto; font-size: 0.76rem; color: var(--color-ink-muted); }
.filter-list .count.soon { font-style: italic; color: var(--color-sable); text-transform: lowercase; letter-spacing: 0.02em; }

.filter-price { display: flex; align-items: center; gap: 10px; }
.filter-price input { width: 100%; min-width: 0; border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card); padding: 10px 11px; font-family: var(--font-body); font-size: 0.85rem; color: var(--color-foret); outline: none; background: var(--color-creme-soft); }
.filter-price span { color: var(--color-ink-muted); }
.filter-apply { margin-top: 14px; width: 100%; justify-content: center; padding: 12px; font-size: 0.66rem; }

.filter-group.filter-pro { background: var(--color-foret); color: var(--color-creme); border-radius: var(--radius-card); padding: 24px; }
.filter-pro h3 { color: var(--color-vert-soft); }
.filter-pro p { font-size: 0.85rem; color: rgba(245, 240, 225, 0.8); margin: 0 0 18px; line-height: 1.6; }
.filter-pro-btn { width: 100%; justify-content: center; padding: 13px 14px; font-size: 0.62rem; letter-spacing: 0.16em; }

/* Toolbar */
.shop-toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; padding-bottom: 22px; margin-bottom: 30px; border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.shop-count { font-size: 0.88rem; color: var(--color-ink-soft); }
.shop-count strong { color: var(--color-foret); font-weight: 500; }
.shop-sort { display: inline-flex; align-items: center; gap: 10px; font-size: 0.8rem; color: var(--color-ink-muted); }
.shop-sort select {
  font-family: var(--font-body); font-size: 0.85rem; color: var(--color-foret);
  border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card);
  padding: 9px 34px 9px 13px; cursor: pointer; outline: none;
  appearance: none; -webkit-appearance: none;
  background: var(--color-creme-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232C3830' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 11px center;
  background-size: 11px;
}

/* Grille produits */
.shop-products { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
@media (min-width: 1100px) { .shop-products { grid-template-columns: repeat(3, 1fr); gap: 28px; } }

.product-card .price-old { font-size: 0.82rem; color: var(--color-ink-muted); text-decoration: line-through; }

/* Pagination */
.pagination { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 60px; }
.pagination a, .pagination > span { min-width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(44, 56, 48, 0.15); font-size: 0.86rem; color: var(--color-ink-soft); transition: all .2s ease; }
.pagination a:hover { border-color: var(--color-foret); color: var(--color-foret); }
.pagination .is-current { background: var(--color-foret); color: var(--color-creme); border-color: var(--color-foret); }
.pagination .dots { border: none; }

/* ============================================================
   MODALE D'ARRIVÉE — Profil Pro / Particulier
   ============================================================ */
.welcome-modal {
  position: fixed; inset: 0; z-index: 2000;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  background: rgba(28, 36, 30, 0.55);
  backdrop-filter: blur(8px);
  opacity: 0; visibility: hidden;
  transition: opacity .45s ease, visibility .45s ease;
}
.welcome-modal.is-open { opacity: 1; visibility: visible; }
body.welcome-locked { overflow: hidden; }

.welcome-card {
  position: relative;
  width: 100%; max-width: 760px;
  background: linear-gradient(135deg, var(--color-sable) 0%, var(--color-creme) 55%);
  border: 1px solid rgba(245, 240, 225, 0.5);
  border-radius: 6px;
  padding: clamp(34px, 5vw, 60px) clamp(26px, 5vw, 64px) clamp(28px, 4vw, 48px);
  text-align: center;
  box-shadow: 0 40px 120px -30px rgba(28, 36, 30, 0.6);
  transform: translateY(18px) scale(0.98);
  opacity: 0;
  transition: transform .5s cubic-bezier(.2,.8,.25,1), opacity .5s ease;
}
.welcome-modal.is-open .welcome-card { transform: translateY(0) scale(1); opacity: 1; }

.welcome-emblem {
  display: inline-flex; align-items: center; justify-content: center;
  width: 74px; height: 74px; margin-bottom: 18px;
  border-radius: 50%;
  background: var(--color-foret);
  box-shadow: 0 14px 30px -12px rgba(28, 36, 30, 0.5);
}
.welcome-emblem img { width: 40px; height: 40px; object-fit: contain; }

.welcome-overline {
  display: block;
  font-size: 0.68rem; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--color-sauge); margin-bottom: 14px;
}
.welcome-title {
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  font-style: italic; line-height: 1.05;
  color: var(--color-foret); margin: 0 0 14px;
}
.welcome-sub {
  max-width: 46ch; margin: 0 auto 30px;
  font-size: 0.92rem; line-height: 1.65; color: var(--color-ink-soft);
}

.welcome-choices {
  display: grid; grid-template-columns: 1fr; gap: 16px;
  text-align: left;
}
@media (min-width: 620px) { .welcome-choices { grid-template-columns: 1fr 1fr; } }

.welcome-choice {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px;
  padding: 24px 22px 22px;
  background: rgba(251, 247, 236, 0.7);
  border: 1px solid rgba(44, 56, 48, 0.12);
  border-radius: 5px;
  cursor: pointer;
  transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
.welcome-choice:hover {
  transform: translateY(-3px);
  border-color: var(--color-foret);
  background: #fff;
  box-shadow: 0 22px 50px -24px rgba(28, 36, 30, 0.45);
}
.welcome-choice-eyebrow {
  font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--color-terracotta);
}
.welcome-choice-title {
  font-family: var(--font-display);
  font-size: 1.32rem; color: var(--color-foret); line-height: 1.15;
}
.welcome-choice-desc {
  font-size: 0.84rem; line-height: 1.6; color: var(--color-ink-soft);
  margin-bottom: 4px;
}
.welcome-choice-go {
  display: inline-flex; align-items: center; gap: 8px; margin-top: auto;
  font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-sauge);
  transition: gap .25s ease, color .25s ease;
}
.welcome-choice:hover .welcome-choice-go { color: var(--color-foret); gap: 12px; }
.welcome-choice-go svg { transition: transform .25s ease; }
.welcome-choice:hover .welcome-choice-go svg { transform: translateX(3px); }

.welcome-note {
  margin: 26px auto 0; max-width: 50ch;
  font-size: 0.7rem; line-height: 1.6; color: var(--color-ink-muted);
}

/* ============================================================
   FICHE PRODUIT (single product)
   ============================================================ */
.single-product-page { background: var(--color-creme); }
.product-top { padding: clamp(20px, 3vw, 30px) 0 clamp(40px, 6vw, 80px); }
.product-top .breadcrumb { margin-bottom: 30px; }

.product-main { display: grid; grid-template-columns: 1fr; gap: 40px; }
@media (min-width: 900px) { .product-main { grid-template-columns: 1.05fr 1fr; gap: 60px; align-items: start; } }
@media (min-width: 1200px) { .product-main { gap: 80px; } }

/* ----- Galerie ----- */
.product-gallery { display: flex; flex-direction: column; gap: 16px; }
@media (min-width: 900px) { .product-gallery { position: sticky; top: 110px; } }
.pg-stage {
  position: relative; overflow: hidden;
  border-radius: var(--radius-card);
  background: var(--color-creme-soft);
  aspect-ratio: 4 / 5;
}
.pg-stage img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pg-stage .tag {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  padding: 6px 12px; font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase;
  background: var(--color-vert); color: var(--color-foret); border-radius: 4px;
}
.pg-thumbs { display: flex; gap: 14px; }
.pg-thumb {
  flex: 1; max-width: 110px; aspect-ratio: 1 / 1; overflow: hidden; cursor: pointer;
  border: 1px solid rgba(44, 56, 48, 0.12); border-radius: var(--radius-card);
  background: var(--color-creme-soft); padding: 0;
  transition: border-color .25s ease, opacity .25s ease; opacity: 0.72;
}
.pg-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pg-thumb:hover { opacity: 1; }
.pg-thumb.is-active { border-color: var(--color-foret); opacity: 1; }

/* ----- Résumé / achat ----- */
.product-summary { display: flex; flex-direction: column; }
.ps-cat { font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-vert); margin-bottom: 12px; }
.ps-title { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05; color: var(--color-foret); margin: 0 0 14px; }
.ps-tagline { font-size: 1.02rem; line-height: 1.6; color: var(--color-ink-soft); font-style: italic; margin: 0 0 22px; }

.ps-price { display: flex; align-items: baseline; gap: 10px; padding-bottom: 22px; margin-bottom: 24px; border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.ps-price .price { font-family: var(--font-display); font-size: 2.1rem; color: var(--color-foret); }
.ps-tax { font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-ink-muted); }

.ps-excerpt { font-size: 0.94rem; line-height: 1.7; color: var(--color-ink-soft); margin: 0 0 28px; }
.ps-power { margin: 0 0 28px; }
.ps-power p { font-size: 0.94rem; line-height: 1.75; color: var(--color-ink-soft); margin: 0 0 14px; }
.ps-power p:last-child { margin-bottom: 0; }

/* ----- Attributs / variations ----- */
.ps-form { display: flex; flex-direction: column; gap: 24px; }
.ps-attr { display: flex; flex-direction: column; gap: 12px; }
.ps-attr-label { font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-ink-muted); }
.ps-options { display: flex; flex-wrap: wrap; gap: 10px; }
.ps-opt {
  padding: 12px 20px; cursor: pointer;
  font-family: var(--font-body); font-size: 0.82rem;
  background: transparent; color: var(--color-foret);
  border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card);
  transition: border-color .2s ease, background .2s ease, color .2s ease;
}
.ps-opt:hover { border-color: var(--color-foret); }
.ps-opt.is-selected { background: var(--color-foret); color: var(--color-creme); border-color: var(--color-foret); }

/* ----- Quantité + ajout panier ----- */
.ps-buy { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 4px; }
.ps-qty { display: inline-flex; align-items: center; border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card); overflow: hidden; }
.ps-qty-btn { width: 46px; height: 56px; border: none; background: transparent; cursor: pointer; font-size: 1.2rem; color: var(--color-foret); transition: background .2s ease; }
.ps-qty-btn:hover { background: var(--color-creme-deep); }
.ps-qty-val { width: 46px; height: 56px; text-align: center; border: none; border-left: 1px solid rgba(44, 56, 48, 0.12); border-right: 1px solid rgba(44, 56, 48, 0.12); background: transparent; font-family: var(--font-body); font-size: 0.95rem; color: var(--color-foret); }
.ps-qty-val:focus { outline: none; }
.ps-add { flex: 1; min-width: 220px; justify-content: center; background: var(--color-foret); color: var(--color-creme); }
.ps-add:hover { background: var(--color-sauge); }
.ps-add.is-done { background: var(--color-vert); color: var(--color-foret); }

/* ----- Réassurance ----- */
.ps-reassure { list-style: none; margin: 30px 0 0; padding: 24px 0 0; border-top: 1px solid rgba(44, 56, 48, 0.1); display: flex; flex-direction: column; gap: 12px; }
.ps-reassure li { display: flex; align-items: center; gap: 12px; font-size: 0.84rem; color: var(--color-ink-soft); }
.ps-reassure svg { color: var(--color-sauge); flex-shrink: 0; }

/* ----- Méta produit ----- */
.ps-meta { margin: 26px 0 0; padding-top: 22px; border-top: 1px solid rgba(44, 56, 48, 0.1); display: flex; flex-direction: column; gap: 10px; }
.ps-meta > div { display: flex; gap: 10px; font-size: 0.8rem; }
.ps-meta dt { color: var(--color-ink-muted); letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.68rem; min-width: 96px; padding-top: 1px; }
.ps-meta dd { margin: 0; color: var(--color-ink-soft); }
.ps-meta dd a { color: var(--color-sauge); text-decoration: underline; text-underline-offset: 3px; }
.ps-meta dd a:hover { color: var(--color-terracotta); }

/* ----- Détail (accordéons dans la colonne résumé) ----- */
.ps-accordions { margin-top: 30px; padding-top: 26px; border-top: 1px solid rgba(44, 56, 48, 0.1); }
.ps-accordions .acc-list { display: flex; flex-direction: column; gap: 12px; }
.ps-accordions .acc-item { border-radius: 10px; }
.ps-accordions .acc-trigger { font-size: 1rem; padding: 17px 20px; }
.ps-accordions .acc-trigger .icon { width: 28px; height: 28px; margin-left: 12px; }
.ps-accordions .acc-content > div { padding: 0 20px 22px; font-size: 0.9rem; }
.acc-lead { font-family: var(--font-display); font-size: 1.18rem; font-style: italic; color: var(--color-foret); margin: 0 0 14px; }
.ps-bullets { list-style: none; margin: 4px 0 16px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ps-bullets li { position: relative; padding-left: 22px; }
.ps-bullets li::before { content: ""; position: absolute; left: 0; top: 9px; width: 7px; height: 7px; border-radius: 50%; background: var(--color-vert); }
.ps-steps { margin: 4px 0 16px; padding-left: 20px; display: flex; flex-direction: column; gap: 10px; }
.ps-steps li { padding-left: 6px; }
.ps-steps li::marker { color: var(--color-terracotta); font-family: var(--font-display); font-weight: 600; }
.acc-content > div p strong { color: var(--color-foret); font-weight: 500; }
.acc-content > div p:last-child, .acc-content > div ul:last-child, .acc-content > div ol:last-child { margin-bottom: 0; }

/* ----- Produits liés ----- */
.related-products { padding: clamp(50px, 7vw, 90px) 0; }
.related-head { text-align: center; margin-bottom: 44px; }
.related-head h2 { font-family: var(--font-display); font-size: clamp(1.8rem, 3.5vw, 2.6rem); color: var(--color-foret); margin: 10px 0 0; }
@media (min-width: 1100px) { .related-grid { grid-template-columns: repeat(4, 1fr); } }

/* ============================================================
   TUNNEL D'ACHAT (panier · commande · confirmation)
   ============================================================ */
.tunnel-page { background: var(--color-creme); }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.tunnel-page .price { font-family: var(--font-display); color: var(--color-foret); }

/* ----- En-tête + étapes ----- */
.tunnel-head { background: linear-gradient(135deg, var(--color-sable) 0%, var(--color-creme) 60%); padding: clamp(24px, 4vw, 40px) 0 clamp(24px, 3vw, 34px); border-bottom: 1px solid rgba(44, 56, 48, 0.08); }
.tunnel-head .breadcrumb { margin-bottom: 16px; }
.tunnel-head h1 { font-family: var(--font-display); font-style: italic; font-size: clamp(1.9rem, 4vw, 3rem); color: var(--color-foret); margin: 0; }
.head-tag { display: inline-block; vertical-align: middle; margin-left: 12px; font-family: var(--font-body); font-style: normal; font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-sauge); background: rgba(125, 184, 125, 0.16); border: 1px solid rgba(74, 93, 78, 0.25); border-radius: 999px; padding: 5px 12px; }
.cart-devis-btn { width: 100%; justify-content: center; margin-top: 12px; }
.alt-devis { display: block; text-align: center; margin-top: 16px; font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-sauge); text-decoration: underline; text-underline-offset: 3px; }
.alt-devis:hover { color: var(--color-terracotta); }
.tunnel-steps { list-style: none; display: flex; flex-wrap: wrap; gap: 10px 26px; margin: 22px 0 0; padding: 0; }
.tunnel-steps li { display: inline-flex; align-items: center; gap: 9px; font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-ink-muted); }
.tunnel-steps .ts-num { width: 24px; height: 24px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 0.74rem; border: 1px solid rgba(44, 56, 48, 0.25); background: transparent; }
.tunnel-steps li.is-active { color: var(--color-foret); }
.tunnel-steps li.is-active .ts-num { background: var(--color-foret); color: var(--color-creme); border-color: var(--color-foret); }
.tunnel-steps li.is-done { color: var(--color-sauge); }
.tunnel-steps li.is-done .ts-num { background: var(--color-vert); color: var(--color-foret); border-color: var(--color-vert); }

.tunnel-body { padding: clamp(36px, 5vw, 64px) 0 clamp(60px, 8vw, 100px); }

/* ----- PANIER : disposition ----- */
.cart-layout { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start; }
@media (min-width: 1000px) { .cart-layout { grid-template-columns: 1fr 360px; gap: 56px; } }

.shop_table.cart { width: 100%; border-collapse: collapse; }
.shop_table.cart thead th { text-align: left; font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-ink-muted); font-weight: 400; padding: 0 0 16px; border-bottom: 1px solid rgba(44, 56, 48, 0.14); }
.shop_table.cart thead th.product-price, .shop_table.cart thead th.product-subtotal { text-align: right; }
.shop_table.cart thead th.product-quantity { text-align: center; }
.cart_item td { padding: 22px 0; border-bottom: 1px solid rgba(44, 56, 48, 0.1); vertical-align: middle; }
.cart_item .product-name { display: flex; align-items: center; gap: 18px; }
.ci-thumb { flex-shrink: 0; width: 84px; height: 84px; border-radius: var(--radius-card); overflow: hidden; background: var(--color-creme-soft); }
.ci-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ci-info { display: flex; flex-direction: column; gap: 5px; }
.ci-name { font-family: var(--font-display); font-size: 1.12rem; color: var(--color-foret); }
.ci-name:hover { color: var(--color-terracotta); }
.variation { margin: 0; display: flex; flex-wrap: wrap; gap: 4px 14px; }
.variation > div { display: flex; gap: 5px; font-size: 0.76rem; color: var(--color-ink-muted); }
.variation dt, .variation dd { margin: 0; }
.product-price, .product-subtotal { text-align: right; }
.product-price .price { font-size: 1rem; }
.product-subtotal .price { font-size: 1.15rem; }
.product-quantity { text-align: center; }
.product-quantity .ps-qty { display: inline-flex; }
.cart_item .ps-qty-btn { width: 38px; height: 44px; }
.cart_item .ps-qty-val { width: 40px; height: 44px; }
.product-remove { text-align: right; width: 40px; }
.ci-remove { width: 30px; height: 30px; border-radius: 50%; border: 1px solid rgba(44, 56, 48, 0.18); background: transparent; color: var(--color-ink-muted); font-size: 1.1rem; line-height: 1; cursor: pointer; transition: all .2s ease; }
.ci-remove:hover { background: var(--color-terracotta); border-color: var(--color-terracotta); color: #fff; }

.cart-actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 18px; margin-top: 26px; }
.coupon { display: flex; gap: 10px; }
.coupon .input-text { padding: 12px 16px; border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card); font-family: var(--font-body); font-size: 0.85rem; background: var(--color-creme-soft); min-width: 160px; }
.coupon .input-text:focus { outline: none; border-color: var(--color-foret); }
.btn-outline { background: transparent; color: var(--color-foret); border: 1px solid var(--color-foret); padding: 12px 22px; font-size: 0.66rem; letter-spacing: 0.18em; }
.btn-outline:hover { background: var(--color-foret); color: var(--color-creme); }
.continue-shopping { font-size: 0.82rem; color: var(--color-sauge); letter-spacing: 0.04em; }
.continue-shopping:hover { color: var(--color-terracotta); }

/* ----- Totaux (panier) ----- */
.cart_totals { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 12px; padding: 28px 26px; position: sticky; top: 110px; }
.cart_totals h2 { font-family: var(--font-display); font-size: 1.35rem; color: var(--color-foret); margin: 0 0 20px; }
.cart_totals .shop_table { width: 100%; }
.cart_totals .shop_table th { text-align: left; font-weight: 400; font-size: 0.85rem; color: var(--color-ink-soft); padding: 12px 0; vertical-align: top; }
.cart_totals .shop_table td { text-align: right; padding: 12px 0; }
.cart_totals .shop_table small { display: block; font-size: 0.68rem; color: var(--color-ink-muted); text-transform: none; letter-spacing: 0; margin-top: 2px; }
.cart_totals tr.cart-subtotal th, .cart_totals tr.cart-subtotal td, .cart_totals tr.shipping th, .cart_totals tr.shipping td { border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.order-total th { font-family: var(--font-display); font-size: 1.05rem; color: var(--color-foret); }
.order-total .total-price { font-size: 1.5rem; }

.shipping-methods { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.shipping-methods li { border: 1px solid rgba(44, 56, 48, 0.14); border-radius: var(--radius-card); transition: border-color .2s ease, background .2s ease; }
.shipping-methods li:has(input:checked) { border-color: var(--color-foret); background: rgba(125, 184, 125, 0.07); }
.shipping-methods label { display: grid; grid-template-columns: auto 1fr auto; align-items: center; column-gap: 12px; padding: 12px 14px; cursor: pointer; }
.shipping-methods input[type="radio"] { accent-color: var(--color-foret); width: 16px; height: 16px; }
.shipping-methods .sm-name { display: flex; flex-direction: column; gap: 2px; text-align: left; font-size: 0.85rem; color: var(--color-foret); }
.shipping-methods .sm-name small { font-size: 0.68rem; color: var(--color-ink-muted); }
.shipping-methods .sm-price { font-family: var(--font-display); color: var(--color-foret); text-align: right; white-space: nowrap; }
.cart_totals .shipping td { text-align: left; padding-top: 4px; }
.ship-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.ship-list li { display: grid; grid-template-columns: 1fr auto; column-gap: 10px; }
.ship-list .sl-name { font-size: 0.85rem; color: var(--color-foret); }
.ship-list .sl-price { font-family: var(--font-display); color: var(--color-foret); text-align: right; }
.ship-list small { grid-column: 1 / -1; font-size: 0.68rem; color: var(--color-ink-muted); margin-top: 1px; }

.checkout-button { width: 100%; justify-content: center; background: var(--color-foret); color: var(--color-creme); margin-top: 22px; }
.checkout-button:hover { background: var(--color-sauge); }
.cart-devis-link { display: block; text-align: center; margin-top: 14px; font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-sauge); text-decoration: underline; text-underline-offset: 3px; }
.cart-devis-link:hover { color: var(--color-terracotta); }
.tunnel-reassure { list-style: none; margin: 22px 0 0; padding: 18px 0 0; border-top: 1px solid rgba(44, 56, 48, 0.1); display: flex; flex-direction: column; gap: 10px; }
.tunnel-reassure li { display: flex; align-items: center; gap: 10px; font-size: 0.78rem; color: var(--color-ink-soft); }
.tunnel-reassure svg { color: var(--color-sauge); flex-shrink: 0; }

/* ----- COMMANDE (checkout) ----- */
.checkout-layout { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: start; }
@media (min-width: 1000px) { .checkout-layout { grid-template-columns: 1fr 400px; gap: 48px; } }
#customer_details { display: flex; flex-direction: column; gap: 24px; }
.checkout-card { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 12px; padding: 28px 26px; }
.checkout-card h3 { font-family: var(--font-display); font-size: 1.25rem; color: var(--color-foret); margin: 0 0 20px; }
.form-row-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; }
.form-row { margin: 0; display: flex; flex-direction: column; gap: 7px; grid-column: 1 / -1; }
.form-row.half { grid-column: span 1; }
@media (min-width: 560px) { .form-row.third { grid-column: span 2; } .form-row-grid { grid-template-columns: repeat(4, 1fr); } .form-row.half { grid-column: span 2; } }
.form-row label { font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-ink-muted); }
.form-row label .optional { text-transform: none; letter-spacing: 0; font-size: 0.74rem; }
.form-row abbr { color: var(--color-terracotta); text-decoration: none; }
.form-row input, .form-row select, .form-row textarea { padding: 13px 15px; border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card); font-family: var(--font-body); font-size: 0.9rem; background: #fff; color: var(--color-ink); width: 100%; }
.form-row textarea { resize: vertical; min-height: 96px; line-height: 1.6; }
.form-row input:focus, .form-row select:focus, .form-row textarea:focus { outline: none; border-color: var(--color-foret); }

/* Demande de devis */
.devis-note { display: flex; align-items: flex-start; gap: 9px; font-size: 0.78rem; line-height: 1.6; color: var(--color-ink-soft); background: rgba(125, 184, 125, 0.1); border-radius: var(--radius-card); padding: 14px 16px; margin: 0 0 22px; }
.devis-note svg { color: var(--color-sauge); flex-shrink: 0; margin-top: 1px; }
.devis-submit { border-top: 1px solid rgba(44, 56, 48, 0.1); padding-top: 22px; }
.checkbox-row { flex-direction: row; }
.cb { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-size: 0.84rem; letter-spacing: 0; text-transform: none; color: var(--color-ink-soft); }
.cb input { width: 17px; height: 17px; margin-top: 1px; accent-color: var(--color-foret); flex-shrink: 0; }
.cb a { color: var(--color-sauge); text-decoration: underline; text-underline-offset: 2px; }
.shipping-card .shipping-methods { gap: 12px; }
.shipping-card .shipping-methods label { padding: 14px 16px; }

/* order review */
#order_review .order-review-card { position: sticky; top: 110px; }
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; margin-bottom: 22px; }
.woocommerce-checkout-review-order-table .cart_item td { padding: 14px 0; border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.ro-name { font-size: 0.9rem; color: var(--color-ink-soft); line-height: 1.5; }
.ro-meta { display: block; font-size: 0.74rem; color: var(--color-ink-muted); }
.ro-qty { color: var(--color-ink-muted); font-size: 0.82rem; }
.ro-total { text-align: right; vertical-align: top; white-space: nowrap; padding-left: 14px; }
.woocommerce-checkout-review-order-table tfoot th { text-align: left; font-weight: 400; font-size: 0.85rem; color: var(--color-ink-soft); padding: 11px 0; }
.woocommerce-checkout-review-order-table tfoot td { text-align: right; padding: 11px 0; }
.woocommerce-checkout-review-order-table tfoot small { font-size: 0.7rem; color: var(--color-ink-muted); }
.woocommerce-checkout-review-order-table tfoot .cart-subtotal th, .woocommerce-checkout-review-order-table tfoot .cart-subtotal td, .woocommerce-checkout-review-order-table tfoot .shipping th, .woocommerce-checkout-review-order-table tfoot .shipping td { border-bottom: 1px solid rgba(44, 56, 48, 0.1); }

/* payment */
.woocommerce-checkout-payment { border-top: 1px solid rgba(44, 56, 48, 0.1); padding-top: 22px; }
.payment_methods { list-style: none; margin: 0 0 18px; padding: 0; }
.payment_method_stripe { border: 1px solid var(--color-foret); border-radius: var(--radius-card); overflow: hidden; }
.pm-head { display: flex; align-items: center; gap: 10px; padding: 15px 16px; cursor: pointer; font-size: 0.9rem; color: var(--color-foret); background: rgba(125, 184, 125, 0.08); }
.pm-head input { accent-color: var(--color-foret); width: 16px; height: 16px; }
.pm-logos { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.pm-chip { font-size: 0.58rem; letter-spacing: 0.06em; font-weight: 600; color: var(--color-sauge); border: 1px solid rgba(44, 56, 48, 0.2); border-radius: 3px; padding: 3px 6px; background: #fff; }
.pm-stripe { font-size: 0.66rem; font-style: italic; color: var(--color-ink-muted); }
.payment_box { padding: 18px 16px 20px; }
.pm-secure { display: flex; align-items: flex-start; gap: 8px; font-size: 0.74rem; color: var(--color-ink-muted); line-height: 1.5; margin: 14px 0 0; }
.pm-secure svg { color: var(--color-sauge); flex-shrink: 0; margin-top: 1px; }
.terms { margin: 0 0 18px; }
.place-order { width: 100%; justify-content: center; background: var(--color-foret); color: var(--color-creme); }
.place-order:hover { background: var(--color-sauge); }
.back-to-cart, .back-home { display: block; text-align: center; margin-top: 16px; font-size: 0.8rem; color: var(--color-sauge); }
.back-to-cart:hover, .back-home:hover { color: var(--color-terracotta); }

/* ----- CONFIRMATION ----- */
.confirm-layout { max-width: 920px; }
.confirm-hero { text-align: center; margin-bottom: 36px; }
.confirm-check { display: inline-flex; align-items: center; justify-content: center; width: 70px; height: 70px; border-radius: 50%; background: var(--color-vert); color: var(--color-foret); margin-bottom: 20px; }
.confirm-hero h1 { font-family: var(--font-display); font-style: italic; font-size: clamp(1.9rem, 4vw, 2.8rem); color: var(--color-foret); margin: 0 0 14px; }
.confirm-hero p { max-width: 52ch; margin: 0 auto; color: var(--color-ink-soft); line-height: 1.7; }
.order-overview { list-style: none; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; margin: 0 0 36px; padding: 0; background: rgba(44, 56, 48, 0.1); border: 1px solid rgba(44, 56, 48, 0.1); border-radius: 12px; overflow: hidden; }
@media (min-width: 720px) { .order-overview { grid-template-columns: repeat(4, 1fr); } }
.order-overview li { background: var(--color-creme-soft); padding: 20px 22px; display: flex; flex-direction: column; gap: 6px; }
.oo-label { font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-ink-muted); }
.order-overview strong { font-family: var(--font-display); font-size: 1.05rem; color: var(--color-foret); font-weight: 400; }
.confirm-grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 800px) { .confirm-grid { grid-template-columns: 1.3fr 1fr; } }
.confirm-card { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 12px; padding: 26px 24px; }
.confirm-card h2 { font-family: var(--font-display); font-size: 1.2rem; color: var(--color-foret); margin: 0 0 18px; }
.confirm-card .shop_table { width: 100%; border-collapse: collapse; }
.confirm-card .order_item td { padding: 12px 0; border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.confirm-card tfoot th { text-align: left; font-weight: 400; font-size: 0.85rem; color: var(--color-ink-soft); padding: 10px 0; }
.confirm-card tfoot td { text-align: right; padding: 10px 0; }
.confirm-card tfoot small { font-size: 0.7rem; color: var(--color-ink-muted); }
.confirm-card tfoot .order-total th { font-family: var(--font-display); font-size: 1rem; color: var(--color-foret); }
.confirm-address { font-style: normal; font-size: 0.92rem; line-height: 1.8; color: var(--color-ink-soft); margin-bottom: 18px; }
.confirm-ship { display: flex; align-items: flex-start; gap: 10px; font-size: 0.82rem; color: var(--color-ink-muted); line-height: 1.6; margin: 0; }
.confirm-ship svg { color: var(--color-sauge); flex-shrink: 0; margin-top: 2px; }
.confirm-actions { text-align: center; margin-top: 40px; }
.confirm-actions .btn { background: var(--color-foret); color: var(--color-creme); }
.confirm-actions .btn:hover { background: var(--color-sauge); }
.confirm-actions .back-home { margin-top: 18px; }

/* ----- Responsive panier (table empilée) ----- */
@media (max-width: 720px) {
  .shop_table.cart thead { display: none; }
  .shop_table.cart, .shop_table.cart tbody, .cart_item, .cart_item td { display: block; width: 100%; }
  .cart_item { border-bottom: 1px solid rgba(44, 56, 48, 0.12); padding: 18px 0; position: relative; }
  .cart_item td { border: none; padding: 6px 0; }
  .cart_item .product-name { padding-top: 0; }
  .cart_item .product-price, .cart_item .product-subtotal, .cart_item .product-quantity { text-align: left; }
  .cart_item .product-price::before, .cart_item .product-subtotal::before { content: attr(data-title) " : "; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-ink-muted); }
  .cart_item .product-remove { position: absolute; top: 16px; right: 0; width: auto; }
}

/* ============================================================
   VOLET PRO — toggle de profil (en-tête) + suffixe prix HT/TTC
   ============================================================ */
.profil-toggle {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-body); font-size: 0.72rem; letter-spacing: 0.04em;
  color: var(--color-foret); background: transparent;
  border: 1px solid rgba(44, 56, 48, 0.22); border-radius: var(--radius-pill);
  padding: 6px 12px; cursor: pointer; transition: border-color .2s ease, background .2s ease;
  white-space: nowrap;
}
.profil-toggle:hover { border-color: var(--color-foret); }
.profil-toggle .profil-toggle-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--color-sauge); flex-shrink: 0;
}
.profil-toggle.is-pro { background: rgba(125, 184, 125, 0.12); border-color: var(--color-foret); }
.profil-toggle.is-pro .profil-toggle-dot { background: var(--color-foret); }
/* En-tête sombre (hero accueil) : toggle lisible sur fond foncé, comme les icônes. */
.site-header.dark .profil-toggle { color: var(--color-creme); border-color: rgba(245, 240, 225, 0.4); }
.site-header.dark .profil-toggle .profil-toggle-dot { background: var(--color-creme); }
.site-header.dark .profil-toggle:hover { background: var(--color-creme); color: var(--color-foret); border-color: var(--color-creme); }
.site-header.dark .profil-toggle.is-pro { background: rgba(245, 240, 225, 0.16); border-color: rgba(245, 240, 225, 0.55); }
.site-header.dark .profil-toggle.is-pro .profil-toggle-dot { background: var(--color-creme); }
/* Header redevenu clair (scroll / méga ouvert) : toggle repasse en foncé. */
.site-header.is-stuck.dark .profil-toggle,
.site-header.mega-open .profil-toggle { color: var(--color-foret); border-color: rgba(44, 56, 48, 0.22); }
.site-header.is-stuck.dark .profil-toggle:hover,
.site-header.mega-open .profil-toggle:hover { background: transparent; border-color: var(--color-foret); }
.site-header.is-stuck.dark .profil-toggle .profil-toggle-dot,
.site-header.mega-open .profil-toggle .profil-toggle-dot { background: var(--color-sauge); }
.site-header.is-stuck.dark .profil-toggle.is-pro,
.site-header.mega-open .profil-toggle.is-pro { background: rgba(125, 184, 125, 0.12); border-color: var(--color-foret); }
.site-header.is-stuck.dark .profil-toggle.is-pro .profil-toggle-dot,
.site-header.mega-open .profil-toggle.is-pro .profil-toggle-dot { background: var(--color-foret); }

/* Suffixe « HT » / « TTC » accolé aux prix (cartes, fiches). */
.price .price-suffix { font-size: 0.66em; font-weight: 400; color: var(--color-ink-muted); letter-spacing: 0.04em; margin-left: 2px; }

/* ============================================================
   RECHERCHE — panneau d'en-tête + page de résultats
   ============================================================ */
.site-search {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(44, 56, 48, 0.55); backdrop-filter: blur(3px);
  display: flex; align-items: flex-start; justify-content: center;
  opacity: 0; visibility: hidden; transition: opacity .28s ease, visibility .28s ease;
}
.site-search.is-open { opacity: 1; visibility: visible; }
.site-search-inner {
  position: relative; width: min(680px, calc(100% - 40px)); margin-top: 14vh;
  background: var(--color-creme); border-radius: var(--radius-card);
  padding: 34px 32px 32px; box-shadow: 0 30px 70px rgba(44, 56, 48, 0.25);
  transform: translateY(-14px); transition: transform .28s ease;
}
.site-search.is-open .site-search-inner { transform: translateY(0); }
.site-search-eyebrow { font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-ink-muted); margin: 0 0 14px; }
.site-search .cat-search { background: #fff; }
.site-search-close {
  position: absolute; top: 16px; right: 16px; width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid rgba(44, 56, 48, 0.18); border-radius: 50%;
  color: var(--color-foret); cursor: pointer; transition: background .2s ease, color .2s ease;
}
.site-search-close:hover { background: var(--color-foret); color: var(--color-creme); }

.search-head { padding-top: 38px; padding-bottom: 30px; }
.search-head h1 { font-family: var(--font-display); font-style: italic; font-size: clamp(2rem, 4vw, 2.9rem); color: var(--color-foret); margin: 6px 0 10px; }
.search-meta { font-size: 0.92rem; color: var(--color-ink-soft); margin: 0 0 22px; }
.search-meta strong { color: var(--color-foret); font-weight: 600; }
.search-refine { max-width: 520px; }
.search-results { padding: 8px 0 72px; }
.search-empty {
  max-width: 560px; margin: 24px auto 40px; text-align: center;
  background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08);
  border-radius: 16px; padding: 48px 36px;
}
.search-empty svg { color: var(--color-sauge); opacity: 0.7; margin-bottom: 14px; }
.search-empty h2 { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-foret); margin: 0 0 12px; }
.search-empty p { color: var(--color-ink-soft); line-height: 1.7; margin: 0 0 24px; }

@media (prefers-reduced-motion: reduce) {
  .site-search, .site-search-inner { transition: none; }
}

/* ============================================================
   COMPTE CLIENT — connexion / inscription / tableau de bord
   ============================================================ */
.account-page .account-shell { padding-bottom: 72px; }

/* ----- Connexion + inscription : panneau de marque + onglets ----- */
.account-auth-shell { display: grid; grid-template-columns: 1fr; max-width: 1000px; margin: 0 auto; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.1); border-radius: 20px; overflow: hidden; box-shadow: 0 24px 60px rgba(44, 56, 48, 0.08); }
@media (min-width: 880px) { .account-auth-shell { grid-template-columns: 0.85fr 1fr; } }

/* Panneau de marque (gauche, masqué sur mobile) */
.account-aside { position: relative; display: none; padding: 44px 40px; color: var(--color-creme); background-color: var(--color-foret); background-size: cover; background-position: center; overflow: hidden; }
@media (min-width: 880px) { .account-aside { display: flex; flex-direction: column; justify-content: center; } }
.account-aside-tint { position: absolute; inset: 0; background: linear-gradient(150deg, rgba(28, 38, 32, 0.92), rgba(44, 56, 48, 0.74)); }
.account-aside-inner { position: relative; z-index: 2; }
.account-aside-eyebrow { font-size: 0.66rem; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(245, 240, 225, 0.7); }
.account-aside-title { font-family: var(--font-display); font-style: italic; font-size: 1.95rem; line-height: 1.15; color: var(--color-creme); margin: 14px 0 16px; }
.account-aside-text { font-size: 0.9rem; line-height: 1.7; color: rgba(245, 240, 225, 0.85); margin: 0 0 26px; max-width: 36ch; }
.account-benefits { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.account-benefits li { display: flex; align-items: flex-start; gap: 11px; font-size: 0.86rem; line-height: 1.4; color: rgba(245, 240, 225, 0.92); }
.account-benefits svg { color: var(--color-vert); flex-shrink: 0; margin-top: 1px; }
.account-aside-crest { position: absolute; right: -56px; bottom: -56px; width: 240px; opacity: 0.1; z-index: 1; }

/* Colonne formulaires (droite) */
.account-forms { padding: 38px 30px 40px; background: var(--color-creme); }
@media (min-width: 560px) { .account-forms { padding: 44px 46px 46px; } }
.account-tabs { display: inline-flex; gap: 4px; padding: 4px; margin: 0 0 28px; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.1); border-radius: var(--radius-pill); }
.account-tab { appearance: none; border: 0; background: transparent; cursor: pointer; padding: 9px 20px; border-radius: var(--radius-pill); font-family: var(--font-body); font-size: 0.82rem; letter-spacing: 0.02em; color: var(--color-ink-soft); transition: background .2s ease, color .2s ease; }
.account-tab.is-active { background: var(--color-foret); color: var(--color-creme); }
.account-tab:focus-visible { outline: 2px solid var(--color-sauge); outline-offset: 2px; }
.account-panel[hidden] { display: none; }
.account-panel-head { margin: 0 0 24px; }
.account-panel-head h2 { font-family: var(--font-display); font-size: 1.7rem; color: var(--color-foret); margin: 0 0 4px; }
.account-panel-head p { font-size: 0.88rem; color: var(--color-ink-muted); margin: 0; }
.account-forms .form-row { margin: 0 0 10px; }
.account-forms .form-row-grid { gap: 6px 14px; margin: 0 0 10px; }
.account-forms .form-row-grid .form-row { margin: 0; }
.account-forms .form-row label { display: block; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-ink-muted); margin-bottom: 6px; }
.account-forms .input-text { width: 100%; padding: 13px 15px; border: 1px solid rgba(44, 56, 48, 0.18); border-radius: var(--radius-card); font-family: var(--font-body); font-size: 0.9rem; background: #fff; color: var(--color-ink); transition: border-color .2s ease, box-shadow .2s ease; }
.account-forms .input-text:focus { outline: none; border-color: var(--color-foret); box-shadow: 0 0 0 3px rgba(125, 184, 125, 0.18); }
.account-forms .required { color: var(--color-terracotta); }
.account-row-between { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin: 2px 0 20px; flex-wrap: wrap; }
.account-submit { width: 100%; justify-content: center; margin-top: 4px; }
.account-lost { font-size: 0.82rem; color: var(--color-sauge); text-decoration: underline; text-underline-offset: 2px; }
.account-lost:hover { color: var(--color-terracotta); }
.account-switch { text-align: center; margin: 22px 0 0; font-size: 0.85rem; color: var(--color-ink-soft); }
.account-link-btn { appearance: none; border: 0; background: transparent; padding: 0; cursor: pointer; font: inherit; color: var(--color-foret); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.account-link-btn:hover { color: var(--color-terracotta); }
.account-forms .woocommerce-privacy-policy-text { font-size: 0.74rem; line-height: 1.55; color: var(--color-ink-muted); margin: 12px 0 0; }
.account-profil-toggle { margin-bottom: 8px; }

/* Bascule Particulier / Professionnel */
.account-profil-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 0 0 10px; }
.ap-opt { position: relative; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 10px; border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card); cursor: pointer; font-size: 0.86rem; color: var(--color-foret); transition: border-color .2s ease, background .2s ease; }
.ap-opt input { position: absolute; opacity: 0; pointer-events: none; }
.ap-opt:has(input:checked) { border-color: var(--color-foret); background: rgba(125, 184, 125, 0.1); font-weight: 500; }
.ap-opt:has(input:focus-visible) { outline: 2px solid var(--color-sauge); outline-offset: 2px; }
.account-profil-hint { font-size: 0.76rem; line-height: 1.5; color: var(--color-ink-muted); margin: 0 0 12px; }
.account-pro-fields { margin: 0 0 2px; }

/* ----- Tableau de bord (connecté) ----- */
.account-grid { display: grid; grid-template-columns: 1fr; gap: 30px; align-items: start; }
@media (min-width: 900px) { .account-grid { grid-template-columns: 250px 1fr; gap: 44px; } }
/* Neutralise les floats WooCommerce par défaut (nav 30% / contenu 68%). */
.account-grid .woocommerce-MyAccount-navigation,
.account-grid .woocommerce-MyAccount-content { float: none; width: auto; margin: 0; }

.account-nav { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 14px; padding: 20px; position: sticky; top: 100px; }
.account-nav-badge { display: inline-flex; align-items: center; gap: 7px; font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-sauge); margin-bottom: 16px; }
.account-nav-badge.is-pro { color: var(--color-foret); }
.account-nav-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.account-nav ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.account-nav li a { display: block; padding: 11px 14px; border-radius: 9px; font-size: 0.9rem; color: var(--color-ink-soft); transition: background .2s ease, color .2s ease; }
.account-nav li a:hover { background: rgba(44, 56, 48, 0.05); color: var(--color-foret); }
.account-nav li.is-active a, .account-nav li.woocommerce-MyAccount-navigation-link--dashboard.is-active a { background: var(--color-foret); color: var(--color-creme); }

.account-dash { display: flex; flex-direction: column; gap: 26px; }
.account-profil-card { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; justify-content: space-between; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.1); border-radius: 14px; padding: 24px 26px; }
.account-profil-card.is-pro { background: rgba(125, 184, 125, 0.1); border-color: rgba(74, 93, 78, 0.3); }
.ap-eyebrow { font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-ink-muted); display: block; }
.ap-value { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-foret); display: block; margin: 4px 0 6px; }
.ap-desc { font-size: 0.84rem; color: var(--color-ink-soft); margin: 0; max-width: 42ch; }
.btn-outline { display: inline-flex; align-items: center; justify-content: center; padding: 11px 22px; border-radius: var(--radius-pill); border: 1px solid var(--color-foret); color: var(--color-foret); background: transparent; font-size: 0.84rem; cursor: pointer; transition: background .2s ease, color .2s ease; }
.btn-outline:hover { background: var(--color-foret); color: var(--color-creme); }

.account-links { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 560px) { .account-links { grid-template-columns: 1fr; } }
.account-link-card { display: flex; flex-direction: column; gap: 3px; padding: 22px 22px 20px; background: #fff; border: 1px solid rgba(44, 56, 48, 0.1); border-radius: 12px; transition: border-color .2s ease, transform .2s ease; }
.account-link-card:hover { border-color: var(--color-foret); }
.account-link-card svg { color: var(--color-sauge); margin-bottom: 10px; }
.account-link-card strong { font-family: var(--font-body); font-weight: 600; font-size: 0.96rem; color: var(--color-foret); }
.account-link-card span { font-size: 0.78rem; color: var(--color-ink-muted); }

.account-recent h3 { font-family: var(--font-display); font-size: 1.2rem; color: var(--color-foret); margin: 0 0 14px; }
.account-orders { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.account-orders li { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; padding: 14px 18px; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 10px; font-size: 0.86rem; }
.account-orders .ao-num { font-weight: 600; color: var(--color-foret); }
.account-orders .ao-date { color: var(--color-ink-muted); }
.account-orders .ao-status { font-size: 0.7rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-sauge); }
.account-orders .ao-total { margin-left: auto; font-family: var(--font-display); color: var(--color-foret); }
.account-orders .ao-view { color: var(--color-sauge); text-decoration: underline; text-underline-offset: 2px; }

.account-logout-row { margin: 8px 0 0; }
.account-logout { font-size: 0.82rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-ink-muted); }
.account-logout:hover { color: var(--color-terracotta); }

/* ----- Contenu WC par défaut (commandes, adresses, infos) habillé ----- */
.woocommerce-MyAccount-content > p:first-child { color: var(--color-ink-soft); line-height: 1.7; }
.woocommerce-MyAccount-content .woocommerce-Button, .woocommerce-MyAccount-content button[type="submit"] { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--color-foret); color: var(--color-creme); border: 0; border-radius: var(--radius-pill); padding: 13px 26px; font-size: 0.88rem; cursor: pointer; transition: background .2s ease; }
.woocommerce-MyAccount-content .woocommerce-Button:hover, .woocommerce-MyAccount-content button[type="submit"]:hover { background: var(--color-sauge); }
.woocommerce-MyAccount-content table.shop_table { width: 100%; border-collapse: collapse; font-size: 0.88rem; }
.woocommerce-MyAccount-content table.shop_table th, .woocommerce-MyAccount-content table.shop_table td { text-align: left; padding: 12px 10px; border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.woocommerce-MyAccount-content table.shop_table th { font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-ink-muted); font-weight: 400; }
.woocommerce-MyAccount-content .form-row label, .woocommerce-EditAccountForm label, .woocommerce-address-fields label { display: block; font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-ink-muted); margin-bottom: 7px; }
.woocommerce-MyAccount-content input.input-text, .woocommerce-MyAccount-content input[type="password"], .woocommerce-MyAccount-content select { width: 100%; padding: 13px 15px; border: 1px solid rgba(44, 56, 48, 0.2); border-radius: var(--radius-card); font-family: var(--font-body); font-size: 0.9rem; background: #fff; color: var(--color-ink); margin-bottom: 14px; }
.woocommerce-MyAccount-content .woocommerce-Address { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 12px; padding: 22px 24px; }
.woocommerce-MyAccount-content address { font-style: normal; line-height: 1.7; color: var(--color-ink-soft); }

/* ============================================================
   Page compte — NEUTRALISE les défauts WooCommerce qui fuient
   (.woocommerce form .form-row{padding:3px;margin:0 0 6px} +
    label{line-height:2} + .input-text{padding:.5em}) : ils battent
   .account-forms en spécificité (0,2,1 > 0,2,0). On repasse au-dessus
   avec .account-page .account-forms (0,3,x) pour un espacement serré.
   ============================================================ */
.account-page .account-forms .form-row { margin: 0 0 8px; padding: 0; }
.account-page .account-forms .form-row-grid { gap: 6px 14px; margin: 0 0 8px; }
.account-page .account-forms .form-row-grid .form-row { margin: 0; }
.account-page .account-forms .form-row label { line-height: 1.35; margin-bottom: 6px; }
.account-page .account-forms .form-row .input-text { padding: 13px 15px; line-height: normal; box-sizing: border-box; height: auto; }
.account-page .account-forms .account-profil-toggle { margin-bottom: 8px; }
.account-page .account-forms .account-profil-hint { margin-bottom: 12px; }

/* ============================================================
   INPUTS uniformes (compte · checkout · devis) — fond crème doux
   (PLUS de blanc) + bordure cohérente. Spécificité 0,4,x pour battre
   les défauts WooCommerce qui fuient (.woocommerce form .form-row
   .input-text { background-color:#fff; border:var(--wc-form-border-color) }
   en 0,3,1, dont la bordure sombre rgba(32,7,7,.8)).
   ============================================================ */
.account-page .account-forms .form-row .input-text,
.account-page .account-forms .form-row textarea,
.checkout-page .checkout .form-row input.input-text,
.checkout-page .checkout .form-row textarea,
.checkout-page .checkout .form-row select,
.tunnel-body .form-row input,
.tunnel-body .form-row textarea,
.tunnel-body .form-row select {
  background-color: var(--color-creme-deep);
  border: 1px solid rgba(44, 56, 48, 0.18);
}
.account-page .account-forms .form-row .input-text:focus,
.account-page .account-forms .form-row textarea:focus,
.checkout-page .checkout .form-row input.input-text:focus,
.checkout-page .checkout .form-row textarea:focus,
.checkout-page .checkout .form-row select:focus,
.tunnel-body .form-row input:focus,
.tunnel-body .form-row textarea:focus,
.tunnel-body .form-row select:focus {
  background-color: #fffdf8;
  border-color: var(--color-foret);
  box-shadow: 0 0 0 3px rgba(125, 184, 125, 0.18);
  outline: none;
}


/* ===== PORTÉ depuis html/pages/css/style.css — styles pages vitrines ===== */
/* ============================================================
   PAGES VITRINES (Qui sommes-nous, Notre laboratoire, etc.)
   Jeu de classes .vp-* réutilisable sur toutes les pages internes
   ============================================================ */
.vitrine-page { background: var(--color-creme); }
.vitrine-page h2 { font-family: var(--font-display); font-weight: 300; color: var(--color-foret); line-height: 1.08; }

/* ----- Hero ----- */
.vp-hero { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--color-sable) 0%, var(--color-creme) 60%); padding: clamp(28px, 5vw, 52px) 0 clamp(40px, 6vw, 70px); border-bottom: 1px solid rgba(44, 56, 48, 0.08); }
.vp-hero.has-photo { padding-top: clamp(40px, 6vw, 72px); padding-bottom: clamp(48px, 7vw, 88px); }
.vp-hero-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center right; z-index: 0; }
.vp-hero.has-photo::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(100deg, var(--color-sable) 0%, rgba(245, 240, 225, 0.96) 38%, rgba(245, 240, 225, 0.74) 56%, rgba(237, 229, 208, 0.28) 82%, rgba(237, 229, 208, 0.08) 100%); }
.vp-hero > .container { position: relative; z-index: 2; }
.vp-hero .breadcrumb { margin-bottom: 22px; }
.vp-hero h1 { font-family: var(--font-display); font-weight: 300; font-style: normal; font-size: clamp(2.1rem, 5vw, 3.6rem); line-height: 1.05; color: var(--color-foret); max-width: 17ch; margin: 0; }

/* ----- Section générique + fond doux ----- */
.vp-section { padding: clamp(48px, 7vw, 96px) 0; }
.vp-section.is-soft, .vp-section.is-soft { background: linear-gradient(135deg, var(--color-sable) 0%, var(--color-creme) 62%); }
.vp-head { max-width: 760px; margin: 0 0 clamp(32px, 4vw, 52px); }
.vp-head .eyebrow { display: block; margin-bottom: 14px; }
.vp-head h2 { font-size: clamp(1.6rem, 3.2vw, 2.5rem); margin: 0 0 18px; }
.vp-head p { font-size: 1rem; line-height: 1.75; color: var(--color-ink-soft); margin: 0 0 14px; }

/* ----- Split image / texte ----- */
.vp-split-grid { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; }
@media (min-width: 920px) { .vp-split-grid { grid-template-columns: 1fr 1fr; gap: clamp(48px, 6vw, 88px); } .vp-split-grid.is-reverse .vp-media { order: -1; } }
.vp-body .eyebrow { display: block; margin-bottom: 14px; }
.vp-body h2 { font-size: clamp(1.55rem, 3vw, 2.35rem); margin: 0 0 20px; }
.vp-body p { font-size: 1rem; line-height: 1.78; color: var(--color-ink-soft); margin: 0 0 16px; }
.vp-body p:last-child { margin-bottom: 0; }
.vp-body a { color: var(--color-sauge); text-decoration: underline; text-underline-offset: 3px; transition: color .2s ease; }
.vp-body a:hover { color: var(--color-terracotta); }
.vp-media { position: relative; }
.vp-media img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-card); aspect-ratio: 5 / 4; }
@media (min-width: 920px) { .vp-media img { aspect-ratio: 4 / 5; max-height: 620px; } }
.vp-media-label { position: absolute; left: 16px; bottom: 16px; padding: 8px 16px; background: rgba(245, 240, 225, 0.92); color: var(--color-foret); font-family: var(--font-display); font-style: italic; font-size: 0.95rem; border-radius: 3px; }

/* ----- Expertise : intro + cartes métiers ----- */
.vp-expertise-grid { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start; }
@media (min-width: 920px) { .vp-expertise-grid { grid-template-columns: 1fr 1fr; gap: clamp(48px, 6vw, 80px); } }
.vp-expertise-intro p { font-size: 1rem; line-height: 1.78; color: var(--color-ink-soft); margin: 0 0 16px; }
.vp-expertise-intro a { color: var(--color-sauge); text-decoration: underline; text-underline-offset: 3px; }
.vp-expertise-intro a:hover { color: var(--color-terracotta); }
.vp-expertise-foot { margin-top: 22px; padding-top: 22px; border-top: 1px solid rgba(44, 56, 48, 0.12); }
.vp-cards { display: flex; flex-direction: column; gap: 16px; }
.vp-card { position: relative; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 12px; padding: 24px 26px 24px 64px; transition: border-color .25s ease, transform .25s ease; }
.vp-card:hover { border-color: var(--color-vert); transform: translateX(4px); }
.vp-card-num { position: absolute; left: 24px; top: 24px; font-family: var(--font-display); font-size: 1.1rem; color: var(--color-terracotta); }
.vp-card h3 { font-family: var(--font-display); font-weight: 300; font-size: 1.2rem; color: var(--color-foret); margin: 0 0 6px; }
.vp-card p { font-size: 0.92rem; line-height: 1.65; color: var(--color-ink-soft); margin: 0; }

/* ----- Bande sombre (ADN) ----- */
.vp-dark { position: relative; padding: clamp(60px, 8vw, 110px) 0; background: var(--color-foret); overflow: hidden; }
.vp-dark.vp-bg-botanic { background-image: url('../images/hero-botanic.jpg'); background-size: cover; background-position: center; }
.vp-dark-overlay { position: absolute; inset: 0; background: linear-gradient(120deg, rgba(28, 36, 30, 0.92) 0%, rgba(28, 36, 30, 0.78) 60%, rgba(28, 36, 30, 0.6) 100%); }
.vp-dark-inner { position: relative; max-width: 760px; }
.vp-dark-inner .eyebrow { display: block; margin-bottom: 14px; color: var(--color-vert-soft); }
.vp-dark-inner h2 { font-size: clamp(1.6rem, 3.2vw, 2.5rem); color: var(--color-creme); margin: 0 0 22px; }
.vp-dark-inner p { font-size: 1.02rem; line-height: 1.8; color: rgba(245, 240, 225, 0.82); margin: 0 0 16px; }
.vp-dark-inner p:last-child { margin-bottom: 0; }
.vp-dark-inner strong { color: var(--color-creme); font-weight: 500; }

/* ----- Marques propres ----- */
.vp-brands { display: grid; grid-template-columns: 1fr; gap: 28px; }
@media (min-width: 760px) { .vp-brands { grid-template-columns: 1fr 1fr; gap: 32px; } }
.vp-brand { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; }
.vp-brand-media { aspect-ratio: 16 / 10; overflow: hidden; background: var(--color-sable); }
.vp-brand-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.vp-brand:hover .vp-brand-media img { transform: scale(1.05); }
.vp-brand-body { padding: 26px 28px 30px; }
.vp-brand-body h3 { font-family: var(--font-display); font-weight: 300; font-size: 1.5rem; color: var(--color-foret); margin: 0 0 12px; }
.vp-brand-body p { font-size: 0.95rem; line-height: 1.7; color: var(--color-ink-soft); margin: 0; }
.vp-aside-link { margin: 30px 0 0; font-size: 0.96rem; color: var(--color-ink-soft); }
.vp-aside-link a { color: var(--color-sauge); text-decoration: underline; text-underline-offset: 3px; }
.vp-aside-link a:hover { color: var(--color-terracotta); }

/* ----- Valeurs ----- */
.vp-values-layout { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start; }
@media (min-width: 920px) { .vp-values-layout { grid-template-columns: 0.85fr 1.15fr; gap: clamp(48px, 6vw, 84px); } }
.vp-values { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.vp-values li { padding: 20px 0; border-bottom: 1px solid rgba(44, 56, 48, 0.12); font-size: 1rem; line-height: 1.7; color: var(--color-ink-soft); }
.vp-values li:first-child { padding-top: 0; }
.vp-values li:last-child { border-bottom: none; }
.vp-val-key { font-family: var(--font-display); font-style: italic; font-size: 1.15rem; color: var(--color-foret); }

/* ----- CTA ----- */
.vp-cta { position: relative; padding: clamp(60px, 8vw, 110px) 0; background: var(--color-sauge); overflow: hidden; }
.vp-cta.vp-bg-producteurs { background-image: url('../images/producteurs.jpg'); background-size: cover; background-position: center; }
.vp-cta-overlay { position: absolute; inset: 0; background: linear-gradient(120deg, rgba(28, 36, 30, 0.9) 0%, rgba(44, 56, 48, 0.72) 100%); }
.vp-cta-inner { position: relative; max-width: 720px; text-align: center; margin: 0 auto; }
.vp-cta-inner .eyebrow { display: block; margin-bottom: 14px; color: var(--color-vert-soft); }
.vp-cta-inner h2 { font-size: clamp(1.6rem, 3.4vw, 2.6rem); color: var(--color-creme); margin: 0 0 20px; }
.vp-cta-inner p { font-size: 1.02rem; line-height: 1.8; color: rgba(245, 240, 225, 0.85); margin: 0 0 16px; }
.vp-cta-inner .btn { margin-top: 16px; }

/* ----- FAQ ----- */
.vp-faq-grid { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start; }
@media (min-width: 1024px) { .vp-faq-grid { grid-template-columns: 0.9fr 1.1fr; gap: 72px; } }
.vp-faq-side .eyebrow { display: block; margin-bottom: 14px; }
.vp-faq-side h2 { font-size: clamp(1.5rem, 3vw, 2.2rem); }
.vp-faq .acc-list { display: flex; flex-direction: column; gap: 14px; }

/* Variantes vitrine : cartes en rangée (process) + horaires */
.vp-cards.is-row { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 860px) { .vp-cards.is-row { grid-template-columns: repeat(3, 1fr); gap: 22px; } }
.vp-cards.is-row .vp-card { padding: 28px 26px 26px; }
.vp-cards.is-row .vp-card-num { position: static; display: block; margin-bottom: 12px; }
.vp-hours { list-style: none; margin: 18px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.vp-hours li { position: relative; padding-left: 18px; font-size: 0.95rem; color: var(--color-ink-soft); }
.vp-hours li::before { content: ""; position: absolute; left: 0; top: 0.6em; width: 5px; height: 5px; border-radius: 50%; background: var(--color-vert); }
.vp-hours strong { color: var(--color-foret); font-weight: 500; }

/* Fonds d'images pour bandes sombres / CTA des pages vitrines */
.vp-dark.vp-bg-huiles { background-image: url('../images/huiles-vegetales.jpg'); background-size: cover; background-position: center; }
.vp-cta.vp-bg-macerats { background-image: url('../images/macerats.jpg'); background-size: cover; background-position: center; }
.vp-dark.vp-bg-producteurs2 { background-image: url('../images/producteurs.jpg'); background-size: cover; background-position: center; }

/* ============================================================
   PAGES VITRINES — BLOCS ENRICHIS (réutilisables)
   Hero étendu · Bande de stats · Manifeste marque · Citation ·
   Mission focale · Grille de valeurs
   ============================================================ */

/* ----- Hero enrichi ----- */
.vp-hero h1.is-wide { max-width: 34ch; }
.vp-hero-lede { margin: 24px 0 0; max-width: 56ch; font-size: clamp(1rem, 1.3vw, 1.12rem); line-height: 1.8; color: var(--color-ink-soft); }
.vp-hero-lede strong { color: var(--color-foret); font-weight: 500; }
.vp-hero-actions { margin-top: 34px; display: flex; gap: 16px; flex-wrap: wrap; }

/* ----- Bande de statistiques (clair) — réutilisable ----- */
.vp-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px 24px; margin: 0; padding: 0; list-style: none; }
@media (min-width: 760px) { .vp-stats { grid-template-columns: repeat(4, 1fr); gap: 34px; } }
.vp-stats li { position: relative; padding-left: 20px; }
.vp-stats li::before { content: ""; position: absolute; left: 0; top: 8px; bottom: 8px; width: 2px; background: var(--color-terracotta); border-radius: 2px; }
.vp-stat-num { display: block; font-family: var(--font-display); font-weight: 300; font-size: clamp(2.3rem, 4vw, 3.2rem); line-height: 1; color: var(--color-foret); }
.vp-stat-num em { font-style: italic; color: var(--color-terracotta); }
.vp-stat-label { display: block; margin-top: 12px; font-size: 0.82rem; line-height: 1.55; color: var(--color-ink-soft); }
@media (min-width: 760px) { .vp-stats.is-3 { grid-template-columns: repeat(3, 1fr); } }

/* ----- Manifeste / hommage à la marque ----- */
.vp-manifesto { position: relative; background: linear-gradient(160deg, var(--color-sable) 0%, var(--color-creme) 58%); overflow: hidden; }
.vp-manifesto-inner { position: relative; max-width: 900px; margin: 0 auto; text-align: center; }
.vp-manifesto-logo { width: clamp(208px, 26vw, 312px); height: auto; margin: 0 auto 32px; display: block; }
.vp-manifesto .eyebrow { display: inline-flex; justify-content: center; margin-bottom: 20px; }
.vp-manifesto h2 { font-size: clamp(1.85rem, 3.6vw, 2.9rem); line-height: 1.16; color: var(--color-foret); margin: 0 auto 22px; max-width: none; }
.vp-manifesto h2 em { font-style: italic; color: var(--color-terracotta); }
.vp-manifesto-lead { font-size: clamp(1rem, 1.3vw, 1.1rem); line-height: 1.85; color: var(--color-ink-soft); max-width: 62ch; margin: 0 auto; }
.vp-manifesto-lead strong { color: var(--color-foret); font-weight: 500; }
.vp-manifesto .vp-stats { margin-top: clamp(44px, 5vw, 66px); text-align: left; padding-top: clamp(36px, 4vw, 48px); border-top: 1px solid rgba(44, 56, 48, 0.14); }

/* ----- Citation éditoriale (réutilisable) ----- */
.vp-quote { position: relative; margin: clamp(36px, 4vw, 48px) 0 0; padding: 8px 0 8px 34px; border-left: 2px solid var(--color-vert); font-family: var(--font-display); font-style: italic; font-size: clamp(1.25rem, 2vw, 1.6rem); line-height: 1.45; color: var(--color-foret); max-width: 30ch; }

/* ----- Pied de bloc : citation à gauche, bouton en bas à droite ----- */
.vp-exigence-foot { margin-top: clamp(34px, 4vw, 52px); display: flex; flex-wrap: wrap; gap: 24px 32px; align-items: flex-end; justify-content: space-between; }
.vp-exigence-foot .vp-quote { margin: 0; }
.vp-exigence-foot .btn { flex-shrink: 0; }
@media (max-width: 620px) { .vp-exigence-foot { align-items: flex-start; } }

/* ----- Bouton(s) centré(s) sous une section ----- */
.vp-btn-row { margin-top: clamp(34px, 4vw, 48px); display: flex; gap: 16px; flex-wrap: wrap; }
.vp-btn-row.is-center { justify-content: center; }

/* ----- Mission focale (bande sombre, chiffre/affirmation en avant) ----- */
.vp-mission { position: relative; background: var(--color-foret); color: var(--color-creme); padding: clamp(60px, 8vw, 110px) 0; overflow: hidden; }
.vp-mission::before { content: ""; position: absolute; top: -120px; right: -120px; width: 420px; height: 420px; border-radius: 50%; background: rgba(125, 184, 125, 0.10); pointer-events: none; }
.vp-mission-grid { position: relative; display: grid; grid-template-columns: 1fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
@media (min-width: 960px) { .vp-mission-grid { grid-template-columns: 0.9fr 1.1fr; } }
.vp-mission-figure { position: relative; }
.vp-mission-figure .vp-mission-big { font-family: var(--font-display); font-weight: 300; font-style: italic; font-size: clamp(3.4rem, 8vw, 6rem); line-height: 0.95; color: var(--color-vert); display: block; }
.vp-mission-figure .vp-mission-cap { display: block; margin-top: 16px; font-family: var(--font-body); font-size: 0.78rem; letter-spacing: 0.32em; text-transform: uppercase; color: rgba(245, 240, 225, 0.7); }
.vp-mission-body .eyebrow { display: block; color: var(--color-vert-soft); margin-bottom: 16px; }
.vp-mission-body h2 { font-size: clamp(1.6rem, 3.2vw, 2.5rem); color: var(--color-creme); margin: 0 0 20px; }
.vp-mission-body > p { font-size: 1.02rem; line-height: 1.8; color: rgba(245, 240, 225, 0.82); margin: 0 0 26px; }
.vp-mission-body strong { color: var(--color-creme); font-weight: 500; }
.vp-mission-points { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 620px) { .vp-mission-points { grid-template-columns: repeat(3, 1fr); } }
.vp-mission-points li { padding: 20px 18px; background: rgba(245, 240, 225, 0.05); border: 1px solid rgba(245, 240, 225, 0.12); border-radius: 12px; }
.vp-mission-points strong { display: block; font-family: var(--font-display); font-style: normal; font-size: 1.05rem; color: var(--color-creme); margin-bottom: 6px; }
.vp-mission-points span { font-size: 0.84rem; line-height: 1.5; color: rgba(245, 240, 225, 0.72); }

/* ----- Grille de valeurs (clair, numérotée) ----- */
.vp-valuegrid { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: clamp(32px, 4vw, 48px); }
@media (min-width: 680px) { .vp-valuegrid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .vp-valuegrid { grid-template-columns: repeat(3, 1fr); } }
.vp-value { position: relative; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 14px; padding: 30px 28px 28px; overflow: hidden; }
.vp-value-num { font-family: var(--font-display); font-size: 0.9rem; letter-spacing: 0.18em; color: var(--color-terracotta); }
.vp-value h3 { font-family: var(--font-display); font-weight: 300; font-size: 1.4rem; color: var(--color-foret); margin: 12px 0 10px; }
.vp-value p { font-size: 0.92rem; line-height: 1.65; color: var(--color-ink-soft); margin: 0; }

/* ----- Galerie de familles (cartes photo immersives) ----- */
.vp-gallery-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 720px) { .vp-gallery-grid { grid-template-columns: repeat(3, 1fr); gap: 24px; } }
.vp-gallery-item { position: relative; display: block; aspect-ratio: 4 / 5; border-radius: 16px; overflow: hidden; background: var(--color-sable); }
.vp-gallery-item img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1s ease; }
.vp-gallery-item:hover img { transform: scale(1.06); }
.vp-gallery-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(175deg, transparent 38%, rgba(28, 36, 30, 0.86) 100%); z-index: 1; }
.vp-gallery-body { position: absolute; inset: auto 0 0 0; z-index: 2; padding: 26px 26px 28px; display: flex; flex-direction: column; gap: 4px; }
.vp-gallery-kicker { font-family: var(--font-body); font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--color-vert-soft); }
.vp-gallery-body h3 { font-family: var(--font-display); font-weight: 300; font-style: italic; font-size: 1.6rem; color: var(--color-creme); margin: 2px 0 0; }
.vp-gallery-go { display: inline-flex; align-items: center; gap: 8px; margin-top: 12px; font-size: 0.68rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--color-creme); }
.vp-gallery-go svg { transition: transform .3s ease; }
.vp-gallery-item:hover .vp-gallery-go svg { transform: translateX(4px); }

/* ----- Fond photo pour la bande mission ----- */
.vp-mission.has-photo { background-image: linear-gradient(120deg, rgba(28, 36, 30, 0.94) 0%, rgba(28, 36, 30, 0.82) 55%, rgba(28, 36, 30, 0.7) 100%), url('../images/mission-bg.jpg'); background-size: cover; background-position: center; }

/* ----- Fond photo CTA L'essentiel ----- */
.vp-cta.vp-bg-essentiel { background-image: url('../images/cta-essentiel.jpg'); background-size: cover; background-position: center; }

/* ----- Emblème « e » en grand filigrane dans le bloc mission ----- */
.vp-mission-figure { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.vp-mission-emblem { display: block; width: clamp(240px, 34vw, 470px); height: auto; opacity: 0.5; pointer-events: none; }

/* ----- Carte valeur en photo : la photo s'adapte au format des cartes ----- */
.vp-value.is-photo { padding: 0; border: none; min-height: 200px; }
.vp-value.is-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }

/* ----- Lisibilité du titre « Pour qui ? » sur fond sauge ----- */
.vitrine-page .duo h2 { color: var(--color-creme); }

/* ============================================================
   PAGE NOTRE LABORATOIRE — blocs dédiés (réutilisables)
   ============================================================ */

/* ----- Process en 3 étapes (icônes + ligne de liaison) ----- */
.vp-process { display: grid; grid-template-columns: 1fr; gap: 44px; margin-top: clamp(36px, 4vw, 56px); }
@media (min-width: 860px) { .vp-process { grid-template-columns: repeat(3, 1fr); gap: 30px; } }
.vp-process-step { position: relative; }
.vp-process-icon { position: relative; z-index: 1; width: 66px; height: 66px; border-radius: 50%; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.14); display: flex; align-items: center; justify-content: center; color: var(--color-foret); margin-bottom: 26px; }
.vp-process-icon svg { width: 28px; height: 28px; }
.vp-process-num { position: absolute; top: -6px; left: 52px; z-index: 2; font-family: var(--font-display); font-size: 0.95rem; color: var(--color-terracotta); background: var(--color-creme); padding: 0 7px; border-radius: 8px; }
.vp-section.is-soft .vp-process-num { background: var(--color-creme); }
@media (min-width: 860px) {
  .vp-process-step:not(:last-child)::before { content: ""; position: absolute; top: 33px; left: 82px; right: -18px; height: 1px; background: linear-gradient(90deg, var(--color-sable) 0%, var(--color-sable) 60%, transparent 100%); }
}
.vp-process-step h3 { font-family: var(--font-display); font-weight: 300; font-size: 1.5rem; color: var(--color-foret); margin: 0 0 14px; }
.vp-process-step p { font-size: 0.95rem; line-height: 1.72; color: var(--color-ink-soft); margin: 0; }
.vp-process-step p strong { color: var(--color-foret); font-weight: 500; }

/* ----- Fonds photo dédiés (labo) ----- */
.vp-dark.vp-bg-lab-essentiel { background-image: url('../images/lab-essentiel.jpg'); background-size: cover; background-position: center; }
.vp-cta.vp-bg-lab { background-image: url('../images/lab-cta.jpg'); background-size: cover; background-position: center; }

/* ----- Grille de bénéfices avec icônes (réutilisable) ----- */
.vp-features { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: clamp(32px, 4vw, 50px); }
@media (min-width: 680px) { .vp-features { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .vp-features { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 680px) { .vp-features.is-4 { grid-template-columns: repeat(2, 1fr); } }
.vp-feature { display: flex; gap: 18px; padding: 26px 26px 28px; background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 14px; }
.vp-feature-icon { flex-shrink: 0; width: 48px; height: 48px; border-radius: 50%; background: var(--color-creme); border: 1px solid rgba(44, 56, 48, 0.12); display: flex; align-items: center; justify-content: center; color: var(--color-foret); }
.vp-feature-icon svg { width: 22px; height: 22px; }
.vp-feature-body h3 { font-family: var(--font-display); font-weight: 300; font-size: 1.22rem; color: var(--color-foret); margin: 5px 0 8px; }
.vp-feature-body p { font-size: 0.9rem; line-height: 1.62; color: var(--color-ink-soft); margin: 0; }

/* ----- Fonds photo dédiés (producteurs) ----- */
.vp-dark.vp-bg-prod-terroir { background-image: url('../images/prod-terroir.jpg'); background-size: cover; background-position: center; }
.vp-cta.vp-bg-prod { background-image: url('../images/prod-cta.jpg'); background-size: cover; background-position: center; }

/* ----- Liste éditoriale d'engagements numérotés (réutilisable) ----- */
.vp-pledges { margin-top: clamp(36px, 4vw, 54px); border-top: 1px solid rgba(44, 56, 48, 0.14); }
.vp-pledge { display: grid; grid-template-columns: 1fr; gap: 10px 40px; padding: clamp(28px, 3.4vw, 40px) 0; border-bottom: 1px solid rgba(44, 56, 48, 0.14); }
@media (min-width: 820px) { .vp-pledge { grid-template-columns: auto 0.85fr 1.5fr; align-items: start; } }
.vp-pledge-num { font-family: var(--font-display); font-weight: 300; font-style: italic; font-size: clamp(2rem, 3vw, 2.9rem); line-height: 1; color: var(--color-terracotta); }
.vp-pledge h3 { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.4rem, 2.2vw, 1.95rem); color: var(--color-foret); margin: 0; line-height: 1.14; }
.vp-pledge p { font-size: 0.98rem; line-height: 1.72; color: var(--color-ink-soft); margin: 0; }
.vp-pledge p strong { color: var(--color-foret); font-weight: 500; }

/* ----- Petits tags (ex. formats recharge) ----- */
.vp-tags { display: flex; flex-wrap: wrap; gap: 10px; margin: 22px 0 0; padding: 0; list-style: none; }
.vp-tags li { font-family: var(--font-body); font-size: 0.78rem; letter-spacing: 0.03em; color: var(--color-foret); background: var(--color-creme); border: 1px solid rgba(44, 56, 48, 0.16); border-radius: 999px; padding: 8px 16px; }

/* ----- Variante 2 colonnes pour les points de bande sombre (ex. 4 points) ----- */
@media (min-width: 620px) { .vp-mission-points.is-2col { grid-template-columns: repeat(2, 1fr); } }

/* ----- Fonds photo dédiés (engagements) ----- */
.vp-dark.vp-bg-france { background-image: url('../images/eng-france.jpg'); background-size: cover; background-position: center; }
.vp-cta.vp-bg-engage { background-image: url('../images/eng-cta.jpg'); background-size: cover; background-position: center; }

/* ----- Variante 3 colonnes pour les cartes marques/familles ----- */
@media (min-width: 880px) { .vp-brands.is-3 { grid-template-columns: repeat(3, 1fr); } }

/* ----- Fonds photo dédiés (actifs) ----- */
.vp-dark.vp-bg-act-terroir { background-image: url('../images/act-terroir.jpg'); background-size: cover; background-position: center; }
.vp-cta.vp-bg-act { background-image: url('../images/act-cta.jpg'); background-size: cover; background-position: center; }

/* ----- Fonds photo dédiés (produits) ----- */
.vp-mission.vp-bg-produits { background-image: linear-gradient(120deg, rgba(28, 36, 30, 0.94) 0%, rgba(28, 36, 30, 0.82) 55%, rgba(28, 36, 30, 0.72) 100%), url('../images/prod2-pourquoi.jpg'); background-size: cover; background-position: center; }
.vp-cta.vp-bg-prod-devis { background-image: url('../images/prod2-cta.jpg'); background-size: cover; background-position: center; }

/* ============================================================
   PAGE CONTACT — formulaire + coordonnées (réutilisable)
   ============================================================ */
.vp-contact-grid { display: grid; grid-template-columns: 1fr; gap: clamp(36px, 5vw, 60px); align-items: start; margin-top: clamp(28px, 3.5vw, 44px); }
@media (min-width: 940px) { .vp-contact-grid { grid-template-columns: 1.12fr 0.88fr; } }

/* Formulaire */
.vp-form { display: flex; flex-direction: column; gap: 20px; }
.vp-form-row { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 560px) { .vp-form-row { grid-template-columns: 1fr 1fr; } }
.vp-field { display: flex; flex-direction: column; gap: 8px; }
.vp-field label { font-family: var(--font-body); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-ink-soft); }
.vp-field input, .vp-field select, .vp-field textarea { font-family: var(--font-body); font-size: 0.98rem; color: var(--color-foret); background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.16); border-radius: 10px; padding: 14px 16px; width: 100%; transition: border-color .2s ease, background .2s ease; }
.vp-field textarea { min-height: 150px; resize: vertical; }
.vp-field input:focus, .vp-field select:focus, .vp-field textarea:focus { outline: none; border-color: var(--color-vert); background: var(--color-creme); }
.vp-field input::placeholder, .vp-field textarea::placeholder { color: var(--color-ink-muted); }
.vp-field select { appearance: none; -webkit-appearance: none; padding-right: 42px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232C3830' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; cursor: pointer; }
.vp-form-note { font-size: 0.78rem; color: var(--color-ink-muted); line-height: 1.6; margin: 0; }
.vp-form .btn { align-self: flex-start; margin-top: 4px; }

/* Coordonnées */
.vp-contact-info { background: var(--color-creme-soft); border: 1px solid rgba(44, 56, 48, 0.08); border-radius: 16px; padding: clamp(26px, 3vw, 38px); }
.vp-contact-block { padding: 22px 0; border-bottom: 1px solid rgba(44, 56, 48, 0.1); }
.vp-contact-block:first-child { padding-top: 0; }
.vp-contact-block:last-child { padding-bottom: 0; border-bottom: none; }
.vp-contact-label { display: block; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-terracotta); margin-bottom: 12px; }
.vp-contact-block p { font-size: 0.95rem; line-height: 1.7; color: var(--color-ink-soft); margin: 0; }
.vp-contact-block a { color: var(--color-foret); text-decoration: none; transition: color .2s ease; }
.vp-contact-block a:hover { color: var(--color-terracotta); }
.vp-contact-big { display: inline-block; font-family: var(--font-display); font-style: italic; font-size: 1.18rem; color: var(--color-foret); margin-bottom: 4px; }
.vp-contact-block .vp-hours { margin: 0; }

/* ----- Un bouton dans un corps de split ne doit pas hériter du lien souligné ----- */
.vp-body a.btn { text-decoration: none; }
.vp-body a.btn--foret, .vp-body a.btn--foret:hover,
.vp-body a.btn--primary, .vp-body a.btn--primary:hover { color: var(--color-creme); }
.vp-body a.btn--cream, .vp-body a.btn--cream:hover { color: var(--color-foret); }
.vp-body a.btn--ghost, .vp-body a.btn--ghost:hover,
.vp-body a.btn--outline-dark, .vp-body a.btn--outline-dark:hover { color: var(--color-foret); }
.vp-body a.btn--terracotta, .vp-body a.btn--terracotta:hover { color: var(--color-creme); }

/* Formulaire de contact — messages de retour (succès / erreur) */
.vp-form-feedback { margin: 0 0 20px; padding: 14px 18px; border-radius: 12px; font-size: .92rem; line-height: 1.5; }
.vp-form-feedback.is-success { background: rgba(74,93,78,.12); color: var(--color-foret); border: 1px solid rgba(74,93,78,.30); }
.vp-form-feedback.is-error { background: rgba(176,84,58,.10); color: var(--color-terracotta); border: 1px solid rgba(176,84,58,.30); }
