/* 
 * Modern-UI Clean Slate CSS - ULTRA-STABLE
 * Author: Antigravity AI
 * Version: 2.9 (Semantic Classes & Submenu Arrow)
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root {
    --primary: #2563eb;
    --primary-light: rgba(37, 99, 235, 0.08);
    --bg-main: #f8fafc;
    --sidebar-bg: #ffffff;
    --header-bg: rgba(255, 255, 255, 0.9);
    --text-main: #1e293b;
    --text-muted: #64748b;
    --border-color: #e2e8f0;
    --card-bg: #ffffff;
    --sidebar-width: 280px;
    --sidebar-mini-width: 80px;
    --header-height: 80px;

    /* RADIUS SYSTEM - New Modern Aesthetics */
    --radius-lg: 20px;
    --radius-md: 12px;
    --radius-sm: 8px;

    /* SOFT SHADOWS */
    --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 10px 30px rgba(0, 0, 0, 0.08);
    --shadow-lg: 0 20px 50px rgba(0, 0, 0, 0.12);
}

body {
    background-color: var(--bg-main) !important;
    font-family: 'Inter', sans-serif !important;
    color: var(--text-main) !important;
    margin: 0;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* Rounded Cards - Global Support */
.card {
    border-radius: var(--radius-lg) !important;
    border: 1px solid var(--border-color) !important;
    background: var(--card-bg) !important;
    box-shadow: var(--shadow-md) !important;
    overflow: hidden !important;
    /* Critical for rounding */
    margin-bottom: 30px !important;
}

.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 20px 25px !important;
}

.card-title {
    font-weight: 700 !important;
    font-size: 1.1rem !important;
    color: var(--text-main) !important;
}

/* ==========================================================================
   1. CORE STRUCTURE
   ========================================================================== */

/* Nav Header Cleanup */
body .nav-header {
    background-color: transparent !important;
    background: transparent !important;
    border-bottom: none !important;
}

body .nav-header .brand-logo {
    background: transparent !important;
}

#main-wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.quixnav {
    background: var(--sidebar-bg) !important;
    height: 100vh !important;
    position: fixed !important;
    left: 0;
    top: 0;
    z-index: 1000;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    border-right: 1px solid var(--border-color) !important;
    overflow: visible !important;
}

.header {
    height: var(--header-height) !important;
    background: var(--header-bg) !important;
    backdrop-filter: blur(10px);
    position: fixed !important;
    top: 15px !important;
    z-index: 999 !important;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-md) !important;
    border: 1px solid var(--border-color) !important;
    padding: 0 10px !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
}

.header-content {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
}

.header-content .navbar {
    width: 100% !important;
    padding: 0 !important;
    height: 100% !important;
}

.header-content .navbar-collapse {
    width: 100% !important;
    display: flex !important;
    height: 100% !important;
}

/* Ensure right-side icons are visible and spaced */
.header-right {
    flex-direction: row !important;
    align-items: center !important;
    margin-right: 10px !important;
}

.header-right .nav-item {
    padding: 0 10px !important;
}

.header-right .nav-link {
    color: var(--text-main) !important;
    font-size: 1.1rem !important;
    display: flex !important;
    align-items: center !important;
}

.content-body {
    padding-top: calc(var(--header-height) + 30px) !important;
    transition: all 0.3s ease;
}

/* ==========================================================================
   2. BREAKPOINT MATRIX (STATES)
   ========================================================================== */

/* --- A. DESKTOP ( >= 1200px ) --- */
@media (min-width: 1200px) {
    #main-wrapper:not(.menu-toggle) .quixnav {
        width: var(--sidebar-width) !important;
    }

    #main-wrapper:not(.menu-toggle) .header {
        left: calc(var(--sidebar-width) + 20px) !important;
        width: calc(100% - var(--sidebar-width) - 40px) !important;
        right: auto !important;
    }

    #main-wrapper:not(.menu-toggle) .content-body {
        margin-left: var(--sidebar-width) !important;
    }

    #main-wrapper.menu-toggle .quixnav {
        width: var(--sidebar-mini-width) !important;
    }

    #main-wrapper.menu-toggle .header {
        left: calc(var(--sidebar-mini-width) + 20px) !important;
        width: calc(100% - var(--sidebar-mini-width) - 40px) !important;
        right: auto !important;
    }

    #main-wrapper.menu-toggle .content-body {
        margin-left: var(--sidebar-mini-width) !important;
    }
}

