/* ═══════════════════════════════════════════════════════════
   GestPro Design System
   Section 1 — Light mode (always active)
   Section 2 — Dark mode ([data-bs-theme=dark])
═══════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────
   SECTION 1 · LIGHT MODE
───────────────────────────────────────── */

/* ── Tokens ── */
:root {
    --gp-accent:       #6366f1;
    --gp-accent-dark:  #4f46e5;
    --gp-accent-soft:  #eef2ff;
    --gp-accent-mid:   #c7d2fe;
    --gp-purple:       #8b5cf6;
    --gp-success:      #10b981;
    --gp-warning:      #f59e0b;
    --gp-danger:       #ef4444;
    --gp-info:         #06b6d4;

    --gp-bg:           #f1f5f9;
    --gp-white:        #ffffff;
    --gp-border:       #e2e8f0;
    --gp-border-soft:  #f1f5f9;

    --gp-text:         #0f172a;
    --gp-text-body:    #475569;
    --gp-text-muted:   #94a3b8;

    --gp-shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
    --gp-shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
    --gp-shadow-md: 0 4px 16px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
    --gp-shadow-accent: 0 4px 20px rgba(99,102,241,0.25);

    /* Velzon topbar is fixed; keep content below it */
    --gp-topbar-height: 70px;
}

/* ── Base font ── */
html, body, * {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
}

/* Brand wordmark — Syne (distinct from UI sans) */
.gp-logo-wordmark {
    font-family: 'Syne', sans-serif !important;
    font-weight: 700;
    letter-spacing: -0.04em;
    font-feature-settings: "kern" 1;
}

/* Arabic (RTL): Tajawal — readable UI Arabic; keep icon fonts intact */
html[dir="rtl"] {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

html[dir="rtl"] body {
    font-family: 'Tajawal', 'Segoe UI', Tahoma, sans-serif !important;
}

html[dir="rtl"] body * {
    font-family: inherit !important;
}

/* Remix Icon: class order is often "align-middle … ri-foo" — match any class containing ri- */
html[dir="rtl"] [class*="ri-"] {
    font-family: "remixicon" !important;
    font-style: normal;
    font-weight: normal;
    direction: ltr;
    unicode-bidi: isolate;
}

html[dir="rtl"] .mdi,
html[dir="rtl"] .mdi:before,
html[dir="rtl"] .mdi-set:before {
    font-family: "Material Design Icons" !important;
    direction: ltr;
    unicode-bidi: isolate;
}

/* Boxicons (header: moon, bell, fullscreen) — must not inherit Tajawal */
html[dir="rtl"] .bx,
html[dir="rtl"] .bx:before {
    font-family: "boxicons" !important;
    font-style: normal;
    font-weight: normal;
    direction: ltr;
    unicode-bidi: isolate;
}

html[dir="rtl"] .gp-logo-wordmark {
    font-family: 'Syne', sans-serif !important;
}

/* Keep topbar icon glyphs stable in RTL */
html[dir="rtl"] #page-topbar .bx,
html[dir="rtl"] #page-topbar .mdi,
html[dir="rtl"] #page-topbar [class*="ri-"] {
    display: inline-block;
}

/* ── Page background ── */
body {
    background-color: var(--gp-bg) !important;
    color: var(--gp-text) !important;
}

/* ══════════════════════════════════════════════════════════
   TOPBAR / HEADER
══════════════════════════════════════════════════════════ */
#page-topbar {
    background: var(--gp-white) !important;
    border-bottom: 1px solid var(--gp-border) !important;
    box-shadow: var(--gp-shadow-sm) !important;
}
.navbar-header { height: 60px !important; }

.hamburger-icon span {
    background-color: var(--gp-text-body) !important;
    height: 2px !important; border-radius: 2px !important;
    transition: background-color 0.2s !important;
}

.app-search .form-control {
    background: var(--gp-bg) !important;
    border: 1.5px solid var(--gp-border) !important;
    border-radius: 10px !important;
    color: var(--gp-text) !important;
    font-size: 13px !important; height: 38px !important;
    box-shadow: none !important;
    transition: border-color 0.22s, background 0.22s !important;
}
.app-search .form-control:focus {
    background: var(--gp-white) !important;
    border-color: var(--gp-accent) !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.13) !important;
}
.app-search .form-control::placeholder { color: var(--gp-text-muted) !important; }
.app-search .mdi-magnify { color: var(--gp-text-muted) !important; }

