/* ============================================
   SIDEBAR FIX CSS - LOADED SUCCESSFULLY!
   Version: 2.0 - Updated: 15:50
   ============================================ */

/* Emergency override to ensure toggle button is visible */
.main-menu .navbar-header .modern-nav-toggle {
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.main-menu .navbar-header .modern-nav-toggle i,
.main-menu .navbar-header .modern-nav-toggle svg {
    color: #fff !important;
    font-size: 1.3rem !important;
}

/* Toggle icon logic - Burger when collapsed, X when expanded */
.vertical-layout.menu-expanded .main-menu .navbar-header .modern-nav-toggle .toggle-icon-burger {
    display: none !important;
}

.vertical-layout.menu-expanded .main-menu .navbar-header .modern-nav-toggle .collapse-toggle-icon-close {
    display: block !important;
}

.vertical-layout.menu-collapsed .main-menu .navbar-header .modern-nav-toggle .toggle-icon-burger {
    display: block !important;
    font-size: 1.5rem !important;
}

.vertical-layout.menu-collapsed .main-menu .navbar-header .modern-nav-toggle .collapse-toggle-icon-close {
    display: none !important;
}

/* FORCE hide logo when collapsed */
body.menu-collapsed .main-menu .navbar-header .navbar-brand,
body.menu-collapsed .main-menu .navbar-header .navbar-brand .brand-logo,
body.menu-collapsed .main-menu .navbar-header .navbar-brand img,
.vertical-layout.menu-collapsed .main-menu .navbar-header .navbar-brand,
.vertical-layout.menu-collapsed .main-menu .navbar-header .navbar-brand .brand-logo,
.vertical-layout.menu-collapsed .main-menu .navbar-header .navbar-brand img {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    position: absolute !important;
    pointer-events: none !important;
    z-index: -999 !important;
}

/* FORCE burger menu to show when collapsed */
body.menu-collapsed .main-menu .navbar-header .modern-nav-toggle,
.vertical-layout.menu-collapsed .main-menu .navbar-header .modern-nav-toggle {
    position: relative !important;
    right: auto !important;
    left: auto !important;
    top: auto !important;
    bottom: auto !important;
    transform: none !important;
    margin: 0 auto !important;
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 14px !important;
    z-index: 9999 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: all !important;
}

body.menu-collapsed .main-menu .navbar-header .modern-nav-toggle:hover,
.vertical-layout.menu-collapsed .main-menu .navbar-header .modern-nav-toggle:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: scale(1.05) !important;
}

/* FORCE burger icon to be visible */
body.menu-collapsed .main-menu .navbar-header .modern-nav-toggle .toggle-icon-burger,
.vertical-layout.menu-collapsed .main-menu .navbar-header .modern-nav-toggle .toggle-icon-burger,
body.menu-collapsed .main-menu .navbar-header .modern-nav-toggle i.toggle-icon-burger,
.vertical-layout.menu-collapsed .main-menu .navbar-header .modern-nav-toggle i.toggle-icon-burger {
    display: block !important;
    font-size: 1.5rem !important;
    color: #fff !important;
    z-index: 10000 !important;
    position: relative !important;
    opacity: 1 !important;
    visibility: visible !important;
    width: auto !important;
    height: auto !important;
    pointer-events: all !important;
}

/* Center the navbar header content when collapsed */
body.menu-collapsed .main-menu .navbar-header,
.vertical-layout.menu-collapsed .main-menu .navbar-header {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: auto !important;
    max-width: 100% !important;
}

/* Remove fixed width from navbar-header and center content */
.main-menu .navbar-header {
    width: auto !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 15px !important;
}

/* Customer sidebar header — logo left, toggle right */
.main-menu.menu-no-scroll .navbar-header {
    width: 100% !important;
    justify-content: space-between !important;
    padding: 18px 16px 12px !important;
}

/* Center navbar-brand as well */
.main-menu .navbar-header .navbar-brand {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Hide scrollbar and disable scroll on customer sidebar */
.main-menu.menu-no-scroll,
.main-menu.menu-no-scroll .main-menu-content {
    overflow: hidden !important;
    overscroll-behavior: none !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
}

.main-menu.menu-no-scroll .main-menu-content::-webkit-scrollbar,
.main-menu .main-menu-content::-webkit-scrollbar,
.main-menu .main-menu-content.ps::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
}

.main-menu.menu-no-scroll .ps__rail-y,
.main-menu.menu-no-scroll .ps__rail-x {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
}

.main-menu .ps__rail-y,
.main-menu .ps__rail-x,
.ps__rail-y,
.ps__rail-x {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
}

