/* Dark theme for Bootstrap components */

body {
    background-color: var(--background-color);
    color: var(--text-color);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    margin: 0;
    padding: 0;
}

/* Cards */
.card {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

.card-header {
    background-color: var(--sidebar-bg);
    border-color: var(--border-color);
    color: var(--text-color);
}

.card-footer {
    background-color: var(--sidebar-bg);
    border-color: var(--border-color);
}

/* Tables */
.table {
    color: var(--text-color);
}

.table-dark {
    --bs-table-bg: var(--card-background);
    --bs-table-border-color: var(--border-color);
    --bs-table-striped-bg: #333;
    --bs-table-hover-bg: var(--hover-bg);
}

.table > thead {
    background-color: var(--sidebar-bg);
}

.table > tbody > tr:hover {
    background-color: var(--hover-bg);
}

.table-bordered > :not(caption) > * > * {
    border-color: var(--border-color);
}

/* Forms */
.form-control,
.form-select {
    background-color: var(--input-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

.form-control:focus,
.form-select:focus {
    background-color: var(--input-background);
    border-color: var(--primary-blue);
    color: var(--text-color);
    box-shadow: 0 0 0 0.2rem rgba(75, 139, 190, 0.25);
}

.form-control::placeholder {
    color: #6c757d;
}

.form-label {
    color: var(--text-color);
}

.input-group-text {
    background-color: var(--sidebar-bg);
    border-color: var(--border-color);
    color: var(--text-color);
}

/* Modals */
.modal-content {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

.modal-header {
    border-color: var(--border-color);
}

.modal-footer {
    border-color: var(--border-color);
}

.btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

/* Dropdowns */
.dropdown-menu {
    background-color: var(--card-background);
    border-color: var(--border-color);
}

.dropdown-item {
    color: var(--text-color);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--hover-bg);
    color: var(--text-color);
}

.dropdown-divider {
    border-color: var(--border-color);
}

/* Pagination */
.page-link {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

.page-link:hover {
    background-color: var(--hover-bg);
    border-color: var(--border-color);
    color: var(--text-color);
}

.page-item.active .page-link {
    background-color: var(--primary-blue);
    border-color: var(--primary-blue);
}

.page-item.disabled .page-link {
    background-color: var(--sidebar-bg);
    border-color: var(--border-color);
    color: #6c757d;
}

/* Buttons */
.btn-primary {
    background-color: var(--primary-blue);
    border-color: var(--primary-blue);
}

.btn-primary:hover {
    background-color: #3d7aab;
    border-color: #3d7aab;
}

.btn-outline-secondary {
    border-color: var(--border-color);
    color: var(--text-color);
}

.btn-outline-secondary:hover {
    background-color: var(--hover-bg);
    color: var(--text-color);
}

/* Badges */
.badge.bg-draft { background-color: #6c757d !important; }
.badge.bg-active { background-color: var(--success-color) !important; }
.badge.bg-completed { background-color: var(--primary-blue) !important; }
.badge.bg-archived { background-color: var(--warning-color) !important; color: #000 !important; }

/* Alerts */
.alert-dark {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

/* Tooltips and Popovers */
.tooltip-inner {
    background-color: var(--card-background);
    color: var(--text-color);
}

/* Nav tabs */
.nav-tabs {
    border-color: var(--border-color);
}

.nav-tabs .nav-link {
    color: var(--text-color);
}

.nav-tabs .nav-link:hover {
    border-color: var(--border-color);
}

.nav-tabs .nav-link.active {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

/* Scrollbar */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--background-color);
}

::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #6c757d;
}

/* List groups */
.list-group-item {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

.list-group-item:hover {
    background-color: var(--hover-bg);
}

/* Toast */
.toast {
    background-color: var(--card-background);
    border-color: var(--border-color);
    color: var(--text-color);
}

/* Accordion */
.accordion-item {
    background-color: var(--card-background);
    border-color: var(--border-color);
}

.accordion-button {
    background-color: var(--card-background);
    color: var(--text-color);
}

.accordion-button:not(.collapsed) {
    background-color: var(--sidebar-bg);
    color: var(--text-color);
}

/* Breadcrumb */
.breadcrumb {
    background-color: transparent;
}

.breadcrumb-item a {
    color: var(--primary-blue);
}

.breadcrumb-item.active {
    color: #adb5bd;
}

/* Progress */
.progress {
    background-color: var(--sidebar-bg);
}

/* Spinner */
.spinner-border {
    color: var(--primary-blue);
}

/* Utility */
.text-muted {
    color: #adb5bd !important;
}

a {
    color: var(--primary-blue);
}

a:hover {
    color: #6cb0e0;
}

hr {
    border-color: var(--border-color);
}

/* Leaflet dark overrides */
.leaflet-control-zoom a {
    background-color: var(--card-background) !important;
    color: var(--text-color) !important;
    border-color: var(--border-color) !important;
}

.leaflet-control-layers {
    background-color: var(--card-background) !important;
    color: var(--text-color) !important;
    border-color: var(--border-color) !important;
}
