﻿
/* Add to your site.css - Theme Variables */
:root {
    /* Light Theme (Default) */
    --bg-primary: #f8f8f8;
    --bg-secondary: #ffffff;
    --bg-card: #ffffff;
    --text-primary: #1f2937;
    --text-secondary: #5a5a5a;
    --text-muted: #6b7280;
    --border-color: #e5e5e5;
    --shadow: rgba(0, 0, 0, 0.08);
    --accent-color: #3f73ff;
    --accent-hover: #1e50d5;
    --grid-header-bg: #e3f2fd;
    --grid-header-border: #bbdefb;
    --input-bg: #ffffff;
    --input-border: #ccc;
    --footer-bg: #f7f7f7;
    --menu-bg: #f8f8f8;
    --dropdown-bg: #ffffff;
    --hover-bg: #eef2ff;
}

/* Dark Theme */
[data-theme="dark"] {
    --bg-primary: #1a1a2e;
    --bg-secondary: #16213e;
    --bg-card: #1f2937;
    --text-primary: #f3f4f6;
    --text-secondary: #d1d5db;
    --text-muted: #9ca3af;
    --border-color: #374151;
    --shadow: rgba(0, 0, 0, 0.3);
    --accent-color: #60a5fa;
    --accent-hover: #3b82f6;
    --grid-header-bg: #1e3a5f;
    --grid-header-border: #2d4a6f;
    --input-bg: #1f2937;
    --input-border: #4b5563;
    --footer-bg: #111827;
    --menu-bg: #1a1a2e;
    --dropdown-bg: #1f2937;
    --hover-bg: #374151;
}

/* Apply Variables to Elements */
body {
    background-color: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* Navbar */
.custom-navbar {
    background-color: var(--menu-bg) !important;
    border-bottom-color: var(--border-color) !important;
}

/* Cards */
.card, .export-card {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

/* Text Classes */
.text-muted {
    color: var(--text-muted) !important;
}

/* Footer */
.tc-footer {
    background-color: var(--footer-bg) !important;
    border-top-color: var(--border-color) !important;
}

.footer-content, .footer-text {
    color: var(--text-secondary) !important;
}

/* Inputs & Dropdowns */
input, select, textarea,
#ddltenant, #ddlclienttenant {
    background-color: var(--input-bg) !important;
    border-color: var(--input-border) !important;
    color: var(--text-primary) !important;
}

/* Kendo Grid */
.k-grid {
    background-color: var(--bg-card) !important;
    border-color: var(--border-color) !important;
}

    .k-grid .k-grid-header,
    .k-grid .k-grid-header .k-header {
        background-color: var(--grid-header-bg) !important;
        border-color: var(--grid-header-border) !important;
        color: var(--text-primary) !important;
    }

    .k-grid td, .k-grid .k-grid-content {
        background-color: var(--bg-card) !important;
        color: var(--text-primary) !important;
        border-color: var(--border-color) !important;
    }

    .k-grid .k-alt {
        background-color: var(--bg-secondary) !important;
    }

/* Kendo Pager */
.k-pager, .k-pager-wrap {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

/* Kendo Menu */
#Menu.k-menu.k-menu-horizontal {
    background-color: var(--menu-bg) !important;
}

#Menu .k-menu-link {
    color: var(--accent-color) !important;
}

#Menu .k-menu-group {
    background-color: var(--dropdown-bg) !important;
    border-color: var(--border-color) !important;
}

    #Menu .k-menu-group .k-menu-link {
        color: var(--text-primary) !important;
    }

        #Menu .k-menu-group .k-menu-link:hover {
            background-color: var(--hover-bg) !important;
        }

/* Kendo Dropdowns */
.k-dropdown, .k-dropdown-wrap, .k-picker {
    background-color: var(--input-bg) !important;
    border-color: var(--input-border) !important;
    color: var(--text-primary) !important;
}

.k-list, .k-popup {
    background-color: var(--dropdown-bg) !important;
    border-color: var(--border-color) !important;
}

    .k-list .k-item {
        color: var(--text-primary) !important;
    }

        .k-list .k-item:hover {
            background-color: var(--hover-bg) !important;
        }

/* Kendo ListView */
.k-listview {
    background-color: transparent !important;
}

/* Charts - Kendo charts need special handling */
[data-theme="dark"] .k-chart {
    background-color: var(--bg-card) !important;
}

/* Buttons */
.btn-primary {
    background-color: var(--accent-color) !important;
    border-color: var(--accent-color) !important;
}

    .btn-primary:hover {
        background-color: var(--accent-hover) !important;
    }

/* Theme Toggle Button */
#themeToggle {
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-primary);
    transition: all 0.3s ease;
}

    #themeToggle:hover {
        background-color: var(--hover-bg);
        border-color: var(--accent-color);
    }

/* Badge adjustments for dark mode */
[data-theme="dark"] .badge.bg-light {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
}


/*#pinToDashboardModal .k-dropdown,
#pinToDashboardModal .k-dropdown-wrap,
#pinToDashboardModal .k-input-inner {
    width: 100% !important;
    box-sizing: border-box;
}
*/
/*#pinToDashboardModal .k-dropdown {
    display: block !important;
    margin-top: 4px;
    margin-bottom: 16px;
}
*/

/*#pinToDashboardModal .k-dropdown {
    display: block !important;
    width: 100% !important;
    margin-top: 4px;
    margin-bottom: 16px;
}*/

#tenantLabel {
    font-weight: 500;
    color: var(--text-primary);
    margin: 0;
}

#ddltenant {
    min-width: 220px;
}

/* Fix Kendo MultiSelect alignment & height */
.k-multiselect {
    min-height: 36px !important;
    line-height: 1.2 !important;
    display: flex !important;
    align-items: center !important;
    padding: 2px 6px !important;
}

    /* Tag mode “single” should stay centered */
    .k-multiselect .k-chip-list {
        display: flex !important;
        align-items: center !important;
        padding: 0 !important;
    }

/* Make the collapsed tag more compact */
.k-chip {
    margin: 0 !important;
    padding: 4px 6px !important;
}

/* Optional: remove blue outline if you dislike it */
.k-multiselect.k-focus {
    box-shadow: none !important;
    border-color: #ccc !important;
}



/* ✅ Base navbar */
/*.custom-navbar {
    min-height: 64px !important;*/ /* Increased for premium look */
    /*padding: 0 28px !important;
    background-color: #f8f8f8 !important;
    border-bottom: 1px solid #e5e5e5;
    display: flex;
    align-items: center;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);*/ /* subtle enterprise shadow */
/*}*/



/* ✅ Dropdown styling */
#ddlclienttenant {
    min-width: 250px;
    max-width: 250px;
    padding: 6px 12px;
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
    background-color: #fff;
    box-shadow: 0 1px 2px rgba(0,0,0,0.1);
    transition: border-color 0.3s, box-shadow 0.3s;
}

    #ddlclienttenant:focus {
        border-color: #007bff;
        box-shadow: 0 0 5px rgba(0,123,255,0.5);
    }





/* Make dropdown consistent and readable */
#ddltenant {
    width: 250px;
    max-width: 250px;
    white-space: normal; /* allow wrapping */
    word-wrap: break-word; /* break long names */
    line-height: 1.4;
}

    /* Make dropdown options wrap instead of expanding width */
    #ddltenant option {
        white-space: normal !important;
        word-wrap: break-word !important;
        max-width: 240px;
        overflow-wrap: break-word;
    }

.k-dropdown, .k-dropdown-wrap {
    max-width: 250px !important;
    white-space: normal !important;
}



#region Navbar styles
.navbar-header {
    border-bottom: 1px solid rgba(255,255,255, 0.1);
}

