/* ============================================
   MOXIE THEME — PS9 / Hummingbird child
   Palette : #0a0a0a noir + #c1d101 accent
   Dernière mise à jour : Avril 2026
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;800&display=swap');

/* ============================================
   VARIABLES
   ============================================ */

:root {
  --moxie-black:        #0a0a0a;
  --moxie-white:        #ffffff;
  --moxie-accent:       #c1d101;
  --moxie-accent-dark:  #3a3f00;
  --moxie-gray-light:   #f5f5f5;
  --moxie-gray-mid:     #e5e5e5;
  --moxie-gray-text:    #666666;
  --moxie-border:       #e5e5e5;
  --moxie-radius:       6px;
}

/* ============================================
   BASE
   ============================================ */

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--moxie-black);
  background: var(--moxie-white);
  -webkit-font-smoothing: antialiased;
}

a { color: var(--moxie-black); transition: color .15s; }
a:hover { color: var(--moxie-accent); text-decoration: none; }

#search_widget { display: none !important; }

/* ============================================
   TICKER
   ============================================ */

.moxie-ticker {
  background: var(--moxie-black);
  overflow: hidden;
  white-space: nowrap;
  padding: 8px 0;
  width: 100%;
}

.moxie-ticker__inner {
  display: inline-block;
  animation: moxieTick 24s linear infinite;
  font-size: 11px;
  color: var(--moxie-accent);
  letter-spacing: .14em;
  text-transform: uppercase;
}

@keyframes moxieTick {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ============================================
   HEADER
   ============================================ */

.header {
  background: var(--moxie-white) !important;
  border-bottom: .5px solid var(--moxie-border);
  box-shadow: none !important;
  position: relative;
  z-index: 1000;
}

.header-top { display: none !important; }

.header-bottom {
  padding: 0 !important;
  border-bottom: none !important;
}

.header-bottom__container {
  max-width: 100% !important;
  padding: 0 32px !important;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header-bottom__row {
  width: 100%;
  height: 72px;
  display: flex !important;
  align-items: center;
  flex-wrap: nowrap;
}

.header-bottom__logo img,
.header-bottom__logo svg {
  max-height: 32px;
  filter: brightness(0);
}

.header-bottom #_desktop_top_menu {
  flex: 1;
  display: flex;
  justify-content: center;
}

.header-bottom .top-menu {
  display: flex;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ps-mainmenu__tree-link {
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--moxie-gray-text) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  padding: 8px 16px !important;
  display: block;
  transition: background .2s, color .2s !important;
  text-decoration: none !important;
  white-space: nowrap;
  border-radius: 20px !important;
  background: transparent !important;
}

.ps-mainmenu__tree-link:hover,
.ps-mainmenu__tree-item.current .ps-mainmenu__tree-link,
.ps-mainmenu__tree-link[aria-current="page"] {
  color: var(--moxie-white) !important;
  background: var(--moxie-black) !important;
  border-bottom: none !important;
  outline: none !important;
}

.ps-mainmenu__tree-link::after,
.ps-mainmenu__tree-link::before {
  display: none !important;
  content: none !important;
}

.header-bottom a:focus,
.header-bottom a:focus-visible,
.header-bottom button:focus,
.header-bottom button:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

.header-bottom .top-menu .sub-menu {
  background: var(--moxie-white);
  border: .5px solid var(--moxie-border);
  border-radius: var(--moxie-radius);
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
  padding: 8px 0;
  min-width: 200px;
}

.header-bottom .top-menu .sub-menu a {
  font-size: 12px !important;
  color: var(--moxie-gray-text) !important;
  padding: 8px 16px !important;
}

.header-bottom .top-menu .sub-menu a:hover {
  background: var(--moxie-gray-light);
  color: var(--moxie-black) !important;
}

/* ============================================
   CONNEXION
   ============================================ */

.moxie-user-info { display: flex; align-items: center; }

.moxie-user-info__btn {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--moxie-black) !important;
  text-decoration: none !important;
  padding: 6px 10px;
  border-radius: 4px;
  border: .5px solid transparent;
  transition: border-color .15s, background .15s;
  white-space: nowrap;
  font-weight: 400;
}

.moxie-user-info__btn:hover {
  border-color: var(--moxie-border);
  background: var(--moxie-gray-light);
  color: var(--moxie-black) !important;
}

.moxie-user-info__btn--logged { color: var(--moxie-black) !important; }
.moxie-user-info__btn--logged:hover { color: var(--moxie-accent) !important; border-color: transparent; background: transparent; }
.moxie-user-info__label { display: block; }

/* ============================================
   PANIER
   ============================================ */

#blockcart-wrapper { display: flex; align-items: center; }

.moxie-cart-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--moxie-black);
  color: var(--moxie-white) !important;
  font-size: 12px;
  font-weight: 500;
  padding: 7px 14px;
  border-radius: 4px;
  text-decoration: none !important;
  white-space: nowrap;
  transition: background .15s;
  letter-spacing: .01em;
}

.moxie-cart-btn:hover { background: #222; color: var(--moxie-white) !important; }
.moxie-cart-btn__label { line-height: 1; }

.moxie-cart-btn__count {
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark);
  font-size: 10px;
  font-weight: 600;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  line-height: 1;
}

/* ============================================
   MOXIE SEARCH
   ============================================ */

.moxie-search { position: relative; display: flex; align-items: center; }

.moxie-search__trigger {
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 6px;
  color: var(--moxie-black);
  display: flex;
  align-items: center;
  border-radius: 4px;
  transition: background .15s;
}

.moxie-search__trigger:hover { background: var(--moxie-gray-light); }
.moxie-search--open .moxie-search__trigger { color: var(--moxie-accent); }

.moxie-search__overlay {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 0;
  overflow: hidden;
  transition: width .25s cubic-bezier(.4,0,.2,1);
  z-index: 200;
}

.moxie-search__overlay--open { width: 520px; }

.moxie-search__box {
  display: flex;
  align-items: center;
  background: var(--moxie-white);
  border: .5px solid var(--moxie-border);
  border-radius: 6px;
  overflow: hidden;
  height: 40px;
  box-shadow: 0 4px 16px rgba(0,0,0,.08);
}

.moxie-search__cat {
  border: none !important;
  border-right: .5px solid var(--moxie-border) !important;
  background: var(--moxie-gray-light);
  font-size: 12px;
  color: var(--moxie-gray-text);
  padding: 0 10px;
  height: 100%;
  cursor: pointer;
  outline: none;
  min-width: 140px;
  border-radius: 0 !important;
  font-family: inherit;
  flex-shrink: 0;
}

.moxie-search__form { display: flex; align-items: center; flex: 1; height: 100%; }

.moxie-search__input {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  font-size: 13px;
  padding: 0 12px !important;
  height: 100%;
  flex: 1;
  outline: none;
  color: var(--moxie-black);
  min-width: 0;
}

.moxie-search__input::placeholder { color: #bbb; }

.moxie-search__submit {
  background: transparent;
  border: none;
  padding: 0 10px;
  height: 100%;
  cursor: pointer;
  color: var(--moxie-gray-text);
  display: flex;
  align-items: center;
  transition: color .15s;
  flex-shrink: 0;
}

.moxie-search__submit:hover { color: var(--moxie-accent); }

.moxie-search__close {
  background: transparent;
  border: none;
  padding: 0 10px;
  height: 100%;
  cursor: pointer;
  color: #bbb;
  display: flex;
  align-items: center;
  transition: color .15s;
  flex-shrink: 0;
  border-left: .5px solid var(--moxie-border);
}

.moxie-search__close:hover { color: var(--moxie-black); }

.moxie-search__results {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 100%;
  background: var(--moxie-white);
  border: .5px solid var(--moxie-border);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0,0,0,.1);
  overflow: hidden;
  display: none;
  z-index: 300;
}

.moxie-search__results--visible { display: block; }

.moxie-search__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  text-decoration: none !important;
  border-bottom: .5px solid #f5f5f5;
  transition: background .1s;
  color: var(--moxie-black) !important;
}

.moxie-search__item:last-of-type { border-bottom: none; }
.moxie-search__item:hover { background: var(--moxie-gray-light); }

.moxie-search__item-img {
  width: 44px;
  height: 44px;
  border-radius: 6px;
  overflow: hidden;
  background: var(--moxie-gray-light);
  flex-shrink: 0;
}

.moxie-search__item-img img { width: 100%; height: 100%; object-fit: cover; }

