/* ==========================================================================
   COMPOSANT AVANT/APRÈS - SLIDER DE COMPARAISON
   ========================================================================== */

/* Priorité élevée pour éviter les conflits avec les styles de landing */
#pixelyz-hero .pixelyz-before-after-container,
.pixelyz-before-after-container {
    position: relative !important;
    overflow: visible !important; /* Permettre le débordement des badges */
    user-select: none !important;
    cursor: col-resize !important;
    border-radius: 24px !important;
    box-shadow: 0 25px 60px -15px rgba(0, 0, 0, 0.5) !important;
    background: #0f172a !important;
    border: 1px solid #1e293b !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    /* Annuler les styles de .card */
    height: auto !important;
    display: block !important;
    /* Créer un contexte de stacking pour les badges */
    isolation: isolate !important;
}

/* Fenêtre macOS (optionnelle) */
#pixelyz-hero .pixelyz-before-after-window,
.pixelyz-before-after-window {
    background: #0f172a !important;
    border-bottom: 1px solid #1e293b !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 16px !important;
    justify-content: space-between !important;
    width: 100% !important;
    box-sizing: border-box !important;
    position: relative !important;
    z-index: 10 !important; /* En dessous des badges (100) mais au-dessus du slider */
}

.pixelyz-before-after-window .traffic-lights {
    display: flex;
    gap: 8px;
}

.pixelyz-before-after-window .traffic-light {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.pixelyz-before-after-window .traffic-light.red {
    background: #FF5F56;
    border-color: rgba(224, 68, 62, 0.3);
}

.pixelyz-before-after-window .traffic-light.yellow {
    background: #FFBD2E;
    border-color: rgba(222, 161, 35, 0.3);
}

.pixelyz-before-after-window .traffic-light.green {
    background: #27C93F;
    border-color: rgba(26, 171, 41, 0.3);
}

.pixelyz-before-after-window .fake-url {
    flex: 1;
    max-width: 400px;
    margin: 0 16px;
}

.pixelyz-before-after-window .fake-url-bar {
    background: #020617;
    border: 1px solid #1e293b;
    border-radius: 6px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 500;
    padding: 0 16px;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.3);
    color: #e2e8f0;
    letter-spacing: 0.5px;
}

.pixelyz-before-after-window .fake-url-bar i {
    font-size: 10px;
    margin-right: 8px;
    color: #64748b;
}

/* Zone du slider */
#pixelyz-hero .pixelyz-before-after-slider,
.pixelyz-before-after-slider {
    position: relative !important;
    height: 450px !important;
    width: 100% !important;
    background: #0f172a !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important; /* Le slider lui-même cache le débordement des images */
    border-radius: 0 0 24px 24px !important; /* Arrondir seulement le bas - IMPORTANT pour garder les arrondis */
    z-index: 1 !important; /* En dessous de la fenêtre et des badges */
}

@media (min-width: 768px) {
    .pixelyz-before-after-slider {
        height: 600px;
    }
}

/* Image après (fond) */
.pixelyz-before-after-after {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    border-radius: 0 0 24px 24px; /* Arrondi en bas pour correspondre au slider */
    overflow: hidden; /* S'assurer que l'image respecte les arrondis */
    z-index: 0; /* En dessous du container .before (z-index 1) et du curseur (z-index 30-31) */
}

.pixelyz-before-after-after img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    opacity: 0.9;
    transition: opacity 0.7s ease;
    border-radius: 0 0 24px 24px; /* Arrondi en bas pour respecter le container */
    display: block; /* Éviter les espaces inline */
}

.pixelyz-before-after-container:hover .pixelyz-before-after-after img {
    opacity: 1;
}

.pixelyz-before-after-after .badge {
    position: absolute;
    top: 24px;
    right: 24px;
    background: rgba(15, 23, 42, 0.3);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    color: #3b82f6; /* Bleu au lieu de magenta/violet */
    font-size: 10px; /* Réduit de 12px à 10px */
    font-weight: 700;
    padding: 5px 10px; /* Padding réduit */
    border-radius: 6px; /* Réduit de 8px à 6px */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
    z-index: 0 !important; /* Visible au-dessus de l'image de fond, mais en dessous du container .before (z-index 1) et du curseur (z-index 30-31) */
    border: 1px solid rgba(51, 65, 85, 0.3);
    pointer-events: none; /* Ne pas bloquer les interactions avec le slider */
}

/* Annuler l'agrandissement de la première lettre pour les badges du module de comparaison */
.pixelyz-before-after-after .badge::first-letter {
    font-size: 10px !important; /* Aligner sur la taille normale du texte */
}

