/**
 * Section Plus-value - EFFET CARTES STABILISÉ ET OPTIMISÉ - FULL WIDTH
 * wp-content/themes/custom-theme/src/assets/css/agence/plusvalue-styles.css
 */

/* ====================================
   🏯 BLOC PLUS-VALUE AVEC PIN - FULL WIDTH
   ==================================== */

/* Container englobant pour ScrollTrigger */
.plusvalue-trigger-container {
    position: relative;
}

.plusvalue-section {
    min-height: 100vh;
    background: var(--primary);
    position: relative;
    display: flex;
    align-items: center;
    padding: var(--space-xxl) 0;
    overflow: hidden;
    margin-top: 0;
    width: 100vw !important;
    margin-bottom: 0 !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    left: 0 !important;
    right: 0 !important;
    box-sizing: border-box;
}

/* ✅ Wrapper parent créé par ScrollTrigger pin */
.plusvalue-section.pin-spacer,
div[class*="pin-spacer"] > .plusvalue-section {
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    left: 0 !important;
    right: 0 !important;
}

/* FOND SVG À GAUCHE - 50% DE LARGEUR */
.plusvalue-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background-image: url('/wp-content/uploads/2025/09/fond-bg.svg');
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
    z-index: 1;
    pointer-events: none;
}

/* États de pin gérés par ScrollTrigger */
.plusvalue-section.pin-spacer {
    position: static !important;
}

/* Spacer automatique créé par ScrollTrigger */
.pin-spacer {
    background: transparent;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

.plusvalue-container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
    width: 100%;
    position: relative;
    z-index: 2;
}

.plusvalue-wrapper {
    display: grid;
    grid-template-columns: 50% 50%;
    gap: 0;
    align-items: stretch;
    min-height: 70vh;
    position: relative;
}

/* ====================================
   📋 COLONNE GAUCHE - CONTENU DYNAMIQUE (ORIGINAL)
   ==================================== */
.plusvalue-left-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-right: var(--space-lg);
    position: relative;
    z-index: 3;
    margin: 7em 0 0 0;
}

/* Header avec icône + titre */
.plusvalue-header {
    display: grid;
    grid-template-columns: 6% 95%;
    gap: var(--space-sm);
    align-items: flex-start;
    margin-bottom: var(--space-lg);
}

.plusvalue-icon {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    opacity: 0;
    transform: translateY(30px);
    top: 10px;
    position: relative;
}

.plusvalue-icon img {
    width: 40px;
    height: 40px;
    object-fit: contain;
    position: relative;
    top: 22px;
}

.plusvalue-title-h2 {
    font-family: var(--font-primary);
    font-size: var(--h1-size);
    font-weight: 900;
    line-height: var(--h1-line-height);
    color: var(--white);
    margin-bottom: 0;
    opacity: 0;
    transform: translateY(50px);
}

/* Titre desktop - visible uniquement sur desktop */
.plusvalue-title-desktop {
    display: block;
}

/* Titre mobile - masqué par défaut sur desktop */
.plusvalue-title-mobile {
    display: none;
}

/* Contenu des items - FADE SIMPLE comme À la base */
.plusvalue-content-wrapper {
    margin-left: 67px;
    position: relative;
    min-height: 300px;
    overflow: visible;
    margin-right: 3em;
}

.plusvalue-content-item {
    /* Tous les items en absolute pour éviter les sauts */
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    visibility: hidden;
    /* Ajout pour éviter les sauts */
    transform: translateZ(0);
    backface-visibility: hidden;
}

.plusvalue-content-item.active {
    opacity: 1;
    visibility: visible;
    position: absolute;
}

.plusvalue-item-subtitle {
    font-family: var(--font-primary);
    font-size: var(--h3-size);
    font-weight: 900;
    line-height: var(--h3-line-height);
    color: var(--white);
    margin-bottom: var(--space-sm);
}

.plusvalue-item-description {
    font-family: var(--font-inter);
    font-size: var(--p-size);
    line-height: var(--p-line-height);
    color: var(--white);
    font-weight: normal;
}

.plusvalue-item-description p {
    margin-bottom: var(--space-sm);
    color: var(--white);
    font-weight: 300;
    line-height: var(--p-line-height);
}

/* ====================================
   COLONNE DROITE - IMAGES AVEC EFFET CARTES STABILISÉ
   ==================================== */

