/* Cliente shell inspirado no Metronic demo1: sidebar lateral, acordeon e colapso. */
:root {
    --shell-sidebar-width: 280px;
    --shell-sidebar-collapsed-width: 58px;
    --shell-header-height: 64px;
    --shell-bg: #f8fafc;
    --shell-surface: #ffffff;
    --shell-border: #e5e7eb;
    --shell-text: #111827;
    --shell-muted: #8a94a6;
    --shell-primary: #9B111E;
    --shell-primary-soft: rgba(155, 17, 30, .08);
    --shell-hover: #f3f4f6;
    --shell-shadow: 0 10px 30px rgba(15, 23, 42, .10);
    --footer-height: 60px;
}

[data-theme="dark"] {
    --shell-bg: #0f1117;
    --shell-surface: #151821;
    --shell-border: #272b36;
    --shell-text: #f3f4f6;
    --shell-muted: #949cac;
    --shell-primary-soft: rgba(255, 148, 148, .13);
    --shell-hover: #1f2430;
    --shell-shadow: 0 14px 34px rgba(0, 0, 0, .42);
}

.app-shell {
    min-height: 100vh;
    background: var(--shell-bg);
    color: var(--shell-text);
}

.app-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 1040;
    display: flex;
    width: var(--shell-sidebar-width);
    height: 100vh;
    height: 100dvh;
    flex-direction: column;
    background: var(--shell-surface);
    border-right: 1px solid var(--shell-border);
    transition: width .2s ease, transform .2s ease;
}

.sidebar-brand {
    position: relative;
    display: flex;
    height: var(--shell-header-height);
    flex: 0 0 auto;
    align-items: center;
    justify-content: space-between;
    padding: 0 22px;
    border-bottom: 1px solid var(--shell-border);
}

.sidebar-brand-link {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    text-decoration: none;
}

.header-brand-link,
.brand-logos {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    text-decoration: none;
}

.brand-logos .logo-dark {
    display: none;
}

[data-theme="dark"] .brand-logos .logo-default {
    display: none;
}

[data-theme="dark"] .brand-logos .logo-dark {
    display: inline-block;
}

.sidebar-brand .brand-logos {
    display: inline-flex;
    min-width: 0;
    align-items: center;
}

.sidebar-brand img {
    max-width: 150px;
    object-fit: contain;
}

.sidebar-brand .logo-dark {
    display: none;
}

[data-theme="dark"] .sidebar-brand .logo-default {
    display: none;
}

[data-theme="dark"] .sidebar-brand .logo-dark {
    display: inline-block;
}

.brand-icon {
    display: none;
    width: 24px;
    height: 24px;
}

.sidebar-nav {
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: visible;
    padding: 20px 12px 16px 20px;
    scrollbar-width: thin;
    scrollbar-color: rgba(138, 148, 166, .32) transparent;
}

.sidebar-meta {
    display: flex;
    flex: 0 0 auto;
    flex-direction: column;
    gap: 8px;
    padding: 12px 20px 16px;
    border-top: 1px solid var(--shell-border);
    color: var(--shell-muted);
    font-size: .81rem;
}

.sidebar-meta-item {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 8px;
    color: var(--shell-muted);
    text-decoration: none;
}

.sidebar-meta-item.help-link {
    color: var(--shell-primary);
    font-weight: 600;
}

