/* Stili generali */

body {

    font-family: 'Arial', sans-serif;

    line-height: 1.6;

    color: #333;

    background-color: #f8f9fa;

}



/* Header 04/07*/

header {

    background-color: #007bff !important; /* Colore blu di Bootstrap */

    padding: 60px 0;

    margin-bottom: 30px;

}



header h1 {

    font-size: 3.5rem;

    font-weight: bold;

    color: #ffffff;

}



header p.lead {

    font-size: 1.5rem;

    color: #e2e6ea;

}

.navbar_mt{
    background-color: #007bff !important; /* Colore blu di Bootstrap */
	opacity: 1 !important;
}


/* Dettagli del libro */

#book-details img {

    max-width: 100%;

    height: auto;

    border: 5px solid #dee2e6;

    transition: transform 0.3s ease-in-out;

}



#book-details img:hover {

    transform: scale(1.02);

}



#book-details h2 {

    color: #007bff; /* Colore primario di Bootstrap */

    font-weight: bold;

    margin-bottom: 20px;

}



.book-meta li {

    margin-bottom: 10px;

    font-size: 1.1rem;

}



.btn-primary {

    background-color: #007bff;

    border-color: #007bff;

    font-size: 1.3rem;

    padding: 10px 30px;

    transition: background-color 0.3s ease-in-out, border-color 0.3s ease-in-out;

}



.btn-primary:hover {

    background-color: #0056b3;

    border-color: #0056b3;

}



/* --- SEZIONE RECENSIONI CAROUSEL: ULTIMISSIMA REVISIONE --- */

#reviews {

    background-color: #f0f0f0;

    padding: 40px 0;

    border-radius: 8px;

    box-shadow: 0 4px 8px rgba(0,0,0,0.1);

    margin-top: 50px;

    margin-bottom: 50px;

    overflow: hidden; /* **CRUCIALE**: Mantiene le slide fuori vista nascoste */

    position: relative; /* Assicura che i suoi discendenti absolute si posizionino correttamente rispetto a esso */

}



#reviews h2 {

    color: #343a40;

    margin-bottom: 30px;

    font-size: 2.5rem;

}



/* Contenitore principale del carosello */

#reviews .carousel {

    position: relative;

    margin: 0 auto;

    max-width: 900px; /* Limita la larghezza massima per estetica */

}



/* Il contenitore interno che gestisce lo scorrimento delle slide */

#reviews .carousel-inner {

    position: relative; /* **FONDAMENTALE**: Punto di riferimento per le slide */

    width: 100%;

    overflow: hidden; /* **CRUCIALE**: Nasconde le slide non visibili */

    min-height: 250px; /* Assicura un'altezza minima per il carosello */

    padding: 0 50px; /* Spazio ai lati per i bottoni di navigazione */

    display: flex; /* Permette il centraggio del contenuto delle slide */

    align-items: center; /* Centra verticalmente il contenuto */

    /* Queste proprietà sono gestite da Bootstrap per l'animazione,

       non dovremmo aver bisogno di toccarle, ma in caso di problemi,

       un 'transform: none !important;' qui potrebbe annullare l'animazione. */

}



/* Ogni singola slide del carosello */

#reviews .carousel-item {

    background-color: #ffffff;

    padding: 30px;

    border-radius: 8px;

    width: 100%;

    /* Display flex per il contenuto interno */

    display: flex;

    flex-direction: column;

    align-items: center;

    justify-content: center;

    text-align: center;

    box-sizing: border-box;



    /* --- PROPRIETÀ CRITICHE DI BOOTSTRAP, FORZATE CON !important PER DEBUG --- */

    position: absolute !important; /* **ASSICURA** che le slide si sovrappongano e scorrano */

    top: 0 !important;

    left: 0 !important;

    opacity: 0 !important; /* Inizialmente invisibile */

    transition: transform 0.6s ease-in-out, opacity 0.6s ease-in-out !important; /* Animazione fluida */

    -webkit-backface-visibility: hidden !important; /* Fix per i browser WebKit (Chrome, Safari) */

    backface-visibility: hidden !important;

    perspective: 1000px !important; /* Per un rendering 3D migliore */

}



