/**
 * COMMERCIFY - BARRE DE FILTRAGE STICKY
 * Design minimaliste et performant
 * Zéro killer de process - Optimisé pour la fluidité
 */

/* ==========================================================================
   VARIABLES CSS - COULEURS COMMERCIFY
   ========================================================================== */
:root {
  /* Couleurs Commercify */
  --cfy-primary: #854fff;
  --cfy-primary-light: #9d72ff;
  --cfy-primary-dark: #6b3fff;
  --cfy-success: #1ee0ac;
  --cfy-info: #09c2de;
  --cfy-warning: #f4bd0e;
  --cfy-secondary: #364a63;
  /* Palette Commercify homepage : noir, orange, bleu Jump */
  --cfy-orange: #ff8a00;
  --cfy-orange-dark: #e67a00;
  --cfy-cyan: #09c2de;
  --cfy-noir: #1a1d21;
  
  /* Backgrounds */
  --cfy-bg-light: #ffffff;
  --cfy-bg-light-alt: #f5f6fa;
  --cfy-bg-dark: #1f2b3a;
  --cfy-bg-dark-alt: #2d3238;
  
  /* Text */
  --cfy-text-light: #1f2b3a;
  --cfy-text-dark: #dee2e6;
  --cfy-text-muted: #8091a7;
  
  /* Borders */
  --cfy-border-light: #e5e9f2;
  --cfy-border-dark: #364a63;
  
  /* Shadows - Légères uniquement */
  --cfy-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.08);
  --cfy-shadow: 0 4px 8px rgba(0, 0, 0, 0.12);
  
  /* Dimensions cohérentes */
  --cfy-height-base: 40px;
  --cfy-padding-x: 12px;
  --cfy-padding-y: 10px;
  --cfy-radius: 6px;
  --cfy-gap: 8px;
  
  /* Z-index */
  --sticky-z-index: 1000;
}

/* Mode sombre : variables limitées au sticky (aucun impact sur le reste de l'app) */
.dark-mode .sticky-filters-container,
html.dark-mode .sticky-filters-container,
body.dark-mode .sticky-filters-container,
[data-bs-theme='dark'] .sticky-filters-container {
  --cfy-bg-light: var(--cfy-bg-dark);
  --cfy-bg-light-alt: var(--cfy-bg-dark-alt);
  --cfy-text-light: var(--cfy-text-dark);
  --cfy-border-light: var(--cfy-border-dark);
}

/* ==========================================================================
   ZONE STICKY FILTERS : POSITION FIXE (BORD À BORD)
   La variable nkContentHorizontalPadding n'impacte pas cette zone : le wrapper
   compense uniquement le padding du parent pour rester entre menu et bord d'écran.
   ========================================================================== */
.cfy-sticky-outer-wrapper {
  margin-inline-start: calc(0px - var(--nk-content-padding, 0px)) !important;
  margin-inline-end: calc(0px - var(--nk-content-padding, 0px)) !important;
  width: calc(100% + 2 * var(--nk-content-padding, 0px)) !important;
  box-sizing: border-box !important;
}

/* ==========================================================================
   CONTAINER STICKY PRINCIPAL - CENTRÉ - HYPER RESPONSIVE
   ========================================================================== */
.sticky-filters-container {
  --sticky-row-gap: clamp(2px, 0.3vw, 6px);
  --sticky-row-padding-inline: clamp(6px, 0.8vw, 16px);
  --sticky-padding-block: clamp(3px, 0.3vw, 6px);
  --sticky-control-height: clamp(32px, 2.2vw, 38px);
  --sticky-control-padding-inline: clamp(6px, 0.5vw, 10px);
  --sticky-control-font-size: clamp(0.7rem, 0.6vw, 0.8rem);
  position: sticky;
  top: var(--header-height, 70px);
  left: 0;
  right: 0;
  width: 100%;
  z-index: var(--sticky-z-index);
  /* Pas de background ici : couleur fournie par le HTML/JS (configurée, défaut noir) — évite d'écraser l'inline */
  border-bottom: none;
  box-shadow: none;
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin: 0;
  margin-bottom: 0;
  overflow: visible;
  box-sizing: border-box;
}

/* Espacement entre stickyfilters et vignettes */
.glassystem-main-container,
.cfy-vignettes-block {
  margin-top: 0px !important;
}

