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

:root {
  --lila: #D2CBF3;
  --lila-soft: #CBBDF0;
  --lila-hover: #C8A2FF;
  --violet-dark: #2E294E;
  --prune-dark: #2F2B44;
  --dark: #23232B;
  --dark-panel: #1e1e24;
  --text-light: #F6F6F6;

  --tile-h: 660px;
  --tile-radius: 30px;
}


/* =========================================================
   BOUTON "CHOISIR MON POINT RELAIS"
   ========================================================= */

a[href*="choisir-mon-point-relais"] {
  display: inline-block !important;
  padding: 14px 28px !important;
  background-color: var(--lila) !important;
  color: var(--violet-dark) !important;
  border-radius: 40px !important;
  font-weight: 600 !important;
  font-size: 16px !important;
  line-height: 1.1 !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
}

a[href*="choisir-mon-point-relais"] strong {
  color: inherit !important;
  font-weight: inherit !important;
}

a[href*="choisir-mon-point-relais"]:hover {
  background-color: #B8AFE9 !important;
  color: var(--violet-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 0 12px rgba(210,203,243,0.6) !important;
}


/* =========================================================
   PANIER / RÉCAPITULATIF
   ========================================================= */

.cart__recap__wrapper {
  padding: 14px;
}

.cart__recap__title {
  margin-left: -14px;
  margin-right: -14px;
  padding-left: 14px;
  padding-right: 14px;
}

@media (max-width: 768px) {
  .cart__recap__wrapper {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .delivery-comp,
  .delivery-comp strong,
  .delivery-comp .livraison-comp-val,
  .delivery-comp .livraison-comp-name,
  .td-option-price,
  .td-option-price .option-price,
  .td-option-infos,
  .td-option-infos .option-name,
  .td-option-infos .option-val {
    color: #000 !important;
  }

  .delivery-comp a {
    color: var(--lila) !important;
    font-weight: 600;
  }

  #cart-recap .cart__recap__wrapper {
    background: #fff !important;
    border-radius: 18px !important;
    border: 1px solid rgba(210,203,243,.40) !important;
    box-shadow: 0 10px 26px rgba(0,0,0,.14) !important;
    overflow: hidden !important;
  }

  #cart-recap .cart__recap__content {
    background: transparent !important;
  }

  #cart-recap .cart__recap__title {
    margin: 0 !important;
    padding: 14px 16px !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    letter-spacing: .2px !important;
    background: rgba(210,203,243,.26) !important;
    color: #2b2b3c !important;
    border-bottom: 1px solid rgba(0,0,0,.06) !important;
  }

  #cart-recap .cart__recap__item--code {
    background: transparent !important;
    border-bottom: 1px solid rgba(0,0,0,.06) !important;
  }

  #cart-recap .td-reduc-form.cart__recap__item__button {
    padding: 12px 16px !important;
  }

  #cart-recap .td-reduc-form.cart__recap__item__button .option-name {
    color: #2b2b3c !important;
    font-weight: 700 !important;
    letter-spacing: .2px !important;
  }

  #cart-recap .prod.row {
    background: transparent !important;
    padding: 12px 16px !important;
    margin: 0 !important;
    border-bottom: 1px solid rgba(0,0,0,.06) !important;
  }

  #cart-recap .prod.row .column {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #cart-recap .td-prod-photo img {
    width: 56px !important;
    height: 56px !important;
    object-fit: cover !important;
    border-radius: 12px !important;
    border: 1px solid rgba(0,0,0,.06) !important;
    background: #f6f6fb !important;
    display: block !important;
  }

  #cart-recap .prod-name,
  #cart-recap .prod-name-a {
    color: #2b2b3c !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
    text-decoration: none !important;
  }

  #cart-recap .prod-name-a {
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  #cart-recap .var-wrapper {
    display: inline-block !important;
    margin-top: 6px !important;
    padding: 3px 8px !important;
    border-radius: 999px !important;
    background: rgba(210,203,243,.35) !important;
    color: #2b2b3c !important;
    font-size: 12px !important;
    font-weight: 600 !important;
  }

  #cart-recap .prod-price,
  #cart-recap .cart__prod__price__cur__symbol,
  #cart-recap .delivery-details-name,
  #cart-recap .payment-details-name,
  #cart-recap .delivery-details-price,
  #cart-recap .payment-details-price,
  #cart-recap .total-name,
  #cart-recap .total-price {
    color: #2b2b3c !important;
    font-weight: 900 !important;
  }

  #cart-recap #option-delivery,
  #cart-recap #option-payment {
    background: transparent !important;
    padding: 12px 16px !important;
    margin: 0 !important;
    border-bottom: 1px solid rgba(0,0,0,.06) !important;
  }

  #cart-recap .cart__recap__item--end {
    background: rgba(210,203,243,.22) !important;
    padding: 12px 16px !important;
  }
}

