:root {
    --kendo-font-size: 0.875rem !important;

    /* ClearSenseIQ Dark Theme Palette */
    --csiq-bg: #0f1724;
    --csiq-bg-card: #1a2332;
    --csiq-bg-card-alt: #1e2738;
    --csiq-bg-header: #263238;
    --csiq-bg-sidebar: #0b1220;
    --csiq-bg-input: #1a2332;
    --csiq-bg-table-head: #151e2d;
    --csiq-text: #e6edf7;
    --csiq-text-muted: #8899ab;
    --csiq-text-bright: #ffffff;
    --csiq-text-label: #4da3ff;
    --csiq-text-dim: #5a6b7d;
    --csiq-accent-orange: #FF9500;
    --csiq-accent-blue: #4a9eff;
    --csiq-accent-teal: #10b981;
    --csiq-accent-pink: #e74c8b;
    --csiq-accent-indigo: #a78bfa;
    --csiq-border: rgba(255, 255, 255, 0.08);
    --csiq-border-light: rgba(255, 255, 255, 0.12);
    --csiq-border-input: rgba(255, 255, 255, 0.15);
    --csiq-hover: rgba(74, 158, 255, 0.08);
}

.card {
    margin-bottom: 10px;
}

.AccountPage {
    width: 50%;
    position: absolute;
    top: 0px;
    left: 0px;
    height: 100%;
}

.register {
    margin: 0px;
    display: block;
}

    .register .register-content {
        margin: 0;
        max-width: 100%;
    }

.promotionalInfo {
    position: fixed;
    top: 0px;
    right: 0px;
    background-color: var(--csiq-bg-header) !important;
    max-width: 50%;
    height: 100%;
}

.register-promotion-container {
    background-color: cadetblue !important;
    height: 100%;
    min-height: 300px;
}

.k-pdf-viewer {
    width: 100% !important;
}

.promotionalInfo img {
    max-height: 100%;
    width: 100%;
}

.dataTables_scrollBody thead {
    visibility: collapse;
}

@media (max-width: 992px) {
    .AccountPage {
        width: 100%;
    }

    .promotionalInfo {
        display: none;
    }
}

.k-upload .k-actions {
    display: none !important;
}

/* Increase header height to accommodate larger ClearSenseIQ logo */
.app-header {
    min-height: 80px;
}

.app-header .brand,
.app-header .desktop-toggler,
.app-header .menu-toggler,
.app-header .menu-item .menu-link {
    height: 80px;
}

.app {
    padding-top: 80px;
}


/* ==========================================================================
   CLEARSENSEIQ GLOBAL DARK THEME
   Applied to all pages using _Layout.cshtml
   ========================================================================== */

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

.app {
    font-family: 'Inter', sans-serif !important;
}

/* --- Body & App Background --- */
#app-content {
    background-color: var(--csiq-bg) !important;
}

.app-content {
    background-color: var(--csiq-bg) !important;
}

/* --- Header --- */
.app-header {
    background: var(--csiq-bg-header) !important;
    box-shadow: 0 1px 0 var(--csiq-border) !important;
}

.app-header .menu-toggler .bar {
    background: var(--csiq-text-muted) !important;
}

.app-header .menu-text {
    color: var(--csiq-text-muted) !important;
}

.app-header #headerDistrictName h2 {
    color: var(--csiq-accent-orange) !important;
}

.app-header .dropdown-menu {
    background: #ffffff !important;
}

.app-header .dropdown-menu .dropdown-item {
    color: #333 !important;
}

.app-header .dropdown-menu .dropdown-item:hover {
    background: #f0f0f0 !important;
}

/* --- Sidebar --- */
.app-sidebar {
    background: var(--csiq-bg-sidebar) !important;
    border-right-color: var(--csiq-border) !important;
}

.app-sidebar .app-sidebar-content {
    background: var(--csiq-bg-sidebar) !important;
}

.app-sidebar .menu-header {
    color: var(--csiq-accent-orange) !important;
    font-weight: 700;
}

.app-sidebar .menu > .menu-item > .menu-link {
    color: var(--csiq-text-muted) !important;
}

.app-sidebar .menu > .menu-item > .menu-link:hover,
.app-sidebar .menu > .menu-item > .menu-link:focus {
    color: var(--csiq-text) !important;
    background: rgba(255, 255, 255, 0.04) !important;
}

.app-sidebar .menu > .menu-item.active > .menu-link,
.app-sidebar .menu > .menu-item > .menu-link.active {
    color: var(--csiq-accent-blue) !important;
}