/* Image avant (dessus - masquée par le slider) */
.pixelyz-before-after-before {
    position: absolute;
    inset: 0;
    width: 50%;
    height: 100%;
    overflow: hidden !important; /* Forcer le overflow pour que le badge s'efface */
    border-right: 1px solid rgba(255, 255, 255, 0.1);
    background: #0f172a;
    box-shadow: 5px 0 30px rgba(0, 0, 0, 0.5);
    border-radius: 0 0 24px 0; /* Arrondi en bas à gauche pour correspondre au container */
    z-index: 2 !important; /* Au-dessus du badge "Photo Pixelyz" (z-index 0) mais en dessous du curseur (z-index 30-31) */
    /* Le badge à l'intérieur gardera sa taille grâce à white-space: nowrap et width: auto */
}

.pixelyz-before-after-before .wrapper {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background: #1e293b;
    overflow: hidden; /* S'assurer que le contenu respecte les limites */
    border-radius: 0 0 0 24px; /* Arrondi en bas à gauche */
}

.pixelyz-before-after-before img {
    position: absolute;
    top: 0;
    left: 0;
    /* L'image garde sa taille naturelle - sera définie en pixels par JavaScript */
    /* Ne pas utiliser de pourcentage pour éviter le redimensionnement */
    width: auto !important; /* Largeur automatique basée sur le ratio de l'image */
    height: 100% !important;
    object-fit: cover !important;
    object-position: left center !important; /* Aligner à gauche pour que le slider révèle progressivement */
    filter: grayscale(30%) contrast(75%) brightness(75%);
    border-radius: 0 0 0 24px; /* Arrondi en bas à gauche pour respecter le container */
    display: block; /* Éviter les espaces inline */
    /* La largeur sera définie dynamiquement par JavaScript pour correspondre exactement au slider */
    /* Mais on utilise object-fit: cover pour que l'image remplisse la hauteur sans déformation */
}

/* Badge Photo Originale - Dans le container .before pour s'effacer progressivement */
.pixelyz-before-after-before .badge,
.pixelyz-before-after-before .badge-before {
    position: absolute;
    bottom: 16px; /* Descendu de 24px à 16px */
    left: 24px;
    background: rgba(2, 6, 23, 0.3);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    color: #cbd5e1;
    font-size: 10px;
    font-weight: 700;
    padding: 5px 10px; /* Padding réduit */
    border-radius: 6px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
    z-index: 20;
    border: 1px solid rgba(30, 41, 59, 0.3);
    pointer-events: none;
    /* Le badge reste à sa position fixe et s'efface progressivement avec le container */
    white-space: nowrap; /* Empêcher le texte de se couper */
    transform: none !important; /* Empêcher toute transformation */
    width: auto !important; /* Largeur automatique basée sur le contenu */
    min-width: auto !important;
    max-width: none !important;
}

/* Annuler l'agrandissement de la première lettre pour les badges du module de comparaison */
.pixelyz-before-after-before .badge::first-letter,
.pixelyz-before-after-before .badge-before::first-letter {
    font-size: 10px !important; /* Aligner sur la taille normale du texte */
}

/* Input range invisible */
.pixelyz-before-after-input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: col-resize;
    z-index: 40;
    margin: 0;
}

/* Ligne verticale du slider */
.pixelyz-before-after-handle {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 4px;
    background: rgba(255, 255, 255, 0.9);
    z-index: 30;
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Bouton central du slider */
.pixelyz-before-after-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 44px;
    height: 44px;
    background: #1e293b;
    border: 2px solid #334155;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #3b82f6; /* Bleu au lieu de magenta/violet */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
    z-index: 31;
}

.pixelyz-before-after-button i {
    font-size: 14px;
}

/* Badges flottants - Positionnés par rapport au container principal */
.pixelyz-before-after-container .pixelyz-before-after-badge {
    position: absolute;
    z-index: 100 !important; /* Au-dessus de tout : fenêtre macOS (30-40), slider (30-40), images */
    pointer-events: none;
    animation: float 6s ease-in-out infinite;
}

.pixelyz-before-after-badge {
    position: absolute;
    z-index: 100 !important;
    pointer-events: none;
    animation: float 6s ease-in-out infinite;
}

