/* ================================================================
   PM Product Page — Premiere Manche
   Pixel-perfect adaptation of product-desktop.html + product-mobile.html
   Loaded only on page.page_name == 'product'.
   Inherits CSS variables from pm-global.css (--bg, --dk, --gold, --fd, --fb, --fi, --g, --mw, --nav-h, --banner-h …).
   ================================================================ */

/* ── PRODUCT-PAGE LOCAL TOKENS ─────────────────────────────────── */
.pm-prod {
  --bg:        #FFFFFF;          /* product page: pure white per client request */
  --pp-panel:  #F2EFE8;
  --pp-bg2:    #EDEAE2;
  --pp-clay:   #B84A2E;
  --pp-tr:     .28s cubic-bezier(.25,.1,.25,1);
  --atc-h-mob: 68px;
  font-family: var(--fb);
  color: var(--text);
}

/* Hide native PrestaShop product chrome we replace with our own UI */
.pm-prod .images-container,
.pm-prod .product-cover,
.pm-prod .js-qv-mask,
.pm-prod .productimagesmobile,
.pm-prod .product-additional-info > .product-additional-info,
.pm-prod .product-minimal-quantity:empty { display: none !important; }

/* Hide native PS variant select once our tiles are built (kept for form sync).
   IMPORTANT: Use position/visibility hiding instead of display:none because
   PS core.js uses jQuery delegated 'change' events that won't fire on hidden elements. */
.pm-prod .product-variants .form-control-select.is-pm-hidden,
.pm-prod .product-variants ul.is-pm-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  padding: 0 !important;
  margin: -1px !important;
}

/* Hide the native ATC button: we render a custom one inside .pp-actions */
.pm-prod .product-add-to-cart .add { display: none !important; }
.pm-prod .product-add-to-cart .control-label.quantty { display: none !important; }
.pm-prod .product-add-to-cart .product-quantity { display: none !important; }

/* ══════════════════════════════════════════
   1. WRAPPER + PRODUCT ZONE (DESKTOP MOSAIC)
══════════════════════════════════════════ */
/* Remove parent container padding/margins so product grid spans full viewport width */
body#product #content-wrapper { padding: 0 !important; }
body#product .full-container > .row { margin-left: 0; margin-right: 0; }

.pm-prod {
  background: var(--bg);
  overflow-x: clip;
}

.pp-zone {
  max-width: var(--mw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr clamp(360px, 34vw, 540px);
  align-items: start;
  gap: 0;
}

/* ── LEFT COLUMN: breadcrumb + gallery ── */
.pp-left { display: flex; flex-direction: column; }

.pp-bc {
  display: flex;
  align-items: center;
  gap: 7px;
  font: 300 9px/1 var(--fb);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 12px 14px 10px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .5s .1s, transform .5s .1s;
}
.pp-bc.in { opacity: 1; transform: translateY(0); }
.pp-bc a { color: var(--muted); transition: color .2s; }
.pp-bc a:hover { color: var(--text); }
.pp-bc__sep { opacity: .28; }
.pp-bc__cur { color: var(--text); }

/* ── DESKTOP GALLERY MOSAIC ── */
.gallery {
  display: flex;
  flex-direction: column;
  gap: 3px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .7s .05s, transform .7s .05s;
}
.gallery.in { opacity: 1; transform: translateY(0); }
.gallery__row { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; }
.gallery__photo {
  position: relative;
  overflow: hidden;
  cursor: zoom-in;
  background: #ffffff;
  aspect-ratio: 2/3;
}
.gallery__photo--full { aspect-ratio: 3/4; }
.gallery__photo img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top center;
  display: block;
  transition: transform .65s cubic-bezier(.25,.46,.45,.94);
}
.gallery__photo:hover img { transform: scale(1.03); }
.gallery__photo-n {
  position: absolute;
  bottom: 10px; right: 12px;
  z-index: 2;
  pointer-events: none;
  font: 300 8px/1 var(--fb);
  letter-spacing: .14em;
  color: rgba(255,255,255,.5);
}

/* ── MOBILE GALLERY SWIPER (hidden on desktop) ── */
.gallery-mob { display: none; }

/* ══════════════════════════════════════════
   2. PURCHASE PANEL (RIGHT, STICKY)
══════════════════════════════════════════ */
.purchase {
  position: sticky;
  top: calc(var(--banner-h) + var(--nav-h));
  height: calc(100vh - var(--banner-h) - var(--nav-h));
  overflow-y: auto;
  scrollbar-width: none;
  align-self: start;
  background: var(--pp-panel);
  border-left: 1px solid var(--border);
  padding: clamp(20px, 2.2vw, 36px) clamp(24px, 3.8vw, 56px) clamp(24px, 2.8vw, 48px);
  opacity: 0;
  transform: translateX(16px);
  transition: opacity .7s .15s, transform .7s .15s;
  display: flex;
  flex-direction: column;
}
.purchase > * {
  flex-shrink: 0;
}
.purchase.in { opacity: 1; transform: translateX(0); }
.purchase::-webkit-scrollbar { display: none; }

