/* ============================================================
   VESPERA - design minimaliste (chassis MAUBRUME).
   Lampes-bouteilles d'ambiance (Lumen, Onde) + vases imprimes en 3D
   (Faro, Fractal), declines en noir / blanc / dore. Header menu/logo/
   panier + menu overlay, bascule jour/nuit, bascule ESPACE/GRILLE en bas.
   Zero emoji, zero tiret cadratin, eyebrow = texte seul.
   ============================================================ */

:root{
  /* VESPERA - palette chaude (lueur du soir). MODE JOUR */
  --ink:#1A1714; --ink-soft:#6B6259; --paper:#FFFFFF; --bg:#FBF8F3;
  --line:#ECE5DA; --line-2:#E2D9CC; --soft:#F4EFE7;
  --accent:#B8893B; --accent-soft:#E8C88A; --glow:#F4C77B; --wine:#5A2A33; --ok:#3FA277;
  --on-ink:#FFFFFF; /* texte pose SUR un fond var(--ink) ; bascule en nuit (cf bloc dark) */

  /* tons par categorie (Lampes / Vases) + alias heritage MAUBRUME (ne rien casser) */
  --lampes:#EBD6A8; --vases:#D8C7B0;
  --rose:var(--lampes); --orange:var(--accent); --vert:var(--vases);
  --brun:var(--wine); --creme:var(--soft);
  --cream:var(--soft);--cream-2:#EFEAE2;--terre:var(--accent);--encre:var(--ink);
  --verveine:var(--vases);--blush:var(--lampes);--blush-deep:var(--accent);
  --sage:var(--vases);--gold:var(--accent);--cta:var(--ink);--cta-hover:#000;
  --corail:var(--accent);--caramel:var(--wine);--menthe:var(--vases);
  --lavande:var(--accent-soft);--peche:var(--soft);--jaune:var(--soft);--prune:var(--wine);
  --tan:var(--accent);--citron:var(--vases);--pop:var(--accent);--star:#C9A14A;

  --shadow-sm:0 2px 10px rgba(26,23,20,.05);
  --shadow-md:0 14px 36px rgba(26,23,20,.10);
  --shadow-lg:0 28px 64px rgba(26,23,20,.16);
  --radius:14px;--radius-lg:22px;--max:1320px;
  --serif:"Fraunces","Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
}
/* MODE NUIT */
:root[data-theme="dark"]{
  --ink:#F3EBDD; --ink-soft:#B6AB99; --paper:#1E1A16; --bg:#14110E;
  --line:#2E2820; --line-2:#3A332A; --soft:#241F19;
  --accent:#D8AE63; --accent-soft:#4E3F26; --glow:#F0B95E; --wine:#8A4450;
  --lampes:#4E3F26; --vases:#3A332A; --star:#D8AE63;
  --on-ink:#171310; /* en nuit, --ink devient clair -> le texte "sur ink" doit etre sombre */
  --shadow-sm:0 2px 12px rgba(0,0,0,.4);
  --shadow-md:0 18px 44px rgba(0,0,0,.5);
  --shadow-lg:0 32px 76px rgba(0,0,0,.6);
}
/* surfaces blanches MAUBRUME -> suivent le theme en nuit */
:root[data-theme="dark"] .topbar-rotator,:root[data-theme="dark"] .nav,
:root[data-theme="dark"] .menu-overlay,:root[data-theme="dark"] .cart-overlay,
:root[data-theme="dark"] .mb-modal-card,:root[data-theme="dark"] .card,
:root[data-theme="dark"] .family,:root[data-theme="dark"] .mq-card,
:root[data-theme="dark"] .quiz,:root[data-theme="dark"] .site-footer,
:root[data-theme="dark"] .espace,:root[data-theme="dark"] .espace-stage,
:root[data-theme="dark"] .marquee-viewport,:root[data-theme="dark"] .contact-form input,
:root[data-theme="dark"] .contact-form textarea,:root[data-theme="dark"] .mb-news-form input,
:root[data-theme="dark"] .cart-promo input,:root[data-theme="dark"] .foot-news input,
:root[data-theme="dark"] .swatch,:root[data-theme="dark"] .filters button,
:root[data-theme="dark"] .pdp-gufram,:root[data-theme="dark"] .pdp-stage,
:root[data-theme="dark"] .cart-fsbar-track,:root[data-theme="dark"] .cart-item-qty button,
:root[data-theme="dark"] .cart-item-rm,:root[data-theme="dark"] .adr-bar,
:root[data-theme="dark"] .quiz-opt{background:var(--paper)}
:root[data-theme="dark"] .eg-toggle{background:color-mix(in srgb,var(--paper) 80%,transparent)}
/* support des VRAIES images dans cartes + tunnel (sinon placeholder CSS .flacon) */
.card-media img,.espace-item img{width:100%;height:100%;object-fit:cover;display:block;border-radius:var(--radius-lg)}
.espace-item img{border-radius:20px;box-shadow:0 24px 60px rgba(22,22,22,.16),inset 0 0 0 1px rgba(22,22,22,.05)}
:root[data-theme="dark"] .espace-item img{box-shadow:0 24px 60px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.06)}
/* bouton jour/nuit dans la pilule */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;color:var(--ink);padding:2px;margin-right:4px}
.theme-toggle svg{width:20px;height:20px}
.theme-toggle .ico-sun{display:none}.theme-toggle .ico-moon{display:block}
:root[data-theme="dark"] .theme-toggle .ico-sun{display:block}:root[data-theme="dark"] .theme-toggle .ico-moon{display:none}
/* badge bientot (vases) */
.soon-badge{display:inline-block;background:var(--accent);color:#fff;border-radius:999px;padding:2px 9px;font-size:.56rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;vertical-align:middle}
:root[data-theme="dark"] .soon-badge{color:#1a1410}
.card.is-soon{position:relative}
.card.is-soon .card-media::after{content:"Bientot";position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;border-radius:999px;padding:3px 10px;font-family:var(--serif);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;z-index:2}
/* badge "Bientot" des cartes selon la langue (le contenu vient du CSS) */
:root[data-lang="es"] .card.is-soon .card-media::after{content:"Muy pronto"}
:root[data-lang="it"] .card.is-soon .card-media::after{content:"In arrivo"}
:root[data-lang="de"] .card.is-soon .card-media::after{content:"Bald erhältlich"}
:root[data-lang="en"] .card.is-soon .card-media::after{content:"Coming soon"}
:root[data-theme="dark"] .card.is-soon .card-media::after{color:#1a1410}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.02;letter-spacing:-.025em;margin:0}
h1{font-size:clamp(2.4rem,6vw,4.4rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
h3{font-size:clamp(1.1rem,1.7vw,1.4rem);letter-spacing:-.01em}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--serif);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.lead{font-size:clamp(1.02rem,1.3vw,1.18rem);color:var(--ink-soft)}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
.center{text-align:center}.muted{color:var(--ink-soft)}

/* ---------- topbar : petite pilule centree, juste au-dessus de la pilule du header ---------- */
.topbar{background:transparent;color:var(--ink);font-size:.56rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:11px 0 0;position:relative;overflow:visible;border:0;z-index:120}
.topbar-rotator{position:relative;display:inline-flex;align-items:center;height:24px;min-width:300px;max-width:92vw;margin:0 auto;padding:0 20px;background:rgba(255,255,255,.94);backdrop-filter:blur(9px);border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm);overflow:hidden}
/* convoyeur vertical : le message sort completement par le haut, le suivant remonte du bas (clip par la pilule) */
.topbar-msg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap;transform:translateY(125%);transition:transform .5s cubic-bezier(.55,0,.2,1)}
.topbar-msg.active{transform:translateY(0)}
.topbar-msg.leaving{transform:translateY(-125%)}
.topbar-msg.no-anim{transition:none}
.topbar-msg .ic{width:12px;height:12px;color:var(--ink)}
@media(prefers-reduced-motion:reduce){.topbar-msg{transition:none}}

/* ---------- header : menu / logo / panier ---------- */
/* header = petite pilule centree flottante (facon Gufram) */
.site-header{position:sticky;top:0;z-index:120;padding:12px 0;text-align:center;background:transparent;pointer-events:none}
.nav{display:inline-flex;align-items:center;gap:17px;padding:12px 24px;background:rgba(255,255,255,.94);backdrop-filter:blur(9px);border:1px solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm);pointer-events:auto}
.menu-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;color:var(--ink);padding:2px}
.menu-btn svg{width:21px;height:21px}
.menu-btn .menu-label{display:none}  /* mot "Menu" masque : icone seule */
.menu-btn:hover{color:var(--ink-soft)}
.brand{font-family:var(--serif);font-size:1.32rem;font-weight:600;text-transform:none;letter-spacing:.16em;line-height:1}
.brand b{color:var(--accent);font-weight:600}
.brand small{display:none}
.nav-right{display:inline-flex;align-items:center;transition:opacity .2s ease}
/* menu deroulant ouvert : la zone utilitaire droite (panier) s'efface, la pilule se recentre */
html.menu-open .nav-right{opacity:0;visibility:hidden;pointer-events:none}
.cart-btn{position:relative;display:inline-flex;align-items:center;color:var(--ink);transition:transform .2s}
.cart-btn:hover{transform:translateY(-2px)}
.cart-ic{width:21px;height:21px}
.cart-count{position:absolute;top:-6px;right:-8px;background:var(--ink);color:var(--on-ink);border-radius:50%;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700}
.nav-left,.menu-toggle,.has-dropdown{display:none}

