body {
    font-size: 0.875rem;
}

.feather {
    width: 16px;
    height: 16px;
    vertical-align: text-bottom;
}

.sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 100; 
    padding: 48px 0 0; 
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1);
}

.sidebar-sticky {
    position: relative;
    top: 0;
    height: calc(100vh - 48px); 
    padding-top: .5rem;
    overflow-x: hidden;
    overflow-y: auto;
}

.sidebar .nav-link {
    font-weight: 500;
    color: #333;
    padding: .75rem 1.25rem; 
}

.sidebar .nav-link.active {
    color: #007bff;
}

.sidebar .nav-link:hover {
    color: #007bff;
    background-color: #e9ecef;
}

.sidebar .nav-link i {
    margin-right: 10px; 
    color: #999;
}

.sidebar .nav-link.active i {
    color: #007bff;
}

.navbar-nav li.dropdown {
    position: relative; 
}

.navbar-nav .dropdown-menu {
    position: absolute !important; 
    z-index: 1050;          
    top: 100%;              
    right: 0;               
    left: auto;             
    min-width: 160px;       
}
.navbar-nav li.dropdown.show .dropdown-menu {
    display: block;
}


.navbar-brand {
    padding-top: .75rem;
    padding-bottom: .75rem;
    font-size: 1rem;
    background-color: rgba(0, 0, 0, .25);
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25);
}

[role="main"] {
    padding-top: 48px; 
}


@media (max-width: 767.98px) {
    .navbar.sticky-top {
        display: flex;
        flex-wrap: wrap;     
        padding-top: 0.5rem;    
        padding-bottom: 0.5rem; 
        align-items: center;    
        --toggler-icon-margin-top: 48px; 
    }

    .navbar .navbar-brand {
        width: 100%;            
        order: 1;               
        text-align: center;     
        padding-left: 15px;     
        padding-right: 15px;    
        margin-bottom: 0.5rem;  
        font-size: 1.1rem;      
        flex-grow: 0;           
        line-height: 1.5;       
    }
    
    .navbar .navbar-toggler.d-md-none {
        order: 2;               
        position: static;       
        transform: none;        
        margin-right: auto;     
        margin-left: 10px;      
        
        padding-top: .5rem; 
        padding-bottom: .5rem;
        padding-left: .75rem; 
        padding-right: .75rem;

        font-size: 0.9rem;      
        z-index: 1035;
        display: inline-flex;   
        align-items: center;    
        
        margin-top: var(--toggler-icon-margin-top);
    }

    .navbar .navbar-toggler.d-md-none .navbar-toggler-icon {
        width: 1.1em;           
        height: 1.1em;
    }

    .navbar-nav.ml-auto {
        order: 3;               
        margin-left: 0;         
        padding-right: 10px;    
        display: flex;
        align-items: center; 
    }
    
    .navbar-nav .dropdown-menu {
    }

    .sidebar {
        padding-top: 0; 
    }

    .sidebar.show {
        top: 135px; 
        left: 0;
        right: 0;
        width: 100%;
        height: calc(100vh - 135px); 
        z-index: 1060; 
        background-color: #f8f9fa;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075);
    }

    .sidebar.collapsing {
        height: calc(100vh - 135px) !important; 
        transition: none !important; 
    }
    
    .sidebar.collapse:not(.show) {
    }

    .sidebar-sticky {
        height: 100%; 
        padding-top: 1rem; 
        padding-bottom: 1rem; 
    }
}


.border-left-primary {
    border-left: .25rem solid #4e73df !important;
}

.border-left-success {
    border-left: .25rem solid #1cc88a !important;
}

.border-left-info {
    border-left: .25rem solid #36b9cc !important;
}

.border-left-warning {
    border-left: .25rem solid #f6c23e !important;
}

.border-left-danger {
    border-left: .25rem solid #e74a3b !important;
}

.text-gray-300 {
    color: #dddfeb !important;
}

.text-gray-800 {
    color: #5a5c69 !important;
}

.form-signin {
    width: 100%;
    max-width: 330px;
    padding: 15px;
    margin: auto;
}