/* --- B. TABLET ( 768px - 1199px ) --- */
@media (max-width: 1199px) and (min-width: 768px) {
    #main-wrapper:not(.menu-toggle) .quixnav {
        width: var(--sidebar-mini-width) !important;
    }

    #main-wrapper:not(.menu-toggle) .header {
        left: calc(var(--sidebar-mini-width) + 20px) !important;
        width: calc(100% - var(--sidebar-mini-width) - 40px) !important;
        right: auto !important;
    }

    #main-wrapper:not(.menu-toggle) .content-body {
        margin-left: var(--sidebar-mini-width) !important;
    }

    #main-wrapper.menu-toggle .quixnav {
        width: var(--sidebar-width) !important;
    }

    #main-wrapper.menu-toggle .header {
        left: calc(var(--sidebar-width) + 20px) !important;
        width: calc(100% - var(--sidebar-width) - 40px) !important;
        right: auto !important;
    }

    #main-wrapper.menu-toggle .content-body {
        margin-left: var(--sidebar-width) !important;
    }
}

/* Hide the mobile-integrated hamburger on desktop */
.header .nav-control {
    display: none;
}

/* --- C. MOBILE ( < 768px ) --- */
@media (max-width: 767px) {
    .quixnav {
        width: 80px !important;
        position: fixed !important;
        left: 0 !important;
        top: 0 !important;
        height: 100vh !important;
        z-index: 1001 !important;
        transition: all 0.3s ease;
        transform: translateX(-100%);
        visibility: hidden;
        background: #fff !important;
        box-shadow: 5px 0 25px rgba(0, 0, 0, 0.08) !important;
    }

    #main-wrapper.menu-toggle .quixnav {
        transform: translateX(0);
        visibility: visible;
    }

    .header {
        left: 15px !important;
        width: calc(100% - 30px) !important;
        right: auto !important;
        top: 10px !important;
        transition: all 0.3s ease;
    }

    /* Shift header slightly when menu open if desired, but overlay is better */
    #main-wrapper.menu-toggle .header {
        opacity: 0.3;
        pointer-events: none;
    }

    .content-body {
        margin-left: 0 !important;
        padding-left: 15px !important;
        padding-right: 15px !important;
    }

    /* Maximize horizontal space on mobile - No padding */
    .content-body .container-fluid {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Overlay/Backdrop */
    .nav-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(15, 23, 42, 0.4);
        backdrop-filter: blur(4px);
        z-index: 1000;
        transition: all 0.3s ease;
    }

    #main-wrapper.menu-toggle .nav-overlay {
        display: block;
    }

    /* Aggressively hide labels and arrows in mini mobile */
    #main-wrapper.menu-toggle .quixnav .nav-text,
    #main-wrapper.menu-toggle .quixnav .has-submenu:after,
    #main-wrapper.menu-toggle .quixnav .app-menu li a span {
        display: none !important;
    }

    /* Adjust padding for mini mobile icons - Perfectly Centered */
    #main-wrapper.menu-toggle .quixnav .app-menu>li>a {
        padding: 15px 0 !important;
        justify-content: center !important;
        margin: 5px !important;
        display: flex !important;
        align-items: center !important;
    }

    #main-wrapper.menu-toggle .quixnav .app-menu li a i {
        margin-right: 0 !important;
        font-size: 1.25rem !important;
        /* Slightly smaller as requested */
        display: block !important;
        width: auto !important;
    }

    /* Submenu links alignment - Ensure left alignment in mobile */
    #main-wrapper.menu-toggle .quixnav .app-menu ul li a {
        justify-content: flex-start !important;
        padding: 10px 20px !important;
        margin: 2px 10px !important;
    }

    /* SUBMENUS - Floating Popup Style for Mobile */
    .quixnav .app-menu>li {
        position: relative !important;
    }

    .quixnav .app-menu>li>ul {
        display: none !important;
        position: absolute !important;
        left: 80px !important;
        top: 0 !important;
        width: 230px !important;
        background: #fff !important;
        box-shadow: 10px 5px 20px rgba(0, 0, 0, 0.1) !important;
        border-radius: 0 10px 10px 0 !important;
        border: 1px solid var(--border-color) !important;
        z-index: 9999 !important;
        padding: 5px 0 !important;
    }

    /* Support for submenus opening upwards if at the bottom of the screen */
    .quixnav .app-menu>li.dropup>ul {
        top: auto !important;
        bottom: 0 !important;
        border-radius: 10px 10px 10px 0 !important;
        box-shadow: 10px -5px 20px rgba(0, 0, 0, 0.1) !important;
    }

    /* Show submenu popup on click (managed by mm-active or JS) */
    .quixnav .app-menu>li.mm-active>ul {
        display: block !important;
    }

    /* CRITICAL: Allow submenus inside the floating sidebar to overflow */
    #main-wrapper.menu-toggle .quixnav-scroll {
        overflow: visible !important;
    }

    .quixnav .app-menu ul li a {
        padding: 10px 20px !important;
        margin: 2px 10px !important;
        justify-content: flex-start !important;
        font-size: 0.9rem !important;
    }

    /* Force spacing between icons and text in submenus */
    #main-wrapper.menu-toggle .quixnav .app-menu ul li a i {
        margin-right: 10px !important;
        /* Increased for better visibility */
        font-size: 1rem !important;
        width: 20px !important;
        text-align: center !important;
        display: inline-block !important;
        /* Ensure margin is respected */
    }

    /* Hide the old nav-header container completely on mobile */
    .nav-header {
        display: none !important;
    }

    /* Style the new integrated hamburger in the main header */
    .header .nav-control {
        margin-right: 20px !important;
        display: flex !important;
        align-items: center !important;
        position: relative !important;
        /* Forces it back into the flex flow */
        top: auto !important;
        right: auto !important;
        left: 0 !important;
        bottom: auto !important;
        transform: none !important;
        width: auto !important;
        height: auto !important;
        z-index: 10 !important;
    }

    .header .hamburger {
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        background: transparent !important;
        padding: 0 !important;
        cursor: pointer !important;
        width: 45px !important;
        height: 45px !important;
    }

    .header .hamburger .line {
        background: var(--primary) !important;
        height: 3px !important;
        border-radius: 3px !important;
        width: 25px !important;
        margin: 2px 0 !important;
        display: block !important;
    }

    .header-right {
        margin-right: -10px !important;
        padding-right: 0 !important;
    }

    /* Provide space in the main header for the hamburger */
    .header .header-content {
        padding-left: 15px !important;
        padding-right: 10px !important;
    }

    .header-left {
        display: flex !important;
        justify-content: flex-start !important;
        flex: 0 0 auto !important;
        /* Don't grow too much */
    }
}

