/* ===========================================================
   ESPACE PINEUILH — Vape & CBD · Boutique en ligne
   Habillage selon le Design System Espace Pineuilh
   Vert vapeur lime #A4C41C + encre #14150F sur blanc
   Montserrat (titres CAPS lourds) · Mulish (corps)
   =========================================================== */

/* ---- compat: my component vars -> EP design tokens ---- */
:root{
  --font-sans: var(--font-body);
  --font-serif: var(--font-body);      /* no serif in EP — clean Mulish */
  --ink: var(--ink-900);
  --c-noir: #000;
  --paper: #fff;
  --bg-alt: #fff;
  --bg: var(--gray-50);                 /* page background */
  --taupe: var(--gray-600);
  --sable: var(--brand-green);          /* accent on dark surfaces */
  --rouge: var(--green-700);            /* accent (icons, fills, dots) */
  --cream-hi: var(--green-50);
  --r-1: var(--r-md);
  --shadow-ink: var(--shadow-md);
  --track-eyebrow: var(--tracking-caps);
  --track-display: -0.02em;
  --ease: cubic-bezier(.2,.7,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-weight:400;line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--brand-green);color:var(--ink-900)}

/* ---- layout primitives ---- */
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.wrap-wide{max-width:1280px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:var(--tracking-caps);text-transform:uppercase;color:var(--green-800)}
.eyebrow .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--brand-green);margin-right:9px;vertical-align:middle}
.serif{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:var(--track-display)}
.disp{font-family:var(--font-display);text-transform:uppercase;letter-spacing:var(--track-display);font-weight:900}
.hr-rule{height:1px;background:var(--border);border:0}
.rouge{color:var(--green-800)}

/* =================== BUTTONS =================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-body);font-size:15px;font-weight:700;letter-spacing:0;text-transform:none;
  padding:13px 26px;border:1.5px solid var(--brand-green);background:var(--brand-green);color:var(--ink-900);
  border-radius:var(--r-pill);transition:background .16s var(--ease),color .16s,transform .12s,box-shadow .16s;white-space:nowrap}
.btn:hover{background:var(--green-600);border-color:var(--green-600);box-shadow:var(--shadow-brand);transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.99)}
.btn.outline{background:transparent;color:var(--green-800);border-color:var(--border)}
.btn.outline:hover{background:var(--green-50);border-color:var(--brand-green);box-shadow:none;color:var(--green-800)}
.btn.ink,.btn.rouge{background:var(--ink-900);border-color:var(--ink-900);color:#fff}
.btn.ink:hover,.btn.rouge:hover{background:var(--ink-700);border-color:var(--ink-700);box-shadow:none}
.btn.sm{padding:9px 18px;font-size:13px}
.btn.block{width:100%}
.btn.ghost{background:transparent;border-color:transparent;color:var(--green-800);padding-left:6px;padding-right:6px}
.btn.ghost:hover{background:transparent;color:var(--green-600);box-shadow:none;transform:none}
.btn:disabled{opacity:.4;pointer-events:none}
.btn .arr{width:16px;height:1px;background:currentColor;position:relative;flex:none}
.btn .arr::after{content:"";position:absolute;right:0;top:-3px;width:7px;height:7px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg)}
.tlink{border-bottom:1px solid currentColor;padding-bottom:1px;transition:color .2s;color:var(--green-800)}
.tlink:hover{color:var(--green-600)}

/* =================== ANNOUNCE + NAV =================== */
.announce{background:var(--ink-900);color:#cfd2c4;font-size:12.5px;font-weight:500;letter-spacing:0;text-align:center;padding:9px 16px}
.announce b{color:var(--brand-green);font-weight:700}
header.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.88);backdrop-filter:saturate(1.1) blur(10px);border-bottom:1px solid var(--border-soft)}
.promo-banner{display:flex;align-items:center;justify-content:center;gap:14px;background:var(--brand-green);color:var(--ink-900);text-decoration:none;padding:13px 20px;font-size:15.5px;font-weight:600;text-align:center}
.promo-banner .pbn-emoji{font-size:22px;flex:none}
.promo-banner .pbn-txt{color:var(--ink-900)}
.promo-banner .pbn-txt strong{color:var(--ink-900);font-weight:900}
.promo-banner .pbn-cta{flex:none;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:13px;color:var(--brand-green);background:var(--ink-900);padding:9px 18px;border-radius:var(--r-pill);box-shadow:var(--shadow-sm);transition:transform .15s,background .15s}
.promo-banner:hover .pbn-cta{transform:translateY(-1px);background:#000}
@media(max-width:760px){.promo-banner{gap:10px;padding:11px 14px;font-size:13px;flex-wrap:wrap}.promo-banner .pbn-emoji{font-size:18px}.promo-banner .pbn-cta{font-size:11.5px;padding:8px 14px}}
@media(max-width:520px){.promo-banner{gap:8px;padding:10px 12px;font-size:12.5px}.promo-banner .pbn-cta{width:auto}}

/* Pronos — call-out fiche produit */
.pdp-prono{display:flex;align-items:center;gap:13px;background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--r-md);padding:12px 15px;margin:16px 0;text-decoration:none;transition:box-shadow .15s,border-color .15s}
.pdp-prono:hover{box-shadow:var(--shadow-sm);border-color:var(--brand-green)}
.pdpp-flag{font-size:28px;line-height:1;flex:none}
.pdpp-txt{flex:1;font-size:13.5px;color:var(--ink-900);line-height:1.4}
.pdpp-txt strong{color:var(--green-800);font-weight:800}
.pdpp-cta{flex:none;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:12px;color:var(--ink-900);background:var(--brand-green);padding:8px 14px;border-radius:var(--r-pill)}
@media(max-width:520px){.pdp-prono{flex-wrap:wrap}.pdpp-txt{flex:1 1 60%}.pdpp-cta{width:100%;text-align:center;margin-top:4px}}

/* Détail — création mixologue (saveurs + drapeaux) */
.pdp-mix{background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--r-md);padding:15px 16px;margin:16px 0}
.pdp-mix-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.pmx-flags{display:flex;align-items:center}
.pmx-flags .pmx-flag{font-size:22px;margin-left:-7px}
.pmx-flags .pmx-flag:first-child{margin-left:0}
.pmx-title{font-size:13.5px;color:var(--ink-900)}
.pmx-title strong{color:var(--green-800);font-weight:800}
.pdp-mix-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,180px),1fr));gap:8px}
.pmx-row{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--green-200);border-radius:var(--r-sm);padding:8px 11px}
.pmx-row.has-mel{align-items:flex-start}
.pmx-rflag{font-size:19px;flex:none}
.pmx-body{flex:1;min-width:0}
.pmx-line{display:flex;align-items:center;gap:8px}
.pmx-saveur{font-weight:700;font-size:13.5px;color:var(--ink-900);flex:1;min-width:0}
.pmx-pays{font-size:11px;font-weight:600;color:var(--gray-500);white-space:nowrap}
.pmx-melange{font-size:12px;color:var(--green-800);margin-top:3px;line-height:1.4}

