/* =========================================================================
   LE BOCAL — Pâtes à tartiner artisanales
   Feuille de style globale / système de design
   Auteur : direction artistique pour Louka
   --------------------------------------------------------------------------
   Sommaire :
   1.  Tokens (couleurs, type, espacements)
   2.  Reset & base
   3.  Typographie
   4.  Layout (container, sections, grilles)
   5.  Boutons & champs
   6.  Header / navigation / drawer panier
   7.  Marquee (bandeau défilant)
   8.  Bocaux interactifs (élément clé)
   9.  Hero
   10. Cartes produit, grille boutique, filtres
   11. Page produit
   12. À propos
   13. Contact / formulaires
   14. Panier (page)
   15. Footer
   16. Animations d'apparition au scroll
   17. Responsive
   18. Accessibilité / reduced-motion
   ========================================================================= */

/* =========================================================================
   1. TOKENS
   ========================================================================= */
:root {
  /* Palette imposée -------------------------------------------------------*/
  --cream:        #FAF1E4;  /* fond principal / grands aplats             */
  --milk:         #A6713F;  /* chocolat lait — accent chaud               */
  --dark:         #2A1A12;  /* chocolat noir — texte + CTA                */
  --white-choc:   #EFE0C7;  /* chocolat blanc — surfaces secondaires      */

  /* Nuances dérivées (cohérentes, tone-on-tone) ------------------------- */
  --cream-deep:   #F3E6D1;  /* fond de section alterné                    */
  --milk-dark:    #8A5A2F;  /* hover du chocolat lait                     */
  --dark-soft:    #3D281C;  /* surfaces foncées plus douces               */
  --dark-2:       #1E120B;  /* noir le plus profond                       */
  --line:         rgba(42, 26, 18, .14);   /* filets/bordures             */
  --line-soft:    rgba(42, 26, 18, .08);

  /* Typo ----------------------------------------------------------------- */
  --font-display: "Bricolage Grotesque", "Hanken Grotesk", sans-serif;
  --font-body:    "Hanken Grotesk", system-ui, sans-serif;

  /* Échelle fluide harmonisée (ratio ~1.5 régulier, sans saut brutal) ----
     clamp = responsive sans média-queries. Le plafond de --step-5 a été
     ramené de 11rem à 7.5rem pour éviter les titres démesurés et garder
     une vraie cohérence entre les pages. */
  --step--1: clamp(.83rem, .80rem + .14vw, .92rem);
  --step-0:  clamp(1rem, .96rem + .2vw, 1.1rem);    /* corps */
  --step-1:  clamp(1.18rem, 1.08rem + .45vw, 1.45rem);
  --step-2:  clamp(1.5rem, 1.28rem + .95vw, 2.1rem);
  --step-3:  clamp(2rem, 1.6rem + 1.7vw, 3rem);
  --step-4:  clamp(2.6rem, 2rem + 2.6vw, 4.4rem);
  --step-5:  clamp(3.1rem, 2.2rem + 4vw, 6rem);
  --step-6:  clamp(3.6rem, 2.4rem + 5.4vw, 7.5rem);  /* réservé aux héros */

  /* Espacements & rythme ------------------------------------------------- */
  --gap:      clamp(1rem, .8rem + 1vw, 1.5rem);
  --pad-x:    clamp(1.2rem, .5rem + 3.5vw, 4rem);
  --section-y:clamp(3.5rem, 2rem + 7vw, 9rem);
  --radius:   18px;
  --radius-lg: 30px;
  --maxw:     1320px;

  --shadow:   0 30px 60px -30px rgba(42, 26, 18, .45);
  --shadow-sm:0 12px 30px -18px rgba(42, 26, 18, .55);

  --ease:     cubic-bezier(.16, 1, .3, 1);   /* easing « premium » doux    */
}

/* =========================================================================
   1b. THÈME NOIR & BLANC
   --------------------------------------------------------------------------
   On surcharge UNIQUEMENT les variables de couleur : tout le reste du
   système (espacements, type, ombres) suit automatiquement. Les niveaux
   de gris sont calibrés pour conserver un contraste de texte AA.
   Transition douce sur le changement de thème.
   ========================================================================= */
:root[data-theme="bw"] {
  --cream:      #F4F4F2;
  --milk:       #595959;   /* « accent » devient gris moyen (AA sur crème) */
  --dark:       #161616;
  --white-choc: #E2E2E0;

  --cream-deep: #E8E8E6;
  --milk-dark:  #3E3E3E;
  --dark-soft:  #2A2A2A;
  --dark-2:     #0D0D0D;
  --line:       rgba(22, 22, 22, .16);
  --line-soft:  rgba(22, 22, 22, .08);
}
:root[data-theme="bw"] ::selection { background: #161616; color: #F4F4F2; }

/* Désature les éléments qui portent des couleurs de parfum codées en dur
   (pastilles du hero, points de parfum, miniatures SVG) pour un N&B cohérent.
   Les bocaux 3D, eux, se recolorent déjà proprement via JS. */
:root[data-theme="bw"] .hero__switch button,
:root[data-theme="bw"] .flavor-switch .dot,
:root[data-theme="bw"] .product-card__flavor .dot,
:root[data-theme="bw"] .chip .dot,
:root[data-theme="bw"] .jar-stage,
:root[data-theme="bw"] .jar-3d-fallback { filter: grayscale(1); }

/* La transition de thème s'applique aux grandes surfaces colorées. */
body, .site-header, .section, .section--dark, .product-card, .cart-drawer,
.btn, .chip, .input, .select, .textarea, .footer-cta, .values > * {
  transition: background-color .5s var(--ease), color .5s var(--ease), border-color .5s var(--ease);
}

/* =========================================================================
   2. RESET & BASE
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: var(--step-0);
  line-height: 1.55;
  color: var(--dark);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;        /* clip (et non hidden) : évite de faire du body un conteneur de défilement, ce qui casserait scrollIntoView / l'IntersectionObserver */
  position: relative;
  min-height: 100vh;
}

