/**
 * VIA OPERA - Home Page Styles (Version Magazine)
 * Layout éditorial inspiré des magazines de mode/culture
 */

/* ============================================
   HERO SECTION - VERSION MAGAZINE
   ============================================ */

   .home-hero {
    position: relative;
    width: 100%;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: flex-start; /* Changé : alignement à gauche du container */
    overflow: hidden;
}

.home-hero__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 35% center; /* Décale légèrement le visage vers la gauche */
    filter: grayscale(100%);
    z-index: 1;
}

.home-hero__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        /* Gradient asymétrique : plus sombre à droite */
        linear-gradient(
            to right,
            rgba(0, 0, 0, 0.1) 0%,
            rgba(0, 0, 0, 0.3) 50%,
            rgba(0, 0, 0, 0.6) 100%
        ),
        /* Vignettage subtil */
        radial-gradient(
            ellipse at 70% 50%,
            transparent 0%,
            transparent 30%,
            rgba(0, 0, 0, 0.3) 70%,
            rgba(0, 0, 0, 0.5) 100%
        );
    z-index: 2;
}

.home-hero__content {
    position: relative;
    z-index: 3;
    text-align: left; /* KEY: Alignement à gauche du texte */
    padding: var(--spacing-xl) var(--spacing-md);
    max-width: 600px; /* Bloc de texte plus étroit */
    width: auto;
    
    /* Positionnement magazine : bloc à droite, texte aligné à gauche */
    margin-left: auto;
    margin-right: 5%;
    
    /* Espacement du haut pour mobile */
    padding-top: calc(80px + var(--spacing-xl)); /* Header height + spacing */
}

.home-hero__title {
    font-family: var(--font-heading-primary);
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--color-white);
    margin-bottom: var(--spacing-xs);
    line-height: 0.95;
    text-shadow: 
        0 0 40px rgba(0, 0, 0, 0.9),
        0 4px 20px rgba(0, 0, 0, 0.8),
        3px 3px 12px rgba(0, 0, 0, 0.7);
    letter-spacing: -0.01em; /* Légèrement serré, style éditorial */
    text-transform: uppercase;
}

/* Prénom et nom empilés verticalement */
.home-hero__title .first-name {
    display: block;
    font-size: 0.7em; /* Prénom plus petit */
    font-weight: 300;
    letter-spacing: 0.15em;
    margin-bottom: 0.1em;
    opacity: 0.9;
}

.home-hero__title .last-name {
    display: block;
    font-size: 0.9em; /* Nom de famille dominant */
    font-weight: 700;
    letter-spacing: 0.05em;
}

.home-hero__subtitle {
    font-family: var(--font-body-secondary);
    font-size: 1rem;
    font-weight: 300;
    color: var(--color-white);
    line-height: 1.8;
    text-shadow: 
        0 0 25px rgba(0, 0, 0, 0.9),
        0 2px 10px rgba(0, 0, 0, 0.7);
    position: relative;
    padding-top: var(--spacing-md);
    margin-bottom: 0;
    letter-spacing: 0.08em;
    text-transform: lowercase; /* Style magazine : tout en minuscules */
    font-style: italic;
}

/* Ligne dorée AVANT le sous-titre (style magazine) */
.home-hero__subtitle::before {
    content: '';
    display: block;
    width: 40px;
    height: 1px;
    background: var(--color-gold);
    margin-bottom: var(--spacing-sm);
    box-shadow: 
        0 1px 4px rgba(212, 175, 55, 0.6),
        0 0 12px rgba(212, 175, 55, 0.3);
}

/* Décoration optionnelle : petite lettrine dorée */
.home-hero__title::first-letter {
    color: var(--color-gold);
    text-shadow: 
        0 0 20px rgba(212, 175, 55, 0.8),
        0 2px 8px rgba(0, 0, 0, 0.8);
}

/* ============================================
   TABLETTE (≥ 768px)
   ============================================ */

