/* ===========================================================
   Le Panier Naturel Zevlo™ — page de vente
   Couleurs : principale #ffffff · secondaire #ededed · CTA #538125
   =========================================================== */

:root{
  --white:#ffffff;
  --gray:#ededed;
  --gray-2:#f6f6f6;
  --cta:#538125;
  --cta-dark:#456d1f;
  --ink:#1c1c1c;
  --ink-soft:#3a3a3a;
  --muted:#6b6b6b;
  --line:#e3e3e3;
  --promo:#d23a2a;          /* prix promo rouge */
  --dark:#222222;           /* footer + sticky bar (sombre, pas noir pur) */
  --dark-2:#2b2b2b;
  --star:#f5a623;
  --radius:14px;
  --maxw:1180px;
  --pad:24px;
  --ff: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;overflow-x:clip;max-width:100%;}
body{
  font-family:var(--ff);
  color:var(--ink);
  background:var(--white);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
h1,h2,h3,h4{margin:0;line-height:1.15;letter-spacing:-0.01em;font-weight:800;}
p{margin:0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);}

/* ---- placeholder image style (templates bruts) ---- */
.ph{
  width:100%;height:100%;object-fit:cover;background:#bdbdbd;display:block;
}
.ratio{position:relative;width:100%;overflow:hidden;background:#bdbdbd;border-radius:12px;}
.ratio>img,.ratio>video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ratio.sq{aspect-ratio:1/1;}
.ratio.r43{aspect-ratio:4/3;}
.ratio.r54{aspect-ratio:5/4;}
.ratio.r11{aspect-ratio:1/1;}

/* ===========================================================
   0. Announcement bar + 1. Header  (sticky en haut)
   =========================================================== */
.topbar{position:sticky;top:0;z-index:60;}
.announce{
  background:var(--dark);color:#fff;overflow:hidden;white-space:nowrap;
  font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  height:38px;display:flex;align-items:center;
}
.announce .track{display:inline-flex;gap:48px;padding-left:48px;animation:marquee 28s linear infinite;}
.announce .track span{display:inline-flex;align-items:center;gap:10px;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

.header{
  background:var(--white);border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  padding:14px var(--pad);position:relative;
}
.header .nav-left{display:flex;gap:26px;font-size:14px;font-weight:600;color:var(--ink-soft);}
.header .nav-left a:hover{color:var(--cta);}
.logo{
  grid-column:2;text-align:center;font-weight:800;font-size:26px;letter-spacing:.18em;
  color:var(--ink);
}
.header .nav-right{display:flex;justify-content:flex-end;gap:18px;}
.icon-btn{background:none;border:0;padding:6px;color:var(--ink);display:inline-flex;}
.icon-btn svg{width:22px;height:22px;}
.header .hamb,.header .m-search,.header .m-cart{display:none;}

/* ===========================================================
   2. Section produit (hero + achat)
   =========================================================== */
.product{padding:34px 0 10px;}
.product-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:start;}

/* galerie */
.gallery{position:sticky;top:96px;}
.gallery-main{position:relative;border-radius:16px;overflow:hidden;background:#bdbdbd;}
.gallery-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.gallery-track::-webkit-scrollbar{display:none;}
.gallery-track .slide{min-width:100%;scroll-snap-align:center;}
.gallery-track .slide .ratio{border-radius:0;aspect-ratio:1/1;}
.gallery-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.92);
  box-shadow:0 2px 10px rgba(0,0,0,.18);display:grid;place-items:center;color:var(--ink);
}
.gallery-arrow svg{width:20px;height:20px;}
.gallery-arrow.prev{left:14px;} .gallery-arrow.next{right:14px;}
.gallery-dots{display:flex;gap:6px;justify-content:center;margin-top:10px;}
.gallery-dots i{width:7px;height:7px;border-radius:50%;background:#cfcfcf;transition:.2s;}
.gallery-dots i.on{background:var(--ink);width:22px;border-radius:4px;}
.thumbs{display:flex;gap:10px;margin-top:14px;overflow-x:auto;padding-bottom:4px;}
.thumbs button{flex:0 0 auto;width:72px;height:72px;border-radius:10px;overflow:hidden;border:2px solid transparent;background:#bdbdbd;padding:0;}
.thumbs button.on{border-color:var(--ink);}
.thumbs button.is-video{position:relative;}
.thumbs button.is-video .tb-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.28);color:#fff;}
.thumbs button.is-video .tb-play svg{width:22px;height:22px;}

/* infos */
.seller{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink-soft);margin-bottom:14px;}
.seller .av{width:34px;height:34px;border-radius:50%;background:#bdbdbd;flex:0 0 auto;position:relative;overflow:hidden;}
.seller .av img{width:100%;height:100%;object-fit:cover;}
.seller b{color:var(--ink);}
.p-title{font-size:30px;font-weight:800;line-height:1.2;margin-bottom:18px;}
.rating{display:flex;align-items:center;gap:10px;margin-bottom:20px;font-size:14.5px;color:var(--ink-soft);}
.stars{color:var(--star);letter-spacing:1px;font-size:17px;}
.bullets{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:14px;}
.bullets li{display:flex;gap:12px;font-size:15px;color:var(--ink-soft);line-height:1.45;}
.bullets .ck{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;margin-top:1px;}
.bullets .ck svg{width:13px;height:13px;}
.bullets b{color:var(--ink);font-weight:700;}

.price{display:flex;align-items:baseline;gap:14px;margin-bottom:14px;}
.price .old{color:var(--muted);text-decoration:line-through;font-size:20px;font-weight:600;}
.price .now{color:var(--promo);font-size:34px;font-weight:800;}
.rarity{display:flex;gap:10px;align-items:flex-start;font-size:15px;line-height:1.45;color:var(--ink-soft);margin-bottom:22px;}
.rarity svg{width:18px;height:18px;color:var(--cta);flex:0 0 auto;margin-top:2px;}
.rarity b{color:var(--ink);font-weight:700;}
.rarity.cta-note{margin:14px 0 0;justify-content:center;text-align:center;}
.pulse-dot{width:11px;height:11px;border-radius:50%;background:#e98a1f;flex:0 0 auto;margin-top:4px;box-shadow:0 0 0 0 rgba(233,138,31,.5);animation:pulseDot 1.5s ease-in-out infinite;}
@keyframes pulseDot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(233,138,31,.45);}50%{opacity:.5;box-shadow:0 0 0 5px rgba(233,138,31,0);}}
@media (prefers-reduced-motion: reduce){.pulse-dot{animation:none;}}