.moxie-search__item-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.moxie-search__item-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--moxie-black);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.moxie-search__item-name mark { background: transparent; color: var(--moxie-accent); font-weight: 600; padding: 0; }
.moxie-search__item-cat { font-size: 11px; color: #aaa; text-transform: uppercase; letter-spacing: .06em; }
.moxie-search__item-price { font-size: 13px; font-weight: 500; color: var(--moxie-black); flex-shrink: 0; }
.moxie-search__loading, .moxie-search__no-result { padding: 14px 16px; font-size: 13px; color: #aaa; text-align: center; }
.moxie-search__no-result { color: var(--moxie-gray-text); }

.moxie-search__all {
  display: block;
  padding: 10px 16px;
  font-size: 12px;
  color: var(--moxie-gray-text);
  text-align: center;
  border-top: .5px solid var(--moxie-border);
  text-decoration: none !important;
  background: var(--moxie-gray-light);
  transition: color .15s;
}

.moxie-search__all:hover { color: var(--moxie-black); }

@media (max-width: 768px) {
  .moxie-search__overlay--open { width: calc(100vw - 32px); right: -16px; }
}

/* ============================================
   HERO SLIDER WRAPPER
   ============================================ */

.moxie-heroslider {
  position: relative;
  overflow: hidden;
}

.moxie-heroslider__track {
  display: flex;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

.moxie-heroslider__slide {
  flex-shrink: 0;
  width: 100%;
}

.moxie-heroslider__nav {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 10;
}

.moxie-heroslider__arrow {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.3);
  background: rgba(0,0,0,.25);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background .15s, border-color .15s;
}

.moxie-heroslider__arrow:hover {
  background: rgba(0,0,0,.5);
  border-color: rgba(255,255,255,.5);
}

.moxie-heroslider__dots {
  display: flex;
  gap: 6px;
  align-items: center;
}

.moxie-heroslider__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: #ccc;
  cursor: pointer;
  padding: 0;
  transition: background .3s, width .3s, border-radius .3s;
}

.moxie-heroslider__dot.is-active {
  background: #0a0a0a;
  width: 24px;
  border-radius: 4px;
}

.moxie-heroslider__dot:hover { background: #999; }
.moxie-heroslider__dot.is-active:hover { background: #0a0a0a; }

/* ============================================
   SLIDE 2 — Power Bank (fond rosé)
   ============================================ */

.moxie-hero--powerbank {
  background: #ddcec5 !important;
}

.moxie-hero--powerbank .moxie-hero__left::before { display: none; }

.moxie-hero__eyebrow--warm { color: #b07060 !important; }

.moxie-hero__title--dark { color: #3a2a22 !important; }
.moxie-hero__title--italic { font-style: italic; color: #3a2a22 !important; }

.moxie-hero__baseline {
  font-size: 14px;
  color: #8a6a5a;
  line-height: 1.5;
  margin-bottom: 24px;
}

.moxie-hero__specs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 24px;
  width: 100%;
  max-width: 320px;
}

.moxie-hero__spec {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(255,255,255,.55);
  font-size: 12px;
  font-weight: 500;
  color: #5a3a2a;
}

.moxie-hero__spec-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #e8a090;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.moxie-hero__spec-icon svg { width: 14px; height: 14px; }

.moxie-btn-dark--warm {
  background: #3a2a22 !important;
  color: #fff !important;
}

.moxie-btn-dark--warm:hover { background: #5a3a2a !important; }

.moxie-btn-outline--warm {
  border-color: #8a6a5a !important;
  color: #5a3a2a !important;
}

.moxie-btn-outline--warm:hover { border-color: #3a2a22 !important; }

.moxie-hero__right--pb { background: #ddcec5; }

/* ============================================
   HERO HOME
   ============================================ */

.moxie-hero {
  display: grid;
  grid-template-columns: 44% 56%;
  height: 550px !important;
  border-bottom: .5px solid var(--moxie-border);
  background: url('../img/hero-bg.jpg') center/cover no-repeat;
}

.moxie-hero__left {
  background: transparent;
  padding: 48px 32px 48px 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.moxie-hero__left::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 3px;
  background: var(--moxie-accent);
}

.moxie-hero__brand-img { max-height: 36px; width: auto; margin-bottom: 18px; object-fit: contain; }

.moxie-hero__eyebrow {
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--moxie-accent);
  margin-bottom: 20px;
  font-weight: 500;
}

.moxie-hero__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 82px;
  font-weight: 800;
  line-height: .95;
  margin-bottom: 36px;
  color: var(--moxie-white);
  letter-spacing: -.01em;
  text-transform: uppercase;
}

.moxie-hero__title em { font-style: normal; color: var(--moxie-accent); }

.moxie-hero__ctas { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 28px; }

.moxie-hero__left .moxie-btn-outline { border-color: #444; color: var(--moxie-white) !important; }
.moxie-hero__left .moxie-btn-outline:hover { border-color: var(--moxie-white); }

.moxie-hero__rating { display: flex; align-items: center; gap: 8px; }
.moxie-hero__stars { color: var(--moxie-accent); font-size: 13px; letter-spacing: 2px; }
.moxie-hero__rating-text { font-size: 12px; color: #555; }
.moxie-hero__rating-text strong { color: var(--moxie-white); font-weight: 500; }

.moxie-hero__right--photo { position: relative; overflow: hidden; background: transparent; }

.moxie-hero__photo { width: 100%; height: 100%; object-fit: contain; object-position: right center; display: block; }

.moxie-hero__photo-tag {
  position: absolute;
  top: 20px;
  left: 20px;
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 3px;
}

/* ============================================
   SECTIONS COMMUNES
   ============================================ */

.moxie-section { padding: 40px 32px; }
.moxie-section--no-top { padding-top: 0; }

.moxie-section__header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 24px; }
.moxie-section__header--center { justify-content: center; }

.moxie-section__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 32px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .01em;
  color: var(--moxie-black);
  margin: 0;
  display: inline-block;
  border-bottom: 3px solid var(--moxie-accent);
  padding-bottom: 4px;
}

.moxie-section__title--plain { border-bottom: none; padding-bottom: 0; }

.moxie-section__link {
  font-size: 12px;
  color: #888;
  border-bottom: .5px solid #ddd;
  padding-bottom: 1px;
  text-decoration: none;
  transition: color .15s;
}

.moxie-section__link:hover { color: var(--moxie-black); text-decoration: none; }

/* ============================================
   CATÉGORIES HOME
   ============================================ */

.moxie-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }

.moxie-cat {
  background: var(--moxie-black);
  border-radius: 10px;
  padding: 28px 20px 20px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: background .15s;
  text-decoration: none !important;
  display: block;
}

.moxie-cat:hover { background: #111; }

.moxie-cat__icon {
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif !important;
  font-size: 26px !important;
  margin-bottom: 14px;
  display: block;
  line-height: 1;
}

.moxie-cat__name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--moxie-white);
  margin-bottom: 4px;
}

.moxie-cat__count { font-size: 12px; color: #555; }

.moxie-cat__arrow {
  position: absolute;
  bottom: 16px;
  right: 16px;
  width: 26px;
  height: 26px;
  background: var(--moxie-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: var(--moxie-accent-dark);
  font-weight: 700;
  opacity: 0;
  transition: opacity .2s;
}

.moxie-cat:hover .moxie-cat__arrow { opacity: 1; }

.moxie-cat__bar {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: var(--moxie-accent);
  transition: width .25s;
}

.moxie-cat:hover .moxie-cat__bar { width: 100%; }

/* ============================================
   FEATURED TILES (2×2) — bannières marketing
   Grande tuile image + titre + CTA
   ============================================ */

.moxie-featured {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 16px;
}

.moxie-featured__item {
  position: relative;
  display: block;
  aspect-ratio: 2.25 / 1;
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none !important;
  color: var(--moxie-white) !important;
  background: #f0f0f0;
  transition: transform .25s ease, box-shadow .25s ease;
}

.moxie-featured__item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}

/* Dégradés pastel en fallback — visibles tant que featured-N.png n'est pas présent */
.moxie-featured__item--1 { background: linear-gradient(125deg, #f3e4ee 0%, #e8ccd2 45%, #d8a89c 100%); }
.moxie-featured__item--2 { background: linear-gradient(125deg, #ece0ea 0%, #d8e6d5 60%, #c7dbc2 100%); }
.moxie-featured__item--3 { background: linear-gradient(125deg, #dcdcee 0%, #c5c4dc 100%); }
.moxie-featured__item--4 { background: linear-gradient(125deg, #d5dcd0 0%, #b8c2b0 100%); }

/* Image de fond plein cadre */
.moxie-featured__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .4s ease;
}

.moxie-featured__item:hover .moxie-featured__bg { transform: scale(1.03); }

/* Bloc texte bas-gauche */
.moxie-featured__content {
  position: absolute;
  bottom: 28px;
  left: 32px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.moxie-featured__eyebrow {
  font-size: 12px;
  font-weight: 500;
  color: var(--moxie-white);
  letter-spacing: .01em;
  margin: 0;
  text-shadow: 0 1px 2px rgba(0,0,0,.18);
}

.moxie-featured__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--moxie-white);
  line-height: 1;
  margin: 0 0 10px;
  text-shadow: 0 1px 2px rgba(0,0,0,.18);
}

.moxie-featured__btn {
  display: inline-block;
  background: var(--moxie-white);
  color: var(--moxie-black);
  font-size: 12px;
  font-weight: 500;
  padding: 8px 16px;
  border-radius: 6px;
  transition: background .15s, color .15s;
}

.moxie-featured__item:hover .moxie-featured__btn {
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark);
}

/* Responsive featured */
@media (max-width: 992px) {
  .moxie-featured__title { font-size: 22px; }
  .moxie-featured__content { bottom: 22px; left: 22px; }
}

@media (max-width: 576px) {
  .moxie-featured { grid-template-columns: 1fr; gap: 12px; }
  .moxie-featured__item { aspect-ratio: 16 / 9; }
  .moxie-featured__content { bottom: 18px; left: 18px; }
  .moxie-featured__title { font-size: 20px; }
}

/* ============================================
   PRODUITS HOME
   ============================================ */

.moxie-products-wrap .slick-slider,
.moxie-products-wrap .slick-list,
.moxie-products-wrap .slick-track,
.moxie-products-wrap [data-slick],
.moxie-products-wrap .js-product-list-header,
.moxie-products-wrap .featured-products .products-section-title { display: none !important; }

.moxie-products-wrap .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

.moxie-products-wrap .products > li,
.moxie-products-wrap .products > article {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.moxie-products-wrap .products-section-title,
.moxie-products-wrap h2.h3,
.moxie-products-wrap .all-product-link { display: none !important; }

/* ============================================
   NOS INDISPENSABLES — Hero + liste (option C)
   ============================================ */

.moxie-indis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: stretch;
}

/* ---- HERO : carte foncée gauche ---- */
.moxie-indis__hero {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 340px;
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none !important;
  background: var(--moxie-black);
  transition: opacity .15s;
}

.moxie-indis__hero:hover { opacity: .92; }

/* Photo en fond avec dégradé */
.moxie-indis__hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: .35;
  transition: opacity .3s, transform .3s;
}

.moxie-indis__hero:hover .moxie-indis__hero-bg {
  opacity: .45;
  transform: scale(1.03);
}

/* Dégradé bas → haut pour lisibilité */
.moxie-indis__hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 70%;
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 100%);
  pointer-events: none;
}

.moxie-indis__hero-content {
  position: relative;
  z-index: 1;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Badge "Coup de cœur" */
.moxie-indis__tag {
  display: inline-block;
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 3px;
  align-self: flex-start;
  margin-bottom: 4px;
}

.moxie-indis__hero-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--moxie-white);
  line-height: 1.15;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.moxie-indis__hero-price {
  font-size: 22px;
  font-weight: 500;
  color: var(--moxie-accent);
  margin-top: 4px;
}

.moxie-indis__hero-cta {
  display: inline-flex;
  align-items: center;
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark);
  font-size: 12px;
  font-weight: 600;
  padding: 9px 16px;
  border-radius: 4px;
  align-self: flex-start;
  margin-top: 6px;
  transition: background .15s;
}

.moxie-indis__hero:hover .moxie-indis__hero-cta { background: #aaba00; }

/* ---- LISTE : colonne de mini-cartes droite ---- */
.moxie-indis__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.moxie-indis__mini {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--moxie-white);
  border: .5px solid var(--moxie-border);
  border-radius: 8px;
  padding: 14px;
  text-decoration: none !important;
  flex: 1;
  transition: border-color .15s, transform .15s;
  min-height: 0;
}

.moxie-indis__mini:hover {
  border-color: var(--moxie-black);
  transform: translateX(2px);
}

.moxie-indis__mini-img-wrap {
  width: 80px;
  height: 80px;
  border-radius: 6px;
  overflow: hidden;
  background: var(--moxie-gray-light);
  flex-shrink: 0;
}

.moxie-indis__mini-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}

.moxie-indis__mini:hover .moxie-indis__mini-img { transform: scale(1.06); }

.moxie-indis__mini-info {
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
  min-width: 0;
}

.moxie-indis__mini-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--moxie-black);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.moxie-indis__mini-price {
  font-size: 15px;
  font-weight: 500;
  color: var(--moxie-black);
}

.moxie-indis__mini-arrow {
  width: 32px;
  height: 32px;
  background: var(--moxie-black);
  color: var(--moxie-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  transition: background .15s, color .15s;
}

.moxie-indis__mini:hover .moxie-indis__mini-arrow {
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark);
}

/* Responsive */
@media (max-width: 992px) {
  .moxie-indis { grid-template-columns: 1fr; }
  .moxie-indis__hero { min-height: 280px; }
  .moxie-indis__list { flex-direction: row; flex-wrap: wrap; }
  .moxie-indis__mini { flex: 1 1 calc(50% - 6px); min-width: 0; }
}

@media (max-width: 576px) {
  .moxie-indis__list { flex-direction: column; }
  .moxie-indis__mini { flex: 1 1 100%; }
}

/* ============================================
   STRIP MARQUE
   ============================================ */

.moxie-brand-strip {
  background: #f5f5f0;
  color: var(--moxie-black);
  padding: 56px clamp(32px, 6vw, 120px);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
}

.moxie-brand-strip__left { max-width: 420px; display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.moxie-brand-strip__divider { display: none; }

.moxie-brand-strip__stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; width: 300px; flex-shrink: 0; }

.moxie-brand-strip__label { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: #999; }

.moxie-brand-strip__title {
  font-size: 30px;
  font-weight: 500;
  line-height: 1.15;
  color: var(--moxie-black);
}

.moxie-brand-strip__title em { font-style: italic; }

.moxie-brand-strip__desc { font-size: 13px; color: #888; line-height: 1.75; max-width: 320px; }

.moxie-stat {
  background: var(--moxie-white);
  border-radius: 8px;
  padding: 20px 18px;
  border: none;
}

.moxie-stat__num { font-size: 26px; font-weight: 500; margin-bottom: 6px; color: var(--moxie-black); }
.moxie-stat__label { font-size: 11px; color: #555; text-transform: uppercase; letter-spacing: .06em; }

/* ============================================
   NEWSLETTER — option B split sobre
   ============================================ */

.moxie-newsletter {
  background: #f5f5f0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
  padding: 48px clamp(32px, 6vw, 120px);
}

/* Colonne gauche */
.moxie-newsletter__left {
  max-width: 420px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.moxie-newsletter__eyebrow {
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #999;
}

.moxie-newsletter__title {
  font-size: 26px;
  font-weight: 500;
  color: var(--moxie-black);
  line-height: 1.25;
  margin: 0;
}

.moxie-newsletter__title-underline {
  display: inline;
  font-style: italic;
}

.moxie-newsletter__desc {
  font-size: 13px;
  color: #888;
  line-height: 1.75;
}

/* Séparateur vertical */
.moxie-newsletter__divider {
  display: none;
}

/* Colonne droite */
.moxie-newsletter__right {
  flex: 1;
  max-width: 380px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Messages succès / erreur */
.moxie-newsletter__msg {
  font-size: 13px;
  padding: 10px 14px;
  border-radius: 4px;
}

.moxie-newsletter__msg--success {
  background: #eaf6ed;
  color: #2d6a3f;
  border: .5px solid #b7dfc0;
}

.moxie-newsletter__msg--error {
  background: #fef2f2;
  color: #991b1b;
  border: .5px solid #fca5a5;
}

/* Formulaire */
.moxie-newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.moxie-newsletter__input-wrap {
  display: flex;
  background: var(--moxie-white);
  border: .5px solid #e5e5e5;
  border-radius: 6px;
  overflow: hidden;
  transition: border-color .15s;
}

.moxie-newsletter__input-wrap:focus-within {
  border-color: var(--moxie-black);
}

.moxie-newsletter__input {
  flex: 1;
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 13px 16px !important;
  font-size: 13px !important;
  color: var(--moxie-black);
  outline: none;
  min-width: 0;
}

.moxie-newsletter__input::placeholder { color: #bbb; }

.moxie-newsletter__btn {
  background: var(--moxie-black);
  color: var(--moxie-white);
  border: none;
  padding: 13px 20px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  font-family: inherit;
  transition: background .15s;
  flex-shrink: 0;
}

.moxie-newsletter__btn:hover { background: #222; }

.moxie-newsletter__legal {
  font-size: 11px;
  color: #aaa;
}

/* Avantages */
.moxie-newsletter__perks {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.moxie-newsletter__perk {
  font-size: 11px;
  color: #aaa;
  display: flex;
  align-items: center;
  gap: 5px;
}

.moxie-newsletter__perk-check {
  color: var(--moxie-black);
  font-size: 13px;
  font-weight: 500;
}

/* Responsive */
@media (max-width: 992px) {
  .moxie-newsletter {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 32px 16px;
  }
  .moxie-newsletter__divider { display: none; }
  .moxie-newsletter__left { padding-right: 0; }
  .moxie-newsletter__right { padding-left: 0; }
}

/* ============================================
   TRUST BAR
   ============================================ */

/* Fond beige continu entre brand strip et newsletter */
.footer-before { background: #f5f5f0; }
.page--home ~ .footer-before { margin-top: 0; padding-top: 0; }
.page--home { padding-bottom: 0 !important; margin-bottom: 0 !important; }
#wrapper { margin-bottom: 0; }
#content-wrapper { padding-bottom: 0; }

.moxie-trust {
  display: flex;
  border-top: 1px solid #e5e5e0;
  border-bottom: 1px solid #e5e5e0;
  background: #f5f5f0;
  padding: 0;
}

.moxie-trust__item { flex: 1; display: flex; align-items: center; justify-content: center; gap: 10px; font-size: 12px; font-weight: 500; color: #666; padding: 18px 16px; }
.moxie-trust__item + .moxie-trust__item { border-left: 1px solid #e5e5e0; }

.moxie-trust__icon {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  opacity: 0.4;
}

.moxie-trust__icon svg { width: 20px; height: 20px; }

/* ============================================
   BOUTONS GLOBAUX
   ============================================ */

.moxie-btn-dark {
  display: inline-flex;
  align-items: center;
  background: var(--moxie-black);
  color: var(--moxie-white) !important;
  font-size: 13px;
  padding: 12px 24px;
  border-radius: 5px;
  font-weight: 500;
  text-decoration: none !important;
  transition: background .15s;
  border: none;
  cursor: pointer;
}

.moxie-btn-dark:hover { background: #222; }

.moxie-btn-outline {
  display: inline-flex;
  align-items: center;
  border: .5px solid #ccc;
  color: var(--moxie-black) !important;
  font-size: 13px;
  padding: 12px 24px;
  border-radius: 5px;
  font-weight: 400;
  text-decoration: none !important;
  transition: border-color .15s;
  background: transparent;
  cursor: pointer;
}

.moxie-btn-outline:hover { border-color: var(--moxie-black); }

.moxie-btn-accent {
  display: inline-block;
  background: var(--moxie-accent);
  color: var(--moxie-accent-dark) !important;
  font-size: 13px;
  padding: 12px 26px;
  border-radius: 5px;
  font-weight: 500;
  text-decoration: none !important;
  transition: background .15s;
  border: none;
  cursor: pointer;
}

.moxie-btn-accent:hover { background: #aaba00; }

.btn-primary,
.btn.btn-primary,
button.btn-primary,
.add-to-cart {
  background: var(--moxie-black) !important;
  border-color: var(--moxie-black) !important;
  color: var(--moxie-white) !important;
  border-radius: 5px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  transition: background .15s !important;
}

.btn-primary:hover, .add-to-cart:hover {
  background: #222 !important;
  border-color: #222 !important;
}

/* ============================================
   PAGE CATÉGORIE — LAYOUT PLEIN ÉCRAN
   ============================================ */

/* Supprime la sidebar */
#category #left-column,
#search #left-column { display: none !important; }

/* Content full-width */
#category #content-wrapper,
#search #content-wrapper {
  flex: 0 0 100% !important;
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#category #wrapper > .container,
#search #wrapper > .container {
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* === BANNIÈRE CATÉGORIE === */
.moxie-cat-banner {
  background: var(--moxie-black);
  padding: 32px 28px 28px;
  position: relative;
}

.moxie-cat-banner::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 28px;
  width: 44px;
  height: 3px;
  background: var(--moxie-accent);
}

.moxie-cat-banner__eyebrow {
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--moxie-accent);
  margin-bottom: 8px;
}

.moxie-cat-banner__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 52px;
  text-transform: uppercase;
  color: var(--moxie-white);
  line-height: .95;
  letter-spacing: -.01em;
  margin: 0;
}

.moxie-cat-banner__desc { color: #999; font-size: 12px; margin-top: 10px; line-height: 1.5; max-width: 540px; }

/* === TOOLBAR === */
.moxie-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 28px;
  border-bottom: 1px solid var(--moxie-border);
  background: var(--moxie-white);
  position: sticky;
  top: 0;
  z-index: 100;
}

.moxie-toolbar__count { font-size: 13px; color: var(--moxie-gray-text); flex: 1; }
.moxie-toolbar__count strong { color: var(--moxie-black); font-weight: 700; }

.moxie-toolbar__right { display: flex; align-items: center; gap: 10px; }

/* Tri natif Hummingbird restyled */
.moxie-toolbar .products__sort-label { display: none !important; }

.moxie-toolbar .products__sort-dropdown-button {
  border: 1px solid var(--moxie-border) !important;
  border-radius: 3px !important;
  background: var(--moxie-white) !important;
  color: var(--moxie-black) !important;
  font-size: 12px !important;
  padding: 6px 12px !important;
  font-family: inherit !important;
  box-shadow: none !important;
  text-transform: none !important;
}

.moxie-toolbar .products__sort-dropdown-button:hover { background: var(--moxie-gray-light) !important; }

.moxie-toolbar .dropdown-menu {
  border: 1px solid var(--moxie-border) !important;
  border-radius: 3px !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.08) !important;
  padding: 4px 0 !important;
  min-width: 160px;
}

.moxie-toolbar .dropdown-item {
  font-size: 12px !important;
  padding: 8px 14px !important;
  color: var(--moxie-black) !important;
}

.moxie-toolbar .dropdown-item:hover,
.moxie-toolbar .dropdown-item.current { background: var(--moxie-gray-light) !important; }

/* Bouton FILTRES */
.moxie-toolbar__filter-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--moxie-black);
  border: none;
  color: var(--moxie-white);
  padding: 7px 14px;
  border-radius: 3px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .05em;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s, color .15s;
  white-space: nowrap;
}

.moxie-toolbar__filter-btn:hover { background: var(--moxie-accent); color: var(--moxie-black); }
.moxie-toolbar__filter-btn svg { width: 14px; height: 14px; flex-shrink: 0; }

.moxie-filter-badge {
  background: var(--moxie-accent);
  color: var(--moxie-black);
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  min-width: 16px;
  text-align: center;
  line-height: 1.6;
}

/* === GRILLE 5 COLONNES === */
#category #js-product-list .products,
#search #js-product-list .products {
  display: grid !important;
  grid-template-columns: repeat(5, 1fr) !important;
  gap: 1px !important;
  background: var(--moxie-border) !important;
  padding: 0 !important;
  margin: 0 !important;
}

#category #js-product-list,
#search #js-product-list { background: var(--moxie-border); }

/* === OVERLAY FILTRES === */
.moxie-filter-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10,10,10,.5);
  z-index: 998;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}

.moxie-filter-overlay.is-open { opacity: 1; pointer-events: all; }

/* === DRAWER FILTRES === */
.moxie-filter-drawer {
  position: fixed;
  top: 0;
  right: -380px;
  width: 360px;
  height: 100vh;
  background: var(--moxie-white);
  z-index: 999;
  transition: right .28s cubic-bezier(.25,.8,.25,1);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-left: 1px solid var(--moxie-border);
  box-shadow: -4px 0 24px rgba(0,0,0,.1);
}

.moxie-filter-drawer.is-open { right: 0; }

.moxie-filter-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--moxie-border);
  flex-shrink: 0;
  background: var(--moxie-white);
}

.moxie-filter-drawer__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: .01em;
  color: var(--moxie-black);
}

.moxie-filter-drawer__close {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  color: var(--moxie-gray-text);
  padding: 4px 8px;
  line-height: 1;
  transition: color .15s;
  font-family: inherit;
}

.moxie-filter-drawer__close:hover { color: var(--moxie-black); }

.moxie-filter-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  scrollbar-width: thin;
  scrollbar-color: var(--moxie-border) transparent;
}

.moxie-filter-drawer__body::-webkit-scrollbar { width: 4px; }
.moxie-filter-drawer__body::-webkit-scrollbar-track { background: transparent; }
.moxie-filter-drawer__body::-webkit-scrollbar-thumb { background: var(--moxie-border); border-radius: 2px; }

/* Facettes dans le drawer */
.moxie-filter-drawer__body .facet { margin-bottom: 24px; border: none !important; padding: 0 !important; }

.moxie-filter-drawer__body .facet-title,
.moxie-filter-drawer__body p.h6.facet-title,
.moxie-filter-drawer__body .h6.facet-title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--moxie-black) !important;
  border-bottom: 2px solid var(--moxie-accent) !important;
  display: inline-block !important;
  padding-bottom: 2px !important;
  margin-bottom: 12px !important;
  border-radius: 0 !important;
}

.moxie-filter-drawer__body .facet-label {
  font-size: 12px !important;
  color: var(--moxie-black) !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 5px 0 !important;
  cursor: pointer !important;
  margin: 0 !important;
  transition: color .15s !important;
}

.moxie-filter-drawer__body .facet-label:hover { color: var(--moxie-accent) !important; }
.moxie-filter-drawer__body .facet-label.active { font-weight: 600 !important; }

.moxie-filter-drawer__body ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.moxie-filter-drawer__body .magnitude { font-size: 10px; color: var(--moxie-gray-text); }
.moxie-filter-drawer__body .collapse { display: block !important; }

.moxie-filter-drawer__body .facet-label .color {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.12);
  flex-shrink: 0;
}

/* Custom checkboxes Moxie */
.moxie-filter-drawer__body .custom-checkbox {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  cursor: pointer;
  z-index: 2;
}

.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"] + span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border: 1.5px solid #ccc;
  border-radius: 3px;
  background: var(--moxie-white);
  transition: border-color .15s, background .15s;
  flex-shrink: 0;
}