.navbar-brand {
    font-size: 2rem;
    font-weight: lighter;
}
 #endregion 


/* #region Footer styles 
.footer {
    position: absolute;
    bottom: 0;
    width: 100%;
    font-size: 0.85em;
}
 #endregion */

 #region custom Kendo UI styles 


h1 a {
    color: #fff;
    text-decoration: none;
}

h2 {
    font-weight: lighter;
}

.placeholder img {
    display: inline-block;
}

p .k-button {
    margin: 0 15px 0 0;
}

#configure {
    display: none;
}

p .k-button {
    margin: 0 15px 0 0;
}

.k-state-active .label {
    font-size: 1em;
}

#responsive-panel {
    padding: 0;
    width: 100%;
}

#endregion 

@media (max-width: 767px) {
    #responsive-panel {
        transition: all linear .2s;
    }

    #configure {
        display: block;
        float: right;
    }

    .k-rpanel {
        padding: 0 1rem;
    }

    .k-rpanel-expanded {
        padding: .5rem 1rem;
    }

    .navbar-header {
        width: 100%;
    }

    .navbar-brand {
        font-size: 1.5rem;
    }

    h2 {
        font-size: 2rem;
    }


    .k-rpanel-expanded ul {
        flex-direction: column;
    }
}


.loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    z-index: 2000;
    font-family: sans-serif;
}

.spinner {
    border: 4px solid #e0e0e0;
    border-top: 4px solid #0078d4;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: spin 1s linear infinite;
}

.loader-text {
    margin-top: 12px;
    color: var(--text-primary);
    font-size: 14px;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}


html, body {
    height: 100%;
    margin: 0;
}

body {
    display: flex;
    flex-direction: column;
}

main {
    flex: 1 0 auto;
}

.tc-footer {
    flex-shrink: 0;
}

/*body {
    padding-bottom: 60px;
}*/

/*Wrapping element 
 Set some basic padding to keep content from hitting the edges*/
.body-content {
    padding-left: 15px;
    padding-right: 15px;
}


.label {
    color: #337ab7;
}


/* Sticky footer styles */
/*.footer {
    position: absolute;
    bottom: 10px;
    height: 40px;
}

    .footer .text-muted {
        margin: 0;
        display: inline-block;
    }*/

.body-content > .row:first-child {
    margin-bottom: 15px;
}

.k-tabstrip ul li.k-item {
    width: 100px;
}

h1 a {
    color: #e0e0e0;
    text-decoration: none;
}

    h1 a:hover,
    h1 a:active {
        color: #ffffff;
        text-decoration: none;
    }

.img-responsive {
    padding-top: 25px;
}

/* Styling menu toggle button */
.btn-toggle {
    position: absolute;
    top: 0;
    left: 0;
    box-shadow: none;
    height: 48px;
}

    .btn-toggle .k-icon {
        opacity: 1;
    }

    .btn-toggle,
    .btn-toggle:focus:active:not(.k-state-disabled):not([disabled]),
    .btn-toggle:focus:not(.k-state-disabled):not([disabled]) {
        box-shadow: none;
        border-radius: 0;
    }

        .btn-toggle .k-i-hbars,
        .btn-toggle:focus:active:not(.k-state-disabled):not([disabled]) .k-i-hbars,
        .btn-toggle:focus:not(.k-state-disabled):not([disabled]) .k-i-hbars {
            background-position: -80px -32px;
        }

/* Styling menu and header for smaller resolutions */
@media (max-width: 768px) {

    .k-header h1 {
        margin: 0;
        padding: 16px 15px 14px 60px;
        font-size: 18px;
        font-weight: lighter;
    }


    .k-rpanel {
        position: relative;
        box-sizing: border-box;
    }

        .k-rpanel .k-menu {
            float: none;
            display: block;
            box-sizing: border-box;
        }

            .k-rpanel .k-menu .k-item {
                display: block;
                clear: both;
                float: none;
                width: 100%;
            }
}



.k-multiselect .k-input {
    font-family: 'Segoe UI', sans-serif;
    font-size: 13px;
}

.k-list .k-selected {
    background-color: #0078d7 !important; /* highlight blue */
    color: #fff !important;
}

.k-button.k-primary {
    background-color: #0078d7;
    color: #fff;
    border-radius: 6px;
    font-size: 13px;
    padding: 4px 12px;
}


/* --- MultiSelect outer shell --- */
.k-multiselect {
    font-family: "Segoe UI", sans-serif !important;
    font-size: 12px !important;
    width: 200px; /* adjust to match layout */
}

    /* --- Wrap (actual input area) fix: lock height --- */
    .k-multiselect .k-multiselect-wrap {
        display: flex !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        height: 32px !important;
        min-height: 32px !important;
        max-height: 32px !important;
        padding: 0 4px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        border-radius: 6px !important;
        box-sizing: border-box !important;
    }

    /* --- Chips compact --- */
    .k-multiselect .k-chip {
        background-color: #f3f6fc !important;
        color: #222 !important;
        border-radius: 4px !important;
        padding: 1px 6px !important;
        margin: 1px 2px !important;
        font-size: 11px !important;
        line-height: 1 !important;
        flex-shrink: 0 !important;
    }

/* --- 'X' close icon centered --- */
.k-chip .k-icon.k-i-close,
.k-chip .k-icon.k-i-x {
    font-size: 10px !important;
    margin-left: 3px !important;
    margin-top: 0 !important;
    color: #555 !important;
    opacity: 0.8 !important;
}

.k-chip .k-icon:hover {
    color: #0067c5 !important;
    opacity: 1 !important;
}

/* --- Dropdown item styling --- */
.k-list .k-item {
    font-size: 12px !important;
    padding: 4px 8px !important;
}

.k-list .k-selected {
    background-color: #0067c5 !important;
    color: #fff !important;
}

/* --- Apply button matches height exactly --- */
#applyClinicSelection {
    height: 32px !important;
    margin-left: 6px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    padding: 0 14px;
    background-color: #0067c5;
    color: #fff;
    border: none;
    vertical-align: middle;
}

    #applyClinicSelection:hover {
        background-color: #0053a3;
    }


.k-multiselect-wrap .k-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 3px !important; /* reduced from 6px → 3px */
    padding: 2px 7px !important;
    height: 26px !important;
    background-color: #eef1f5 !important;
    border-radius: 6px !important;
    font-size: 13px !important;
}

.k-multiselect-wrap .k-select {
    position: static !important;
    margin-left: 2px !important; /* reduced from 4px → 2px */
    font-size: 12px !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
}


/* --- Delete (X) icon fix --- */
.k-multiselect-wrap .k-select {
    position: static !important;
    margin-left: 4px !important;
    font-size: 12px !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
}

/* --- Keep overall control compact --- */
.k-multiselect-wrap {
    align-items: center !important;
    min-height: 32px !important;
}


#tenantContainer {
    position: absolute;
    right: 25px;
    top: 8px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
}


/* Avatar Circle */
.avatar-circle {
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, #3f73ff, #5a8bff);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    margin-right: 8px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}


/* Username row */
.user-row {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #333;
    font-size: 14px;
    font-weight: 600;
}


/* Clinic box (container style like Azure filters) */
.clinic-box {
    background: var(--bg-card);
    padding: 6px 10px;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid var(--border-color);
}

    .clinic-box label {
        font-weight: 600;
        color: var(--text-secondary);
    }


/* Welcome text */
.welcome-text {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .2px;
    color: var(--text-primary) !important;
}



/* Horizontal menu container */
#Menu.k-menu.k-menu-horizontal {
    display: flex !important;
    align-items: center !important;
    gap: 20px !important;
    border: none !important;
    background: var(--menu-bg) !important; /* ← FIXED */
}