/* Supprimer toute marge/padding en haut du conteneur des vignettes (grand format et mini) */
.glassystem-view-container,
.cfy-vignettes-layout-shell {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Premier niveau sous glassystem-view-container (row ou div.mt-0) : pas d'espacement forcé en haut */
.glassystem-main-container .glassystem-view-container > div,
.cfy-vignettes-block .cfy-vignettes-layout-shell > div {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* ==========================================================================
   MOBILE & TABLETTE - LOGIQUE DE FLUX NATUREL (CLEAN DOM)
   ========================================================================== */
/* Sur les écrans non-desktop (< 1200px), on force le header en position relative
   pour qu'il prenne sa place dans le flux et pousse le contenu vers le bas.
   Plus de hacks de margin-top fixes ou calculés en JS. */
@media (max-width: 1199.98px) {
  /* Header : Position relative pour qu'il pousse le contenu */
  .nk-header-fixed {
    position: relative !important;
    top: auto !important;
    width: 100% !important;
  }

  /* Content : On annule la compensation de marge prévue pour le header fixe */
  .nk-header-fixed + .nk-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* Tablette uniquement : supprimer toute bande blanche entre header et zone titre catalogue */
  @media (min-width: 769px) and (max-width: 1199.98px) {
    .nk-content-body,
    .nk-content-inner {
      padding-top: 0 !important;
      margin-top: 0 !important;
    }
  }

  /* Vignettes : Espacement standard pour Mobile et Tablettes classiques (iPad Air, etc.) */
  /* On remet à 0 ou une petite valeur positive pour éviter le chevauchement rapporté sur iPad Air */
  .glassystem-main-container {
    margin-top: 0px !important;
    padding-top: 0 !important;
  }
  
  /* Masquer le conteneur sticky filters au cas où il serait chargé */
  .sticky-filters-container {
    display: none !important;
  }
}

/* ==========================================================================
   EXCEPTIONS TABLETTES PAR RÉSOLUTION (uniquement si body.device-tablet)
   ========================================================================== */

/* iPad Air vertical 820×1180 : trop d'espace → remonter de 10px */
@media (min-width: 815px) and (max-width: 825px) {
  body.device-tablet .glassystem-main-container {
    margin-top: -20px !important;
  }
}

/* Surface Pro 7 vertical 912×1368 : vignettes sous le header → ajouter espacement */
@media (min-width: 907px) and (max-width: 917px) {
  body.device-tablet .glassystem-main-container {
    margin-top: 10px !important;
  }
}

/* iPad Pro 12.9" (1024px) : vide qu'on compense par marge négative */
@media (min-width: 1024px) and (max-width: 1199.98px) {
  .glassystem-main-container {
    margin-top: -20px !important;
  }
}

@media (min-width: 1200px) {
  .nk-sidebar + .nk-wrap {
    --sticky-sidebar-offset: 290px;
  }

  .nk-sidebar.is-compact:not(:hover) + .nk-wrap {
    --sticky-sidebar-offset: 76px;
  }

  .nk-sidebar.is-compact:hover + .nk-wrap {
    --sticky-sidebar-offset: 290px;
  }

  /* Wrapper parent : recoit la compensation en PHP (pushed) ou le positionnement par le theme (overlay) */
  .cfy-sticky-outer-wrapper {
    box-sizing: border-box !important;
    width: 100%;
  }
  .cfy-sticky-outer {
    box-sizing: border-box !important;
    max-width: 100% !important;
  }
  .cfy-sticky-outer .sticky-filters-container {
    margin-inline-start: 0 !important;
    margin-inline-end: 0 !important;
    width: 100% !important;
  }

  .sticky-filters-container {
    --sticky-row-gap: clamp(2px, 0.3vw, 5px);
    --sticky-row-padding-inline: clamp(8px, 0.5vw, 14px);
    --sticky-padding-block: clamp(4px, 0.3vw, 6px);
    --sticky-control-height: clamp(30px, 2vw, 36px);
    --sticky-control-font-size: clamp(0.7rem, 0.6vw, 0.8rem);
    --sticky-control-padding-inline: clamp(6px, 0.45vw, 9px);
  }
}

/* Masquer uniquement sur mobile/tablette (<= 1024px) */
@media (max-width: 1024.98px) {
  .sticky-filters-container {
    display: none !important;
  }
}

/* ==========================================================================
   STRUCTURE INTERNE - CENTRÉE ET SIMPLIFIÉE
   ========================================================================== */
.sticky-filters-container .card {
  border: none;
  box-shadow: none;
  background: transparent;
  margin: 0;
  margin-top: 0;
  padding: 0;
  padding-top: 0;
  max-width: 100vw;
  width: 100%;
  overflow: visible !important;
  box-sizing: border-box;
}

.sticky-filters-container .card-body {
  padding: 0;
  padding-top: 0;
  background: transparent;
  margin: 0;
  margin-top: 0;
  max-width: 100vw;
  width: 100%;
  overflow: visible !important;
  box-sizing: border-box;
}

/* Boutons de contrôle textuels - Style harmonisé avec la première ligne */
.sticky-control-btn-textual {
  height: var(--sticky-control-height);
  padding: 0 var(--sticky-control-padding-inline);
  font-size: var(--sticky-control-font-size);
  font-weight: 400;
  color: var(--cfy-text-light);
  background: transparent !important;
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  transition: border-color 0.15s ease;
  cursor: pointer;
  box-shadow: none;
  display: inline-block;
  white-space: nowrap;
  line-height: var(--sticky-control-height);
  text-decoration: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  overflow: visible;
  min-width: fit-content;
  text-overflow: clip;
  box-sizing: border-box;
  text-align: left;
}

/* Selects avec le style des boutons */
select.sticky-control-btn-textual {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 12 12'%3E%3Cpath fill='%23854fff' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  background-size: 8px;
  padding-right: 18px;
  overflow: visible;
  text-overflow: clip;
}

.sticky-control-btn-textual:hover {
  border-color: var(--cfy-primary-light);
  text-decoration: none;
}

.sticky-control-btn-textual:focus {
  outline: 0;
  border-color: var(--cfy-primary);
  box-shadow: 0 0 0 2px rgba(133, 79, 255, 0.1);
}

.sticky-control-btn-textual:active {
  border-color: var(--cfy-primary-dark);
}

/* Mode sombre pour les boutons textuels */
html.dark-mode .sticky-control-btn-textual,
html[data-bs-theme='dark'] .sticky-control-btn-textual,
body.dark-mode .sticky-control-btn-textual,
body[data-bs-theme='dark'] .sticky-control-btn-textual,
.dark-mode .sticky-control-btn-textual {
  background: transparent !important;
  border-color: var(--cfy-border-dark);
  color: var(--cfy-text-dark);
}

html.dark-mode .sticky-control-btn-textual:hover,
html[data-bs-theme='dark'] .sticky-control-btn-textual:hover,
body.dark-mode .sticky-control-btn-textual:hover,
body[data-bs-theme='dark'] .sticky-control-btn-textual:hover,
.dark-mode .sticky-control-btn-textual:hover {
  border-color: var(--cfy-primary-light);
}

html.dark-mode .sticky-control-btn-textual:focus,
html[data-bs-theme='dark'] .sticky-control-btn-textual:focus,
body.dark-mode .sticky-control-btn-textual:focus,
body[data-bs-theme='dark'] .sticky-control-btn-textual:focus,
.dark-mode .sticky-control-btn-textual:focus {
  border-color: var(--cfy-primary);
  box-shadow: 0 0 0 2px rgba(133, 79, 255, 0.1);
}

/* Dropdown menu pour les contrôles */
.sticky-control-dropdown-menu {
  min-width: 200px;
  padding: clamp(4px, 0.4vw, 8px) 0;
  border-radius: 0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  border: 1px solid var(--cfy-border-light);
  background: transparent !important;
}

.sticky-control-dropdown-menu .dropdown-item {
  padding: clamp(6px, 0.5vw, 8px) clamp(12px, 1vw, 16px);
  font-size: clamp(0.8rem, 0.7vw, 0.9rem);
  display: flex;
  align-items: center;
  gap: clamp(8px, 0.7vw, 12px);
  transition: all 0.15s ease;
}

.sticky-control-dropdown-menu .dropdown-item:hover {
  background: rgba(133, 79, 255, 0.2);
  color: var(--cfy-primary);
}

.sticky-control-dropdown-menu .dropdown-item.active {
  background: rgba(133, 79, 255, 0.25);
  color: var(--cfy-primary);
  font-weight: 600;
}

.sticky-control-dropdown-menu .dropdown-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

.sticky-control-dropdown-menu .dropdown-item i {
  font-size: clamp(0.85rem, 0.75vw, 0.95rem);
  width: 16px;
  text-align: center;
}


html.dark-mode .sticky-control-dropdown-menu,
html[data-bs-theme='dark'] .sticky-control-dropdown-menu,
body.dark-mode .sticky-control-dropdown-menu,
body[data-bs-theme='dark'] .sticky-control-dropdown-menu,
.dark-mode .sticky-control-dropdown-menu {
  background: transparent !important;
  border-color: var(--cfy-border-dark);
}

html.dark-mode .sticky-control-dropdown-menu .dropdown-item,
html[data-bs-theme='dark'] .sticky-control-dropdown-menu .dropdown-item,
body.dark-mode .sticky-control-dropdown-menu .dropdown-item,
body[data-bs-theme='dark'] .sticky-control-dropdown-menu .dropdown-item,
.dark-mode .sticky-control-dropdown-menu .dropdown-item {
  color: var(--cfy-text-dark);
}

html.dark-mode .sticky-control-dropdown-menu .dropdown-item:hover,
html[data-bs-theme='dark'] .sticky-control-dropdown-menu .dropdown-item:hover,
body.dark-mode .sticky-control-dropdown-menu .dropdown-item:hover,
body[data-bs-theme='dark'] .sticky-control-dropdown-menu .dropdown-item:hover,
.dark-mode .sticky-control-dropdown-menu .dropdown-item:hover {
  background: rgba(133, 79, 255, 0.2);
  color: var(--cfy-primary-light);
}


.sticky-filters-container .row {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: var(--sticky-row-gap);
  margin: 0 auto;
  margin-top: 0;
  /* Alignement sur le même axe vertical que le sélecteur de catalogue (réduire l’espace menu → bouton vues) */
  margin-left: 0;
  padding: 0 10px;
  padding-top: 5px;
  /* Bornes : 10px entre le bord et le bouton reset (gauche) / sélecteur filtre (droite) pour alignement visuel */
  padding-left: 10px;
  padding-right: 10px;
  max-width: 100vw;
  width: 100%;
  overflow: visible;
  box-sizing: border-box;
  min-width: 0;
}

/* Colonnes (y compris col-auto pour le sélecteur de vues) : même hauteur, contenu aligné */
.sticky-filters-container .col-md-1,
.sticky-filters-container .col-md-2,
.sticky-filters-container .col-auto,
.sticky-filters-container .sticky-filter-mode {
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  align-self: stretch;
  flex: 0 0 auto;
  min-width: 0;
  max-width: 100%;
  overflow: visible;
  box-sizing: border-box;
}

/* ==========================================================================
   GROUPES DE FILTRES - MÊME HAUTEUR ET ALIGNEMENT VERTICAL
   ========================================================================== */
/* Ligne des filtres : alignement vertical coherent pour tous les blocs (recherche, Min/Max, Trier, etc.) */
.sticky-filters-container .card-body .row {
  align-items: center !important;
  min-height: var(--sticky-control-height);
}
.sticky-filters-container .card-body .row > [class*="col-"] {
  display: flex !important;
  align-items: center !important;
  min-height: var(--sticky-control-height);
}
/* Tous les input-group de la barre : meme hauteur pour alignement horizontal */
.sticky-filters-container .input-group,
.sticky-filters-container .input-group-sm {
  height: var(--sticky-control-height) !important;
  min-height: var(--sticky-control-height) !important;
  align-items: center;
}
.sticky-filters-container .filter-group {
  width: 100%;
  max-width: 100%;
  display: flex;
  align-items: center;
  min-height: var(--sticky-control-height);
  min-width: 0;
  margin: 0;
  margin-top: 0;
  padding: 0;
  padding-top: 0;
  overflow: visible !important;
  box-sizing: border-box;
}

/* Labels - Masqués */
.sticky-filter-label {
  display: none !important;
}

/* ==========================================================================
   DIMENSIONS COHÉRENTES DES FILTRES - HYPER RESPONSIVE
   ========================================================================== */

/* Base : Utilisation de clamp() pour une adaptation fluide continue */
/* Valeurs par défaut pour HD+ (1024px+) - seront surchargées par les breakpoints */
/* Protection contre le zoom : toutes les largeurs sont relatives au viewport */
.sticky-filter-display-mode {
  width: clamp(95px, 8.5vw, 200px);
  min-width: clamp(95px, 8.5vw, 200px);
  max-width: 100%;
  flex: 0 0 clamp(95px, 8.5vw, 200px);
  box-sizing: border-box;
  overflow: visible;
}

.sticky-filter-mode {
  width: auto;
  min-width: 72px;
  max-width: 100%;
  flex: 0 0 auto;
  margin-right: var(--sticky-row-gap);
  box-sizing: border-box;
  overflow: visible;
}

/* En fin de ligne (LTR) : coller le sélecteur au bord droit du contenu (alignement DashLite) */
.sticky-filters-container .row .sticky-filter-mode:last-child {
  margin-left: auto;
  margin-right: 0;
}

html[dir="rtl"] .sticky-filters-container .sticky-filter-mode {
  margin-right: 0;
  margin-left: var(--sticky-row-gap);
}
/* En début de ligne (RTL, ordre DOM inversé) : coller le sélecteur au bord gauche du contenu */
html[dir="rtl"] .sticky-filters-container .row .sticky-filter-mode:first-child {
  margin-right: auto;
  margin-left: 0;
}
.sticky-filter-mode #glassystem-mode-selector {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  height: 100% !important;
  min-height: var(--sticky-control-height) !important;
  max-height: var(--sticky-control-height) !important;
  line-height: var(--sticky-control-height);
  box-sizing: border-box;
  padding: 0 var(--sticky-control-padding-inline);
}

/* Le filter-group dans sticky-filter-mode : aligne le select comme les autres controles */
.sticky-filter-mode .filter-group {
  flex-direction: row;
  align-items: center;
  gap: 0;
  width: 100%;
  min-height: var(--sticky-control-height);
}

/* Sélecteur de vues : même hauteur et alignement que la barre de recherche et les autres filtres */
.sticky-filter-mode .input-group {
  height: var(--sticky-control-height) !important;
  min-height: var(--sticky-control-height) !important;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  flex: 1;
  width: 100%;
}
.sticky-filter-mode .input-group .form-select,
.sticky-filter-mode #glassystem-mode-selector {
  height: var(--sticky-control-height) !important;
  min-height: var(--sticky-control-height) !important;
  max-height: var(--sticky-control-height) !important;
  line-height: var(--sticky-control-height);
  padding-top: 0;
  padding-bottom: 0;
  box-sizing: border-box;
  flex: 1;
}