.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"]:checked + span {
  background: var(--moxie-black);
  border-color: var(--moxie-black);
}

.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"] + span i,
.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"] + span .material-icons {
  display: none;
}

.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"]:checked + span::after {
  content: '';
  display: block;
  width: 10px;
  height: 10px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23fff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}

.moxie-filter-drawer__body .custom-checkbox input[type="checkbox"]:hover + span {
  border-color: var(--moxie-black);
}

/* Custom radio */
.moxie-filter-drawer__body .custom-radio {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.moxie-filter-drawer__body .custom-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  cursor: pointer;
  z-index: 2;
}

.moxie-filter-drawer__body .custom-radio input[type="radio"] + span {
  display: block;
  width: 18px;
  height: 18px;
  border: 1.5px solid #ccc;
  border-radius: 50%;
  background: var(--moxie-white);
  transition: border-color .15s;
  flex-shrink: 0;
}

.moxie-filter-drawer__body .custom-radio input[type="radio"]:checked + span {
  border-color: var(--moxie-black);
  background: var(--moxie-white);
  box-shadow: inset 0 0 0 4px var(--moxie-black);
}

/* Links dans les facets */
.moxie-filter-drawer__body .search-link {
  color: var(--moxie-black) !important;
  text-decoration: none !important;
  font-size: 12px;
}

