@font-face {
    font-family: 'Montserrat';
    src: url('https://whoisfra.it/fonts/Montserrat-VariableFont_wght.ttf') format('truetype');
    font-weight: 100 900; /* Imposta l'intervallo di pesi supportati */
    font-style: normal;
    font-display: swap; /* Ottimizza il caricamento del font */
  }

body {
    background-color: black;
    width: 100%;
    margin: 0;
    padding: 0;
    font-family: 'Montserrat', sans-serif;
}

.centra {
    width: 1200px;
    margin: auto;
}



.avvio {

    transition: opacity 1s;
  }

.rivela{
    position: relative;
    transform: translateX(-100%);
    opacity: 0;
    transition: 1s all ease;
}
  
.rivela.attivo{
    transform: translateX(0);
    opacity: 1;
}

.rivela_sotto{
    position: relative;
    transform: translateY(100%);
    opacity: 0;
    transition: 1s all ease;
}
  
.rivela_sotto.attivo_sotto{
    transform: translateY(0);
    opacity: 1;
}












/* --- Media Queries per Responsività Galleria --- */

/* ----- Stili per Tablet e Schermi Medi (fino a 768px) ----- */
@media (max-width: 768px) {

    .explorer-window {
        width: 95%; /* Occupa più larghezza */
        height: 90vh; /* Altezza relativa alla viewport, più flessibile */
        min-height: 500px; /* Altezza minima */
        margin: 20px auto; /* Margine ridotto */
        font-size: 0.9em; /* Riduci leggermente la dimensione base del font */
    }

    .main-area {
        padding: 10px;
        gap: 15px; /* Spazio ridotto tra le icone */
    }

    .icon {
        width: 70px; /* Icone leggermente più piccole */
    }

    .icon img {
        width: 40px; /* Immagine icona più piccola */
        height: 40px;
    }

    .icon span {
        font-size: 0.75em; /* Testo icona più piccolo */
    }

    .address-bar .path-input {
        font-size: 0.85em; /* Testo barra indirizzi più piccolo */
    }

    /* Adattamenti Modale Foto */
    .modal-content.photo-viewer-window {
        width: 95%;
        height: 90%;
    }

    .photo-controls button {
        padding: 6px 10px; /* Pulsanti modale leggermente più piccoli */
        margin: 0 5px;
        font-size: 0.9em;
    }
}


/* ----- Stili per Telefoni (fino a 480px) ----- */
@media (max-width: 480px) {
     .address-bar .path-input {
         /* Potrebbe essere necessario ridurlo o nasconderlo */
         /* Esempio: */
         /* display: none; */ /* Oppure: */
         width: 50%;
         overflow: hidden; /* Nascondi testo che non entra */
         white-space: nowrap;
         text-overflow: ellipsis; /* Mostra ... per testo lungo */
     }
      .status-bar {
        font-size: 0.75em; /* Testo barra stato più piccolo */
        padding: 2px 5px;
    }


    .main-area {
        padding: 8px;
        gap: 10px; /* Spazio icone ancora ridotto */
    }

    .icon {
        width: 65px; /* Icone ancora più piccole */
    }

    .icon img {
        width: 35px; /* Immagine icona più piccola */
        height: 35px;
    }

     .icon span {
        font-size: 0.7em; /* Testo icona piccolo */
     }


    /* Adattamenti Modale Foto per schermi molto piccoli */
     .modal-content.photo-viewer-window {
        width: 100%;
        height: 100%;
        border-radius: 0;
        border: none;
    }

     .photo-title-bar .title-text {
         font-size: 0.9em; /* Testo titolo modale più piccolo */
     }

     .photo-controls {
         padding: 5px;
     }

    .photo-controls button {
        padding: 5px 8px;
        margin: 0 3px;
        font-size: 0.8em;
        /* Potresti anche mostrare solo icone invece di testo */
        /* Esempio: */
        /* content: '<'; font-size: 1.2em; */
    }
}












