/* Dark Mode Theme for HakiTume Sacco Application */

/* ===== DARK MODE COLOR PALETTE ===== */
:root {
    --dark-primary-bg: #1a1a1a;
    --dark-secondary-bg: #2d2d2d;
    --dark-card-bg: #3a3a3a;
    --dark-border: #4a4a4a;
    --dark-text-primary: #ffffff;
    --dark-text-secondary: #b3b3b3;
  --dark-text-muted: #8a8a8a;
    --dark-header-bg: #252525;
    --dark-sidebar-bg: #1e1e1e;
    --dark-accent-blue: #3b82f6; /* Uses same blue as --secondary-blue for consistency */
    --dark-success: #4caf50;
    --dark-warning: #ff9800;
 --dark-danger: #f44336;
    --dark-hover: #404040;
    --dark-shadow: rgba(0, 0, 0, 0.5);
}

/* ===== DARK MODE PROFESSIONAL PAGE HEADER & CONTRIBUTIONS SUMMARY VARIABLES ===== */
body.dark-mode {
    /* Professional page header variables for dark mode */
    --page-header-bg: #1e293b;
    --page-header-border: rgba(148, 163, 184, 0.3);
    --page-header-title-color: #f1f5f9;
    --page-header-icon-color: #94a3b8;
    --page-header-subtitle-color: #cbd5e1;
    
    /* Contributions Summary variables for dark mode */
    --contrib-card-bg-start: #1e293b;
    --contrib-card-bg-end: #0f172a;
    --contrib-card-border: rgba(148, 163, 184, 0.2);
    --contrib-card-shadow: rgba(0, 0, 0, 0.6);
    --contrib-card-shadow-hover: rgba(0, 0, 0, 0.7);
    --contrib-header-bg-start: #1e293b;
    --contrib-header-bg-end: #0f172a;
    --contrib-header-border: rgba(148, 163, 184, 0.2);
    --contrib-icon-color: #94a3b8;
    --contrib-title-color: #f1f5f9;
    --contrib-stat-bg: rgba(30, 41, 59, 0.6);
    --contrib-stat-border: rgba(148, 163, 184, 0.2);
    --contrib-stat-hover-bg: rgba(30, 41, 59, 0.8);
    --contrib-label-color: #cbd5e1;
    --contrib-value-color: #ffffff;
    --contrib-amount-color: #4ade80;
    --contrib-divider-color: rgba(148, 163, 184, 0.3);
}

