/* /Components/Auth/Login.razor.rz.scp.css */
.login-container[b-1suo6wqrjo] {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    background: linear-gradient(180deg, #002C3E 70%, #DB9300 180%);
}

.login-box[b-1suo6wqrjo] {
    background-color: rgba(255, 255, 255, 0.08);
    padding: 40px;
    border-radius: 12px;
    box-shadow: 0 6px 25px rgba(0,0,0,0.4);
    text-align: center;
    width: 400px;
    backdrop-filter: blur(6px);
    color: #ffffff;
}

.login-logo[b-1suo6wqrjo] {
    width: 140px;
    margin-bottom: 20px;
    filter: drop-shadow(0 0 5px rgba(0,0,0,0.3));
}

.dxbl-textbox input[b-1suo6wqrjo] {
    border: 1px solid #DB9300;
    border-radius: 6px;
    padding: 8px 10px;
    background-color: #ffffff;
    color: #002C3E;
    font-size: 15px;
}

.dxbl-button[b-1suo6wqrjo] {
    width: 100%;
    background-color: #DB9300 !important;
    color: #002C3E !important;
    font-weight: bold;
    border: none;
    border-radius: 6px;
    padding: 10px;
    transition: background-color 0.2s ease-in-out;
}

    .dxbl-button:hover[b-1suo6wqrjo] {
        background-color: #e8a526 !important;
    }

.footer-bar[b-1suo6wqrjo] {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: #001e29;
    color: #ffffff;
    text-align: center;
    padding: 10px 0;
    font-size: 14px;
}


.login-actions[b-1suo6wqrjo] {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 20px;
    gap: 10px;
}

/* Pulsante principale */
.login-btn[b-1suo6wqrjo] {
    width: 100%;
    background-color: #DB9300 !important;
    color: #002C3E !important;
    font-weight: 600;
    font-size: 16px;
    border-radius: 6px;
    padding: 10px 0;
    box-shadow: 0 3px 8px rgba(0,0,0,0.2);
    transition: all 0.2s ease-in-out;
}

    .login-btn:hover[b-1suo6wqrjo] {
        background-color: #e8a526 !important;
        transform: translateY(-1px);
        box-shadow: 0 4px 10px rgba(0,0,0,0.25);
    }

/* Link "Password dimenticata?" */
.forgot-link[b-1suo6wqrjo] {
    font-size: 14px;
    color: #DB9300;
    text-decoration: none;
    transition: color 0.2s;
}

    .forgot-link:hover[b-1suo6wqrjo] {
        text-decoration: underline;
        color: #e8a526;
    }
/* /Components/Auth/ResetPassword.razor.rz.scp.css */
.Container[b-inl4ti1538] {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    background: linear-gradient(180deg, #002C3E 70%, #DB9300 180%);
    font-family: 'Segoe UI', Arial, sans-serif;
}

.MailFormContainer[b-inl4ti1538] {
    background-color: rgba(255, 255, 255, 0.08);
    padding: 40px;
    border-radius: 12px;
    box-shadow: 0 6px 25px rgba(0,0,0,0.4);
    text-align: center;
    width: 400px;
    backdrop-filter: blur(6px);
    color: #ffffff;
}

.TitleContainer[b-inl4ti1538] {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 20px;
}

    .TitleContainer h2[b-inl4ti1538] {
        color: #ffffff;
        margin-bottom: 10px;
        font-size: 22px;
    }

    .TitleContainer p[b-inl4ti1538] {
        color: #ddd;
        font-size: 15px;
        text-align: center;
    }

/* Input */
.FormInput[b-inl4ti1538] {
    all: unset;
    width: 100%;
    padding: 10px 12px;
    font-size: 15px;
    border: 1px solid #DB9300;
    border-radius: 6px;
    background-color: #ffffff;
    color: #002C3E;
    box-sizing: border-box;
    transition: all 0.2s ease-in-out;
}

    .FormInput:focus[b-inl4ti1538] {
        border-color: #e8a526;
        box-shadow: 0 0 6px rgba(219, 147, 0, 0.6);
        outline: none;
    }

/* Pulsante */
.ButtonChange[b-inl4ti1538] {
    width: 100%;
    padding: 10px;
    font-size: 16px;
    border-radius: 6px;
    border: none;
    background-color: #DB9300;
    color: #002C3E;
    font-weight: bold;
    margin-top: 20px;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out, transform 0.1s ease-in-out;
}

    .ButtonChange:hover[b-inl4ti1538] {
        background-color: #e8a526;
        transform: translateY(-1px);
    }

/* Messaggi di errore o info */
.Message[b-inl4ti1538] {
    font-size: 14px;
    color: #DB9300;
    margin-top: 10px;
}

/* Responsive */
@media (max-width: 480px) {
    .MailFormContainer[b-inl4ti1538] {
        width: 90%;
        padding: 25px;
    }

    .TitleContainer h2[b-inl4ti1538] {
        font-size: 20px;
    }
}
/* /Components/CommessaCard.razor.rz.scp.css */

/* Card singola */
.card[b-clqc82o1xk] {
    width: 280px;
    border-radius: 15px;
    background: var(--eim-blue);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(219, 147, 0, 0.4); /* contorno dorato */
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    color: white;
}

    .card:hover[b-clqc82o1xk] {
        transform: translateY(-5px);
        box-shadow: 0 8px 20px rgba(0, 0, 0, 0.35);
        border-color: var(--eim-gold);
    }

/* Testo card */
.text[b-clqc82o1xk] {
    padding: 18px;
}

.title[b-clqc82o1xk] {
    font-size: 1.2em;
    font-weight: 700;
    margin-bottom: 5px;
    color: white;
}

.subtitle[b-clqc82o1xk] {
    font-size: 0.9em;
    color: var(--eim-gold);
    margin-bottom: 10px;
}

.dates[b-clqc82o1xk] {
    font-size: 0.85em;
    display: flex;
    flex-direction: column;
    gap: 4px;
    color: #f5f5f5;
}

/* Stato commessa */
.status[b-clqc82o1xk] {
    text-align: center;
    padding: 10px 0;
    font-weight: 600;
    font-size: 1em;
    letter-spacing: 0.5px;
}

    .status.open[b-clqc82o1xk] {
        background: var(--eim-gold);
        color: var(--eim-blue);
    }

    .status.closed[b-clqc82o1xk] {
        background: #6c757d;
        color: #fff;
    }

/* Responsive */
@media (max-width: 768px) {
    .card[b-clqc82o1xk] {
        width: 90%;
    }
}
/* /Components/ElencoFilesAllegatiView.razor.rz.scp.css */
/* =========================================================
   DETTAGLIO PROGETTO – VERSIONE COMPATTA
   ========================================================= */

.project-info[b-892n7k0nbx] {
    background: #f5f7f8;
    border: 1px solid var(--eim-gold);
    border-radius: 10px;
    padding: 1.2rem 1.5rem;
    margin-bottom: 1.5rem;
}

.project-title[b-892n7k0nbx] {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--eim-blue);
    margin-bottom: 0.6rem;
}

.project-meta[b-892n7k0nbx] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 2rem;
    font-size: 0.95rem;
}

    .project-meta div[b-892n7k0nbx] {
        color: #333;
    }

    .project-meta strong[b-892n7k0nbx] {
        font-weight: 600;
        color: #002b36;
    }