.app-sidebar .menu > .menu-item .menu-submenu .menu-item > .menu-link {
    color: var(--csiq-text-muted) !important;
}

.app-sidebar .menu > .menu-item .menu-submenu .menu-item > .menu-link:hover {
    color: var(--csiq-text) !important;
}

.app-sidebar .menu > .menu-item .menu-submenu .menu-item.active > .menu-link {
    color: var(--csiq-accent-blue) !important;
}

.app-sidebar .menu .menu-divider {
    background: var(--csiq-border) !important;
}

.menu-text {
    color: var(--csiq-text-muted) !important;
}

/* --- Page Headers & Text --- */
.page-header {
    color: var(--csiq-text) !important;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--csiq-text);
}

p {
    color: var(--csiq-text-muted);
}

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

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

.font-weight-600.text-dark,
.font-weight-600 {
    color: var(--csiq-text-bright) !important;
}

/* --- Breadcrumbs --- */
.breadcrumb {
    background: transparent !important;
}

.breadcrumb-item a {
    color: var(--csiq-accent-orange) !important;
}

.breadcrumb-item.active {
    color: var(--csiq-text-muted) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--csiq-text-dim) !important;
}

/* --- Cards --- */
.card {
    background: var(--csiq-bg-card) !important;
    border: 1px solid var(--csiq-border) !important;
    border-radius: 16px !important;
    color: var(--csiq-text);
}

.card-header {
    background: rgba(255, 255, 255, 0.03) !important;
    border-bottom: 1px solid var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.card h5 {
    color: var(--csiq-text-bright) !important;
}

.card .fs-13px {
    color: var(--csiq-text-label) !important;
}

/* Gradient stat cards (Dashboard) keep their colors */
.card[class*="bg-gradient"] {
    border: none !important;
}

.card.text-white-transparent-7 {
    border: none !important;
}

/* --- Tables (Bootstrap) --- */
.table {
    color: var(--csiq-text) !important;
    --bs-table-bg: transparent !important;
    --bs-table-striped-bg: transparent !important;
    --bs-table-hover-bg: var(--csiq-hover) !important;
}

.table > :not(caption) > * > * {
    background-color: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
    box-shadow: none !important;
}

.table > thead > tr > th {
    background-color: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text-bright) !important;
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-bottom: 2px solid rgba(255, 149, 0, 0.3) !important;
}

.table > tbody > tr:nth-child(odd) > td,
.table > tbody > tr:nth-child(odd) > th {
    background-color: var(--csiq-bg-card-alt) !important;
}

.table > tbody > tr:nth-child(even) > td,
.table > tbody > tr:nth-child(even) > th {
    background-color: var(--csiq-bg-card) !important;
}

.table > tbody > tr:hover > td,
.table > tbody > tr:hover > th {
    background-color: #1e3a50 !important;
    color: #fff !important;
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: var(--csiq-bg-card-alt) !important;
    color: var(--csiq-text) !important;
}

/* --- DataTables --- */
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
    background: var(--csiq-bg-input) !important;
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text) !important;
}

.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label {
    color: var(--csiq-text-muted) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
    color: var(--csiq-text-muted) !important;
    background: transparent !important;
    border-color: var(--csiq-border) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.current {
    color: var(--csiq-text-bright) !important;
    background: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-accent-blue) !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
    color: var(--csiq-text-bright) !important;
    background: rgba(74, 158, 255, 0.15) !important;
    border-color: var(--csiq-accent-blue) !important;
}

.dataTables_scrollHead,
.dataTables_scrollBody {
    background: var(--csiq-bg-card) !important;
}

table.dataTable thead th {
    background-color: var(--csiq-bg-table-head) !important;
}

/* --- Forms --- */
.form-control,
.form-select {
    background-color: var(--csiq-bg-input) !important;
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text) !important;
}

.form-control:focus,
.form-select:focus {
    background-color: var(--csiq-bg-input) !important;
    border-color: var(--csiq-accent-blue) !important;
    color: var(--csiq-text) !important;
    box-shadow: 0 0 0 0.2rem rgba(74, 158, 255, 0.15) !important;
}

.form-control::placeholder {
    color: var(--csiq-text-dim) !important;
}

.form-label,
label {
    color: var(--csiq-text-label) !important;
}

.form-text {
    color: var(--csiq-text-dim) !important;
}

.form-check-label {
    color: var(--csiq-text) !important;
}