/* Submit control replaces Velzon’s span.search-widget-icon (same placement) */
.app-search button.search-widget-icon {
    position: absolute;
    z-index: 10;
    font-size: 18px;
    line-height: 38px;
    right: 13px;
    top: 0;
    cursor: pointer;
    color: var(--gp-text-muted) !important;
}
html[dir="rtl"] .app-search button.search-widget-icon {
    right: auto;
    left: 13px;
}

.btn-topbar, .btn-ghost-secondary {
    color: var(--gp-text-body) !important;
    background: transparent !important; border: none !important;
    transition: background 0.18s, color 0.18s !important;
}
.btn-topbar:hover, .btn-ghost-secondary:hover {
    background: var(--gp-accent-soft) !important;
    color: var(--gp-accent) !important;
}

#page-header-user-dropdown .user-name-text  { color: var(--gp-text) !important; font-weight: 600 !important; font-size: 13px !important; }
#page-header-user-dropdown .user-name-sub-text { color: var(--gp-text-muted) !important; font-size: 11px !important; }

.topbar-badge { background: var(--gp-accent) !important; font-size: 9px !important; }

.dropdown-head.bg-primary,
.dropdown-head.bg-primary.bg-pattern {
    background: linear-gradient(135deg, var(--gp-accent) 0%, var(--gp-purple) 100%) !important;
    border-radius: 12px 12px 0 0 !important;
}

/* ══════════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════════ */
.app-menu.navbar-menu {
    background: var(--gp-white) !important;
    border-right: 1px solid var(--gp-border) !important;
    box-shadow: 2px 0 12px rgba(0,0,0,0.05) !important;
}
.navbar-brand-box {
    background: var(--gp-white) !important;
    border-bottom: 1px solid var(--gp-border) !important;
}
.sidebar-background { display: none !important; }

.menu-title > span {
    color: var(--gp-text-muted) !important;
    font-size: 10px !important; font-weight: 700 !important;
    letter-spacing: 1.6px !important; text-transform: uppercase !important;
}

#navbar-nav .nav-item > .nav-link,
#navbar-nav .nav-item > .menu-link {
    color: var(--gp-text-body) !important;
    font-size: 13px !important; font-weight: 500 !important;
    border-radius: 9px !important;
    margin: 1px 10px !important; padding: 9px 14px !important;
    transition: background 0.18s, color 0.18s !important;
    display: flex !important; align-items: center !important; gap: 10px !important;
}
#navbar-nav .nav-item > .nav-link i,
#navbar-nav .nav-item > .nav-link .mdi,
#navbar-nav .nav-item > .menu-link i,
#navbar-nav .nav-item > .menu-link .mdi {
    font-size: 17px !important; width: 20px !important;
    text-align: center !important; flex-shrink: 0 !important;
    color: var(--gp-text-muted) !important; transition: color 0.18s !important;
}
#navbar-nav .nav-item > .nav-link:hover,
#navbar-nav .nav-item > .menu-link:hover {
    background: var(--gp-accent-soft) !important; color: var(--gp-accent) !important;
}
#navbar-nav .nav-item > .nav-link:hover i,
#navbar-nav .nav-item > .nav-link:hover .mdi,
#navbar-nav .nav-item > .menu-link:hover i,
#navbar-nav .nav-item > .menu-link:hover .mdi { color: var(--gp-accent) !important; }
#navbar-nav .nav-item > .nav-link.active,
#navbar-nav .nav-item > .menu-link.active {
    background: var(--gp-accent-soft) !important; color: var(--gp-accent) !important; font-weight: 600 !important;
}
#navbar-nav .nav-item > .nav-link.active i,
#navbar-nav .nav-item > .nav-link.active .mdi,
#navbar-nav .nav-item > .menu-link.active i,
#navbar-nav .nav-item > .menu-link.active .mdi { color: var(--gp-accent) !important; }