/* Pronos — pop-up d'accueil */
.pronos-pop-ov{position:fixed;inset:0;z-index:120;background:rgba(20,21,15,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;animation:ppFade .2s ease}
@keyframes ppFade{from{opacity:0}to{opacity:1}}
.pronos-pop{background:#fff;border-radius:var(--r-xl);max-width:420px;width:100%;overflow:hidden;box-shadow:var(--shadow-lg);position:relative;animation:ppRise .25s var(--ease)}
@keyframes ppRise{from{transform:translateY(14px);opacity:.6}to{transform:translateY(0);opacity:1}}
.pronos-pop-top{background:var(--ink-900);color:#fff;padding:30px 26px 26px;text-align:center;position:relative;overflow:hidden}
.pronos-pop-top::after{content:"";position:absolute;right:-50px;top:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(164,196,28,.32),transparent 65%)}
.pp-trophy{font-size:46px;position:relative;z-index:1}
.pronos-pop-top h2{font-family:var(--font-display);font-weight:900;text-transform:uppercase;letter-spacing:-.02em;font-size:26px;line-height:1.05;margin:8px 0 0;position:relative;z-index:1}
.pronos-pop-top h2 .g{color:var(--brand-green)}
.pronos-pop-body{padding:22px 26px 26px;text-align:center}
.pronos-pop-body p{font-size:14.5px;color:var(--gray-600);line-height:1.55;margin:0 0 18px}
.pp-btns{display:flex;flex-direction:column;gap:9px}
.pp-go{display:block;background:var(--brand-green);color:var(--ink-900);font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.03em;font-size:15px;padding:14px;border-radius:var(--r-pill);box-shadow:var(--shadow-brand);text-decoration:none;transition:background .15s}
.pp-go:hover{background:var(--green-600)}
.pp-later{background:none;border:none;color:var(--gray-500);font-size:13px;font-weight:600;cursor:pointer;padding:6px}
.pp-later:hover{color:var(--ink-900)}
.pronos-pop-x{position:absolute;top:12px;right:12px;z-index:2;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;border:none;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}
.pronos-pop-x:hover{background:rgba(255,255,255,.28)}
@media(max-width:520px){.pronos-pop-top h2{font-size:23px}.pronos-pop-body p{font-size:13.5px}}

/* Pronos — rail « Coupe du Monde des liquides » sur l'accueil */
.wc-sec .wc-rail{display:flex;gap:18px;overflow-x:auto;padding:4px 2px 14px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.wc-sec .wc-rail::-webkit-scrollbar{height:8px}
.wc-sec .wc-rail::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--r-pill)}
.wc-item{flex:0 0 230px;width:230px;scroll-snap-align:start}
@media(max-width:560px){.wc-item{flex:0 0 165px;width:165px}.wc-sec .wc-rail{gap:12px}}
.nav-row{display:flex;align-items:center;gap:22px;padding:13px 0}
.brand{display:flex;align-items:center;flex:none;margin-right:4px}
.brand img{height:48px;display:block}
.nav-cats{display:flex;gap:2px;margin-left:4px}
.nav-cats a{font-family:var(--font-display);font-size:14px;font-weight:800;letter-spacing:.01em;text-transform:uppercase;color:var(--ink-800);padding:9px 13px;border-radius:var(--r-pill);transition:background .15s,color .15s;white-space:nowrap}ckground .15s,color .15s}
.nav-cats a:hover{background:var(--green-50);color:var(--green-800)}
.nav-cats a.on{background:var(--ink-900);color:#fff}
.nav-tools{margin-left:auto;display:flex;align-items:center;gap:4px}
.nav-burger{display:none}
.mobile-menu{border-top:1px solid var(--border-soft);background:#fff;padding:8px 0 14px;display:flex;flex-direction:column}
.mobile-menu a{display:flex;align-items:center;gap:12px;padding:13px 4px;font-family:var(--font-display);font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.02em;color:var(--ink-900);border-bottom:1px solid var(--border-soft)}
.mobile-menu a:last-child{border-bottom:0}
.mobile-menu a.on{color:var(--green-800)}
.mobile-menu a svg{width:20px;height:20px;color:var(--green-700);flex:none}
.mm-search{display:flex;align-items:center;gap:9px;border:1.5px solid var(--border);border-radius:var(--r-pill);padding:10px 16px;margin:6px 0 10px}
.mm-search input{border:0;outline:0;flex:1;font-family:var(--font-body);font-size:15px;background:transparent;color:var(--ink-900)}
.mm-search svg{width:18px;height:18px;color:var(--gray-500);flex:none}
.icon-btn{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border:1.5px solid transparent;border-radius:var(--r-pill);background:transparent;color:var(--ink-900);position:relative;transition:border-color .2s,color .2s,background .2s}
.icon-btn:hover{background:var(--green-50);color:var(--green-800)}
.icon-btn svg{width:21px;height:21px}
.icon-btn .count{position:absolute;top:0;right:0;min-width:18px;height:18px;padding:0 4px;border-radius:var(--r-pill);background:var(--brand-green);color:var(--ink-900);font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;font-family:var(--font-body)}
.searchbar{flex:1;max-width:330px;display:flex;align-items:center;gap:9px;border:1.5px solid var(--border);border-radius:var(--r-pill);padding:9px 16px;background:#fff;transition:border-color .2s,box-shadow .2s}
.searchbar:focus-within{border-color:var(--brand-green);box-shadow:var(--ring-brand)}
.searchbar input{border:0;outline:0;background:transparent;flex:1;font-family:var(--font-body);font-size:14px;color:var(--ink-900)}
.searchbar svg{width:18px;height:18px;color:var(--gray-500);flex:none}

/* =================== HERO =================== */
.hero{position:relative;padding:64px 0 56px;overflow:hidden}
.hero .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);line-height:.98;font-size:clamp(46px,5.6vw,82px);color:var(--ink-900);overflow-wrap:break-word;word-break:break-word;hyphens:auto}
.hero h1 em{font-style:normal;color:var(--green-700)}
.hero .lead{font-family:var(--font-body);font-weight:500;font-size:18px;color:var(--fg-muted);max-width:460px;margin:22px 0 30px;line-height:1.55}
.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}
.hero-visual{position:relative;width:488px;max-width:100%;aspect-ratio:1/1;margin-left:auto;border-radius:var(--r-lg);background:var(--ink-900);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-visual .ph{text-align:center;padding:34px;position:relative;z-index:2}
.hero-visual .ph img{height:auto;width:300px;max-width:78%;margin:0 auto}
.hero-visual .smoke{position:absolute;right:-30px;bottom:-30px;width:280px;opacity:.10;filter:invert(1)}
.hero-stat{position:absolute;z-index:3;background:var(--brand-green);color:var(--ink-900);border-radius:var(--r-pill);padding:9px 16px;font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.trustline{display:flex;gap:28px;flex-wrap:wrap;margin-top:34px;padding-top:24px;border-top:1px solid var(--border-soft)}
.trustline .ti{display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:600;color:var(--ink-800)}
.trustline .ti svg{width:19px;height:19px;color:var(--green-700);flex:none}

/* =================== SECTION HEADS =================== */
.sec{padding:54px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:30px}
.sec-head h2{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);font-size:clamp(28px,3vw,40px);line-height:1;color:var(--ink-900)}
.sec-head .eyebrow{margin-bottom:10px}
.sec-head .serif-sub{font-family:var(--font-body);font-weight:500;color:var(--fg-muted);font-size:16px;margin-top:8px}

/* =================== CATEGORY TILES =================== */
.cat-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cat-tile{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);padding:26px 22px;min-height:168px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:transform .18s,box-shadow .18s,border-color .18s;box-shadow:var(--shadow-xs)}
.cat-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--brand-green)}
.cat-tile .ct-ic{width:42px;height:42px;border-radius:var(--r-pill);background:var(--green-50);display:flex;align-items:center;justify-content:center;color:var(--green-700)}
.cat-tile .ct-ic svg{width:23px;height:23px}
.cat-tile .ct-n{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.01em;font-weight:800;font-size:20px;color:var(--ink-900)}
.cat-tile .ct-c{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green-800);margin-top:4px}