.input-group-text {
    background-color: var(--csiq-bg-table-head) !important;
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text-muted) !important;
}

textarea.form-control {
    background-color: var(--csiq-bg-input) !important;
    color: var(--csiq-text) !important;
}

/* --- Buttons --- */
.btn-default,
.btn-light {
    background-color: var(--csiq-bg-card-alt) !important;
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text) !important;
}

.btn-default:hover,
.btn-light:hover {
    background-color: rgba(255, 255, 255, 0.08) !important;
    color: var(--csiq-text-bright) !important;
}

.btn-primary {
    background-color: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-accent-blue) !important;
    color: #fff !important;
}

.btn-primary:hover {
    background-color: #3d8fe6 !important;
    border-color: #3d8fe6 !important;
}

.btn-outline-primary {
    color: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-accent-blue) !important;
}

.btn-outline-primary:hover {
    background-color: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-accent-blue) !important;
    color: #fff !important;
}

.btn-outline-primary:active,
.btn-outline-primary.active {
    background-color: #3d8fe6 !important;
    border-color: #3d8fe6 !important;
    color: #fff !important;
}

.btn-outline-secondary {
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text-muted) !important;
}

.btn-outline-secondary:hover {
    background-color: rgba(255, 255, 255, 0.08) !important;
    color: var(--csiq-text) !important;
}

/* --- Kendo UI Grid --- */
.k-grid {
    background: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.k-grid .k-grid-header {
    background: var(--csiq-bg-table-head) !important;
    border-color: var(--csiq-border) !important;
}

.k-grid .k-grid-header th.k-header,
.k-grid .k-grid-header .k-grid-header-wrap th {
    background: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text-bright) !important;
    border-color: var(--csiq-border) !important;
    font-weight: 600;
}

.k-grid .k-grid-content {
    background: var(--csiq-bg-card) !important;
}

.k-grid td {
    background: var(--csiq-bg-card) !important;
    color: var(--csiq-text) !important;
    border-color: var(--csiq-border) !important;
}

.k-grid tr.k-alt td,
.k-grid .k-master-row.k-alt td {
    background: var(--csiq-bg-card-alt) !important;
}

.k-grid tr:hover td,
.k-grid tr.k-hover td,
.k-grid .k-master-row:hover td {
    background: var(--csiq-hover) !important;
}

.k-grid tr.k-selected td,
.k-grid td.k-selected {
    background: rgba(74, 158, 255, 0.15) !important;
    color: var(--csiq-text-bright) !important;
}

.k-grid .k-grid-footer,
.k-grid .k-grid-footer td {
    background: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text) !important;
    border-color: var(--csiq-border) !important;
}

.k-grid .k-pager {
    background: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text-muted) !important;
    border-color: var(--csiq-border) !important;
}

.k-grid .k-pager .k-pager-numbers .k-link,
.k-grid .k-pager .k-pager-nav {
    color: var(--csiq-text-muted) !important;
}

.k-grid .k-pager .k-pager-numbers .k-link.k-selected,
.k-grid .k-pager .k-pager-numbers .k-link:hover {
    background: var(--csiq-accent-blue) !important;
    color: var(--csiq-text-bright) !important;
}

.k-grid .k-grouping-header {
    background: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text-muted) !important;
}

.k-grid .k-filter-row th {
    background: var(--csiq-bg-card) !important;
}

.k-grid .k-grid-norecords {
    background: var(--csiq-bg-card) !important;
    color: var(--csiq-text-muted) !important;
}

/* --- Kendo Dropdowns & Inputs --- */
.k-dropdownlist,
.k-combobox,
.k-datepicker,
.k-timepicker,
.k-datetimepicker,
.k-numerictextbox {
    background-color: var(--csiq-bg-input) !important;
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text) !important;
}

.k-dropdownlist .k-input-inner,
.k-combobox .k-input-inner,
.k-datepicker .k-input-inner,
.k-timepicker .k-input-inner {
    color: var(--csiq-text) !important;
}

.k-dropdownlist .k-input-button,
.k-combobox .k-input-button,
.k-datepicker .k-input-button,
.k-timepicker .k-input-button {
    color: var(--csiq-text-muted) !important;
}

/* Kendo popup/list stays light for readability */
.k-animation-container .k-list,
.k-animation-container .k-popup {
    background: #ffffff !important;
    color: #333 !important;
}

