@charset "UTF-8";

@font-face {
    font-family: Magistral;
    src: url('../fonts/Magistral Regular.otf');
}

body {
    margin: 0;
    background: linear-gradient(90deg, #FFFFFF, #0075BE);
    font-family: Magistral;
}
.input-error {
    border: 2px solid red !important;
    box-shadow: 0 0 5px red !important;
}
.selected_menu{
    background-color:#999999 !important;
}
#sidebar {
    transform: translateX(-250px); /* Sidebar nascosta inizialmente */
    transition: transform 1s ease-in-out; /* Animazione scorrevole */
    width: 250px;
    background-color: rgba(0, 117, 190,0.8);
    color: white;
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
    padding: 20px 10px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}
    /* Stato visibile della sidebar */
    #sidebar.animated {
        transition: transform 1s ease-in-out; /* Animazione scorrevole */
        transform: translateX(0); /* Mostra la sidebar */
    }
    #sidebar.noanimated {
        transition: transform 0s ease-in-out; /* Animazione scorrevole */
        transform: translateX(0); /* Mostra la sidebar */
    }

    #sidebar #logo-sidebar {
        font-size: 1.5rem;
        font-weight: bold;
        margin-bottom: 30px;
        text-align: center;
        transition: all 1s ease-in-out;
    }

    #sidebar ul {
        list-style: none;
        padding: 0;
        margin-top:75%;
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center; /* Centra verticalmente gli item */
        flex-grow: 1; /* Fai in modo che l'elenco occupi tutto lo spazio verticale disponibile */
        transition: transform 1s ease-in-out, top 1s ease-in-out, left 1s ease-in-out;
    }

        #sidebar ul li {
            margin: 5px 0;
        }

            #sidebar ul li a {
                margin-top:10px;
                color: white;
                text-decoration: none;
                text-align: center;
                padding: 10px;
                display: block;
                border-radius: 5px;
                background-color: rgba(0, 117, 190,0.5);
                transition: background-color 0.3s;
                letter-spacing: 3px;
            }

                #sidebar ul li a:hover {
                    background-color: #575757;
                }

#main-content {
    margin-left: 250px;
    padding: 20px;
}

/* Login page styles */
#login-container {
    height: 91vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    margin-left:-250px;
}

/* Stato iniziale del logo */
#logo-login {
    position: absolute;
    top: 20%; 
    left: 50%; /* Centro orizzontale */
    transform: translate(-50%, -50%);
    transition: transform 1s ease-in-out, top 1s ease-in-out, left 1s ease-in-out;
    z-index: 9999;
}
    #logo {
        width: auto;
        max-height: 30vh;
        max-width: 252px;
    }

/* Schermi con altezza fino a 500px */
@media (max-height: 500px) {
    #logo {
        max-height: 10vh;
    }
}

/* Schermi con altezza tra 501px e 800px */
@media (min-height: 501px) and (max-height: 800px) {
    #logo {
        max-height: 20vh;
    }
}

/* Schermi con altezza tra 801px e 1200px */
@media (min-height: 801px) and (max-height: 1200px) {
    #logo {
        max-height: 25vh;
    }
}

/* Schermi con altezza maggiore di 1200px */
@media (min-height: 1201px) {
    #logo {
        max-height: 30vh;
    }
}


    /* Stato quando il logo si muove */
    #logo-login.moving {
        transform: scale(0.75); /* Riduzione dimensioni */
        top: 20px; /* Posizione alto */
        left: 0px; /* Posizione sinistra */        
    }
.moving_img {
    transition: transform 1s ease-in-out, top 1s ease-in-out, left 1s ease-in-out;
    max-width: 100%;
}
.moving_img_noanim {
    transition: transform 0s ease-in-out, top 0s ease-in-out, left 0s ease-in-out !important;
    max-width: 100%;
    transform: scale(0.75) !important; /* Riduzione dimensioni */
    top: 20px !important; /* Posizione alto */
    left: 0px !important; /* Posizione sinistra */
}