@media (min-width: 768px) {
    .home-hero {
        min-height: 90vh;
    }

    .home-hero__content {
        padding: var(--spacing-xxl) var(--spacing-xl);
        margin-right: 8%;
        max-width: 500px;
        padding-top: 0;
    }

    .home-hero__title {
        font-size: 4rem;
        margin-bottom: var(--spacing-sm);
    }

    .home-hero__title .first-name {
        font-size: 0.5em;
        letter-spacing: 0.2em;
    }

    .home-hero__subtitle {
        font-size: 1.1rem;
        padding-top: var(--spacing-lg);
    }

    .home-hero__subtitle::before {
        width: 60px;
        height: 2px;
    }
}

/* ============================================
   DESKTOP (≥ 1050px)
   ============================================ */

@media (min-width: 1050px) {
    .home-hero {
        min-height: 100vh;
    }

    .home-hero__content {
        margin-right: 10%;
        max-width: 550px;
        padding: var(--spacing-xxxl) var(--spacing-xxl);
    }

    .home-hero__title {
        font-size: 5.5rem;
        line-height: 0.9;
    }

    .home-hero__title .first-name {
        font-size: 0.45em;
        letter-spacing: 0.25em;
    }

    .home-hero__subtitle {
        font-size: 1.2rem;
        letter-spacing: 0.1em;
        padding-top: var(--spacing-xl);
    }

    .home-hero__subtitle::before {
        width: 80px;
    }
}

/* ============================================
   TRÈS GRAND ÉCRAN (≥ 1400px)
   ============================================ */

@media (min-width: 1400px) {
    .home-hero__content {
        margin-right: 12%;
        max-width: 600px;
    }

    .home-hero__title {
        font-size: 6.5rem;
    }

    .home-hero__subtitle {
        font-size: 1.3rem;
    }
}

/* ============================================
   ANIMATIONS VERSION MAGAZINE
   ============================================ */

/* Slide in depuis la droite */
@keyframes slideInMagazine {
    from {
        opacity: 0;
        transform: translateX(60px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

.home-hero__content {
    animation: slideInMagazine 1s ease-out;
}

/* Prénom apparaît en premier */
.home-hero__title .first-name {
    animation: slideInMagazine 0.8s ease-out 0.2s both;
}

/* Nom apparaît ensuite */
.home-hero__title .last-name {
    animation: slideInMagazine 0.8s ease-out 0.4s both;
}

/* Sous-titre en dernier */
.home-hero__subtitle {
    animation: slideInMagazine 0.8s ease-out 0.6s both;
}

/* Ligne dorée se dessine */
@keyframes lineDrawMagazine {
    from {
        width: 0;
        opacity: 0;
    }
    to {
        width: 60px;
        opacity: 1;
    }
}

.home-hero__subtitle::before {
    animation: lineDrawMagazine 0.6s ease-out 0.8s both;
}

@media (min-width: 1050px) {
    @keyframes lineDrawMagazine {
        from {
            width: 0;
            opacity: 0;
        }
        to {
            width: 80px;
            opacity: 1;
        }
    }
}

/* ============================================
   SECTION BIOGRAPHIE HOME
   ============================================ */

.home-biography {
    background-color: var(--color-white);
    padding: var(--spacing-xxl) var(--spacing-md);
}

.home-biography__title {
    font-family: var(--font-heading-primary);
    font-size: 2rem;
    font-weight: 600;
    color: var(--color-black);
    text-align: center;
    margin-bottom: var(--spacing-xl);
    letter-spacing: 0.02em;
}

.home-biography__title::after {
    content: '';
    display: block;
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, var(--color-gold), var(--color-gold-light));
    margin: var(--spacing-sm) auto;
}

.home-biography__content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    max-width: 1200px;
    margin: 0 auto;
}

.home-biography__image-wrapper {
    width: 100%;
    order: 1;
}

.home-biography__image {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 4px;
    filter: grayscale(20%);
    transition: filter var(--transition-normal);
}

.home-biography__image:hover {
    filter: grayscale(0%);
}

.home-biography__text {
    order: 2;
    text-align: center; /* Centrer le contenu en mobile */
}

.home-biography__summary {
    font-family: var(--font-body-primary);
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--color-black);
    margin-bottom: var(--spacing-md);
    text-align: justify;
}