@media (min-width: 1024px) {
  .modal-cart__title {
    color: #000 !important;
  }

  .cw .prod-name,
  .cw .prod-name a,
  .cw .prod-name * {
    color: #000 !important;
    -webkit-text-fill-color: #000 !important;
    text-shadow: none !important;
    mix-blend-mode: normal !important;
    opacity: 1 !important;
  }

  .cw .prod-name a:hover,
  .cw .prod-name a:focus {
    color: #000 !important;
  }
}


/* =========================================================
   PAGE LOGIN / BREADCRUMBS
   ========================================================= */

h1.logup__title {
  color: #000 !important;
}

@media (max-width: 768px) {
  .logup__content.logup__login {
    --text-on-body: #111 !important;
    --text-on-body-light: #111 !important;
  }

  .logup__content.logup__login .logup__title,
  .logup__content.logup__login .form__label,
  .logup__content.logup__login .form__span,
  .logup__content.logup__login a,
  .logup__content.logup__login p,
  .logup__content.logup__login span {
    color: var(--text-on-body) !important;
  }

  .logup__content.logup__login input,
  .logup__content.logup__login textarea,
  .logup__content.logup__login select {
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
  }

  .logup__content.logup__login input::placeholder,
  .logup__content.logup__login textarea::placeholder {
    color: #444 !important;
    opacity: 1 !important;
  }

  .breadcrumbs__a.breadcrumbs__a--home {
    color: #fff !important;
    fill: #fff !important;
    opacity: 1 !important;
  }
}


/* =========================================================
   BLOCS HOME : NOUVELLE MARQUE / WIZI ORGASME / GUIDE
   ========================================================= */

.nouvelle-marque h2,
.wizi-orgasme-deux h2 {
  font-size: 3rem;
  font-weight: bold;
  text-shadow: 0 0 5px #fff, 0 0 10px #9b59b6, 0 0 20px #9b59b6;
  margin-bottom: 20px;
}

.nouvelle-marque p,
.wizi-orgasme-deux p {
  font-size: 1.2rem;
  margin: 10px 0 30px;
}

.nouvelle-marque a,
.wizi-orgasme-deux a {
  display: inline-block;
  padding: 12px 30px;
  background: var(--lila);
  color: #fff !important;
  font-weight: bold;
  text-decoration: none;
  border-radius: 30px;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}

.nouvelle-marque a:hover,
.wizi-orgasme-deux a:hover {
  background: #8e44ad;
  box-shadow: 0 0 10px #9b59b6, 0 0 20px #9b59b6;
}

.nouvelle-marque img {
  border-radius: 10px;
  overflow: hidden;
}

.wizi-orgasme-deux {
  border-radius: 30px !important;
  overflow: hidden !important;
  position: relative !important;
  z-index: 1;
}

.wizi-orgasme-deux::before,
.wizi-orgasme-deux::after {
  border-radius: inherit !important;
}

.wizi-orgasme-deux img,
.wizi-orgasme-deux > *:first-child {
  border-radius: inherit !important;
  overflow: hidden !important;
}


/* Bloc "On vous guide" */

.lbao-guide {
  position: relative;
  padding: 32px !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  background-position: right center !important;
}

.lbao-guide > div {
  display: flex !important;
  align-items: center !important;
  gap: 32px !important;
}

.lbao-guide > div > div {
  max-width: 560px !important;
}

.lbao-guide h1,
.lbao-guide h2,
.lbao-guide h3 {
  font-size: 3rem !important;
  font-weight: bold !important;
  margin: 0 0 20px !important;
  color: var(--lila) !important;
  text-shadow:
    0 0 5px #fff,
    0 0 10px #9b59b6,
    0 0 20px #9b59b6 !important;
}

.lbao-guide p {
  font-size: 1.1rem !important;
  line-height: 1.5 !important;
  margin: 0 0 24px !important;
}

