/* ===== EASYDOC MODERN THEME SYSTEM ===== */

/* CSS Variables para tema unificado */
:root {
    /* Transições suaves */
    --transition-smooth: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-fast: all 0.15s ease-in-out;

    /* Sombras */
    --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);

    /* Bordas */
    --border-radius-sm: 4px;
    --border-radius: 6px;
    --border-radius-md: 8px;
    --border-radius-lg: 12px;
}

/* MODO CLARO (Light Mode) */
body:not(.dark-mode),
body.light-mode {
    /* Cores de fundo */
    --bg-primary: #ffffff;
    --bg-secondary: #f8fafc;
    --bg-tertiary: #f1f5f9;
    --bg-quaternary: #e2e8f0;

    /* Cores de superficie */
    --surface-primary: #ffffff;
    --surface-secondary: #f8fafc;
    --surface-elevated: #ffffff;

    /* Cores de texto */
    --text-primary: #1e293b;
    --text-secondary: #475569;
    --text-tertiary: #64748b;
    --text-quaternary: #94a3b8;
    --text-inverse: #ffffff;

    /* Cores de borda */
    --border-primary: #e2e8f0;
    --border-secondary: #cbd5e1;
    --border-focus: #3b82f6;

    /* Cores de ação */
    --primary: #3b82f6;
    --primary-hover: #2563eb;
    --primary-light: #dbeafe;

    --success: #10b981;
    --success-hover: #059669;
    --success-light: #d1fae5;

    --warning: #f59e0b;
    --warning-hover: #d97706;
    --warning-light: #fef3c7;

    --danger: #ef4444;
    --danger-hover: #dc2626;
    --danger-light: #fee2e2;

    --info: #06b6d4;
    --info-hover: #0891b2;
    --info-light: #cffafe;

    /* Estados de hover */
    --hover-primary: #f8fafc;
    --hover-secondary: #f1f5f9;

    /* Estados específicos */
    --input-bg: #ffffff;
    --input-border: #d1d5db;
    --table-stripe: #f9fafb;
    --table-hover: #f3f4f6;

    /* Cores dos cards do dashboard */
    --card-blue: #3b82f6;
    --card-red: #ef4444;
    --card-green: #10b981;
    --card-yellow: #f59e0b;
    --card-purple: #8b5cf6;

    /* Sombras para modo claro */
    --shadow-color: rgba(0, 0, 0, 0.1);
}

/* MODO ESCURO (Dark Mode) */
body.dark-mode {
    /* Cores de fundo */
    --bg-primary: #0f172a;
    --bg-secondary: #1e293b;
    --bg-tertiary: #334155;
    --bg-quaternary: #475569;

    /* Cores de superficie */
    --surface-primary: #1e293b;
    --surface-secondary: #334155;
    --surface-elevated: #475569;

    /* Cores de texto */
    --text-primary: #f1f5f9;
    --text-secondary: #e2e8f0;
    --text-tertiary: #cbd5e1;
    --text-quaternary: #94a3b8;
    --text-inverse: #0f172a;

    /* Cores de borda */
    --border-primary: #334155;
    --border-secondary: #475569;
    --border-focus: #60a5fa;

    /* Cores de ação - ajustadas para melhor contraste */
    --primary: #60a5fa;
    --primary-hover: #3b82f6;
    --primary-light: #1e3a8a;

    --success: #34d399;
    --success-hover: #10b981;
    --success-light: #064e3b;

    --warning: #fbbf24;
    --warning-hover: #f59e0b;
    --warning-light: #92400e;

    --danger: #f87171;
    --danger-hover: #ef4444;
    --danger-light: #991b1b;

    --info: #22d3ee;
    --info-hover: #06b6d4;
    --info-light: #164e63;

    /* Estados de hover */
    --hover-primary: #334155;
    --hover-secondary: #475569;

    /* Estados específicos */
    --input-bg: #334155;
    --input-border: #475569;
    --table-stripe: #334155;
    --table-hover: #475569;

    /* Cores dos cards do dashboard - melhor contraste */
    --card-blue: #60a5fa;
    --card-red: #f87171;
    --card-green: #34d399;
    --card-yellow: #fbbf24;
    --card-purple: #a78bfa;

    /* Sombras para modo escuro */
    --shadow-color: rgba(0, 0, 0, 0.4);
}

/* APLICAÇÃO GLOBAL DO TEMA */
body {
    background-color: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    transition: var(--transition-smooth);
}

/* Layout principal */
.box-general {
    background-color: var(--bg-primary) !important;
}