/* ===== MAIN BODY DARK MODE ===== */
body.dark-mode {
    background-color: var(--dark-primary-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== HEADER DARK MODE ===== */
body.dark-mode .m-header {
    background-color: var(--dark-header-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-brand--skin-light {
    background: var(--dark-header-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
    box-shadow: 0 1px 3px var(--dark-shadow) !important;
}

body.dark-mode .sacco-header-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .sacco-title-main,
body.dark-mode .sacco-title-accent {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .sacco-subtitle {
    color: var(--dark-text-secondary) !important;
}

/* ===== TOPBAR DARK MODE ===== */
body.dark-mode .m-topbar {
    background-color: var(--dark-header-bg) !important;
}

body.dark-mode .m-topbar .m-nav__link {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-topbar .m-nav__link:hover {
    background-color: var(--dark-hover) !important;
}

body.dark-mode .m-topbar .m-nav__link-icon {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-topbar .m-nav__link-badge {
    background-color: var(--dark-danger) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== ENHANCED SIDEBAR DARK MODE WITH FORCED OVERRIDES ===== */
/* High priority overrides for skin-light classes and custom scrollbars */
body.dark-mode .m-aside-left,
body.dark-mode .m-aside-left--skin-light,
body.dark-mode #m_aside_left.m-aside-left--skin-light {
    background-color: var(--dark-sidebar-bg) !important;
    border-right: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-aside-menu,
body.dark-mode .m-aside-menu--skin-light,
body.dark-mode .m-aside-menu--submenu-skin-light,
body.dark-mode #m_ver_menu.m-aside-menu--skin-light,
body.dark-mode #m_ver_menu.m-aside-menu--submenu-skin-light {
    background-color: var(--dark-sidebar-bg) !important;
    background: var(--dark-sidebar-bg) !important;
}

/* Custom scrollbar dark mode overrides */
body.dark-mode .mCustomScrollbar,
body.dark-mode .mCustomScrollbar .mCSB_scrollTools,
body.dark-mode .mCustomScrollbar .mCSB_scrollTools .mCSB_dragger,
body.dark_mode .mCustomScrollbar .mCSB_scrollTools .mCSB_draggerRail,
body.dark_mode .mCS-autoHide > .mCSB_scrollTools,
body.dark_mode ._mCS_6 .mCSB_scrollTools,
body.dark_mode .mCS-autoHide.mCustomScrollbar .mCSB_scrollTools {
    background-color: var(--dark-sidebar-bg) !important;
    background: var(--dark-sidebar-bg) !important;
}

body.dark-mode .mCustomScrollbar .mCSB_container {
    background-color: var(--dark-sidebar-bg) !important;
    background: var(--dark-sidebar-bg) !important;
}

body.dark-mode .mCSB_dragger .mCSB_dragger_bar {
    background-color: var(--dark-text-secondary) !important;
}

body.dark-mode .mCSB_draggerRail {
    background-color: var(--dark-secondary-bg) !important;
}

body.dark-mode .m-menu__nav,
body.dark_mode .m-menu__nav--dropdown-submenu-arrow {
    background-color: var(--dark-sidebar-bg) !important;
    background: var(--dark-sidebar-bg) !important;
}

body.dark-mode .m-menu__nav .m-menu__item .m-menu__link {
    color: var(--dark-text-primary) !important;
    background-color: transparent !important;
    background: transparent !important;
}

body.dark-mode .m-menu__nav .m-menu__item .m-menu__link:hover,
body.dark-mode .m-menu__nav .m-menu__item .m-menu__link:focus {
    background-color: var(--dark-hover) !important;
    background: var(--dark-hover) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-menu__nav .m-menu__item--active > .m-menu__link,
body.dark-mode .m-menu__nav .m-menu__item--active .m-menu__link {
    background-color: var(--dark-accent-blue) !important;
    background: var(--dark-accent-blue) !important;
    color: white !important;
}

body.dark-mode .m-menu__nav .m-menu__item--submenu > .m-menu__link:hover {
    background-color: var(--dark-hover) !important;
    background: var(--dark-hover) !important;
}

body.dark-mode .m-menu__link-icon,
body.dark-mode .m-menu__link-icon.flaticon-layers,
body.dark_mode .m-menu__link-icon.flaticon-graphic-1,
body.dark_mode .m-menu__link-icon.flaticon-open-box,
body.dark_mode .m-menu__link-icon.flaticon-share,
body.dark_mode .m-menu__link-icon.flaticon-interface-4,
body.dark_mode .m-menu__link-icon.flaticon-interface-8,
body.dark_mode .m-menu__link-icon.flaticon-interface-9,
body.dark_mode .m-menu__link-icon.flaticon-grid-menu,
body.dark_mode .m-menu__link-icon.flaticon-add {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .m-menu__item--active .m-menu__link-icon,
body.dark-mode .m-menu__item--active .m-menu__link-icon.flaticon-layers,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-graphic-1,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-open-box,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-share,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-interface-4,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-interface-8,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-interface-9,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-grid-menu,
body.dark_mode .m-menu__item--active .m-menu__link-icon.flaticon-add {
    color: white !important;
}

body.dark-mode .m-menu__link-text {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-menu__item--active .m-menu__link-text {
    color: white !important;
}

body.dark-mode .m-menu__ver-arrow,
body.dark_mode .m-menu__ver-arrow.la,
body.dark_mode .m-menu__ver-arrow.la-angle-right {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .m-menu__item--active .m-menu__ver-arrow,
body.dark_mode .m-menu__item--active .m-menu__ver-arrow.la,
body.dark_mode .m-menu__item--active .m-menu__ver-arrow.la-angle-right {
    color: white !important;
}

/* ===== SUBMENU DARK MODE WITH FORCED OVERRIDES ===== */
body.dark-mode .m-menu__submenu {
    background-color: var(--dark-secondary-bg) !important;
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.8) !important;
    opacity: 1 !important;
}

body.dark-mode .m-menu__subnav {
    background-color: var(--dark-secondary-bg) !important;
    background: var(--dark-secondary-bg) !important;
    opacity: 1 !important;
}

body.dark-mode .m-menu__subnav .m-menu__item .m-menu__link {
    color: var(--dark-text-primary) !important;
    background-color: var(--dark-secondary-bg) !important;
    background: var(--dark-secondary-bg) !important;
}

body.dark-mode .m-menu__subnav .m-menu__item .m-menu__link:hover {
    background-color: var(--dark-hover) !important;
    background: var(--dark-hover) !important;
}

body.dark-mode .m-menu__subnav .m-menu__item--active > .m-menu__link,
body.dark-mode .m-menu__subnav .m-menu__item--active .m-menu__link {
    background-color: var(--dark-accent-blue) !important;
    background: var(--dark-accent-blue) !important;
    color: white !important;
}

/* ===== FORCED OVERRIDE FOR ALL SKIN-LIGHT VARIANTS ===== */
body.dark-mode [class*="--skin-light"] {
    background-color: var(--dark-sidebar-bg) !important;
    background: var(--dark-sidebar-bg) !important;
}

/* ===== SPECIFIC ID AND CLASS COMBINATIONS ===== */
body.dark-mode #m_aside_left,
body.dark-mode #m_ver_menu {
    background-color: var(--dark-sidebar-bg) !important;
    background: var(--dark-sidebar-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== CONTENT AREA DARK MODE ===== */
body.dark-mode .m-content {
    background-color: var(--dark-primary-bg) !important;
}

body.dark-mode .m-portlet {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    box-shadow: 0 2px 8px var(--dark-shadow) !important;
}

body.dark-mode .m-portlet__head {
    background-color: var(--dark-secondary-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-portlet__head-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-portlet__body {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== DASHBOARD WIDGETS DARK MODE ===== */
body.dark-mode .professional-widget {
    background: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
    box-shadow: 0 2px 8px var(--dark-shadow) !important;
}

body.dark-mode .professional-widget:hover {
    box-shadow: 0 4px 12px var(--dark-shadow) !important;
}

body.dark-mode .professional-widget-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-widget-description {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .professional-widget-value {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-widget-icon {
    color: var(--dark-accent-blue) !important;
}

/* ===== PROFESSIONAL PROGRESS BARS DARK MODE ===== */
body.dark-mode .professional-progress {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .professional-progress-bar {
    background: var(--dark-accent-blue) !important;
}

body.dark-mode .professional-progress-bar.success {
    background: var(--dark-success) !important;
}

body.dark-mode .professional-progress-bar.warning {
    background: var(--dark-warning) !important;
}

body.dark-mode .professional-progress-bar.danger {
    background: var(--dark-danger) !important;
}

/* ===== METRO WIDGETS DARK MODE ===== */
body.dark-mode .m-widget24 {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-widget24__item {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-widget24__title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .m-widget24__desc {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .m-widget24__stats {
    color: var(--dark-accent-blue) !important;
}

/* ===== PROFESSIONAL DASHBOARD HEADER DARK MODE ===== */
body.dark-mode .professional-dashboard-header {
    background: var(--dark-secondary-bg) !important;
    border-bottom: 3px solid var(--dark-accent-blue) !important;
}

body.dark-mode .professional-dashboard-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-dashboard-subtitle {
    color: var(--dark-text-secondary) !important;
}

/* ===== CHART CONTAINERS DARK MODE ===== */
body.dark-mode .professional-chart-container {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-chart-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-chart-subtitle {
    color: var(--dark-text-secondary) !important;
}

/* ===== PROFESSIONAL CHART HEADER DARK MODE ===== */
body.dark-mode .professional-chart-header {
    background-color: var(--dark-secondary-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode .professional-chart-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-chart-title-icon {
    color: var(--dark-accent-blue) !important;
}

body.dark-mode .professional-chart-body {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== AMCHARTS DARK MODE SUPPORT ===== */
body.dark-mode .amcharts {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .amcharts svg {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode .amcharts text {
    fill: var(--dark-text-primary) !important;
}

body.dark.mode .amcharts .amcharts-axis-label {
    fill: var(--dark-text-secondary) !important;
}

body.dark.mode .amcharts .amcharts-axis-title {
    fill: var(--dark-text-primary) !important;
}

body.dark.mode .amcharts .amcharts-legend-label {
    fill: var(--dark-text-primary) !important;
}

body.dark.mode .amcharts .amcharts-legend-item-color {
    stroke: var(--dark-border) !important;
}

body.dark.mode .amcharts .amcharts-grid-line {
    stroke: var(--dark-border) !important;
}

body.dark.mode .amcharts .amcharts-axis-line {
    stroke: var(--dark-border) !important;
}

/* ===== CHART LOADING STATES DARK MODE ===== */
body.dark-mode .professional-chart-loading {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-secondary) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .professional-chart-loading::before {
    border: 2px solid var(--dark-border) !important;
    border-top: 2px solid var(--dark-accent-blue) !important;
}

/* ===== CHART.JS DARK MODE SUPPORT ===== */
body.dark-mode .chartjs-chart canvas {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode .chart-container {
    background-color: var(--dark-card-bg) !important;
}

/* ===== GENERIC CHART ELEMENTS ===== */
body.dark-mode .chart-legend,
body.dark-mode .chart-title,
body.dark-mode .chart-subtitle {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .chart-axis-label,
body.dark-mode .chart-tick-label {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .chart-grid-line {
    stroke: var(--dark-border) !important;
}

/* ===== D3.JS AND SVG CHARTS DARK MODE ===== */
body.dark-mode svg {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode svg text {
    fill: var(--dark-text-primary) !important;
}

body.dark-mode svg .axis text {
    fill: var(--dark-text-secondary) !important;
}

body.dark.mode svg .axis path,
body.dark.mode svg .axis line {
    stroke: var(--dark-border) !important;
}

body.dark.mode svg .grid line {
    stroke: var(--dark-border) !important;
}

body.dark.mode svg .domain {
    stroke: var(--dark-border) !important;
}

/* ===== HIGHCHARTS DARK MODE SUPPORT ===== */
body.dark-mode .highcharts-container {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode .highcharts-background {
    fill: var(--dark-card-bg) !important;
}

body.dark-mode .highcharts-title {
    fill: var(--dark-text-primary) !important;
}

body.dark-mode .highcharts-subtitle {
    fill: var(--dark-text-secondary) !important;
}

body.dark-mode .highcharts-axis-labels text {
    fill: var(--dark-text-secondary) !important;
}

body.dark-mode .highcharts-legend-item text {
    fill: var(--dark-text-primary) !important;
}

body.dark.mode .highcharts-grid-line {
    stroke: var(--dark-border) !important;
}

/* ===== CHART CONTAINERS AND WRAPPERS ===== */
body.dark-mode .chart-wrapper,
body.dark-mode .chart-panel,
body.dark-mode .graph-container {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== CHAT AND MESSAGING DARK MODE ===== */
body.dark-mode .chat-container,
body.dark-mode .message-container,
body.dark-mode .conversation-container {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .chat-message,
body.dark-mode .message-item {
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .chat-message.sent {
    background-color: var(--dark-accent-blue) !important;
    color: white !important;
}

body.dark-mode .chat-message.received {
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .chat-input,
body.dark-mode .message-input {
    background-color: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .chat-input::placeholder,
body.dark-mode .message-input::placeholder {
    color: var(--dark-text-muted) !important;
}

body.dark-mode .chat-header,
body.dark-mode .message-header {
    background-color: var(--dark-header-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .chat-timestamp,
body.dark-mode .message-timestamp {
    color: var(--dark-text-muted) !important;
}

body.dark-mode .chat-status,
body.dark-mode .message-status {
    color: var(--dark-text-secondary) !important;
}

/* ===== NOTIFICATION AND MESSAGE ENHANCEMENTS ===== */
body.dark-mode .professional-warning-message,
body.dark-mode .professional-info-message,
body.dark-mode .professional-error-message {
    background-color: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== ADDITIONAL WIDGET TYPES DARK MODE ===== */
body.dark-mode .widget,
body.dark-mode .card,
body.dark-mode .panel {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .widget-title,
body.dark-mode .card-title,
body.dark-mode .card-header,
body.dark-mode .panel-title {
    color: var(--dark-text-primary) !important;
    background-color: var(--dark-secondary-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode .widget-body,
body.dark-mode .card-body,
body.dark-mode .panel-body {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* ===== DASHBOARD SPECIFIC ELEMENTS ===== */
body.dark-mode .m-content__wrapper {
    background-color: var(--dark-primary-bg) !important;
}

body.dark-mode .m-grid__item {
    background-color: transparent !important;
}

/* ===== LOADING INDICATORS DARK MODE ===== */
body.dark-mode .loading,
body.dark-mode [class*="loading"] {
    color: var(--dark-text-secondary) !important;
}

/* ===== HEADER DARK MODE IMPLEMENTATION ===== */
body.dark-mode .m-header {
    background-color: var(--dark-bg) !important;
    color: var(--dark-text) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-brand--skin-light,
body.dark-mode .m-brand {
    background-color: var(--dark-bg) !important;
    color: var(--dark-text) !important;
}

body.dark-mode .m-header-head {
    background-color: var(--dark-bg) !important;
    color: var(--dark-text) !important;
}

body.dark-mode .m-topbar {
    background-color: var(--dark-bg) !important;
    color: var(--dark-text) !important;
}

/* Header Search Dark Mode */
body.dark-mode .m-header-search--skin-light,
body.dark-mode .m-header-search {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
}

body.dark-mode .m-header-search .m-dropdown__wrapper {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-header-search .m-dropdown__body {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
}

/* Header Navigation Dark Mode */
body.dark-mode .m-topbar__nav .m-nav__link {
    color: var(--dark-text) !important;
}

body.dark-mode .m-topbar__nav .m-nav__link:hover {
    background-color: var(--dark-hover) !important;
    color: var(--dark-text) !important;
}

/* Header Dropdowns Dark Mode */
body.dark-mode .m-dropdown--skin-light .m-dropdown__wrapper,
body.dark-mode .m-dropdown__wrapper {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-dropdown--skin-light .m-dropdown__inner,
body.dark-mode .m-dropdown__inner {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
}

body.dark-mode .m-dropdown--skin-light .m-dropdown__header,
body.dark-mode .m-dropdown__header {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-dropdown--skin-light .m-dropdown__body,
body.dark-mode .m-dropdown__body {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
}

/* Header Notifications Dark Mode */
body.dark-mode .m-topbar__notifications .m-nav__link-badge {
    background-color: #dc3545 !important;
    color: white !important;
}

body.dark-mode .m-list-timeline--skin-light,
body.dark-mode .m-list-timeline {
    background-color: var(--dark-card-bg) !important;
}

/* Header Quick Actions Dark Mode */
body.dark-mode .m-nav-grid--skin-light,
body.dark-mode .m-nav-grid {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode .m-nav-grid__item {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode .m-nav-grid__item:hover {
    background-color: var(--dark-hover) !important;
    color: var(--dark-text) !important;
}

body.dark-mode .m-nav-grid__icon {
    color: var(--dark-accent) !important;
}

/* Header User Profile Dark Mode */
body.dark-mode .m-card-user--skin-light,
body.dark-mode .m-card-user {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text) !important;
}

body.dark-mode .m-card-user__email {
    color: var(--dark-text) !important;
}

/* Header Title Dark Mode */
body.dark-mode .sacco-header-title {
    color: var(--dark-text) !important;
}

body.dark-mode .sacco-title-main,
body.dark_mode .sacco-title-accent {
    color: var(--dark-text) !important;
}

body.dark-mode .sacco-subtitle {
    color: var(--dark-text-secondary) !important;
}

/* Header Icons Dark Mode */
body.dark-mode .m-brand__icon,
body.dark-mode .m-nav__link-icon,
body.dark-mode .flaticon-music-2,
body.dark-mode .flaticon-share,
body.dark-mode .flaticon-user-ok,
body.dark-mode .flaticon-more {
    color: var(--dark-text) !important;
}

/* ===== BORDER ADJUSTMENTS ===== */
body.dark-mode .m-portlet--border-bottom-primary {
    border-bottom: 3px solid var(--dark-accent-blue) !important;
}

body.dark-mode .m-portlet--border-bottom-info {
    border-bottom: 3px solid var(--dark-accent-blue) !important;
}

body.dark-mode .m-portlet--border-bottom-success {
    border-bottom: 3px solid var(--dark-success) !important;
}

body.dark-mode .m-portlet--border-bottom-warning {
    border-bottom: 3px solid var(--dark-warning) !important;
}

body.dark-mode .m-portlet--border-bottom-danger {
    border-bottom: 3px solid var(--dark-danger) !important;
}

/* ===== TABLES DARK MODE ===== */
body.dark-mode .table {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .table th {
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .table td {
    border-color: var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(255, 255, 255, 0.05) !important;
}

/* ===== LOANS PAGE DATATABLE DARK MODE ===== */
body.dark-mode #dt_basic {
    background-color: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode #dt_basic thead {
    background: var(--dark-secondary-bg) !important;
}

body.dark-mode #dt_basic thead th {
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode #dt_basic tbody td {
    background-color: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border-color: var(--dark-border) !important;
    text-align: left !important; /* Align all td items to left as requested */
}

body.dark-mode #dt_basic tbody tr {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode #dt_basic tbody tr:nth-child(even) {
    background-color: var(--dark-secondary-bg) !important;
}

body.dark-mode #dt_basic tbody tr:nth-child(odd) {
    background-color: var(--dark-card-bg) !important;
}

body.dark-mode #dt_basic tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
    border-left-color: var(--dark-accent-blue) !important;
}

/* Specific column styling for better visibility in dark mode */
body.dark-mode #dt_basic tbody td:nth-child(1) {
    color: var(--dark-text-secondary) !important;
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(2),
body.dark-mode #dt_basic tbody td:nth-child(3) {
    color: var(--dark-text-primary) !important;
    background-color: rgba(59, 130, 246, 0.15) !important;
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(4),
body.dark-mode #dt_basic tbody td:nth-child(5) {
    color: #10b981 !important; /* Brighter green for dark mode */
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(6) {
    color: #fbbf24 !important; /* Brighter orange for dark mode */
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(7) {
    color: #60a5fa !important; /* Brighter blue for dark mode */
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(8) {
    color: #f87171 !important; /* Brighter red for dark mode */
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(9) {
    color: #a78bfa !important; /* Brighter purple for dark mode */
    text-align: left !important;
}

body.dark-mode #dt_basic tbody td:nth-child(10) {
    color: var(--dark-text-secondary) !important;
    text-align: left !important;
}

/* Dark mode hover effects for loans table */
body.dark-mode #dt_basic tbody tr:hover td:nth-child(4),
body.dark-mode #dt_basic tbody tr:hover td:nth-child(5) {
    background-color: rgba(16, 185, 129, 0.2) !important;
    color: #10b981 !important;
}

body.dark-mode #dt_basic tbody tr:hover td:nth-child(6) {
    background-color: rgba(251, 191, 36, 0.2) !important;
    color: #fbbf24 !important;
}

body.dark-mode #dt_basic tbody tr:hover td:nth-child(7) {
    background-color: rgba(96, 165, 250, 0.2) !important;
    color: #60a5fa !important;
}

body.dark-mode #dt_basic tbody tr:hover td:nth-child(8) {
    background-color: rgba(248, 113, 113, 0.2) !important;
    color: #f87171 !important;
}

body.dark-mode #dt_basic tbody tr:hover td:nth-child(9) {
    background-color: rgba(167, 139, 250, 0.2) !important;
    color: #a78bfa !important;
}

/* Loans selector dropdown dark mode */
body.dark-mode .loans-selector {
    background-color: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .loans-selector label {
    color: var(--dark-text-primary) !important;
}

body.dark-mode #Loans {
    background-color: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode #Loans option {
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode #Loans:focus {
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3) !important;
}

body.dark-mode #Loans:hover {
    border-color: var(--dark-text-secondary) !important;
}

/* ===== LOAN APPLICATION COMPLETE PAGE DARK MODE ===== */
/* Professional tab navigation dark mode */
body.dark-mode .professional-tab-container {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

body.dark-mode .professional-tab-nav {
    background: var(--dark-secondary-bg) !important;
    border-bottom-color: var(--dark-border) !important;
}

body.dark-mode .professional-tab-link {
    background: var(--dark-secondary-bg) !important;
    color: var(--dark-text-secondary) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .professional-tab-link:hover {
    background: var(--dark-hover) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-tab-link.active {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom-color: var(--dark-card-bg) !important;
}

body.dark-mode .professional-tab-content {
    background: var(--dark-card-bg) !important;
}

body.dark-mode .professional-tab-pane {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* Form sections dark mode */
body.dark-mode .professional-form-section {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .professional-section-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-membership-input,
body.dark-mode .professional-membership-select,
body.dark-mode .professional-membership-textarea {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-membership-input:focus,
body.dark-mode .professional-membership-select:focus,
body.dark-mode .professional-membership-textarea:focus {
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3) !important;
}

body.dark-mode .professional-membership-label {
    color: var(--dark-text-primary) !important;
}

/* Guidelines section dark mode */
body.dark-mode .professional-guarantor-info-section {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .professional-guarantor-guidelines {
    background: var(--dark-secondary-bg) !important;
}

body.dark-mode .professional-guideline-item {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .professional-guideline-content {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-guideline-content strong {
    color: var(--dark-text-primary) !important;
}

/* Committee and approval sections dark mode */
body.dark-mode .professional-committee-section,
body.dark-mode .professional-approval-section,
body.dark-mode .professional-final-approval-section {
    background: var(--dark-card-bg) !important;
}

body.dark-mode .professional-approval-grid-modern {
    background: var(--dark-card-bg) !important;
}

body.dark-mode .professional-approval-content {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
}

/* Decision cards dark mode */
body.dark-mode .decision-card-modern {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

body.dark.mode .decision-header {
    background: var(--dark-secondary-bg) !important;
    border-bottom-color: var(--dark-border) !important;
}

body.dark.mode .decision-title {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .decision-subtitle {
    color: var(--dark-text-secondary) !important;
}

body.dark.mode .decision-option-card {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark.mode .decision-option-card:hover {
    background: var(--dark-hover) !important;
    border-color: #10b981 !important;
}

body.dark.mode .decision-option-card.approve:hover {
    border-color: #10b981 !important;
}

body.dark.mode .decision-option-card.deny:hover {
    border-color: #f87171 !important;
}

body.dark mode .decision-option-label h6 {
    color: var(--dark-text-primary) !important;
}

body.dark mode .decision-option-label p {
    color: var(--dark-text-secondary) !important;
}

/* Radio buttons dark mode */
body.dark-mode .professional-radio-group {
    background: var(--dark-card-bg) !important;
}

body.dark-mode .professional-radio-item {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark-mode .professional-radio-label {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-radio-label:hover {
    background: var(--dark-hover) !important;
}

body.dark-mode .professional-radio-label.selected {
    background: rgba(59, 130, 246, 0.2) !important;
    border-color: var(--dark-accent-blue) !important;
}

/* Prerequisites section dark mode */
body.dark-mode .credit-committee-prerequisites {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark.mode .prerequisites-title {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .prerequisite-item {
    background: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .prerequisite-item.completed {
    background: rgba(16, 185, 129, 0.2) !important;
    border-color: #10b981 !important;
}

/* Summary cards dark mode */
body.dark.mode .decision-summary-cards {
    background: var(--dark-card-bg) !important;
}

body.dark.mode .summary-info-card {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark.mode .summary-info-card .info-content label {
    color: var(--dark-text-secondary) !important;
}

body.dark.mode .summary-info-card .info-content p {
    color: var(--dark-text-primary) !important;
}

/* Action info section dark mode */
body.dark.mode .action-info {
    background: rgba(59, 130, 246, 0.1) !important;
    color: var(--dark-text-primary) !important;
    border-color: var(--dark-accent-blue) !important;
}

/* Modal dark mode */
body.dark.mode .modal-content {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

body.dark.mode .modal-header {
    background: var(--dark-secondary-bg) !important;
    border-bottom-color: var(--dark-border) !important;
}

body.dark.mode .modal-title {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .modal-body {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .modal-footer {
    background: var(--dark-secondary-bg) !important;
    border-top-color: var(--dark-border) !important;
}

body.dark.mode .close {
    color: var(--dark-text-primary) !important;
    opacity: 0.8;
}

body.dark.mode .close:hover {
    color: var(--dark-text-primary) !important;
    opacity: 1;
}

/* Schedule container dark mode */
body.dark.mode .professional-schedule-container {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

/* Validation error styling dark mode */
body.dark.mode .professional-validation-error {
    color: #f87171 !important;
}

body.dark.mode .professional-validation-summary {
    background: rgba(248, 113, 113, 0.1) !important;
    border-color: #f87171 !important;
    color: var(--dark-text-primary) !important;
}

/* Section divider dark mode - Enhanced visibility */
body.dark.mode .professional-section-divider,
body.dark.mode hr {
    border-color: var(--dark-border) !important;
    border-top-color: rgba(255, 255, 255, 0.2) !important;
    background: rgba(255, 255, 255, 0.1) !important;
    opacity: 1 !important;
    height: 1px !important;
    margin: 1.5rem 0 !important;
}

/* Form section enhancements for better visibility */
body.dark.mode .professional-form-section {
    background: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    border-radius: 6px !important;
    padding: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}

body.dark.mode .professional-section-title {
    color: var(--dark-text-primary) !important;
    font-weight: 600 !important;
    margin-bottom: 1rem !important;
}

/* Enhanced form elements visibility */
body.dark.mode .professional-membership-label {
    color: var(--dark-text-primary) !important;
    font-weight: 500 !important;
}

body.dark.mode .professional-membership-input,
body.dark.mode .professional-membership-select {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-membership-input:focus,
body.dark.mode .professional-membership-select:focus {
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.25) !important;
}

body.dark.mode .professional-membership-input[readonly] {
    background: rgba(255, 255, 255, 0.05) !important;
    color: var(--dark-text-secondary) !important;
}

/* Enhanced guarantor section visibility */
body.dark.mode .professional-next-of-kin-header {
    background: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    padding: 1rem !important;
    border-radius: 6px !important;
}

body.dark.mode .professional-next-of-kin-title {
    color: var(--dark-text-primary) !important;
}

/* Loan status container dark mode */
body.dark.mode .professional-loan-status-container {
    background: var(--dark-card-bg) !important;
    border-color: var(--dark-border) !important;
}

/* Focus states dark mode */
body.dark.mode .professional-form-col.focused .professional-membership-input,
body.dark.mode .professional-form-col.focused .professional-membership-select,
body.dark.mode .professional-form-col.focused .professional-membership-textarea {
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3) !important;
}

body.dark.mode .professional-form-col.has-success .professional-membership-input,
body.dark.mode .professional-form-col.has-success .professional-membership-select {
    border-color: #10b981 !important;
}

body.dark.mode .professional-form-col.has-error .professional-membership-input,
body.dark.mode .professional-form-col.has-error .professional-membership-select {
    border-color: #f87171 !important;
}

/* ===== LOAN STATUS MESSAGES DARK MODE ===== */
body.dark.mode .professional-loan-status-container {
    background: var(--dark-card-bg) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
}

body.dark.mode .professional-loan-status-message {
    color: var(--dark-text-primary) !important;
    background: var(--dark-card-bg) !important;
}

body.dark.mode .professional-loan-status-title {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-loan-status-text {
    color: var(--dark-text-primary) !important;
}

/* Success status dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-loan-status-success,
body.dark.mode .professional-loan-status-message.professional-loan-status-success {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.15) 0%, rgba(16, 185, 129, 0.25) 100%) !important;
    border-left-color: #10b981 !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-loan-status-container .professional-loan-status-success .professional-loan-status-icon,
body.dark.mode .professional-loan-status-message.professional-loan-status-success .professional-loan-status-icon,
body.dark.mode .professional-loan-status-success .professional-loan-status-icon {
    background: #10b981 !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

/* Info status dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-loan-status-info,
body.dark.mode .professional-loan-status-message.professional-loan-status-info {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.15) 0%, rgba(59, 130, 246, 0.25) 100%) !important;
    border-left-color: var(--dark-accent-blue) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-loan-status-container .professional-loan-status-info .professional-loan-status-icon,
body.dark.mode .professional-loan-status-message.professional-loan-status-info .professional-loan-status-icon,
body.dark.mode .professional-loan-status-info .professional-loan-status-icon {
    background: var(--dark-accent-blue) !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

/* Warning status dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-loan-status-warning,
body.dark.mode .professional-loan-status-message.professional-loan-status-warning {
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.15) 0%, rgba(251, 191, 36, 0.25) 100%) !important;
    border-left-color: #fbbf24 !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-loan-status-container .professional-loan-status-warning .professional-loan-status-icon,
body.dark.mode .professional-loan-status-message.professional-loan-status-warning .professional-loan-status-icon,
body.dark.mode .professional-loan-status-warning .professional-loan-status-icon {
    background: #fbbf24 !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

/* Error status dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-loan-status-error,
body.dark.mode .professional-loan-status-message.professional-loan-status-error {
    background: linear-gradient(135deg, rgba(248, 113, 113, 0.15) 0%, rgba(248, 113, 113, 0.25) 100%) !important;
    border-left-color: #f87171 !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-loan-status-container .professional-loan-status-error .professional-loan-status-icon,
body.dark.mode .professional-loan-status-message.professional-loan-status-error .professional-loan-status-icon,
body.dark.mode .professional-loan-status-error .professional-loan-status-icon {
    background: #f87171 !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

/* Processing status dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-loan-status-processing,
body.dark.mode .professional-loan-status-message.professional-loan-status-processing {
    background: linear-gradient(135deg, rgba(167, 139, 250, 0.15) 0%, rgba(167, 139, 250, 0.25) 100%) !important;
    border-left-color: #a78bfa !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .professional-loan-status-container .professional-loan-status-processing .professional-loan-status-icon,
body.dark.mode .professional-loan-status-message.professional-loan-status-processing .professional-loan-status-icon,
body.dark.mode .professional-loan-status-processing .professional-loan-status-icon {
    background: #a78bfa !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: none !important;
}

/* Amount highlight dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-loan-amount-highlight,
body.dark.mode .professional-loan-status-message .professional-loan-amount-highlight {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

/* Progress bar dark mode - Higher specificity */
body.dark.mode .professional-loan-status-container .professional-guarantor-progress,
body.dark.mode .professional-loan-status-message .professional-guarantor-progress {
    background: rgba(255, 255, 255, 0.1) !important;
}

body.dark.mode .professional-loan-status-container .professional-guarantor-progress-bar,
body.dark.mode .professional-loan-status-message .professional-guarantor-progress-bar {
    background: #10b981 !important;
}

body.dark.mode .professional-loan-status-container .professional-guarantor-progress-bar.incomplete,
body.dark.mode .professional-loan-status-message .professional-guarantor-progress-bar.incomplete {
    background: #fbbf24 !important;
}

/* ===== ACCOUNT STATEMENT DATATABLE DARK MODE ===== */
body.dark-mode #dt_AccountStatement {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode #dt_AccountStatement thead th {
    background: var(--dark-header-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom: 2px solid var(--dark-border) !important;
    border-right: 1px solid var(--dark-border) !important;
    text-align: left !important;
    font-weight: 600 !important;
    padding: 12px 8px !important;
}

body.dark-mode #dt_AccountStatement tbody td {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom: 1px solid var(--dark-border) !important;
    border-right: 1px solid var(--dark-border) !important;
    text-align: left !important;
    padding: 10px 8px !important;
}

body.dark-mode #dt_AccountStatement tbody tr {
    background: var(--dark-card-bg) !important;
}

body.dark-mode #dt_AccountStatement tbody tr:hover {
    background: var(--dark-hover) !important;
}

/* Account Statement specific column styling */
body.dark.mode #dt_AccountStatement tbody td:nth-child(1) {
    color: var(--dark-text-primary) !important;
    font-weight: 500 !important;
}

body.dark.mode #dt_AccountStatement tbody td:nth-child(2) {
    color: var(--dark-text-primary) !important;
}

body.dark.mode #dt_AccountStatement tbody td:nth-child(3) {
    color: var(--dark-text-primary) !important;
}

body.dark.mode #dt_AccountStatement tbody td:nth-child(4) {
    color: #10b981 !important;
    font-weight: 600 !important;
}

body.dark.mode #dt_AccountStatement tbody td:nth-child(5) {
    color: #f87171 !important;
    font-weight: 600 !important;
}

body.dark.mode #dt_AccountStatement tbody td:nth-child(6) {
    color: #60a5fa !important;
    font-weight: 600 !important;
}

/* DataTable wrapper and controls for Account Statement */
body.dark.mode #dt_AccountStatement_wrapper {
    background: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    border-radius: 6px !important;
    padding: 1rem !important;
}

body.dark.mode #dt_AccountStatement_wrapper .dataTables_length select,
body.dark.mode #dt_AccountStatement_wrapper .dataTables_filter input {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
    border-radius: 4px !important;
    padding: 6px 12px !important;
}

body.dark.mode #dt_AccountStatement_wrapper .dataTables_length label,
body.dark.mode #dt_AccountStatement_wrapper .dataTables_filter label,
body.dark.mode #dt_AccountStatement_wrapper .dataTables_info,
body.dark.mode #dt_AccountStatement_wrapper .dataTables_paginate {
    color: var(--dark-text-primary) !important;
}

body.dark.mode #dt_AccountStatement_wrapper .dataTables_paginate .paginate_button {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode #dt_AccountStatement_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--dark-hover) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode #dt_AccountStatement_wrapper .dataTables_paginate .paginate_button.current {
    background: var(--dark-accent-blue) !important;
    color: #ffffff !important;
}

/* ===== CONTRIBUTIONS DATATABLE DARK MODE ===== */
body.dark-mode #contributionsTable {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode #contributionsTable thead th {
    background: var(--dark-header-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom: 2px solid var(--dark-border) !important;
    border-right: 1px solid var(--dark-border) !important;
    text-align: left !important;
    font-weight: 600 !important;
    padding: 12px 8px !important;
}

body.dark-mode #contributionsTable tbody td {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom: 1px solid var(--dark-border) !important;
    border-right: 1px solid var(--dark-border) !important;
    text-align: left !important;
    padding: 10px 8px !important;
}

body.dark-mode #contributionsTable tbody tr {
    background: var(--dark-card-bg) !important;
}

body.dark-mode #contributionsTable tbody tr:hover {
    background: var(--dark-hover) !important;
}

/* Contributions specific column styling */
body.dark-mode #contributionsTable tbody td:nth-child(1) {
    color: #60a5fa !important;
    font-weight: 600 !important;
}

body.dark-mode #contributionsTable tbody td:nth-child(2) {
    color: #fbbf24 !important;
    font-weight: 500 !important;
}

body.dark-mode #contributionsTable tbody td:nth-child(3) {
    color: #10b981 !important;
    font-weight: 600 !important;
}

body.dark-mode #contributionsTable tbody td:nth-child(4) {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode #contributionsTable tbody td:nth-child(5) {
    color: var(--dark-text-primary) !important;
}

/* DataTable wrapper and controls for Contributions */
body.dark-mode #contributionsTable_wrapper {
    background: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    border-radius: 6px !important;
    padding: 1rem !important;
}

body.dark-mode #contributionsTable_wrapper .dataTables_length select,
body.dark-mode #contributionsTable_wrapper .dataTables_filter input {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
    border-radius: 4px !important;
    padding: 6px 12px !important;
}

body.dark.mode #contributionsTable_wrapper .dataTables_length label,
body.dark.mode #contributionsTable_wrapper .dataTables_filter label,
body.dark.mode #contributionsTable_wrapper .dataTables_info,
body.dark.mode #contributionsTable_wrapper .dataTables_paginate {
    color: var(--dark-text-primary) !important;
}

body.dark.mode #contributionsTable_wrapper .dataTables_paginate .paginate_button {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode #contributionsTable_wrapper .dataTables_paginate .paginate_button:hover {
    background: var(--dark-hover) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode #contributionsTable_wrapper .dataTables_paginate .paginate_button.current {
    background: var(--dark-accent-blue) !important;
    color: #ffffff !important;
}

/* ===== ALL CONTRIBUTIONS TABLE DARK MODE (dt_basicAllContributions) ===== */
body.dark-mode #dt_basicAllContributions {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark-mode #dt_basicAllContributions thead {
    background: var(--dark-header-bg) !important;
}

body.dark-mode #dt_basicAllContributions thead th {
    background: var(--dark-header-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom: 2px solid var(--dark-border) !important;
    border-right: 1px solid var(--dark-border) !important;
    text-align: left !important;
    font-weight: 600 !important;
    font-size: 0.875rem !important;
    padding: 12px 8px !important;
    vertical-align: middle !important;
    text-transform: uppercase !important;
    letter-spacing: 0.025em !important;
}

body.dark-mode #dt_basicAllContributions tbody td {
    background: var(--dark-card-bg) !important;
    color: var(--dark-text-primary) !important;
    border-bottom: 1px solid var(--dark-border) !important;
    border-right: 1px solid var(--dark-border) !important;
    text-align: left !important;
    padding: 10px 8px !important;
    font-weight: 400 !important;
    font-size: 0.875rem !important;
    vertical-align: middle !important;
}

body.dark-mode #dt_basicAllContributions tbody tr {
    background: var(--dark-card-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark-mode #dt_basicAllContributions tbody tr:nth-child(even) {
    background: var(--dark-secondary-bg) !important;
}

body.dark-mode #dt_basicAllContributions tbody tr:hover {
    background: rgba(59, 130, 246, 0.15) !important;
}

/* All Contributions specific column styling */
body.dark-mode #dt_basicAllContributions tbody td:nth-child(1) {
    color: #60a5fa !important;
    font-weight: 600 !important;
}

body.dark-mode #dt_basicAllContributions tbody td:nth-child(2) {
    color: #fbbf24 !important;
    font-weight: 500 !important;
}

body.dark-mode #dt_basicAllContributions tbody td:nth-child(3) {
    color: #10b981 !important;
    font-weight: 500 !important;
}

body.dark-mode #dt_basicAllContributions tbody td:nth-child(4) {
    color: #4ade80 !important;
    font-weight: 600 !important;
}

body.dark-mode #dt_basicAllContributions tbody td:nth-child(5) {
    color: var(--dark-text-primary) !important;
    font-weight: 400 !important;
}

/* DataTable wrapper and controls for All Contributions */
body.dark-mode #dt_basicAllContributions_wrapper {
    background: transparent !important;
    padding: 0 !important;
    font-family: 'Roboto', sans-serif !important;
}

body.dark-mode #dt_basicAllContributions_wrapper .dataTables_length,
body.dark-mode #dt_basicAllContributions_wrapper .dataTables_filter,
body.dark-mode #dt_basicAllContributions_wrapper .dataTables_info,
body.dark-mode #dt_basicAllContributions_wrapper .dataTables_paginate {
    color: var(--dark-text-primary) !important;
    font-weight: 400 !important;
    font-size: 0.875rem !important;
    font-family: 'Roboto', sans-serif !important;
}

body.dark-mode #dt_basicAllContributions_wrapper .dataTables_length select,
body.dark-mode #dt_basicAllContributions_wrapper .dataTables_filter input {
    border: 1px solid var(--dark-border) !important;
    border-radius: 6px !important;
    padding: 0.5rem 0.75rem !important;
    font-weight: 400 !important;
    font-size: 0.875rem !important;
    background: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    font-family: 'Roboto', sans-serif !important;
}

body.dark-mode #dt_basicAllContributions_wrapper .dataTables_length select:focus,
body.dark-mode #dt_basicAllContributions_wrapper .dataTables_filter input:focus {
    border-color: var(--dark-accent-blue) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.3) !important;
}

body.dark-mode #dt_basicAllContributions_wrapper .dataTables_filter label,
body.dark-mode #dt_basicAllContributions_wrapper .dataTables_length label {
    font-weight: 500 !important;
    color: var(--dark-text-primary) !important;
    font-family: 'Roboto', sans-serif !important;
}

body.dark.mode #dt_basicAllContributions_wrapper .dataTables_paginate .paginate_button {
    border: 1px solid var(--dark-border) !important;
    border-radius: 6px !important;
    padding: 0.5rem 0.75rem !important;
    background: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    font-weight: 400 !important;
    font-size: 0.875rem !important;
    text-decoration: none !important;
    font-family: 'Roboto', sans-serif !important;
}

body.dark.mode #dt_basicAllContributions_wrapper .dataTables_paginate .paginate_button:hover {
    background: rgba(59, 130, 246, 0.2) !important;
    border-color: var(--dark-accent-blue) !important;
    color: var(--dark-text-primary) !important;
    text-decoration: none !important;
}

body.dark.mode #dt_basicAllContributions_wrapper .dataTables_paginate .paginate_button.current {
    background: var(--dark-header-bg) !important;
    border-color: var(--dark-header-bg) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode #dt_basicAllContributions_wrapper .dataTables_paginate .paginate_button.disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    background: var(--dark-secondary-bg) !important;
    color: var(--dark-text-secondary) !important;
}

/* Contribution table container dark mode */
body.dark-mode .professional-table-body {
    background: var(--dark-card-bg) !important;
    padding: 1.5rem 2rem !important;
}

body.dark-mode .professional-table-container {
    background: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.3) !important;
}

body.dark-mode .professional-table-header {
    background: var(--dark-header-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
    padding: 1.5rem 2rem !important;
}

body.dark-mode .professional-table-title {
    color: var(--dark-text-primary) !important;
}

body.dark-mode .professional-table-title-icon {
    color: var(--dark-accent-blue) !important;
}

/* DataTable buttons for contributions table */
body.dark-mode #dt_basicAllContributions_wrapper .dt-buttons .btn {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
    padding: 0.5rem 1rem !important;
    border-radius: 6px !important;
    margin-right: 0.5rem !important;
    transition: all 0.15s ease-in-out !important;
    font-size: 0.875rem !important;
}

body.dark-mode #dt_basicAllContributions_wrapper .dt-buttons .btn:hover {
    background: var(--dark-hover) !important;
    border-color: var(--dark-accent-blue) !important;
    color: var(--dark-text-primary) !important;
}

body.dark-mode .buttons-print:hover {
    background: #dc3545 !important;
    color: var(--dark-text-primary) !important;
    border-color: #dc3545 !important;
}

body.dark-mode .buttons-excel:hover {
    background: #16a34a !important;
    color: var(--dark-text-primary) !important;
    border-color: #16a34a !important;
}

body.dark-mode .buttons-pdf:hover {
    background: #dc2626 !important;
    color: var(--dark-text-primary) !important;
    border-color: #dc2626 !important;
}

body.dark-mode .buttons-copy:hover,
body.dark-mode .buttons-csv:hover {
    background: var(--dark-accent-blue) !important;
    color: var(--dark-text-primary) !important;
    border-color: var(--dark-accent-blue) !important;
}

/* ===== FORMS DARK MODE ===== */
body.dark.mode .form-control {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .form-control:focus {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 0.2rem rgba(74, 158, 255, 0.25) !important;
}

body.dark.mode .form-control::placeholder {
    color: var(--dark-text-muted) !important;
}

/* ===== BUTTONS DARK MODE ===== */
body.dark.mode .btn-primary {
    background-color: var(--dark-accent-blue) !important;
    border-color: var(--dark-accent-blue) !important;
}

body.dark.mode .btn-secondary {
    background-color: var(--dark-secondary-bg) !important;
    border-color: var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .btn-secondary:hover {
    background-color: var(--dark-hover) !important;
}

/* ===== DROPDOWN DARK MODE ===== */
body.dark.mode .m-dropdown__wrapper {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
    box-shadow: 0 4px 12px var(--dark-shadow) !important;
}

body.dark.mode .m-dropdown__header {
    background-color: var(--dark-secondary-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark.mode .m-dropdown__header-title,
body.dark.mode .m-dropdown__header-subtitle {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .m-dropdown__content {
    background-color: var(--dark-card-bg) !important;
}

/* ===== NOTIFICATIONS DARK MODE ===== */
body.dark.mode .m-list-timeline__item {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .m-list-timeline__time {
    color: var(--dark-text-secondary) !important;
}

/* ===== MODAL DARK MODE ===== */
body.dark.mode .modal-content {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark.mode .modal-header {
    background-color: var(--dark-secondary-bg) !important;
    border-bottom: 1px solid var(--dark-border) !important;
}

body.dark.mode .modal-title {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .modal-body {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .modal-footer {
    border-top: 1px solid var(--dark-border) !important;
}

/* ===== FOOTER DARK MODE ===== */
body.dark.mode .m-footer {
    background-color: var(--dark-header-bg) !important;
    border-top: 1px solid var(--dark-border) !important;
    color: var(--dark-text-secondary) !important;
}

/* ===== ALERTS AND BADGES DARK MODE ===== */
body.dark.mode .alert {
    border: 1px solid var(--dark-border) !important;
}

body.dark.mode .alert-success {
    background-color: rgba(76, 175, 80, 0.1) !important;
    border-color: var(--dark-success) !important;
    color: var(--dark-success) !important;
}

body.dark.mode .alert-warning {
    background-color: rgba(255, 152, 0, 0.1) !important;
    border-color: var(--dark-warning) !important;
    color: var(--dark-warning) !important;
}

body.dark.mode .alert-danger {
    background-color: rgba(244, 67, 54, 0.1) !important;
    border-color: var(--dark-danger) !important;
    color: var(--dark-danger) !important;
}

/* ===== CHARTS AND WIDGETS DARK MODE ===== */
body.dark.mode .widget {
    background-color: var(--dark-card-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark.mode .widget-title {
    color: var(--dark-text-primary) !important;
}

/* ===== COMPREHENSIVE TEXT COLOR FIXES ===== */
body.dark.mode h1,
body.dark.mode h2, 
body.dark.mode h3,
body.dark.mode h4,
body.dark.mode h5,
body.dark.mode h6 {
    color: var(--dark-text-primary) !important;
}

body.dark.mode p,
body.dark.mode span,
body.dark.mode div,
body.dark.mode label {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .text-muted {
    color: var(--dark-text-muted) !important;
}

body.dark.mode .text-secondary {
    color: var(--dark-text-secondary) !important;
}

/* ===== BOOTSTRAP TEXT UTILITY CLASSES DARK MODE ===== */
body.dark.mode .text-dark {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .text-primary {
    color: var(--dark-accent-blue) !important;
}

/* ===== LINK STYLES DARK MODE ===== */
body.dark.mode a {
    color: var(--dark-accent-blue) !important;
}

body.dark.mode a:hover {
    color: #2563eb !important;
}

body.dark.mode a.text-decoration-none {
    color: var(--dark-accent-blue) !important;
}

body.dark.mode a.text-decoration-none:hover {
    color: #2563eb !important;
    text-decoration: underline !important;
}

/* ===== SPECIFIC BACKGROUND FIXES ===== */
body.dark.mode .bg-white,
body.dark.mode [class*="bg-white"] {
    background-color: var(--dark-card-bg) !important;
}

body.dark.mode .bg-light,
body.dark.mode [class*="bg-light"] {
    background-color: var(--dark-secondary-bg) !important;
}

/* ===== LOADING AND PROGRESS INDICATORS ===== */
body.dark.mode .progress {
    background-color: var(--dark-secondary-bg) !important;
}

body.dark.mode .progress-bar {
    background-color: var(--dark-accent-blue) !important;
}

/* ===== LOGIN PAGE DARK MODE ===== */
body.dark.mode.login-modern {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%) !important;
}

/* Enhanced login container dark mode - rounded and blended */
body.dark-mode .login-container {
    background: linear-gradient(135deg, rgba(26, 26, 46, 0.9) 0%, rgba(22, 33, 62, 0.95) 100%) !important;
    border-radius: 32px !important;
    padding: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4) !important;
}

body.dark-mode .login-card {
    background: rgba(26, 26, 26, 0.95) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
    border-radius: 24px !important;
}

/* Enhanced dark mode styling for expanded forms */
body.dark.mode .login-container.expanded {
    background: linear-gradient(135deg, rgba(26, 26, 46, 0.9) 0%, rgba(22, 33, 62, 0.95) 100%) !important;
    border-radius: 32px !important;
    padding: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4) !important;
}

body.dark.mode .login-container.expanded .login-card {
    background: rgba(26, 26, 26, 0.98) !important;
    border: 1px solid var(--dark-border) !important;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.4) !important;
    border-radius: 24px !important;
}

body.dark.mode .login-logo h2 {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .login-logo p {
    color: var(--dark-text-secondary) !important;
}

body.dark.mode .security-badge {
    background: rgba(59, 130, 246, 0.1) !important;
    border: 1px solid rgba(59, 130, 246, 0.2) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .security-badges {
    margin: 20px 0 30px 0 !important;
}

body.dark.mode .trust-indicators {
    margin-top: 25px !important;
    padding-top: 16px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

body.dark.mode .trust-indicators small {
    color: var(--dark-text-muted) !important;
}

/* ===== LOGIN PAGE CONTENT BLENDING FIX ===== */
/* Fix login logo background bleeding */
body.dark-mode .login-logo {
    background: transparent !important;
    margin-bottom: 20px !important;
}

/* Fix form elements background in dark mode */
body.dark-mode .login-card .form-floating input,
body.dark-mode .login-card .form-control {
    background: rgba(255, 255, 255, 0.95) !important;
    border: 2px solid rgba(59, 130, 246, 0.3) !important;
    color: #2d3748 !important;
}

body.dark-mode .login-card .form-floating input:focus,
body.dark-mode .login-card .form-control:focus {
    background: #ffffff !important;
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.25) !important;
}

/* Fix form labels in login card */
body.dark-mode .login-card .form-label {
    color: var(--dark-text-primary) !important;
    font-weight: 500 !important;
}

body.dark-mode .login-card .form-floating label {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .login-card .form-floating input:focus + label,
body.dark-mode .login-card .form-floating input:not(:placeholder-shown) + label {
    color: var(--dark-accent-blue) !important;
}

/* Fix button styling in dark mode login */
body.dark-mode .login-card .btn-login {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    border: none !important;
    color: white !important;
}

body.dark-mode .login-card .btn-login:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 30px rgba(102, 126, 234, 0.35) !important;
}

/* Fix checkbox styling in dark mode */
body.dark-mode .login-card .form-check-input {
    background-color: rgba(255, 255, 255, 0.9) !important;
    border: 2px solid rgba(59, 130, 246, 0.3) !important;
}

body.dark-mode .login-card .form-check-input:checked {
    background-color: var(--dark-accent-blue) !important;
    border-color: var(--dark-accent-blue) !important;
}

body.dark-mode .login-card .form-check-label {
    color: var(--dark-text-primary) !important;
}

/* Fix forgot password link */
body.dark-mode .login-card .forgot-password {
    color: var(--dark-text-secondary) !important;
}

body.dark-mode .login-card .forgot-password:hover {
    color: var(--dark-accent-blue) !important;
}

/* Fix password toggle icon */
body.dark-mode .login-card .password-toggle {
    color: #6b7280 !important;
}

body.dark-mode .login-card .password-toggle:hover {
    color: var(--dark-accent-blue) !important;
}

/* ===== SECURITY INDICATOR DARK MODE ===== */
body.dark.mode .security-indicator {
    background: rgba(74, 158, 255, 0.1) !important;
    color: var(--dark-accent-blue) !important;
    border: 1px solid rgba(74, 158, 255, 0.2) !important;
}

/* ===== SIMPLIFIED FORM STYLES DARK MODE ===== */
body.dark.mode .form-label {
    color: var(--dark-text-secondary) !important;
}

body.dark.mode .form-control {
    background: var(--dark-secondary-bg) !important;
    border: 2px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .form-control:focus {
    background: var(--dark-secondary-bg) !important;
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.25) !important;
}

body.dark.mode .form-control::placeholder {
    color: var(--dark-text-muted) !important;
}

body.dark.mode select.form-control {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23b3b3b3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e") !important;
}

body.dark.mode select.form-control option {
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    padding: 12px 16px !important;
    border: none !important;
}

/* Enhanced cross-browser dropdown option support */
body.dark.mode select.form-control option:hover,
body.dark.mode select.form-control option:focus,
body.dark.mode select.form-control option:active {
    background: var(--dark-accent-blue) !important;
    background-color: var(--dark-accent-blue) !important;
    color: #ffffff !important;
}

/* Additional browser-specific dropdown fixes */
body.dark.mode select.form-control optgroup {
    background: var(--dark-secondary-bg) !important;
    background-color: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
}

/* Force dropdown styling for better cross-browser support */
body.dark.mode select.form-control {
    background: var(--dark-secondary-bg) !important;
    background-color: var(--dark-secondary-bg) !important;
    border: 2px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23b3b3b3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e") !important;
    background-position: right 18px center !important;
    background-repeat: no-repeat !important;
    background-size: 16px !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

body.dark.mode .password-toggle {
    color: var(--dark-text-muted) !important;
}

body.dark.mode .password-toggle:hover {
    color: var(--dark-accent-blue) !important;
}

/* ===== FORM CHECK ELEMENTS DARK MODE ===== */
body.dark.mode .form-check-label {
    color: var(--dark-text-primary) !important;
}

body.dark.mode .form-check-input {
    background-color: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
}

body.dark.mode .form-check-input:checked {
    background-color: var(--dark-accent-blue) !important;
    border-color: var(--dark-accent-blue) !important;
}

body.dark.mode .form-check-input:focus {
    border-color: var(--dark-accent-blue) !important;
    box-shadow: 0 0 0 0.25rem rgba(59, 130, 246, 0.25) !important;
}

/* ===== FORGOT PASSWORD LINK DARK MODE ===== */
body.dark.mode .forgot-password {
    color: var(--dark-text-secondary) !important;
}

body.dark.mode .forgot-password:hover {
    color: var("--dark-accent-blue") !important;
}

/* ===== ALERT COMPONENTS DARK MODE ===== */
body.dark.mode .alert-info {
    background: var(--dark-secondary-bg) !important;
    border: 1px solid var(--dark-border) !important;
    color: var(--dark-text-primary) !important;
}

body.dark.mode .alert-info .text-primary {
    color: var(--dark-accent-blue) !important;
}

body.dark.mode .alert-info .text-muted {
    color: var(--dark-text-muted) !important;
}

/* ===== VALIDATION FEEDBACK DARK MODE ===== */
body.dark.mode .form-floating .invalid-feedback,
body.dark.mode .form-floating .field-validation-error {
    color: var(--dark-danger) !important;
    background: rgba(26, 26, 26, 0.95) !important;
    border: 1px solid var(--dark-danger) !important;
}

body.dark.mode .form-floating .valid-feedback,
body.dark.mode .form-floating .field-validation-valid {
    color: var(--dark-success) !important;
    background: rgba(26, 26, 26, 0.95) !important;
    border: 1px solid var(--dark-success) !important;
}

/* ===== ENHANCED FOCUS STATES FOR ACCESSIBILITY ===== */
body.dark.mode .form-floating input:focus,
body.dark.mode .btn-login:focus,
body.dark.mode .form-check-input:focus,
body.dark.mode .forgot-password:focus {
    outline: 2px solid var(--dark-accent-blue) !important;
    outline-offset: 2px !important;
}

/* ===== FONT AWESOME ICONS DARK MODE ===== */
  body.dark.mode .fas,
  body.dark.mode .far,
  body.dark.mode .fal,
  body.dark.mode .fab,
  body.dark.mode .fa-solid,
  body.dark.mode .fa-regular,
  body.dark.mode .fa-light,
  body.dark.mode .fa-brands,
  body.dark.mode [class*="fa-"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    color: inherit !important;
  }

/* Specific icon styling for form elements */
body.dark.mode .form-floating label .fas,
body.dark.mode .form-floating label .far,
body.dark.mode .form-floating label [class*="fa-"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    text-shadow: none !important;
    filter: none !important;
}

/* Specific styling for professional guideline icons to ensure transparency */
body.dark.mode .professional-guideline-icon .fas,
body.dark.mode .professional-guideline-icon .far,
body.dark.mode .professional-guideline-icon [class*="fa-"],
body.dark.mode .professional-card-icon .fas,
body.dark.mode .professional-card-icon .far,
body.dark.mode .professional-card-icon [class*="fa-"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    text-shadow: none !important;
    filter: none !important;
}

/* Additional styling for buttons, datatables, and other elements with FontAwesome icons */
body.dark.mode .btn .fas,
body.dark.mode .btn .far,
body.dark.mode .btn [class*="fa-"],
body.dark.mode .m-nav__link-icon.fas,
body.dark.mode .m-nav__link-icon.far,
body.dark.mode .m-nav__link-icon[class*="fa-"],
body.dark.mode .dt-buttons .fas,
body.dark.mode .dt-buttons .far,
body.dark.mode .dt-buttons [class*="fa-"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    text-shadow: none !important;
    filter: none !important;
}

/* Comprehensive styling for all FontAwesome icons in various contexts to ensure transparency */
body.dark.mode .m-badge .fas,
body.dark.mode .m-badge .far,
body.dark.mode .m-badge [class*="fa-"],
body.dark.mode .table .fas,
body.dark.mode .table .far,
body.dark.mode .table [class*="fa-"],
body.dark.mode h1 .fas, body.dark.mode h1 .far, body.dark.mode h1 [class*="fa-"],
body.dark.mode h2 .fas, body.dark.mode h2 .far, body.dark.mode h2 [class*="fa-"],
body.dark.mode h3 .fas, body.dark.mode h3 .far, body.dark.mode h3 [class*="fa-"],
body.dark.mode h4 .fas, body.dark.mode h4 .far, body.dark.mode h4 [class*="fa-"],
body.dark.mode h5 .fas, body.dark.mode h5 .far, body.dark.mode h5 [class*="fa-"],
body.dark.mode span .fas, body.dark.mode span .far, body.dark.mode span [class*="fa-"],
body.dark.mode div .fas, body.dark.mode div .far, body.dark.mode div [class*="fa-"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    text-shadow: none !important;
    filter: none !important;
}

/* ===== LOGIN PAGE DARK MODE TOGGLE ===== */
.dark-mode-toggle {
    background: rgba(0, 0, 0, 0.08) !important;
    border: 1px solid rgba(0, 0, 0, 0.25) !important;
    border-radius: 20px !important;
    padding: 6px 12px !important;
    color: #333333 !important;
    font-size: 14px !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15) !important;
}

.dark-mode-toggle:hover {
    background: rgba(0, 0, 0, 0.12) !important;
    border-color: rgba(0, 0, 0, 0.35) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
}

body.dark.mode .dark-mode-toggle {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
    color: var(--dark-text-primary) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

body.dark.mode .dark-mode-toggle:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4) !important;
}

.dark-mode-toggle i {
    font-size: 16px !important;
    color: inherit !important;
}

/* ===== SCROLL BARS DARK MODE ===== */
body.dark.mode ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

body.dark.mode ::-webkit-scrollbar-track {
    background: var(--dark-secondary-bg);
}

body.dark.mode ::-webkit-scrollbar-thumb {
    background: var(--dark-border);
    border-radius: 4px;
}

body.dark.mode ::-webkit-scrollbar-thumb:hover {
    background: var(--dark-hover);
}

/* ===== PROFESSIONAL MEMBERSHIP BUTTONS DARK MODE ===== */
body.dark.mode .professional-save-btn {
    background: #10b981 !important;
    color: var(--dark-text-primary) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
    border: 2px solid #059669 !important;
}

body.dark.mode .professional-save-btn:hover {
    background: #059669 !important;
    color: var(--dark-text-primary) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.4) !important;
    border-color: #047857 !important;
}

body.dark.mode .professional-back-btn {
    background: var(--dark-secondary-bg) !important;
    color: var(--dark-text-primary) !important;
    border: 2px solid var(--dark-border) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

body.dark.mode .professional-back-btn:hover {
    background: var(--dark-hover) !important;
    color: var(--dark-text-primary) !important;
    border-color: var(--dark-text-secondary) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.4) !important;
}

body.dark.mode .professional-next-of-kin-create-btn {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%) !important;
    color: var(--dark-text-primary) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
    border: 2px solid #2563eb !important;
}

body.dark.mode .professional-next-of-kin-create-btn:hover {
    background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%) !important;
    color: var(--dark-text-primary) !important;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4) !important;
    border-color: #1d4ed8 !important;
}

/* ===== TRANSITION FOR SMOOTH MODE SWITCHING ===== */
* {
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease !important;
}

/* ===== FORCE DARK MODE ON STUBBORN ELEMENTS ===== */
body.dark-mode * {
    border-color: var(--dark-border) !important;
}

/* Exclude login page and left side menu from the catch-all rule that forces inherit, but allow submenus to inherit dark mode styles */
body.dark-mode:not(.login-modern) *:not(.btn):not([class*="btn-"]):not(.badge):not([class*="badge-"]):not(.alert):not([class*="alert-"]):not(.progress-bar):not(.m-menu__link-icon):not([class*="flaticon-"]):not(.m-aside-left):not(.m-aside-menu):not(.m-menu__nav):not(.m-menu__item):not(.m-menu__link):not(.m-brand) {
    background-color: inherit !important;
    color: inherit !important;
}