.lbao-guide a {
  display: inline-block !important;
  width: fit-content !important;
  margin: 0 0 14px !important;
  padding: 12px 30px !important;
  background: var(--lila) !important;
  color: #fff !important;
  font-weight: bold !important;
  text-decoration: none !important;
  border-radius: 30px !important;
  transition: all 0.3s ease-in-out !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2) !important;
}

.lbao-guide a:hover {
  background: #8e44ad !important;
  box-shadow: 0 0 10px #9b59b6, 0 0 20px #9b59b6 !important;
}

@media (max-width: 900px) {
  .lbao-guide {
    background-size: 60% auto !important;
    background-position: center bottom !important;
    padding-bottom: 180px !important;
    text-align: center !important;
  }

  .lbao-guide > div {
    flex-direction: column !important;
  }

  .lbao-guide a {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .lbao-guide h1,
  .lbao-guide h2,
  .lbao-guide h3 {
    font-size: 2.2rem !important;
  }
}


/* =========================================================
   BLOC NOUVEAUTÉS MOBILE / SCROLLBAR
   ========================================================= */

@media (max-width: 900px) {
  .nouveautes-section {
    --page-margin: 18px;
    --edge-fade: 12px;
  }

  .nouveautes-section .glass-band {
    margin-left: var(--page-margin) !important;
    margin-right: var(--page-margin) !important;
    margin-bottom: 14px !important;
    padding-top: 32px !important;
    padding-bottom: 24px !important;
    overflow: visible !important;
    background: rgba(255,255,255,0.11) !important;
    border-color: rgba(255,255,255,0.22) !important;
    backdrop-filter: blur(10px) saturate(120%) !important;
    -webkit-backdrop-filter: blur(10px) saturate(120%) !important;
  }

  .nouveautes-section .title-glow,
  .home-section.nouveautes-section .glass-band h2.title-glow,
  .home-section.nouveautes-section .glass-band .title-glow,
  .home-section.nouveautes-section .glass-band [class~="title-glow"] {
    font-size: 1.45rem !important;
    line-height: 1.2 !important;
    margin-top: 0 !important;
    margin-bottom: 20px !important;
    white-space: normal !important;
    text-shadow:
      0 0 3px #fff,
      0 0 6px #cbbdf0,
      0 0 10px #cbbdf0 !important;
  }

  .nouveautes-section .carousel-track,
  .home-section.nouveautes-section .glass-band .carousel-track {
    padding-left: 16px !important;
    padding-right: 16px !important;
    padding-bottom: 24px !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: thin !important;
    scrollbar-color: var(--lila-soft) rgba(255,255,255,0.10) !important;
    -webkit-mask-image: linear-gradient(to right,
      transparent 0,
      #000 var(--edge-fade),
      #000 calc(100% - var(--edge-fade)),
      transparent 100%);
    mask-image: linear-gradient(to right,
      transparent 0,
      #000 var(--edge-fade),
      #000 calc(100% - var(--edge-fade)),
      transparent 100%);
  }

  .nouveautes-section .carousel-track::-webkit-scrollbar,
  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar {
    height: 8px !important;
    display: initial !important;
  }

  .nouveautes-section .carousel-track::-webkit-scrollbar-track,
  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.10) !important;
    border-radius: 999px !important;
  }

  .nouveautes-section .carousel-track::-webkit-scrollbar-thumb,
  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar-thumb {
    background: var(--lila-soft) !important;
    border-radius: 999px !important;
  }

  .nouveautes-section .carousel-track::-webkit-scrollbar-thumb:hover,
  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar-thumb:hover {
    background: #d8ccf4 !important;
  }
}

@media (min-width: 901px) {
  .home-section.nouveautes-section .glass-band .carousel-track {
    scrollbar-width: thin;
    scrollbar-color: var(--lila-soft) rgba(255,255,255,0.08);
  }

  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar {
    height: 8px;
  }

  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.08);
    border-radius: 999px;
  }

  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar-thumb {
    background: var(--lila-soft);
    border-radius: 999px;
  }

  .home-section.nouveautes-section .glass-band .carousel-track::-webkit-scrollbar-thumb:hover {
    background: #D9CFF8;
  }
}


/* =========================================================
   FICHES PRODUITS : ONGLETS + / -
   ========================================================= */

