:root {
    --shadcn-sidebar-expanded-width: 18rem;
    --shadcn-sidebar-collapsed-width: 5.25rem;
    --shadcn-sidebar-bg: #ffffff;
    --shadcn-sidebar-border: #e5e7eb;
    --shadcn-sidebar-text: #333333;
    --shadcn-sidebar-muted: #6b7280;
    --shadcn-sidebar-hover: #f3f4f6;
    --shadcn-sidebar-active: #eaf2ff;
    --shadcn-sidebar-active-text: #1d4ed8;
    --shadcn-sidebar-active-border: #bfdbfe;
    --shadcn-sidebar-parent-active-bg: #007BFE;
    --shadcn-sidebar-parent-active-text: #ffffff;
    --shadcn-sidebar-child-active-bg: #eff6ff;
    --shadcn-sidebar-child-active-text: #1d4ed8;
    --shadcn-sidebar-child-active-border: #dbeafe;
    --shadcn-sidebar-parent-open-bg: #2563eb;
    --shadcn-sidebar-parent-open-text: #ffffff;
    --shadcn-sidebar-nested-text: #4b5563;
    --shadcn-sidebar-nested-hover-bg: #f8fafc;
    --shadcn-sidebar-nested-bg: #f8fafc;
    --shadcn-sidebar-nested-border: #e5e7eb;
    --shadcn-sidebar-nested-connector: #dbe3ef;
    --shadcn-sidebar-nested-open-bg: #f3f4f6;
    --shadcn-sidebar-nested-open-text: #374151;
    --shadcn-sidebar-nested-open-border: #e5e7eb;
    --shadcn-content-gutter-open: 0rem;
    --shadcn-content-gutter-collapsed: 0rem;
    --shadcn-topbar-height: 3.6rem;
    --shadcn-sidebar-shadow: 0 0 0 1px rgba(17, 24, 39, 0.01), 0 12px 24px rgba(17, 24, 39, 0.06);
    --shadcn-sidebar-toggle-bg: #ffffff;
    --shadcn-sidebar-toggle-text: #4b5563;
    --shadcn-sidebar-toggle-border: #d1d5db;
    --shadcn-sidebar-toggle-hover-border: #d1d5db;
    --shadcn-sidebar-toggle-shadow: 0 6px 14px rgba(17, 24, 39, 0.14);
    --shadcn-sidebar-parent-active-shadow: 0 2px 8px rgba(37, 99, 235, 0.22);
    --shadcn-sidebar-child-active-indicator: #3b82f6;
    --shadcn-sidebar-active-parent-bg: #eef4ff;
    --shadcn-sidebar-active-parent-text: #1e40af;
    --shadcn-sidebar-active-parent-border: #dbeafe;
}

[data-bs-theme=dark],
body.theme-dark,
[data-menu-theme=dark] {
    --shadcn-sidebar-bg: #0f172a;
    --shadcn-sidebar-border: #1e293b;
    --shadcn-sidebar-text: #e2e8f0;
    --shadcn-sidebar-muted: #94a3b8;
    --shadcn-sidebar-hover: #1e293b;
    --shadcn-sidebar-active: #172554;
    --shadcn-sidebar-active-text: #bfdbfe;
    --shadcn-sidebar-active-border: #1e40af;
    --shadcn-sidebar-parent-active-bg: #1d4ed8;
    --shadcn-sidebar-parent-active-text: #eff6ff;
    --shadcn-sidebar-child-active-bg: #172554;
    --shadcn-sidebar-child-active-text: #bfdbfe;
    --shadcn-sidebar-child-active-border: #1e40af;
    --shadcn-sidebar-parent-open-bg: #1e3a8a;
    --shadcn-sidebar-parent-open-text: #dbeafe;
    --shadcn-sidebar-nested-text: #cbd5e1;
    --shadcn-sidebar-nested-hover-bg: #1e293b;
    --shadcn-sidebar-nested-bg: #0f172a;
    --shadcn-sidebar-nested-border: #334155;
    --shadcn-sidebar-nested-connector: #334155;
    --shadcn-sidebar-nested-open-bg: #1e293b;
    --shadcn-sidebar-nested-open-text: #e2e8f0;
    --shadcn-sidebar-nested-open-border: #334155;
    --shadcn-sidebar-shadow: 0 0 0 1px rgba(15, 23, 42, 0.45), 0 16px 32px rgba(2, 6, 23, 0.55);
    --shadcn-sidebar-toggle-bg: #111827;
    --shadcn-sidebar-toggle-text: #cbd5e1;
    --shadcn-sidebar-toggle-border: #334155;
    --shadcn-sidebar-toggle-hover-border: #475569;
    --shadcn-sidebar-toggle-shadow: 0 8px 18px rgba(2, 6, 23, 0.6);
    --shadcn-sidebar-parent-active-shadow: 0 6px 14px rgba(30, 64, 175, 0.45);
    --shadcn-sidebar-child-active-indicator: #60a5fa;
    --shadcn-sidebar-active-parent-bg: #1e3a8a;
    --shadcn-sidebar-active-parent-text: #bfdbfe;
    --shadcn-sidebar-active-parent-border: #1e40af;
}