/* Base menu item */
#Menu .k-menu-link {
    color: #3f73ff !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    padding: 10px 22px !important;
    border-radius: 8px !important;
    transition: 0.15s ease-in-out;
    text-decoration: none !important;
}

    /* Hover + Active */
    #Menu .k-menu-link:hover,
    #Menu .k-menu-link.k-state-selected,
    #Menu .k-menu-link.k-state-active {
        background: #3f73ff !important;
        color: #ffffff !important;
    }

/* Dropdown Panel */
#Menu .k-menu-group {
    border-radius: 10px;
    padding: 6px 0;
    box-shadow: 0 10px 30px var(--shadow);
    background: var(--dropdown-bg) !important; /* ← FIXED */
}

    /* Dropdown items */
    #Menu .k-menu-group .k-menu-link {
        background: transparent !important;
        color: #374151 !important;
        font-size: 15px !important;
        font-weight: 500 !important;
        height: 38px !important;
        padding: 0 20px !important;
    }

        /* Dropdown hover */
        #Menu .k-menu-group .k-menu-link:hover {
            background: #eef2ff !important;
            color: #1e40af !important;
        }

/* Fix dropdown visibility */
#Menu .k-animation-container {
    overflow: visible !important;
    height: auto !important;
    width: auto !important;
}

/* Remove all separators */
#Menu .k-separator,
#Menu li.k-separator,
#Menu.k-menu.k-menu-horizontal > li::after,
#Menu.k-menu.k-menu-horizontal > li::before {
    display: none !important;
}
/* ------------------------------------- */
/*   NEW CUSTOM TOP MENU (Bootstrap)     */
/* ------------------------------------- */

/* ==========================
   PREMIUM COMPACT TOP MENU
   ========================== */

#topMenu {
    display: flex;
    align-items: center;
    gap: 18px; /* tighter spacing */
}

    /* Main links */
    #topMenu .menu-link {
        color: var(--accent-color) !important; /* elegant blue */
        font-size: 15px !important; /* compact premium */
        font-weight: 500 !important;
        padding: 6px 12px !important; /* no bulky tabs */
        border-radius: 6px !important;
        text-decoration: none !important;
        transition: 0.15s ease;
    }

        /* Hover + Active */
        #topMenu .menu-link:hover,
        #topMenu .menu-link.active {
            background: #4a63ff !important;
            color: #ffffff !important;
            font-weight: 600 !important;
        }

    /* Dropdown */
    #topMenu .dropdown-menu {
        padding: 8px 0 !important;
        border-radius: 8px !important;
        box-shadow: 0 4px 20px rgba(0,0,0,0.12) !important;
    }

    /* Dropdown items */
    #topMenu .dropdown-item {
        font-size: 14px !important;
        padding: 6px 16px !important;
        color: var(--text-primary) !important;
    }

        #topMenu .dropdown-item:hover {
            background: #eef2ff !important;
            color: #1e40af !important;
        }

    /* Smaller arrow for dropdown toggle */
    #topMenu .dropdown-toggle::after {
        margin-left: 6px;
        font-size: 10px;
    }

.custom-navbar {
    display: flex;
    align-items: center;
    justify-content: space-between; /* Distribute 3 sections */
    padding: 0 24px;
}

/* Left, Center, Right containers */
.nav-left {
    flex: 0 0 auto;
}

.nav-center {
    flex: 1; /* Takes remaining space */
    display: flex;
    justify-content: center; /* Centers the menu */
}

.nav-right {
    flex: 0 0 auto;
}

.custom-navbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 12px !important; /* reduce side padding */
}
#tenantContainer {
    margin-left: auto !important;
}
/* Active menu highlight */
.menu-link.k-state-selected {
    font-weight: 700 !important;
    color: #3f73ff !important;
    border-bottom: 3px solid #3f73ff !important;
    padding-bottom: 6px !important;
}

.tc-footer {
    width: 100%;
    //padding: 14px 0;
    background: var(--footer-bg) !important;
    border-top: 1px solid var(--border-color) !important;
    padding: 10px 25px;
    display: flex;
    justify-content: flex-start;
    padding-left: 25px;
}

.footer-content {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--text-secondary) !important;
    font-size: 12px
}

.footer-logo {
    height: 22px;
    width: auto;
    opacity: 0.85;
}

.footer-text {
    font-weight: 500;
    color: #666;
}
html, body {
    height: 100%;
    margin: 0;
}

body {
    display: flex;
    flex-direction: column;
}

main {
    flex: 1 0 auto; /* takes available space */
}

.tc-footer {
    flex-shrink: 0; /* prevents floating */
}
.tc-footer {
    background: #f8f8f8;
    border-top: 1px solid #e0e0e0;
    padding: 10px 25px;
}

.footer-content {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #555;
    font-size: 12px; /* smaller text */
}

.footer-logo {
    height: 18px; /* smaller logo */
    opacity: 0.9;
}
/* FIX NAVBAR ON TOP */
/*.custom-navbar {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;*/ /* above everything */
    /*background: #f8f8f8 !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}*/

/* Push page content down so it does not hide under navbar */
body,
main {
    padding-top: 40px !important; /* matches navbar height */
}


#dashboardNotification .k-notification {
    max-width: 360px; /* keep it from getting too wide on big screens */
    font-size: 13px;
    padding: 10px 14px;
}


/*.custom-navbar {
    height: 72px !important;*/ /* NEW: fixed height */
    /*min-height: 72px !important;*/ /* NEW: match min-height */
    /*padding: 0 32px !important;*/ /* a bit more horizontal padding */
    /*background-color: #f8f8f8 !important;
    border-bottom: 1px solid #ddd;
    display: flex;
    align-items: center;*/ /* keep items vertically centered */
/*}*/

.custom-navbar {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 72px !important;
    min-height: 72px !important;
    padding: 0 32px !important;
    z-index: 9999;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    /* THEME VARIABLES */
    background-color: var(--menu-bg) !important;
    border-bottom: 1px solid var(--border-color) !important;
    box-shadow: 0 2px 8px var(--shadow);
}

#Menu.k-menu.k-menu-horizontal {
    display: flex !important;
    align-items: center !important;
    gap: 20px !important;
    border: none !important;
    background: #f8f8f8 !important;
}

#Menu .k-menu-link:hover,
#Menu .k-state-selected {
    background-color: #3f73ff !important;
    color: #fff !important;
    border-radius: 6px;
    font-weight: 600;
}

#tenantContainer {
    position: absolute;
    top: 10px;
    right: 25px;
    display: flex;
    align-items: center;
    gap: 10px;
}

#ddltenant {
    padding: 5px;
    min-width: 220px;
    border-radius: 6px;
    border: 1px solid #ccc;
}

#tenantContainer .dropdown-toggle {
    color: #444 !important;
    font-size: 18px;
    text-decoration: none !important;
}

    #tenantContainer .dropdown-toggle:hover {
        color: #0d6efd !important;
    }

    #tenantContainer .dropdown-toggle i {
        color: #3f73ff !important;
        transition: color 0.2s ease;
    }

    #tenantContainer .dropdown-toggle:hover i {
        color: #1e50d5 !important;
    }

#tenantContainer .dropdown > a.text-secondary i.fas.fa-cog {
    color: #3f73ff !important;
}

#tenantContainer .dropdown > a.text-secondary:hover i.fas.fa-cog {
    color: #1e50d5 !important;
}
/* Make Kendo Menu dropdown actually visible */
#Menu .k-animation-container {
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
}

