/* Importation de la police Poppins */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500&display=swap');


/* Page d'accueil */
body {
    margin: 0;
    padding: 0;
    font-family: 'Poppins', sans-serif;
    background: url(./img/background1.0.webp) no-repeat center center fixed;
    background-size: cover;
    color: #f0f0f0;
    position: relative;
    overflow-x: hidden;
    cursor: none; /* Cacher le curseur par défaut */
}

.logo {
    position: absolute;
    top: 10px;
    left: 10px;
    margin: 0.5rem;
    cursor: none;
  }
  
  .logo img {
    width: 50px; /* Ajuste la taille du logo */
    height: auto;
    z-index: 1000;
  }
  

.cursor {
    position: fixed;
    width: 10px; /* Taille du point */
    height: 10px; /* Taille du point */
    background-color: rgba(255, 255, 255, 0.8); /* Couleur du point */
    border-radius: 50%; /* Rendre le point circulaire */
    pointer-events: none; /* Ignore les événements de la souris */
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.5); /* Aura lumineuse */
    transition: transform 0.1s ease; /* Transition pour un mouvement fluide */
    z-index: 10000; /* Z-index élevé pour être au-dessus des autres éléments */
}

/* Grossissement du curseur */
.cursor-hover {
    transform: translate(-50%, -50%) scale(2);
    background: rgba(255, 255, 255, 0.8); /* Intensification de la lumière */
}

.hero {
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background: rgba(0, 0, 0, 0.5);
    position: relative;
}

.hero-content {
    text-align: center;
    z-index: 1;
}

.hero-content h1 {
    font-size: 4rem;
    color: #f0f0f0;
    position: relative;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.6);
    animation: flicker 3s ease-in-out forwards;
}

.hero-content a {
    text-decoration: none;
    font-size: 1.5rem;
    color: #f0f0f0;
    position: relative;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.6);
    animation: flicker 3s ease-in-out forwards;
    cursor: none;
}

@keyframes flicker {
    0% {
        text-shadow: 0 0 5px rgba(255, 255, 255, 0.2), 0 0 10px rgba(255, 255, 255, 0.2);
    }
    5% {
        text-shadow: 0 0 20px rgba(255, 255, 255, 1), 0 0 30px rgba(255, 255, 255, 0.8);
    }
    15% {
        text-shadow: 0 0 5px rgba(255, 255, 255, 0.2), 0 0 10px rgba(255, 255, 255, 0.2);
    }
    30% {
        text-shadow: 0 0 40px rgba(255, 255, 255, 1), 0 0 50px rgba(255, 255, 255, 0.9);
    }
    50% {
        text-shadow: 0 0 15px rgba(255, 255, 255, 0.5), 0 0 25px rgba(255, 255, 255, 0.4);
    }
    70% {
        text-shadow: 0 0 5px rgba(255, 255, 255, 0.2), 0 0 10px rgba(255, 255, 255, 0.2);
    }
    100% {
        text-shadow: 0 0 15px rgba(255, 255, 255, 0.6), 0 0 20px rgba(255, 255, 255, 0.5); /* Lumière plus faible à la fin */
    }
}


/* Menu burger plus visuel et agrandi */
.menu {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 9999;
}

.burger {
    width: 60px;
    height: 60px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid #f0f0f0;
    border-radius: 50%;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.5);
    z-index: 100;
    cursor: none;
}

.burger:hover {
    transform: scale(1.2);
    box-shadow: 0 0 25px rgba(255, 255, 255, 0.8);
}

/* Lignes du menu burger */
.line {
    width: 30px;
    height: 5px;
    background-color: white;
    border-radius: 5px;
    position: absolute;
    transition: all 0.4s ease;
    z-index: 99;
}

.line:nth-child(1) {
    top: 16px;
}

.line:nth-child(2) {
    top: 28px;
}

.line:nth-child(3) {
    top: 40px;
}

/* Effet lors de l'activation du menu */
.menu-overlay.active .burger .line:nth-child(1) {
    transform: rotate(45deg);
    top: 28px;
}

.menu-overlay.active .burger .line:nth-child(2) {
    opacity: 0;
}

.menu-overlay.active .burger .line:nth-child(3) {
    transform: rotate(-45deg);
    top: 28px;
}

/* Styles pour la classe open */
.burger.open .line:nth-child(1) {
    transform: rotate(45deg);
    top: 28px;
}

.burger.open .line:nth-child(2) {
    opacity: 0;
}

.burger.open .line:nth-child(3) {
    transform: rotate(-45deg);
    top: 28px;
}

.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding-left: 20px;
    transition: background 0.6s ease;
}

.menu-overlay.active {
    display: flex;
}