/* Header */
.header {
    background-color: var(--surface-primary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
    box-shadow: var(--shadow-sm);
}

.topbar {
    background-color: var(--surface-primary) !important;
}

/* Sidebar */
.sidebar,
.menu-sidebar {
    background-color: var(--surface-secondary) !important;
    border-right: 1px solid var(--border-primary) !important;
}

.sidebar ul li a,
.menu-sidebar ul li a {
    color: var(--text-secondary) !important;
    transition: var(--transition-fast);
}

.sidebar ul li a:hover,
.menu-sidebar ul li a:hover,
.sidebar ul li a.active,
.menu-sidebar ul li a.active {
    background-color: var(--hover-primary) !important;
    color: var(--text-primary) !important;
}

/* Container principal */
.container {
    background-color: var(--bg-secondary) !important;
}

/* Cards e superfícies */
.card,
.dash-info-icon,
.box-content,
.table-wrap,
.modal-content,
.dropdown-menu {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
    box-shadow: var(--shadow);
    transition: var(--transition-smooth);
}

.card-header {
    background-color: var(--surface-secondary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
}

/* Textos */
h1, h2, h3, h4, h5, h6 {
    color: var(--text-primary) !important;
}

p, span, div, td, th, label {
    color: var(--text-secondary) !important;
}

.text-muted,
.small-text {
    color: var(--text-tertiary) !important;
}

/* Inputs e formulários */
input,
select,
textarea,
.form-control,
.form-select {
    background-color: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--text-primary) !important;
    transition: var(--transition-fast);
}

input:focus,
select:focus,
textarea:focus,
.form-control:focus,
.form-select:focus {
    border-color: var(--border-focus) !important;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1) !important;
}

input::placeholder,
textarea::placeholder {
    color: var(--text-quaternary) !important;
}

/* Botões */
.btn {
    transition: var(--transition-fast);
    border-radius: var(--border-radius) !important;
}

.btn-blue,
.btn-primary {
    background-color: var(--primary) !important;
    border-color: var(--primary) !important;
    color: var(--text-inverse) !important;
}

.btn-blue:hover,
.btn-primary:hover {
    background-color: var(--primary-hover) !important;
    border-color: var(--primary-hover) !important;
}

.btn-gray,
.btn-default {
    background-color: var(--surface-secondary) !important;
    border: 1px solid var(--border-primary) !important;
    color: var(--text-primary) !important;
}

.btn-gray:hover,
.btn-default:hover {
    background-color: var(--hover-secondary) !important;
}

/* Theme Toggle Button */
.theme-btn {
    background: transparent !important;
    border: 1px solid var(--border-primary) !important;
    color: var(--text-secondary) !important;
    padding: 0.5rem !important;
    border-radius: var(--border-radius) !important;
    cursor: pointer;
    transition: var(--transition-fast);
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.theme-btn:hover {
    background-color: var(--hover-primary) !important;
    border-color: var(--primary) !important;
    color: var(--primary) !important;
    transform: scale(1.05);
}

/* Tabelas */
table {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
}

table thead {
    background-color: var(--surface-secondary) !important;
}

table thead th {
    color: var(--text-primary) !important;
    border-bottom: 2px solid var(--border-primary) !important;
}

table tbody tr {
    border-bottom: 1px solid var(--border-primary) !important;
}

table tbody tr:nth-child(even) {
    background-color: var(--table-stripe) !important;
}

table tbody tr:hover {
    background-color: var(--table-hover) !important;
}

/* Badges e labels */
.badge {
    border-radius: var(--border-radius-sm) !important;
}

.badge-blue {
    background-color: var(--card-blue) !important;
    color: var(--text-inverse) !important;
}

.badge-red {
    background-color: var(--card-red) !important;
    color: var(--text-inverse) !important;
}

.badge-green {
    background-color: var(--card-green) !important;
    color: var(--text-inverse) !important;
}

.badge-yellow {
    background-color: var(--card-yellow) !important;
    color: var(--text-inverse) !important;
}

/* Cards do Dashboard */
.dash-info-icon.ocean {
    background: linear-gradient(135deg, var(--card-blue), #2563eb) !important;
}

.dash-info-icon.red {
    background: linear-gradient(135deg, var(--card-red), #dc2626) !important;
}

.dash-info-icon.green {
    background: linear-gradient(135deg, var(--card-green), #059669) !important;
}

.dash-info-icon.yellow {
    background: linear-gradient(135deg, var(--card-yellow), #d97706) !important;
}

.dash-info-icon .big-text,
.dash-info-icon .small-text {
    color: var(--text-inverse) !important;
}

/* Alertas */
.alert {
    border-radius: var(--border-radius) !important;
    border: 1px solid var(--border-primary) !important;
}

.alert-default {
    background-color: var(--surface-secondary) !important;
    color: var(--text-secondary) !important;
}

/* Dropdown */
.dropdown-menu {
    border: 1px solid var(--border-primary) !important;
    box-shadow: var(--shadow-lg);
}

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

.dropdown-item:hover {
    background-color: var(--hover-primary) !important;
    color: var(--text-primary) !important;
}

/* Modais */
.modal-content {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
}

.modal-header {
    border-bottom: 1px solid var(--border-primary) !important;
}

.modal-footer {
    border-top: 1px solid var(--border-primary) !important;
}

/* Gráficos e charts */
.chart-container {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--border-radius) !important;
}

/* Scrollbars para dark mode */
body.dark-mode ::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

body.dark-mode ::-webkit-scrollbar-track {
    background: var(--bg-secondary);
}

body.dark-mode ::-webkit-scrollbar-thumb {
    background: var(--border-secondary);
    border-radius: 4px;
}

body.dark-mode ::-webkit-scrollbar-thumb:hover {
    background: var(--text-quaternary);
}

/* Animações e transições */
* {
    transition: var(--transition-smooth);
}

/* Estados de carregamento */
.loading {
    opacity: 0.7;
    pointer-events: none;
}

/* Fix para elementos específicos */
.page-header {
    background-color: var(--surface-primary) !important;
    border-bottom: 1px solid var(--border-primary) !important;
}

.title {
    color: var(--text-primary) !important;
}

/* Melhorias para acessibilidade */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Gráficos Chart.js - Correção para dark mode */
body.dark-mode canvas {
    filter: brightness(1.1) !important;
}

/* Correções específicas para textos que ficam invisíveis */
body.dark-mode .chart-title,
body.dark-mode .chart-legend,
body.dark-mode .chart-labels {
    color: var(--text-primary) !important;
    fill: var(--text-primary) !important;
}

/* Correções para elementos SVG */
body.dark-mode svg text {
    fill: var(--text-primary) !important;
}

body.dark-mode svg .domain,
body.dark-mode svg .tick line {
    stroke: var(--border-primary) !important;
}

/* Select2 - Dropdown melhorado */
body.dark-mode .select2-container--default .select2-selection--single {
    background-color: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--text-primary) !important;
}

body.dark-mode .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text-primary) !important;
}

body.dark-mode .select2-dropdown {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
}

body.dark-mode .select2-container--default .select2-results__option {
    background-color: var(--surface-primary) !important;
    color: var(--text-secondary) !important;
}

body.dark-mode .select2-container--default .select2-results__option--highlighted {
    background-color: var(--primary) !important;
    color: var(--text-inverse) !important;
}

/* Tab navigation */
.tab-main .nav li a {
    color: var(--text-secondary) !important;
    border-bottom: 2px solid transparent;
    transition: var(--transition-fast);
}

.tab-main .nav li.active a,
.tab-main .nav li a:hover {
    color: var(--primary) !important;
    border-bottom-color: var(--primary) !important;
}

/* Melhorias para a sidebar */
.sidebar {
    box-shadow: 2px 0 8px var(--shadow-color);
}

.sidebar ul li.active a {
    background-color: var(--primary) !important;
    color: var(--text-inverse) !important;
}

.sidebar ul li.active a i {
    color: var(--text-inverse) !important;
}

/* Page header */
.page-header .title {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 0;
}

/* Charts container - período */
.chart-period-container {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
    border-radius: var(--border-radius) !important;
    padding: 1rem;
}

/* Texto dos gráficos */
.chart-period-container h3,
.chart-period-container .chart-title {
    color: var(--text-primary) !important;
    text-align: center;
    margin-bottom: 1rem;
}

/* Filtros de data */
.date-range-text {
    color: var(--text-tertiary) !important;
    font-size: 0.875rem;
    text-align: center;
    margin-bottom: 0.5rem;
}

/* Loading states */
.loading-overlay {
    background-color: rgba(var(--bg-primary), 0.8) !important;
    color: var(--text-primary) !important;
}

/* Tooltips */
.tooltip {
    background-color: var(--surface-elevated) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border-primary) !important;
    box-shadow: var(--shadow-md);
}