.prod-infos__title .icon.icon--arrow-cross,
.prod-carac__title .icon,
.prod-desc__title .icon {
  display: none !important;
}

.prod-infos__title,
.prod-carac__title,
.prod-desc__title {
  position: relative;
  padding-right: 32px;
  cursor: pointer;
}

.prod-infos__title::after,
.prod-carac__title::after,
.prod-desc__title::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 800;
  font-size: 26px;
  line-height: 1;
  color: var(--lila);
}

.prod-details__infos.open .prod-infos__title::after,
.prod-infos__title[aria-expanded="true"]::after,
.prod-details__infos.is-open .prod-infos__title::after,
.prod-details__infos.active .prod-infos__title::after,
.prod-details__desc.open .prod-desc__title::after,
.prod-details__desc .prod-desc__title[aria-expanded="true"]::after,
.prod-details__desc[aria-expanded="true"] .prod-desc__title::after,
.prod-details__carac.open .prod-carac__title::after,
.prod-carac__title[aria-expanded="true"]::after,
.prod-details__carac.is-open .prod-carac__title::after,
.prod-details__carac.active .prod-carac__title::after,
.prod-details__carac[aria-expanded="true"] .prod-carac__title::after {
  content: "–";
}

@media (min-width: 1024px) {
  p.prod-infos__title,
  p.prod-carac__title {
    cursor: default !important;
    pointer-events: none !important;
    background-image: none !important;
  }

  p.prod-infos__title::after,
  p.prod-infos__title::before,
  p.prod-carac__title::after,
  p.prod-carac__title::before {
    display: none !important;
    content: none !important;
    width: 0 !important;
    height: 0 !important;
    background: none !important;
    mask: none !important;
    -webkit-mask: none !important;
    border: 0 !important;
  }
}


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

@media (max-width: 768px) {
  header#header,
  header#header.header__content {
    min-height: 100px !important;
    height: auto !important;
    border: none !important;
    box-shadow: none !important;
  }

  header#header::after,
  header#header.header__content::after {
    display: none !important;
  }

  header#header .container,
  header#header .row,
  header#header .header__inner {
    min-height: 100px !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    overflow: visible !important;
  }

  .header__logo,
  .header__logo--blog {
    min-height: 100px !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
    flex: 0 0 auto !important;
  }

  .header__logo img,
  .header__logo--blog img {
    height: 90px !important;
    width: auto !important;
    max-height: none !important;
    display: block !important;
  }

  .header__icons,
  .header__actions,
  .header__right {
    margin-left: auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    flex: 0 0 auto !important;
  }

  .header__icons a,
  .header__icons button {
    width: 40px !important;
    height: 40px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  header#header * {
    overflow: visible !important;
    line-height: normal !important;
  }

  body {
    padding-top: 100px !important;
  }
}


/* =========================================================
   SIDEBAR / MENU CATÉGORIES
   ========================================================= */

html.lbao-no-scroll {
  overflow: hidden;
}

aside.sidebar {
  left: 0 !important;
  right: auto !important;
  transform: translateX(-100%) !important;
}

aside.sidebar.show {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  z-index: 9999 !important;
  transform: translateX(0) !important;
}

.prod-list__backgroundClose {
  z-index: 9998 !important;
}

.list-top__sidebar {
  background: none;
  border: none;
  cursor: pointer;
  color: #fff !important;
  font-weight: 700;
  white-space: nowrap;
  transition: color .2s;
}

.list-top__sidebar:hover {
  color: var(--lila) !important;
}

.lbao-menu-btn {
  background: none;
  border: none;
  outline: none;
  cursor: pointer;
  color: var(--lila);
  font: inherit;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  white-space: nowrap;
  padding: 0;
}

aside.sidebar .sidebar__li:hover,
aside.sidebar .sidebar__link:hover {
  background: transparent !important;
  box-shadow: none !important;
}

aside.sidebar .sidebar__li:hover .sidebar__link span,
aside.sidebar .sidebar__link:hover span {
  color: var(--lila) !important;
}


/* Bouton catégories mobile */

.menu-categories-btn {
  position: fixed;
  left: 50%;
  right: auto;
  bottom: 18px;
  transform: translateX(-50%);
  z-index: 9999;
  background: var(--lila);
  color: #1E1E24;
  border: none;
  border-radius: 999px;
  padding: 12px 18px;
  font-weight: 700;
  letter-spacing: .2px;
  box-shadow: 0 8px 22px rgba(210,203,243,0.45), 0 0 0 2px rgba(210,203,243,0.35);
}

