/* ================================================================
   dashboard.css — global styles for all MainLayout inner pages
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600;700;800&display=swap');

/* ── Variables ─────────────────────────────────────────────────── */
:root {
    --d-green:    #0b7a34;
    --d-green-dk: #064b20;
    --d-green-lt: #e6f4ec;
    --d-teal:     #0d8b8f;
    --d-bg:       #f0f6f2;
    --d-surface:  #ffffff;
    --d-border:   #d0e5d8;
    --d-text:     #152019;
    --d-muted:    #56695e;
    --d-warn:     #c8860a;
    --d-danger:   #c0392b;
    --d-r:        10px;
    --d-r-sm:     6px;
    --d-sh-sm:    0 2px 12px rgba(15,43,28,.08);
    --d-sh-md:    0 8px 28px rgba(15,43,28,.12);
    --d-ease:     .2s ease;
}

/* ── Base ──────────────────────────────────────────────────────── */
html, body {
    font-family: 'Open Sans', 'Trebuchet MS', Arial, sans-serif !important;
    font-size: 14px;
    line-height: 1.6;
    color: var(--d-text);
    background-color: var(--d-bg);
    background-image:
        linear-gradient(158deg,
            rgba(225,244,233,.95)  0%,
            rgba(240,246,242,.90) 45%,
            rgba(248,252,250,.85) 100%),
        url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><defs><pattern id='dw' x='0' y='0' width='100' height='60' patternUnits='userSpaceOnUse' patternTransform='rotate(35)'><path d='M-10 20 C15 0 35 40 60 20 C85 0 105 40 130 20' stroke='rgba(11,122,52,0.05)' stroke-width='1.2' fill='none'/></pattern></defs><rect width='200' height='200' fill='url(%23dw)'/></svg>");
    background-attachment: fixed;
}

/* ── Shared page wrapper ───────────────────────────────────────── */
.page {
    display: flex;
    flex-direction: row;
    min-height: 100vh;
}

/* ── Top row inside content area ──────────────────────────────── */
.top-row {
    background: rgba(255,255,255,.95) !important;
    border-bottom: 1px solid var(--d-border) !important;
    height: 52px !important;
    min-height: 52px;
    display: flex;
    align-items: center;
    padding: 0 20px;
    font-size: .88rem;
    color: var(--d-muted);
    backdrop-filter: blur(8px);
    box-shadow: var(--d-sh-sm);
}

.top-row .divLefth {
    font-size: .82rem;
    font-weight: 600;
    color: var(--d-green-dk);
}

/* ── Content article ───────────────────────────────────────────── */
article.content {
    padding: 20px 24px 40px !important;
}

/* ── Footer bar ────────────────────────────────────────────────── */
.footerdiv {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    background: var(--d-green-dk);
    color: rgba(255,255,255,.7);
    font-size: .76rem;
    z-index: 50;
    box-shadow: 0 -2px 12px rgba(0,0,0,.12);
}

.footerdiv .divLeftee,
.footerdiv .divCenteree,
.footerdiv .divRightee {
    position: static !important;
    left: auto !important;
    width: auto !important;
    background: transparent !important;
    color: rgba(255,255,255,.7);
    font-size: .76rem;
}

/* ── Global card ───────────────────────────────────────────────── */
.dash-card {
    background: var(--d-surface);
    border: 1px solid var(--d-border);
    border-radius: var(--d-r);
    box-shadow: var(--d-sh-sm);
    padding: 18px 20px;
    transition: box-shadow var(--d-ease), transform var(--d-ease);
}
.dash-card:hover {
    box-shadow: var(--d-sh-md);
    transform: translateY(-2px);
}