/* =========================================================
   STATO PROGETTO
   ========================================================= */

.project-status[b-892n7k0nbx] {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 600;
    margin-left: 0.3rem;
}

    .project-status.open[b-892n7k0nbx] {
        background-color: rgba(34, 197, 94, 0.15);
        color: #15803d;
    }

    .project-status.closed[b-892n7k0nbx] {
        background-color: rgba(239, 68, 68, 0.15);
        color: #b91c1c;
    }
/* /Components/Layout/Drawer.razor.rz.scp.css */
[b-vbsanav23a] .navigation-drawer {
    --dxbl-drawer-panel-footer-justify-content: center;
    height: 100vh;
    max-height: 100%;
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel {
    background-image: linear-gradient(180deg, var(--bs-primary, var(--DS-primary-90)) 0%, var(--bs-black, #000) 150%);
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-content {
    height: 100vh;
    overflow: auto;
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel > .dxbl-drawer-header {
    border-bottom: none;
    padding: 2rem 1rem;
    background: none;
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel > .dxbl-drawer-header > .navigation-drawer-header {
    width: 100%;
    display: flex;
    justify-content: space-between;
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel > .dxbl-drawer-body {
    --dxbl-drawer-panel-body-padding-x: 0;
    --dxbl-drawer-panel-body-padding-y: 1rem;
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel > .dxbl-drawer-footer {
    --dxbl-drawer-panel-footer-justify-content: center;
    border-top: none;
    padding-bottom: 1.5rem;
    background: none;
}

[b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel {
    display: flex;
}

[b-vbsanav23a] .navigation-drawer.mobile > .dxbl-drawer-panel {
    display: none;
}

[b-vbsanav23a] .navigation-drawer.mobile > .dxbl-drawer-shading {
    display: none;
}

@media (max-width: 768px) {
    [b-vbsanav23a] .navigation-drawer > .dxbl-drawer-panel {
        display: none;
    }

    [b-vbsanav23a] .navigation-drawer.mobile > .dxbl-drawer-panel {
        display: flex;
    }

    [b-vbsanav23a] .navigation-drawer.mobile > .dxbl-drawer-shading {
        display: block;
    }
}

[b-vbsanav23a] .panel-open:not(.mobile) .menu-button {
    display: none;
}

@media (max-width: 768px) {
    [b-vbsanav23a] .panel-open:not(.mobile) .menu-button {
        display: inline-flex;
    }

    .mobile-drawer-closed .shading-copy[b-vbsanav23a] {
        display: none;
        visibility: hidden;
    }

    [b-vbsanav23a] .shading-copy {
        background-color: var(--dxbl-drawer-content-shading-bg);
        height: 100%;
        position: absolute;
        transition: opacity ease var(--dxbl-drawer-animation-duration);
        visibility: visible;
        width: 100%;
        z-index: 99;
        opacity: var(--dxbl-drawer-content-shading-opacity);
    }

    [b-vbsanav23a] .panel-open .shading-copy {
        opacity: 0;
        visibility: unset;
        height: unset;
    }
}
/* /Components/Layout/MainLayout.razor.rz.scp.css */

/* === DRAWER COMPLETO (sfondo e testo) === */
[b-7c4glh9q4a] .dxbl-drawer,
[b-7c4glh9q4a] .dxbl-drawer-header,
[b-7c4glh9q4a] .dxbl-drawer-body,
[b-7c4glh9q4a] .dxbl-drawer-content,
[b-7c4glh9q4a] .dxbl-drawer-footer {
    background-color: var(--eim-blue) !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

[b-7c4glh9q4a] .icon-menu {
    --icon-mask-image: var(--icon-menu-mask-image);
}

[b-7c4glh9q4a] .icon-back {
    --icon-mask-image: var(--icon-back-mask-image);
}

/* === HEADER CON LOGO === */
.navigation-drawer-header[b-7c4glh9q4a] {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 0;
    height: 140px;
    background-color: var(--eim-blue);
}

.logo-eim[b-7c4glh9q4a] {
    height: 55px;
    width: auto;
    object-fit: contain;
    filter: drop-shadow(0 0 3px rgba(0, 0, 0, 0.25));
}

/* === VOCI DI MENU === */
[b-7c4glh9q4a] .dxbl-nav-item {
    color: #ffffff !important;
    font-weight: 500;
    margin: 4px 10px;
    border-radius: 5px;
    transition: all 0.2s ease;
}

    [b-7c4glh9q4a] .dxbl-nav-item:hover {
        background-color: rgba(219, 147, 0, 0.2);
        color: var(--eim-gold) !important;
    }

    [b-7c4glh9q4a] .dxbl-nav-item .dxbl-icon {
        color: #ffffff !important;
        transition: color 0.2s ease;
    }

    [b-7c4glh9q4a] .dxbl-nav-item:hover .dxbl-icon {
        color: var(--eim-gold) !important;
    }


.drawer-footer[b-7c4glh9q4a] {
    position: relative;
    width: 100%;
    background-color: var(--eim-blue);
    color: var(--eim-gold);
    text-align: center;
    padding: 0;
    overflow: hidden;
}

/* BARRA DORATA ORIZZONTALE */
.footer-barra-visibile[b-7c4glh9q4a] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 10px;
    background: var(--eim-gold);
    transform: skewX(-35deg);
    transform-origin: left center;
    z-index: 5;
}

/* CONTENUTO TESTUALE */
.footer-content[b-7c4glh9q4a] {
    position: relative;
    z-index: 10;
    padding: 20px 0;
}

/* LINK EFFETTO ORO */
.footer-link[b-7c4glh9q4a] {
    color: var(--eim-gold);
    font-weight: 600;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s ease, opacity 0.2s ease;
}

    .footer-link:hover[b-7c4glh9q4a] {
        opacity: 0.8;
        color: #ffcc55;
    }

/* === RESPONSIVE HEADER === */
@media (max-height: 700px) {
    .navigation-drawer-header[b-7c4glh9q4a] {
        padding: 25px 0;
        height: 110px;
    }

    .logo-eim[b-7c4glh9q4a] {
        height: 45px;
    }
}
/* /Components/Layout/NavMenu.razor.rz.scp.css */

/* === SIDEBAR === */
#sidebar[b-fggmehggu3] {
    min-width: 15rem;
    max-width: 15rem;
    transition: transform 0.1s ease-out;
    height: 100%;
    max-height: 100%;
    display: block;
    background: inherit;
}

.logo[b-fggmehggu3] {
    text-align: center;
}

[b-fggmehggu3] .menu.display-mobile,
[b-fggmehggu3] .menu.display-iam {
    margin-bottom: 2rem;
}

[b-fggmehggu3] .menu {
    background-color: inherit;
    --dxbl-menu-bottom-left-border-radius: 0;
    --dxbl-menu-bottom-right-border-radius: 0;
    --dxbl-menu-top-left-border-radius: 0;
    --dxbl-menu-top-right-border-radius: 0;
}

    [b-fggmehggu3] .menu .dxbl-menu-item-list {
        gap: 0.5rem;
    }

/* === TESTO === */
[b-fggmehggu3] .menu-item {
    color: var(--eim-gold) !important;
    font-weight: 500;
    display: flex;
    align-items: center;
}

    /* Hover: oro più chiaro sul testo */
    [b-fggmehggu3] .menu-item:hover {
        color: #ffc94d !important;
    }

    /* Selezionato: testo bianco su sfondo oro */
    [b-fggmehggu3] .menu-item.dxbl-menu-item-selected {
        background-color: var(--eim-gold) !important;
        color: #ffffff !important;
    }

/* === RESPONSIVE === */
@media (max-width: 768px) {
    #sidebar[b-fggmehggu3] {
        min-width: inherit;
        max-width: inherit;
        display: block;
    }

    .logo[b-fggmehggu3] {
        text-align: inherit;
    }
}
/* /Components/Pages/ChangePassword.razor.rz.scp.css */
.WrapperError[b-99cf9z5diz] {
    display: flex;
    flex-direction: column;
    row-gap: 35px;
    align-items: center;
    justify-content: center;
}

.ErrorMessage[b-99cf9z5diz] {
    font-size: clamp(1rem, 0.4012rem + 3.8323vw, 5rem);
    text-align: center;
    font-weight: 700;
    color: var(--eim-blue);
}

.BackToHome[b-99cf9z5diz] {
    background-color: var(--eim-blue);
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 15px 45px;
    border-radius: 10px;
    cursor: pointer;
    transition: .25s ease-in-out;
}

    .BackToHome:hover[b-99cf9z5diz] {
        background-color: var(--eim-gold);
        color: #000;
        transition: .25s ease-in-out;
        padding-bottom: 18px;
        padding-top: 12px;
    }



.Container[b-99cf9z5diz] {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
    width: 100%;
    background: linear-gradient(180deg, #002C3E 70%, #DB9300 180%);
}

.ChangePasswordFormContainer[b-99cf9z5diz] {
    background-color: rgba(255, 255, 255, 0.08);
    padding: 40px;
    border-radius: 12px;
    box-shadow: 0 6px 25px rgba(0,0,0,0.4);
    text-align: center;
    width: 400px;
    backdrop-filter: blur(6px);
    color: #ffffff;
    display: flex;
    flex-direction: column;
    row-gap: 25px;
}

.TitleContainer[b-99cf9z5diz] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #ffffff;
}

    .TitleContainer p[b-99cf9z5diz] {
        text-align: center;
    }

.InputWrapper[b-99cf9z5diz] {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    row-gap: 6px;
}

.InpuContainer[b-99cf9z5diz] {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
    position: relative;
}

.InputWrapper label[b-99cf9z5diz] {
    color: #ffffff;
}

.FormInput[b-99cf9z5diz] {
    all: unset;
    padding: 7px 13px;
    font-size: 1rem;
    border: 1px solid #DB9300;
    border-bottom-left-radius: 7px;
    border-top-left-radius: 7px;
    background-color: #ffffff;
    color: #002C3E;
    transition: all 0.2s ease;
    width: 100%;
    height: 34px;
    border-right: none;
}

    .FormInput:focus[b-99cf9z5diz] {
        border-color: #e8a526;
        box-shadow: 0 0 0 3px rgba(232, 165, 38, 0.25);
        outline: none;
    }

    .FormInput:hover[b-99cf9z5diz] {
        border-color: #e8a526;
    }

    .FormInput.error[b-99cf9z5diz] {
        border-color: darkred;
    }

    .FormInput:valid[b-99cf9z5diz] {
        border-color: forestgreen;
    }

.TogglePassword[b-99cf9z5diz] {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    border: 2px solid #DB9300;
    border-radius: 50%;
    background-color: rgba(0, 44, 62, 0.85);
    color: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    box-shadow: 0 2px 6px rgba(0,0,0,0.25);
}

    .TogglePassword:hover[b-99cf9z5diz] {
        background-color: #e8a526;
        border-color: #e8a526;
        color: #002C3E;
        transform: translateY(-50%) scale(1.05);
    }


        /* Effetti hover e focus del bottone */
        .TogglePassword:hover + .FormInput[b-99cf9z5diz] {
            border-color: #e8a526;
        }


/* Effetti hover e focus del bottone */
.FormInput:hover + .TogglePassword[b-99cf9z5diz] {
    border-color: #e8a526;
}

.FormInput:focus + .TogglePassword[b-99cf9z5diz] {
    box-shadow: 0 0 0 3px rgba(232, 165, 38, 0.25);
}

/* Stati condizionali: solo se hai JS che applica classi dinamiche */
.FormInput.error + .TogglePassword[b-99cf9z5diz] {
    border-color: darkred;
}

.FormInput.valid + .TogglePassword[b-99cf9z5diz] {
    border-color: forestgreen;
}

.IconaPassword[b-99cf9z5diz] {
    fill: currentColor;
    height: 60%;
}

.ChangeForm[b-99cf9z5diz] {
    row-gap: 20px;
    display: flex;
    flex-direction: column;
}

.ButtonChange[b-99cf9z5diz] {
    width: 100%;
    padding: 0.75rem;
    font-size: 1rem;
    border-radius: 8px;
    background-color: #DB9300;
    border: none;
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
    color: #002C3E;
    margin-top: 8px;
}

    .ButtonChange:hover[b-99cf9z5diz] {
        background-color: #e8a526;
        color: #002C3E;
    }
/* /Components/Pages/Counter.razor.rz.scp.css */
.counter-block[b-b0envfoucz] {
    display: flex;
    padding: 2.5rem 1.5rem 1.5rem 1.5rem;
    flex-direction: column;
    border-radius: 1rem;
    gap: 1.5rem;
    justify-content: center;
    align-items: center;
    width: 16.875rem;
    height: 17rem;
    position: relative;
}

    .counter-block .counter-content[b-b0envfoucz] {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
    }

    .counter-block .counter-count[b-b0envfoucz] {
        font-size: 7.5rem;
        font-weight: 400;
        line-height: 7.75rem;
    }

    .counter-block .counter-block-back[b-b0envfoucz] {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: var(--bs-body-color, var(--DS-color-content-neutral-default-rest));
        opacity: 0.05;
        border-radius: 1rem;
        z-index: -2;
    }
/* /Components/Pages/DettaglioDocumento.razor.rz.scp.css */


/* === STRUTTURA PAGINA === */
.page-wrapper[b-vapqto9zwo] {
    padding: 2rem;
}

.page-header[b-vapqto9zwo] {
    border-bottom: 2px solid var(--eim-gold);
    margin-bottom: 1.5rem;
}

    .page-header h2[b-vapqto9zwo] {
        color: var(--eim-blue);
        margin: 0;
    }

    .page-header p[b-vapqto9zwo] {
        color: white;
        margin: 0.3rem 0 0;
    }

.doc-info[b-vapqto9zwo] {
    background: #f5f7f8;
    border: 1px solid var(--eim-gold);
    border-radius: 10px;
    padding: 1.2rem 1.5rem;
    margin-bottom: 1rem;
}

.doc-header[b-vapqto9zwo] {
    display: grid;
    grid-template-columns: 2fr 1fr auto;
    align-items: center;
    gap: 1rem;
}

/* --- Colonna sinistra --- */
.doc-title[b-vapqto9zwo] {
    font-size: 1.4rem;
    color: #002b36;
    margin-bottom: 0.5rem;
}

.doc-meta[b-vapqto9zwo] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem 2rem;
    font-size: 0.95rem;
}

.doc-meta div[b-vapqto9zwo] {
    color: #333;
}

/* --- Colonna destra (totale) --- */
.doc-total[b-vapqto9zwo] {
    text-align: right;
}

.total-label[b-vapqto9zwo] {
    display: block;
    font-size: 0.85rem;
    color: #666;
    margin-bottom: 0.2rem;
}

.total-value[b-vapqto9zwo] {
    font-size: 1.4rem;
    font-weight: 700;
    color: #00384d;
}

/* --- Responsive --- */
@media (max-width: 992px) {
    .doc-header[b-vapqto9zwo] {
        grid-template-columns: 1fr auto;
        grid-template-rows: auto auto;
    }

    .doc-total[b-vapqto9zwo] {
        grid-column: 1 / -1;
        text-align: right;
        margin-top: 0.5rem;
    }
}

@media (max-width: 600px) {
    .doc-header[b-vapqto9zwo] {
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }

    .doc-total[b-vapqto9zwo] {
        text-align: left;
        margin-top: 0.5rem;
    }
}


/* === INFO PANEL === */
.info-panel[b-vapqto9zwo] {
    background-color: #f9fafb;
    border-left: 4px solid var(--eim-gold);
    padding: 1.2rem 1.5rem;
    border-radius: 8px;
    margin-top: 2rem;
}

    .info-panel h4[b-vapqto9zwo] {
        color: var(--eim-blue);
        margin-bottom: 0.5rem;
    }

/* === GRIGLIA === */
[b-vapqto9zwo] .my-grid {
    border-radius: 8px;
    overflow: hidden;
}


/* === ALLEGATI === */
/* === ALLEGATI GRID === */
.allegati-list[b-vapqto9zwo] {
    list-style: none;
    margin: 1.5rem 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 1rem;
}

/* Card compatta */
.allegato-item[b-vapqto9zwo] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    background-color: #fff;
    border: 1px solid #e3e6eb;
    border-left: 4px solid var(--eim-gold);
    padding: 1rem 1.2rem;
    border-radius: 10px;
    transition: all 0.2s ease;
}

    .allegato-item:hover[b-vapqto9zwo] {
        box-shadow: 0 3px 8px rgba(0,0,0,0.08);
        transform: translateY(-1px);
    }

/* Contenuto file */
.file-info[b-vapqto9zwo] {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    flex: 1;
    overflow: hidden;
}

.file-icon[b-vapqto9zwo] {
    font-size: 1.6rem;
    color: var(--eim-blue);
    flex-shrink: 0;
    margin-top: 0.3rem;
}

.file-details[b-vapqto9zwo] {
    flex: 1;
    min-width: 0;
}

    .file-details strong[b-vapqto9zwo] {
        color: var(--eim-blue);
        font-size: 1rem;
        display: block;
        margin-bottom: 0.2rem;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .file-details .desc[b-vapqto9zwo] {
        margin: 0;
        color: #555;
        font-size: 0.85rem;
    }

.file-meta[b-vapqto9zwo] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1rem;
    margin-top: 0.4rem;
}

    .file-meta .meta-item[b-vapqto9zwo] {
        font-size: 0.85rem;
        color: #666;
    }

        .file-meta .meta-item.amount[b-vapqto9zwo] {
            font-weight: 600;
            color: var(--eim-blue);
        }

.stato[b-vapqto9zwo] {
    display: inline-block;
    background-color: rgba(219, 147, 0, 0.1);
    color: var(--eim-gold);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    margin-top: 0.2rem;
}

/* Pulsante circolare (già definito sopra) */
.Btn[b-vapqto9zwo] {
    margin-left: 0.8rem;
    flex-shrink: 0;
}


.file-info[b-vapqto9zwo] {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    flex: 1;
}

.file-icon[b-vapqto9zwo] {
    font-size: 1.8rem;
    color: var(--eim-blue);
    flex-shrink: 0;
    margin-top: 0.2rem;
}

    /* Differenzia icone per tipo */
    .file-icon .fa-file-pdf[b-vapqto9zwo] {
        color: #c0392b;
    }
    /* rosso PDF */
    .file-icon .fa-file-image[b-vapqto9zwo] {
        color: #16a085;
    }
    /* verde immagine */
    .file-icon .fa-file[b-vapqto9zwo] {
        color: var(--eim-blue);
    }
/* blu default */

.file-details[b-vapqto9zwo] {
    flex: 1;
}

    .file-details strong[b-vapqto9zwo] {
        color: var(--eim-blue);
        font-size: 1rem;
        display: block;
        margin-bottom: 0.2rem;
    }

    .file-details .desc[b-vapqto9zwo] {
        margin: 0;
        color: #555;
        font-size: 0.85rem;
        line-height: 1.3;
    }

.file-meta[b-vapqto9zwo] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1rem;
    margin-top: 0.4rem;
}

    .file-meta .meta-item[b-vapqto9zwo] {
        font-size: 0.85rem;
        color: #666;
    }

        .file-meta .meta-item.amount[b-vapqto9zwo] {
            font-weight: 600;
            color: var(--eim-blue);
        }

/* Badge stato */
.stato[b-vapqto9zwo] {
    display: inline-block;
    background-color: rgba(219, 147, 0, 0.1);
    color: var(--eim-gold);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    margin-top: 0.4rem;
}

.action-btn-outline[b-vapqto9zwo] {
    background: transparent;
    border: 1px solid var(--eim-gold);
    color: var(--eim-gold);
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 0.85rem;
    transition: all 0.2s ease;
}

    .action-btn-outline:hover[b-vapqto9zwo] {
        background-color: var(--eim-gold);
        color: white;
        transform: translateY(-1px);
    }

.no-allegati[b-vapqto9zwo] {
    color: #555;
    font-size: 0.9rem;
    margin-top: 0.5rem;
    font-style: italic;
}


.Btn[b-vapqto9zwo] {
    width: 48px;
    height: 48px;
    border: none;
    border-radius: 50%;
    background-color: var(--eim-blue);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    position: relative;
    transition: all 0.3s ease;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.15);
}

.svgIcon[b-vapqto9zwo] {
    fill: var(--eim-gold);
    transition: all 0.3s ease;
}

.icon2[b-vapqto9zwo] {
    width: 23px;
    height: 5px;
    border-bottom: 2px solid var(--eim-gold);
    border-left: 2px solid var(--eim-gold);
    border-right: 2px solid var(--eim-gold);
    transition: all 0.3s ease;
    padding-bottom: 5px;
    margin-bottom: 7px;
}

.tooltip[b-vapqto9zwo] {
    position: absolute;
    right: -105px;
    opacity: 0;
    background-color: var(--eim-blue);
    color: white;
    padding: 5px 10px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    pointer-events: none;
    letter-spacing: 0.5px;
    font-size: 0.85rem;
}

    .tooltip[b-vapqto9zwo]::before {
        position: absolute;
        content: "";
        width: 10px;
        height: 10px;
        background-color: var(--eim-blue);
        transform: rotate(45deg);
        left: -5%;
    }

.Btn:hover .tooltip[b-vapqto9zwo] {
    opacity: 1;
    transition-duration: .3s;
}

.Btn:hover[b-vapqto9zwo] {
    background-color: var(--eim-gold);
    transform: translateY(-2px);
}

    .Btn:hover .icon2[b-vapqto9zwo] {
        border-color: white;
    }

    .Btn:hover .svgIcon[b-vapqto9zwo] {
        fill: white;
        animation: slide-in-top-b-vapqto9zwo 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
    }

@keyframes slide-in-top-b-vapqto9zwo {
    0% {
        transform: translateY(-10px);
        opacity: 0;
    }

    100% {
        transform: translateY(0px);
        opacity: 1;
    }
}
/* /Components/Pages/ElencoCommesse.razor.rz.scp.css */
/* Contenitore generale per le card */
.commesse-container[b-hzlvmhp6g9] {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
    padding: 20px;
}


.page-title[b-hzlvmhp6g9] {
    color: white;
    margin: 10px 20px;
    font-size: 1.4em;
    font-weight: 600;
}

.filter-bar[b-hzlvmhp6g9] {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 20px 20px 20px;
    padding: 10px 15px;
    border-radius: 8px;
    border: 1px solid rgba(219, 147, 0, 0.4);
    background-color: rgba(255, 255, 255, 0.05);
}

[b-hzlvmhp6g9](.dxbl-combobox) {
    background-color: var(--eim-blue);
    color: white;
    border-color: var(--eim-gold);
}

[b-hzlvmhp6g9](.dxbl-combobox input) {
    color: white;
}
/* /Components/Pages/ElencoDocumenti.razor.rz.scp.css */
/* === PAGE WRAPPER === */
.page-wrapper[b-zorv7gly72] {
    padding: 2rem;
}

/* === HEADER === */
.page-header[b-zorv7gly72] {
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--eim-gold);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 1rem;
}

.header-left h2[b-zorv7gly72] {
    color: var(--eim-blue);
    margin-bottom: 0.3rem;
}

.header-left p[b-zorv7gly72] {
    color: white;
    font-size: 0.95rem;
    margin: 0;
}

/* === SELECT MODERNO === */
.anno-label[b-zorv7gly72] {
    color: var(--eim-blue);
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 0.25rem;
    display: block;
}

.anno-select-wrapper[b-zorv7gly72] {
    position: relative;
    display: inline-block;
    width: 160px;
}

.anno-select[b-zorv7gly72] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 100%;
    background-color: #fff;
    border: 2px solid var(--eim-blue);
    border-radius: 8px;
    color: var(--eim-blue);
    font-weight: 600;
    font-size: 0.95rem;
    padding: 8px 36px 8px 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-sizing: border-box;
}

    .anno-select option[b-zorv7gly72] {
        background-color: #ffffff;
        color: var(--eim-blue);
        font-weight: 500;
    }

        .anno-select option:checked[b-zorv7gly72] {
            background-color: var(--eim-gold);
            color: white;
        }

    .anno-select:hover[b-zorv7gly72] {
        border-color: var(--eim-gold);
        box-shadow: 0 0 6px rgba(219, 147, 0, 0.4);
    }

    .anno-select:focus[b-zorv7gly72] {
        outline: none;
        border-color: var(--eim-gold);
        box-shadow: 0 0 8px rgba(219, 147, 0, 0.5);
    }

/* Freccia decorativa oro */
.anno-icon[b-zorv7gly72] {
    position: absolute;
    right: 12px;
    top: 50%;
    width: 10px;
    height: 10px;
    pointer-events: none;
    transform: translateY(-50%) rotate(45deg);
    border-right: 2px solid var(--eim-gold);
    border-bottom: 2px solid var(--eim-gold);
    transition: transform 0.2s ease;
}

.anno-select:focus + .anno-icon[b-zorv7gly72] {
    transform: translateY(-60%) rotate(225deg);
}

/* === INFO PANEL === */
.info-panel[b-zorv7gly72] {
    background-color: #f9fafb;
    border-left: 4px solid var(--eim-gold);
    padding: 1rem 1.5rem;
    border-radius: 8px;
    margin: 2rem 0;
}

    .info-panel h4[b-zorv7gly72] {
        color: var(--eim-blue) !important;
        margin-bottom: 0.5rem;
    }

    .info-panel ul[b-zorv7gly72] {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    .info-panel li[b-zorv7gly72] {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        color: #333;
        font-size: 0.9rem;
    }

/* === LEGEND ICON === */
.legend-icon[b-zorv7gly72] {
    width: 14px;
    height: 14px;
    border-radius: 3px;
    display: inline-block;
}

    .legend-icon.invoice[b-zorv7gly72] {
        background-color: #2E86DE;
    }

    .legend-icon.credit[b-zorv7gly72] {
        background-color: #E67E22;
    }

    .legend-icon.attachment[b-zorv7gly72] {
        background-color: #8E44AD;
    }

/* === GRIGLIA === */
[b-zorv7gly72] .my-grid {
    border-radius: 8px;
    overflow: hidden;
}

.doc-type[b-zorv7gly72] {
    font-weight: 500;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 0.85rem;
    color: white;
}

.doc-invoice[b-zorv7gly72] {
    background-color: #2E86DE;
}

.doc-credit[b-zorv7gly72] {
    background-color: #E67E22;
}

.doc-other[b-zorv7gly72] {
    background-color: #8E44AD;
}

/* === BUTTONS === */
.action-btn[b-zorv7gly72] {
    background-color: var(--eim-gold);
    color: white;
    border: none;
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 0.85rem;
    margin-right: 4px;
    transition: background 0.3s ease;
}

    .action-btn:hover[b-zorv7gly72] {
        background-color: #ffc94d;
    }

.action-btn-outline[b-zorv7gly72] {
    background: transparent;
    border: 1px solid var(--eim-gold);
    color: var(--eim-gold);
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 0.85rem;
    transition: background 0.3s ease, color 0.3s ease;
}

    .action-btn-outline:hover[b-zorv7gly72] {
        background-color: var(--eim-gold);
        color: white;
    }

/* === DXCOMBOBOX ANNO === */
[b-zorv7gly72] .anno-combo {
    width: 160px;
    --dxbl-editor-bg: #ffffff;
    --dxbl-editor-border-color: var(--eim-blue);
    --dxbl-editor-focused-border-color: var(--eim-gold);
    --dxbl-editor-hover-border-color: var(--eim-gold);
    --dxbl-editor-text-color: var(--eim-blue);
    --dxbl-editor-placeholder-color: #777;
    --dxbl-dropdown-bg: #ffffff;
    --dxbl-dropdown-border-color: var(--eim-blue);
    --dxbl-dropdown-item-hover-bg: var(--eim-gold);
    --dxbl-dropdown-item-hover-color: #ffffff;
    --dxbl-dropdown-item-selected-bg: var(--eim-gold);
    --dxbl-dropdown-item-selected-color: #ffffff;
    font-weight: 600;
    border-radius: 8px;
}

[b-zorv7gly72] .dxbl-editor-container {
    border-radius: 8px !important;
}



/* === RESPONSIVE === */
@media (max-width: 768px) {
    .page-header[b-zorv7gly72] {
        flex-direction: column;
        align-items: flex-start;
    }

    .anno-select-wrapper[b-zorv7gly72] {
        width: 100%;
    }

    .kpi-bar[b-zorv7gly72] {
        flex-direction: column;
        gap: 1rem;
    }

    .kpi-container[b-zorv7gly72] {
        max-height: 0;
        opacity: 0;
        pointer-events: none;
    }
}


.page-header[b-zorv7gly72] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px; /* Spazio tra gli elementi */
}

.project-select[b-zorv7gly72] {
    display: flex;
    flex-direction: column;
}

.header-left[b-zorv7gly72] {
    flex: 1;
}

.header-right[b-zorv7gly72] {
    display: flex;
    justify-content: space-between;
    flex: 1;
}

.section-title[b-zorv7gly72] {
    font-size: 16px;
    margin-bottom: 8px;
}

.anno-combo[b-zorv7gly72] {
    padding: 5px;
}


.page-header[b-zorv7gly72] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px; /* Spazio tra gli elementi */
}