/* ==========================================================================
   3. VISIBILITY LOGIC (TEXT VS ICONS)
   ========================================================================== */

/* HIDE in any 80px state */
@media (min-width: 1200px) {

    #main-wrapper.menu-toggle .quixnav .nav-text,
    #main-wrapper.menu-toggle .quixnav .has-submenu:after,
    #main-wrapper.menu-toggle .brand-title {
        display: none !important;
    }
}

@media (max-width: 1199px) and (min-width: 768px) {

    #main-wrapper:not(.menu-toggle) .quixnav .nav-text,
    #main-wrapper:not(.menu-toggle) .quixnav .has-submenu:after,
    #main-wrapper:not(.menu-toggle) .brand-title {
        display: none !important;
    }
}

/* SHOW in any 280px state */
#main-wrapper:not(.menu-toggle) .quixnav .nav-text {
    display: block;
}

@media (max-width: 1199px) and (min-width: 768px) {
    #main-wrapper.menu-toggle .quixnav .nav-text {
        display: block !important;
    }
}

@media (max-width: 767px) {
    #main-wrapper.menu-toggle .quixnav .nav-text {
        display: block !important;
    }
}

/* ==========================================================================
   4. SUBMENU ACCORDION LOGIC
   ========================================================================== */

/* By default, hide all nested lists in standard mode */
.quixnav .app-menu ul {
    display: none;
    /* Hide submenus initially */
    padding-left: 0;
}

/* But let .slideDown() or .mm-active control display within the full sidebar */
.quixnav .app-menu li.mm-active>ul {
    display: block;
}

/* Arrow/Chevron for Submenus */
.quixnav .app-menu .has-submenu {
    position: relative;
}

.quixnav .app-menu .has-submenu:after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    border-right: 2px solid var(--text-muted);
    border-bottom: 2px solid var(--text-muted);
    position: absolute;
    right: 1.5rem;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    transition: transform 0.3s ease;
    opacity: 0.7;
}

/* Rotate arrow when active */
.quixnav .app-menu li.mm-active>.has-submenu:after {
    transform: translateY(-50%) rotate(225deg);
    border-color: var(--primary);
}

/* ==========================================================================
   5. SUBMENU POPUPS (MINI MODE)
   ========================================================================== */

/* Desktop Mini Popups */
@media (min-width: 1200px) {
    #main-wrapper.menu-toggle .quixnav .app-menu>li {
        position: relative !important;
    }

    #main-wrapper.menu-toggle .quixnav .app-menu>li>ul {
        display: none !important;
        /* Force hide initially even if active */
        position: absolute !important;
        left: 80px !important;
        top: 0 !important;
        width: 260px !important;
        background: #fff !important;
        box-shadow: 10px 5px 30px rgba(0, 0, 0, 0.1) !important;
        border-radius: 0 10px 10px 0 !important;
        border: 1px solid var(--border-color) !important;
        z-index: 9999 !important;
        padding: 0 0 10px 0 !important;
        /* Removed top padding to fix white gap */
    }

    #main-wrapper.menu-toggle .quixnav .app-menu>li.mm-active>ul {
        display: block !important;
    }

    /* CRITICAL: Allow popups to overflow the scroll container */
    #main-wrapper.menu-toggle .quixnav-scroll {
        overflow: visible !important;
    }
}