.form-signin .form-control {
    position: relative;
    box-sizing: border-box;
    height: auto;
    padding: 10px;
    font-size: 16px;
}

.form-signin .form-control:focus {
    z-index: 2;
}

.table th {
    font-size: 0.85rem;
    background-color: #f8f9fc;
    border-bottom-width: 1px;
}

.table td {
    vertical-align: middle;
}

.card-header {
    background-color: #f8f9fc;
    border-bottom: 1px solid #e3e6f0;
}

.card-header h6 {
    color: #4e73df;
}

.btn-circle {
    border-radius: 100%;
    height: 2.5rem;
    width: 2.5rem;
    font-size: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-circle.btn-sm {
    height: 1.8rem;
    width: 1.8rem;
    font-size: 0.75rem;
}

.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 15px;
}

.tag-item {
    background-color: #f0f0f0;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 4px 8px;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.2s;
}

.tag-item:hover {
    background-color: #e0e0e0;
}

.qrcode-container {
    text-align: center;
    padding: 20px;
    margin: 20px 0;
    border: 1px solid #ddd;
    border-radius: 4px;
}

.connection-status {
    padding: 10px 15px;
    border-radius: 4px;
    margin-bottom: 20px;
}

.connection-status.connected {
    background-color: #d4edda;
    color: #155724;
}

.connection-status.disconnected {
    background-color: #f8d7da;
    color: #721c24;
}

.progress-container {
    margin: 20px 0;
}

.badge-counter {
    position: absolute;
    transform: scale(0.7);
    transform-origin: top right;
    right: 0;
    top: 0;
}

.form-revenda {
    background-color: #fff;
    padding: 20px;
    border-radius: 5px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}

.navbar-dark .navbar-nav .nav-link {
    color: rgba(255,255,255,.8);
}

.navbar-dark .navbar-nav .nav-link:hover {
    color: rgba(255,255,255,1);
}

.credit-info {
    font-size: 0.9rem;
    background-color: #f8f9fc;
    border-radius: 4px;
}

.verification-code {
    letter-spacing: 5px;
    font-size: 24px;
    text-align: center;
    font-weight: bold;
}

.error-container {
    text-align: center;
    padding: 100px 0;
}

.error-container i {
    font-size: 5rem;
    color: #e74a3b;
}

.error-container h1 {
    font-size: 2.5rem;
    margin: 20px 0;
}

.error-container p {
    font-size: 1.2rem;
    color: #666;
    margin-bottom: 30px;
}

#modeloMensagemContainer img,
#modeloMensagemContainer video {
    max-width: 100%;
    height: auto;
    display: block;
    margin-left: auto;
    margin-right: auto;
    object-fit: contain; 
}

#modeloMensagemContainer audio {
    width: 100%;    
    max-width: 100%; 
    display: block; 
}

.login-page-body {
    background-color: #f0f2f5; 
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    margin: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; 
}

.login-card {
    border: 1px solid #e0e0e0; 
    border-radius: 12px; 
    background-color: #ffffff;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.07), 0 7px 10px rgba(0, 0, 0, 0.05);
}

.login-card-header {
    background-color: transparent; 
    border-bottom: none; 
    padding-top: 2rem !important; 
    padding-bottom: 1.5rem !important; 
}

.login-card-header h2 {
    color: #333; 
    font-weight: 600; 
}

.login-logo svg {
    border-radius: 12px; 
}

.login-tabs .nav-link {
    color: #6c757d; 
    border: none;
    border-bottom: 2px solid transparent; 
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    font-weight: 500;
}

.login-tabs .nav-link.active {
    color: #007bff; 
    border-bottom-color: #007bff;
    background-color: transparent; 
}

.login-tabs .nav-link:hover {
    color: #0056b3; 
    border-bottom-color: #0056b3;
}

.login-card .form-control {
    border-radius: 6px; 
    border: 1px solid #ced4da;
    padding: 0.75rem 1rem; 
}

.login-card .form-control:focus {
    border-color: #80bdff;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.login-card .btn-primary {
    background-color: #007bff;
    border-color: #007bff;
    padding: 0.75rem; 
    font-weight: 500;
    border-radius: 8px; 
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.login-card .btn-primary:hover {
    background-color: #0056b3;
    border-color: #0052a8; 
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); 
}