/* Logo — white on dark green sidebar (no blue circle) */
.main-menu .navbar-header .brand-logo {
    width: auto !important;
    height: auto !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 0 !important;
}

.main-menu .navbar-header .brand-logo img,
.main-menu .mista-sidebar-logo {
    width: auto !important;
    max-height: 34px !important;
    height: auto !important;
    object-fit: contain !important;
    object-position: center !important;
    filter: brightness(0) invert(1) !important;
}

.main-menu .mista-sidebar-brand {
    gap: 10px !important;
    min-width: 0 !important;
}

.main-menu .mista-sidebar-brand-text {
    color: #ffffff !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
}

/* Customer sidebar — hide in-sidebar close toggle; use header burger */
.main-menu.menu-no-scroll .navbar-header .modern-nav-toggle {
    display: none !important;
}

.main-menu.menu-no-scroll .navigation li.has-sub > a:after,
.vertical-layout.vertical-menu-modern.menu-expanded .main-menu.menu-no-scroll .navigation li.has-sub > a:after,
.vertical-layout.vertical-menu-modern.menu-collapsed .main-menu.menu-no-scroll.expanded .navigation li.has-sub > a:after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'%3E%3C/polyline%3E%3C/svg%3E") !important;
}

.main-menu .navbar-header .brand-logo:hover {
    transform: none !important;
    box-shadow: none !important;
}

.main-menu .navbar-header .brand-logo:active {
    transform: translateY(-1px) scale(1.02) !important;
}

.menu-collapsed .main-menu .navbar-header .navbar-brand,
.menu-collapsed .main-menu .navbar-header .brand-logo {
    cursor: pointer;
}

/* ============================================
   SIDEBAR — customer header green (#01694a)
   ============================================ */
.main-menu,
body .main-menu.menu-light,
body .main-menu.menu-dark,
body .main-menu.menu-modern {
    background: #01694a !important;
    background-image: none !important;
    border-right: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    margin: 0 !important;
    height: 100vh !important;
    min-height: 100vh !important;
    top: 0 !important;
    left: 0 !important;
    position: fixed !important;
}

.main-menu.menu-no-scroll {
    display: flex !important;
    flex-direction: column !important;
}

.main-menu.menu-no-scroll .main-menu-content {
    flex: 1 1 auto !important;
    min-height: 0 !important;
}

.main-menu .navigation > li > a,
.main-menu .navigation .nav-item > a {
    border-left: none !important;
    border-radius: 10px !important;
    margin: 3px 12px !important;
}

.main-menu .navigation > li > a .bi,
.main-menu .navigation .nav-item > a .bi,
.main-menu .menu-content .bi,
.main-menu .modern-nav-toggle .bi {
    color: #ffffff !important;
}

.main-menu .navigation > li.active > a,
.main-menu .navigation .nav-item.active > a {
    background: rgba(255, 255, 255, 0.16) !important;
    color: #fff !important;
    border-left: none !important;
    box-shadow: none !important;
}

.main-menu .sidebar-search .search-input-wrapper input {
    background: #001812 !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 10px !important;
}

/* Hide dots pattern on customer sidebar */
.main-menu.menu-no-scroll::after,
body .main-menu.menu-no-scroll::after {
    display: none !important;
}