.home-biography__link {
    display: inline-block;
    font-family: var(--font-body-secondary);
    font-size: 1rem;
    color: var(--color-white);
    background-color: var(--color-black);
    text-decoration: none;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 2px solid var(--color-black);
    transition: all var(--transition-fast);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin: 0 auto; /* Centré en mobile */
}

.home-biography__link:hover {
    background-color: var(--color-white);
    color: var(--color-gold);
    border-color: var(--color-gold);
}

/* ============================================
   TABLETTE (≥ 768px)
   ============================================ */

@media (min-width: 768px) {
    .home-biography {
        padding: var(--spacing-xxxl) var(--spacing-lg);
    }

    .home-biography__title {
        font-size: 2.5rem;
        margin-bottom: var(--spacing-xxl);
    }

    .home-biography__content {
        flex-direction: row;
        align-items: center;
        gap: var(--spacing-xl);
    }

    .home-biography__image-wrapper {
        flex: 0 0 40%;
        order: 1;
    }

    .home-biography__text {
        flex: 1;
        order: 2;
        text-align: left; /* Alignement à gauche en desktop */
    }
    
    .home-biography__link {
        margin: 0; /* Retirer le centrage en desktop */
    }

    .home-biography__summary {
        font-size: 1.15rem;
    }
}

/* ============================================
   DESKTOP (≥ 1050px)
   ============================================ */

@media (min-width: 1050px) {
    .home-biography {
        padding: var(--spacing-xxxl) var(--spacing-xxl);
    }

    .home-biography__title {
        font-size: 3rem;
    }

    .home-biography__content {
        gap: var(--spacing-xxl);
    }

    .home-biography__image-wrapper {
        flex: 0 0 45%;
    }

    .home-biography__summary {
        font-size: 1.2rem;
        margin-bottom: var(--spacing-lg);
    }

    .home-biography__link {
        font-size: 1.1rem;
        padding: var(--spacing-sm) var(--spacing-lg);
    }
}

/* ============================================
   SECTION ÉVÉNEMENTS / RÉPERTOIRE
   ============================================ */

.home-events-repertoire {
    background-color: var(--color-black);
    color: var(--color-white);
    padding: var(--spacing-xs);
}

.home-events-repertoire__title {
    font-family: var(--font-heading-primary);
    font-size: 2rem;
    font-weight: 600;
    color: var(--color-white);
    text-align: center;
    margin-bottom: var(--spacing-xl);
    letter-spacing: 0.02em;
}

.home-events-repertoire__title::after {
    content: '';
    display: block;
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, var(--color-gold), var(--color-gold-light));
    margin: var(--spacing-sm) auto;
}

/* Card Événement */
.event-card {
    background-color: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--color-gold);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-md);

}

.event-card__image-wrapper {
    align-items: center;
    width: 100%;
    order: 1;
}

.event-card__image {
    width: 90%;
    margin-left: 5%;
}

.event-card__content {
    order: 2;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    justify-content: center;
    align-items: center;
}

.event-card__work {
    font-family: var(--font-heading-primary);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--color-white);
    margin: 0 0 var(--spacing-sm) 0;
    order: 1;
}

.event-card__info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-sm);
    order: 2;
}

