/* ================================
   CUOCHI' THEME — PALETTE
   Primario:   #CA0031 (bordeaux)
    #CA0031
   Secondario: #CBBBA0 (champagne)
   Accent CTA: #C8A24A (oro soft)
   Sfondo:     #FAF7F2 (avorio)
   Testo:      #1F2937 (antracite)
================================ */

/* ===== RESET & BASE ===== */
*,
*::before,
*::after {
    box-sizing: border-box;
}

:focus-visible {
    outline: 2px solid #C8A24A;
    outline-offset: 2px;
}

/* ===== VARIABILI (UNICA DEFINIZIONE) ===== */
:root {
    /* Layout */
    --side-w: 280px; /* allineato alla tua nav più larga */
    --head-h: 70px;
    --footer-h: 38px;
    /* Palette */
    --brand-primary: #CA0031; /* bordeaux */
    --brand-primary-dark: #651824; /* scuro per submenu/hover */
    --brand-primary-darker: #54131E; /* ancora più scuro */
    --brand-secondary: #CBBBA0; /* champagne */
    --brand-accent: #C8A24A; /* oro soft */

    --bg: #FAF7F2; /* avorio */
    --surface: #FFFFFF; /* card/superfici */
    --text: #1F2937; /* antracite */
    --muted: #6B7280; /* testo secondario */
    /* Compat (vecchie variabili usate nel CSS/app) */
    --blue: var(--brand-primary);
    --brand-blue: var(--brand-primary);
    /* UI */
    --border: rgba(31, 41, 55, .12);
    --hover: rgba(122, 30, 44, .10);
    --active: rgba(122, 30, 44, .16);
    --icon: #FAF7F2;
    /* Typography Compact */
    --fs-base: 15px;
    --fs-nav: .95rem;
    --fs-header: .95rem;
    --fs-h1: 1.45rem;
    --fs-h2: 1.25rem;
    --fs-h3: 1.05rem;
    --fs-grid-cell: 13.2px;
    --fs-grid-head: 12.8px;
    --fs-grid-pager: 12.6px;
    --fs-btn: .92rem;
    --fs-label: .85rem;
    --fs-input: .95rem;
}

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    font-family: 'Inter', 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background-color: var(--bg);
    color: var(--text);
    font-size: var(--fs-base);
    line-height: 1.4;
}

h1 {
    font-size: var(--fs-h1);
}

h2 {
    font-size: var(--fs-h2);
}

h3 {
    font-size: var(--fs-h3);
}

/* ===== WRAPPER DI STATO ===== */
.root {
}

    .root.root-collapsed .sidenav {
        transform: translateX(calc(-1 * var(--side-w)));
    }

    .root.root-collapsed .appbar {
        left: 0;
    }

    .root.root-collapsed .content {
        margin-left: 0;
    }

    .root.root-collapsed .site-footer,
    .root.root-collapsed .appfooter {
        left: 0;
    }

/* ===== NAVBAR VERTICALE ===== */
.sidenav {
    position: fixed;
    top: 0;
    left: 0;
    width: var(--side-w);
    height: 100vh;
    background: var(--brand-primary);
    color: #fff;
    border-right: 1px solid rgba(255,255,255,.08);
    overflow-y: auto;
    z-index: 1100;
    transform: translateX(0);
    transition: transform .25s ease-in-out;
}

/* Brand */
.sidenav-brand {
    padding: 10px 12px;
    border-bottom: 1px solid rgba(255,255,255,.10);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--brand-primary);
}

    .sidenav-brand img {
        height: 46px;
        max-width: 100%;
        object-fit: contain;
        display: block;
    }