/* Optional: nice enterprise-style dropdown look */
#Menu .k-menu-group {
    border-radius: 10px;
    padding: 6px 0;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.18);
    background: var(--bg-card);
}

    /* Submenu items */
    #Menu .k-menu-group .k-menu-item .k-menu-link {
        height: 36px;
        padding: 0 18px;
        font-size: 14px;
        border-radius: 0;
    }

    /* Hover in submenu */
    #Menu .k-menu-group .k-menu-link:hover {
        background: var(--hover-bg) !important;
        color: var(--accent-color) !important;
    }

/* 1. Light Blue Header Background for ALL Grids */
.k-grid .k-grid-header,
.k-grid .k-grid-header .k-header {
    background-color: var(--grid-header-bg) !important;
    border-color: var(--grid-header-border) !important;
    color: var(--text-primary) !important;
}


/* ====== KENDO MULTISELECT - THEME AWARE ====== */

/* Main MultiSelect Container */
.k-multiselect,
.k-multiselect-wrap,
.k-multiselect .k-multiselect-wrap {
    background-color: var(--input-bg) !important;
    border-color: var(--input-border) !important;
    color: var(--text-primary) !important;
}

    /* The floating wrapper */
    .k-multiselect-wrap.k-floatwrap {
        background-color: var(--input-bg) !important;
        border-color: var(--input-border) !important;
    }

    /* Input inside MultiSelect */
    .k-multiselect .k-input,
    .k-multiselect input.k-input {
        background-color: var(--input-bg) !important;
        color: var(--text-primary) !important;
    }

    /* Selected Chips/Tags */
    .k-multiselect .k-chip,
    .k-multiselect .k-button,
    .k-multiselect-wrap .k-button {
        background-color: var(--hover-bg) !important;
        color: var(--text-primary) !important;
        border-color: var(--border-color) !important;
    }

        /* Chip close (X) icon */
        .k-multiselect .k-chip .k-icon,
        .k-multiselect .k-chip .k-i-close,
        .k-multiselect .k-chip .k-i-x {
            color: var(--text-secondary) !important;
        }

            .k-multiselect .k-chip .k-icon:hover {
                color: var(--accent-color) !important;
            }

    /* Dropdown arrow/select button */
    .k-multiselect .k-select,
    .k-multiselect-wrap .k-select {
        background-color: var(--input-bg) !important;
        color: var(--text-secondary) !important;
    }

    /* Focus state */
    .k-multiselect.k-focus,
    .k-multiselect:focus,
    .k-multiselect-wrap.k-state-focused {
        border-color: var(--accent-color) !important;
        box-shadow: 0 0 0 2px rgba(96, 165, 250, 0.2) !important;
    }

/* Dropdown Popup List */
.k-list-container,
.k-popup.k-list-container {
    background-color: var(--dropdown-bg) !important;
    border-color: var(--border-color) !important;
}

/* Dropdown List Items */
.k-list .k-item,
.k-list-optionlabel {
    background-color: var(--dropdown-bg) !important;
    color: var(--text-primary) !important;
}

    /* Hover state for list items */
    .k-list .k-item:hover,
    .k-list .k-item.k-state-hover {
        background-color: var(--hover-bg) !important;
        color: var(--text-primary) !important;
    }

    /* Selected item in dropdown */
    .k-list .k-item.k-state-selected,
    .k-list .k-item.k-selected,
    .k-list .k-selected {
        background-color: var(--accent-color) !important;
        color: #ffffff !important;
    }

/* Checkbox inside MultiSelect (if using checkboxes) */
.k-multiselect .k-checkbox,
.k-list .k-checkbox {
    background-color: var(--input-bg) !important;
    border-color: var(--input-border) !important;
}

/* No data message */
.k-nodata,
.k-no-data {
    color: var(--text-muted) !important;
}

/* Clear button */
.k-multiselect .k-clear-value,
.k-multiselect .k-i-close {
    color: var(--text-secondary) !important;
}

    .k-multiselect .k-clear-value:hover {
        color: var(--accent-color) !important;
    }


/* =============================================
   KENDO WINDOW / DIALOG - DARK THEME
============================================= */

/* Main Window Container */
[data-theme="dark"] .k-window {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
}

/* Window Title Bar */
[data-theme="dark"] .k-window-titlebar {
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border-color) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .k-window-title {
    color: var(--text-primary) !important;
}

/* Window Actions (minimize, maximize, close buttons) */
[data-theme="dark"] .k-window-actions {
    background: transparent !important;
}

    [data-theme="dark"] .k-window-actions .k-button,
    [data-theme="dark"] .k-window-actions .k-window-action {
        background: transparent !important;
        color: var(--text-secondary) !important;
        border: none !important;
    }

        [data-theme="dark"] .k-window-actions .k-button:hover,
        [data-theme="dark"] .k-window-actions .k-window-action:hover {
            background: var(--hover-bg) !important;
            color: var(--text-primary) !important;
        }

            /* Close button hover - red */
            [data-theme="dark"] .k-window-actions .k-i-close:hover,
            [data-theme="dark"] .k-window-actions .k-button:hover .k-i-close {
                color: #ef4444 !important;
            }

/* Window Content */
[data-theme="dark"] .k-window-content {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}

/* Specific: Full Chart View Window */
[data-theme="dark"] #chartFullViewWindow,
[data-theme="dark"] [id*="FullViewWindow"] {
    background: var(--bg-card) !important;
}

/* Chart inside the window */
[data-theme="dark"] .k-window-content .k-chart {
    background: var(--bg-card) !important;
}

/* ====== KENDO DIALOG ====== */

[data-theme="dark"] .k-dialog {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
}