/* Motion scale tokens — tweak here to adjust feel globally */
:root {
    --shadcn-dur-micro: 0.18s;  /* hover colors, icon tints */
    --shadcn-dur-fast: 0.22s;   /* chevron rotation, label fade */
    --shadcn-dur-base: 0.5s;   /* sidebar width, dropdown menu */
    --shadcn-ease: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Slightly smaller sidebar on common laptop widths */
@media (min-width: 1367px) and (max-width: 1536px) {
    :root {
        --shadcn-sidebar-expanded-width: 17rem;
        --shadcn-sidebar-collapsed-width: 5rem;
    }
}

@media (min-width: 992px) and (max-width: 1366px) {
    :root {
        --shadcn-sidebar-expanded-width: 16rem;
        --shadcn-sidebar-collapsed-width: 4.75rem;
    }
}

/* Honour user's motion preference — kill all animations */
@media (prefers-reduced-motion: reduce) {
    #sidebar,
    #sidebar *,
    body[bp-layout^="vertical"] aside.navbar-vertical,
    body[bp-layout^="vertical"] aside.navbar-vertical * {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
    }
}

#sidebar {
    width: var(--shadcn-sidebar-expanded-width) !important;
    color: var(--shadcn-sidebar-text);
    background: var(--shadcn-sidebar-bg) !important;
    border-right: 1px solid var(--shadcn-sidebar-border);
    box-shadow: var(--shadcn-sidebar-shadow);
    transition: width var(--shadcn-dur-base) var(--shadcn-ease);
    overflow: hidden;
}

#sidebar .sidebar-brand {
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.75rem 0.75rem;
    border-bottom: 1px solid var(--shadcn-sidebar-border);
}

#sidebar .sidebar-brand-link {
    display: flex;
    align-items: center;
    min-width: 0;
    max-width: calc(100% - 2.75rem);
    overflow: hidden;
    color: var(--shadcn-sidebar-text) !important;
    font-weight: 600;
    letter-spacing: 0;
}

#sidebar .sidebar-brand-link img {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 0.7rem;
    object-fit: contain;
    margin-right: 0.65rem !important;
}

#sidebar .sidebar-brand-link b,
#sidebar .sidebar-brand-link span {
    color: var(--shadcn-sidebar-text) !important;
    line-height: 1.1;
}

#sidebar .sidebar-shadcn-toggle,
body[bp-layout^="vertical"] .sidebar-shadcn-toggle {
    width: 2rem;
    min-width: 2rem;
    height: 2rem;
    border: 1px solid var(--shadcn-sidebar-toggle-border);
    border-radius: 0.5rem;
    background: var(--shadcn-sidebar-toggle-bg);
    color: var(--shadcn-sidebar-toggle-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

#sidebar .sidebar-shadcn-toggle svg,
body[bp-layout^="vertical"] .sidebar-shadcn-toggle svg {
    width: 1rem;
    height: 1rem;
}

#sidebar .sidebar-shadcn-toggle:hover,
body[bp-layout^="vertical"] .sidebar-shadcn-toggle:hover {
    background: var(--shadcn-sidebar-hover);
    border-color: var(--shadcn-sidebar-toggle-hover-border);
    color: var(--shadcn-sidebar-text);
}

#sidebar .sidebar-nav {
    padding: 0.75rem 0.6rem 1rem;
}

#sidebar .sidebar-nav .simplebar-content {
    display: flex;
    flex-direction: column;
    gap: 0.22rem;
}