/* --- Kendo Upload --- */
.k-upload {
    background: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.k-upload .k-dropzone {
    background: var(--csiq-bg-card-alt) !important;
    color: var(--csiq-text-muted) !important;
    border-color: var(--csiq-border) !important;
}

.k-upload .k-upload-files {
    border-color: var(--csiq-border) !important;
}

.k-upload .k-file {
    background: var(--csiq-bg-card) !important;
    color: var(--csiq-text) !important;
}

/* --- Kendo PDF Viewer --- */
.k-pdf-viewer .k-toolbar {
    background: var(--csiq-bg-table-head) !important;
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.k-pdf-viewer .k-toolbar .k-button {
    color: var(--csiq-text-muted) !important;
}

.k-pdf-viewer .k-toolbar .k-button:hover {
    color: var(--csiq-text-bright) !important;
    background: rgba(255, 255, 255, 0.08) !important;
}

/* --- Alerts --- */
.alert-danger {
    background-color: rgba(220, 53, 69, 0.15) !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    color: #ff6b6b !important;
}

.alert-success {
    background-color: rgba(16, 185, 129, 0.15) !important;
    border-color: rgba(16, 185, 129, 0.3) !important;
    color: var(--csiq-accent-teal) !important;
}

.alert-warning {
    background-color: rgba(255, 149, 0, 0.15) !important;
    border-color: rgba(255, 149, 0, 0.3) !important;
    color: var(--csiq-accent-orange) !important;
}

.alert-info {
    background-color: rgba(74, 158, 255, 0.15) !important;
    border-color: rgba(74, 158, 255, 0.3) !important;
    color: var(--csiq-accent-blue) !important;
}

/* --- Modals (keep light for readability) --- */
.modal-content {
    background: #ffffff !important;
    color: #333 !important;
}

/* Quick Menu loading spinner — preserve dark gradient background */
#qmLoadingModal .modal-content {
    background: linear-gradient(135deg, #0b1220 0%, #1B4A7C 100%) !important;
    color: #fff !important;
}

.modal-header {
    border-bottom-color: #dee2e6 !important;
}

.modal-title {
    color: #1B4A7C !important;
}

.modal-footer {
    border-top-color: #dee2e6 !important;
}

/* --- Kendo Dialogs (keep light for readability) --- */
.k-dialog,
.k-window {
    background: #ffffff !important;
    color: #212529 !important;
    border-color: #dee2e6 !important;
}

.k-dialog .k-window-titlebar,
.k-window .k-window-titlebar,
.k-dialog .k-dialog-titlebar {
    background-color: #1B4A7C !important;
    color: #ffffff !important;
    border-bottom: 1px solid #dee2e6 !important;
}

.k-dialog .k-window-titlebar .k-window-title,
.k-window .k-window-titlebar .k-window-title,
.k-dialog .k-dialog-titlebar .k-dialog-title {
    color: #ffffff !important;
}

.k-dialog .k-window-titlebar .k-window-titlebar-action,
.k-dialog .k-dialog-titlebar .k-dialog-titlebar-action {
    color: #ffffff !important;
}

.k-dialog .k-window-content,
.k-dialog .k-dialog-content,
.k-window .k-window-content {
    background: #ffffff !important;
    color: #212529 !important;
}

.k-dialog .k-dialog-content p,
.k-dialog .k-window-content p,
.k-dialog .k-dialog-content b,
.k-dialog .k-window-content b {
    color: #212529 !important;
}

.k-dialog .form-check-label,
.k-window .form-check-label,
.modal-content .form-check-label {
    color: #212529 !important;
}

.k-dialog .form-check-input,
.k-window .form-check-input,
.modal-content .form-check-input {
    border-color: #212529 !important;
    background-color: #fff !important;
}

.k-dialog .form-check-input:checked,
.k-window .form-check-input:checked,
.modal-content .form-check-input:checked {
    background-color: #0d6efd !important;
    border-color: #0d6efd !important;
}

.k-dialog label,
.k-window label,
.modal-content label {
    color: #212529 !important;
}

/* Add Student modal — bright blue labels and dropdown text */
#addStudentModal .form-label {
    color: #4a9eff !important;
}
#addStudentModal .form-label .text-danger {
    color: #dc3545 !important;
}
#addStudentModal .parent-row .card-header {
    background: #1B4A7C !important;
    color: #ffffff !important;
}
#addStudentModal .parent-row .card-header .fw-bold {
    color: #ffffff !important;
}

.k-dialog .k-actions,
.k-dialog .k-dialog-actions,
.k-window .k-actions {
    background: #f8f9fa !important;
    border-top: 1px solid #dee2e6 !important;
}