.login-card .btn-success,
.login-card .btn-success:focus,
.login-card .btn-success:active {
    background-color: #007bff !important; 
    border-color: #007bff !important;    
    color: #fff !important; 
    box-shadow: none !important; 
    padding: 0.75rem;
    font-weight: 500;
    border-radius: 8px; 
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.login-card .btn-success:hover {
    background-color: #0056b3 !important; 
    border-color: #0052a8 !important;    
    color: #fff !important;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1) !important; 
}

.login-card .btn-success:focus {
    outline: none;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25) !important; 
}


.login-card .input-group-text {
    background-color: #e9ecef; 
    border: 1px solid #ced4da;
    border-right: none; 
    border-radius: 6px 0 0 6px;
}

.login-card .form-control {
    border-left: none; 
    border-radius: 0 6px 6px 0;
}

#register .form-control {
    border-left: 1px solid #ced4da;
    border-radius: 6px;
}

/* Estilos para página de login no tema escuro */
body.dark-theme.login-page-body {
    background-color: #1a1a1a;
    color: #f8f9fa;
}

body.dark-theme .login-card {
    background-color: #2c2c2c;
    border-color: #404040;
}

body.dark-theme .login-card-header {
    background-color: #232323;
    border-bottom-color: #404040;
    color: #f8f9fa;
}

body.dark-theme .login-card .card-body {
    background-color: #2c2c2c;
    color: #f8f9fa;
}

body.dark-theme .login-card .form-control {
    background-color: #3a3a3a;
    border-color: #505050;
    color: #f8f9fa;
}

body.dark-theme .login-card .form-control:focus {
    background-color: #3a3a3a;
    border-color: #8ab4f8;
    color: #f8f9fa;
    box-shadow: 0 0 0 0.2rem rgba(138, 180, 248, 0.25);
}

body.dark-theme .login-card .input-group-text {
    background-color: #3a3a3a;
    border-color: #505050;
    color: #adb5bd;
}

body.dark-theme .login-card label {
    color: #f8f9fa;
}

body.dark-theme .login-tabs .nav-link {
    color: #adb5bd;
    border-color: #404040;
}

body.dark-theme .login-tabs .nav-link.active {
    background-color: #232323;
    border-color: #404040 #404040 #232323;
    color: #8ab4f8;
}

body.dark-theme .login-tabs .nav-link:hover {
    color: #8ab4f8;
    border-color: #404040;
}

body.dark-theme .login-card .alert {
    background-color: #3a3a3a;
    border-color: #505050;
}

body.dark-theme .login-card .alert-danger {
    background-color: #5a2a2a;
    border-color: #7a3a3a;
    color: #ffcccc;
}

body.dark-theme .login-card .alert-success {
    background-color: #2a5a2a;
    border-color: #3a7a3a;
    color: #ccffcc;
}

body.dark-theme .login-card .text-muted {
    color: #adb5bd !important;
}

body.dark-theme .login-card a {
    color: #8ab4f8;
}

body.dark-theme .login-card a:hover {
    color: #99cfff;
}

/* Estilos para o Modal de Mensagem Global */
#modalMensagemGlobal .modal-body {
    padding-left: 25px;
    padding-right: 25px;
}

#modalMensagemGlobal .modal-footer {
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 25px;
    padding-right: 25px;
}

#modalMensagemGlobal .modal-title i {
    font-size: 1.2em; /* Ícone um pouco maior no título */
}

/* Temas Claro e Escuro */
body.light-theme {
    background-color: #f8f9fa; /* Cor de fundo principal para o tema claro */
    color: #212529; /* Cor de texto principal para o tema claro */
}

body.light-theme .navbar {
    background-color: #343a40 !important; /* Navbar escura no tema claro, conforme original */
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
}

body.light-theme .navbar-brand {
    background-color: rgba(0, 0, 0, .25) !important;
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25) !important;
}

body.light-theme .sidebar {
    background-color: #f8f9fa; /* Fundo da sidebar no tema claro */
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1);
}