.pixelyz-before-after-badge.delay {
    animation-delay: 2s;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

.pixelyz-before-after-badge-content {
    background: rgba(15, 23, 42, 0.3);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    padding: 12px 16px 8px 10px; /* Padding-top augmenté pour descendre le texte */
    border-radius: 12px;
    box-shadow: 0 8px 16px rgba(59, 130, 246, 0.15); /* Ombre bleutée plus subtile */
    border: 1px solid rgba(59, 130, 246, 0.2); /* Bordure bleutée plus subtile */
    display: flex;
    align-items: flex-start; /* Alignement en haut au lieu de center */
    gap: 10px; /* Gap réduit */
}

.pixelyz-before-after-badge-icon {
    width: 32px; /* Légèrement réduit */
    height: 32px; /* Légèrement réduit */
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px; /* Légèrement réduit */
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.pixelyz-before-after-badge-icon img {
    width: 18px;
    height: 18px;
    object-fit: contain;
    display: block;
}

/* Appliquer la couleur bleue (#60a5fa) à l'image du badge emerald */
.pixelyz-before-after-badge-icon.emerald img {
    filter: brightness(0) saturate(100%) invert(67%) sepia(89%) saturate(1352%) hue-rotate(195deg) brightness(102%) contrast(101%);
}

.pixelyz-before-after-badge-icon.emerald {
    background: rgba(59, 130, 246, 0.15); /* Bleu au lieu de vert */
    color: #60a5fa; /* Bleu plus clair */
    border-color: rgba(59, 130, 246, 0.3);
}

.pixelyz-before-after-badge-icon.brand {
    background: rgba(34, 197, 94, 0.15); /* Vert pour symboliser l'augmentation */
    color: #22c55e; /* Vert principal */
    border-color: rgba(34, 197, 94, 0.3);
}

/* Appliquer la couleur verte à l'image du badge brand */
.pixelyz-before-after-badge-icon.brand img {
    filter: brightness(0) saturate(100%) invert(58%) sepia(95%) saturate(1352%) hue-rotate(95deg) brightness(95%) contrast(95%);
}

.pixelyz-before-after-badge-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start; /* Aligner à gauche au lieu de centrer */
    text-align: left; /* Aligner le texte à gauche */
    padding-top: 0; /* Remonté pour remonter les valeurs */
}

.pixelyz-before-after-badge-label {
    font-size: 9px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #94a3b8;
    margin-bottom: -6px; /* Espace réduit avec la valeur pour remonter les valeurs */
    text-align: left; /* Aligner le label à gauche */
    width: 100%; /* Prendre toute la largeur */
}

.pixelyz-before-after-badge-value {
    font-size: 24px; /* Agrandi pour plus de visibilité */
    font-weight: 700;
    color: #ffffff;
    line-height: 1;
    margin-top: -14px; /* Remonté encore plus pour réduire l'espace avec le label */
    text-align: left; /* Aligner la valeur à gauche */
    width: 100%; /* Prendre toute la largeur */
}

/* Positionnement des badges - Par rapport au container principal */
.pixelyz-before-after-container .pixelyz-before-after-badge.top-left,
.pixelyz-before-after-badge.top-left {
    top: 60px; /* Légèrement descendu */
    left: -80px; /* Décalé plus à gauche */
}

@media (min-width: 768px) {
    .pixelyz-before-after-container .pixelyz-before-after-badge.top-left,
    .pixelyz-before-after-badge.top-left {
        top: 64px; /* Légèrement descendu pour desktop */
        left: -100px; /* Décalé encore plus à gauche sur desktop */
    }
}

.pixelyz-before-after-container .pixelyz-before-after-badge.bottom-right,
.pixelyz-before-after-badge.bottom-right {
    bottom: 20px; /* Positionné depuis le bas */
    right: -60px; /* Déplacé plus à droite */
}

@media (min-width: 768px) {
    .pixelyz-before-after-container .pixelyz-before-after-badge.bottom-right,
    .pixelyz-before-after-badge.bottom-right {
        bottom: 20px;
        right: -70px; /* Déplacé plus à droite sur desktop */
    }
}

/* Annuler les styles de .card pour le composant */
#pixelyz-hero .pixelyz-before-after-container.card,
#pixelyz-hero .card .pixelyz-before-after-container {
    background: #0f172a !important;
    border: 1px solid #1e293b !important;
    border-radius: 24px !important;
    padding: 0 !important;
    box-shadow: 0 25px 60px -15px rgba(0, 0, 0, 0.5) !important;
    transform: none !important;
    transition: none !important; /* Supprimer la transition de transform */
}

/* Effet de zoom au survol supprimé */

/* S'assurer que le composant n'est pas dans un card-inner */
#pixelyz-hero .card-inner .pixelyz-before-after-container,
#pixelyz-hero .pixelyz-before-after-container {
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Responsive */
@media (max-width: 767px) {
    #pixelyz-hero .pixelyz-before-after-slider,
    .pixelyz-before-after-slider {
        height: 400px !important;
    }
    
    #pixelyz-hero .pixelyz-before-after-badge,
    .pixelyz-before-after-badge {
        display: none !important; /* Masquer les badges sur mobile pour plus de clarté */
    }
    
    #pixelyz-hero .pixelyz-before-after-window,
    .pixelyz-before-after-window {
        display: none !important; /* Masquer la fenêtre macOS sur mobile */
    }
}

