/* ==========================================================================
   SÈVE & SECRETS — Feuille de style maîtresse
   Basée sur le dossier stratégique §5 (palette), §6 (typographies),
   §7 (système graphique), §15/16 (animations & micro-interactions).
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. TOKENS
   -------------------------------------------------------------------------- */
:root {
  /* Couleurs — §5.1 */
  --c-vert-seve: #1F3D2B;
  --c-ivoire: #FAF6EF;
  --c-blanc-casse: #F4EFE6;
  --c-champagne: #D9C29A;
  --c-sable: #C9B99B;
  --c-cacao: #4A2F23;
  --c-or: #B08D57;
  --c-terracotta: #C4735B;

  --c-text: var(--c-vert-seve);
  --c-text-soft: var(--c-cacao);
  --c-bg: var(--c-ivoire);
  --c-bg-alt: var(--c-blanc-casse);
  --c-border: var(--c-sable);

  /* Univers Secrets (lumière du soir) */
  --c-secrets-bg: var(--c-blanc-casse);
  --c-secrets-text: var(--c-cacao);
  --c-secrets-accent: var(--c-terracotta);

  /* Typographies — §6 */
  --f-serif: "Cormorant Garamond", "Times New Roman", serif;
  --f-sans: "Figtree", -apple-system, "Segoe UI", sans-serif;

  /* Échelle typo (clamp mobile → desktop, cf. §6.2) */
  --fs-display: clamp(2.75rem, 3.2vw + 2rem, 5.5rem);
  --fs-h1: clamp(2.25rem, 2vw + 1.75rem, 3.5rem);
  --fs-h2: clamp(1.75rem, 1.4vw + 1.4rem, 2.5rem);
  --fs-h3: clamp(1.375rem, 0.8vw + 1.15rem, 1.75rem);
  --fs-eyebrow: 0.75rem;
  --fs-body: clamp(1rem, 0.2vw + 0.95rem, 1.0625rem);
  --fs-small: 0.8125rem;
  --fs-button: 0.8125rem;
  --fs-price: clamp(1.125rem, 0.3vw + 1rem, 1.25rem);

  /* Grille & rythme — §7 */
  --grid-gutter: 32px;
  --grid-margin: 8%;
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-6: 48px;
  --space-8: 64px;
  --section-space: 160px;
  --section-space-mobile: 96px;
  --max-col: 68ch;

  /* Mouvement — §15 */
  --ease-lux: cubic-bezier(0.22, 1, 0.36, 1);
  --dur-reveal: 700ms;
  --dur-fast: 400ms;
  --dur-cascade: 90ms;

  --radius: 1px;
  --header-h: 88px;
}

@media (max-width: 768px) {
  :root {
    --grid-margin: 20px;
    --section-space: var(--section-space-mobile);
    --header-h: 72px;
  }
}

/* --------------------------------------------------------------------------
   2. RESET & BASE
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  margin: 0;
  background: var(--c-bg);
  color: var(--c-text);
  font-family: var(--f-sans);
  font-size: var(--fs-body);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; margin: 0; padding: 0; }
button { font-family: inherit; cursor: pointer; background: none; border: none; color: inherit; }
input, select, textarea { font-family: inherit; font-size: inherit; color: inherit; }

h1, h2, h3, .display {
  font-family: var(--f-serif);
  font-weight: 300;
  margin: 0;
  color: var(--c-vert-seve);
  letter-spacing: -0.01em;
}
.display { font-size: var(--fs-display); line-height: 1.05; }
h1, .h1 { font-size: var(--fs-h1); line-height: 1.1; }
h2, .h2 { font-size: var(--fs-h2); line-height: 1.15; font-weight: 400; }
h3, .h3 { font-size: var(--fs-h3); line-height: 1.25; font-weight: 500; }

.eyebrow {
  display: inline-block;
  font-family: var(--f-sans);
  font-weight: 500;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-or);
  margin-bottom: var(--space-2);
}

p { margin: 0 0 1em; max-width: var(--max-col); }
p:last-child { margin-bottom: 0; }
strong, b { font-weight: inherit; font-style: italic; font-family: var(--f-serif); font-size: 1.05em; }

.price {
  font-family: var(--f-serif);
  font-size: var(--fs-price);
  letter-spacing: 0.04em;
  font-variant-numeric: oldstyle-nums;
}

small, .small { font-size: var(--fs-small); letter-spacing: 0.02em; color: var(--c-text-soft); }

::selection { background: var(--c-champagne); color: var(--c-cacao); }

/* --------------------------------------------------------------------------
   3. LAYOUT
   -------------------------------------------------------------------------- */
.wrap {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding-left: var(--grid-margin);
  padding-right: var(--grid-margin);
}

.narrow { max-width: 720px; margin-left: auto; margin-right: auto; text-align: center; }

.section {
  padding-top: var(--section-space);
  padding-bottom: var(--section-space);
  position: relative;
}
.section--tight { padding-top: calc(var(--section-space) / 2); padding-bottom: calc(var(--section-space) / 2); }
.section--alt { background: var(--c-bg-alt); }

.grid-12 {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--grid-gutter);
}
@media (max-width: 900px) {
  .grid-12 { grid-template-columns: repeat(4, 1fr); gap: 20px; }
}