body.light-theme .sidebar .nav-link {
    color: #333;
}

body.light-theme .sidebar .nav-link.active,
body.light-theme .sidebar .nav-link:hover {
    color: #007bff;
}

body.light-theme .sidebar .nav-link i {
    color: #999;
}

body.light-theme .sidebar .nav-link.active i {
    color: #007bff;
}

body.light-theme .card {
    background-color: #fff;
    border: 1px solid #e3e6f0;
}

body.light-theme .card-header {
    background-color: #f8f9fc;
    border-bottom: 1px solid #e3e6f0;
    color: #5a5c69;
}

body.light-theme .card-header h6 {
    color: #4e73df;
}

body.light-theme .table {
    color: #212529;
    background-color: #fff;
}

body.light-theme .table th {
    background-color: #f8f9fc;
    color: #5a5c69;
    border-bottom-width: 1px;
}

body.light-theme .table td {
    border-color: #e3e6f0;
}

body.light-theme .form-control {
    background-color: #fff;
    color: #495057;
    border: 1px solid #ced4da;
}

body.light-theme .modal-content {
    background-color: #fff;
    color: #212529;
}

body.light-theme .modal-header {
    border-bottom: 1px solid #dee2e6;
}

body.light-theme .modal-footer {
    border-top: 1px solid #dee2e6;
}

body.light-theme .dropdown-menu {
    background-color: #fff;
    border: 1px solid rgba(0,0,0,.15);
}

body.light-theme .dropdown-item {
    color: #212529;
}

body.light-theme .dropdown-item:hover,
body.light-theme .dropdown-item:focus {
    color: #16181b;
    background-color: #f8f9fa;
}


/* Tema Escuro */
body.dark-theme {
    background-color: #1a1a1a; /* Cor de fundo principal para o tema escuro */
    color: #f8f9fa; /* Cor de texto principal para o tema escuro */
}

body.dark-theme .navbar {
    background-color: #2c2c2c !important; /* Navbar um pouco mais clara que o fundo no tema escuro */
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.2) !important;
}

body.dark-theme .navbar-brand {
    background-color: rgba(0, 0, 0, .25) !important;
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25) !important;
}

body.dark-theme .navbar-dark .navbar-nav .nav-link {
    color: rgba(255,255,255,.85);
}
body.dark-theme .navbar-dark .navbar-nav .nav-link:hover {
    color: #fff;
}


body.dark-theme .sidebar {
    background-color: #232323; /* Fundo da sidebar no tema escuro */
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25);
}

body.dark-theme .sidebar .nav-link {
    color: #adb5bd;
}

body.dark-theme .sidebar .nav-link.active,
body.dark-theme .sidebar .nav-link:hover {
    color: #8ab4f8; /* Um azul claro para destaque no tema escuro */
    background-color: #303030;
}

body.dark-theme .sidebar .nav-link i {
    color: #6c757d;
}

body.dark-theme .sidebar .nav-link.active i {
    color: #8ab4f8;
}

/* Certificando que a sidebar e seus conteúdos diretos peguem o tema escuro */
body.dark-theme .sidebar {
    background-color: #232323 !important; /* Fundo da sidebar no tema escuro */
    box-shadow: inset -1px 0 0 rgba(0, 0, 0, .25) !important;
}

body.dark-theme .sidebar .nav-link {
    color: #adb5bd !important;
}

body.dark-theme .sidebar .nav-link:hover {
    color: #8ab4f8 !important;
    background-color: #303030 !important;
}

body.dark-theme .sidebar .nav-link.active {
    color: #ffffff !important; /* Texto branco para o item ativo */
    background-color: #007bff !important; /* Fundo azul para destaque, similar ao tema claro */
}
body.dark-theme .sidebar .nav-link.active:hover {
    color: #ffffff !important;
    background-color: #0056b3 !important; /* Um azul mais escuro no hover do ativo */
}


body.dark-theme .sidebar .nav-link i {
    color: #6c757d !important;
}

body.dark-theme .sidebar .nav-link.active i {
    color: #ffffff !important; /* Ícone branco para o item ativo */
}