.app-nav {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.app-nav > .nav-item {
    position: relative;
}

.app-nav > .nav-item:nth-child(2)::before,
.app-nav > .nav-item:nth-child(5)::before {
    display: block;
    padding: 12px 10px 6px;
    color: var(--shell-muted);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.app-nav > .nav-item:nth-child(2)::before {
    content: "Operação";
}

.app-nav > .nav-item:nth-child(5)::before {
    content: "Gestão";
}

.app-nav .nav-link,
.app-sidebar .dropdown-item {
    position: relative;
    display: flex;
    min-height: 38px;
    align-items: center;
    gap: 10px;
    padding: 7px 10px;
    border: 1px solid transparent;
    border-radius: 8px;
    color: var(--shell-text);
    font-size: .86rem;
    font-weight: 500;
    line-height: 1.2;
    text-decoration: none;
    transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}

.app-nav .nav-link:hover,
.app-nav .nav-link:focus,
.app-sidebar .dropdown-item:hover,
.app-sidebar .dropdown-item:focus {
    background: var(--shell-hover);
    color: var(--shell-primary);
}

.app-nav .nav-link.active,
.app-nav .nav-item.active > .nav-link,
.app-nav .dropdown.has-current-page > .nav-link,
.app-sidebar .dropdown.show > .nav-link,
.app-sidebar .dropdown-item.active {
    background: var(--shell-primary-soft);
    color: var(--shell-primary);
    font-weight: 600;
}

.app-nav .nav-link.active,
.app-nav .nav-item.active > .nav-link,
.app-nav .dropdown.has-current-page > .nav-link {
    border-color: color-mix(in srgb, var(--shell-primary) 20%, transparent);
}

.nav-icon {
    display: inline-flex;
    width: 20px;
    min-width: 20px;
    align-items: flex-start;
    justify-content: center;
    color: var(--shell-muted);
}

.nav-icon i {
    font-size: 1rem;
    line-height: 1;
}

.app-nav .nav-link:hover .nav-icon,
.app-nav .nav-link:focus .nav-icon,
.app-nav .nav-link.active .nav-icon,
.app-nav .nav-item.active > .nav-link .nav-icon,
.app-nav .dropdown.has-current-page > .nav-link .nav-icon,
.app-sidebar .dropdown.show > .nav-link .nav-icon {
    color: var(--shell-primary);
}

.nav-text {
    min-width: 0;
    flex: 1 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.nav-current-label {
    display: none;
}

.app-sidebar .dropdown-toggle::after,
.app-sidebar .nav-link.dropdown-toggle::after {
    border: 0 !important;
    margin: 0 !important;
    vertical-align: initial !important;
}

.app-sidebar .nav-link.dropdown-toggle::after {
    content: "+";
    display: inline-block;
    width: 20px;
    margin-left: auto !important;
    color: var(--shell-muted);
    font-size: 1rem;
    font-weight: 500;
    line-height: 1;
    text-align: right;
}

.app-sidebar .dropdown.show > .nav-link.dropdown-toggle::after,
.app-sidebar .nav-link.dropdown-toggle[aria-expanded="true"]::after {
    content: "-";
}

.app-sidebar .dropdown-menu {
    position: static !important;
    display: none;
    float: none;
    min-width: 0;
    width: auto;
    padding: 2px 0 6px 10px;
    margin: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    transform: none !important;
}

.app-sidebar .dropdown-menu.show {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.app-sidebar .dropdown-menu::before {
    content: "";
    position: absolute;
    left: 30px;
    top: 40px;
    bottom: 8px;
    border-left: 1px solid var(--shell-border);
}

.app-sidebar .dropdown-menu .nav-item {
    position: relative;
}

.app-sidebar .dropdown-item {
    min-height: 36px;
    gap: 14px;
    padding: 8px 10px;
    font-size: .82rem;
    font-weight: 400;
}

.app-sidebar .dropdown-item.active {
    border-color: transparent;
    border-radius: 8px;
}

.app-sidebar .dropdown-item .nav-icon {
    position: relative;
    width: 6px;
    min-width: 6px;
    margin-left: 7px;
}

.app-sidebar .dropdown-item .nav-icon i {
    display: none;
}

.app-sidebar .dropdown-item .nav-icon::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--shell-muted) 38%, transparent);
    transform: translateY(-50%);
}

.app-sidebar .dropdown-item:hover .nav-icon::before,
.app-sidebar .dropdown-item:focus .nav-icon::before,
.app-sidebar .dropdown-item.active .nav-icon::before {
    background: var(--shell-primary);
}

.flyout-section-label {
    display: none;
}

.app-header {
    position: fixed;
    top: 0;
    right: 0;
    left: var(--shell-sidebar-width);
    z-index: 1030;
    height: var(--shell-header-height);
    background: var(--shell-surface);
    border-bottom: 1px solid var(--shell-border);
    transition: left .2s ease;
}

.app-header-inner {
    display: flex;
    height: 100%;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
}

.app-header-left,
.app-header-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.app-sidebar-toggle {
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border-color: var(--shell-border);
    background: var(--shell-surface);
    color: var(--shell-muted);
}

.app-sidebar-toggle:hover,
.app-sidebar-toggle:focus {
    color: var(--shell-primary);
    border-color: color-mix(in srgb, var(--shell-primary) 25%, var(--shell-border));
}

.app-main {
    min-height: 100vh;
}

.app-shell.has-sidebar .app-main {
    margin-left: var(--shell-sidebar-width);
    transition: margin-left .2s ease;
}

.app-content {
    min-height: 100vh;
    padding: calc(var(--shell-header-height) + 22px) 24px calc(28px + var(--footer-height));
}

.footer-fixed {
    left: var(--shell-sidebar-width);
    transition: left .2s ease;
}

.app-shell.is-guest .app-header,
.app-shell.is-guest .footer-fixed {
    left: 0;
}

.app-shell.is-guest .help-chat-widget {
    display: none;
}

.sidebar-collapsed .app-sidebar {
    width: var(--shell-sidebar-collapsed-width);
}

.sidebar-collapsed.sidebar-hover-expanded .app-sidebar {
    width: var(--shell-sidebar-width);
    box-shadow: var(--shell-shadow);
}

.sidebar-collapsed.app-shell.has-sidebar .app-main {
    margin-left: var(--shell-sidebar-collapsed-width);
}

.sidebar-collapsed .app-header {
    left: var(--shell-sidebar-collapsed-width);
}

.sidebar-collapsed .footer-fixed {
    left: var(--shell-sidebar-collapsed-width);
}

.sidebar-collapsed .sidebar-brand {
    justify-content: center;
    padding: 0;
}

.sidebar-collapsed.sidebar-hover-expanded .sidebar-brand {
    justify-content: space-between;
    padding: 0 22px;
}

.sidebar-collapsed .sidebar-brand .brand-logos,
.sidebar-collapsed .nav-text,
.sidebar-collapsed .sidebar-meta .meta-text,
.sidebar-collapsed .app-nav .dropdown > .nav-link::after,
.sidebar-collapsed .app-nav > .nav-item::before {
    display: none;
}

.sidebar-collapsed.sidebar-hover-expanded .sidebar-brand .brand-logos,
.sidebar-collapsed.sidebar-hover-expanded .nav-text,
.sidebar-collapsed.sidebar-hover-expanded .sidebar-meta .meta-text,
.sidebar-collapsed.sidebar-hover-expanded .app-nav .dropdown > .nav-link::after,
.sidebar-collapsed.sidebar-hover-expanded .app-nav > .nav-item::before {
    display: inline;
}

.sidebar-collapsed .brand-icon {
    display: inline-block;
}

.sidebar-collapsed.sidebar-hover-expanded .brand-icon {
    display: none;
}

.sidebar-collapsed .sidebar-nav {
    padding: 20px 8px 16px;
}

.sidebar-collapsed.sidebar-hover-expanded .sidebar-nav {
    padding: 20px 12px 16px 20px;
}

.sidebar-collapsed .app-nav .nav-link {
    justify-content: center;
    min-height: 42px;
    padding: 8px;
}

.sidebar-collapsed.sidebar-hover-expanded .app-nav .nav-link {
    justify-content: flex-start;
    min-height: 38px;
    padding: 7px 10px;
}

.sidebar-collapsed .nav-icon {
    width: 20px;
    min-width: 20px;
}

.sidebar-collapsed .dropdown.has-current-page > .nav-link::before,
.sidebar-collapsed .nav-item.active > .nav-link::before,
.sidebar-collapsed .nav-link.active::before {
    content: "";
    position: absolute;
    right: 8px;
    top: 8px;
    width: 7px;
    height: 7px;
    border: 2px solid var(--shell-surface);
    border-radius: 999px;
    background: var(--shell-primary);
}

.sidebar-collapsed .sidebar-meta {
    align-items: center;
    padding: 12px 0 16px;
}

.sidebar-collapsed.sidebar-hover-expanded .sidebar-meta {
    align-items: stretch;
    padding: 12px 20px 16px;
}

.sidebar-collapsed .sidebar-meta-item {
    justify-content: center;
}

.sidebar-collapsed.sidebar-hover-expanded .sidebar-meta-item {
    justify-content: flex-start;
}

.sidebar-collapsed .app-sidebar .dropdown-menu {
    position: static !important;
    display: none;
    width: auto;
    max-height: none;
    overflow: visible;
    padding: 2px 0 6px 10px;
    border: 0;
    background: transparent;
    box-shadow: none;
    z-index: auto;
}

.sidebar-collapsed .app-sidebar .dropdown-menu.show {
    display: flex;
}

.sidebar-collapsed .app-sidebar .dropdown-menu::before {
    display: block;
}

.sidebar-collapsed .flyout-section-label {
    display: none;
}

.sidebar-collapsed .app-sidebar .dropdown-item .nav-text {
    display: inline;
}

.mobile-sidebar-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1038;
    background: rgba(15, 23, 42, .44);
    opacity: 0;
    pointer-events: none;
    transition: opacity .16s ease;
}