.project-select[b-zorv7gly72] {
    display: flex;
    flex-direction: column;
}

.header-left[b-zorv7gly72] {
    flex: 1;
}

.header-right[b-zorv7gly72] {
    display: flex;
    gap: 30px; /* Spazio tra i due combo box */
}

.section-title[b-zorv7gly72] {
    font-size: 16px;
    margin-bottom: 8px;
}

.anno-combo[b-zorv7gly72],
.filtro-progetto[b-zorv7gly72] {
    padding: 5px;
    width: 100%; /* Si adatta alla larghezza disponibile */
    min-width: 250px; /* Imposta una larghezza minima */
}
/* /Components/Pages/Index.razor.rz.scp.css */
[b-z9c9z0vjs9] .welcome-gridlayout {
    margin: auto;
    width: auto;
    height: auto;
}

    [b-z9c9z0vjs9] .welcome-gridlayout .dxbl-gridlayout-root {
        align-content: center;
        justify-content: center;
    }

[b-z9c9z0vjs9] .title {
    text-align: center;
}

[b-z9c9z0vjs9] .welcome-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    justify-content: center;
}

[b-z9c9z0vjs9] .welcome-card {
    width: 26.25rem;
    height: 15rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 0px 4px 6px -1px rgba(0, 0, 0, 0.1), 0px 2px 4px -2px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.2s;
    border-radius: 1rem;
    color: var(--bs-link-color, var(--DS-primary-90));
    gap: 1.5rem;
    text-decoration: none;
    position: relative;
}

    [b-z9c9z0vjs9] .welcome-card:hover {
        box-shadow: 0px 20px 25px -5px rgba(0, 0, 0, 0.1), 0px 8px 10px -6px rgba(0, 0, 0, 0.1);
    }

    [b-z9c9z0vjs9] .welcome-card .welcome-card-img {
        width: 6.5rem;
        height: 6.5rem;
    }

    [b-z9c9z0vjs9] .welcome-card .welcome-card-text {
        font-size: 1.75rem;
        font-weight: 600;
        letter-spacing: 0em;
        text-align: center;
        text-decoration: unset;
    }

    [b-z9c9z0vjs9] .welcome-card .welcome-card-back {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: var(--bs-body-color, var(--DS-color-content-neutral-default-rest));
        opacity: 0.05;
        border-radius: 1rem;
        z-index: -2;
    }