.menu-overlay ul {
    list-style: none;
    padding: 0;
}

.menu-overlay ul li {
    margin: 20px 0;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

/* Classe pour gérer la visibilité */
.menu-overlay ul li.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Changement des mots du menu burger */
.menu-overlay ul li a {
    text-decoration: none;
    color: white;
    font-size: 5rem; /* Taille encore plus grande */
    text-transform: uppercase;
    font-weight: bold;
    letter-spacing: 0.2em; /* Espacement des lettres pour un effet plus large */
    margin-left: 40px; /* Ajout d'un margin pour éloigner du bord gauche */
    transition: color 0.3s ease, transform 0.3s ease, font-size 0.3s ease;
    cursor: none;
    font-size: bold;
}

/* Animation au survol */
.menu-overlay ul li a:hover {
    color: white; /* Garde le texte blanc */
    font-size: 5.5rem; /* Grossissement lors du survol */
    transform: translateX(10px); /* Légère translation vers la droite */
    text-shadow: 0 0 20px rgba(255, 255, 255, 1), 0 0 30px rgba(255, 255, 255, 0.8), 0 0 40px rgba(255, 255, 255, 0.6); /* Effet lumineux */
}

/* Animation de brillance lumineuse */
@keyframes glow {
    0% {
        text-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.6), 0 0 30px rgba(255, 255, 255, 0.4);
    }
    100% {
        text-shadow: 0 0 20px rgba(255, 255, 255, 1), 0 0 30px rgba(255, 255, 255, 0.8), 0 0 40px rgba(255, 255, 255, 0.6);
    }
}


/*-----------projet-----------*/

/* Styles pour le titre de la page "Mes Projets" */

/* Personnalisation de la scrollbar pour les navigateurs basés sur WebKit (Chrome, Safari, etc.) */
::-webkit-scrollbar {
    width: 8px; /* Largeur de la scrollbar */
}

::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1); /* Couleur de la piste (fond de la scrollbar) */
    border-radius: 10px; /* Coins arrondis pour la piste */
}

::-webkit-scrollbar-thumb {
    background-color: rgba(255, 255, 255, 0.5); /* Couleur de la barre de défilement */
    border-radius: 10px; /* Coins arrondis pour la barre */
    border: 2px solid rgba(0, 0, 0, 0.3); /* Ajout d'une bordure pour donner un effet de relief */
}

::-webkit-scrollbar-thumb:hover {
    background-color: rgba(255, 255, 255, 0.7); /* Couleur plus claire au survol */
}

/* Scrollbar pour Firefox */
* {
    scrollbar-width: thin; /* Scrollbar plus fine */
    scrollbar-color: rgba(255, 255, 255, 0.5) rgba(0, 0, 0, 0.3); /* Couleurs pour Firefox (thumb et track) */
}

.projects-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 50px; /* Ajout de padding pour ne pas coller le contenu aux bords */
}

.projects-title-page {
    font-size: 4rem;
    color: #f0f0f0; /* Couleur du texte */
    margin-bottom: 20px; /* Espacement en bas du titre */
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.6); /* Éclaircissement lumineux */
    animation: neon 1.5s ease-in-out infinite alternate; /* Animation de clignotement */
}

@keyframes neon {
    0% {
        text-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.6);
        opacity: 1;
    }
    50% {
        text-shadow: 0 0 20px rgba(255, 255, 255, 1), 0 0 30px rgba(255, 255, 255, 0.7);
        opacity: 0.8;
    }
    100% {
        text-shadow: 0 0 30px rgba(255, 255, 255, 1), 0 0 40px rgba(255, 255, 255, 0.5);
        opacity: 1;
    }
}

@keyframes neon {
    0% {
        opacity: 1;
    }
    50% {
        opacity: 0.8;
    }
    100% {
        opacity: 1;
    }
}

.projects-list {
    list-style: none;
    padding: 0;
    width: 100%; /* S'assurer que la liste prend toute la largeur */
}

.projects-list a {
    text-decoration: none;
    cursor: none;
}

.project-card {
    display: flex;
    align-items: center;
    justify-content: space-between; /* Espace entre les éléments */
    background: rgba(255, 255, 255, 0.1); /* Cadre transparent */
    border-radius: 10px; /* Coins arrondis */
    margin: 30px 20px; /* Augmentation de l'espacement entre les projets */
    padding: 20px; /* Espacement interne */
    width: calc(100% - 40px); /* Largeur des cartes (100% de la page moins les marges) */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); /* Ombre portée */
    transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.5s ease; /* Transition pour l'animation */
    opacity: 0; /* Commence invisible */
    transform: scale(0.9); /* Réduit légèrement la taille */
}