@media (max-width: 2300px){
    .centra {
        width: 1200px;
    }
    h1 {
        font-size: 150px;
        float: right;
        text-align: right;
        font-weight: 700;
        line-height: 121px;
    }

    .hero img{
        width: 30%;
        float: left;
        margin-top: 40px; 
    }


}

@media (max-width: 768px) {

    .centra {
        width: 400px;
        display: flex;
        flex-wrap: wrap;
    }
    h1 {
        margin-left: 5%;
        margin-right: 5%;
        width: 90%;
        font-size: 65px;
        text-align: center;
        font-weight: 700;
        line-height: 55px;

    }
    .hero img{
        padding: 0;
        width: 70%;
        position: relative;
        margin-left: 15%;
        margin-right: 15%;
    }



    .hacker-text {
        font-size: 1.5rem; 
    }

    header ul {
        flex-direction: column;
        position: absolute;
        top: 60px;
        right: 0;
        background-color: black;
        width: 100%;
        text-align: center;
        transition: max-height 0.3s ease-in-out;
        max-height: 0;
        overflow: hidden;
    }

    header ul.show {
        max-height: 300px; /* Adjust as needed */
    }

    header li {
        margin: 10px 0;
    }

    .menu-toggle {
        display: block;
        cursor: pointer;
        position: absolute;
        top: 15px;
        right: 25px;
        font-size: 30px;
        color: white;
        z-index: 20; /* Ensure it is above other elements */
    }
}

@media (max-width: 480px) {
    .centra {
        width: 90%;
        display: flex;
        flex-wrap: wrap;
    }
    h1 {
        margin-left: 5%;
        margin-right: 5%;
        width: 90%;
        font-size: 60px;
        text-align: center;
        font-weight: 700;
        line-height: 52px;
    }

    .cybersec {
        margin-top: 150px;
    }

    .hero img {
        padding: 0;
        width: 80%;
        position: relative;
        margin-left: 10%;
        margin-right: 10%;
    }

    .hacker-text {
        font-size: 1.2rem;
    }
}

@keyframes gradient {
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}




header {
    height: 100px;
}

header ul{
    width: fit-content;
    margin-top: 25px;
    float: right;
}

header li{
    font-size: 20px;
    display: inline;
    margin-right: 25px;
}

header a{
    color: #b4b4b4;
    text-decoration: none;
    transition: 200ms;
}

header a:hover{
    color: #252525;
    transition: 500ms;
}

header p{
    font-family: 'Courier New', Courier, monospace;
    float: left;
    padding-left: 25px;
    color: white;
    font-weight: 600;
    font-size: x-large;
}

.it{
    color: red;
    padding-left: 0;
}

.hero {
    height: 500px;
    padding-top: 100px;
}