/* =================== PRODUCT GRID & CARD =================== */
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pgrid.g3{grid-template-columns:repeat(3,1fr)}
.pcard{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s;position:relative;overflow:hidden;box-shadow:var(--shadow-xs)}
.pcard:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.pcard .pthumb{aspect-ratio:1/1;background:#fff;position:relative;overflow:hidden;border-bottom:1px solid var(--border-soft)}
.pcard .pthumb img{width:100%;height:100%;object-fit:contain;padding:16px;mix-blend-mode:multiply;transition:transform .35s var(--ease)}
.pcard:hover .pthumb img{transform:scale(1.05)}
.pcard .pthumb .fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--green-50);color:var(--green-800);text-align:center;padding:18px}
.pcard .pthumb .fallback img{width:44%;height:auto;padding:0;mix-blend-mode:multiply;opacity:.92}
.pcard .pthumb .fallback .fn{font-family:var(--font-display);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;line-height:1.4}
.pbadge{position:absolute;top:11px;left:11px;z-index:2;display:flex;flex-direction:column;gap:5px;align-items:flex-start}
.tag{font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-pill)}
.tag.ink{background:var(--ink-900);color:#fff}
.tag.rouge{background:var(--danger);color:#fff}
.tag.sable{background:var(--brand-green);color:var(--ink-900)}
.tag.line{background:var(--green-100);color:var(--green-800)}
.tag.gold{background:var(--warning-bg);color:#8a6d1f;border:1px solid var(--warning)}
.tag.mix{display:inline-flex;align-items:center;gap:5px;background:var(--info-bg);color:var(--info);border:1px solid var(--info)}
.tag.boost{font-style:italic;font-size:9.5px;padding:3px 9px;background:var(--green-800);color:#fff;text-transform:none;letter-spacing:.01em}
.tag.collab{display:inline-flex;align-items:center;gap:5px;background:var(--ink-900);color:var(--brand-green);text-transform:none;letter-spacing:.01em}
.fav-btn{position:absolute;top:10px;right:10px;z-index:2;width:34px;height:34px;border-radius:var(--r-pill);background:rgba(255,255,255,.92);border:1px solid var(--border-soft);display:flex;align-items:center;justify-content:center;color:var(--gray-500);transition:color .2s,border-color .2s,transform .15s}
.fav-btn:hover{border-color:var(--brand-green);color:var(--green-700);transform:scale(1.08)}
.fav-btn.on{color:var(--green-700);border-color:var(--brand-green)}
.prono-badge{position:absolute;top:52px;right:10px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none}
.prono-badge .pb-flag{width:34px;height:34px;border-radius:50%;background:#fff;border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:center;font-size:19px;line-height:1;transition:transform .15s}
.prono-badge:hover .pb-flag{transform:scale(1.1);border-color:var(--brand-green)}
.prono-badge .pb-vote{font-family:var(--font-display);font-size:8.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-900);background:var(--brand-green);padding:2px 8px;border-radius:var(--r-pill);box-shadow:var(--shadow-xs)}
.prono-badge.multi .pb-flags{display:flex;align-items:center}
.prono-badge.multi .pb-flag{margin-left:-9px;font-size:17px}
.prono-badge.multi .pb-flag:first-child{margin-left:0}
.fav-btn svg{width:16px;height:16px}
.pcard .pbody{padding:15px 16px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.pcard .pbrand{font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green-800)}
.pcard .pname{font-family:var(--font-display);font-size:16px;font-weight:800;line-height:1.12;letter-spacing:-.01em;text-transform:uppercase;color:var(--ink-900);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.24em}
.pcard .pmeta{display:flex;gap:6px;flex-wrap:wrap;margin-top:1px}
.minichip{font-size:10.5px;font-weight:600;letter-spacing:.02em;color:var(--gray-600);background:var(--gray-100);padding:3px 9px;border-radius:var(--r-pill)}
.intens{display:inline-flex;align-items:center;gap:9px}
.intens-i{display:inline-flex;align-items:center;gap:4px;font-size:10px}
.intens-i.fresh{color:var(--info)}
.intens-i.sugar{color:var(--green-800)}
.dots{display:inline-flex;gap:2px}
.dots .dot{width:5px;height:5px;border-radius:50%;background:var(--gray-300)}
.intens-i.fresh .dot.on{background:var(--info)}
.intens-i.sugar .dot.on{background:var(--green-700)}
.pcard .pfoot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:10px}
.price{font-family:var(--font-display);font-weight:800;font-size:20px;letter-spacing:-.01em;color:var(--ink-900)}
.price .old{font-size:13px;color:var(--gray-500);text-decoration:line-through;margin-right:7px;font-weight:600}
.addmini{width:40px;height:40px;border-radius:var(--r-pill);border:0;background:var(--ink-900);color:#fff;display:flex;align-items:center;justify-content:center;transition:background .16s,transform .12s}
.addmini:hover{background:var(--green-600);color:var(--ink-900);transform:translateY(-1px)}
.addmini svg{width:18px;height:18px}
.nicpop{position:absolute;bottom:calc(100% + 8px);right:0;z-index:31;background:#fff;border:1.5px solid var(--ink-900);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:8px;min-width:120px;animation:toastin .16s ease}
.nicpop-h{font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-500);padding:4px 8px 7px}
.nicpop-opt{display:block;width:100%;text-align:left;border:0;background:transparent;font-family:var(--font-body);font-weight:600;font-size:13.5px;color:var(--ink-900);padding:9px 10px;border-radius:var(--r-sm);cursor:pointer}
.nicpop-opt:hover{background:var(--green-50);color:var(--green-800)}

/* gauges */
.gauge{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600)}
.gauge .dots{display:flex;gap:4px}
.gauge .d{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--gray-400)}
.gauge .d.on{background:var(--brand-green);border-color:var(--brand-green)}
.gauge.fresh .d.on{background:var(--info);border-color:var(--info)}

/* =================== CATALOG LAYOUT =================== */
.catalog{display:grid;grid-template-columns:250px 1fr;gap:34px;align-items:start;padding:34px 0 72px}
.filters{position:sticky;top:104px;border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-xs)}
.filters .fgroup{border-bottom:1px solid var(--border-soft);padding:18px 20px}
.filters .fgroup:last-child{border-bottom:0}
.filters h4{font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-900);margin-bottom:13px}
.fopt{display:flex;align-items:flex-start;gap:10px;padding:6px 0;font-size:13.5px;line-height:1.35;color:var(--gray-600);cursor:pointer;transition:color .15s}
.fopt:hover{color:var(--ink-900)}
.fopt .box{width:16px;height:16px;margin-top:1px;border:1.5px solid var(--gray-400);border-radius:var(--r-xs);flex:none;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}
.fopt.on{color:var(--ink-900);font-weight:600}
.fopt.on .box{background:var(--brand-green);border-color:var(--brand-green)}
.fopt .box svg{width:11px;height:11px;color:var(--ink-900);opacity:0;transition:opacity .15s}
.fopt.on .box svg{opacity:1}
.fopt .c{margin-left:auto;padding-left:8px;font-size:11px;color:var(--gray-400);flex:none}
.catalog-main{min-width:0}
.catalog-main .cm-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.catalog-main h1{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);font-size:36px;line-height:1;color:var(--ink-900)}
.catalog-main .sub{font-family:var(--font-body);font-weight:500;color:var(--fg-muted);font-size:14.5px;margin-top:6px;max-width:560px}
.crumbs{font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--gray-500);margin-bottom:14px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumbs a:hover{color:var(--green-800)}
.crumbs .sep{color:var(--gray-300)}
.selectx{border:1.5px solid var(--border);background:#fff;padding:9px 14px;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--ink-900);border-radius:var(--r-pill)}
.chipbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.subchips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;align-items:center}
.subchips .sc-lbl{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500);margin-right:4px}
.subchip{flex:none;font-family:var(--font-body);font-weight:600;font-size:13px;padding:9px 15px;border:1.5px solid var(--border);background:#fff;border-radius:var(--r-pill);color:var(--gray-600);white-space:nowrap;cursor:pointer;transition:all .15s}
.subchip:hover{border-color:var(--ink-900);color:var(--ink-900)}
.subchip.on{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.fchip{font-size:12px;font-weight:600;letter-spacing:.02em;padding:6px 13px;border:1.5px solid var(--border);background:#fff;border-radius:var(--r-pill);color:var(--gray-600);transition:all .15s;display:inline-flex;align-items:center;gap:7px}
.fchip:hover{border-color:var(--ink-900);color:var(--ink-900)}
.fchip.on{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.fchip.on .x{opacity:.7}

.pager{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:44px}
.pager button{min-width:40px;height:40px;border:1.5px solid var(--border);background:#fff;color:var(--ink-900);font-size:14px;font-weight:700;border-radius:var(--r-pill);padding:0 12px;transition:all .15s}
.pager button:hover:not(:disabled){border-color:var(--ink-900)}
.pager button.on{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.pager button:disabled{opacity:.35}

.empty{text-align:center;padding:64px 20px;border:1.5px dashed var(--border);border-radius:var(--r-md);color:var(--gray-600);background:#fff}
.empty .serif{font-size:24px;color:var(--ink-900);display:block;margin-bottom:10px}

/* =================== PRODUCT PAGE =================== */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:30px 0 64px;align-items:start}
.pdp-media{position:sticky;top:104px}
.pdp-img{aspect-ratio:1/1;background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-lg);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.pdp-img img{width:100%;height:100%;object-fit:contain;padding:42px;mix-blend-mode:multiply}
.pdp-img .fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--green-50);color:var(--green-800)}
.pdp-img .fallback img{width:38%;height:auto;padding:0;mix-blend-mode:multiply}
.pdp-img .fallback .fn{font-family:var(--font-display);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:13px}
.pdp-info .pdp-brand{color:var(--green-800);font-family:var(--font-body);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:700;margin-bottom:10px}
.pdp-info h1{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);font-size:clamp(28px,3.4vw,42px);line-height:1.02;color:var(--ink-900)}
.pdp-price{font-family:var(--font-display);font-weight:800;font-size:32px;letter-spacing:-.01em;margin:18px 0;color:var(--ink-900)}
.pdp-price .old{font-size:20px;color:var(--gray-500);text-decoration:line-through;margin-right:10px;font-weight:600}
.pdp-desc{color:var(--fg-muted);font-size:15px;line-height:1.7;white-space:pre-line;margin:6px 0 8px;max-height:200px;overflow:hidden;position:relative;transition:max-height .3s}
.pdp-desc.open{max-height:1400px}
.pdp-desc.clip::after{content:"";position:absolute;left:0;right:0;bottom:0;height:54px;background:linear-gradient(transparent,var(--bg))}
.readmore{font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--green-800);margin-top:8px;background:none;border:0;padding:0}
.pdp-block{border-top:1px solid var(--border-soft);padding:22px 0}
.pdp-block h3{font-family:var(--font-display);font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px;color:var(--ink-900)}
.opt-row{display:flex;gap:9px;flex-wrap:wrap}
.opt{padding:11px 17px;border:1.5px solid var(--border);background:#fff;border-radius:var(--r-pill);font-size:13.5px;font-weight:600;letter-spacing:0;color:var(--ink-900);transition:all .15s;min-width:54px;text-align:center}
.opt:hover{border-color:var(--ink-900)}
.opt.on{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.opt.opt-img{display:inline-flex;align-items:center;gap:8px;padding-left:8px}
.opt-thumb{width:26px;height:26px;object-fit:contain;border-radius:var(--r-xs);background:#fff;mix-blend-mode:multiply;flex:none}
.opt small{display:block;font-size:10px;color:inherit;opacity:.7;margin-top:2px;font-weight:500}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--r-pill)}
.qty button{width:42px;height:44px;background:transparent;border:0;font-size:18px;color:var(--ink-900);border-radius:var(--r-pill)}
.qty button:hover{background:var(--green-50)}
.qty span{min-width:42px;text-align:center;font-size:15px;font-weight:700}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.specs .sp{background:var(--gray-50);border:1px solid var(--border-soft);border-radius:var(--r-sm);padding:13px 15px}
.specs .sp .k{font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500)}
.specs .sp .v{font-size:14px;font-weight:600;margin-top:3px;display:flex;align-items:center;gap:8px;color:var(--ink-900)}

/* =================== CALCULATOR =================== */
.calc{border:1.5px solid var(--ink-900);border-radius:var(--r-lg);background:#fff;box-shadow:var(--shadow-md);overflow:hidden;margin-top:4px}
.calc .ch{background:var(--ink-900);color:#fff;padding:15px 18px;display:flex;align-items:center;gap:11px}
.calc .ch svg{width:22px;height:22px;color:var(--brand-green)}
.calc .ch .t{font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:.04em;font-size:15px}
.calc .ch .s{font-size:11.5px;color:#cfd2c4;letter-spacing:.02em;margin-left:auto;font-weight:500}
.calc .cbody{padding:20px 18px;background:var(--green-50)}
.calc .lbl{font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-800);margin-bottom:11px;display:flex;align-items:center;gap:8px}
.calc .result{background:#fff;border:1.5px solid var(--brand-green);border-radius:var(--r-md);padding:18px;margin:18px 0;text-align:center;box-shadow:var(--shadow-xs)}
.calc .result .big{font-family:var(--font-display);font-weight:900;font-size:34px;letter-spacing:-.02em;color:var(--ink-900);line-height:1}
.calc .result .big .u{color:var(--green-700)}
.calc .result .lab{font-size:12px;font-weight:600;color:var(--gray-600);margin-top:8px}
.calc .result .note{font-size:12px;color:var(--gray-600);margin-top:9px;line-height:1.5}
.vialrow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:6px}
.vialcard{border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-md);padding:14px}
.vialcard .vn{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--ink-900)}
.vialcard .vn .swatch{width:11px;height:11px;border-radius:50%}
.vialcard .vmeta{font-size:11px;color:var(--gray-600);margin:4px 0 12px;line-height:1.45}
.stepper{display:flex;align-items:center;justify-content:space-between;border:1.5px solid var(--ink-900);border-radius:var(--r-pill)}
.stepper button{width:38px;height:38px;background:transparent;border:0;font-size:18px;color:var(--ink-900);border-radius:var(--r-pill)}
.stepper button:hover{background:var(--green-50)}
.stepper span{font-size:16px;font-weight:800;font-family:var(--font-display)}

/* =================== FINDER (questionnaire) =================== */
.finder-band{background:var(--ink-900);color:#fff;border-radius:var(--r-lg);overflow:hidden;position:relative}
.finder-band .fb-in{padding:46px 44px;display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:center}
.finder-band h2{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);font-size:clamp(28px,3vw,40px);line-height:1.02}
.finder-band h2 em{font-style:normal;color:var(--brand-green)}
.finder-band p{color:#b9bcae;font-size:15px;margin-top:14px;max-width:440px;font-weight:500;line-height:1.55}
.finder-wrap{max-width:760px;margin:0 auto;padding:44px 0 72px}
.finder-card{border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:40px}
.finder-prog{display:flex;gap:6px;margin-bottom:30px}
.finder-prog .s{flex:1;height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden}
.finder-prog .s.on{background:var(--brand-green)}
.finder-q{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);font-size:28px;text-align:center;margin-bottom:6px;color:var(--ink-900)}
.finder-sub{text-align:center;color:var(--fg-muted);font-weight:500;font-size:15px;margin-bottom:30px}
.choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.choice{border:1.5px solid var(--border);background:#fff;border-radius:var(--r-md);padding:24px 16px;text-align:center;transition:all .18s;display:flex;flex-direction:column;align-items:center;gap:11px}
.choice:hover{border-color:var(--brand-green);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.choice.on{border-color:var(--brand-green);background:var(--green-50);box-shadow:inset 0 0 0 1.5px var(--brand-green)}
.choice svg{width:34px;height:34px;color:var(--green-700)}
.choice .cl{font-family:var(--font-display);font-size:13px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-900)}
.choice .cd{font-size:11.5px;color:var(--gray-600);line-height:1.4}

/* =================== DRAWER / CART =================== */
.scrim{position:fixed;inset:0;background:rgba(20,21,15,.5);z-index:90;opacity:0;animation:fade .2s forwards}
@keyframes fade{to{opacity:1}}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,94vw);background:var(--bg);z-index:91;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);transform:translateX(100%);animation:slidein .32s var(--ease) forwards}
@keyframes slidein{to{transform:translateX(0)}}
.drawer .dh{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border-soft);background:#fff}
.drawer .dh .t{font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:.04em;font-size:17px;color:var(--ink-900)}
.drawer .dbody{flex:1;overflow-y:auto;padding:8px 22px;background:#fff}
.drawer .dfoot{border-top:1px solid var(--border-soft);padding:20px 22px;background:#fff}
.citem{display:grid;grid-template-columns:64px 1fr auto;gap:13px;padding:16px 0;border-bottom:1px solid var(--border-soft)}
.citem .ci-img{width:64px;height:64px;background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-sm);overflow:hidden;display:flex;align-items:center;justify-content:center}
.citem .ci-img img{width:100%;height:100%;object-fit:contain;padding:6px;mix-blend-mode:multiply}
.citem .ci-n{font-size:13.5px;font-weight:600;line-height:1.3;color:var(--ink-900)}
.citem .ci-v{font-size:11px;color:var(--gray-600);margin-top:3px;line-height:1.4}
.citem .ci-p{font-family:var(--font-display);font-weight:800;font-size:16px;text-align:right;white-space:nowrap;color:var(--ink-900)}
.citem .ci-rm{font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--gray-500);margin-top:6px;background:none;border:0;padding:0}
.citem .ci-rm:hover{color:var(--danger)}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;font-size:13.5px;color:var(--gray-600)}
.cart-total.grand{font-size:16px;color:var(--ink-900);margin:12px 0 18px;font-weight:600}
.cart-total.grand .v{font-family:var(--font-display);font-weight:800;font-size:26px}
.ship-bar{height:7px;background:var(--gray-200);border-radius:var(--r-pill);overflow:hidden;margin:6px 0 8px}
.ship-bar i{display:block;height:100%;background:var(--brand-green);transition:width .4s}