.footer-info {
    position: absolute;
    width: -webkit-fill-available;
    bottom: 0px;
    display: flex;
    left: 0px;
    align-content: center;
    align-items: flex-end;
    flex-wrap: nowrap;
    justify-content: center;
    color:black;
    font-size:0.9em;
}
.footer-info-image {
    position: absolute;
    bottom: 108px;
    left: 0;
    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    align-items: center;
    width: -webkit-fill-available;
}
#login-form {
    width: 300px;
    display: flex;
    flex-direction: column;
}

    #login-form input {
        margin-bottom: 15px;
        padding: 10px;
        font-size: 1rem;
    }

    #login-form button {
        padding: 10px;
        font-size: 1rem;
    }
        #login-form input:focus, #login-form button:focus {
            outline: none;
            box-shadow: 0 0 5px rgba(0, 117, 190, 0.7);
        }


.hidden {
    display: none !important;
}



/*Tabelle*/
/* Stile generale della tabella */
/* Tabella template per larghezze */
.table-template {
    visibility: collapse; /* Nasconde la tabella ma mantiene larghezze */
    position: absolute;
    top: 0;
    left: 0;
}

.parent-container {
    height: 90vh; /* Altezza massima pari allo schermo */
    display: flex; /* Layout flessibile */
    flex-direction: column; /* Contenuti in colonna */
    z-index:99999;
}
.table-container {
    display: flex;
    flex-direction: column;
    height: 94vh; /* Altezza massima disponibile */    
    width: -webkit-fill-available;
}
/* Header fisso */
.table-header {
    display: flex;
    flex-direction: column;
    margin-bottom:-16px;
}

/* Corpo scrollabile */
.table-body {
    flex: 1 1 auto; /* Occupa lo spazio rimanente */
    overflow-y: auto; /* Scorrimento verticale */
}

/* Footer fisso */
.table-footer {
    flex: 0 0 auto; /* Altezza fissa */
    margin-top: -16px;
}
.table {
    width: 100%;
    border-collapse: collapse;
    background: rgba(255, 255, 255, 0.8); /* Sfondo trasparente bianco all'80% */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Leggera ombreggiatura */
    border-radius: 8px; /* Bordo arrotondato */
    overflow: hidden; /* Evita che il contenuto fuoriesca */
    word-wrap: break-word; /* Permette la rottura delle parole lunghe */
    word-break: break-word; /* Gestisce la rottura delle parole */
    white-space: pre-wrap; /* Mantiene i ritorni a capo */
}
/* Personalizzazione della scrollbar per WebKit (Chrome, Safari, Edge) */
    .table-body::-webkit-scrollbar {
    width: 12px; /* Larghezza della scrollbar */
}

.table-body::-webkit-scrollbar-track {
    background: rgba(0, 117, 190,0.5); /* Colore del track (sfondo della scrollbar) */
    border-radius: 6px;
}

.table-body::-webkit-scrollbar-thumb {
    background-color: #AAA; /* Colore del cursore */
    border-radius: 6px;
    border: 3px solid #f0f0f0; /* Spessore e colore intorno al cursore */
}

    .table-body::-webkit-scrollbar-thumb:hover {
        background-color: #555; /* Colore del cursore al passaggio del mouse */
    }


    /* Stile dell'intestazione */
    .table thead {
        background: #0075BE; /* Colore blu per l'intestazione */
        color: white; /* Testo bianco */
        text-transform: uppercase; /* Testo in maiuscolo */
        font-size: 1rem; /* Dimensione leggibile */
        font-weight: bold;
    }

        /* Stile per le celle dell'intestazione */
        .table thead th {
            padding: 10px;
            text-align: left; /* Allineamento a sinistra */
            border-bottom: 2px solid white; /* Separatore tra intestazione e dati */
            position: sticky; /* Mantiene l'header fisso */
            top: 0;
            z-index: 1;
            cursor: pointer;
            user-select: none;
        }

    /* Stile delle righe dei dati */
    .table tbody tr {
        transition: background-color 0.3s ease; /* Effetto hover */
    }

        .table tbody tr:nth-child(odd) {
            background: rgba(0, 117, 190, 0.1); /* Alternanza di righe */
        }

        .table tbody tr:nth-child(even) {
            background: rgba(0, 117, 190, 0.05); /* Colore pi� chiaro per le righe pari */
        }

    /* Stile per le celle dei dati */
    .table tbody td {
        padding: 10px;
        text-align: left; /* Allineamento a sinistra */
        color: #333; /* Testo scuro */        
    }

    /* Stile per il focus al passaggio del mouse */
    .table tbody tr:hover {
        background-color: rgba(0, 117, 190, 0.3); /* Evidenziazione della riga */
        cursor: pointer;
    }