/* Sélecteur de vues : fond transparent pour s'adapter au BG utilisateur (passe-partout) */
html:not(.dark-mode):not([data-bs-theme='dark']) .sticky-filter-mode #glassystem-mode-selector,
body:not(.dark-mode):not([data-bs-theme='dark']) .sticky-filter-mode #glassystem-mode-selector {
  background-color: transparent !important;
  color: inherit;
}

/* Textes des options du sélecteur de vues */
.sticky-filter-mode #glassystem-mode-selector option {
  color: inherit;
  background-color: transparent !important;
}

/* Mode dark : options transparent aussi */
.dark-mode .sticky-filter-mode #glassystem-mode-selector option,
html.dark-mode .sticky-filter-mode #glassystem-mode-selector option,
[data-bs-theme='dark'] .sticky-filter-mode #glassystem-mode-selector option {
  color: inherit;
  background-color: transparent !important;
}

.sticky-filter-search {
  flex: 1 1 clamp(140px, 18vw, 500px);
  min-width: clamp(140px, 18vw, 500px);
  max-width: clamp(200px, 23vw, 600px);
  box-sizing: border-box;
  overflow: visible;
}

.sticky-filter-price {
  width: clamp(100px, 10vw, 230px);
  min-width: clamp(100px, 10vw, 230px);
  max-width: 100%;
  flex: 0 0 clamp(100px, 10vw, 230px);
  box-sizing: border-box;
  overflow: visible;
}

.sticky-filter-category,
.sticky-filter-rayon {
  width: clamp(75px, 7.5vw, 180px);
  min-width: clamp(75px, 7.5vw, 180px);
  max-width: 100%;
  flex: 0 0 clamp(75px, 7.5vw, 180px);
  box-sizing: border-box;
  overflow: visible;
}

/* NOUVEAUX FILTRES : Devises, Langues, Pays, Publishers */
.sticky-filter-devise,
.sticky-filter-langue,
.sticky-filter-pays,
.sticky-filter-publisher {
  width: clamp(75px, 6.5vw, 150px);
  min-width: clamp(75px, 6.5vw, 150px);
  max-width: 100%;
  flex: 0 0 clamp(75px, 6.5vw, 150px);
  box-sizing: border-box;
  overflow: visible;
}