/* START HERO SECTION */
.hero[b-z9c9z0vjs9] {
    position: relative;
    background: url('/images/LogInBg.webp') no-repeat center center/cover;
    padding: 6rem 1rem;
    color: white;
    text-align: center;
}

.hero-overlay[b-z9c9z0vjs9] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #002C3E;
    z-index: 0;
}

.hero-content[b-z9c9z0vjs9] {
    position: relative;
    z-index: 1;
    max-width: 800px;
    margin: auto;
}

.hero h1[b-z9c9z0vjs9] {
    font-size: 3rem;
    margin-bottom: 1rem;
}

.hero p[b-z9c9z0vjs9] {
    font-size: 1.25rem;
    margin-bottom: 2rem;
}

.cta-btn[b-z9c9z0vjs9] {
    padding: 0.8rem 1.5rem;
    background-color: #ffffff;
    color: #0050A3;
    font-weight: bold;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 1rem;
    transition: background 0.3s;
}

    .cta-btn:hover[b-z9c9z0vjs9] {
        background-color: #f0f0f0;
    }
/* END HERO SECTION */

/* START USAGE SECTION */
.usage[b-z9c9z0vjs9] {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    padding: 4rem 1.5rem;
    background-color: white;
}

.usage-text[b-z9c9z0vjs9] {
    flex: 1;
    min-width: 200px;
    padding-right: 2rem;
}