/* Dialog button overrides — prevent dark-theme styles from hiding buttons on white bg */
.k-dialog .btn-default,
.k-dialog .btn-light,
.k-window .btn-default,
.k-window .btn-light {
    background-color: #ffffff !important;
    border-color: #6c757d !important;
    color: #212529 !important;
}

.k-dialog .btn-default:hover,
.k-dialog .btn-light:hover,
.k-window .btn-default:hover,
.k-window .btn-light:hover {
    background-color: #e9ecef !important;
    border-color: #6c757d !important;
    color: #212529 !important;
}

.k-dialog .btn-primary,
.k-window .btn-primary {
    background-color: #1B4A7C !important;
    border-color: #1B4A7C !important;
    color: #ffffff !important;
}

.k-dialog .btn-primary:hover,
.k-window .btn-primary:hover {
    background-color: #153d66 !important;
    border-color: #153d66 !important;
    color: #ffffff !important;
}

/* Form controls inside dialogs and modals — black text on white background */
.k-dialog .form-control,
.k-dialog .form-select,
.k-dialog textarea,
.k-window .form-control,
.k-window .form-select,
.k-window textarea,
.modal-content .form-control,
.modal-content .form-select,
.modal-content textarea {
    background-color: #ffffff !important;
    color: #212529 !important;
    border-color: #ced4da !important;
}

.k-dialog .form-control:focus,
.k-dialog .form-select:focus,
.k-dialog textarea:focus,
.k-window .form-control:focus,
.k-window .form-select:focus,
.k-window textarea:focus,
.modal-content .form-control:focus,
.modal-content .form-select:focus,
.modal-content textarea:focus {
    background-color: #ffffff !important;
    color: #212529 !important;
    border-color: #0d6efd !important;
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25) !important;
}

.k-dialog .form-control::placeholder,
.k-window .form-control::placeholder,
.modal-content .form-control::placeholder {
    color: #6c757d !important;
}

.k-dialog .text-danger,
.k-window .text-danger {
    color: #dc3545 !important;
}

.k-dialog .text-muted,
.k-window .text-muted {
    color: #6c757d !important;
}

/* --- Dropdowns (keep light) --- */
.dropdown-menu {
    background: #ffffff !important;
    border-color: #dee2e6 !important;
}

.dropdown-menu .dropdown-item {
    color: #333 !important;
}

.dropdown-menu .dropdown-item:hover {
    background: #f0f0f0 !important;
}

/* --- Tabs & Nav --- */
.nav-tabs {
    border-bottom-color: var(--csiq-border) !important;
}

.nav-tabs .nav-link {
    color: #1B4A7C !important;
}

/* Task detail tabs — white text when unselected, orange on hover */
ul#tab-nav.nav-tabs .nav-link:not(.active) {
    color: #fff !important;
    font-size: 1.05rem !important;
}

ul#tab-nav.nav-tabs .nav-link:not(.active):hover {
    color: #f47920 !important;
}

.nav-tabs .nav-link:hover {
    color: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-border) !important;
}

.nav-tabs .nav-link.active {
    background-color: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) var(--csiq-border) var(--csiq-bg-card) !important;
    color: var(--csiq-accent-blue) !important;
}

.nav-pills .nav-link {
    color: #1B4A7C !important;
}

.nav-pills .nav-link.active {
    background-color: var(--csiq-accent-blue) !important;
    color: var(--csiq-text-bright) !important;
}

/* --- Links --- */
a {
    color: var(--csiq-accent-orange);
}

a:hover {
    color: #ffb347;
}

a.text-decoration-none:not(.text-white):not(.btn):not(.menu-link):not(.dropdown-item) {
    color: var(--csiq-accent-orange) !important;
}

/* --- Badges --- */
.badge.bg-success {
    background: rgba(16, 185, 129, 0.15) !important;
    color: var(--csiq-accent-teal) !important;
}

.badge.bg-primary {
    background: rgba(74, 158, 255, 0.15) !important;
    color: var(--csiq-accent-blue) !important;
}

.badge.bg-warning {
    background: rgba(255, 149, 0, 0.15) !important;
    color: var(--csiq-accent-orange) !important;
}

.badge.bg-danger {
    background: rgba(220, 53, 69, 0.15) !important;
    color: #ff6b6b !important;
}

/* --- Progress Bars --- */
.progress {
    background-color: rgba(255, 255, 255, 0.08) !important;
}

