:root,
body.theme-colored {
    --bg: linear-gradient(135deg, #e0f2fe, #eff6ff, #dbeafe);
    --text: #102033;
    --muted: #475569;
    --card: rgba(255, 255, 255, 0.95);
    --border: #bfdbfe;

    --primary: #2563eb;
    --primary-soft: #dbeafe;

    --navbar: linear-gradient(90deg, #1d4ed8, #2563eb, #06b6d4);
    --navbar-text: #ffffff;

    --sidebar: linear-gradient(180deg, #1e3a8a, #2563eb);
    --sidebar-text: #ffffff;
    --sidebar-hover: rgba(255, 255, 255, 0.18);

    --shadow: 0 12px 30px rgba(37, 99, 235, 0.18);
}

body.theme-dark {
    --bg: #020617;
    --text: #f8fafc;
    --muted: #94a3b8;
    --card: #0f172a;
    --border: #334155;

    --primary: #38bdf8;
    --primary-soft: #082f49;

    --navbar: #020617;
    --navbar-text: #f8fafc;

    --sidebar: #0f172a;
    --sidebar-text: #f8fafc;
    --sidebar-hover: #1e293b;

    --shadow: 0 12px 30px rgba(0, 0, 0, 0.45);
}

body.theme-light {
    --bg: #ffffff;
    --text: #111827;
    --muted: #6b7280;
    --card: #ffffff;
    --border: #e5e7eb;

    --primary: #111827;
    --primary-soft: #f3f4f6;

    --navbar: #ffffff;
    --navbar-text: #111827;

    --sidebar: #ffffff;
    --sidebar-text: #111827;
    --sidebar-hover: #f3f4f6;

    --shadow: none;
}

body.theme-corporate {
    --bg: #f3f4f6;
    --text: #1f2937;
    --muted: #4b5563;
    --card: #f9fafb;
    --border: #9ca3af;

    --primary: #374151;
    --primary-soft: #e5e7eb;

    --navbar: #374151;
    --navbar-text: #ffffff;

    --sidebar: #4b5563;
    --sidebar-text: #f9fafb;
    --sidebar-hover: #6b7280;

    --shadow: 0 8px 18px rgba(31, 41, 55, 0.20);
}

/* APPLY THEME */
body {
    background: var(--bg);
    color: var(--text);
}

/* NAVBAR */
.app-navbar {
    background: var(--navbar);
    border-bottom: 1px solid var(--border);
    color: var(--navbar-text);
    box-shadow: var(--shadow);
}

.navbar-logo {
    background: rgba(255, 255, 255, 0.18);
    color: #ffffff;
}

.navbar-title,
.navbar-user-name {
    color: var(--navbar-text);
}

.navbar-subtitle,
.navbar-user-role {
    color: rgba(255, 255, 255, 0.78);
}

body.theme-light .navbar-subtitle,
body.theme-light .navbar-user-role {
    color: var(--muted);
}

.navbar-btn {
    color: #0f172a;
    background: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.45);
}

.navbar-btn:hover {
    color: var(--primary);
}

.navbar-btn-danger {
    color: #dc2626;
}

.navbar-btn-danger:hover {
    color: #b91c1c;
}

/* SIDEBAR */
.app-sidebar {
    background: var(--sidebar);
    border-right: 1px solid var(--border);
}

.sidebar-title,
.sidebar-link {
    color: var(--sidebar-text);
}

.sidebar-link:hover {
    background: var(--sidebar-hover);
    color: #ffffff;
}

/* CARD */
.card,
.login-card {
    background: var(--card) !important;
    border: 1px solid var(--border) !important;
    color: var(--text) !important;
    box-shadow: var(--shadow);
}

.login-title p {
    color: var(--muted);
}

/* FORM */
.form-control,
.form-select {
    background: var(--card);
    color: var(--text);
    border-color: var(--border);
}

.form-control:focus,
.form-select:focus {
    background: var(--card);
    color: var(--text);
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.15);
}

.form-control::placeholder {
    color: var(--muted);
}

.form-select option {
    background: var(--card);
    color: var(--text);
}

/* TRANSITIONS */
body,
.app-navbar,
.app-sidebar,
.card,
.login-card,
.sidebar-link,
.form-control,
.form-select,
.navbar-btn {
    transition: background-color 0.2s ease,
                color 0.2s ease,
                border-color 0.2s ease,
                box-shadow 0.2s ease;
}

/* TABLE */
.table {
    --bs-table-bg: var(--card);
    --bs-table-color: var(--text);
    --bs-table-border-color: var(--border);

    --bs-table-hover-bg: var(--primary-soft);
    --bs-table-hover-color: var(--text);

    color: var(--text) !important;
    border-color: var(--border) !important;
}

.table th,
.table td {
    background-color: transparent !important;
    color: var(--text) !important;
    border-color: var(--border) !important;
}

.table thead th {
    background: var(--primary-soft) !important;
    color: var(--text) !important;
    border-color: var(--border) !important;
}

.table tbody tr:hover td {
    background: var(--primary-soft) !important;
    color: var(--text) !important;
}

/* DARK THEME TABLE FIX */
body.theme-dark .table {
    --bs-table-bg: #0f172a;
    --bs-table-color: #f8fafc;
    --bs-table-border-color: #334155;
    --bs-table-hover-bg: #1e293b;
    --bs-table-hover-color: #f8fafc;
}

body.theme-dark .table thead th {
    background: #1e293b !important;
    color: #f8fafc !important;
}

body.theme-dark .table th,
body.theme-dark .table td {
    color: #f8fafc !important;
    border-color: #334155 !important;
}

/* DARK THEME TEXT MUTED FIX */
body.theme-dark .text-muted {
    color: #ffffff !important;
}

body.theme-dark p.text-muted {
    color: #ffffff !important;
}

body.theme-dark .app-content p.text-muted {
    color: #ffffff !important;
}

body.theme-dark .page-subtitle {
    color: #ffffff !important;
}

body.theme-dark .app-content p {
    color: #ffffff !important;
}

body.theme-dark .app-content .d-flex div p {
    color: #ffffff !important;
}

body.theme-dark .app-content .d-flex div p span {
    color: #ffffff !important;
}

/* LIGHT THEME - para hindi flat */
body.theme-light {
    --bg: #f8fafc;
    --card: #ffffff;
    --border: #d1d5db;
    --shadow: 0 8px 22px rgba(15, 23, 42, 0.08);
}

body.theme-light .card {
    box-shadow: var(--shadow);
}

/* CORPORATE TABLE */
body.theme-corporate .table thead th {
    background: #e5e7eb !important;
}