.usage-image[b-z9c9z0vjs9] {
    flex: 1;
    min-width: 200px;
}

    .usage-image img[b-z9c9z0vjs9] {
        max-width: 100%;
        border-radius: 12px;
    }

.usage h2[b-z9c9z0vjs9] {
    font-size: 2rem;
    color: #1b1f3a;
    margin-bottom: 1rem;
}

.usage p[b-z9c9z0vjs9] {
    font-size: 1.05rem;
    color: #333;
    line-height: 1.6;
    margin-bottom: 1rem;
}
/* END USAGE SECTION */
/* /Components/Pages/NotAllowed.razor.rz.scp.css */
/* === PAGINA ACCESSO NEGATO === */
.notallowed-wrapper[b-xz1i361vza] {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: calc(100vh - 120px);
    background-color: #f9fafb;
}

.notallowed-card[b-xz1i361vza] {
    background: #fff;
    border: 1px solid #e3e6eb;
    border-left: 6px solid var(--eim-gold);
    border-radius: 12px;
    padding: 2rem 3rem;
    text-align: center;
    max-width: 500px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
}

.icon-wrapper[b-xz1i361vza] {
    background-color: rgba(219, 147, 0, 0.1);
    color: var(--eim-gold);
    width: 70px;
    height: 70px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2rem;
    margin: 0 auto 1rem;
}

