/* RESET ET BASES */
html, body, .stage, .ring, .img {
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    user-select: none;
}

html, body, .stage {
    overflow: hidden;
    background: #ffffff;
    margin: 0;
    padding: 0;
}

/* HEADER */
header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 60px;
    padding: 0 20px 0 40px; /* Moins de padding à droite pour coller au bord */
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 1000;
    background: white;
    backdrop-filter: none;
    box-sizing: border-box;
}

.logo {
    font-family: 'Italiana', sans-serif; /* Ou votre nouvelle police Climate Crisis */
    font-size: 35px;
    font-weight: 1000;
    color: black;
    text-decoration: none; /* Supprime le soulignement */
    cursor: pointer;
    letter-spacing: 1px;
}

.logo:hover {
    opacity: 0.7; /* Petit effet visuel au survol pour montrer que c'est cliquable */
}

.nav-right {
    display: flex;
    align-items: center;
    gap: 20px;
    position: relative; /* Annule le absolute global */
}

/* INSTAGRAM */
.instagram {
    color: black;
    font-size: 22px;
    text-decoration: none;
    transition: opacity 0.3s;
    display: flex;
    align-items: center;
}

.instagram:hover {
    opacity: 0.6;
}

/* DROPDOWN MENU */
/* OVERLAY MENU (Remplacer l'ancien Dropdown) */
.dropdown {
    position: relative;
    display: inline-block;
    z-index: 2000;
}

.dropbtn {
    background: none;
    border: none;
    font-size: 28px;
    color: black;
    cursor: pointer;
    z-index: 1200; /* Doit être au-dessus du menu */
    position: relative;
    padding: 5px;
}

.dropdown-content {
    position: fixed;
    top: 0;
    right: 0;
    width: 20%; /* Prend 1/4 de la page */
    height: 100vh;
    background-color: rgba(255, 255, 255, 0.85); /* Semi-opaque */
    backdrop-filter: blur(10px); /* Flou artistique en arrière-plan */
    display: flex;
    flex-direction: column;
    justify-content: flex-start; /* Aligne le contenu vers le haut */
    padding-top: 50px;          /* Ajustez cette valeur pour descendre un peu les titres du haut */
    align-items: center;
    gap: 30px;
    z-index: 1100;
    
    /* Animation de glissement */
    transform: translateX(100%); 
    transition: transform 0.5s ease-in-out;
    box-shadow: -5px 0 15px rgba(0,0,0,0.05);
}

/* Quand on ajoute la classe .show en JS */
.dropdown-content.show {
    transform: translateX(0);
}

.dropdown-content a {
    color: black;
    text-decoration: none;
    /* On utilise la nouvelle police */
    font-family: 'Archivo Black', sans-serif; 
    
    /* On force l'aspect massif et étiré */
    font-size: 20px;          /* Taille imposante comme sur l'image */
    text-transform: uppercase; /* Tout en majuscules */
    line-height: 1.1;         /* Espacement vertical serré */
    letter-spacing: -1px;      /* Lettres légèrement serrées ou 0 pour équilibré */
    
    padding: 15px 40px;
    display: block;
    transition: all 0.3s ease;
    text-align: right;        /* Aligné à droite pour coller au bord du menu */
}

/* Effet au survol (optionnel mais stylé) */
.dropdown-content a:hover {
    opacity: 0.5;
    transform: translateX(-10px); /* Petit décalage vers la gauche */
}

.dropdown-content a:hover {
    letter-spacing: 2px;
    opacity: 0.6;
}

/* Responsive : sur téléphone, le menu prend plus de place */
@media (max-width: 768px) {
    .dropdown-content {
        width: 70%;
    }
}


/* CONTENEUR CARROUSEL */
.container {
    perspective: 2000px;
    width: 300px;  /* Doit être identique à .img */
    height: 400px; /* Doit être identique à .img */
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    position: absolute;
}

/* Trouve la classe .img (ou ajoute-la si elle est fusionnée au début) */
.img {
    /* On fixe la taille moyenne */
    width: 300px; 
    height: 400px;
    
    transform-style: preserve-3d;
    user-select: none;
    
    /* Le secret pour l'uniformité : */
    background-size: cover;    /* Remplit tout le cadre, quitte à couper un peu les bords */
    background-position: center; /* Centre le sujet de la photo */
    background-repeat: no-repeat;
    
    /* On enlève les positions absolues qui pourraient gêner ici */
    position: absolute; 
    top: 0;
    left: 0;
    will-change: transform, opacity;
    backface-visibility: hidden;

    /* Indispensable pour la fluidité 3D */
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    /* Empêche le navigateur de recalculer le lissage des images pendant l'animation */
    image-rendering: -webkit-optimize-contrast; 
    /* Force le rendu sur un calque séparé */
    transform: translateZ(0);
}