.pp-cat {
  font: 300 9px/1 var(--fb);
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 16px;
}
.pp-name {
  font-family: var(--fd);
  font-size: clamp(28px, 2.2vw, 44px);
  letter-spacing: .03em;
  text-transform: uppercase;
  color: var(--dk);
  line-height: .88;
  margin-bottom: 12px;
}
.pp-rule { width: 32px; height: 1px; background: var(--gold); margin-bottom: 14px; }
.pp-desc {
  font: 300 italic 12px/1.65 var(--fi);
  color: var(--muted);
  margin-bottom: 16px;
  /* Clamp long DB descriptions on desktop so ATC stays above fold */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.pp-desc p {
  margin: 0 0 8px 0;
}
.pp-desc p:last-child {
  margin-bottom: 0;
}
.pp-sub {
  font: 300 italic 13px/1.4 var(--fi);
  color: var(--muted);
  margin-bottom: 10px;
}

/* Stars */
.pp-stars { display: flex; align-items: center; gap: 4px; margin-bottom: 14px; }
.pp-stars svg { width: 9px; height: 9px; fill: var(--dk); }
.pp-stars__link {
  margin-left: 8px;
  font: 300 9.5px/1 var(--fb);
  letter-spacing: .08em;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  transition: color var(--pp-tr), border-color var(--pp-tr);
}
.pp-stars__link:hover { color: var(--dk); border-color: var(--dk); }

/* Price */
.pp-price-row { display: flex; align-items: baseline; gap: 12px; margin-bottom: 10px; flex-wrap: wrap; }
.pp-price { font-family: var(--fd); font-size: 28px; letter-spacing: .03em; color: var(--dk); }
.pp-price-old { font: 300 14px/1 var(--fb); color: var(--muted); text-decoration: line-through; }
.pp-discount-badge {
  font: 400 9px/1 var(--fb); letter-spacing: .14em; text-transform: uppercase;
  color: #fff; background: var(--pp-clay); padding: 4px 8px;
}
.pp-stock-badge {
  font: 300 9px/1 var(--fb); letter-spacing: .14em; text-transform: uppercase;
  color: var(--pp-clay); display: flex; align-items: center; gap: 4px;
}
.pp-stock-badge::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--pp-clay); flex-shrink: 0;
}
.pp-stock-badge--available {
  color: #3b7a57 !important;
}
.pp-stock-badge--available::before {
  background: #3b7a57 !important;
}
.pp-stock-badge--oos {
  color: var(--muted) !important;
}
.pp-stock-badge--oos::before {
  background: var(--muted) !important;
}
.pp-ref {
  font: 300 9px/1 var(--fb); letter-spacing: .1em; text-transform: uppercase;
  color: var(--muted); opacity: .55; margin-bottom: 22px;
}