.hero h1{
    background-image: linear-gradient(-45deg, #ee1b1b, #e52c2c, #5e23d5, #234fd5);
    animation: gradient 5s ease infinite;
    background-clip: text;
    -webkit-background-clip: text;
    background-size: 150% 200%;
    color: #E5E5E5;
    transition: 2000ms;
}

.hero h1:hover{
    color: transparent;
    transition: 400ms;
}


.cybersec {
    margin-top: 180px;
    height: 300px;
    height: fit-content;
    width: screen;
}

.cybersec h2{
    color:#ffffff;
    font-size: 3rem;
}


.hacker-text {
    position: relative;
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    cursor: pointer;
    transition: color 0.3s ease;
}

.terminal {
    width: 100%;
    min-height: 250px;
    margin-top: -30px;
    padding: 10px;
    color: red;
    font-size: large;
    font-family: monospace;
    background-color: black;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    transition: height 0.3s ease;
}

.terminal-output {
    margin-bottom: 10px;
    white-space: pre-wrap;
    word-wrap: break-word;
}


.terminal-input {
    width: 100%;
    background: black;
    color: red;
    border: none;
    outline: none;
    font-family: monospace;
    font-size: large;
    padding: 10px;
    margin-top: 10px;
}

.help-message {
    color: red;
    font-family: monospace;
    font-size: large;
    margin-top: 10px;
}


/* Sezione curriculum */

.curriculum{
    font-family: 'Fira Code', monospace;
    width: 100%;
    margin-top: 150px;
    color: red;
    display: flex;
    justify-content: center;
    align-items: center;
    height: fit-content;
    overflow: hidden;
}
.terminal2 {
    width: 85%;
    margin-left: 0;
    height: fit-content;
    padding: 15px;
    background: #121212;
    border-radius: 10px;
    box-shadow: 0px 0px 15px red;
    overflow-y: auto;
    overflow-x: hidden;
    border: 2px solid red;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.progress-bar-container {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #222;
    border: 2px solid red;
    padding: 5px;
    border-radius: 5px;
    box-sizing: border-box;
}
.progress-bar {
    flex: 1;
    height: 20px;
    background: #222;
    border-radius: 5px;
    overflow: hidden;
    position: relative;
    margin-right: 10px;
}
.progress {
    height: 100%;
    background: linear-gradient(to right, red, #aa0000);
    width: 0%;
    transition: width 0.3s ease-in-out;
}
.speed {
    color: red;
    font-size: 14px;
}
.title-bar {
    padding: 5px 10px;
    border-bottom: 2px solid red;
    display: flex;
    align-items: center;
}
.title-bar span {
    color: red;
    font-weight: 700;
}
.dots {
    margin-right: 10px;
    color: red;
    transition: 1s;
}

.download a:hover{
    color: red;
}



/* Sezione skills*/

.skills {
    margin-top: 100px;
    height: 300px;
    color: #ffffff;
    height: fit-content;
    width: screen;
}


.skills h2 {
    color: #ffffff;
    font-size: 3.5rem;
    z-index: 1;
    margin-top: 100px;
    margin-bottom: 50px;
}

#skill {
    height: fit-content;
    width: 200px;
    margin-bottom: 20px;
}

.skill-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Media query per dispositivi mobili */
@media (max-width: 600px) {
    .skill-container {
        display: block;
        flex-direction: column;
        align-items: center;
        margin-left: 10px;   
    }

    #skill {
        height: fit-content;
        width: 150px;
        margin-bottom: 40px;
    }

    #skill h3 {
        font-size: x-large;
        margin-bottom: -10px;
    }

    #skill p{
        margin-bottom: -9px;
        font-size: large;
    }
}



.curriculum h3 {
    color: #fff;
    font-size: 2000%;
}

.galleria img{
    color: #000000;
}

.links {
    height: 1200px;
    
}

.contatti {
    margin-top: 100px;
    padding: 20px;
    border-radius: 5px;
    color: #ffffff;
    font-family: 'Fira Code', monospace;
}

.contatti h3 {
    font-size: 3rem;
    margin-bottom: 20px;
}

.cmd-content p {
    font-size: 1.5rem;
    margin: 10px 0;
}

.cmd-content a {
    color: #ffffff;
    text-decoration: none;
    transition: color 0.3s ease;
}

.cmd-content a:hover {
    color: #868686;
}

footer {
    height: 60px;
    width: 100%;
}

footer p{
    color: #b4b4b4;
    margin-top: 30px;
}


footer a{
    text-decoration: none;
    color: #b4b4b4;
    transition: 1s;
}

footer a:hover{
    color: #252525;
    transition: 500ms;
}

footer h2{
    font-size: 2rem;
    color: #000000;
    font-family: 'Montserrat', sans-serif;
}















/* Stili Finestra Esplora File */
/* --- Modifiche per Finestra Movibile --- */