.moxie-filter-drawer__body .search-link:hover {
  color: var(--moxie-accent) !important;
}

/* Price slider dans le drawer */
.moxie-filter-drawer__body .faceted-slider {
  padding: 10px 4px 0 !important;
}

.moxie-filter-drawer__body .faceted-slider #facet_label_,
.moxie-filter-drawer__body .faceted-slider [id^="facet_label_"] {
  font-size: 12px;
  color: var(--moxie-gray-text);
  margin-bottom: 12px;
}

.moxie-filter-drawer__body .ui-slider {
  height: 4px !important;
  background: var(--moxie-gray-mid) !important;
  border: none !important;
  border-radius: 2px !important;
  margin: 0 8px;
}

.moxie-filter-drawer__body .ui-slider .ui-slider-range {
  background: var(--moxie-black) !important;
  border-radius: 2px;
}

.moxie-filter-drawer__body .ui-slider .ui-slider-handle {
  width: 18px !important;
  height: 18px !important;
  top: -7px !important;
  background: var(--moxie-white) !important;
  border: 2px solid var(--moxie-black) !important;
  border-radius: 50% !important;
  cursor: pointer;
  outline: none;
  box-shadow: 0 1px 4px rgba(0,0,0,.15);
}

.moxie-filter-drawer__body .ui-slider .ui-slider-handle:hover,
.moxie-filter-drawer__body .ui-slider .ui-slider-handle:focus {
  background: var(--moxie-accent) !important;
  border-color: var(--moxie-black) !important;
}

/* Dropdown facet */
.moxie-filter-drawer__body .facet-dropdown .select-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  border: 1px solid var(--moxie-border);
  border-radius: 3px;
  font-size: 12px;
  color: var(--moxie-black);
  cursor: pointer;
  background: var(--moxie-white);
  text-decoration: none !important;
}

.moxie-filter-drawer__body .facet-dropdown .dropdown-menu {
  border: 1px solid var(--moxie-border) !important;
  border-radius: 3px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.08) !important;
  padding: 4px 0 !important;
  width: 100%;
}

.moxie-filter-drawer__body .facet-dropdown .select-list {
  display: block;
  padding: 6px 12px;
  font-size: 12px;
  color: var(--moxie-black);
  text-decoration: none !important;
  transition: background .1s;
}

.moxie-filter-drawer__body .facet-dropdown .select-list:hover {
  background: var(--moxie-gray-light);
}

/* Filtres actifs (pills) sous toolbar */
#js-active-search-filters,
.js-active-filters { padding: 0 28px; margin-top: 5px; }

.active-filter-title { display: none !important; }

.js-active-filters .active_filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 0;
}

.js-active-filters .filter-block {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--moxie-gray-light);
  border: 1px solid var(--moxie-border);
  border-radius: 3px;
  padding: 4px 10px;
  font-size: 11px;
  color: var(--moxie-black);
}

.js-active-filters .filter-block .close {
  font-size: 14px;
  line-height: 1;
  color: var(--moxie-gray-text);
  cursor: pointer;
  margin-left: 4px;
  transition: color .15s;
}

.js-active-filters .filter-block .close:hover {
  color: var(--moxie-black);
}

/* Hide PS native left column (sidebar — already hidden via #category #left-column above) */
.block-categories { display: none !important; }

/* Collapse mobile toggler dans drawer — toujours ouvert */
.moxie-filter-drawer__body .title.hidden-md-up { display: none !important; }
.moxie-filter-drawer__body .hidden-sm-down { display: block !important; }