#sidebar .nav-link {
    min-height: 2.5rem;
    border-radius: 2px;
    color: var(--shadcn-sidebar-text) !important;
    font-weight: 500;
    padding: 0.58rem 0.72rem;
    transition: background-color var(--shadcn-dur-micro) var(--shadcn-ease),
                color var(--shadcn-dur-micro) var(--shadcn-ease);
}

#sidebar .nav-link .nav-icon {
    width: 1.25rem;
    min-width: 1.25rem;
    height: 1.25rem;
    color: var(--shadcn-sidebar-muted);
    margin-right: 0.75rem;
    font-size: 1.1rem;
    flex-shrink: 0;
    transition: color var(--shadcn-dur-micro) var(--shadcn-ease);
}

#sidebar .nav-link span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    /* Smooth fade when collapsed — driven by max-width on the parent link */
    opacity: 1;
    transition: opacity var(--shadcn-dur-fast) var(--shadcn-ease);
}

#sidebar .nav-link:hover,
#sidebar .nav-group.show > .nav-link {
    background: var(--shadcn-sidebar-hover);
    text-decoration: none;
}

/* CoreUI sidebar chevron — use rotation instead of content swap */
#sidebar .nav-group-toggle::after {
    display: inline-block;
    color: var(--shadcn-sidebar-muted);
    /* Do NOT change content here — let CoreUI keep its glyph, we rotate it */
    transition: transform var(--shadcn-dur-fast) var(--shadcn-ease),
                color var(--shadcn-dur-micro) var(--shadcn-ease);
}

#sidebar .nav-group.show > .nav-group-toggle::after {
    transform: rotate(-180deg);
}

#sidebar .nav-link.active {
    background: var(--shadcn-sidebar-active);
    color: var(--shadcn-sidebar-active-text) !important;
    border: 1px solid var(--shadcn-sidebar-active-border);
}

#sidebar .nav-link.active .nav-icon {
    color: var(--shadcn-sidebar-active-text) !important;
}

#sidebar .nav-group-items {
    margin: 0.2rem 0 0.3rem;
    padding: 0.1rem 0 0.1rem 1.8rem;
    border-left: 1px solid var(--shadcn-sidebar-border);
}

#sidebar .nav-group-items .nav-link {
    min-height: 2.2rem;
    font-weight: 450;
    color: var(--shadcn-sidebar-nested-open-text) !important;
    padding: 0.45rem 0.55rem;
}

/* CoreUI collapse duration — keep consistent with motion tokens */
#sidebar .nav-group-items.collapsing {
    transition-duration: var(--shadcn-dur-base) !important;
    transition-timing-function: var(--shadcn-ease) !important;
}