.menu-categories-btn:hover,
.menu-categories-btn:focus {
  filter: saturate(110%);
  box-shadow: 0 10px 28px rgba(210,203,243,0.55), 0 0 0 3px rgba(210,203,243,0.45);
}

@media (min-width: 1024px) {
  .menu-categories-btn {
    position: sticky;
    left: auto;
    right: auto;
    bottom: auto;
    transform: none;
    top: 96px;
    margin: 12px 0 24px;
  }
}

.menu-categories-panel {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: 72vh;
  background: linear-gradient(0deg, #1F1F27 0%, #252533 100%);
  color: var(--text-light);
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
  box-shadow: 0 -12px 30px rgba(0,0,0,0.45), 0 0 0 1px rgba(255,255,255,0.04) inset;
  padding: 14px 16px 22px;
  z-index: 10000;
  overflow: auto;
  transform: translateY(100%);
  transition: transform .28s ease-out;
}

.menu-categories-panel.is-open {
  transform: translateY(0);
}

.menu-categories-panel .panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

.menu-categories-panel .panel-title {
  font-family: 'Oswald', system-ui, -apple-system, sans-serif;
  font-size: 18px;
  letter-spacing: .3px;
  text-transform: uppercase;
}

@media (max-width: 767px) {
  .menu-categories-btn,
  .button-categories,
  .js-open-categories,
  a[title*="catégor"],
  button[title*="catégor"],
  a[href*="categorie"],
  a[href*="categories"] {
    position: fixed !important;
    left: 16px !important;
    right: auto !important;
    bottom: 18px !important;
    transform: none !important;
    z-index: 9999 !important;
    background: #2b2b2b !important;
    color: #fff !important;
    border: 1px solid #fff !important;
    box-shadow: none !important;
    border-radius: 999px !important;
    padding: 12px 18px !important;
    font-family: 'Oswald', system-ui, sans-serif !important;
    font-weight: 500 !important;
    font-size: 16px !important;
    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease !important;
  }

  .menu-categories-btn:hover,
  .button-categories:hover,
  .js-open-categories:hover,
  a[title*="catégor"]:hover,
  button[title*="catégor"]:hover,
  a[href*="categorie"]:hover,
  a[href*="categories"]:hover {
    filter: brightness(1.08) !important;
    box-shadow: 0 0 10px rgba(255,255,255,0.2) !important;
    transform: translateY(-1px) !important;
  }

  .menu-categories-btn:active,
  .button-categories:active,
  .js-open-categories:active,
  a[title*="catégor"]:active,
  button[title*="catégor"]:active,
  a[href*="categorie"]:active,
  a[href*="categories"]:active {
    filter: brightness(0.95) !important;
    transform: translateY(0) scale(0.98) !important;
    box-shadow: 0 0 6px rgba(255,255,255,0.15) !important;
  }

  .menu-categories-btn:focus-visible,
  .button-categories:focus-visible,
  .js-open-categories:focus-visible {
    outline: 2px dashed #fff !important;
    outline-offset: 3px !important;
  }

  .cat-mobile-row #cat-mobile-trigger {
    position: static !important;
    display: inline-flex;
    align-items: center;
    margin: 0;
    transform: none !important;
    background: #2b2b2b !important;
    color: #fff !important;
    border: 1px solid #fff !important;
    box-shadow: none !important;
    font-family: 'Oswald', system-ui, sans-serif !important;
    font-weight: 500 !important;
  }

  .menu-categories-panel ul,
  .categories-panel ul,
  .offcanvas-categories ul,
  .drawer-categories ul,
  nav[aria-label*="catégor"] ul,
  div[id*="categor"] ul,
  aside[id*="categor"] ul {
    list-style: none !important;
    margin: 8px 0 !important;
    padding: 0 !important;
  }

  .menu-categories-panel li,
  .categories-panel li,
  .offcanvas-categories li,
  .drawer-categories li,
  nav[aria-label*="catégor"] li,
  div[id*="categor"] li,
  aside[id*="categor"] li {
    font-size: 18px !important;
    padding: 14px 12px !important;
    border-radius: 12px !important;
    cursor: pointer !important;
  }

  .menu-categories-panel li a,
  .categories-panel li a,
  .offcanvas-categories li a,
  .drawer-categories li a,
  nav[aria-label*="catégor"] li a,
  div[id*="categor"] li a,
  aside[id*="categor"] li a {
    text-decoration: none !important;
    color: inherit !important;
    display: block !important;
  }

  .menu-categories-panel li:hover,
  .categories-panel li:hover,
  .offcanvas-categories li:hover,
  .drawer-categories li:hover,
  nav[aria-label*="catégor"] li:hover,
  div[id*="categor"] li:hover,
  aside[id*="categor"] li:hover {
    background: rgba(210,203,243,0.12) !important;
  }
}