.explorer-window {

    position: absolute; /* O 'fixed' se la vuoi fissa rispetto alla finestra del browser */
    /* Imposta dimensioni e posizione iniziale */
    width: 800px; /* Larghezza iniziale fissa */
    height: 550px; /* Altezza iniziale fissa */
    top: 120px;  /* Posizione iniziale dall'alto */
    left: calc(50% - 400px); /* Posizione iniziale orizzontale (centrata) */
    max-width: 95%; /* Limite per schermi piccoli */
    max-height: 90%;/* Limite per schermi piccoli */

    background-color: #f0f0f0;
    border: 1px solid #a0a0a0;
    border-radius: 5px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    overflow: hidden; /* Mantiene l'overflow hidden */
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    z-index: 990; /* Assicurati che sia sopra altri elementi ma sotto la modale foto */
}

.title-bar {
    /* Rimuovi 'cursor: grab;' se presente, lo gestirà JS */
    /* Assicurati che queste siano presenti: */
    background: linear-gradient(to bottom, #e0e0e0, #c0c0c0);
    padding: 5px 8px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #a0a0a0;
    user-select: none; /* Impedisce la selezione del testo durante il drag */
    cursor: grab; /* Cursore iniziale per il trascinamento */
}

.explorer-window.maximized-window {
    border-radius: 0;
    transition: none !important; 
}

/* Stile opzionale mentre si trascina */
.explorer-window.dragging .title-bar {
    cursor: grabbing;
}

/* Rimuovi o modifica le regole @media che impostavano width/height/margin
   per .explorer-window se entrano in conflitto con position:absolute.
   Potresti dover aggiustare top/left/width/height dentro le media query
   per posizionare/dimensionare la finestra su schermi piccoli. */

/* Esempio di adattamento in @media (max-width: 480px) */
@media (max-width: 480px) {
    .explorer-window {
        width: 98%;
        height: 85vh; /* Altezza ancora relativa */
        left: 1%;
        max-width: 98%;
        max-height: calc(100vh - 70px);
        border: none; /* Nascondi bordo se full-width */
        border-radius: 0;
    }
    /* ... altre regole @media ... */
}

.title-bar {
    background: linear-gradient(to bottom, #e0e0e0, #c0c0c0); /* Gradiente per barra titolo */
    padding: 5px 8px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #a0a0a0;
    cursor: grab; /* Simula trascinamento */
}

.title-icon {
    width: 16px;
    height: 16px;
    margin-right: 5px;
}

.title-text {
    flex-grow: 1; /* Occupa spazio disponibile */
    font-weight: bold;
    font-size: 0.9em;
    color: #333;
}

.window-controls {
    display: flex;
}

.control-btn {
    background-color: #d0d0d0;
    border: 1px solid #a0a0a0;
    margin-left: 3px;
    padding: 0px 8px;
    font-size: 0.8em;
    font-weight: bold;
    cursor: pointer;
}
.control-btn.close {
    background-color: #e81123; /* Rosso per chiudi */
    color: white;
    border-color: #e81123;
}
.control-btn:hover {
    filter: brightness(1.1);
}
.control-btn.close:hover {
     background-color: #f1707a;
}


.address-bar {
    background-color: #f0f0f0;
    padding: 5px;
    border-bottom: 1px solid #d0d0d0;
    display: flex;
    align-items: center;
}

.nav-btn {
    background: none;
    border: 1px solid transparent;
    font-size: 1.2em;
    margin-right: 5px;
    padding: 2px 5px;
    cursor: pointer;
}
.nav-btn:hover {
    background-color: #e0e0e0;
    border-color: #c0c0c0;
}
.nav-btn:disabled {
    color: #a0a0a0;
    cursor: default;
}
.nav-btn:disabled:hover {
    background: none;
    border-color: transparent;
}

.path-input {
    flex-grow: 1;
    border: 1px solid #ccc;
    padding: 3px 5px;
    font-size: 0.9em;
    margin-left: 10px;
    background-color: white; /* Input modificabile */
}


.main-area {
    flex-grow: 1; /* Occupa lo spazio verticale rimanente */
    background-color: #ffffff; /* Sfondo bianco area file */
    padding: 15px;
    overflow-y: auto; /* Scroll se il contenuto è troppo */
    display: flex;
    flex-wrap: wrap; /* Manda a capo le icone */
    align-content: flex-start; /* Allinea icone in alto */
    gap: 20px; /* Spazio tra le icone */
}

.icon {
    display: flex;
    flex-direction: column; /* Immagine sopra, testo sotto */
    align-items: center; /* Centra orizzontalmente */
    text-align: center;
    width: 80px; /* Larghezza fissa per icona */
    padding: 5px;
    cursor: pointer;
    border: 1px solid transparent;
    border-radius: 3px;
}

.icon:hover {
    background-color: #e6f2ff; /* Sfondo azzurrino su hover */
    border-color: #cce4ff;
}

.icon img {
    width: 48px; /* Dimensione icona grande */
    height: 48px;
    margin-bottom: 5px;
}

.icon span {
    font-size: 0.8em;
    word-wrap: break-word; /* Manda a capo testo lungo */
    width: 100%;
}

.status-bar {
    background-color: #f0f0f0;
    padding: 3px 10px;
    border-top: 1px solid #d0d0d0;
    font-size: 0.8em;
    color: #555;
    display: flex;
    justify-content: space-between;
}


/* Stili Finestra Modale Foto */
.modal {
    position: fixed; /* Fissata rispetto alla viewport */
    z-index: 1000; /* Sopra tutto il resto */
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); /* Sfondo scuro semi-trasparente */
    display: flex; /* Usa flexbox per centrare */
    justify-content: center;
    align-items: center;
}

.modal-content.photo-viewer-window {
    background-color: #2d2d2d; /* Sfondo scuro per app foto */
    color: white;
    width: 90%;
    max-width: 1000px;
    height: 85%;
    max-height: 800px;
    border-radius: 5px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.4);
    display: flex;
    cursor: grab;
    position: relative;
    flex-direction: column;
    overflow: hidden;
}