body.dark-theme .card {
    background-color: #2c2c2c;
    border: 1px solid #444;
    color: #f8f9fa;
}

body.dark-theme .card-body { /* Adicionando regra específica para card-body */
    background-color: #2c2c2c; /* Mesmo fundo do card */
    color: #f8f9fa;       /* Mesma cor de texto do card */
}

body.dark-theme .card-header {
    background-color: #343a40;
    border-bottom: 1px solid #444;
    color: #f8f9fa;
}

body.dark-theme .card-header h6 {
    color: #8ab4f8;
}

body.dark-theme .table {
    color: #f8f9fa;
    background-color: #2c2c2c;
}

body.dark-theme .table th,
body.dark-theme .table td {
    border-color: #444;
}

body.dark-theme .table th {
    background-color: #343a40;
    color: #f8f9fa;
}

body.dark-theme .form-control {
    background-color: #343a40;
    color: #f8f9fa;
    border: 1px solid #555;
}

body.dark-theme .form-control:focus {
    background-color: #3a3f44;
    border-color: #8ab4f8;
    color: #f8f9fa;
}

body.dark-theme .modal-content {
    background-color: #2c2c2c;
    color: #f8f9fa;
    border: 1px solid #444;
}

body.dark-theme .modal-header {
    border-bottom: 1px solid #444;
}
body.dark-theme .modal-header .close {
    color: #f8f9fa;
}

body.dark-theme .modal-footer {
    border-top: 1px solid #444;
}

body.dark-theme .dropdown-menu {
    background-color: #2c2c2c;
    border: 1px solid #444;
    color: #f8f9fa;
}

body.dark-theme .dropdown-item {
    color: #f8f9fa;
}

body.dark-theme .dropdown-item:hover,
body.dark-theme .dropdown-item:focus {
    color: #fff;
    background-color: #343a40;
}

body.dark-theme .btn-light {
    color: #f8f9fa;
    background-color: #3a3f44;
    border-color: #3a3f44;
}
body.dark-theme .btn-light:hover {
    background-color: #4a4f54;
    border-color: #4a4f54;
}

body.dark-theme .text-primary {
    color: #8ab4f8 !important;
}
body.dark-theme .text-muted {
    color: #adb5bd !important;
}
body.dark-theme .text-dark {
    color: #e9ecef !important;
}
body.dark-theme .text-gray-800 {
    color: #e9ecef !important;
}
body.dark-theme .text-gray-300 {
    color: #6c757d !important;
}
body.dark-theme .border-left-primary {
    border-left-color: #8ab4f8 !important;
}
body.dark-theme .border-left-success {
    border-left-color: #5cb85c !important; /* Manter verde, mas talvez um tom diferente se necessário */
}
body.dark-theme .border-left-info {
    border-left-color: #5bc0de !important;
}
body.dark-theme .border-left-warning {
    border-left-color: #f0ad4e !important;
}
body.dark-theme .border-left-danger {
    border-left-color: #d9534f !important;
}

/* Ajustes específicos para elementos que podem não herdar bem */
body.dark-theme .list-group-item {
    background-color: #2c2c2c;
    border-color: #444;
    color: #f8f9fa;
}
body.dark-theme .list-group-item-action:hover, body.dark-theme .list-group-item-action:focus {
    background-color: #343a40;
}
body.dark-theme .custom-file-label {
    background-color: #343a40;
    border-color: #555;
    color: #f8f9fa;
}
body.dark-theme .custom-select {
    background-color: #343a40;
    border-color: #555;
    color: #f8f9fa;
}
body.dark-theme .page-link {
    background-color: #343a40;
    border-color: #555;
    color: #8ab4f8;
}
body.dark-theme .page-item.disabled .page-link {
    color: #6c757d;
    background-color: #2c2c2c;
    border-color: #555;
}
body.dark-theme .page-item.active .page-link {
    background-color: #8ab4f8;
    border-color: #8ab4f8;
    color: #1a1a1a;
}
body.dark-theme .badge-secondary {
    color: #1a1a1a;
    background-color: #adb5bd;
}
body.dark-theme .progress {
    background-color: #343a40;
}