@media (min-width: 1600px) {
    .app-content {
        padding-inline: 28px;
    }
}

@media (max-width: 991.98px) {
    .app-sidebar {
        width: min(86vw, 300px);
        transform: translateX(-105%);
        box-shadow: var(--shell-shadow);
    }

    .mobile-nav-open .app-sidebar {
        transform: translateX(0);
    }

    .mobile-nav-open .mobile-sidebar-backdrop {
        opacity: 1;
        pointer-events: auto;
    }

    .app-shell.has-sidebar .app-main,
    .sidebar-collapsed.app-shell.has-sidebar .app-main {
        margin-left: 0;
    }

    .app-header,
    .sidebar-collapsed .app-header {
        left: 0;
    }

    .app-header-inner {
        padding: 0 14px;
    }

    .app-content {
        padding: calc(var(--shell-header-height) + 14px) 12px calc(22px + var(--footer-height));
    }

    .footer-fixed,
    .sidebar-collapsed .footer-fixed {
        left: 0;
    }

    .sidebar-collapsed .sidebar-brand .brand-logos,
    .sidebar-collapsed .nav-text,
    .sidebar-collapsed .sidebar-meta .meta-text,
    .sidebar-collapsed .app-nav .dropdown > .nav-link::after,
    .sidebar-collapsed .app-nav > .nav-item::before {
        display: inline;
    }

    .sidebar-collapsed .brand-icon {
        display: none;
    }

    .sidebar-collapsed .sidebar-nav {
        padding: 20px 12px 16px 20px;
    }

    .sidebar-collapsed .app-nav .nav-link {
        justify-content: flex-start;
        min-height: 38px;
        padding: 7px 10px;
    }

    .sidebar-collapsed .dropdown.has-current-page > .nav-link::before,
    .sidebar-collapsed .nav-item.active > .nav-link::before,
    .sidebar-collapsed .nav-link.active::before {
        display: none;
    }

    .sidebar-collapsed .app-sidebar .dropdown-menu {
        position: static !important;
        width: auto;
        max-height: none;
        overflow: visible;
        padding: 2px 0 6px 10px;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    .sidebar-collapsed .flyout-section-label {
        display: none;
    }
}

@media (max-width: 575.98px) {
    .user-menu-dropdown-wrap .dropdown-toggle {
        max-width: 152px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
}