/* QP badge */
.pp-qp-badge {
  display: inline-flex; align-items: center; gap: 5px;
  border: 1px solid var(--gold); padding: 5px 10px;
  font: 400 8px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase;
  color: var(--gold); background: transparent; cursor: pointer;
  transition: background .2s, color .2s; margin-bottom: 14px;
}
.pp-qp-badge:hover { background: var(--gold); color: #fff; }
.pp-qp-badge svg { width: 9px; height: 9px; fill: var(--gold); stroke: none; flex-shrink: 0; transition: fill .2s; }
.pp-qp-badge:hover svg { fill: #fff; }

/* Separator */
.pp-sep { height: 1px; background: var(--border); margin: 18px 0; }

/* Size */
.pp-sz-hd { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.pp-lbl { font: 400 10px/1 var(--fb); letter-spacing: .18em; text-transform: uppercase; color: var(--dk); }
.pp-guide-btn {
  display: flex; align-items: center; gap: 4px;
  font: 300 9px/1 var(--fb); letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); border-bottom: 1px solid transparent; cursor: pointer;
  transition: color var(--pp-tr), border-color var(--pp-tr); background: none;
}
.pp-guide-btn:hover { color: var(--dk); border-color: var(--dk); }
.pp-guide-btn svg { width: 9px; height: 9px; stroke: currentColor; stroke-width: 1.6; fill: none; }

.pp-sizes { display: flex; flex-wrap: nowrap; gap: 3px; margin-bottom: 10px; }
.sz {
  width: 44px; height: 38px;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  background: var(--bg);
  font: 300 12px/1 var(--fb); color: var(--text);
  cursor: pointer;
  transition: border-color .16s, background .16s, color .16s, transform .12s;
  user-select: none;
}
.sz:hover:not(.dis) { border-color: var(--dk); transform: translateY(-1px); }
.sz.on { background: var(--dk); color: #fff; border-color: var(--dk); }
.sz.dis { opacity: .24; cursor: not-allowed; text-decoration: line-through; }
.sz-err { font: 300 italic 11px/1.4 var(--fi); color: var(--pp-clay); margin-bottom: 10px; display: none; }
.sz-err.show { display: block; }

/* Model line */
.pp-model {
  display: flex; align-items: center; gap: 5px;
  font: 300 italic 10.5px/1 var(--fi); color: var(--muted);
  margin-top: 8px; margin-bottom: 0;
}
.pp-model svg { width: 10px; height: 10px; stroke: var(--muted); stroke-width: 1.4; fill: none; flex-shrink: 0; }
.pp-model strong { font-style: normal; font-weight: 400; color: var(--text); }

/* Qty */
.pp-qty-row { display: flex; align-items: center; gap: 14px; margin: 16px 0; }
.qty-ctrl { display: flex; align-items: center; border: 1px solid var(--border); background: var(--bg); }
.q-btn {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: var(--text);
  transition: background .16s;
  background: none; border: none;
}
.q-btn:hover { background: var(--pp-bg2); }
.q-val {
  width: 44px; height: 40px;
  border-left: 1px solid var(--border); border-right: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font: 300 13px/1 var(--fb); color: var(--dk);
}

/* ATC & Actions Row (mockup side-by-side layout) */
.pp-actions {
  display: flex; align-items: stretch; gap: 6px; margin-bottom: 14px;
}
.pp-actions .pp-atc {
  flex: 1; margin-bottom: 0;
}
.pp-atc {
  width: 100%; height: 48px;
  background: var(--dk); border: 1px solid var(--dk); color: #fff;
  font: 400 11px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; position: relative; overflow: hidden;
  margin-bottom: 6px; transition: color .34s;
}
.pp-atc::before {
  content: ''; position: absolute; inset: 0; background: var(--bg);
  transform: translateX(-102%);
  transition: transform .42s cubic-bezier(.77,0,.175,1); z-index: 0;
}
.pp-atc:hover::before { transform: translateX(0); }
.pp-atc:hover { color: var(--dk); }
.pp-atc[disabled] { opacity: .55; cursor: not-allowed; }
.atc-in { position: relative; z-index: 1; display: flex; align-items: center; gap: 10px; pointer-events: none; }
.atc-in svg { width: 14px; height: 14px; stroke: #fff; stroke-width: 1.5; fill: none; transition: stroke .34s; }
.pp-atc:hover .atc-in svg { stroke: var(--dk); }
.pp-atc:active { transform: scale(.99); }
.pp-atc.ok { background: var(--dk); border-color: var(--dk); pointer-events: none; }
.pp-atc.ok::before { display: none; }
@keyframes ckIn { from { opacity: 0; transform: scale(0) rotate(-20deg); } 65% { transform: scale(1.35) rotate(4deg); } to { opacity: 1; transform: scale(1) rotate(0); } }
.ck-ico { animation: ckIn .36s cubic-bezier(.36,.07,.19,.97) forwards; }

.pp-wish-icon {
  width: 48px; flex-shrink: 0;
  border: 1px solid var(--border); background: transparent;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: border-color .2s, background .2s;
}
.pp-wish-icon svg {
  width: 14px; height: 14px;
  stroke: var(--muted); stroke-width: 1.5; fill: none;
  transition: stroke .2s, fill .2s;
}
.pp-wish-icon:hover { border-color: var(--pp-clay); }
.pp-wish-icon:hover svg { stroke: var(--pp-clay); }
.pp-wish-icon.on svg { fill: var(--pp-clay); stroke: var(--pp-clay); }

/* Full-width wishlist button (mockup layout) */
.pp-wish {
  width: 100%; height: 36px;
  border: 1px solid var(--border); background: transparent;
  font: 300 10px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase;
  color: var(--muted);
  display: none; align-items: center; justify-content: center; gap: 7px;
  transition: border-color .2s, color .2s;
  margin-bottom: 8px; cursor: pointer;
}
.pp-wish svg {
  width: 12px; height: 12px;
  stroke: currentColor; stroke-width: 1.5; fill: none;
}
.pp-wish:hover { border-color: var(--dk); color: var(--dk); }
.pp-wish.on svg { fill: var(--pp-clay); stroke: var(--pp-clay); }
.pp-wish.on { color: var(--pp-clay); border-color: var(--pp-clay); }

/* Availability badge (green dot) */
.pp-avail {
  display: flex; align-items: center; gap: 7px;
  font: 300 10px/1 var(--fb); letter-spacing: .06em;
  color: var(--muted); margin-bottom: 14px;
}
.pp-avail__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #2E7D50; flex-shrink: 0;
  box-shadow: 0 0 0 2.5px rgba(46,125,80,.18);
}
.pp-avail strong { color: #2E7D50; font-weight: 500; }
.pp-avail--oos { color: var(--pp-clay); }
.pp-avail--oos ~ .pp-avail__dot,
.pp-avail:has(.pp-avail--oos) .pp-avail__dot { background: var(--pp-clay); box-shadow: 0 0 0 2.5px rgba(184,74,46,.18); }

/* Trust stack */
.pp-trust {
  display: flex; flex-direction: column; gap: 0;
  border-top: 1px solid var(--border);
  margin-top: auto; margin-bottom: 0;
}
.pp-trust__item {
  display: flex; align-items: center; gap: 9px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
}
.pp-trust__ico {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--pp-bg2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.pp-trust__ico svg { width: 10px; height: 10px; stroke: var(--dk); stroke-width: 1.5; fill: none; }
.pp-trust__name { font: 500 9px/1 var(--fb); letter-spacing: .1em; text-transform: uppercase; color: var(--dk); }
.pp-trust__desc { font: 300 8px/1.3 var(--fb); letter-spacing: .04em; color: var(--muted); margin-top: 2px; }

/* Accordéon détails (mockup: .acc style with +/- pseudo-elements) */
.pp-details-acc { border-bottom: 1px solid var(--border); }
.pp-acc-btn {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 0;
  font: 300 10.5px/1 var(--fb); letter-spacing: .18em; text-transform: uppercase; color: var(--text);
  cursor: pointer; background: none; border: none; user-select: none;
  transition: color var(--pp-tr);
}
.pp-acc-btn:hover { color: var(--dk); }
/* +/- icon via pseudo-elements (mockup style) */
.pp-acc-ico {
  width: 18px; height: 18px; position: relative; flex-shrink: 0;
  /* Hide the SVG chevron content */
  stroke: none; fill: none;
}
.pp-acc-ico::before, .pp-acc-ico::after {
  content: ''; position: absolute; background: currentColor; border-radius: 1px;
  transition: transform .3s;
}
.pp-acc-ico::before { width: 1px; height: 11px; top: 3.5px; left: 8.5px; }
.pp-acc-ico::after  { width: 11px; height: 1px; top: 8.5px; left: 3.5px; }
.pp-acc-btn.open .pp-acc-ico::before { transform: rotate(90deg); }
.pp-acc-body { max-height: 0; overflow: hidden; transition: max-height .42s cubic-bezier(.04,.62,.23,.98); }
.pp-acc-btn.open + .pp-acc-body { max-height: 700px; }
.pp-acc-body .pp-feats { padding-bottom: 16px; }

.pp-feats { display: flex; flex-direction: column; gap: 8px; }
.feat { display: flex; align-items: flex-start; gap: 8px; font: 300 11.5px/1.55 var(--fb); color: var(--text); }
.feat svg { width: 10px; height: 10px; stroke: var(--gold); stroke-width: 2.2; fill: none; flex-shrink: 0; margin-top: 3px; }

/* ══════════════════════════════════════════
   3. REVEAL ANIMATIONS
══════════════════════════════════════════ */
.reveal {
  opacity: 0; transform: translateY(28px);
  transition: opacity .75s cubic-bezier(.16,1,.3,1), transform .75s cubic-bezier(.16,1,.3,1);
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }
.reveal-delay-4 { transition-delay: .4s; }

/* ══════════════════════════════════════════
   4. NOTRE AVIS
══════════════════════════════════════════ */
.notre-avis {
  padding: 88px var(--g) 64px;
  max-width: var(--mw); margin: 0 auto; text-align: center;
}
.na-title {
  font-family: var(--fd);
  font-size: clamp(26px, 2.4vw, 40px);
  letter-spacing: .18em; text-transform: uppercase; color: var(--dk);
  margin-bottom: 36px;
}
.na-body {
  max-width: 700px; margin: 0 auto;
  font: 300 14px/2 var(--fb); color: var(--text);
  text-align: left;
}
.na-body p { margin-bottom: 14px; }
.na-body b, .na-body strong { font-weight: 400; color: var(--dk); }
.na-care {
  display: flex; justify-content: center; align-items: flex-start; gap: 40px;
  margin-top: 52px; padding-top: 40px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.na-care-item { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.na-care-icon {
  width: 46px; height: 46px; border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
}
.na-care-icon svg { width: 20px; height: 20px; stroke: var(--dk); stroke-width: 1.4; fill: none; }
.na-care-icon span { font: 400 11px/1 var(--fb); color: var(--dk); }
.na-care-lbl { font: 300 9px/1 var(--fb); letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }

/* ══════════════════════════════════════════
   5. FICHE TECHNIQUE
══════════════════════════════════════════ */
.fiche-wrap { background: var(--pp-bg2); padding: 72px var(--g); }
.fiche-inner { max-width: var(--mw); margin: 0 auto; }
.fiche-title {
  font-family: var(--fd);
  font-size: clamp(24px, 2.2vw, 36px);
  letter-spacing: .18em; text-transform: uppercase; color: var(--dk);
  text-align: center; margin-bottom: 48px;
}
.fiche-grid {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
.fiche-item {
  background: var(--bg);
  padding: 20px 18px;
  display: flex; align-items: center; gap: 14px;
  border: 1px solid var(--border);
  transition: border-color .2s, box-shadow .2s, opacity .5s, transform .5s;
  cursor: default;
  opacity: 0; transform: translateY(16px);
}
.fiche-grid.in .fiche-item { opacity: 1; transform: translateY(0); }
.fiche-grid.in .fiche-item:nth-child(1)  { transition-delay: .05s; }
.fiche-grid.in .fiche-item:nth-child(2)  { transition-delay: .10s; }
.fiche-grid.in .fiche-item:nth-child(3)  { transition-delay: .15s; }
.fiche-grid.in .fiche-item:nth-child(4)  { transition-delay: .20s; }
.fiche-grid.in .fiche-item:nth-child(5)  { transition-delay: .25s; }
.fiche-grid.in .fiche-item:nth-child(6)  { transition-delay: .30s; }
.fiche-grid.in .fiche-item:nth-child(7)  { transition-delay: .35s; }
.fiche-grid.in .fiche-item:nth-child(8)  { transition-delay: .40s; }
.fiche-grid.in .fiche-item:nth-child(9)  { transition-delay: .45s; }
.fiche-grid.in .fiche-item:nth-child(10) { transition-delay: .50s; }
.fiche-item:hover { box-shadow: inset 0 0 0 1px var(--dk), 0 4px 16px rgba(11,11,9,.07); }
.fiche-ico {
  width: 44px; height: 44px; flex-shrink: 0; background: var(--pp-bg2);
  display: flex; align-items: center; justify-content: center;
}
.fiche-ico img { width: 28px; height: 28px; object-fit: contain; opacity: .6; }
.fiche-ico svg { width: 20px; height: 20px; stroke: var(--muted); stroke-width: 1.4; fill: none; }
.fiche-lbl { font: 300 9px/1 var(--fb); letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: 5px; }
.fiche-val { font: 400 12px/1 var(--fb); color: var(--dk); }

/* ══════════════════════════════════════════
   6. À PROPOS / CALLOUTS
══════════════════════════════════════════ */
.apropos-wrap { max-width: var(--mw); margin: 0 auto; padding: 80px var(--g); }
.apropos-title {
  font-family: var(--fd);
  font-size: clamp(24px, 2.2vw, 36px);
  letter-spacing: .14em; text-transform: uppercase; color: var(--dk);
  text-align: center; margin-bottom: 60px;
}
.apropos-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.apropos-img {
  width: 100%; max-width: 520px; justify-self: center;
  opacity: 0; transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.apropos-grid.in .apropos-img { opacity: 1; transform: translateY(0); }
.apropos-img img { width: 100%; display: block; object-fit: cover; }
.apropos-features { display: flex; flex-direction: column; gap: 0; }
.ap-feat {
  display: flex; align-items: flex-start; gap: 18px;
  padding: 22px 0; border-bottom: 1px solid var(--border);
  opacity: 0; transform: translateX(20px);
  transition: opacity .55s, transform .55s cubic-bezier(.16,1,.3,1);
}
.ap-feat:first-child { border-top: 1px solid var(--border); }
.apropos-grid.in .ap-feat { opacity: 1; transform: translateX(0); }
.apropos-grid.in .ap-feat:nth-child(1) { transition-delay: .08s; }
.apropos-grid.in .ap-feat:nth-child(2) { transition-delay: .16s; }
.apropos-grid.in .ap-feat:nth-child(3) { transition-delay: .24s; }
.apropos-grid.in .ap-feat:nth-child(4) { transition-delay: .32s; }
.apropos-grid.in .ap-feat:nth-child(5) { transition-delay: .40s; }
.apropos-grid.in .ap-feat:nth-child(6) { transition-delay: .48s; }
.ap-dot {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--dk); color: #fff; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font: 400 14px/1 var(--fb); margin-top: 1px;
  transition: transform .35s cubic-bezier(.34,1.56,.64,1), background .25s;
}
.ap-feat:hover .ap-dot { transform: rotate(135deg) scale(1.12); background: var(--gold); }
.ap-title {
  font: 400 11px/1 var(--fb); letter-spacing: .14em; text-transform: uppercase;
  color: var(--dk); margin-bottom: 6px;
  transition: font-weight .18s, letter-spacing .18s;
}
.ap-feat:hover .ap-title { font-weight: 700; letter-spacing: .10em; }
.ap-desc { font: 300 12px/1.7 var(--fb); color: var(--muted); }

/* ══════════════════════════════════════════
   7. TROUVER MA TAILLE (inline)
══════════════════════════════════════════ */
.taille-wrap { background: var(--pp-bg2); padding: 80px var(--g); text-align: center; }
.taille-inner { max-width: 620px; margin: 0 auto; }
.taille-title {
  font-family: var(--fd);
  font-size: clamp(24px, 2.2vw, 36px);
  letter-spacing: .18em; text-transform: uppercase; color: var(--dk);
  margin-bottom: 10px;
}
.taille-sub { font: 300 italic 13px/1 var(--fi); color: var(--muted); margin-bottom: 44px; }
.taille-row {
  display: grid; grid-template-columns: 140px 1fr 80px;
  align-items: center; gap: 18px; margin-bottom: 20px;
}
.taille-lbl {
  font: 300 9px/1 var(--fb); letter-spacing: .18em; text-transform: uppercase;
  color: var(--muted); text-align: right;
}
.taille-lbl em { display: block; font: 300 9px/1 var(--fi); color: var(--muted); letter-spacing: 0; font-style: italic; margin-top: 3px; }
.taille-val {
  font-family: var(--fd); font-size: 28px; letter-spacing: .04em; color: var(--dk);
  text-align: left;
}
.taille-unit { font: 300 9px/1 var(--fb); letter-spacing: .12em; text-transform: uppercase; color: var(--muted); text-align: left; }
input[type=range].t-range {
  width: 100%; height: 2px;
  -webkit-appearance: none; appearance: none;
  background: var(--border); outline: none; cursor: pointer;
}
input[type=range].t-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--dk); cursor: pointer;
  border: 2px solid var(--bg); box-shadow: 0 0 0 1px var(--dk);
}
input[type=range].t-range::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--dk); cursor: pointer;
  border: 2px solid var(--bg); box-shadow: 0 0 0 1px var(--dk);
}
.taille-btn {
  width: 100%; height: 52px; background: var(--dk); color: #fff;
  font: 400 11px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase;
  margin-top: 32px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; position: relative; overflow: hidden;
  transition: color .34s;
  border: none;
}
.taille-btn::before {
  content: ''; position: absolute; inset: 0; background: var(--bg);
  transform: translateX(-102%);
  transition: transform .42s cubic-bezier(.77,0,.175,1); z-index: 0;
}
.taille-btn:hover::before { transform: translateX(0); }
.taille-btn:hover { color: var(--dk); }
.taille-btn span { position: relative; z-index: 1; }
.taille-result {
  margin-top: 24px; display: none;
  background: var(--pp-panel); border: 1px solid var(--border);
  padding: 22px 24px; text-align: left;
}
.taille-result.show { display: block; }
.tr-lbl { font: 300 9px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.tr-size { font-family: var(--fd); font-size: 42px; letter-spacing: .04em; color: var(--dk); line-height: 1; }
.tr-note { font: 300 italic 12px/1.6 var(--fi); color: var(--muted); margin-top: 8px; }

/* ══════════════════════════════════════════
   8. CROSS-SELL
══════════════════════════════════════════ */
.xsell-wrap { max-width: var(--mw); margin: 88px auto 0; padding: 0 var(--g); }
.xsell-hd {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding-bottom: 20px; border-bottom: 1px solid var(--border); margin-bottom: 32px;
}
.xsell-title {
  font-family: var(--fd); font-size: 32px;
  letter-spacing: .06em; text-transform: uppercase; color: var(--dk); line-height: 1;
}
.xsell-all {
  display: flex; align-items: center; gap: 6px;
  font: 300 9px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase;
  color: var(--muted); transition: color var(--pp-tr); margin-bottom: 3px;
}
.xsell-all:hover { color: var(--dk); }
.xsell-all svg { width: 10px; height: 10px; stroke: currentColor; stroke-width: 1.8; fill: none; transition: transform .22s; }
.xsell-all:hover svg { transform: translateX(3px); }
.xsell { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.xc { cursor: pointer; }
.xc-img {
  aspect-ratio: 3/4; overflow: hidden; background: var(--pp-bg2);
  margin-bottom: 14px; position: relative; display: block;
}
.xc-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .58s cubic-bezier(.25,.46,.45,.94);
}
.xc:hover .xc-img img { transform: scale(1.048); }
.xc-cta {
  position: absolute; inset: auto 0 0; padding: 14px 16px;
  background: rgba(11,11,9,.78); color: #fff; text-align: center;
  font: 300 9px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase;
  transform: translateY(100%); transition: transform .26s cubic-bezier(.32,.72,0,1);
}
.xc:hover .xc-cta { transform: translateY(0); }
.xc-name { font: 300 12px/1.4 var(--fb); color: var(--dk); margin-bottom: 4px; }
.xc-price { font: 400 12px/1 var(--fb); color: var(--dk); }

/* ══════════════════════════════════════════
   9. EDITORIAL PARALLAX BAND
══════════════════════════════════════════ */
.ed-band {
  display: grid; grid-template-columns: 55fr 45fr;
  min-height: 680px; overflow: hidden;
  margin-top: 88px;
}
.ed-band__img-col { position: relative; overflow: hidden; background: var(--pp-bg2); }
.ed-band__bg {
  position: absolute; inset: -80px 0;
  background-size: cover; background-position: center 20%;
  filter: brightness(.68);
  will-change: transform;
}
.ed-band__text-col {
  background: var(--dk);
  display: flex; flex-direction: column; justify-content: center;
  padding: 80px clamp(36px, 5vw, 76px);
  position: relative;
}
.ed-band__text-col::before {
  content: ''; position: absolute; top: 56px; left: clamp(36px, 5vw, 76px);
  width: 28px; height: 1px; background: var(--gold); opacity: .55;
}
.ed-band__tag {
  font: 600 10px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 26px;
}
.ed-band__title {
  font-family: var(--fd);
  font-size: clamp(40px, 4.6vw, 70px);
  letter-spacing: .03em; text-transform: uppercase;
  color: #fff; line-height: .86; margin-bottom: 30px;
}
.ed-band__body {
  font: 300 13px/1.8 var(--fb);
  color: rgba(255,255,255,.75);
  max-width: 400px; margin-bottom: 44px;
}
.ed-band__divider { height: 1px; background: rgba(255,255,255,.07); margin-bottom: 32px; }
.ed-band__stats { display: flex; gap: 36px; align-items: flex-start; flex-wrap: wrap; }
.ed-stat-num {
  font-family: var(--fd); font-size: 50px; letter-spacing: .02em;
  color: rgba(255,255,255,.9); line-height: 1;
}
.ed-stat-lbl {
  font: 300 8.5px/1.65 var(--fb); letter-spacing: .18em; text-transform: uppercase;
  color: rgba(255,255,255,.28); margin-top: 5px;
}

/* ══════════════════════════════════════════
   10. STICKY ATC (desktop bottom bar)
══════════════════════════════════════════ */
.satc {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 800;
  background: rgba(250,250,248,.97);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border-top: 1px solid var(--border);
  padding: 12px var(--g);
  display: flex; align-items: center; gap: 18px;
  transform: translateY(110%); transition: transform .36s cubic-bezier(.32,.72,0,1);
}
.satc.on { transform: translateY(0); }
.satc__info { display: flex; flex-direction: column; gap: 3px; flex-shrink: 0; min-width: 140px; }
.satc__name { font-family: var(--fd); font-size: 13px; letter-spacing: .07em; text-transform: uppercase; color: var(--dk); }
.satc__price { font: 300 10px/1 var(--fb); color: var(--muted); }
.satc__sizes { display: flex; gap: 3px; flex: 1; overflow-x: auto; scrollbar-width: none; }
.satc__sizes::-webkit-scrollbar { display: none; }
.satc__sz {
  width: 36px; height: 34px; border: 1px solid var(--border); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; background: var(--bg);
  font: 300 10.5px/1 var(--fb); color: var(--text); cursor: pointer;
  transition: border-color .16s, background .16s, color .16s; user-select: none;
}
.satc__sz:hover:not(.dis) { border-color: var(--dk); }
.satc__sz.on { background: var(--dk); color: #fff; border-color: var(--dk); }
.satc__sz.dis { opacity: .24; cursor: not-allowed; text-decoration: line-through; }
.satc__btn {
  height: 42px; padding: 0 28px; background: var(--dk); color: #fff; border: 1px solid var(--dk);
  font: 400 10px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase;
  display: flex; align-items: center; gap: 8px; flex-shrink: 0;
  position: relative; overflow: hidden; transition: color .3s;
  cursor: pointer;
}
.satc__btn::before {
  content: ''; position: absolute; inset: 0; background: var(--bg);
  transform: translateX(-102%); transition: transform .36s cubic-bezier(.77,0,.175,1); z-index: 0;
}
.satc__btn:hover::before { transform: translateX(0); }
.satc__btn:hover { color: var(--dk); }
.satc__btn-in { position: relative; z-index: 1; display: flex; align-items: center; gap: 6px; transition: color .3s; }
.satc__btn:hover .satc__btn-in { color: var(--dk); }
.satc__btn-in svg { width: 12px; height: 12px; stroke: currentColor; stroke-width: 1.5; fill: none; transition: stroke .3s; }
.satc__btn.ok { background: var(--dk); border-color: var(--dk); pointer-events: none; }

/* ══════════════════════════════════════════
   11. LIGHTBOX
══════════════════════════════════════════ */
.lb {
  position: fixed; inset: 0; z-index: 9990; background: rgba(11,11,9,.96);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .24s;
}
.lb.on { opacity: 1; pointer-events: auto; }
.lb img { max-width: 86vw; max-height: 86vh; object-fit: contain; transition: opacity .2s; }
.lb__x, .lb__arr {
  position: absolute; display: flex; align-items: center; justify-content: center; cursor: pointer;
  color: rgba(255,255,255,.36); transition: color .18s;
  background: none; border: none;
}
.lb__x:hover, .lb__arr:hover { color: #fff; }
.lb__x { top: 20px; right: 24px; width: 44px; height: 44px; }
.lb__x svg { width: 17px; height: 17px; stroke: currentColor; stroke-width: 1.6; fill: none; }
.lb__arr { top: 50%; transform: translateY(-50%); width: 52px; height: 52px; }
.lb__arr svg { width: 17px; height: 17px; stroke: currentColor; stroke-width: 1.5; fill: none; }
.lb__arr--l { left: 20px; }
.lb__arr--r { right: 20px; }
.lb__n {
  position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
  font: 300 9px/1 var(--fb); letter-spacing: .22em; color: rgba(255,255,255,.26);
}

/* ══════════════════════════════════════════
   12. QP DRAWER (Notre Transparence)
══════════════════════════════════════════ */
.drawer-overlay {
  position: fixed; inset: 0; z-index: 9800;
  background: rgba(11,11,9,0); pointer-events: none;
  transition: background .32s;
}
.drawer-overlay.open { background: rgba(11,11,9,.45); pointer-events: auto; }
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 9900;
  width: min(440px, 90vw); background: var(--bg);
  transform: translateX(102%); overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .38s cubic-bezier(.4,0,.2,1);
  border-left: 1px solid var(--border);
}
.drawer.open { transform: translateX(0); }
.drawer__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 28px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.drawer__title { font-family: var(--fd); font-size: 20px; letter-spacing: .06em; text-transform: uppercase; color: var(--dk); }
.drawer__close {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border); background: none; cursor: pointer;
  transition: border-color .2s, background .2s;
}
.drawer__close:hover { border-color: var(--dk); background: var(--pp-bg2); }
.drawer__close svg { width: 11px; height: 11px; stroke: var(--dk); stroke-width: 2; fill: none; }
.drawer__body { padding: 24px 28px; flex: 1; overflow-y: auto; scrollbar-width: none; }
.drawer__body::-webkit-scrollbar { display: none; }
.drawer__tag {
  font: 300 9px/1 var(--fb); letter-spacing: .24em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.drawer__tag::before { content: ''; width: 18px; height: 1px; background: var(--gold); flex-shrink: 0; }
.drawer__lead { font: 300 italic 14px/1.6 var(--fi); color: var(--text); margin-bottom: 22px; }
.drawer__section { margin-bottom: 20px; }
.drawer__section-title {
  font: 400 9px/1 var(--fb); letter-spacing: .2em; text-transform: uppercase;
  color: var(--dk); margin-bottom: 12px;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.drawer__compare { display: flex; flex-direction: column; gap: 4px; margin-bottom: 20px; }
.drawer__cmp-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: var(--pp-bg2);
}
.drawer__cmp-item--us { background: var(--dk); }
.drawer__cmp-label { font: 300 9.5px/1 var(--fb); letter-spacing: .06em; color: var(--muted); }
.drawer__cmp-item--us .drawer__cmp-label { color: rgba(255,255,255,.5); }
.drawer__cmp-price { font: 400 16px/1 var(--fd); letter-spacing: .04em; color: var(--dk); }
.drawer__cmp-item--us .drawer__cmp-price { color: #fff; }
.drawer__cmp-badge {
  font: 400 7px/1 var(--fb); letter-spacing: .14em; text-transform: uppercase;
  color: var(--gold); background: rgba(168,129,42,.1);
  padding: 2px 6px; display: inline-block; margin-top: 4px;
}
.drawer__points { display: flex; flex-direction: column; gap: 10px; }
.drawer__point { display: flex; align-items: flex-start; gap: 10px; }
.drawer__point svg { width: 11px; height: 11px; stroke: var(--gold); stroke-width: 2; fill: none; flex-shrink: 0; margin-top: 2px; }
.drawer__point-text { font: 300 11.5px/1.55 var(--fi); color: var(--text); }
.drawer__footer { padding: 20px 28px; border-top: 1px solid var(--border); flex-shrink: 0; }
.drawer__cta {
  width: 100%; height: 48px; background: var(--dk); border: none;
  font: 400 10px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase; color: #fff;
  cursor: pointer; transition: background .2s;
}
.drawer__cta:hover { background: var(--gold); }

/* ══════════════════════════════════════════
   13. SIZE GUIDE BOTTOM SHEET
══════════════════════════════════════════ */
.gs-bg {
  position: fixed; inset: 0; z-index: 9980;
  background: rgba(11,11,9,.45);
  opacity: 0; pointer-events: none; transition: opacity .28s;
}
.gs-bg.on { opacity: 1; pointer-events: auto; }
.gs-sheet {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9982;
  background: var(--bg); max-height: 78vh; overflow-y: auto;
  scrollbar-width: none;
  transform: translateY(103%); transition: transform .4s cubic-bezier(.32,.72,0,1);
}
.gs-sheet.on { transform: translateY(0); }
.gs-sheet::-webkit-scrollbar { display: none; }
.gs-pill { width: 36px; height: 4px; background: var(--border); border-radius: 2px; margin: 14px auto 0; }
.gs-head {
  max-width: 900px; margin: 0 auto; padding: 18px var(--g) 0;
  display: flex; align-items: center; justify-content: space-between;
}
.gs-title {
  font-family: var(--fd); font-size: 24px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--dk);
}
.gs-close {
  width: 42px; height: 42px;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); cursor: pointer; transition: color .18s;
  background: none; border: none;
}
.gs-close:hover { color: var(--dk); }
.gs-close svg { width: 14px; height: 14px; stroke: currentColor; stroke-width: 2; fill: none; }
.gs-body {
  max-width: 900px; margin: 0 auto; padding: 24px var(--g) 44px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
}
/* Calculator box */
.calc-box {
  background: var(--pp-panel); border: 1px solid var(--border); padding: 28px;
}
.calc-title {
  font-family: var(--fd); font-size: 18px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--dk); margin-bottom: 6px;
}
.calc-sub { font: 300 italic 11px/1.55 var(--fi); color: var(--muted); margin-bottom: 22px; }
.calc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.calc-fld label {
  display: block; font: 300 9px/1 var(--fb); letter-spacing: .16em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 5px;
}
.calc-fld input {
  width: 100%; height: 40px; border: 1px solid var(--border);
  background: var(--bg); padding: 0 12px;
  font: 300 13px/1 var(--fb); color: var(--text);
  outline: none; transition: border-color .18s;
}
.calc-fld input:focus { border-color: var(--dk); }
.calc-fit-lbl { font: 300 9px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.calc-fits { display: flex; gap: 5px; margin-bottom: 20px; }
.fit {
  flex: 1; height: 38px; border: 1px solid var(--border); background: transparent;
  font: 300 10px/1 var(--fb); letter-spacing: .1em; text-transform: uppercase;
  color: var(--muted); cursor: pointer; transition: border-color .18s, color .18s, background .18s;
}
.fit.on { background: var(--dk); color: #fff; border-color: var(--dk); }
.fit:hover:not(.on) { border-color: var(--dk); color: var(--dk); }
.calc-go {
  width: 100%; height: 44px; background: var(--dk); color: #fff;
  font: 400 10px/1 var(--fb); letter-spacing: .22em; text-transform: uppercase;
  cursor: pointer; position: relative; overflow: hidden; transition: color .32s;
  border: none;
}
.calc-go::before {
  content: ''; position: absolute; inset: 0; background: var(--bg);
  transform: translateX(-102%); transition: transform .38s cubic-bezier(.77,0,.175,1); z-index: 0;
}
.calc-go:hover::before { transform: translateX(0); }
.calc-go:hover { color: var(--dk); }
.calc-go span { position: relative; z-index: 1; }
.calc-res {
  margin-top: 16px; display: none;
  font: 300 italic 13px/1.5 var(--fi); color: var(--dk);
  border-top: 1px solid var(--border); padding-top: 14px;
}
.calc-res.show { display: block; }
.calc-res strong { font-family: var(--fd); font-size: 24px; color: var(--dk); }
/* Size table */
.gs-note { font: 300 italic 12px/1.65 var(--fi); color: var(--muted); margin-bottom: 18px; }
.gs-tbl { width: 100%; border-collapse: collapse; }
.gs-tbl th {
  font: 400 8px/1 var(--fb); letter-spacing: .16em; text-transform: uppercase;
  color: var(--muted); padding: 9px 10px; text-align: left;
  border-bottom: 1px solid var(--border); background: var(--pp-bg2);
}
.gs-tbl td { font: 300 11px/1 var(--fb); padding: 9px 10px; border-bottom: 1px solid var(--border); }
.gs-tbl tr:last-child td { border-bottom: none; }
.gs-tbl td:first-child { font-weight: 400; color: var(--dk); }
.gs-tbl tr.hl td { background: rgba(11,11,9,.03); }

/* ══════════════════════════════════════════
   14. MOBILE (≤ 900px)
══════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Switch from mosaic to swiper */
  .pp-zone { display: block; }
  .pp-left { display: block; }
  .gallery { display: none; }
  .gallery-mob { display: block; position: relative; margin-top: 10px; }
  .gallery-mob__swiper {
    display: flex; overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
  }
  .gallery-mob__swiper::-webkit-scrollbar { display: none; }
  .gallery-mob__slide {
    flex: 0 0 100%; scroll-snap-align: start;
    position: relative;
    /* Use aspect-ratio instead of fixed vw height — prevents portrait images from being cropped */
    aspect-ratio: 3/4;
    max-height: 75vh;
    overflow: hidden; background: #ffffff;
  }
  .gallery-mob__slide img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
  .gallery-mob__count {
    position: absolute; bottom: 10px; right: 12px;
    font: 300 9px/1 var(--fb); letter-spacing: .18em;
    color: rgba(255,255,255,.7); pointer-events: none; z-index: 2;
    background: rgba(11,14,21,.28); padding: 4px 8px;
  }
  .gallery-mob__dots { display: flex; justify-content: center; gap: 5px; padding: 10px 0 4px; }
  .gd { width: 16px; height: 2px; background: var(--border); border-radius: 1px; transition: background .2s, width .2s; cursor: pointer; }
  .gd.on { background: var(--dk); width: 24px; }

  /* Purchase becomes static */
  .purchase {
    position: static; height: auto; overflow: visible;
    background: transparent; border-left: none; padding: 16px var(--g) 0;
    transform: none; opacity: 1;
  }
  .pp-actions { display: block; }
  .pp-actions .pp-wish-icon { display: none; }
  .pp-wish { display: flex; }
  .pp-name { font-size: clamp(28px, 8vw, 38px); line-height: .92; }
  /* Reset line-clamp on mobile — show full description */
  .pp-desc { display: block; -webkit-line-clamp: unset; -webkit-box-orient: initial; overflow: visible; }
  .pp-trust { margin-top: 16px; padding: 12px 0; border-bottom: 1px solid var(--border); }

  /* Sticky ATC mobile (chip + button) */
  body.pm-prod-page { padding-bottom: calc(var(--atc-h-mob) + env(safe-area-inset-bottom)); }
  .satc {
    padding: 10px var(--g);
    padding-bottom: calc(10px + env(safe-area-inset-bottom));
    gap: 10px;
  }
  .satc__info { display: none; }
  .satc__sizes { display: none; }
  /* Show mobile chip + full-width button */
  .satc__chip {
    flex: 0 0 auto; height: 48px; border: 1px solid var(--border);
    padding: 0 12px; display: flex; align-items: center; gap: 6px;
    font: 300 10px/1 var(--fb); text-transform: uppercase; letter-spacing: .1em;
    white-space: nowrap; color: var(--muted); cursor: pointer; background: var(--bg);
  }
  .satc__chip-val { color: var(--dk); font-weight: 400; }
  .satc__btn { flex: 1; height: 48px; padding: 0; }

  /* Sections compactes */
  .notre-avis { padding: 56px var(--g) 40px; }
  .na-care { gap: 18px; }
  .fiche-wrap { padding: 48px var(--g); }
  .fiche-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .apropos-wrap { padding: 56px var(--g); }
  .apropos-grid { grid-template-columns: 1fr; gap: 36px; }
  .apropos-img { max-width: 360px; }
  .taille-wrap { padding: 56px var(--g); }
  .taille-row { grid-template-columns: 90px 1fr 70px; gap: 12px; }
  .taille-val { font-size: 22px; }
  .xsell-wrap { margin-top: 56px; }
  .xsell { grid-template-columns: 1fr; gap: 24px; }
  .ed-band { grid-template-columns: 1fr; min-height: auto; margin-top: 56px; }
  .ed-band__img-col { min-height: 320px; }
  .ed-band__text-col { padding: 56px var(--g); }
  .ed-band__stats { gap: 24px; }
  .ed-stat-num { font-size: 38px; }
  /* Size guide sheet mobile */
  .gs-body { grid-template-columns: 1fr; gap: 24px; }
  .gs-tbl { font-size: 10px; }
  .gs-tbl th, .gs-tbl td { padding: 7px 6px; }
}

/* Hide desktop sticky bar elements always on small screens before media kicks (defensive) */
@media (max-width: 480px) {
  .satc__btn { padding: 0 16px; letter-spacing: .18em; }
  .fiche-grid { grid-template-columns: 1fr; }
}