[data-theme="dark"] .k-dialog-titlebar {
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border-color) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .k-dialog-title {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .k-dialog-content {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .k-dialog-buttongroup,
[data-theme="dark"] .k-dialog-actions {
    background: var(--bg-secondary) !important;
    border-top: 1px solid var(--border-color) !important;
}

/* ====== KENDO POPUP / LIST CONTAINER ====== */

[data-theme="dark"] .k-popup {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4) !important;
}

[data-theme="dark"] .k-list-container {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] .k-list {
    background: var(--bg-card) !important;
}

    [data-theme="dark"] .k-list .k-item {
        background: var(--bg-card) !important;
        color: var(--text-primary) !important;
    }

        [data-theme="dark"] .k-list .k-item:hover,
        [data-theme="dark"] .k-list .k-item.k-state-hover {
            background: var(--hover-bg) !important;
        }

        [data-theme="dark"] .k-list .k-item.k-state-selected,
        [data-theme="dark"] .k-list .k-item.k-selected {
            background: var(--accent-color) !important;
            color: #ffffff !important;
        }

/* ====== OVERLAY / BACKDROP ====== */

[data-theme="dark"] .k-overlay {
    background: rgba(0, 0, 0, 0.6) !important;
}

/* ====== WINDOW RESIZE HANDLES ====== */

[data-theme="dark"] .k-resize-handle {
    background: transparent !important;
}

/* ====== ANIMATION CONTAINER ====== */

[data-theme="dark"] .k-animation-container {
    background: transparent !important;
}

    [data-theme="dark"] .k-animation-container .k-popup {
        background: var(--bg-card) !important;
        border-color: var(--border-color) !important;
    }

/* ====== DROPDOWN LIST SPECIFIC ====== */

[data-theme="dark"] .k-dropdown .k-dropdown-wrap,
[data-theme="dark"] .k-dropdownlist .k-dropdown-wrap {
    background: var(--input-bg) !important;
    border-color: var(--input-border) !important;
}

[data-theme="dark"] .k-dropdown .k-input,
[data-theme="dark"] .k-dropdownlist .k-input {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .k-dropdown .k-select,
[data-theme="dark"] .k-dropdownlist .k-select {
    background: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
}

[data-theme="dark"] .k-dropdown .k-icon,
[data-theme="dark"] .k-dropdownlist .k-icon {
    color: var(--text-secondary) !important;
}

/* ====== COMBOBOX ====== */

[data-theme="dark"] .k-combobox .k-dropdown-wrap {
    background: var(--input-bg) !important;
    border-color: var(--input-border) !important;
}

[data-theme="dark"] .k-combobox .k-input {
    background: var(--input-bg) !important;
    color: var(--text-primary) !important;
}

/* ====== MULTISELECT ====== */

[data-theme="dark"] .k-multiselect-wrap {
    background: var(--input-bg) !important;
    border-color: var(--input-border) !important;
}

[data-theme="dark"] .k-multiselect .k-button {
    background: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

/* ====== TOOLTIP ====== */

[data-theme="dark"] .k-tooltip {
    background: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4) !important;
}

    [data-theme="dark"] .k-tooltip .k-callout {
        border-color: var(--bg-secondary) transparent transparent transparent !important;
    }

/* ====== CHART TOOLTIP ====== */

[data-theme="dark"] .k-chart-tooltip {
    background: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}

[data-theme="dark"] .k-chart-tooltip-wrapper {
    background: transparent !important;
}

[data-theme="dark"] .k-window {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
}

/* Window Title Bar - IMPROVED */
[data-theme="dark"] .k-window-titlebar {
    background: #1e3a5f !important; /* Darker blue for better contrast */
    border-bottom: 1px solid var(--border-color) !important;
    padding: 12px 16px !important;
}

[data-theme="dark"] .k-window-title {
    color: #ffffff !important; /* Pure white for readability */
    font-weight: 600 !important;
    font-size: 16px !important;
}

/* Window Actions (minimize, maximize, close buttons) */
[data-theme="dark"] .k-window-actions {
    background: transparent !important;
}

    [data-theme="dark"] .k-window-actions .k-button,
    [data-theme="dark"] .k-window-actions .k-window-action {
        background: transparent !important;
        color: #ffffff !important;
        border: none !important;
        opacity: 0.8;
    }

        [data-theme="dark"] .k-window-actions .k-button:hover,
        [data-theme="dark"] .k-window-actions .k-window-action:hover {
            background: rgba(255, 255, 255, 0.1) !important;
            color: #ffffff !important;
            opacity: 1;
        }

        /* Close button hover - red tint */
        [data-theme="dark"] .k-window-actions .k-button:last-child:hover,
        [data-theme="dark"] .k-window-action[aria-label="Close"]:hover {
            background: rgba(239, 68, 68, 0.3) !important;
            color: #fca5a5 !important;
        }

/* Window Content */
[data-theme="dark"] .k-window-content {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}


/* =============================================
   KENDO WINDOW - DARK THEME (FIXED)
============================================= */

/* Main Window Container */
[data-theme="dark"] .k-window {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
}

/* Window Title Bar - CLEAN DARK BACKGROUND */
[data-theme="dark"] .k-window-titlebar {
    background: #1f2937 !important; /* Clean dark gray - no pattern */
    background-image: none !important; /* Remove any background image/pattern */
    border-bottom: 1px solid var(--border-color) !important;
    padding: 12px 16px !important;
}

    [data-theme="dark"] .k-window-titlebar,
    [data-theme="dark"] .k-window-titlebar * {
        background-image: none !important; /* Force remove any inherited patterns */
    }

        [data-theme="dark"] .k-window-title,
        [data-theme="dark"] .k-window-titlebar .k-window-title {
            color: #ffffff !important;
            font-weight: 600 !important;
            font-size: 16px !important;
            background: transparent !important;
            background-image: none !important;
        }

/* Window Actions */
[data-theme="dark"] .k-window-actions {
    background: transparent !important;
    background-image: none !important;
}

    [data-theme="dark"] .k-window-actions .k-button,
    [data-theme="dark"] .k-window-actions .k-window-action {
        background: transparent !important;
        background-image: none !important;
        color: #ffffff !important;
        border: none !important;
    }

        [data-theme="dark"] .k-window-actions .k-button:hover,
        [data-theme="dark"] .k-window-actions .k-window-action:hover {
            background: rgba(255, 255, 255, 0.1) !important;
            color: #ffffff !important;
        }

/* Window Content */
[data-theme="dark"] .k-window-content {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}

/* =============================================
   CHART TEXT VISIBILITY - DARK THEME
============================================= */

/* ALL Chart Text - Force Light Colors */
[data-theme="dark"] .k-chart text,
[data-theme="dark"] .k-chart .k-chart-surface text,
[data-theme="dark"] .k-chart svg text {
    fill: #e5e7eb !important;
}

/* Axis Labels */
[data-theme="dark"] .k-chart .k-chart-axis-label,
[data-theme="dark"] .k-chart .k-axis-label {
    fill: #e5e7eb !important;
    color: #e5e7eb !important;
}

/* Axis Titles */
[data-theme="dark"] .k-chart .k-chart-axis-title,
[data-theme="dark"] .k-chart .k-axis-title {
    fill: #f3f4f6 !important;
    color: #f3f4f6 !important;
}

/* Value Labels on Charts */
[data-theme="dark"] .k-chart .k-chart-label,
[data-theme="dark"] .k-chart .k-label {
    fill: #f3f4f6 !important;
    color: #f3f4f6 !important;
}

/* Legend Text */
[data-theme="dark"] .k-chart .k-chart-legend text,
[data-theme="dark"] .k-chart .k-legend-item text {
    fill: #e5e7eb !important;
}

/* Gauge Specific - Scale Labels */
[data-theme="dark"] .k-chart .k-scale text,
[data-theme="dark"] .k-chart .k-scale-label,
[data-theme="dark"] .k-gauge text,
[data-theme="dark"] .k-arcgauge text,
[data-theme="dark"] .k-radialgauge text,
[data-theme="dark"] .k-lineargauge text {
    fill: #e5e7eb !important;
}

/* Gauge Center Label (the big number) */
[data-theme="dark"] .k-chart .k-chart-donut-center text,
[data-theme="dark"] .k-chart .k-center-label,
[data-theme="dark"] .k-gauge .k-gauge-label,
[data-theme="dark"] .k-arcgauge .k-arcgauge-label {
    fill: #f3f4f6 !important;
}

/* Donut/Pie Center Text */
[data-theme="dark"] .k-chart .k-donut-center text {
    fill: #f3f4f6 !important;
}

/* Series Labels */
[data-theme="dark"] .k-chart .k-series-label,
[data-theme="dark"] .k-chart .k-chart-series-label {
    fill: #f3f4f6 !important;
    color: #f3f4f6 !important;
}

/* Tooltip */
[data-theme="dark"] .k-chart-tooltip,
[data-theme="dark"] .k-chart-shared-tooltip {
    background: #1f2937 !important;
    border: 1px solid var(--border-color) !important;
    color: #f3f4f6 !important;
}

/* Grid Lines - subtle */
[data-theme="dark"] .k-chart .k-chart-axis-line,
[data-theme="dark"] .k-chart .k-axis-line {
    stroke: #374151 !important;
}

[data-theme="dark"] .k-chart .k-chart-major-gridlines line,
[data-theme="dark"] .k-chart .k-major-gridlines line {
    stroke: #374151 !important;
}

[data-theme="dark"] .k-chart .k-chart-minor-gridlines line,
[data-theme="dark"] .k-chart .k-minor-gridlines line {
    stroke: #1f2937 !important;
}

/* =============================================
   FULL CHART VIEW WINDOW SPECIFIC
============================================= */

[data-theme="dark"] #chartFullViewWindow .k-window-titlebar,
[data-theme="dark"] [id*="FullView"] .k-window-titlebar {
    background: #1f2937 !important;
    background-image: none !important;
}

[data-theme="dark"] #chartFullViewWindow .k-window-content,
[data-theme="dark"] [id*="FullView"] .k-window-content {
    background: var(--bg-card) !important;
}

/* =============================================
   HIDE KENDO GRID FOOTER
============================================= */

/* Hide the footer template row */
.k-grid .k-footer-template,
.k-grid tr.k-footer-template,
.k-grid .k-grid-footer,
.k-grid tfoot {
    display: none !important;
}

/* Also hide any footer wrap */
.k-grid .k-grid-footer-wrap {
    display: none !important;
}

/* Specific to chartResultsGrid */
#chartResultsGrid .k-footer-template,
#chartResultsGrid tr.k-footer-template,
#chartResultsGrid .k-grid-footer,
#chartResultsGrid tfoot {
    display: none !important;
}


/* =============================================
   SETTINGS DROPDOWN MENU - DARK THEME
============================================= */

/* Dropdown Menu Container */
[data-theme="dark"] .settings-dd .dropdown-menu,
[data-theme="dark"] .dropdown-menu-right {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4) !important;
}

    /* Dropdown Items */
    [data-theme="dark"] .settings-dd .dropdown-item,
    [data-theme="dark"] .dropdown-menu-right .dropdown-item {
        color: var(--text-primary) !important;
        background: transparent !important;
    }

        [data-theme="dark"] .settings-dd .dropdown-item:hover,
        [data-theme="dark"] .settings-dd .dropdown-item:focus,
        [data-theme="dark"] .dropdown-menu-right .dropdown-item:hover,
        [data-theme="dark"] .dropdown-menu-right .dropdown-item:focus {
            background: var(--hover-bg) !important;
            color: var(--text-primary) !important;
        }

        /* Icons in dropdown */
        [data-theme="dark"] .settings-dd .dropdown-item i,
        [data-theme="dark"] .dropdown-menu-right .dropdown-item i {
            color: var(--text-secondary) !important;
        }

        [data-theme="dark"] .settings-dd .dropdown-item:hover i,
        [data-theme="dark"] .dropdown-menu-right .dropdown-item:hover i {
            color: var(--accent-color) !important;
        }

    /* Dropdown Divider */
    [data-theme="dark"] .settings-dd .dropdown-divider,
    [data-theme="dark"] .dropdown-menu-right .dropdown-divider {
        border-top-color: var(--border-color) !important;
    }

    /* Logout item - keep red */
    [data-theme="dark"] .settings-dd .dropdown-item.text-danger,
    [data-theme="dark"] .dropdown-menu-right .dropdown-item.text-danger {
        color: #f87171 !important;
    }

        [data-theme="dark"] .settings-dd .dropdown-item.text-danger:hover,
        [data-theme="dark"] .dropdown-menu-right .dropdown-item.text-danger:hover {
            background: rgba(239, 68, 68, 0.1) !important;
            color: #ef4444 !important;
        }

        [data-theme="dark"] .settings-dd .dropdown-item.text-danger i,
        [data-theme="dark"] .dropdown-menu-right .dropdown-item.text-danger i {
            color: #f87171 !important;
        }