/* Add dots using ::after - fixed position so it doesn't affect layout */
.main-menu:not(.menu-no-scroll)::after,
body .main-menu.menu-light::after,
body .main-menu.menu-dark::after {
    content: '' !important;
    position: fixed !important;
    bottom: 100px !important;
    left: 0 !important;
    width: 260px !important;
    height: 309px !important;
    background: url(/images/backgrounds/dots.svg) no-repeat center !important;
    background-size: 100% auto !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

/* ============================================
   STICKY HEADER NAVBAR - FIXED AT TOP
   ============================================ */
.header-navbar,
.nav.header-navbar,
body.navbar-sticky .header-navbar,
body.navbar-sticky .nav.header-navbar,
.vertical-layout.navbar-sticky .header-navbar,
.vertical-layout.navbar-sticky .nav.header-navbar {
    position: fixed !important;
    top: 0 !important;
    left: 260px !important;
    right: 0 !important;
    z-index: 998 !important;
    width: calc(100% - 260px) !important;
    transition: all 0.3s ease !important;
}

/* Adjust header position when sidebar is collapsed */
body.menu-collapsed .header-navbar,
body.menu-collapsed .nav.header-navbar,
.vertical-layout.menu-collapsed.navbar-sticky .header-navbar,
.vertical-layout.menu-collapsed.navbar-sticky .nav.header-navbar {
    left: 80px !important;
    width: calc(100% - 80px) !important;
}

/* Ensure header stays above content */
.header-navbar {
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
}

/* ============================================
   STICKY CUSTOMER HEADER - FIXED AT TOP
   ============================================ */
.header,
body .header,
.vertical-layout .header {
    position: fixed !important;
    top: 0 !important;
    left: 260px !important;
    right: 0 !important;
    z-index: 998 !important;
    width: calc(100% - 260px) !important;
    transition: all 0.3s ease !important;
}

/* Adjust customer header position when sidebar is collapsed */
body.menu-collapsed .header,
.vertical-layout.menu-collapsed .header {
    left: 80px !important;
    width: calc(100% - 80px) !important;
}

/* ============================================
   CONTENT PADDING ADJUSTMENT FOR FIXED HEADER
   ============================================ */
/* The existing navbar-sticky padding should handle this, but ensure it works */
body.navbar-sticky .app-content.content {
    padding-top: calc(2rem + 4.45rem) !important;
}

/* Adjust for customer header (smaller height ~60px) */
body .header + .app-content.content {
    padding-top: calc(2rem + 60px) !important;
}

/* ============================================
   MOBILE / TABLET — full-width header & content
   (sidebar-fix desktop rules must not win on small screens)
   ============================================ */
@media (max-width: 1199px) {
    html,
    body {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }

    .header-navbar,
    body .header-navbar,
    .nav.header-navbar,
    .header,
    body .header,
    .vertical-layout .header {
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100vw !important;
    }

    .app-content,
    .app-content.content,
    .content-wrapper {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100vw !important;
    }

    body .header + .app-content.content {
        padding-top: calc(70px + 0.75rem) !important;
    }

    .footer.footer-light,
    .footer {
        margin-left: 0 !important;
        width: 100% !important;
        max-width: 100vw !important;
    }

    .main-menu::after,
    body .main-menu.menu-light::after,
    body .main-menu.menu-dark::after {
        display: none !important;
        content: none !important;
        width: 0 !important;
    }
}

@media (max-width: 768px) {
    .header,
    body .header {
        padding: 8px 12px !important;
        min-height: 56px !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .header-left {
        width: auto !important;
        flex: 0 0 auto !important;
        order: 1 !important;
    }

    .header-right {
        width: auto !important;
        flex: 1 1 auto !important;
        order: 2 !important;
        justify-content: flex-end !important;
        flex-wrap: nowrap !important;
        gap: 6px !important;
        min-width: 0 !important;
    }

    .content-header.row {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .content-header-title {
        font-size: 1.15rem !important;
        float: none !important;
    }

    .breadcrumb-wrapper {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .breadcrumb {
        flex-wrap: nowrap !important;
        font-size: 12px !important;
        margin-bottom: 0 !important;
    }

    .card .table-responsive,
    .table-responsive {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    /* Action bars: stack buttons instead of overflowing */
    #datatables-basic .mb-3,
    section#datatables-basic > .mb-3 {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        align-items: stretch !important;
    }

    #datatables-basic .btn-group,
    section#datatables-basic .btn-group {
        width: 100% !important;
    }

    #datatables-basic .btn-group .btn,
    section#datatables-basic .btn-group .btn,
    #datatables-basic .btn-success,
    section#datatables-basic .btn-success {
        width: 100% !important;
        margin: 0 !important;
    }

    .dataTables_wrapper .dataTables_length,
    .dataTables_wrapper .dataTables_filter {
        width: 100% !important;
        text-align: left !important;
        margin-bottom: 8px !important;
    }

    .dataTables_wrapper .dataTables_filter input {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
    }
}

@media (max-width: 576px) {
    .header-right .balance-card {
        display: none !important;
    }

    .dropdown-panel {
        max-width: calc(100vw - 24px) !important;
    }
}

/* ============================================
   FINAL SIDEBAR COLOR LOCK — match header #01694a
   ============================================ */
body .main-menu,
body .main-menu.menu-light,
body .main-menu.menu-dark,
body .main-menu.menu-modern,
.vertical-layout .main-menu {
    background-color: #01694a !important;
    background-image: none !important;
    height: 100vh !important;
    min-height: 100vh !important;
}

body .main-menu .navigation > li.active > a,
body .main-menu .navigation .nav-item.active > a {
    background-color: rgba(255, 255, 255, 0.16) !important;
    color: #ffffff !important;
}

body .main-menu.menu-no-scroll {
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

body .main-menu.menu-no-scroll .main-menu-content {
    overflow: hidden !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
}