/* DESKTOP 1920px - Par défaut */
@media (min-width: 1600px) {
    .plusvalue-right-content {
        position: absolute;
        right: -28em;
        top: 55%;
        transform: translateY(-50%);
        width: calc(50vw + (99vw - var(--container-max)) / 2);
        height: 110vh;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        z-index: 2;
    }

    .plusvalue-image-wrapper {
        position: relative;
        width: 100%;
        height: 100%;
        min-height: 955px;
        overflow: visible;
        perspective: 2000px;
    }
}

@media (max-width: 2000px) {
    .plusvalue-right-content {
        position: absolute;
        right: -14em;
        top: 50%;
        transform: translateY(-50%);
        width: calc(50vw + (109vw - var(--container-max)) / 2);
        height: 70vh;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        z-index: 2;
    }

    .plusvalue-icon img {
        width: 35px;
        height: 35px;
        object-fit: contain;
        position: relative;
        top: -5px;
    }

    .plusvalue-header {
        display: grid;
        grid-template-columns: 8% 95%;
        gap: var(--space-sm);
        align-items: flex-start;
        margin-bottom: var(--space-lg);
    }

    .plusvalue-content-wrapper {
        margin-left: 57px;
        position: relative;
        min-height: 300px;
        overflow: visible;
        margin-right: 3em;
    }

    .plusvalue-image-wrapper {
        position: relative;
        width: 100%;
        height: 100%;
        min-height: 900px;
        overflow: visible;
        perspective: 2000px;
    }

    .plusvalue-icon {
        top: 30px;
        position: relative;
    }
}

/* 1440px - Laptop 13/15 pouces */
@media (max-width: 1600px) {
    .plusvalue-section {
        padding: 6em 0;
    }

    .plusvalue-right-content {
        right: -28em;
        height: 0;
    }

    .plusvalue-icon img {
        width: 35px;
        height: 35px;
        object-fit: contain;
        position: relative;
        top: -5px;
    }

    .plusvalue-image-wrapper {
        min-height: 775px;
        perspective: 1790px;
    }

    .plusvalue-content-wrapper {
        margin-left: 57px;
        position: relative;
        min-height: 300px;
        overflow: visible;
        margin-right: 3em;
    }

    .plusvalue-header {
        margin-bottom: 30px;
    }

    .plusvalue-icon {
        top: 22px;
        position: relative;
    }
}

/* 1300px - Petit écran desktop */
@media (max-width: 1300px) {
    .plusvalue-section {
        padding: 5em 0;
    }

    .plusvalue-right-content {
        right: -17em;
        height: 60vh;
    }

    .plusvalue-image-wrapper {
        min-height: 680px;
        perspective: 1600px;
    }

    .plusvalue-content-wrapper {
        margin-right: 4em;
        min-height: 280px;
    }

    .plusvalue-icon {
        top: 16px;
        position: relative;
    }
}

/* 1024px - Tablettes */
@media (max-width: 1024px) {
    .plusvalue-section {
        padding: 4em 0;
    }

    .plusvalue-right-content {
        right: -8em;
        height: 55vh;
    }

    .plusvalue-image-wrapper {
        min-height: 600px;
        perspective: 1400px;
    }

    .plusvalue-content-wrapper {
        margin-right: 3em;
        min-height: 260px;
    }

    .plusvalue-header {
        grid-template-columns: 6% 94%;
    }
}

/* ====================================
   🎴 EFFET CARTES - CHUTE DU HAUT VERS LE BAS AVEC ROTATION
   ==================================== */

.plusvalue-image-item {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform-origin: center center;

    /* États initiaux - TOUS cachés par défaut */
    opacity: 1;
    visibility: hidden;

    /* Position de départ - EN HAUT (hors de la vue) */
    transform: translateY(-150%) translateZ(0);

    /* Optimisation GPU - CRITIQUE pour la stabilité */
    will-change: transform;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    transform-style: preserve-3d;
    -webkit-transform-style: preserve-3d;

    /* Transition linéaire pour effet de chute - ACCÉLÉRÉE */
    transition: transform 0.5s linear,
    visibility 0s linear 0s;
}

/* ====================================
   ÉTATS DES CARTES - SYSTÈME DE CHUTE
   ==================================== */

/* Carte ACTIVE - À sa position finale, bien visible */
.plusvalue-image-item.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) translateZ(0);
    z-index: 10;
    transition: transform 0.5s linear,
    opacity 0.3s ease,
    visibility 0s linear 0s;
}

/* ROTATIONS SPÉCIFIQUES PAR INDEX - DESKTOP */