/* ===== NavMenu ===== */
.navmenu {
    padding: 8px 0;
}

    .navmenu ul {
        list-style: none;
        margin: 0;
        padding: 0;
    }

    .navmenu li {
        margin: 0;
        padding: 0;
    }

    /* Voci base */
    .navmenu .nav-item,
    .sidenav-menu .nav-item {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        padding: 12px 16px;
        color: #fff;
        text-decoration: none;
        border-left: 3px solid transparent;
        line-height: 1.05rem;
        font-weight: 500;
        background: transparent;
        font-size: var(--fs-nav);
    }

        .navmenu .nav-item i,
        .sidenav-menu .nav-item i {
            width: 1.25rem;
            text-align: center;
            font-size: 1.05rem;
            color: rgba(255,255,255,.88);
            transition: color .2s ease-in-out, transform .15s ease-in-out;
        }

        .navmenu .nav-item:hover,
        .sidenav-menu .nav-item:hover {
            background: rgba(255,255,255,.10);
            color: #fff;
        }

            .navmenu .nav-item:hover i,
            .sidenav-menu .nav-item:hover i {
                color: #fff;
                transform: translateX(1px);
            }

        .navmenu .nav-item.active,
        .sidenav-menu .nav-item.active {
            background: rgba(255,255,255,.12);
            border-left-color: var(--brand-accent);
            color: #fff;
        }

            .navmenu .nav-item.active i,
            .sidenav-menu .nav-item.active i {
                color: #fff;
            }

    /* Sezioni espandibili */
    .navmenu .dropdown {
        margin: 0;
    }

    .navmenu .section-toggle {
        border: 0;
        background: transparent;
        text-align: left;
        cursor: pointer;
        color: #fff;
        padding: 12px 16px;
        width: 100%;
        display: flex;
        align-items: center;
        gap: 10px;
        border-left: 3px solid transparent;
        font-weight: 600;
        font-size: var(--fs-nav);
    }

        .navmenu .section-toggle i {
            color: rgba(255,255,255,.88);
        }

        .navmenu .section-toggle:hover {
            background: rgba(255,255,255,.10);
            color: #fff;
        }

            .navmenu .section-toggle:hover i {
                color: #fff;
            }

        .navmenu .section-toggle .caret {
            margin-left: auto;
            transition: transform .2s ease-in-out;
            color: rgba(255,255,255,.88);
        }

        .navmenu .section-toggle.open .caret {
            transform: rotate(180deg);
            color: #fff;
        }

    /* Submenu */
    .navmenu .submenu {
        display: none;
        padding: 2px 0 6px;
        margin: 0;
        border-left: 3px solid var(--brand-accent);
        background: var(--brand-primary-dark);
    }

        .navmenu .submenu.open {
            display: block;
        }

        .navmenu .submenu li a.nav-item {
            padding: 10px 22px 10px 30px;
            font-weight: 500;
            color: rgba(255,255,255,.92);
        }

            .navmenu .submenu li a.nav-item i {
                color: rgba(255,255,255,.85);
            }

            .navmenu .submenu li a.nav-item:hover {
                background: rgba(255,255,255,.10);
                color: #fff;
            }

                .navmenu .submenu li a.nav-item:hover i {
                    color: #fff;
                }

        /* Nested submenu (se esiste) */
        .navmenu .submenu .submenu {
            margin-left: .75rem;
            border-left: 2px solid rgba(255,255,255,.15);
            padding-left: .75rem;
            background: var(--brand-primary-darker);
        }

/* ===== HEADER ORIZZONTALE ===== */
.appbar {
    position: fixed;
    top: 0;
    left: var(--side-w);
    right: 0;
    height: var(--head-h);
    background: var(--brand-primary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 12px;
    z-index: 1000;
    border-bottom: 1px solid rgba(0,0,0,.12);
}

.appbar-left, .appbar-right {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Non forzare tutti gli span bianchi nell'appbar */
.appbar a,
.appbar .btn,
.appbar .user-chip,
.appbar .btn-profile,
.appbar .btn-logout {
    color: #fff !important;
}

.appbar .badge {
    color: var(--text) !important;
    background-color: var(--brand-secondary) !important;
    border: 1px solid rgba(0,0,0,.10);
}

.hamburger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 0;
    background: transparent;
    color: #fff;
    font-size: 1.4rem;
    cursor: pointer;
}

.app-link {
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: .2px;
}

    .app-link:hover {
        text-decoration: underline;
    }

.user-chip {
    font-weight: 600;
    font-size: var(--fs-header);
}

.btn-profile, .btn-logout {
    color: #fff;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    padding: .28rem .55rem;
    border-radius: .35rem;
    border: 1px solid rgba(255,255,255,.35);
    font-size: var(--fs-header);
}

    .btn-profile:hover, .btn-logout:hover {
        background: rgba(255,255,255,.12);
    }

/* ===== LOGO HEADER ===== */
.appbar .logo img {
    max-height: 40px;
    display: block;
    object-fit: contain;
}

.appbar .logo {
    display: flex;
    align-items: center;
    height: 100%;
}

/* ===== BACKDROP (mobile) ===== */
.backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    display: none;
    z-index: 1050;
}

    .backdrop.show {
        display: block;
    }