/* Force Hummingbird accordion facets OPEN inside drawer */
.moxie-filter-drawer__body .accordion-collapse,
.moxie-filter-drawer__body .collapse {
  display: block !important;
  height: auto !important;
  overflow: visible !important;
  visibility: visible !important;
}

.moxie-filter-drawer__body .accordion-button::after { display: none !important; }

.moxie-filter-drawer__body .accordion-item {
  border: none !important;
  background: transparent !important;
}

.moxie-filter-drawer__body .accordion-button {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 0 8px !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--moxie-black) !important;
  border-bottom: 2px solid var(--moxie-accent) !important;
  border-radius: 0 !important;
  display: inline-block !important;
  width: auto !important;
  margin-bottom: 8px !important;
}

.moxie-filter-drawer__body .accordion-body {
  padding: 0 0 16px !important;
}

/* Hide "Filtrer par" title (already in drawer head) */
.moxie-filter-drawer__body .left-block_title,
.moxie-filter-drawer__body [class*="block_title"] {
  display: none !important;
}

/* Facet list items inside accordion */
.moxie-filter-drawer__body .accordion li {
  list-style: none;
}

.moxie-filter-drawer__body .accordion ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Footer drawer */
.moxie-filter-drawer__footer {
  padding: 14px 20px;
  border-top: 1px solid var(--moxie-border);
  display: flex;
  gap: 10px;
  flex-shrink: 0;
  background: var(--moxie-white);
}

.moxie-filter-drawer__reset {
  background: none;
  border: 1px solid var(--moxie-border);
  color: var(--moxie-gray-text);
  padding: 10px 16px;
  font-size: 12px;
  cursor: pointer;
  border-radius: 3px;
  transition: all .15s;
  text-decoration: none !important;
  display: flex;
  align-items: center;
  font-family: inherit;
}

.moxie-filter-drawer__reset:hover { border-color: var(--moxie-black); color: var(--moxie-black); }
.moxie-filter-drawer__reset--disabled { opacity: .4; cursor: default; pointer-events: none; }

.moxie-filter-drawer__apply {
  flex: 1;
  background: var(--moxie-black);
  color: var(--moxie-white);
  border: none;
  padding: 10px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  cursor: pointer;
  border-radius: 3px;
  text-transform: uppercase;
  transition: background .15s, color .15s;
  font-family: inherit;
}

.moxie-filter-drawer__apply:hover { background: var(--moxie-accent); color: var(--moxie-black); }

/* Message vide drawer */
.moxie-filter-empty { padding: 12px 0; text-align: center; }

.moxie-filter-empty__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 12px;
  color: var(--moxie-black);
}

.moxie-filter-empty__desc { font-size: 12px; color: var(--moxie-gray-text); line-height: 1.7; }

/* ============================================
   MINIATURES — CARTE PRODUIT (catégorie)
   ============================================ */

/* Reset card */
.product-miniature {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: var(--moxie-white) !important;
  padding: 0 !important;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .15s !important;
}

#category .product-miniature,
#search .product-miniature {
  border-radius: 0 !important;
  border: none !important;
}

/* Container image */
#category .product-miniature__image-container,
#category .thumbnail-container {
  background: var(--moxie-gray-light);
  overflow: hidden;
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  padding: 12px;
  border-radius: 0 !important;
}

/* Force pas de radius sur toute la chaîne image */
#category .product-miniature__top,
#category .product-miniature__image-container,
#category .thumbnail-container,
#category .product-miniature__image-link {
  border-radius: 0 !important;
}

#category .product-miniature__image-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

#category .product-miniature__image-link picture {
  display: block;
  width: 100%;
  height: 100%;
}

#category .product-miniature__image {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  transition: transform .3s;
  mix-blend-mode: multiply;
}

#category .product-miniature:hover .product-miniature__image { transform: scale(1.04); }

/* IMAGE TOP : position relative pour overlay + bande */
#category .product-miniature__top,
#search .product-miniature__top {
  position: relative;
  overflow: hidden;
}

/* === OVERLAY HOVER (Option B) === */
.moxie-card-overlay {
  position: absolute;
  inset: 0;
  background: var(--moxie-black);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .25s;
  pointer-events: none;
  z-index: 2;
}

#category .product-miniature:hover .moxie-card-overlay { opacity: .55; }
#search .product-miniature:hover .moxie-card-overlay { opacity: .55; }

.moxie-card-overlay__cta {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--moxie-white);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  transform: translateY(8px);
  transition: transform .25s;
}

#category .product-miniature:hover .moxie-card-overlay__cta,
#search .product-miniature:hover .moxie-card-overlay__cta { transform: translateY(0); }

.moxie-card-overlay__circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1.5px solid var(--moxie-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--moxie-accent);
}

.moxie-card-overlay__circle svg { width: 14px; height: 10px; }

/* === BANDE MODÈLES (Option C) === */
.moxie-model-strip {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(10,10,10,.80);
  padding: 7px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 3;
  pointer-events: none;
  transition: opacity .25s;
  border-radius: 0 !important;
  margin: 0 !important;
}

.product-miniature:hover .moxie-model-strip { opacity: 0; }

.moxie-model-strip__label {
  font-size: 8px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--moxie-accent);
  white-space: nowrap;
  flex-shrink: 0;
}

.moxie-model-strip__list {
  display: flex;
  align-items: center;
  flex: 1;
  overflow: hidden;
}

.moxie-model-strip__item {
  font-size: 8px;
  color: rgba(255,255,255,.75);
  white-space: nowrap;
  flex-shrink: 0;
}

.moxie-model-strip__item + .moxie-model-strip__item::before {
  content: ' · ';
  color: rgba(255,255,255,.3);
}

.moxie-model-strip__more {
  font-size: 8px;
  font-weight: 700;
  color: var(--moxie-accent);
  white-space: nowrap;
  flex-shrink: 0;
  margin-left: 4px;
}

/* Sideband désactivé */
.moxie-sideband { display: none !important; }

/* Corps carte */
#category .product-miniature__bottom,
#search .product-miniature__bottom {
  padding: 10px 14px 14px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

#category .product-miniature__infos,
#search .product-miniature__infos {
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

/* Titre 2 lignes */
.moxie-product-title {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--moxie-black) !important;
  text-decoration: none !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 34px;
  line-height: 1.4;
}

/* Prix */
.moxie-product-prices { display: flex; align-items: baseline; gap: 8px; margin-top: 4px; }
.moxie-product-price { font-size: 15px; font-weight: 700; color: var(--moxie-black); }
.moxie-product-old-price { font-size: 12px; color: #ccc; text-decoration: line-through; font-weight: 400; }

/* Pastilles couleur */
.moxie-color-dots { display: flex; align-items: center; gap: 5px; margin-bottom: 4px; }

.moxie-cdot {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1.5px solid rgba(0,0,0,.12);
  flex-shrink: 0;
  text-decoration: none;
  transition: transform .15s;
}

.moxie-cdot:hover { transform: scale(1.2); }
.moxie-cdot.active { border-color: var(--moxie-black); box-shadow: 0 0 0 2px #fff, 0 0 0 3.5px var(--moxie-black); }
.moxie-cdot-more { font-size: .68rem; font-weight: 500; color: var(--moxie-gray-text); line-height: 1; }

/* Supprime actions (bouton split hérité) */
#category .product-miniature__actions,
#search .product-miniature__actions { display: none !important; }

/* Pagination masquée (infinite scroll) */
.products__pagination {
  visibility: hidden;
  height: 0;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

/* ============================================
   INFINITE SCROLL
   ============================================ */

#moxie-scroll-sentinel { height: 1px; width: 100%; display: block; }

#moxie-scroll-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 32px 0;
  width: 100%;
}

#moxie-scroll-loader[hidden] { display: none; }

.moxie-scroll-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--moxie-black);
  animation: moxieDotPulse 1.2s ease-in-out infinite;
  display: inline-block;
}

.moxie-scroll-dot:nth-child(2) { animation-delay: .2s; }
.moxie-scroll-dot:nth-child(3) { animation-delay: .4s; }

@keyframes moxieDotPulse {
  0%, 80%, 100% { opacity: .2; transform: scale(.8); }
  40%           { opacity: 1;  transform: scale(1); }
}

#moxie-scroll-end {
  text-align: center;
  padding: 32px 0 40px;
  width: 100%;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--moxie-gray-text);
}

/* ============================================
   BOUTON SPLIT — signature visuelle (home)
   ============================================ */

.moxie-btn-split {
  display: flex;
  align-items: center;
  border: none;
  border-top: .5px solid #f0f0f0;
  border-radius: 0 0 8px 8px;
  overflow: hidden;
  text-decoration: none !important;
  width: 100%;
  transition: border-color .15s;
  background: transparent;
}

.product-miniature:hover .moxie-btn-split { border-top-color: var(--moxie-black); }

.moxie-btn-split__label { flex: 1; padding: 9px 12px; font-size: 11px; font-weight: 500; color: var(--moxie-black); white-space: nowrap; }

.moxie-btn-split__arrow {
  background: var(--moxie-black);
  color: var(--moxie-white);
  padding: 9px 13px;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
  transition: background .15s, color .15s;
  line-height: 1;
}

.product-miniature:hover .moxie-btn-split__arrow { background: var(--moxie-accent); color: var(--moxie-accent-dark); }

/* ============================================
   FICHE PRODUIT
   ============================================ */

.moxie-product { padding: 32px; max-width: 1400px; margin: 0 auto; }

.moxie-product__layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 48px;
  align-items: start;
}

.moxie-product__gallery { overflow: hidden; background: var(--moxie-gray-light); border-radius: 10px; margin-bottom: 32px; }

.moxie-product .js-images-container,
.moxie-product .product__images { display: flex !important; flex-direction: row !important; gap: 10px; align-items: flex-start; height: 100%; }

.moxie-product .product__thumbnails { order: -1; flex-shrink: 0; width: 76px; padding: 8px 0 8px 8px; overflow-y: auto; scrollbar-width: none; box-sizing: border-box; }
.moxie-product .product__thumbnails::-webkit-scrollbar { display: none; }
.moxie-product .product__thumbnails-list { display: flex !important; flex-direction: column !important; flex-wrap: nowrap !important; gap: 8px; padding: 0; margin: 0; list-style: none; }