/* Première carte (index 0) - Rotation 5deg */
.plusvalue-image-item[data-index="0"].active {
    transform: translateY(0) rotate(5deg) translateZ(0);
}

.plusvalue-image-item[data-index="0"]:not(.active) {
    transform: translateY(-150%) rotate(5deg) translateZ(0);
}

/* Deuxième carte (index 1) - Rotation 10deg */
.plusvalue-image-item[data-index="1"].active {
    transform: translateY(0) rotate(10deg) translateZ(0);
}

.plusvalue-image-item[data-index="1"]:not(.active) {
    transform: translateY(-150%) rotate(10deg) translateZ(0);
}

/* Troisième carte (index 2) - Rotation -11deg */
.plusvalue-image-item[data-index="2"].active {
    transform: translateY(0) rotate(-11deg) translateZ(0);
}

.plusvalue-image-item[data-index="2"]:not(.active) {
    transform: translateY(-150%) rotate(-11deg) translateZ(0);
}

/* Carte HIDDEN (cachée) - En haut, hors de la vue */
.plusvalue-image-item.hidden {
    opacity: 0;
    visibility: hidden;
    z-index: 1;
    pointer-events: none;
    transition: transform 0.5s linear,
    opacity 0.25s ease,
    visibility 0s linear 0.25s;
}

/* Carte EXITING (en train de sortir) - Remonte vers le haut */
.plusvalue-image-item.exiting {
    opacity: 0;
    visibility: hidden;
    z-index: 2;
    transition: transform 0.5s linear,
    opacity 0.3s ease,
    visibility 0s linear 0.3s;
}