.photo-title-bar {
     background: #1c1c1c; /* Barra titolo più scura */
     color: #e0e0e0;
     border-bottom: 1px solid #444;
}
.photo-title-bar .title-text {
    color: #e0e0e0;
}
.photo-title-bar .control-btn {
     background-color: #444;
     border-color: #666;
     color: #e0e0e0;
}
.photo-title-bar .control-btn.close {
    background-color: #e81123; color: white; border-color: #e81123;
}
.photo-title-bar .control-btn.close:hover {
    background-color: #f1707a;
}


.photo-area {
    flex-grow: 1; /* Occupa spazio verticale */
    display: flex;
    justify-content: center; /* Centra immagine orizzontalmente */
    align-items: center; /* Centra immagine verticalmente */
    padding: 10px;
    overflow: hidden; /* Per immagini molto grandi */
}

#modal-image {
    max-width: 100%; /* Immagine non più larga dell'area */
    max-height: 100%; /* Immagine non più alta dell'area */
    display: block;
    transition: none;
    will-change: transform;
}

.photo-controls {
    padding: 10px;
    text-align: center;
    border-top: 1px solid #444;
}
.photo-controls button {
    background-color: #444;
    color: white;
    border: 1px solid #666;
    padding: 8px 15px;
    margin: 0 10px;
    cursor: pointer;
    border-radius: 3px;
}
.photo-controls button:hover {
    background-color: #555;
}





















/* Aggiungi questo al tuo style.css */

.blog-section {
    /* Stili per l'intera sezione del blog */
    color: #e0e0e0;
}

.blog-section h2 {
    color: #ffffff;
    font-size: 2.8rem; /* O la dimensione che preferisci */
    margin-bottom: 30px;
    padding-bottom: 10px;
    border-bottom: 2px solid red; /* Mantiene lo stile del sito */
}

#blog-posts-container {
    /* Contenitore dei post */
    margin-top: 20px;
}

#blog-posts-container p { /* Stile per messaggi di caricamento/errore */
    color: #cccccc;
    font-style: italic;
}