.moxie-product .product__thumbnail,
.moxie-product .js-thumb-container {
  width: 68px !important;
  height: 68px !important;
  min-height: 68px;
  flex-shrink: 0;
  border-radius: 6px;
  overflow: hidden;
  background: var(--moxie-gray-light);
  border: .5px solid var(--moxie-border) !important;
  padding: 0 !important;
  cursor: pointer;
  transition: border-color .15s;
  display: block;
  outline: none !important;
  box-shadow: none !important;
}

.moxie-product .product__thumbnail.active,
.moxie-product .js-thumb-container.active,
.moxie-product .js-thumb-container:hover { border-color: var(--moxie-black) !important; }

.moxie-product .js-thumb-container:focus,
.moxie-product .js-thumb-container:focus-visible { outline: 0 !important; box-shadow: none !important; }
.moxie-product .js-thumb-container { --bs-focus-ring-width: 0; --bs-focus-ring-color: transparent; --bs-focus-ring-box-shadow: 0 0 0 0 transparent; }

.moxie-product .product__thumbnail-image,
.moxie-product .js-thumb-container picture,
.moxie-product .js-thumb-container img { width: 100%; height: 100%; object-fit: cover; display: block; mix-blend-mode: multiply; }

.moxie-product .product__carousel,
.moxie-product .js-product-carousel { flex: 1; min-width: 0; aspect-ratio: auto !important; height: 100%; border-radius: 10px; overflow: hidden; background: var(--moxie-gray-light); }

.moxie-product .carousel-inner { height: 100%; }
.moxie-product .carousel-item { height: 100%; }
.moxie-product .carousel-item picture { display: block; height: 100%; }
.moxie-product .carousel-item img { width: 100%; height: 100%; object-fit: contain; display: block; mix-blend-mode: multiply; }

/* ============================================
   FIX BORDURE BLEUE THUMBNAIL — AJOUTÉ 21/04/2026
   ============================================ */

/* Suppression complète de la bordure bleue focus-ring sur les thumbnails */
.moxie-product .product__thumbnail.focus-ring,
.moxie-product .js-thumb-container.focus-ring,
.moxie-product button.focus-ring.js-thumb-container {
  --bs-focus-ring-width: 0 !important;
  --bs-focus-ring-color: transparent !important;
  --bs-focus-ring-box-shadow: none !important;
}

.moxie-product .product__thumbnail.focus-ring:focus,
.moxie-product .product__thumbnail.focus-ring:focus-visible,
.moxie-product .js-thumb-container.focus-ring:focus,
.moxie-product .js-thumb-container.focus-ring:focus-visible,
.moxie-product button.focus-ring.js-thumb-container:focus,
.moxie-product button.focus-ring.js-thumb-container:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  border-color: var(--moxie-black) !important;
}

/* État actif - seule la bordure noire doit être visible */
.moxie-product .product__thumbnail.active.focus-ring,
.moxie-product .js-thumb-container.active.focus-ring {
  outline: none !important;
  box-shadow: none !important;
  border-color: var(--moxie-black) !important;
}

/* ============================================
   ONGLETS ET CONTENU PRODUIT (suite)
   ============================================ */

/* Onglets */
.moxie-product__tab-nav { display: flex; gap: 8px; padding: 4px 0 16px; margin-bottom: 20px; }

.moxie-product__tab-btn {
  background: none;
  border: 1px solid #e0e0e0;
  padding: 7px 20px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #888;
  cursor: pointer;
  font-family: inherit;
  border-radius: 20px;
  transition: background .15s, border-color .15s, color .15s;
}