/* =================== CHECKOUT =================== */
.checkout{display:grid;grid-template-columns:1fr 410px;gap:42px;padding:34px 0 72px;align-items:start}
.co-section{border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-md);padding:26px 28px;margin-bottom:20px;box-shadow:var(--shadow-xs)}
.co-section h3{font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:.04em;font-size:18px;margin-bottom:4px;display:flex;align-items:center;gap:12px;color:var(--ink-900)}
.co-section h3 .num{width:27px;height:27px;background:var(--brand-green);color:var(--ink-900);border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;font-family:var(--font-display);flex:none}
.co-section .hint{color:var(--gray-600);font-size:13.5px;font-weight:500;margin-bottom:20px;margin-left:39px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600);margin-bottom:7px}
.field label .req{color:var(--danger)}
.field input,.field textarea,.field select{width:100%;padding:12px 14px;font-family:var(--font-body);font-size:14px;color:var(--ink-900);background:#fff;border:1.5px solid var(--border);border-radius:var(--r-sm);outline:none;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brand-green);box-shadow:var(--ring-brand)}
.field input.err{border-color:var(--danger);background:var(--danger-bg)}
.field .errmsg{color:var(--danger);font-size:11.5px;margin-top:6px;display:flex;align-items:center;gap:6px;font-weight:600}
.field .ok-tick{color:var(--success)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.optcard{border:1.5px solid var(--border);background:#fff;border-radius:var(--r-md);padding:16px 18px;display:flex;gap:13px;align-items:flex-start;cursor:pointer;transition:all .18s;margin-bottom:12px}
.optcard:hover{border-color:var(--ink-900)}
.optcard.on{border-color:var(--brand-green);background:var(--green-50);box-shadow:inset 0 0 0 1.5px var(--brand-green)}
.optcard .radio{width:19px;height:19px;border:1.5px solid var(--gray-400);border-radius:50%;flex:none;margin-top:2px;display:flex;align-items:center;justify-content:center}
.optcard.on .radio{border-color:var(--green-600)}
.optcard.on .radio::after{content:"";width:10px;height:10px;border-radius:50%;background:var(--brand-green)}
.optcard .oc-t{font-size:14.5px;font-weight:700;display:flex;align-items:center;gap:10px;color:var(--ink-900)}
.optcard .oc-d{font-size:12.5px;color:var(--gray-600);margin-top:4px;line-height:1.5}
.optcard .oc-tag{margin-left:auto;font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--green-800)}
.slotgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;margin-top:6px}
.slot{border:1.5px solid var(--border);background:#fff;border-radius:var(--r-pill);padding:9px;text-align:center;font-size:12.5px;font-weight:600;color:var(--green-800);-webkit-text-fill-color:var(--green-800);transition:all .15s}
.slot:hover{border-color:var(--green-800)}
.slot.on{background:var(--green-800);color:#fff;-webkit-text-fill-color:#fff;border-color:var(--green-800)}
/* iOS/Safari : neutralise la détection auto des horaires (sinon affichés en bleu) */
.slot a,.slot a[x-apple-data-detectors],.selectx a[x-apple-data-detectors]{color:inherit!important;-webkit-text-fill-color:inherit!important;text-decoration:none!important;pointer-events:none}
.slot .sd{font-size:10px;color:inherit;opacity:.7;text-transform:uppercase;letter-spacing:.06em}
/* Pièce d'identité — vignette & agrandissement (back-office) */
@keyframes idFade{from{opacity:0}to{opacity:1}}
.id-thumb{display:inline-block;position:relative;width:104px;height:66px;border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden;background:var(--gray-100);cursor:zoom-in;padding:0}
.id-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.id-thumb-pdf{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:var(--font-display);font-weight:800;font-size:15px;color:var(--gray-600);letter-spacing:.06em}
.id-thumb-zoom{position:absolute;right:5px;bottom:5px;width:22px;height:22px;border-radius:50%;background:rgba(20,21,15,.72);color:#fff;display:flex;align-items:center;justify-content:center}
.id-thumb:hover{border-color:var(--green-800)}
.id-lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,21,15,.82);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:30px 20px;animation:idFade .18s ease}
.id-lightbox-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:92vw}
.id-lb-img{max-width:min(86vw,820px);max-height:78vh;border-radius:var(--r-md);box-shadow:var(--shadow-lg);background:#fff}
.id-lb-x{position:absolute;top:-16px;right:-16px;width:40px;height:40px;border-radius:50%;background:#fff;color:var(--ink-900);font-size:16px;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}
.id-lb-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.summary{position:sticky;top:104px;border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-sm)}
.summary .sh{padding:18px 22px;border-bottom:1px solid var(--border-soft);font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:.04em;font-size:16px;color:var(--ink-900)}
.summary .sbody{padding:8px 22px;max-height:300px;overflow-y:auto}
.summary .sfoot{padding:18px 22px;border-top:1px solid var(--border-soft);background:var(--gray-50);border-radius:0 0 var(--r-md) var(--r-md)}

/* =================== ACCOUNT =================== */
.acct{display:grid;grid-template-columns:230px 1fr;gap:34px;padding:34px 0 72px;align-items:start}
.acct-nav{border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-md);overflow:hidden;position:sticky;top:104px;box-shadow:var(--shadow-xs)}
.acct-nav button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:15px 18px;background:transparent;border:0;border-bottom:1px solid var(--border-soft);font-size:13.5px;font-weight:600;letter-spacing:0;color:var(--gray-600);transition:all .15s}
.acct-nav button:last-child{border-bottom:0}
.acct-nav button svg{width:18px;height:18px}
.acct-nav button:hover{color:var(--ink-900);background:var(--green-50)}
.acct-nav button.on{color:var(--ink-900);background:var(--green-50);border-left:3px solid var(--brand-green);font-weight:700}
.order-card{border:1px solid var(--border-soft);background:#fff;border-radius:var(--r-md);padding:20px 22px;margin-bottom:16px;box-shadow:var(--shadow-xs)}
.order-card .oh{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--border-soft);margin-bottom:14px;flex-wrap:wrap}
.statuschip{font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:var(--r-pill)}
.statuschip.prep{background:var(--warning-bg);color:#8a6d1f}
.statuschip.new{background:var(--info-bg);color:var(--info)}
.qtyx{display:inline-flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--r-pill);overflow:hidden}
.qtyx button{border:none;background:none;width:30px;height:30px;cursor:pointer;font-size:16px;font-weight:700;color:var(--ink-900);display:flex;align-items:center;justify-content:center}
.qtyx button:hover{background:var(--green-50)}
.qtyx span{min-width:26px;text-align:center;font-weight:700;font-size:13px}
.statuschip.ready{background:var(--success-bg);color:var(--success)}
.statuschip.sent{background:var(--ink-900);color:#fff}
.oa-k{font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500);margin-bottom:3px}
.oa-v{font-size:13.5px;color:var(--ink-900);line-height:1.5}