.cursor-guide {
    position: absolute;
    top: 55%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 20px;
    /* La main est blanche */
    color: white; 
    z-index: 2000;
    pointer-events: none;
    opacity: 0;
    
    /* Le contour noir épais (style Mac) */
    text-shadow: 
        -2px -2px 0 #000,  
         2px -2px 0 #000,
        -2px  2px 0 #000,
         2px  2px 0 #000,
         0px  3px 5px rgba(0,0,0,0.3); /* Petite ombre portée pour le relief */
}

/* --- AJOUT POUR LA PAGE PHOTOS --- */

/* PAGE PHOTOS : AFFICHAGE PLEINE PAGE */
/* --- RENDU GRILLE PROFESSIONNELLE --- */

.photos-page {
    overflow-y: auto !important;
    background: white;
}

.photos-grid {
    display: grid;
    /* On crée 4 colonnes égales */
    grid-template-columns: repeat(4, 1fr);
    /* 'dense' permet aux petites photos de boucher les trous laissés par les grandes */
    grid-auto-flow: dense; 
    gap: 2px; /* Liseré très fin blanc */
    padding: 70px 2px 2px 2px; /* Marges égales au liseré */
    background: white;
}

.photo-item {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background: #f0f0f0; /* Fond gris très clair en attendant le chargement */
}

/* Photo paysage : elle prend 2 colonnes et 1 ligne */
.photo-item.landscape {
    grid-column: span 2;
}

/* Photo portrait haute : elle peut prendre 2 lignes de haut si tu veux */
.photo-item.portrait-tall {
    grid-row: span 2;
}

.photo-item img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Remplit tout le carré/rectangle sans bandes noires */
    display: block;
    transition: transform 0.5s ease, opacity 0.4s ease;
}

/* L'effet au survol */
.photo-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: rgba(0, 0, 0, 0.5); /* Voile noir léger */
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
    z-index: 2;
}

.photo-item:hover img {
    transform: scale(1.05); /* Petit zoom élégant */
    opacity: 0.8;
}

.photo-item:hover .photo-overlay {
    opacity: 1;
}

.photo-info {
    color: white;
    font-family: 'Archivo Black', sans-serif;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-align: center;
}
/* Pour centrer une photo landscape sur la dernière ligne d'une grille de 4 */
.photo-item.last-centered {
    grid-column: 2 / span 2;
}
/* Style pour l'image dans le menu */
/* Style pour l'image dans le menu - RENDU ROND */
.menu-image {
    width: 200px;
    height: 200px;
    object-fit: cover;
    display: block;
    margin: 30px auto;
    margin-top: 50px;
    opacity: 0.9;
    
    /* Découpe l'image en forme de losange proprement */
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
    
    border: none; /* Le border classique ne marche pas avec clip-path */
}
.photo-item a {
    text-decoration: none; /* Enlève le soulignement si du texte apparaît */
    color: inherit;        /* Garde la couleur définie dans ton CSS */
    display: block;        /* Le lien prend toute la place de la div */
    width: 100%;
    height: 100%;
}
/* Tablette et Desktop */
@media (min-width: 769px) {
    /* 1. On force les 3 derniers projets à se comporter comme un bloc uni */
    .photo-item.centered-row {
        grid-column: span 1 !important; /* On s'assure qu'ils ne prennent qu'une case */
    }

    /* 2. On force le PREMIER des trois (Photo 8) à aller sur une nouvelle ligne 
          et à laisser la première case vide pour centrer */
    .photo-item.centered-row:nth-last-child(3) {
        grid-column-start: 2 !important;
        clear: both; /* Force le passage à la ligne */
    }
}

/* Style pour la page Contact */
/* Centrage total de la page Contact */
.contact-container {
    display: flex;
    flex-direction: column;
    justify-content: center; /* Centre verticalement */
    align-items: center;     /* Centre horizontalement */
    height: 100vh;           /* Prend 100% de la hauteur de la fenêtre */
    text-align: center;
    box-sizing: border-box;
    padding-top: 60px;       /* Pour ne pas être caché par le header fixe */
}