.moxie-product__tab-btn:hover { border-color: #aaa; color: var(--moxie-black); }
.moxie-product__tab-btn--active { background: var(--moxie-black); border-color: var(--moxie-black); color: var(--moxie-white); }
.moxie-product__tab-content { display: none; }
.moxie-product__tab-content--active { display: block; }
.moxie-product__description { font-size: 13px; color: #555; line-height: 1.8; margin-bottom: 24px; }

/* Chips caractéristiques */
.moxie-product__features { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.moxie-product__chip { display: inline-flex; align-items: center; gap: 6px; background: var(--moxie-black); color: var(--moxie-white); font-size: 11px; padding: 5px 12px; border-radius: 20px; line-height: 1.3; white-space: nowrap; }
.moxie-product__chip-key { color: var(--moxie-accent); font-weight: 600; }
.moxie-product__chip-sep { opacity: .3; font-weight: 300; }

/* Fiche technique */
.moxie-product__details-table { display: flex; flex-direction: column; border: .5px solid var(--moxie-border); border-radius: 8px; overflow: hidden; }
.moxie-product__details-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: .5px solid var(--moxie-border); gap: 16px; }
.moxie-product__details-row:last-child { border-bottom: none; }
.moxie-product__details-key { font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: #888; }
.moxie-product__details-val { font-size: 13px; font-weight: 500; color: var(--moxie-black); font-family: 'Courier New', monospace; }

/* Sidebar sticky */
.moxie-product__sidebar { position: sticky; top: 24px; }

.moxie-product__panel {
  background: #f9f9f9;
  border: .5px solid var(--moxie-border);
  border-radius: 10px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.moxie-product__badges { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }

.moxie-product__eyebrow {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--moxie-accent);
  margin: 0 0 2px;
  display: block;
}

.moxie-product__name {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 34px;
  font-weight: 800;
  line-height: 1.0;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--moxie-black);
  margin: 0 0 6px;
}

.moxie-product__brand { font-size: 12px; color: #888; text-decoration: none; margin-bottom: 14px; display: block; }

.moxie-product__price-wrap { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin: 14px 0; }
.moxie-product__price { font-size: 32px; font-weight: 500; color: var(--moxie-black); line-height: 1; }
.moxie-product__price-old { font-size: 15px; color: #ccc; text-decoration: line-through; font-weight: 400; }
.moxie-product__discount-badge { background: var(--moxie-accent); color: var(--moxie-accent-dark); font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 3px; }
.moxie-product__price-unavailable { font-size: 14px; color: #999; font-style: italic; }
.moxie-product__short-desc { font-size: 12px; color: #888; line-height: 1.7; margin-bottom: 4px; }
.moxie-product__divider { border: none; border-top: .5px solid var(--moxie-border); margin: 14px 0; }
.moxie-product__variants { margin-bottom: 10px; }
.moxie-product__variants .product-variant__label, .moxie-product__variants .product-variant__selected { display: none; }

/* ATC */
.moxie-atc { display: flex; flex-direction: row; gap: 10px; align-items: stretch; width: 100%; }

.moxie-product__atc-row .product__actions-qty-add {
  flex-direction: row !important;
  align-items: stretch !important;
  gap: 10px !important;
  width: 100% !important;
}

.moxie-atc__qty { display: flex; align-items: center; border: 1px solid var(--moxie-border); border-radius: 8px; overflow: hidden; background: #fff; flex-shrink: 0; height: 50px; }

.moxie-atc__qty-btn {
  background: none;
  border: none;
  width: 36px;
  height: 100%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--moxie-black);
  transition: background .1s;
  flex-shrink: 0;
}

.moxie-atc__qty-btn:hover { background: var(--moxie-gray-light); }

.moxie-atc__qty-input {
  width: 36px;
  border: none !important;
  border-left: 1px solid var(--moxie-border) !important;
  border-right: 1px solid var(--moxie-border) !important;
  border-radius: 0 !important;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  height: 100%;
  padding: 0 !important;
  box-shadow: none !important;
  -moz-appearance: textfield;
  background: #fff;
}

.moxie-atc__qty-input::-webkit-inner-spin-button,
.moxie-atc__qty-input::-webkit-outer-spin-button { -webkit-appearance: none; }

.moxie-atc__btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--moxie-black) !important;
  color: var(--moxie-white) !important;
  border: none !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: .04em;
  text-transform: uppercase;
  height: 50px;
  padding: 0 18px !important;
  transition: background .15s !important;
  cursor: pointer;
  white-space: nowrap;
}

.moxie-atc__btn:hover { background: #1a1a1a !important; }
.moxie-atc__btn:disabled, .moxie-atc__btn[aria-disabled="true"] { opacity: .45; cursor: not-allowed; }
.moxie-atc__btn-sep { opacity: .4; font-weight: 300; }
.moxie-atc__btn-price { font-weight: 700; }
.moxie-atc__total { display: flex; align-items: center; justify-content: flex-end; gap: 6px; margin-top: 8px; }
.moxie-atc__total-label { font-size: 12px; color: #888; }
.moxie-atc__total-price { font-size: 18px; font-weight: 600; color: var(--moxie-black); white-space: nowrap; }

/* Réassurance */
.moxie-reassurance { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; }
.moxie-reassurance__item { display: flex; align-items: center; gap: 8px; }
.moxie-reassurance__icon { flex-shrink: 0; color: var(--moxie-black); opacity: .65; display: flex; align-items: center; }
.moxie-reassurance__text { font-size: 12px; color: #555; line-height: 1.4; }

/* Dropdown modèles */
.moxie-vsel { position: relative; width: 100%; }

.moxie-vsel-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 12px 14px;
  background: var(--moxie-black);
  border: none;
  border-radius: 8px;
  font-family: inherit;
  cursor: pointer;
  text-align: left;
  transition: background .15s;
}

.moxie-vsel-btn:hover { background: #1a1a1a; }
.moxie-vsel-btn[aria-expanded="true"] { background: #111; border-radius: 8px 8px 0 0; }
.moxie-vsel-thumb { width: 28px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.moxie-vsel-thumb svg { width: 22px; height: auto; }
.moxie-vsel-text { display: flex; flex-direction: column; gap: 1px; flex: 1; min-width: 0; }
.moxie-vsel-hint { font-size: 10px; color: #666; text-transform: uppercase; letter-spacing: .1em; }
.moxie-vsel-value { font-size: 13px; color: #fff; font-weight: 400; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.moxie-vsel-icon { width: 26px; height: 26px; background: var(--moxie-accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: transform .2s; }
.moxie-vsel-btn[aria-expanded="true"] .moxie-vsel-icon { transform: rotate(180deg); }

.moxie-vsel-list {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--moxie-black);
  border: .5px solid #222;
  border-top: none;
  border-radius: 0 0 8px 8px;
  list-style: none;
  padding: 4px 0;
  margin: 0;
  z-index: 200;
  max-height: 260px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #333 transparent;
}

.moxie-vsel-list::-webkit-scrollbar { width: 4px; }
.moxie-vsel-list::-webkit-scrollbar-track { background: transparent; }
.moxie-vsel-list::-webkit-scrollbar-thumb { background: #333; border-radius: 2px; }
.moxie-vsel-option { display: flex; align-items: center; gap: 12px; padding: 9px 14px; cursor: pointer; border-bottom: .5px solid #111; transition: background .1s; }
.moxie-vsel-option:last-child { border-bottom: none; }
.moxie-vsel-option:hover { background: #1a1a1a; }
.moxie-vsel-option.is-selected { background: #0f0f0f; }
.moxie-vsel-option.is-selected .moxie-vsel-opt-text { color: var(--moxie-accent); font-weight: 500; }
.moxie-vsel-opt-thumb { width: 24px; flex-shrink: 0; display: flex; align-items: center; }
.moxie-vsel-opt-thumb svg { width: 18px; height: auto; }
.moxie-vsel-opt-text { font-size: 13px; color: #ccc; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Swatches couleur */
.moxie-csel { display: flex; flex-direction: column; gap: 10px; }
.moxie-csel__header { display: flex; align-items: center; gap: 5px; font-size: 13px; }
.moxie-csel__group-name { color: #888; }
.moxie-csel__label { color: var(--moxie-black); font-weight: 500; }
.moxie-csel__grid { display: flex; flex-wrap: wrap; gap: 8px; }

.moxie-csel__swatch {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  outline: none;
  transition: transform .1s, border-color .15s, box-shadow .15s;
  position: relative;
  flex-shrink: 0;
}

.moxie-csel__swatch:hover { transform: scale(1.12); box-shadow: 0 2px 8px rgba(0,0,0,.18); }
.moxie-csel__swatch.is-selected { border-color: var(--moxie-black); box-shadow: 0 0 0 1px var(--moxie-black); }
.moxie-csel__swatch.is-selected::after { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23fff' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/14px no-repeat; border-radius: 4px; }
.moxie-csel__swatch--light.is-selected::after { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%230a0a0a' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.moxie-csel__swatch--light { border-color: #d0d0d0; box-shadow: inset 0 0 0 1px #d0d0d0; }
.moxie-csel__swatch--text { font-size: 9px; font-weight: 600; color: #555; display: flex; align-items: center; justify-content: center; border-color: #d0d0d0; }

/* Rupture de stock */
.moxie-oos-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 500; padding: 5px 10px; border-radius: 6px; background: #fef2f2; color: #c0392b; border: .5px solid #fca5a5; margin-bottom: 12px; }
.moxie-atc--oos .moxie-atc__btn { background: #f0f0f0 !important; color: #aaa !important; border-color: #f0f0f0 !important; cursor: not-allowed !important; text-decoration: line-through; opacity: 1 !important; }
.moxie-atc--oos .moxie-atc__qty { opacity: .4; pointer-events: none; }

.moxie-mailalert { margin-top: 2px; }
.moxie-mailalert__label { font-size: 11px; color: #888; margin: 0 0 8px; }
.moxie-mailalert__row { display: flex; gap: 8px; align-items: stretch; }
.moxie-mailalert__input { flex: 1; padding: 10px 12px; border: 1px solid var(--moxie-border); border-radius: 8px; font-size: 12px; box-shadow: none; background: #fff; color: var(--moxie-black); outline: none; }
.moxie-mailalert__input:focus { border-color: var(--moxie-black); }
.moxie-mailalert__btn { background: var(--moxie-black); color: #fff; border: none; border-radius: 8px; padding: 10px 14px; font-size: 12px; font-weight: 500; cursor: pointer; white-space: nowrap; flex-shrink: 0; transition: background .15s; }
.moxie-mailalert__btn:hover { background: #222; }
.moxie-mailalert__gdpr { font-size: 10px; color: #aaa; margin-top: 6px; line-height: 1.4; }
.moxie-mailalert__confirmed { display: flex; align-items: center; gap: 6px; font-size: 12px; color: #2d6a3f; background: #eaf6ed; border: .5px solid #b7dfc0; border-radius: 6px; padding: 8px 12px; margin: 4px 0 0; }

.moxie-oos-alert__form .ps-emailalerts, .moxie-oos-alert__form .ps-emailalerts--product { background: none !important; border: none !important; padding: 0 !important; margin: 0 !important; }
.moxie-oos-alert__form .ps-emailalerts__content .h4, .moxie-oos-alert__form .ps-emailalerts__content p, .moxie-oos-alert__form .ps-emailalerts__content .fs-6 { display: none !important; }
.moxie-oos-alert__form .ps-emailalerts__content { display: flex !important; gap: 8px; align-items: stretch; padding: 0 !important; background: none !important; border: none !important; border-radius: 0 !important; }
.moxie-oos-alert__form .ps-emailalerts__content input[type="email"] { flex: 1 !important; padding: 10px 12px !important; border: 1px solid var(--moxie-border) !important; border-radius: 8px !important; font-size: 12px !important; height: auto !important; box-shadow: none !important; background: #fff !important; color: var(--moxie-black) !important; width: auto !important; order: 1; }
.moxie-oos-alert__form .ps-emailalerts__content input[type="email"]:focus { border-color: var(--moxie-black) !important; outline: none !important; box-shadow: none !important; }
.moxie-oos-alert__form [data-ps-action="emailalerts-subscribe"] { background: var(--moxie-black) !important; color: #fff !important; border: none !important; border-radius: 8px !important; padding: 10px 14px !important; font-size: 12px !important; font-weight: 500 !important; cursor: pointer !important; white-space: nowrap; text-transform: none !important; letter-spacing: 0 !important; height: auto !important; flex-shrink: 0; order: 2; width: auto !important; display: inline-flex !important; align-items: center; }
.moxie-oos-alert__form [data-ps-action="emailalerts-subscribe"]:hover { background: #222 !important; }
.moxie-oos-alert__form .alert-info, .moxie-oos-alert__form .alert-success { font-size: 12px; color: #2d6a3f; background: #eaf6ed; border: .5px solid #b7dfc0; border-radius: 6px; padding: 8px 12px; margin-top: 4px; }

.star-content .star-on, .grade-stars .star-on { color: var(--moxie-accent) !important; }

/* Responsive fiche produit */
@media (max-width: 992px) {
  .moxie-product { padding: 20px 16px; }
  .moxie-product__layout { grid-template-columns: 1fr; gap: 24px; }
  .moxie-product__sidebar { position: static; }
}

@media (max-width: 576px) {
  .moxie-product__panel { padding: 16px; }
  .moxie-product__price { font-size: 26px; }
  .moxie-product__name { font-size: 26px; }
}

/* ============================================
   FOOTER
   ============================================ */

.moxie-footer { background: var(--moxie-black); color: var(--moxie-white); padding: 48px 32px 0; }

.moxie-footer__inner { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr 1.2fr; gap: 32px; padding-bottom: 40px; border-bottom: .5px solid #2a2a2a; }
.moxie-footer__logo { max-height: 36px; margin-bottom: 10px; filter: brightness(0) invert(1); display: block; }
.moxie-footer__tagline { font-size: 11px; color: var(--moxie-accent); letter-spacing: .12em; text-transform: uppercase; margin-bottom: 16px; }
.moxie-footer__address { font-size: 12px; color: #999; line-height: 1.9; font-style: normal; margin-bottom: 14px; }
.moxie-footer__address a, .moxie-footer__b2b a { color: #999; text-decoration: none; transition: color .15s; }
.moxie-footer__address a:hover, .moxie-footer__b2b a:hover { color: var(--moxie-accent); }
.moxie-footer__b2b { font-size: 11px; color: #777; line-height: 1.6; }
.moxie-footer__heading { font-size: 11px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--moxie-white); margin-bottom: 16px; }
.moxie-footer__links { list-style: none; padding: 0; margin: 0; }
.moxie-footer__links li { margin-bottom: 8px; }
.moxie-footer__links a { font-size: 12px; color: #999; text-decoration: none; transition: color .15s; line-height: 1.8; }
.moxie-footer__links a:hover { color: var(--moxie-accent); }
.moxie-footer__account-label { font-size: 11px; color: #999; margin-bottom: 12px; line-height: 1.5; text-transform: uppercase; letter-spacing: .06em; }

.moxie-footer__btn { display: block; border: .5px solid #444; color: var(--moxie-white) !important; font-size: 12px; font-weight: 500; padding: 9px 16px; border-radius: 4px; text-align: center; text-decoration: none !important; margin-bottom: 8px; transition: border-color .15s, background .15s; }
.moxie-footer__btn:hover { border-color: var(--moxie-accent); }
.moxie-footer__btn--outline { background: transparent; border-color: #444; color: #999 !important; }
.moxie-footer__btn--outline:hover { border-color: var(--moxie-accent); color: var(--moxie-accent) !important; }

.moxie-footer__payments { border-top: .5px solid #2a2a2a; padding: 28px 0; text-align: center; }
.moxie-footer__payments-title { font-size: 12px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--moxie-white); margin-bottom: 4px; }
.moxie-footer__payments-sub { font-size: 11px; color: #777; margin-bottom: 16px; }
.moxie-footer__payments-img { max-height: 32px; opacity: .7; }

.moxie-footer__bottom { border-top: .5px solid #2a2a2a; padding: 16px 0; display: flex; align-items: center; justify-content: space-between; }
.moxie-footer__copy { font-size: 11px; color: #777; }
.moxie-footer__instagram { display: flex; align-items: center; gap: 8px; font-size: 12px; color: #999; text-decoration: none !important; transition: color .15s; }
.moxie-footer__instagram:hover { color: var(--moxie-accent); }

/* ============================================
   FORMULAIRES
   ============================================ */

.form-control, input[type="text"], input[type="email"], input[type="password"], textarea {
  border: .5px solid var(--moxie-border) !important;
  border-radius: 4px !important;
  font-size: 13px !important;
  transition: border-color .15s !important;
}

.form-control:focus, input:focus {
  border-color: var(--moxie-black) !important;
  box-shadow: none !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 992px) {
  /* Header */
  .header-bottom__container,
  .header-bottom__row { height: 56px; }

  /* Hero slider */
  .moxie-hero { grid-template-columns: 1fr; height: auto; }
  .moxie-hero__left { min-height: 300px; padding: 36px 24px; }
  .moxie-hero__right--photo { min-height: 280px; }
  .moxie-hero__title { font-size: 56px; }
  .moxie-hero__specs { max-width: 280px; }
  .moxie-heroslider__nav { bottom: 16px; }

  /* Categories */
  .moxie-cats { grid-template-columns: repeat(2, 1fr); }

  /* Produits home */
  .moxie-products-wrap .products { grid-template-columns: repeat(2, 1fr) !important; }

  /* Brand strip */
  .moxie-brand-strip { flex-direction: column; padding: 32px 24px; gap: 32px; text-align: center; align-items: center; }
  .moxie-brand-strip__left { max-width: 100%; align-items: center; }
  .moxie-brand-strip__desc { max-width: 100%; }
  .moxie-brand-strip__stats { width: 100%; max-width: 400px; }

  /* Trust bar */
  .moxie-trust { flex-wrap: wrap; }
  .moxie-trust__item { flex: 1 1 50%; padding: 14px 12px; }
  .moxie-trust__item:nth-child(3) { border-left: none; }
  .moxie-trust__item:nth-child(3),
  .moxie-trust__item:nth-child(4) { border-top: 1px solid #e5e5e0; }

  /* Newsletter */
  .moxie-newsletter { flex-direction: column; padding: 32px 24px; gap: 28px; align-items: center; text-align: center; }
  .moxie-newsletter__left { max-width: 100%; align-items: center; }
  .moxie-newsletter__right { max-width: 100%; width: 100%; }

  /* Footer */
  .moxie-footer__inner { grid-template-columns: repeat(2, 1fr); }
  .moxie-footer__brand { grid-column: 1 / -1; }

  /* Catégorie 3 colonnes */
  #category #js-product-list .products,
  #search #js-product-list .products { grid-template-columns: repeat(3, 1fr) !important; }

  .moxie-cat-banner__title { font-size: 38px; }
  .moxie-toolbar { padding: 10px 16px; }
  .moxie-filter-drawer { width: 320px; right: -330px; }
}

@media (max-width: 768px) {
  /* Hero */
  .moxie-hero__left { min-height: 260px; padding: 28px 20px; }
  .moxie-hero__right--photo { min-height: 240px; }
  .moxie-hero__title { font-size: 48px; margin-bottom: 24px; }
  .moxie-hero__baseline { font-size: 13px; margin-bottom: 18px; }
  .moxie-hero__ctas { justify-content: center; }
  .moxie-hero__photo { object-position: center center; }

  /* Catégorie 2 colonnes */
  #category #js-product-list .products,
  #search #js-product-list .products { grid-template-columns: repeat(2, 1fr) !important; }

  .moxie-cat-banner { padding: 20px 16px 20px; }
  .moxie-cat-banner__title { font-size: 32px; }
  .moxie-cat-banner::after { left: 16px; }
  .moxie-toolbar { padding: 10px 12px; gap: 8px; }

  /* Drawer plein écran sur mobile */
  .moxie-filter-drawer { width: 100%; right: -100%; }
}

@media (max-width: 576px) {
  /* Header */
  .header-bottom__container { padding: 0 16px !important; }

  /* Sections */
  .moxie-section { padding: 24px 16px; }
  .moxie-section__title { font-size: 24px; }

  /* Hero */
  .moxie-hero__left { min-height: 220px; padding: 24px 16px; }
  .moxie-hero__left::before { display: none; }
  .moxie-hero__right--photo { min-height: 200px; }
  .moxie-hero__title { font-size: 38px; margin-bottom: 20px; }
  .moxie-hero__eyebrow { font-size: 10px; margin-bottom: 14px; }
  .moxie-hero__brand-img { max-height: 28px; margin-bottom: 12px; }
  .moxie-hero__rating { flex-direction: column; gap: 4px; }
  .moxie-hero__specs { gap: 6px; max-width: 100%; }
  .moxie-hero__spec { padding: 6px 10px; font-size: 11px; }
  .moxie-hero__spec-icon { width: 24px; height: 24px; }
  .moxie-hero__spec-icon svg { width: 12px; height: 12px; }
  .moxie-hero__baseline { font-size: 12px; margin-bottom: 16px; }
  .moxie-hero__ctas { gap: 8px; }
  .moxie-btn-dark, .moxie-btn-outline { font-size: 12px; padding: 10px 18px; }
  .moxie-heroslider__nav { bottom: 10px; }

  /* Categories */
  .moxie-cats { grid-template-columns: repeat(2, 1fr); }

  /* Produits */
  .moxie-products-wrap .products { grid-template-columns: repeat(2, 1fr) !important; }

  /* Brand strip */
  .moxie-brand-strip { padding: 28px 16px; gap: 24px; }
  .moxie-brand-strip__title { font-size: 24px; }
  .moxie-brand-strip__desc { font-size: 12px; }
  .moxie-brand-strip__stats { gap: 10px; }
  .moxie-stat { padding: 14px 12px; }
  .moxie-stat__num { font-size: 20px; }

  /* Trust bar */
  .moxie-trust { flex-wrap: wrap; }
  .moxie-trust__item { flex: 1 1 50%; font-size: 11px; padding: 12px 10px; gap: 6px; }

  /* Newsletter */
  .moxie-newsletter { padding: 28px 16px; gap: 20px; }
  .moxie-newsletter__title { font-size: 22px; }
  .moxie-newsletter__input-wrap { flex-direction: column; border-radius: 6px; }
  .moxie-newsletter__input { border-bottom: .5px solid #e5e5e5 !important; }
  .moxie-newsletter__btn { border-radius: 0 0 6px 6px; padding: 12px 16px; }

  /* Footer */
  .moxie-footer { padding: 32px 16px 0; }
  .moxie-footer__inner { grid-template-columns: 1fr; gap: 24px; }
  .moxie-footer__bottom { flex-direction: column; gap: 12px; text-align: center; }
}

@media (max-width: 480px) {
  /* Hero */
  .moxie-hero__title { font-size: 32px; }
  .moxie-hero__left { min-height: 180px; }
  .moxie-hero__right--photo { min-height: 180px; }

  /* Catégorie */
  #category #js-product-list .products,
  #search #js-product-list .products { grid-template-columns: repeat(2, 1fr) !important; gap: 1px !important; }

  .moxie-cat-banner__title { font-size: 28px; }
  .moxie-model-strip__label { display: none; }
  .moxie-toolbar .products__sort-label { display: none !important; }
}


/* ============================================
   PAGE RECHERCHE — EN-TÊTE STYLISÉ
   ============================================ */

.moxie-search-header {
  background: var(--moxie-black);
  padding: 32px 28px 28px;
  position: relative;
}

.moxie-search-header::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 28px;
  width: 44px;
  height: 3px;
  background: var(--moxie-accent);
}

.moxie-search-header__inner {
  max-width: 700px;
}

.moxie-search-header__eyebrow {
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--moxie-accent);
  display: block;
  margin-bottom: 8px;
}

.moxie-search-header__title {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 42px;
  text-transform: uppercase;
  color: var(--moxie-white);
  line-height: 1;
  letter-spacing: -.01em;
  margin: 0;
}

.moxie-search-header__keyword {
  color: var(--moxie-accent);
}

.moxie-search-header__count {
  font-size: 13px;
  color: #999;
  margin: 10px 0 0;
}

.moxie-search-header__hint {
  font-size: 13px;
  color: #666;
  margin: 12px 0 0;
  line-height: 1.5;
}

.moxie-search-empty {
  padding: 40px 28px;
  text-align: center;
  font-size: 14px;
  color: var(--moxie-gray-text);
}

/* Masquer la toolbar complète sur la page recherche (infos déjà dans le header) */
#search .moxie-toolbar { display: none; }

@media (max-width: 768px) {
  .moxie-search-header { padding: 20px 16px 20px; }
  .moxie-search-header__title { font-size: 32px; }
  .moxie-search-header::after { left: 16px; }
}

@media (max-width: 480px) {
  .moxie-search-header__title { font-size: 26px; }
}

/* ============================================
   PAGE RECHERCHE — MINIATURES HARMONISÉES
   Mêmes styles que la page catégorie
   ============================================ */

/* Container image : fond gris + aspect-ratio */
#search .product-miniature__image-container,
#search .thumbnail-container {
  background: var(--moxie-gray-light);
  overflow: hidden;
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  padding: 12px;
  border-radius: 0 !important;
}

/* Force pas de radius sur toute la chaîne image */
#search .product-miniature__top,
#search .product-miniature__image-container,
#search .thumbnail-container,
#search .product-miniature__image-link {
  border-radius: 0 !important;
}

#search .product-miniature__image-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

#search .product-miniature__image-link picture {
  display: block;
  width: 100%;
  height: 100%;
}

#search .product-miniature__image {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  transition: transform .3s;
  mix-blend-mode: multiply;
}

#search .product-miniature:hover .product-miniature__image {
  transform: scale(1.04);
}

/* Bandeau modèle : ZÉRO radius partout */
#search .moxie-model-strip {
  border-radius: 0 !important;
}

/* ============================================
   PRODUITS DANS LA MÊME CATÉGORIE (page produit)
   Règles pour forcer le fond gris comme sur pages catégories
   ============================================ */
 
/* Fond gris FORCÉ sur tous les containers d'images */
.moxie-category-products .product-miniature__top,
.moxie-category-products .product-miniature__image-container,
.moxie-category-products .thumbnail-container {
  background: #f5f5f5 !important;
  padding: 16px !important;
  border-radius: 0 !important;
}
 
/* Bandeau modèle : ZÉRO radius partout */
.moxie-category-products .moxie-model-strip {
  border-radius: 0 !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}
 
/* Activation overlay hover */
.moxie-category-products .product-miniature:hover .moxie-card-overlay {
  opacity: .55 !important;
}