/* Grain fin pour une atmosphère « papier » premium (très léger) */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: .04;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
ul { list-style: none; }
::selection { background: var(--milk); color: var(--cream); }

:focus-visible {
  outline: 2px solid var(--milk);
  outline-offset: 3px;
  border-radius: 4px;
}

/* =========================================================================
   3. TYPOGRAPHIE
   ========================================================================= */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: .95;
  letter-spacing: -.02em;
  text-wrap: balance;
}

.display {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: .88;
  letter-spacing: -.035em;
  text-transform: none;
}

/* Tailles de titres sémantiques — à utiliser à la place des font-size inline.
   Une seule source de vérité pour toute la hiérarchie visuelle du site. */
.t-hero { font-size: var(--step-6); line-height: .86; }  /* H1 d'accueil */
.t-xl   { font-size: var(--step-5); line-height: .9; }   /* gros titres de page */
.t-lg   { font-size: var(--step-4); line-height: .92; }
.t-md   { font-size: var(--step-3); line-height: .98; }
.t-sm   { font-size: var(--step-2); line-height: 1.05; }

.eyebrow {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--step--1);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--milk);
  display: inline-flex;
  align-items: center;
  gap: .6em;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 2px;
  background: currentColor;
  display: inline-block;
}

.lede { font-size: var(--step-1); line-height: 1.4; font-weight: 500; }
.muted { color: color-mix(in srgb, var(--dark) 62%, var(--cream)); }
em.serif { font-style: italic; }

/* =========================================================================
   4. LAYOUT
   ========================================================================= */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad-x); }
.section { padding-block: var(--section-y); position: relative; }
.section--cream-deep { background: var(--cream-deep); }
.section--dark { background: var(--dark); color: var(--cream); }
.section--dark .muted { color: color-mix(in srgb, var(--cream) 65%, var(--dark)); }
.section--dark .eyebrow { color: var(--white-choc); }

.stack > * + * { margin-top: var(--gap); }
.center { text-align: center; }
.grid { display: grid; gap: var(--gap); }

/* en-tête de section réutilisable */
.section-head { max-width: 60ch; }
.section-head.center { margin-inline: auto; }
.section-head h2 { font-size: var(--step-3); margin-top: .5rem; }

/* =========================================================================
   5. BOUTONS & CHAMPS
   ========================================================================= */
.btn {
  --bg: var(--dark);
  --fg: var(--cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6em;
  padding: .95em 1.7em;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--step--1);
  letter-spacing: .04em;
  text-transform: uppercase;
  border-radius: 100px;
  border: 1.5px solid var(--bg);
  transition: transform .5s var(--ease), background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
  position: relative;
  will-change: transform;
}
.btn:hover { background: var(--milk); border-color: var(--milk); color: var(--cream); transform: translateY(-3px); }
.btn:active { transform: translateY(0) scale(.98); }
.btn .btn__arrow { transition: transform .45s var(--ease); }
.btn:hover .btn__arrow { transform: translateX(5px); }

.btn--ghost { --bg: transparent; --fg: var(--dark); border-color: var(--dark); }
.btn--ghost:hover { background: var(--dark); color: var(--cream); border-color: var(--dark); }
.btn--cream { --bg: var(--cream); --fg: var(--dark); }
.btn--cream:hover { background: var(--white-choc); border-color: var(--white-choc); color: var(--dark); }
.btn--lg { padding: 1.15em 2.2em; font-size: var(--step-0); }
.btn--block { width: 100%; }

/* lien souligné animé */
.link-u { position: relative; font-weight: 700; }
.link-u::after {
  content: ""; position: absolute; left: 0; bottom: -3px;
  width: 100%; height: 2px; background: currentColor;
  transform: scaleX(0); transform-origin: right; transition: transform .4s var(--ease);
}
.link-u:hover::after { transform: scaleX(1); transform-origin: left; }

/* champs de formulaire */
.field { display: flex; flex-direction: column; gap: .5rem; }
.field label { font-weight: 700; font-size: var(--step--1); letter-spacing: .04em; }
.input, .textarea, .select {
  font: inherit;
  padding: .95em 1.1em;
  background: var(--cream);
  border: 1.5px solid var(--line);
  border-radius: 14px;
  color: var(--dark);
  transition: border-color .3s var(--ease), background .3s var(--ease);
  width: 100%;
}
.section--dark .input, .section--dark .textarea, .section--dark .select { background: var(--dark-soft); border-color: rgba(250,241,228,.2); color: var(--cream); }
.input:focus, .textarea:focus, .select:focus { outline: none; border-color: var(--milk); }
.textarea { resize: vertical; min-height: 140px; }

/* puce / tag */
.chip {
  display: inline-flex; align-items: center; gap: .5em;
  padding: .5em 1.05em; border-radius: 100px;
  border: 1.5px solid var(--line);
  font-weight: 700; font-size: var(--step--1);
  letter-spacing: .03em;
  background: transparent; color: var(--dark);
  transition: all .35s var(--ease);
}
.chip .dot { width: 11px; height: 11px; border-radius: 50%; }
.chip:hover { border-color: var(--dark); }
.chip[aria-pressed="true"], .chip.is-active { background: var(--dark); color: var(--cream); border-color: var(--dark); }

