/* =========================================
   KleanJob Theme - Bootstrap 5 Overrides
   ========================================= */

:root {
    /* Brand Colors - Overriding Bootstrap Variables where possible in build, 
       but here we use CSS variables for runtime theming */
    --kj-primary: #0d6efd;
    --kj-secondary: #6c757d;
    --kj-success: #198754;
    --kj-danger: #dc3545;
    --kj-warning: #ffc107;
    --kj-info: #0dcaf0;

    /* Typography */
    --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
    --font-mono: 'Source Code Pro', monospace;
}

body {
    font-family: var(--font-sans);
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

/* =========================================
   Dark Mode Support (Attribute-based)
   ========================================= */
[data-theme="dark"] {
    --bs-body-bg: #121212;
    --bs-body-color: #e9ecef;
    --bs-card-bg: #1e1e1e;
    --bs-card-border-color: #333;
    --bs-border-color: #333;

    /* Bootstrap Dark Mode Overrides */
    color-scheme: dark;
}

/* =========================================
   Component Customizations
   ========================================= */

/* Navbar */
.navbar-brand {
    font-weight: 700;
    letter-spacing: -0.5px;
}

.navbar-brand span {
    font-weight: 300;
    opacity: 0.8;
}

/* Cards */
.card {
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

[data-theme="dark"] .card {
    background-color: var(--bs-card-bg);
    border-color: var(--bs-card-border-color);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
}

/* Forms */
.form-control:focus,
.form-select:focus {
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.15);
}

[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
    background-color: #2c2c2c;
    border-color: #444;
    color: #e9ecef;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
    background-color: #2c2c2c;
    border-color: var(--kj-primary);
    color: #e9ecef;
}

/* Tables */
.table {
    vertical-align: middle;
}

/* Dark mode table overrides */
[data-theme="dark"] .table {
    --bs-table-bg: transparent;
    --bs-table-striped-bg: rgba(255, 255, 255, 0.02);
    --bs-table-hover-bg: rgba(255, 255, 255, 0.05);
    --bs-table-border-color: rgba(255, 255, 255, 0.1);
    color: var(--bs-body-color);
    /* Assuming --text-primary maps to body color or similar */
}

[data-theme="dark"] .table thead {
    background-color: rgba(255, 255, 255, 0.05) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

[data-theme="dark"] .table tbody tr {
    border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .table-hover tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.05);
    color: var(--bs-body-color);
    /* Assuming --text-primary maps to body color or similar */
}

/* Dark mode body background */
[data-theme="dark"] body {
    background-color: var(--bs-body-bg) !important;
    /* Using existing --bs-body-bg for consistency */
}

.font-mono {
    font-family: var(--font-mono);
}

/* Status Badges */
.badge {
    font-weight: 500;
    letter-spacing: 0.5px;
    padding: 0.5em 0.8em;
}

.badge-pending {
    background-color: var(--kj-warning);
    color: #000;
}

.badge-done {
    background-color: var(--kj-info);
    color: #fff;
}

.badge-verified {
    background-color: var(--kj-success);
    color: #fff;
}

.badge-ready {
    background-color: #28a745;
    color: #fff;
}

.badge-rejected {
    background-color: var(--kj-danger);
    color: #fff;
}

.badge-canceled {
    background-color: #6c757d;
    color: #fff;
}

/* Toast Container */
#toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1060;
}