.menu-dropdown { padding-left: 4px !important; }
.menu-dropdown .nav-link {
    color: var(--gp-text-body) !important;
    font-size: 12.5px !important; font-weight: 400 !important;
    padding: 7px 14px 7px 42px !important;
    border-radius: 8px !important; margin: 1px 10px !important;
    transition: background 0.18s, color 0.18s !important;
}
.menu-dropdown .nav-link:hover  { background: var(--gp-accent-soft) !important; color: var(--gp-accent) !important; }
.menu-dropdown .nav-link.active { background: var(--gp-accent-soft) !important; color: var(--gp-accent) !important; font-weight: 600 !important; }

#scrollbar { overflow-y: auto !important; overflow-x: hidden !important; }
#scrollbar::-webkit-scrollbar { width: 4px; }
#scrollbar::-webkit-scrollbar-track { background: transparent; }
#scrollbar::-webkit-scrollbar-thumb { background: var(--gp-border); border-radius: 4px; }

/* ══════════════════════════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════════════════════════ */
.main-content { background: var(--gp-bg) !important; }
.page-content  { padding: calc(var(--gp-topbar-height) + 20px) 24px 80px !important; }

/* ══════════════════════════════════════════════════════════
   BREADCRUMB (Elegant pill / card style)
═══════════════════════════════════════════════════════════ */
.gp-breadcrumb-card {
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid var(--gp-border);
    border-radius: 999px;
    padding: 6px 8px;
    box-shadow: var(--gp-shadow-xs);
}

[data-bs-theme=dark] .gp-breadcrumb-card {
    background: rgba(20, 22, 27, 0.65);
    border-color: rgba(255, 255, 255, 0.10);
}

.gp-breadcrumb-card .breadcrumb {
    align-items: center;
    gap: 6px;
}

.gp-breadcrumb-card .breadcrumb-item + .breadcrumb-item::before {
    content: "›";
    color: var(--gp-text-muted);
    padding: 0 6px;
}

.gp-breadcrumb-pill {
    display: inline-flex;
    align-items: center;
    height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .2px;
    color: rgba(31, 45, 61, 0.78);
    background: rgba(99, 102, 241, 0.10);
}

.gp-breadcrumb-pill-active {
    color: #fff;
    background: linear-gradient(135deg, var(--gp-accent) 0%, var(--gp-purple) 100%);
    box-shadow: var(--gp-shadow-accent);
}

[data-bs-theme=dark] .gp-breadcrumb-pill {
    color: rgba(255, 255, 255, 0.78);
    background: rgba(99, 102, 241, 0.18);
}

.gp-breadcrumb-card .breadcrumb-item.active {
    color: inherit;
}

/* RTL: flip separator */
html[dir="rtl"] .gp-breadcrumb-card .breadcrumb-item + .breadcrumb-item::before {
    content: "‹";
}

/* ══════════════════════════════════════════════════════════
   CARDS
══════════════════════════════════════════════════════════ */
.card {
    border: 1px solid var(--gp-border) !important;
    border-radius: 14px !important;
    box-shadow: var(--gp-shadow-sm) !important;
    background: var(--gp-white) !important;
    transition: box-shadow 0.22s !important;
}
.card:hover { box-shadow: var(--gp-shadow-md) !important; }
.card-header {
    background: transparent !important;
    border-bottom: 1px solid var(--gp-border-soft) !important;
    padding: 14px 20px !important; border-radius: 14px 14px 0 0 !important;
}
.card-header.border-bottom-dashed { border-bottom-style: solid !important; border-bottom-color: var(--gp-border-soft) !important; }
.card-title  { font-size: 13px !important; font-weight: 700 !important; color: var(--gp-text) !important; }
.card-body   { padding: 18px 20px !important; }