/* Drawer catégories mobile */

#cat-mobile-drawer .sidebar__ul > .sidebar__li > a,
#cat-mobile-drawer .sidebar__ul > .sidebar__li > span {
  font-size: 20px;
  font-weight: 600;
  padding: 8px 10px;
  line-height: 1.35;
}

#cat-mobile-drawer .sidebar__li .sidebar__ul li > a,
#cat-mobile-drawer .sidebar__li .sidebar__ul li > span {
  font-size: 16px;
  font-weight: 400 !important;
  padding: 6px 10px;
  line-height: 1.3;
}

@media (max-width: 768px) {
  .cat-mobile-row {
    display: flex;
    gap: 12px;
    align-items: center;
    padding: 10px 0 12px;
  }

  #cat-mobile-drawer .sidebar__title {
    margin: 14px 10px 6px;
  }

  #cat-mobile-drawer .sidebar__title__text {
    font-family: 'Oswald', system-ui, -apple-system, sans-serif;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: .2px;
    color: #fff;
    text-decoration: none;
    display: inline-block;
  }

  #cat-mobile-drawer .sidebar__ul > .sidebar__li > a,
  #cat-mobile-drawer .sidebar__ul > .sidebar__li > span {
    font-family: 'Oswald', system-ui, -apple-system, sans-serif;
    font-size: 18px !important;
    font-weight: 600 !important;
    padding: 8px 10px;
    line-height: 1.35;
  }

  #cat-mobile-drawer .sidebar__li .sidebar__ul li > a,
  #cat-mobile-drawer .sidebar__li .sidebar__ul li > span,
  #cat-mobile-drawer .sidebar__li .sidebar__ul li > a *,
  #cat-mobile-drawer .sidebar__li .sidebar__ul li > span * {
    font-family: 'Oswald', system-ui, -apple-system, sans-serif;
    font-size: 16px;
    font-weight: 400 !important;
    padding: 6px 10px;
    line-height: 1.3;
  }

  #cat-mobile-drawer .sidebar__ul {
    list-style: none;
    margin: 6px 0;
    padding: 0;
  }

  #cat-mobile-drawer .sidebar__li {
    margin: 2px 0;
    border-radius: 12px;
  }

  #cat-mobile-drawer .sidebar__li:hover {
    background: rgba(210,203,243,0.12);
  }
}


/* =========================================================
   FILTRES DROPIZI — DESKTOP ONLY
   ========================================================= */