/* Tablet Mini Popups (Default) */
@media (max-width: 1199px) and (min-width: 768px) {
    #main-wrapper:not(.menu-toggle) .quixnav .app-menu>li {
        position: relative !important;
    }

    #main-wrapper:not(.menu-toggle) .quixnav .app-menu>li>ul {
        display: none !important;
        position: absolute !important;
        left: 80px !important;
        top: 0 !important;
        width: 260px !important;
        background: #fff !important;
        box-shadow: 10px 5px 30px rgba(0, 0, 0, 0.1) !important;
        border-radius: 0 10px 10px 0 !important;
        border: 1px solid var(--border-color) !important;
        z-index: 9999 !important;
        padding: 0 0 10px 0 !important;
        /* Removed top padding to fix white gap */
    }

    #main-wrapper:not(.menu-toggle) .quixnav .app-menu>li.mm-active>ul {
        display: block !important;
    }

    /* CRITICAL: Allow popups to overflow the scroll container */
    #main-wrapper:not(.menu-toggle) .quixnav-scroll {
        overflow: visible !important;
    }
}

/* ==========================================================================
   6. UI REFINEMENTS (BLUE & WHITE)
   ========================================================================== */

.nav-header {
    height: var(--header-height) !important;
    width: var(--sidebar-width) !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.quixnav .app-menu li a {
    color: var(--text-muted) !important;
    font-weight: 500;
    padding: 12px 20px !important;
    margin: 4px 15px !important;
    border-radius: 12px !important;
    display: flex;
    align-items: center;
}

.quixnav .app-menu li a i {
    color: var(--primary) !important;
    font-size: 1.25rem;
    width: 30px;
    text-align: center;
    margin-right: 15px;
}



/* Submenu Icons (Smaller & Indented) */
.quixnav .app-menu ul a i {
    font-size: 0.9rem !important;
    width: 20px;
    margin-right: 10px;
    opacity: 0.8;
}

/* 3rd Level Menu Indentation */
.quixnav .app-menu ul ul a {
    padding-left: 40px !important;
    /* Increased indentation for deep nesting */
    font-size: 0.85rem !important;
    /* Slightly smaller text for hierarchy */
}

/* 
 * MINI MODE HEADER INJECTION
 * Hidden by default, visible only in Mini Mode
 */
.mini-menu-header {
    display: none;
    /* Hide in normal vertical mode */
}

/* Show in Desktop Mini Mode */
#main-wrapper.menu-toggle .quixnav .app-menu .mini-menu-header {
    display: block !important;
    padding: 10px 15px;
    background-color: var(--primary-light);
    /* Changed to light blue */
    color: var(--primary);
    /* Changed to blue text */
    font-weight: 700;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 0 var(--radius-md) 0 0;
    /* Rounded top matches submenu border */
    text-align: center;
    margin-bottom: 5px;
}

/* Show in Tablet Mini Mode (Default) */
@media (max-width: 1199px) and (min-width: 768px) {
    #main-wrapper:not(.menu-toggle) .quixnav .app-menu .mini-menu-header {
        display: block !important;
        padding: 10px 15px;
        background-color: var(--primary-light);
        /* Changed to light blue */
        color: var(--primary);
        /* Changed to blue text */
        font-weight: 700;
        font-size: 0.9rem;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        border-radius: 0 var(--radius-md) 0 0;
        text-align: center;
        margin-bottom: 5px;
    }
}

.quixnav .app-menu li.mm-active>a,
.quixnav .app-menu li.mm-active-parent>a {
    background: var(--primary-light) !important;
    color: var(--primary) !important;
    font-weight: 700 !important;
    border-radius: var(--radius-md) !important;
}

.hamburger .line {
    background: var(--primary) !important;
    height: 3px !important;
}

#preloader {
    z-index: 100000 !important;
    background: #ffffff !important;
}

#preloader .sk-three-bounce .sk-child {
    background-color: var(--primary) !important;
}

/* ==========================================================================
   5. AUTHENTICATION PAGES (LOGIN/SIGNUP)
   ========================================================================== */

.authincation {
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100vh !important;
}

.authincation-content {
    background: var(--card-bg) !important;
    box-shadow: var(--shadow-lg) !important;
    border-radius: var(--radius-lg) !important;
    border: 1px solid var(--border-color) !important;
    overflow: hidden !important;
}

.auth-form {
    padding: 40px 35px !important;
}

.auth-form h4 {
    font-weight: 800 !important;
    color: var(--text-main) !important;
    font-size: 1.5rem !important;
    margin-bottom: 30px !important;
}

.auth-form label {
    font-weight: 600 !important;
    color: var(--text-muted) !important;
    font-size: 0.85rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 8px !important;
}