/* =========================================================================
   6. HEADER / NAVIGATION / DRAWER PANIER
   ========================================================================= */
.site-header {
  position: sticky; top: 0; z-index: 200;
  background: color-mix(in srgb, var(--cream) 80%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .4s var(--ease), background .4s var(--ease);
}
.site-header.is-scrolled { border-color: var(--line); }
.nav {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
  height: clamp(64px, 4.5vw, 84px);
}
.brand {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.25rem, 1rem + 1vw, 1.7rem);
  letter-spacing: -.03em;
  display: inline-flex; align-items: center; gap: .55em;
  line-height: 1;
}
.brand__mark { width: 1.05em; height: 1.05em; flex: 0 0 auto; }

.nav__links { display: flex; align-items: center; gap: clamp(1.2rem, 2vw, 2.4rem); }
.nav__links a { font-weight: 600; font-size: var(--step--1); letter-spacing: .03em; position: relative; padding-block: .3em; }
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 2px; width: 100%;
  background: var(--milk); transform: scaleX(0); transform-origin: right; transition: transform .35s var(--ease);
}
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after { transform: scaleX(1); transform-origin: left; }
.nav__links a[aria-current="page"] { color: var(--milk); }

.nav__actions { display: flex; align-items: center; gap: .7rem; }

/* Sélecteur de langue FR / EN / IT */
.lang { display: inline-flex; align-items: center; gap: 2px; padding: 3px; border: 1.5px solid var(--line); border-radius: 100px; }
.lang__btn {
  min-width: 2.2em; padding: .3em .5em; border-radius: 100px;
  font-weight: 700; font-size: .72rem; letter-spacing: .06em; color: var(--dark);
  transition: background .25s var(--ease), color .25s var(--ease);
}
.lang__btn:hover { color: var(--milk); }
.lang__btn[aria-pressed="true"] { background: var(--dark); color: var(--cream); }

/* Bouton de bascule de thème (couleur ⇄ noir & blanc) */
.icon-btn {
  width: 40px; height: 40px; border-radius: 50%;
  display: inline-grid; place-items: center;
  border: 1.5px solid var(--line); color: var(--dark);
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .3s var(--ease);
}
.icon-btn:hover { border-color: var(--dark); transform: rotate(-12deg); }
.icon-btn:active { transform: scale(.92); }

/* bouton panier */
.cart-btn { position: relative; display: inline-flex; align-items: center; gap: .5em; padding: .6em .9em; border-radius: 100px; border: 1.5px solid var(--dark); font-weight: 700; font-size: var(--step--1); transition: background .3s var(--ease), color .3s var(--ease); }
.cart-btn:hover { background: var(--dark); color: var(--cream); }
.cart-btn__count {
  min-width: 1.5em; height: 1.5em; padding: 0 .3em;
  display: inline-grid; place-items: center;
  background: var(--milk); color: var(--cream);
  border-radius: 100px; font-size: .72em; font-weight: 800;
  transition: transform .4s var(--ease);
}
.cart-btn__count.bump { animation: bump .5s var(--ease); }
@keyframes bump { 0%{transform:scale(1)} 35%{transform:scale(1.45)} 100%{transform:scale(1)} }

/* burger mobile */
.burger { display: none; width: 44px; height: 44px; border-radius: 12px; border: 1.5px solid var(--dark); position: relative; }
.burger span { position: absolute; left: 50%; top: 50%; width: 18px; height: 2px; background: var(--dark); transform: translate(-50%, -50%); transition: .4s var(--ease); }
.burger span:nth-child(1) { translate: 0 -5px; }
.burger span:nth-child(3) { translate: 0 5px; }
body.menu-open .burger span:nth-child(1) { translate: 0 0; rotate: 45deg; }
body.menu-open .burger span:nth-child(2) { opacity: 0; }
body.menu-open .burger span:nth-child(3) { translate: 0 0; rotate: -45deg; }

/* panneau mobile + drawer panier : overlay commun */
.overlay {
  position: fixed; inset: 0; z-index: 250;
  background: rgba(30,18,11,.45);
  backdrop-filter: blur(3px);
  opacity: 0; visibility: hidden; transition: opacity .4s var(--ease), visibility .4s var(--ease);
}
.overlay.is-open { opacity: 1; visibility: visible; }

/* menu mobile plein écran */
.mobile-menu {
  position: fixed; inset: 0 0 0 auto; z-index: 260; width: min(86vw, 420px);
  background: var(--dark); color: var(--cream);
  transform: translateX(100%); transition: transform .55s var(--ease);
  display: flex; flex-direction: column; padding: clamp(1.5rem,5vw,3rem);
}
body.menu-open .mobile-menu { transform: translateX(0); }
.mobile-menu a { display: block; font-family: var(--font-display); font-weight: 800; font-size: var(--step-3); letter-spacing: -.02em; padding-block: .25em; opacity: 0; transform: translateY(20px); }
body.menu-open .mobile-menu a { opacity: 1; transform: none; transition: opacity .5s var(--ease), transform .5s var(--ease); }
body.menu-open .mobile-menu a:nth-child(1){ transition-delay:.12s } 
body.menu-open .mobile-menu a:nth-child(2){ transition-delay:.18s }
body.menu-open .mobile-menu a:nth-child(3){ transition-delay:.24s }
body.menu-open .mobile-menu a:nth-child(4){ transition-delay:.30s }
body.menu-open .mobile-menu a:nth-child(5){ transition-delay:.36s }
.mobile-menu__foot { margin-top: auto; color: var(--white-choc); font-size: var(--step--1); }