body.dark-theme .tag-item {
    background-color: #3a3f44 !important; /* Fundo escuro para as tags */
    border-color: #555 !important;        /* Borda mais escura */
    color: #f8f9fa !important;           /* Texto claro */
}

body.dark-theme .tag-item:hover {
    background-color: #4a4f54 !important; /* Um pouco mais claro no hover */
    border-color: #666 !important;
    color: #ffffff !important;
}

/* Estilos para a página de atualizações no tema escuro */
body.dark-theme .update-item h5 {
    color: #f8f9fa; /* Título branco no tema escuro */
}
body.dark-theme .update-item .update-date {
    color: #adb5bd; /* Um cinza claro para a data no tema escuro */
}
body.dark-theme .update-item .update-content {
    color: #f8f9fa; /* Cor de texto branca para o conteúdo no tema escuro */
}

/* Reforçando estilos de modais genéricos para tema escuro */
body.dark-theme .modal-content {
    background-color: #2c2c2c !important;
    color: #f8f9fa !important;
    border: 1px solid #444 !important;
}

body.dark-theme .modal-header {
    border-bottom: 1px solid #444 !important;
}
body.dark-theme .modal-header .close { /* Para o botão 'x' de fechar */
    color: #f8f9fa !important;
    text-shadow: none !important;
}
body.dark-theme .modal-header .close:hover {
    color: #fff !important;
}

body.dark-theme .modal-body {
    /* A cor do texto já deve ser herdada de .modal-content, mas pode ser reforçada se necessário */
    /* color: #f8f9fa !important; */
}

body.dark-theme .modal-footer {
    border-top: 1px solid #444 !important;
}
/* Fim dos estilos reforçados para modais */

/* Estilos para modais de alerta/confirmação (tentativa mais abrangente) */
body.dark-theme .modal-dialog .modal-content, /* Bootstrap padrão */
body.dark-theme .swal2-popup { /* SweetAlert2 comum */
    background-color: #2c2c2c !important;
    color: #f8f9fa !important;
}

body.dark-theme .modal-dialog .modal-header,
body.dark-theme .swal2-header,
body.dark-theme .swal2-title {
    color: #f8f9fa !important;
    border-bottom-color: #444 !important;
}

body.dark-theme .modal-dialog .modal-body,
body.dark-theme .swal2-html-container,
body.dark-theme .swal2-content { /* SweetAlert2 antigo */
    color: #f8f9fa !important;
}

body.dark-theme .modal-dialog .modal-footer,
body.dark-theme .swal2-actions {
    border-top-color: #444 !important;
}

body.dark-theme .swal2-confirm,
body.dark-theme .swal2-deny,
body.dark-theme .swal2-cancel {
    /* Estilos para botões dentro do SweetAlert2, se necessário */
    /* Exemplo:
    background-color: #007bff !important;
    color: white !important;
    */
}
/* Fim dos estilos para modais de alerta */

body.dark-theme #infoClienteModal .modal-body,
body.dark-theme #infoClienteModal .modal-body p,
body.dark-theme #infoClienteModal .modal-body strong {
    color: #f8f9fa !important;
}

body.dark-theme .credit-info {
    background-color: #2c2c2c !important; 
    color: #adb5bd !important; 
    border: 1px solid #444 !important;
    border-radius: 4px; /* Mantendo o border-radius original */
}

/* Ajustes para cor de texto em hover/focus no tema escuro */
body.dark-theme a:hover,
body.dark-theme a:focus {
    /* Cor de link genérica no hover/focus - pode precisar de ajuste se for muito abrangente */
    /* Por enquanto, vamos focar nos dropdowns e nav-links que são mais críticos */
}

body.dark-theme .dropdown-item:hover,
body.dark-theme .dropdown-item:focus {
    color: #ffffff !important; /* Garante texto branco no hover/focus */
    background-color: #343a40 !important; /* Mantém o fundo escuro no hover/focus */
}

/* Para links de navegação, se necessário (já parecem estar ok, mas para garantir) */
body.dark-theme .nav-link:hover,
body.dark-theme .nav-link:focus {
    color: #ffffff !important; /* Garante texto branco no hover/focus */
}