.auth-form .form-control {
    background-color: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: var(--radius-md) !important;
    padding: 12px 15px !important;
    height: auto !important;
    font-size: 15px !important;
    transition: all 0.2s ease !important;
}

.auth-form .form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 4px var(--primary-light) !important;
    background-color: #ffffff !important;
}

/* Global Button Refinement (Normalization) */
.btn {
    border-radius: var(--radius-md) !important;
    font-weight: 600 !important;
    transition: all 0.2s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 10px 20px !important;
    height: 42px !important;
    /* Unified Height */
    font-size: 14px !important;
    border-width: 1px !important;
}

.btn i {
    margin-right: 8px;
    font-size: 1rem;
}

/* Button Variants Overrides */
.btn-primary {
    background-color: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 10px rgba(37, 99, 235, 0.15) !important;
}

.btn-primary:hover {
    background-color: #1d4ed8 !important;
    /* Slightly darker blue */
    transform: translateY(-1px);
    box-shadow: 0 6px 15px rgba(37, 99, 235, 0.25) !important;
}

.btn-dark {
    background-color: #334155 !important;
    /* Modern Slate */
    border-color: #334155 !important;
    color: #ffffff !important;
}

.btn-success {
    background-color: #10b981 !important;
    /* Modern Emerald */
    border-color: #10b981 !important;
    color: #ffffff !important;
}

.btn-warning {
    background-color: #f59e0b !important;
    /* Modern Amber */
    border-color: #f59e0b !important;
    color: #ffffff !important;
}

.btn-danger {
    background-color: #f43f5e !important;
    /* Modern Rose */
    border-color: #f43f5e !important;
    color: #ffffff !important;
}

/* Button Sizes */
.btn-lg {
    height: 52px !important;
    padding: 12px 25px !important;
    font-size: 16px !important;
}

.btn-sm {
    height: 32px !important;
    padding: 5px 15px !important;
    font-size: 12px !important;
}

.btn-block {
    width: 100% !important;
}

/* Nav Pills (Settings Tabs) Correction */
.nav-pills .nav-link {
    border-radius: var(--radius-md) !important;
    padding: 12px 20px !important;
    color: var(--text-muted) !important;
    font-weight: 500 !important;
    margin-bottom: 5px !important;
    transition: all 0.2s ease !important;
}

.nav-pills .nav-link i {
    margin-right: 10px;
    width: 20px;
    text-align: center;
}

.nav-pills .nav-link.active,
.nav-pills .show>.nav-link {
    background-color: var(--primary-light) !important;
    color: var(--primary) !important;
    font-weight: 700 !important;
}

/* DataTables Buttons Styling */
.dt-buttons {
    margin-bottom: 20px !important;
}

.dt-buttons .btn-secondary,
.dt-buttons .buttons-copy,
.dt-buttons .buttons-print,
.dt-buttons .buttons-excel,
.dt-buttons .buttons-pdf {
    background-color: #f8fafc !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-muted) !important;
    border-radius: var(--radius-md) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    padding: 8px 16px !important;
    height: auto !important;
    min-height: 38px !important;
    transition: all 0.2s ease !important;
    box-shadow: none !important;
    margin-right: 5px !important;
}

.dt-buttons .btn-secondary:hover {
    background-color: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
}

.dt-buttons .btn-secondary i {
    margin-right: 5px;
}


/* Form Controls Consistency */
.form-control {
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
    padding: 10px 15px !important;
    height: auto !important;
    min-height: 42px !important;
    font-size: 14px !important;
}

.card-body {
    padding: 1.875rem !important;
    padding-bottom: 3rem !important;
    /* Extra room for dropdowns at the bottom */
}

.form-group {
    margin-bottom: 1.875rem !important;
}

.form-group label {
    font-weight: 600 !important;
    color: var(--text-muted) !important;
    margin-bottom: 8px !important;
}

/* Force Select2 dropdown down if space permits and refine border */
.select2-container--default .select2-dropdown--below {
    border-top: none !important;
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
}

.select2-container--default .select2-dropdown--above {
    border-bottom: none !important;
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

/* Custom Switches/Checks colors */
.custom-control-input:checked~.custom-control-label::before {
    background-color: var(--primary) !important;
    border-color: var(--primary) !important;
}

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

/* Select2 Standardization */
.select2-container--default .select2-selection--single {
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
    height: 42px !important;
    padding: 6px 12px !important;
    transition: all 0.2s ease !important;
    background-color: #fff !important;
    display: flex !important;
    align-items: center !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 1.2 !important;
    color: var(--text-dark) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    padding-left: 5px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 40px !important;
    right: 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--primary) !important;
}

.select2-dropdown {
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: var(--shadow-md) !important;
    z-index: 1050 !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: var(--primary) !important;
}

.select2-search--dropdown {
    padding: 10px !important;
}

