:root {
    --sidebar-bg: #343a40;
    --sidebar-color: #fff;
    --sidebar-hover: #495057;
    --body-bg: #f8f9fa;
    --text-color: #333;
    --card-bg: #fff;
    --border-color: #dee2e6;
    --table-bg: #fff;
    --table-stripe: #f8f9fa;
    --alert-bg: #fff;
    --input-bg: #fff;
    --input-border: #ced4da;
    --btn-bg: #fff;
    --btn-color: #333;
}

[data-theme="dark"] {
    --sidebar-bg: #212529;
    --sidebar-color: #fff;
    --sidebar-hover: #495057;
    --body-bg: #121212;
    --text-color: #e9ecef;
    --card-bg: #1e1e1e;
    --border-color: #495057;
    --table-bg: #1e1e1e;
    --table-stripe: #2d2d2d;
    --alert-bg: #1e1e1e;
    --input-bg: #2d2d2d;
    --input-border: #495057;
    --btn-bg: #2d2d2d;
    --btn-color: #e9ecef;
}

body {
    background-color: var(--body-bg);
    color: var(--text-color);
    transition: background-color 0.3s ease, color 0.3s ease;
}

.bg-light {
    background-color: var(--body-bg) !important;
}

.table {
    background-color: var(--table-bg);
    color: var(--text-color);
}

.table-striped > tbody > tr:nth-of-type(odd) > td {
    background-color: var(--table-stripe);
}

.table-dark {
    background-color: var(--card-bg);
    color: var(--text-color);
}

.alert {
    background-color: var(--alert-bg);
    color: var(--text-color);
    border-color: var(--border-color);
}

.form-control {
    background-color: var(--input-bg);
    border-color: var(--input-border);
    color: var(--text-color);
}

.form-control:focus {
    background-color: var(--input-bg);
    border-color: var(--input-border);
    color: var(--text-color);
}

.btn {
    background-color: var(--btn-bg);
    color: var(--btn-color);
    border-color: var(--border-color);
}

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

.theme-toggle {
    position: fixed;
    top: 18px;
    right: 18px;
    z-index: 1045;
    background: var(--sidebar-bg);
    color: var(--sidebar-color);
    border: 1px solid var(--sidebar-color);
    border-radius: 50%;
    width: 45px;
    height: 45px;
    font-size: 1.2rem;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.theme-toggle:hover {
    background: var(--sidebar-hover);
    transform: scale(1.1);
}

.container {
    background-color: var(--card-bg);
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    transition: background-color 0.3s ease;
}

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

.modal-content {
    background-color: var(--card-bg);
    color: var(--text-color);
}

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

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

[data-theme="dark"] .table-dark th,
[data-theme="dark"] .table-dark td {
    color: var(--sidebar-color) !important;
} 

/* Correção para botão Sair sempre vermelho */
.btn-danger.btn-logout,
.btn-danger.btn-logout:focus,
.btn-danger.btn-logout:active {
    color: #fff !important;
    background-color: #dc3545 !important;
    border-color: #dc3545 !important;
}
.btn-danger.btn-logout:hover {
    color: #fff !important;
    background-color: #b02a37 !important;
    border-color: #a71d2a !important;
} 