/*
Theme Name: Astra Child Interflora
Description: Thème enfant d'Astra avec header et footer d'Interflora
Template: astra
Version: 1.0.1
*/

/* Styles de bas e pour le thème enfant */
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Reset des styles Astra pour le header et footer */
.ast-header-wrap,
.ast-footer-wrap {
    display: none !important;
}

/* Styles généraux pour maintenir la cohérence */
.site-header,
.site-footer {
    width: 100%;
    z-index: 999;
}

/* Responsive design */
@media (max-width: 768px) {
    .hideOnMobile {
        display: none !important;
    }
}

@media (min-width: 769px) {
    .hideOnDesktop {
        display: none !important;
    }
}

.entry-content h1, h1 {
    line-height: 1.2 !important;
}

/* assets/css/interflora.css ou style.css du thème enfant */
.main-navigation {
    display: none;
}

.main-navigation.mobile-menu-open {
    display: block;
}

.main-menu li a:visited {
  border:0px !important;
}


.reassurance-wrapper {
  background: #f9f3ee;
  padding: 2rem 1rem;
  text-align: center;
}

.reassurance-slider {
  display: flex;
  gap: 2rem;
  justify-content: center;
  flex-wrap: nowrap;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
}

.reassurance-slide {
  scroll-snap-align: center;
  flex: 0 0 100%;
  max-width: 360px;
  margin: 0 auto;
  display: none;
  flex-direction: column;
  align-items: center;
}

.reassurance-slide.active {
  display: flex;
}

.reassurance-slide img {
  width: 120px;
  height: auto;
  margin-bottom: 1rem;
}

.reassurance-slide h3 {
  font-size: 1.2rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: #1d1d1d;
}

.reassurance-slide p {
  font-size: 0.95rem;
  color: #444;
}

.reassurance-dots {
  margin-top: 1rem;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
}

.reassurance-dots .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: #ccc;
  cursor: pointer;
}

.reassurance-dots .dot.active {
  background: #111;
}

/* Desktop layout */
@media (min-width: 768px) {
  .reassurance-slider {
    flex-wrap: wrap;
    overflow: visible;
  }

  .reassurance-slide {
    display: flex !important;
    flex: 0 0 30%;
    max-width: 30%;
  }

  .reassurance-dots {
    display: none;
  }
}
.reassurance-dots .dot {
  all: unset;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #ccc;
  margin: 0 8px;
  display: inline-block;
  cursor: pointer;
  transition: background-color 0.3s ease;
  padding: 18px; /* agrandit la zone cliquable tout en gardant le cercle visible centré */
  box-sizing: content-box; /* empêche que le padding n'étire visuellement le bouton */
}

.reassurance-dots .dot.active {
  background-color: #111;
}

.menu-desktop-item {
  display: inline-block;
  border-bottom: 3px solid transparent;
  padding-bottom: 3px !important; /* Réserve la place pour la bordure */
  transition: border-color 0.3s ease;
}


@media (max-width: 880px) {
  .mobile-navigation .menu-item-has-children > .sub-menu {
    display: none !important;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
  }

  .mobile-navigation .menu-item-has-children.menu-open > .sub-menu {
    display: block !important;
    max-height: 1000px;
  }
}

/* Menu mobile - ouverture sous-menus */
@media (max-width: 880px) {
  .mobile-navigation .menu-item-has-children .sub-menu {
    display: none !important;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
  }

  .mobile-navigation .menu-item-has-children.menu-open > .sub-menu {
    display: block !important;
    max-height: 1000px; /* grande valeur pour permettre l'expansion */
  }
}

@media (max-width: 880px) {
  .mobile-menu .menu-item-has-children.menu-open > .sub-menu {
    display: block !important;
    max-height: none !important;
    overflow: visible !important;
    opacity: 1 !important;
    visibility: visible !important;
    height: auto !important;
    position: static !important;
    padding-left: 1rem !important;
    margin-top: 0.5rem !important;
    border-left: 2px solid #eee !important;
  }
}

/* caché par défaut */
.mobile-navigation .sub-menu {display:none;}
/* visible quand .menu-open est présent (inutile de mettre !important) */
.mobile-navigation .menu-item-has-children.menu-open > .sub-menu {display:block;}

/* assets/css/mobile-menu-fix.css   – tout à la fin du fichier */
@media (max-width:880px){
  .mobile-menu .sub-menu{display:none;}
  .mobile-menu .menu-item-has-children.menu-open > .sub-menu{
    display:block;
  }
}

.mobile-menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
}

.mobile-menu-overlay.is-active {
  opacity: 1;
  visibility: visible;
}

/* Grille responsive */
.itfr-trustpilot-reviews{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  margin: 20px 0;
}
@media (max-width: 1024px){
  .itfr-trustpilot-reviews{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .itfr-trustpilot-reviews{ grid-template-columns: 1fr; }
}

/* Carte */
.itfr-trustpilot-review{
  background:#fff;
  border: 1px solid #e8e8e8;
  border-radius: 14px;
  padding: 18px 18px 16px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  display:flex;
  flex-direction:column;
  min-height: 190px;
}

/* En-tête (étoiles + titre) */
.itfr-trustpilot-review__header{
  margin-bottom: 10px;
}
.itfr-trustpilot-review__stars{
  font-size: 16px;
  letter-spacing: 2px;
  line-height: 1;
  margin-bottom: 8px;
}
.itfr-trustpilot-review__title{
  font-size: 16px;
  font-weight: 650;
  margin: 0;
}

/* Texte (limité à quelques lignes, avec ellipsis) */
.itfr-trustpilot-review__text{
  margin: 10px 0 0;
  color:#333;
  line-height: 1.5;

  display: -webkit-box;
  -webkit-line-clamp: 4;       /* nb de lignes affichées */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Footer */
.itfr-trustpilot-review__footer{
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid #f0f0f0;
  color:#666;
  font-size: 13px;
}
.itfr-trustpilot-review__date{
  display:inline-block;
}

.itfr-trustpilot-disclaimer{
  margin-top: 14px;
  font-size: 13px;
  color: #666;
}
.itfr-trustpilot-disclaimer a{
  text-decoration: underline;
}

.footer,
.section-avis,
.section-seo {
  content-visibility: auto;
  contain-intrinsic-size: auto 600px;
}