.blog-post-item {
    background-color: #1f1f1f; /* Sfondo scuro per ogni post */
    padding: 20px;
    margin-bottom: 25px;
    border-left: 5px solid red; /* Bordo distintivo */
    border-radius: 0 5px 5px 0; /* Angoli arrotondati (tranne a sinistra) */
    transition: background-color 0.3s ease;
}

.blog-post-item:hover {
     background-color: #2a2a2a; /* Leggero cambio colore su hover */
}


.blog-post-item a {
    color: #ffffff;
    text-decoration: none;
    font-size: 1.5rem; /* Dimensione titolo post */
    font-weight: 600;
    display: block; /* Occupa tutta la larghezza */
    margin-bottom: 10px;
    transition: color 0.3s ease;
}

.blog-post-item a:hover {
    color: #ff6666; /* Rosso più chiaro su hover */
}

.blog-post-metadata {
    display: flex;
    align-items: center; /* Allinea icona e data verticalmente */
    gap: 10px; /* Spazio tra icona e data */
    margin-top: 10px;
}

.blog-post-metadata .file-icon {
    width: 16px; /* Dimensione piccola per l'icona */
    height: 16px;
}

.blog-post-metadata .post-date {
    color: #a0a0a0; /* Colore grigio per la data */
    font-size: 0.9em;
}









/* --- Sovrascritture Specifiche per Pagina Privacy --- */

/* Contenitore del testo della policy */
.policy-text-container {
    color: #e0e0e0; /* Testo principale un po' più chiaro per contrasto su nero */
    margin-top: 30px; /* Spazio dopo l'hero H1 */
}

/* Paragrafi nella policy */
.policy-text-container p {
    line-height: 1.7; /* Aumenta interlinea per blocchi di testo lunghi */
    font-size: 1rem; /* Assicura una dimensione leggibile */
    color: #cccccc; /* Grigio chiaro, ma non bianco puro */
    margin-bottom: 1.2em; /* Spazio tra paragrafi */
}

/* Titoli H2 nella policy */
.policy-text-container h2 {
    color: red; /* Mantiene il rosso distintivo */
    font-size: 1.8rem; /* Dimensione adeguata */
    margin-top: 2.5em; /* Più spazio sopra H2 */
    margin-bottom: 1em;
    border-bottom: 1px solid #444; /* Linea separatrice sottile */
    padding-bottom: 0.3em;
}
/* Rimuovi margine extra se H2 è il primo elemento nel container */
.policy-text-container h2:first-child {
     margin-top: 0;
}


/* Titoli H3 nella policy */
.policy-text-container h3 {
    color: #f0f0f0; /* Quasi bianco per i sottotitoli */
    font-size: 1.3rem;
    margin-top: 1.5em;
    margin-bottom: 0.8em;
}

/* Link dentro la policy */
.policy-text-container a {
    color: #ff6666; /* Rosso chiaro per i link, come nel banner cookie */
    text-decoration: underline;
}
.policy-text-container a:hover {
    color: #ffffff;
}

