/* =========================================
   Sidebar Modern (RTL Native)
   ========================================= */

/* 1. Base Layout & Positioning */
.sidebar-modern {
    position: fixed;
    inset-block-start: 0;
    inset-block-end: 0;
    inset-inline-start: 0;
    /* Left in LTR, Right in RTL */

    width: var(--sidebar-width);
    background-color: var(--sidebar-bg);
    color: var(--sidebar-text);
    z-index: var(--z-sidebar);

    display: flex;
    flex-direction: column;
    transition: transform var(--transition-normal), width var(--transition-normal);

    /* Shadow only on the inner side */
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
}

/* 2. Sidebar Header & Logo */
.sidebar-header {
    height: var(--navbar-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-inline: 1.5rem;
    border-bottom: 1px solid var(--sidebar-border-color);
    background-color: var(--sidebar-bg-dark);
}

.sidebar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: #fff;
    overflow: hidden;
}

.logo-wrapper {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.brand-logo {
    max-width: 100%;
    max-height: 100%;
}

.brand-name {
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    white-space: nowrap;
    opacity: 1;
    transition: opacity var(--transition-normal);
}

.sidebar-close-btn {
    background: none;
    border: none;
    color: var(--sidebar-text);
    font-size: 1.25rem;
    cursor: pointer;
    padding: 4px;
}

/* 2b. Entity Switcher */
.entity-switcher-container {
    padding: 0.875rem 0.875rem 0.75rem;
    border-bottom: 1px solid var(--sidebar-border-color);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.015));
}

.entity-switcher-label {
    display: block;
    margin-block-end: 0.45rem;
    padding-inline: 0.125rem;
    color: rgba(255, 255, 255, 0.58);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.entity-switcher-dropdown {
    position: relative;
}

.entity-switcher-card {
    width: 100%;
    min-width: 0;
    min-height: 54px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0.58rem 0.65rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background-color: rgba(255, 255, 255, 0.075);
    color: rgba(255, 255, 255, 0.94);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
    text-align: start;
    transition: background-color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}

button.btn.entity-switcher-card,
button.btn.entity-switcher-card:not(:hover):not(:focus):not(:active),
.entity-switcher-card.entity-switcher-card--static {
    color: rgba(255, 255, 255, 0.94) !important;
}

.entity-switcher-card--static {
    cursor: default;
}

.entity-switcher-toggle:hover,
.entity-switcher-toggle:focus,
.entity-switcher-toggle.show {
    background-color: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.22);
    color: #fff;
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.14);
}

.entity-switcher-main {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex: 1;
}