/* --- Mailbox / Notifications --- */
.mailbox {
    background: var(--csiq-bg-card) !important;
}

.mailbox-toolbar {
    background: var(--csiq-bg-table-head) !important;
    border-color: var(--csiq-border) !important;
}

.mailbox-toolbar-link {
    color: #4a9eff !important;
    font-weight: 500;
}

.mailbox-toolbar-link:hover {
    color: #fff !important;
}

.mailbox-toolbar-link.active {
    color: #fff !important;
    background: #4a9eff !important;
    border-radius: 4px;
    padding: 4px 12px;
}

.mailbox-toolbar-link.text-primary,
.mailbox-toolbar-link.bg-blue-transparent-1 {
    color: #fff !important;
    background: #4a9eff !important;
    border-radius: 4px;
    padding: 4px 12px;
}

.mailbox-sidebar {
    background: var(--csiq-bg-sidebar) !important;
    border-color: var(--csiq-border) !important;
}

.mailbox-sidebar .mailbox-list .mailbox-list-item {
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.mailbox-sidebar .mailbox-list .mailbox-list-item:hover {
    background: var(--csiq-hover) !important;
}

.mailbox-sidebar .mailbox-list .mailbox-list-item.active {
    background: rgba(74, 158, 255, 0.1) !important;
}

.mailbox-content {
    background: var(--csiq-bg-card) !important;
    color: var(--csiq-text) !important;
}

.mailbox-content .mailbox-detail-header {
    background: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.mailbox-title {
    color: #fff !important;
}

.mailbox-sender-name {
    color: #fff !important;
}

.mailbox-time {
    color: #4da3ff !important;
}

.mailbox-detail-body {
    color: var(--csiq-text) !important;
}

/* --- Summernote Editor --- */
.note-editable {
    color: #000 !important;
}

/* --- Chat --- */
.widget-chat .widget-chat-item .widget-chat-bubble {
    background: var(--csiq-bg-card-alt) !important;
    color: var(--csiq-text) !important;
}

.widget-chat .widget-chat-item .widget-chat-bubble .widget-chat-bubble-arrow::before {
    border-color: transparent var(--csiq-bg-card-alt) transparent transparent !important;
}

.widget-chat .widget-chat-item.right .widget-chat-bubble {
    background: rgba(74, 158, 255, 0.15) !important;
}

.bg-light {
    background-color: var(--csiq-bg-card) !important;
}

/* --- Calendar (FullCalendar) --- */
.calendar {
    background: var(--csiq-bg-card) !important;
    color: var(--csiq-text) !important;
}

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

.fc .fc-toolbar-title {
    color: var(--csiq-text-bright) !important;
}

.fc .fc-button {
    background-color: var(--csiq-bg-card-alt) !important;
    border-color: var(--csiq-border-input) !important;
    color: var(--csiq-text) !important;
}

.fc .fc-button-active,
.fc .fc-button:hover {
    background-color: var(--csiq-accent-blue) !important;
    color: var(--csiq-text-bright) !important;
}

.fc th {
    background: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text-label) !important;
    border-color: var(--csiq-border) !important;
}

.fc td {
    border-color: var(--csiq-border) !important;
}

.fc .fc-daygrid-day {
    background: var(--csiq-bg-card) !important;
}

.fc .fc-daygrid-day:hover {
    background: var(--csiq-bg-card-alt) !important;
}

.fc .fc-day-today {
    background: rgba(255, 149, 0, 0.12) !important;
}

.fc .fc-day-today .fc-daygrid-day-number {
    background: #FF9500 !important;
    color: #fff !important;
    border-radius: 50%;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
}

.fc .fc-daygrid-day-number {
    color: var(--csiq-text) !important;
}

.fc .fc-popover {
    background: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
}

.fc .fc-popover-header {
    background: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text) !important;
}

.fc .fc-list-event:hover td {
    background: var(--csiq-hover) !important;
}

/* --- Settings & Forms Sections --- */
.list-group-item {
    background-color: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
    color: var(--csiq-text) !important;
}

.list-group-item.active {
    background-color: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-accent-blue) !important;
    color: var(--csiq-text-bright) !important;
}

/* --- Accordion --- */
.accordion-item {
    background-color: var(--csiq-bg-card) !important;
    border-color: var(--csiq-border) !important;
}

.accordion-button {
    background-color: var(--csiq-bg-card) !important;
    color: var(--csiq-text) !important;
}