.selected {
    background-color: rgba(0, 117, 190, 0.7) !important; /* Evidenziazione della riga */    
}
    /*
        STILE PER ROUND BOX DI OGGETTI
    */
.roundbox {
    border-radius: 5px;
    border: 1px solid white;
    display: flex;
    flex-wrap: wrap;
    padding: 1em;
    padding-top: 1.5em;
}
.roundbox_title {
    position: relative;
    top: 17px;
    left: 1em;
    font-weight: bolder;
    letter-spacing:0.2em;
    font-size: 1.5em;
    background-color: rgba(255, 255, 255, 1);
    width: fit-content;
    padding: 0.1em;
    padding-right: 0.5em;
    padding-left: 0.5em;
    border-radius:5px;
}
.roundbox_options {   
    position:relative;
    display:inline-flex;
}
.roundbox_label {
    font-weight: bolder;
    font-size: 1em;
    margin-left: 5px;
    letter-spacing: 0.1em;
    margin-bottom: 0px; /* Margine inferiore tra la label e l'input */
}
form {
    display: flex;
    flex-wrap: wrap;
    width: -webkit-fill-available;
    gap: 10px; /* Spaziatura tra i campi */
}
.form-group {
    display: flex;
    flex-direction: column; /* Posiziona la label sopra l'input */
    flex: 1; /* Consente ai campi di occupare lo spazio disponibile */
    min-width: 150px; /* Imposta una larghezza minima per evitare sovrapposizioni */
    max-width:300px;
}
.form-group_full {
    display: flex;
    flex-direction: column; /* Posiziona la label sopra l'input */
    flex: 1; /* Consente ai campi di occupare lo spazio disponibile */
    min-width: 100%; /* Imposta una larghezza minima per evitare sovrapposizioni */
    max-width: 100%;
}
.form-group input {
    margin-bottom: 10px;
    min-height: 45px;
    padding: 0.5em;
}
.form-group select {
    margin-bottom: 10px;
    min-height: 45px;
    padding:0.5em;
}
.submit_button {
    background-color: rgb(160, 221, 117);
    border: 1px solid #FFF;
    border-radius: 5px;
    padding: 0em;
    font-size:2em;
    letter-spacing:0.2em;
}
.submit_button:hover {
    background-color: rgba(160, 221, 117,0.5);
}
    .submit_button:active {
        background-color: rgba(120, 180, 90, 0.7); /* Colore durante il click */
        transition:ease 0.1s;
        transform: scale(0.99); /* Piccola animazione per un effetto "pressione" */
    }

.precedenti_abbinati {
    background-color: rgba(255, 0, 0, 0.5)!important;
}
.precedenti_abbinati_txt {
    color: rgba(255, 0, 0, 0.5) !important;
}

.odierni_abbinati {
    background-color: rgba(0, 0, 255, 0.5)!important;
}
.odierni_abbinati_txt {
    color: rgba(0, 0, 255, 0.5) !important;
}

.successivi_non_abbinati {
    background-color: rgba(255, 255, 0, 0.5)!important;
}
.successivi_non_abbinati_txt {
    color: rgb(175 147 1) !important
}