.project-card-non-clickable {
    display: flex;
    align-items: center;
    justify-content: space-between; /* Espace entre les éléments */
    background: rgba(255, 255, 255, 0.1); /* Cadre transparent */
    border-radius: 10px; /* Coins arrondis */
    margin: 30px 20px; /* Augmentation de l'espacement entre les projets */
    padding: 20px; /* Espacement interne */
    width: calc(100% - 40px); /* Largeur des cartes (100% de la page moins les marges) */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); /* Ombre portée */
    transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.5s ease; /* Transition pour l'animation */
    opacity: 0; /* Commence invisible */
    transform: scale(0.9); /* Réduit légèrement la taille */
}

.project-card.visible {
    opacity: 1; /* Rend le cadre visible */
    transform: scale(1); /* Rétablit la taille */
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.8), 0 0 30px rgba(255, 255, 255, 0.5); /* Ombre lumineuse */
}

.project-card-non-clickable.visible {
    opacity: 1; /* Rend le cadre visible */
    transform: scale(1); /* Rétablit la taille */
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.8), 0 0 30px rgba(255, 255, 255, 0.5); /* Ombre lumineuse */
}

.project-info {
    flex: 1; /* Permet à l'info de prendre tout l'espace */
    text-align: left; /* Alignement à gauche */
}

.project-title {
    font-size: 2.5rem; /* Taille du titre du projet */
    color: #f0f0f0;
}

.project-style,
.project-date {
    font-size: 1rem; /* Taille pour le style et la date */
    color: #f0f0f0;
}

.project-image {
    width: 200px; /* Largeur de l'image */
    height: auto; /* Garde les proportions de l'image */
    border-radius: 5px; /* Coins arrondis pour l'image */
    margin-left: 20px; /* Espacement entre le texte et l'image */
}

.project-image-small {
    width: 150px; /* Largeur de l'image */
    height: auto; /* Garde les proportions de l'image */
    border-radius: 5px; /* Coins arrondis pour l'image */
    margin-left: 20px; /* Espacement entre le texte et l'image */
}

.project-image-mem {
    width: 250px; /* Largeur de l'image */
    height: auto; /* Garde les proportions de l'image */
    border-radius: 5px; /* Coins arrondis pour l'image */
    margin-left: 20px; /* Espacement entre le texte et l'image */
}

.project-image-mem-pres {
    width: 150px; /* Largeur de l'image */
    height: auto; /* Garde les proportions de l'image */
    border-radius: 5px; /* Coins arrondis pour l'image */
    margin-left: 20px; /* Espacement entre le texte et l'image */
}


/* Styles pour la carte spécifique avec l'image uniquement */
.project-card.project-card-image-only {
    /* Supprimer l'animation */
    animation: none !important;
    opacity: 1 !important; /* La carte est immédiatement visible */
    transform: none !important; /* Pas de transformation */
    box-shadow: none !important; /* Pas d'ombre */
    cursor: default !important; /* Désactiver l'effet de survol de la souris */
}

.project-card.project-card-image-only .project-info {
    display: none; /* Cacher les informations de la carte */
}

.project-card.project-card-image-only .project-image {
    width: 100%; /* L'image prend toute la largeur de la carte */
    height: auto; /* Garde les proportions de l'image */
    border-radius: 10px; /* Coins arrondis pour l'image */
}

/* Le conteneur de projet */
.projects-container {
    max-width: 1000px;
    margin: 30px auto;
  }
  
  /* La zone de texte (au-dessus de l'image) */
  .project-info-spe {
    position: relative;
    top: -30px; /* Décalage pour que le texte soit au-dessus de l'image */
    z-index: 1;
    background-color: white;
    padding: 20px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    margin-bottom: -20px; /* Pour un léger chevauchement */
  }
  
  /* Le texte du projet */
  .project-text h2 {
    font-size: 2em;
    margin-bottom: 15px;
    color: #333;
  }
  
  .project-text p {
    font-size: 1.2em;
    line-height: 1.6;
    color: #666;
    margin-bottom: 15px;
  }
  
.video-projet{
    border-radius:4px ;
    cursor: none;
}

/* Conteneur pour centrer le bouton */
.drive-button {
    display: flex; /* Permet de centrer */
    justify-content: center; /* Centrage horizontal */
    margin-bottom: 20px; /* Espacement par rapport au texte */
    cursor: none;
}