/* =================== AGE GATE =================== */
.agegate{position:fixed;inset:0;z-index:200;background:var(--ink-900);display:flex;align-items:center;justify-content:center;padding:24px}
.agegate .ag-card{max-width:460px;text-align:center;color:#fff}
.agegate .ag-logo{height:84px;margin:0 auto 26px;filter:brightness(0) invert(1)}
.agegate .ag-mark{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:.12em;font-size:24px;margin-bottom:4px}
.agegate .ag-sub{font-weight:500;color:var(--brand-green);font-size:14px;margin-bottom:32px;letter-spacing:.04em}
.agegate h2{font-family:var(--font-display);font-weight:900;text-transform:uppercase;font-size:34px;line-height:1.05;letter-spacing:var(--track-display);margin-bottom:18px}
.agegate p{color:#b9bcae;font-size:14px;line-height:1.6;max-width:390px;margin:0 auto 32px}
.agegate .ag-btns{display:flex;gap:12px;justify-content:center}
.agegate .btn.outline{color:#fff;border-color:rgba(255,255,255,.4)}
.agegate .btn.outline:hover{background:#fff;color:var(--ink-900);border-color:#fff}
.agegate .ag-deny{color:#8d9082;font-size:12px;margin-top:24px;font-weight:500}

/* =================== TOAST =================== */
.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{background:var(--ink-900);color:#fff;padding:13px 22px;border-radius:var(--r-pill);font-size:13.5px;font-weight:600;letter-spacing:.01em;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg);animation:toastin .3s var(--ease)}
.toast svg{width:18px;height:18px;color:var(--brand-green);flex:none}
@keyframes toastin{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* =================== FOOTER =================== */
footer.site{background:var(--ink-900);color:#fff;margin-top:40px}
footer.site .ft{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:36px;padding:56px 0 40px}
footer.site .fcol h5{font-family:var(--font-display);font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-green);margin-bottom:18px}
footer.site .fcol a,footer.site .fcol p{color:#cfd2c4;font-size:13.5px;line-height:2;display:block}
footer.site .fcol a:hover{color:#fff}
footer.site .fbrand .flogo{height:40px;margin-bottom:16px}
footer.site .fbrand p{font-size:13.5px;color:#a9ac9e;line-height:1.7;max-width:300px}
footer.site .hours{display:flex;justify-content:space-between;font-size:13px;color:#cfd2c4;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.08)}
footer.site .hours b{color:#fff;font-weight:600}
footer.site .legal{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;font-size:11.5px;color:#8d9082;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;letter-spacing:.01em}
footer.site .credit{padding:0 0 26px;font-size:11.5px;color:#7c8073;letter-spacing:.02em;text-align:center}
footer.site .credit a{color:#a9ac9e;text-decoration:none;font-weight:600;transition:color .18s var(--ease)}
footer.site .credit a:hover{color:var(--brand-green)}
.socials{display:flex;gap:10px;margin-top:12px}
footer.site .socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.2);border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;color:#cfd2c4;transition:all .2s;line-height:0;padding:0}
footer.site .socials a:hover{background:var(--brand-green);border-color:var(--brand-green);color:var(--ink-900)}
footer.site .socials svg{width:16px;height:16px;display:block}

/* nicotine warn */
.nic-warn{background:#fff;border:1px solid var(--border-soft);border-left:3px solid var(--brand-green);border-radius:var(--r-sm);padding:13px 16px;font-size:12.5px;color:var(--gray-600);line-height:1.5;display:flex;gap:11px;align-items:flex-start}
.nic-warn svg{width:17px;height:17px;color:var(--green-700);flex:none;margin-top:1px}

/* related */
.related-wrap{border-top:1px solid var(--border-soft);padding:48px 0 10px}

/* ===== brands ===== */
.brand-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.brand-card{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-xs);transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;flex-direction:column}
.brand-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--brand-green)}
.brand-card-img{aspect-ratio:3/2;background:#fff;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-soft);overflow:hidden}
.brand-card-img img{width:100%;height:100%;object-fit:contain;padding:18px;mix-blend-mode:multiply}
.brand-initials{font-family:var(--font-display);font-weight:900;font-size:34px;color:var(--green-700)}
.brand-card-body{padding:14px 16px}
.brand-card-name{font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:-.01em;font-size:17px;color:var(--ink-900)}
.brand-card-count{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green-800);margin-top:3px}
.brand-hero{background:var(--ink-900);color:#fff}
.brand-hero .crumbs{color:#a9ac9e}
.brand-hero .crumbs a:hover{color:#fff}
.brand-hero .crumbs .sep{color:#555}
.brand-hero-in{display:flex;align-items:center;gap:28px;padding:18px 0 44px}
.brand-hero-logo{width:140px;height:110px;flex:none;background:#fff;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:12px}
.brand-hero-logo img{max-width:100%;max-height:100%;object-fit:contain}
.brand-hero .eyebrow{color:var(--brand-green)}
.brand-hero-title{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:-.02em;font-size:clamp(32px,5vw,58px);line-height:1;margin:8px 0 0}
.brand-hero-desc{color:#cfd2c4;font-size:15.5px;line-height:1.6;max-width:640px;margin-top:14px}
.gamme-text{font-family:var(--font-body);font-size:14.5px;line-height:1.55;color:var(--gray-600);max-width:620px;margin-top:8px}
.gamme-carousel{display:flex;gap:18px;overflow-x:auto;padding:4px 2px 18px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.gamme-carousel::-webkit-scrollbar{height:8px}
.gamme-carousel::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}
.gamme-item{flex:0 0 248px;max-width:248px;scroll-snap-align:start}
@media(max-width:560px){ .gamme-item{flex:0 0 70%;max-width:70%} }
/* étiquettes marque / gamme (back-office) */
.etq{display:inline-flex;align-items:center;gap:7px;background:var(--ink-900);color:#fff;font-family:var(--font-body);font-weight:700;font-size:12.5px;letter-spacing:.01em;padding:7px 8px 7px 13px;border-radius:var(--r-pill);max-width:100%}
.etq.etq-g{background:var(--green-100);color:var(--green-800);border:1px solid var(--green-300)}
.etq button{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:0;cursor:pointer;background:rgba(255,255,255,.22);color:inherit;flex:none}
.etq.etq-g button{background:var(--green-300)}
.etq button:hover{background:rgba(255,255,255,.4)}
.tag-pop{position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:20;background:#fff;border:1.5px solid var(--ink-900);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:6px;max-height:230px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.tag-pop-opt,.tag-pop-new{text-align:left;border:0;background:transparent;font-family:var(--font-body);font-size:13px;color:var(--ink-900);padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;gap:7px}
.tag-pop-opt:hover{background:var(--green-50);color:var(--green-800)}
.tag-pop-new{font-weight:700;color:var(--green-800);border-bottom:1px solid var(--border-soft);border-radius:0;margin-bottom:2px}
.tag-pop-new:hover{background:var(--green-50)}

/* ===== Tableau de bord ===== */
.dash{max-width:760px}
.dash-notif{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;background:var(--ink-900);color:#fff;border-radius:var(--r-md);padding:14px 18px;margin-bottom:18px}
.dash-notif svg{color:var(--brand-green)}
.dash-period{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:22px}
/* analyse d'audience */
.dash-an{background:var(--gray-50);border:1px solid var(--border-soft);border-radius:var(--r-lg);padding:18px;margin-bottom:22px}
.dash-an .an-head{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
.dash-an .an-head h3{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.03em;font-size:15px;color:var(--ink-900)}
.dash-an .an-sub{font-size:12.5px;color:var(--gray-500);font-weight:600}
.an-empty{font-size:13.5px;color:var(--gray-500);background:#fff;border:1px dashed var(--border);border-radius:var(--r-md);padding:18px;text-align:center}
.an-chart{display:flex;align-items:flex-end;gap:5px;height:64px;margin:6px 0 18px;padding:0 2px}
.an-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;justify-content:flex-end;height:100%}
.an-bar{width:100%;max-width:22px;background:var(--brand-green);border-radius:4px 4px 0 0;transition:height .3s}
.an-bar-day{font-size:9px;color:var(--gray-400);font-weight:600}
.an-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.an-list{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);padding:13px 14px}
.an-list-h{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--green-800);margin-bottom:9px}
.an-list-empty{font-size:12px;color:var(--gray-400);padding:6px 0}
.an-row{display:flex;align-items:center;gap:9px;padding:6px 0;border-top:1px solid var(--gray-100)}
.an-row:first-of-type{border-top:0}
.an-rank{flex:none;width:18px;height:18px;border-radius:50%;background:var(--green-100);color:var(--green-800);font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center}
.an-name{flex:1;min-width:0;font-size:12.5px;color:var(--ink-900);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.an-val{flex:none;font-size:12.5px;font-weight:800;color:var(--gray-600)}
@media(max-width:760px){.an-cols{grid-template-columns:1fr}}
.dash-stat{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:18px 18px 16px;box-shadow:var(--shadow-xs)}
.ds-val{font-family:var(--font-display);font-weight:900;font-size:30px;letter-spacing:-.02em;color:var(--ink-900);line-height:1}
.ds-lbl{font-family:var(--font-display);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-600);margin-top:8px}
.ds-sub{font-size:12px;color:var(--gray-500);margin-top:3px}
.dash-pending{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-xs)}
.dash-ph{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-soft);background:var(--gray-50)}
.dash-ph h3{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:15px;color:var(--ink-900)}
.dash-count{font-family:var(--font-display);font-weight:900;font-size:14px;background:var(--brand-green);color:var(--ink-900);min-width:26px;height:26px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;padding:0 8px}
.dash-order{display:flex;gap:12px;align-items:center;padding:13px 18px;border-bottom:1px solid var(--border-soft)}
.dash-order:last-child{border-bottom:0}
.dash-push{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-xs);margin-bottom:18px}
.tg-steps{margin:0 0 14px;padding-left:20px;font-size:13px;color:var(--gray-700);line-height:1.7}
.tg-steps code{background:var(--gray-100);padding:1px 6px;border-radius:4px;font-family:var(--font-mono,monospace);font-size:12px}
.deal-badge{display:flex;align-items:center;gap:9px;background:var(--green-50);border:1px solid var(--green-300);border-radius:var(--r-md);padding:11px 14px;margin:14px 0;font-size:13px;color:var(--green-900);line-height:1.4}
.deal-badge svg{color:var(--green-700);flex:none}
.deal-badge b{color:var(--green-800)}
.carousel{display:block;overflow-x:auto;padding:4px 2px 16px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.carousel::-webkit-scrollbar{height:8px}
.carousel::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}
.carousel-rows{display:flex;flex-direction:column;gap:18px;width:max-content}
.carousel-row{display:flex;gap:18px}
.carousel-item{flex:0 0 240px;max-width:240px}
@media(max-width:560px){ .carousel-item{flex:0 0 64vw;max-width:64vw} }

/* ===== back-office responsive ===== */
.bo-tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--border-soft);padding-bottom:14px;flex-wrap:wrap}
.bo-tabsel{display:none}
@media(max-width:860px){
  .bo-tabs{display:none}
  .bo-tabsel{display:block;width:100%;margin-bottom:18px;padding:13px 14px;border:1.5px solid var(--ink-900);border-radius:var(--r-md);background:var(--ink-900);color:#fff;font-family:var(--font-display);font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.02em;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='white' stroke-width='2'><path d='M4 6l4 4 4-4'/></svg>");background-repeat:no-repeat;background-position:right 14px center}
  /* tables admin : on autorise le scroll horizontal plutôt que de casser */
  .wrap-wide .bo-table, .dash{overflow-x:visible}
  .bo-row-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
}
/* en-tête gérant : empile proprement sur mobile/tablette */
@media(max-width:960px){
  .bo-head{flex-direction:column;align-items:stretch !important}
  .bo-head h1{font-size:clamp(24px,6vw,32px) !important;line-height:1.05}
  .bo-head .bo-actions{display:flex;flex-wrap:wrap;gap:8px}
  .bo-head .bo-actions .btn{flex:1 1 auto;justify-content:center;white-space:nowrap}
}
@media(max-width:420px){
  .bo-head .bo-actions{display:grid;grid-template-columns:1fr 1fr}
  .bo-head .bo-actions .btn:last-child{grid-column:1 / -1}
}
@media(max-width:560px){
  .dash-grid{grid-template-columns:1fr 1fr;gap:10px}
  .ds-val{font-size:25px}
  .dash-order{flex-direction:column;align-items:stretch}
  .dash-order>div:last-child{text-align:left !important;display:flex;align-items:center;justify-content:space-between}
  .dash-order>div:last-child>div:last-child{margin-top:0 !important}
}

/* ===== back-office : liste clients & confort tactile mobile ===== */
@media(max-width:640px){
  /* la ligne client devient une carte empilée, plus de dézoom */
  .cli-row{grid-template-columns:1fr auto !important;gap:3px 10px !important;padding:13px 14px !important;align-items:start !important}
  .cli-name{grid-column:1 !important;grid-row:1 !important;font-size:15px !important}
  .cli-actions{grid-column:2 !important;grid-row:1 !important;flex-wrap:wrap;justify-content:flex-end !important}
  .cli-contact{grid-column:1 / -1 !important;grid-row:2 !important;word-break:break-word;font-size:12.5px !important}
  .cli-meta{grid-column:1 / -1 !important;grid-row:3 !important;font-size:12.5px !important;color:var(--gray-500) !important}
  /* cibles tactiles plus confortables dans la gestion */
  .wrap-wide .btn.sm{padding:10px 14px;font-size:13px}
  .order-card{padding:16px 15px}
  .order-card .oh{gap:8px}
  /* évite tout débordement horizontal sur les écrans serrés */
  .wrap-wide{padding-left:14px;padding-right:14px;overflow-x:hidden}
}

/* ===== Le Mag (blog) ===== */
.mag-head{padding:40px 0 24px;text-align:center}
.mag-title{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:-.02em;font-size:clamp(40px,6vw,72px);color:var(--ink-900);margin:10px 0 6px}
.mag-sub{font-family:var(--font-body);font-weight:600;color:var(--gray-600);font-size:16px;max-width:520px;margin:0 auto}
.mag-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:28px;border-bottom:1px solid var(--border-soft);padding-bottom:16px}
.mag-cats{display:flex;gap:8px;flex-wrap:wrap}
.mag-cat{display:inline-block;font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--green-800);background:var(--green-50);padding:5px 11px;border-radius:var(--r-pill);margin-bottom:10px}
.mag-feat{display:grid;grid-template-columns:1.15fr 1fr;gap:0;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:30px;background:#fff;transition:box-shadow .2s}
.mag-feat:hover{box-shadow:var(--shadow-md)}
.mf-cover{min-height:300px;background:var(--gray-100)}
.mf-cover img{width:100%;height:100%;object-fit:cover;display:block}
.mf-ph{width:100%;height:100%;min-height:200px;display:flex;align-items:center;justify-content:center;color:var(--gray-300)}
.mf-ph svg{width:46px;height:46px}
.mf-body{padding:34px;display:flex;flex-direction:column;justify-content:center}
.mf-body h2{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:28px;line-height:1.05;color:var(--ink-900);margin-bottom:12px}
.mf-body p{font-size:15px;line-height:1.6;color:var(--gray-600);margin-bottom:16px}
.mf-date{font-size:12px;color:var(--gray-500);font-weight:600}
.mag-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.mag-card{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}
.mag-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.mc-cover{aspect-ratio:16/10;background:var(--gray-100);overflow:hidden}
.mc-cover img{width:100%;height:100%;object-fit:cover;display:block}
.mc-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.mc-body h3{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:17px;line-height:1.1;color:var(--ink-900);margin-bottom:8px}
.mc-body p{font-size:13.5px;line-height:1.55;color:var(--gray-600);margin-bottom:12px;flex:1}
/* article */
.mag-article{padding:34px 0 70px}
.mag-back{display:inline-flex;align-items:center;gap:5px;border:0;background:transparent;font-family:var(--font-display);font-weight:800;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--green-800);cursor:pointer;margin-bottom:18px;padding:0}
.mag-art-title{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:-.02em;font-size:clamp(32px,5vw,56px);line-height:1.02;color:var(--ink-900);margin-bottom:14px}
.mag-meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--gray-500);font-weight:600}
.mag-meta .sep{color:var(--gray-300)}
.mag-cover{margin:26px 0 8px;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:21/9;background:var(--gray-100)}
.mag-cover img{width:100%;height:100%;object-fit:cover;display:block}
.mag-body{padding-top:18px}
.mag-lead{font-family:var(--font-body);font-size:19px;line-height:1.6;font-weight:600;color:var(--ink-800);margin:8px 0 22px}
.mag-h{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:26px;color:var(--ink-900);margin:34px 0 12px;line-height:1.1}
.mag-p{font-size:17px;line-height:1.72;color:var(--ink-800);margin:0 0 18px}
.mag-quote{border-left:3px solid var(--brand-green);padding:6px 0 6px 22px;margin:24px 0;font-family:var(--font-display);font-style:italic;font-weight:700;font-size:22px;line-height:1.3;color:var(--ink-900)}
.mag-fig{margin:26px 0}
.mag-fig img{width:100%;border-radius:var(--r-md);display:block}
.mag-fig.wide{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);width:100vw;max-width:1100px;margin-inline:auto}
.mag-fig figcaption{font-size:13px;color:var(--gray-500);margin-top:8px;text-align:center}
.mag-cta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;background:var(--ink-900);color:#fff;border-radius:var(--r-lg);padding:24px 28px;margin:28px 0}
.mag-cta-t{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:20px;margin-bottom:4px}
.mag-cta-s{font-size:14px;color:#cfd2c4}
.mag-prod{display:flex;gap:16px;align-items:center;border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin:24px 0;background:var(--gray-50)}
.mp-thumb{width:96px;height:96px;flex:none;background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-sm);overflow:hidden;display:flex;align-items:center;justify-content:center}
.mp-info{flex:1;min-width:0}
.mp-brand{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green-800)}
.mp-name{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:18px;color:var(--ink-900);display:block;margin:2px 0}
.mp-note{font-size:13.5px;color:var(--gray-600);margin-bottom:8px}
.mp-foot{display:flex;align-items:center;gap:14px}
.mag-brandcard{display:flex;align-items:center;gap:14px;border:1px solid var(--border);border-radius:var(--r-md);padding:16px 20px;margin:24px 0;background:#fff}
.mb-ic{width:46px;height:46px;border-radius:var(--r-pill);background:var(--ink-900);color:var(--brand-green);display:flex;align-items:center;justify-content:center;flex:none}
.mb-n{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:18px;color:var(--ink-900)}
.mb-c{font-size:13px;color:var(--green-800);font-weight:600}
.mag-tags{display:flex;flex-wrap:wrap;gap:7px;margin:30px 0 0;padding-top:20px;border-top:1px solid var(--border-soft)}
/* éditeur blocs */
.blk{border:1px solid var(--border-soft);border-radius:var(--r-md);padding:12px;margin-bottom:10px;background:var(--gray-50)}
.blk-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.blk-type{font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--green-800)}
.blk-add{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px}
.blk-add-btn{display:inline-flex;align-items:center;gap:6px;border:1.5px dashed var(--border);background:#fff;border-radius:var(--r-pill);padding:8px 13px;font-family:var(--font-body);font-weight:700;font-size:12.5px;color:var(--ink-800);cursor:pointer}
.blk-add-btn:hover{border-color:var(--green-700);color:var(--green-800);border-style:solid}
@media(max-width:860px){
  .mag-feat{grid-template-columns:1fr}
  .mag-grid{grid-template-columns:1fr 1fr;gap:14px}
}
@media(max-width:560px){
  .mag-grid{grid-template-columns:1fr}
  .mag-prod{flex-direction:column;align-items:flex-start}
}
@media(max-width:1080px){ .brand-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:680px){ .brand-grid{grid-template-columns:repeat(2,1fr)} .brand-hero-in{flex-direction:column;align-items:flex-start;gap:16px;padding-bottom:32px} .brand-hero-logo{width:100px;height:80px} }

/* ===== legal pages ===== */
.legal-h1{font-family:var(--font-display);text-transform:uppercase;font-weight:900;letter-spacing:var(--track-display);font-size:clamp(30px,4vw,46px);line-height:1.02;color:var(--ink-900);margin:10px 0 22px}
.legal-body{font-size:15px;line-height:1.7;color:var(--ink-800)}
.legal-body p{margin-bottom:14px}
.legal-h2{font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:.02em;font-size:18px;color:var(--ink-900);margin:28px 0 10px}
.legal-ul{margin:0 0 14px 0;padding-left:20px}
.legal-ul li{margin-bottom:7px}
.legal-callout{display:flex;gap:13px;align-items:flex-start;background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--r-md);padding:16px 18px;margin:6px 0 18px;font-size:14px;line-height:1.6}
.legal-callout svg{color:var(--green-700);flex:none;margin-top:2px}
.legal-callout.warn{background:var(--warning-bg);border-color:var(--warning)}
.legal-callout.warn svg{color:var(--warning)}

/* ===== cookies ===== */
.cookie-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:85;background:var(--ink-900);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:16px 20px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;max-width:1120px;margin:0 auto}
.cookie-txt{flex:1;min-width:260px;font-size:13px;line-height:1.55;color:#d8dcc8}
.cookie-txt .tlink{color:var(--brand-green)}
.cookie-acts{display:flex;gap:8px;flex-wrap:wrap}
.cookie-bar .btn.outline{color:#fff;border-color:rgba(255,255,255,.4)}
.cookie-bar .btn.outline:hover{background:#fff;color:var(--ink-900);border-color:#fff}
.cookie-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(480px,94vw);background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:28px;z-index:96}
.cookie-modal h3{font-family:var(--font-display);text-transform:uppercase;font-weight:800;font-size:18px;color:var(--ink-900);margin-bottom:8px}
.cookie-modal p{font-size:13.5px;color:var(--gray-600);line-height:1.6;margin-bottom:16px}
.cookie-opt{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border:1px solid var(--border-soft);border-radius:var(--r-sm);margin-bottom:10px;cursor:pointer}
.cookie-opt .co-t{font-weight:700;font-size:14px;color:var(--ink-900)}
.cookie-opt .co-d{font-size:12px;color:var(--gray-500);margin-top:3px;line-height:1.45}
.cookie-fixed{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green-700);flex:none}
.switch{width:42px;height:24px;border-radius:var(--r-pill);background:var(--gray-300);position:relative;flex:none;transition:background .18s}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .18s}
.switch.on{background:var(--brand-green)}
.switch.on::after{left:21px}

/* prominent checkout validation alert */
.form-alert{display:flex;gap:11px;align-items:flex-start;background:var(--danger-bg);border:1.5px solid var(--danger);border-radius:var(--r-md);padding:14px 16px;margin:6px 0 14px;font-size:14px;font-weight:600;line-height:1.45;color:#a32525}
.form-alert svg{color:var(--danger);flex:none;margin-top:1px}

/* ===== product gallery ===== */
.pdp-gallery{display:flex;flex-direction:column;gap:12px}
.pdp-thumbs{display:flex;gap:10px;flex-wrap:wrap}
.pdp-thumb{width:72px;height:72px;background:#fff;border:1.5px solid var(--border-soft);border-radius:var(--r-sm);overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s}
.pdp-thumb:hover{border-color:var(--gray-400)}
.pdp-thumb.on{border-color:var(--brand-green);box-shadow:inset 0 0 0 1.5px var(--brand-green)}
.pdp-thumb img{width:100%;height:100%;object-fit:contain;padding:6px;mix-blend-mode:multiply}

/* ===== editor overlay ===== */
.editor{position:fixed;top:0;right:0;bottom:0;width:min(760px,98vw);background:#fff;z-index:95;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);transform:translateX(100%);animation:slidein .32s var(--ease) forwards}
.editor-head{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 26px;border-bottom:1px solid var(--border-soft);background:#fff}
.editor-body{flex:1;overflow-y:auto;padding:8px 26px 26px}
.editor-foot{display:flex;justify-content:flex-end;gap:12px;padding:18px 26px;border-top:1px solid var(--border-soft);background:#fff}
.ed-sec{border-bottom:1px solid var(--border-soft);padding:22px 0}
.ed-sec:last-child{border-bottom:0}
.ed-sec h4{font-family:var(--font-display);font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-900);margin-bottom:14px}
.mini-btn{width:30px;height:30px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:#fff;color:var(--ink-900);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex:none}
.mini-btn:hover{border-color:var(--ink-900)}
.mini-btn.danger:hover{border-color:var(--danger);color:var(--danger)}

/* fix: social icons perfectly centered */
.socials svg,.icon-btn svg,.btn svg,.ti svg,.trustline svg{display:block}

/* reassurance grid */
.reassure{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.reassure .ri{background:#fff;border:1px solid var(--border-soft);border-radius:var(--r-md);padding:26px 22px;box-shadow:var(--shadow-xs)}
.reassure .ri .ic{width:42px;height:42px;border-radius:var(--r-pill);background:var(--green-50);display:flex;align-items:center;justify-content:center;color:var(--green-700);margin-bottom:14px}
.reassure .ri .t{font-family:var(--font-display);text-transform:uppercase;font-weight:800;letter-spacing:-.01em;font-size:15px;margin-bottom:7px;color:var(--ink-900)}
.reassure .ri .d{font-size:13px;color:var(--gray-600);line-height:1.55}

/* responsive */
@media(max-width:1080px){
  .pgrid{grid-template-columns:repeat(3,1fr)}
  .cat-tiles{grid-template-columns:repeat(2,1fr)}
  .reassure{grid-template-columns:repeat(2,1fr)}
  .hero .grid{grid-template-columns:1fr;gap:32px}
  .hero-visual{max-width:460px}
  .pdp{grid-template-columns:1fr;gap:28px}
  .pdp-media{position:static}
  .checkout{grid-template-columns:1fr}
  .summary{position:static}
  .finder-band .fb-in{grid-template-columns:1fr}
}
@media(max-width:1024px){
  .nav-cats{display:none}
  .nav-burger{display:flex}
}
@media(max-width:860px){
  .nav-cats{display:none}
  .catalog{grid-template-columns:1fr}
  .catalog > div:first-child{display:none}
  .subchips{flex-wrap:nowrap;overflow-x:auto;padding:2px 2px 14px;margin:0 -2px 6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .subchips::-webkit-scrollbar{display:none}
  .subchips .sc-lbl{display:none}
  .filters{position:static}
  .acct{grid-template-columns:1fr}
  .acct-nav{position:static;display:flex;overflow-x:auto}
  .acct-nav button{border-bottom:0;border-right:1px solid var(--border-soft);white-space:nowrap}
}
@media(max-width:680px){
  .wrap,.wrap-wide{padding:0 16px}
  .pdp-info{display:flex;flex-direction:column}
  .pdp-descwrap{order:5}
  .pdp-info .pdp-block:last-of-type{order:6}
  .pgrid,.pgrid.g3{grid-template-columns:repeat(2,1fr);gap:12px}
  .choice-grid{grid-template-columns:1fr 1fr}
  .row2{grid-template-columns:1fr}
  .vialrow{grid-template-columns:1fr}
  .reassure{grid-template-columns:1fr}
  footer.site .ft{grid-template-columns:1fr 1fr}
  footer.site .hours{flex-direction:column;align-items:flex-start;gap:1px;padding:7px 0}
  footer.site .hours b{font-size:13px}
  .searchbar{display:none}
  .brand img{height:46px}
  .hero{padding:40px 0 40px}
  .hero h1{font-size:clamp(28px,8.5vw,46px) !important;line-height:1.02}
  .hero .lead{font-size:16px}
  .hero-visual{width:100%;max-width:380px;margin:0 auto}
  .announce{font-size:11.5px;padding:8px 14px}
}
@media(max-width:380px){
  .hero h1{font-size:31px !important}
  .pgrid,.pgrid.g3{grid-template-columns:repeat(2,1fr);gap:10px}
  .pcard .pname{font-size:14px}
  .pcard .pbody{padding:12px 12px 13px}
}