/* sélecteur de langue à l'intérieur du menu mobile (sur fond foncé) */
.mobile-menu .lang { display: inline-flex; border-color: rgba(250,241,228,.3); }
.mobile-menu .lang__btn { color: var(--cream); font-size: .85rem; min-width: 2.6em; padding: .45em .7em; }
.mobile-menu .lang__btn[aria-pressed="true"] { background: var(--cream); color: var(--dark); }

/* drawer panier */
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 270;
  width: min(92vw, 440px); background: var(--cream);
  transform: translateX(100%); transition: transform .55s var(--ease);
  display: flex; flex-direction: column; box-shadow: var(--shadow);
}
.cart-drawer.is-open { transform: translateX(0); }
.cart-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 1.4rem clamp(1.2rem,4vw,1.8rem); border-bottom: 1px solid var(--line); }
.cart-drawer__head h3 { font-size: var(--step-2); }
.cart-drawer__close { width: 40px; height: 40px; border-radius: 50%; border: 1.5px solid var(--line); display: grid; place-items: center; transition: .3s var(--ease); }
.cart-drawer__close:hover { background: var(--dark); color: var(--cream); }
.cart-drawer__body { flex: 1; overflow-y: auto; padding: clamp(1.2rem,4vw,1.8rem); display: flex; flex-direction: column; gap: 1.1rem; }
.cart-drawer__foot { padding: clamp(1.2rem,4vw,1.8rem); border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 1rem; }
.cart-empty { text-align: center; color: var(--milk); margin: auto 0; }
.cart-empty svg { margin: 0 auto 1rem; opacity: .5; }

/* ligne panier */
.cart-line { display: grid; grid-template-columns: 64px 1fr auto; gap: 1rem; align-items: center; }
.cart-line__thumb { width: 64px; height: 64px; border-radius: 14px; overflow: hidden; background: var(--white-choc); display: grid; place-items: center; }
.cart-line__thumb svg { width: 70%; height: 70%; }
.cart-line__name { font-weight: 700; line-height: 1.2; }
.cart-line__meta { font-size: var(--step--1); color: var(--milk); }
.cart-line__qty { display: inline-flex; align-items: center; gap: .4rem; margin-top: .4rem; }
.qty-btn { width: 26px; height: 26px; border-radius: 8px; border: 1.5px solid var(--line); display: grid; place-items: center; font-weight: 800; line-height: 1; transition: .25s var(--ease); }
.qty-btn:hover { background: var(--dark); color: var(--cream); border-color: var(--dark); }
.cart-line__right { text-align: right; font-weight: 800; }
.cart-line__remove { display: block; font-size: var(--step--1); color: var(--milk); margin-top: .4rem; }
.cart-line__remove:hover { text-decoration: underline; }
.cart-total { display: flex; align-items: baseline; justify-content: space-between; font-weight: 800; font-size: var(--step-1); }

/* =========================================================================
   7. MARQUEE
   ========================================================================= */
.marquee { background: var(--dark); color: var(--cream); overflow: hidden; padding-block: .85rem; border-block: 1px solid var(--dark); }
.marquee__track { display: flex; gap: 2.5rem; width: max-content; animation: marquee 32s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee span { display: inline-flex; align-items: center; gap: 2.5rem; font-family: var(--font-display); font-weight: 800; font-size: clamp(1rem,.8rem+1vw,1.6rem); letter-spacing: -.01em; text-transform: uppercase; white-space: nowrap; }
.marquee span::after { content: "✦"; color: var(--milk); }
@keyframes marquee { to { transform: translateX(-50%); } }

/* =========================================================================
   8. BOCAUX INTERACTIFS — élément clé
   ========================================================================= */
.jar-stage {
  perspective: 1100px;          /* donne la profondeur 3D au survol        */
  display: inline-block;
  position: relative;
  user-select: none;
  cursor: pointer;
  --rx: 0deg; --ry: 0deg;        /* mis à jour par jars.js (inclinaison)    */
}
.jar-3d {
  transform-style: preserve-3d;
  transform: rotateX(var(--rx)) rotateY(var(--ry));
  transition: transform .6s var(--ease);
}
.jar-stage.is-hovering .jar-3d { transition: transform .12s linear; } /* suivi souris réactif */

.jar-svg { width: clamp(170px, 22vw, 280px); height: auto; overflow: visible; filter: drop-shadow(0 26px 30px rgba(42,26,18,.30)); }

/* le couvercle : groupe pivoté / soulevé à l'ouverture */
.jar__lid {
  transform-box: fill-box;
  transform-origin: 90% 90%;
  transition: transform .7s var(--ease);
}
.jar-stage.is-open .jar__lid { transform: translateY(-50px) rotate(-24deg); }

/* surface de la pâte qui « respire » légèrement */
.jar__paste-top { transform-box: fill-box; transform-origin: center; }
.jar-stage.is-open .jar__paste-top { animation: paste-rise 3.4s var(--ease) infinite alternate; }
@keyframes paste-rise { from { transform: translateY(2px); } to { transform: translateY(-3px); } }

/* coulée de pâte : masquée puis révélée à l'ouverture */
.jar__pour { opacity: 0; transform-box: fill-box; transform-origin: top center; transform: scaleY(0); transition: opacity .3s var(--ease); }
.jar-stage.is-open .jar__pour { opacity: 1; animation: pour 1.4s var(--ease) forwards; }
@keyframes pour { 0% { transform: scaleY(0); } 60% { transform: scaleY(1.05); } 100% { transform: scaleY(1); } }

/* dollop / goutte qui se forme en bas */
.jar__drip { opacity: 0; transform-box: fill-box; transform-origin: center top; transform: scale(0); }
.jar-stage.is-open .jar__drip { animation: drip 1.6s var(--ease) .5s forwards; }
@keyframes drip { 0% { opacity:0; transform: scale(0); } 30% { opacity:1; } 100% { opacity:1; transform: scale(1); } }

/* reflets du verre, légère parallaxe via translate au survol */
.jar__shine { opacity: .85; mix-blend-mode: screen; }

/* état sélectionné */
.jar-stage.is-selected::after {
  content: "";
  position: absolute; left: 50%; bottom: -14px; transform: translateX(-50%);
  width: 64%; height: 14px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(42,26,18,.28), transparent 70%);
}
.jar-stage.is-selected .jar-svg { filter: drop-shadow(0 30px 34px rgba(166,113,63,.5)); }