/* filigrane feuille nervurée — sections éditoriales uniquement */
.section--leaf { position: relative; }
.section--leaf::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url('../assets/leaf-vein.svg') no-repeat center / contain;
  opacity: 0.04;
  pointer-events: none;
}

/* --------------------------------------------------------------------------
   4. BOUTONS
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-sans);
  font-weight: 500;
  font-size: var(--fs-button);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 16px 32px;
  border: 1px solid var(--c-vert-seve);
  border-radius: var(--radius);
  background: transparent;
  color: var(--c-vert-seve);
  position: relative;
  overflow: hidden;
  z-index: 0;
  transition: color var(--dur-fast) var(--ease-lux);
}
.btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--c-vert-seve);
  transform: scaleX(0);
  transform-origin: left;
  z-index: -1;
  transition: transform var(--dur-fast) var(--ease-lux);
}
.btn:hover::before, .btn:focus-visible::before { transform: scaleX(1); }
.btn:hover, .btn:focus-visible { color: var(--c-ivoire); }

.btn--fill {
  background: var(--c-vert-seve);
  color: var(--c-ivoire);
}
.btn--fill::before { background: var(--c-cacao); }

.btn--ghost {
  border-color: currentColor;
  color: inherit;
}
.btn--ghost::before { background: currentColor; opacity: 0.12; }
.btn--ghost:hover { color: inherit; }

.btn--sm { padding: 11px 22px; }
.btn[disabled] { opacity: 0.4; pointer-events: none; }

.link-underline {
  position: relative;
  padding-bottom: 2px;
}
.link-underline::after {
  content: "";
  position: absolute;
  left: 50%;
  right: 50%;
  bottom: 0;
  height: 1px;
  background: var(--c-champagne);
  transition: left var(--dur-fast) var(--ease-lux), right var(--dur-fast) var(--ease-lux);
}
.link-underline:hover::after, .link-underline:focus-visible::after { left: 0; right: 0; }

/* --------------------------------------------------------------------------
   5. HEADER & NAVIGATION
   -------------------------------------------------------------------------- */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: var(--header-h);
  display: flex;
  align-items: center;
  background: rgba(250, 246, 239, 0.72);
  backdrop-filter: blur(10px) saturate(1.1);
  -webkit-backdrop-filter: blur(10px) saturate(1.1);
  border-bottom: 1px solid rgba(31, 61, 43, 0.08);
  transition: background var(--dur-fast) var(--ease-lux);
}
.site-header .wrap {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
}

.nav-group { display: flex; align-items: center; gap: var(--space-4); }
.nav-group--right { justify-content: flex-end; }
.nav-link {
  font-size: var(--fs-small);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--f-serif);
  font-size: 1.35rem;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.logo .drop { width: 16px; height: 16px; }

.icon-btn {
  position: relative;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
}
.icon-btn svg { width: 19px; height: 19px; stroke: var(--c-vert-seve); fill: none; stroke-width: 1.25; }
.cart-count {
  position: absolute;
  top: -6px; right: -8px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--c-terracotta);
  color: var(--c-ivoire);
  font-size: 10px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--f-sans);
}

.mega {
  position: absolute;
  top: 100%; left: 0; right: 0;
  background: var(--c-ivoire);
  border-bottom: 1px solid rgba(31,61,43,0.08);
  padding: var(--space-6) 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity var(--dur-fast) var(--ease-lux), transform var(--dur-fast) var(--ease-lux), visibility var(--dur-fast);
}
.nav-item:hover .mega,
.nav-item:focus-within .mega { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-item { position: relative; }
.mega-grid { display: flex; gap: var(--space-8); }
.mega-grid a { display: block; padding: 6px 0; font-size: var(--fs-small); letter-spacing: 0.04em; }
.mega-visual { width: 220px; aspect-ratio: 4/5; border-radius: var(--radius); overflow: hidden; }

.menu-toggle { display: none; flex-direction: column; gap: 5px; width: 22px; }
.menu-toggle span { height: 1px; background: var(--c-vert-seve); display: block; transition: transform var(--dur-fast) var(--ease-lux), opacity var(--dur-fast) var(--ease-lux); }

.search-inline {
  position: absolute; top: 100%; right: var(--grid-margin); margin-top: 10px;
  background: var(--c-ivoire); border: 1px solid var(--c-border); border-radius: var(--radius);
  padding: 6px; display: flex; gap: 6px;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity var(--dur-fast) var(--ease-lux), transform var(--dur-fast) var(--ease-lux), visibility var(--dur-fast);
}
.search-inline.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
.search-inline input { border: none; background: transparent; padding: 8px 10px; width: 200px; }
.search-inline input:focus { outline: none; }
.search-inline button { padding: 8px 12px; }

.currency-mini {
  border: none; background: none; font-size: 11px; letter-spacing: 0.06em;
  color: var(--c-vert-seve); padding-right: 4px;
}

.mobile-panel {
  position: fixed; inset: 0; top: var(--header-h);
  background: var(--c-ivoire);
  z-index: 99;
  padding: var(--space-4) var(--grid-margin);
  transform: translateY(-12px);
  opacity: 0; visibility: hidden;
  transition: opacity var(--dur-fast) var(--ease-lux), transform var(--dur-fast) var(--ease-lux), visibility var(--dur-fast);
  overflow-y: auto;
}
.mobile-panel.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
.mobile-panel a { display: block; padding: 14px 0; font-family: var(--f-serif); font-size: 1.4rem; border-bottom: 1px solid rgba(31,61,43,0.08); }
.mobile-panel .mobile-sub { padding-left: 12px; }
.mobile-panel .mobile-sub a { font-family: var(--f-sans); font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 0.06em; padding: 10px 0; border-bottom: none; }

@media (max-width: 900px) {
  .nav-group--left { display: none; }
  .nav-group--right .nav-link { display: none; }
  .menu-toggle { display: flex; }
  .site-header .wrap { grid-template-columns: auto 1fr auto; }
}

/* --------------------------------------------------------------------------
   6. HERO
   -------------------------------------------------------------------------- */
.hero {
  height: 100vh;
  min-height: 640px;
  display: flex;
  align-items: flex-end;
  position: relative;
  color: var(--c-ivoire);
  overflow: hidden;
}
.hero--short { height: 55vh; min-height: 420px; }
.hero-media {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 60% 20%, #2c4d38 0%, var(--c-vert-seve) 55%, #12241a 100%);
  z-index: -1;
}
.hero-media::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(18,36,26,0) 30%, rgba(18,36,26,0.55) 100%);
}
.hero-media img, .hero-media video {
  width: 100%; height: 100%; object-fit: cover;
  transform: scale(1);
  animation: kenburns 16s var(--ease-lux) forwards;
}
@keyframes kenburns { to { transform: scale(1.06); } }
@media (prefers-reduced-motion: reduce) { .hero-media img, .hero-media video { animation: none; } }