/* Style du bouton */
.styled-button {
    display: inline-block;
    background: rgba(255, 255, 255, 0.1); /* Fond translucide */
    color: #fff; /* Couleur du texte */
    border: 2px solid rgba(255, 255, 255, 0.2); /* Bordure subtile */
    border-radius: 10px; /* Coins arrondis */
    padding: 10px 20px; /* Espacement interne */
    text-decoration: none; /* Suppression du soulignement */
    font-size: 1rem; /* Taille du texte */
    text-align: center; /* Alignement du texte */
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.2); /* Ombre lumineuse */
    transition: all 0.3s ease; /* Transition fluide */
    cursor: none;
}

/* Effets au survol */
.styled-button:hover {
    background: rgba(255, 255, 255, 0.2); /* Fond légèrement plus lumineux */
    border-color: rgba(255, 255, 255, 0.5); /* Bordure accentuée */
    box-shadow: 0 0 25px rgba(255, 255, 255, 0.8), 0 0 40px rgba(255, 255, 255, 0.5); /* Éclairage */
    transform: translateY(-5px); /* Légère élévation */
}

  
/* Zone blanche en dessous des cartes */
.extra-content {
    background-color: #fff;
    padding: 40px 20px; /* Espacement interne */
    margin-top: 40px; /* Espacement au-dessus de la zone */
    margin-bottom: 40px; /* Espacement en bas de la zone */
    max-width: 800px; /* Largeur maximale de la zone */
    margin-left: auto; /* Centrer la zone horizontalement */
    margin-right: auto; /* Centrer la zone horizontalement */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); /* Ombre légère */
    border-radius: 10px; /* Coins arrondis */
}

.extra-content-mem {
    display: flex;
    justify-content: center;
    background-color: #fff;
    padding: 40px 20px; /* Espacement interne */
    margin-top: 40px; /* Espacement au-dessus de la zone */
    margin-bottom: 40px; /* Espacement en bas de la zone */
    max-width: 1100px; /* Largeur maximale de la zone */
    margin-left: auto; /* Centrer la zone horizontalement */
    margin-right: auto; /* Centrer la zone horizontalement */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); /* Ombre légère */
    border-radius: 10px; /* Coins arrondis */
}

.extra-content h3 {
    font-size: 2em;
    color: #333;
    margin-bottom: 20px;
}

.extra-content p {
    font-size: 1.2em;
    line-height: 1.6;
    color: #666;
    margin-bottom: 20px;
}

/*page profil*/

/* Grille Tetris */
.tetris-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 colonnes */
    gap: 20px; /* Espacement entre les cases */
    padding: 20px;
    max-width: 80%; /* Réduit la largeur globale */
    margin: 20px auto; /* Centre la grille horizontalement */
}

/* Cellules Tetris */
.tetris-cell {
    background: rgba(255, 255, 255, 0.1); /* Fond translucide */
    border: 2px solid rgba(255, 255, 255, 0.2); /* Bordure lumineuse subtile */
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.2); /* Ombre lumineuse */
    border-radius: 10px; /* Coins arrondis */
    padding: 20px;
    text-align: center;
    font-size: 1.2rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Animation au survol */
    height: auto; /* Permet de s'adapter au contenu */
}

/* Taille spécifique des blocs */
.tetris-cell.small span {
    grid-column: span 1; /* 1 colonne de large */
    grid-row: span 1; /* 1 rangée de haut */
    min-height: 150px; /* Taille augmentée */
    min-width: 150px; /* Largeur augmentée */
    font-size: small;
}

.tetris-cell.medium {
    grid-column: span 2; /* 2 colonnes de large */
    grid-row: span 1; /* 1 rangée de haut */
    min-height: 150px; /* Inchangé */
}

.tetris-cell.large {
    grid-column: span 2; /* 2 colonnes de large */
    grid-row: span 2; /* 2 rangées de haut */
    min-height: 300px; /* Inchangé */
}

.tetris-cell.tall {
    grid-column: span 1; /* 1 colonne de large */
    grid-row: span 2; /* 2 rangées de haut */
    min-height: 250px; /* Inchangé */
}

/* Bloc photo spécifique */
.tetris-cell.photo-tetris {
    grid-column: span 2; /* Occupe 2 colonnes */
    grid-row: span 2; /* Occupe 2 rangées */
    min-height: 150px; /* Taille minimale réduite */
    max-height: 200px; /* Limite la taille maximale */
    width: 100%; /* Assure une largeur adaptée */
    display: flex; /* Pour centrer le contenu */
    justify-content: center; /* Centre horizontalement */
    align-items: center; /* Centre verticalement */
    overflow: hidden; /* Coupe tout débordement de l'image */
    border: 2px solid rgba(255, 255, 255, 0.2); /* Bordure lumineuse subtile */
    background: rgba(255, 255, 255, 0.1); /* Fond translucide */
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.2); /* Ombre légère */
    border-radius: 10px; /* Coins arrondis */
}