/* Settings Gear Icon */
[data-theme="dark"] .settings-dd .dropdown-toggle,
[data-theme="dark"] .settings-dd .dropdown-toggle i {
    color: var(--text-secondary) !important;
}

    [data-theme="dark"] .settings-dd .dropdown-toggle:hover,
    [data-theme="dark"] .settings-dd .dropdown-toggle:hover i {
        color: var(--text-primary) !important;
    }

/* Active/Selected state */
[data-theme="dark"] .settings-dd .dropdown-item.active,
[data-theme="dark"] .dropdown-menu-right .dropdown-item.active {
    background: var(--accent-color) !important;
    color: #ffffff !important;
}


/* =============================================
   KENDO CHART - SUBTLE GRID LINES (DARK THEME)
============================================= */

/* Major Grid Lines - Very subtle */
[data-theme="dark"] .k-chart .k-chart-grid line,
[data-theme="dark"] .k-chart line[stroke="#e0e0e0"],
[data-theme="dark"] .k-chart line[stroke="#ccc"],
[data-theme="dark"] .k-chart line[stroke="#cccccc"],
[data-theme="dark"] .k-chart path[stroke="#e0e0e0"] {
    stroke: rgba(255, 255, 255, 0.08) !important;
}

/* Axis Lines - Slightly more visible than grid */
[data-theme="dark"] .k-chart .k-chart-axis line,
[data-theme="dark"] .k-chart .k-axis-line,
[data-theme="dark"] .k-chart line[stroke="#000"],
[data-theme="dark"] .k-chart path[stroke="#000"],
[data-theme="dark"] .k-chart path[stroke="#333"] {
    stroke: rgba(255, 255, 255, 0.15) !important;
}

/* SVG paths that form grid/axis - target by fill */
[data-theme="dark"] .k-chart path[fill="none"][stroke],
[data-theme="dark"] .k-chart line[data-role="major"] {
    stroke: rgba(255, 255, 255, 0.08) !important;
}

/* Minor Grid Lines - Even more subtle */
[data-theme="dark"] .k-chart .k-chart-minor-grid line {
    stroke: rgba(255, 255, 255, 0.04) !important;
}

/* Target white/light strokes specifically */
[data-theme="dark"] .k-chart line[stroke="#fff"],
[data-theme="dark"] .k-chart line[stroke="#ffffff"],
[data-theme="dark"] .k-chart line[stroke="white"],
[data-theme="dark"] .k-chart path[stroke="#fff"],
[data-theme="dark"] .k-chart path[stroke="#ffffff"],
[data-theme="dark"] .k-chart path[stroke="white"] {
    stroke: rgba(255, 255, 255, 0.1) !important;
}


/* Hide the white background box behind chart labels */
.k-chart svg path[fill*="255, 255, 255"],
.k-chart svg path[fill*="rgba(255"] {
    fill: transparent !important;
}

/* Or make labels more visible with dark background */
.k-chart-surface path[stroke="#ccc"] {
    fill: rgba(0, 0, 0, 0.5) !important;
}

/* Export notification badge */
.export-link {
    position: relative;
}

.export-badge {
    position: absolute;
    top: -8px;
    right: -12px;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
    animation: pulse-badge 2s infinite;
}

@keyframes pulse-badge {
    0%, 100% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.1);
    }
}


/* =============================================
   EXPORT TOAST NOTIFICATION - Enterprise Style
   Supports Light & Dark Theme
============================================= */

.export-toast {
    position: fixed;
    bottom: -120px;
    left: 50%;
    transform: translateX(-50%);
    min-width: 450px;
    max-width: 600px;
    z-index: 2147483647;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2), 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: bottom 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    /* Light Theme (Default) */
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid #e2e8f0;
}

    .export-toast.show {
        bottom: 30px;
    }

.export-toast-content {
    display: flex;
    align-items: flex-start;
    padding: 16px 20px;
    gap: 14px;
}

.export-toast-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.export-spinner {
    width: 22px;
    height: 22px;
    border: 3px solid rgba(255, 255, 255, 0.3);
    border-top: 3px solid #ffffff;
    border-radius: 50%;
    animation: exportSpin 1s linear infinite;
}

@keyframes exportSpin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.export-toast-text {
    flex: 1;
    min-width: 0;
}

.export-toast-title {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 4px;
    /* Light Theme */
    color: #1e293b;
}

.export-toast-message {
    font-size: 13px;
    line-height: 1.5;
    /* Light Theme */
    color: #64748b;
}

    .export-toast-message strong {
        color: #3b82f6;
        font-weight: 600;
    }

