/* H'isy Friperie — storefront UI kit layout styles (composes the DS tokens) */

.store { min-height: 100%; background: var(--cream-light); }

/* ─────────────── Footer vitrine ─────────────── */
.site-footer { background: var(--brown); color: rgba(245,236,215,.72); margin-top: 60px; }
.sf-inner { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--container-px); }
.sf-top .sf-inner { padding-top: 54px; padding-bottom: 38px; display: grid; grid-template-columns: 1.7fr 1fr 1fr 1.5fr; gap: 40px; }
.sf-brand img { height: 40px; width: auto; margin-bottom: 16px; display: block; }
.sf-logo-img { height: 46px !important; filter: brightness(0) invert(1); opacity: .95; }
.sf-brand p { font-size: .88rem; line-height: 1.65; color: rgba(245,236,215,.65); max-width: 320px; }
.sf-social { display: flex; gap: 10px; margin-top: 18px; }
.sf-social a { width: 38px; height: 38px; border-radius: 50%; background: rgba(245,236,215,.1); color: var(--caramel-light); display: grid; place-items: center; text-decoration: none; transition: background .15s, color .15s; }
.sf-social a:hover { background: var(--caramel); color: #fff; }
.sf-col h4, .sf-news h4 { color: #fff; font-family: var(--f-display, var(--font-display)); font-size: 1rem; font-weight: 700; margin-bottom: 16px; }
.sf-col { display: flex; flex-direction: column; gap: 11px; }
.sf-col a { font-size: .88rem; color: rgba(245,236,215,.68); text-decoration: none; transition: color .15s; width: fit-content; }
.sf-col a:hover { color: #fff; }
.sf-news p { font-size: .85rem; line-height: 1.6; color: rgba(245,236,215,.65); margin-bottom: 16px; }
.sf-news-form { display: flex; gap: 8px; }
.sf-news-form input { flex: 1; min-width: 0; height: 46px; border: 1px solid rgba(245,236,215,.25); background: rgba(245,236,215,.08); border-radius: 999px; padding: 0 18px; color: #fff; font-family: inherit; font-size: .88rem; }
.sf-news-form input::placeholder { color: rgba(245,236,215,.5); }
.sf-news-form input:focus { outline: none; border-color: var(--caramel); background: rgba(245,236,215,.12); }
.sf-news-form button { width: 46px; height: 46px; flex-shrink: 0; border-radius: 50%; border: none; background: var(--caramel); color: #fff; cursor: pointer; font-size: .95rem; transition: background .15s; }
.sf-news-form button:hover { background: var(--caramel-light); }
.sf-news-wa { display: inline-flex; align-items: center; gap: 8px; margin-top: 14px; font-size: .84rem; font-weight: 600; color: var(--caramel-light); text-decoration: none; }
.sf-news-wa:hover { color: #fff; }
.sf-news-ok { display: flex; align-items: center; gap: 9px; font-size: .9rem; font-weight: 600; color: #6ee79e; padding: 12px 0; }
.sf-pay { border-top: 1px solid rgba(245,236,215,.13); }
.sf-pay-inner { padding-top: 18px; padding-bottom: 18px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.sf-pay-lbl { font-size: .8rem; font-weight: 600; color: rgba(245,236,215,.6); display: inline-flex; align-items: center; gap: 8px; }
.sf-pay-lbl i { color: var(--caramel-light); }
.sf-pay-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-left: auto; align-items: center; }
.sf-pay-logo { display: inline-flex; align-items: center; justify-content: center; height: 34px; padding: 0 10px; background: #fff; border-radius: 8px; box-shadow: 0 2px 6px rgba(0,0,0,.18); }
.sf-pay-logo img { height: 20px; width: auto; display: block; object-fit: contain; }
.sf-pay-ic { display: inline-flex; align-items: center; gap: 7px; height: 34px; padding: 0 12px; font-size: .74rem; font-weight: 600; color: rgba(245,236,215,.82); background: rgba(245,236,215,.08); border: 1px solid rgba(245,236,215,.16); border-radius: 8px; }
.sf-pay-ic i { color: var(--caramel-light); }
.sf-bar { border-top: 1px solid rgba(245,236,215,.13); }
.sf-bar-inner { padding-top: 18px; padding-bottom: 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: .78rem; color: rgba(245,236,215,.55); }
.sf-legal { display: flex; gap: 20px; }
.sf-legal a { color: rgba(245,236,215,.6); text-decoration: none; }
.sf-legal a:hover { color: #fff; }
@media (max-width: 860px) {
  .sf-top .sf-inner { grid-template-columns: 1fr 1fr; gap: 30px; }
  .sf-brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
  .sf-top .sf-inner { grid-template-columns: 1fr; }
  .sf-bar-inner { flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* ── Header ── */
.hd { position: sticky; top: 0; z-index: 50; background: var(--cream-light); border-bottom: 1px solid var(--border); }
.hd-promo { background: var(--brown); color: rgba(245,236,215,.82); font-size: 0.72rem; text-align: center; padding: 7px 16px; letter-spacing: .02em; }
.hd-in { display: flex; align-items: center; gap: 16px; height: 74px; }
.hd-logo { display: flex; align-items: center; gap: 10px; flex-shrink: 0; cursor: pointer; }
.hd-logo img { height: 42px; width: auto; }
.hd-nav { display: flex; align-items: center; gap: 2px; flex: 1; justify-content: center; }
.hd-nav a { padding: 8px 15px; border-radius: var(--r-pill); font-size: 0.86rem; font-weight: 500; color: var(--muted); cursor: pointer; transition: all .2s; }
.hd-nav a:hover, .hd-nav a.active { background: var(--cream); color: var(--brown); }
.hd-act { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.ico-btn { width: 40px; height: 40px; border-radius: 50%; border: none; background: var(--cream); cursor: pointer; display: grid; place-items: center; color: var(--brown); transition: background .2s; position: relative; font-size: 0.95rem; }
.ico-btn:hover { background: var(--cream-dark); }
.ico-btn .dot { position: absolute; top: -3px; right: -3px; min-width: 18px; height: 18px; padding: 0 4px; background: var(--caramel); border-radius: var(--r-pill); border: 2px solid var(--cream-light); font-size: 0.6rem; font-weight: 700; color: #fff; display: grid; place-items: center; }
.hd-burger { display: none; width: 40px; height: 40px; border: none; background: var(--cream); border-radius: 50%; color: var(--brown); font-size: 1rem; cursor: pointer; }
.hd-menu, .hd-m-backdrop { display: none; }

/* ── Header search popover ── */
.hd-search-wrap { position: relative; display: flex; }
.hd-search-backdrop { position: fixed; inset: 0; z-index: 90; }
.hd-search-pop { position: absolute; top: calc(100% + 12px); right: 0; z-index: 91; width: min(340px, 86vw); background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-lg); padding: 16px; animation: hdSearchIn .18s var(--ease); }
@keyframes hdSearchIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.hd-search-pop::before { content: ''; position: absolute; top: -7px; right: 14px; width: 12px; height: 12px; background: #fff; border-left: 1px solid var(--border); border-top: 1px solid var(--border); transform: rotate(45deg); }
.hd-search-field { position: relative; display: flex; align-items: center; margin-bottom: 10px; }
.hd-search-field > i { position: absolute; left: 13px; color: var(--light); font-size: 0.85rem; pointer-events: none; }
.hd-search-field input { width: 100%; padding: 11px 36px 11px 35px; border: 1.5px solid var(--cream-dark); border-radius: var(--r-pill); font-size: 0.88rem; color: var(--brown); outline: none; background: var(--cream-light); }
.hd-search-field input::placeholder { color: var(--light); }
.hd-search-field input:focus { border-color: var(--caramel); box-shadow: var(--ring); background: #fff; }
.hd-search-x { position: absolute; right: 8px; width: 24px; height: 24px; border-radius: 50%; border: none; background: var(--cream); color: var(--muted); cursor: pointer; display: grid; place-items: center; font-size: 0.7rem; }
.hd-search-x:hover { background: var(--caramel); color: #fff; }
.hd-search-sugg { margin-top: 14px; }
.hd-search-sugg-lbl { font-size: 0.66rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); font-weight: 700; }
.hd-search-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 9px; }
.hd-search-tag { padding: 6px 13px; border-radius: var(--r-pill); border: 1px solid var(--border); background: #fff; color: var(--muted); font-size: 0.78rem; cursor: pointer; transition: all .2s var(--ease); font-family: inherit; }
.hd-search-tag:hover { border-color: var(--caramel); color: var(--caramel-dark); background: var(--accent-soft); }
@media (max-width: 900px) {
  .hd-nav { display: none; }
  .hd-burger { display: grid; place-items: center; }
  .hd-in { gap: 10px; }
  .hd-logo { flex: 1; justify-content: center; }
  .hd-search { display: none; }
  /* mobile menu drawer */
  .hd-m-backdrop { display: block; position: fixed; inset: 0; background: rgba(45,21,5,.45); z-index: 80; opacity: 0; pointer-events: none; transition: opacity .3s; }
  .hd-m-backdrop.show { opacity: 1; pointer-events: auto; }
  .hd-menu { display: flex; flex-direction: column; gap: 18px; position: fixed; top: 0; left: 0; bottom: 0; width: min(320px, 86vw); background: var(--cream-light); z-index: 81; padding: 18px 22px 24px; transform: translateX(-100%); transition: transform .32s var(--ease); box-shadow: var(--sh-lg); }
  .hd-menu.open { transform: none; }
  .hd-menu-top { display: flex; align-items: center; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid var(--border); }
  .hd-menu-top img { height: 38px; }
  .hd-menu-nav { display: flex; flex-direction: column; flex: 1; }
  .hd-menu-nav a { display: flex; align-items: center; justify-content: space-between; padding: 15px 4px; border-bottom: 1px solid var(--border); font-size: 1rem; font-weight: 500; color: var(--brown); cursor: pointer; }
  .hd-menu-nav a i { color: var(--light); font-size: 0.8rem; }
  .hd-menu-nav a.active { color: var(--caramel-dark); }
}

/* ── Hero (two columns: text panel + video) ── */
.hero { position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; min-height: 580px; }
.hero-text { background: var(--brown); color: var(--cream); padding: clamp(40px, 6vw, 88px); display: flex; flex-direction: column; justify-content: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 7px; align-self: flex-start; background: rgba(200,149,106,.18); color: var(--caramel-light); border: 1px solid rgba(200,149,106,.3); padding: 7px 15px; border-radius: var(--r-pill); font-size: 0.72rem; font-weight: 600; letter-spacing: .03em; margin-bottom: 24px; }
.hero-text h1 { color: var(--cream); font-size: clamp(2.5rem, 4.6vw, 4.2rem); margin-bottom: 20px; line-height: 1.05; }
.hero-text h1 em { font-style: italic; color: var(--caramel-light); font-variation-settings: 'opsz' 144, 'SOFT' 60, 'WONK' 1; }
.hero-sub { color: rgba(245,236,215,.78); font-size: 1.04rem; max-width: 470px; margin-bottom: 34px; }
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 34px; margin-top: 46px; }
.hero-stat .n { font-family: var(--font-display); font-size: 2rem; font-weight: 800; color: var(--caramel-light); line-height: 1; font-variation-settings: var(--fraunces-text); }
.hero-stat .n i { font-size: 0.7em; margin-left: 2px; }
.hero-stat .l { font-size: 0.72rem; color: rgba(245,236,215,.6); text-transform: uppercase; letter-spacing: .08em; margin-top: 6px; }
.hero-img { position: relative; background: var(--cream-dark); overflow: hidden; }
.hero-img video, .hero-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-tag { position: absolute; bottom: 22px; left: 22px; background: rgba(253,248,242,.92); backdrop-filter: blur(6px); border-radius: var(--r); padding: 11px 16px; display: flex; align-items: center; gap: 10px; box-shadow: var(--sh); }
.hero-tag i { color: var(--caramel-dark); }
.hero-tag strong { font-size: 0.82rem; color: var(--brown); display: block; }
.hero-tag span { font-size: 0.72rem; color: var(--muted); }
@media (max-width: 820px) { .hero-grid { grid-template-columns: 1fr; } .hero-img { min-height: 340px; } }

/* ── Trust strip ── */
.trust { background: var(--cream); border-bottom: 1px solid var(--border); }
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; padding: 26px 0; }
.trust-it { display: flex; align-items: center; gap: 12px; }
.trust-it .ic { width: 42px; height: 42px; border-radius: 50%; background: var(--accent-soft); display: grid; place-items: center; color: var(--caramel-dark); font-size: 1.05rem; flex-shrink: 0; }
.trust-it strong { display: block; font-size: 0.86rem; color: var(--brown); font-weight: 600; }
.trust-it span { font-size: 0.76rem; color: var(--muted); }
@media (max-width: 820px) { .trust-grid { grid-template-columns: repeat(2, 1fr); } }

/* ── Generic section ── */
.sec { padding: var(--section-py) 0; }
.sec--cream { background: var(--cream); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.sec-head-l { margin-bottom: 30px; }
.sec-head-l h2 { margin-bottom: 6px; }
.sec-head-l p { font-size: 0.92rem; max-width: 560px; }
.sec-top { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 30px; flex-wrap: wrap; }
.sec-link { display: inline-flex; align-items: center; gap: 7px; font-size: 0.84rem; font-weight: 600; color: var(--caramel-dark); cursor: pointer; transition: gap .2s; }
.sec-link:hover { gap: 11px; }

/* ── Vente flash / Bons plans ── */
.flash-sec .eyebrow { color: var(--red); display: inline-flex; align-items: center; gap: 6px; }
.flash-count { display: flex; flex-direction: row; align-items: center; flex-wrap: wrap; gap: 12px; }
.flash-count-lbl { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); display: inline-flex; align-items: center; gap: 6px; }
.flash-count-lbl i { color: var(--red); }
.flash-count-boxes { display: flex; align-items: center; gap: 6px; }
.flash-box { background: var(--brown); color: var(--cream); font-family: var(--font-display); font-variation-settings: var(--fraunces-text); font-size: 1.2rem; font-weight: 700; padding: 5px 12px; border-radius: var(--r-sm); min-width: 46px; text-align: center; font-variant-numeric: tabular-nums; }
.flash-sep { color: var(--brown); font-weight: 700; }
@media (max-width: 600px) { .flash-count { align-items: flex-start; } .flash-top-right { align-items: flex-start; } }
.flash-top-right { display: flex; flex-direction: row; align-items: center; flex-wrap: wrap; gap: 18px; }

/* ── Rayons (tuiles photo éditoriales) ── */
.rayons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.rayon { position: relative; border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 3/4; border: 1px solid var(--border); cursor: pointer; padding: 0; background: none; font-family: inherit; box-shadow: var(--sh-sm); transition: box-shadow .25s var(--ease), transform .25s var(--ease); }
.rayon:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); }
.rayon > img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.rayon:hover > img { transform: scale(1.05); }
.rayon-label { position: absolute; left: 0; right: 0; bottom: 0; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 26px 18px 16px; background: linear-gradient(to top, rgba(45,21,5,.86), rgba(45,21,5,0)); }
.rayon-nm { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; color: #fff; font-variation-settings: var(--fraunces-display); line-height: 1.05; }
.rayon-label i { color: #fff; background: rgba(255,255,255,.18); width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-size: 0.8rem; flex-shrink: 0; transition: background .25s var(--ease), transform .25s var(--ease); }
.rayon:hover .rayon-label i { background: var(--caramel); transform: translateX(3px); }
@media (max-width: 680px) { .rayons { grid-template-columns: 1fr; } .rayon { aspect-ratio: 16/10; } }

/* ════════ BRAND MARQUEE (editorial ticker) ════════ */
.marquee { background: var(--brown); overflow: hidden; padding: 15px 0; }
.marquee-track { display: flex; width: max-content; animation: hisyMarquee 34s linear infinite; }
.marquee-item { display: inline-flex; align-items: center; gap: 22px; padding: 0 26px; white-space: nowrap; }
.marquee-item span { font-family: var(--font-display); font-style: italic; font-size: 1.3rem; font-weight: 500; color: var(--cream); font-variation-settings: var(--fraunces-text); }
.marquee-item i { color: var(--caramel-light); font-size: 0.6rem; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes hisyMarquee { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; } }

/* ════════ MANIFESTO (brand statement) ════════ */
.manifesto { background: var(--cream-light); text-align: center; position: relative; overflow: hidden; }
.manifesto::before { content: '\201C'; position: absolute; top: -0.18em; left: 50%; transform: translateX(-50%); font-family: var(--font-display); font-size: 16rem; line-height: 1; color: var(--caramel); opacity: 0.1; pointer-events: none; }
.manifesto .wrap { max-width: 900px; position: relative; }
.manifesto .eyebrow { text-align: center; }
.manifesto blockquote { font-family: var(--font-display); font-weight: 400; font-size: clamp(1.7rem, 3.6vw, 2.9rem); line-height: 1.28; color: var(--brown); font-variation-settings: var(--fraunces-display); margin: 6px 0 0; }
.manifesto blockquote em { font-family: var(--font-script); font-style: normal; font-weight: 400; color: var(--caramel-dark); }
.manifesto .sig { margin-top: 26px; display: inline-flex; align-items: center; gap: 12px; font-size: 0.84rem; color: var(--muted); }
.manifesto .sig::before { content: ''; width: 30px; height: 1px; background: var(--caramel); }
.impact { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 780px; margin: 46px auto 0; }
.impact-it { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 24px 18px; }
.impact-n { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.4rem); font-weight: 800; color: var(--caramel-dark); line-height: 1; font-variation-settings: var(--fraunces-display); }
.impact-l { font-size: 0.8rem; color: var(--muted); margin-top: 8px; line-height: 1.4; }
.manifesto-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 36px; }
@media (max-width: 620px) {
  .impact { grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 32px; }
  .impact-it { padding: 16px 14px; border-radius: var(--r); text-align: center; position: relative; overflow: hidden; }
  .impact-it::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--caramel); }
  .impact-n { font-size: 1.6rem; }
  .impact-l { font-size: 0.72rem; margin-top: 6px; line-height: 1.35; }
  .impact-it:last-child:nth-child(odd) { grid-column: 1 / -1; }
}


/* ════════ PRODUCT CARD (pro) ════════ */
.pc { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; transition: box-shadow .3s var(--ease), transform .3s var(--ease), border-color .3s; display: flex; flex-direction: column; }
.pc:hover { transform: translateY(-6px); box-shadow: 0 20px 38px -14px rgba(45,21,5,.34); border-color: var(--caramel); }
.pc.is-incart { border-color: var(--caramel); }
.pc-media { position: relative; aspect-ratio: 3/4; overflow: hidden; cursor: pointer; background: linear-gradient(145deg, var(--cream-dark), var(--caramel-light)); }
.pc-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity .45s var(--ease), transform .6s var(--ease); }
.pc-img.hover { opacity: 0; }
.pc:hover .pc-img.base { opacity: 0; }
.pc:hover .pc-img.hover { opacity: 1; transform: scale(1.04); }
.pc-bads { position: absolute; top: 10px; left: 10px; display: flex; flex-direction: column; gap: 6px; align-items: flex-start; z-index: 2; }
.pc-unique { display: inline-flex; align-items: center; gap: 4px; padding: 4px 9px; border-radius: var(--r-pill); font-size: 0.6rem; font-weight: 700; letter-spacing: .02em; background: rgba(45,21,5,.82); color: var(--cream); backdrop-filter: blur(4px); }
.pc-unique i { font-size: 0.62em; }
.pc-timer { display: inline-flex; align-items: center; gap: 5px; padding: 4px 9px; border-radius: var(--r-pill); font-size: 0.62rem; font-weight: 700; letter-spacing: .01em; font-variant-numeric: tabular-nums; background: rgba(45,21,5,.78); color: var(--cream); backdrop-filter: blur(4px); }
.pc-timer i { font-size: 0.9em; opacity: .85; }
.pc-timer.urgent { background: var(--red, #B71C1C); color: #fff; }
.pc-fav { position: absolute; top: 10px; right: 10px; z-index: 2; width: 34px; height: 34px; border-radius: 50%; border: none; background: rgba(255,255,255,.92); backdrop-filter: blur(4px); color: var(--brown); cursor: pointer; display: grid; place-items: center; box-shadow: var(--sh-sm); transition: all .2s; font-size: 0.85rem; }
.pc-fav:hover { background: #fff; transform: scale(1.08); }
.pc-fav.on { background: var(--caramel); color: #fff; }
.pc-quick { position: absolute; left: 10px; right: 10px; bottom: 10px; z-index: 2; transform: translateY(140%); opacity: 0; transition: transform .3s var(--ease), opacity .3s; }
.pc:hover .pc-quick { transform: none; opacity: 1; }
.pc-quick-btn { width: 100%; border: none; cursor: pointer; padding: 10px; border-radius: var(--r); background: rgba(253,248,242,.95); backdrop-filter: blur(6px); color: var(--brown); font-size: 0.78rem; font-weight: 600; display: flex; align-items: center; justify-content: center; gap: 7px; box-shadow: var(--sh); transition: background .2s; }
.pc-quick-btn:hover { background: #fff; }
.pc-quick-btn i { color: var(--caramel-dark); }
.pc-sizes { display: flex; align-items: center; gap: 6px; background: rgba(253,248,242,.96); backdrop-filter: blur(6px); padding: 7px; border-radius: var(--r); box-shadow: var(--sh); }
.pc-sizes-lbl { font-size: 0.66rem; color: var(--muted); padding-left: 4px; }
.pc-size { width: 30px; height: 30px; border-radius: var(--r-sm); border: 1.5px solid var(--brown); background: var(--brown); color: #fff; font-size: 0.72rem; font-weight: 600; cursor: pointer; }
.pc-size-add { flex: 1; border: none; background: var(--caramel); color: #fff; border-radius: var(--r-sm); font-size: 0.72rem; font-weight: 600; padding: 0 8px; height: 30px; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 5px; }
.pc-size-add:hover { background: var(--caramel-dark); }
.pc-body { padding: 13px 15px 15px; display: flex; flex-direction: column; gap: 2px; }
.pc-brand { font-size: 0.64rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--caramel-dark); }
.pc-name { font-size: 0.92rem; font-weight: 600; color: var(--brown); cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pc-meta { font-size: 0.72rem; color: var(--muted); display: flex; align-items: center; gap: 6px; margin-bottom: 8px; }
.pc-dot { width: 10px; height: 10px; border-radius: 50%; border: 1px solid rgba(45,21,5,.15); flex-shrink: 0; }
.pc-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; margin-top: auto; }
.pc-price { display: flex; align-items: baseline; gap: 7px; }
.pc-cart { width: 38px; height: 38px; border-radius: 50%; border: none; cursor: pointer; display: grid; place-items: center; font-size: 0.85rem; background: var(--accent-soft); color: var(--caramel-dark); transition: all .2s; flex-shrink: 0; }
.pc-cart:hover { background: var(--caramel); color: #fff; }
.pc-cart.in { background: var(--caramel); color: #fff; }

/* ── Product grid (auto-fill: card count adapts to width) ── */
.pgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 18px; }
@media (max-width: 760px) { .pgrid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; } }

/* ════════ SLIDER ════════ */
.sl { position: relative; }
.sl-track { display: grid; grid-auto-flow: column; grid-auto-columns: clamp(220px, 22.5vw, 300px); gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 14px 0 34px; scrollbar-width: none; cursor: grab; }
.sl-track::-webkit-scrollbar { display: none; }
.sl-track:active { cursor: grabbing; }
.sl-track > * { scroll-snap-align: start; }
.sl--full .sl-track { padding-left: var(--container-px); padding-right: var(--container-px); scroll-padding-inline: var(--container-px); }
.sl-ctrl { display: flex; align-items: center; gap: 10px; margin-top: 6px; }
.sl-ctrl-nav { display: flex; gap: 10px; margin-left: auto; }
.sl--full .sl-ctrl { padding-left: max(var(--container-px), calc((100% - var(--max-w)) / 2 + var(--container-px))); padding-right: max(var(--container-px), calc((100% - var(--max-w)) / 2 + var(--container-px))); }
.sl-nav { width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--border); background: #fff; color: var(--brown); cursor: pointer; display: grid; place-items: center; box-shadow: var(--sh-sm); transition: all .2s; }
.sl-nav:hover:not(:disabled) { background: var(--brown); color: var(--cream); border-color: var(--brown); }
.sl-nav:disabled { opacity: .35; cursor: default; }

/* ════════ HOW IT WORKS ════════ */
.hiw-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.hiw-step { position: relative; background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 30px 26px; text-align: center; }
.hiw-num { position: absolute; top: 18px; right: 20px; font-family: var(--font-display); font-size: 1.6rem; font-weight: 800; color: var(--cream-dark); font-variation-settings: var(--fraunces-text); }
.hiw-ic { width: 60px; height: 60px; border-radius: 50%; background: var(--accent-soft); color: var(--caramel-dark); display: grid; place-items: center; font-size: 1.4rem; margin: 0 auto 16px; }
.hiw-step h4 { font-size: 1.05rem; margin-bottom: 8px; }
.hiw-step p { font-size: 0.85rem; line-height: 1.6; }
@media (max-width: 820px) { .hiw-grid { grid-template-columns: 1fr; } }

/* ════════ FEATURED — onglets Pépites / Bons plans ════════ */
.featured-wrap { padding: 0 var(--container-px); }
.featured-top { align-items: center; }
.featured-aside { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.seg { display: inline-flex; align-items: center; gap: 4px; background: var(--cream-dark); border-radius: var(--r-pill); padding: 5px; }
.seg-btn { display: inline-flex; align-items: center; gap: 9px; padding: 11px 22px; border: none; background: transparent; border-radius: var(--r-pill); font-family: inherit; font-size: 1rem; font-weight: 600; color: var(--muted); cursor: pointer; white-space: nowrap; transition: background .25s var(--ease), color .25s var(--ease); }
.seg-btn i { font-size: 0.82em; }
.seg-btn.active { background: var(--brown); color: var(--cream); box-shadow: var(--sh-sm); }
.seg-btn.active i { color: var(--caramel-light); }
.seg-btn:not(.active):hover { color: var(--brown); }
@media (max-width: 600px) { .seg { width: 100%; } .seg-btn { flex: 1; justify-content: center; padding: 11px 10px; font-size: 0.9rem; } }

/* ════════ COLLECTIONS — mosaïque éditoriale par rayon ════════ */.coll-mosaic { display: grid; grid-template-columns: 1.5fr 1fr; grid-auto-rows: 1fr; gap: 16px; height: clamp(420px, 50vw, 560px); }
.coll-tile { position: relative; overflow: hidden; border-radius: var(--r-lg); border: none; padding: 0; cursor: pointer; font-family: inherit; box-shadow: var(--sh-sm); transition: box-shadow .3s var(--ease), transform .3s var(--ease); }
.coll-tile:hover { box-shadow: var(--sh-lg); transform: translateY(-3px); }
.coll-tile.feature { grid-row: 1 / span 2; }
.coll-tile > img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.coll-tile:hover > img { transform: scale(1.06); }
.coll-scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(45,21,5,.8) 0%, rgba(45,21,5,.18) 46%, transparent 72%); }
.coll-body { position: absolute; left: 0; right: 0; bottom: 0; padding: 22px; display: flex; flex-direction: column; align-items: flex-start; gap: 11px; }
.coll-nm { font-family: var(--font-display); font-variation-settings: var(--fraunces-display); font-size: 1.5rem; font-weight: 700; color: #fff; line-height: 1; }
.coll-tile.feature .coll-nm { font-size: clamp(1.8rem, 3vw, 2.4rem); }
.coll-go { display: inline-flex; align-items: center; gap: 8px; font-size: 0.8rem; font-weight: 600; color: var(--cream); padding: 7px 15px; border-radius: var(--r-pill); background: rgba(255,255,255,.16); backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,.28); transition: background .25s var(--ease), border-color .25s var(--ease); }
.coll-go i { font-size: .82em; transition: transform .25s var(--ease); }
.coll-tile:hover .coll-go { background: var(--caramel); border-color: var(--caramel); }
.coll-tile:hover .coll-go i { transform: translateX(3px); }
@media (max-width: 760px) {
  .coll-mosaic { grid-template-columns: 1fr 1fr; height: auto; grid-auto-rows: auto; }
  .coll-tile { aspect-ratio: 1/1; }
  .coll-tile.feature { grid-column: 1 / -1; grid-row: auto; aspect-ratio: 16/10; }
}
@media (max-width: 440px) { .coll-mosaic { grid-template-columns: 1fr; } }

/* ════════ LOOKBOOK ════════ */
.look { display: grid; grid-template-columns: 1fr 1.15fr 1fr; gap: 20px; align-items: center; }
.look-img { position: relative; border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 3/4; }
.look-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.look-img:hover img { transform: scale(1.05); }
.look-pill { position: absolute; top: 14px; left: 14px; background: rgba(253,248,242,.92); backdrop-filter: blur(5px); color: var(--brown); font-size: 0.68rem; font-weight: 600; padding: 5px 11px; border-radius: var(--r-pill); }
.look-text { padding: 0 6px; }
.look-text h2 { margin-bottom: 14px; }
.look-text > p { font-size: 0.92rem; margin-bottom: 18px; }
.look-list { list-style: none; display: flex; flex-direction: column; gap: 9px; margin-bottom: 24px; }
.look-list li { font-size: 0.88rem; color: var(--brown); display: flex; align-items: center; gap: 10px; }
.look-list i { color: var(--green); font-size: 0.7rem; width: 22px; height: 22px; background: var(--green-bg); border-radius: 50%; display: grid; place-items: center; flex-shrink: 0; }
@media (max-width: 980px) { .look { grid-template-columns: 1fr 1fr; } .look-text { grid-column: 1 / -1; order: -1; padding: 0; } }
@media (max-width: 600px) { .look { grid-template-columns: 1fr; } .look-img.b { display: none; } }

/* ════════ NEWSLETTER / COMMUNITY (caramel band) ════════ */
.news { background: var(--caramel); border-radius: var(--r-lg); padding: clamp(30px, 5vw, 56px); display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: center; position: relative; overflow: hidden; box-shadow: var(--sh); }
.news::after { content: '\f2b6'; font-family: 'Font Awesome 6 Free'; font-weight: 900; position: absolute; right: -10px; bottom: -34px; font-size: 12rem; color: rgba(45,21,5,.08); }
.news-text h2 { color: var(--brown); margin-bottom: 12px; }
.news-text p { color: rgba(45,21,5,.74); font-size: 0.92rem; }
.news-incentive { display: inline-flex; align-items: center; gap: 7px; background: rgba(45,21,5,.12); color: var(--brown); border: 1px solid rgba(45,21,5,.2); padding: 6px 13px; border-radius: var(--r-pill); font-size: 0.74rem; font-weight: 600; margin-bottom: 16px; }
.news-benefits { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }
.news-benefits li { font-size: 0.85rem; color: rgba(45,21,5,.85); display: flex; align-items: center; gap: 10px; font-weight: 500; }
.news-benefits i { color: var(--brown); width: 16px; text-align: center; }
.news-action { position: relative; z-index: 1; }
.news-form { display: flex; gap: 10px; }
.news-form .form-control { flex: 1; }
.news-fine { font-size: 0.72rem; color: rgba(45,21,5,.6); margin-top: 10px; text-align: center; }
@media (max-width: 820px) { .news { grid-template-columns: 1fr; gap: 24px; } }

/* ── Why us ── */
.essence { background: var(--brown); color: var(--cream); }
.essence-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
.essence-quote { font-family: var(--font-display); font-variation-settings: var(--fraunces-display); font-weight: 400; font-size: clamp(1.5rem, 2.8vw, 2.15rem); line-height: 1.3; color: var(--cream); margin: 14px 0 18px; text-wrap: pretty; }
.essence-quote em { font-family: var(--font-script); font-style: normal; color: var(--caramel-light); }
.essence-sig { font-size: 0.84rem; color: rgba(245,236,215,.6); display: inline-flex; align-items: center; gap: 12px; }
.essence-sig::before { content: ''; width: 28px; height: 1px; background: var(--caramel); }
.essence-impact { display: flex; gap: 30px; margin: 26px 0 28px; flex-wrap: wrap; }
.essence-impact > div { display: flex; flex-direction: column; }
.essence-impact strong { font-family: var(--font-display); font-variation-settings: var(--fraunces-display); font-size: 1.5rem; color: var(--caramel-light); line-height: 1; }
.essence-impact span { font-size: 0.72rem; color: rgba(245,236,215,.6); margin-top: 6px; max-width: 140px; line-height: 1.35; }
.essence-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.essence-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.essence-card { background: rgba(245,236,215,.06); border: 1px solid rgba(245,236,215,.12); border-radius: var(--r-lg); padding: 22px 20px; transition: background .25s var(--ease), border-color .25s var(--ease); }
.essence-card:hover { background: rgba(245,236,215,.1); border-color: rgba(200,149,106,.5); }
.essence-ic { width: 42px; height: 42px; border-radius: 50%; background: rgba(200,149,106,.18); color: var(--caramel-light); display: grid; place-items: center; font-size: 1rem; margin-bottom: 14px; }
.essence-card h4 { font-size: 0.98rem; color: var(--cream); margin-bottom: 6px; }
.essence-card p { font-size: 0.82rem; color: rgba(245,236,215,.66); line-height: 1.5; }
@media (max-width: 900px) { .essence-grid { grid-template-columns: 1fr; gap: 40px; } }
@media (max-width: 480px) { .essence-pillars { grid-template-columns: 1fr; } }
.why { background: var(--brown); color: var(--cream); }
.why-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 48px; align-items: center; }
.why h2 { color: var(--cream); }
.why-intro p { color: rgba(245,236,215,.72); margin: 14px 0 22px; }
.why-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.why-card { background: rgba(245,236,215,.05); border: 1px solid rgba(245,236,215,.1); border-radius: var(--r-lg); padding: 24px; }
.why-card .num { font-family: var(--font-display); font-size: 1.6rem; font-weight: 800; color: var(--caramel-light); margin-bottom: 8px; font-variation-settings: var(--fraunces-text); }
.why-card h4 { color: var(--cream); margin-bottom: 6px; }
.why-card p { font-size: 0.82rem; color: rgba(245,236,215,.66); line-height: 1.6; }
@media (max-width: 820px) { .why-grid { grid-template-columns: 1fr; gap: 28px; } }

/* ── Reviews ── */
.reviews { background: var(--cream); }
.rev-rate { text-align: right; }
.rev-rate-stars { color: var(--star); font-size: 1.05rem; letter-spacing: 2px; }
.rev-rate-meta { display: block; font-size: 0.82rem; color: var(--muted); margin-top: 5px; }
.rev-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.rev-card { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px; }
.rev-stars { color: var(--star); font-size: 0.8rem; margin-bottom: 10px; letter-spacing: 2px; }
.rev-text { font-size: 0.85rem; color: var(--text); line-height: 1.6; margin-bottom: 16px; }
.rev-auth { display: flex; align-items: center; gap: 10px; }
.rev-av { width: 38px; height: 38px; border-radius: 50%; background: var(--caramel); color: #fff; display: grid; place-items: center; font-weight: 700; font-size: 0.9rem; }
.rev-nm { font-size: 0.82rem; font-weight: 600; color: var(--brown); }
.rev-dt { font-size: 0.72rem; color: var(--light); }
@media (max-width: 1024px) { .rev-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .rev-grid { grid-template-columns: 1fr; } }

/* ── Final CTA ── */
.cta { background: var(--caramel); text-align: center; }

/* ── Home final CTA band (brown) ── */
.home-cta { background: var(--brown); color: var(--cream); padding: clamp(40px, 6vw, 72px) 0; }
.home-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 36px; flex-wrap: wrap; }
.home-cta .eyebrow { color: var(--caramel-light); }
.home-cta h2 { color: var(--cream); margin: 6px 0 12px; }
.home-cta p { color: rgba(245,236,215,.78); font-size: 0.96rem; max-width: 540px; line-height: 1.7; }
.home-cta-act { display: flex; gap: 12px; flex-wrap: wrap; flex-shrink: 0; }
.btn-ghost-light { background: transparent; color: var(--cream); border: 1px solid rgba(245,236,215,.4); }
.btn-ghost-light:hover { background: rgba(245,236,215,.1); border-color: var(--cream); }
@media (max-width: 720px) { .home-cta-inner { flex-direction: column; align-items: flex-start; } }
.cta h2 { color: var(--brown); margin-bottom: 12px; }
.cta-band { padding: var(--section-py) 0; }
.cta-band-in { background: linear-gradient(135deg, #2D1505 0%, #3F2008 45%, #5A3414 100%); border-radius: var(--r-lg); padding: clamp(40px, 7vw, 76px) clamp(24px, 5vw, 64px); text-align: center; position: relative; overflow: hidden; box-shadow: 0 24px 60px rgba(45,21,5,.3); }
.cta-band-in::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(rgba(245,236,215,.06) 1px, transparent 1px); background-size: 22px 22px; pointer-events: none; }
.cta-band-in::after { content: ''; position: absolute; right: -80px; top: -80px; width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle, rgba(200,149,106,.4), transparent 70%); pointer-events: none; }
.cta-band-in .eyebrow { color: var(--caramel-light); position: relative; z-index: 1; }
.cta-band-in h2 { color: var(--cream); margin: 10px 0 0; font-size: clamp(1.6rem, 4vw, 2.4rem); position: relative; z-index: 1; }
.cta-band-in p { color: rgba(245,236,215,.82); max-width: 540px; margin: 14px auto 0; line-height: 1.7; font-size: 0.96rem; position: relative; z-index: 1; }
.cta-band-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 26px; position: relative; z-index: 1; }
@media (max-width: 460px) { .cta-band-btns .btn { width: 100%; } }
.cta p { color: rgba(45,21,5,.72); max-width: 460px; margin: 0 auto 26px; }
.cta-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ── Footer ── */
.ft { background: var(--brown); color: rgba(245,236,215,.7); padding: 0 0 26px; }
.ft-news { display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap; padding: 40px 0; border-bottom: 1px solid rgba(245,236,215,.12); }
.ft-news-text h3 { color: var(--cream); font-size: 1.5rem; margin-bottom: 5px; }
.ft-news-text p { color: rgba(245,236,215,.58); font-size: 0.9rem; max-width: 440px; }
.ft-news-form { display: flex; gap: 12px; align-items: center; }
.ft-news-form input { background: rgba(245,236,215,.05); border: 1px solid rgba(245,236,215,.18); border-radius: var(--r-pill); padding: 14px 22px; color: var(--cream); font-size: 0.9rem; width: 300px; outline: none; transition: border-color .2s; }
.ft-news-form input::placeholder { color: rgba(245,236,215,.42); }
.ft-news-form input:focus { border-color: var(--caramel); }
.ft-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; padding: 48px 0 36px; }
.ft img.logo { height: 46px; margin-bottom: 14px; }
.ft p { font-size: 0.84rem; color: rgba(245,236,215,.6); line-height: 1.7; max-width: 280px; }
.ft h5 { color: var(--cream); font-family: var(--font-body); font-size: 0.78rem; text-transform: uppercase; letter-spacing: .1em; margin-bottom: 14px; }
.ft ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.ft a { font-size: 0.84rem; color: rgba(245,236,215,.6); cursor: pointer; }
.ft a:hover { color: var(--caramel-light); }
.ft-socials { display: flex; gap: 10px; margin-top: 16px; }
.ft-socials a { width: 36px; height: 36px; border-radius: 50%; background: rgba(245,236,215,.08); display: grid; place-items: center; color: var(--cream); }
.ft-socials a:hover { background: var(--caramel); }
.ft-bot { border-top: 1px solid rgba(245,236,215,.12); padding-top: 22px; display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; font-size: 0.76rem; color: rgba(245,236,215,.5); }
.ft-pay { display: flex; align-items: center; justify-content: center; flex: 1; padding-left: 10px; }
.ft-pay-badge { display: inline-flex; line-height: 0; border-radius: 50%; overflow: hidden; margin-left: -10px; box-shadow: 0 0 0 2px var(--brown); transition: transform .2s var(--ease); position: relative; }
.ft-pay-badge:first-child { margin-left: 0; }
.ft-pay-badge:hover { transform: translateY(-3px); z-index: 2; }
.ft-pay-badge img { height: 36px; width: 36px; object-fit: cover; display: block; border-radius: 50%; }
.ft-legal { display: inline-flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.ft-legal a { color: inherit; text-decoration: none; transition: color .2s; }
.ft-legal a:hover { color: var(--caramel); }
.ft-legal-sep { opacity: .4; }
@media (max-width: 820px) { .ft-grid { grid-template-columns: 1fr 1fr; } .ft-news { flex-direction: column; align-items: flex-start; } .ft-news-form { width: 100%; } .ft-news-form input { flex: 1; width: auto; } }

/* ════════ CATALOG (pro filters) ════════ */
.cat-head { background: var(--cream); border-bottom: 1px solid var(--border); padding: 30px 0 26px; }
.cat-layout { display: grid; grid-template-columns: 256px 1fr; gap: 30px; align-items: start; padding-top: 26px; }
.fil { position: sticky; top: 96px; background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 4px 20px 20px; }
.fil-grp { padding: 18px 0; border-bottom: 1px solid var(--border); }
.fil-grp:last-child { border-bottom: none; }
.fil-grp h5 { font-family: var(--font-body); font-size: 0.74rem; text-transform: uppercase; letter-spacing: .09em; color: var(--brown); font-weight: 700; margin-bottom: 12px; }
.fil-search { position: relative; margin-top: 16px; }
.fil-search i { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--light); font-size: 0.82rem; }
.fil-search input { width: 100%; padding: 10px 12px 10px 36px; border: 1.5px solid var(--border); border-radius: var(--r); font-size: 0.84rem; outline: none; }
.fil-search input:focus { border-color: var(--caramel); box-shadow: var(--ring); }
.fil-list { display: flex; flex-direction: column; gap: 2px; }
.fil-opt { display: flex; align-items: center; justify-content: space-between; padding: 7px 10px; border-radius: var(--r-sm); font-size: 0.85rem; color: var(--muted); cursor: pointer; border: none; background: none; width: 100%; text-align: left; transition: all .15s; }
.fil-opt:hover { background: var(--cream); color: var(--brown); }
.fil-opt.active { background: var(--brown); color: #fff; }
.fil-opt .ct { font-size: 0.72rem; opacity: .7; }
.fil-sizes { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.fil-size { aspect-ratio: 1; border: 1.5px solid var(--border); background: #fff; border-radius: var(--r-sm); font-size: 0.76rem; font-weight: 600; color: var(--muted); cursor: pointer; transition: all .15s; }
.fil-size:hover { border-color: var(--caramel); }
.fil-size.active { background: var(--brown); border-color: var(--brown); color: #fff; }
.fil-colors { display: flex; flex-wrap: wrap; gap: 9px; }
.fil-color { width: 28px; height: 28px; border-radius: 50%; cursor: pointer; border: 2px solid #fff; box-shadow: 0 0 0 1.5px var(--border); transition: all .15s; position: relative; }
.fil-color:hover { transform: scale(1.1); }
.fil-color.active { box-shadow: 0 0 0 2px var(--caramel); }
.fil-color.active::after { content: '\f00c'; font-family: 'Font Awesome 6 Free'; font-weight: 900; position: absolute; inset: 0; display: grid; place-items: center; color: #fff; font-size: 0.6rem; text-shadow: 0 1px 2px rgba(0,0,0,.4); }
.fil-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.fil-toggle { display: flex; align-items: center; gap: 11px; width: 100%; cursor: pointer; padding: 11px 13px; border: 1.5px solid var(--border); border-radius: var(--r); background: #fff; text-align: left; transition: border-color .2s, background .2s; font-family: var(--font-body); }
.fil-toggle:hover { border-color: var(--caramel); }
.fil-toggle.on { border-color: var(--caramel); background: var(--accent-soft); }
.fil-toggle-ic { width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center; background: var(--cream); color: var(--muted); font-size: 0.82rem; transition: background .2s, color .2s; }
.fil-toggle.on .fil-toggle-ic { background: var(--caramel); color: #fff; }
.fil-toggle-txt { flex: 1; display: flex; flex-direction: column; line-height: 1.25; }
.fil-toggle-txt b { font-size: 0.86rem; color: var(--brown); font-weight: 600; }
.fil-toggle-txt small { font-size: 0.72rem; color: var(--muted); }
.sw { width: 40px; height: 23px; border-radius: var(--r-pill); background: var(--cream-dark); position: relative; transition: background .2s; flex-shrink: 0; }
.sw::after { content: ''; position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%; background: #fff; box-shadow: var(--sh-sm); transition: transform .2s; }
.fil-toggle.on .sw { background: var(--caramel); }
.fil-toggle.on .sw::after { transform: translateX(17px); }
.fil-price-row { display: flex; align-items: center; gap: 8px; font-size: 0.78rem; color: var(--muted); margin-bottom: 10px; }
.fil-price-row b { color: var(--brown); }
.fil-range { width: 100%; accent-color: var(--caramel); }

/* toolbar */
.cat-search { position: relative; margin-bottom: 16px; }
.cat-search > i { position: absolute; left: 16px; top: 50%; transform: translateY(-50%); color: var(--light); font-size: 0.9rem; pointer-events: none; }
.cat-search input { width: 100%; padding: 13px 44px 13px 42px; border: 1.5px solid var(--cream-dark); border-radius: var(--r-pill); font-size: 0.9rem; color: var(--brown); outline: none; background: #fff; transition: border-color .2s, box-shadow .2s; font-family: var(--font-body); }
.cat-search input::placeholder { color: var(--light); }
.cat-search input:focus { border-color: var(--caramel); box-shadow: var(--ring); }
.cat-search-clear { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); width: 26px; height: 26px; border-radius: 50%; border: none; background: var(--cream); color: var(--muted); cursor: pointer; display: grid; place-items: center; font-size: 0.7rem; transition: background .2s, color .2s; }
.cat-search-clear:hover { background: var(--caramel); color: #fff; }
.cat-bar { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; flex-wrap: nowrap; }
.cat-bar-l { display: flex; align-items: center; gap: 10px; flex-wrap: nowrap; min-width: 0; flex: 1; }
.cat-count { font-size: 0.84rem; color: var(--muted); white-space: nowrap; flex-shrink: 0; }
.active-chips { display: flex; align-items: center; gap: 8px; overflow-x: auto; min-width: 0; flex: 1; padding-bottom: 2px; scrollbar-width: thin; -webkit-overflow-scrolling: touch; }
.active-chips::-webkit-scrollbar { height: 4px; }
.active-chips::-webkit-scrollbar-thumb { background: var(--cream-dark); border-radius: 99px; }
.cat-count b { color: var(--brown); }
.active-chip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 8px 5px 12px; border-radius: var(--r-pill); background: var(--cream); border: 1px solid var(--border); font-size: 0.76rem; color: var(--brown); white-space: nowrap; flex-shrink: 0; }em; color: var(--brown); }
.active-chip button { border: none; background: none; cursor: pointer; color: var(--muted); display: grid; place-items: center; width: 16px; height: 16px; border-radius: 50%; }
.active-chip button:hover { background: var(--cream-dark); color: var(--brown); }
.clear-all { font-size: 0.78rem; color: var(--caramel-dark); cursor: pointer; font-weight: 600; background: none; border: none; white-space: nowrap; flex-shrink: 0; }
.cat-bar-r { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.sortsel { padding: 9px 32px 9px 14px; border: 1.5px solid var(--border); border-radius: var(--r); background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235C4A3A' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center; font-size: 0.82rem; color: var(--brown); cursor: pointer; -webkit-appearance: none; appearance: none; font-family: var(--font-body); }

/* Branded sort dropdown */
.dd { position: relative; }
.dd-btn { display: inline-flex; align-items: center; gap: 7px; padding: 10px 16px; border: 1.5px solid var(--cream-dark); border-radius: var(--r-pill); background: #fff; font-size: 0.84rem; color: var(--brown); cursor: pointer; font-family: var(--font-body); transition: border-color .2s, box-shadow .2s; white-space: nowrap; }
.dd-btn:hover { border-color: var(--caramel); }
.dd.open .dd-btn { border-color: var(--caramel); box-shadow: var(--ring); }
.dd-lbl { color: var(--muted); }
.dd-val { font-weight: 600; }
.dd-caret { font-size: 0.65rem; color: var(--muted); margin-left: 2px; transition: transform .25s var(--ease); }
.dd.open .dd-caret { transform: rotate(180deg); }
.dd-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 210px; background: #fff; border: 1px solid var(--border); border-radius: var(--r); box-shadow: var(--sh-lg); padding: 6px; z-index: 30; opacity: 0; transform: translateY(-6px) scale(.98); transform-origin: top right; pointer-events: none; transition: opacity .18s var(--ease), transform .18s var(--ease); }
.dd.open .dd-menu { opacity: 1; transform: none; pointer-events: auto; }
.dd-item { display: flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; padding: 9px 12px; border: none; background: none; border-radius: var(--r-sm); font-size: 0.84rem; color: var(--muted); cursor: pointer; font-family: var(--font-body); text-align: left; transition: background .15s, color .15s; }
.dd-item:hover { background: var(--cream); color: var(--brown); }
.dd-item.active { color: var(--brown); font-weight: 600; }
.dd-item.active i { color: var(--caramel-dark); font-size: 0.74rem; }
.dens { display: flex; border: 1.5px solid var(--border); border-radius: var(--r); overflow: hidden; }
.dens button { border: none; background: #fff; width: 38px; height: 38px; cursor: pointer; color: var(--muted); display: grid; place-items: center; }
.dens button.active { background: var(--brown); color: #fff; }
.fil-btn-m { display: none; }
.cat-empty { text-align: center; padding: 60px 20px; color: var(--muted); }
.cat-empty i { font-size: 2rem; color: var(--cream-dark); margin-bottom: 12px; }

/* pagination */
.related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 900px) { .related-grid { grid-template-columns: repeat(2, 1fr); } }.pager { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 32px; padding-top: 22px; border-top: 1px solid var(--border); flex-wrap: wrap; }
.pager-info { font-size: 0.82rem; color: var(--muted); }
.pager-info b { color: var(--brown); }
.pager-ctrl { display: flex; align-items: center; gap: 6px; }
.pager-btn, .pager-num { min-width: 38px; height: 38px; border-radius: var(--r); border: 1.5px solid var(--border); background: #fff; color: var(--brown); font-size: 0.84rem; font-weight: 600; cursor: pointer; display: grid; place-items: center; padding: 0 6px; font-family: var(--font-body); transition: all .18s var(--ease); }
.pager-btn:hover:not(:disabled), .pager-num:hover { border-color: var(--caramel); color: var(--caramel-dark); }
.pager-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.pager-num.active { background: var(--brown); border-color: var(--brown); color: var(--cream); }
.pager-gap { min-width: 24px; text-align: center; color: var(--light); font-size: 0.84rem; }
@media (max-width: 560px) { .pager { justify-content: center; } .pager-info { width: 100%; text-align: center; } }
@media (max-width: 820px) {
  .cat-layout { grid-template-columns: 1fr; }
  .fil { position: fixed; inset: 0 0 0 auto; width: min(340px, 88vw); border-radius: 0; z-index: 60; overflow-y: auto; transform: translateX(100%); transition: transform .3s var(--ease); box-shadow: var(--sh-lg); }
  .fil.open { transform: none; }
  .fil-btn-m { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border: 1.5px solid var(--brown); border-radius: var(--r); background: #fff; color: var(--brown); font-weight: 600; font-size: 0.82rem; cursor: pointer; }
  .fil-backdrop { position: fixed; inset: 0; background: rgba(45,21,5,.4); z-index: 55; }
}

/* ── Product detail ── */
.pd { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; }
.pd-gallery { display: flex; flex-direction: column; gap: 12px; position: sticky; top: 88px; align-self: start; }
.pd-main { aspect-ratio: 3/4; max-height: 560px; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); background: var(--cream); }
.pd-main img { width: 100%; height: 100%; object-fit: cover; }
.pd-thumbs { display: flex; gap: 10px; }
.pd-thumbs button { width: 72px; height: 86px; border-radius: var(--r); overflow: hidden; border: 2px solid var(--border); padding: 0; cursor: pointer; background: none; }
.pd-thumbs button.active { border-color: var(--caramel); }
.pd-thumbs img { width: 100%; height: 100%; object-fit: cover; }
.pd-info .badges { display: flex; gap: 8px; margin-bottom: 14px; align-items: center; }
.pd-info h1 { font-size: 2.1rem; margin-bottom: 6px; }
.pd-sku { font-size: 0.8rem; color: var(--light); font-family: monospace; margin-bottom: 18px; }
.pd-price { display: flex; align-items: baseline; gap: 12px; margin-bottom: 22px; }
.pd-price { display: flex; align-items: baseline; gap: 12px; margin-bottom: 22px; flex-wrap: wrap; }
.pd-now { font-family: var(--font-display); font-size: 2.1rem; font-weight: 800; color: var(--brown); font-variation-settings: var(--fraunces-text); white-space: nowrap; }
.pd-was { font-size: 1rem; text-decoration: line-through; color: var(--light); }
.pd-specs { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 18px 0; margin-bottom: 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pd-spec .k { font-size: 0.72rem; color: var(--light); text-transform: uppercase; letter-spacing: .06em; }
.pd-spec .v { font-size: 0.9rem; color: var(--brown); font-weight: 600; }
.pd-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.pd-sizelink { display: inline-flex; align-items: center; gap: 8px; margin: -6px 0 22px; padding: 9px 15px; border: 1px solid var(--border); border-radius: var(--r-pill); background: var(--cream-light); color: var(--brown); font-size: 0.84rem; font-weight: 600; text-decoration: none; transition: border-color .2s, background .2s, color .2s; }
.pd-sizelink:hover { border-color: var(--caramel); background: var(--accent-soft); color: var(--caramel-dark); }
.pd-sizelink > i:first-child { color: var(--caramel-dark); }
.pd-sizelink > i:last-child { font-size: 0.72em; }
@media (max-width: 820px) { .pd { grid-template-columns: 1fr; } }

/* ════════ PAGE HERO (À propos / Contact) ════════ */
.page-head { background: var(--cream); border-bottom: 1px solid var(--border); padding: 40px 0; }
.page-head h1 { font-size: clamp(1.9rem, 3.5vw, 2.8rem); margin-bottom: 10px; }
.page-head p { font-size: 0.96rem; max-width: 600px; }
.story-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 56px; align-items: center; }
.story-media { position: relative; }
.story-media::before { content: ''; position: absolute; left: -16px; top: -16px; width: 110px; height: 110px; border-left: 3px solid var(--caramel); border-top: 3px solid var(--caramel); border-top-left-radius: var(--r-lg); opacity: .55; }
.story-img { border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 4/5; box-shadow: var(--sh-lg); position: relative; z-index: 1; }
.story-img img { width: 100%; height: 100%; object-fit: cover; }
.story-badge { position: absolute; left: -24px; bottom: 30px; z-index: 2; background: #fff; border: 1px solid var(--border); border-radius: var(--r); box-shadow: var(--sh-lg); padding: 13px 16px; display: flex; align-items: center; gap: 12px; }
.story-badge-ic { width: 40px; height: 40px; border-radius: 50%; background: var(--accent-soft); color: var(--caramel-dark); display: grid; place-items: center; font-size: 1rem; flex-shrink: 0; }
.story-badge strong { display: block; font-size: 0.86rem; color: var(--brown); }
.story-badge span { font-size: 0.74rem; color: var(--muted); }
.story-chip { position: absolute; top: 18px; right: 18px; z-index: 2; background: rgba(253,248,242,.92); backdrop-filter: blur(6px); border-radius: var(--r-pill); padding: 7px 14px; font-size: 0.74rem; font-weight: 700; color: var(--brown); display: inline-flex; align-items: center; gap: 7px; box-shadow: var(--sh-sm); }
.story-chip i { color: var(--caramel-dark); }
.story-content h2 { margin-bottom: 0; }
.story-lead { font-size: 1.06rem; line-height: 1.7; color: var(--brown); font-weight: 500; margin-bottom: 14px; }
.story-content p { font-size: 0.94rem; line-height: 1.85; margin-bottom: 14px; color: var(--text); }
.story-points { list-style: none; padding: 0; margin: 4px 0 22px; display: flex; flex-direction: column; gap: 10px; }
.story-points li { display: flex; align-items: center; gap: 11px; font-size: 0.9rem; color: var(--text); font-weight: 500; }
.story-points li i { color: var(--green); background: var(--green-bg); width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 0.66rem; flex-shrink: 0; }
.story-sign { font-family: var(--font-script); font-size: 1.4rem; color: var(--caramel-dark); margin-bottom: 24px; line-height: 1; }
.story-cta { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 820px) { .story-grid { grid-template-columns: 1fr; gap: 44px; } .story-media::before { left: -8px; top: -8px; } }
.story-content p strong { color: var(--brown); }
.numbers { background: var(--brown); }
.numbers-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.num strong { display: block; font-family: var(--font-display); font-size: 2.4rem; font-weight: 800; color: var(--caramel-light); line-height: 1; margin-bottom: 6px; font-variation-settings: var(--fraunces-text); }
.num span { font-size: 0.76rem; color: rgba(245,236,215,.6); text-transform: uppercase; letter-spacing: .08em; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.value { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 30px 24px; transition: transform .3s, box-shadow .3s; }
.value:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }
.value-ic { width: 56px; height: 56px; border-radius: 50%; background: var(--accent-soft); display: grid; place-items: center; font-size: 1.4rem; color: var(--caramel-dark); margin-bottom: 16px; }
.value h3 { font-size: 1.05rem; margin-bottom: 8px; }
.value p { font-size: 0.85rem; line-height: 1.6; }
@media (max-width: 900px) { .story-grid { grid-template-columns: 1fr; gap: 28px; } .numbers-grid { grid-template-columns: repeat(2, 1fr); } .values-grid { grid-template-columns: 1fr; } }

/* ── Engagement ── */
.engage { background: var(--cream-light); }
.engage-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.engage-it { text-align: center; display: flex; flex-direction: column; align-items: center; padding: 0 8px; }
.engage-ic { width: 76px; height: 76px; border-radius: 50%; display: grid; place-items: center; background: var(--cream-dark); color: var(--caramel-dark); font-size: 1.5rem; margin-bottom: 20px; transition: transform .25s var(--ease), background .25s; }
.engage-it:hover .engage-ic { transform: translateY(-4px); background: var(--caramel); color: #fff; }
.engage-it h4 { color: var(--brown); font-size: 1.05rem; margin-bottom: 9px; }
.engage-it p { color: var(--muted); font-size: 0.86rem; line-height: 1.65; max-width: 240px; }
@media (max-width: 820px) { .engage-grid { grid-template-columns: 1fr 1fr; gap: 32px 20px; } }
@media (max-width: 460px) { .engage-grid { grid-template-columns: 1fr; } }

/* ── Contact ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 44px; align-items: start; }
.contact-info { display: flex; flex-direction: column; gap: 14px; }
.cinfo { display: flex; gap: 14px; align-items: flex-start; background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 20px; }
.cinfo .ic { width: 42px; height: 42px; border-radius: 50%; background: var(--accent-soft); color: var(--caramel-dark); display: grid; place-items: center; flex-shrink: 0; }
.cinfo h4 { margin-bottom: 3px; }
.cinfo p { font-size: 0.86rem; margin: 0; }
.cinfo a { color: var(--caramel-dark); font-weight: 500; }
.contact-form { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 30px; }
.contact-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cmap { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); height: 280px; position: relative; background: var(--cream); }
.cmap img { width: 100%; height: 100%; object-fit: cover; filter: sepia(.25) saturate(1.1); }
.cmap .pin { position: absolute; left: 0; right: 0; bottom: 14px; display: flex; justify-content: center; pointer-events: none; }
.cmap .pin span { background: var(--brown); color: var(--cream); padding: 8px 16px; border-radius: var(--r-pill); font-size: 0.82rem; font-weight: 600; box-shadow: var(--sh); display: inline-flex; gap: 7px; align-items: center; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width: 100%; text-align: left; background: none; border: none; padding: 18px 0; display: flex; justify-content: space-between; align-items: center; gap: 16px; cursor: pointer; font-size: 0.95rem; font-weight: 600; color: var(--brown); }
.faq-q i { transition: transform .25s; color: var(--caramel-dark); flex-shrink: 0; }
.faq-item.open .faq-q i { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s var(--ease); }
.faq-item.open .faq-a { max-height: 220px; }
.faq-a p { font-size: 0.88rem; padding-bottom: 18px; line-height: 1.7; }
@media (max-width: 820px) { .contact-grid { grid-template-columns: 1fr; } .contact-form .row2 { grid-template-columns: 1fr; } }

/* ════════ CART DRAWER ════════ */
.cd-backdrop { position: fixed; inset: 0; background: rgba(45,21,5,.45); z-index: 70; opacity: 0; pointer-events: none; transition: opacity .3s; }
.cd-backdrop.show { opacity: 1; pointer-events: auto; }
.cd { position: fixed; top: 0; right: 0; bottom: 0; width: min(420px, 92vw); background: var(--cream-light); z-index: 71; display: flex; flex-direction: column; transform: translateX(100%); transition: transform .35s var(--ease); box-shadow: var(--sh-lg); }
.cd.open { transform: none; }
.cd-head { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px; border-bottom: 1px solid var(--border); }
.cd-head h3 { font-size: 1.2rem; }
.cd-head h3 span { color: var(--muted); font-weight: 400; }
.cd-head-act { display: flex; align-items: center; gap: 8px; }
.cd-clear { display: inline-flex; align-items: center; gap: 6px; padding: 7px 13px; border-radius: var(--r-pill); border: 1px solid var(--border); background: #fff; color: var(--muted); font-size: 0.78rem; font-weight: 600; font-family: inherit; cursor: pointer; transition: all .2s var(--ease); }
.cd-clear:hover { border-color: var(--red, #B71C1C); color: var(--red, #B71C1C); background: color-mix(in srgb, var(--red, #B71C1C), transparent 92%); }
.cd-clear i { font-size: 0.82rem; }
.cd-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; color: var(--muted); padding: 30px; text-align: center; }
.cd-empty i { font-size: 2.4rem; color: var(--cream-dark); }
.cd-list { flex: 1; overflow-y: auto; padding: 8px 22px; }
.cd-list .ck-sum-it { padding: 14px 0; border-bottom: 1px solid var(--border); }
.cd-list .ck-sum-it:last-child { border-bottom: none; }
.cd-item { display: flex; gap: 13px; padding: 16px 0; border-bottom: 1px solid var(--border); }
.cd-item img { width: 66px; height: 84px; object-fit: cover; border-radius: var(--r-sm); flex-shrink: 0; }
.cd-it-body { flex: 1; min-width: 0; }
.cd-it-brand { font-size: 0.64rem; font-weight: 600; text-transform: uppercase; letter-spacing: .07em; color: var(--caramel-dark); }
.cd-it-name { font-size: 0.9rem; font-weight: 600; color: var(--brown); }
.cd-it-meta { font-size: 0.74rem; color: var(--muted); margin: 2px 0 6px; }
.cd-it-price { font-family: var(--font-display); font-weight: 700; color: var(--brown); font-variation-settings: var(--fraunces-text); }
.cd-rm { border: none; background: none; color: var(--light); cursor: pointer; align-self: flex-start; padding: 4px; transition: color .2s; }
.cd-rm:hover { color: var(--red); }
.cd-foot { padding: 18px 22px 22px; border-top: 1px solid var(--border); background: #fff; }
.cd-line { display: flex; justify-content: space-between; align-items: baseline; font-size: 0.92rem; color: var(--text); }
.cd-line b { font-family: var(--font-display); font-size: 1.2rem; color: var(--brown); font-variation-settings: var(--fraunces-text); }
.cd-note { font-size: 0.72rem; color: var(--muted); margin: 6px 0 14px; }
.cd-foot .btn + .btn { margin-top: 8px; }

/* ── Wishlist drawer actions ── */
.wish-acts { margin-left: auto; display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.wish-add { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--border); background: #fff; color: var(--caramel-dark); cursor: pointer; display: grid; place-items: center; font-size: 0.76rem; transition: all .2s var(--ease); }
.wish-add:hover { border-color: var(--caramel); background: var(--accent-soft); }
.wish-add.in { background: var(--caramel); border-color: var(--caramel); color: #fff; }

/* ── WhatsApp FAB popover ── */
.wa-backdrop { position: fixed; inset: 0; z-index: 59; }
.wa-pop { position: fixed; right: 18px; bottom: 88px; z-index: 61; width: min(330px, calc(100vw - 36px)); background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-lg); overflow: hidden; animation: waPopIn .2s var(--ease); }
@keyframes waPopIn { from { opacity: 0; transform: translateY(12px) scale(.96); } to { opacity: 1; transform: none; } }
.wa-pop-head { display: flex; align-items: center; gap: 11px; padding: 14px 16px; background: var(--whatsapp); color: #fff; }
.wa-pop-ava { width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.2); display: grid; place-items: center; font-size: 1.1rem; flex-shrink: 0; }
.wa-pop-name { font-weight: 700; font-size: 0.92rem; }
.wa-pop-status { font-size: 0.7rem; opacity: .92; display: flex; align-items: center; gap: 5px; margin-top: 2px; }
.wa-dot { width: 7px; height: 7px; border-radius: 50%; background: #b9f6ca; display: inline-block; }
.wa-pop-x { margin-left: auto; width: 28px; height: 28px; border-radius: 50%; border: none; background: rgba(255,255,255,.18); color: #fff; cursor: pointer; display: grid; place-items: center; flex-shrink: 0; }
.wa-pop-x:hover { background: rgba(255,255,255,.3); }
.wa-pop-body { padding: 16px; background: var(--cream-light); }
.wa-bubble { background: #fff; border: 1px solid var(--border); border-radius: 4px 14px 14px 14px; padding: 11px 14px; font-size: 0.84rem; color: var(--text); line-height: 1.55; box-shadow: var(--sh-sm); }
.wa-quick { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.wa-quick-it { display: flex; align-items: center; gap: 10px; padding: 11px 14px; border-radius: var(--r); border: 1px solid var(--border); background: #fff; color: var(--brown); font-size: 0.84rem; font-weight: 600; text-decoration: none; transition: all .2s var(--ease); }
.wa-quick-it > i:first-child { color: var(--whatsapp-dk, #1DA851); width: 16px; text-align: center; }
.wa-quick-it:hover { border-color: var(--whatsapp); background: color-mix(in srgb, var(--whatsapp), transparent 92%); }
.wa-quick-go { margin-left: auto; font-size: 0.7rem; color: var(--muted); }
.wa-pop-cta { border-radius: 0; }

/* ════════ CHECKOUT ════════ */
.ck { display: grid; grid-template-columns: 1fr 380px; gap: 30px; align-items: start; }
.ck-main { display: flex; flex-direction: column; gap: 18px; }
.ck-block { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 24px; transition: opacity .25s, filter .25s; }
.ck-block.locked { opacity: 0.55; filter: grayscale(0.5); pointer-events: none; user-select: none; }
.ck-block.done { border-color: var(--green); }
.ck-locked-hint { font-size: 0.78rem; color: var(--muted); margin: -6px 0 14px; display: flex; align-items: center; gap: 6px; }
.ck-block h3 { font-size: 1.1rem; margin-bottom: 18px; display: flex; align-items: center; gap: 12px; }
.ck-step { width: 28px; height: 28px; border-radius: 50%; background: var(--brown); color: var(--cream); font-family: var(--font-body); font-size: 0.82rem; font-weight: 700; display: grid; place-items: center; flex-shrink: 0; transition: background .25s; }
.ck-block.done .ck-step { background: var(--green); }
.ck-block.locked .ck-step { background: var(--light); }
.ck-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
/* delivery mode toggle */
.ck-modes { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.ck-mode { display: flex; flex-direction: column; align-items: flex-start; gap: 3px; padding: 14px 16px; border: 1.5px solid var(--border); border-radius: var(--r); background: #fff; cursor: pointer; text-align: left; transition: all .15s; }
.ck-mode:hover { border-color: var(--caramel-light); }
.ck-mode.active { border-color: var(--caramel); background: var(--accent-soft); }
.ck-mode i { font-size: 1.05rem; color: var(--caramel-dark); margin-bottom: 4px; }
.ck-mode-t { font-size: 0.88rem; font-weight: 600; color: var(--brown); }
.ck-mode-s { font-size: 0.74rem; color: var(--muted); }
/* distance-based delivery */
.ck-dist { margin-top: 16px; }
.ck-dist-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.ck-dist-km { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--brown); font-variation-settings: var(--fraunces-text); }
.ck-dist-range { width: 100%; accent-color: var(--caramel); cursor: pointer; }
.ck-dist-calc { margin-top: 14px; background: var(--cream); border-radius: var(--r); padding: 12px 14px; display: flex; flex-direction: column; gap: 7px; }
.ck-dist-calc .ck-line { font-size: 0.82rem; }
.ck-dist-tot { border-top: 1px solid var(--border); padding-top: 8px; margin-top: 2px; }
.ck-dist-tot b { font-size: 0.95rem; color: var(--brown); }
.ck-dist-note { margin-top: 12px; font-size: 0.74rem; color: var(--muted); line-height: 1.5; }
.ck-dist-note i { color: var(--caramel-dark); margin-right: 5px; }
.ck-pickup { margin-top: 14px; font-size: 0.84rem; color: var(--muted); background: var(--cream); border-radius: var(--r); padding: 12px 14px; }
.ck-pickup i { color: var(--caramel-dark); margin-right: 6px; }
/* deposit / total choice */
.ck-paychoice { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 18px; }
.ck-paychoice-opt { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; padding: 14px 16px; border: 1.5px solid var(--border); border-radius: var(--r); background: #fff; cursor: pointer; text-align: left; transition: all .15s; }
.ck-paychoice-opt:hover { border-color: var(--caramel-light); }
.ck-paychoice-opt.active { border-color: var(--caramel); background: var(--accent-soft); }
.ck-pc-top { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; font-weight: 600; color: var(--brown); }
.ck-pc-radio { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--cream-dark); flex-shrink: 0; position: relative; transition: border-color .2s; }
.ck-paychoice-opt.active .ck-pc-radio { border-color: var(--caramel); }
.ck-paychoice-opt.active .ck-pc-radio::after { content: ''; position: absolute; inset: 2px; border-radius: 50%; background: var(--caramel); }
.ck-pc-amt { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--brown); font-variation-settings: var(--fraunces-text); }
.ck-pc-sub { font-size: 0.72rem; color: var(--muted); }
.ck-pays { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.ck-pay { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 7px; padding: 14px 10px; border: 1.5px solid var(--border); border-radius: var(--r); background: #fff; cursor: pointer; font-size: 0.82rem; font-weight: 600; color: var(--brown); transition: all .2s; }
.ck-pay i { font-size: 1.1rem; color: var(--caramel-dark); }
.ck-pay-logo { height: 30px; width: auto; max-width: 70px; object-fit: contain; }
.ck-pay:hover { border-color: var(--caramel-light); }
.ck-pay.active { border-color: var(--caramel); background: var(--accent-soft); }
.ck-secure { font-size: 0.76rem; color: var(--muted); margin-top: 14px; }
.ck-secure i { color: var(--green); margin-right: 5px; }
.ck-deposit-note { display: flex; align-items: flex-start; gap: 9px; margin-top: 16px; padding: 11px 14px; border-radius: var(--r); background: rgba(212,160,23,.08); border: 1px solid rgba(212,160,23,.2); font-size: 0.78rem; line-height: 1.5; color: #92400e; }
.ck-deposit-note i { color: #D4A017; flex-shrink: 0; margin-top: 1px; }
.ck-cgv { display: flex; align-items: flex-start; gap: 11px; margin-top: 14px; padding: 12px 14px; border: 1.5px solid var(--border); border-radius: var(--r); cursor: pointer; font-size: 0.8rem; line-height: 1.5; color: var(--muted); transition: border-color .2s, background .2s; }
.ck-cgv.on { border-color: var(--caramel); background: var(--accent-soft); }
.ck-cgv input { width: 17px; height: 17px; margin-top: 1px; accent-color: var(--caramel); cursor: pointer; flex-shrink: 0; }
.ck-cgv a { color: var(--caramel-dark); font-weight: 600; text-decoration: underline; }
.ck-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.ck-sum { position: sticky; top: 96px; background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 24px; }
.ck-sum h3 { font-size: 1.05rem; margin-bottom: 16px; }
.ck-sum-list { display: flex; flex-direction: column; gap: 12px; max-height: 260px; overflow-y: auto; margin-bottom: 16px; }
.ck-sum-it { display: flex; gap: 11px; align-items: center; }
.ck-sum-it img { width: 46px; height: 58px; object-fit: cover; border-radius: var(--r-sm); }
.ck-sum-it .nm { font-size: 0.82rem; font-weight: 600; color: var(--brown); text-decoration: none; cursor: pointer; display: inline-block; }
.ck-sum-it a.nm:hover { color: var(--caramel-dark); text-decoration: underline; }
.ck-sum-img { display: block; flex-shrink: 0; }
.ck-sum-it .mt { font-size: 0.72rem; color: var(--muted); }
.ck-sum-it .pr { margin-left: auto; font-size: 0.82rem; font-weight: 600; color: var(--brown); }
.ck-sum-rm { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; border: none; background: none; color: var(--light); cursor: pointer; display: grid; place-items: center; font-size: 0.78rem; transition: background .18s, color .18s; }
.ck-sum-rm:hover { background: var(--red-bg); color: var(--red); }
.ck-sum-lines { border-top: 1px solid var(--border); padding-top: 14px; display: flex; flex-direction: column; gap: 9px; margin-bottom: 14px; }
.ck-line { display: flex; justify-content: space-between; align-items: center; font-size: 0.86rem; color: var(--muted); }
.ck-line b { color: var(--brown); }
/* promo / affiliate code */
.ck-codes { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.ck-codes .ck-promo { margin-bottom: 0; }
.ck-deducts { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.ck-promo input:disabled { background: var(--green-bg); border-color: var(--green); color: var(--green); font-weight: 600; -webkit-text-fill-color: var(--green); opacity: 1; }
.ck-promo-ok:disabled { background: var(--green); border-color: var(--green); color: #fff; cursor: default; }
.ck-promo { display: flex; gap: 10px; align-items: stretch; margin-bottom: 12px; }
.ck-promo .form-control { flex: 1; }
.ck-promo-ok { width: 52px; flex-shrink: 0; border: 1.5px solid var(--cream-dark); border-radius: 50%; height: 48px; aspect-ratio: 1; background: #fff; color: var(--brown); font-weight: 700; font-size: 0.8rem; cursor: pointer; transition: all .2s; }
.ck-promo-ok:hover { background: var(--brown); color: var(--cream); border-color: var(--brown); }
.ck-discount { color: var(--green); font-weight: 600; margin-bottom: 12px; }
.ck-discount b { color: var(--green); }
.ck-discount i { margin-right: 6px; }
.ck-sum-total { border-top: 1px solid var(--border); padding-top: 14px; display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.ck-line.acompte { color: var(--brown); font-weight: 600; font-size: 0.84rem; }
.ck-line.acompte b { color: var(--brown); }
.ck-line.total { font-size: 1.05rem; color: var(--text); }
.ck-line.total b { font-family: var(--font-display); font-size: 1.7rem; color: var(--brown); font-variation-settings: var(--fraunces-display); }
.ck-reass { list-style: none; margin: 18px 0 0; display: flex; flex-direction: column; gap: 10px; }
.ck-reass li { font-size: 0.8rem; color: var(--muted); display: flex; align-items: center; gap: 9px; }
.ck-reass i { color: var(--green); font-size: 0.9rem; flex-shrink: 0; }
.ck-loyalty { margin: 18px auto 0; width: fit-content; display: flex; align-items: center; gap: 8px; background: var(--cream); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 8px 16px; font-size: 0.78rem; font-weight: 600; color: var(--brown); }
.ck-loyalty i { color: var(--caramel-dark); }
@media (max-width: 900px) { .ck { grid-template-columns: 1fr; } .ck-sum { position: static; } .ck-row2 { grid-template-columns: 1fr; } }

/* ════════ CONFIRMATION ════════ */
.conf { text-align: center; }
.conf-ic { width: 76px; height: 76px; border-radius: 50%; background: var(--green-bg); color: var(--green); display: grid; place-items: center; font-size: 1.9rem; margin: 0 auto 20px; }
.conf h1 { margin-bottom: 12px; }
.conf > p { max-width: 460px; margin: 0 auto 26px; }
.conf > p b { color: var(--brown); }
.conf-card { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px; text-align: left; display: flex; flex-direction: column; gap: 10px; max-width: 420px; margin: 0 auto 26px; }
.conf-steps { display: flex; justify-content: center; gap: 22px; flex-wrap: wrap; margin-bottom: 26px; }
.conf-step { font-size: 0.82rem; font-weight: 500; color: var(--brown); display: flex; align-items: center; gap: 7px; }
.conf-step i { color: var(--green); }
.conf-step.muted { color: var(--light); }
.conf-step.muted i { color: var(--cream-dark); }
.conf-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ════════ SUIVI ════════ */
.track-form { display: flex; gap: 12px; margin-bottom: 28px; }
.track-form .form-control { flex: 1; }
.track-form .btn { flex-shrink: 0; }
.track-result { background: #fff; border: 1px solid var(--border); border-radius: var(--r-lg); padding: 28px; }
.track-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding-bottom: 22px; border-bottom: 1px solid var(--border); margin-bottom: 8px; flex-wrap: wrap; }
.track-ref { font-family: var(--font-display); font-size: 1.3rem; font-weight: 800; color: var(--brown); font-variation-settings: var(--fraunces-text); }
.track-eta { font-size: 0.82rem; color: var(--muted); margin-top: 4px; }
.track-line { padding-top: 14px; }
.track-step { display: flex; gap: 16px; position: relative; padding-bottom: 26px; }
.track-step:not(:last-child)::before { content: ''; position: absolute; left: 21px; top: 44px; bottom: 0; width: 2px; background: var(--cream-dark); }
.track-step.done:not(:last-child)::before { background: var(--caramel); }
.track-dot { width: 44px; height: 44px; border-radius: 50%; background: var(--cream); color: var(--light); display: grid; place-items: center; flex-shrink: 0; border: 2px solid var(--cream-dark); z-index: 1; transition: all .2s; }
.track-step.done .track-dot { background: var(--caramel); color: #fff; border-color: var(--caramel); }
.track-step.active .track-dot { box-shadow: 0 0 0 5px var(--accent-soft); }
.track-info .t { font-size: 0.95rem; font-weight: 600; color: var(--light); }
.track-step.done .track-info .t { color: var(--brown); }
.track-info .d { font-size: 0.8rem; color: var(--muted); margin-top: 2px; }
.track-help { font-size: 0.84rem; color: var(--muted); margin-top: 8px; }

/* ── Toast ── */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(140%); background: var(--brown); color: var(--cream); padding: 13px 22px; border-radius: var(--r-pill); font-size: 0.85rem; font-weight: 500; box-shadow: var(--sh-lg); display: flex; align-items: center; gap: 10px; z-index: 100; transition: transform .35s var(--ease); }
.toast.show { transform: translateX(-50%) translateY(0); }
.toast i { color: var(--caramel-light); }

/* ════════ WHATSAPP FAB ════════ */
.wa-fab { display: flex; position: fixed; right: 18px; bottom: 18px; width: 56px; height: 56px; border-radius: 50%; background: var(--whatsapp); color: #fff; align-items: center; justify-content: center; font-size: 1.6rem; box-shadow: 0 8px 24px rgba(37,211,102,.4); z-index: 65; animation: waPulse 2.6s ease-in-out infinite; transition: transform .2s; }
.wa-fab:hover { transform: scale(1.08); }
@keyframes waPulse { 0%, 100% { box-shadow: 0 8px 24px rgba(37,211,102,.4); } 50% { box-shadow: 0 8px 32px rgba(37,211,102,.6); } }
@media (max-width: 900px) { .wa-fab { right: 14px; bottom: 14px; } }
@media (prefers-reduced-motion: reduce) { .wa-fab { animation: none; } }

/* ════════ RESPONSIVE POLISH ════════ */
@media (max-width: 1024px) {
}
@media (max-width: 760px) {
  :root { --section-py: clamp(40px, 9vw, 60px); }
  .hd-promo { font-size: 0.64rem; padding: 6px 12px; }
  .hero-text h1 { font-size: clamp(2.1rem, 9vw, 3rem); }
  .hero-stats { gap: 22px; margin-top: 32px; }
  .hero-stat .n { font-size: 1.6rem; }
  .sec-top { gap: 12px; }
  .rev-rate { text-align: left; }
  .pc-brand { font-size: 0.58rem; }
  .pc-name { font-size: 0.84rem; }
  .conf-steps { gap: 12px; }
  .cd { width: 100vw; }
}
@media (max-width: 460px) {
  .hero-btns .btn, .cta-btns .btn { width: 100%; }
  .hero-btns, .cta-btns { width: 100%; }
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .ft-bot { flex-direction: column; gap: 8px; }
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .news-form { flex-direction: column; }
  .news-form .btn { width: 100%; }
  .track-form { flex-direction: column; }
  .track-form .btn { width: 100%; }
}

/* ════════ MOBILE TEXT & INPUTS POLISH ════════ */
@media (max-width: 600px) {
  /* ≥16px : évite le zoom automatique d'iOS au focus des champs */
  .form-control, input.form-control, textarea.form-control, select.form-control, .hd-search input { font-size: 16px; }
  .sec-head h2, .page-head h1 { font-size: clamp(1.5rem, 6.5vw, 2rem); line-height: 1.15; text-wrap: balance; }
  .sec-head p, .page-head p { font-size: 0.88rem; line-height: 1.6; }
  .eyebrow { font-size: 0.64rem; }
  .pc-price, .pc-now { font-size: 0.92rem; }
  .breadcrumb { font-size: 0.74rem; flex-wrap: wrap; }
  .btn { font-size: 0.9rem; }
  .btn-lg { padding: 13px 20px; }
  /* cibles tactiles ≥ 44px */
  .hd-ico-btn, .hd-burger, .pc-fav, .qty-btn { min-width: 44px; min-height: 44px; }
}
@media (max-width: 380px) {
  .sec-head h2, .page-head h1 { font-size: 1.4rem; }
  .pc-name { font-size: 0.8rem; }
  .hero-text h1 { font-size: clamp(1.9rem, 9vw, 2.4rem); }
}

/* ════════ BARRE DE NAVIGATION RAPIDE (tablette & mobile) ════════ */
.qnav { display: none; }
@media (max-width: 1024px) {
  .qnav {
    display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    background: rgba(253,248,242,.96); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid var(--border);
    padding: 6px 4px calc(6px + env(safe-area-inset-bottom, 0px));
    box-shadow: 0 -6px 20px rgba(45,21,5,.08);
  }
  .qnav-i {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
    padding: 6px 2px; border: none; background: none; cursor: pointer; text-decoration: none;
    color: var(--muted); font-family: var(--font-body); font-size: 0.62rem; font-weight: 600;
    letter-spacing: .01em; position: relative; min-height: 48px; transition: color .15s;
  }
  .qnav-i i { font-size: 1.12rem; }
  .qnav-i.active { color: var(--caramel-dark); }
  .qnav-i:active { transform: scale(.94); }
  .qnav-badge {
    position: absolute; top: 2px; left: 50%; margin-left: 4px;
    min-width: 16px; height: 16px; padding: 0 4px; border-radius: 9px;
    background: var(--caramel); color: #fff; font-size: 0.6rem; font-weight: 800;
    display: flex; align-items: center; justify-content: center; line-height: 1;
    box-shadow: 0 1px 4px rgba(45,21,5,.3);
  }
  /* éviter que le contenu / FAB ne soit masqué par la barre */
  body { padding-bottom: calc(60px + env(safe-area-inset-bottom, 0px)); }
  .wa-fab { bottom: calc(72px + env(safe-area-inset-bottom, 0px)) !important; }
}