@media (hover:hover) and (pointer:fine) and (min-width: 1024px) {
  .filter,
  .filter__wrapper,
  .filter__item,
  .filter__item__content {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  .filter__wrapper {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 18px !important;
    align-items: center !important;
    justify-content: flex-start !important;
  }

  .filter__item {
    flex: 0 0 auto !important;
    position: relative !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .filter__wrapper > .arrow,
  .filter__item > .arrow {
    display: none !important;
  }

  .filter .filter__label {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 220px !important;
    height: 44px !important;
    padding: 0 16px !important;
    background: #2b2b2b !important;
    background-image: none !important;
    color: #fff !important;
    border: 1px solid #fff !important;
    border-radius: 999px !important;
    box-shadow: none !important;
    font-family: 'Oswald', system-ui, sans-serif !important;
    font-weight: 500 !important;
    font-size: 18px !important;
    line-height: 1 !important;
    letter-spacing: .2px;
    cursor: pointer !important;
  }

  .filter .filter__label::before,
  .filter .filter__label::after,
  .filter__item::before,
  .filter__item::after {
    content: none !important;
    display: none !important;
    background: none !important;
    border: 0 !important;
    box-shadow: none !important;
    width: 0 !important;
    height: 0 !important;
    pointer-events: none !important;
  }

  .filter .filter__label .arrow > *,
  .filter .filter__label .arrow svg,
  .filter .filter__label .arrow i,
  .filter .filter__label .arrow img,
  .filter .filter__label [class*="icon"],
  .filter .filter__label [class*="chevron"] {
    display: none !important;
  }

  .filter .filter__label .arrow {
    position: relative !important;
    top: -1px !important;
    margin-left: auto !important;
    width: 10px !important;
    height: 10px !important;
    background: none !important;
    border-right: 2px solid #fff !important;
    border-bottom: 2px solid #fff !important;
    transform: rotate(-45deg) !important;
    transition: transform .18s ease, border-color .15s ease;
    display: inline-block !important;
    pointer-events: none !important;
    overflow: visible !important;
  }

  .filter .filter__item:hover .filter__label .arrow,
  .filter .filter__showSublevel:checked + .filter__label .arrow {
    transform: rotate(45deg) !important;
    border-right-color: var(--lila-hover) !important;
    border-bottom-color: var(--lila-hover) !important;
  }

  .filter .filter__sublevel {
    display: none !important;
    background: var(--dark-panel) !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,0.2) !important;
    border-radius: 12px !important;
    padding: 12px !important;
    margin-top: 10px !important;
  }

  .filter .filter__item:hover > .filter__item__content > .filter__sublevel,
  .filter .filter__item:hover .filter__sublevel,
  .filter .filter__showSublevel:checked + .filter__label + .filter__sublevel {
    display: block !important;
  }

  .filter .filter__sublevel button.filter__link,
  .filter .filter__sublevel .filter__link {
    display: block !important;
    width: 100% !important;
    text-align: left !important;
    background: transparent !important;
    border: 0 !important;
    color: #fff !important;
    padding: 8px 10px !important;
    border-radius: 8px !important;
    transition: background .15s ease !important;
  }

  .filter .filter__sublevel .filter__link *,
  .filter .filter__sublevel .filter__text,
  .filter .filter__sublevel .filter__text * {
    background: transparent !important;
    color: #fff !important;
    border: 0 !important;
  }

  .filter .filter__sublevel .filter__link:hover {
    background: rgba(255,255,255,0.08) !important;
  }

  .filter .filter__count {
    color: #BBB !important;
    font-weight: 300 !important;
  }

  .filter .filter__sublevel input[type="checkbox"] {
    accent-color: #fff !important;
  }

  .filter .filter__range .input-group,
  .filter .filter__range .input-group * {
    background: transparent !important;
    border-color: rgba(255,255,255,0.22) !important;
    color: #fff !important;
  }

  .filter .filter__range-input {
    background: #2b2b2b !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    border-radius: 6px !important;
    padding: 8px 10px !important;
    color: #fff !important;
  }

  .filter .filter__range .input-group__append,
  .filter .filter__range .input-group__append *,
  .filter .filter__range .input-group__append::before,
  .filter .filter__range .input-group__append::after {
    color: #fff !important;
    font-weight: 500 !important;
    border: 0 !important;
  }

  .filter .filter__sublevel *::before,
  .filter .filter__sublevel *::after {
    background: transparent !important;
    border: 0 !important;
  }

  .filter .filter__sublevel::-webkit-scrollbar {
    width: 10px;
  }

  .filter .filter__sublevel::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.25);
    border-radius: 8px;
  }

  .filter .filter__sublevel::-webkit-scrollbar-track {
    background: transparent;
  }
}


/* =========================================================
   BLOC "PLAISIRS DE SEPTEMBRE"
   ========================================================= */

.wb-promo-sept {
  background-position: 50% 50%;
}

.wb-promo-sept h2 {
  font-size: 3rem;
  font-weight: bold;
  text-shadow: 0 0 5px #fff, 0 0 10px #9b59b6, 0 0 20px #9b59b6;
  margin-bottom: 24px;
}

.wb-promo-sept p {
  font-size: 1.2rem;
  margin: 10px 0 30px;
  text-shadow: 0 2px 8px rgba(0,0,0,0.35);
}

.wb-promo-sept a {
  display: inline-block;
  padding: 12px 30px;
  background: var(--lila);
  color: #fff !important;
  font-weight: bold;
  text-decoration: underline;
  text-decoration-color: #fff;
  text-decoration-thickness: 2px;
  border-radius: 30px;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
  margin-top: 18px;
  text-shadow: none !important;
}