.event-card__detail {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.event-card__label {
    font-family: var(--font-body-secondary);
    font-size: 0.85rem;
    color: var(--color-gold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.event-card__value {
    font-family: var(--font-body-primary);
    font-size: 1rem;
    color: var(--color-white);
}

.event-card__description {
    font-family: var(--font-body-primary);
    font-size: 1rem;
    line-height: 1.7;
    color: var(--color-white);
    margin-top: var(--spacing-sm);
}

.event-card__link {
    display: inline-block;
    font-family: var(--font-body-secondary);
    font-size: 1rem;
    color: var(--color-black);
    background-color: var(--color-gold);
    text-decoration: none;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 2px solid var(--color-gold);
    transition: all var(--transition-fast);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
    margin-top: var(--spacing-md);
    align-self: flex-start;
}

.event-card__link:hover {
    background-color: transparent;
    color: var(--color-gold);
    border-color: var(--color-gold);
}

/* Container pour les rôles */
.roles-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    width: 100%;
}

/* Card Rôle */
.role-card {
    background-color: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--color-gold);
    padding: var(--spacing-lg) var(--spacing-sm);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-xs);
    transition: all var(--transition-fast);
    height: 280px; /* Hauteur fixe */
    justify-content: center; /* Centrer verticalement le contenu */
}

.role-card:hover {
    background-color: rgba(255, 255, 255, 0.08);
    border-color: var(--color-gold);
    transform: translateY(-2px);
}

.role-card__work {
    font-family: var(--font-heading-primary);
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--color-white);
    margin: 0;
}

.role-card__composer {
    font-family: var(--font-body-primary);
    font-size: 1rem;
    color: var(--color-gold);
    margin: 0;
}

.role-card__role {
    font-family: var(--font-body-primary);
    font-size: 0.95rem;
    color: var(--color-white);
    margin: var(--spacing-xs) 0 0 0;
    font-style: italic;
}

.role-card__period {
    font-family: var(--font-body-secondary);
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    margin: var(--spacing-xs) 0 0 0;
}

/* Bouton Voir plus */
.events-repertoire__actions {
    display: flex;
    justify-content: center;
    align-items: center;
}

.events-repertoire__link {
    display: inline-block;
    font-family: var(--font-body-secondary);
    font-size: 1rem;
    color: var(--color-white);
    background-color: transparent;
    text-decoration: none;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 2px solid var(--color-gold);
    transition: all var(--transition-fast);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
}

.events-repertoire__link:hover {
    background-color: var(--color-gold);
    color: var(--color-black);
    border-color: var(--color-gold);
}

/* ============================================
   TABLETTE (≥ 768px)
   ============================================ */

@media (min-width: 768px) {
    .home-events-repertoire {
        padding: var(--spacing-xxxl) var(--spacing-lg);
    }

    .roles-container {
        flex-direction: row;
        gap: var(--spacing-xl);
        flex-wrap: wrap;
    }

    .role-card {
        flex: 1 1 calc(50% - var(--spacing-xl) / 2); /* 2 colonnes avec gap */
        max-width: calc(50% - var(--spacing-xl) / 2);
    }

    .event-card {
        flex-direction: row;
    }

    .event-card__image-wrapper {
        flex: 0 0 40%;
        order: 1;
    }

    .event-card__image {
        width: 100%;
        min-height: 400px;
    }

    .event-card__content {
        flex: 1;
        order: 2;
    }

    .event-card__work {
        font-size: 1.8rem;
    }

    .role-card {
        height: 320px; /* Hauteur fixe en tablette */
    }

    .role-card__work {
        font-size: 1.5rem;
    }
}

/* ============================================
   DESKTOP (≥ 1050px)
   ============================================ */

@media (min-width: 1050px) {
    .home-events-repertoire {
        padding: var(--spacing-xxxl) var(--spacing-xxl);
    }

    .roles-container {
        flex-direction: row;
        gap: var(--spacing-xxl);
        flex-wrap: wrap;
    }

    .role-card {
        flex: 1 1 calc(33.333% - var(--spacing-xxl) * 2 / 3); /* 3 colonnes avec gap */
        max-width: calc(33.333% - var(--spacing-xxl) * 2 / 3);
    }

    .event-card__work {
        font-size: 2rem;
    }

    .event-card__content {
        padding: var(--spacing-xxl);
    }

    .role-card {
        height: 350px; /* Hauteur fixe en desktop */
    }

    .role-card__work {
        font-size: 1.6rem;
    }
}

