/*******MAIN LAYOUT *********************************************/
:root {
    --element-padding: 10px;
    --element-margin: 5px;
    --element-border-radius: 5px;
}

html, body {
    margin: 0;
    height: 100%; /* Assicurati che questo sia presente */
    font-size: 12px; /* Dimensione base del font per mobile */
}
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}
main {
    flex: 1;/*flex : 1 permette di occupare tutto lo spazio disponibile in alto e in basso*/
    display: flex;
    justify-content: center;
    align-items: center;
}
main {
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden; /* Aggiungi questa riga */
    background-color: #f0f0f0;
}

#container {
    flex: 1; 
    display: flex; 
    flex-direction: column; /* Per mobile */
    overflow: hidden; 
    padding: 3px; /* Aggiunto padding di 3px */
    box-sizing: border-box; /* Assicura che il padding non aumenti le dimensioni totali */
}

#menu, #content {
    box-sizing: border-box;
    padding: var(--element-padding);
    margin: var(--element-margin);
    border-radius: var(--element-border-radius);
}

/* Stili generali per l'header */
header {
    background-color: #bd96ff; /* Leggermente più chiaro */
    padding: 1rem;
    border-radius: 0; /* Bordi dritti */
    box-shadow: 0 4px 6px rgba(43, 18, 116, 0.8); /* Ombra grossa del colore precedente */
}

/* Layout di base per la navigazione */
header nav {
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Distribuzione equa dello spazio tra i link */
header nav > * {
    flex: 1;
    text-align: center;
}

/* Media query per il layout responsive */
@media (max-width: 768px) {
    header nav {
        flex-direction: column;
    }
}


#menu {
    overflow-y: auto;
    width: 100%;
    order: -1; /* Posiziona il menu in cima per mobile */
}

#content {
    flex: 1;
    width: 100%;
    overflow-y: auto;
}

.popup {
    position: absolute;
    top: 10px;
    left: 5vw;
    right: 5vw;
    width: 90vw;
    max-width: 90vw;
    max-height: 90vh;
    height: auto;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/*******MEDIA QUERIES *********************************************/
@media screen and (min-width: 481px) { /* Tablet */
    html, body {
        font-size: 14px;
    }
}

@media screen and (min-width: 769px) { /* Desktop */
    html, body {
        font-size: 16px;
    }

    #container {
        flex-direction: row; /* Cambia la direzione per affiancare menu e content */
    }

    #header {
        width: 100%;
        order: -1;
    }

    #menu {
        width: auto; /* o una larghezza specifica se necessario */
        order: 0; /* Ripristina l'ordine predefinito */
        flex-shrink: 0; /* Impedisce al menu di restringersi */
        margin-bottom: 0; /* Rimuove il margine inferiore su desktop */
        margin-right: 10px; /* Aggiunge spazio tra menu e content su desktop */
    }

    #content {
        flex: 1; /* Permette al content di occupare lo spazio rimanente */
    }

    .popup {
        left: auto;
        right: auto;
        width: auto;
    }
}

@media screen and (max-width: 768px) { /* Per tablet in verticale */
    #container {
        height: auto; /* Rimuovi altezze fisse se presenti */
        min-height: 100%; /* Usa min-height invece di height */
    }
    
    #content {
        flex: 1;
        overflow-y: auto;
    }
}