/* ===== CONTENUTO ===== */
.content {
    margin-left: var(--side-w);
    padding-top: var(--head-h);
    padding-bottom: var(--footer-h);
    min-height: calc(100vh - var(--head-h) - var(--footer-h));
    transition: margin-left .25s ease-in-out;
}

.content-inner {
    padding: 20px;
    background: var(--surface);
    border-radius: 10px;
    border: 1px solid var(--border);
    box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

/* Card contenuti allineate a sinistra */
.container-left {
    max-width: 1200px;
}

/* ===== FOOTER FISSO ===== */
.site-footer,
.appfooter {
    position: fixed;
    left: var(--side-w);
    right: 0;
    bottom: 0;
    height: var(--footer-h);
    background: rgba(255,255,255,.88);
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    color: var(--muted);
    z-index: 900;
}

.appfooter-inner {
    padding: 0 10px;
}

/* ===== PAGINA DI LOGIN ===== */
.login-page {
    background: var(--brand-primary);
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 24px;
}

.login-box {
    background: var(--surface);
    width: 100%;
    max-width: 420px;
    padding: 28px 26px 24px;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0,0,0,.20);
    text-align: center;
    border: 1px solid rgba(0,0,0,.06);
}

.login-logo {
    height: 60px;
    margin-bottom: 14px;
}

.login-box h3 {
    margin: 0 0 14px;
    color: var(--brand-primary);
}

