/* Améliorations pour une galerie moderne et responsive */


/* Définition de variables pour faciliter la maintenance */

:root {
    --card-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    --card-shadow-hover: 0 8px 16px rgba(0, 0, 0, 0.2);
    --card-border-radius: 8px;
    --card-margin: 1rem;
    --card-padding: 1rem;
}

.gallery {
    /* Utilise une grille pour un contrôle précis de l'espacement et des colonnes */
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--card-margin);
    /* Espacement uniforme entre les cartes */
    padding: var(--card-padding);
}

.gallery-item {
    background-color: #fff;
    border-radius: var(--card-border-radius);
    overflow: hidden;
    /* S'assure que les coins de l'image sont arrondis */
    box-shadow: var(--card-shadow);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: pointer;
}

.gallery-item:hover {
    box-shadow: var(--card-shadow-hover);
    transform: translateY(-5px);
    /* Effet de soulèvement au survol */
}

.gallery-item img {
    /* Ajout d'une hauteur fixe pour un affichage uniforme des images */
    width: 100%;
    height: 200px;
    /* Hauteur fixe pour toutes les images */
    object-fit: cover;
    /* Recadre l'image pour qu'elle remplisse la zone sans distorsion */
    display: block;
}

.gallery-item .description {
    padding: var(--card-padding);
    text-align: center;
    color: #555;
    font-size: 1rem;
    line-height: 1.4;
}