.select2-search--dropdown .select2-search__field {
    border-radius: var(--radius-sm) !important;
    border: 1px solid var(--border-color) !important;
    padding: 8px 12px !important;
    outline: none !important;
    font-size: 13px !important;
}

.select2-results__option {
    padding: 10px 15px !important;
    font-size: 14px !important;
}

.select2-container--default .select2-results__option[aria-selected="true"] {
    background-color: var(--primary-light) !important;
    color: var(--primary) !important;
}

/* ==========================================================================
   9. INPUT GROUP NORMALIZATION
   ========================================================================== */

.input-group {
    display: flex !important;
    align-items: stretch !important;
    width: 100% !important;
    border-radius: var(--radius-md) !important;
    overflow: visible !important;
}

.input-group .form-control,
.input-group .btn,
.input-group .input-group-text {
    border-radius: 0 !important;
    margin: 0 !important;
    position: relative !important;
    z-index: 1 !important;
}

/* 1. Left side rounding (for first visible elements) */
.input-group>.form-control:first-child,
.input-group>.input-group-prepend:first-child .btn,
.input-group>.input-group-prepend:first-child .input-group-text,
.input-group>input[type="hidden"]:first-child+.form-control,
.input-group>input[type="hidden"]:first-child+.input-group-prepend .btn {
    border-top-left-radius: var(--radius-md) !important;
    border-bottom-left-radius: var(--radius-md) !important;
}

/* 2. Right side rounding (for last visible elements) */
.input-group>.form-control:last-child,
.input-group>.input-group-append:last-child .btn,
.input-group>.input-group-append:last-child .input-group-text,
.input-group>.input-group-prepend:last-child .btn,
/* Support misuse of prepend at the end */
.input-group>.input-group-prepend:last-child .input-group-text {
    border-top-right-radius: var(--radius-md) !important;
    border-bottom-right-radius: var(--radius-md) !important;
}

/* 3. Handle specific focus state to keep borders clean */
.input-group>.form-control:focus {
    z-index: 3 !important;
    border-color: var(--primary) !important;
}

.input-group-text {
    background-color: #f1f5f9 !important;
    border: 1px solid var(--border-color) !important;
    color: var(--text-muted) !important;
    font-weight: 600 !important;
    padding: 0 15px !important;
    display: flex !important;
    align-items: center !important;
    font-size: 14px !important;
}



.auth-form a {
    color: var(--primary) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
}

/* UI Polish: Breadcrumbs & Welcome Titles */
.welcome-text h4,
.welcome-text span,
.page-titles h4,
.page-titles .breadcrumb-item.active {
    color: var(--primary) !important;
}

.welcome-text h4 i,
.page-titles h4 i {
    color: var(--primary) !important;
    margin-right: 8px !important;
}

.page-titles .breadcrumb-item a {
    color: var(--text-muted) !important;
    transition: color 0.2s ease !important;
}

.page-titles .breadcrumb-item a:hover {
    color: var(--primary) !important;
}

/* Profile Dropdown Rounding */
.header-profile .dropdown-menu {
    border-radius: var(--radius-md) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: var(--shadow-lg) !important;
    padding: 0.8rem !important;
    margin-top: 15px !important;
}

.header-profile .dropdown-item {
    border-radius: var(--radius-sm) !important;
    padding: 10px 20px !important;
    font-weight: 500 !important;
    color: var(--text-main) !important;
    margin-bottom: 2px !important;
    transition: all 0.2s ease !important;
}

.header-profile .dropdown-item:hover {
    background-color: var(--primary-light) !important;
    color: var(--primary) !important;
}

.header-profile .dropdown-item i {
    color: var(--text-muted) !important;
    width: 20px !important;
    text-align: center !important;
}

.header-profile .dropdown-item:hover i {
    color: var(--primary) !important;
}

/* ==========================================================================
   7. MODAL REFINEMENT
   ========================================================================== */

.modal-content {
    border-radius: var(--radius-lg) !important;
    border: none !important;
    box-shadow: var(--shadow-lg) !important;
}

