.right-bar {
    width: 790px;
    right: -800px;
}

:root {
    --bridge-color: #2a3042;
    --bridge-color-rgb: 42, 48, 66;
    --bridge-color-hover: #1e222e;
}

.bg-bridge {
    background-color: var(--bridge-color) !important;
}

.text-bridge {
    color: var(--bridge-color) !important;
}

.border-bridge {
    border-color: var(--bridge-color) !important;
}

.bg-soft-bridge {
    background-color: rgba(var(--bridge-color-rgb), 0.12) !important;
    color: var(--bridge-color) !important;
}

.btn-bridge {
    background-color: var(--bridge-color);
    border-color: var(--bridge-color);
    color: #fff;
}

.btn-bridge:hover,
.btn-bridge:focus,
.btn-bridge:active,
.btn-bridge.active,
.show > .btn-bridge.dropdown-toggle {
    background-color: var(--bridge-color-hover) !important;
    border-color: var(--bridge-color-hover) !important;
    color: #fff !important;
}

.btn-outline-bridge {
    background-color: transparent;
    border-color: var(--bridge-color);
    color: var(--bridge-color);
}

.btn-outline-bridge:hover,
.btn-outline-bridge:focus,
.btn-outline-bridge:active,
.btn-outline-bridge.active,
.show > .btn-outline-bridge.dropdown-toggle {
    background-color: var(--bridge-color) !important;
    border-color: var(--bridge-color) !important;
    color: #fff !important;
}

.bg-blue-login,
.btn-blue-login {
    background-color: var(--bridge-color);
    color: #fff;
}

.btn-blue-login:hover {
    background-color: var(--bridge-color-hover);
    color: #fff;
}

.btn-blue-login:active {
    background-color: var(--bridge-color-hover) !important;
    color: #fff !important;
}

.header-avatar-initials {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85rem;
    color: #1f2937;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

.avatar-bg-0 {
    background-color: #E8F0FE;
}

.avatar-bg-1 {
    background-color: #E8F8F2;
}

.avatar-bg-2 {
    background-color: #FDF2E9;
}

.avatar-bg-3 {
    background-color: #F1ECFF;
}

.avatar-bg-4 {
    background-color: #EAF3FF;
}

.avatar-bg-5 {
    background-color: #FCE8F3;
}


/* Section Loader Overlay */
.section-loader-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    min-height: 200px; /* Ensure visibility if container is empty */
    background-color: rgba(255, 255, 255, 0.7);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1050; /* Above most elements */
    border-radius: 0.25rem;
}

.section-loader-overlay .spinner-border {
    width: 3rem;
    height: 3rem;
}

/* Dark Mode Overrides for Loader */
[data-bs-theme="dark"] .section-loader-overlay {
    background-color: rgba(42, 48, 66, 0.7);
}

html, body {
    height: 100%;
}

body {
    min-height: 100vh;
}

#layout-wrapper {
    min-height: 100vh;
}

.main-content {
    margin-left: 250px;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow: visible;
}

.page-content {
    padding: calc(70px + 24px) calc(24px * .75) 24px calc(24px * .75);
}

.footer {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    height: auto !important;
    margin-top: auto;
}

@media (max-width: 991.98px) {
    .main-content {
        margin-left: 0 !important;
    }
}

.vertical-collpsed .main-content {
    margin-left: 70px;
}

.vertical-menu {
    top: 70px;
    bottom: 0;
    height: calc(100vh - 70px) !important;
    min-height: calc(100vh - 70px) !important;
}

body.vertical-collpsed,
body[data-sidebar=dark].vertical-collpsed {
    min-height: 100vh !important;
}

.vertical-collpsed .vertical-menu {
    position: fixed !important;
    top: 70px;
    bottom: 0;
    width: 70px !important;
    height: calc(100vh - 70px) !important;
    min-height: calc(100vh - 70px) !important;
    z-index: 1001;
}

@media (max-width: 991.98px) {
    .vertical-collpsed .vertical-menu {
        left: 0;
    }
}

/* Reusable mobile eyebrow label for compact titles/subtitles */
.mobile-eyebrow,
.flows-mobile-eyebrow {
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--bs-primary);
    margin-bottom: 0.45rem;
}

/* Fix navbar brand logo centering and visibility (Only Logo Light) */
.navbar-brand-box {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 70px;
    padding: 0 !important;
    overflow: hidden;
    width: 250px !important;
}

.navbar-brand-box .logo {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100%;
    height: 70px;
    margin: 0 !important;
    padding: 0;
    line-height: 1 !important;
}

/* Base Visibility Logic: Expanded Sidebar (Default) */
.navbar-brand-box .logo-light .logo-sm {
    display: none !important;
}
.navbar-brand-box .logo-light .logo-lg {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100%;
}

/* Collapsed Sidebar State */
.vertical-collpsed .navbar-brand-box {
    width: 70px !important;
}
.vertical-collpsed .navbar-brand-box .logo-light .logo-lg {
    display: none !important;
}
.vertical-collpsed .navbar-brand-box .logo-light .logo-sm {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100%;
}

/* Mobile State */
@media (max-width: 992px) {
    .navbar-brand-box {
        width: 60px !important; /* Ensure enough space for the logo-sm on mobile */
        min-width: 60px !important;
    }
    .navbar-brand-box .logo-light .logo-lg {
        display: none !important;
    }
    .navbar-brand-box .logo-light .logo-sm {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        height: 100%;
    }
}

.navbar-brand-box .logo img {
    display: block;
    vertical-align: middle;
}

.login-hero-logo {
    max-height: 120px;
    width: auto;
}