/* ============================================
   DESKTOP LARGE (≥ 1400px)
   ============================================ */

@media (min-width: 1400px) {
    .roles-container {
        gap: var(--spacing-xxxl);
    }

           .role-card {
               flex: 1 1 calc(33.333% - var(--spacing-xxxl) * 2 / 3); /* 3 colonnes avec gap */
               max-width: calc(33.333% - var(--spacing-xxxl) * 2 / 3);
           }
       }

       /* ============================================
          SECTION GALERIE HOME
          ============================================ */

       .home-gallery {
           background-color: var(--color-white);
           padding: var(--spacing-xxl) var(--spacing-md);
       }

       .home-gallery__title {
           font-family: var(--font-heading-primary);
           font-size: 2rem;
           font-weight: 600;
           color: var(--color-black);
           text-align: center;
           margin-bottom: var(--spacing-xl);
           letter-spacing: 0.02em;
       }

       .home-gallery__title::after {
           content: '';
           display: block;
           width: 60px;
           height: 2px;
           background: linear-gradient(90deg, var(--color-gold), var(--color-gold-light));
           margin: var(--spacing-sm) auto;
       }

       .home-gallery__grid {
           display: grid;
           grid-template-columns: repeat(2, 1fr);
           gap: var(--spacing-md);
           margin-bottom: var(--spacing-xl);
           max-width: 1200px;
           margin-left: auto;
           margin-right: auto;
       }

       /* Cacher la troisième image en mobile */
       .home-gallery__item:nth-child(3) {
           display: none;
       }

       .home-gallery__item {
           position: relative;
           width: 100%;
           overflow: hidden;
           border-radius: 4px;
       }

       .home-gallery__image {
           width: 100%;
           height: auto;
           object-fit: cover;
           filter: grayscale(20%);
           transition: all var(--transition-normal);
       }

       .home-gallery__item:hover .home-gallery__image {
           filter: grayscale(0%);
           transform: scale(1.05);
       }

       .home-gallery__actions {
           display: flex;
           justify-content: center;
           align-items: center;
           margin-top: var(--spacing-xl);
       }

       .home-gallery__link {
           display: inline-block;
           font-family: var(--font-body-secondary);
           font-size: 1rem;
           color: var(--color-white);
           background-color: var(--color-black);
           text-decoration: none;
           padding: var(--spacing-sm) var(--spacing-md);
           border: 2px solid var(--color-black);
           transition: all var(--transition-fast);
           letter-spacing: 0.05em;
           text-transform: uppercase;
           margin: 0 auto; /* Centré en mobile */
       }

       .home-gallery__link:hover {
           background-color: var(--color-white);
           color: var(--color-gold);
           border-color: var(--color-gold);
       }

       /* ============================================
          TABLETTE (≥ 768px)
          ============================================ */

       @media (min-width: 768px) {
           .home-gallery {
               padding: var(--spacing-xxxl) var(--spacing-lg);
           }

           .home-gallery__title {
               font-size: 2.5rem;
               margin-bottom: var(--spacing-xxl);
           }

           .home-gallery__grid {
               grid-template-columns: repeat(2, 1fr);
               gap: var(--spacing-lg);
           }

           /* Afficher la troisième image à partir de la tablette */
           .home-gallery__item:nth-child(3) {
               display: block;
           }

           .home-gallery__link {
               margin: 0; /* Retirer le centrage en desktop */
           }
       }

       /* ============================================
          DESKTOP (≥ 1050px)
          ============================================ */

       @media (min-width: 1050px) {
           .home-gallery {
               padding: var(--spacing-xxxl) var(--spacing-xxl);
           }

           .home-gallery__title {
               font-size: 3rem;
           }

           .home-gallery__grid {
               grid-template-columns: repeat(3, 1fr);
               gap: var(--spacing-xl);
           }

           .home-gallery__link {
               font-size: 1.1rem;
               padding: var(--spacing-sm) var(--spacing-lg);
           }
       }