.hero-content { padding: 0 var(--grid-margin) var(--space-8); max-width: 900px; }
.hero-content .display { color: var(--c-ivoire); }
.hero-content p { color: var(--c-blanc-casse); max-width: 46ch; margin-top: var(--space-3); }

.scroll-cue {
  position: absolute;
  bottom: var(--space-4); left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: var(--c-ivoire);
  font-size: var(--fs-small);
  letter-spacing: 0.1em;
}
.scroll-cue .drop-fall { width: 6px; height: 6px; border-radius: 50% 50% 50% 0; transform: rotate(45deg); background: var(--c-champagne); animation: dropfall 1.8s ease-in-out infinite; }
@keyframes dropfall { 0%, 100% { transform: translateY(0) rotate(45deg); opacity: 1; } 50% { transform: translateY(10px) rotate(45deg); opacity: 0.4; } }
@media (prefers-reduced-motion: reduce) { .drop-fall { animation: none; } }

/* --------------------------------------------------------------------------
   7. REVEAL AU SCROLL (piloté par js/main.js)
   -------------------------------------------------------------------------- */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--dur-reveal) var(--ease-lux), transform var(--dur-reveal) var(--ease-lux);
}
[data-reveal].is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* --------------------------------------------------------------------------
   8. MANIFESTE
   -------------------------------------------------------------------------- */
.manifesto { text-align: center; }
.manifesto p {
  font-family: var(--f-serif);
  font-size: var(--fs-h3);
  line-height: 1.5;
  color: var(--c-vert-seve);
  margin: 0 auto;
  max-width: 42ch;
}

/* --------------------------------------------------------------------------
   9. LES DEUX UNIVERS
   -------------------------------------------------------------------------- */