/* Stat card accent bar */
.gp-stat-card { position: relative; overflow: hidden; }
.gp-stat-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0;
    height: 3px; border-radius: 14px 14px 0 0;
}
.gp-stat-card.accent-indigo::before { background: linear-gradient(90deg,var(--gp-accent),var(--gp-purple)); }
.gp-stat-card.accent-green::before  { background: linear-gradient(90deg,var(--gp-success),#34d399); }
.gp-stat-card.accent-amber::before  { background: linear-gradient(90deg,var(--gp-warning),#fcd34d); }
.gp-stat-card.accent-cyan::before   { background: linear-gradient(90deg,var(--gp-info),#67e8f9); }

.gp-icon-box {
    width: 46px; height: 46px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; flex-shrink: 0;
}
.gp-icon-box.indigo { background: var(--gp-accent-soft); color: var(--gp-accent); }
.gp-icon-box.green  { background: #d1fae5; color: var(--gp-success); }
.gp-icon-box.amber  { background: #fef3c7; color: var(--gp-warning); }
.gp-icon-box.cyan   { background: #cffafe; color: var(--gp-info); }

/* ══════════════════════════════════════════════════════════
   PAGE TITLE
══════════════════════════════════════════════════════════ */
.page-title-box { padding: 0 0 20px !important; }
.page-title-box h4 {
    font-size: 20px !important; font-weight: 800 !important;
    color: var(--gp-text) !important; letter-spacing: -0.5px !important; margin: 0 !important;
}

/* ══════════════════════════════════════════════════════════
   TABLES
══════════════════════════════════════════════════════════ */
.table { font-size: 13px !important; color: var(--gp-text-body) !important; margin: 0 !important; }
.table thead th {
    font-size: 10.5px !important; font-weight: 700 !important;
    letter-spacing: 1px !important; text-transform: uppercase !important;
    color: var(--gp-text-muted) !important; background: #f8fafc !important;
    border-bottom: 1px solid var(--gp-border) !important;
    padding: 10px 14px !important; white-space: nowrap !important;
}
.table tbody td {
    padding: 10px 14px !important;
    border-bottom: 1px solid var(--gp-border-soft) !important;
    vertical-align: middle !important; color: var(--gp-text-body) !important;
}
.table tbody tr:last-child td { border-bottom: none !important; }
.table-striped > tbody > tr:nth-of-type(odd) > * { background-color: rgba(99,102,241,0.02) !important; }
.table-light { background: #f8fafc !important; color: var(--gp-text-muted) !important; }
.table-responsive { border-radius: 0 0 14px 14px !important; }

/* Progress */
.progress { background: var(--gp-border-soft) !important; border-radius: 6px !important; height: 7px !important; overflow: hidden !important; }
.progress-bar.bg-success { background: linear-gradient(90deg,var(--gp-accent),var(--gp-purple)) !important; border-radius: 6px !important; }

/* ══════════════════════════════════════════════════════════
   BADGES
══════════════════════════════════════════════════════════ */
.badge { font-size: 10.5px !important; font-weight: 600 !important; padding: 3.5px 8px !important; border-radius: 6px !important; }

/* ══════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════ */
.btn { border-radius: 9px !important; font-size: 13px !important; font-weight: 600 !important; transition: all 0.2s !important; }
.btn-primary, .btn-primary:focus {
    background: var(--gp-accent) !important; border-color: var(--gp-accent) !important;
    box-shadow: 0 4px 14px rgba(99,102,241,0.3) !important;
}
.btn-primary:hover {
    background: var(--gp-accent-dark) !important; border-color: var(--gp-accent-dark) !important;
    box-shadow: 0 6px 20px rgba(99,102,241,0.4) !important;
}
.btn-soft-primary {
    background: var(--gp-accent-soft) !important; color: var(--gp-accent) !important;
    border: 1px solid var(--gp-accent-mid) !important;
}
.btn-soft-primary:hover { background: var(--gp-accent) !important; color: var(--gp-white) !important; border-color: var(--gp-accent) !important; }
.btn-soft-warning { background: #fef3c7 !important; color: var(--gp-warning) !important; border: 1px solid #fde68a !important; }
.btn-soft-info    { background: #cffafe !important; color: var(--gp-info) !important; border: 1px solid #a5f3fc !important; }

/* ══════════════════════════════════════════════════════════
   DROPDOWNS
══════════════════════════════════════════════════════════ */
.dropdown-menu {
    border: 1px solid var(--gp-border) !important; border-radius: 12px !important;
    box-shadow: var(--gp-shadow-md) !important; padding: 6px !important;
    background: var(--gp-white) !important;
}
.dropdown-item {
    border-radius: 7px !important; font-size: 13px !important;
    color: var(--gp-text-body) !important; padding: 8px 12px !important;
    transition: background 0.15s, color 0.15s !important;
}
.dropdown-item:hover, .dropdown-item:focus { background: var(--gp-accent-soft) !important; color: var(--gp-accent) !important; }
.dropdown-divider { border-color: var(--gp-border) !important; margin: 4px 0 !important; }
.dropdown-header {
    font-size: 10px !important; font-weight: 700 !important;
    letter-spacing: 1.2px !important; text-transform: uppercase !important;
    color: var(--gp-text-muted) !important; padding: 6px 12px 4px !important;
}

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
.footer {
    background: var(--gp-white) !important; border-top: 1px solid var(--gp-border) !important;
    color: var(--gp-text-muted) !important; font-size: 12px !important;
}

/* ══════════════════════════════════════════════════════════
   ALERTS
══════════════════════════════════════════════════════════ */
.alert { border-radius: 10px !important; border: none !important; font-size: 13px !important; }

/* ══════════════════════════════════════════════════════════
   FORM CONTROLS
══════════════════════════════════════════════════════════ */
.form-control, .form-select {
    border: 1.5px solid var(--gp-border) !important; border-radius: 9px !important;
    background: var(--gp-bg) !important; color: var(--gp-text) !important;
    font-size: 13px !important; transition: border-color 0.22s, box-shadow 0.22s !important;
}
.form-control:focus, .form-select:focus {
    background: var(--gp-white) !important; border-color: var(--gp-accent) !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.13) !important; color: var(--gp-text) !important;
}
.form-label {
    font-size: 12px !important; font-weight: 600 !important;
    color: var(--gp-text-body) !important; letter-spacing: 0.4px !important;
    text-transform: uppercase !important; margin-bottom: 6px !important;
}

/* Modals */
.modal-content  { border: none !important; border-radius: 16px !important; box-shadow: 0 24px 60px rgba(0,0,0,0.15) !important; overflow: hidden !important; }
.modal-header   { background: var(--gp-white) !important; border-bottom: 1px solid var(--gp-border) !important; padding: 18px 24px !important; }
.modal-title    { font-size: 15px !important; font-weight: 700 !important; color: var(--gp-text) !important; }
.modal-body     { padding: 24px !important; }
.modal-footer   { border-top: 1px solid var(--gp-border) !important; padding: 14px 24px !important; }

/* ══════════════════════════════════════════════════════════
   DATATABLE
══════════════════════════════════════════════════════════ */
.dataTables_wrapper .dataTables_filter input {
    border: 1.5px solid var(--gp-border) !important; border-radius: 9px !important;
    padding: 5px 12px !important; font-size: 13px !important;
    background: var(--gp-bg) !important; color: var(--gp-text) !important;
    outline: none !important; transition: border-color 0.2s !important;
}
.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--gp-accent) !important; background: var(--gp-white) !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
}
.paginate_button.current, .paginate_button.current:hover {
    background: var(--gp-accent) !important; border-color: var(--gp-accent) !important;
    color: white !important; border-radius: 7px !important;
}
.paginate_button:hover {
    background: var(--gp-accent-soft) !important; border-color: var(--gp-accent-mid) !important;
    color: var(--gp-accent) !important; border-radius: 7px !important;
}

/* ══════════════════════════════════════════════════════════
   SELECT2
══════════════════════════════════════════════════════════ */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border: 1.5px solid var(--gp-border) !important; border-radius: 9px !important;
    background: var(--gp-bg) !important; height: 38px !important;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--gp-accent) !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
}
.select2-dropdown {
    border: 1.5px solid var(--gp-border) !important;
    border-radius: 10px !important; box-shadow: var(--gp-shadow-md) !important; overflow: hidden !important;
}
.select2-container--default .select2-results__option--highlighted { background: var(--gp-accent) !important; }

/* ══════════════════════════════════════════════════════════
   MISC
══════════════════════════════════════════════════════════ */
.vertical-overlay { background: rgba(15,23,42,0.25) !important; backdrop-filter: blur(2px) !important; }


/* ─────────────────────────────────────────
   SECTION 2 · DARK MODE [data-bs-theme=dark]
   Every rule here wins over Section 1 by
   having [data-bs-theme=dark] in the selector
───────────────────────────────────────── */

[data-bs-theme=dark] {
    --gp-bg:           #0f172a;
    --gp-white:        #1e293b;
    --gp-border:       #334155;
    --gp-border-soft:  #253147;
    --gp-text:         #f1f5f9;
    --gp-text-body:    #94a3b8;
    --gp-text-muted:   #64748b;
    --gp-accent-soft:  rgba(99,102,241,0.15);
    --gp-accent-mid:   rgba(99,102,241,0.30);
    --gp-shadow-sm:    0 1px 3px rgba(0,0,0,0.3), 0 1px 2px rgba(0,0,0,0.2);
    --gp-shadow-md:    0 4px 16px rgba(0,0,0,0.4), 0 2px 6px rgba(0,0,0,0.2);
}

[data-bs-theme=dark] body    { background-color: #0f172a !important; color: #f1f5f9 !important; }
[data-bs-theme=dark] .main-content { background: #0f172a !important; }

/* Header */
[data-bs-theme=dark] #page-topbar {
    background: #1e293b !important;
    border-bottom-color: #334155 !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.35) !important;
}
[data-bs-theme=dark] .hamburger-icon span { background-color: #94a3b8 !important; }

[data-bs-theme=dark] .app-search .form-control {
    background: rgba(255,255,255,0.05) !important;
    border-color: #334155 !important; color: #f1f5f9 !important;
}
[data-bs-theme=dark] .app-search .form-control:focus {
    background: rgba(99,102,241,0.1) !important; border-color: #6366f1 !important;
}
[data-bs-theme=dark] .app-search .form-control::placeholder { color: #64748b !important; }
[data-bs-theme=dark] .app-search .mdi-magnify { color: #64748b !important; }
[data-bs-theme=dark] .app-search button.search-widget-icon { color: #64748b !important; }

[data-bs-theme=dark] .btn-topbar,
[data-bs-theme=dark] .btn-ghost-secondary { color: #94a3b8 !important; }
[data-bs-theme=dark] .btn-topbar:hover,
[data-bs-theme=dark] .btn-ghost-secondary:hover {
    background: rgba(99,102,241,0.15) !important; color: #818cf8 !important;
}

[data-bs-theme=dark] #page-header-user-dropdown .user-name-text      { color: #f1f5f9 !important; }
[data-bs-theme=dark] #page-header-user-dropdown .user-name-sub-text  { color: #64748b !important; }

/* Sidebar */
[data-bs-theme=dark] .app-menu.navbar-menu {
    background: #1e293b !important; border-right-color: #334155 !important;
    box-shadow: 2px 0 12px rgba(0,0,0,0.3) !important;
}
[data-bs-theme=dark] .navbar-brand-box {
    background: #1e293b !important; border-bottom-color: #334155 !important;
}
[data-bs-theme=dark] .menu-title > span { color: #475569 !important; }

[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link { color: #94a3b8 !important; }
[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link i,
[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link .mdi,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link i,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link .mdi { color: #475569 !important; }

[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link:hover,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link:hover {
    background: rgba(99,102,241,0.15) !important; color: #818cf8 !important;
}
[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link:hover i,
[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link:hover .mdi,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link:hover i,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link:hover .mdi { color: #818cf8 !important; }

[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link.active,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link.active {
    background: rgba(99,102,241,0.18) !important; color: #818cf8 !important;
}
[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link.active i,
[data-bs-theme=dark] #navbar-nav .nav-item > .nav-link.active .mdi,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link.active i,
[data-bs-theme=dark] #navbar-nav .nav-item > .menu-link.active .mdi { color: #818cf8 !important; }

[data-bs-theme=dark] .menu-dropdown .nav-link { color: #94a3b8 !important; }
[data-bs-theme=dark] .menu-dropdown .nav-link:hover  { background: rgba(99,102,241,0.15) !important; color: #818cf8 !important; }
[data-bs-theme=dark] .menu-dropdown .nav-link.active { background: rgba(99,102,241,0.18) !important; color: #818cf8 !important; }

[data-bs-theme=dark] #scrollbar::-webkit-scrollbar-thumb { background: #334155; }

/* Cards */
[data-bs-theme=dark] .card {
    background: #1e293b !important; border-color: #334155 !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
}
[data-bs-theme=dark] .card:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.4) !important; }
[data-bs-theme=dark] .card-header { border-bottom-color: #334155 !important; }
[data-bs-theme=dark] .card-title  { color: #f1f5f9 !important; }

/* Dashboard gp-card / gp-stat */
[data-bs-theme=dark] .gp-card { background: #1e293b !important; border-color: #334155 !important; }
[data-bs-theme=dark] .gp-card-head  { border-bottom-color: #334155 !important; }
[data-bs-theme=dark] .gp-card-title { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-stat { background: #1e293b !important; border-color: #334155 !important; }
[data-bs-theme=dark] .gp-stat:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.4) !important; }
[data-bs-theme=dark] .gp-stat-num  { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-stat-lbl  { color: #64748b !important; }
[data-bs-theme=dark] .gp-stat-hint { color: #64748b !important; }
[data-bs-theme=dark] .ico-indigo { background: rgba(99,102,241,0.18) !important; color: #818cf8 !important; }
[data-bs-theme=dark] .ico-green  { background: rgba(16,185,129,0.15) !important; color: #34d399 !important; }
[data-bs-theme=dark] .ico-amber  { background: rgba(245,158,11,0.15) !important; color: #fcd34d !important; }
[data-bs-theme=dark] .ico-cyan   { background: rgba(6,182,212,0.15)  !important; color: #67e8f9 !important; }

/* Page title / welcome */
[data-bs-theme=dark] .page-title-box h4 { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-welcome-title  { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-welcome-sub    { color: #64748b !important; }

/* Tables */
[data-bs-theme=dark] .table { color: #94a3b8 !important; }
[data-bs-theme=dark] .table thead th {
    background: #253147 !important; color: #64748b !important; border-bottom-color: #334155 !important;
}
[data-bs-theme=dark] .table tbody td {
    color: #94a3b8 !important; border-bottom-color: #253147 !important;
}
[data-bs-theme=dark] .table-striped > tbody > tr:nth-of-type(odd) > * { background-color: rgba(99,102,241,0.04) !important; }
[data-bs-theme=dark] .table-light { background: #253147 !important; color: #64748b !important; }

[data-bs-theme=dark] .gp-res-table th { background: #253147 !important; color: #64748b !important; border-bottom-color: #334155 !important; }
[data-bs-theme=dark] .gp-res-table td { color: #94a3b8 !important; border-bottom-color: #253147 !important; }
[data-bs-theme=dark] .gp-res-table tbody tr:hover td { background: #253147 !important; }
[data-bs-theme=dark] .gp-plate { background: #334155 !important; color: #f1f5f9 !important; }

/* Status / Revenue / Top rows */
[data-bs-theme=dark] .gp-status-row-item { border-bottom-color: #253147 !important; }
[data-bs-theme=dark] .gp-status-row-item:hover { background: #253147 !important; }
[data-bs-theme=dark] .gp-status-count  { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-status-amount { color: #64748b !important; }
[data-bs-theme=dark] .gp-rev-row { border-bottom-color: #253147 !important; }
[data-bs-theme=dark] .gp-rev-row:hover { background: #253147 !important; }
[data-bs-theme=dark] .gp-rev-month  { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-rev-nb     { color: #64748b !important; }
[data-bs-theme=dark] .gp-rev-amount { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-rev-bar-bg { background: #334155 !important; }
[data-bs-theme=dark] .gp-top-row { border-bottom-color: #253147 !important; }
[data-bs-theme=dark] .gp-top-row:hover { background: #253147 !important; }
[data-bs-theme=dark] .gp-avatar  { background: rgba(99,102,241,0.18) !important; color: #818cf8 !important; }
[data-bs-theme=dark] .gp-top-name   { color: #f1f5f9 !important; }
[data-bs-theme=dark] .gp-top-nb     { color: #64748b !important; }
[data-bs-theme=dark] .gp-top-amount { color: #818cf8 !important; }

/* Progress */
[data-bs-theme=dark] .progress { background: #334155 !important; }

/* Dropdowns */
[data-bs-theme=dark] .dropdown-menu { background: #1e293b !important; border-color: #334155 !important; }
[data-bs-theme=dark] .dropdown-item { color: #94a3b8 !important; }
[data-bs-theme=dark] .dropdown-item:hover,
[data-bs-theme=dark] .dropdown-item:focus { background: rgba(99,102,241,0.15) !important; color: #818cf8 !important; }
[data-bs-theme=dark] .dropdown-divider { border-color: #334155 !important; }
[data-bs-theme=dark] .dropdown-header  { color: #475569 !important; }

/* Footer */
[data-bs-theme=dark] .footer {
    background: #1e293b !important; border-top-color: #334155 !important; color: #64748b !important;
}

/* Alerts */
[data-bs-theme=dark] .alert-warning {
    background: rgba(245,158,11,0.12) !important;
    color: #fcd34d !important; border-color: rgba(245,158,11,0.25) !important;
}

/* Form controls */
[data-bs-theme=dark] .form-control,
[data-bs-theme=dark] .form-select {
    background: rgba(255,255,255,0.05) !important;
    border-color: #334155 !important; color: #f1f5f9 !important;
}
[data-bs-theme=dark] .form-control:focus,
[data-bs-theme=dark] .form-select:focus {
    background: rgba(99,102,241,0.08) !important;
    border-color: #6366f1 !important; color: #f1f5f9 !important;
}
[data-bs-theme=dark] .form-control::placeholder { color: #475569 !important; }
[data-bs-theme=dark] .form-label { color: #94a3b8 !important; }

/* Modals */
[data-bs-theme=dark] .modal-content  { background: #1e293b !important; }
[data-bs-theme=dark] .modal-header   { background: #1e293b !important; border-bottom-color: #334155 !important; }
[data-bs-theme=dark] .modal-title    { color: #f1f5f9 !important; }
[data-bs-theme=dark] .modal-footer   { border-top-color: #334155 !important; }

/* Buttons */
[data-bs-theme=dark] .btn-soft-primary {
    background: rgba(99,102,241,0.18) !important; color: #818cf8 !important;
    border-color: rgba(99,102,241,0.3) !important;
}
[data-bs-theme=dark] .btn-soft-primary:hover { background: #6366f1 !important; color: #fff !important; }
[data-bs-theme=dark] .btn-soft-warning { background: rgba(245,158,11,0.15) !important; color: #fcd34d !important; border-color: rgba(245,158,11,0.3) !important; }
[data-bs-theme=dark] .btn-soft-info    { background: rgba(6,182,212,0.15)  !important; color: #67e8f9 !important; border-color: rgba(6,182,212,0.3)  !important; }

/* DataTables */
[data-bs-theme=dark] .dataTables_wrapper .dataTables_filter input {
    background: rgba(255,255,255,0.05) !important; border-color: #334155 !important; color: #f1f5f9 !important;
}
[data-bs-theme=dark] .dataTables_wrapper .dataTables_filter input:focus { background: rgba(99,102,241,0.08) !important; border-color: #6366f1 !important; }
[data-bs-theme=dark] .dataTables_wrapper,
[data-bs-theme=dark] .dataTables_wrapper .dataTables_info,
[data-bs-theme=dark] .dataTables_wrapper .dataTables_length,
[data-bs-theme=dark] .dataTables_wrapper .dataTables_paginate { color: #94a3b8 !important; }
[data-bs-theme=dark] .paginate_button { color: #94a3b8 !important; }
[data-bs-theme=dark] .paginate_button:hover { background: rgba(99,102,241,0.15) !important; border-color: rgba(99,102,241,0.3) !important; color: #818cf8 !important; }
[data-bs-theme=dark] .paginate_button.current,
[data-bs-theme=dark] .paginate_button.current:hover { background: #6366f1 !important; border-color: #6366f1 !important; color: #fff !important; }

/* Select2 */
[data-bs-theme=dark] .select2-container--default .select2-selection--single,
[data-bs-theme=dark] .select2-container--default .select2-selection--multiple {
    background: rgba(255,255,255,0.05) !important; border-color: #334155 !important;
}
[data-bs-theme=dark] .select2-dropdown { background: #1e293b !important; border-color: #334155 !important; }
[data-bs-theme=dark] .select2-container--default .select2-results__option { color: #94a3b8 !important; background: transparent !important; }
[data-bs-theme=dark] .select2-container--default .select2-results__option--highlighted { background: rgba(99,102,241,0.2) !important; color: #818cf8 !important; }
[data-bs-theme=dark] .select2-selection__rendered { color: #f1f5f9 !important; }
[data-bs-theme=dark] .select2-search__field { background: rgba(255,255,255,0.05) !important; color: #f1f5f9 !important; border-color: #334155 !important; }

/* Sidebar logo text */
[data-bs-theme=dark] .navbar-brand-box [style*="color:#0f172a"] { color: #f1f5f9 !important; }
[data-bs-theme=dark] .navbar-brand-box [style*="color:#94a3b8"] { color: #475569 !important; }