/* anneau de sélection / badge */
.jar-card { display: flex; flex-direction: column; align-items: center; gap: 1.2rem; }
.jar-card__name { font-family: var(--font-display); font-weight: 800; font-size: var(--step-2); letter-spacing: -.02em; text-align: center; }
.jar-card__price { font-weight: 700; color: var(--milk); }
.jar-card__hint { font-size: var(--step--1); color: color-mix(in srgb, var(--dark) 55%, var(--cream)); }
.section--dark .jar-card__hint { color: color-mix(in srgb, var(--cream) 55%, var(--dark)); }

/* quintet de pots sur l'accueil (5 → 3 → 2 colonnes) */
.jars-quintet { display: grid; grid-template-columns: repeat(5, 1fr); gap: clamp(.8rem, 2vw, 1.8rem); align-items: end; }
@media (max-width: 1100px) { .jars-quintet { grid-template-columns: repeat(3, 1fr); gap: 2rem 1.4rem; } }
@media (max-width: 620px) { .jars-quintet { grid-template-columns: repeat(2, 1fr); gap: 2rem 1rem; } }

/* =========================================================================
   9. HERO
   ========================================================================= */
.hero { position: relative; padding-top: clamp(2rem, 4vw, 4rem); padding-bottom: var(--section-y); overflow: hidden; }
.hero__bg {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 50% at 80% 12%, rgba(166,113,63,.22), transparent 60%),
    radial-gradient(50% 40% at 10% 90%, rgba(239,224,199,.6), transparent 60%);
}
.hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 4vw, 4rem); align-items: center; }
.hero__title { font-size: var(--step-5); letter-spacing: -.04em; }
.hero__title .accent { color: var(--milk); }
.hero__title .outline { -webkit-text-stroke: 2px var(--dark); color: transparent; }
.hero__sub { max-width: 44ch; margin-top: 1.6rem; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.2rem; }
.hero__stage { position: relative; display: grid; place-items: center; min-height: 380px; }
/* halo derrière le bocal du hero */
.hero__stage::before {
  content: ""; position: absolute; width: 78%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, var(--white-choc), transparent 68%);
  z-index: -1;
}
.hero__switch { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); display: flex; gap: .6rem; }
.hero__switch button { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--dark); transition: .3s var(--ease); }
.hero__switch button[aria-pressed="true"] { transform: scale(1.25); }

.hero__scroll { margin-top: 3rem; display: inline-flex; align-items: center; gap: .6rem; font-size: var(--step--1); letter-spacing: .12em; text-transform: uppercase; font-weight: 700; color: var(--milk); }
.hero__scroll .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--milk); animation: scroll-dot 1.6s var(--ease) infinite; }
@keyframes scroll-dot { 0%,100%{transform:translateY(0);opacity:1} 50%{transform:translateY(6px);opacity:.4} }

/* bande de réassurance sous le hero */
.assurance { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border-block: 1px solid var(--line); }
.assurance > div { background: var(--cream); padding: 1.4rem var(--pad-x); display: flex; flex-direction: column; gap: .2rem; }
.assurance strong { font-family: var(--font-display); font-size: var(--step-1); }
.assurance span { font-size: var(--step--1); color: var(--milk); }

/* =========================================================================
   10. CARTES PRODUIT / GRILLE / FILTRES
   ========================================================================= */
.shop-toolbar { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: clamp(1.5rem,3vw,2.5rem); }
.filters { display: flex; flex-wrap: wrap; gap: .6rem; }
.shop-count { font-size: var(--step--1); color: var(--milk); font-weight: 700; }

.products-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 2.5vw, 2.2rem); }