/* Links */
a {
    color: var(--primary) !important;
    text-decoration: none;
    transition: var(--transition-fast);
}

a:hover {
    color: var(--primary-hover) !important;
}

/* Error messages */
.error {
    color: var(--danger) !important;
    font-size: 0.875rem;
    margin-top: 0.25rem;
}

/* Success messages */
.success {
    color: var(--success) !important;
}

/* Warning messages */
.warning {
    color: var(--warning) !important;
}

/* Paginação */
.pagination {
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
}

.pagination a,
.pagination span {
    color: var(--text-secondary) !important;
    background-color: var(--surface-primary) !important;
    border: 1px solid var(--border-primary) !important;
}

.pagination a:hover {
    background-color: var(--hover-primary) !important;
    color: var(--text-primary) !important;
}

.pagination .active span {
    background-color: var(--primary) !important;
    color: var(--text-inverse) !important;
}

/* Correções para chart.js específico */
.chart-container canvas {
    background-color: var(--surface-primary) !important;
}

/* Força contraste em todos os textos dentro de gráficos */
body.dark-mode .chartjs-tooltip {
    background-color: var(--surface-elevated) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border-primary) !important;
}

/* Print styles */
@media print {
    body {
        background-color: white !important;
        color: black !important;
    }

    .sidebar {
        display: none !important;
    }

    .theme-toggle {
        display: none !important;
    }
}

/* RESPONSIVIDADE MOBILE */
@media (max-width: 768px) {
    /* Stack columns on mobile */
    .col-50 {
        width: 100% !important;
        margin-right: 0 !important;
    }

    /* Fix modal sizing */
    .modal-main {
        width: 95% !important;
        margin: 10px auto !important;
    }

    /* Ensure tables scroll horizontally */
    .table-wrap {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }

    /* Adjust padding for container */
    .container {
        padding: 10px !important;
    }

    /* Adjust button sizes for touch */
    .btn {
        padding: 12px 20px !important;
        height: auto !important;
    }
}