/* Riduci effetto gradiente su H1 solo per questa pagina se disturba */
.hero-policy h1 {
        background-image: linear-gradient(-45deg, #ee1b1b, #e52c2c, #5e23d5, #234fd5);
        animation: gradient 5s ease infinite;
        background-clip: text;
        -webkit-background-clip: text;
        background-size: 150% 200%;
        color: #E5E5E5;
        transition: 2000ms;
             /* Meglio: aggiustiamo solo la dimensione per mobile */
        font-size: 3rem; /* Dimensione base per H1 policy */
        line-height: 1.2;
        text-align: center; /* Centra l'H1 nella policy */
        float: none; /* Rimuovi float se presente */
}
    
.hero-policy h1:hover{
        color: transparent;
        transition: 400ms;
}




/* --- Media Queries Specifiche per Policy --- */

@media (max-width: 768px) {
    .policy-text-container p {
        font-size: 0.95rem;
        line-height: 1.6;
    }
    .policy-text-container h2 {
        font-size: 1.6rem;
    }
    .policy-text-container h3 {
        font-size: 1.2rem;
    }
     .hero-policy h1 {
         font-size: 2.5rem; /* Riduci H1 su tablet */
     }
}

@media (max-width: 480px) {
    .policy-text-container {
         padding: 0 10px; /* Aggiungi un po' di padding laterale su mobile */
    }
    .policy-text-container p {
        font-size: 0.9rem;
    }
    .policy-text-container h2 {
        font-size: 1.4rem;
    }
    .policy-text-container h3 {
        font-size: 1.1rem;
    }
    .hero-policy h1 {
         font-size: 2rem; /* Riduci ulteriormente H1 su mobile */
         line-height: 1.3;
     }
}













/* Stili per il Cookie Consent Banner */
.cookie-banner {
    position: fixed; /* Fisso in basso */
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: #252525; /* Sfondo scuro, coerente col tuo stile */
    color: #e0e0e0;
    padding: 15px 25px;
    box-shadow: 0 -2px 5px rgba(0,0,0,0.5);
    z-index: 1001; /* Assicurati sia sopra altri elementi fissi, ma sotto eventuali modali aperte se necessario */
    
    font-size: 0.9em;
    box-sizing: border-box; /* Include padding nella larghezza */
    align-items: center; /* Centra verticalmente se usi flex */
    justify-content: space-between; /* Spazio tra testo e bottoni se usi flex */
}

/* Usa flexbox per layout responsivo (opzionale ma consigliato) */
.cookie-banner { /* <<< REGOLE CONFLITTUANTI */
    display: flex; /* Cambia da none a flex quando mostrato da JS */
    flex-wrap: wrap; /* Permette ai bottoni di andare sotto su schermi piccoli */
    gap: 15px; /* Spazio tra testo e bottoni */
}


.cookie-banner p {
    margin: 0; /* Rimuovi margini default del paragrafo */
    flex-grow: 1; /* Il testo occupa lo spazio disponibile */
    color: #e0e0e0; /* Assicura colore testo */
    font-size: 1em; /* Reset per coerenza */
    margin-left: 0; /* Sovrascrivi stile globale se necessario */
    line-height: 1.4;
}

.cookie-banner a {
    color: #ff6666; /* Rosso chiaro per il link, stile sito */
    text-decoration: underline;
}

.cookie-banner a:hover {
    color: #ffffff;
}

.cookie-buttons {
    /* Contenitore per i bottoni */
    display: flex;
    gap: 10px; /* Spazio tra i bottoni */
    flex-shrink: 0; /* Evita che i bottoni si restringano troppo */
}

footer #change-cookie-consent {
    color: #aaaaaa; /* Grigio chiaro */
    text-decoration: underline;
    transition: color 0.3s ease;
}

footer #change-cookie-consent:hover {
    color: #ffffff; /* Bianco su hover */
}

.cookie-banner button {
    background-color: red; /* Rosso stile sito */
    color: white;
    border: none;
    padding: 8px 15px;
    border-radius: 4px;
    cursor: pointer;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.cookie-banner button:hover {
    background-color: #cc0000; /* Rosso più scuro su hover */
}

/* Stile specifico per bottone Rifiuta (opzionale) */
.cookie-banner button#decline-cookies-btn {
    background-color: #555;
}

.cookie-banner button#decline-cookies-btn:hover {
    background-color: #777;
}

/* Media Query per schermi piccoli */
@media (max-width: 768px) {
    .cookie-banner {
        flex-direction: column; /* Testo sopra, bottoni sotto */
        align-items: flex-start; /* Allinea a sinistra */
        text-align: center;
    }
     .cookie-banner p {
         margin-bottom: 10px; /* Spazio tra testo e bottoni */
         text-align: center;
    }
    .cookie-buttons {
        width: 100%; /* Bottoni a tutta larghezza */
        justify-content: center; /* Centra i bottoni */
    }
}