/* ====================================================================
   FAIR HOME V2 — CSS résiduel (effets décoratifs irréductibles)
   À ajouter en fin de home.css après nettoyage
   ==================================================================== */

/* ===== HERO — Bg "FAIR/" décoratif géant ===== */
[data-id="db77532"] {
    position: relative;
    overflow: hidden;
}
[data-id="db77532"] .fair-hero-bg-decoration {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    font-size: clamp(19.8rem, 39.6vw, 39.6rem);
    color: rgba(0,0,0,0.04);
    z-index: 1;
    line-height: 1;
    user-select: none;
    pointer-events: none;
    white-space: nowrap;
}

/* Garantir que le contenu textuel passe AU-DESSUS du bg décoratif */
[data-id="db77532"] > .e-con {
    position: relative;
    z-index: 2;
}

/* ===== HERO H1 em (mot "de l'anglais juste, équitable, loyal" en gris clair) ===== */
[data-id="db77532"] h1 em {
    font-style: normal;
    color: rgba(0,0,0,0.25);
}

/* ===== FAMILIES — Hover dramatique (bg noir + texte blanc) ===== */
.fair-family-card-v2 {
    transition: transform 0.3s ease, box-shadow 0.35s ease, background 0.35s ease !important;
}
.fair-family-card-v2:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.08) !important;
    background-color: #0A0A0A !important;
}

/* Au hover : tous les enfants en blanc */
.fair-family-card-v2:hover h3,
.fair-family-card-v2:hover .elementor-heading-title,
.fair-family-card-v2:hover p {
    color: #FFFFFF !important;
}
.fair-family-card-v2:hover .elementor-widget-text-editor,
.fair-family-card-v2:hover .elementor-widget-text-editor p {
    color: rgba(255,255,255,0.7) !important;
}
.fair-family-card-v2:hover ul li {
    border-top-color: rgba(255,255,255,0.15) !important;
}
.fair-family-card-v2:hover ul li a {
    color: rgba(255,255,255,0.9) !important;
}

/* ===== Liens hover dans les listes families (padding-left effet) ===== */
.fair-family-card-v2 ul li a {
    transition: padding-left 0.2s ease, color 0.35s ease !important;
    display: block;
}
.fair-family-card-v2 ul li a:hover {
    padding-left: 8px !important;
    color: #444444 !important;
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
    [data-id="db77532"] .fair-hero-bg-decoration {
        font-size: clamp(8rem, 25vw, 14rem);
        opacity: 0.5;
    }
}




/* ===== Family cards hover (data-id targeting car _css_classes container ignoré par Elementor v4 atomic) ===== */
[data-id="78ed223"],
[data-id="a05d4cc"],
[data-id="89d2f23"] {
    transition: transform 0.3s ease, box-shadow 0.35s ease, background-color 0.35s ease !important;
}
[data-id="78ed223"]:hover,
[data-id="a05d4cc"]:hover,
[data-id="89d2f23"]:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.08) !important;
    background-color: #0A0A0A !important;
}
[data-id="78ed223"]:hover .elementor-heading-title,
[data-id="a05d4cc"]:hover .elementor-heading-title,
[data-id="89d2f23"]:hover .elementor-heading-title {
    color: #FFFFFF !important;
}
[data-id="78ed223"]:hover .elementor-widget-text-editor,
[data-id="a05d4cc"]:hover .elementor-widget-text-editor,
[data-id="89d2f23"]:hover .elementor-widget-text-editor,
[data-id="78ed223"]:hover .elementor-widget-text-editor *,
[data-id="a05d4cc"]:hover .elementor-widget-text-editor *,
[data-id="89d2f23"]:hover .elementor-widget-text-editor * {
    color: rgba(255,255,255,0.85) !important;
}
[data-id="78ed223"]:hover ul li,
[data-id="a05d4cc"]:hover ul li,
[data-id="89d2f23"]:hover ul li {
    border-top-color: rgba(255,255,255,0.15) !important;
}
[data-id="78ed223"]:hover ul li a,
[data-id="a05d4cc"]:hover ul li a,
[data-id="89d2f23"]:hover ul li a {
    color: rgba(255,255,255,0.9) !important;
}

/* ===== #fair-challenges (panel fixed injecté par header.php) ===== */

#fair-challenges {
  position: fixed;
  right: 0;
  top: 245px;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 4px;
  pointer-events: all;
  max-width: 45vw;
}

.fair-challenge {
  width: 100%;
  max-height: 50px;
  min-height: 50px;
  background: rgba(10,10,10,0.55);
  color: #FFFFFF;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  cursor: pointer;
  pointer-events: all;
  box-sizing: border-box;
  overflow: hidden;
  opacity: 0;
  transform: translateX(60px);
  transition: 
    transform 0.3s ease, 
    opacity 0.5s ease,
    background-color 0.35s ease,
    max-height 0.4s ease,
    padding 0.3s ease;
}

.fair-challenge.visible {
  opacity: 1;
  transform: translateX(0);
}

.fair-challenge.visible:hover {
  transform: translateX(-8px);
  max-height: 200px;
  background: var(--challenge-color, rgba(10,10,10,0.85));
  padding: 12px 20px;
}

.fair-challenge-q {
  font-family: 'Barlow Condensed', sans-serif;
  font-size:clamp(1rem, 1.22vw, 1.1rem);
  font-weight: 600;
  color: #FFFFFF;
  letter-spacing: 0.5px;
}

.fair-challenge-expand {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.4s ease, opacity 0.3s ease 0.1s;
}

.fair-challenge.visible:hover .fair-challenge-expand {
  max-height: 100px;
  opacity: 1;
}

.fair-challenge-expand p {
  font-family: 'Inter', sans-serif;
  font-size:clamp(0.75rem, 0.91vw, 0.82rem);
  color: rgba(255,255,255,0.85);
  margin: 6px 0 4px 0;
  line-height: 1.4;
}

.fair-challenge-expand a {
  font-family: 'Barlow Condensed', sans-serif;
  font-size:clamp(0.82rem, 1vw, 0.9rem);
  font-weight: 600;
  color: #FFFFFF;
  text-decoration: none;
  letter-spacing: 1px;
  text-transform: uppercase;
}