/* ---------- menu panneau (ancre sous le header, pas un modal) ---------- */
/* menu = panneau qui se deploie juste sous la pilule du header, sans fond assombri */
.menu-overlay{position:fixed;top:84px;left:50%;transform:translateX(-50%) translateY(-10px);z-index:110;width:min(390px,92vw);max-height:calc(100vh - 100px);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .28s ease,transform .28s ease,visibility .28s;overflow:auto}
.menu-overlay.open{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
/* aucune barre de defilement visible dans les panneaux (le defilement reste actif) */
.menu-overlay,.cart-overlay{scrollbar-width:none;-ms-overflow-style:none}
.menu-overlay::-webkit-scrollbar,.cart-overlay::-webkit-scrollbar{display:none}
.menu-top{display:flex;justify-content:flex-end;align-items:center;padding:11px 14px 4px}
.menu-close{background:none;border:0;font-family:var(--serif);font-weight:700;font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:color .2s}
.menu-close:hover{color:var(--ink)}
.menu-close svg{width:13px;height:13px}
.menu-nav{display:flex;flex-direction:column;align-items:center;gap:1px;padding:22px 18px}
.menu-nav a{font-family:var(--serif);font-weight:700;font-size:1.18rem;text-transform:uppercase;letter-spacing:.01em;color:var(--ink);transition:color .2s,transform .2s;line-height:1.5}
.menu-nav a:hover{color:var(--orange);transform:translateX(6px)}
/* groupe deroulant "Produits" dans le menu (reactive .has-dropdown, masque ailleurs) */
.menu-nav .has-dropdown{display:flex;flex-direction:column;align-items:center;width:100%}
.menu-nav .dd-toggle{display:inline-flex;align-items:center;gap:9px;background:none;border:0;cursor:pointer;font-family:var(--serif);font-weight:700;font-size:1.18rem;text-transform:uppercase;letter-spacing:.01em;color:var(--ink);line-height:1.5;transition:color .2s}
.menu-nav .dd-toggle:hover{color:var(--orange)}
.menu-nav .dd-caret{font-weight:400;font-size:.82em;line-height:1;transition:transform .35s ease;display:inline-block}
.menu-nav .has-dropdown.open .dd-caret{transform:rotate(45deg)}
.menu-nav .dd-panel{overflow:hidden;max-height:0;opacity:.001;transition:max-height .4s cubic-bezier(.2,.8,.25,1),opacity .3s ease;display:flex;flex-direction:column;align-items:center;gap:2px;width:100%}
.menu-nav .has-dropdown.open .dd-panel{max-height:420px;opacity:1;margin-top:7px}
.menu-nav .dd-panel a{font-family:var(--serif);font-weight:600;font-size:.96rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);line-height:1.95;transition:color .2s,transform .2s}
.menu-nav .dd-panel a:hover{color:var(--orange);transform:translateX(6px)}
.menu-foot{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line)}
.menu-foot-cell{display:flex;align-items:center;justify-content:center;gap:7px;padding:12px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--ink)}
.menu-foot-cell + .menu-foot-cell{border-left:1px solid var(--line)}
.menu-foot-cell svg{width:15px;height:15px}
.menu-legal{display:flex;flex-wrap:wrap;gap:8px 14px;justify-content:center;padding:12px;border-top:1px solid var(--line);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.menu-legal a{color:var(--ink-soft)}
.menu-legal a:hover{color:var(--ink)}
/* bascule jour/nuit deplacee DANS le menu (ligne dediee pleine largeur, liberant la pilule du header) */
.menu-theme{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;background:none;border:0;border-top:1px solid var(--line);padding:13px;font-family:var(--sans);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);cursor:pointer;transition:color .2s}
.menu-theme:hover{color:var(--orange)}
.menu-theme svg{width:16px;height:16px}
.menu-theme .ico-sun{display:none}.menu-theme .ico-moon{display:block}
:root[data-theme="dark"] .menu-theme .ico-sun{display:block}:root[data-theme="dark"] .menu-theme .ico-moon{display:none}
.menu-cookies{background:var(--ink);color:var(--on-ink);text-align:center;padding:9px;font-size:.62rem;text-transform:uppercase;letter-spacing:.12em}
/* selecteur de langue / region (entre Jour/Nuit et Confidentialite & cookies) */
.menu-langs{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.menu-langs button{border:0;background:none;padding:11px 6px;font-family:var(--sans);font-size:.64rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-soft);cursor:pointer;transition:color .2s}
.menu-langs button:hover{color:var(--orange)}
.menu-langs button.active{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.menu-langs button:nth-child(n+4){border-top:1px solid var(--line)}
.menu-langs button:nth-child(3n+2),.menu-langs button:nth-child(3n+3){border-left:1px solid var(--line)}
/* apparition en cascade a l'ouverture du menu (revelation progressive, ~1.9s) */
.menu-overlay .menu-top,
.menu-overlay .menu-nav > *,
.menu-overlay .menu-legal,
.menu-overlay .menu-foot,
.menu-overlay .menu-theme,
.menu-overlay .menu-langs,
.menu-overlay .menu-cookies{opacity:0}
.menu-overlay.open .menu-top{animation:menuReveal .6s both .12s}
.menu-overlay.open .menu-nav > *{animation:menuFade .6s both}
.menu-overlay.open .menu-nav > *:nth-child(1){animation-delay:.22s}
.menu-overlay.open .menu-nav > *:nth-child(2){animation-delay:.32s}
.menu-overlay.open .menu-nav > *:nth-child(3){animation-delay:.42s}
.menu-overlay.open .menu-nav > *:nth-child(4){animation-delay:.52s}
.menu-overlay.open .menu-nav > *:nth-child(5){animation-delay:.62s}
.menu-overlay.open .menu-nav > *:nth-child(6){animation-delay:.72s}
.menu-overlay.open .menu-nav > *:nth-child(7){animation-delay:.82s}
.menu-overlay.open .menu-nav > *:nth-child(8){animation-delay:.92s}
.menu-overlay.open .menu-legal{animation:menuReveal .6s both 1.00s}
.menu-overlay.open .menu-foot{animation:menuReveal .6s both 1.13s}
.menu-overlay.open .menu-theme{animation:menuReveal .6s both 1.26s}
.menu-overlay.open .menu-langs{animation:menuReveal .6s both 1.36s}
.menu-overlay.open .menu-cookies{animation:menuReveal .6s both 1.46s}
@keyframes menuReveal{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes menuFade{from{opacity:0}to{opacity:1}}
/* declencheurs cliquables dans le menu */
.menu-foot-cell[data-popup],.menu-cookies[data-popup]{cursor:pointer;transition:background .2s,color .2s}
.menu-foot-cell[data-popup]:hover{color:var(--orange)}
.menu-cookies[data-popup]:hover{background:#2a2a2a}

/* ---------- pop-ups (newsletter + rubriques legales) ---------- */
.mb-modal{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s}
.mb-modal.open{opacity:1;visibility:visible}
.mb-modal-backdrop{position:absolute;inset:0;background:rgba(22,22,22,.5);backdrop-filter:blur(3px)}
.mb-modal-card{position:relative;background:#fff;border-radius:24px;max-width:440px;width:100%;padding:36px 30px 30px;box-shadow:var(--shadow-lg);transform:translateY(16px) scale(.97);transition:transform .4s cubic-bezier(.2,.8,.2,1);max-height:88vh;overflow:auto}
.mb-modal.open .mb-modal-card{transform:none}
.mb-modal-close{position:absolute;top:15px;right:16px;background:none;border:0;color:var(--ink-soft);cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-family:var(--serif);font-weight:700;font-size:.58rem;text-transform:uppercase;letter-spacing:.12em;transition:color .2s}
.mb-modal-close:hover{color:var(--ink)}
.mb-modal-close svg{width:13px;height:13px}
.mb-modal-eyebrow{font-family:var(--sans);font-size:.62rem;text-transform:uppercase;letter-spacing:.22em;color:var(--ink-soft);font-weight:700;text-align:center}
.mb-modal-title{font-family:var(--serif);font-size:1.65rem;font-weight:800;text-transform:uppercase;letter-spacing:-.02em;text-align:center;margin:9px 0 8px;line-height:1.04}
.mb-modal-text{font-size:.9rem;color:var(--ink-soft);text-align:center;line-height:1.5;margin:0 auto 22px;max-width:330px}
/* newsletter */
.mb-news-form{display:flex;flex-direction:column;gap:10px}
.mb-news-form input{border:1.5px solid var(--line-2);border-radius:13px;padding:14px 16px;font-family:var(--sans);font-size:.92rem;color:var(--ink);width:100%}
.mb-news-form input:focus{outline:none;border-color:var(--ink)}
.mb-news-form button{background:var(--ink);color:var(--on-ink);border:0;border-radius:13px;padding:15px;font-family:var(--serif);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;cursor:pointer;transition:opacity .2s}
.mb-news-form button:hover{opacity:.88}
.mb-news-note{font-size:.66rem;color:var(--ink-soft);text-align:center;margin-top:8px}
.mb-news-ok{text-align:center;color:var(--ink);font-size:.96rem;line-height:1.5;padding:14px 0}
/* rubriques legales */
.mb-legal-list{display:flex;flex-direction:column;gap:10px}
.mb-legal-item{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1.5px solid var(--line);border-radius:15px;padding:15px 18px;text-decoration:none;color:var(--ink);transition:border-color .2s,transform .2s}
.mb-legal-item:hover{border-color:var(--ink);transform:translateX(4px)}
.mb-legal-item .mb-legal-t{display:block;font-family:var(--serif);font-weight:700;font-size:.92rem;text-transform:uppercase;letter-spacing:.03em}
.mb-legal-item .mb-legal-d{display:block;font-size:.72rem;color:var(--ink-soft);margin-top:3px}
.mb-legal-item .mb-legal-arrow{font-family:var(--sans);color:var(--ink-soft);font-size:1.15rem;flex:0 0 auto}
/* carte legale : en-tete fige + corps a defilement interne */
.mb-legal-card{padding:0;overflow:hidden;display:flex;flex-direction:column;max-width:580px;width:min(580px,94vw);text-align:left}
.mb-legal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 18px;border-bottom:1px solid var(--line);flex:0 0 auto}
.mb-legal-card .mb-modal-close{position:static}
.mb-legal-back{background:none;border:0;display:inline-flex;align-items:center;gap:6px;font-family:var(--serif);font-weight:700;font-size:.58rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);cursor:pointer;transition:color .2s}
.mb-legal-back:hover{color:var(--ink)}
.mb-legal-back[hidden]{display:none}
.mb-legal-back svg{width:13px;height:13px}
.mb-legal-body{flex:1 1 auto;overflow:auto;padding:24px 26px 28px;-webkit-overflow-scrolling:touch}
/* contenu d'un document legal */
.vlegal-title{font-family:var(--serif);font-size:1.5rem;font-weight:800;text-transform:uppercase;letter-spacing:-.01em;color:var(--ink);margin:6px 0 2px;line-height:1.08}
.vlegal-updated{font-size:.74rem;color:var(--ink-soft);margin:0 0 14px}
.vlegal{font-size:.9rem;color:var(--ink-soft);line-height:1.6}
.vlegal h2{font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--ink);text-transform:none;letter-spacing:0;margin:20px 0 6px}
.vlegal p,.vlegal li{margin:6px 0}
.vlegal ul,.vlegal ol{padding-left:20px;margin:6px 0}
.vlegal strong{color:var(--ink)}
.vlegal a{color:var(--accent);text-decoration:none}
.vlegal a:hover{text-decoration:underline}
.vlegal table{width:100%;border-collapse:collapse;margin:10px 0;font-size:.82rem}
.vlegal th,.vlegal td{border:1px solid var(--line);padding:7px 9px;text-align:left;vertical-align:top}
.vlegal th{background:var(--soft);color:var(--ink);font-weight:700}
.vlegal .fictif{background:var(--soft);border:1px solid var(--line-2);border-radius:10px;padding:11px 14px;font-size:.82rem;color:var(--ink);margin-bottom:14px}
.vlegal .foot{margin-top:20px;border-top:1px solid var(--line);padding-top:10px;font-size:.74rem;color:var(--ink-soft)}
.mb-modal-stagger{opacity:0}
.mb-modal.open .mb-modal-stagger{animation:menuFade .5s both}
@media(prefers-reduced-motion:reduce){.mb-modal-card{transition:none}.mb-modal-stagger{opacity:1}.mb-modal.open .mb-modal-stagger{animation:none}}
@media(prefers-reduced-motion:reduce){
  .menu-overlay .menu-top,.menu-overlay .menu-nav > *,.menu-overlay .menu-legal,.menu-overlay .menu-foot,.menu-overlay .menu-cookies{opacity:1}
  .menu-overlay.open .menu-top,.menu-overlay.open .menu-nav > *,.menu-overlay.open .menu-legal,.menu-overlay.open .menu-foot,.menu-overlay.open .menu-cookies{animation:none}
}
.menu-addr{text-align:center;padding:10px;font-size:.66rem;color:var(--ink-soft)}

/* ---------- panier en pop-up (calque sur le menu) ---------- */
.cart-overlay{position:fixed;top:84px;left:50%;transform:translateX(-50%) translateY(-10px);z-index:115;width:min(420px,94vw);max-height:calc(100vh - 100px);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .28s ease,transform .28s ease,visibility .28s;overflow:hidden}
.cart-overlay.open{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.cart-top{justify-content:space-between;padding:15px 18px 10px}
.cart-title{font-family:var(--serif);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;color:var(--ink)}
.cart-fsbar{margin:0 16px 12px;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;flex:0 0 auto}
.cart-fsbar-label{margin:0 0 9px;font-size:.8rem;color:var(--ink-soft);text-align:center;line-height:1.4}
.cart-fsbar-label b{color:var(--ink);font-weight:700;white-space:nowrap}
.cart-fsbar .fs-check{color:var(--ok);font-weight:700;margin-right:3px}
.cart-fsbar-track{height:8px;border-radius:999px;background:#fff;border:1px solid var(--line);overflow:hidden}
.cart-fsbar-fill{height:100%;width:0;border-radius:999px;background:var(--ink);transition:width .45s ease}
.cart-fsbar.done .cart-fsbar-fill{background:var(--ok)}
.cart-empty{display:none;text-align:center;color:var(--ink-soft);font-size:.92rem;padding:18px 22px 30px}
.cart-empty .btn{display:inline-flex;margin-top:14px}
.cart-items{overflow:auto;padding:0 18px;display:flex;flex-direction:column}
.cart-item{display:grid;grid-template-columns:78px 1fr auto;gap:13px;align-items:center;padding:14px 0;border-top:1px solid var(--line)}
.cart-item:first-child{border-top:0}
.cart-item-ph{width:78px;height:78px;flex:0 0 78px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:inset 0 0 0 1px rgba(22,22,22,.05)}
.cart-item-ph .flacon{margin-bottom:0;width:42%}
.cart-item-ph img{width:100%;height:100%;object-fit:cover;display:block}
/* .ph (placeholder generique, defini plus bas) impose padding 18px et height 100% : on le neutralise */
.cart-item-ph.ph{width:78px;height:78px;padding:0}
.cart-item-name{font-family:var(--serif);font-weight:700;font-size:.85rem;color:var(--ink);text-decoration:none;text-transform:uppercase;letter-spacing:.01em;line-height:1.15;display:block}
.cart-item-name:hover{color:var(--ink-soft)}
.cart-item-unit{font-size:.74rem;color:var(--ink-soft);margin:2px 0 8px}
.cart-item-qty{display:flex;align-items:center;gap:7px}
.cart-item-qty button{width:24px;height:24px;border:1px solid var(--line-2);background:#fff;border-radius:7px;color:var(--ink);cursor:pointer;font-size:.95rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0}
.cart-item-qty button:hover{border-color:var(--ink)}
.cart-item-qty span{min-width:16px;text-align:center;font-size:.84rem;font-weight:600}
.cart-item-end{display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.cart-item-rm{width:28px;height:28px;flex:0 0 28px;border:1px solid var(--line-2);background:#fff;border-radius:8px;color:var(--ink-soft);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:border-color .18s,color .18s,background .18s}
.cart-item-rm:hover{border-color:var(--ink);color:var(--ink);background:var(--soft)}
.cart-item-rm svg{width:15px;height:15px}
.cart-item-line{font-family:var(--serif);font-weight:700;font-size:.86rem;white-space:nowrap}
.cart-foot{border-top:1px solid var(--line);padding:16px 18px 18px;flex:0 0 auto}
.cart-sub{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;font-size:.9rem;color:var(--ink-soft)}
.cart-sub b{font-family:var(--serif);font-size:1.2rem;font-weight:800;color:var(--ink)}
.cart-foot-note{text-align:center;color:var(--ink-soft);font-size:.7rem;margin-top:10px}
/* code promo */
.cart-promo{display:flex;gap:8px;margin-bottom:8px}
.cart-promo input{flex:1;min-width:0;border:1.5px solid var(--line-2);border-radius:11px;padding:11px 13px;font-family:var(--sans);font-size:.85rem;color:var(--ink);background:#fff}
.cart-promo input:focus{outline:none;border-color:var(--ink)}
.cart-promo button{flex:0 0 auto;border:0;background:var(--ink);color:var(--on-ink);border-radius:11px;padding:0 16px;font-family:var(--serif);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}
.cart-promo button:hover{background:#000}
.cart-promo-msg{font-size:.74rem;min-height:0;margin-bottom:6px;line-height:1.4}
.cart-promo-msg:empty{display:none}
.cart-promo-msg.ok{color:var(--ok)}
.cart-promo-msg.err{color:#b4452f}
.cart-promo-msg b{font-weight:700}
.cart-promo-msg [data-promo-clear]{border:0;background:none;color:var(--ink-soft);text-decoration:underline;font-size:.72rem;cursor:pointer;padding:0;margin-left:4px}
.cart-promo-msg [data-promo-clear]:hover{color:var(--ink)}
/* detail des montants */
.cart-lines{border-top:1px solid var(--line);padding-top:12px;margin-bottom:14px;display:flex;flex-direction:column;gap:7px}
.cart-line{display:flex;justify-content:space-between;align-items:baseline;font-size:.84rem;color:var(--ink-soft)}
.cart-line[hidden]{display:none}
.cart-line b{color:var(--ink);font-weight:600}
.cart-line-promo b{color:var(--ok)}
.cart-line.cart-total{margin-top:5px;padding-top:11px;border-top:1px solid var(--line);font-size:.95rem;color:var(--ink)}
.cart-line.cart-total b{font-family:var(--serif);font-size:1.25rem;font-weight:800}
/* recap commande de demonstration */
.cart-demo-recap{text-align:left;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin:0 0 22px}
.cdr-ref{font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft);font-weight:700;margin-bottom:12px}
.cdr-line{display:flex;justify-content:space-between;gap:14px;font-size:.86rem;color:var(--ink);padding:6px 0;border-top:1px solid var(--line)}
.cdr-line:first-of-type{border-top:0}
.cdr-line small{color:var(--ink-soft)}
.cdr-totals{margin-top:12px;padding-top:12px;border-top:1px solid var(--line-2);display:flex;flex-direction:column;gap:6px}
.cdr-tot{display:flex;justify-content:space-between;font-size:.84rem;color:var(--ink-soft)}
.cdr-tot b{color:var(--ink);font-weight:600}
.cdr-grand{margin-top:4px;padding-top:9px;border-top:1px solid var(--line-2);font-size:.98rem;color:var(--ink)}
.cdr-grand b{font-family:var(--serif);font-size:1.2rem;font-weight:800}
@keyframes cartItemIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.cart-item.is-new{animation:cartItemIn .45s cubic-bezier(.2,.8,.25,1) both}
@keyframes cartBump{0%{transform:scale(1)}40%{transform:scale(1.22)}100%{transform:scale(1)}}
.cart-btn.bump .cart-count{animation:cartBump .4s ease}
@media(prefers-reduced-motion:reduce){.cart-item.is-new{animation:none}.cart-fsbar-fill{transition:none}.cart-btn.bump .cart-count{animation:none}}

/* ---------- boutons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--ink);color:var(--on-ink);border:0;border-radius:11px;padding:14px 28px;font-family:var(--serif);font-size:.95rem;font-weight:600;transition:transform .15s,background .2s}
.btn:hover{background:#000;transform:translateY(-2px)}
.btn-block{width:100%}.btn-ink{background:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--on-ink)}
.btn-lg{padding:16px 34px;font-size:1.04rem}

/* ---------- banniere : 5 logos categorie ---------- */
.banner{padding:46px 0 30px}
.banner-head{text-align:center;margin-bottom:30px}
.banner-head h1{text-transform:uppercase}
.banner-head .eyebrow{display:block;margin-bottom:12px}
.banner-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.banner-tile{aspect-ratio:4/5;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-decoration:none;transition:transform .25s,box-shadow .25s;overflow:hidden;position:relative}
.banner-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.banner-logo{font-family:var(--serif);font-weight:800;font-size:clamp(1rem,1.5vw,1.5rem);text-transform:lowercase;letter-spacing:-.03em}
.banner-cat{font-family:var(--serif);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em}
.banner-tile.cat-brumes{background:var(--rose)}
.banner-tile.cat-corps{background:var(--orange)}
.banner-tile.cat-cheveux{background:var(--vert)}
.banner-tile.cat-coffrets{background:var(--brun)}
.banner-tile.cat-abonnements{background:var(--creme)}
.banner-tile.cat-corps .banner-logo,.banner-tile.cat-corps .banner-cat,
.banner-tile.cat-coffrets .banner-logo,.banner-tile.cat-coffrets .banner-cat{color:#fff}
@media(max-width:760px){.banner-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- sections ---------- */
section{scroll-margin-top:80px}
.sec{padding:70px 0}.sec-cream{background:var(--soft)}
.sec-head{max-width:64ch;margin:0 auto 40px;text-align:center}
.sec-head .eyebrow{display:block;margin-bottom:13px}
.sec-head h2{margin-bottom:13px;text-transform:uppercase}
.page-intro{padding:58px 0 48px;text-align:center;border-bottom:1px solid var(--line)}
.page-intro .eyebrow{display:block;margin-bottom:13px}
.page-intro h1{text-transform:uppercase}
.page-intro p{max-width:60ch;margin:15px auto 0}

/* ---------- placeholder visuel : tuile couleur + flacon blanc ---------- */
.ph{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%;height:100%;background:var(--rose);color:var(--ink);font-family:var(--serif);font-weight:600;font-size:.98rem;line-height:1.15;padding:18px}
.ph .ph-note{font-family:var(--sans);font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(22,22,22,.4);margin-top:7px;font-weight:700}
.ph .flacon{width:28%;max-width:66px;aspect-ratio:.46/1;border-radius:15px 15px 10px 10px;background:linear-gradient(160deg,rgba(255,255,255,.96),rgba(255,255,255,.8));box-shadow:inset 0 -8px 15px rgba(0,0,0,.05),0 7px 16px rgba(22,22,22,.11);margin-bottom:13px;position:relative}
.ph .flacon::before{content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:30%;height:11px;background:var(--ink);border-radius:4px 4px 2px 2px}
.ph .flacon::after{content:"";position:absolute;top:34%;left:50%;transform:translateX(-50%);width:54%;height:30%;border-radius:6px;background:rgba(22,22,22,.06)}

/* couleur du placeholder = couleur de la categorie (page ou bande) */
body.cat-brumes .ph,.cat-brumes .ph{background:var(--rose)}
body.cat-corps .ph,.cat-corps .ph{background:var(--orange)}
body.cat-cheveux .ph,.cat-cheveux .ph{background:var(--vert)}
body.cat-coffrets .ph,.cat-coffrets .ph{background:var(--brun)}
body.cat-abonnements .ph,.cat-abonnements .ph{background:var(--creme)}
body.cat-corps .ph,body.cat-coffrets .ph,.cat-corps .ph,.cat-coffrets .ph{color:#fff}
body.cat-neutre .ph{background:var(--soft);color:var(--ink)}
body.cat-neutre .ph .flacon{display:none}

/* badge famille/categorie */
.fam-tag{display:inline-flex;align-items:center;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:rgba(22,22,22,.06);border-radius:999px;padding:4px 11px;width:fit-content}

/* ---------- grilles produit minimal ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s}
.card:hover{transform:translateY(-4px)}
.card-media{aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-lg);display:block}
.card-media .ph{transition:transform .4s}
.card:hover .card-media .ph{transform:scale(1.04)}
.card-body{padding:13px 4px 6px;display:flex;flex-direction:column;gap:4px}
.card-body .role{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:700}
.card-body h3{font-size:1.06rem;font-weight:700}
.card-body .price{display:flex;align-items:baseline;gap:9px}
.price .now{font-weight:700;font-size:1rem}
.price .was{color:var(--ink-soft);text-decoration:line-through;font-size:.88rem}
.card-body .desc{display:none}
.card-body .btn{margin-top:8px;background:none;color:var(--ink);border:1.4px solid var(--line-2);border-radius:9px;padding:9px 16px;font-size:.86rem}
.card-body .btn:hover{background:var(--ink);color:var(--on-ink);border-color:var(--ink);transform:none}
.card-mini .card-body h3{font-size:.98rem}
.filters{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin-bottom:34px}
.filters button{border:1.5px solid var(--line-2);background:#fff;border-radius:999px;padding:9px 18px;font-size:.78rem;font-weight:600;color:var(--ink-soft);font-family:var(--serif);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:.2s}
.filters button:hover{border-color:var(--ink);color:var(--ink)}
.filters button.active{background:var(--ink);border-color:var(--ink);color:var(--on-ink)}

/* ---------- ESPACE / GRILLE (accueil) ---------- */
/* scene plein ecran : on bloque le scroll de la page (la molette pilote le tunnel) */
html.espace-lock,html.espace-lock body{overflow:hidden;height:100%}

.espace{position:relative;background:#fff}
/* page d'accueil (experience ESPACE) sur fond uni = celui de la grille : evite la bande de couleur
   differente en haut quand on bascule en GRILLE (le calque blanc plein ecran de l'ESPACE est masque).
   var(--paper) vaut blanc en jour et sombre en nuit -> coherent dans les deux modes. */
body[data-page="home"]{background:var(--paper)}
/* tunnel infini : scene fixe plein ecran avec profondeur 3D */
.espace-stage{position:fixed;inset:0;width:100%;height:100%;z-index:0;background:#fff;overflow:hidden;perspective:1000px;perspective-origin:50% 48%}
.espace.is-grid .espace-stage{display:none}
.espace-item{position:absolute;left:50%;top:50%;width:320px;display:flex;flex-direction:column;align-items:center;text-decoration:none;opacity:0;will-change:transform,opacity}
.espace-inner{display:flex;flex-direction:column;align-items:center}
.espace-ph-wrap{width:100%;aspect-ratio:1/1}
.espace-item .ph{border-radius:20px;box-shadow:0 24px 60px rgba(22,22,22,.16),inset 0 0 0 1px rgba(22,22,22,.05);width:100%;height:100%}
.espace-item .ph .flacon{margin-bottom:0}
.espace-label{margin-top:13px;display:flex;flex-direction:column;align-items:center;gap:2px;opacity:0;transform:translateY(5px);transition:opacity .2s,transform .2s;pointer-events:none}
.espace-item:hover .espace-label{opacity:1;transform:none}
.espace-label .el-name{font-family:var(--serif);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em;color:var(--ink);white-space:nowrap}
.espace-label .el-price{font-family:var(--sans);font-size:.72rem;color:var(--ink-soft)}
@media(max-width:600px){.espace-item{width:min(86vw,360px)}}

/* transition de selection : le flacon vole vers l'image de la page produit (View Transitions) */
@view-transition{navigation:auto}
/* phase 1 : les autres flacons et l'interface disparaissent, le flacon choisi reste fige */
.mb-leaving .espace-item{transition:opacity 1.1s ease}
.mb-leaving .eg-toggle,.mb-leaving .site-header,.mb-leaving .topbar{opacity:0;transition:opacity 1s ease;pointer-events:none}
/* le flacon choisi : clone 2D net, fige a sa position, porteur de l'element partage */
.espace-pick{position:fixed;z-index:130;pointer-events:none}
/* vol du clone vers l'emplacement de la galerie produit (avant la bascule de page) */
.espace-pick.fly{transition:left 1.05s cubic-bezier(.22,.75,.25,1),top 1.05s cubic-bezier(.22,.75,.25,1),width 1.05s cubic-bezier(.22,.75,.25,1),height 1.05s cubic-bezier(.22,.75,.25,1)}
.espace-pick.fly img{border-radius:22px}
@media(prefers-reduced-motion:reduce){.espace-pick.fly{transition:none}}
.espace-pick .ph{width:100%;height:100%;border-radius:20px;box-shadow:0 24px 60px rgba(22,22,22,.16),inset 0 0 0 1px rgba(22,22,22,.05)}
/* le clone porte la VRAIE image (et non un fond uni) : elle s'agrandit vers la page produit */
.espace-pick img{width:100%;height:100%;object-fit:cover;border-radius:20px;box-shadow:0 24px 60px rgba(22,22,22,.16),inset 0 0 0 1px rgba(22,22,22,.05)}
/* phase 2 : morph du flacon vers l'image principale de la page de destination */
.pdp-hero .ph,.vt-hero,.pg-main,.gallery-main img{view-transition-name:product-hero}
::view-transition-group(product-hero){animation-duration:.8s;animation-timing-function:cubic-bezier(.16,.84,.3,1)}
::view-transition-old(product-hero),::view-transition-new(product-hero){animation-duration:.45s}
::view-transition-old(root),::view-transition-new(root){animation-duration:1.8s}
/* bascule JOUR/NUIT : le nouveau theme (couleurs + images) se revele de haut en bas */
/* pendant la bascule jour/nuit, l'image produit suit le balayage global de la page
   (sans calque dedie : un calque nomme passerait au-dessus du menu et des overlays) */
html.theme-switching .pdp-hero .ph,html.theme-switching .vt-hero,html.theme-switching .pg-main,html.theme-switching .gallery-main img{view-transition-name:none}
html.theme-switching::view-transition-group(root){animation-duration:.6s}
html.theme-switching::view-transition-old(root){animation:none}
html.theme-switching::view-transition-new(root){animation:vesperaThemeWipe .6s cubic-bezier(.4,0,.2,1) both}
@keyframes vesperaThemeWipe{from{clip-path:inset(0 0 100% 0)}to{clip-path:inset(0 0 0 0)}}

/* vue GRILLE par categorie (bandes) */
.grille-cats{display:none;padding:30px 0 90px}
.espace.is-grid .grille-cats{display:block}
/* transition ESPACE -> GRILLE : disparition du tunnel, puis apparition (bandes, puis produits) */
.espace.is-exiting .espace-item{transition:opacity .6s ease}
@keyframes bandIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
/* phase 1 : la grille (bandes + ossature) apparait, les produits restent caches */
.espace.grille-in .cat-band{animation:bandIn .6s cubic-bezier(.2,.8,.25,1) both}
.espace.grille-in .cat-band .card{opacity:0}
/* phase 2 : les produits apparaissent en cascade (declenche apres 2 s) */
.espace.cards-in .cat-band .card{animation:cardIn .5s cubic-bezier(.2,.8,.25,1) both}
@media(prefers-reduced-motion:reduce){.espace.is-exiting .espace-item{transition:none}.espace.grille-in .cat-band,.espace.cards-in .cat-band .card{animation:none}.espace.grille-in .cat-band .card{opacity:1}}
.cat-band{border-top:1px solid var(--line);padding:30px 0}
.cat-band + .cat-band{border-top:0}   /* pas de trait entre la bande Lampes et la bande Vases */
.cat-band:last-child{border-bottom:1px solid var(--line)}
.cat-band-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}
.cat-band-head--solo{justify-content:flex-end}
.cat-band-label{font-family:var(--serif);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink)}
.cat-band-link{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}
.cat-band-link:hover{color:var(--ink)}
.cat-band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat-band-grid .card-media{aspect-ratio:1/1}
@media(max-width:1000px){.cat-band-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.cat-band-grid{grid-template-columns:repeat(2,1fr)}}
/* grille par produit : 1 rangee de 3 coloris (Noir / Blanc / Dore) */
.grid-product{margin-top:26px}
.grid-product:first-of-type{margin-top:0}
.grid-product-label{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin:0 0 13px;padding-bottom:9px;border-bottom:1px solid var(--line)}
.grid-product-label .gp-name{font-family:var(--serif);font-weight:700;font-size:1.02rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink)}
.grid-product-label .gp-link{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);white-space:nowrap}
.grid-product-label .gp-link:hover{color:var(--ink)}
.color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.color-grid .card-media{aspect-ratio:1/1}
.color-grid .card-body h3{font-size:.92rem}
@media(max-width:600px){.color-grid{grid-template-columns:1fr 1fr;gap:9px}.color-grid .card-body h3{font-size:.82rem}}

/* bascule ESPACE / GRILLE fixe en bas (l'element "Espace Gris") */
.eg-toggle{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:120;display:inline-flex;border:1.5px solid var(--ink);border-radius:999px;padding:4px;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);box-shadow:var(--shadow-sm)}
.eg-toggle button{border:0;background:none;border-radius:999px;padding:9px 24px;font-family:var(--serif);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);transition:background .25s,color .25s}
.eg-toggle button.active{background:var(--ink);color:var(--on-ink)}

/* ---------- curseur personnalise ---------- */
.mb-cursor{position:fixed;top:0;left:0;width:32px;height:32px;margin:-16px 0 0 -16px;border:1.5px solid var(--ink);border-radius:50%;pointer-events:none;z-index:9999;transition:width .25s,height .25s,margin .25s;background:transparent}
.mb-cursor.is-hover{width:62px;height:62px;margin:-31px 0 0 -31px}
.mb-cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;margin:-3px 0 0 -3px;background:var(--ink);border-radius:50%;pointer-events:none;z-index:9999}
@media(pointer:fine){
  body.mb-has-cursor{cursor:none}
  body.mb-has-cursor a,body.mb-has-cursor button,body.mb-has-cursor .espace-item{cursor:none}
  body.mb-has-cursor input,body.mb-has-cursor textarea{cursor:auto}
}
@media(pointer:coarse){.mb-cursor,.mb-cursor-dot{display:none}}

/* ---------- bundle ---------- */
.bundle{background:var(--soft);border-radius:var(--radius-lg);padding:44px;display:grid;grid-template-columns:1.1fr 1fr;gap:42px;align-items:center}
.bundle-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.bundle-imgs .ph{border-radius:14px;aspect-ratio:1/1}
.bundle .save{display:inline-block;background:var(--ink);color:var(--on-ink);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:6px 13px;border-radius:999px;margin-bottom:12px}
.bundle h2{text-transform:uppercase}
.bundle .price{margin:14px 0 22px}.bundle .price .now{font-size:1.6rem;font-weight:700}

/* ---------- PDP minimaliste (Gufram) ---------- */
.pdp-gufram{padding:16px 0 30px;background:#fff}
.pdp-back{display:inline-flex;align-items:center;gap:8px;margin:0 28px 4px;font-family:var(--serif);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink)}
.pdp-back svg{width:18px;height:18px}
.pdp-gufram-grid{display:grid;grid-template-columns:1.7fr 1fr;align-items:start;max-width:1480px;margin:0 auto}
.pdp-stage{position:relative;display:flex;align-items:center;justify-content:center;background:#fff;min-height:70vh;overflow:hidden;padding:30px}
.pdp-hero{width:min(46%,400px);aspect-ratio:.82/1}
.pdp-hero .ph{border-radius:24px}
.pdp-hero .ph .flacon{width:42%;max-width:140px}
.pdp-peek{position:absolute;top:50%;transform:translateY(-50%);width:180px;aspect-ratio:.82/1;border-radius:20px;opacity:.4}
.pdp-peek-left{left:-84px}.pdp-peek-right{right:-84px}
/* galerie produit : grille de photos du produit (differentes vues, pas de carrousel) */
.pdp-gallery{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-content:start;padding:2px 0 20px}
.pdp-gallery .ph{position:relative;aspect-ratio:1/1;border-radius:18px;box-shadow:inset 0 0 0 1px rgba(22,22,22,.05)}
/* toutes les images de la galerie en 1:1, taille uniforme (grille 2 colonnes) */
.pdp-gallery .pg-main{aspect-ratio:1/1;border-radius:20px}
.pdp-gallery .pg-span{aspect-ratio:1/1;border-radius:18px}
.pg-cap{position:absolute;left:15px;bottom:13px;font-family:var(--serif);font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink)}
/* section Clips Parfaits : exemples de clips video (format portrait) */
.clips-sec{border-top:1px solid var(--line)}
.clips-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.clip{display:block;text-decoration:none}
.clip-ph{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:9/16;border-radius:18px;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(22,22,22,.05)}
.clip-play{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:transform .25s}
.clip:hover .clip-play{transform:scale(1.08)}
.clip-play svg{width:20px;height:20px;margin-left:3px;color:var(--ink)}
.clip-cap{display:block;margin-top:11px;font-family:var(--serif);font-weight:600;font-size:.82rem;color:var(--ink);text-align:center}
@media(max-width:820px){.clips-grid{grid-template-columns:repeat(2,1fr)}}
.pdp-rail{border-left:1px solid var(--line);padding:30px 38px 44px}
.pdp-rail .fam-tag{margin-bottom:14px}
.pdp-rail h1{font-size:clamp(1.7rem,2.4vw,2.4rem);text-transform:uppercase;margin-bottom:10px;line-height:1.02}
.pdp-meta{font-size:.84rem;color:var(--ink-soft);border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:18px;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.pdp-meta .stars{color:var(--star);letter-spacing:1px}
.pdp-desc{font-size:.98rem;color:var(--ink-soft);margin-bottom:24px}
.buy-price{display:flex;align-items:baseline;gap:12px;margin-bottom:20px}
.buy-price .now{font-size:1.9rem;font-weight:700;font-family:var(--serif)}
.buy-price .was{font-size:1.05rem;color:var(--ink-soft);text-decoration:line-through}
.opt-label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:11px;display:block}
.opt-label span{color:var(--ink)}
.swatches{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:24px}
.swatch{border:1.5px solid var(--line-2);background:#fff;border-radius:999px;padding:9px 16px;font-size:.84rem;color:var(--ink);cursor:pointer;transition:.2s}
.swatch:hover{border-color:var(--ink)}
.swatch.active{border-color:var(--ink);background:var(--ink);color:var(--on-ink);font-weight:600}
.swatches a.swatch{text-decoration:none}
/* fiche produit generique : notes / contenu / formule */
.pdp-variants{display:block}
/* vignettes de variantes : photo (placeholder) + nom, pour bien voir les variantes */
/* vignettes : largeur FIXE -> meme taille 1:1 sur toutes les pages, quel que soit le nombre de variantes */
.vthumbs{display:grid;grid-template-columns:repeat(auto-fill,84px);justify-content:start;gap:12px;margin:0 0 24px}
.vthumb{display:flex;flex-direction:column;align-items:center;gap:7px;text-decoration:none;color:var(--ink);transition:transform .2s}
.vthumb:hover{transform:translateY(-3px)}
.vthumb .ph{width:100%;height:auto;aspect-ratio:1/1;padding:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:13px;box-shadow:inset 0 0 0 1px rgba(22,22,22,.06);transition:box-shadow .2s}
.vthumb .ph .flacon{margin-bottom:0;width:34%}
.vthumb.active .ph{box-shadow:0 0 0 2px var(--ink)}
.vthumb:hover .ph{box-shadow:0 0 0 1.5px var(--ink)}
.vthumb-name{font-size:.72rem;font-weight:600;text-align:center;line-height:1.16;letter-spacing:.01em;color:var(--ink)}
.vthumb-price{font-size:.7rem;color:var(--ink-soft);margin-top:-3px}
.pdp-notes{border:1px solid var(--line);border-radius:var(--radius);padding:13px 16px;margin:0 0 24px}
.pdp-notes .pn-h{display:block;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.pn-row{display:flex;justify-content:space-between;gap:14px;padding:6px 0;border-top:1px solid var(--line)}
.pn-row:first-of-type{border-top:0}
.pn-row > span{color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;font-size:.68rem;font-weight:700;align-self:center;flex:0 0 auto}
.pn-row b{color:var(--ink);text-align:right;font-weight:500;font-size:.88rem}
.pdp-contents{list-style:none;margin:0 0 24px;padding:0;display:flex;flex-direction:column;gap:9px}
.pdp-contents li{position:relative;padding-left:20px;font-size:.92rem;color:var(--ink);line-height:1.4}
.pdp-contents li:before{content:"";position:absolute;left:2px;top:.5em;width:7px;height:7px;border-radius:50%;background:var(--ink);opacity:.45}
.pdp-formula{font-size:.92rem;color:var(--ink-soft);margin:0 0 22px;line-height:1.5}
.pdp-cross{margin-top:8px;border-top:1px solid var(--line);padding-top:20px}
.pdp-cross-row{display:flex;flex-wrap:wrap;gap:9px}
.pdp-cross-chip{display:inline-flex;align-items:center;border:1.5px solid var(--line-2);border-radius:999px;padding:9px 15px;font-size:.8rem;font-weight:600;color:var(--ink);text-decoration:none;transition:.2s}
.pdp-cross-chip:hover{border-color:var(--ink);background:var(--ink);color:var(--on-ink)}
.qty-row{display:flex;gap:14px;align-items:stretch;margin-bottom:16px}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line-2);border-radius:11px;overflow:hidden}
.qty button{background:none;border:0;width:44px;font-size:1.2rem;color:var(--ink-soft)}
.qty input{width:40px;border:0;text-align:center;font-size:1rem;font-weight:700;background:none;color:var(--ink)}
/* nuit : le stepper devient un pave clair (accorde au bouton Ajouter) -> le "1" est noir et lisible */
:root[data-theme="dark"] .qty{background:var(--ink);border-color:var(--ink)}
:root[data-theme="dark"] .qty button{color:var(--on-ink)}
:root[data-theme="dark"] .qty input{color:var(--on-ink)}
.reassure{display:flex;flex-direction:column;gap:10px;margin:22px 0;padding:18px 20px;background:var(--soft);border-radius:var(--radius)}
.reassure div,.reassure span{display:flex;gap:11px;align-items:center;font-size:.88rem}
.reassure .ic{color:var(--ok);flex:0 0 18px;width:18px;height:18px}
.pay-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.pay-badges span{font-size:.68rem;border:1px solid var(--line-2);border-radius:6px;padding:4px 8px;color:var(--ink-soft);font-weight:600}
.upsell{border:1.5px dashed var(--line-2);border-radius:var(--radius);padding:14px 16px;display:flex;gap:14px;align-items:center;margin-bottom:22px}
.upsell .ph{width:52px;height:52px;border-radius:10px;flex:0 0 52px}.upsell .ph .flacon{display:none}
.upsell .u-txt{flex:1;font-size:.88rem}.upsell .u-txt b{display:block}

/* accordeons */
.accordions{margin-top:26px;border-top:1px solid var(--line)}
.acc{border-bottom:1px solid var(--line)}
.acc-head{width:100%;background:none;border:0;display:flex;justify-content:space-between;align-items:center;padding:17px 2px;font-size:.82rem;font-weight:700;font-family:var(--serif);color:var(--ink);text-align:left;text-transform:uppercase;letter-spacing:.06em}
.acc-head .pm{font-size:1.2rem;color:var(--ink-soft);transition:transform .2s}
.acc.open .pm{transform:rotate(45deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--ink-soft);font-size:.92rem}
.acc.open .acc-body{max-height:640px}.acc-body .inner{padding:0 2px 20px}
.acc-head svg,.acc-head .ic{width:18px;height:18px}

/* bande, features, etapes, checklist */
.band{padding:74px 0}
.band-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.band.rev .band-grid,.band-grid.rev{direction:rtl}.band.rev .band-grid>*,.band-grid.rev>*{direction:ltr}
.band-media{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}.band-media .ph{width:100%;height:100%}
.band-media img{width:100%;height:100%;object-fit:cover;display:block}
.band h2{margin-bottom:16px;text-transform:uppercase}
.checklist{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:11px}
.checklist li{display:flex;gap:12px;align-items:flex-start;font-size:1rem}
.checklist li::before{content:"";flex:0 0 7px;width:7px;height:7px;border-radius:50%;background:var(--ink);margin-top:9px}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.features-4{grid-template-columns:repeat(4,1fr)}
.feature{background:var(--soft);border-radius:var(--radius-lg);padding:28px 24px}
.feature .ic{width:34px;height:34px;color:var(--ink);margin-bottom:14px}
.feature h3{font-size:1.12rem;margin-bottom:8px;font-weight:700}.feature p{color:var(--ink-soft);font-size:.9rem;margin:0}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.step{text-align:center}
.step-img{aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:18px}.step-img .ph{width:100%;height:100%}
.step .num{display:inline-flex;width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--on-ink);align-items:center;justify-content:center;font-weight:700;font-family:var(--serif);margin-bottom:12px}
.step h3{font-size:1.12rem;margin-bottom:7px;font-weight:700}.step p{color:var(--ink-soft);font-size:.9rem;margin:0}

/* avis marquee */
.marquee-rows{display:flex;flex-direction:column;margin-top:18px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-viewport{overflow:hidden;background:#fff;--mask:linear-gradient(to right,transparent 0,#000 6%,#000 94%,transparent 100%);-webkit-mask-image:var(--mask);mask-image:var(--mask)}
.marquee-viewport + .marquee-viewport{border-top:1px solid var(--line)}
.marquee-track{display:flex;width:max-content}
.marquee-track-left{animation:mq-left 75s linear infinite}.marquee-track-right{animation:mq-right 65s linear infinite}
.marquee-viewport:hover .marquee-track{animation-play-state:paused}
@keyframes mq-left{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@keyframes mq-right{from{transform:translate3d(-50%,0,0)}to{transform:translate3d(0,0,0)}}
@media(prefers-reduced-motion:reduce){.marquee-track-left,.marquee-track-right{animation:none}}
.mq-card{flex:0 0 330px;width:330px;background:#fff;border-right:1px solid var(--line);padding:24px 26px;min-height:180px;display:flex;flex-direction:column}
.mq-card .stars{color:var(--star);font-size:.95rem}.mq-card p{font-size:.9rem;margin:10px 0 14px;color:var(--ink);font-style:italic;flex:1}
.mq-card .who{display:flex;align-items:center;gap:11px}.mq-card .av{width:36px;height:36px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--ink);font-size:.78rem;flex:0 0 36px}
.mq-card .who b{font-size:.84rem;display:flex;align-items:center;gap:6px}.mq-card .who small{color:var(--ink-soft);font-size:.74rem;display:block}
.mq-card .ver{font-size:.64rem;color:var(--ok);font-weight:700;display:inline-flex;align-items:center;gap:4px}.mq-card .ver svg{width:12px;height:12px}
.rating{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--ink-soft)}.stars{color:var(--star);letter-spacing:1px}
/* page Avis : resume (note moyenne + repartition) */
.avis-summary{display:grid;grid-template-columns:auto 1fr;gap:46px;align-items:center;background:var(--soft);border-radius:var(--radius-lg);padding:32px 38px;margin-bottom:14px}
.avis-score{text-align:center;flex:0 0 auto}
.avis-avg{font-family:var(--serif);font-weight:800;line-height:1;color:var(--ink)}
.avis-avg span{font-size:3.4rem}.avis-avg small{font-size:1.1rem;color:var(--ink-soft);font-weight:600;margin-left:4px}
.avis-stars{font-size:1.15rem;margin:8px 0 6px}
.avis-count{font-size:.84rem;color:var(--ink-soft)}.avis-count b{color:var(--ink)}
.avis-dist{display:flex;flex-direction:column;gap:7px;min-width:0}
.avis-dist-row{display:grid;grid-template-columns:38px 1fr 40px;align-items:center;gap:12px}
.adr-star{font-size:.74rem;font-weight:700;color:var(--ink-soft);white-space:nowrap}
.adr-bar{height:8px;background:#fff;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.adr-bar span{display:block;height:100%;background:var(--ink);border-radius:999px}
.adr-pct{font-size:.74rem;color:var(--ink-soft);text-align:right}
/* page Avis : mur anime a 5 rangees (cartes un peu plus compactes, plus minimaliste) */
.marquee-rows-avis{margin-top:30px}
.marquee-rows-avis .mq-card{min-height:138px;padding:18px 22px}
@media(max-width:900px){.avis-summary{grid-template-columns:1fr;gap:24px;text-align:center}.avis-dist{max-width:420px;margin:0 auto;width:100%}}

/* familles / visages */
.families{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.family{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;text-align:center}
.family-img{aspect-ratio:4/5;overflow:hidden}.family-img .ph{width:100%;height:100%}
.family-body{padding:18px}.family .mom{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px}
.family .mom .mono{width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--on-ink);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.74rem}
.family h3{font-size:1.06rem;font-weight:700}.family .role{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin:4px 0 10px}
.family p{font-size:.84rem;color:var(--ink-soft);font-style:italic;margin:0}

/* quiz */
.quiz{max-width:720px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:42px 40px;min-height:430px}
.quiz-progress{display:flex;gap:8px;margin-bottom:30px}.quiz-progress span{flex:1;height:5px;border-radius:3px;background:var(--line)}.quiz-progress span.done{background:var(--ink)}
.quiz-step{display:none}.quiz-step.active{display:block;animation:quizin .4s ease}
@keyframes quizin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.quiz-step .eyebrow{display:block;margin-bottom:8px}.quiz-step h2{margin-bottom:24px}
.quiz-options{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.quiz-opt{display:flex;align-items:center;gap:14px;text-align:left;border:1.5px solid var(--line-2);background:#fff;border-radius:var(--radius);padding:18px 20px;font-size:1rem;color:var(--ink);cursor:pointer;transition:.2s}
.quiz-opt:hover{border-color:var(--ink);transform:translateY(-2px)}
.quiz-opt .qo-ic{width:40px;height:40px;flex:0 0 40px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ink)}.quiz-opt .qo-ic svg{width:22px;height:22px}
.quiz-opt b{display:block}.quiz-opt small{display:block;color:var(--ink-soft);font-size:.8rem;margin-top:2px}
.quiz-back{margin-top:24px;background:none;border:0;color:var(--ink-soft);font-size:.88rem;cursor:pointer}.quiz-back:hover{color:var(--ink)}
.quiz-result{display:none;text-align:center}.quiz-result.active{display:block;animation:quizin .4s ease}
.quiz-result .result-card{background:var(--soft);border-radius:var(--radius-lg);padding:32px;margin:22px 0}
.quiz-result .result-fam{font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--ink);margin:6px 0 4px;text-transform:uppercase}
.quiz-result .result-prods{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
/* cartes de resultat quiz : photo 1:1 (placeholder) + nom */
.quiz-reco{display:flex;flex-direction:column;align-items:center;gap:10px;text-decoration:none;color:var(--ink);transition:transform .2s}
.quiz-reco:hover{transform:translateY(-4px)}
.quiz-reco .ph{width:100%;height:auto;aspect-ratio:1/1;padding:0;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:16px;box-shadow:inset 0 0 0 1px rgba(22,22,22,.06)}
.quiz-reco:hover .ph{box-shadow:0 0 0 1.5px var(--ink)}
.quiz-reco .ph .flacon{margin-bottom:0;width:30%}
.quiz-reco-name{font-family:var(--serif);font-weight:700;font-size:.92rem;text-transform:uppercase;letter-spacing:.02em;line-height:1.2;text-align:center}

/* prose / legal */
.prose{max-width:760px;margin:0 auto;padding:54px 28px}
.prose h2{margin:36px 0 12px;text-transform:uppercase}.prose h3{margin:24px 0 8px}
.prose p,.prose li{color:var(--ink-soft);font-size:1rem}
.prose ul,.prose ol{padding-left:1.2rem;display:flex;flex-direction:column;gap:6px;margin:0 0 1rem}.prose .lead{color:var(--ink)}
.prose table{width:100%;border-collapse:collapse;margin:8px 0 22px;font-size:.86rem}
.prose th,.prose td{text-align:left;padding:10px 12px;border:1px solid var(--line);vertical-align:top;color:var(--ink-soft)}
.prose th{background:var(--soft);color:var(--ink);font-family:var(--serif);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em}
.prose h2{scroll-margin-top:90px}.prose h3{color:var(--ink)}
/* variante aeree : page Histoire (recit) - n'affecte pas les pages legales (.prose seul) */
.prose-air{max-width:820px;padding-top:60px;padding-bottom:60px}
.prose-air h2{margin:56px 0 18px;padding-top:30px;border-top:1px solid var(--line);font-size:clamp(1.3rem,2vw,1.7rem)}
.prose-air h2:first-child{margin-top:0;padding-top:0;border-top:0}
.prose-air h3{margin:38px 0 10px}
.prose-air p{margin:0 0 18px;line-height:1.78}
.prose-air p + h3{margin-top:30px}
.prose-air .cosmetic-note{margin:30px 0}
/* page Contact : grille + formulaire stylise + colonne FAQ en accordeons */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-form .cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form label{margin-top:16px}
.contact-form .cf-row label{margin-top:0}
.contact-form input,.contact-form textarea{width:100%;border:1.5px solid var(--line-2);border-radius:13px;padding:13px 15px;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fff;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--ink)}
.contact-form textarea{resize:vertical;min-height:130px}
.contact-faq .contact-faq-title{display:block;margin-bottom:2px}
.contact-faq .accordions{margin-top:10px}
.contact-faq .acc-body .inner ul{padding-left:1.1rem;margin:10px 0 0;display:flex;flex-direction:column;gap:5px}
.contact-faq .acc-body .inner a{color:var(--ink-soft);text-decoration:underline}
.contact-faq .acc-body .inner a:hover{color:var(--ink)}
@media(max-width:760px){.contact-grid,.contact-form .cf-row{grid-template-columns:1fr}}
.legal-toc{background:var(--soft);border:1px solid var(--line-2);border-radius:var(--radius);padding:20px 24px;margin:24px 0 8px}
.legal-toc ol{margin:0;padding-left:1.3rem;gap:4px}
.legal-toc a{color:var(--ink-soft)}.legal-toc a:hover{color:var(--ink)}
.legal-meta{font-size:.82rem;color:var(--ink-soft);border-left:3px solid var(--ink);padding-left:14px;margin-bottom:24px}
.cosmetic-note{background:var(--soft);border:1px solid var(--line-2);border-radius:var(--radius);padding:16px 20px;font-size:.88rem;color:var(--ink);margin:20px 0}
/* cross-links collection (Histoire / Contact) */
.discover-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.discover-card{display:flex;flex-direction:column;gap:5px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;text-decoration:none;transition:border-color .2s,transform .2s}
.discover-card:hover{border-color:var(--ink);transform:translateY(-3px)}
.discover-card .dc-name{font-family:var(--serif);font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:.03em;color:var(--ink)}
.discover-card .dc-meta{font-size:.82rem;color:var(--ink-soft)}
.discover-card .dc-go{margin-top:8px;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:700}
@media(max-width:700px){.discover-row{grid-template-columns:1fr}}
.contact-more{margin:6px auto 0;color:var(--ink-soft);font-size:.9rem}
.contact-more a{color:var(--accent);text-decoration:none}
.contact-more a:hover{text-decoration:underline}
.cosmetic-note b{color:var(--ok)}
.welcome-soft{background:var(--soft);border-radius:var(--radius-lg);padding:50px;text-align:center;max-width:820px;margin:0 auto}
.welcome-soft .eyebrow{display:block;margin-bottom:12px}.welcome-soft h2{margin-bottom:8px;text-transform:uppercase}
.email-band{background:var(--ink);color:var(--on-ink);border-radius:var(--radius-lg);padding:50px;text-align:center;max-width:780px;margin:0 auto}
.email-band h2{color:var(--on-ink);margin-bottom:10px;text-transform:uppercase}.email-band p{color:var(--on-ink);opacity:.72}
.email-form{display:flex;gap:10px;max-width:460px;margin:24px auto 0}.email-form input{flex:1;border:0;border-radius:11px;padding:14px 20px;font-size:.95rem}.email-form .btn{flex:0 0 auto;background:var(--on-ink);color:var(--ink)}

/* ---------- footer minimal ---------- */
.site-footer{background:#fff;border-top:1px solid var(--line);padding:50px 0 26px;color:var(--ink)}
.foot-trust{max-width:var(--max);margin:0 auto 32px;padding:0 28px 26px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.trust-item{display:flex;align-items:center;gap:12px;font-size:.84rem;color:var(--ink)}
.trust-item .ic-wrap{width:38px;height:38px;flex:0 0 38px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center}
.trust-item .ic{width:19px;height:19px;color:var(--ink)}
.trust-item b{display:block;font-weight:700;font-size:.86rem}.trust-item small{color:var(--ink-soft);font-weight:400;font-size:.78rem}
.foot-grid{max-width:var(--max);margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.2fr 1fr 1.4fr;gap:40px}
.foot-col h4{font-family:var(--serif);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin:0 0 14px}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.foot-col a{color:var(--ink-soft);font-size:.9rem}.foot-col a:hover{color:var(--ink)}
.foot-news input{width:100%;border:1px solid var(--line-2);border-radius:11px;padding:12px 16px;margin-bottom:10px;font-size:.9rem;background:#fff}
.foot-bottom{max-width:var(--max);margin:32px auto 0;padding:18px 28px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center;color:var(--ink-soft);font-size:.8rem}
.foot-bottom a{color:var(--ink-soft)}.foot-bottom a:hover{color:var(--ink)}
.foot-pay{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.foot-pay .secure{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--ink)}.foot-pay .secure .ic{width:16px;height:16px;color:var(--ok)}
.card-badge{height:26px;width:40px;background:#fff;border:1px solid var(--line-2);border-radius:5px;display:inline-flex;align-items:center;justify-content:center;padding:0 3px}.card-badge svg{height:13px;width:auto}

/* sticky buy (pdp) */
.sticky-buy{position:fixed;left:0;right:0;bottom:0;z-index:60;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid var(--line);transform:translateY(110%);transition:transform .3s}
.sticky-buy.show{transform:translateY(0)}
.sticky-inner{max-width:var(--max);margin:0 auto;padding:12px 28px;display:flex;align-items:center;gap:18px;justify-content:space-between}
.sticky-inner .s-info{display:flex;align-items:center;gap:14px}.sticky-inner .ph{width:44px;height:44px;border-radius:10px}.sticky-inner .ph .flacon{display:none}.sticky-inner .s-price{font-weight:700}

/* reveal */
[data-page="home"] .reveal,[data-page="avis"] .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
[data-page="home"] .reveal.in,[data-page="avis"] .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){[data-page="home"] .reveal,[data-page="avis"] .reveal{opacity:1!important;transform:none!important}}

/* responsive */
@media(max-width:1000px){
  .pdp-gufram-grid,.band-grid,.bundle{grid-template-columns:1fr;gap:32px}
  .pdp-rail{border-left:0;border-top:1px solid var(--line)}.pdp-peek{display:none}
  .grid-4{grid-template-columns:repeat(3,1fr)}.cards,.features,.families{grid-template-columns:repeat(2,1fr)}
  .foot-trust{grid-template-columns:repeat(2,1fr)}.foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .grid-4,.cards,.features,.families,.foot-trust,.steps{grid-template-columns:1fr 1fr}
  .quiz-options,.quiz-result .result-prods{grid-template-columns:1fr}.quiz{padding:30px 22px}
  .email-form{flex-direction:column}.foot-grid{grid-template-columns:1fr}.sec{padding:52px 0}
  .espace-head h1{font-size:clamp(2.2rem,9vw,3.2rem)}
  .mq-card{flex-basis:280px;width:280px}
}

/* ---------- PDP a coloris VESPERA (chassis MAUBRUME) ---------- */
.pdp{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;padding:24px 28px 56px;max-width:var(--max);margin:0 auto;align-items:start}
.pdp .gallery{position:sticky;top:90px;transition:opacity .23s ease,transform .23s ease}
.pdp .gallery.gallery-switching{opacity:0;transform:translateY(10px) scale(.99)}
@media(prefers-reduced-motion:reduce){.pdp .gallery{transition:none}}
.pdp .gallery-main{aspect-ratio:1/1;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.pdp .gallery-main img{width:100%;height:100%;object-fit:cover;display:block}
.pdp .thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.pdp .thumb{width:74px;height:74px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--soft);padding:0;opacity:.7;cursor:pointer;transition:opacity .2s,border-color .2s}
.pdp .thumb img{width:100%;height:100%;object-fit:cover}
.pdp .thumb.active,.pdp .thumb:hover{opacity:1;border-color:var(--accent)}
.pdp-info h1{font-size:clamp(1.8rem,2.6vw,2.5rem);text-transform:uppercase;margin:.2em 0 .1em}
.pdp-info .fam-tag{margin-bottom:14px}
.pdp-desc{color:var(--ink-soft);font-size:1rem;margin:14px 0 20px}
.pdp-info .swatches{margin:8px 0 22px}
.swatch-img{background:var(--paper);border:1.5px solid var(--line-2);border-radius:12px;padding:8px;display:flex;flex-direction:column;align-items:center;gap:6px;width:84px;cursor:pointer;transition:border-color .2s,transform .2s}
.swatch-img img{width:46px;height:46px;object-fit:cover;border-radius:8px}
.swatch-img span{font-size:.7rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}
.swatch-img.active{border-color:var(--accent);transform:translateY(-2px)}
.swatch-img.active span{color:var(--ink);font-weight:600}
.pdp-info ul.features{display:flex;flex-direction:column;gap:0;list-style:none;padding:0;margin:14px 0 0}
.pdp-info ul.features li{position:relative;padding:8px 0 8px 22px;border-top:1px solid var(--line);color:var(--ink-soft);font-size:.92rem}
.pdp-info ul.features li:first-child{border-top:0}
.pdp-info ul.features li::before{content:"";position:absolute;left:2px;top:14px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.usages{display:flex;flex-wrap:wrap;gap:9px;margin:6px 0 20px}
.usages span{background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:6px 13px;font-size:.8rem;color:var(--ink-soft)}
.pdp-price{margin:12px 0 18px}
.ambiance{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ambiance .amb{width:100%;border-radius:var(--radius-lg);border:1px solid var(--line);display:block}
:root[data-theme="light"] .ambiance .amb-night{display:none}
:root[data-theme="dark"] .ambiance .amb-day{display:none}
/* ---- section Fonctionnement (PDP) : 3 etapes annotees (photo + trait SVG + label creme), jour/nuit ---- */
.sec-fct{background:var(--bg)}
.sec-fct .sec-head{margin-bottom:34px}
[data-fonctionnement]{--fct-stroke:rgba(26,23,20,.34)}
:root[data-theme="dark"] [data-fonctionnement]{--fct-stroke:rgba(238,228,210,.55)}
.fct-steps{margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:start}
.fct-step{display:flex;flex-direction:column}
.fct-frame{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);box-shadow:0 16px 40px rgba(26,23,20,.12)}
:root[data-theme="dark"] .fct-frame{background:#0c0a08;box-shadow:0 18px 46px rgba(0,0,0,.5)}
.fct-frame>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.fct-frame>svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.fct-cal{position:absolute;max-width:30%;pointer-events:none;background:rgba(244,238,228,.93);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border:1px solid rgba(0,0,0,.08);border-radius:9px;padding:4px 9px;box-shadow:0 6px 18px rgba(0,0,0,.22)}
.fct-cal[data-side="r"]{transform:translateY(-50%);text-align:left}
.fct-cal[data-side="l"]{transform:translate(-100%,-50%);text-align:right}
.fct-cal-l{display:block;font-family:var(--serif);font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#1A1714;line-height:1.25}
.fct-cap{margin-top:15px;text-align:center;padding:0 6px}
.fct-cap-head{display:flex;align-items:baseline;justify-content:center;gap:9px;margin-bottom:6px}
.fct-num{font-family:var(--serif);font-size:.92rem;font-weight:600;color:var(--accent);letter-spacing:.04em}
.fct-title{font-family:var(--serif);font-size:1.12rem;font-weight:600;color:var(--ink);margin:0;text-transform:none}
.fct-text{color:var(--ink-soft);font-size:.86rem;line-height:1.5;margin:0}
.fct-top{display:flex;justify-content:center;margin-top:46px}
.fct-top-btn svg{width:18px;height:18px}
@media(max-width:760px){.fct-steps{grid-template-columns:1fr;max-width:560px;gap:34px}}
@media(max-width:560px){.fct-top{margin-top:34px}}
@media(max-width:900px){.pdp{grid-template-columns:1fr;gap:30px}.pdp .gallery{position:static}.ambiance{grid-template-columns:1fr}}
/* --- mobile (telephone) : galerie + bloc achat --- */
@media(max-width:560px){
  /* les 6 vignettes : grille 3 colonnes, espacees et centrees */
  .pdp .thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;justify-items:center;max-width:360px;margin:14px auto 0}
  .pdp .thumb{width:100%;height:auto;aspect-ratio:1/1}
  /* bloc achat empile : quantite pleine largeur, puis bouton pleine largeur dessous */
  .qty-row{flex-direction:column;align-items:stretch;gap:12px}
  .qty{width:100%;justify-content:space-between}
  .qty input{flex:1;width:auto}
  .qty-row .btn{width:100%}
}