.field-label{font-size:14px;font-weight:700;margin-bottom:10px;}
.sizes{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap;}
.size-opt{
  flex:1 1 0;min-width:150px;border:1.5px solid var(--line);border-radius:12px;padding:12px 16px;background:#fff;
  text-align:left;transition:.18s;display:flex;flex-direction:column;gap:2px;
}
.size-opt .s-name{font-weight:700;font-size:15px;}
.size-opt .s-sub{font-size:12.5px;color:var(--muted);}
.size-opt .s-price{font-size:15px;font-weight:700;margin-top:4px;}
.size-opt.on{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink);}
.stock{display:flex;gap:9px;align-items:center;font-size:14px;color:var(--ink-soft);margin:6px 0 26px;}
.stock .dot{width:10px;height:10px;border-radius:50%;background:#e98a1f;flex:0 0 auto;}
.stock b{color:var(--ink);}

/* bundle */
.bundle-title{text-align:center;font-size:17px;font-weight:800;letter-spacing:.01em;margin:8px 0 16px;color:var(--ink);}
.bundle-title span{display:inline-block;padding:0 6px;}
.bundles{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;}
.bundle{
  position:relative;border:1.5px solid var(--line);border-radius:14px;background:var(--gray-2);
  padding:18px 20px;transition:.18s;cursor:pointer;
}
.bundle.on{border-color:var(--ink);background:#fff;box-shadow:0 0 0 1px var(--ink);}
.bundle-row{display:flex;align-items:center;gap:14px;}
.bundle .radio{width:22px;height:22px;border-radius:50%;border:2px solid #c4c4c4;flex:0 0 auto;display:grid;place-items:center;}
.bundle.on .radio{border-color:var(--ink);}
.bundle.on .radio::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--ink);}
.bundle .b-main{flex:1;}
.bundle .b-name{font-weight:800;font-size:18px;}
.bundle .b-desc{font-size:13.5px;color:var(--muted);}
.bundle .b-price{text-align:right;white-space:nowrap;}
.bundle .b-price .now{font-weight:800;font-size:19px;}
.bundle .b-price .old{display:block;color:var(--muted);text-decoration:line-through;font-size:13px;}
.popular{position:absolute;top:-12px;right:18px;background:var(--cta);color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;padding:5px 12px;border-radius:8px;}
.bundle .selectors{margin-top:0;max-height:0;opacity:0;overflow:hidden;display:flex;flex-direction:column;gap:10px;transition:max-height .35s ease, opacity .28s ease, margin-top .35s ease;}
.bundle.on .selectors{margin-top:14px;max-height:320px;opacity:1;}
.bundle .selrow{display:flex;align-items:center;gap:10px;}
.bundle .selrow .tag{font-size:13px;font-weight:700;color:var(--muted);width:24px;}
.bundle select{
  flex:1;padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:14px;font-weight:600;color:var(--ink);
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:16px;
}
.bundle .sel-label{font-size:12.5px;color:var(--muted);font-weight:600;}

/* CTA */
.btn-cta{
  width:100%;background:var(--cta);color:#fff;border:0;border-radius:40px;
  padding:19px;font-size:17px;font-weight:800;letter-spacing:.01em;transition:.18s;
  box-shadow:0 6px 18px rgba(83,129,37,.28);
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.btn-cta .cta-arrow{width:20px;height:20px;flex:0 0 auto;transition:transform .2s ease;}
.btn-cta .cta-label{white-space:nowrap;}
.btn-cta:hover .cta-arrow{transform:translateX(4px);}
.btn-cta.done .cta-arrow{display:none;}
.btn-cta:hover{background:var(--cta-dark);}
.btn-cta:active{transform:scale(.985);}
.btn-cta.done{background:var(--cta-dark);}

.payments{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-top:18px;}
.pay{height:26px;min-width:38px;padding:0 7px;border-radius:5px;background:#fff;border:1px solid #e4e4e4;
  display:grid;place-items:center;font-size:9px;font-weight:800;letter-spacing:.02em;color:#444;text-transform:uppercase;}

/* ===========================================================
   2c. Mini-carrousel témoignages
   =========================================================== */
.testi{padding:30px 0 6px;position:relative;}
.testi-viewport{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.testi-viewport::-webkit-scrollbar{display:none;}
.testi-track{display:flex;}
.testi-card{
  min-width:100%;display:flex;gap:18px;align-items:center;padding:6px 50px;scroll-snap-align:center;
}
.testi-card .av{flex:0 0 96px;}
.testi-card .av .ratio{border-radius:12px;}
.testi-card .body .stars{font-size:16px;}
.testi-card .body .name{font-weight:800;margin:6px 0 2px;display:flex;align-items:center;gap:7px;}
.testi-card .verified{font-size:11px;color:var(--cta);font-weight:700;display:inline-flex;align-items:center;gap:3px;}
.testi-card .body p{font-size:15px;color:var(--ink-soft);line-height:1.5;}
.testi-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:0 2px 8px rgba(0,0,0,.08);display:grid;place-items:center;z-index:3;}
.testi-arrow svg{width:18px;height:18px;}
.testi-arrow.prev{left:0;} .testi-arrow.next{right:0;}

/* ===========================================================
   3. Bandeau picto avantages (fond gris)
   =========================================================== */
.perks{background:var(--gray);padding:54px 0;margin-top:34px;}
.perks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px 30px;}
.perk{text-align:center;}
.perk .ic{font-size:30px;line-height:1;margin-bottom:14px;}
.perk h4{font-size:16px;margin-bottom:8px;}
.perk p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;}
.perk.center{grid-column:1/-1;max-width:300px;margin:6px auto 0;}
.perks-bar{display:none;}

/* ===========================================================
   4. Galerie "Ces minous adorent leur panier"
   =========================================================== */
.lovers{padding:64px 0;}
.section-title{text-align:center;font-size:30px;font-weight:800;margin-bottom:36px;}
.lovers-wrap{position:relative;}
.lovers-viewport{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.lovers-viewport::-webkit-scrollbar{display:none;}
.lovers-track{display:flex;gap:18px;}
.lovers-track .cell{flex:0 0 calc((100% - 36px)/3);scroll-snap-align:start;}
.lovers-track .cell .ratio{border-radius:14px;}
.lovers-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:0 3px 12px rgba(0,0,0,.12);display:grid;place-items:center;z-index:3;}
.lovers-arrow svg{width:20px;height:20px;}
.lovers-arrow.prev{left:-10px;} .lovers-arrow.next{right:-10px;}

/* ===========================================================
   5. Data Doesn't Lie / Les chiffres
   =========================================================== */
.stats{padding:20px 0 60px;}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.stat{border:1.5px dashed #cfcfcf;border-radius:12px;padding:34px 26px;text-align:center;}
.stat .num{font-size:40px;font-weight:800;margin-bottom:14px;}
.stat p{font-size:14px;color:var(--ink-soft);line-height:1.5;}
.stat .src{font-style:italic;font-size:12.5px;color:var(--muted);margin-top:10px;}

/* ===========================================================
   6/7/8/9. Image + texte (split sections)
   =========================================================== */
.split{padding:46px 0;}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
.split.rev .split-grid{direction:rtl;}
.split.rev .split-grid>*{direction:ltr;}
.split .media .ratio{border-radius:14px;}
.split .eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;}
.split h2{font-size:30px;margin-bottom:18px;}
.split .lede{font-size:15px;color:var(--ink-soft);line-height:1.6;margin-bottom:16px;}
.split .lede b{color:var(--ink);}
.split .feat{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px;}
.split .feat li{display:flex;gap:12px;font-size:14.5px;color:var(--ink-soft);line-height:1.5;}
.split .feat .ck{flex:0 0 auto;width:20px;height:20px;color:var(--cta);margin-top:2px;}
.split .feat b{color:var(--ink);display:block;}

/* ===========================================================
   10. FAQ
   =========================================================== */
.faq{padding:54px 0;}
.faq-head{text-align:center;margin-bottom:8px;}
.faq-head h2{font-size:30px;}
.faq-all{display:block;text-align:center;color:var(--cta);font-weight:700;font-size:14px;margin-bottom:26px;}
.faq-list{max-width:840px;margin:0 auto;}
.faq-item{border-top:1px solid var(--line);}
.faq-item:last-child{border-bottom:1px solid var(--line);}
.faq-q{width:100%;background:none;border:0;display:flex;align-items:center;gap:14px;padding:20px 4px;text-align:left;font-size:16px;font-weight:600;color:var(--ink);}
.faq-q .heart{flex:0 0 auto;width:22px;height:22px;color:var(--ink);}
.faq-q .q-text{flex:1;}
.faq-q .chev{flex:0 0 auto;width:18px;height:18px;transition:transform .25s;color:var(--muted);}
.faq-item.open .chev{transform:rotate(180deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a .inner{padding:0 4px 22px 40px;font-size:14.5px;color:var(--ink-soft);line-height:1.6;}
.faq-a .inner ul{margin:10px 0 0;padding-left:18px;}
.faq-a .inner li{margin-bottom:8px;}
.faq-a .inner b{color:var(--ink);}

/* ===========================================================
   11/12. Benefits + Guarantee (3 cols dashed)
   =========================================================== */
.cols3{padding:50px 0;}
.cols3 h2{text-align:center;font-size:30px;margin-bottom:38px;}
.cols3-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.cell3{border:1.5px dashed #cfcfcf;border-radius:12px;padding:38px 30px;text-align:center;}
.cell3 .ic{width:46px;height:46px;margin:0 auto 18px;color:var(--ink);}
.cell3 .ic svg{width:100%;height:100%;}
.cell3 h4{font-size:17px;margin-bottom:12px;}
.cell3 p{font-size:14px;color:var(--ink-soft);line-height:1.55;}

/* ===========================================================
   13. Avis clients (masonry)
   =========================================================== */
.reviews{padding:40px 0 60px;}
.reviews-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap;}
.reviews-bar .lhs{display:flex;align-items:center;gap:12px;}
.reviews-bar .stars{font-size:20px;}
.reviews-bar .count{font-weight:700;font-size:16px;white-space:nowrap;}
.reviews-bar .rhs{display:flex;gap:10px;align-items:center;}
.btn-ghost{border:1px solid var(--line);background:#fff;border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:700;}
.filter-btn{border:1px solid var(--line);background:#fff;border-radius:8px;width:40px;height:38px;display:grid;place-items:center;}
.filter-btn svg{width:18px;height:18px;}
.masonry{column-count:4;column-gap:18px;}
.rev-card{break-inside:avoid;margin-bottom:18px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;}
.rev-card .ph-media .ratio{border-radius:0;}
.rev-card .rc-body{padding:14px 16px 18px;}
.rev-card .rc-name{display:flex;align-items:center;gap:6px;font-weight:800;font-size:14.5px;}
.rev-card .rc-verified{font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:3px;font-weight:600;}
.rev-card .rc-verified svg{width:13px;height:13px;color:var(--cta);}
.rev-card .stars{font-size:14px;margin:5px 0 8px;}
.rev-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;}
.rev-card .rc-type{margin-top:12px;font-size:11.5px;color:var(--muted);}
.rev-card .rc-type b{color:var(--ink-soft);display:block;font-weight:700;font-size:11px;text-transform:none;}
.reviews-more{text-align:center;margin-top:24px;display:none;}

/* ===========================================================
   14. Footer
   =========================================================== */
.footer{background:var(--dark);color:#cfcfcf;padding:60px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.4fr .8fr 1fr 1.1fr;gap:40px;}
.footer h5{color:#fff;font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:800;margin-bottom:18px;}
.footer p,.footer li,.footer a{font-size:13.5px;line-height:1.7;color:#bdbdbd;}
.footer .about p{margin-bottom:14px;}
.footer .about b{color:#fff;}
.footer ul{list-style:none;padding:0;margin:0;}
.footer ul li{margin-bottom:8px;}
.footer ul a:hover{color:#fff;}
.news-form{display:flex;border-bottom:1px solid #555;padding-bottom:6px;margin-bottom:14px;max-width:280px;}
.news-form input{flex:1;background:none;border:0;color:#fff;font-family:inherit;font-size:14px;outline:none;}
.news-form input::placeholder{color:#9a9a9a;}
.news-form button{background:none;border:0;color:#fff;font-size:18px;}
.socials{display:flex;gap:12px;margin-top:18px;}
.socials a{width:34px;height:34px;border-radius:50%;border:1px solid #555;display:grid;place-items:center;}
.socials svg{width:16px;height:16px;}
.footer-bottom{border-top:1px solid #3a3a3a;margin-top:50px;padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;}
.footer-bottom .selrow{display:flex;gap:14px;}
.footer-bottom select{background:#2e2e2e;border:1px solid #4a4a4a;color:#cfcfcf;border-radius:6px;padding:7px 10px;font-family:inherit;font-size:12.5px;}
.footer-bottom .copy{font-size:12.5px;color:#9a9a9a;}
.footer-bottom .payments .pay{background:#fff;}

/* ===========================================================
   15. Sticky Add to Cart
   =========================================================== */
.sticky-cart{
  position:fixed;left:0;right:0;bottom:0;z-index:80;background:#fff;border-top:1px solid var(--line);
  transform:translateY(110%);transition:transform .3s ease;
  padding:12px var(--pad);padding-bottom:calc(12px + env(safe-area-inset-bottom));
  box-shadow:0 -6px 24px rgba(0,0,0,.12);
}
.sticky-cart.show{transform:translateY(0);}
.sticky-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:16px;min-height:64px;}
.sticky-cart .thumb{width:52px;height:52px;border-radius:8px;overflow:hidden;background:#bdbdbd;flex:0 0 auto;}
.sticky-cart .sc-info{flex:1;min-width:0;}
.sticky-cart .sc-name{color:var(--ink);font-weight:800;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sticky-cart .sc-price{display:flex;gap:9px;align-items:baseline;}
.sticky-cart .sc-price .old{color:var(--muted);text-decoration:line-through;font-size:13px;}
.sticky-cart .sc-price .now{color:var(--ink);font-weight:800;font-size:16px;}
.sticky-cart select{
  background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 34px 11px 14px;font-family:inherit;font-weight:700;font-size:14px;color:var(--ink);
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:15px;flex:0 0 auto;
}
.sticky-cart .btn-cta{width:auto;padding:14px 30px;flex:0 0 auto;box-shadow:none;}

/* ===========================================================
   Responsive — mobile
   =========================================================== */
@media (max-width:980px){
  .perks-grid{grid-template-columns:repeat(2,1fr);}
  .masonry{column-count:3;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:760px){
  :root{--pad:18px;}
  /* sur mobile la galerie n'est pas sticky : on bloque tout débordement horizontal */
  html,body{overflow-x:hidden;}
  .product-grid{min-width:0;}
  .gallery,.buybox{min-width:0;max-width:100%;}
  .header{grid-template-columns:auto 1fr auto;padding:12px var(--pad);}
  .header .nav-left{display:none;}
  .header .nav-right .desk-only{display:none;}
  .header .hamb{display:inline-flex;}
  .header .m-search{display:inline-flex;}
  .header .left-icons{display:flex;gap:10px;align-items:center;}
  .header .m-cart{display:inline-flex;}
  .logo{font-size:22px;}

  .product{padding:0 0 10px;}
  .product-grid{grid-template-columns:1fr;gap:26px;}
  .gallery{position:static;}
  /* galerie pleine largeur, aucune marge latérale, sur mobile */
  .gallery-main{border-radius:0;margin:0 calc(-1*var(--pad));max-width:none;}
  .gallery-dots{padding:0 var(--pad);}
  .gallery .thumbs{margin:0 calc(-1*var(--pad));padding:14px var(--pad) 4px;scrollbar-width:none;-ms-overflow-style:none;}
  .gallery .thumbs::-webkit-scrollbar{display:none;}
  .gallery-main + .gallery-dots{margin-top:12px;}
  .p-title{font-size:24px;}
  .section-title,.split h2,.cols3 h2,.faq-head h2,.stat .num{}
  .section-title{font-size:24px;}
  .stats-grid{grid-template-columns:1fr;}
  .split-grid{grid-template-columns:1fr;gap:24px;}
  .split-grid .media{order:-1;}
  .split.rev .split-grid{direction:ltr;}
  .split h2{font-size:24px;}
  .testi-card{padding:6px 36px;flex-direction:column;text-align:center;}
  .testi-card .av{flex:0 0 auto;width:130px;}
  .lovers-track .cell{flex:0 0 calc((100% - 18px)/2);}
  .lovers-arrow.prev{left:0;} .lovers-arrow.next{right:0;}
  .cols3-grid{grid-template-columns:1fr;}
  .perks-grid{
    display:flex;grid-template-columns:none;gap:0;
    overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;margin:0 calc(-1*var(--pad));padding:6px var(--pad) 0;
  }
  .perks-grid::-webkit-scrollbar{display:none;}
  .perks .perk{flex:0 0 100%;scroll-snap-align:center;padding:18px 14px;}
  .perks .perk.center{max-width:none;margin:0;}
  .perks-bar{display:block;width:140px;height:4px;border-radius:99px;background:#d6d6d6;margin:20px auto 0;overflow:hidden;}
  .perks-bar span{display:block;height:100%;width:20%;border-radius:99px;background:var(--ink);will-change:transform;}
  .masonry{column-count:2;column-gap:12px;}
  .masonry.collapsed .rev-card:nth-child(n+7){display:none;}
  .reviews-more{display:block;}
  .rev-card{margin-bottom:12px;}
  .footer-grid{grid-template-columns:1fr;gap:30px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .sizes{flex-direction:column;}
  .size-opt{min-width:0;}
  .sticky-inner{gap:10px;}
  .sticky-cart .thumb{display:none;}
  .sticky-cart .sc-name{font-size:13px;}
  .sticky-cart .btn-cta{padding:13px 18px;font-size:14px;}
  .sticky-cart select{padding:11px 30px 11px 12px;font-size:13px;}
  .section-title{font-size:24px;}
}
@media (max-width:420px){
  .testi-card{padding:6px 30px;}
  .lovers-track .cell{flex:0 0 calc((100% - 18px)/1.25);}
}
