/* ============================================================================
   Shop — design system premium, inspiré d'une direction artistique naturelle.
   ============================================================================ */

:root{
  --c-bg:        #FAF7F2;
  --c-surface:   #FFFFFF;
  --c-ink:       #1E1B16;
  --c-ink-2:     #5B5247;
  --c-muted:     #A79E92;
  --c-line:      #E9E3D8;
  --c-accent:    #6E7A3A;
  --c-accent-dk: #525C28;
  --c-gold:      #B38E5D;
  --c-danger:    #B24A3A;
  --c-success:   #4F7A4A;

  /* Century Gothic d'abord (installé nativement Windows/Mac), fallback URW/Jost puis génériques */
  --ff-display: "Century Gothic", "CenturyGothic", "URW Gothic", "Jost", "Futura", "Avenir Next", "Helvetica Neue", Arial, sans-serif;
  --ff-body:    "Century Gothic", "CenturyGothic", "URW Gothic", "Jost", "Futura", "Avenir Next", "Helvetica Neue", Arial, sans-serif;

  --r-sm: 6px; --r-md: 12px; --r-lg: 20px; --r-pill: 999px;
  --sh-1: 0 1px 2px rgba(30,27,22,.04), 0 2px 8px rgba(30,27,22,.04);
  --sh-2: 0 8px 24px rgba(30,27,22,.06);
}

*{box-sizing:border-box}
html,body{background:var(--c-bg);color:var(--c-ink);font-family:var(--ff-body);font-weight:700;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100%}
/* Century Gothic bold partout — fallback Jost 700 */
body,p,li,td,th,a,span,label,button,h1,h2,h3,h4,h5,h6,.btn{font-weight:700}
strong,b{font-weight:800}
/* Champs de saisie en 500 — bold à la frappe est illisible */
input,textarea,select,.form-control,.form-select{font-weight:500}
body{min-height:100vh;display:flex;flex-direction:column;margin:0}
main{flex:1 0 auto;outline:none}
img,video,svg{max-width:100%;height:auto}
/* iOS : toute font-size < 16px déclenche le zoom auto sur focus — on force 16px */
@media (max-width:576px){
  input[type="text"],input[type="email"],input[type="tel"],input[type="password"],input[type="search"],input[type="number"],input[type="date"],textarea,select{
    font-size:16px !important;
  }
}

a{color:inherit}
a:hover{color:var(--c-accent-dk)}