.notallowed-card h2[b-xz1i361vza] {
    color: var(--eim-blue);
    margin-bottom: 0.8rem;
}

.notallowed-card p[b-xz1i361vza] {
    color: #555;
    font-size: 0.95rem;
    line-height: 1.5;
    margin-bottom: 1.5rem;
}

/* Bottone home */
.btn-home[b-xz1i361vza] {
    background-color: var(--eim-blue);
    color: white;
    border: none;
    padding: 0.6rem 1.2rem;
    border-radius: 8px;
    font-size: 0.95rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

    .btn-home i[b-xz1i361vza] {
        margin-right: 0.4rem;
    }

    .btn-home:hover[b-xz1i361vza] {
        background-color: var(--eim-gold);
        color: #fff;
    }
/* /Components/Pages/ProgettoDettaglioPage.razor.rz.scp.css */
.project-detail-card[b-mht3oivhy3] {
    background: #fff;
    border-radius: 8px;
    padding: 18px;
    margin-bottom: 25px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

.detail-label[b-mht3oivhy3] {
    font-size: 0.85rem;
    color: #777;
    margin-bottom: 2px;
    display: block;
}

.detail-value[b-mht3oivhy3] {
    font-size: 1rem;
    font-weight: 500;
    color: #333;
}
/* /Components/Pages/Timesheets.razor.rz.scp.css */
/* === CONTAINER GENERALE === */
.giorni-container[b-yma18bhldn] {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.2em;
    padding: 1em;
}

/* === CARD GIORNALIERA STILE CLOUD === */
.card-time-cloud[b-yma18bhldn] {
    position: relative;
    border-radius: 1em;
    width: 15em;
    height: 7em;
    z-index: 2;
    border: solid 0.15em var(--eim-gold);
    transition: 0.5s all ease-in-out;
    overflow: hidden;
    background: #ffffff;
    box-shadow: 0em 0em rgba(0, 0, 0, 0.25);
    cursor: pointer;
}

/* === LAYER ANIMATI === */
.card-time-cloud-front[b-yma18bhldn] {
    width: 18em;
    height: 11em;
    background: rgba(255, 255, 255, 0.85);
    border-radius: 1em;
    position: absolute;
    z-index: 2;
    top: 95%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.5s all ease-in-out;
}

.card-time-cloud-back[b-yma18bhldn] {
    width: 18em;
    height: 16em;
    background: var(--eim-blue);
    border-radius: 1em;
    position: absolute;
    z-index: 1;
    top: 57.5%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.5s all ease-in-out;
}

    .card-time-cloud-back svg[b-yma18bhldn] {
        position: absolute;
        z-index: 1;
        top: -14em;
        left: -5em;
        width: 22em;
        opacity: 1;
        fill: var(--eim-gold);
        animation: rotate-cloud-b-yma18bhldn 15s linear infinite;
    }

        .card-time-cloud-back svg:nth-child(2)[b-yma18bhldn] {
            animation-delay: 1s;
            opacity: 0.4;
        }

/* === ANIMAZIONE DELLE FORME === */
@keyframes rotate-cloud-b-yma18bhldn {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

/* === TESTO === */
.card-time-cloud-day[b-yma18bhldn] {
    color: var(--eim-blue);
    position: absolute;
    z-index: 3;
    top: 1em;
    left: 0.75em;
    font-size: 1.1em;
    font-weight: 700;
    text-transform: lowercase;
}

.card-time-cloud-hour[b-yma18bhldn] {
    color: var(--eim-blue);
    position: absolute;
    z-index: 3;
    top: 1em;
    right: 0.75em;
    font-size: 1.8em;
    font-weight: 800;
    transition: 0.5s all ease-in-out;
}

.card-time-cloud-day-number[b-yma18bhldn] {
    color: var(--eim-blue);
    position: absolute;
    z-index: 3;
    top: 3em;
    left: 0.9em;
    font-size: 1em;
    font-weight: 500;
    transition: 0.5s all ease-in-out;
}

/* === ICONA SOLE === */
.card-time-cloud-icon svg[b-yma18bhldn] {
    position: absolute;
    z-index: 4;
    bottom: 0.8em;
    right: 0.8em;
    width: 1.6em;
    transition: 0.5s all ease-in-out;
    stroke: var(--eim-gold);
}

/* === EFFETTO HOVER (corretto) === */
.card-time-cloud:hover[b-yma18bhldn] {
    height: 12em;
    box-shadow: 0 1em rgba(219, 147, 0, 0.4);
    transform: translateY(-5px);
}

    .card-time-cloud:hover .card-time-cloud-front[b-yma18bhldn] {
        top: 98%; /* prima era 105% → scende meno */
        z-index: 1; /* spostato sotto agli elementi testuali */
    }

    .card-time-cloud:hover .card-time-cloud-back[b-yma18bhldn] {
        z-index: 0;
    }

/* 🔆 Icona visibile sempre colorata */
.card-time-cloud-icon svg[b-yma18bhldn] {
    z-index: 3;
    stroke: var(--eim-gold); /* colore dorato costante */
    stroke-width: 3;
    fill: none;
    transition: all 0.5s ease;
}

/* Effetto hover solo su dimensione e posizione */
.card-time-cloud:hover .card-time-cloud-icon svg[b-yma18bhldn] {
    bottom: -1em;
    right: -1em;
    width: 6em;
    transform: rotate(-30deg);
    stroke: var(--eim-gold); /* 🔥 mantiene lo stesso colore */
    opacity: 1;
}

.card-time-cloud:hover .card-time-cloud-hour[b-yma18bhldn] {
    font-size: 2.8em;
    top: 0.4em;
    color: var(--eim-gold);
    z-index: 5; /* mantiene sempre visibilità */
}

.card-time-cloud:hover .card-time-cloud-day[b-yma18bhldn],
.card-time-cloud:hover .card-time-cloud-day-number[b-yma18bhldn] {
    z-index: 5;
    color: var(--eim-gold);
}




/* === EFFETTO CLICK === */
.card-time-cloud:active[b-yma18bhldn] {
    transform: scale(0.97);
    transition: 0.2s all ease-in-out;
}

/* === RESPONSIVE DESIGN === */
@media (max-width: 992px) {
    .card-time-cloud[b-yma18bhldn] {
        width: 17em;
        height: 8em;
    }

    .card-time-cloud-hour[b-yma18bhldn] {
        font-size: 1.9em;
    }

    .card-time-cloud-day[b-yma18bhldn] {
        font-size: 1.2em;
    }
}

@media (max-width: 768px) {
    .giorni-container[b-yma18bhldn] {
        gap: 1em;
    }

    .card-time-cloud[b-yma18bhldn] {
        width: 100%;
        max-width: 20em;
        height: 8.5em;
    }

    .card-time-cloud-hour[b-yma18bhldn] {
        font-size: 2em;
    }

    .card-time-cloud:hover[b-yma18bhldn] {
        height: 13em;
    }
}

@media (max-width: 480px) {
    .card-time-cloud[b-yma18bhldn] {
        width: 100%;
        max-width: 18em;
        height: 8em;
    }

    .card-time-cloud-day[b-yma18bhldn] {
        font-size: 1em;
    }

    .card-time-cloud-hour[b-yma18bhldn] {
        font-size: 1.6em;
    }

    .card-time-cloud-day-number[b-yma18bhldn] {
        top: 3.2em;
    }
}

/* === LAYOUT GRIGLIE LAVORATE/PREVISTE === */
.timesheet-container[b-yma18bhldn] {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 2rem;
    margin-top: 1.5rem;
}

.timesheet-box[b-yma18bhldn] {
    flex: 1 1 45%;
    min-width: 420px;
    background-color: var(--eim-blue);
    border-radius: 0.6em;
    padding: 1em;
    color: #fff;
}

    .timesheet-box h5[b-yma18bhldn] {
        margin-bottom: 0.5rem;
        color: var(--eim-gold);
    }

/* Modalità mobile */
@media (max-width: 992px) {
    .timesheet-container[b-yma18bhldn] {
        flex-direction: column;
        align-items: stretch;
    }

    .timesheet-box[b-yma18bhldn] {
        flex: 1 1 100%;
        min-width: auto;
    }
}




.dx-grid[b-yma18bhldn] {
    background-color: #f8f9fa;
}


.fade-in[b-yma18bhldn] {
    animation: fadeIn-b-yma18bhldn 0.6s ease;
}

@keyframes fadeIn-b-yma18bhldn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.kpi-wrapper[b-yma18bhldn] {
    margin: 1.5rem 0;
    background-color: rgba(0, 44, 62, 0.05);
    border: 1px solid var(--eim-gold);
    border-radius: 10px;
    overflow: hidden;
}

/* Intestazione cliccabile */
.kpi-header[b-yma18bhldn] {
    background-color: var(--eim-blue);
    color: var(--eim-gold);
    padding: 0.6rem 1rem;
    font-weight: 600;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    user-select: none;
}

    .kpi-header:hover[b-yma18bhldn] {
        background-color: #00384f;
    }




.kpi-toggle[b-yma18bhldn] {
    background: var(--eim-gold);
    color: white;
    border: none;
    border-radius: 6px;
    padding: 0.4rem 0.8rem;
    cursor: pointer;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    transition: background 0.3s ease;
}

    .kpi-toggle:hover[b-yma18bhldn] {
        background: #ffc94d;
    }

/* Icona freccia animata */
.arrow-icon[b-yma18bhldn] {
    display: inline-block;
    font-size: 0.9rem;
    transition: transform 0.3s ease;
}

    .arrow-icon.open[b-yma18bhldn] {
        transform: rotate(180deg);
    }

.kpi-container[b-yma18bhldn] {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.5rem;
    padding: 1rem 0;
    transition: all 0.4s ease;
}

    /* Espansione / Collasso */
    .kpi-container.collapsed[b-yma18bhldn] {
        max-height: 0;
        overflow: hidden;
        opacity: 0;
        padding: 0;
    }

    .kpi-container.open[b-yma18bhldn] {
        max-height: none;
        opacity: 1;
        padding: 1rem 0;
        pointer-events: all;
    }

/* Card KPI */
.kpi-card[b-yma18bhldn] {
    background: var(--eim-blue);
    color: white;
    border: 1px solid var(--eim-gold);
    border-radius: 10px;
    padding: 1rem 1.5rem;
    text-align: center;
    min-width: 160px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
    transition: transform 0.3s ease;
}

    .kpi-card:hover[b-yma18bhldn] {
        transform: translateY(-4px);
    }

.kpi-label[b-yma18bhldn] {
    display: block;
    font-size: 0.9rem;
    opacity: 0.9;
}

.kpi-value[b-yma18bhldn] {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--eim-gold);
}

.kpi-card.positive .kpi-value[b-yma18bhldn] {
    color: #4CAF50;
}

.kpi-card.negative .kpi-value[b-yma18bhldn] {
    color: #E94560;
}

/* Responsività */
@media (max-width: 768px) {
    .kpi-container[b-yma18bhldn] {
        flex-direction: column;
        align-items: center;
        transition: max-height 0.5s ease, opacity 0.4s ease;
    }

    .kpi-card[b-yma18bhldn] {
        width: 90%;
    }
}

.btn-quick[b-yma18bhldn] {
    background-color: var(--eim-gold);
    color: white;
    border: none;
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.2s ease;
}

    .btn-quick:hover[b-yma18bhldn] {
        background-color: #ffc94d;
        transform: translateY(-2px);
    }

@media (max-width: 768px) {
    .d-flex.gap-3.mt-3[b-yma18bhldn] {
        flex-direction: column;
    }

    .btn-quick[b-yma18bhldn] {
        flex: 1 1 auto;
        width: 100%;
    }
}


.quick-filter-buttons[b-yma18bhldn] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem; /* più spazio orizzontale */
    margin-top: 0.75rem;
    margin-bottom: 1rem; /* separa dal blocco date */
}

.btn-quick[b-yma18bhldn] {
    background-color: var(--eim-gold);
    color: white;
    border: none;
    border-radius: 6px;
    padding: 8px 16px;
    font-size: 0.95rem;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.2s ease;
}

    .btn-quick:hover[b-yma18bhldn] {
        background-color: #ffc94d;
        transform: translateY(-2px);
    }

@media (max-width: 768px) {
    .quick-filter-buttons[b-yma18bhldn] {
        flex-direction: column;
        gap: 0.5rem;
        margin-bottom: 1.5rem;
    }

    .btn-quick[b-yma18bhldn] {
        width: 100%;
    }
}
/* /Components/Shared/FooterComponent.razor.rz.scp.css */
.footer-wrapper[b-q6ab6d2zs0] {
    font-family: 'Segoe UI', Arial, sans-serif;
    font-size: 0.95rem;
    color: #ffffff;
    background-color: #002C3E;
    border-top: 4px solid #DB9300;
}

/* BLOCCO SUPERIORE */
.footer-top[b-q6ab6d2zs0] {
    padding: 2.5rem 1.5rem;
}

.footer-grid[b-q6ab6d2zs0] {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 2rem;
    max-width: 1200px;
    margin: 0 auto;
}

.footer-col[b-q6ab6d2zs0] {
    flex: 1 1 250px;
}

.footer-logo[b-q6ab6d2zs0] {
    max-width: 200px;
    height: auto;
    filter: brightness(0) invert(1);
}

.footer-col h4[b-q6ab6d2zs0] {
    font-size: 1.1rem;
    margin-bottom: 1rem;
    color: #DB9300;
    border-bottom: 1px solid rgba(255,255,255,0.2);
    padding-bottom: 0.3rem;
}

.footer-col ul[b-q6ab6d2zs0] {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-col li[b-q6ab6d2zs0] {
    margin-bottom: 0.5rem;
}

.footer-col a[b-q6ab6d2zs0] {
    text-decoration: none;
    color: #e5e5e5;
    transition: color 0.2s ease, transform 0.1s ease;
}

    .footer-col a:hover[b-q6ab6d2zs0] {
        color: #DB9300;
        transform: translateX(2px);
    }

.footer-col p[b-q6ab6d2zs0] {
    margin: 0;
    line-height: 1.6;
}

    .footer-col p a[b-q6ab6d2zs0] {
        color: #DB9300;
        text-decoration: none;
    }

        .footer-col p a:hover[b-q6ab6d2zs0] {
            text-decoration: underline;
        }

/* BLOCCO INFERIORE */
.footer-bottom[b-q6ab6d2zs0] {
    text-align: center;
    background-color: #001e29;
    color: #ffffff;
    padding: 15px 0;
    font-size: 0.85rem;
    letter-spacing: 0.3px;
}

/* RESPONSIVE */
@media (max-width: 768px) {
    .footer-grid[b-q6ab6d2zs0] {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .footer-col[b-q6ab6d2zs0] {
        flex: 1 1 100%;
    }

    .footer-logo[b-q6ab6d2zs0] {
        margin-bottom: 20px;
    }
}