/* ── Stat pill ─────────────────────────────────────────────────── */
.stat-pill {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--d-surface);
    border: 1px solid var(--d-border);
    border-radius: var(--d-r);
    padding: 14px 18px;
    box-shadow: var(--d-sh-sm);
}
.stat-pill-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--d-r-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}
.stat-pill-icon.green  { background: var(--d-green-lt); color: var(--d-green); }
.stat-pill-icon.warn   { background: #fff8e6; color: var(--d-warn); }
.stat-pill-icon.teal   { background: #e4f4f5; color: var(--d-teal); }
.stat-pill-icon.danger { background: #fdecea; color: var(--d-danger); }
.stat-pill-num   { font-size: 1.3rem; font-weight: 800; color: var(--d-text); line-height: 1; }
.stat-pill-label { font-size: .76rem; color: var(--d-muted); margin-top: 2px; }

/* ── Section heading ───────────────────────────────────────────── */
.dash-heading {
    font-size: 1rem;
    font-weight: 700;
    color: var(--d-green-dk);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--d-green-lt);
}
.dash-heading i { color: var(--d-green); font-size: .95rem; }

/* ── Global table overrides ────────────────────────────────────── */
.table-themed {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
}
.table-themed thead tr {
    background: var(--d-green-dk);
    color: #fff;
}
.table-themed thead th {
    padding: 10px 12px;
    font-weight: 600;
    text-align: left;
    white-space: nowrap;
    border: none;
}
.table-themed tbody td {
    padding: 9px 12px;
    border-bottom: 1px solid var(--d-border);
    color: var(--d-text);
    vertical-align: middle;
}
.table-themed tbody tr:last-child td { border-bottom: none; }
.table-themed tbody tr:hover td { background: var(--d-green-lt); }
.table-themed tbody tr:nth-child(even) td { background: rgba(230,244,236,.35); }
.table-themed tbody tr:nth-child(even):hover td { background: var(--d-green-lt); }

/* ── Modal overrides ───────────────────────────────────────────── */
.modal-content {
    border-radius: var(--d-r) !important;
    border: 1px solid var(--d-border) !important;
    box-shadow: var(--d-sh-md) !important;
    font-family: 'Open Sans', sans-serif !important;
}
.modal-header {
    background: var(--d-green-dk) !important;
    color: #fff !important;
    border-radius: var(--d-r) var(--d-r) 0 0 !important;
    padding: 14px 20px !important;
    border-bottom: none !important;
}
.modal-header .modal-title { color: #fff !important; font-weight: 700 !important; font-size: .98rem !important; }
.modal-header .close { color: #fff !important; opacity: .7; font-size: 1.3rem !important; }
.modal-header .close:hover { opacity: 1; }
.modal-footer {
    border-top: 1px solid var(--d-border) !important;
    padding: 12px 20px !important;
    gap: 8px;
}

/* ── Button overrides ──────────────────────────────────────────── */
.btn-success, .btn-primary {
    background: var(--d-green) !important;
    border-color: var(--d-green) !important;
    border-radius: var(--d-r-sm) !important;
    font-weight: 600 !important;
}
.btn-success:hover, .btn-primary:hover {
    background: var(--d-green-dk) !important;
    border-color: var(--d-green-dk) !important;
}
.btn-secondary {
    background: #f4f7f5 !important;
    border-color: var(--d-border) !important;
    color: var(--d-text) !important;
    border-radius: var(--d-r-sm) !important;
    font-weight: 600 !important;
}
.btn-secondary:hover { background: #e6f4ec !important; border-color: var(--d-green) !important; color: var(--d-green) !important; }

/* ── Form select overrides ─────────────────────────────────────── */
.form-select, .form-control, select, input[type=text], input[type=number] {
    border: 1px solid var(--d-border) !important;
    border-radius: var(--d-r-sm) !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: .88rem !important;
    padding: 7px 10px !important;
    color: var(--d-text) !important;
    background: var(--d-surface) !important;
    transition: border-color var(--d-ease), box-shadow var(--d-ease) !important;
}
.form-select:focus, .form-control:focus, select:focus, input[type=text]:focus, input[type=number]:focus {
    border-color: var(--d-green) !important;
    box-shadow: 0 0 0 3px rgba(11,122,52,.1) !important;
    outline: none !important;
}

/* ── User profile menu (top-right) ─────────────────────────────── */
.usersection { margin-left: auto; }

.navigation {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px;
}

.navigation .userBx {
    display: flex !important;
    align-items: center;
    gap: 8px;
    width: auto !important;
    height: auto !important;
    background: transparent !important;
    transition: none !important;
}

.navigation .userBx .imgBx {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    border-radius: 50% !important;
    border: 2px solid var(--d-border) !important;
    overflow: hidden;
    background: var(--d-green-lt) !important;
}

.navigation .userBx .imgBx img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.navigation .userBx .username {
    font-size: .82rem !important;
    font-weight: 600;
    color: var(--d-text) !important;
    white-space: nowrap;
}

.navigation .userBx .username .role_val {
    font-size: .72rem !important;
    color: var(--d-muted) !important;
    display: block;
}

/* Keep dropdown menu working */
.navigation .menuToggle {
    width: 32px !important;
    height: 32px !important;
    background: var(--d-green-lt) !important;
    border-radius: var(--d-r-sm) !important;
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.navigation .menuToggle::before {
    width: 14px !important;
    height: 1.5px !important;
    background: var(--d-green-dk) !important;
    box-shadow: 0 5px var(--d-green-dk) !important;
    transform: translateY(-3px) !important;
}
.navigation .menuToggle::after {
    width: 14px !important;
    height: 1.5px !important;
    background: var(--d-green-dk) !important;
    transform: translateY(3px) !important;
}
.navigation.active .menuToggle::before {
    transform: translateY(0) rotate(45deg) !important;
    box-shadow: none !important;
}
.navigation.active .menuToggle::after {
    transform: translateY(0) rotate(-45deg) !important;
}

.navigation.active {
    width: auto !important;
    height: auto !important;
}

.menu {
    position: absolute !important;
    top: calc(100% + 4px) !important;
    right: 0;
    left: auto !important;
    width: 200px !important;
    background: var(--d-surface);
    border: 1px solid var(--d-border);
    border-radius: var(--d-r);
    box-shadow: var(--d-sh-md);
    padding: 8px !important;
    margin-top: 0 !important;
    z-index: 200;
}
.menu li { list-style: none !important; }
.menu li a {
    display: flex !important;
    align-items: center;
    gap: 8px;
    padding: 8px 10px !important;
    border-radius: var(--d-r-sm);
    font-size: .86rem !important;
    color: var(--d-text) !important;
    text-decoration: none !important;
    transition: background var(--d-ease);
    margin: 2px 0 !important;
}
.menu li a:hover { background: var(--d-green-lt) !important; color: var(--d-green) !important; }

/* ── Toast tweaks ──────────────────────────────────────────────── */
.toast-container { font-family: 'Open Sans', sans-serif !important; }

/* ================================================================
   DÉPLACEMENT PAGES — shared (DeplacementCommune/Village/Ville)
   ================================================================ */

/* page wrapper */
.dp-page {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 4px 0 60px;
    font-family: 'Open Sans', sans-serif;
}

/* two-column split */
.dp-split {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    padding: 16px 0;
}

/* panel */
.dp-panel {
    background: rgba(255,255,255,.88);
    border: 1px solid #d0e5d8;
    border-radius: 12px;
    box-shadow: 0 2px 14px rgba(6,75,32,.08);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    backdrop-filter: blur(4px);
}

/* panel header */
.dp-panel-head {
    background: #064b20;
    color: #fff;
    padding: 11px 16px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.dp-panel-head i { font-size: .9rem; opacity: .7; }
.dp-panel-head h3 {
    margin: 0;
    font-size: .94rem;
    font-weight: 700;
    color: #fff;
}

/* filter bar inside panel */
.dp-filters {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    padding: 12px 14px 8px;
    border-bottom: 1px solid #d0e5d8;
    flex-shrink: 0;
    background: rgba(230,244,236,.3);
}

.dp-filter-group {
    display: flex;
    flex-direction: column;
    gap: 3px;
    flex: 1;
    min-width: 130px;
}

.dp-filter-group label {
    font-size: .72rem;
    font-weight: 700;
    color: #56695e;
    letter-spacing: .04em;
    text-transform: uppercase;
    margin: 0;
}

.dp-filter-group select {
    border: 1px solid #d0e5d8 !important;
    border-radius: 6px !important;
    font-size: .86rem !important;
    padding: 7px 10px !important;
    color: #152019 !important;
    background: #fff !important;
    transition: border-color .18s ease, box-shadow .18s ease !important;
    width: 100%;
}
.dp-filter-group select:focus {
    border-color: #0b7a34 !important;
    box-shadow: 0 0 0 3px rgba(11,122,52,.1) !important;
    outline: none !important;
}

/* table scroll area */
.dp-table-wrap {
    flex: 1;
    overflow-y: auto;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: #d0e5d8 transparent;
}
.dp-table-wrap::-webkit-scrollbar { width: 4px; height: 4px; }
.dp-table-wrap::-webkit-scrollbar-thumb { background: #d0e5d8; border-radius: 99px; }

/* table */
.dp-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .85rem;
}
.dp-table thead tr { background: #0b7a34; position: sticky; top: 0; z-index: 2; }
.dp-table thead th {
    padding: 9px 12px;
    color: #fff;
    font-weight: 600;
    text-align: left;
    white-space: nowrap;
    border: none;
    font-size: .8rem;
}
.dp-table tbody td {
    padding: 8px 12px;
    border-bottom: 1px solid #e8f2ec;
    color: #152019;
    vertical-align: middle;
}
.dp-table tbody tr:last-child td { border-bottom: none; }
.dp-table tbody tr:hover td { background: #e6f4ec !important; cursor: pointer; }
.dp-table tbody tr.highlight td {
    background: rgba(13,139,143,.12) !important;
    font-weight: 600;
}
.dp-table tbody tr:nth-child(even) td { background: rgba(230,244,236,.3); }
.dp-table tbody tr:nth-child(even).highlight td { background: rgba(13,139,143,.12) !important; }

/* move icon */
.dp-table td img {
    width: 18px !important; height: 18px !important;
    cursor: pointer; opacity: .55;
    transition: opacity .15s, transform .15s;
    vertical-align: middle;
}
.dp-table td img:hover { opacity: 1; transform: scale(1.15); }

/* warning banner */
.dp-warning {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    background: rgba(255,248,230,.95);
    border: 1px solid #c8860a;
    border-radius: 10px;
    padding: 14px 18px;
    margin-top: 6px;
}
.dp-warning-text {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex: 1;
    font-size: .88rem;
    color: #7a4f00;
    line-height: 1.55;
}
.dp-warning-text i { font-size: 1.1rem; color: #c8860a; margin-top: 2px; flex-shrink: 0; }

/* action button */
.dp-btn-move {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: #0b7a34;
    border: none;
    border-radius: 8px;
    color: #fff;
    font-family: 'Open Sans', sans-serif;
    font-size: .92rem;
    font-weight: 700;
    min-height: 40px;
    padding: 0 20px;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    box-shadow: 0 4px 14px rgba(11,122,52,.28);
    transition: background .18s ease, box-shadow .18s ease, transform .18s ease;
}
.dp-btn-move:hover {
    background: #064b20;
    box-shadow: 0 8px 22px rgba(11,122,52,.36);
    transform: translateY(-1px);
}

/* modal code-field inline */
.dp-code-field {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 4px;
}
.dp-code-field input {
    border: 1px solid #d0e5d8 !important;
    border-radius: 6px !important;
    font-size: .88rem !important;
    padding: 6px 10px !important;
    width: 110px !important;
    transition: border-color .18s ease !important;
}
.dp-code-field input:focus { border-color: #0b7a34 !important; outline: none !important; }

/* modal table inside modal-body */
.dp-modal-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.dp-modal-table td {
    padding: 8px 12px;
    border-bottom: 1px solid #e8f2ec;
    vertical-align: top;
    color: #152019;
}
.dp-modal-table td:first-child { color: #56695e; font-weight: 600; white-space: nowrap; }
.dp-modal-table tr:last-child td { border-bottom: none; }

/* error label in modal footer */
.dp-error { font-size: .86rem; color: #c0392b; font-weight: 600; }

@media (max-width: 900px) {
    .dp-split { grid-template-columns: 1fr; }
}

/* ================================================================
   MAIN LAYOUT — sidebar + body (global, not scoped)
   ================================================================ */

/* ── Layout shell ──────────────────────────────────────────────── */
.ml-page {
    --sb-w:        240px;
    --sb-w-col:     60px;
    --sb-bg:       #083a18;
    --sb-bg-dk:    #052a10;
    --sb-border:   rgba(255,255,255,.09);
    --sb-text:     rgba(255,255,255,.78);
    --sb-muted:    rgba(255,255,255,.35);
    --sb-active:   #0d8b8f;
    --sb-hover:    rgba(255,255,255,.08);
    --top-h:        52px;
    --foot-h:       34px;
    display: flex !important;
    flex-direction: row !important;
    min-height: 100vh;
    font-family: 'Open Sans', sans-serif;
}

/* ── Sidebar ───────────────────────────────────────────────────── */
.ml-side {
    width: var(--sb-w);
    min-width: var(--sb-w);
    background: var(--sb-bg);
    display: flex !important;
    flex-direction: column !important;
    height: 100vh;
    position: sticky;
    top: 0;
    overflow: hidden;
    transition: width .22s ease, min-width .22s ease;
    z-index: 100;
    box-shadow: 3px 0 18px rgba(0,0,0,.18);
    flex-shrink: 0;
}

.ml-collapsed .ml-side {
    width: var(--sb-w-col) !important;
    min-width: var(--sb-w-col) !important;
}

/* ── Brand ─────────────────────────────────────────────────────── */
.ml-brand {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 56px;
    min-height: 56px;
    padding: 0 10px 0 14px;
    background: var(--sb-bg-dk);
    border-bottom: 1px solid var(--sb-border);
    flex-shrink: 0;
}

.ml-brand-link {
    display: flex !important;
    align-items: center !important;
    gap: 9px;
    text-decoration: none !important;
    overflow: hidden;
    flex: 1;
    min-width: 0;
}

.ml-brand-img {
    width: 28px; height: 28px;
    border-radius: 6px;
    background: rgba(255,255,255,.12);
    padding: 5px;
    flex-shrink: 0;
    filter: brightness(0) invert(1);
    opacity: .8;
    object-fit: contain;
}

.ml-brand-name {
    font-size: .95rem;
    font-weight: 800;
    color: #fff;
    white-space: nowrap;
    letter-spacing: .2px;
    transition: opacity .22s ease, max-width .22s ease;
    max-width: 180px;
    overflow: hidden;
}

.ml-collapsed .ml-brand-name { opacity: 0; max-width: 0; }

.ml-toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 26px; height: 26px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 6px;
    color: rgba(255,255,255,.7);
    cursor: pointer;
    flex-shrink: 0;
    font-size: .8rem;
    transition: background .18s ease;
}
.ml-toggle:hover { background: rgba(255,255,255,.22); color: #fff; }

/* ── Nav scroll container ──────────────────────────────────────── */
.ml-nav {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 6px 0 16px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.1) transparent;
}
.ml-nav::-webkit-scrollbar { width: 3px; }
.ml-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 99px; }

/* ── Nav group + labels ────────────────────────────────────────── */
.ml-group { margin-bottom: 2px; }

.ml-group-label {
    display: block !important;
    font-size: .65rem;
    font-weight: 700;
    color: var(--sb-muted);
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 14px 16px 4px;
    white-space: nowrap;
    overflow: hidden;
    transition: opacity .18s ease, max-height .18s ease;
    max-height: 40px;
}

.ml-sub-label {
    display: block !important;
    font-size: .62rem;
    font-weight: 600;
    color: rgba(255,255,255,.26);
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 10px 16px 2px;
    white-space: nowrap;
    overflow: hidden;
    transition: opacity .18s ease, max-height .18s ease;
    max-height: 32px;
}

.ml-collapsed .ml-group-label,
.ml-collapsed .ml-sub-label {
    opacity: 0;
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    pointer-events: none;
}

/* ── Nav item — THE critical block ────────────────────────────── */
.ml-item,
a.ml-item,
.ml-nav a.ml-item,
.ml-nav .ml-item {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px;
    padding: 9px 16px;
    color: var(--sb-text) !important;
    text-decoration: none !important;
    font-size: .86rem;
    font-weight: 400;
    border-left: 3px solid transparent;
    white-space: nowrap;
    overflow: hidden;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, border-color .15s ease;
    width: 100%;
    box-sizing: border-box;
}

.ml-item i {
    font-size: .9rem;
    width: 18px;
    min-width: 18px;
    text-align: center;
    flex-shrink: 0;
    opacity: .65;
    transition: opacity .15s;
}

.ml-item .lbl {
    overflow: hidden;
    white-space: nowrap;
    flex: 1;
    transition: opacity .18s ease, max-width .18s ease;
    max-width: 180px;
}

/* hover */
.ml-item:hover,
a.ml-item:hover {
    background: var(--sb-hover) !important;
    color: #fff !important;
    border-left-color: rgba(13,139,143,.55) !important;
    text-decoration: none !important;
}
.ml-item:hover i { opacity: 1; }

/* active (Blazor NavLink adds .active class) */
.ml-item.active,
a.ml-item.active {
    background: rgba(13,139,143,.18) !important;
    color: #fff !important;
    border-left-color: #0d8b8f !important;
    font-weight: 600;
}
.ml-item.active i { opacity: 1; color: #0d8b8f; }

/* collapsed — icon only */
.ml-collapsed .ml-item,
.ml-collapsed a.ml-item {
    justify-content: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    gap: 0 !important;
}
.ml-collapsed .ml-item .lbl { opacity: 0; max-width: 0; }
.ml-collapsed .ml-item:hover { border-left-color: transparent !important; }

/* ── Sidebar footer ────────────────────────────────────────────── */
.ml-side-footer {
    display: flex !important;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-top: 1px solid var(--sb-border);
    font-size: .76rem;
    color: var(--sb-muted);
    flex-shrink: 0;
    white-space: nowrap;
    overflow: hidden;
}
.ml-side-footer i { font-size: .8rem; flex-shrink: 0; }
.ml-side-footer .lbl { transition: opacity .18s ease, max-width .18s ease; max-width: 160px; }
.ml-collapsed .ml-side-footer { justify-content: center; padding-left: 0; padding-right: 0; gap: 0; }
.ml-collapsed .ml-side-footer .lbl { opacity: 0; max-width: 0; }

/* ── Body area ─────────────────────────────────────────────────── */
.ml-body {
    flex: 1;
    min-width: 0;
    display: flex !important;
    flex-direction: column !important;
    background:
        linear-gradient(158deg, rgba(225,244,233,.95) 0%, rgba(240,246,242,.90) 50%, rgba(248,252,250,.88) 100%),
        url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><defs><pattern id='dp' x='0' y='0' width='100' height='60' patternUnits='userSpaceOnUse' patternTransform='rotate(35)'><path d='M-10 20 C15 0 35 40 60 20 C85 0 105 40 130 20' stroke='rgba(11,122,52,0.04)' stroke-width='1.2' fill='none'/></pattern></defs><rect width='200' height='200' fill='url(%23dp)'/></svg>");
    background-attachment: fixed;
}

/* ════════════════════════════════════════════════════════════════
   TOP BAR — redesigned
   ════════════════════════════════════════════════════════════════ */
.ml-topbar {
    position: sticky;
    top: 0;
    height: 56px;
    min-height: 56px;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between;
    padding: 0 22px;
    background: #fff;
    /* gradient green accent line at bottom */
    border-bottom: 2px solid transparent;
    border-image: linear-gradient(90deg, #0b7a34 0%, #0d8b8f 60%, transparent 100%) 1;
    box-shadow: 0 2px 20px rgba(6,75,32,.10);
    z-index: 50;
    gap: 14px;
    flex-shrink: 0;
}

/* ── Left: context badge ─────────────────────────────────────── */
.ml-topbar-ctx {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

.ml-ctx-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #e6f4ec;
    border: 1px solid #c5dfc9;
    border-radius: 6px;
    padding: 4px 10px;
    font-size: .78rem;
    font-weight: 700;
    color: #064b20;
    white-space: nowrap;
}
.ml-ctx-badge i { font-size: .75rem; color: #0b7a34; }

.ml-ctx-sep {
    width: 1px; height: 20px;
    background: #d0e5d8;
    flex-shrink: 0;
}

.ml-ctx-label {
    font-size: .84rem;
    font-weight: 600;
    color: #56695e;
    white-space: nowrap;
}
.ml-ctx-label strong { color: #064b20; font-weight: 800; }

.ml-year-pill {
    display: inline-flex;
    align-items: center;
    background: linear-gradient(135deg, #0b7a34, #0d8b8f);
    color: #fff;
    border-radius: 20px;
    font-size: .72rem;
    font-weight: 700;
    padding: 3px 10px;
    letter-spacing: .03em;
    flex-shrink: 0;
}

/* ── Right: user card ────────────────────────────────────────── */
.ml-topbar-user {
    margin-left: auto;
    flex-shrink: 0;
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* ── Standalone logout button — sits between ctx and user card ── */
.ml-topbar-logout {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    height: 36px;
    padding: 0 14px;
    background: transparent;
    border: 1.5px solid rgba(192,57,43,.35);
    border-radius: 8px;
    color: #c0392b;
    font-family: 'Open Sans', sans-serif;
    font-size: .82rem;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    letter-spacing: .01em;
    transition: background .16s ease, border-color .16s ease,
                color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.ml-topbar-logout i { font-size: .88rem; }
.ml-topbar-logout:hover {
    background: #c0392b;
    border-color: #c0392b;
    color: #fff;
    box-shadow: 0 4px 14px rgba(192,57,43,.3);
    transform: translateY(-1px);
}
.ml-topbar-logout:active { transform: translateY(0); box-shadow: none; }

/* icon-only logout — kept for reference */
.ml-logout-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: #fff0f0;
    border: 1px solid rgba(192,57,43,.22);
    border-radius: 8px;
    color: #c0392b;
    font-size: .9rem;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .16s ease, border-color .16s ease,
                color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.ml-logout-icon:hover {
    background: #c0392b;
    border-color: #c0392b;
    color: #fff;
    box-shadow: 0 3px 12px rgba(192,57,43,.3);
    transform: translateY(-1px);
}
.ml-logout-icon:active { transform: translateY(0); box-shadow: none; }

/* standalone logout button (kept for reference, no longer rendered) */
.ml-logout-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 36px;
    padding: 0 14px;
    background: #fff0f0;
    border: 1px solid rgba(192,57,43,.25);
    border-radius: 8px;
    color: #c0392b;
    font-family: 'Open Sans', sans-serif;
    font-size: .82rem;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background .16s ease, border-color .16s ease,
                color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.ml-logout-btn i { font-size: .9rem; }
.ml-logout-btn:hover {
    background: #c0392b;
    border-color: #c0392b;
    color: #fff;
    box-shadow: 0 4px 14px rgba(192,57,43,.3);
    transform: translateY(-1px);
}
.ml-logout-btn:active { transform: translateY(0); box-shadow: none; }

/* navigation card — fixed height, never clips overflow */
.ml-topbar .navigation {
    align-items: center;
    background: #fff;
    border: 1px solid #d0e5d8;
    border-radius: 10px;
    box-shadow: 0 3px 14px rgba(15,43,30,.09);
    display: flex !important;
    height: 46px;
    overflow: visible;    /* ← let the menu pop out */
    position: relative;
    width: 288px;
    z-index: 100;
    transition: box-shadow .18s ease;
}

.ml-topbar .navigation.active {
    box-shadow: 0 4px 18px rgba(15,43,30,.14);
    z-index: 500;
}

/* user info row */
.ml-topbar .navigation .userBx {
    display: flex !important;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
    height: 46px;
    overflow: hidden;
    padding: 0 12px;
}

/* avatar circle */
.ml-topbar .navigation .userBx .imgBx {
    width: 34px; height: 34px; min-width: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, #0b7a34, #0d8b8f);
    border: 2px solid rgba(11,122,52,.2);
    overflow: hidden;
    position: relative;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(11,122,52,.25);
}
.ml-topbar .navigation .userBx .imgBx img {
    position: absolute; top: 0; left: 0;
    width: 100%; height: 100%; object-fit: cover;
}

/* name + role */
.ml-topbar .navigation .userBx p.username {
    font-size: .84rem;
    font-weight: 700;
    color: #152019;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 0;
    line-height: 1.25;
}
.ml-topbar .role_val {
    font-size: .68rem;
    color: #0d8b8f;
    display: block;
    font-weight: 600;
    margin-top: 1px;
}

/* hamburger toggle */
.ml-topbar .navigation .menuToggle {
    width: 46px; height: 46px;
    background: #f2f8f4;
    border-left: 1px solid #d0e5d8;
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative;
    flex-shrink: 0;
    transition: background .16s ease;
}
.ml-topbar .navigation .menuToggle:hover { background: #e0f0e6; }

.ml-topbar .navigation .menuToggle::before,
.ml-topbar .navigation .menuToggle::after {
    content: "";
    position: absolute;
    width: 16px; height: 1.8px;
    background: #0b7a34;
    transition: .22s cubic-bezier(.4,0,.2,1);
}
.ml-topbar .navigation .menuToggle::before {
    box-shadow: 0 6px #0b7a34;
    transform: translateY(-4px);
}
.ml-topbar .navigation .menuToggle::after { transform: translateY(4px); }
.ml-topbar .navigation.active .menuToggle { background: #e0f0e6; }
.ml-topbar .navigation.active .menuToggle::before {
    box-shadow: none;
    transform: rotate(45deg);
}
.ml-topbar .navigation.active .menuToggle::after { transform: rotate(-45deg); }

/* ── Dropdown menu — pops out absolutely below the card ──────── */
.ml-topbar .menu {
    display: none;                 /* hidden by default            */
    position: absolute;
    top: calc(100% + 6px);        /* 6px gap below the card       */
    right: 0;
    left: auto;
    width: 230px;
    height: auto;
    background: #fff;
    border: 1px solid #d0e5d8;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(15,43,30,.18);
    padding: 8px 6px;
    z-index: 600;                  /* above everything             */
    overflow: visible;
    animation: menuFadeIn .15s ease both;
}

/* show when .active is on the parent .navigation */
.ml-topbar .navigation.active .menu { display: block; }

@keyframes menuFadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.ml-topbar .menu li { list-style: none; }

.ml-topbar .menu li a {
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: 8px;
    font-size: .85rem;
    font-weight: 500;
    color: #2d3748;
    text-decoration: none;
    transition: background .14s ease, color .14s ease;
    margin: 1px 0;
}

.ml-topbar .menu li a i {
    width: 18px;
    font-size: .88rem;
    text-align: center;
    color: #64736b;
    flex-shrink: 0;
    transition: color .14s ease;
}

.ml-topbar .menu li a:hover {
    background: #e6f4ec;
    color: #064b20;
}
.ml-topbar .menu li a:hover i { color: #0b7a34; }

/* divider */
.ml-topbar .menu-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, #d0e5d8 30%, #d0e5d8 70%, transparent);
    margin: 6px 8px;
}

/* logout — distinctive red */
.ml-topbar .menu li a.menu-logout {
    color: #c0392b;
    font-weight: 600;
    margin-top: 2px;
}
.ml-topbar .menu li a.menu-logout i { color: #c0392b; }
.ml-topbar .menu li a.menu-logout:hover {
    background: linear-gradient(135deg, #fff0f0, #fff5f5);
    color: #9b1c1c;
    border: 1px solid rgba(192,57,43,.15);
}
.ml-topbar .menu li a.menu-logout:hover i { color: #9b1c1c; }

/* ── Main content ──────────────────────────────────────────────── */
.ml-main {
    flex: 1;
    overflow: auto;
    padding-bottom: calc(var(--foot-h) + 8px);
}
.ml-main .content.px-4 { padding: 20px 24px !important; }

/* ── Footer ────────────────────────────────────────────────────── */
.ml-footer {
    height: var(--foot-h);
    display: grid !important;
    grid-template-columns: 1fr 1.6fr 1fr;
    align-items: center;
    padding: 0 18px;
    background: #064b20;
    color: rgba(255,255,255,.6);
    font-size: .74rem;
    gap: 10px;
    flex-shrink: 0;
    box-shadow: 0 -2px 10px rgba(0,0,0,.1);
}
.ml-footer div:nth-child(2) { text-align: center; }
.ml-footer div:nth-child(3) { text-align: right; }

/* ── Mobile ────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .ml-side {
        position: fixed;
        top: 0; left: 0;
        height: 100vh;
        z-index: 300;
        transform: translateX(0);
        transition: transform .22s ease, width .22s ease;
    }
    .ml-collapsed .ml-side {
        transform: translateX(calc(-1 * var(--sb-w)));
        width: var(--sb-w) !important;
        min-width: var(--sb-w) !important;
    }
    .ml-body { width: 100%; }
    .ml-footer { grid-template-columns: 1fr; height: auto; padding: 6px 12px; }
    .ml-footer div:nth-child(2), .ml-footer div:nth-child(3) { text-align: left; }
}