.contact-container h1 {
    font-family: 'Gasoek One', sans-serif; /* Utilise la police de ton logo */
    font-size: 2.5rem;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.contact-container p {
    font-family: 'Archivo Black', sans-serif;
    font-size: 1.2rem;
    margin: 5px 0;
}

.contact-container a {
    text-decoration: none;
    color: black;
}

.contact-insta {
    font-size: 2.5rem;
    margin-top: 20px;
}

/* --- Page À Propos --- */
.propos-section {
    padding-top: 100px; /* Espace pour le header */
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
}

.propos-container {
    display: flex;
    max-width: 1000px; /* Largeur max de la section */
    width: 90%;
    gap: 50px; /* Espace entre la photo et le texte */
    align-items: center; /* Aligne verticalement au milieu */
}

.propos-image {
    flex: 1; /* Prend 50% de l'espace */
}

.propos-image img {
    width: 100%;
    height: auto;
    border-radius: 20px; /* Optionnel : arrondit un peu les angles */
    filter: grayscale(0%); /* Tu peux mettre 100% pour du Noir et Blanc */
}

.propos-text {
    flex: 1; /* Prend 50% de l'espace */
    text-align: left;
}

.propos-text h1 {
    font-family: 'Gasoek One', sans-serif;
    font-size: 3rem;
    margin-bottom: 20px;
}

.propos-text p {
    font-family: 'Archivo Black', sans-serif;
    font-size: 1.1rem;
    line-height: 1.6;
    margin-bottom: 15px;
}

/* Version Mobile : on empile la photo et le texte */
@media (max-width: 768px) {
    .propos-container {
        flex-direction: column;
        text-align: center;
    }
    .propos-text {
        text-align: center;
    }
}

/* --- OPTIMISATION MOBILE (Écrans de moins de 768px) --- */
@media (max-width: 768px) {
    
    /* 1. Header : On réduit un peu la taille du logo */
    header {
        padding: 0 15px;
        height: 50px;
    }

    .logo {
        font-size: 22px;
        letter-spacing: 1px;
    }

    /* 2. Grilles (Photos et Projets) : On passe à 1 ou 2 colonnes au lieu de 4 */
    .photos-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur mobile */
        gap: 10px;
        padding: 60px 10px 20px 10px;
    }

    /* On force les photos "landscape" à prendre toute la largeur sur mobile */
    .photo-item.landscape, 
    .photo-item.last-centered,
    .photo-item.centered-row {
        grid-column: span 2 !important; 
    }

    /* 3. Page À Propos : On empile la photo et le texte */
    .propos-container {
        flex-direction: column; /* Photo au-dessus, texte en dessous */
        gap: 20px;
        padding-top: 20px;
    }

    .propos-text h1 {
        font-size: 2rem;
        text-align: center;
    }

    .propos-text p {
        font-size: 1rem;
        text-align: justify;
    }

    /* 4. Page Contact : On ajuste la taille pour les petits écrans */
    .contact-container h1 {
        font-size: 1.8rem;
    }
    
    .contact-container p {
        font-size: 1rem;
    }

    /* 5. Menu Dropdown : On s'assure qu'il prend bien la place sur mobile */
    /* 5. Menu Dropdown sur mobile */
    .dropdown-content {
        width: 250px;    /* Largeur fixe pour ne pas couvrir tout l'écran */
        right: 0;        /* Aligné à droite */
        left: auto;      /* On annule l'alignement à gauche */
        border-left: 1px solid #eee; /* Petite séparation discrète */
        box-shadow: -5px 0 15px rgba(0,0,0,0.1); /* Ombre à gauche pour donner du relief */
        height: 100vh;   /* Optionnel : si tu veux qu'il descende jusqu'en bas */
    }

    /* On réduit aussi la taille de l'image losange dans le menu sur mobile 
       pour qu'elle ne prenne pas toute la place dans un petit menu */
    .menu-image {
        width: 120px;
        height: 120px;
        margin-top: 30px;
    }
}

/* --- Ajustement spécifique pour les TRÈS petits téléphones --- */
@media (max-width: 480px) {
    .photos-grid {
        grid-template-columns: 1fr; /* 1 seule colonne pour plus de clarté */
    }
    .photo-item.landscape, 
    .photo-item.last-centered,
    .photo-item.centered-row {
        grid-column: span 1 !important;
    }
}