/* Stili Generali */
body {
    font-family: Arial, sans-serif;
    background-color: #f0f0f0; 
    display: flex;
    justify-content: center;
    padding: 10px;
    margin: 0;
}

/* Contenitore della Galleria */
.gallery-container {
    width: 95%; 
    max-width: 800px; 
    margin: 0 auto;
}

/* 🔑 Contenitore dell'Immagine (Riquadro fisso con Aspect Ratio) */
.image-slide {
    position: relative;
    height: 0;
    padding-top: 66.66%; /* Esempio di Aspect Ratio 3:2 */
    margin-bottom: 0; /* Rimosso il margine per attaccare la didascalia */
    background-color: black; 
    overflow: hidden; 
}

/* Stile dell'Immagine (come precedentemente modificato per 'contain') */
.image-slide img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain; /* Assicura che l'intera immagine sia visibile */
    opacity: 0.9;
}

/* 🔑 MODIFICA CHIAVE: Didascalia (Ora esterna e sotto l'immagine) */
.caption {
    /* Non più 'position: absolute'. Si comporta come un normale blocco di testo. */
    width: 100%; 
    /* Altezza fissa o minima per mantenere l'uniformità */
    min-height: 50px; 
    background-color: black; /* Sfondo scuro per il riquadro */
    color: white;
    padding: 15px 10px;
    font-size: 1.1em;
    font-weight: 500;
    display: flex; 
    align-items: center;
    box-sizing: border-box; /* Include padding e border nella larghezza totale */
    margin-bottom: 20px; /* Spazio sotto la didascalia e prima della condivisione */
}

/* Indicatore "1/4" (Posizione non modificata, rimane sopra l'immagine) */
.counter {
    position: absolute;
    top: 10px;
    left: 10px;
    color: white;
    background-color: rgba(0, 0, 0, 0.5);
    padding: 5px 10px;
    font-size: 0.9em;
    z-index: 10;
}

/* Pulsanti di Navigazione (Non modificati) */
.prev-btn, .next-btn {
    position: absolute;
    top: calc(50% - 25px); /* Regolato leggermente per tenere conto della didascalia ora esterna */
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px 15px;
    cursor: pointer;
    font-size: 24px;
    z-index: 10;
    opacity: 0; 
    transition: opacity 0.2s;
}

.image-slide:hover .prev-btn, .image-slide:hover .next-btn {
    opacity: 1;
}

.prev-btn { left: 0; }
.next-btn { right: 0; }

/* Sezione di Condivisione (Non modificata) */
.social-share {
    display: flex;
    align-items: center;
    padding: 10px 0;
    font-size: 0.9em;
    color: #555;
}

/* Media Queries (Non modificate) */
@media (max-width: 600px) {
    /* ... stili per schermi piccoli ... */
    .caption {
        min-height: 40px;
        padding: 10px;
        font-size: 0.9em;
        line-height: 1.3;
    }
    
    .prev-btn, .next-btn {
        padding: 5px 10px;
        font-size: 18px;
        opacity: 1;
        background-color: rgba(0, 0, 0, 0.3);
    }

    .counter {
        font-size: 0.8em;
    }
    
    .social-share {
        font-size: 0.8em;
    }
}