/* Se houver botões com texto que muda de cor indevidamente */
body.dark-theme .btn:hover,
body.dark-theme .btn:focus {
    /* Se um botão específico estiver causando problemas, ele precisará de uma regra mais direcionada.
       Exemplo: body.dark-theme .btn-primary:hover { color: #fff !important; } */
}

/* Para o texto dentro do dropdown do usuário na navbar */
body.dark-theme .navbar-nav .dropdown-menu .dropdown-item {
    color: #f8f9fa !important; /* Cor base do texto */
}
body.dark-theme .navbar-nav .dropdown-menu .dropdown-item:hover,
body.dark-theme .navbar-nav .dropdown-menu .dropdown-item:focus {
    color: #ffffff !important; /* Cor do texto no hover/focus */
    background-color: #343a40 !important; /* Fundo no hover/focus */
}

/* Para os ícones dentro dos dropdown-items, caso estejam mudando de cor */
body.dark-theme .dropdown-item i {
    color: #adb5bd; /* Cor padrão para ícones no tema escuro */
}

body.dark-theme .dropdown-item:hover i,
body.dark-theme .dropdown-item:focus i {
    color: #ffffff !important; /* Ícones brancos no hover/focus do item */
}

/* Ajustes para hover em tabelas e listas no tema escuro */
body.dark-theme .table tbody tr:hover,
body.dark-theme .table.table-hover tbody tr:hover { /* Adicionando especificidade para .table-hover */
    background-color: #343a40 !important; /* Fundo um pouco mais claro no hover da linha */
    color: #ffffff !important; /* Cor do texto padrão para a linha no hover */
}

body.dark-theme .table tbody tr:hover td,
body.dark-theme .table tbody tr:hover th,
body.dark-theme .table.table-hover tbody tr:hover td, /* Adicionando especificidade */
body.dark-theme .table.table-hover tbody tr:hover th { /* Adicionando especificidade */
    color: #ffffff !important; /* Garante que o texto nas células fique branco */
}

body.dark-theme .table tbody tr:hover td a,
body.dark-theme .table tbody tr:hover th a,
body.dark-theme .table.table-hover tbody tr:hover td a, /* Adicionando especificidade */
body.dark-theme .table.table-hover tbody tr:hover th a { /* Adicionando especificidade */
    color: #99cfff !important; /* Cor para links dentro de linhas de tabela no hover, um azul claro */
}
body.dark-theme .table tbody tr:hover td a:hover,
body.dark-theme .table tbody tr:hover th a:hover,
body.dark-theme .table.table-hover tbody tr:hover td a:hover, /* Adicionando especificidade */
body.dark-theme .table.table-hover tbody tr:hover th a:hover { /* Adicionando especificidade */
    color: #ffffff !important; /* Links ficam brancos no hover do link em si */
}

/* Para List Group Items, caso sejam usados para as listas mencionadas */
body.dark-theme .list-group-item:hover,
body.dark-theme .list-group-item:focus {
    background-color: #343a40 !important;
    color: #ffffff !important;
    border-color: #444 !important; /* Mantém a borda consistente */
}

body.dark-theme .list-group-item:hover a,
body.dark-theme .list-group-item:focus a {
    color: #99cfff !important; /* Links dentro de list-group-item no hover */
}

body.dark-theme .list-group-item:hover a:hover,
body.dark-theme .list-group-item:focus a:hover {
    color: #ffffff !important;
}

/* Caso as listas sejam apenas divs ou outros elementos com links diretos */
body.dark-theme .card-body a:hover, /* Exemplo se a lista estiver num card-body */
body.dark-theme .modal-body a:hover { /* Exemplo se a lista estiver num modal-body */
    color: #99cfff !important; /* Cor de hover para links genéricos em contextos escuros */
}
body.dark-theme .card-body a:hover:not(.btn), 
body.dark-theme .modal-body a:hover:not(.btn) {
    color: #99cfff !important; /* Evitar aplicar a botões que têm seus próprios estilos */
}