.form-row {
    text-align: left;
    margin-bottom: 12px;
}

    .form-row.inline {
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .form-row label {
        display: block;
        font-size: var(--fs-label);
        color: var(--text);
        margin-bottom: 6px;
    }

    .form-row input[type=text],
    .form-row input[type=password] {
        width: 100%;
        padding: 10px 12px;
        border: 1px solid var(--border);
        border-radius: 8px;
        background: #fff;
        font-size: var(--fs-input);
    }

/* ===== BOTTONI ===== */
.e-btn, .e-css .e-btn, .btn {
    font-size: var(--fs-btn);
}

    .btn.btn-primary {
        width: 100%;
        margin-top: 8px;
        background: var(--brand-primary);
        color: #fff;
        border: 1px solid rgba(0,0,0,.10);
        border-radius: 8px;
        padding: 10px 12px;
        cursor: pointer;
    }

        .btn.btn-primary:hover {
            filter: brightness(1.05);
        }

        .btn.btn-primary[disabled] {
            opacity: .7;
            cursor: default;
        }

    /* CTA (oro) – se vuoi usarla: class="btn btn-cta" */
    .btn.btn-cta {
        background: var(--brand-accent);
        border: 1px solid rgba(0,0,0,.10);
        color: #1b1b1b;
        border-radius: 8px;
    }

        .btn.btn-cta:hover {
            filter: brightness(1.04);
        }

.error {
    color: #b91c1c;
    margin-top: 10px;
    font-weight: 600;
    white-space: pre-wrap;
}

/* ===== Syncfusion – allineamento al brand ===== */
.e-btn.e-primary, .e-css.e-btn.e-primary {
    background-color: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: #fff !important;
}

    .e-btn.e-primary:hover, .e-css.e-btn.e-primary:hover {
        filter: brightness(1.05);
    }

/* Consiglio: se usi un bottone CTA in Syncfusion, puoi applicare class="e-btn e-flat cuochi-cta" */
.cuochi-cta.e-btn,
.cuochi-cta.e-css.e-btn {
    background-color: var(--brand-accent) !important;
    border-color: var(--brand-accent) !important;
    color: #1b1b1b !important;
}

    .cuochi-cta.e-btn:hover,
    .cuochi-cta.e-css.e-btn:hover {
        filter: brightness(1.04);
    }

/* Header griglia più chiaro e leggibile */
.e-grid .e-gridheader, .e-grid .e-headercell {
    background: rgba(203, 187, 160, .22);
}

/* Toolbar hover */
.e-toolbar .e-tbar-btn:hover {
    background: rgba(122, 30, 44, .08);
}

/* Dialog header */
.e-dialog .e-dlg-header {
    font-weight: 700;
    color: var(--brand-primary);
}

/* Syncfusion Grid – testo celle, header, filterbar, pager */
.e-grid .e-rowcell,
.e-grid .e-groupcaption,
.e-grid .e-detailrow {
    font-size: var(--fs-grid-cell);
}

.e-grid .e-headercell,
.e-grid .e-columnheader,
.e-grid .e-filterbarcell,
.e-grid .e-filterbarcell .e-input,
.e-grid .e-filterbarcell input {
    font-size: var(--fs-grid-head);
}

.e-grid .e-pager,
.e-grid .e-pager .e-numericitem,
.e-grid .e-pager .e-pagercontainer {
    font-size: var(--fs-grid-pager);
}

/* compattare leggermente le celle */
.e-grid .e-rowcell {
    padding-top: 6px;
    padding-bottom: 6px;
}

.e-grid .e-headercell {
    padding-top: 8px;
    padding-bottom: 8px;
}

/* ===== FORM COMPACT ===== */
.form-compact .card-header {
    padding: .5rem 1rem;
}

.form-compact .card-body {
    padding: .75rem 1rem;
}

.form-compact .form-label {
    margin-bottom: .25rem;
    font-size: .9rem;
}

.form-compact .form-control,
.form-compact .form-select {
    padding: .25rem .5rem;
    font-size: .9rem;
    height: calc(1.5em + .5rem + 2px);
}

.form-compact .mb-3 {
    margin-bottom: .5rem !important;
}

.form-compact .mt-4 {
    margin-top: 1rem !important;
}

/* ===== CHIP ===== */
.project-chip {
    display: inline-block;
    padding: .18rem .5rem;
    border-radius: .4rem;
    background: rgba(255,255,255,.14);
    color: #fff;
    border: 1px solid rgba(255,255,255,.22);
    margin: 0 .5rem;
    font-weight: 700;
    line-height: 1.2;
    cursor: default;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 992px) {
    .sidenav {
        transform: translateX(calc(-1 * var(--side-w)));
    }

        .sidenav.open {
            transform: translateX(0);
        }

    .appbar {
        left: 0;
    }

    .content {
        margin-left: 0;
    }

    .site-footer,
    .appfooter {
        left: 0;
    }
}

/* LoginDisplay compatto su mobile */
@media (max-width: 576px) {
    .appbar .user-chip,
    .appbar .btn-profile,
    .appbar .btn-logout,
    .appbar .project-chip {
        font-size: 0.75rem;
        padding: .15rem .35rem;
    }

        .appbar .btn-profile i,
        .appbar .btn-logout i {
            font-size: .85rem;
        }

    .appbar .user-chip {
        max-width: 100px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}

/* Griglie Syncfusion scrollabili su schermi piccoli */
@media (max-width: 768px) {
    .e-grid {
        overflow-x: auto !important;
        display: block;
        -webkit-overflow-scrolling: touch;
    }

        .e-grid .e-gridcontent,
        .e-grid .e-table {
            min-width: 600px;
        }

        .e-grid .e-gridcontent {
            overflow-x: auto !important;
        }
}

/* ===== Verbali UI (se rimane qualche dialog/section) ===== */
.verbali-dialog-body {
    height: calc(80vh - 120px);
    overflow-y: auto;
    padding: 0.5rem 1rem;
}

.verbali-section {
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 1rem;
    background-color: rgba(203, 187, 160, .12);
}

.verbali-section-title {
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 0.75rem;
    color: var(--brand-primary);
}

/* Nascondi il banner di errore standard di Blazor */
#blazor-error-ui {
    display: none !important;
}
/* Sidebar layout corretto */
.sidenav {
    display: flex;
    flex-direction: column;
}

.sidenav-brand {
    flex: 0 0 auto;
}

.sidenav-menu {
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    background: transparent;
    padding: 6px 0;
}

/* Navmenu (struttura a sezioni) */
.navmenu {
    padding: 6px 0;
}

    .navmenu ul {
        list-style: none;
        margin: 0;
        padding: 0;
    }

    .navmenu a.nav-item,
    .navmenu button.section-toggle {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        padding: 12px 16px;
        background: transparent;
        border: 0;
        color: #fff;
        text-decoration: none;
        text-align: left;
        cursor: pointer;
    }

        .navmenu a.nav-item:hover,
        .navmenu button.section-toggle:hover {
            background: rgba(255,255,255,.10);
        }

        .navmenu a.nav-item.active-link {
            background: rgba(255,255,255,.12);
            border-left: 3px solid var(--brand-accent);
            padding-left: 13px; /* compenso bordo */
            font-weight: 700;
        }

    /* Submenu */
    .navmenu .submenu {
        display: none;
        margin: 0;
        padding: 4px 0 8px;
        background: rgba(0,0,0,.12);
        border-left: 3px solid var(--brand-accent);
    }

        .navmenu .submenu.open {
            display: block;
        }

        .navmenu .submenu a.nav-item {
            padding: 10px 22px 10px 30px;
            color: rgba(255,255,255,.92);
        }

/* Mobile */
@media (max-width: 992px) {
    .sidenav {
        transform: translateX(calc(-1 * var(--side-w)));
        transition: transform .3s ease;
    }

        .sidenav.open {
            transform: translateX(0);
        }

    .appbar {
        left: 0;
    }

    .content {
        margin-left: 0;
    }

    .appfooter {
        left: 0;
    }
}
/* ===== FIX: sidebar interna non deve diventare bianca ===== */
.sidenav {
    background: var(--brand-primary) !important;
}

.sidenav-brand {
    background: var(--brand-primary) !important;
}

.sidenav-menu {
    background: var(--brand-primary) !important;
}

    /* Il nav del menu deve essere trasparente */
    .sidenav-menu .navmenu,
    .sidenav-menu .navmenu ul,
    .sidenav-menu .navmenu li {
        background: transparent !important;
    }

        /* Link e bottoni del menu sempre bianchi */
        .sidenav-menu .navmenu a.nav-item,
        .sidenav-menu .navmenu button.section-toggle {
            color: #fff !important;
        }

            /* Hover/active coerenti */
            .sidenav-menu .navmenu a.nav-item:hover,
            .sidenav-menu .navmenu button.section-toggle:hover {
                background: rgba(255,255,255,.10) !important;
            }

            .sidenav-menu .navmenu a.nav-item.active-link {
                background: rgba(255,255,255,.12) !important;
                border-left: 3px solid var(--brand-accent) !important;
            }

/* ===== LOGO SIDEBAR: riempie tutta la fascia ===== */
.sidenav-brand {
    height: 120px; /* <-- scegli tu l'altezza fascia logo */
    padding: 0; /* niente padding, così riempie davvero */
    display: flex;
    align-items: stretch;
    justify-content: stretch;
    background: var(--brand-primary);
    border-bottom: 1px solid rgba(255,255,255,.12);
}

    .sidenav-brand img {
        width: 100%;
        height: 100%;
        object-fit: contain; /* se vuoi tagliarlo per riempire: cover */
        display: block;
    }
/* ===== BRAND: stessa altezza della barra in alto ===== */
.sidenav-brand {
    height: var(--head-h); /* = altezza appbar */
    background: #fff !important;
    padding: 6px 10px; /* poco padding */
    border-bottom: 1px solid rgba(0,0,0,.08);
    display: flex;
    align-items: center;
    justify-content: center;
}

    .sidenav-brand .brand-logo {
        height: 100%;
        max-height: calc(var(--head-h) - 12px); /* riempie senza uscire */
        width: 100%;
        max-width: 260px;
        object-fit: contain;
        display: block;
    }
