@import "icomoon/style.css";

/* Desktop par défaut */
header .logo.img-fluid{
  max-width: 300px;
  height: auto;
}

/* Tablet */
@media (max-width: 1024px){
  header .logo.img-fluid{ max-width: 220px; }
}

/* Mobile */
@media (max-width: 767px){
  header .logo.img-fluid{ max-width: 200px; }
}

/* Très petits écrans */
@media (max-width: 360px){
  header .logo.img-fluid{ max-width: 200px; }
}

/* Titres d’onglets en majuscules */
.cbp-tab-title,
.cbp-tab-title > a,
.cbp-tab-title > span {
  text-transform: uppercase !important;
  /* optionnel : un léger tracking pour l'esthétique */
  letter-spacing: .03em;
}
/* Menu desktop : supprimer tout fond au hover/ouvert et afficher seulement un trait orange */
@media (min-width:1024px){

  /* 1) Neutralise les fonds posés par le thème, sur li + a + pseudo-éléments */
  #iqitmegamenu-wrapper .cbp-hrmenu-tab,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab:hover,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab.cbp-hropen,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab.active,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab:hover > a.nav-link,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab.cbp-hropen > a.nav-link,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab.active > a.nav-link{
    background: transparent !important;
    box-shadow: none !important;
  }
  #iqitmegamenu-wrapper .cbp-hrmenu-tab::before,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab::after,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link::before{
    content: none !important;
    background: none !important;
  }

  /* 2) Trait orange (animation propre, ne change pas la hauteur) */
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link{
    position: relative;
  }
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link::after{
    content:"";
    position:absolute; left:0; right:0; bottom:0; height:3px;
    background:#fae100; border-radius:2px;
    transform:scaleX(0); transform-origin:left; transition:transform .18s ease;
  }
  #iqitmegamenu-wrapper .cbp-hrmenu-tab:hover > a.nav-link::after,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab.cbp-hropen > a.nav-link::after,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab.active > a.nav-link::after{
    transform:scaleX(1);
  }

  /* Plan B (certains thèmes font encore un fond via un sélecteur plus large) */
  header .cbp-hrmenu-tab:hover > a.nav-link,
  header .cbp-hrmenu-tab.cbp-hropen > a.nav-link,
  header .cbp-hrmenu-tab.active > a.nav-link{
    background: transparent !important;
  }
}

  /* forcer l’héritage sur le span + icônes */
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link .cbp-tab-title{ color:inherit !important; }
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link i,
  #iqitmegamenu-wrapper .cbp-hrmenu-tab > a.nav-link svg{
    color: inherit !important; fill: currentColor !important;
  }
}
/* Ajout de padding haut image */
.thumbnail-container .product-thumbnail {
  padding-top: 15px;
}

/* 1) Le parent sert d'ancre */
.hero-box{ position: relative; }

/* Assure une pile propre du carousel + voile */
.hero-box .elementor-widget-image-carousel{ position: relative; z-index: 1; }

/* 2) L'overlay occupe toute la zone du carrousel */
.hero-box .hero-overlay{
  position: absolute;
  inset: 0;                 /* top/right/bottom/left: 0 */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(12px, 4vw, 32px);
  text-align: center;
  color: #fff;
  z-index: 5;
  pointer-events: none;     /* conserve le swipe du slider */
}

/* 3) Contenu (compat : bloc unique .hero-overlay__inner ou multi .content) */
.hero-overlay__inner,
.hero-overlay .content{
  max-width: 960px;
  margin: 0 auto;
}
.hero-overlay__inner h1,
.hero-overlay .content h1{
  margin: 0 0 .25em;
  line-height: 1.05;
  font-weight: 800;
  font-size: clamp(32px, 6vw, 72px);
}
.hero-overlay__inner p,
.hero-overlay .content p{
  margin: 0 0 1.2em;
  font-size: clamp(18px, 2.2vw, 20px); /* +2px vs 16→18 et 22→24 */
  opacity: .95;
}

/* 4) Boutons */
.hero-overlay .cta{ display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.hero-overlay .btn{
  pointer-events: auto;      /* re-active les clics sur les boutons */
  display: inline-block;
  padding: 12px 22px;
  border-radius: 10px;
  font-weight: 700;
  text-decoration: none;
  border: 2px solid transparent;
  transition: background-color .25s ease, color .25s ease, border-color .25s ease, transform .2s ease;
}

/* Bouton 1 (primary) : base #0C1645, texte blanc, bordure blanche → hover inversé */
.hero-overlay .btn.primary{
  background:#0C1645; color:#fff; border-color:#fff;
}
.hero-overlay .btn.primary:hover,
.hero-overlay .btn.primary:focus-visible{
  background:#F8FB01; color:#000; border-color:#000; transform:translateY(-2px);
}

/* Bouton 2 (ghost) : base #F8FB01, texte noir, bordure noire → hover inversé */
.hero-overlay .btn.ghost{
  background:#F8FB01; color:#000; border-color:#000;
}
.hero-overlay .btn.ghost:hover,
.hero-overlay .btn.ghost:focus-visible{
  background:#0C1645; color:#fff; border-color:#fff; transform:translateY(-2px);
}

/* 5) Voile sombre sur les images du carrousel pour la lisibilité (optionnel) */
.hero-box .elementor-image-carousel::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(transparent, rgba(0,0,0,.25)), rgba(0,0,0,.25);
  pointer-events:none;
  z-index: 2;
}

/* 6) Multi-slides : n'afficher que le contenu du slide actif */
.hero-overlay .content{ display:none; }
.hero-overlay .content.is-active{ display:block; }

/* Quand aucun bloc ne correspond au slide, on masque l'overlay entier */
.hero-overlay.is-hidden{ opacity:0; pointer-events:none; transition:opacity .2s ease; }

/* Sécurité responsive */
@media (max-width: 767px){
  .hero-overlay .cta{ gap: 10px; }
}

#product-availability {

    display: none;
}
/* Fixe le header en haut de l'écran */
#mobile-header-sticky {
  position: sticky;
  top: 0; /* Fixe le header en haut de l'écran */
  z-index: 1000; /* Assure que le header reste au-dessus du contenu */
  background-color: #fff; /* Fond blanc pour éviter la transparence du contenu sous-jacent */
  width: 100%; /* S'assure que le header couvre toute la largeur */
}

#mobile-header-sticky .container {
  padding: 0 15px; /* Ajuste le padding si nécessaire pour mobile */
}

@media (max-width: 767px) {
  #mobile-header-sticky {
    position: sticky; /* Confirme le sticky sur mobile */
    top: 0;
    z-index: 1000;
  }

  /* Ajuste la hauteur si les éléments débordent */
  #mobile-header-sticky .row-mobile-header {
    min-height: 60px; /* Hauteur minimale pour éviter que le header ne soit écrasé */
  }
}