.export-toast-close {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    /* Light Theme */
    background: #f1f5f9;
    color: #64748b;
}

    .export-toast-close:hover {
        background: #e2e8f0;
        color: #334155;
    }

    .export-toast-close i {
        font-size: 12px;
    }

/* Progress Bar at bottom */
.export-toast-progress {
    height: 4px;
    background: linear-gradient(90deg, #3b82f6, #8b5cf6, #3b82f6);
    background-size: 200% 100%;
    animation: exportProgress 2s linear infinite;
}

@keyframes exportProgress {
    0% {
        background-position: 100% 0;
    }

    100% {
        background-position: -100% 0;
    }
}

/* =============================================
   DARK THEME SUPPORT
============================================= */

[data-theme="dark"] .export-toast {
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
    border: 1px solid #334155;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), 0 2px 8px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .export-toast-icon {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}

[data-theme="dark"] .export-toast-title {
    color: #f1f5f9;
}

[data-theme="dark"] .export-toast-message {
    color: #94a3b8;
}

    [data-theme="dark"] .export-toast-message strong {
        color: #60a5fa;
    }

[data-theme="dark"] .export-toast-close {
    background: #334155;
    color: #94a3b8;
}

    [data-theme="dark"] .export-toast-close:hover {
        background: #475569;
        color: #e2e8f0;
    }

[data-theme="dark"] .export-toast-progress {
    background: linear-gradient(90deg, #3b82f6, #8b5cf6, #3b82f6);
    background-size: 200% 100%;
}

/* =============================================
   RESPONSIVE - Mobile Support
============================================= */

@media (max-width: 576px) {
    .export-toast {
        min-width: calc(100% - 20px);
        max-width: calc(100% - 20px);
        left: 10px;
        right: 10px;
        transform: none;
    }

        .export-toast.show {
            bottom: 10px;
        }

    .export-toast-content {
        padding: 14px 16px;
    }

    .export-toast-icon {
        width: 38px;
        height: 38px;
    }

    .export-spinner {
        width: 18px;
        height: 18px;
    }

    .export-toast-title {
        font-size: 14px;
    }

    .export-toast-message {
        font-size: 12px;
    }
}


/* =============================================
   EXPORT TOAST NOTIFICATION - CENTERED
============================================= */

.export-toast {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%) translateY(150%); /* Start hidden below */
    min-width: 420px;
    max-width: 500px;
    z-index: 2147483647;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
    transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    background: #ffffff;
    border: 1px solid #e5e7eb;
}

    .export-toast.show {
        transform: translateX(-50%) translateY(0); /* Slide up to center */
    }

    .export-toast.export-ready {
        border-left: 4px solid #10b981;
    }

/* Dark theme */
[data-theme="dark"] .export-toast {
    background: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
    border: 1px solid #334155;
}

    [data-theme="dark"] .export-toast.export-ready {
        border-left: 4px solid #10b981;
    }

/* Kendo Grid Grouping Row - Text Visibility Fix */
.k-grid .k-grouping-row,
.k-grid .k-grouping-row td {
    background-color: var(--bg-secondary) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

    .k-grid .k-grouping-row .k-reset,
    .k-grid .k-grouping-row p.k-reset,
    .k-grid .k-grouping-row p {
        color: var(--text-primary) !important;
    }

        .k-grid .k-grouping-row .k-reset a,
        .k-grid .k-grouping-row p.k-reset a {
            color: var(--text-primary) !important;
        }

    .k-grid .k-grouping-row .k-icon,
    .k-grid .k-grouping-row .k-i-collapse,
    .k-grid .k-grouping-row .k-i-expand,
    .k-grid .k-grouping-row .k-svg-icon {
        color: var(--accent-color) !important;
    }

.k-grid .group-count-badge {
    color: var(--text-muted) !important;
}

.k-grid .k-group-cell,
.k-grid td.k-group-cell {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
}

/* Kendo Grid Grouping Row - Text Visibility Fix */
.k-grid .k-grouping-row td {
    background-color: var(--bg-secondary) !important;
    border-color: var(--border-color) !important;
}

    .k-grid .k-grouping-row .k-reset,
    .k-grid .k-grouping-row p.k-reset,
    .k-grid .k-grouping-row p,
    .k-grid .k-grouping-row td p {
        color: var(--text-primary) !important;
    }

[data-theme="dark"] .k-grid .k-grouping-row .k-reset,
[data-theme="dark"] .k-grid .k-grouping-row p.k-reset,
[data-theme="dark"] .k-grid .k-grouping-row p,
[data-theme="dark"] .k-grid .k-grouping-row td p {
    color: #f3f4f6 !important;
}

    [data-theme="dark"] .k-grid .k-grouping-row .k-reset a,
    [data-theme="dark"] .k-grid .k-grouping-row td p a {
        color: #f3f4f6 !important;
    }

[data-theme="dark"] .k-grid .group-count-badge {
    color: #9ca3af !important;
}


/* Toast/Notification styling for dark theme - Clean, no border, no background */
[data-theme="dark"] .k-notification,
[data-theme="dark"] .k-notification-content,
[data-theme="dark"] .toast-message,
[data-theme="dark"] .k-notification-wrap {
    color: #ffffff !important;
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Success toast */
[data-theme="dark"] .k-notification-success,
[data-theme="dark"] .k-notification-success .k-notification-content {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    color: #ffffff !important;
}

    /* Keep icon green */
    [data-theme="dark"] .k-notification-success .k-icon,
    [data-theme="dark"] .k-notification-success svg {
        color: #10b981 !important;
    }

/* Warning toast */
[data-theme="dark"] .k-notification-warning,
[data-theme="dark"] .k-notification-warning .k-notification-content {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    color: #ffffff !important;
}

/* Error toast */
[data-theme="dark"] .k-notification-error,
[data-theme="dark"] .k-notification-error .k-notification-content {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    color: #ffffff !important;
}

/* Info toast */
[data-theme="dark"] .k-notification-info,
[data-theme="dark"] .k-notification-info .k-notification-content {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    color: #ffffff !important;
}





/* =============================================
   ENTERPRISE TOAST NOTIFICATIONS
============================================= */

/* 1. Strip Kendo's default wrapper */
div.k-widget.k-notification,
div.k-notification-success,
div.k-notification-warning,
div.k-notification-error,
div.k-notification-info {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin-bottom: 14px !important;
}

/* 2. Enterprise White-Card Base */
.toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 99999;
    display: flex;
    flex-direction: column;
}

.toast {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px 20px;
    border-radius: 8px;
    background-color: #ffffff !important;
    border: 1px solid #e5e7eb !important;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.05) !important;
    font-size: 14px;
    font-weight: 500;
    color: #1f2937 !important;
    min-width: 320px;
    max-width: 420px;
    animation: slideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

    .toast i {
        font-size: 20px;
        margin-top: 1px;
    }

    .toast div {
        flex: 1;
        line-height: 1.5;
    }

/* 3. Subtle Status Accents (Left border & Icon) */
.toast-success {
    border-left: 4px solid #10b981 !important;
}

    .toast-success i {
        color: #10b981 !important;
    }

.toast-error {
    border-left: 4px solid #ef4444 !important;
}

    .toast-error i {
        color: #ef4444 !important;
    }

.toast-warning {
    border-left: 4px solid #f59e0b !important;
}

    .toast-warning i {
        color: #f59e0b !important;
    }

.toast-info {
    border-left: 4px solid #3b82f6 !important;
}
    /* The Light Blue */
    .toast-info i {
        color: #3b82f6 !important;
    }

/* 4. Slide Animation */
@keyframes slideIn {
    from {
        transform: translateX(100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* 5. Dark Theme Overrides */
[data-theme="dark"] .toast {
    background-color: #1f2937 !important;
    border-color: #374151 !important;
    color: #f3f4f6 !important;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.5) !important;
}

/* =============================================
   TOAST FIXES: Text Wrapping & Double Icons
============================================= */

/* 1. Hide Kendo's default auto-injected icon */
.k-notification-wrap > span.k-icon,
.k-notification-wrap > i.k-icon {
    display: none !important;
}

/* 2. Override Kendo's default 'no-wrap' to allow multi-line text */
.k-notification-wrap {
    white-space: normal !important;
    padding: 0 !important;
    width: 100% !important;
}

/* 3. Ensure our custom text container handles long strings gracefully */
.toast div {
    flex: 1;
    line-height: 1.5;
    white-space: normal !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    padding-right: 8px; /* Adds a little breathing room on the right */
}

/* 1. Hide ANY Kendo-injected icons (Only allow our .toast template to show) */
.k-notification-wrap > *:not(.toast) {
    display: none !important;
}

/* =============================================
   TOAST FIX: REMOVE KENDO DOUBLE ICON
============================================= */
.k-notification-wrap > span.k-icon,
.k-notification-wrap > span.k-svg-icon,
.k-notification .k-i-success,
.k-notification .k-i-warning,
.k-notification .k-i-error,
.k-notification .k-i-info {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
}

/* =============================================
   TOAST FIX: COMPLETELY HIDE KENDO ICONS
============================================= */

/* 1. Hide physical DOM icons Kendo might inject */
div.k-widget.k-notification .k-notification-wrap > span.k-icon,
div.k-widget.k-notification .k-notification-wrap > span[class^="k-i-"] {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
}

/* 2. Kill the Bootstrap theme's CSS pseudo-element icons (The real culprit!) */
div.k-widget.k-notification::before,
div.k-notification-wrap::before,
div.k-notification-warning::before,
div.k-notification-success::before,
div.k-notification-error::before,
div.k-notification-info::before {
    display: none !important;
    content: none !important;
}

/* 3. Ensure multi-line text wraps perfectly */
div.k-widget.k-notification .k-notification-wrap {
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
    white-space: normal !important;
}

/* 4. Text container alignment */
.toast div {
    flex: 1;
    line-height: 1.5;
    white-space: normal !important;
    word-wrap: break-word !important;
    padding-right: 8px;
}

/* =============================================
   TOAST FIX: COMPLETELY HIDE KENDO ICONS
============================================= */

/* 1. Hide any Kendo-injected elements inside the wrapper EXCEPT our custom .toast */
.k-notification-wrap > *:not(.toast) {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
}

/* 2. Remove padding/margins from the Kendo wrapper so it tightly hugs our .toast */
.k-notification-wrap {
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
    background: transparent !important;
    border: none !important;
}

    /* 3. Nuke Bootstrap theme pseudo-elements (the likely culprit) */
    .k-notification::before,
    .k-notification::after,
    .k-notification-wrap::before,
    .k-notification-wrap::after,
    .k-notification-warning::before,
    .k-notification-warning::after {
        display: none !important;
        content: none !important;
        background-image: none !important;
    }

/* 4. Text container styling (inside our custom template) */
.toast div {
    flex: 1;
    line-height: 1.5;
    white-space: normal !important;
    word-wrap: break-word !important;
    padding-right: 8px;
}

/* ── Fix Pager Navigation Arrows ── */
[data-theme="dark"] .k-pager-wrap .k-pager-nav,
[data-theme="dark"] #chartResultsGrid .k-pager-wrap .k-pager-nav {
    background-color: transparent !important;
    border-color: var(--border-color, #4b5563) !important;
    color: var(--text-primary, #e5e7eb) !important;
}

    [data-theme="dark"] .k-pager-wrap .k-pager-nav:hover,
    [data-theme="dark"] #chartResultsGrid .k-pager-wrap .k-pager-nav:hover {
        background-color: rgba(255, 255, 255, 0.1) !important;
    }

    /* Disabled state for arrows (e.g., prev arrow on page 1) */
    [data-theme="dark"] .k-pager-wrap .k-pager-nav.k-state-disabled {
        opacity: 0.5 !important;
        background-color: transparent !important;
    }

/* ── Fix Page Size Dropdown ── */
[data-theme="dark"] .k-pager-sizes .k-dropdown-wrap,
[data-theme="dark"] .k-pager-sizes select {
    background-color: var(--input-bg, #1f2937) !important;
    border-color: var(--border-color, #4b5563) !important;
    color: var(--text-primary, #e5e7eb) !important;
}

    [data-theme="dark"] .k-pager-sizes .k-dropdown-wrap .k-input {
        color: var(--text-primary, #e5e7eb) !important;
    }



/* =============================================
   NAVBAR ALIGNMENT FIX
============================================= */

/* 1. Force the flex layout and remove the navbar's built-in right padding */
.custom-navbar {
    display: flex !important;
    width: 100% !important;
    /* Change 12px to 0px if you want it to touch the absolute edge of the monitor */
    padding-right: 12px !important;
}

/* 2. Push the container to the far right */
.nav-right {
    margin-left: auto !important;
    margin-right: 0 !important;
    display: flex !important;
    justify-content: flex-end !important;
}

/* 3. Reduce the internal spacing on the right side of the clinic box */
.clinic-box {
    margin-right: 0 !important;
    /* Overrides your current 10px right-padding to push the gear icon to the edge */
    padding-right: 0 !important;
}


/* =============================================
   BTN-ACTION-PRIMARY — Global Primary Button Style
   Applies to ALL .btn-action-primary across the app
   ============================================= */

.btn-action-primary {
    background: linear-gradient(135deg, #0078d7 0%, #005a9e 100%) !important;
    border: 1px solid rgba(0, 120, 215, 0.2) !important;
    color: #ffffff !important;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.3px;
    padding: 8px 20px;
    border-radius: 8px;
    box-shadow: 0 4px 14px rgba(0, 120, 215, 0.3), 0 0 0 1px rgba(0, 120, 215, 0.08);
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    line-height: 1.4;
    text-transform: uppercase;
    text-decoration: none;
}

    .btn-action-primary:hover {
        background: linear-gradient(135deg, #0062cc 0%, #004a99 100%) !important;
        box-shadow: 0 6px 20px rgba(0, 120, 215, 0.45);
        transform: translateY(-1px);
        color: #ffffff !important;
        text-decoration: none;
    }

    .btn-action-primary:active {
        transform: translateY(0);
        box-shadow: 0 2px 8px rgba(0, 120, 215, 0.3);
    }

    .btn-action-primary:focus,
    .btn-action-primary:focus-visible {
        outline: 2px solid rgba(0, 120, 215, 0.5);
        outline-offset: 2px;
    }

    .btn-action-primary:disabled,
    .btn-action-primary.disabled {
        background: linear-gradient(135deg, #9ca3af 0%, #6b7280 100%) !important;
        box-shadow: none;
        cursor: not-allowed;
        opacity: 0.65;
        transform: none;
    }

/* --- DARK THEME --- */
[data-theme="dark"] .btn-action-primary {
    background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%) !important;
    border: 1px solid rgba(96, 165, 250, 0.25) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.35), 0 0 0 1px rgba(96, 165, 250, 0.1);
}

    [data-theme="dark"] .btn-action-primary:hover {
        background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
        box-shadow: 0 6px 24px rgba(59, 130, 246, 0.5), 0 0 0 1px rgba(96, 165, 250, 0.2) !important;
        transform: translateY(-1px);
    }