:root,
[data-theme="light"] {
    --primary:          #4F46E5;
    --primary-hover:    #4338CA;
    --primary-light:    #EEF2FF;
    --accent:           #6366F1;
    --bg:               #F1F5F9;
    --card:             #FFFFFF;
    --card-2:           #F8FAFC;
    --border:           #E2E8F0;
    --text:             #0F172A;
    --text-muted:       #64748B;
    --sidebar-w:        260px;
    --sidebar-bg:       #0F172A;
    --sidebar-bg-2:     #1E293B;
    --sidebar-fg:       #CBD5E1;
    --success:          #059669;
    --success-bg:       #ECFDF5;
    --warning:          #D97706;
    --warning-bg:       #FFFBEB;
    --danger:           #DC2626;
    --danger-bg:        #FEF2F2;
    --info:             #0284C7;
    --info-bg:          #F0F9FF;
    --shadow-sm:        0 1px 2px rgba(15, 23, 42, .06);
    --shadow:           0 1px 3px rgba(15, 23, 42, .08);
    --shadow-md:        0 4px 12px rgba(15, 23, 42, .08);
    --radius:           10px;
    --radius-lg:        14px;
}

[data-theme="dark"] {
    --primary:          #818CF8;
    --primary-hover:    #6366F1;
    --primary-light:    rgba(129,140,248,.15);
    --accent:           #818CF8;
    --bg:               #0B1220;
    --card:             #131C2E;
    --card-2:           #1B2538;
    --border:           #283449;
    --text:             #E5E9F0;
    --text-muted:       #94A3B8;
    --sidebar-bg:       #050B17;
    --sidebar-bg-2:     #0B1220;
    --sidebar-fg:       #94A3B8;
    --success:          #10B981;
    --success-bg:       rgba(16,185,129,.15);
    --warning:          #F59E0B;
    --warning-bg:       rgba(245,158,11,.15);
    --danger:           #F87171;
    --danger-bg:        rgba(248,113,113,.15);
    --info:             #38BDF8;
    --info-bg:          rgba(56,189,248,.15);
    --shadow-sm:        0 1px 2px rgba(0,0,0,.4);
    --shadow:           0 1px 3px rgba(0,0,0,.5);
    --shadow-md:        0 4px 12px rgba(0,0,0,.5);
}

* { box-sizing: border-box; }

html, body { height: 100%; }
body {
    background: var(--bg);
    color: var(--text);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-hover); }

h1, h2, h3, h4, h5, h6 { color: var(--text); font-weight: 600; }
.text-muted { color: var(--text-muted) !important; }
hr { border-color: var(--border); }

/* ============== LAYOUT ============== */
.layout { display: flex; min-height: 100vh; position: relative; }

/* ══════════════════════════════════════════════════════════════
   SIDEBAR — BEAUTIFUL REDESIGN
   ══════════════════════════════════════════════════════════════ */
.sidebar {
    width: var(--sidebar-w);
    background: linear-gradient(180deg, #0f172a 0%, #131d30 60%, #0c1628 100%);
    color: #cbd5e1;
    min-height: 100vh;
    position: fixed; top: 0; left: 0; bottom: 0;
    z-index: 1040;
    overflow-y: auto;
    overflow-x: hidden;
    transition: transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow: 4px 0 24px rgba(0,0,0,.22);
    display: flex;
    flex-direction: column;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,.08) transparent;
}
.sidebar::-webkit-scrollbar { width: 4px; }
.sidebar::-webkit-scrollbar-track { background: transparent; }
.sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.08); border-radius: 99px; }
.sidebar::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.15); }

/* subtle mesh overlay */
.sidebar::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 20% 15%, rgba(99,102,241,.12) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 70%, rgba(139,92,246,.08) 0%, transparent 50%);
    pointer-events: none;
    z-index: 0;
}
.sidebar > * { position: relative; z-index: 1; }

.main {
    flex: 1;
    margin-left: var(--sidebar-w);
    display: flex; flex-direction: column; min-height: 100vh;
    min-width: 0;
    transition: margin-left .28s cubic-bezier(.4,0,.2,1);
}
.content { flex: 1; padding: 20px 24px; max-width: 100%; overflow-x: hidden; }

.sidebar-backdrop {
    position: fixed; inset: 0;
    background: rgba(8,15,30,.65);
    backdrop-filter: blur(2px);
    z-index: 1035;
    display: none;
}