.wb-promo-sept a:hover {
  background: #8e44ad;
  box-shadow: 0 0 10px #9b59b6, 0 0 20px #9b59b6;
}

.wb-promo-sept img {
  border-radius: 30px;
}

@media (min-width: 1024px) {
  .wb-promo-sept p {
    text-shadow:
      0 2px 14px rgba(0,0,0,0.85),
      0 0 10px rgba(0,0,0,0.65),
      0 0 2px rgba(0,0,0,0.55);
  }
}

@media (max-width: 640px) {
  .wb-promo-sept {
    background-position: 42% 50% !important;
  }

  .wb-promo-sept p,
  .wb-promo-sept .tagline,
  .wb-promo-sept .wizitext p,
  .wb-promo-sept .wizi-text p,
  .wb-promo-sept .wiziHtml p {
    text-shadow:
      0 3px 16px rgba(0,0,0,0.9),
      0 0 10px rgba(0,0,0,0.75),
      0 0 2px rgba(0,0,0,0.6) !important;
  }
}


/* =========================================================
   DUO ACCUEIL : PROMO SEPTEMBRE + FOCUS MARQUE
   ========================================================= */

.wb-promo-sept,
.focus-marque-accueil {
  display: inline-block;
  vertical-align: top;
  width: 49%;
  margin: 0 0.5% 24px !important;
  padding-bottom: 0 !important;
  box-sizing: border-box;
  height: var(--tile-h) !important;
  border-radius: var(--tile-radius) !important;
  overflow: hidden !important;
  clip-path: inset(0 round var(--tile-radius)) !important;
  background-size: cover !important;
  background-position: center !important;
  transform: none !important;
  padding-top: 0 !important;
}

.wb-promo-sept img,
.focus-marque-accueil img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wb-promo-sept > *:first-child,
.focus-marque-accueil > *:first-child {
  border-radius: inherit !important;
  overflow: hidden !important;
}

.wb-promo-sept :is(h1,h2,h3):first-child,
.focus-marque-accueil :is(h1,h2,h3):first-child {
  margin-top: 0 !important;
}

.wb-promo-sept :is(h1,h2,h3,p,div):last-child,
.focus-marque-accueil :is(h1,h2,h3,p,div):last-child {
  margin-bottom: 0 !important;
}

@media (min-width: 901px) {
  .wb-promo-sept + .focus-marque-accueil {
    transform: translateY(14px) !important;
  }

  div:has(> .wb-promo-sept):has(> .focus-marque-accueil) {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  div:has(> .wb-promo-sept):has(> .focus-marque-accueil) + * {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  .wizi-orgasme-deux {
    top: auto !important;
    margin-top: 28px !important;
    margin-bottom: 28px !important;
    padding-top: 0 !important;
  }

  .wizi-orgasme-deux + * {
    margin-top: 28px !important;
  }
}

@media (max-width: 900px) {
  .wb-promo-sept,
  .focus-marque-accueil {
    display: block;
    width: 100%;
    height: auto !important;
    margin: 0 0 20px 0 !important;
    clip-path: none !important;
  }

  .wizi-orgasme-deux {
    position: static !important;
    top: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 20px !important;
  }
}
/* =========================================================
   AVIS CLIENTS — + / – MOBILE raccord avec les autres accordéons
   ========================================================= */

@media (max-width: 719px) {

  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head {
    position: relative !important;
    padding-right: 56px !important;
  }

  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head::before {
    content: none !important;
    display: none !important;
  }

  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head.close::after,
  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head.open::after,
  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head:not(.close)::after {
    position: absolute !important;
    right: 19px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;

    color: #D2CBF3 !important;
    font-family: "Playfair Display", Georgia, serif !important;
    font-size: 29px !important;
    font-weight: 400 !important;
    line-height: 1 !important;

    background: none !important;
    width: auto !important;
    height: auto !important;
    pointer-events: none !important;
  }

  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head.close::after {
    content: "+" !important;
  }

  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head.open::after,
  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__head:not(.close)::after {
    content: "–" !important;
  }
}
/* Texte "Ce produit n'a pas encore reçu d'évaluations..." en blanc */
@media (max-width: 719px) {
  #wz-showMessage.rating-v2 .wz-showMessage__wrapper__content__dataMobile__text {
    color: #ffffff !important;
  }
}