/* La slide attiva */

#reviews .carousel-item.active {

    display: flex !important; /* Deve essere visibile */

    opacity: 1 !important; /* Deve essere completamente visibile */

    transform: translateX(0) !important; /* Nessuno spostamento orizzontale */

}



/* Le slide che stanno per entrare/uscire */

#reviews .carousel-item-next:not(.carousel-item-start),

#reviews .carousel-item-prev:not(.carousel-item-end) {

    transform: translateX(0) !important; /* Assicura che siano pronte per l'animazione */

}



#reviews .carousel-item-next,

#reviews .carousel-item-prev {

    position: absolute !important;

    top: 0 !important;

    left: 0 !important;

    opacity: 0 !important;

}



#reviews .carousel-item-next.carousel-item-start,

#reviews .carousel-item-prev.carousel-item-end {

    transform: translateX(0) !important;

}





/* Stile per il testo e footer della review */

#reviews blockquote {

    font-size: 1.4rem;

    font-style: italic;

    color: #555;

    margin-bottom: 1.5rem;

    line-height: 1.6;

    max-width: 80%;

    margin-left: auto;

    margin-right: auto;

}



#reviews .blockquote-footer {

    font-size: 1rem;

    color: #777;

    margin-top: auto;

}



/* Stile per le frecce di navigazione del carosello */

#reviews .carousel-control-prev,

#reviews .carousel-control-next {

    position: absolute;

    top: 50%;

    transform: translateY(-50%);

    width: 5%;

    opacity: 0.8;

    transition: opacity 0.3s ease;

    z-index: 10; /* Assicura che siano cliccabili sopra le slide */

}



#reviews .carousel-control-prev {

    left: 0;

}



#reviews .carousel-control-next {

    right: 0;

}



#reviews .carousel-control-prev:hover,

#reviews .carousel-control-next:hover {

    opacity: 1;

}



#reviews .carousel-control-prev-icon,

#reviews .carousel-control-next-icon {

    background-color: #007bff;

    border-radius: 50%;

    padding: 10px;

    background-size: 60%;

    display: block;

    margin: 0 auto;

}

/* --- FINE SEZIONE RECENSIONI CAROUSEL --- */



/* Footer */

footer {

    background-color: #212529 !important;

    color: #ffffff;

    padding: 20px 0;

}



footer a {

    color: #007bff;

    text-decoration: none;

}



footer a:hover {

    text-decoration: underline;

}



.social-links a {

    font-size: 1.8rem;

    margin: 0 10px;

    color: #ffffff; /* Colore base delle icone social: bianco */

    transition: color 0.3s ease-in-out; /* Transizione fluida del colore */

}



/* Rendiamo la regola più specifica usando anche la classe 'footer' */

footer .social-links a:hover {

    color: #007bff !important; /* Forziamo il colore delle icone social all'hover: blu di Bootstrap */

}



/* Media Queries per la responsività */

@media (max-width: 768px) {

    header h1 {

        font-size: 2.5rem;

    }



    header p.lead {

        font-size: 1.2rem;

    }



    #book-details .col-md-5,

    #book-details .col-md-7 {

        text-align: center;

    }



    #book-details img {

        margin-bottom: 20px;

    }



    #reviews h2 {

        font-size: 2rem;

    }

    #reviews .carousel-inner {

        padding: 0 10px;

        min-height: 180px;

    }

    #reviews .carousel-item {

        padding: 20px;

    }

    #reviews blockquote {

        font-size: 1.2rem;

    }

}



@media (max-width: 576px) {

    header h1 {

        font-size: 2rem;

    }



    header p.lead {

        font-size: 1rem;

    }



    .btn-primary {

        font-size: 1.1rem;

        padding: 8px 20px;

    }



    #reviews h2 {

        font-size: 1.8rem;

    }

    #reviews .carousel-inner {

        padding: 0 5px;

        min-height: 150px;

    }

    #reviews .carousel-item {

        padding: 15px;

    }

    #reviews blockquote {

        font-size: 1rem;

    }

    #reviews .carousel-control-prev-icon,

    #reviews .carousel-control-next-icon {

        padding: 8px;

        background-size: 50%;

    }

}