@media (min-width: 992px) {
    body[bp-layout^="vertical"] .page {
        padding-left: 0 !important;
    }

    /* Single transition rule covers both expand and collapse — stays in sync with sidebar width */
    body[bp-layout^="vertical"] .page-wrapper {
        transition: margin-left var(--shadcn-dur-base) var(--shadcn-ease);
    }

    body[bp-layout^="vertical"]:not(.sidebar-shadcn-collapsed) .page-wrapper {
        margin-left: calc(var(--shadcn-sidebar-expanded-width) + var(--shadcn-content-gutter-open)) !important;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed .page-wrapper {
        margin-left: calc(var(--shadcn-sidebar-collapsed-width) + var(--shadcn-content-gutter-collapsed)) !important;
    }

    body[bp-layout^="vertical"] .page-body > main,
    body[bp-layout^="vertical"] header.topbar-transparent > .container-xl,
    body[bp-layout^="vertical"] header.topbar-transparent > .container-fluid,
    body[bp-layout^="vertical"] .page-wrapper > .sticky-top .container-xl,
    body[bp-layout^="vertical"] .page-wrapper > .sticky-top .container-fluid,
    body[bp-layout^="vertical"] .page-wrapper > .footer .container-xl,
    body[bp-layout^="vertical"] .page-wrapper > .footer .container-fluid {
        max-width: none !important;
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    body.sidebar-shadcn-collapsed #sidebar {
        width: var(--shadcn-sidebar-collapsed-width) !important;
    }

    body.sidebar-shadcn-collapsed #sidebar .sidebar-brand {
        justify-content: center;
        padding-inline: 0.45rem;
    }

    body.sidebar-shadcn-collapsed #sidebar .sidebar-brand-link {
        max-width: 2.2rem;
        margin-right: 0;
    }

    body.sidebar-shadcn-collapsed #sidebar .sidebar-brand-link img {
        margin-right: 0 !important;
    }

    /* Fade out brand text instead of display:none snap */
    body.sidebar-shadcn-collapsed #sidebar .sidebar-brand-link b,
    body.sidebar-shadcn-collapsed #sidebar .sidebar-brand-link span {
        opacity: 0;
        pointer-events: none;
        /* display:none still needed after transition so it doesn't take space */
        /* JS adds display:none via transitionend — see sidebar.blade.php */
        max-width: 0;
        overflow: hidden;
    }

    body.sidebar-shadcn-collapsed #sidebar .sidebar-nav {
        padding-left: 0.45rem;
        padding-right: 0.45rem;
    }

    body.sidebar-shadcn-collapsed #sidebar .nav-link {
        justify-content: center;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    body.sidebar-shadcn-collapsed #sidebar .nav-link .nav-icon {
        margin-right: 0;
    }

    /* Fade nav labels when collapsed — do not snap with display:none */
    body.sidebar-shadcn-collapsed #sidebar .nav-link span {
        opacity: 0;
        max-width: 0;
        margin: 0;
        overflow: hidden;
        pointer-events: none;
    }

    /* Collapse chevrons and sub-groups smoothly */
    body.sidebar-shadcn-collapsed #sidebar .nav-group-toggle::after {
        opacity: 0;
        pointer-events: none;
    }

    body.sidebar-shadcn-collapsed #sidebar .nav-group-items {
        display: none !important;
    }

    body.sidebar-shadcn-collapsed #sidebar .sidebar-shadcn-toggle {
        position: absolute;
        top: 0.85rem;
        right: 0.5rem;
    }

    body[bp-layout="vertical-transparent"] .page-wrapper > div:first-child {
        min-height: var(--shadcn-topbar-height);
    }

    body[bp-layout="vertical-transparent"] header.topbar-transparent {
        position: fixed !important;
        top: 0;
        right: 0;
        left: calc(var(--shadcn-sidebar-expanded-width) + var(--shadcn-content-gutter-open));
        z-index: 1025;
        min-height: var(--shadcn-topbar-height);
        background: var(--shadcn-sidebar-bg) !important;
        border-bottom: 1px solid var(--shadcn-sidebar-border);
        box-shadow: var(--shadcn-sidebar-shadow);
        transition: left 0.2s ease;
    }

    body[bp-layout="vertical-transparent"].sidebar-shadcn-collapsed header.topbar-transparent {
        left: calc(var(--shadcn-sidebar-collapsed-width) + var(--shadcn-content-gutter-collapsed));
    }

    body[bp-layout="vertical-transparent"] .page-body {
        margin-top: 0.75rem;
    }
}

@media (max-width: 991.98px) {
    /* Prevent horizontal scroll when the off-canvas sidebar slides in */
    body[bp-layout^="vertical"] {
        overflow-x: hidden;
    }

    body[bp-layout^="vertical"] .page,
    body[bp-layout^="vertical"] .page-wrapper {
        padding-left: 0 !important;
        margin-left: 0 !important;
        /* Disable the desktop transition on mobile — no margin shifting needed */
        transition: none !important;
    }

    body[bp-layout^="vertical"] .page-body > main,
    body[bp-layout^="vertical"] header.topbar-transparent > .container-xl,
    body[bp-layout^="vertical"] header.topbar-transparent > .container-fluid,
    body[bp-layout^="vertical"] .page-wrapper > .sticky-top .container-xl,
    body[bp-layout^="vertical"] .page-wrapper > .sticky-top .container-fluid,
    body[bp-layout^="vertical"] .page-wrapper > .footer .container-xl,
    body[bp-layout^="vertical"] .page-wrapper > .footer .container-fluid {
        max-width: none !important;
        width: 100% !important;
    }

    #sidebar {
        box-shadow: none;
    }

    body[bp-layout^="vertical"] aside.navbar-vertical.navbar-expand-lg {
        width: min(85vw, var(--shadcn-sidebar-expanded-width));
        max-width: 100%;
    }

    body[bp-layout^="vertical"] aside.navbar-vertical .navbar-collapse {
        max-height: calc(100vh - 4.75rem);
    }
}