.product-card {
  position: relative;
  background: var(--cream-deep);
  border-radius: var(--radius-lg);
  padding: clamp(1.4rem, 3vw, 2rem);
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), background .5s var(--ease);
  border: 1px solid transparent;
}
.product-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-sm); border-color: var(--line); }
.product-card__media { aspect-ratio: 1; display: grid; place-items: center; position: relative; }
.product-card__media .jar-stage { transform: scale(.92); }
.product-card__badge { position: absolute; top: 0; left: 0; font-size: var(--step--1); font-weight: 800; letter-spacing: .04em; text-transform: uppercase; padding: .4em .9em; border-radius: 100px; background: var(--dark); color: var(--cream); }
.product-card__flavor { font-size: var(--step--1); font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--milk); margin-top: 1rem; display: inline-flex; align-items: center; gap: .5em; }
.product-card__flavor .dot { width: 10px; height: 10px; border-radius: 50%; }
.product-card__name { font-family: var(--font-display); font-weight: 800; font-size: var(--step-2); letter-spacing: -.02em; margin-top: .3rem; line-height: 1; }
.product-card__desc { color: color-mix(in srgb, var(--dark) 60%, var(--cream)); font-size: var(--step--1); margin-top: .5rem; }
.product-card__foot { margin-top: auto; padding-top: 1.2rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.product-card__price { font-family: var(--font-display); font-weight: 800; font-size: var(--step-1); }
.product-card__add { width: 48px; height: 48px; border-radius: 50%; background: var(--dark); color: var(--cream); display: grid; place-items: center; transition: transform .4s var(--ease), background .35s var(--ease); flex: 0 0 auto; }
.product-card__add:hover { background: var(--milk); transform: rotate(90deg); }
.product-card.is-hidden { display: none; }

/* =========================================================================
   11. PAGE PRODUIT
   ========================================================================= */
.product { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.product__visual { position: sticky; top: 110px; background: var(--cream-deep); border-radius: var(--radius-lg); padding: clamp(2rem,5vw,4rem); display: grid; place-items: center; min-height: 420px; }
.product__visual::before { content: ""; position: absolute; width: 60%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, var(--white-choc), transparent 70%); }
.product__visual .jar-stage { position: relative; z-index: 1; }

.product__title { font-size: var(--step-4); letter-spacing: -.03em; }
.product__price { font-family: var(--font-display); font-weight: 800; font-size: var(--step-3); }
.product__desc { max-width: 52ch; }

.flavor-switch { display: flex; gap: .7rem; flex-wrap: wrap; }
.flavor-switch button { display: inline-flex; align-items: center; gap: .55em; padding: .6em 1.1em; border-radius: 100px; border: 1.5px solid var(--line); font-weight: 700; font-size: var(--step--1); transition: .3s var(--ease); }
.flavor-switch button .dot { width: 13px; height: 13px; border-radius: 50%; }
.flavor-switch button[aria-pressed="true"] { border-color: var(--dark); background: var(--dark); color: var(--cream); }

.buy-row { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.qty-select { display: inline-flex; align-items: center; gap: .8rem; border: 1.5px solid var(--line); border-radius: 100px; padding: .35em .6em; }
.qty-select button { width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; font-weight: 800; font-size: 1.2em; transition: .25s var(--ease); }
.qty-select button:hover { background: var(--dark); color: var(--cream); }
.qty-select output { min-width: 2ch; text-align: center; font-weight: 800; font-variant-numeric: tabular-nums; }

/* accordéon infos produit */
.accordion { border-top: 1px solid var(--line); }
.accordion__item { border-bottom: 1px solid var(--line); }
.accordion__btn { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.2rem 0; font-family: var(--font-display); font-weight: 800; font-size: var(--step-1); text-align: left; }
.accordion__btn .plus { position: relative; width: 18px; height: 18px; flex: 0 0 auto; }
.accordion__btn .plus::before, .accordion__btn .plus::after { content: ""; position: absolute; inset: 0; margin: auto; background: var(--dark); transition: transform .4s var(--ease); }
.accordion__btn .plus::before { width: 100%; height: 2px; }
.accordion__btn .plus::after { width: 2px; height: 100%; }
.accordion__item.is-open .plus::after { transform: scaleY(0); }
.accordion__panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .45s var(--ease); }
.accordion__item.is-open .accordion__panel { grid-template-rows: 1fr; }
.accordion__panel > div { overflow: hidden; }
.accordion__panel p { padding-bottom: 1.3rem; color: color-mix(in srgb, var(--dark) 65%, var(--cream)); }

/* =========================================================================
   12. À PROPOS
   ========================================================================= */
.about-hero { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,4vw,4rem); align-items: center; }
.about-hero h1 { font-size: var(--step-5); }

/* portrait du créateur */
.creator-portrait { margin: 0; position: relative; }
.creator-portrait img {
  width: 100%; height: auto; max-height: 620px; object-fit: cover;
  border-radius: var(--radius-lg); display: block;
  box-shadow: 0 30px 60px rgba(42,26,18,.28);
}
.creator-portrait figcaption {
  margin-top: .9rem; text-align: center; font-size: var(--step--1);
  letter-spacing: .14em; text-transform: uppercase; color: var(--milk); font-weight: 700;
}
:root[data-theme="bw"] .creator-portrait img { filter: grayscale(1); }
.story-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(2rem,5vw,5rem); align-items: center; }
.story-grid.flip .story-grid__media { order: -1; }
.story-grid__media { aspect-ratio: 4/3; border-radius: var(--radius-lg); background: var(--white-choc); display: grid; place-items: center; overflow: hidden; position: relative; }
.story-grid__media .big-num { font-family: var(--font-display); font-weight: 800; font-size: clamp(5rem,14vw,12rem); color: var(--milk); opacity: .25; letter-spacing: -.05em; }
.values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(250,241,228,.15); }
.values > div { background: var(--dark); padding: clamp(1.6rem,3vw,2.4rem); }
.values h3 { font-size: var(--step-2); color: var(--white-choc); }
.values p { margin-top: .6rem; color: color-mix(in srgb, var(--cream) 70%, var(--dark)); }
.timeline { display: grid; gap: 0; }
.timeline__row { display: grid; grid-template-columns: 120px 1fr; gap: clamp(1rem,3vw,2.5rem); padding-block: clamp(1.4rem,3vw,2.2rem); border-top: 1px solid var(--line); }
.timeline__year { font-family: var(--font-display); font-weight: 800; font-size: var(--step-2); color: var(--milk); }
.timeline__row h3 { font-size: var(--step-1); }

/* =========================================================================
   13. CONTACT
   ========================================================================= */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,5rem); align-items: start; }