/* Image à l'intérieur du bloc photo */
.tetris-cell.photo-tetris img {
    width: 100%; /* S'adapte à la largeur du bloc */
    height: auto; /* Préserve les proportions */
    max-height: 100%; /* Limite la hauteur pour éviter qu'elle dépasse le bloc */
    object-fit: cover; /* Ajuste l'image sans la déformer */
    border-radius: 10px; /* Coins arrondis pour correspondre au conteneur */
    transition: transform 0.3s ease; /* Animation fluide */
}

/* Effet au survol */
.tetris-cell.photo-tetris:hover img {
    transform: scale(1.1); /* Zoom léger au survol */
}

/* Bloc Hobbies ajusté */
.tetris-cell.hobbies {
    grid-column: 3 / span 1; /* Positionne dans la 3e colonne */
    grid-row: 3 / span 1; /* Positionne dans la 3e rangée */
    min-height: 150px; /* Taille appropriée pour le "trou" */
}

/* Bloc avec image */
.tetris-cell.image-block img {
    width: 100%; /* Image prend toute la largeur */
    height: 100%; /* Image prend toute la hauteur */
    object-fit: cover; /* Ajuste l'image */
    border-radius: 10px; /* Coins arrondis */
}

/* Bloc Logiciels avec grille interne */
.tetris-cell.large .softwares-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 colonnes */
    gap: 10px; /* Espacement horizontal entre les cases */
    row-gap: 40px; /* Espacement vertical entre les lignes */
    margin-top: 70px; /* Espacement entre le titre et les cases */
    justify-items: center; /* Centre les éléments horizontalement */
}

/* Cellules pour les logiciels */
.software-cell {
    background: rgba(255, 255, 255, 0.1); /* Fond translucide */
    border: 2px solid rgba(255, 255, 255, 0.2); /* Bordure lumineuse subtile */
    border-radius: 10px; /* Coins arrondis */
    width: 90px; /* Taille originale */
    height: 90px; /* Taille originale */
    display: flex; /* Pour centrer le contenu */
    align-items: center; /* Centre verticalement */
    justify-content: center; /* Centre horizontalement */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Animation au survol */
}

/* Logos dans les cellules */
.software-cell img {
    max-width: 100%; /* Taille ajustée */
    max-height: 100%; /* Taille ajustée */
    object-fit: contain; /* Préserve les proportions */
}

/* Effet au survol */
.software-cell:hover {
    transform: scale(1.1); /* Agrandissement subtil */
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.8); /* Effet lumineux au survol */
}

/* Effet au survol pour les blocs */
.tetris-cell:hover {
    transform: translateY(-10px); /* Légère élévation */
    box-shadow: 0 0 25px rgba(255, 255, 255, 0.8), 0 0 40px rgba(0, 224, 255, 0.5); /* Lumière plus intense */
}

/* Cellules pour les logiciels */
.xp-cell1 {
    background: rgba(255, 255, 255, 0.1); /* Fond translucide */
    border: 2px solid rgba(255, 255, 255, 0.2); /* Bordure lumineuse subtile */
    border-radius: 10px; /* Coins arrondis */
    width: 250px; /* Taille originale */
    height: 90px; /* Taille originale */
    display: flex; /* Pour centrer le contenu */
    align-items: center; /* Centre verticalement */
    justify-content: left; /* Centre horizontalement */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Animation au survol */
    margin-top: 2rem;
    background-color: #ffffffce;
}

.xp-cell2 {
    background: rgba(255, 255, 255, 0.1); /* Fond translucide */
    border: 2px solid rgba(255, 255, 255, 0.2); /* Bordure lumineuse subtile */
    border-radius: 10px; /* Coins arrondis */
    width: 250px; /* Taille originale */
    height: 90px; /* Taille originale */
    display: flex; /* Pour centrer le contenu */
    align-items: center; /* Centre verticalement */
    justify-content: center; /* Centre horizontalement */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Animation au survol */
    margin-top: 2rem;
}

/* Logos dans les cellules */
.xp-cell1 img {
    max-width: 100%; /* Taille ajustée */
    max-height: 100%; /* Taille ajustée */
    object-fit: contain; /* Préserve les proportions */
    border-radius: 10px;
}

/* Effet au survol */
.xp-cell1:hover {
    transform: scale(1.1); /* Agrandissement subtil */
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.8); /* Effet lumineux au survol */
}

/* Effet au survol pour les blocs */
.xp-cell1:hover {
    transform: translateY(-10px); /* Légère élévation */
    box-shadow: 0 0 25px rgba(255, 255, 255, 0.8), 0 0 40px rgba(0, 224, 255, 0.5); /* Lumière plus intense */
}