/* Container de l'image */
.plusvalue-image-container {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: var(--border-radius-xl);
    overflow: hidden;
    transition: box-shadow 0.4s ease;
    /* Force le GPU rendering */
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

.plusvalue-image-container img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    /* Optimisation GPU pour l'image */
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

/* ====================================
   📱 RESPONSIVE
   ==================================== */

/* 968px - Transition tablette/mobile */
@media (max-width: 968px) {
    .plusvalue-section {
        min-height: auto;
        padding: var(--space-lg) 0;
        overflow: hidden;
        margin-top: 70px;
        scroll-margin-top: 80px;
    }

    .plusvalue-section::before {
        width: 100%;
        background-position: center;
        opacity: 0.3;
    }

    /* Affichage des titres sur tablette/mobile */
    .plusvalue-title-desktop {
        display: none;
    }

    .plusvalue-title-mobile {
        display: block;
    }

    .plusvalue-wrapper {
        grid-template-columns: 1fr;
        gap: var(--space-md);
        min-height: auto;
    }

    .plusvalue-left-content {
        order: 1;
        padding-right: 0;
        padding-bottom: var(--space-md);
    }

    .plusvalue-right-content {
        order: 2;
        position: relative;
        width: 100%;
        height: auto;
        transform: none;
        right: auto;
        top: 18px;
    }

    h2.plusvalue-title-h2 {
        margin-top: 20px;
    }

    .plusvalue-header {
        grid-template-columns: 8% 92%;
        margin-bottom: var(--space-md);
    }

    .plusvalue-icon img {
        width: 40px;
        height: 40px;
    }

    .plusvalue-content-wrapper {
        min-height: 200px;
        margin-left: 44px;
        margin-right: 0;
    }

    .plusvalue-image-wrapper {
        min-height: 500px;
        perspective: 1200px;
        margin-top: -2em;
    }

    /* Adapter les rotations sur tablette - réduites */
    .plusvalue-image-item[data-index="0"].active {
        transform: translateY(0) rotate(3deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="0"]:not(.active) {
        transform: translateY(-150%) rotate(3deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="1"].active {
        transform: translateY(0) rotate(6deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="1"]:not(.active) {
        transform: translateY(-150%) rotate(6deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="2"].active {
        transform: translateY(0) rotate(-6deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="2"]:not(.active) {
        transform: translateY(-150%) rotate(-6deg) translateZ(0);
    }
}

/* 768px - Mobile large */
@media (max-width: 768px) {
    .plusvalue-section {
        padding: var(--space-lg) 0;
        margin-top: 55px;
        scroll-margin-top: 80px;
    }

    .plusvalue-section::before {
        opacity: 0.2;
        background-size: contain;
    }

    h2.plusvalue-title-h2 {
        margin-top: 20px;
    }

    .plusvalue-wrapper {
        gap: 30px;
        display: flex;
        flex-direction: column-reverse;
    }

    .plusvalue-header {
        grid-template-columns: 10% 90%;
        gap: var(--space-xs);
        margin-bottom: var(--space-sm);
    }

    .plusvalue-icon img {
        width: 35px;
        height: 35px;
    }

    .plusvalue-content-wrapper {
        min-height: 300px;
        margin-left: 40px;
    }

    .plusvalue-image-wrapper {
        min-height: 420px;
        perspective: 1000px;
    }

    /* Adapter les rotations sur mobile - encore plus réduites */
    .plusvalue-image-item[data-index="0"].active {
        transform: translateY(0) rotate(2.5deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="0"]:not(.active) {
        transform: translateY(-150%) rotate(2.5deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="1"].active {
        transform: translateY(0) rotate(5deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="1"]:not(.active) {
        transform: translateY(-150%) rotate(5deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="2"].active {
        transform: translateY(0) rotate(-5.5deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="2"]:not(.active) {
        transform: translateY(-150%) rotate(-5.5deg) translateZ(0);
    }
}

/* 480px - Petit mobile */
@media (max-width: 480px) {
    .plusvalue-section {
        padding: var(--space-md) 0;
        margin-top: 0 !important;
    }

    .plusvalue-section::before {
        opacity: 0.15;
        background-size: contain;
        background-position: center top;
    }

    .plusvalue-header {
        grid-template-columns: 100%;
        margin-bottom: var(--space-sm);
        margin-top: -6em;
    }

    .plusvalue-icon img {
        width: 30px;
        height: 30px;
        position: relative;
        top: 1px;
    }

    .plusvalue-content-item.active {
        padding: 0;
    }

    .plusvalue-content-wrapper {
        min-height: 250px;
        margin: 0;
    }

    .plusvalue-content-item {
        padding: var(--space-sm);
    }

    .plusvalue-image-wrapper {
        min-height: 350px;
        perspective: 800px;
    }

    .plusvalue-item-subtitle {
        font-family: var(--font-primary);
        font-size: var(--p-size);
        font-weight: 900;
        line-height: var(--p-line-height);
        color: var(--white);
        margin-bottom: var(--space-sm);
    }

    /* Rotations minimales sur petit mobile */
    .plusvalue-image-item[data-index="0"].active {
        transform: translateY(0) rotate(6deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="0"]:not(.active) {
        transform: translateY(-150%) rotate(6deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="1"].active {
        transform: translateY(0) rotate(8deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="1"]:not(.active) {
        transform: translateY(-150%) rotate(8deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="2"].active {
        transform: translateY(0) rotate(-10deg) translateZ(0);
    }

    .plusvalue-image-item[data-index="2"]:not(.active) {
        transform: translateY(-150%) rotate(-10deg) translateZ(0);
    }
}

/* ====================================
   🎨 OPTIMISATIONS CRITIQUES
   ==================================== */
.plusvalue-title-h2,
.plusvalue-icon,
.plusvalue-content-item,
.plusvalue-image-item {
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.plusvalue-section {
    contain: layout style;
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

/* Force le hardware acceleration */
.plusvalue-image-wrapper,
.plusvalue-image-item,
.plusvalue-image-container {
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
}

/* ====================================
   🚨 FALLBACKS
   ==================================== */
.plusvalue-section:not(.plusvalue-initialized) .plusvalue-title-h2,
.plusvalue-section:not(.plusvalue-initialized) .plusvalue-icon {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* Si JavaScript ne fonctionne pas : premier item visible */
.plusvalue-section:not(.plusvalue-initialized) .plusvalue-content-item:first-child,
.plusvalue-section:not(.plusvalue-initialized) .plusvalue-image-item:first-child {
    opacity: 1 !important;
    visibility: visible !important;
    position: relative !important;
    transform: translate3d(0, 0, 0) rotateX(0deg) rotateZ(0deg) scale(1) !important;
}

.plusvalue-section:not(.plusvalue-initialized) .plusvalue-content-item:not(:first-child),
.plusvalue-section:not(.plusvalue-initialized) .plusvalue-image-item:not(:first-child) {
    display: none !important;
}

/* ====================================
   🔧 DEBUG
   ==================================== */
.debug-plusvalue {
    border: 2px dashed red !important;
}

.debug-plusvalue .plusvalue-content-item.active {
    background: rgba(255, 0, 0, 0.1) !important;
}

.debug-plusvalue .plusvalue-image-item.active {
    outline: 3px solid yellow !important;
}