.entity-icon-disc {
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background-color: rgba(14, 165, 233, 0.16);
    background-color: color-mix(in srgb, var(--entity-color, #38bdf8) 18%, transparent);
    color: var(--entity-color, #38bdf8);
    font-size: 0.88rem;
}

.entity-icon-disc i,
.entity-icon-disc svg {
    color: var(--entity-color, #38bdf8) !important;
}

.entity-icon-disc--muted {
    background-color: rgba(148, 163, 184, 0.18);
    color: #cbd5e1;
}

.entity-icon-disc--muted i,
.entity-icon-disc--muted svg {
    color: #cbd5e1 !important;
}

.entity-copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.08rem;
    line-height: 1.15;
}

.entity-name {
    min-width: 0;
    max-width: 100%;
    display: block;
    overflow: hidden;
    color: inherit;
    font-size: 0.88rem;
    font-weight: 650;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.entity-switcher-card .entity-name,
.entity-switcher-option .entity-name {
    color: rgba(255, 255, 255, 0.94) !important;
}

.entity-subtitle {
    min-width: 0;
    max-width: 100%;
    display: block;
    overflow: hidden;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.entity-switcher-card .entity-subtitle,
.entity-switcher-option .entity-subtitle {
    color: rgba(255, 255, 255, 0.64) !important;
}

.entity-switcher-chevron {
    flex: 0 0 auto;
    color: rgba(255, 255, 255, 0.55);
    font-size: 0.68rem;
    transition: transform var(--transition-fast);
}

.entity-switcher-card .entity-switcher-chevron,
.entity-switcher-card .entity-switcher-chevron i,
.entity-switcher-card .entity-switcher-chevron svg {
    color: rgba(255, 255, 255, 0.72) !important;
}

.entity-switcher-toggle[aria-expanded="true"] .entity-switcher-chevron {
    transform: rotate(180deg);
}

.entity-switcher-menu {
    width: min(380px, calc(100vw - 2rem));
    min-width: 100%;
    max-height: min(620px, calc(100vh - var(--navbar-height) - 2rem));
    overflow: hidden;
    padding: 0.55rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background-color: var(--sidebar-bg, #1e2a3a);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.38);
}

.entity-switcher-menu-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.2rem 0.25rem 0.55rem;
}

.entity-switcher-menu-title {
    color: #fff;
    font-size: 0.82rem;
    font-weight: 700;
}

.entity-switcher-count {
    flex: 0 0 auto;
    color: rgba(255, 255, 255, 0.52);
    font-size: 0.72rem;
    font-weight: 600;
}

.entity-switcher-search {
    position: relative;
    margin-block-end: 0.5rem;
}

.entity-switcher-search i {
    position: absolute;
    inset-block-start: 50%;
    inset-inline-start: 0.68rem;
    transform: translateY(-50%);
    color: rgba(255, 255, 255, 0.48);
    font-size: 0.78rem;
    pointer-events: none;
}

.entity-switcher-search .form-control {
    height: 34px;
    padding-inline-start: 2rem;
    padding-inline-end: 0.75rem;
    border-color: rgba(255, 255, 255, 0.13);
    border-radius: 7px;
    background-color: rgba(15, 23, 42, 0.46);
    color: #fff;
    font-size: 0.82rem;
}

.entity-switcher-search .form-control::placeholder {
    color: rgba(255, 255, 255, 0.44);
}

.entity-switcher-search .form-control:focus {
    border-color: rgba(14, 165, 233, 0.58);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.16);
    background-color: rgba(15, 23, 42, 0.72);
}

.entity-switcher-options {
    max-height: min(430px, calc(100vh - 240px));
    overflow-y: auto;
    overflow-x: hidden;
    padding-inline-end: 0.15rem;
    scrollbar-width: thin;
    scrollbar-color: #475569 transparent;
}

.entity-switcher-options::-webkit-scrollbar {
    width: 5px;
}

.entity-switcher-options::-webkit-scrollbar-thumb {
    background-color: #475569;
    border-radius: 4px;
}

.entity-switcher-group {
    padding: 0.62rem 0.55rem 0.28rem;
    color: rgba(255, 255, 255, 0.48);
    font-size: 0.66rem;
    font-weight: 750;
    letter-spacing: 0;
    line-height: 1.1;
    text-transform: uppercase;
}

.entity-switcher-option-form {
    margin: 0;
}

.entity-switcher-option {
    width: 100%;
    min-width: 0;
    min-height: 46px;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.48rem 0.55rem;
    border: 0;
    border-radius: 7px;
    background: transparent;
    color: rgba(255, 255, 255, 0.84);
    text-align: start;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.entity-switcher-option:hover,
.entity-switcher-option:focus {
    background-color: rgba(255, 255, 255, 0.09);
    color: #fff;
    outline: none;
}

.entity-switcher-option:hover .entity-name,
.entity-switcher-option:focus .entity-name {
    color: #fff !important;
}

.entity-switcher-option.active,
.entity-switcher-option:disabled {
    background-color: rgba(16, 185, 129, 0.13);
    color: #fff;
    opacity: 1;
}

.entity-switcher-option:disabled {
    cursor: default;
    pointer-events: none;
}

.entity-active-check {
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-inline-start: auto;
    border-radius: 999px;
    background-color: rgba(16, 185, 129, 0.18);
    color: #34d399;
    font-size: 0.68rem;
}

.entity-switcher-empty {
    padding: 0.9rem 0.65rem;
    color: rgba(255, 255, 255, 0.58);
    font-size: 0.82rem;
    text-align: center;
}

/* 3. Navigation Content */
.sidebar-content {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding-block: 1rem;
    /* Thin Scrollbar */
    scrollbar-width: thin;
    scrollbar-color: #475569 transparent;
}

.sidebar-content::-webkit-scrollbar {
    width: 5px;
}

.sidebar-content::-webkit-scrollbar-thumb {
    background-color: #475569;
    border-radius: 4px;
}

.sidebar-nav {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding-inline: 12px;
}

/* 4. Section Labels */
.nav-section-label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #64748b;
    margin-block: 16px 8px;
    padding-inline-start: 16px;
    white-space: nowrap;
}

/* 4b. Role Section Headers (multi-role unified sidebar) */
.role-section-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    margin-block-start: 8px;
    border-block-start: 1px solid rgba(255, 255, 255, 0.08);
    cursor: pointer;
    user-select: none;
    transition: background-color var(--transition-fast);
    border-radius: var(--border-radius-md);
}

.role-section-header:first-child {
    margin-block-start: 0;
    border-block-start: none;
}

.role-section-header:hover {
    background-color: rgba(255, 255, 255, 0.05);
}

.role-section-icon {
    width: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    flex-shrink: 0;
}

.role-section-label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: rgba(255, 255, 255, 0.5);
    flex: 1;
    white-space: nowrap;
}

.role-section-arrow {
    font-size: 0.65rem;
    color: rgba(255, 255, 255, 0.3);
    transition: transform var(--transition-normal);
    margin-inline-start: auto;
}

.role-section-header.collapsed .role-section-arrow {
    transform: rotate(-90deg);
}

:root[dir="rtl"] .role-section-header.collapsed .role-section-arrow {
    transform: rotate(90deg);
}

/* Role section content collapse/expand */
.role-section-content {
    list-style: none;
}

.role-section-content.collapsed {
    display: none;
}

.role-section-nav {
    padding-inline: 0;
}

/* 5. Nav Items & Links */
.nav-item {
    position: relative;
}

.nav-link {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    color: var(--sidebar-text);
    text-decoration: none;
    border-radius: var(--border-radius-md);
    transition: all var(--transition-fast);
    white-space: nowrap;
    font-weight: 500;
}

.nav-link:hover {
    background-color: var(--sidebar-item-bg-hover);
    color: var(--sidebar-text-hover);
}

.nav-link.active,
.nav-link.active:hover {
    background-color: var(--sidebar-item-bg-active);
    color: var(--sidebar-item-text-active);
    box-shadow: 0 4px 6px -1px rgba(14, 165, 233, 0.2);
}

.nav-icon {
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
    transition: transform var(--transition-fast);
}

.nav-label {
    margin-inline-start: 12px;
    flex: 1;
    opacity: 1;
    transition: opacity var(--transition-normal);
}

.nav-arrow {
    font-size: 0.8rem;
    transition: transform var(--transition-normal);
    margin-inline-start: auto;
}

/* 6. Submenus (Accordion) */
.nav-submenu {
    list-style: none;
    padding: 0;
    margin: 0;
    overflow: hidden;
    max-height: 0;
    transition: max-height 400ms ease-in-out;
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: var(--border-radius-md);
    margin-top: 2px;
}

.nav-item.has-submenu.open>.nav-submenu {
    max-height: 1000px;
    /* Arbitrary large number for CSS transition */
}

.nav-item.has-submenu.open>.nav-link .nav-arrow {
    transform: rotate(180deg);
}

.submenu-link {
    display: block;
    padding: 8px 16px 8px 48px;
    /* Indent subitems */
    color: var(--sidebar-text);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color var(--transition-fast);
}

/* RTL adjustment for padding implemented by logical properties automatically? 
   No, 'padding' 4th value is physical-left. We must use logical. */
.submenu-link {
    padding-block: 8px;
    padding-inline-start: 48px;
    padding-inline-end: 16px;
}

.submenu-link:hover {
    color: #fff;
}

.submenu-divider {
    height: 1px;
    background-color: rgba(255, 255, 255, 0.1);
    margin: 8px 16px;
}

/* 7. Footer / Help */
.mt-auto {
    margin-top: auto;
}

/* 8. Layout Offset for Fixed Sidebar */
.page-container {
    padding-inline-start: var(--sidebar-width);
    padding-inline-end: 0;
    transition: padding-inline-start var(--transition-normal), padding-inline-end var(--transition-normal);
}

body.is-collapsed .page-container {
    padding-inline-start: var(--sidebar-collapsed-width);
    padding-inline-end: 0;
}

/* =========================================
   Responsive & Collapsed States
   ========================================= */

/* Mobile Pattern (< 992px) */
@media (max-width: 991.98px) {
    .sidebar-modern {
        transform: translateX(calc(var(--sidebar-width) * -1));
        /* Physical shift left (assumes LTR default) */
    }

    /* RTL Mirroring for Mobile Transform */
    :root[dir="rtl"] .sidebar-modern:not(.show) {
        transform: translateX(var(--sidebar-width));
    }

    .sidebar-modern.show {
        transform: translateX(0);
    }

    /* Overlay */
    .sidebar-overlay {
        position: fixed;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.5);
        backdrop-filter: blur(2px);
        z-index: var(--z-sidebar-overlay);
        opacity: 0;
        visibility: hidden;
        transition: all var(--transition-normal);
    }

    .sidebar-overlay.show {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .entity-switcher-menu {
        width: min(420px, calc(100vw - 1.5rem));
        max-height: calc(100vh - 6rem);
    }

    .entity-switcher-options {
        max-height: calc(100vh - 15rem);
    }
}

@media (max-width: 991.98px) {
    .page-container {
        padding-inline-start: 0;
        padding-inline-end: 0;
    }
}

/* Desktop Collapsed State (>= 992px) */
@media (min-width: 992px) {
    body.is-collapsed .sidebar-modern {
        width: var(--sidebar-collapsed-width);
    }

    body.is-collapsed .sidebar-brand .brand-name,
    body.is-collapsed .nav-label,
    body.is-collapsed .nav-arrow,
    body.is-collapsed .nav-section-label,
    body.is-collapsed .nav-submenu,
    body.is-collapsed .role-section-header,
    body.is-collapsed .role-section-nav .nav-section-label {
        display: none;
        opacity: 0;
    }

    body.is-collapsed .entity-switcher-container {
        padding: 0.65rem 0.5rem;
    }

    body.is-collapsed .entity-switcher-label,
    body.is-collapsed .entity-copy,
    body.is-collapsed .entity-switcher-chevron {
        display: none;
    }

    body.is-collapsed .entity-switcher-card {
        min-height: 44px;
        justify-content: center;
        padding: 0.4rem;
    }

    body.is-collapsed .entity-switcher-main {
        flex: 0 0 auto;
        justify-content: center;
        gap: 0;
    }

    body.is-collapsed .entity-icon-disc {
        margin: 0;
    }

    body.is-collapsed .entity-switcher-menu {
        width: 340px;
        min-width: 340px;
    }

    body.is-collapsed .nav-link {
        padding-inline: 0;
        justify-content: center;
    }

    body.is-collapsed .nav-icon {
        margin-inline: 0;
        font-size: 1.25rem;
    }

    /* Keep collapsed sidebar width stable to prevent overlap with navbar. */
    body.is-collapsed .sidebar-modern:hover {
        width: var(--sidebar-collapsed-width);
    }
}