.universes { display: grid; grid-template-columns: 1fr 1fr; }
@media (max-width: 800px) { .universes { grid-template-columns: 1fr; } }
.universe-card {
  position: relative;
  min-height: 640px;
  display: flex; align-items: flex-end;
  padding: var(--space-8) var(--space-6);
  color: var(--c-ivoire);
  overflow: hidden;
}
.universe-card__bg { position: absolute; inset: 0; z-index: -1; transition: transform 1.2s var(--ease-lux); }
.universe-card:hover .universe-card__bg { transform: scale(1.04); }
.universe-card--seve .universe-card__bg { background: linear-gradient(200deg, #3c6248, var(--c-vert-seve) 60%, #16281c); }
.universe-card--secrets .universe-card__bg { background: linear-gradient(200deg, #6b4331, var(--c-cacao) 60%, #2a1a12); }
.universe-card h3 { color: var(--c-ivoire); font-size: var(--fs-h1); font-weight: 300; }
.universe-card .eyebrow { color: var(--c-champagne); }
.universe-card p { color: var(--c-blanc-casse); margin-top: var(--space-2); }
.universe-card__link { margin-top: var(--space-3); }

/* --------------------------------------------------------------------------
   10. BANDEAU INGRÉDIENTS (scrollytelling)
   -------------------------------------------------------------------------- */
.ingredients-band { overflow: hidden; }
.ingredients-track {
  display: flex;
  gap: var(--space-6);
  width: max-content;
  will-change: transform;
}
.ingredient-item {
  width: 320px;
  flex: none;
}
.ingredient-item__visual {
  aspect-ratio: 1/1;
  border-radius: var(--radius);
  margin-bottom: var(--space-2);
  background: radial-gradient(circle at 35% 30%, #e7dcc4, var(--c-champagne) 45%, var(--c-sable) 100%);
}
.ingredient-item:nth-child(2) .ingredient-item__visual { background: radial-gradient(circle at 35% 30%, #fff, #efe6d3 45%, var(--c-sable) 100%); }
.ingredient-item:nth-child(3) .ingredient-item__visual { background: radial-gradient(circle at 35% 30%, #d8c9a3, #b89a6a 45%, var(--c-cacao) 100%); }
.ingredient-item:nth-child(4) .ingredient-item__visual { background: radial-gradient(circle at 35% 30%, #7a5236, var(--c-cacao) 45%, #2a1a12 100%); }

/* --------------------------------------------------------------------------
   11. GRILLE PRODUITS & CARTE PRODUIT
   -------------------------------------------------------------------------- */
.product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gutter);
}
@media (max-width: 900px) { .product-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; } }
@media (max-width: 520px) { .product-grid { grid-template-columns: 1fr; } }

.product-card { display: block; }
.product-card__media {
  position: relative;
  aspect-ratio: 4/5;
  background: var(--c-blanc-casse);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: var(--space-2);
}
.product-card__media .ph { position: absolute; inset: 0; }
.product-card__media .ph--texture { opacity: 0; transition: opacity var(--dur-fast) var(--ease-lux); }
.product-card:hover .ph--texture { opacity: 1; }
.product-card__add {
  position: absolute;
  bottom: 12px; left: 12px; right: 12px;
  opacity: 0; transform: translateY(8px);
  transition: opacity var(--dur-fast) var(--ease-lux), transform var(--dur-fast) var(--ease-lux);
}
.product-card:hover .product-card__add,
.product-card:focus-within .product-card__add { opacity: 1; transform: translateY(0); }
.product-card__badge {
  position: absolute; top: 12px; left: 12px;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--c-terracotta); color: var(--c-ivoire);
  padding: 5px 10px; border-radius: var(--radius);
}
.product-card__wish {
  position: absolute; top: 10px; right: 10px;
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(250,246,239,0.85);
  display: flex; align-items: center; justify-content: center;
}
.product-card__wish svg { width: 14px; height: 14px; stroke: var(--c-cacao); fill: none; stroke-width: 1.4; transition: fill var(--dur-fast); }
.product-card__wish.is-active svg { fill: var(--c-terracotta); stroke: var(--c-terracotta); }
.product-card h3 { font-size: 1.15rem; margin-bottom: 2px; }
.product-card .subtitle { font-size: var(--fs-small); color: var(--c-text-soft); margin-bottom: 6px; display: block; }

/* placeholders texture — en attendant le vrai shooting §17 */
.ph--karite { background: radial-gradient(circle at 40% 35%, #fff9ec, #e9dcc0 55%, var(--c-sable)); }
.ph--coco { background: radial-gradient(circle at 40% 35%, #ffffff, #efe9db 55%, var(--c-champagne)); }
.ph--baobab { background: radial-gradient(circle at 40% 35%, #f3e6c8, var(--c-champagne) 55%, var(--c-or)); }
.ph--cacao { background: radial-gradient(circle at 40% 35%, #8a6247, var(--c-cacao) 55%, #221510); }
.ph--intime { background: radial-gradient(circle at 40% 35%, #f1ded2, var(--c-terracotta) 65%, var(--c-cacao)); }
.ph--vert { background: linear-gradient(160deg, #3c6248, var(--c-vert-seve)); }
.ph-label {
  position: absolute; bottom: 8px; right: 8px;
  font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase;
  color: rgba(250,246,239,0.75); background: rgba(31,61,43,0.4);
  padding: 3px 6px; border-radius: 2px;
}

/* --------------------------------------------------------------------------
   12. BLOC ÉDITORIAL (histoire / citation)
   -------------------------------------------------------------------------- */
.editorial { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-8); align-items: center; }
@media (max-width: 900px) { .editorial { grid-template-columns: 1fr; } }
.editorial__media { aspect-ratio: 4/3; border-radius: var(--radius); overflow: hidden; }
.editorial .signature { font-family: var(--f-serif); font-style: italic; font-size: 1.4rem; margin-top: var(--space-3); color: var(--c-or); }

.quote-block {
  text-align: center;
  font-family: var(--f-serif);
  font-style: italic;
  font-size: var(--fs-h2);
  line-height: 1.4;
  max-width: 900px; margin: 0 auto;
}
.quote-block cite { display: block; margin-top: var(--space-3); font-style: normal; font-size: var(--fs-small); letter-spacing: 0.08em; text-transform: uppercase; color: var(--c-text-soft); }

/* --------------------------------------------------------------------------
   13. RITUEL / ÉTAPES
   -------------------------------------------------------------------------- */
.ritual-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: center; }
@media (max-width: 900px) { .ritual-split { grid-template-columns: 1fr; } }
.ritual-steps { counter-reset: step; }
.ritual-step { display: flex; gap: var(--space-3); counter-increment: step; padding: var(--space-3) 0; border-top: 1px solid rgba(31,61,43,0.1); }
.ritual-step:first-child { border-top: none; }
.ritual-step::before {
  content: counter(step, upper-roman);
  font-family: var(--f-serif); font-size: 1.5rem; color: var(--c-or); width: 2.2ch; flex: none;
}

/* --------------------------------------------------------------------------
   14. AVIS / TÉMOIGNAGES
   -------------------------------------------------------------------------- */
.reviews-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
@media (max-width: 900px) { .reviews-strip { grid-template-columns: 1fr; } }
.review { text-align: center; }
.review p { font-family: var(--f-serif); font-style: italic; font-size: 1.25rem; margin: 0 auto var(--space-2); }
.stars { color: var(--c-or); letter-spacing: 3px; margin-bottom: var(--space-2); font-size: 0.9rem; }
.review cite { font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 0.08em; color: var(--c-text-soft); font-style: normal; }

/* --------------------------------------------------------------------------
   15. JOURNAL
   -------------------------------------------------------------------------- */
.journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--grid-gutter); }
@media (max-width: 900px) { .journal-grid { grid-template-columns: 1fr; } }
.journal-card__media { aspect-ratio: 4/3; border-radius: var(--radius); overflow: hidden; margin-bottom: var(--space-2); }
.journal-card .eyebrow { color: var(--c-terracotta); }

/* --------------------------------------------------------------------------
   16. NEWSLETTER
   -------------------------------------------------------------------------- */
.newsletter { text-align: center; }
.newsletter-form {
  display: flex; justify-content: center; gap: 12px; margin-top: var(--space-4);
  max-width: 460px; margin-left: auto; margin-right: auto;
}
.newsletter-form input {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--c-border);
  padding: 12px 4px;
  font-size: var(--fs-body);
  transition: border-color var(--dur-fast) var(--ease-lux);
}
.newsletter-form input:focus { outline: none; border-color: var(--c-vert-seve); }
@media (max-width: 520px) { .newsletter-form { flex-direction: column; } }

/* --------------------------------------------------------------------------
   17. FOOTER
   -------------------------------------------------------------------------- */
.site-footer { background: var(--c-vert-seve); color: var(--c-blanc-casse); padding: var(--space-8) 0 var(--space-4); }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
@media (max-width: 800px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-grid h4 { font-family: var(--f-sans); font-size: var(--fs-small); letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-champagne); margin-bottom: var(--space-2); }
.footer-grid a, .footer-grid li { font-size: var(--fs-small); color: rgba(250,246,239,0.8); line-height: 2.1; }
.footer-bottom {
  margin-top: var(--space-8);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(250,246,239,0.15);
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: rgba(250,246,239,0.6);
}
.footer-monogram { font-family: var(--f-serif); font-size: 1.1rem; color: var(--c-champagne); }
.discretion-note { display: flex; align-items: center; gap: 8px; }
.discretion-note svg { width: 16px; height: 16px; stroke: var(--c-champagne); fill: none; }

.site-footer .field input { color: var(--c-ivoire); border-bottom-color: rgba(250,246,239,0.3); }
.site-footer .field label { color: rgba(250,246,239,0.65); }
.site-footer .field input:focus, .site-footer .field input:not(:placeholder-shown) { border-bottom-color: var(--c-champagne); }
.site-footer .field input:focus + label, .site-footer .field input:not(:placeholder-shown) + label { color: var(--c-champagne); }

/* --------------------------------------------------------------------------
   18. TIROIR PANIER
   -------------------------------------------------------------------------- */
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(420px, 100vw);
  background: var(--c-ivoire);
  box-shadow: -20px 0 60px rgba(31,61,43,0.18);
  z-index: 300;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--dur-fast) var(--ease-lux);
}
.cart-drawer.is-open { transform: translateX(0); }
.cart-overlay {
  position: fixed; inset: 0; background: rgba(18,36,26,0.35);
  z-index: 290; opacity: 0; visibility: hidden; transition: opacity var(--dur-fast) var(--ease-lux), visibility var(--dur-fast);
}
.cart-overlay.is-open { opacity: 1; visibility: visible; }

.cart-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4); border-bottom: 1px solid rgba(31,61,43,0.1); }
.cart-drawer__body { flex: 1; overflow-y: auto; padding: var(--space-3) var(--space-4); }
.cart-drawer__foot { padding: var(--space-4); border-top: 1px solid rgba(31,61,43,0.1); }

.cart-line { display: grid; grid-template-columns: 72px 1fr auto; gap: 14px; padding: var(--space-2) 0; border-bottom: 1px solid rgba(31,61,43,0.06); }
.cart-line__media { width: 72px; height: 90px; border-radius: var(--radius); overflow: hidden; }
.cart-line__qty { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
.cart-line__qty button { width: 22px; height: 22px; border: 1px solid var(--c-border); border-radius: var(--radius); }
.cart-line__remove { font-size: 11px; text-decoration: underline; color: var(--c-text-soft); margin-top: 6px; }

.shipping-bar { height: 3px; background: rgba(31,61,43,0.12); border-radius: 3px; overflow: hidden; margin: var(--space-2) 0; }
.shipping-bar__fill { height: 100%; background: var(--c-champagne); transition: width var(--dur-reveal) var(--ease-lux); }

.reassurance-trio { display: flex; justify-content: space-between; gap: 10px; margin-top: var(--space-3); flex-wrap: wrap; }
.reassurance-trio div { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--c-text-soft); }
.reassurance-trio svg { width: 15px; height: 15px; stroke: var(--c-or); fill: none; stroke-width: 1.2; }

/* --------------------------------------------------------------------------
   19. ACCORDÉONS
   -------------------------------------------------------------------------- */
.accordion-item { border-top: 1px solid rgba(31,61,43,0.12); }
.accordion-item:last-child { border-bottom: 1px solid rgba(31,61,43,0.12); }
.accordion-trigger {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-2) 0; text-align: left; font-family: var(--f-serif); font-size: 1.15rem;
}
.accordion-trigger .chevron { width: 12px; height: 12px; border-right: 1px solid currentColor; border-bottom: 1px solid currentColor; transform: rotate(45deg); transition: transform 350ms var(--ease-lux); }
.accordion-item.is-open .chevron { transform: rotate(-135deg); }
.accordion-panel { max-height: 0; overflow: hidden; transition: max-height 350ms var(--ease-lux); }
.accordion-panel__inner { padding-bottom: var(--space-3); }

/* --------------------------------------------------------------------------
   20. FORMULAIRES
   -------------------------------------------------------------------------- */
.field { position: relative; margin-bottom: var(--space-4); }
.field input, .field textarea, .field select {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--c-border);
  padding: 14px 2px 10px;
  transition: border-color var(--dur-fast) var(--ease-lux);
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--c-vert-seve); }
.field label {
  position: absolute; left: 2px; top: 14px;
  color: var(--c-text-soft); font-size: var(--fs-body);
  transition: transform var(--dur-fast) var(--ease-lux), font-size var(--dur-fast) var(--ease-lux), color var(--dur-fast) var(--ease-lux);
  pointer-events: none;
}
.field input:focus + label, .field input:not(:placeholder-shown) + label,
.field textarea:focus + label, .field textarea:not(:placeholder-shown) + label {
  transform: translateY(-16px);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-or);
}
/* honeypot anti-spam (piège invisible pour robots, cf. thème WordPress) */
.field--trap { position: absolute; left: -9999px; top: -9999px; }

/* --------------------------------------------------------------------------
   21. FIL D'ARIANE / BARRE OUTILS BOUTIQUE
   -------------------------------------------------------------------------- */
.breadcrumb { font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--c-text-soft); margin-bottom: var(--space-2); }
.breadcrumb a { text-decoration: underline; }

.toolbar {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-2);
  padding: var(--space-3) 0; border-top: 1px solid rgba(31,61,43,0.1); border-bottom: 1px solid rgba(31,61,43,0.1);
}
.filters { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.filter-chip {
  font-size: 12px; letter-spacing: 0.04em; padding: 8px 16px;
  border: 1px solid var(--c-border); border-radius: var(--radius);
  transition: background var(--dur-fast) var(--ease-lux), color var(--dur-fast) var(--ease-lux), border-color var(--dur-fast) var(--ease-lux);
}
.filter-chip.is-active, .filter-chip:hover { background: var(--c-vert-seve); border-color: var(--c-vert-seve); color: var(--c-ivoire); }
.sort-select { border: 1px solid var(--c-border); padding: 8px 12px; border-radius: var(--radius); background: transparent; }

/* --------------------------------------------------------------------------
   22. FICHE PRODUIT
   -------------------------------------------------------------------------- */
.product-view { display: grid; grid-template-columns: 55% 45%; gap: var(--space-8); }
@media (max-width: 960px) { .product-view { grid-template-columns: 1fr; } }

.gallery-main { aspect-ratio: 4/5; border-radius: var(--radius); overflow: hidden; margin-bottom: var(--space-2); }
.gallery-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.gallery-thumbs button { aspect-ratio: 1/1; border-radius: var(--radius); overflow: hidden; border: 1px solid transparent; }
.gallery-thumbs button.is-active { border-color: var(--c-or); }

.product-info .eyebrow { color: var(--c-terracotta); }
.product-info h1 { margin-bottom: var(--space-1); }
.product-info .subtitle { display: block; color: var(--c-text-soft); margin-bottom: var(--space-2); max-width: 40ch; }
.product-info .price { display: block; margin-bottom: var(--space-3); }
.rating-line { display: flex; align-items: center; gap: 8px; font-size: var(--fs-small); color: var(--c-text-soft); margin-bottom: var(--space-3); }

.qty-selector { display: inline-flex; align-items: center; border: 1px solid var(--c-border); border-radius: var(--radius); }
.qty-selector button { width: 38px; height: 44px; }
.qty-selector input { width: 40px; text-align: center; border: none; background: transparent; -moz-appearance: textfield; }
.qty-selector input::-webkit-outer-spin-button, .qty-selector input::-webkit-inner-spin-button { -webkit-appearance: none; }

.add-row { display: flex; align-items: center; gap: 14px; margin: var(--space-3) 0 var(--space-4); flex-wrap: wrap; }
.add-row .btn--fill { flex: 1; justify-content: center; min-width: 220px; }
.wish-toggle {
  width: 46px; height: 46px; border: 1px solid var(--c-border); border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center; flex: none;
}
.wish-toggle svg { width: 17px; height: 17px; stroke: var(--c-cacao); fill: none; transition: transform var(--dur-fast) var(--ease-lux); }
.wish-toggle.is-active svg { fill: var(--c-terracotta); stroke: var(--c-terracotta); animation: pulse-once 400ms var(--ease-lux); }
@keyframes pulse-once { 50% { transform: scale(1.25); } }

.texture-band { position: relative; height: 46vh; min-height: 320px; margin: var(--section-space) calc(var(--grid-margin) * -1) 0; overflow: hidden; }
.texture-band .ph { position: absolute; inset: 0; }

.cross-sell { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; padding: var(--space-3); border: 1px solid var(--c-border); border-radius: var(--radius); }
.cross-sell__thumb { width: 56px; height: 70px; border-radius: var(--radius); overflow: hidden; flex: none; }

/* --------------------------------------------------------------------------
   23. TIMELINE / CHAPITRES (Notre Histoire)
   -------------------------------------------------------------------------- */
.chapter { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: center; }
.chapter:nth-child(even) { direction: rtl; }
.chapter:nth-child(even) > * { direction: ltr; }
@media (max-width: 900px) { .chapter, .chapter:nth-child(even) { grid-template-columns: 1fr; direction: ltr; } }
.chapter__media { aspect-ratio: 4/5; border-radius: var(--radius); overflow: hidden; }
.chapter .eyebrow { color: var(--c-or); }

/* --------------------------------------------------------------------------
   24. FAQ
   -------------------------------------------------------------------------- */
.faq-tabs { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-6); justify-content: center; }
.faq-search { max-width: 480px; margin: 0 auto var(--space-6); }

/* --------------------------------------------------------------------------
   25. COMPTE CLIENT
   -------------------------------------------------------------------------- */
.account-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-8); }
@media (max-width: 800px) { .account-layout { grid-template-columns: 1fr; } }
.account-nav a { display: block; padding: 10px 0; font-size: var(--fs-small); letter-spacing: 0.04em; border-bottom: 1px solid rgba(31,61,43,0.08); }
.account-nav a.is-active { color: var(--c-or); }
.account-card { border: 1px solid var(--c-border); border-radius: var(--radius); padding: var(--space-4); margin-bottom: var(--space-3); }
.loyalty-meter { height: 6px; border-radius: 6px; background: rgba(31,61,43,0.1); overflow: hidden; margin: var(--space-2) 0; }
.loyalty-meter__fill { height: 100%; background: linear-gradient(90deg, var(--c-champagne), var(--c-or)); }

/* --------------------------------------------------------------------------
   26. TOAST / LOADER / CURSEUR
   -------------------------------------------------------------------------- */
.toast {
  position: fixed; bottom: 28px; right: 28px; z-index: 400;
  background: var(--c-vert-seve); color: var(--c-ivoire);
  padding: 14px 22px; border-radius: var(--radius);
  display: flex; align-items: center; gap: 10px;
  font-size: var(--fs-small);
  transform: translateX(120%); transition: transform var(--dur-fast) var(--ease-lux);
}
.toast.is-visible { transform: translateX(0); }

.page-loader {
  position: fixed; inset: 0; z-index: 999; background: var(--c-ivoire);
  display: flex; align-items: center; justify-content: center;
  transition: opacity 500ms var(--ease-lux), visibility 500ms;
}
.page-loader.is-hidden { opacity: 0; visibility: hidden; }
.loader-drop { width: 14px; height: 14px; border-radius: 50% 50% 50% 0; transform: rotate(45deg); background: var(--c-vert-seve); animation: loaderfall 1.1s ease-in-out infinite; }
@keyframes loaderfall { 0%, 100% { transform: translateY(-10px) rotate(45deg); opacity: 0.5; } 50% { transform: translateY(10px) rotate(45deg); opacity: 1; } }

.cursor-drop {
  position: fixed; top: 0; left: 0; width: 8px; height: 8px; border-radius: 50%;
  background: var(--c-champagne); pointer-events: none; z-index: 500; mix-blend-mode: multiply;
  transform: translate(-50%, -50%); transition: width 250ms var(--ease-lux), height 250ms var(--ease-lux), border-radius 250ms var(--ease-lux);
  display: none;
}
@media (hover: hover) and (pointer: fine) { .cursor-drop { display: block; } }
.cursor-drop.is-active { width: 34px; height: 40px; border-radius: 50% 50% 50% 0; }

@media (prefers-reduced-motion: reduce) {
  .page-loader, .cursor-drop, .drop-fall, .loader-drop { display: none !important; }
}

/* --------------------------------------------------------------------------
   27. UTILITAIRES
   -------------------------------------------------------------------------- */
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.badge-triptych { display: flex; justify-content: center; gap: var(--space-6); flex-wrap: wrap; text-align: center; }
.badge-triptych div { max-width: 200px; }
.badge-triptych svg { width: 26px; height: 26px; stroke: var(--c-or); fill: none; stroke-width: 1; margin-bottom: 10px; }
.section-title-row { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: var(--space-6); flex-wrap: wrap; gap: var(--space-2); }

.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; left: 12px; top: -60px; background: var(--c-vert-seve); color: var(--c-ivoire);
  padding: 10px 18px; z-index: 1000; transition: top var(--dur-fast) var(--ease-lux);
}
.skip-link:focus { top: 12px; }

/* --------------------------------------------------------------------------
   28. COMPATIBILITÉ GABARITS NATIFS WOOCOMMERCE
   (checkout, panier, compte : templates non surchargés — habillage visuel
   uniquement, la logique de paiement/compte reste 100% gérée par WooCommerce)
   -------------------------------------------------------------------------- */
.woocommerce-message, .woocommerce-error, .woocommerce-info,
.woocommerce-noreviews, p.no-comments {
  list-style: none;
  background: var(--c-blanc-casse);
  border-left: 2px solid var(--c-or);
  padding: var(--space-2) var(--space-3);
  font-size: var(--fs-small);
  margin: 0 0 var(--space-4);
}
.woocommerce-error { border-left-color: var(--c-terracotta); }

.woocommerce form .form-row label { color: var(--c-text-soft); font-size: var(--fs-small); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout select,
.woocommerce-additional-fields select {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--c-border);
  padding: 12px 2px;
  border-radius: 0;
  transition: border-color var(--dur-fast) var(--ease-lux);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { outline: none; border-color: var(--c-vert-seve); }
.woocommerce form .form-row.woocommerce-invalid input.input-text { border-color: var(--c-terracotta); }

.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce-Button {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--f-sans); font-weight: 500; font-size: var(--fs-button);
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 16px 32px; border: 1px solid var(--c-vert-seve); border-radius: var(--radius);
  background: var(--c-vert-seve); color: var(--c-ivoire) !important;
  transition: background var(--dur-fast) var(--ease-lux), opacity var(--dur-fast) var(--ease-lux);
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover {
  background: var(--c-cacao); opacity: 1;
}
.woocommerce a.button.alt, .woocommerce #place_order {
  width: 100%; justify-content: center;
}

.woocommerce table.shop_table {
  border: none; border-collapse: collapse; width: 100%;
}
.woocommerce table.shop_table th {
  font-family: var(--f-sans); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--c-text-soft); border-bottom: 1px solid var(--c-border); padding: 12px 8px; text-align: left;
}
.woocommerce table.shop_table td {
  border-bottom: 1px solid rgba(31,61,43,0.08); padding: 16px 8px;
}
.woocommerce table.shop_table td.product-thumbnail img { border-radius: var(--radius); max-width: 72px; }
.woocommerce .cart-collaterals .cart_totals { font-family: var(--f-sans); }
.woocommerce .cart_totals table.shop_table { border-top: 1px solid var(--c-border); }
.woocommerce .cart_totals .order-total .amount { font-family: var(--f-serif); font-size: 1.2rem; }