.accordion-button:not(.collapsed) {
    background-color: var(--csiq-bg-card-alt) !important;
    color: var(--csiq-accent-orange) !important;
}

.accordion-body {
    background-color: var(--csiq-bg-card) !important;
    color: var(--csiq-text) !important;
}

/* --- Global Warning Banner --- */
.global-warning .accordion-button {
    background-color: #2a1800 !important;
    color: var(--csiq-accent-orange) !important;
}

.global-warning .accordion-body {
    background-color: var(--csiq-bg-card) !important;
    color: var(--csiq-text-muted) !important;
}

.global-warning .accordion-body b,
.global-warning .accordion-body a {
    color: var(--csiq-accent-orange) !important;
}

/* --- Scrollbar --- */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--csiq-bg-header);
}

::-webkit-scrollbar-thumb {
    background: #3a4a5c;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #4a5a6c;
}

/* --- Tooltips --- */
.tooltip-inner {
    background: var(--csiq-bg-card-alt) !important;
    color: var(--csiq-text) !important;
    border: 1px solid var(--csiq-border) !important;
}

/* --- Misc --- */
.bg-white {
    background-color: var(--csiq-bg-card) !important;
}

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

hr {
    border-color: var(--csiq-border) !important;
    opacity: 1;
}

.shadow-sm, .shadow {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

/* Disabled rows in DataTables */
tr.rowDisabled,
tr.rowDisabled > td {
    background-color: var(--csiq-bg-table-head) !important;
    color: var(--csiq-text-dim) !important;
    font-style: italic;
}

/* Notification badges */
.badge.bg-success-transparent-2 {
    background: rgba(16, 185, 129, 0.15) !important;
    color: var(--csiq-accent-teal) !important;
}

/* Onboarding wizard steps */
.sw .sw-container {
    background: var(--csiq-bg-card) !important;
}

.sw .toolbar > .btn {
    background: var(--csiq-accent-blue) !important;
    border-color: var(--csiq-accent-blue) !important;
    color: var(--csiq-text-bright) !important;
}

/* Nav wizards (workflow steps) */
.nav-wizards-3 .nav-link {
    color: var(--csiq-text-muted);
}

.nav-wizards-3 .nav-link .nav-text {
    color: var(--csiq-text-muted) !important;
}

.nav-wizards-3 .nav-link .nav-dot {
    background: var(--csiq-bg-card);
    border-color: #3a4a5c;
}

.nav-wizards-3 .nav-link::before {
    background: #3a4a5c !important;
}

.nav-wizards-3 .nav-link.active {
    color: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-link.active .nav-text {
    color: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-link.active .nav-dot {
    border-color: var(--csiq-accent-orange) !important;
    box-shadow: 0 0 0 5px rgba(255, 149, 0, 0.2) !important;
}

.nav-wizards-3 .nav-link.active::after {
    background: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-link.completed {
    color: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-link.completed .nav-text {
    color: var(--csiq-accent-teal) !important;
}

.nav-wizards-3 .nav-link.completed .nav-dot {
    border-color: var(--csiq-accent-orange) !important;
    background: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-link.completed::after {
    background: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-item:last-child .nav-link.active::before,
.nav-wizards-3 .nav-item:last-child .nav-link.completed::before {
    background: var(--csiq-accent-orange) !important;
}

.nav-wizards-3 .nav-link.disabled {
    color: #3a4a5c !important;
}

.nav-wizards-3 .nav-link.disabled .nav-text {
    color: #3a4a5c !important;
}

.nav-link.processing {
    color: var(--csiq-accent-orange) !important;
}

.nav-link.processing .nav-dot {
    color: var(--csiq-accent-orange) !important;
    border-color: var(--csiq-accent-orange) !important;
}

.nav-link.processing::after,
.nav-link.processing::before {
    background: var(--csiq-accent-orange) !important;
}

/* =============================================
   Commercial Theme — Green accent (#10b981)
   Applied when user is CommercialCompany role.
   ============================================= */

/* Sidebar menu headers — green instead of blue/orange */
.commercial-sidebar .menu-header {
    color: #10b981 !important;
}

/* Sidebar active menu item — green highlight */
.commercial-sidebar .menu-item.active > .menu-link,
.commercial-sidebar .menu-item.active > .menu-link:hover {
    color: #10b981 !important;
}

.commercial-sidebar .menu-link:hover {
    color: #34d399 !important;
}

/* Help button in sidebar — green */
.commercial-sidebar .menu-item .menu-link .fa-question {
    color: #10b981 !important;
}

/* Breadcrumb links — green for commercial */
body.commercial-theme .breadcrumb-item a {
    color: #10b981 !important;
}

body.commercial-theme .breadcrumb-item a:hover {
    color: #34d399 !important;
}

body.commercial-theme .breadcrumb-item.active {
    color: #34d399 !important;
}

/* ============================================
   Kendo Pager: sleek dark pill-style buttons
   Override Kendo CSS variables + direct selectors
   ============================================ */
.k-pager {
    --kendo-color-surface: transparent !important;
    --kendo-color-border: transparent !important;
    --kendo-color-on-app-surface: #8899ab !important;
    --kendo-color-primary: #4a9eff !important;
    --kendo-color-on-primary: #fff !important;
    padding: 10px 12px !important;
    border-color: transparent !important;
    background: transparent !important;
}

/* All pager buttons (numbers + nav arrows) */
.k-pager .k-button {
    color: #8899ab !important;
    background-color: rgba(255, 255, 255, 0.06) !important;
    background-image: none !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 8px !important;
    min-width: 34px !important;
    height: 34px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.15s ease !important;
    margin: 0 2px !important;
    padding: 0 8px !important;
    box-sizing: border-box !important;
}

.k-pager .k-button::before {
    display: none !important;
}

/* Hover */
.k-pager .k-button:hover,
.k-pager .k-button:focus {
    color: #fff !important;
    background-color: rgba(74, 158, 255, 0.18) !important;
    border-color: #4a9eff !important;
}

/* Selected / Active page */
.k-pager .k-button.k-selected,
.k-pager .k-button.k-selected:hover {
    color: #fff !important;
    background: linear-gradient(135deg, #4a9eff, #1B4A7C) !important;
    border-color: #4a9eff !important;
    box-shadow: 0 2px 8px rgba(74, 158, 255, 0.35) !important;
}

/* Disabled nav buttons */
.k-pager .k-button.k-disabled,
.k-pager .k-button[disabled] {
    color: rgba(255, 255, 255, 0.15) !important;
    background-color: rgba(255, 255, 255, 0.02) !important;
    border-color: rgba(255, 255, 255, 0.05) !important;
    opacity: 1 !important;
}

/* Pager info text */
.k-pager .k-pager-info {
    color: #8899ab !important;
    font-size: 0.8rem;
}

/* Numbers container alignment */
.k-pager .k-pager-numbers,
.k-pager .k-pager-numbers-wrap {
    display: flex !important;
    align-items: center !important;
    gap: 2px;
}

/* Page size dropdown */
.k-pager .k-pager-sizes .k-dropdownlist {
    border-radius: 8px !important;
}

/* ============================================
   DataTables Pager: sleek dark pill-style buttons
   ============================================ */
.dataTables_wrapper .dataTables_paginate .paginate_button {
    color: var(--csiq-text-muted, #8899ab) !important;
    padding: 4px 1px !important;
    margin: 0 1px !important;
    transition: all 0.15s ease;
    border: none !important;
    background: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button .page-link {
    color: inherit !important;
    background: none !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    padding: 4px 8px !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button:hover .page-link {
    color: #4a9eff !important;
    background: none !important;
}

.dataTables_wrapper .dataTables_paginate .paginate_button.active,
.dataTables_wrapper .dataTables_paginate .paginate_button.active .page-link {
    color: #fff !important;
    background: linear-gradient(135deg, #4a9eff, #1B4A7C) !important;
    border-radius: 6px !important;
    box-shadow: 0 2px 6px rgba(74, 158, 255, 0.3);
}

.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled .page-link {
    color: rgba(255, 255, 255, 0.15) !important;
    opacity: 1 !important;
}

.dataTables_info {
    color: #8899ab !important;
    font-size: 0.8rem;
}

/* Form inputs: white text on focus/active for dark theme readability */
.form-control:focus,
.form-control:active,
.form-select:focus,
.form-select:active,
input[type="number"]:focus,
input[type="number"]:active,
input[type="text"]:focus,
input[type="text"]:active,
.request-fee-quantity:focus,
.request-fee-input:focus,
.input-group .form-control:focus {
    color: #fff !important;
    caret-color: #fff !important;
}

/* Ensure fee inputs are always readable */
.request-fee-quantity,
.request-fee-input {
    color: #e6edf7 !important;
}
.request-fee-quantity:focus,
.request-fee-input:focus {
    color: #fff !important;
    background-color: #243447 !important;
}