.contact-info { display: flex; flex-direction: column; gap: 1.6rem; }
.contact-info__item h3 { font-size: var(--step-1); }
.contact-info__item p { color: color-mix(in srgb, var(--dark) 62%, var(--cream)); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.form-grid .field--full { grid-column: 1 / -1; }
.form-note { font-size: var(--step--1); color: var(--milk); }
.form-success { background: var(--white-choc); border-radius: var(--radius); padding: 2rem; text-align: center; }

/* =========================================================================
   14. PANIER (page)
   ========================================================================= */
.cart-page { display: grid; grid-template-columns: 1.6fr .9fr; gap: clamp(2rem,4vw,4rem); align-items: start; }
.cart-list { display: flex; flex-direction: column; }
.cart-row { display: grid; grid-template-columns: 92px 1fr auto; gap: 1.4rem; align-items: center; padding-block: 1.5rem; border-top: 1px solid var(--line); }
.cart-row:last-child { border-bottom: 1px solid var(--line); }
.cart-row__thumb { width: 92px; height: 92px; border-radius: 16px; background: var(--white-choc); display: grid; place-items: center; }
.cart-row__name { font-family: var(--font-display); font-weight: 800; font-size: var(--step-1); }
.cart-summary { background: var(--cream-deep); border-radius: var(--radius-lg); padding: clamp(1.6rem,3vw,2.4rem); position: sticky; top: 110px; }
.cart-summary h3 { font-size: var(--step-2); }
.summary-row { display: flex; justify-content: space-between; padding-block: .7rem; border-bottom: 1px solid var(--line); }
.summary-row--total { border-bottom: none; font-family: var(--font-display); font-weight: 800; font-size: var(--step-2); padding-top: 1.1rem; }

/* =========================================================================
   15. FOOTER
   ========================================================================= */
.site-footer { background: var(--dark); color: var(--cream); padding-top: clamp(3rem,6vw,6rem); }
.footer-cta { text-align: center; padding-bottom: clamp(3rem,6vw,6rem); border-bottom: 1px solid rgba(250,241,228,.15); }
.footer-cta h2 { font-size: var(--step-5); letter-spacing: -.04em; }
.footer-cta .milk { color: var(--milk); }
.footer-main { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; padding-block: clamp(2.5rem,5vw,4rem); }
.footer-main h4 { font-size: var(--step--1); letter-spacing: .18em; text-transform: uppercase; color: var(--white-choc); margin-bottom: 1rem; }
.footer-main a { display: block; padding-block: .35rem; color: color-mix(in srgb, var(--cream) 78%, var(--dark)); transition: color .3s var(--ease); }
.footer-main a:hover { color: var(--milk); }
.footer-brand .brand { font-size: clamp(2rem,4vw,3rem); }
.footer-brand p { color: color-mix(in srgb, var(--cream) 70%, var(--dark)); max-width: 34ch; margin-top: 1rem; }
.footer-news { display: flex; gap: .6rem; margin-top: 1rem; }
.footer-news input { flex: 1; background: var(--dark-soft); border: 1.5px solid rgba(250,241,228,.2); border-radius: 100px; padding: .8em 1.2em; color: var(--cream); font: inherit; }
.footer-news button { width: 48px; height: 48px; border-radius: 50%; background: var(--milk); color: var(--cream); display: grid; place-items: center; flex: 0 0 auto; transition: .3s var(--ease); }
.footer-news button:hover { background: var(--cream); color: var(--dark); }
.footer-bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; padding-block: 2rem; border-top: 1px solid rgba(250,241,228,.15); font-size: var(--step--1); color: color-mix(in srgb, var(--cream) 60%, var(--dark)); }

/* =========================================================================
   16. APPARITIONS AU SCROLL
   ========================================================================= */
[data-reveal] { opacity: 0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].is-visible { opacity: 1; transform: none; }
[data-reveal][data-delay="1"]{ transition-delay:.1s } 
[data-reveal][data-delay="2"]{ transition-delay:.2s }
[data-reveal][data-delay="3"]{ transition-delay:.3s }
[data-reveal][data-delay="4"]{ transition-delay:.4s }

/* page-intro : loader « tartine » qui se lève au chargement -------------- */
.page-veil { position: fixed; inset: 0; z-index: 9998; background: var(--cream); display: grid; place-items: center; transition: opacity .7s var(--ease), visibility .7s; }
.page-veil.is-gone { opacity: 0; visibility: hidden; }

.loader-lid { display: flex; flex-direction: column; align-items: center; }
.loader-lid__text { margin-top: .9rem; font-size: var(--step--1); letter-spacing: .18em; text-transform: uppercase; color: var(--milk); font-weight: 700; }

/* le couvercle tourne sur lui-même, avec un léger « rebond » d'échelle */
.loader-lid__spin {
  width: 96px; height: auto; transform-origin: 50% 50%;
  animation: lidSpin 1.5s cubic-bezier(.65,0,.35,1) infinite, lidPulse 1.5s ease-in-out infinite;
}
@keyframes lidSpin  { to { transform: rotate(360deg); } }
@keyframes lidPulse {
  0%, 100% { filter: drop-shadow(0 8px 14px rgba(42,26,18,.18)); }
  50%      { filter: drop-shadow(0 14px 20px rgba(42,26,18,.28)); }
}

/* =========================================================================
   17. RESPONSIVE
   ========================================================================= */