/* Tabler vertical layouts */
body[bp-layout^="vertical"] aside.navbar-vertical.navbar-expand-lg {
    --tblr-navbar-width: var(--shadcn-sidebar-expanded-width);
    width: var(--shadcn-sidebar-expanded-width);
    background: var(--shadcn-sidebar-bg) !important;
    border-right: 1px solid var(--shadcn-sidebar-border);
    box-shadow: var(--shadcn-sidebar-shadow);
    color: var(--shadcn-sidebar-text);
    transition: width var(--shadcn-dur-base) var(--shadcn-ease);
    /* overflow must stay visible for dropdowns to escape the sidebar bounds */
    overflow: visible !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical > .container-fluid {
    height: 100%;
    overflow: visible;
    display: flex;
    flex-direction: column;
}

body[bp-layout^="vertical"] aside.navbar-vertical .shadcn-sidebar-header {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 4.25rem;
    padding: 0.55rem 0.75rem;
    margin-right: 0.2rem;
    border-bottom: 1px solid var(--shadcn-sidebar-border);
}

body[bp-layout^="vertical"] .shadcn-sidebar-brand-link {
    display: flex;
    align-items: center;
    min-width: 0;
    max-width: calc(100% - 0.25rem);
    color: var(--shadcn-sidebar-text) !important;
    overflow: hidden;
    text-decoration: none;
}

body[bp-layout^="vertical"] .shadcn-sidebar-brand-link img {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 2px;
    object-fit: contain;
    margin-right: 0.65rem !important;
}

body[bp-layout^="vertical"] .shadcn-sidebar-brand-link b,
body[bp-layout^="vertical"] .shadcn-sidebar-brand-link span {
    color: var(--shadcn-sidebar-text) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.15;
}

body[bp-layout^="vertical"] .shadcn-sidebar-header .navbar-brand {
    margin: 0 !important;
    flex: 1;
    min-width: 0;
}

/* Toggle is now in the horizontal topbar — shadcn/ui style */
body[bp-layout="vertical-transparent"] header.topbar-transparent .shadcn-topbar-toggle {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: none;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .nav-link,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-item {
    border-radius: 2px;
    color: var(--shadcn-sidebar-text) !important;
    font-weight: 400;
    min-height: 2.45rem;
    display: flex;
    align-items: center;
    margin: 0.12rem 0;
    transition: background-color var(--shadcn-dur-micro) var(--shadcn-ease),
                color var(--shadcn-dur-micro) var(--shadcn-ease),
                border-color var(--shadcn-dur-micro) var(--shadcn-ease);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .nav-link:hover,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-item:hover {
    background: var(--shadcn-sidebar-hover);
    text-decoration: none;
}

body[bp-layout^="vertical"] aside.navbar-vertical .nav-link .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .dropdown-item .nav-icon {
    color: var(--shadcn-sidebar-muted);
    margin-right: 0.72rem;
    width: 1.25rem;
    min-width: 1.25rem;
    flex-shrink: 0;
    transition: color var(--shadcn-dur-micro) var(--shadcn-ease);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown > .nav-link.dropdown-toggle::after {
    /* Keep a single chevron glyph and rotate it — avoids content-swap jank */
    content: "\f107";
    font-family: "Line Awesome Free";
    font-weight: 900;
    font-size: 10px;
    margin-left: auto;
    margin-right: 15px;
    padding-right: 0;
    color: var(--shadcn-sidebar-muted);
    display: inline-block;
    transform: rotate(0deg);
    transition: transform var(--shadcn-dur-fast) var(--shadcn-ease),
                color var(--shadcn-dur-micro) var(--shadcn-ease);
}

/* Rotate the chevron when open — no content swap needed */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown.show > .nav-link.dropdown-toggle::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown > .nav-link.dropdown-toggle.show::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown > .nav-link.dropdown-toggle.is-open::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown > .nav-link.dropdown-toggle[aria-expanded="true"]::after {
    transform: rotate(-180deg);
    color: inherit;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-collapse {
    margin-top: 0.45rem;
    flex: 1 1 auto;
    min-height: 0;
    max-height: calc(100vh - 4.75rem);
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    /* Smooth scroll container appearance */
    scroll-behavior: smooth;
}

/* ── Tabler Sidebar: dropdown-menu slide animation ── */
/* Bootstrap adds/removes .show atomically — we animate via max-height+opacity */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu {
    /* Reset Bootstrap's display:none-only approach by letting the element stay
       in layout and fading it in. We pair this with a JS transitionend guard
       in menu_container.blade.php so closed menus don't overlap siblings. */
    display: block;
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    pointer-events: none;
    transition: max-height var(--shadcn-dur-base) var(--shadcn-ease),
                opacity var(--shadcn-dur-fast) var(--shadcn-ease);
    /* Override Bootstrap positioning that would break layout */
    position: static !important;
    transform: none !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu.show {
    max-height: 2000px; /* large enough for any nested depth */
    opacity: 1;
    pointer-events: auto;
}

/* Nested submenus — same treatment but slightly faster */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-menu.dropdown-submenu {
    display: block;
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    pointer-events: none;
    transition: max-height var(--shadcn-dur-base) var(--shadcn-ease),
                opacity var(--shadcn-dur-fast) var(--shadcn-ease);
    position: static !important;
    transform: none !important;
    /* Keep existing visual indent */
    margin-left: 0.55rem;
    margin-top: 0.12rem;
    padding-left: 0.35rem;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-menu.dropdown-submenu.show {
    max-height: 1000px;
    opacity: 1;
    pointer-events: auto;
}

@media (min-width: 992px) {
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical.navbar-expand-lg {
        --tblr-navbar-width: var(--shadcn-sidebar-collapsed-width);
        width: var(--shadcn-sidebar-collapsed-width);
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-collapse {
        scrollbar-gutter: stable both-edges;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed .shadcn-sidebar-header {
        justify-content: center !important;
        position: relative;
        padding: 0.55rem 0.35rem;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed .shadcn-sidebar-brand-link {
        max-width: 2.2rem;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed .shadcn-sidebar-brand-link img {
        margin-right: 0 !important;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .nav-link,
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .dropdown-item {
        justify-content: center;
        width: 100%;
        padding-left: 0 !important;
        padding-right: 0 !important;
        text-align: center;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .nav-link .nav-icon,
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .dropdown-item .nav-icon {
        width: 1.5rem;
        min-width: 1.5rem;
        margin-right: 0;
        margin-left: 0;
        margin-inline: auto !important;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        text-align: center;
    }

    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .nav-link .nav-icon::before,
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .dropdown-item .nav-icon::before {
        width: 100%;
        text-align: center;
    }

    /* Fade labels and chevrons when collapsed — no display:none snap */
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed .shadcn-sidebar-brand-link b,
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed .shadcn-sidebar-brand-link span,
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .nav-link span,
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .dropdown-item span {
        opacity: 0;
        max-width: 0;
        margin: 0;
        overflow: hidden;
        pointer-events: none;
    }

    /* Fade chevrons out */
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .dropdown-toggle::after {
        display: none !important;
    }

    /* Suppress open dropdowns in collapsed state */
    body[bp-layout^="vertical"].sidebar-shadcn-collapsed aside.navbar-vertical .navbar-nav .dropdown-menu {
        display: none !important;
    }

}

/* Brand link text — fade transition (shared by both CoreUI and Tabler sidebars) */
.shadcn-sidebar-brand-link b,
.shadcn-sidebar-brand-link span,
#sidebar .sidebar-brand-link b,
#sidebar .sidebar-brand-link span {
    transition: opacity var(--shadcn-dur-fast) var(--shadcn-ease),
                max-width var(--shadcn-dur-base) var(--shadcn-ease);
}

/* Nav label fade transition */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .nav-link span,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-item span {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    transition: opacity var(--shadcn-dur-fast) var(--shadcn-ease),
                max-width var(--shadcn-dur-base) var(--shadcn-ease);
}

/* Chevron fade transition */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-toggle::after {
    transition: opacity var(--shadcn-dur-fast) var(--shadcn-ease),
                transform var(--shadcn-dur-fast) var(--shadcn-ease),
                color var(--shadcn-dur-micro) var(--shadcn-ease);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .nav-link.active,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-item.active {
    background: var(--shadcn-sidebar-active) !important;
    color: var(--shadcn-sidebar-active-text) !important;
    border: 1px solid var(--shadcn-sidebar-active-border);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .nav-link.active .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-item.active .nav-icon {
    color: var(--shadcn-sidebar-active-text) !important;
}

/* Hierarchy: parent and child must not look identical */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .nav-link.active,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown.show > .nav-link {
    background: var(--shadcn-sidebar-parent-active-bg) !important;
    color: var(--shadcn-sidebar-parent-active-text) !important;
    border-color: var(--shadcn-sidebar-parent-active-bg) !important;
    box-shadow: var(--shadcn-sidebar-parent-active-shadow);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .nav-link.active .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown.show > .nav-link .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .nav-link.active::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.dropdown.show > .nav-link::after {
    color: var(--shadcn-sidebar-parent-active-text) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.has-active-child > .nav-link.dropdown-toggle:not(.active) {
    background: var(--shadcn-sidebar-parent-open-bg) !important;
    color: var(--shadcn-sidebar-parent-open-text) !important;
    border: 1px solid var(--shadcn-sidebar-parent-open-bg);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.has-active-child > .nav-link.dropdown-toggle:not(.active) .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item.has-active-child > .nav-link.dropdown-toggle:not(.active)::after {
    color: var(--shadcn-sidebar-parent-open-text) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu {
    margin-left: 0.55rem;
    padding-left: 0.45rem;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu {
    border: 0;
    box-shadow: none;
    background: transparent;
    padding: 0.12rem 0.1rem 0.18rem;
    margin-top: 0.1rem;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend {
    position: relative;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend::before {
    content: none;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-menu.dropdown-submenu {
    margin-left: 0.55rem;
    margin-top: 0.12rem;
    padding-left: 0.35rem;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle {
    color: var(--shadcn-sidebar-nested-text) !important;
    background: transparent;
    min-height: 2.2rem;
    border-radius: 2px;
    font-size: 0.9rem;
    border: 1px solid transparent;
    padding-left: 0.62rem !important;
    padding-right: 0.62rem !important;
    padding-top: 0.42rem;
    padding-bottom: 0.42rem;
}

/* First child level: keep a clear visual offset from top-level parent items */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu > .dropdown-menu-columns > .dropdown-menu-column > .dropdown-item,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu > .dropdown-menu-columns > .dropdown-menu-column > .dropend > .dropdown-toggle {
    padding-left: 0.95rem !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle .nav-icon {
    font-size: 1rem;
    opacity: 0.9;
    margin-right: 0.62rem;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item span,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle span {
    flex: 1 1 auto;
    min-width: 0;
    line-height: 1.24;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend > .dropdown-toggle::after {
    /* Same chevron glyph; rotated 90deg when submenu opens */
    content: "\f107";
    font-family: "Line Awesome Free";
    font-weight: 900;
    font-size: 10px;
    margin-left: auto;
    color: var(--shadcn-sidebar-muted);
    margin-right: 15px;
    padding-right: 0;
    display: inline-block;
    transform: rotate(-90deg); /* point right by default (→) */
    transition: transform var(--shadcn-dur-fast) var(--shadcn-ease),
                color var(--shadcn-dur-micro) var(--shadcn-ease);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item:hover,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle:hover {
    background: var(--shadcn-sidebar-nested-hover-bg) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend.show > .dropdown-toggle {
    background: var(--shadcn-sidebar-nested-open-bg) !important;
    color: var(--shadcn-sidebar-nested-open-text) !important;
    border-color: var(--shadcn-sidebar-nested-open-border) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend.show > .dropdown-toggle .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend.show > .dropdown-toggle::after {
    color: var(--shadcn-sidebar-nested-open-text) !important;
}

/* Rotate to point down (↓) when open — no content swap */
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend.show > .dropdown-toggle::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend > .dropdown-toggle.show::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend > .dropdown-toggle.is-open::after,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropend > .dropdown-toggle[aria-expanded="true"]::after {
    transform: rotate(0deg); /* now points down, matching top-level behavior */
    color: var(--shadcn-sidebar-nested-open-text) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item.active {
    position: relative;
    background: var(--shadcn-sidebar-child-active-bg) !important;
    color: var(--shadcn-sidebar-child-active-text) !important;
    border: 1px solid var(--shadcn-sidebar-child-active-border) !important;
    box-shadow: none;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item.active .nav-icon {
    color: var(--shadcn-sidebar-child-active-text) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-item.active::before {
    content: "";
    position: absolute;
    left: 0.45rem;
    top: 0.42rem;
    bottom: 0.42rem;
    width: 3px;
    border-radius: 2px;
    background: var(--shadcn-sidebar-child-active-indicator);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle.active-parent {
    background: var(--shadcn-sidebar-active-parent-bg) !important;
    color: var(--shadcn-sidebar-active-parent-text) !important;
    border: 1px solid var(--shadcn-sidebar-active-parent-border);
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle.active-parent .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav .dropdown-menu .dropdown-toggle.active-parent::after {
    color: var(--shadcn-sidebar-active-parent-text) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu > .dropend > .dropdown-menu .dropend > .dropdown-toggle.active-parent {
    background: var(--shadcn-sidebar-nested-open-bg) !important;
    color: var(--shadcn-sidebar-nested-open-text) !important;
    border-color: var(--shadcn-sidebar-nested-open-border) !important;
}

body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu > .dropend > .dropdown-menu .dropend > .dropdown-toggle.active-parent .nav-icon,
body[bp-layout^="vertical"] aside.navbar-vertical .navbar-nav > .nav-item > .dropdown-menu > .dropend > .dropdown-menu .dropend > .dropdown-toggle.active-parent::after {
    color: var(--shadcn-sidebar-nested-open-text) !important;
}


/* Fixed positioning for vertical navbar */
body[bp-layout^="vertical"] aside.navbar-vertical.navbar-expand-lg {
    position: fixed !important;
    height: 100vh;
    top: 0;
    left: 0;
    z-index: 1030;
}

/* Fixed positioning for horizontal navbar */
body[bp-layout^="horizontal"] header.top {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1030;
    background: var(--shadcn-sidebar-bg) !important;
    border-bottom: 1px solid var(--shadcn-sidebar-border);
    box-shadow: var(--shadcn-sidebar-shadow);
}

/* ================================================
   Sidebar Dropdown Animation — unified motion system
   ================================================ */

/* CoreUI sidebar: collapse speed is controlled via the collapsing rule above.
   The keyframe below provides a subtle fade-in reinforcement for Tabler dropdowns
   where max-height animation already drives the primary motion.                  */
@keyframes sidebarFadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ================================================
   Page-level layout helpers
   ================================================ */

/* Application edit page header sits flush under the topbar */
.application-edit-header {
    margin-top: -7px;
}

/* ================================================
   Sidebar Footer Collapse — Layout Fix
   ================================================ */

/* Hide text and horizontal rules when sidebar is collapsed */
body.sidebar-shadcn-collapsed .sidebar-footer-text {
    display: none !important;
}

/* Stack footer items vertically and center them when collapsed */
body.sidebar-shadcn-collapsed .sidebar-footer-main-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    align-items: center !important;
}

/* Ensure each row in the footer behaves as a column when collapsed */
body.sidebar-shadcn-collapsed .sidebar-footer-row {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    margin-bottom: 0.5rem !important;
}

/* Adjust the link/avatar area to be centered */
body.sidebar-shadcn-collapsed .sidebar-footer-row > a {
    justify-content: center !important;
    flex-grow: 0 !important;
    width: auto !important;
    padding: 0 !important;
    margin-bottom: 0 !important;
}

/* Move mode switcher below the avatar when collapsed */
body.sidebar-shadcn-collapsed .sidebar-mode-switcher {
    margin: 0.5rem 0 0 0 !important;
}

/* Transform the logout button into a circular icon button when collapsed */
body.sidebar-shadcn-collapsed .btn-logout {
    width: 32px !important;
    height: 32px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
}

body.sidebar-shadcn-collapsed .btn-logout i {
    margin: 0 !important;
}

/* Special case for the logout icon spacing in expanded mode */
.sidebar-footer-row .btn-logout i {
    margin-right: 4px;
}