/* Accessibilité : skip-link (lecteurs d'écran + clavier) */
.skip-link{position:absolute;left:-1000px;top:0;background:var(--c-ink);color:#fff;padding:.75rem 1rem;z-index:9999;border-radius:0 0 var(--r-md) 0}
.skip-link:focus{left:0;color:#fff;outline:3px solid var(--c-gold);outline-offset:2px}

/* Focus visible global : clavier only, ne gêne pas la souris */
*:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px;border-radius:3px}
.btn:focus-visible,.btn:focus{outline:3px solid rgba(110,122,58,.35);outline-offset:2px;box-shadow:none}

/* Barre recherche mobile */
.bar-search-mobile{background:#fff;border-top:1px solid var(--c-line)}
.bar-search-mobile[hidden]{display:none !important}
.bar-search-mobile.open{display:block !important}
.bar-search-mobile .form-control{background:var(--c-bg);border:1px solid var(--c-line)}
.bar-search-mobile .form-control:focus{background:#fff;border-color:var(--c-ink);box-shadow:none}

.bg-surface{background:var(--c-surface) !important}
.page-title{font-family:var(--ff-display);font-weight:600;letter-spacing:-.01em;margin-bottom:1rem}
.section-title{font-family:var(--ff-display);font-weight:600;font-size:1.8rem;letter-spacing:-.01em;margin:0}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1.25rem;gap:1rem}
.section-more{color:var(--c-ink-2);text-decoration:none;font-size:.95rem;white-space:nowrap}
.section-more:hover{color:var(--c-accent-dk)}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:1040;background:var(--c-surface);border-bottom:1px solid var(--c-line)}
.site-header .bar-top{background:var(--c-ink);color:#fff}
.site-header .bar-top .text-muted{color:#cfc8bb !important}
.site-header .bar-top a:hover{color:#fff;text-decoration:underline}
.topbar-sep{color:rgba(255,255,255,.25)}
.topbar-phone{display:inline-flex;align-items:center;gap:.4rem;font-weight:500}
.topbar-phone .bi{color:var(--c-gold);font-size:.9rem}
.topbar-free{display:inline-flex;align-items:center;gap:.4rem;color:#E5E0D4}
.topbar-free .bi{color:var(--c-gold)}
.topbar-free strong{color:#fff;font-weight:600}
.topbar-socials{display:inline-flex;align-items:center;gap:.5rem}
.topbar-socials a{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:inline-flex;align-items:center;justify-content:center;color:#E5E0D4;transition:.15s;font-size:.85rem}
.topbar-socials a:hover{background:#fff;color:var(--c-ink);border-color:#fff;text-decoration:none}

/* Social icons dans la barre principale (à côté du panier) */
.header-socials{display:inline-flex;align-items:center;gap:.35rem;padding-right:.25rem;border-right:1px solid var(--c-line);margin-right:.25rem}
.header-socials a{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--c-ink-2);transition:.15s;font-size:1rem}
.header-socials a:hover{background:var(--c-bg);color:var(--c-ink)}

/* Barre info mobile (tel + livraison gratuite) */
.bar-info-mobile{background:var(--c-ink);color:#E5E0D4;padding:.4rem 0;font-size:.78rem;border-bottom:1px solid rgba(255,255,255,.06)}
.bar-info-mobile .mobile-phone{color:#fff;text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:.3rem}
.bar-info-mobile .mobile-phone .bi{color:var(--c-gold)}
.bar-info-mobile .mobile-free{display:inline-flex;align-items:center;gap:.3rem}
.bar-info-mobile .mobile-free .bi{color:var(--c-gold)}
.brand-text{font-family:var(--ff-display);font-weight:600;font-size:1.4rem;letter-spacing:-.01em}
.brand{display:inline-flex;align-items:center;flex:0 0 auto;min-width:0;max-width:280px}
.brand-logo{
  display:block;
  height:52px;               /* hauteur explicite (SVG/PNG) */
  max-height:52px;
  width:auto;
  max-width:100%;
  object-fit:contain;
  object-position:left center;
}

/* Header : distribution flex équilibrée */
.site-header .bar-main > .container-xxl{
  min-height:72px;
}
.icon-link{color:var(--c-ink);text-decoration:none;font-size:1.2rem;position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;transition:background .15s ease;background:transparent;border:0}
.icon-link:hover{color:var(--c-ink);background:var(--c-bg)}
.cart-count{position:absolute;top:2px;right:2px;background:var(--c-ink);color:#fff;font-size:.62rem;padding:1px 5px;min-width:16px;height:16px;line-height:14px;text-align:center;border-radius:999px;font-weight:600;border:2px solid #fff}

.search-form{max-width:560px;margin:0 auto;position:relative;flex:1 1 auto;min-width:0}
.search-form .input-group .form-control{border:1px solid var(--c-line);padding:.55rem .9rem;background:var(--c-bg);font-size:.92rem;height:42px}
.search-form .input-group .form-control:focus{background:#fff;box-shadow:none;border-color:var(--c-ink)}
.search-form .btn-dark{background:var(--c-ink);border-color:var(--c-ink);padding-inline:.9rem;height:42px}
.search-suggest{position:absolute;left:0;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);box-shadow:var(--sh-2);max-height:380px;overflow:auto;z-index:10;display:none}
.search-suggest.open{display:block}
.search-suggest a{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;text-decoration:none;color:inherit;border-bottom:1px solid var(--c-line)}
.search-suggest a:last-child{border-bottom:0}
.search-suggest a:hover{background:var(--c-bg)}
.search-suggest img{width:44px;height:44px;object-fit:cover;border-radius:var(--r-sm)}

/* ===== Mega menu ===== */
.bar-nav{border-top:1px solid var(--c-line);background:#fff}
.nav-top-list{list-style:none;margin:0;padding:0;display:flex;gap:1.5rem;flex-wrap:wrap}
.nav-top-list > li{position:relative;padding:.9rem 0}
.nav-top-list > li > a{color:var(--c-ink);text-decoration:none;font-weight:500;font-size:.95rem;letter-spacing:.01em;padding:.25rem 0;border-bottom:2px solid transparent;transition:border-color .2s}
.nav-top-list > li > a:hover,
.nav-top-list > li > a.active{color:var(--c-ink);border-bottom-color:var(--c-ink)}
.nav-top-list > li.has-children > a::after{content:"";display:inline-block;margin-left:.35rem;border:solid var(--c-muted);border-width:0 2px 2px 0;padding:3px;transform:rotate(45deg);vertical-align:middle}
.nav-top-list > li > .mega{position:absolute;top:100%;left:-1rem;background:#fff;border:1px solid var(--c-line);box-shadow:var(--sh-2);border-radius:var(--r-md);padding:1.25rem;width:860px;max-width:94vw;display:none;z-index:20}
.nav-top-list > li.has-children:hover > .mega{display:block}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.mega-col{min-width:0}

.mega-cats .mega-cat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;padding:.75rem .5rem;border-radius:var(--r-md);color:var(--c-ink);text-decoration:none;transition:background .15s}
.mega-cats .mega-cat:hover{background:var(--c-bg);color:var(--c-accent-dk)}
.mega-cat__img{width:64px;height:64px;border-radius:50%;border:1px solid var(--c-line);overflow:hidden;display:flex;align-items:center;justify-content:center;background:#fff}
.mega-cat__img img{width:100%;height:100%;object-fit:cover}
.mega-cat__label{font-size:.85rem;font-weight:500;line-height:1.25}

/* ===== Hero — pleine largeur, hauteur bornée pour ne jamais dominer l'écran ===== */
.hero{background:#1E1B16;overflow:hidden}
.hero .carousel,
.hero .carousel-inner,
.hero .carousel-item{width:100%;background:#1E1B16}
/* Ratio 16:9 natif sur toutes tailles — l'image reste entière et full-width */
.hero .carousel-item{
  aspect-ratio:16/9;
  min-height:0;
  overflow:hidden;
  background:#1E1B16;
}
.hero-slide{display:block;width:100%;height:100%;background:#1E1B16;position:relative}
.hero-img{
  display:block;width:100%;height:100%;
  object-fit:contain;      /* aucun crop — l'image est intégralement visible */
  object-position:center;
  background:#1E1B16;      /* fond ink = même couleur que l'image → bandes invisibles */
}

.hero .carousel-control-prev,
.hero .carousel-control-next{width:6%;opacity:.6;z-index:2}
.hero .carousel-control-prev:hover,
.hero .carousel-control-next:hover{opacity:1}
.hero .carousel-indicators{margin-bottom:.75rem;z-index:2}
.hero .carousel-indicators [data-bs-target]{width:28px;height:3px;border-radius:2px;background:rgba(255,255,255,.7)}
.hero .carousel-indicators .active{background:#fff}

/* 16:9 natif partout — l'admin impose l'upload à 1920×1080 (ratio 16:9) */
@media (max-width:1199px){
  .hero .carousel-control-prev,.hero .carousel-control-next{width:8%}
}
@media (max-width:767px){
  .hero .carousel-control-prev,.hero .carousel-control-next{width:10%}
}
@media (max-width:575px){
  .hero .carousel-item{aspect-ratio:16/9}
}
@media (max-width:399px){
  .hero .carousel-item{aspect-ratio:16/9}
}

/* ===== Categories tiles (legacy, encore utilisé ailleurs) ===== */
.cat-tile{display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;color:var(--c-ink);padding:1rem;border-radius:var(--r-md);transition:background .2s}
.cat-tile:hover{background:#fff;box-shadow:var(--sh-1);color:var(--c-ink)}
.cat-tile__img{width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--c-surface);border:1px solid var(--c-line);display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}
.cat-tile__img img{width:100%;height:100%;object-fit:cover}
.cat-tile__label{font-size:.9rem;font-weight:500}

/* ===== Categories — slider horizontal élégant ===== */
.cat-slider__nav{
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--c-line);background:#fff;color:var(--c-ink);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;transition:.15s;
}
.cat-slider__nav:hover{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.cat-slider__nav:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}

.cat-slider{
  position:relative;
  margin-inline:calc(var(--bs-gutter-x, 1.5rem) * -.5);
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
          mask-image:linear-gradient(90deg, transparent 0, #000 12px, #000 calc(100% - 12px), transparent 100%);
}
.cat-slider__track{
  display:flex;gap:1rem;padding:.5rem calc(var(--bs-gutter-x, 1.5rem) * .5);
  overflow-x:auto;scroll-behavior:smooth;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.cat-slider__track::-webkit-scrollbar{display:none}
.cat-slider__card{
  position:relative;
  flex:0 0 280px;             /* largeur fixe par item */
  aspect-ratio:4/5;
  border-radius:var(--r-lg);
  overflow:hidden;
  background:#2A251C;
  color:#fff;text-decoration:none;
  isolation:isolate;
  box-shadow:var(--sh-1);
  scroll-snap-align:start;
  transition:transform .3s ease, box-shadow .3s ease;
}
.cat-slider__card:hover{transform:translateY(-3px);box-shadow:var(--sh-2);color:#fff}

.cat-slider__media{position:absolute;inset:0;margin:0;background:linear-gradient(135deg,#2A251C 0%,#3b3328 100%)}
.cat-slider__media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .6s cubic-bezier(.2,.6,.2,1);filter:saturate(.92)}
.cat-slider__card:hover .cat-slider__media img{transform:scale(1.06);filter:saturate(1.05)}

.cat-slider__overlay{
  position:absolute;inset:0;z-index:2;
  display:flex;align-items:flex-end;justify-content:space-between;gap:.6rem;
  padding:1rem 1.15rem;
  background:linear-gradient(180deg, rgba(30,27,22,0) 55%, rgba(30,27,22,.5) 82%, rgba(30,27,22,.88) 100%);
}
.cat-slider__meta{min-width:0;flex:1}
.cat-slider__title{font-family:var(--ff-display);font-weight:600;font-size:1.15rem;line-height:1.15;letter-spacing:-.01em;margin:0 0 .2rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.25)}
.cat-slider__count{margin:0;font-size:.78rem;color:rgba(255,255,255,.78)}
.cat-slider__index{
  position:absolute;top:.85rem;left:.95rem;z-index:3;
  font-family:var(--ff-display);font-weight:600;font-size:.72rem;
  color:rgba(255,255,255,.82);letter-spacing:.1em;
  background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:.15rem .5rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
}
.cat-slider__arrow{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--c-ink);
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .3s ease, background .3s ease;
}
.cat-slider__card:hover .cat-slider__arrow{transform:translateX(3px);background:#fff}

@media (max-width:767.98px){
  .cat-slider__card{flex:0 0 220px}
  .cat-slider__title{font-size:1rem}
  .cat-slider__nav{width:36px;height:36px}
}
@media (max-width:479.98px){
  .cat-slider__card{flex:0 0 180px}
  .cat-slider__overlay{padding:.75rem .85rem}
}

/* ===== Categories — grille éditoriale premium (legacy) ===== */
.cat-editorial__eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-accent-dk);margin-bottom:.3rem;font-weight:600}
.cat-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:320px;
  gap:1rem;
}
/* Rythme asymétrique : 1er item prend 2 colonnes, 2 lignes (hero) */
.cat-grid > .cat-editorial__card:first-child{grid-column:span 2;grid-row:span 2}
/* 2e item prend aussi 2 lignes pour la bande supérieure equilibrée */
.cat-grid > .cat-editorial__card:nth-child(2){grid-column:span 2}

.cat-editorial__card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:var(--r-lg);
  text-decoration:none;
  color:#fff;
  background:#1E1B16;
  isolation:isolate;
  box-shadow:var(--sh-1);
  transition:transform .35s ease, box-shadow .35s ease;
}
.cat-editorial__card:hover{transform:translateY(-3px);box-shadow:var(--sh-2);color:#fff}

.cat-editorial__media{
  position:absolute;inset:0;margin:0;
  background:linear-gradient(135deg,#2A251C 0%,#3b3328 100%);
}
.cat-editorial__media img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform .7s cubic-bezier(.2,.6,.2,1), filter .35s ease;
  filter:saturate(.95);
}
.cat-editorial__card:hover .cat-editorial__media img{transform:scale(1.06);filter:saturate(1.05) brightness(1.03)}

/* Overlay dégradé en bas + contenu */
.cat-editorial__overlay{
  position:absolute;inset:0;z-index:2;
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:1.25rem 1.35rem;
  background:linear-gradient(180deg, rgba(30,27,22,0) 55%, rgba(30,27,22,.45) 80%, rgba(30,27,22,.85) 100%);
  gap:.75rem;
}
.cat-editorial__meta{min-width:0;flex:1}
.cat-editorial__title{
  font-family:var(--ff-display);
  font-weight:600;font-size:1.35rem;line-height:1.15;letter-spacing:-.01em;
  margin:0 0 .25rem;color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.25);
}
.cat-editorial__count{
  margin:0;font-size:.8rem;color:rgba(255,255,255,.78);
  letter-spacing:.02em;
}

.cat-editorial__index{
  position:absolute;top:1rem;left:1.1rem;z-index:3;
  font-family:var(--ff-display);font-weight:600;font-size:.78rem;
  color:rgba(255,255,255,.82);letter-spacing:.1em;
  background:rgba(0,0,0,.25);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:.2rem .55rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
}

.cat-editorial__arrow{
  flex-shrink:0;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--c-ink);
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .3s ease, background .3s ease;
}
.cat-editorial__card:hover .cat-editorial__arrow{transform:translateX(4px);background:#fff}

/* Hero card (1er item) — titre plus grand */
.cat-grid > .cat-editorial__card:first-child .cat-editorial__title{font-size:2rem}
.cat-grid > .cat-editorial__card:first-child .cat-editorial__overlay{padding:1.6rem 1.75rem}
.cat-grid > .cat-editorial__card:first-child .cat-editorial__arrow{width:50px;height:50px}
.cat-grid > .cat-editorial__card:first-child .cat-editorial__arrow svg{width:22px;height:22px}

/* === Responsive === */
@media (max-width:1199.98px){
  .cat-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:280px}
  .cat-grid > .cat-editorial__card:first-child{grid-column:span 2;grid-row:span 2}
  .cat-grid > .cat-editorial__card:nth-child(2){grid-column:span 1}
}
@media (max-width:767.98px){
  .cat-grid{grid-template-columns:1fr 1fr;grid-auto-rows:220px;gap:.75rem}
  .cat-grid > .cat-editorial__card:first-child,
  .cat-grid > .cat-editorial__card:nth-child(2){grid-column:span 2;grid-row:span 1}
  .cat-grid > .cat-editorial__card:first-child{grid-row:span 2}
  .cat-editorial__title{font-size:1.05rem}
  .cat-grid > .cat-editorial__card:first-child .cat-editorial__title{font-size:1.5rem}
  .cat-editorial__overlay{padding:.9rem 1rem}
  .cat-editorial__index{top:.6rem;left:.7rem;font-size:.7rem}
  .cat-editorial__arrow{width:36px;height:36px}
  .cat-editorial__arrow svg{width:16px;height:16px}
}
@media (max-width:479.98px){
  .cat-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .cat-grid > .cat-editorial__card:first-child,
  .cat-grid > .cat-editorial__card:nth-child(2){grid-column:span 1}
  .cat-grid > .cat-editorial__card:first-child{grid-row:span 1;grid-auto-rows:260px}
}

/* ===== Product card ===== */
.product-card{background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease;display:flex;flex-direction:column;height:100%}
.product-card:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.product-card__img{display:block;position:relative;aspect-ratio:4/5;background:var(--c-bg);overflow:hidden}
.product-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.product-card:hover .product-card__img img{transform:scale(1.03)}
.product-card__body{padding:.9rem 1rem 1rem;flex:1;display:flex;flex-direction:column;gap:.35rem}
.product-card__title{font-size:.95rem;font-weight:500;margin:0;line-height:1.3;max-height:2.6em;overflow:hidden}
.product-card__title a{color:inherit;text-decoration:none}
.product-card__title a:hover{color:var(--c-accent-dk)}
.product-card__prices{display:flex;align-items:baseline;gap:.5rem;margin-top:auto}
.price{font-weight:600;font-size:1.05rem}
.price-old{color:var(--c-muted);text-decoration:line-through;font-size:.85rem}
.badge-chip{position:absolute;top:.75rem;left:.75rem;background:var(--c-ink);color:#fff;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .55rem;border-radius:var(--r-pill)}
.badge-chip--promo{background:var(--c-danger)}
.badge-chip--top{left:auto;right:.75rem;background:var(--c-gold)}
.wish-btn{position:absolute;bottom:.6rem;right:.6rem;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);color:var(--c-ink);display:flex;align-items:center;justify-content:center;cursor:pointer}
.wish-btn.active{background:var(--c-ink);color:#fff}

.stars{color:var(--c-gold);letter-spacing:-.05em;font-size:.85rem;display:inline-flex;align-items:center}
.product-card__rate{display:inline-flex;align-items:center;gap:.3rem}
.product-card__rate-num{font-size:.78rem;color:var(--c-ink-2);font-weight:600}

/* ===== Shop / Filters ===== */
.shop-title{font-family:var(--ff-display);font-weight:600;letter-spacing:-.01em;margin:0}
.shop-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;flex-wrap:wrap}
.chip{display:inline-flex;padding:.4rem .9rem;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-pill);color:var(--c-ink);text-decoration:none;font-size:.85rem}
.chip:hover{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.filters{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:1.25rem;position:sticky;top:160px}
.filter-block{padding:1rem 0;border-bottom:1px solid var(--c-line)}
.filter-block:last-child{border-bottom:0}
.filter-title{font-weight:600;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;color:var(--c-ink-2);margin-bottom:.75rem}

/* ===== Pagination (legacy, non utilisée depuis l'infinite scroll) ===== */
.pagination .page-link{color:var(--c-ink);border:1px solid var(--c-line);margin:0 2px;border-radius:var(--r-md)}
.pagination .page-item.active .page-link{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.pagination .page-link:hover{background:var(--c-bg);border-color:var(--c-ink)}

/* ===== Infinite scroll (boutique/catégorie) ===== */
.shop-inf{margin-top:2.5rem;text-align:center;color:var(--c-ink-2)}
.shop-inf__sentinel{height:1px;width:100%}
.shop-inf__loader{display:inline-flex;align-items:center;gap:.6rem;padding:.75rem 1.25rem;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-pill);font-size:.88rem;box-shadow:var(--sh-1)}
.shop-inf__loader[hidden]{display:none}
.shop-inf__spinner{width:16px;height:16px;border:2px solid var(--c-line);border-top-color:var(--c-ink);border-radius:50%;animation:shopInfSpin .7s linear infinite}
@keyframes shopInfSpin{to{transform:rotate(360deg)}}
.shop-inf__end{padding:1.5rem 0;font-size:.85rem;color:var(--c-muted);letter-spacing:.05em;text-transform:uppercase}
.shop-inf__end[hidden]{display:none}
.shop-inf__error{padding:1rem;background:#FDF5F3;border:1px solid #f3d6d0;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;gap:.4rem;color:var(--c-danger);font-size:.88rem}
.shop-inf__error[hidden]{display:none}

/* Anim d'entrée des cartes chargées dynamiquement */
.shop-inf__new{animation:shopInfIn .35s cubic-bezier(.2,.6,.2,1) both}
@keyframes shopInfIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ===== Product detail (pd-*) ===== */
.pd-wrap{background:var(--c-bg)}
.pd-gallery{display:grid;grid-template-columns:96px minmax(0,1fr);gap:1rem;align-items:start}
.pd-gallery.pd-gallery--solo{grid-template-columns:1fr}
@media (max-width:991px){ .pd-gallery,.pd-gallery.pd-gallery--solo{grid-template-columns:1fr} }

.pd-thumbs-v{display:flex;flex-direction:column;gap:.6rem;max-height:720px;overflow:auto;padding-right:2px}
.pd-thumbs-v::-webkit-scrollbar{width:4px}
.pd-thumbs-v::-webkit-scrollbar-thumb{background:var(--c-line);border-radius:2px}
.pd-thumbs-h{display:none;gap:.5rem;margin-top:.75rem;overflow-x:auto;padding-bottom:.25rem}
@media (max-width:991px){ .pd-thumbs-v{display:none} .pd-thumbs-h{display:flex} }

.pd-thumb{flex:0 0 92px;width:92px;aspect-ratio:1/1;height:auto;border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden;background:#fff;padding:0;cursor:pointer;position:relative;transition:.15s}
.pd-thumb:hover{border-color:var(--c-muted)}
.pd-thumb.active{border-color:var(--c-ink);box-shadow:0 0 0 2px #fff inset}
.pd-thumb img{width:100%;height:100%;object-fit:contain;display:block;padding:4px}
@media (max-width:991px){ .pd-thumb{width:76px;flex:0 0 76px} }

/* Zone image principale : grande, carrée (norme e-commerce),
   object-fit: contain pour ne JAMAIS rogner le produit. */
.pd-main{position:relative;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--sh-1);width:100%;max-width:760px;margin-inline:auto}
/* Si image seule, centre et laisse respirer */
.pd-gallery--solo .pd-main{margin-inline:auto}
.pd-main img{width:100%;height:100%;object-fit:contain;padding:1.25rem;cursor:zoom-in;transition:transform .4s ease;background:linear-gradient(180deg,#fff,#FBF8F3)}
.pd-main.zoomed img{cursor:zoom-out;transform:scale(1.6);padding:0}
.pd-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;border:0;background:rgba(255,255,255,.92);box-shadow:var(--sh-1);display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:var(--c-ink);cursor:pointer;transition:.15s}
.pd-nav:hover{background:#fff;transform:translateY(-50%) scale(1.05)}
.pd-nav--prev{left:12px}
.pd-nav--next{right:12px}

.pd-info{position:sticky;top:130px}
@media (max-width:991px){ .pd-info{position:static;padding-bottom:5.5rem} }

.pd-eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--c-accent-dk);text-decoration:none;font-weight:600;margin-bottom:.35rem}
.pd-eyebrow:hover{color:var(--c-accent);text-decoration:underline}
.pd-title{font-family:var(--ff-display);font-weight:600;letter-spacing:-.015em;font-size:1.6rem;line-height:1.2;margin:0 0 .5rem}
.pd-sub{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-bottom:.5rem}
.pd-meta{color:var(--c-muted);font-size:.8rem}
.pd-tag{background:var(--c-danger);color:#fff;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:.15rem .5rem;border-radius:var(--r-pill)}
.pd-rate-block{display:inline-flex;align-items:center;gap:.35rem}
.pd-rate-block .stars{font-size:.95rem}
.pd-rate-num{font-weight:600;color:var(--c-ink);font-size:.85rem}
.pd-sales{display:inline-flex;align-items:center;gap:.3rem;color:var(--c-success);font-size:.82rem;font-weight:500}
.pd-sales .bi{font-size:.88rem}

.pd-prices{display:flex;align-items:baseline;gap:.75rem;margin:.25rem 0 .65rem;flex-wrap:wrap}
.price-main{font-family:var(--ff-display);font-size:1.55rem;font-weight:600;color:var(--c-ink);letter-spacing:-.01em}
.price-old{color:var(--c-muted);text-decoration:line-through;font-size:.9rem}
.price-save{background:var(--c-danger);color:#fff;font-size:.72rem;padding:.15rem .5rem;border-radius:var(--r-pill);font-weight:600;letter-spacing:.03em}

.pd-short{color:var(--c-ink-2);line-height:1.5;margin-bottom:.35rem;font-size:.9rem}
.pd-sep{border:0;border-top:1px solid var(--c-line);margin:.75rem 0}

.pd-option-group{margin:.65rem 0}
.pd-option-group .form-label{font-size:.85rem;margin-bottom:.3rem}
.pd-option-values{display:flex;flex-wrap:wrap;gap:.35rem}
.pd-option-value{cursor:pointer;position:relative}
.pd-option-value input{position:absolute;opacity:0;pointer-events:none}
.pd-option-value span{display:inline-block;padding:.4rem .85rem;border:1px solid var(--c-line);border-radius:var(--r-pill);background:#fff;font-size:.82rem;color:var(--c-ink);transition:.15s;user-select:none}
.pd-option-value:hover span{border-color:var(--c-ink-2)}
.pd-option-value input:checked + span{background:var(--c-ink);color:#fff;border-color:var(--c-ink);box-shadow:0 2px 6px rgba(30,27,22,.1)}

.pd-qty-row{display:flex;gap:.5rem;align-items:stretch;margin-top:.75rem}
.pd-qty-row .qty{flex:0 0 auto}
.pd-qty-row .pd-cta{flex:1;min-height:44px;font-size:.95rem}

.qty{display:inline-flex;align-items:center;border:1px solid var(--c-line);border-radius:var(--r-pill);overflow:hidden;background:#fff}
.qty .btn{border:0;border-radius:0;width:34px;height:44px;padding:0;font-size:1rem}
.qty .btn:hover{background:var(--c-bg)}
.qty input{width:42px;height:44px;border:0;background:transparent;text-align:center;font-weight:600;font-size:.95rem}
.qty input:focus{outline:none}

.pd-wish{font-size:.85rem;padding:.25rem 0}
.pd-wish.active{color:var(--c-danger)}
.pd-wish.active .bi-heart::before{content:"\f417"}

/* Description inline, juste après la CTA — clé de conversion */
.pd-inline-desc__lead{color:var(--c-ink);font-weight:500;margin-bottom:.5rem;font-size:.92rem;line-height:1.55}
.pd-inline-desc__lead p:last-child{margin-bottom:0}
.pd-inline-desc{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--c-line)}
.pd-inline-desc__title{font-family:var(--ff-display);font-weight:600;font-size:1rem;margin:0 0 .4rem;letter-spacing:-.01em}
.pd-inline-desc__body{font-size:.88rem;line-height:1.55;color:var(--c-ink-2);max-height:7.5em;overflow:hidden;position:relative;transition:max-height .25s ease}
.pd-inline-desc__body.is-open{max-height:none}
.pd-inline-desc__body:not(.is-open)::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2.4em;background:linear-gradient(180deg,transparent,#fff)}
.pd-inline-desc__body p{margin:0 0 .5rem}
.pd-inline-desc__body img{max-width:100%;height:auto;border-radius:var(--r-sm)}
.pd-inline-desc__body ul{padding-left:1.1rem;margin:.25rem 0}
.pd-inline-desc__toggle{border:0;background:none;padding:.25rem 0;margin-top:.35rem;color:var(--c-ink);font-size:.82rem;font-weight:600;cursor:pointer}
.pd-inline-desc__toggle:hover{color:var(--c-accent-dk)}
.pd-inline-desc__toggle .less{display:none}
.pd-inline-desc__toggle.is-open .more{display:none}
.pd-inline-desc__toggle.is-open .less{display:inline}

.pd-assurances{list-style:none;padding:.85rem 1rem;margin:.85rem 0 0;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);display:grid;grid-template-columns:1fr 1fr;gap:.55rem .85rem}
@media (max-width:576px){ .pd-assurances{grid-template-columns:1fr;gap:.5rem} }
.pd-assurances li{display:flex;gap:.55rem;align-items:flex-start}
.pd-assurances .bi{color:var(--c-accent);font-size:1.05rem;flex-shrink:0;line-height:1.2}
.pd-assurances strong{display:block;font-size:.8rem;font-weight:600;line-height:1.25}
.pd-assurances small{color:var(--c-muted);font-size:.72rem;line-height:1.2}

.pd-share{display:flex;align-items:center;gap:.35rem;margin-top:.65rem}
.pd-share a, .pd-share button{width:32px;height:32px;border-radius:50%;border:1px solid var(--c-line);background:#fff;color:var(--c-ink);display:inline-flex;align-items:center;justify-content:center;transition:.15s;cursor:pointer;font-size:.85rem}
.pd-share a:hover, .pd-share button:hover{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}

/* Tabs (infos complémentaires, compact) */
.pd-tablist{border:0;gap:.25rem}
.pd-tablist .nav-link{color:var(--c-ink-2);font-weight:500;border:0;border-bottom:2px solid transparent;border-radius:0;padding:.55rem 1rem;background:transparent;font-size:.9rem}
.pd-tablist .nav-link:hover{color:var(--c-ink);border-color:var(--c-line)}
.pd-tablist .nav-link.active{color:var(--c-ink);border-color:var(--c-ink);background:transparent}
.pd-tabpanels{background:#fff;border:1px solid var(--c-line);border-top:0;border-radius:0 0 var(--r-md) var(--r-md);padding:1rem 1.25rem}
.pd-rich{line-height:1.6;color:var(--c-ink-2);font-size:.9rem}
.pd-rich img{max-width:100%;height:auto;border-radius:var(--r-sm)}
.pd-rich ul{padding-left:1.1rem;margin:0}
.pd-rich h2,.pd-rich h3,.pd-rich h4{color:var(--c-ink);font-family:var(--ff-display);margin:.75rem 0 .35rem}

/* Sticky mobile bar */
.pd-sticky-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--c-line);padding:.65rem .85rem;display:flex;align-items:center;gap:.75rem;z-index:1030;box-shadow:0 -6px 20px rgba(30,27,22,.06)}
.pd-sticky-info{flex:1;min-width:0}
.pd-sticky-cta{padding:.65rem 1.5rem}

/* ===== Cart ===== */
.card-block{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:1.5rem}
.cart-list{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);overflow:hidden}
.cart-row{display:grid;grid-template-columns:84px 1fr auto auto auto auto;gap:1rem;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--c-line)}
.cart-row:last-child{border-bottom:0}
.cart-row__img img{width:84px;height:84px;object-fit:cover;border-radius:var(--r-sm)}
.cart-row__title{font-weight:500;text-decoration:none;color:var(--c-ink);display:block}
.cart-row__title:hover{color:var(--c-accent-dk)}
.cart-row__price{color:var(--c-ink-2)}
.cart-row__total{font-weight:600}
@media (max-width:768px){
  .cart-row{grid-template-columns:72px 1fr auto;row-gap:.5rem}
  .cart-row__qty,.cart-row__price,.cart-row__total{grid-column:2 / span 2}
  .cart-row__remove{grid-column:3;justify-self:end}
}

.summary{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:1.5rem}
.summary-title{font-family:var(--ff-display);font-weight:600;margin:0 0 1rem}
.summary .d-flex{padding:.25rem 0}

/* ===== Checkout ===== */
.pay-opt{display:flex;align-items:center;gap:.5rem;padding:.9rem 1rem;border:1px solid var(--c-line);border-radius:var(--r-md);background:#fff;cursor:pointer;height:100%;transition:.15s}
.pay-opt input{accent-color:var(--c-ink)}
.pay-opt:has(input:checked){border-color:var(--c-ink);background:var(--c-bg)}
.success-ring{width:90px;height:90px;border-radius:50%;background:var(--c-success);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:3rem}

/* ===== Account ===== */
.account-nav{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:.5rem;display:flex;flex-direction:column}
.account-nav__link{padding:.7rem 1rem;color:var(--c-ink);text-decoration:none;border-radius:var(--r-sm);font-size:.95rem}
.account-nav__link:hover{background:var(--c-bg);color:var(--c-ink)}
.account-nav__link.active{background:var(--c-ink);color:#fff}
.stat-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:1.25rem}
.stat-card__num{font-family:var(--ff-display);font-size:2rem;font-weight:600;line-height:1}
.stat-card__label{color:var(--c-muted);font-size:.85rem;margin-top:.25rem}
.status-chip{display:inline-block;padding:.2rem .65rem;border-radius:var(--r-pill);color:#fff;font-size:.75rem}

/* ===== Footer ===== */
.site-footer{background:var(--c-ink);color:#d9d3c5;margin-top:4rem}
.site-footer a{color:#d9d3c5;text-decoration:none;transition:color .15s}
.site-footer a:hover{color:#fff;text-decoration:none}

/* Bande "benefits" — bandeau clair en tête de footer */
.footer-top{background:#23201A;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.5rem 0}
.footer-benefit{display:flex;align-items:center;gap:.85rem;padding:.5rem .25rem}
.footer-benefit i{font-size:1.5rem;color:var(--c-gold);flex-shrink:0;line-height:1}
.footer-benefit strong{display:block;font-size:.9rem;color:#fff;font-weight:600;line-height:1.2}
.footer-benefit span{display:block;font-size:.78rem;color:#a9a194;margin-top:.15rem}

/* Bloc principal */
.footer-main{padding:3rem 0 2rem}
.footer-logo-link{display:inline-block;margin-bottom:1rem}
.footer-logo{height:56px;width:auto;display:block}
.footer-tagline{color:#a9a194;font-size:.9rem;line-height:1.6;margin-bottom:1.25rem;max-width:28rem}

.footer-contact{margin:0;display:flex;flex-direction:column;gap:.55rem}
.footer-contact li{display:flex;align-items:flex-start;gap:.65rem;font-size:.88rem;color:#d9d3c5;line-height:1.4}
.footer-contact li i{color:var(--c-gold);font-size:.95rem;margin-top:.15rem;flex-shrink:0;width:1rem;text-align:center}
.footer-contact a{color:#d9d3c5}
.footer-contact a:hover{color:#fff}

.footer-h{letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;color:#fff;font-weight:600;margin-bottom:1rem;position:relative;padding-bottom:.6rem}
.footer-h::after{content:"";position:absolute;left:0;bottom:0;width:32px;height:2px;background:var(--c-gold);border-radius:2px}

.footer-links{margin:0;display:flex;flex-direction:column;gap:.5rem}
.footer-links li{font-size:.88rem}
.footer-links a{display:inline-flex;align-items:center;color:#bcb6a6}
.footer-links a::before{content:"";width:0;height:1px;background:var(--c-gold);margin-right:0;transition:all .2s ease}
.footer-links a:hover{color:#fff}
.footer-links a:hover::before{width:10px;margin-right:.5rem}

.footer-socials{display:flex;gap:.6rem;flex-wrap:wrap}
.footer-socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.15);display:inline-flex;align-items:center;justify-content:center;color:#d9d3c5;transition:.2s;font-size:1rem;background:rgba(255,255,255,.03)}
.footer-socials a:hover{background:var(--c-gold);color:var(--c-ink);border-color:var(--c-gold);transform:translateY(-2px);text-decoration:none}

/* Barre copyright */
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.1rem 0;background:rgba(0,0,0,.15);color:#a9a194}
.footer-bottom .small{color:#a9a194}
.text-muted-2{color:#8a8174}
.footer-payments{flex-wrap:wrap}
.pay-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border-radius:var(--r-pill);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);color:#d9d3c5;font-size:.75rem}
.pay-badge i{color:var(--c-gold);font-size:.85rem}

/* ===== Benefits ===== */
.benefits .display-6{color:var(--c-accent)}

/* ===== Breadcrumb ===== */
.breadcrumb-wrap{background:transparent;padding:.65rem 0 0}
.breadcrumb-wrap .breadcrumb{font-size:.8rem;margin-bottom:0}

/* ===== Buttons override ===== */
.btn-dark{background:var(--c-ink);border-color:var(--c-ink)}
.btn-dark:hover{background:var(--c-accent-dk);border-color:var(--c-accent-dk)}
.btn-outline-dark{color:var(--c-ink);border-color:var(--c-ink)}
.btn-outline-dark:hover{background:var(--c-ink);border-color:var(--c-ink)}
.rounded-pill{border-radius:var(--r-pill) !important}

/* ===== Empty state ===== */
.empty-state{background:#fff;border:1px dashed var(--c-line);border-radius:var(--r-md)}

/* ===== Toasts ===== */
.toast-host .toast{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);box-shadow:var(--sh-2)}

/* ============================================================================
   RESPONSIVE MOBILE — audit et corrections zero-bug
   ============================================================================ */

/* === Tablette (<992px) === */
@media (max-width:991.98px){
  .container-xxl{padding-inline:1rem}
  .page-title{font-size:1.5rem}
  .section-title{font-size:1.35rem}
  .shop-title{font-size:1.3rem}
  .section-head{flex-wrap:wrap;gap:.5rem;align-items:baseline}

  /* Filtres catalogue : plus de sticky encombrant sur tablette/mobile */
  .filters{position:static !important;top:auto !important;padding:1rem}

  /* Produit : info plus en sticky mobile */
  .pd-info{position:static !important;top:auto !important;padding-bottom:5.5rem}

  /* Pagination : wrap sur plusieurs lignes */
  .pagination{flex-wrap:wrap;gap:4px}
  .pagination .page-item .page-link{padding:.35rem .6rem;font-size:.85rem}
}

/* === Mobile (<768px) === */
@media (max-width:767.98px){
  /* Header — compaction logo + icônes, hauteur réduite */
  .site-header .bar-main > .container-xxl{padding-block:.55rem;gap:.5rem;min-height:60px}
  .brand-text{font-size:1.1rem}
  .brand{max-width:160px}
  .brand-logo{height:38px;max-height:38px}
  .icon-link{width:36px;height:36px;font-size:1.1rem}
  .cart-count{top:0;right:0}

  /* Breadcrumb — compact + wrap */
  .breadcrumb-wrap{padding:.5rem 0 0}
  .breadcrumb-wrap .breadcrumb{flex-wrap:wrap;row-gap:.15rem;font-size:.75rem}

  /* Section spacing */
  .section.py-5{padding-top:2rem !important;padding-bottom:2rem !important}
  .section.py-4{padding-top:1.25rem !important;padding-bottom:1.25rem !important}

  /* Hero */
  .hero .carousel-control-prev,.hero .carousel-control-next{width:12%}

  /* Cards produits — grille 2 cols confortable, typographie compacte */
  .product-card__body{padding:.6rem .7rem .75rem;gap:.25rem}
  .product-card__title{font-size:.85rem;max-height:2.3em}
  .price{font-size:.95rem}
  .price-old{font-size:.78rem}
  .product-card__prices{gap:.35rem}
  .badge-chip{top:.45rem;left:.45rem;padding:.15rem .4rem;font-size:.62rem}
  .badge-chip--top{left:auto;right:.45rem}
  .wish-btn{width:30px;height:30px;bottom:.4rem;right:.4rem}

  /* Tiles catégories */
  .cat-tile{padding:.6rem}
  .cat-tile__img{width:68px;height:68px;margin-bottom:.5rem}
  .cat-tile__label{font-size:.78rem}

  /* Fiche produit */
  .pd-wrap{padding-top:.5rem}
  .pd-main{max-width:100%;border-radius:var(--r-md)}
  .pd-main img{padding:.85rem}
  .pd-nav{width:36px;height:36px;font-size:1rem}
  .pd-title{font-size:1.25rem}
  .price-main{font-size:1.35rem}
  .pd-option-value span{padding:.35rem .75rem;font-size:.8rem}
  .qty .btn{width:36px;height:42px}
  .qty input{width:40px;height:42px}
  .pd-qty-row{flex-wrap:nowrap}
  .pd-qty-row .pd-cta{min-height:42px;font-size:.9rem;padding-inline:.6rem}
  .pd-cta .bi{display:none}
  .pd-assurances{padding:.7rem;grid-template-columns:1fr 1fr;gap:.4rem .6rem}
  .pd-assurances strong{font-size:.74rem}
  .pd-assurances small{font-size:.68rem}
  .pd-tablist{overflow-x:auto;flex-wrap:nowrap;white-space:nowrap;padding-bottom:2px}
  .pd-tablist::-webkit-scrollbar{display:none}
  .pd-tabpanels{padding:.85rem 1rem}

  /* Pages d'authentification */
  .auth .card-block,.card-block{padding:1.1rem}

  /* Panier — cart-row : photo + titre + actions alignés proprement */
  .cart-row{grid-template-columns:68px 1fr auto;column-gap:.75rem;row-gap:.35rem;padding:.85rem}
  .cart-row__img img{width:68px;height:68px}
  .cart-row__title{font-size:.92rem}
  .cart-row__qty{grid-column:1 / span 2;grid-row:2}
  .cart-row__price{display:none}
  .cart-row__total{grid-column:3;grid-row:2;align-self:center;text-align:right;font-size:.95rem}
  .cart-row__remove{grid-column:3;grid-row:1;align-self:start;justify-self:end}
  .cart-row__remove .bi{font-size:1.1rem}

  /* Résumé panier / checkout : prend toute la place, scroll naturel */
  .summary{padding:1rem}
  .summary-title{font-size:1rem}

  /* Checkout — bloc paiement pleine largeur */
  .pay-opt{padding:.7rem .85rem;font-size:.9rem}

  /* Compte — nav horizontal scroll */
  .account-nav{flex-direction:row;overflow-x:auto;gap:.25rem;padding:.4rem;flex-wrap:nowrap}
  .account-nav__link{flex:0 0 auto;white-space:nowrap;padding:.55rem .85rem;font-size:.85rem}
  .account-nav__link i{margin-right:.35rem}

  /* Footer mobile/tablette */
  .site-footer{margin-top:2.5rem}
  .footer-benefits{grid-template-columns:repeat(2,1fr);gap:.5rem;padding:1rem 0}
  .footer-benefit{padding:.4rem .25rem}
  .footer-benefit i{font-size:1.25rem}
  .footer-benefit strong{font-size:.82rem}
  .footer-benefit span{font-size:.72rem}
  .footer-main{padding:2rem 0 1.5rem}
  .footer-logo{height:48px}
  .footer-tagline{max-width:none}
  .footer-socials{justify-content:flex-start}
  .footer-payments{justify-content:flex-start}

  /* Alerts */
  .alert{font-size:.9rem}

  /* Mini hacks de sécurité : rien ne déborde en X */
  .row{--bs-gutter-x:1rem}
}

/* === Petit mobile (<576px) === */
@media (max-width:575.98px){
  :root{ --r-lg: 14px; }

  /* Header : toolbar encore plus fine */
  .site-header .bar-main > .container-xxl{gap:.4rem}
  .brand-text{font-size:1.05rem}
  .brand{max-width:130px}
  .brand-logo{height:34px;max-height:34px}

  /* Hero plus bas */
  .hero .carousel-indicators [data-bs-target]{width:22px;height:3px}

  /* 1 colonne pour les grandes rows sur XS */
  .shop-header{gap:.25rem}

  /* Produit — titre compact */
  .pd-title{font-size:1.15rem;line-height:1.2}
  .pd-prices{gap:.55rem}
  .pd-assurances{grid-template-columns:1fr}
  .pd-tablist .nav-link{padding:.5rem .8rem;font-size:.85rem}

  /* Sticky CTA mobile — laisser respirer le bas */
  .pd-sticky-bar{padding:.55rem .7rem;gap:.55rem}
  .pd-sticky-bar .small{font-size:.72rem}
  .pd-sticky-cta{padding:.55rem 1.1rem;font-size:.85rem}

  /* Cart row en XS : titre + qté + total sur 2 lignes clean */
  .cart-row__total{font-size:.9rem}

  /* Express checkout — card encore plus serré */
  .ex-title{font-size:1.35rem}
  .ex-card{padding:.85rem .9rem}
  .ex-step__title{font-size:.9rem}

  /* Tableaux compte : scroll horizontal */
  .table-responsive{margin:0 -.5rem;padding:0 .5rem}

  /* Checkout payment options : 1 col */
  .pay-opt{font-size:.88rem}

  /* Filtres shop : 2 col pour prix min/max */
  .filter-block{padding:.65rem 0}
  .filter-title{font-size:.78rem}

  /* Page titles */
  .page-title{font-size:1.3rem}
  .section-title{font-size:1.15rem}

  /* Empty state compact */
  .empty-state{padding:1.5rem 1rem !important}
  .empty-state .display-4{font-size:2rem}

  /* 404 */
  .display-1{font-size:3rem}

  /* Footer — compact sur petit mobile */
  .footer-benefits{grid-template-columns:1fr 1fr;gap:.25rem}
  .footer-benefit{gap:.6rem}
  .footer-main{padding:1.5rem 0 1rem}
  .footer-logo{height:42px}
  .pay-badge{padding:.25rem .5rem;font-size:.7rem}
}

/* === Très petit mobile (<380px) === */
@media (max-width:379.98px){
  .brand-text{font-size:.95rem}
  .brand{max-width:110px}
  .brand-logo{height:30px;max-height:30px}
  .btn{font-size:.85rem}
  .hero .carousel-control-prev,.hero .carousel-control-next{display:none}
}

/* Touch targets minimums (WCAG 2.5.5) */
@media (pointer:coarse){
  .btn, .btn-sm, .icon-link, .pd-thumb, .pd-option-value, .account-nav__link,
  .nav-link, .form-select, .page-link {
    min-height:42px;
  }
  .qty .btn{min-height:40px}
}

/* Reduce motion respect utilisateur */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}