.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review { max-width: 1100px; margin: 0 auto; }
.woocommerce-checkout .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
@media (max-width: 900px) { .woocommerce-checkout .col2-set { grid-template-columns: 1fr; } }
.woocommerce-checkout #payment { background: var(--c-blanc-casse); border-radius: var(--radius); padding: var(--space-3); }
.woocommerce-checkout #payment ul.payment_methods { border: none; padding: 0; }
.woocommerce-checkout #payment div.payment_box { background: transparent; font-size: var(--fs-small); }
.woocommerce-checkout #payment div.payment_box::before { display: none; }

.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; }
.woocommerce-MyAccount-navigation li { border-bottom: 1px solid rgba(31,61,43,0.08); }
.woocommerce-MyAccount-navigation li a { display: block; padding: 12px 0; font-size: var(--fs-small); letter-spacing: 0.04em; }
.woocommerce-MyAccount-navigation li.is-active a { color: var(--c-or); }
.woocommerce-account .woocommerce { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-8); align-items: flex-start; }
@media (max-width: 800px) { .woocommerce-account .woocommerce { grid-template-columns: 1fr; } }
.woocommerce-MyAccount-content { max-width: 720px; }

.star-rating { color: var(--c-or); }
.star-rating::before { color: rgba(31,61,43,0.2); }
.star-rating span::before { color: var(--c-or); }