/* Bloc Logiciels avec grille interne */
.tetris-cell.medium .Hobbies-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 4 colonnes */
    gap: 10px; /* Espacement horizontal entre les cases */
    row-gap: 40px; /* Espacement vertical entre les lignes */
    margin-top: 20px; /* Espacement entre le titre et les cases */
    justify-items: center; /* Centre les éléments horizontalement */
}

/* Cellules pour les logiciels */
.Hobbies-cell {
    width: 90px; /* Taille originale */
    height: 90px; /* Taille originale */
    display: flex; /* Pour centrer le contenu */
    align-items: center; /* Centre verticalement */
    justify-content: center; /* Centre horizontalement */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Animation au survol */
}

/* Logos dans les cellules */
.Hobbies-cell img {
    max-width: 100%; /* Taille ajustée */
    max-height: 100%; /* Taille ajustée */
    object-fit: contain; /* Préserve les proportions */
}

/* Effet au survol */
.Hobbies-cell:hover {
    transform: scale(1.1); /* Agrandissement subtil */
}

/* Effet au survol pour les blocs */
.Hobbies-cell:hover {
    transform: translateY(-10px); /* Légère élévation */
}

/* Styles généraux pour les appareils mobiles */
@media (max-width: 768px) {

    body{
        background: url(./img/background-responsive.webp) no-repeat center center fixed;
        max-height: 100svh;
    }
    
    /* Projet - Ajustements pour carte avec image uniquement */
    .project-card.project-card-image-only {
        width: 100%; /* La carte prend toute la largeur disponible */
        margin: 0 auto; /* Centrer la carte */
        box-shadow: none !important; /* Pas d'ombre */
    }

    /* Conteneur de projet */
    .projects-container {
        max-width: 100%;
        padding: 10px;
    }

    /* Zone de texte (au-dessus de l'image) */
    .project-info-spe {
        position: relative;
        top: 0;
        z-index: 1;
        background-color: white;
        padding: 15px;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
        border-radius: 10px;
        margin-bottom: 0;
    }

    /* Le texte du projet */
    .project-text h2 {
        font-size: 1.5em; /* Réduction de la taille du titre */
    }

    .project-text p {
        font-size: 1em; /* Réduction de la taille du texte */
    }

    /* Style du bouton */
    .styled-button {
        font-size: 0.9rem; /* Réduire la taille du texte */
        padding: 8px 15px; /* Ajuster l'espace interne */
    }

    /* Zone blanche en dessous des cartes */
    .extra-content {
        padding: 20px;
        margin-top: 20px;
        margin-bottom: 20px;
        max-width: 100%;
        box-shadow: none;
        border-radius: 5px;
    }

    .extra-content h3 {
        font-size: 1.5em; /* Réduction de la taille du titre */
    }

    .extra-content p {
        font-size: 1em; /* Réduction de la taille du texte */
    }

    /* Page profil - Grille Tetris */
    .tetris-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur mobile */
        gap: 10px;
    }

    /* Cellules Tetris */
    .tetris-cell {
        padding: 15px;
        font-size: 1rem;
        min-height: 120px; /* Taille ajustée pour mobile */
    }

    /* Taille des blocs */
    .tetris-cell.small {
        min-height: 100px;
    }

    .tetris-cell.medium {
        min-height: 150px;
    }

    .tetris-cell.large {
        min-height: 250px;
    }

    .tetris-cell.tall {
        min-height: 200px;
    }

    /* Bloc photo spécifique */
    .tetris-cell.photo-tetris {
        min-height: 120px;
        max-height: 180px;
    }

    /* Image à l'intérieur du bloc photo */
    .tetris-cell.photo-tetris img {
        max-height: 100%;
        object-fit: cover;
    }

    /* Bloc Hobbies ajusté */
    .tetris-cell.hobbies {
        grid-column: span 2; /* Occupe toute la largeur sur mobile */
    }

    /* Bloc avec image */
    .tetris-cell.image-block img {
        width: 100%;
        height: auto;
    }

    /* Bloc Logiciels avec grille interne */
    .tetris-cell.large .softwares-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 colonnes sur mobile */
    }

    /* Cellules pour les logiciels */
    .software-cell {
        width: 70px; /* Ajuster la taille */
        height: 70px;
    }

    /* Logos dans les cellules */
    .software-cell img {
        max-width: 80%;
    }

    /* Hobbies Grid */
    .tetris-cell.medium .Hobbies-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 colonnes */
    }

    .Hobbies-cell {
        width: 70px; /* Ajuster la taille */
        height: 70px;
    }

    /* Logos dans les cellules Hobbies */
    .Hobbies-cell img {
        max-width: 80%;
    }

    /* Effet au survol pour tous les blocs */
    .tetris-cell:hover {
        transform: none; /* Désactiver l'effet au survol sur mobile */
        box-shadow: none; /* Désactiver l'ombre sur mobile */
    }

    /* Cellules pour l'expérience professionnelle */
    .xp-cell1, .xp-cell2 {
        width: 100%; /* Prendre toute la largeur disponible */
        height: 90px;
        margin-top: 10px; /* Ajuster l'espacement */
    }

    /* Logos dans les cellules xp */
    .xp-cell1 img, .xp-cell2 img {
        max-width: 80%;
    }

    /* Effet au survol pour les blocs xp */
    .xp-cell1:hover, .xp-cell2:hover {
        transform: none; /* Désactiver l'effet au survol */
        box-shadow: none; /* Désactiver l'ombre */
    }

    /* Ajustement de la largeur des project cards pour mobile */
    .project-card {
        max-width: 95%; /* Réduit la largeur maximale pour occuper toute la largeur de l'écran */
        width: 100%; /* Assure que la carte prend toute la largeur disponible */
        margin: 15px 0; /* Espacement vertical entre les cartes */
        padding: 10px; /* Réduction du padding pour optimiser l'espace */
    }

    /* Suppression du logo sur mobile */
    .project-card .project-logo {
        display: none; /* Cache le logo sur les petits écrans */
    }

    /* Masquer le logo globalement sur mobile */
    .logo {
        display: none;
    }

    /* Réduction de la taille des titres de projet */
    .projects-title-page {
        font-size: 1.5em; /* Taille réduite pour les petits écrans */
        margin-bottom: 10px;
    }

    /* Réduction de la taille des images des projets */
    .project-image {
        width: 20%; /* Image prend toute la largeur de la carte */
        height: auto; /* Laisser l'image s'ajuster */
        max-height: 200px; /* Limiter la hauteur */
        object-fit: cover; /* Maintenir le ratio d'aspect de l'image */
    }

    /* Réduction de la taille des titres des projets */
    .project-title {
        font-size: 1em; /* Taille réduite du titre */
        margin-bottom: 5px;
    }

    /* Réduction de la taille des dates */
    .project-date {
        font-size: 0.9em; /* Taille réduite de la date */
        color: #666; /* Couleur plus claire pour la date */
    }

    /* Menu burger adapté pour téléphone */