@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero__stage { order: -1; min-height: 320px; }
  .product { grid-template-columns: 1fr; }
  .product__visual { position: static; }
  .about-hero, .story-grid, .contact-grid, .cart-page { grid-template-columns: 1fr; }
  .story-grid.flip .story-grid__media { order: 0; }
  .cart-summary { position: static; }
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .assurance { grid-template-columns: repeat(2, 1fr); }
  .footer-main { grid-template-columns: 1fr 1fr; }
  .values { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .nav__links { display: none; }
  .burger { display: block; }
  .cart-btn span.label { display: none; }
  
  .form-grid { grid-template-columns: 1fr; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 560px) {
  .products-grid { grid-template-columns: 1fr; }
  .assurance { grid-template-columns: 1fr; }
  .cart-row { grid-template-columns: 64px 1fr; }
  .cart-row__right { grid-column: 2; text-align: left; }
}

/* =========================================================================
   18. ACCESSIBILITÉ — mouvement réduit
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
  .marquee__track { animation: none; }
  [data-reveal] { opacity: 1; transform: none; }
  .jar-3d { transform: none !important; }
}

/* =========================================================================
   19. BOCAUX 3D (WebGL) + REPLI SVG
   ========================================================================= */
.jar3d { width: 100%; height: 100%; min-height: 300px; outline: none; cursor: grab; touch-action: pan-y; }
.jar3d:active { cursor: grabbing; }
.jar3d.is-selected { filter: drop-shadow(0 18px 30px rgba(42,26,18,.28)); }
.jar3d canvas { width: 100% !important; height: 100% !important; }
/* anneau de focus net pour la navigation clavier */
.jar3d:focus-visible { outline: 2px solid var(--milk); outline-offset: 6px; border-radius: 12px; }
.jar-3d-fallback { width: 100%; height: 100%; display: grid; place-items: center; }

/* =========================================================================
   20. ACCESSIBILITÉ — utilitaires
   ========================================================================= */
/* contenu réservé aux lecteurs d'écran */
.sr-only {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
/* lien d'évitement : caché jusqu'au focus clavier */
.skip-link {
  position: fixed; top: -100px; left: 12px; z-index: 10000;
  background: var(--dark); color: var(--cream);
  padding: .8em 1.2em; border-radius: 0 0 12px 12px; font-weight: 700;
  transition: top .25s var(--ease);
}
.skip-link:focus { top: 0; }

/* =========================================================================
   21. AJUSTEMENTS RESPONSIVE pour les nouveaux composants du header
   ========================================================================= */
@media (max-width: 980px) {
  .lang { display: none; }              /* la langue passe dans le menu mobile */
}
@media (max-width: 760px) {
  .cart-btn { padding: .55em; }
}

/* variante mouvement réduit : loader statique (pâte déjà étalée) */
@media (prefers-reduced-motion: reduce) {
  .loader-lid__spin { animation: none; }
}

/* =========================================================================
   22. POTS EN VRAIES PHOTOS (mise en valeur)
   ========================================================================= */
.jar-photo { position: relative; display: grid; place-items: center; width: 100%; min-height: 300px; }
.jar-photo-slot { width: 100%; min-height: 340px; height: 100%; }
.jar-photo__img {
  position: relative; z-index: 2; width: auto; height: 86%; max-height: 440px;
  object-fit: contain; will-change: transform;
  transition: opacity .25s var(--ease), filter .25s var(--ease);
  filter: drop-shadow(0 22px 28px rgba(42, 26, 18, .28));
  -webkit-user-select: none; user-select: none;
}
.jar-photo.is-hover .jar-photo__img { filter: drop-shadow(0 30px 38px rgba(42, 26, 18, .34)); }
.jar-photo__img.is-swapping { opacity: 0; }

/* halo lumineux derrière le pot (donne du relief sur les fonds) */
.jar-photo__halo {
  position: absolute; z-index: 1; width: 78%; height: 78%; border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 247, 233, .85) 0%, rgba(255, 247, 233, 0) 68%);
  filter: blur(6px);
}
.section--dark .jar-photo__halo { background: radial-gradient(circle, rgba(166, 113, 63, .35) 0%, rgba(166, 113, 63, 0) 70%); }

/* ombre portée au sol */
.jar-photo__shadow {
  position: absolute; z-index: 0; bottom: 7%; width: 56%; height: 26px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(42, 26, 18, .28) 0%, rgba(42, 26, 18, 0) 72%);
  transition: transform .3s var(--ease), opacity .3s var(--ease);
}
.jar-photo.is-hover .jar-photo__shadow { transform: scale(1.06); opacity: .85; }

/* léger flottement continu (désactivé si reduced-motion / tactile) */
@media (hover: hover) {
  @media (prefers-reduced-motion: no-preference) {
    .jar-photo__img { animation: jarFloat 5.5s ease-in-out infinite; }
    .jar-photo.is-hover .jar-photo__img { animation: none; } /* la parallaxe prend le relais */
  }
}
@keyframes jarFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* en thème N&B, on désature légèrement les photos pour rester cohérent */
:root[data-theme="bw"] .jar-photo__img { filter: grayscale(1) drop-shadow(0 22px 28px rgba(0, 0, 0, .3)); }

/* le logo dans le header remplace le wordmark texte */
.brand__logo { height: 30px; width: auto; display: block; }
@media (max-width: 560px) { .brand__logo { height: 26px; } }

/* miniatures de pot (cartes boutique, panier, drawer, produits liés) */
.jar-mini { width: 100%; height: 100%; object-fit: contain; display: block;
  filter: drop-shadow(0 10px 16px rgba(42,26,18,.18)); -webkit-user-select: none; user-select: none; }
.product-card__media .jar-mini { max-height: 260px; margin-inline: auto; transition: transform .4s var(--ease); }
.product-card:hover .jar-mini { transform: translateY(-6px) scale(1.03); }
.cart-row__thumb .jar-mini, .cart-line__thumb .jar-mini { max-height: 76px; }
:root[data-theme="bw"] .jar-mini { filter: grayscale(1) drop-shadow(0 10px 16px rgba(0,0,0,.2)); }