/* ── Brand / Logo ───────────────────────────────────────────── */
.sidebar .brand {
    padding: 20px 16px 16px;
    border-bottom: 1px solid rgba(255,255,255,.06);
    flex-shrink: 0;
}
.sidebar .brand a {
    color: #fff !important;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -.01em;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* ── Role Badge (injected via blade) ────────────────────────── */
.sidebar-role-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin: 10px 16px 0;
    padding: 5px 10px;
    border-radius: 8px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.sidebar-role-badge.role-super  { background: rgba(99,102,241,.18); color: #a5b4fc; border: 1px solid rgba(99,102,241,.25); }
.sidebar-role-badge.role-admin  { background: rgba(14,165,233,.15); color: #7dd3fc; border: 1px solid rgba(14,165,233,.2); }
.sidebar-role-badge.role-manager{ background: rgba(245,158,11,.15); color: #fcd34d; border: 1px solid rgba(245,158,11,.2); }
.sidebar-role-badge.role-user   { background: rgba(16,185,129,.15); color: #6ee7b7; border: 1px solid rgba(16,185,129,.2); }

/* ── Close button (mobile) ──────────────────────────────────── */
.sidebar-close {
    display: none;
    background: transparent; border: none; color: rgba(255,255,255,.5);
    font-size: 22px; padding: 4px 10px;
    position: absolute; top: 14px; right: 10px;
    cursor: pointer;
    transition: color .15s;
    z-index: 2;
}
.sidebar-close:hover { color: #fff; }

/* ── Nav Menu ───────────────────────────────────────────────── */
.sidebar .nav-menu { padding: 8px 8px 16px; flex: 1; }

/* Section labels */
.nav-section-label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 10px 4px;
    font-size: .67rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: rgba(255,255,255,.28);
    pointer-events: none;
    user-select: none;
}
.nav-section-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255,255,255,.07);
}

/* Nav links */
.sidebar .nav-link {
    color: #94a3b8;
    padding: 9px 12px;
    margin-bottom: 1px;
    display: flex; align-items: center; gap: 10px;
    border-radius: 9px;
    font-size: 13.5px;
    font-weight: 500;
    transition: background .15s, color .15s, transform .12s;
    position: relative;
    overflow: hidden;
}
.sidebar .nav-link::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%) scaleY(0);
    width: 3px;
    height: 60%;
    background: linear-gradient(180deg, #818cf8, #6366f1);
    border-radius: 0 3px 3px 0;
    transition: transform .15s;
}
.sidebar .nav-link .nav-icon {
    width: 30px; height: 30px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px;
    font-size: 14px;
    flex-shrink: 0;
    background: rgba(255,255,255,.05);
    transition: background .15s, color .15s;
}
.sidebar .nav-link:hover {
    background: rgba(255,255,255,.06);
    color: #e2e8f0;
    transform: translateX(2px);
}
.sidebar .nav-link:hover .nav-icon {
    background: rgba(99,102,241,.2);
    color: #a5b4fc;
}
.sidebar .nav-link:hover::before {
    transform: translateY(-50%) scaleY(1);
}
.sidebar .nav-link.active {
    background: linear-gradient(135deg, rgba(99,102,241,.25) 0%, rgba(79,70,229,.18) 100%);
    color: #fff !important;
    font-weight: 600;
}
.sidebar .nav-link.active::before {
    transform: translateY(-50%) scaleY(1);
    background: linear-gradient(180deg, #a5b4fc, #818cf8);
}
.sidebar .nav-link.active .nav-icon {
    background: rgba(99,102,241,.35);
    color: #c7d2fe;
}

/* Accordion chevron */
.sidebar .nav-chevron {
    margin-left: auto;
    font-size: 11px;
    opacity: .5;
    transition: transform .22s ease;
    flex-shrink: 0;
}
.sidebar .nav-link[aria-expanded="true"] .nav-chevron {
    transform: rotate(180deg);
    opacity: .8;
}

/* Badge (approval count etc.) */
.sidebar-badge {
    display: inline-flex;
    align-items: center; justify-content: center;
    min-width: 18px; height: 18px;
    padding: 0 5px;
    font-size: 10px; font-weight: 700;
    border-radius: 99px;
    background: #ef4444;
    color: #fff;
    margin-left: auto;
    flex-shrink: 0;
    box-shadow: 0 2px 6px rgba(239,68,68,.4);
    animation: pulseBadge 2s infinite;
}
@keyframes pulseBadge {
    0%,100% { box-shadow: 0 2px 6px rgba(239,68,68,.4); }
    50%      { box-shadow: 0 2px 12px rgba(239,68,68,.7); }
}

/* Sub-menu (collapse) */
.sidebar .collapse .nav-link {
    font-size: 13px;
    padding: 8px 12px 8px 16px;
    color: #64748b;
    margin-bottom: 0;
}
.sidebar .collapse .nav-link .nav-icon {
    width: 24px; height: 24px;
    font-size: 12px;
    background: transparent;
}
.sidebar .collapse .nav-link:hover { color: #cbd5e1; }
.sidebar .collapse .nav-link.active {
    color: #c7d2fe !important;
    background: rgba(99,102,241,.12);
}
.sidebar .collapse .nav-link.active .nav-icon { background: transparent; }

/* ── User Footer ────────────────────────────────────────────── */
.sidebar-user-footer {
    margin: 8px 10px 16px;
    padding: 11px 12px;
    border-radius: 11px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.07);
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    transition: background .15s;
    flex-shrink: 0;
}
.sidebar-user-footer:hover {
    background: rgba(255,255,255,.09);
    text-decoration: none;
}
.sidebar-user-avatar {
    width: 34px; height: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    flex-shrink: 0;
}
.sidebar-user-name {
    font-size: 13px;
    font-weight: 600;
    color: #e2e8f0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 130px;
}
.sidebar-user-role {
    font-size: 11px;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 130px;
}

/* ── Topbar ─────────────────────────────────────────────────── */
.topbar {
    height: 60px;
    background: var(--card) !important;
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
    padding: 0 16px;
    position: sticky; top: 0; z-index: 1030;
}
.topbar .nav-link { color: var(--text) !important; padding: 8px 12px; }
.topbar .nav-link:hover { color: var(--primary) !important; }
.avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border);
}

/* ============== TOPBAR ============== */
.topbar {
    height: 60px;
    background: var(--card) !important;
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-sm);
    padding: 0 16px;
    position: sticky; top: 0; z-index: 1030;
}
.topbar .nav-link { color: var(--text) !important; padding: 8px 12px; }
.topbar .nav-link:hover { color: var(--primary) !important; }
.avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border);
}