.menu {
    position: fixed;
    top: 15px;
    right: 15px;
    z-index: 9999;
}

.burger {
    width: 50px;
    height: 50px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 2px solid #f0f0f0;
    border-radius: 50%;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.5);
    z-index: 100;
    cursor: pointer;
}

.burger:hover {
    transform: scale(1.1);
    box-shadow: 0 0 25px rgba(255, 255, 255, 0.8);
}

/* Lignes du menu burger */
.line {
    width: 30px;
    height: 5px;
    background-color: white;
    border-radius: 5px;
    position: absolute;
    transition: all 0.4s ease;
    z-index: 99;
}

.line:nth-child(1) {
    top: 15px;
}

.line:nth-child(2) {
    top: 23px;
}

.line:nth-child(3) {
    top: 31px;
}

/* Effet lors de l'activation du menu */
.menu-overlay.active .burger .line:nth-child(1) {
    transform: rotate(45deg);
    top: 23px;
}

.menu-overlay.active .burger .line:nth-child(2) {
    opacity: 0;
}

.menu-overlay.active .burger .line:nth-child(3) {
    transform: rotate(-45deg);
    top: 23px;
}

/* Menu overlay */
.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    display: none;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding-left: 20px;
    transition: background 0.6s ease;
}

.menu-overlay.active {
    display: flex;
}

.menu-overlay ul {
    list-style: none;
    padding: 0;
}

.menu-overlay ul li {
    margin: 20px 0;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

/* Classe pour gérer la visibilité des éléments */
.menu-overlay ul li.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Changement des mots du menu burger */
.menu-overlay ul li a {
    text-decoration: none;
    color: white;
    font-size: 2.5rem; /* Taille réduite */
    text-transform: uppercase;
    font-weight: bold;
    letter-spacing: 0.1em; /* Espacement des lettres ajusté */
    margin-left: 40px;
    transition: color 0.3s ease, transform 0.3s ease, font-size 0.3s ease;
}


/* Animation de brillance lumineuse */
@keyframes glow {
    0% {
        text-shadow: 0 0 10px rgba(255, 255, 255, 0.8), 0 0 20px rgba(255, 255, 255, 0.6), 0 0 30px rgba(255, 255, 255, 0.4);
    }
    100% {
        text-shadow: 0 0 20px rgba(255, 255, 255, 1), 0 0 30px rgba(255, 255, 255, 0.8), 0 0 40px rgba(255, 255, 255, 0.6);
    }
}

.projects-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px; /* Réduction du padding pour mobile */
}