.modal-header {
    border-bottom: 1px solid var(--border-color) !important;
    padding: 20px 25px !important;
    background: #ffffff !important;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

.modal-footer {
    border-top: 1px solid var(--border-color) !important;
    padding: 15px 25px !important;
}

.modal-backdrop.show {
    opacity: 0.6 !important;
    /* backdrop-filter: blur(4px); */
    /* Enable if browser supports and doesn't lag */
}

/* ==========================================================================
   8. DATEPICKER (MATERIAL) UNIFICATION
   ========================================================================== */

.dtp {
    font-family: 'Inter', sans-serif !important;
    z-index: 9999 !important;
}

.dtp>.dtp-content {
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    background: #ffffff !important;
    overflow: hidden !important;
}

.dtp>.dtp-content>.dtp-date-view>header {
    background: var(--primary) !important;
    padding: 20px !important;
    border-top-left-radius: var(--radius-lg) !important;
    border-top-right-radius: var(--radius-lg) !important;
}

.dtp div.dtp-date,
.dtp div.dtp-time {
    background: var(--primary) !important;
    opacity: 0.95 !important;
}

.dtp .dtp-actual-month,
.dtp .dtp-actual-num,
.dtp .dtp-actual-year {
    font-weight: 700 !important;
}

.dtp table.dtp-picker-days tr>td>a.selected {
    background: var(--primary) !important;
}

.dtp .dtp-buttons>.btn-flat {
    color: var(--primary) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
}

.dtp .dtp-picker-month>div>a>i,
.dtp .dtp-picker-year>div>a>i {
    color: #ffffff !important;
}

/* Material Icons size fix in datepicker */
.dtp i.material-icons {
    font-size: 24px !important;
    vertical-align: middle !important;
}

.dtp-date-view>header>.dtp-actual-num {
    font-size: 3rem !important;
}

/* ==========================================================================
   11. SUMMERNOTE EDITOR REFINEMENT
   ========================================================================== */
.note-editor.note-frame {
    border: 1px solid var(--border-color) !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: none !important;
    margin-top: 10px !important;
}

.note-toolbar {
    padding: 12px 15px !important;
    background: #f8fafc !important;
    border-bottom: 1px solid var(--border-color) !important;
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0 !important;
    /* Join logical groups into a single bar */
}

.note-btn-group {
    display: flex !important;
    margin-right: 15px !important;
    /* Space between logical segments */
    position: relative !important;
}

.note-btn-group .note-btn {
    border-radius: 0 !important;
    /* Force square by default */
    border: 1px solid var(--border-color) !important;
    margin-left: -1px !important;
    /* Overlap borders */
    background: #fff !important;
    color: var(--text-main) !important;
    box-shadow: none !important;
    height: 34px !important;
    padding: 5px 12px !important;
    transition: all 0.2s ease !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 13px !important;
}

.note-btn-group .note-btn:hover {
    background: var(--primary-light) !important;
    color: var(--primary) !important;
    z-index: 10 !important;
}

/* Round ONLY the extremes of each group (Segmented Look) */
.note-btn-group .note-btn:first-child {
    border-top-left-radius: var(--radius-md) !important;
    border-bottom-left-radius: var(--radius-md) !important;
    margin-left: 0 !important;
}

.note-btn-group .note-btn:last-child {
    border-top-right-radius: var(--radius-md) !important;
    border-bottom-right-radius: var(--radius-md) !important;
}

/* Individual buttons (like Wizard or Link) */
.note-btn-group .note-btn:only-child {
    border-radius: var(--radius-md) !important;
}

.note-editable {
    padding: 20px !important;
    font-family: 'Inter', sans-serif !important;
    color: var(--text-main) !important;
    min-height: 150px !important;
    background-color: #ffffff !important;
}

.note-statusbar {
    background: #f8fafc !important;
    border-top: 1px solid var(--border-color) !important;
}

.note-resizebar {
    padding-top: 5px !important;
    border-top: none !important;
}

.note-icon-caret {
    display: none !important;
    /* cleaner look */
}

.note-btn.dropdown-toggle:after {
    margin-left: 5px !important;
    vertical-align: middle !important;
}

/* ==========================================================================
   12. MODERN DATATABLES STANDARDIZATION
   ========================================================================== */

.dt-modern-style {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    margin: 1.5rem 0 !important;
}

.dt-modern-style thead th {
    background-color: #f8fafc !important;
    color: var(--text-muted) !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.05em !important;
    padding: 15px 20px !important;
    border-top: 1px solid var(--border-color) !important;
    border-bottom: 2px solid var(--border-color) !important;
}

.dt-modern-style tbody td {
    padding: 15px 20px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid var(--border-color) !important;
    color: var(--text-main) !important;
    font-size: 0.9rem !important;
}

.dt-modern-style tbody tr:hover {
    background-color: rgba(37, 99, 235, 0.02) !important;
}

/* Responsive extension refinements */
table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control:before {
    content: '+' !important;
    background-color: var(--primary) !important;
    border: 2px solid #fff !important;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.2) !important;
    top: 50% !important;
    left: 15px !important;
    margin-top: -9px !important;
    height: 18px !important;
    width: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: white !important;
    border-radius: 50% !important;
    text-indent: 0 !important;
}

table.dataTable.dtr-inline.collapsed>tbody>tr.parent>td.dtr-control:before {
    content: '-' !important;
    background-color: #ef4444 !important;
    /* Red for expanded state */
}

/* Ellipsis Button Styling */
.btn-icon.btn-sm {
    width: 32px !important;
    height: 32px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    border: 1px solid transparent !important;
    color: var(--text-muted) !important;
    border-radius: var(--radius-sm) !important;
}

.btn-icon.btn-sm:hover {
    background: var(--primary-light) !important;
    color: var(--primary) !important;
    border-color: var(--primary-light) !important;
}

.dt-modern-style .btn-group {
    display: flex !important;
    justify-content: center !important;
}

/* Pagination consistency */
.dataTables_wrapper .dataTables_paginate {
    padding-top: 1.5rem !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
    padding: 0 !important;
    width: 32px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    margin: 0 4px !important;
    transition: all 0.2s ease !important;
    border: 1px solid transparent !important;
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    color: var(--text-muted) !important;
}

body .dataTables_wrapper .dataTables_paginate .paginate_button.current,
body .dataTables_wrapper .dataTables_paginate .paginate_button.current:hover,
body .dataTables_wrapper .dataTables_paginate .paginate_button.current a,
body .dataTables_wrapper .dataTables_paginate .paginate_button.current:active {
    background: var(--primary) !important;
    color: #ffffff !important;
    border-color: var(--primary) !important;
    font-weight: 700 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 1 !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--primary-light) !important;
    color: var(--primary) !important;
    border-color: var(--primary-light) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:active {
    color: #cbd5e1 !important;
    background: transparent !important;
    border-color: transparent !important;
    cursor: default !important;
}

/* Previous/Next should not be circles */
.dataTables_wrapper .dataTables_paginate .paginate_button.previous,
.dataTables_wrapper .dataTables_paginate .paginate_button.next {
    width: auto !important;
    padding: 0 12px !important;
    border-radius: var(--radius-sm) !important;
}

/* ==========================================================================
   DATEPICKER BUTTON FIX - ROBUST VERSION
   Forces visibility of OK/Cancel buttons with layout resets
   ========================================================================== */
.dtp .dtp-content {
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    border-radius: var(--radius-lg) !important;
    /* Restore rounded corners */
}

.dtp .dtp-content .dtp-date-view {
    height: auto !important;
    overflow: visible !important;
    margin-bottom: 0 !important;
    border-top-left-radius: var(--radius-lg) !important;
    border-top-right-radius: var(--radius-lg) !important;
}

.dtp .dtp-content .dtp-buttons {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    visibility: visible !important;
    opacity: 1 !important;
    padding: 10px 20px !important;
    background: #fff !important;
    /* Ensure bg is white */
    min-height: 50px !important;
    position: relative !important;
    z-index: 100 !important;
    margin-top: -10px !important;
    /* Pull up slightly if gap exists */
    border-bottom-left-radius: var(--radius-lg) !important;
    /* Bottom corners */
    border-bottom-right-radius: var(--radius-lg) !important;
}

.dtp .dtp-content .dtp-buttons .dtp-btn-ok {
    margin-left: 15px !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    color: var(--primary) !important;
    text-transform: uppercase !important;
}

.dtp .dtp-content .dtp-buttons .dtp-btn-cancel {
    display: none !important;
    /* Hidden as per user request */
}

/* ========================================================================== 
   13. BREADCRUMBS & PAGE TITLES REFINEMENT 
   ========================================================================== */

.page-titles {
    padding: 1.5rem 0 !important;
    background: transparent !important;
    margin-bottom: 1rem !important;
}

.welcome-text h4 {
    font-weight: 800 !important;
    font-size: 1.5rem !important;
    display: flex !important;
    align-items: center !important;
}

.welcome-text h4 i,
.welcome-text h4 .material-symbols-outlined,
.welcome-text h4 .material-icons {
    font-size: 1.8rem !important;
    margin-right: 15px !important;
    background: var(--primary-light) !important;
    width: 45px !important;
    height: 45px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px !important;
    color: var(--primary) !important;
}

.welcome-text span {
    font-weight: 500 !important;
    font-size: 0.95rem !important;
    color: var(--text-muted) !important;
    margin-left: 60px !important;
    display: block !important;
    margin-top: -5px !important;
}

.modern-breadcrumb {
    background: transparent !important;
    padding: 10px 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    list-style: none !important;
}

.modern-breadcrumb-item {
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    color: var(--text-muted) !important;
    display: flex !important;
    align-items: center !important;
}

.modern-breadcrumb-item a {
    color: var(--text-muted) !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.modern-breadcrumb-item a:hover {
    color: var(--primary) !important;
}

.modern-breadcrumb-item.active {
    color: var(--primary) !important;
}

/* Modern Breadcrumb Separator */
.modern-breadcrumb-item+.modern-breadcrumb-item::before {
    content: "chevron_right" !important;
    font-family: 'Material Icons' !important;
    font-size: 1.2rem !important;
    line-height: 1 !important;
    vertical-align: middle !important;
    color: var(--border-color) !important;
    padding: 0 12px !important;
}