:root {
    --primary-bg: #ffffff;
    --secondary-bg: #f8f9fa;
    --text-color: #212529;
    --card-bg: #ffffff;
    --table-header-bg: #343a40;
    --table-header-text: #ffffff;
}

[data-theme="dark"] {
    --primary-bg: #212529;
    --secondary-bg: #343a40;
    --text-color: #f8f9fa;
    --card-bg: #2c3034;
    --table-header-bg: #495057;
    --table-header-text: #f8f9fa;
}

body {
    background-color: var(--primary-bg);
    color: var(--text-color);
}

.navbar {
    background-color: var(--secondary-bg) !important;
}

.card {
    background-color: var(--card-bg);
    border: none;
    border-radius: 8px;
}

.table {
    color: var(--text-color);
}

.table-dark {
    background-color: var(--table-header-bg);
    color: var(--table-header-text);
}

.alert {
    background-color: var(--card-bg);
    color: var(--text-color);
    border: 1px solid var(--text-color);
}

.btn-primary {
    background-color: #007bff;
    border-color: #007bff;
}

[data-theme="dark"] .btn-primary {
    background-color: #0056b3;
    border-color: #0056b3;
}

.btn-outline-light {
    border-color: var(--text-color);
    color: var(--text-color);
}

[data-theme="dark"] .btn-outline-light {
    border-color: #f8f9fa;
    color: #f8f9fa;
}

.spinner {
    width: 100px;
    height: 100px;
    border: 10px solid var(--secondary-bg);
    border-top: 10px solid #3498db;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

canvas {
    max-width: 100%;
}