/* Breakpoints spécifiques pour optimisations ciblées */
/* HD (1025px - 1199px) - Ultra compact */
@media (min-width: 1025px) and (max-width: 1199px) {
  .sticky-filters-container {
    --sticky-row-gap: clamp(4px, 0.4vw, 8px);
    --sticky-row-padding-inline: clamp(8px, 0.8vw, 16px);
    --sticky-padding-block: clamp(6px, 0.5vw, 10px);
    --sticky-control-height: clamp(34px, 2.2vw, 40px);
    --sticky-control-font-size: clamp(0.75rem, 0.65vw, 0.85rem);
    --sticky-control-padding-inline: clamp(8px, 0.6vw, 12px);
  }
  .sticky-filter-display-mode { 
    width: clamp(95px, 7vw, 125px);
    min-width: clamp(95px, 7vw, 125px);
    max-width: 100%;
    flex: 0 0 clamp(95px, 7vw, 125px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-mode {
    width: auto;
    min-width: 72px;
    max-width: 100%;
    flex: 0 0 auto;
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-search {
    flex: 1 1 clamp(140px, 15vw, 240px);
    min-width: clamp(140px, 15vw, 240px);
    max-width: clamp(200px, 19vw, 300px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-price {
    width: clamp(100px, 8.5vw, 150px);
    min-width: clamp(100px, 8.5vw, 150px);
    max-width: 100%;
    flex: 0 0 clamp(100px, 8.5vw, 150px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-category,
  .sticky-filter-rayon {
    width: clamp(75px, 6.5vw, 115px);
    min-width: clamp(75px, 6.5vw, 115px);
    max-width: 100%;
    flex: 0 0 clamp(75px, 6.5vw, 115px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-devise,
  .sticky-filter-langue,
  .sticky-filter-pays,
  .sticky-filter-publisher {
    width: clamp(70px, 6vw, 110px);
    min-width: clamp(70px, 6vw, 110px);
    max-width: 100%;
    flex: 0 0 clamp(70px, 6vw, 110px);
    box-sizing: border-box;
    overflow: visible;
  }
}

/* HD+ (1200px - 1365px) - Très compact */
@media (min-width: 1200px) and (max-width: 1365px) {
  .sticky-filter-display-mode { 
    width: clamp(100px, 7.5vw, 135px);
    min-width: clamp(100px, 7.5vw, 135px);
    max-width: 100%;
    flex: 0 0 clamp(100px, 7.5vw, 135px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-mode { 
    width: auto;
    min-width: 72px;
    max-width: 100%;
    flex: 0 0 auto;
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-search { 
    flex: 1 1 clamp(160px, 17vw, 280px);
    min-width: clamp(160px, 17vw, 280px);
    max-width: clamp(230px, 21vw, 350px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-price { 
    width: clamp(115px, 9vw, 165px);
    min-width: clamp(115px, 9vw, 165px);
    max-width: 100%;
    flex: 0 0 clamp(115px, 9vw, 165px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-category,
  .sticky-filter-rayon { 
    width: clamp(85px, 6.5vw, 125px);
    min-width: clamp(85px, 6.5vw, 125px);
    max-width: 100%;
    flex: 0 0 clamp(85px, 6.5vw, 125px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-devise,
  .sticky-filter-langue,
  .sticky-filter-pays,
  .sticky-filter-publisher { 
    width: clamp(75px, 6vw, 115px);
    min-width: clamp(75px, 6vw, 115px);
    max-width: 100%;
    flex: 0 0 clamp(75px, 6vw, 115px);
    box-sizing: border-box;
    overflow: visible;
  }
}

/* FHD (1366px - 1599px) - Compact */
@media (min-width: 1366px) and (max-width: 1599px) {
  .sticky-filter-display-mode { 
    width: clamp(125px, 8.5vw, 160px);
    min-width: clamp(125px, 8.5vw, 160px);
    max-width: 100%;
    flex: 0 0 clamp(125px, 8.5vw, 160px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-mode { 
    width: auto;
    min-width: 72px;
    max-width: 100%;
    flex: 0 0 auto;
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-search { 
    flex: 1 1 clamp(200px, 18vw, 320px);
    min-width: clamp(200px, 18vw, 320px);
    max-width: clamp(280px, 22vw, 400px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-price { 
    width: clamp(140px, 10vw, 185px);
    min-width: clamp(140px, 10vw, 185px);
    max-width: 100%;
    flex: 0 0 clamp(140px, 10vw, 185px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-category,
  .sticky-filter-rayon { 
    width: clamp(110px, 8vw, 150px);
    min-width: clamp(110px, 8vw, 150px);
    max-width: 100%;
    flex: 0 0 clamp(110px, 8vw, 150px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-devise,
  .sticky-filter-langue,
  .sticky-filter-pays,
  .sticky-filter-publisher { 
    width: clamp(90px, 7vw, 135px);
    min-width: clamp(90px, 7vw, 135px);
    max-width: 100%;
    flex: 0 0 clamp(90px, 7vw, 135px);
    box-sizing: border-box;
    overflow: visible;
  }
}

/* 2K (1600px - 1919px) - Standard */
@media (min-width: 1600px) and (max-width: 1919px) {
  .sticky-filter-display-mode { 
    width: clamp(145px, 9.5vw, 180px);
    min-width: clamp(145px, 9.5vw, 180px);
    max-width: 100%;
    flex: 0 0 clamp(145px, 9.5vw, 180px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-mode { 
    width: auto;
    min-width: 72px;
    max-width: 100%;
    flex: 0 0 auto;
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-search { 
    flex: 1 1 clamp(260px, 19vw, 380px);
    min-width: clamp(260px, 19vw, 380px);
    max-width: clamp(360px, 23vw, 480px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-price { 
    width: clamp(160px, 11vw, 210px);
    min-width: clamp(160px, 11vw, 210px);
    max-width: 100%;
    flex: 0 0 clamp(160px, 11vw, 210px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-category,
  .sticky-filter-rayon { 
    width: clamp(125px, 8.5vw, 170px);
    min-width: clamp(125px, 8.5vw, 170px);
    max-width: 100%;
    flex: 0 0 clamp(125px, 8.5vw, 170px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-devise,
  .sticky-filter-langue,
  .sticky-filter-pays,
  .sticky-filter-publisher { 
    width: clamp(110px, 7.5vw, 150px);
    min-width: clamp(110px, 7.5vw, 150px);
    max-width: 100%;
    flex: 0 0 clamp(110px, 7.5vw, 150px);
    box-sizing: border-box;
    overflow: visible;
  }
}

/* 2K+ (1920px - 2559px) - Large */
@media (min-width: 1920px) and (max-width: 2559px) {
  .sticky-filter-display-mode { 
    width: clamp(160px, 10vw, 195px);
    min-width: clamp(160px, 10vw, 195px);
    max-width: 100%;
    flex: 0 0 clamp(160px, 10vw, 195px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-mode { 
    width: auto;
    min-width: 72px;
    max-width: 100%;
    flex: 0 0 auto;
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-search { 
    flex: 1 1 clamp(330px, 20vw, 450px);
    min-width: clamp(330px, 20vw, 450px);
    max-width: clamp(430px, 24vw, 550px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-price { 
    width: clamp(175px, 11.5vw, 230px);
    min-width: clamp(175px, 11.5vw, 230px);
    max-width: 100%;
    flex: 0 0 clamp(175px, 11.5vw, 230px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-category,
  .sticky-filter-rayon { 
    width: clamp(145px, 9vw, 185px);
    min-width: clamp(145px, 9vw, 185px);
    max-width: 100%;
    flex: 0 0 clamp(145px, 9vw, 185px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-devise,
  .sticky-filter-langue,
  .sticky-filter-pays,
  .sticky-filter-publisher { 
    width: clamp(125px, 8vw, 170px);
    min-width: clamp(125px, 8vw, 170px);
    max-width: 100%;
    flex: 0 0 clamp(125px, 8vw, 170px);
    box-sizing: border-box;
    overflow: visible;
  }
}

/* 4K+ (2560px+) - Très large */
@media (min-width: 2560px) {
  .sticky-filter-display-mode { 
    width: clamp(180px, 10.5vw, 220px);
    min-width: clamp(180px, 10.5vw, 220px);
    max-width: 100%;
    flex: 0 0 clamp(180px, 10.5vw, 220px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-mode { 
    width: auto;
    min-width: 72px;
    max-width: 100%;
    flex: 0 0 auto;
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-search { 
    flex: 1 1 clamp(420px, 21vw, 600px);
    min-width: clamp(420px, 21vw, 600px);
    max-width: clamp(520px, 25vw, 700px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-price { 
    width: clamp(210px, 12vw, 270px);
    min-width: clamp(210px, 12vw, 270px);
    max-width: 100%;
    flex: 0 0 clamp(210px, 12vw, 270px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-category,
  .sticky-filter-rayon { 
    width: clamp(170px, 9.5vw, 220px);
    min-width: clamp(170px, 9.5vw, 220px);
    max-width: 100%;
    flex: 0 0 clamp(170px, 9.5vw, 220px);
    box-sizing: border-box;
    overflow: visible;
  }
  .sticky-filter-devise,
  .sticky-filter-langue,
  .sticky-filter-pays,
  .sticky-filter-publisher { 
    width: clamp(150px, 8.5vw, 200px);
    min-width: clamp(150px, 8.5vw, 200px);
    max-width: 100%;
    flex: 0 0 clamp(150px, 8.5vw, 200px);
    box-sizing: border-box;
    overflow: visible;
  }
}

/* ==========================================================================
   FORMULAIRES - STYLE MINIMALISTE ET CENTRÉ - HYPER RESPONSIVE
   ========================================================================== */
.sticky-filters-container .form-control,
.sticky-filters-container .form-select {
  height: var(--sticky-control-height);
  min-height: var(--sticky-control-height);
  padding: 0 var(--sticky-control-padding-inline);
  font-size: var(--sticky-control-font-size);
  font-weight: 400;
  color: var(--cfy-text-light);
  background: transparent !important;
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  transition: border-color 0.15s ease;
  box-sizing: border-box;
  text-align: left;
  line-height: var(--sticky-control-height);
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: visible;
  text-overflow: ellipsis;
  white-space: nowrap;
}


.sticky-filters-container .form-control:focus,
.sticky-filters-container .form-select:focus {
  border-color: var(--cfy-primary);
  outline: 0;
  box-shadow: 0 0 0 2px rgba(133, 79, 255, 0.1);
}

.sticky-filters-container .form-control:hover,
.sticky-filters-container .form-select:hover {
  border-color: var(--cfy-primary-light);
}

.sticky-filters-container .form-control::placeholder {
  color: var(--cfy-text-light);
  opacity: 1;
}

/* Input groups - même hauteur que les dropdowns pour alignement vertical */
.sticky-filters-container .input-group {
  display: flex;
  width: 100%;
  max-width: 100%;
  align-items: center;
  min-height: var(--sticky-control-height);
  height: var(--sticky-control-height);
  min-width: 0;
  overflow: visible;
  box-sizing: border-box;
  flex-wrap: nowrap;
}

/* Boutons reset et loop : on ne touche pas (hauteur propre) — centrés dans la row */
.sticky-filters-container .input-group-sm .input-group-text {
  height: clamp(24px, 1.5vw, 28px);
  padding: 0 clamp(4px, 0.4vw, 10px);
  font-size: clamp(0.6rem, 0.5vw, 0.75rem);
  color: var(--cfy-primary);
  background: transparent !important;
  border: 1px solid var(--cfy-border-light);
  border-right: none;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.sticky-filters-container .input-group-sm .form-control,
.sticky-filters-container .input-group-sm .form-select {
  border-left: none;
  border-radius: 0;
  height: 100% !important;
  min-height: var(--sticky-control-height);
}

.sticky-filters-container .input-group-sm .form-control:focus,
.sticky-filters-container .input-group-sm .form-select:focus {
  border-left: 1px solid var(--cfy-primary);
}

/* Zone de recherche : groupe à la même hauteur que les dropdowns, reset et loop non modifiés */
.sticky-filter-search .input-group {
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  overflow: visible;
  height: var(--sticky-control-height);
  min-height: var(--sticky-control-height);
  align-items: center;
}

.sticky-filter-search .input-group:focus-within {
  border-color: var(--cfy-primary);
  box-shadow: 0 0 0 2px rgba(133, 79, 255, 0.1);
}

.sticky-filter-search .input-group-text {
  background: transparent !important;
  color: var(--cfy-primary);
  border: none;
  cursor: pointer;
}

.sticky-filter-search .input-group-text:hover {
  background: rgba(0, 0, 0, 0.06) !important;
}

/* Champ recherche : même hauteur que la barre, centré */
.sticky-filter-search .form-control {
  background: transparent !important;
  border: none;
  border-radius: 0;
  height: 100% !important;
  min-height: 0;
  flex: 1;
}

.sticky-filter-search .form-control:focus {
  box-shadow: none;
}

/* Prix min/max : groupe à la même hauteur que les dropdowns */
.sticky-filter-price .input-group {
  height: var(--sticky-control-height);
  min-height: var(--sticky-control-height);
  align-items: stretch;
}

.sticky-filter-price .input-group .form-control {
  height: 100% !important;
  min-height: 0;
}

.sticky-filter-price .input-group-sm .form-control:first-child {
  border-radius: 0;
  border-right: none;
}

.sticky-filter-price .input-group-sm .form-control:last-child {
  border-radius: 0;
  border-left: 1px solid var(--cfy-border-light);
}

/* ==========================================================================
   BOUTONS - STYLE MINIMALISTE ET CENTRÉ - HYPER RESPONSIVE
   ========================================================================== */
.sticky-filters-container .btn {
  height: clamp(24px, 1.5vw, 28px);
  padding: 0 clamp(4px, 0.4vw, 10px);
  font-size: clamp(0.55rem, 0.5vw, 0.65rem);
  font-weight: 500;
  border-radius: 0;
  transition: all 0.15s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: clamp(24px, 1.5vw, 28px);
}

/* ==========================================================================
   BOUTON RESET - Dominante noire (White Mode + Dark Mode Dashlite)
   ========================================================================== */
.sticky-filters-container .btn-outline-primary,
.sticky-filters-container #filter-reset.btn-outline-primary {
  color: #e8e8e8 !important;
  background: #1a1a1a !important;
  border: 1px solid #3d3d3d !important;
}
.sticky-filters-container .btn-outline-primary i,
.sticky-filters-container .btn-outline-primary .ni,
.sticky-filters-container #filter-reset.btn-outline-primary i,
.sticky-filters-container #filter-reset.btn-outline-primary .ni {
  color: #e8e8e8 !important;
}

.sticky-filters-container .btn-outline-primary:hover,
.sticky-filters-container #filter-reset.btn-outline-primary:hover {
  color: #ffffff !important;
  background: #2d2d2d !important;
  border-color: #4d4d4d !important;
}
.sticky-filters-container .btn-outline-primary:hover i,
.sticky-filters-container .btn-outline-primary:hover .ni,
.sticky-filters-container #filter-reset.btn-outline-primary:hover i,
.sticky-filters-container #filter-reset.btn-outline-primary:hover .ni {
  color: #ffffff !important;
}

.sticky-filters-container .btn-outline-primary:active,
.sticky-filters-container #filter-reset.btn-outline-primary:active {
  color: #ffffff !important;
  background: #0d0d0d !important;
  border-color: #2d2d2d !important;
}
.sticky-filters-container .btn-outline-primary:active i,
.sticky-filters-container .btn-outline-primary:active .ni,
.sticky-filters-container #filter-reset.btn-outline-primary:active i,
.sticky-filters-container #filter-reset.btn-outline-primary:active .ni {
  color: #ffffff !important;
}

.sticky-filters-container #filter-reset:focus-visible {
  outline: 0 !important;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.35) !important;
}

/* Dark mode : même dominante noire, légèrement éclaircie pour contraste sur fond sombre */
.dark-mode .sticky-filters-container .btn-outline-primary,
html.dark-mode .sticky-filters-container .btn-outline-primary,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary,
.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary,
html.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary,
[data-bs-theme='dark'] .sticky-filters-container #filter-reset.btn-outline-primary {
  color: #e8e8e8 !important;
  background: #252525 !important;
  border: 1px solid #404040 !important;
}
.dark-mode .sticky-filters-container .btn-outline-primary i,
html.dark-mode .sticky-filters-container .btn-outline-primary .ni,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary .ni,
.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary i,
html.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary .ni,
[data-bs-theme='dark'] .sticky-filters-container #filter-reset.btn-outline-primary .ni {
  color: #e8e8e8 !important;
}
.dark-mode .sticky-filters-container .btn-outline-primary:hover,
html.dark-mode .sticky-filters-container .btn-outline-primary:hover,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary:hover,
.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:hover,
html.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:hover,
[data-bs-theme='dark'] .sticky-filters-container #filter-reset.btn-outline-primary:hover {
  color: #ffffff !important;
  background: #353535 !important;
  border-color: #505050 !important;
}
.dark-mode .sticky-filters-container .btn-outline-primary:hover i,
html.dark-mode .sticky-filters-container .btn-outline-primary:hover .ni,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary:hover .ni,
.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:hover i,
html.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:hover .ni,
[data-bs-theme='dark'] .sticky-filters-container #filter-reset.btn-outline-primary:hover .ni {
  color: #ffffff !important;
}
.dark-mode .sticky-filters-container .btn-outline-primary:active,
html.dark-mode .sticky-filters-container .btn-outline-primary:active,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary:active,
.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:active,
html.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:active,
[data-bs-theme='dark'] .sticky-filters-container #filter-reset.btn-outline-primary:active {
  color: #ffffff !important;
  background: #1a1a1a !important;
  border-color: #404040 !important;
}
.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:active i,
html.dark-mode .sticky-filters-container #filter-reset.btn-outline-primary:active .ni,
.dark-mode .sticky-filters-container .btn-outline-primary:active i,
html.dark-mode .sticky-filters-container .btn-outline-primary:active .ni,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary:active i,
[data-bs-theme='dark'] .sticky-filters-container .btn-outline-primary:active .ni,
[data-bs-theme='dark'] .sticky-filters-container #filter-reset.btn-outline-primary:active .ni {
  color: #ffffff !important;
}

/* ==========================================================================
   BADGES
   ========================================================================== */
.sticky-filters-container .badge {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 0;
}

.sticky-filters-container .badge.bg-primary {
  background-color: rgba(133, 79, 255, 0.25) !important;
  color: var(--cfy-primary) !important;
}

/* ==========================================================================
   DROPDOWNS MULTI-SÉLECTION
   ========================================================================== */
.multi-select-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  background: transparent !important;
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  padding: 0 clamp(6px, 0.5vw, 10px);
  height: var(--sticky-control-height);
  min-height: 32px;
  transition: border-color 0.15s ease;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  text-align: left;
  font-size: var(--sticky-control-font-size);
  overflow: visible;
  box-sizing: border-box;
}

.multi-select-trigger:hover {
  border-color: var(--cfy-primary-light);
}

.multi-select-trigger.active {
  border-color: var(--cfy-primary);
}

/* Mini-SVG à gauche du libellé – taille augmentée à l’échelle du bouton */
.sticky-filter-label-icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-inline-end: 0.4em;
  opacity: 1;
  color: var(--cfy-text-light);
  vertical-align: middle;
}

.sticky-filter-label-icon svg {
  width: 22px;
  height: 22px;
}

/* Flèche vers le bas (dropdown) – taille augmentée à l’échelle du bouton */
.sticky-filter-chevron {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--cfy-text-light);
  opacity: 1;
}

.sticky-filter-chevron svg {
  width: 20px;
  height: 20px;
}

.multi-select-label {
  flex: 1;
  min-width: 0;
  max-width: 100%;
  overflow: visible;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: var(--sticky-control-font-size);
  color: var(--cfy-text-light);
  box-sizing: border-box;
}

.multi-select-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 10000 !important;
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
  opacity: 1 !important;
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  box-shadow: var(--cfy-shadow);
  max-height: 300px;
  overflow-y: auto;
  display: none;
  margin-top: 4px;
}

.multi-select-dropdown.show {
  display: block;
}

.multi-select-search {
  padding: 8px;
  border-bottom: 1px solid var(--cfy-border-light);
}

.multi-select-search input {
  width: 100%;
  height: 32px;
  padding: 0 8px;
  font-size: 0.875rem;
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
}

.multi-select-options {
  padding: 8px;
}

.multi-select-dropdown .form-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
}

.multi-select-dropdown .form-check-input {
  margin: 0;
  border-color: var(--cfy-border-light);
}

.multi-select-dropdown .form-check-input:checked {
  background-color: rgba(133, 79, 255, 0.35);
  border-color: var(--cfy-primary);
}

.multi-select-dropdown .form-check-label {
  font-size: 0.875rem;
  color: var(--cfy-text-light);
  cursor: pointer;
}

/* Classe pour masquer les éléments lors de la recherche */
.multi-select-dropdown .hidden {
  display: none !important;
}

.multi-select-dropdown .multi-select-group.hidden {
  display: none !important;
}

/* Distinction visuelle claire entre parents et sous-éléments */
.multi-select-dropdown .multi-select-group {
  margin-bottom: 12px;
  border: 1px solid #6c757d;
  border-radius: 0;
  padding: 8px;
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
}

/* Catégories et rayons parents - Style distinctif (fond opaque, même que dropdown) */
.multi-select-dropdown .parent-check {
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
  border-left: 3px solid #495057;
  padding: 10px 12px;
  margin: -8px -8px 8px -8px;
  border-radius: 0;
  font-weight: 600;
}

.multi-select-dropdown .parent-check .form-check-label {
  font-weight: 600;
  font-size: 0.9rem;
  color: #495057;
  text-transform: uppercase;
}

/* Sous-catégories et sous-rayons - Style sans indentation */
.multi-select-dropdown .multi-select-children {
  padding-left: 0;
  margin-top: 4px;
}

.multi-select-dropdown .child-check {
  padding: 4px 0;
  margin-left: 0;
  border-left: 2px solid transparent;
  padding-left: 0;
  transition: border-color 0.2s ease;
}

.multi-select-dropdown .child-check:hover {
  border-left-color: #6c757d;
}

.multi-select-dropdown .child-check .form-check-label {
  font-weight: 400;
  font-size: 0.85rem;
  color: var(--cfy-text-muted, var(--cfy-text-light));
  text-transform: capitalize;
  display: flex;
  align-items: center;
}

/* Style pour les icônes des filtres (drapeaux, catégories, rayons) */
.multi-select-dropdown .filter-icon {
  width: 20px;
  height: 20px;
  object-fit: contain;
  border-radius: 0;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 1px 2px rgba(0,0,0,0.1);
  flex-shrink: 0;
  background-color: transparent !important;
  padding: 1px;
}

.multi-select-trigger .badge {
  margin-left: 8px;
  background: rgba(133, 79, 255, 0.25);
  color: var(--cfy-primary);
}

/* ==========================================================================
   SUGGESTIONS DE RECHERCHE
   ========================================================================== */
.search-suggestions-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 9999;
  background: transparent !important;
  border: 1px solid var(--cfy-border-light);
  border-radius: 0;
  box-shadow: var(--cfy-shadow);
  max-height: 300px;
  overflow-y: auto;
  display: none;
  margin-top: 4px;
}

.search-suggestions-dropdown.show {
  display: block;
}

.search-suggestion {
  padding: 10px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--cfy-border-light);
  transition: background-color 0.15s ease;
}

.search-suggestion:last-child {
  border-bottom: none;
}

.search-suggestion:hover,
.search-suggestion.active {
  background: rgba(0, 0, 0, 0.06) !important;
}

.search-highlight {
  background: rgba(133, 79, 255, 0.15);
  color: var(--cfy-primary);
  font-weight: 600;
  padding: 2px 4px;
  border-radius: 0;
}

/* ==========================================================================
   MODE SOMBRE — plus de fond transparent sur le container (couleur configurée conservée)
   ========================================================================== */
.dark-mode .sticky-filters-container,
html.dark-mode .sticky-filters-container,
[data-bs-theme='dark'] .sticky-filters-container {
  /* background supprimé : la couleur de la barre vient du HTML/JS (configurée, défaut noir) */
  /* border-bottom-color supprimé pour laisser l'hérité ou le défini par JS */
}

.dark-mode .sticky-filters-container .form-control,
.dark-mode .sticky-filters-container .form-select,
html.dark-mode .sticky-filters-container .form-control,
html.dark-mode .sticky-filters-container .form-select,
[data-bs-theme='dark'] .sticky-filters-container .form-control,
[data-bs-theme='dark'] .sticky-filters-container .form-select {
  background: transparent !important;
  border-color: var(--cfy-border-dark);
  color: var(--cfy-text-dark);
}

.dark-mode .sticky-filters-container .input-group-text,
html.dark-mode .sticky-filters-container .input-group-text,
[data-bs-theme='dark'] .sticky-filters-container .input-group-text {
  background: transparent !important;
  border-color: var(--cfy-border-dark);
}

.dark-mode .sticky-filters-container .multi-select-trigger,
html.dark-mode .sticky-filters-container .multi-select-trigger,
[data-bs-theme='dark'] .sticky-filters-container .multi-select-trigger {
  background: transparent !important;
  border-color: var(--cfy-border-dark);
  color: var(--cfy-text-dark);
}

/* Fond et texte des dropdowns Sticky Filters : même couleur que la barre sticky, toujours opaque (rouge → fond rouge, etc.) */
.sticky-filters-container .multi-select-dropdown,
.dark-mode .sticky-filters-container .multi-select-dropdown,
html.dark-mode .sticky-filters-container .multi-select-dropdown,
[data-bs-theme='dark'] .sticky-filters-container .multi-select-dropdown {
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
}
.sticky-filters-container .multi-select-dropdown .form-check-label,
.sticky-filters-container .multi-select-dropdown .parent-check .form-check-label,
.sticky-filters-container .multi-select-dropdown .child-check .form-check-label {
  color: var(--sticky-dropdown-text, var(--cfy-text-light)) !important;
}

/* Dropdown de l'input de recherche principal : même fond et texte que les autres dropdowns Sticky. Hover/actif en noir-orange-bleu Commercify. */
.sticky-filters-container .search-suggestions-dropdown {
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
  border: 1px solid rgba(26, 29, 33, 0.12);
  border-radius: var(--cfy-radius);
  box-shadow: var(--cfy-shadow-sm), 0 0 0 1px rgba(9, 194, 222, 0.06), 0 2px 8px rgba(26, 29, 33, 0.06);
}
.sticky-filters-container .search-suggestions-dropdown .search-suggestion {
  color: var(--sticky-dropdown-text, var(--cfy-text-light)) !important;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(26, 29, 33, 0.06);
  transition: background-color 0.2s ease, color 0.2s ease, border-left-color 0.2s ease;
  border-left: 3px solid transparent;
}
.sticky-filters-container .search-suggestions-dropdown .search-suggestion:hover,
.sticky-filters-container .search-suggestions-dropdown .search-suggestion.active {
  background: rgba(255, 138, 0, 0.1) !important;
  border-left-color: var(--cfy-orange);
  color: var(--cfy-orange-dark) !important;
}
.sticky-filters-container .search-suggestions-dropdown .search-suggestion:hover .search-highlight,
.sticky-filters-container .search-suggestions-dropdown .search-suggestion.active .search-highlight {
  background: rgba(255, 138, 0, 0.22);
  color: var(--cfy-noir);
}
.sticky-filters-container .search-suggestions-dropdown .search-highlight {
  background: rgba(255, 138, 0, 0.16);
  color: var(--cfy-orange-dark);
  font-weight: 600;
  padding: 2px 4px;
  border-radius: 2px;
}

.sticky-filters-container .multi-select-dropdown .multi-select-search input {
  color: var(--sticky-dropdown-text, var(--cfy-text-light)) !important;
  background-color: var(--sticky-dropdown-bg, #ffffff) !important;
  border-color: var(--cfy-border-light);
}
.sticky-filters-container .multi-select-dropdown .multi-select-search input::placeholder {
  color: rgba(232, 232, 232, 0.5) !important;
}

/* Correction dark mode : Labels parents (catégories et rayons en majuscules) - sticky uniquement */
.dark-mode .sticky-filters-container .multi-select-dropdown .parent-check .form-check-label,
html.dark-mode .sticky-filters-container .multi-select-dropdown .parent-check .form-check-label,
[data-bs-theme='dark'] .sticky-filters-container .multi-select-dropdown .parent-check .form-check-label {
  color: #dee2e6 !important;
}

/* ==========================================================================
   THÈME NOIR (éditeurs-liés) — fond #1a1a1a : textes et bordures clairs
   ========================================================================== */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-control,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-select,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] select {
  color: #e8e8e8 !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
  background: rgba(255, 255, 255, 0.12) !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-control::placeholder {
  color: #e8e8e8 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-control:focus,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-select:focus {
  border-color: rgba(255, 215, 0, 0.95) !important;
  box-shadow: 0 0 0 2px rgba(255, 215, 0, 0.3);
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-control:hover,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-select:hover {
  border-color: rgba(255, 255, 255, 0.65) !important;
}

/* Sélecteur de mode d'affichage (vues) */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #glassystem-mode-selector,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .sticky-filter-mode .form-select {
  color: #e8e8e8 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #glassystem-mode-selector option,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-select option {
  background-color: #1a1a1a !important;
  color: #e8e8e8 !important;
}

/* Input group (recherche, etc.) */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .input-group-text {
  color: #e8e8e8 !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
  background: rgba(255, 255, 255, 0.12) !important;
}

/* Dropdown suggestions recherche : hover lisible sur barre noire (orange clair) */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .search-suggestions-dropdown .search-suggestion:hover,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .search-suggestions-dropdown .search-suggestion.active {
  color: #ffb366 !important;
}
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .search-suggestions-dropdown .search-suggestion:hover .search-highlight,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .search-suggestions-dropdown .search-suggestion.active .search-highlight {
  color: #ffd699 !important;
}
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .search-suggestions-dropdown .search-highlight {
  color: #ffb366 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .input-group-sm .form-control,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .input-group-sm .form-select {
  border-left: 1px solid rgba(255, 255, 255, 0.5) !important;
}

/* Multi-select (dropdowns Éditeurs, Catégories, etc.) - trigger barre uniquement */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-trigger {
  color: #e8e8e8 !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
  background: rgba(255, 255, 255, 0.12) !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-trigger .multi-select-label {
  color: #e8e8e8 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-trigger .ni,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-trigger .icon {
  color: #e8e8e8 !important;
}

/* Chevron et icône de libellé : même couleur que le texte (lisibles sur fond noir) */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .sticky-filter-chevron,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .sticky-filter-chevron svg,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .sticky-filter-label-icon,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .sticky-filter-label-icon svg {
  color: #e8e8e8 !important;
  fill: #e8e8e8 !important;
  stroke: #e8e8e8 !important;
}

/* Flèche du select (mode vues, etc.) : même couleur que le texte */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .form-select,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #glassystem-mode-selector,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] select.sticky-control-btn-textual {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 12 12'%3E%3Cpath fill='%23e8e8e8' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 4px center !important;
  background-size: 8px !important;
  padding-right: 18px !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-trigger .badge {
  background: rgba(255, 255, 255, 0.5) !important;
  color: #e8e8e8 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-dropdown {
  background-color: #222 !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-dropdown .form-check-label,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-dropdown .parent-check .form-check-label,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-dropdown .child-check .form-check-label {
  color: #e8e8e8 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-dropdown .multi-select-search input {
  color: #e8e8e8 !important;
  background-color: #222 !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .multi-select-dropdown .multi-select-search input::placeholder {
  color: rgba(232, 232, 232, 0.5) !important;
}

/* Bouton reset filtres */
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .btn-outline-primary,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #filter-reset.btn-outline-primary {
  color: #e8e8e8 !important;
  border-color: rgba(255, 255, 255, 0.55) !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .btn-outline-primary:hover,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #filter-reset.btn-outline-primary:hover {
  color: #1a1a1a !important;
  background-color: #e8e8e8 !important;
  border-color: #e8e8e8 !important;
}

.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .btn-outline-primary i,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] .btn-outline-primary .ni,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #filter-reset.btn-outline-primary i,
.sticky-filters-container[data-sticky-bg-color="#1a1a1a"] #filter-reset.btn-outline-primary .ni {
  color: inherit !important;
}

/* ==========================================================================
   PROTECTION GLOBALE CONTRE LE ZOOM ET DÉBORDEMENTS
   ========================================================================== */
/* Protection : tous les éléments doivent rester dans le cadre */
.sticky-filters-container,
.sticky-filters-container *,
.sticky-filters-container *::before,
.sticky-filters-container *::after {
  box-sizing: border-box;
  max-width: 100%;
}

/* Protection : row ne doit jamais dépasser */
.sticky-filters-container .row {
  max-width: 100%;
  overflow-x: hidden;
}

/* Protection : tous les filtres doivent rester visibles et dans le cadre */
.sticky-filters-container [class*="sticky-filter-"] {
  max-width: 100%;
  overflow: visible;
}

/* Protection : inputs et selects ne doivent jamais dépasser */
.sticky-filters-container input,
.sticky-filters-container select,
.sticky-filters-container button {
  max-width: 100%;
  overflow: visible;
  text-overflow: ellipsis;
}

/* Protection : dropdowns ne doivent jamais dépasser de l'écran */
.multi-select-dropdown,
.search-suggestions-dropdown {
  max-width: min(100vw, 100%);
  left: 0 !important;
  right: 0 !important;
  box-sizing: border-box;
  overflow-x: hidden;
}

/* ==========================================================================
   OPTIMISATIONS PERFORMANCE
   ========================================================================== */
.sticky-filters-container * {
  /* Pas de transitions complexes */
  transition-property: border-color, background-color, color, opacity;
  transition-duration: 0.15s;
  transition-timing-function: ease;
}

/* Pas d'animations lourdes */
.sticky-filters-container,
.sticky-filters-container * {
  animation: none !important;
}

/* Containment pour éviter les reflows */
.sticky-filters-container {
  contain: layout style;
}

/* ==========================================================================
   GLASSYSTEM - FILTRAGE DES VIGNETTES (Simplifié)
   ========================================================================== */
.vignette-selectable {
  transition: opacity 0.2s ease;
  will-change: opacity;
}

.vignette-selectable.filtered-out {
  opacity: 0.3;
  pointer-events: none;
}

.vignette-selectable.filtered-in {
  opacity: 1;
}

/* Universal effect - Masquer complètement */
.glassystem-behavior-universal-effect .vignette-selectable.filtered-out {
  display: none !important;
}

/* Universal effect - Masquer les colonnes Bootstrap parentes ET vignette-item pour customThumbs */
.glassystem-behavior-universal-effect [class*="col-"].filtered-out-col,
.glassystem-behavior-universal-effect .vignette-item.filtered-out-col {
  display: none !important;
}

/* CORRECTION CHIRURGICALE: Compacter les vignettes en CSS Grid pour customThumbs */
.vignettes-container-custom {
  display: grid !important;
  grid-auto-flow: dense !important; /* Compactage automatique pour éviter les espaces vides */
}

.vignettes-container-custom .vignette-item {
  display: flex !important;
  align-items: stretch !important;
  min-width: 0 !important; /* Permet au contenu de rétrécir */
  max-width: 100% !important;
}

/* Adaptation du contenu du verso pour customthumbs */
.vignettes-container-custom .product-card-flip-back {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.vignettes-container-custom .flip-back-content {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  padding: 0.5rem !important;
}

.vignettes-container-custom .flip-back-header {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.vignettes-container-custom .flip-back-actions {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.vignettes-container-custom .flip-action-btn {
  max-width: 100% !important;
  box-sizing: border-box !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
  white-space: normal !important;
  font-size: 0.75rem !important;
  padding: 0.5rem 0.75rem !important;
}

.vignettes-container-custom .product-card-flip-back-title,
.vignettes-container-custom .product-card-flip-back-subtitle {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
}

/* RESPONSIVE POUR CUSTOMTHUMBS */
@media (max-width: 768px) {
  .vignettes-container-custom {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important;
    gap: 0.5rem !important;
  }
  
  .vignettes-container-custom .vignette-item {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  
  /* Adaptation des polices pour petites vignettes */
  .vignettes-container-custom .product-card-flip-back-title {
    font-size: 0.9rem !important;
  }
  
  .vignettes-container-custom .product-card-flip-back-subtitle {
    font-size: 0.75rem !important;
  }
  
  .vignettes-container-custom .flip-action-btn {
    font-size: 0.7rem !important;
    padding: 0.5rem 0.6rem !important;
    min-width: auto !important;
  }
  
  .vignettes-container-custom .product-card-flip-back-icon {
    font-size: 1.5rem !important;
  }
}

@media (max-width: 576px) {
  .vignettes-container-custom {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)) !important;
    gap: 0.4rem !important;
  }
  
  /* Adaptation encore plus poussée pour très petites vignettes */
  .vignettes-container-custom .product-card-flip-back {
    padding: 0.5rem !important;
  }
  
  .vignettes-container-custom .flip-back-content {
    padding: 0.25rem !important;
  }
  
  .vignettes-container-custom .product-card-flip-back-title {
    font-size: 0.8rem !important;
  }
  
  .vignettes-container-custom .product-card-flip-back-subtitle {
    font-size: 0.7rem !important;
  }
  
  .vignettes-container-custom .flip-action-btn {
    font-size: 0.65rem !important;
    padding: 0.4rem 0.5rem !important;
  }
  
  .vignettes-container-custom .product-card-flip-back-icon {
    font-size: 1.2rem !important;
  }
  
  .vignettes-container-custom .flip-back-header {
    margin-bottom: 0.5rem !important;
    padding-top: 0.5rem !important;
  }
  
  .vignettes-container-custom .flip-back-actions {
    margin: 0.5rem 0 !important;
    gap: 0.5rem !important;
  }
}

/* ========================================
   MINI CUSTOM THUMBS - MINI VIGNETTES
   Styles identiques à customThumbs mais avec namespace séparé
   ======================================== */

.vignettes-container-mini-custom {
  display: grid !important;
  grid-auto-flow: dense !important; /* Compactage automatique pour éviter les espaces vides */
}

.vignettes-container-mini-custom .vignette-item {
  display: flex !important;
  align-items: stretch !important;
  min-width: 0 !important; /* Permet au contenu de rétrécir */
  max-width: 100% !important;
}

/* Adaptation du contenu du verso pour miniCustomThumbs */
.vignettes-container-mini-custom .product-card-flip-back {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}

.vignettes-container-mini-custom .flip-back-content {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  padding: 0.5rem !important;
}

.vignettes-container-mini-custom .flip-back-header {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.vignettes-container-mini-custom .flip-back-actions {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

.vignettes-container-mini-custom .flip-action-btn {
  max-width: 100% !important;
  box-sizing: border-box !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
  white-space: normal !important;
  font-size: 0.75rem !important;
  padding: 0.5rem 0.75rem !important;
}

.vignettes-container-mini-custom .product-card-flip-back-title,
.vignettes-container-mini-custom .product-card-flip-back-subtitle {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
}

/* RESPONSIVE POUR MINICUSTOMTHUMBS */
/* NOTE: Ne pas forcer grid-template-columns pour les vignettes principales, 
   la valeur est gérée par PHP selon le choix de l'utilisateur */
@media (max-width: 768px) {
  /* Ne plus forcer grid-template-columns, laisser PHP gérer selon la session */
  /* .vignettes-container-mini-custom {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important;
    gap: 0.5rem !important;
  } */
  
  .vignettes-container-mini-custom .vignette-item {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  
  /* Adaptation des polices pour petites vignettes */
  .vignettes-container-mini-custom .product-card-flip-back-title {
    font-size: 0.9rem !important;
  }
  
  .vignettes-container-mini-custom .product-card-flip-back-subtitle {
    font-size: 0.75rem !important;
  }
  
  .vignettes-container-mini-custom .flip-action-btn {
    font-size: 0.7rem !important;
    padding: 0.5rem 0.6rem !important;
    min-width: auto !important;
  }
  
  .vignettes-container-mini-custom .product-card-flip-back-icon {
    font-size: 1.5rem !important;
  }
}

@media (max-width: 576px) {
  /* Ne plus forcer grid-template-columns, laisser PHP gérer selon la session */
  /* .vignettes-container-mini-custom {
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)) !important;
    gap: 0.4rem !important;
  } */
  
  /* Adaptation encore plus poussée pour très petites vignettes */
  .vignettes-container-mini-custom .product-card-flip-back {
    padding: 0.5rem !important;
  }
  
  .vignettes-container-mini-custom .flip-back-content {
    padding: 0.25rem !important;
  }
  
  .vignettes-container-mini-custom .product-card-flip-back-title {
    font-size: 0.8rem !important;
  }
  
  .vignettes-container-mini-custom .product-card-flip-back-subtitle {
    font-size: 0.7rem !important;
  }
  
  .vignettes-container-mini-custom .flip-action-btn {
    font-size: 0.65rem !important;
    padding: 0.4rem 0.5rem !important;
  }
  
  .vignettes-container-mini-custom .product-card-flip-back-icon {
    font-size: 1.2rem !important;
  }
  
  .vignettes-container-mini-custom .flip-back-header {
    margin-bottom: 0.5rem !important;
    padding-top: 0.5rem !important;
  }
  
  .vignettes-container-mini-custom .flip-back-actions {
    margin: 0.5rem 0 !important;
    gap: 0.5rem !important;
  }
}

/* RESPONSIVE POUR THUMBS (Bootstrap) */
@media (max-width: 768px) {
  .vignettes-container .row[style*="margin-left"] > [class*="col-"].d-flex.align-items-stretch {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
    margin-bottom: 0.5rem !important;
  }
  
  .vignettes-container .row[style*="margin-left"] > [class*="col-"].vignette-ad.d-flex.align-items-stretch {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
    margin-bottom: 0.5rem !important;
  }
}

@media (max-width: 576px) {
  .vignettes-container .row[style*="margin-left"] > [class*="col-"].d-flex.align-items-stretch {
    padding-left: 0.2rem !important;
    padding-right: 0.2rem !important;
    margin-bottom: 0.4rem !important;
  }
  
  .vignettes-container .row[style*="margin-left"] > [class*="col-"].vignette-ad.d-flex.align-items-stretch {
    padding-left: 0.2rem !important;
    padding-right: 0.2rem !important;
    margin-bottom: 0.4rem !important;
  }
}

/* Glass effect - Garder visible mais gelé */
.glassystem-behavior-glass-effect .vignette-selectable.filtered-out {
  opacity: 0.25;
  pointer-events: none;
}

/* Wave effect - Animation simplifiée */
.glassystem-behavior-wave-effect .vignette-selectable {
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.glassystem-behavior-wave-effect .vignette-selectable.filtered-out {
  opacity: 0;
  transform: translateX(20px);
  pointer-events: none;
}

/* CORRECTION: Désactiver TOUS les effets hover sur les vignettes filtrées en mode wave-effect */
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out:hover,
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out:hover *,
.glassystem-behavior-wave-effect .product-card.filtered-out:hover,
.glassystem-behavior-wave-effect .product-card.filtered-out:hover *,
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out:hover::before,
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out:hover::after,
.glassystem-behavior-wave-effect .product-card.filtered-out:hover::before,
.glassystem-behavior-wave-effect .product-card.filtered-out:hover::after {
  opacity: 0 !important;
  transform: translateX(20px) !important;
  pointer-events: none !important;
  transition: none !important;
  box-shadow: none !important;
  visibility: hidden !important;
}

/* CORRECTION: Désactiver les effets hover sur les images des vignettes filtrées en mode wave-effect */
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out .card-img-top,
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out:hover .card-img-top,
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out .product-thumb::before,
.glassystem-behavior-wave-effect .vignette-selectable.filtered-out:hover .product-thumb::before {
  transform: translateX(20px) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: none !important;
}

/* CORRECTION: Désactiver TOUS les effets hover sur les vignettes filtrées pour tous les modes */
.vignette-selectable.filtered-out:hover,
.vignette-selectable.filtered-out:hover *,
.product-card.filtered-out:hover,
.product-card.filtered-out:hover * {
  pointer-events: none !important;
  opacity: inherit !important;
}

/* CORRECTION: Désactiver les effets hover sur les images des vignettes filtrées pour tous les modes */
.vignette-selectable.filtered-out .card-img-top,
.vignette-selectable.filtered-out:hover .card-img-top,
.vignette-selectable.filtered-out .product-thumb::before,
.vignette-selectable.filtered-out:hover .product-thumb::before {
  pointer-events: none !important;
}

/* ==========================================================================
   ACCESSIBILITÉ
   ========================================================================== */
.sticky-filters-container .form-control:focus-visible,
.sticky-filters-container .form-select:focus-visible,
.sticky-filters-container .btn:focus-visible {
  outline: 2px solid var(--cfy-primary);
  outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  .sticky-filters-container * {
    transition: none !important;
    animation: none !important;
  }
}

/* ==========================================================================
   OVERFLOW POUR DROPDOWNS
   ========================================================================== */
.sticky-filters-container .card,
.sticky-filters-container .card-body,
.sticky-filters-container .row,
.sticky-filters-container .filter-group {
  overflow: visible !important;
}

/* ==========================================================================
   DISPLAY MODE DISABLED
   ========================================================================== */
.sticky-filters-container .ad-display-mode-disabled {
  cursor: not-allowed;
  opacity: 0.6;
}

.sticky-filters-container .ad-display-mode-disabled option:disabled {
  color: var(--cfy-text-muted);
}

/* ==========================================================================
   ZONE AUCUN RÉSULTAT (NO RESULTS) - Thème Commercify
   ========================================================================== */
.vignettes-container.glassystem-no-results-active .glassystem-no-results {
  display: block !important;
}

.glassystem-no-results {
  width: 100%;
  padding: clamp(2rem, 5vw, 3.5rem) var(--cfy-padding-x, 12px);
  margin: 0;
  box-sizing: border-box;
}

.glassystem-no-results .no-results-inner {
  max-width: 420px;
  margin: 0 auto;
  text-align: center;
  padding: clamp(1.5rem, 4vw, 2.25rem) clamp(1.25rem, 3vw, 1.75rem);
  background: var(--cfy-bg-light-alt);
  border-radius: var(--cfy-radius);
  box-shadow: var(--cfy-shadow-sm);
  border: 1px solid var(--cfy-border-light);
}

.glassystem-no-results .no-results-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  margin: 0 auto 1rem;
  font-size: 1.5rem;
  line-height: 1;
  background: linear-gradient(135deg, var(--cfy-primary-light) 0%, var(--cfy-primary) 100%);
  color: #fff;
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(133, 79, 255, 0.35);
}

.glassystem-no-results .no-results-title {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--cfy-text-light);
  margin: 0 0 0.5rem;
  letter-spacing: -0.02em;
}

.glassystem-no-results .no-results-text {
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--cfy-text-muted);
  margin: 0;
}

/* Dark mode - Zone Aucun résultat */
.dark-mode .vignettes-container .glassystem-no-results .no-results-inner,
html.dark-mode .vignettes-container .glassystem-no-results .no-results-inner,
body.dark-mode .vignettes-container .glassystem-no-results .no-results-inner,
[data-bs-theme='dark'] .vignettes-container .glassystem-no-results .no-results-inner {
  background: var(--cfy-bg-dark-alt);
  border-color: var(--cfy-border-dark);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

.dark-mode .vignettes-container .glassystem-no-results .no-results-icon,
html.dark-mode .vignettes-container .glassystem-no-results .no-results-icon,
body.dark-mode .vignettes-container .glassystem-no-results .no-results-icon,
[data-bs-theme='dark'] .vignettes-container .glassystem-no-results .no-results-icon {
  background: linear-gradient(135deg, var(--cfy-primary) 0%, var(--cfy-primary-dark) 100%);
  box-shadow: 0 4px 12px rgba(133, 79, 255, 0.4);
}

.dark-mode .vignettes-container .glassystem-no-results .no-results-title,
html.dark-mode .vignettes-container .glassystem-no-results .no-results-title,
body.dark-mode .vignettes-container .glassystem-no-results .no-results-title,
[data-bs-theme='dark'] .vignettes-container .glassystem-no-results .no-results-title {
  color: var(--cfy-text-dark);
}

.dark-mode .vignettes-container .glassystem-no-results .no-results-text,
html.dark-mode .vignettes-container .glassystem-no-results .no-results-text,
body.dark-mode .vignettes-container .glassystem-no-results .no-results-text,
[data-bs-theme='dark'] .vignettes-container .glassystem-no-results .no-results-text {
  color: var(--cfy-text-muted);
}

/* PHASE 2 : Les styles de masquage pagination ont été déplacés dans commercify_vignettes_pagination.css
   pour consolidation et optimisations performance+++
   
   Voir : engine/tpl/css/commercify_vignettes_pagination.css */

/* ==========================================================================
   STICKY FILTER - SUPPRESSION GLOBALE DES BORDURES
   ========================================================================== */
.sticky-filters-container,
.sticky-filters-container *,
.sticky-filters-container *::before,
.sticky-filters-container *::after {
  border: none !important;
  border-color: transparent !important;
}