/* Correção para cor do texto em TAG Info e Observacao no modal de informações do cliente no tema escuro */
body.dark-theme #infoClienteModal #detalhesCliente #info_cliente_info_tag,
body.dark-theme #infoClienteModal #detalhesCliente #info_cliente_observacao {
    color: #f8f9fa !important; /* Cor de texto clara */
}

/* Estilos para abas no modal de informações do cliente no tema escuro */
body.dark-theme #infoClienteModal .nav-tabs .nav-link {
    color: #f8f9fa !important; /* Texto branco para TODAS as abas */
    background-color: transparent; /* Fundo padrão para abas inativas */
    border: 1px solid #444; /* Borda padrão para abas inativas */
    border-bottom-color: #444; /* Garante a linha inferior separando do conteúdo */
    margin-bottom: -1px; /* Compensa a borda inferior do container .nav-tabs */
}

/* Feedback visual sutil para abas inativas no hover/focus */
body.dark-theme #infoClienteModal .nav-tabs .nav-link:hover,
body.dark-theme #infoClienteModal .nav-tabs .nav-link:focus {
    color: #f8f9fa !important; /* Mantém texto branco */
    background-color: #3a3f44; /* Leve mudança de fundo no hover/focus */
    border-color: #555 #555 #555; /* Borda levemente mais clara no hover/focus */
}

body.dark-theme #infoClienteModal .nav-tabs .nav-link.active {
    color: #f8f9fa !important; /* Texto branco para aba ativa */
    background-color: #2c2c2c !important; /* Fundo da aba ativa igual ao corpo do modal/tab-content */
    border-width: 1px;
    border-style: solid;
    border-color: #f8f9fa #f8f9fa #2c2c2c !important; /* Borda superior e laterais brancas, inferior da cor do conteúdo */
}

/* Garante que a aba ativa não mude de cor no hover/focus, mantendo o destaque */
body.dark-theme #infoClienteModal .nav-tabs .nav-link.active:hover,
body.dark-theme #infoClienteModal .nav-tabs .nav-link.active:focus {
    color: #f8f9fa !important;
    background-color: #2c2c2c !important;
    border-color: #f8f9fa #f8f9fa #2c2c2c !important; /* Mantém a borda destacada */
}

/* Estilos para o Page Loader */
#page-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.99); /* Cor de fundo padrão (tema claro) - Ainda mais opaco */
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.5s ease-out;
}

html.dark-theme #page-loader {
    background-color: rgba(26, 26, 26, 0.99); /* Cor de fundo para tema escuro - Ainda mais opaco */
}

.loader-dots {
    display: flex;
}

.loader-dots span {
    width: 12px;
    height: 12px;
    margin: 0 4px;
    background-color: #007bff; /* Cor padrão dos pontinhos (tema claro) */
    border-radius: 50%;
    animation: dotPulse 1.4s infinite ease-in-out;
    animation-fill-mode: both;
}

html.dark-theme .loader-dots span {
    background-color: #8ab4f8; /* Cor dos pontinhos para tema escuro */
}

.loader-dots span:nth-child(1) {
    animation-delay: -0.32s;
}

.loader-dots span:nth-child(2) {
    animation-delay: -0.16s;
}

.loader-dots span:nth-child(3) {
    animation-delay: 0s;
}

.loader-dots span:nth-child(4) {
    animation-delay: 0.16s;
}

.loader-dots span:nth-child(5) {
    animation-delay: 0.32s;
}

@keyframes dotPulse {
    0%, 80%, 100% {
        transform: scale(0.5);
        opacity: 0.5;
    }
    40% {
        transform: scale(1);
        opacity: 1;
    }
}

/* Classe para esconder o loader */
#page-loader.hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none; /* Impede interação com o loader escondido */
}

.grafico-card-body {
    min-height: 280px; /* Reduzido um pouco mais */
    display: flex; /* Para ajudar a centralizar o canvas se ele for menor */
    align-items: center; /* Centraliza verticalmente */
    justify-content: center; /* Centraliza horizontalmente */
}

.grafico-card-body canvas {
    max-height: 100%; /* Garante que o canvas não ultrapasse a altura do card-body */
    max-width: 100%;
}