.quantity .qty {
  width: 56px; text-align: center; border: 1px solid var(--c-border); border-radius: var(--radius);
  background: transparent; padding: 10px;
}

/* la page Panier / Checkout hérite du gabarit narrow du site */
.woocommerce-cart .wrap, .woocommerce-checkout .wrap { max-width: 1100px; }

/* --------------------------------------------------------------------------
   29. BLOCS GUTENBERG (pages éditoriales : Notre histoire, ingrédients…)
   Permet à la fondatrice d'éditer ces pages visuellement, sans code, tout
   en restant fidèle à la charte (§6/§7).
   -------------------------------------------------------------------------- */
.page-content { max-width: 900px; margin: 0 auto; }
.page-content h2 { margin: var(--space-6) 0 var(--space-2); }
.page-content h3 { margin: var(--space-4) 0 var(--space-1); }
.page-content p { max-width: none; }
.page-content > * + * { margin-top: var(--space-2); }

.wp-block-media-text {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8);
  align-items: center; margin: var(--section-space) 0;
}
.wp-block-media-text .wp-block-media-text__media img { border-radius: var(--radius); aspect-ratio: 4/5; object-fit: cover; width: 100%; }
.wp-block-media-text .wp-block-media-text__content { padding: 0; }
.has-media-on-the-right.wp-block-media-text .wp-block-media-text__media { order: 2; }
@media (max-width: 900px) {
  .wp-block-media-text, .has-media-on-the-right.wp-block-media-text { grid-template-columns: 1fr; }
  .has-media-on-the-right.wp-block-media-text .wp-block-media-text__media { order: 0; }
}

.page-content blockquote, .wp-block-quote {
  font-family: var(--f-serif); font-style: italic; font-size: var(--fs-h3);
  border-left: 2px solid var(--c-or); padding-left: var(--space-3); margin: var(--space-4) 0;
}
.wp-block-columns { gap: var(--space-6); }
.wp-block-button__link { font-family: var(--f-sans); }