/* ============== CARDS ============== */
.card {
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    border-radius: var(--radius-lg);
    background: var(--card);
    color: var(--text);
}
.card-stat {
    border-left: 4px solid var(--primary);
    padding: 16px !important;
    transition: transform .15s ease, box-shadow .15s ease;
}
.card-stat:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.card-stat.warning { border-left-color: var(--warning); }
.card-stat.success { border-left-color: var(--success); }
.card-stat.danger  { border-left-color: var(--danger); }
.card-stat.info    { border-left-color: var(--info); }
.card-stat .text-muted { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.card-stat h3 { font-size: 22px; font-weight: 700; margin-top: 4px; word-break: break-word; }

/* ============== BUTTONS ============== */
.btn {
    border-radius: 8px; padding: 8px 16px; font-weight: 500; font-size: 14px;
    border: 1px solid transparent; transition: all .15s ease;
}
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-primary:hover, .btn-primary:focus { background: var(--primary-hover); border-color: var(--primary-hover); color: #fff; box-shadow: 0 4px 10px rgba(79, 70, 229, .25); }
.btn-success { background: var(--success); border-color: var(--success); color: #fff; }
.btn-success:hover { filter: brightness(.92); color: #fff; }
.btn-danger { background: var(--danger); border-color: var(--danger); color: #fff; }
.btn-danger:hover { filter: brightness(.92); color: #fff; }
.btn-warning { background: var(--warning); border-color: var(--warning); color: #fff; }
.btn-warning:hover { filter: brightness(.92); color: #fff; }
.btn-light { background: var(--card-2); border-color: var(--border); color: var(--text); }
.btn-light:hover { background: var(--bg); }
.btn-outline-primary { color: var(--primary); border-color: var(--primary); background: transparent; }
.btn-outline-primary:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-outline-success { color: var(--success); border-color: var(--success); background: transparent; }
.btn-outline-success:hover { background: var(--success); color: #fff; }
.btn-outline-warning { color: var(--warning); border-color: var(--warning); background: transparent; }
.btn-outline-warning:hover { background: var(--warning); color: #fff; }
.btn-outline-danger { color: var(--danger); border-color: var(--danger); background: transparent; }
.btn-outline-danger:hover { background: var(--danger); color: #fff; }

/* ============== FORMS ============== */
.form-control, .form-select {
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 14px;
    background: var(--card);
    color: var(--text);
    transition: border-color .15s ease, box-shadow .15s ease;
}
.form-control:focus, .form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(79, 70, 229, .12);
    background: var(--card);
    color: var(--text);
}
.form-control::placeholder { color: var(--text-muted); opacity: .6; }
.form-label { font-weight: 500; font-size: 13px; color: var(--text); margin-bottom: 4px; }
.form-check-input { background-color: var(--card); border-color: var(--border); }
.form-check-input:checked { background-color: var(--primary); border-color: var(--primary); }

/* ============== TABLES ============== */
.table {
    margin: 0;
    color: var(--text);
}
.table thead th {
    background: var(--card-2) !important;
    color: var(--text-muted);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    font-weight: 600;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    border-top: none;
    white-space: nowrap;
}
.table tbody td {
    padding: 14px 16px;
    border-top: 1px solid var(--border);
    vertical-align: middle;
    color: var(--text);
}
.table-hover tbody tr:hover { background: var(--card-2); }
.table-responsive { border-radius: var(--radius-lg); overflow-x: auto; }

/* ============== BADGES ============== */
.badge {
    font-weight: 500; padding: 5px 10px; border-radius: 6px;
    font-size: 11px; text-transform: uppercase; letter-spacing: .3px;
}
.bg-success  { background: var(--success-bg) !important; color: var(--success) !important; }
.bg-warning  { background: var(--warning-bg) !important; color: var(--warning) !important; }
.bg-danger   { background: var(--danger-bg)  !important; color: var(--danger)  !important; }
.bg-info     { background: var(--info-bg)    !important; color: var(--info)    !important; }
.bg-primary  { background: var(--primary-light) !important; color: var(--primary) !important; }
.bg-secondary{ background: var(--card-2) !important; color: var(--text-muted) !important; }
.bg-dark     { background: var(--text) !important; color: var(--card) !important; }

/* ============== ALERTS ============== */
.alert { border-radius: var(--radius); border: 1px solid transparent; padding: 12px 16px; font-size: 14px; }
.alert-success { background: var(--success-bg); color: var(--success); border-color: rgba(5,150,105,.2); }
.alert-warning { background: var(--warning-bg); color: var(--warning); border-color: rgba(217,119,6,.2); }
.alert-danger  { background: var(--danger-bg);  color: var(--danger);  border-color: rgba(220,38,38,.2); }
.alert-info    { background: var(--info-bg);    color: var(--info);    border-color: rgba(2,132,199,.2); }

/* ============== TABS ============== */
.nav-tabs { border-bottom: 1px solid var(--border); flex-wrap: nowrap; overflow-x: auto; }
.nav-tabs .nav-link {
    border: none; color: var(--text-muted); padding: 12px 18px;
    font-weight: 500; border-bottom: 2px solid transparent; white-space: nowrap;
}
.nav-tabs .nav-link.active { color: var(--primary); background: transparent; border-bottom-color: var(--primary); }

/* ============== MISC ============== */
.signature-pad { border: 2px dashed var(--border); background: var(--card); border-radius: var(--radius-lg); max-width: 100%; }
.dropdown-menu {
    border: 1px solid var(--border);
    box-shadow: var(--shadow-md);
    border-radius: var(--radius);
    padding: 8px;
    background: var(--card);
    z-index: 1055; /* must be above sidebar (1040) */
}
.dropdown-item { border-radius: 6px; padding: 8px 12px; font-size: 14px; color: var(--text); }
.dropdown-item:hover { background: var(--primary-light); color: var(--primary); }
.dropdown-divider { border-color: var(--border); }
.footer { background: var(--card); border-top: 1px solid var(--border); padding: 14px; color: var(--text-muted); font-size: 12px; }

.theme-toggle {
    background: transparent; border: 1px solid var(--border); border-radius: 8px;
    width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center;
    color: var(--text); cursor: pointer; transition: all .15s ease;
}
.theme-toggle:hover { background: var(--card-2); border-color: var(--primary); color: var(--primary); }

/* ============== SELECT2 Bootstrap-5 theme + dark-mode overrides ============== */

/* ── Single-select box ─────────────────────────────────────── */
.select2-container--bootstrap-5 .select2-selection,
.select2-container--default .select2-selection--single {
    background: var(--card) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    height: 38px !important;
    color: var(--text) !important;
    font-size: 14px;
}
.select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered,
.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 36px !important;
    color: var(--text) !important;
    padding-left: 12px;
}
.select2-container--bootstrap-5 .select2-selection--single .select2-selection__arrow,
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 36px !important;
}

/* ── Focus ring ────────────────────────────────────────────── */
.select2-container--bootstrap-5.select2-container--focus .select2-selection,
.select2-container--bootstrap-5.select2-container--open .select2-selection,
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.15) !important;
    outline: none !important;
}

/* ── Dropdown panel ────────────────────────────────────────── */
.select2-dropdown,
.select2-container--bootstrap-5 .select2-dropdown {
    background: var(--card) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
    z-index: 9999;
}

/* ── Options ───────────────────────────────────────────────── */
.select2-results__option,
.select2-container--bootstrap-5 .select2-results__option {
    color: var(--text) !important;
    padding: 7px 12px;
    font-size: 13px;
}
.select2-container--bootstrap-5 .select2-results__option--highlighted,
.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: var(--primary) !important;
    color: #fff !important;
}
.select2-results__option[aria-selected=true] {
    background-color: var(--primary-light) !important;
    color: var(--primary) !important;
}

/* ── Search input inside dropdown ──────────────────────────── */
.select2-search--dropdown .select2-search__field,
.select2-container--bootstrap-5 .select2-search--dropdown .select2-search__field {
    background: var(--card) !important;
    color: var(--text) !important;
    border: 1px solid var(--border) !important;
    border-radius: 6px !important;
    padding: 6px 10px;
    font-size: 13px;
}
.select2-search--dropdown .select2-search__field:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 2px rgba(79,70,229,.12) !important;
    outline: none !important;
}

/* ── Clear × button ────────────────────────────────────────── */
.select2-container--bootstrap-5 .select2-selection__clear,
.select2-container--default .select2-selection__clear {
    color: var(--text-muted) !important;
    margin-right: 4px;
}
.select2-container--bootstrap-5 .select2-selection__clear:hover,
.select2-container--default .select2-selection__clear:hover {
    color: var(--danger, #ef4444) !important;
}

/* ============== Flatpickr (overrides) ============== */
.flatpickr-input { background: var(--card) !important; color: var(--text) !important; }
.flatpickr-calendar { background: var(--card) !important; box-shadow: var(--shadow-md) !important; border: 1px solid var(--border) !important; }
.flatpickr-calendar .flatpickr-day { color: var(--text); }
.flatpickr-calendar .flatpickr-day.selected { background: var(--primary); border-color: var(--primary); color: #fff; }
.flatpickr-calendar .flatpickr-day:hover { background: var(--primary-light); }
.flatpickr-months .flatpickr-month, .flatpickr-current-month { color: var(--text); }
.flatpickr-weekday { color: var(--text-muted) !important; }

/* ============== LOAN CALC PREVIEW (sticky bottom card) ============== */
.calc-preview {
    position: sticky;
    bottom: 0;
    background: linear-gradient(135deg, #4F46E5 0%, #6366F1 100%);
    color: #fff;
    border-radius: var(--radius-lg);
    padding: 16px 20px;
    box-shadow: 0 -4px 16px rgba(79,70,229,.25);
    margin-top: 16px;
    z-index: 10;
}
.calc-preview h6 { color: #fff; opacity: .85; font-size: 12px; text-transform: uppercase; letter-spacing: 1px; margin: 0 0 10px; }
.calc-preview .calc-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.calc-preview .calc-cell { background: rgba(255,255,255,.12); border-radius: 10px; padding: 10px 14px; backdrop-filter: blur(4px); }
.calc-preview .calc-cell .lbl { font-size: 11px; opacity: .8; text-transform: uppercase; letter-spacing: .5px; }
.calc-preview .calc-cell .val { font-size: 18px; font-weight: 700; margin-top: 2px; }
@media (max-width: 767px) {
    .calc-preview .calc-row { grid-template-columns: repeat(2, 1fr); }
}

/* ============== RESPONSIVE BREAKPOINTS ============== */
/* tablet */
@media (max-width: 1199px) {
    :root { --sidebar-w: 230px; }
    .content { padding: 16px 18px; }
}

/* small tablet & mobile */
@media (max-width: 991px) {
    .sidebar { transform: translateX(-100%); width: 285px; box-shadow: 8px 0 32px rgba(0,0,0,.35); }
    .layout.sidebar-open .sidebar { transform: translateX(0); }
    .layout.sidebar-open .sidebar-backdrop { display: block; }
    .main { margin-left: 0 !important; }
    .sidebar-close { display: block; }
    .topbar { padding: 0 12px; }
    .content { padding: 14px; }
    .card-stat h3 { font-size: 18px; }
    h4 { font-size: 18px; }
}

/* phone */
@media (max-width: 575px) {
    .content { padding: 12px; }
    .row.g-3 { --bs-gutter-x: .5rem; }
    .col-md-3, .col-md-4, .col-md-6, .col-md-8 { width: 100%; }
    .topbar .d-md-block { display: none !important; }
    .table.table-stack thead { display: none; }
    .table.table-stack tbody td { display: block; padding: 6px 12px; border: none; }
    .table.table-stack tbody tr {
        display: block; border: 1px solid var(--border); border-radius: 8px;
        margin-bottom: 8px; padding: 6px;
    }
    .table.table-stack tbody td::before {
        content: attr(data-label) ": "; font-weight: 600; color: var(--text-muted);
        font-size: 11px; text-transform: uppercase;
    }
    .table.table-stack tbody td:not([data-label])::before {
        content: none;
        display: none;
    }
    .btn { padding: 7px 12px; }
    .calc-preview .calc-cell .val { font-size: 14px; }
    .nav-tabs .nav-link { padding: 10px 12px; font-size: 13px; }
    h4 { font-size: 16px; }
    .card-stat h3 { font-size: 16px; }
}

/* very small */
@media (max-width: 374px) {
    .content { padding: 10px; }
    .topbar { padding: 0 8px; }
}

/* ============== DARK THEME: BOOTSTRAP OVERRIDES ============== */
/* Bootstrap hard-codes many colors — override all of them for dark mode */

/* Modals */
.modal-content {
    background: var(--card);
    border: 1px solid var(--border);
    color: var(--text);
}
.modal-header {
    border-bottom: 1px solid var(--border);
    background: var(--card);
    color: var(--text);
}
.modal-footer {
    border-top: 1px solid var(--border);
    background: var(--card);
}
.modal-body { background: var(--card); color: var(--text); }
.btn-close { filter: var(--close-filter, none); }
[data-theme="dark"] { --close-filter: invert(1) grayscale(100%) brightness(200%); }

/* Bootstrap bg-light / bg-white → themed */
.bg-light, .bg-white {
    background-color: var(--card-2) !important;
    color: var(--text) !important;
}
[data-theme="dark"] .bg-light,
[data-theme="dark"] .bg-white {
    background-color: var(--card-2) !important;
    color: var(--text) !important;
}

/* Bootstrap table-light thead */
.table-light, .table-light > th, .table-light > td,
.table thead.table-light th, thead.table-light th {
    background-color: var(--card-2) !important;
    color: var(--text-muted) !important;
    border-color: var(--border) !important;
}

/* Bootstrap input-group-text */
.input-group-text {
    background: var(--card-2);
    border: 1px solid var(--border);
    color: var(--text);
}

/* Bootstrap pagination */
.pagination .page-link {
    background: var(--card);
    border-color: var(--border);
    color: var(--primary);
}
.pagination .page-link:hover {
    background: var(--card-2);
    border-color: var(--border);
    color: var(--primary);
}
.pagination .page-item.active .page-link {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
}
.pagination .page-item.disabled .page-link {
    background: var(--card-2);
    border-color: var(--border);
    color: var(--text-muted);
}

/* Bootstrap list-group */
.list-group-item {
    background: var(--card);
    border-color: var(--border);
    color: var(--text);
}
.list-group-item:hover { background: var(--card-2); }

/* Bootstrap card-header / card-footer (sometimes used) */
.card-header {
    background: var(--card-2);
    border-bottom: 1px solid var(--border);
    color: var(--text);
}
.card-footer {
    background: var(--card-2);
    border-top: 1px solid var(--border);
    color: var(--text-muted);
}

/* Bootstrap alert-secondary */
.alert-secondary {
    background: var(--card-2);
    color: var(--text);
    border-color: var(--border);
}

/* Bootstrap details/summary used in loans/create */
details > summary { color: var(--text-muted); }
details { border: none; }

/* Bootstrap form-check-label */
.form-check-label { color: var(--text); }

/* Bootstrap collapse content inside sidebar */
.collapse .nav-link { color: var(--sidebar-fg); }

/* Bootstrap .text-white on modal headers — keep white */
.modal-header.bg-danger,
.modal-header.bg-success,
.modal-header.bg-primary,
.modal-header.bg-warning { color: #fff !important; }

/* Bootstrap success/danger/info/warning backgrounds in cards */
.bg-success-subtle { background: var(--success-bg) !important; color: var(--success) !important; }
.bg-danger-subtle  { background: var(--danger-bg)  !important; color: var(--danger)  !important; }
.bg-warning-subtle { background: var(--warning-bg) !important; color: var(--warning) !important; }
.bg-info-subtle    { background: var(--info-bg)    !important; color: var(--info)    !important; }

/* Readonly / disabled inputs */
.form-control[readonly], .form-control:disabled,
.form-select:disabled {
    background: var(--card-2) !important;
    color: var(--text-muted) !important;
    border-color: var(--border) !important;
}

/* Bootstrap .text-dark / .text-black  */
[data-theme="dark"] .text-dark  { color: var(--text) !important; }
[data-theme="dark"] .text-black { color: var(--text) !important; }

/* Chart.js canvas — let JS set bg; ensure it inherits card bg */
canvas { background: transparent; }

/* Select2 multi-select tags */
.select2-container--bootstrap-5 .select2-selection--multiple,
.select2-container--default .select2-selection--multiple {
    background: var(--card) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    min-height: 38px;
    padding: 2px 6px;
}
.select2-container--bootstrap-5 .select2-selection__choice,
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background: var(--primary-light) !important;
    border: 1px solid var(--primary) !important;
    color: var(--primary) !important;
    border-radius: 6px !important;
    padding: 2px 8px !important;
    font-size: 12px;
}
.select2-container--bootstrap-5 .select2-selection__choice__remove,
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: var(--primary) !important;
    margin-right: 4px;
}

/* Code / pre */
code, pre {
    background: var(--card-2);
    color: var(--text);
    border-radius: 6px;
    padding: 2px 6px;
    border: 1px solid var(--border);
}

/* Flatpickr month/year pickers */
.flatpickr-months { background: var(--card); }
.numInputWrapper:hover { background: var(--card-2); }
.flatpickr-current-month input.cur-year { color: var(--text); }
.flatpickr-prev-month svg, .flatpickr-next-month svg { fill: var(--text); }
.flatpickr-time input, .flatpickr-time .flatpickr-am-pm {
    background: var(--card);
    color: var(--text);
}
.flatpickr-day.disabled { color: var(--text-muted) !important; }
.flatpickr-day.today { border-color: var(--primary) !important; }

/* Scrollbar (webkit) */
[data-theme="dark"] ::-webkit-scrollbar { width: 6px; height: 6px; }
[data-theme="dark"] ::-webkit-scrollbar-track { background: var(--bg); }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* Tab content card bottom border fix */
.tab-content.card.border-top-0 { border-top: 0 !important; }

/* ============== UI GLITCH FIXES ============== */

/* Sidebar active item loses color on parent when child is active */
.sidebar .nav-link.active { color: #fff !important; }

/* Topbar dropdown arrow color */
.navbar-nav .dropdown-toggle::after { border-top-color: var(--text); }

/* Fix calc-preview sticky overlapping footer on scroll */
.calc-preview { margin-bottom: 16px; }

/* Fix table-stack data-label on dark not visible */
[data-theme="dark"] .table.table-stack tbody td::before { color: var(--text-muted); }

/* Fix Bootstrap outline buttons in dark getting white fill on focus */
.btn-outline-primary:focus,
.btn-outline-secondary:focus,
.btn-outline-danger:focus  { box-shadow: 0 0 0 3px rgba(129,140,248,.25); }

/* Fix .badge inside nav-link alignment */
.nav-link .badge { vertical-align: middle; }

/* Fix Bootstrap .btn-close inside dark modal-header.bg-danger */
.modal-header.bg-danger .btn-close { filter: brightness(0) invert(1); }

/* Fix horizontal rule color in dark */
[data-theme="dark"] hr { border-color: var(--border); opacity: 1; }

/* Fix placeholder text in dark */
[data-theme="dark"] ::placeholder { color: var(--text-muted); opacity: 0.5; }

/* Fix mobile table-stack card borders in dark */
[data-theme="dark"] .table.table-stack tbody tr { border-color: var(--border); }

/* Fix sidebar collapse arrow color */
.sidebar .bi-chevron-down { color: var(--sidebar-fg); }

/* Fix topbar sticky background flash on page load */
.topbar { will-change: background; }

/* Fix details summary arrow in dark */
[data-theme="dark"] details > summary { list-style-image: none; }

/* print */
@media print {
    .sidebar, .topbar, .footer, .btn, .no-print { display: none !important; }
    .main { margin-left: 0 !important; }
    .content { padding: 0; }
    .card { box-shadow: none; border: 1px solid #ccc; }
}

/* ── Notification dropdown ────────────────────────────────────── */
.notif-dropdown {
    overflow: hidden;
    z-index: 1055 !important;
}
.notif-dropdown .notif-body {
    max-height: 340px;
    overflow-y: auto;
}

/* ============== 2026 UI REFRESH: MARKET-STANDARD FINANCE THEME ============== */
:root,
[data-theme="light"] {
    --primary: #4F46E5;
    --primary-hover: #4338CA;
    --primary-light: #EEF2FF;
    --accent: #10B981;
    --accent-2: #F59E0B;
    --accent-3: #0EA5E9;
    --bg: #F6F7FB;
    --card: #FFFFFF;
    --card-2: #F8FAFC;
    --border: #E1E7F0;
    --sidebar-bg: #111827;
    --sidebar-bg-2: #064E3B;
    --sidebar-fg: #D9E2EF;
    --success: #10B981;
    --success-bg: #ECFDF5;
    --warning: #F59E0B;
    --warning-bg: #FFFBEB;
    --danger: #EF4444;
    --danger-bg: #FEF2F2;
    --info: #0EA5E9;
    --info-bg: #F0F9FF;
    --gradient-primary: linear-gradient(135deg, #4F46E5 0%, #10B981 100%);
    --gradient-primary-hover: linear-gradient(135deg, #4338CA 0%, #059669 100%);
    --gradient-success: linear-gradient(135deg, #10B981 0%, #22C55E 100%);
    --gradient-warning: linear-gradient(135deg, #F59E0B 0%, #F97316 100%);
    --gradient-danger: linear-gradient(135deg, #EF4444 0%, #E11D48 100%);
    --gradient-info: linear-gradient(135deg, #0EA5E9 0%, #4F46E5 100%);
    --gradient-secondary: linear-gradient(135deg, #64748B 0%, #334155 100%);
    --shadow: 0 8px 22px rgba(79, 70, 229, .07);
    --shadow-md: 0 14px 32px rgba(15, 23, 42, .12);
    --radius: 8px;
    --radius-lg: 10px;
    --focus-ring: 0 0 0 3px rgba(16, 185, 129, .18);
}

[data-theme="dark"] {
    --primary: #818CF8;
    --primary-hover: #6366F1;
    --primary-light: rgba(129, 140, 248, .16);
    --accent: #34D399;
    --accent-2: #FBBF24;
    --accent-3: #38BDF8;
    --success: #34D399;
    --warning: #FBBF24;
    --danger: #F87171;
    --info: #38BDF8;
    --gradient-primary: linear-gradient(135deg, #818CF8 0%, #34D399 100%);
    --gradient-primary-hover: linear-gradient(135deg, #6366F1 0%, #10B981 100%);
    --gradient-success: linear-gradient(135deg, #10B981 0%, #34D399 100%);
    --gradient-warning: linear-gradient(135deg, #F59E0B 0%, #FBBF24 100%);
    --gradient-danger: linear-gradient(135deg, #EF4444 0%, #F87171 100%);
    --gradient-info: linear-gradient(135deg, #38BDF8 0%, #818CF8 100%);
    --gradient-secondary: linear-gradient(135deg, #64748B 0%, #1F2937 100%);
    --card: #111827;
    --card-2: #182235;
    --sidebar-bg: #061021;
    --sidebar-bg-2: #064E3B;
}

body {
    background:
        linear-gradient(180deg, rgba(79,70,229,.08), rgba(16,185,129,.06) 240px, transparent 520px),
        var(--bg);
}

/* sidebar theme-override removed — base sidebar CSS handles all states */

.topbar {
    background: rgba(255,255,255,.86) !important;
    backdrop-filter: blur(14px);
}
[data-theme="dark"] .topbar { background: rgba(17,24,39,.88) !important; }

.content { padding: 22px 26px; }
.card { border-radius: 10px; box-shadow: var(--shadow); }
.card:not(.card-stat) { overflow: hidden; }
.card:hover { box-shadow: var(--shadow-md); }

.card-stat {
    border-left: 0;
    border-top: 0;
    background:
        radial-gradient(circle at 92% 80%, rgba(79,70,229,.15), transparent 24%),
        linear-gradient(135deg, rgba(79,70,229,.10), rgba(16,185,129,.08) 38%, var(--card) 68%);
    position: relative;
    overflow: hidden;
}
.card-stat::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: var(--gradient-primary);
}
.card-stat::after {
    content: "";
    position: absolute;
    right: -24px;
    bottom: -38px;
    width: 98px;
    height: 98px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--primary), transparent 86%);
}
.card-stat.warning::before { background: var(--gradient-warning); }
.card-stat.success::before { background: var(--gradient-success); }
.card-stat.danger::before { background: var(--gradient-danger); }
.card-stat.info::before { background: var(--gradient-info); }

.topbar .btn,
.topbar button.btn,
.topbar .nav-link.border,
.topbar .nav-link.btn {
    background: linear-gradient(var(--card), var(--card)) padding-box, var(--gradient-primary) border-box;
    border: 1px solid transparent !important;
    color: var(--text) !important;
    box-shadow: 0 6px 16px rgba(79, 70, 229, .10);
}
.topbar .btn:hover,
.topbar button.btn:hover,
.topbar .nav-link.border:hover,
.topbar .nav-link.btn:hover {
    background: var(--gradient-primary);
    color: #fff !important;
}

.input-group .btn,
.card .btn:not(.btn-light):not(.btn-link) {
    box-shadow: 0 8px 18px rgba(79, 70, 229, .13);
}

.table .btn-sm,
.d-inline-flex .btn-sm {
    background: var(--gradient-primary);
    border-color: transparent !important;
    color: #fff !important;
}
.table .btn-outline-danger.btn-sm,
.d-inline-flex .btn-outline-danger.btn-sm {
    background: var(--gradient-danger);
}
.table .btn-outline-warning.btn-sm,
.d-inline-flex .btn-outline-warning.btn-sm {
    background: var(--gradient-warning);
}
.table .btn-outline-success.btn-sm,
.d-inline-flex .btn-outline-success.btn-sm {
    background: var(--gradient-success);
}

.btn { border-radius: 8px; font-weight: 600; }
.btn-primary {
    background: var(--gradient-primary);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 18px rgba(79, 70, 229, .18);
}
.btn-primary:hover,
.btn-primary:focus {
    background: var(--gradient-primary-hover);
    border-color: transparent;
    color: #fff;
    transform: translateY(-1px);
}
.btn-success {
    background: var(--gradient-success);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 18px rgba(16, 185, 129, .18);
}
.btn-warning {
    background: var(--gradient-warning);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 18px rgba(245, 158, 11, .18);
}
.btn-danger {
    background: var(--gradient-danger);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 18px rgba(239, 68, 68, .18);
}
.btn-info {
    background: var(--gradient-info);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 18px rgba(14, 165, 233, .18);
}
.btn-secondary,
.btn-dark {
    background: var(--gradient-secondary);
    border-color: transparent;
    color: #fff;
}
.btn-success:hover,
.btn-warning:hover,
.btn-danger:hover,
.btn-info:hover,
.btn-secondary:hover,
.btn-dark:hover {
    color: #fff;
    filter: brightness(.97);
    transform: translateY(-1px);
}
.btn-outline-primary {
    color: var(--primary);
    border-color: color-mix(in srgb, var(--primary), transparent 40%);
    background: linear-gradient(var(--card), var(--card)) padding-box, var(--gradient-primary) border-box;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background: var(--gradient-primary);
    border-color: transparent;
    color: #fff;
}
.btn-outline-success {
    color: var(--success);
    border-color: color-mix(in srgb, var(--success), transparent 35%);
    background: linear-gradient(var(--card), var(--card)) padding-box, var(--gradient-success) border-box;
}
.btn-outline-success:hover,
.btn-outline-success:focus {
    background: var(--gradient-success);
    border-color: transparent;
    color: #fff;
}
.btn-outline-warning {
    color: #B45309;
    border-color: color-mix(in srgb, var(--warning), transparent 35%);
    background: linear-gradient(var(--card), var(--card)) padding-box, var(--gradient-warning) border-box;
}
.btn-outline-warning:hover,
.btn-outline-warning:focus {
    background: var(--gradient-warning);
    border-color: transparent;
    color: #fff;
}
.btn-outline-danger {
    color: var(--danger);
    border-color: color-mix(in srgb, var(--danger), transparent 35%);
    background: linear-gradient(var(--card), var(--card)) padding-box, var(--gradient-danger) border-box;
}
.btn-outline-danger:hover,
.btn-outline-danger:focus {
    background: var(--gradient-danger);
    border-color: transparent;
    color: #fff;
}
.btn-outline-secondary,
.btn-outline-dark {
    color: var(--text-muted);
    border-color: color-mix(in srgb, var(--text-muted), transparent 45%);
    background: linear-gradient(var(--card), var(--card)) padding-box, var(--gradient-secondary) border-box;
}
.btn-outline-secondary:hover,
.btn-outline-dark:hover {
    background: var(--gradient-secondary);
    border-color: transparent;
    color: #fff;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--accent);
    box-shadow: var(--focus-ring);
}

.table thead th {
    background: linear-gradient(180deg, var(--card-2), color-mix(in srgb, var(--primary-light), transparent 70%)) !important;
}
.table-hover tbody tr:hover { background: color-mix(in srgb, var(--primary-light), transparent 58%); }
.badge { border-radius: 99px; font-weight: 700; }

.calc-preview,
.emi-preview-card {
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 72%, var(--accent-2) 100%);
}

@media (max-width: 991px) {
    .content { padding: 14px; }
}

@media (max-width: 575px) {
    .content { padding: 12px; }
    .content > .d-flex,
    .card-header.d-flex,
    .modal-footer {
        flex-wrap: wrap;
        gap: 8px;
    }
    .content > .d-flex .btn,
    .card-header .btn {
        white-space: nowrap;
    }
    .table-responsive {
        border-radius: 8px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    .table {
        min-width: 720px;
    }
    .table.table-stack {
        min-width: 0;
    }
    .table.table-mobile-card tbody tr {
        display: block;
        border: 1px solid var(--border);
        border-radius: 10px;
        margin-bottom: 10px;
        background: var(--card);
        box-shadow: var(--shadow-sm);
    }
    .table.table-mobile-card tbody td {
        display: flex;
        justify-content: space-between;
        gap: 14px;
        padding: 8px 12px;
        border-top: 1px solid var(--border);
        text-align: right !important;
        white-space: normal;
    }
    .table.table-mobile-card tbody td:first-child { border-top: 0; }
    .table.table-mobile-card tbody td::before {
        content: attr(data-label);
        color: var(--text-muted);
        font-size: 11px;
        font-weight: 700;
        text-transform: uppercase;
        text-align: left;
    }
    .table tbody td:not([data-label])::before {
        content: none !important;
        display: none !important;
    }
    .d-inline-flex.gap-1 {
        flex-wrap: wrap;
        justify-content: flex-end;
    }
}

/* ══════════════════════════════════════════════════════════════════════════════
   DARK MODE — COMPREHENSIVE FIXES
   Covers: form inputs, nav-pills, page-header, filter-card, select2,
           flatpickr, badges, cards, topbar, footer, notif-dropdown, etc.
══════════════════════════════════════════════════════════════════════════════ */

/* ── Form inputs & selects ─────────────────────────────────────────────────── */
.form-control,
.form-select {
    background-color: var(--card);
    border-color: var(--border);
    color: var(--text);
    transition: border-color .15s, box-shadow .15s, background-color .15s;
}
.form-control:focus,
.form-select:focus {
    background-color: var(--card);
    border-color: var(--primary);
    color: var(--text);
    box-shadow: 0 0 0 3px rgba(79,70,229,.15);
}
.form-control::placeholder { color: var(--text-muted); opacity: .65; }
.form-control:disabled,
.form-select:disabled,
.form-control[readonly] {
    background-color: var(--card-2);
    color: var(--text-muted);
    border-color: var(--border);
}
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: var(--card-2);
    border-color: var(--border);
    color: var(--text);
}
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background-color: var(--card);
    border-color: var(--primary);
    color: var(--text);
}
[data-theme="dark"] .form-control:disabled,
[data-theme="dark"] .form-select:disabled,
[data-theme="dark"] .form-control[readonly] {
    background-color: #0f1825;
    color: var(--text-muted);
}

/* ── Textarea ─────────────────────────────────────────────────────────────── */
[data-theme="dark"] textarea.form-control { background-color: var(--card-2); color: var(--text); }

/* ── Input group ──────────────────────────────────────────────────────────── */
[data-theme="dark"] .input-group-text {
    background-color: var(--card-2);
    border-color: var(--border);
    color: var(--text-muted);
}

/* ── Nav pills ────────────────────────────────────────────────────────────── */
.nav-pills .nav-link {
    color: var(--text-muted);
    border-radius: 8px;
}
.nav-pills .nav-link:hover {
    background: var(--primary-light);
    color: var(--primary);
}
.nav-pills .nav-link.active {
    background: var(--primary);
    color: #fff;
}
[data-theme="dark"] .nav-pills .nav-link { color: var(--text-muted); }
[data-theme="dark"] .nav-pills .nav-link.active { background: var(--primary); color: #fff; }

/* ── Nav tabs ──────────────────────────────────────────────────────────────── */
.nav-tabs { border-bottom-color: var(--border); }
.nav-tabs .nav-link { color: var(--text-muted); border-color: transparent; }
.nav-tabs .nav-link.active {
    background: var(--card);
    border-color: var(--border) var(--border) var(--card);
    color: var(--text);
}
[data-theme="dark"] .nav-tabs .nav-link.active {
    background: var(--card);
    border-color: var(--border) var(--border) var(--card);
    color: var(--text);
}
[data-theme="dark"] .tab-content { color: var(--text); }

/* ── Page header ──────────────────────────────────────────────────────────── */
.page-header h1 { color: var(--text); }
.page-header p   { color: var(--text-muted); }

/* ── Filter card / filter-card ────────────────────────────────────────────── */
.filter-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 16px 20px;
    margin-bottom: 20px;
}

/* ── Select2 dark mode (comprehensive) ────────────────────────────────────── */
[data-theme="dark"] .select2-container--bootstrap-5 .select2-selection,
[data-theme="dark"] .select2-container--default .select2-selection--single,
[data-theme="dark"] .select2-container--default .select2-selection--multiple {
    background-color: var(--card-2) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}
[data-theme="dark"] .select2-container--bootstrap-5 .select2-selection--single .select2-selection__rendered,
[data-theme="dark"] .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text) !important;
}
[data-theme="dark"] .select2-dropdown,
[data-theme="dark"] .select2-container--bootstrap-5 .select2-dropdown {
    background-color: var(--card) !important;
    border-color: var(--border) !important;
    box-shadow: var(--shadow-md) !important;
}
[data-theme="dark"] .select2-results__option {
    color: var(--text) !important;
    background-color: transparent;
}
[data-theme="dark"] .select2-container--bootstrap-5 .select2-results__option--highlighted,
[data-theme="dark"] .select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: var(--primary) !important;
    color: #fff !important;
}
[data-theme="dark"] .select2-results__option[aria-selected=true] {
    background: var(--primary-light) !important;
    color: var(--primary) !important;
}
[data-theme="dark"] .select2-search--dropdown .select2-search__field {
    background-color: var(--card-2) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}
[data-theme="dark"] .select2-container--bootstrap-5 .select2-selection__placeholder { color: var(--text-muted) !important; }

/* ── Flatpickr dark mode ──────────────────────────────────────────────────── */
[data-theme="dark"] .flatpickr-calendar {
    background: var(--card) !important;
    border-color: var(--border) !important;
    box-shadow: var(--shadow-md) !important;
}
[data-theme="dark"] .flatpickr-day { color: var(--text) !important; }
[data-theme="dark"] .flatpickr-day:hover { background: var(--primary-light) !important; color: var(--primary) !important; }
[data-theme="dark"] .flatpickr-day.selected,
[data-theme="dark"] .flatpickr-day.selected:hover { background: var(--primary) !important; border-color: var(--primary) !important; color: #fff !important; }
[data-theme="dark"] .flatpickr-day.today { border-color: var(--primary) !important; }
[data-theme="dark"] .flatpickr-day.flatpickr-disabled,
[data-theme="dark"] .flatpickr-day.flatpickr-disabled:hover { color: var(--text-muted) !important; opacity: .4; }
[data-theme="dark"] .flatpickr-months .flatpickr-month,
[data-theme="dark"] .flatpickr-current-month,
[data-theme="dark"] .flatpickr-current-month .cur-month,
[data-theme="dark"] .flatpickr-current-month input.cur-year { color: var(--text) !important; }
[data-theme="dark"] .flatpickr-weekday { color: var(--text-muted) !important; }
[data-theme="dark"] .flatpickr-prev-month,
[data-theme="dark"] .flatpickr-next-month { fill: var(--text-muted) !important; }
[data-theme="dark"] .flatpickr-prev-month:hover svg,
[data-theme="dark"] .flatpickr-next-month:hover svg { fill: var(--primary) !important; }
[data-theme="dark"] .flatpickr-time .flatpickr-time-separator,
[data-theme="dark"] .flatpickr-time input { color: var(--text) !important; background: var(--card-2) !important; }

/* ── Cards ────────────────────────────────────────────────────────────────── */
.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}
.card-header {
    background: var(--card);
    border-bottom: 1px solid var(--border);
    padding: 14px 20px;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.card-footer {
    background: var(--card-2);
    border-top: 1px solid var(--border);
}
[data-theme="dark"] .card,
[data-theme="dark"] .card-header,
[data-theme="dark"] .card-footer { color: var(--text); }

/* ── Topbar ──────────────────────────────────────────────────────────────── */
[data-theme="dark"] .topbar {
    background: var(--card) !important;
    border-bottom-color: var(--border) !important;
}
[data-theme="dark"] .topbar .fw-semibold { color: var(--text); }

/* ── Theme toggle button ──────────────────────────────────────────────────── */
.theme-toggle {
    background: var(--card-2);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 7px 10px;
    color: var(--text);
    cursor: pointer;
    transition: background .15s, color .15s;
    line-height: 1;
}
.theme-toggle:hover { background: var(--primary-light); color: var(--primary); }

/* ── Notification dropdown ────────────────────────────────────────────────── */
[data-theme="dark"] .notif-dropdown,
[data-theme="dark"] .dropdown-menu {
    background: var(--card) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}
[data-theme="dark"] .dropdown-item { color: var(--text) !important; }
[data-theme="dark"] .dropdown-item:hover { background: var(--primary-light) !important; color: var(--primary) !important; }
[data-theme="dark"] .dropdown-header { color: var(--text-muted) !important; }
[data-theme="dark"] .dropdown-divider { border-color: var(--border) !important; }

/* ── Footer ───────────────────────────────────────────────────────────────── */
.footer {
    padding: 16px 24px;
    border-top: 1px solid var(--border);
    color: var(--text-muted);
    font-size: 12px;
    background: var(--card);
}

/* ── Badge tweaks for dark mode ──────────────────────────────────────────── */
[data-theme="dark"] .badge.bg-light { background: var(--card-2) !important; color: var(--text) !important; border: 1px solid var(--border); }
[data-theme="dark"] .bg-primary-soft { background: rgba(129,140,248,.15) !important; }
[data-theme="dark"] .bg-success-soft { background: rgba(16,185,129,.15) !important; }
[data-theme="dark"] .bg-warning-soft { background: rgba(245,158,11,.15) !important; }
[data-theme="dark"] .bg-danger-soft  { background: rgba(248,113,113,.15) !important; }
[data-theme="dark"] .bg-info-soft    { background: rgba(56,189,248,.15)  !important; }

/* ── Stat cards ──────────────────────────────────────────────────────────── */
[data-theme="dark"] .card-stat { background: var(--card-2); }
[data-theme="dark"] .card-stat .stat-icon { background: var(--card) !important; }

/* ── Page loader dark background ─────────────────────────────────────────── */
[data-theme="dark"] #page-loader::after {
    background: radial-gradient(ellipse at center, rgba(0,0,0,.2) 0%, rgba(0,0,0,.6) 100%);
}

/* ── Form-check (checkbox / radio) ──────────────────────────────────────── */
[data-theme="dark"] .form-check-input {
    background-color: var(--card-2);
    border-color: var(--border);
}
[data-theme="dark"] .form-check-input:checked { background-color: var(--primary); border-color: var(--primary); }
[data-theme="dark"] .form-check-label { color: var(--text); }

/* ── Color input ─────────────────────────────────────────────────────────── */
[data-theme="dark"] input[type="color"].form-control-color {
    background: var(--card-2);
    border-color: var(--border);
}

/* ── Progress bars ────────────────────────────────────────────────────────── */
[data-theme="dark"] .progress { background: var(--card-2); }

/* ── Breadcrumb ───────────────────────────────────────────────────────────── */
[data-theme="dark"] .cms-breadcrumb a,
[data-theme="dark"] .cms-breadcrumb { color: var(--text-muted); }
[data-theme="dark"] .cms-breadcrumb .current { color: var(--text); }

/* ── Alert overrides for dark mode ────────────────────────────────────────── */
[data-theme="dark"] .alert-success { background: var(--success-bg); color: var(--success); }
[data-theme="dark"] .alert-danger  { background: var(--danger-bg);  color: var(--danger);  }
[data-theme="dark"] .alert-warning { background: var(--warning-bg); color: var(--warning); }
[data-theme="dark"] .alert-info    { background: var(--info-bg);    color: var(--info);    }

/* ── Border utilities ────────────────────────────────────────────────────── */
[data-theme="dark"] .border,
[data-theme="dark"] .border-top,
[data-theme="dark"] .border-bottom,
[data-theme="dark"] .border-start,
[data-theme="dark"] .border-end { border-color: var(--border) !important; }

/* ── Subscription warning banner ─────────────────────────────────────────── */
[data-theme="dark"] .alert[style*="fef2f2"] {
    background: rgba(248,113,113,.1) !important;
}

/* ══════════════════════════════════════════════════════════════
   STAT CHIP — reusable summary tile used on index pages
══════════════════════════════════════════════════════════════ */
.stat-chip {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    box-shadow: var(--shadow-sm);
    transition: box-shadow .15s, transform .15s;
}
.stat-chip:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.stat-chip-icon {
    width: 46px; height: 46px;
    border-radius: 13px;
    display: flex; align-items: center; justify-content: center;
    font-size: 19px; flex-shrink: 0;
}
.stat-chip-val { font-size: 23px; font-weight: 700; color: var(--text); line-height: 1.1; }
.stat-chip-lbl { font-size: 11px; color: var(--text-muted); font-weight: 600;
                 text-transform: uppercase; letter-spacing: .05em; margin-top: 1px; }

/* ── Avatar XS (tiny circular initial badge) ─────────────────── */
.avatar-xs {
    display: inline-flex; width: 26px; height: 26px; border-radius: 50%;
    background: var(--primary); color: #fff;
    font-size: 11px; font-weight: 700;
    align-items: center; justify-content: center; flex-shrink: 0;
}

/* LMS sidebar alignment */
:root,
[data-theme="light"] {
    --sidebar-bg: #0F172A;
    --sidebar-bg-2: #1E293B;
    --sidebar-fg: #CBD5E1;
}

[data-theme="dark"] {
    --sidebar-bg: #050B17;
    --sidebar-bg-2: #0B1220;
    --sidebar-fg: #94A3B8;
}

.sidebar {
    display: block;
    width: var(--sidebar-w);
    background: linear-gradient(180deg, var(--sidebar-bg) 0%, var(--sidebar-bg-2) 100%);
    color: var(--sidebar-fg);
    box-shadow: 2px 0 8px rgba(15,23,42,.08);
}

.sidebar::before { display: none; }

.sidebar .brand {
    background: rgba(255,255,255,.04);
    padding: 18px 16px;
    border-bottom: 1px solid rgba(255,255,255,.06);
}

.sidebar .brand a {
    color: #fff !important;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: .3px;
}

.sidebar .brand a i {
    background: var(--primary);
    color: #fff;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    margin-right: 0;
}

.sidebar .nav-menu {
    padding: 12px 8px 60px;
    flex: initial;
}

.sidebar-role-badge,
.sidebar-user-footer {
    display: none;
}

.nav-section-label {
    padding: 10px 14px 4px;
    color: rgba(255,255,255,.35);
}

.sidebar .nav-link {
    color: var(--sidebar-fg);
    padding: 10px 14px;
    margin-bottom: 2px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    transition: all .15s ease;
}

.sidebar .nav-link::before { display: none; }

.sidebar .nav-link .nav-icon {
    width: 20px;
    height: auto;
    min-width: 20px;
    background: transparent;
    box-shadow: none;
    color: inherit;
}

.sidebar .nav-link .nav-icon i,
.sidebar .nav-link i:first-child {
    width: 20px;
    text-align: center;
    font-size: 16px;
    opacity: .85;
}

.sidebar .nav-link:hover {
    background: rgba(99, 102, 241, .15);
    color: #fff;
    transform: none;
}

.sidebar .nav-link:hover .nav-icon {
    background: transparent;
    color: inherit;
}

.sidebar .nav-link.active {
    background: var(--primary);
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(79, 70, 229, .35);
}

.sidebar .nav-link.active .nav-icon {
    background: transparent;
    color: inherit;
    box-shadow: none;
}

.sidebar .collapse .nav-link,
.sidebar .ps-2 .nav-link,
.sidebar .ps-4 .nav-link {
    font-size: 13px;
    padding: 7px 12px;
}

.sidebar .collapse .nav-link.active {
    background: var(--primary);
    color: #fff !important;
}

.sidebar .nav-chevron,
.sidebar .bi-chevron-down {
    margin-left: auto;
    color: var(--sidebar-fg);
}

.sidebar-badge {
    background: #ef4444;
    color: #fff;
    box-shadow: none;
}

@media (max-width: 991px) {
    .sidebar {
        transform: translateX(-100%);
        width: 280px;
        box-shadow: 6px 0 24px rgba(0,0,0,.25);
    }
}