.projects-title-page {
    font-size: 2.5rem; /* Taille réduite pour les petits écrans */
    color: #f0f0f0;
    margin-bottom: 10px;
    text-shadow: 0 0 5px rgba(255, 255, 255, 0.8), 0 0 10px rgba(255, 255, 255, 0.6);
    animation: neon 1.5s ease-in-out infinite alternate;
}

@keyframes neon {
    0% {
        text-shadow: 0 0 5px rgba(255, 255, 255, 0.8), 0 0 10px rgba(255, 255, 255, 0.6);
        opacity: 1;
    }
    50% {
        text-shadow: 0 0 10px rgba(255, 255, 255, 1), 0 0 20px rgba(255, 255, 255, 0.7);
        opacity: 0.8;
    }
    100% {
        text-shadow: 0 0 15px rgba(255, 255, 255, 1), 0 0 30px rgba(255, 255, 255, 0.5);
        opacity: 1;
    }
}

.projects-list {
    list-style: none;
    padding: 0;
    width: 100%;
}

.projects-list a {
    text-decoration: none;
    cursor: none;
}

.project-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    margin: 20px 10px; /* Espacement réduit pour mobile */
    padding: 10px; /* Moins de padding */
    width: calc(100% - 20px); /* Ajustement de la largeur */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2); /* Ombre plus légère */
    transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.5s ease;
    opacity: 0;
    transform: scale(0.9);
}

.project-card-non-clickable {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    margin: 20px 10px;
    padding: 10px;
    width: calc(100% - 20px);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.5s ease;
    opacity: 0;
    transform: scale(0.9);
}

.project-card.visible {
    opacity: 1;
    transform: scale(1);
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
}

.project-card-non-clickable.visible {
    opacity: 1;
    transform: scale(1);
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
}

.project-info {
    flex: 1;
    text-align: left;
}

.project-title {
    font-size: 1.5rem; /* Réduction de la taille du titre */
    color: #f0f0f0;
}

.project-style,
.project-date {
    font-size: 0.8rem; /* Réduction de la taille des textes secondaires */
    color: #f0f0f0;
}

.prj {
    display: none; /* Suppression des images sur mobile */
}

.project-info-spe {
    position: relative;
    top: -20px; /* Ajustement du texte au-dessus de l'image */
    z-index: 1;
    background-color: white;
    padding: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    margin-bottom: -10px;
}

.project-text h2 {
    font-size: 1.5rem;
    margin-bottom: 10px;
    color: #333;
}

.project-text p {
    font-size: 1rem;
    line-height: 1.5;
    color: #666;
    margin-bottom: 10px;
}

.drive-button {
    display: flex;
    justify-content: center;
    margin-bottom: 10px;
}

.styled-button {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    padding: 8px 16px;
    text-decoration: none;
    font-size: 0.9rem;
    text-align: center;
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
}

.styled-button:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.5);
    box-shadow: 0 0 20px rgba(255, 255, 255, 0.8);
    transform: translateY(-3px);
}

.extra-content {
    background-color: #fff;
    width: 300px;
    padding: 20px 10px; /* Ajustement du padding */
    margin-top: 30px;
    margin-bottom: 30px;
    max-width: 90%;
    margin-left: auto;
    margin-right: auto;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
}

.extra-content-mem {
    display: flex; /* Active Flexbox */
    flex-direction: column; /* Aligne les images verticalement */
    gap: 15px; /* Espace entre les images */
    margin-left: 10px;
    margin-right: 10px;
}

.project-image-mem {
    width: 90%; /* Images prennent toute la largeur */
    height: auto; /* Conserve les proportions */
}

.video-projet{
    width: 100%;
}

.extra-content h3 {
    font-size: 1.5rem;
    color: #333;
    margin-bottom: 15px;
}

.extra-content p {
    font-size: 1rem;
    line-height: 1.5;
    color: #666;
    margin-bottom: 15px;
}

@media screen and (max-width: 600px) {
    .projects-title-page {
        font-size: 2rem; /* Ajuste encore la taille du titre */
    }
    .project-title {
        font-size: 1.2rem; /* Réduit la taille des titres de projet */
    }
    .project-style,
    .project-date {
        font-size: 0.8rem; /* Petite taille pour les infos supplémentaires */
    }
    .styled-button {
        font-size: 0.8rem; /* Taille du bouton réduite */
    }
}


}
