/* 
 * Estilos principais do Sistema de Prova de Digitação
 * Instituto Dignidade Humana
 */

/* ==========================================
   SISTEMA DE CORES PADRONIZADO - FÁCIL EDIÇÃO
   Edite aqui para alterar cores em todo o sistema
   ========================================== */
/* 
 * IMPORTANTE: Para alterar as cores e configurações do sistema,
 * modifique os valores das variáveis abaixo.
 * Estas configurações foram migradas do banco de dados para facilitar a manutenção.
 */
:root {
    /* === CORES PRINCIPAIS DO SISTEMA === */
    /* Para alterar a cor primária (botões principais, links, etc.) */
    --primary-color: #2e4154;         /* Verde neon - era sistema_cor_primaria */
    --primary-hover: #f5a25d;         /* Verde mais escuro para hover */
    --primary-light: #dbeafe;        /* Azul claro para fundos */
    
    /* Para alterar a cor secundária */
    --secondary-color: #008000;       /* Azul escuro - era sistema_cor_secundaria */
    --secondary-hover: #808000;       /* Azul mais escuro para hover */
    --secondary-light: #f1f5f9;      /* Cinza claro para fundos */
    
    /* === CONFIGURAÇÕES DE LAYOUT === */
    /* Para alterar a largura da barra lateral */
    --sidebar-width: 250px;           /* era layout_sidebar_width */
    
    /* === CONFIGURAÇÕES DO RODAPÉ === */
    /* Para alterar as cores e tamanho do rodapé */
    --footer-background: #2e4154;     /* era layout_footer_background */
    --footer-font-color: #ffffff;     /* era layout_footer_font_color */
    --footer-font-size: 12px;         /* era layout_footer_font_size */
    
    /* === CONFIGURAÇÕES DO LOGO === */
    /* Para alterar o tamanho do logo na primeira coluna */
    --first-column-logo-width: 50px; /* era layout_first_column_logo_width */
    --first-column-logo-height: 25px; /* era layout_first_column_logo_height */
    
    /* ===== CORES DE STATUS ===== */
    /* Verde para sucesso/confirmação */
    --success-color: #059669;        /* Verde principal */
    --success-hover: #047857;        /* Verde mais escuro para hover */
    --success-light: #d1fae5;        /* Verde claro para fundos */
    
    /* Amarelo para avisos */
    --warning-color: #d97706;        /* Amarelo principal */
    --warning-hover: #b45309;        /* Amarelo mais escuro para hover */
    --warning-light: #fef3c7;        /* Amarelo claro para fundos */
    
    /* Vermelho para erros/perigo */
    --danger-color: #dc2626;         /* Vermelho principal */
    --danger-hover: #b91c1c;         /* Vermelho mais escuro para hover */
    --danger-light: #fee2e2;         /* Vermelho claro para fundos */
    
    /* Azul claro para informações */
    --info-color: #0891b2;           /* Azul info principal */
    --info-hover: #0e7490;           /* Azul info mais escuro para hover */
    --info-light: #cffafe;           /* Azul info claro para fundos */
    
    /* ===== CORES GERAIS ===== */
    --light-color: #f8fafc;          /* Cor clara geral */
    --dark-color: #1e293b;           /* Cor escura geral */
    
    /* ===== ESCALA DE CINZAS ===== */
    /* Do mais claro ao mais escuro */
    --gray-100: #f1f5f9;             /* Cinza muito claro */
    --gray-200: #e2e8f0;             /* Cinza claro */
    --gray-300: #cbd5e1;             /* Cinza médio claro */
    --gray-400: #94a3b8;             /* Cinza médio */
    --gray-500: #64748b;             /* Cinza */
    --gray-600: #475569;             /* Cinza escuro */
    --gray-700: #334155;             /* Cinza muito escuro */
    --gray-800: #1e293b;             /* Quase preto */
    --gray-900: #0f172a;             /* Preto */
    
    /* ===== VALORES RGB PARA TRANSPARÊNCIAS ===== */
    /* Usados para efeitos de sombra e transparência */
    --primary-rgb: 37, 99, 235;
    --secondary-rgb: 100, 116, 139;
    --success-rgb: 5, 150, 105;
    --warning-rgb: 217, 119, 6;
    --danger-rgb: 220, 38, 38;
    --info-rgb: 8, 145, 178;
    
    /* ===== CONFIGURAÇÕES GERAIS ===== */
    --font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    
    /* ===== SOMBRAS PADRONIZADAS ===== */
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    
    /* ===== RAIOS DE BORDA PADRONIZADOS ===== */
    --border-radius: 0.5rem;         /* Padrão */
    --border-radius-sm: 0.25rem;     /* Pequeno */
    --border-radius-lg: 0.75rem;     /* Grande */
    --border-radius-xl: 1rem;        /* Extra grande */
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-family);
    line-height: 1.6;
    color: var(--dark-color);
    background-color: #f8f9fa;
}

/* Hero Section */
.hero-section {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');
    opacity: 0.1;
}

.hero-content {
    position: relative;
    z-index: 2;
    color: white;
}

.logo {
    max-width: 200px;
    height: auto;
    filter: brightness(0) invert(1);
}

.hero-image {
    position: relative;
    z-index: 2;
}

.info-item {
    display: flex;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid #eee;
}

.info-item:last-child {
    border-bottom: none;
}

/* ==========================================
   BOTÕES POR SEÇÃO - FÁCIL EDIÇÃO
   ========================================== */

/* ===== BOTÃO BASE (CONFIGURAÇÃO GERAL) ===== */
/* Configurações que se aplicam a todos os botões */
.btn {
    border-radius: var(--border-radius);
    font-weight: 500;
    font-size: 0.875rem;
    line-height: 1.25rem;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease-in-out;
    border: 1px solid transparent;
    box-shadow: var(--shadow-sm);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    white-space: nowrap;
}

.btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}

.btn:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* ===== BOTÕES DA PÁGINA INDEX ===== */
/* Botões principais da página inicial */
.btn-primary {
    background-color: var(--primary-color);     /* Edite aqui a cor do botão principal do index */
    color: white;
    border-color: var(--primary-color);
}

.btn-primary:hover {
    background-color: var(--primary-hover);     /* Edite aqui a cor do hover do botão principal */
    border-color: var(--primary-hover);
    color: white;
}

/* ===== BOTÕES DA ÁREA DE LOGIN ===== */
/* Botões específicos da página de login */
.btn-secondary {
    background-color: var(--secondary-color);   /* Edite aqui a cor dos botões de login */
    color: white;
    border-color: var(--secondary-color);
}

.btn-secondary:hover {
    background-color: var(--secondary-hover);   /* Edite aqui a cor do hover dos botões de login */
    border-color: var(--secondary-hover);
    color: white;
}

/* ===== BOTÕES DE FORMULÁRIOS ADMIN ===== */
/* Botões de submissão e ações em formulários */
.btn-success {
    background-color: var(--success-color);     /* Edite aqui a cor dos botões de submissão */
    color: white;
    border-color: var(--success-color);
}

.btn-success:hover {
    background-color: var(--success-hover);     /* Edite aqui a cor do hover dos botões de submissão */
    border-color: var(--success-hover);
    color: white;
}

/* ===== BOTÕES DE AVISO/EDIÇÃO ===== */
/* Botões para ações de edição e avisos */
.btn-warning {
    background-color: var(--warning-color);     /* Edite aqui a cor dos botões de edição */
    color: white;
    border-color: var(--warning-color);
}

.btn-warning:hover {
    background-color: var(--warning-hover);     /* Edite aqui a cor do hover dos botões de edição */
    border-color: var(--warning-hover);
    color: white;
}

/* ===== BOTÕES DE EXCLUSÃO/PERIGO ===== */
/* Botões para ações perigosas como exclusão */
.btn-danger {
    background-color: var(--danger-color);      /* Edite aqui a cor dos botões de exclusão */
    color: white;
    border-color: var(--danger-color);
}

.btn-danger:hover {
    background-color: var(--danger-hover);      /* Edite aqui a cor do hover dos botões de exclusão */
    border-color: var(--danger-hover);
    color: white;
}

/* ===== BOTÕES DE INFORMAÇÃO ===== */
/* Botões para ações informativas */
.btn-info {
    background-color: var(--info-color);        /* Edite aqui a cor dos botões informativos */
    color: white;
    border-color: var(--info-color);
}

.btn-info:hover {
    background-color: var(--info-hover);        /* Edite aqui a cor do hover dos botões informativos */
    border-color: var(--info-hover);
    color: white;
}

/* ===== BOTÕES ESPECIAIS - EXPORTAÇÃO ===== */
/* Botões para exportar dados (Excel, PDF, etc.) */

/* Botão Excel - Verde Excel */
.btn-excel {
    color: white;
    background-color: #217346;                  /* Edite aqui a cor do botão Excel (verde Excel) */
    border-color: #217346;
    font-weight: 600;
}

.btn-excel:hover {
    color: white;
    background-color: #1a5c37;                  /* Edite aqui a cor do hover do botão Excel */
    border-color: #1a5c37;
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn-excel:focus {
    box-shadow: 0 0 0 0.2rem rgba(33, 115, 70, 0.5);
}

/* Botão PDF - Vermelho Adobe */
.btn-pdf {
    color: white;
    background-color: #dc3545;                  /* Edite aqui a cor do botão PDF (vermelho Adobe) */
    border-color: #dc3545;
    font-weight: 600;
}

.btn-pdf:hover {
    color: white;
    background-color: #c82333;                  /* Edite aqui a cor do hover do botão PDF */
    border-color: #c82333;
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn-pdf:focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.5);
}

/* Botão Imprimir - Cinza escuro */
.btn-print {
    color: white;
    background-color: #495057;                  /* Edite aqui a cor do botão Imprimir */
    border-color: #495057;
    font-weight: 600;
}

.btn-print:hover {
    color: white;
    background-color: #343a40;                  /* Edite aqui a cor do hover do botão Imprimir */
    border-color: #343a40;
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn-print:focus {
    box-shadow: 0 0 0 0.2rem rgba(73, 80, 87, 0.5);
}

/* ===== BOTÕES DE AÇÃO RÁPIDA ===== */
/* Botões pequenos para ações rápidas em tabelas */

.btn-sm {
    padding: 0.375rem 0.75rem;                  /* Edite aqui o tamanho dos botões pequenos */
    font-size: 0.875rem;
    border-radius: var(--border-radius-sm);
}

.btn-lg {
    padding: 1rem 2rem;                         /* Edite aqui o tamanho dos botões grandes */
    font-size: 1.125rem;
    border-radius: var(--border-radius-lg);
}

.btn-block {
    display: block;
    width: 100%;
}

/* ===== GRUPOS DE BOTÕES ===== */
/* Para botões agrupados lado a lado */
.btn-group {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
}

.btn-group > .btn {
    position: relative;
    flex: 1 1 auto;
}

.btn-group > .btn:not(:first-child) {
    margin-left: -1px;
}

.btn-group > .btn:not(:last-child):not(.dropdown-toggle) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.btn-group > .btn:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

/* Botões Outline (Contornados) */
.btn-outline-primary {
    background-color: transparent;
    color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-outline-primary:hover {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

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

.btn-outline-secondary:hover {
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
    color: white;
}

.btn-outline-success {
    background-color: transparent;
    color: var(--success-color);
    border-color: var(--success-color);
}

.btn-outline-success:hover {
    background-color: var(--success-color);
    border-color: var(--success-color);
    color: white;
}

.btn-outline-warning {
    background-color: transparent;
    color: var(--warning-color);
    border-color: var(--warning-color);
}

.btn-outline-warning:hover {
    background-color: var(--warning-color);
    border-color: var(--warning-color);
    color: white;
}

.btn-outline-danger {
    background-color: transparent;
    color: var(--danger-color);
    border-color: var(--danger-color);
}

.btn-outline-danger:hover {
    background-color: var(--danger-color);
    border-color: var(--danger-color);
    color: white;
}

.btn-outline-info {
    background-color: transparent;
    color: var(--info-color);
    border-color: var(--info-color);
}

.btn-outline-info:hover {
    background-color: var(--info-color);
    border-color: var(--info-color);
    color: white;
}

/* Tamanhos de Botões */
.btn-sm {
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    line-height: 1rem;
}

.btn-lg {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    line-height: 1.5rem;
}

.btn-block {
    width: 100%;
    display: flex;
}

/* ==========================================
   TÍTULOS E CABEÇALHOS - FÁCIL EDIÇÃO
   ========================================== */

/* ===== TÍTULOS DE PÁGINAS ADMIN ===== */
/* Títulos principais das páginas do painel admin */
h1.page-title {
    color: var(--gray-800);                      /* Edite aqui a cor dos títulos principais */
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--primary-color); /* Edite aqui a cor da linha sob o título */
    padding-bottom: 0.5rem;
}

/* ===== TÍTULOS DE TABELAS ===== */
/* Cabeçalhos das tabelas de dados */
.table thead th {
    background-color: var(--primary-color);     /* Edite aqui a cor de fundo dos títulos de tabela */
    color: white;                               /* Edite aqui a cor do texto dos títulos de tabela */
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    border: none;
    padding: 1rem 0.75rem;
}

.table thead th:first-child {
    border-top-left-radius: var(--border-radius);
}

.table thead th:last-child {
    border-top-right-radius: var(--border-radius);
}

/* ===== TÍTULOS DE SEÇÕES ===== */
/* Subtítulos para seções dentro das páginas */
h2.section-title {
    color: var(--gray-700);                      /* Edite aqui a cor dos subtítulos de seção */
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 1rem;
    margin-top: 2rem;
}

h3.subsection-title {
    color: var(--gray-600);                      /* Edite aqui a cor dos títulos de subseção */
    font-size: 1.25rem;
    font-weight: 500;
    margin-bottom: 0.75rem;
    margin-top: 1.5rem;
}

/* ==========================================
   CARDS E PAINÉIS - FÁCIL EDIÇÃO
   ========================================== */

/* ===== CARDS PRINCIPAIS ===== */
/* Painéis de conteúdo principais */
.card {
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--gray-200);          /* Edite aqui a cor da borda dos cards */
    background-color: white;                     /* Edite aqui a cor de fundo dos cards */
    box-shadow: var(--shadow);
    overflow: hidden;
}

.card-header {
    background-color: var(--gray-50);           /* Edite aqui a cor de fundo do cabeçalho do card */
    border-bottom: 1px solid var(--gray-200);   /* Edite aqui a cor da linha do cabeçalho */
    padding: 1rem 1.5rem;
    font-weight: 600;
    color: var(--gray-800);                     /* Edite aqui a cor do texto do cabeçalho */
}

.card-body {
    padding: 1.5rem;
    background-color: white;                     /* Edite aqui a cor de fundo do corpo do card */
}

.card-footer {
    background-color: var(--gray-50);           /* Edite aqui a cor de fundo do rodapé do card */
    border-top: 1px solid var(--gray-200);      /* Edite aqui a cor da linha do rodapé */
    padding: 1rem 1.5rem;
}

.card-title {
    margin-bottom: 0.5rem;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--gray-900);                     /* Edite aqui a cor dos títulos dos cards */
}

/* ===== CARDS COM BORDAS COLORIDAS ===== */
/* Cards com indicadores coloridos na lateral */
.card.border-left-primary {
    border-left: 4px solid var(--primary-color); /* Edite aqui a cor da borda azul */
}

.card.border-left-success {
    border-left: 4px solid var(--success-color); /* Edite aqui a cor da borda verde */
}

.card.border-left-warning {
    border-left: 4px solid var(--warning-color); /* Edite aqui a cor da borda amarela */
}

.card.border-left-info {
    border-left: 4px solid var(--info-color);    /* Edite aqui a cor da borda azul info */
}

.card.border-left-danger {
    border-left: 4px solid var(--danger-color);  /* Edite aqui a cor da borda vermelha */
}

/* Typing Test Styles */
.typing-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

.typing-text {
    font-family: 'Courier New', monospace;
    font-size: 18px;
    line-height: 1.8;
    padding: 30px;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
    margin-bottom: 20px;
    max-height: 400px;
    overflow-y: auto;
}

.typing-text span {
    position: relative;
    transition: all 0.2s ease;
}

.typing-text span.correct {
    background-color: #d4edda;
    color: #155724;
}

.typing-text span.incorrect {
    background-color: #f8d7da;
    color: #721c24;
    text-decoration: underline;
}

.typing-text span.active {
    background-color: #cce5ff;
    animation: blink 1s infinite;
}

@keyframes blink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0.3; }
}

.typing-input {
    width: 100%;
    padding: 15px;
    font-size: 18px;
    font-family: 'Courier New', monospace;
    border: 2px solid #ddd;
    border-radius: 8px;
    outline: none;
    transition: border-color 0.3s ease;
}

.typing-input:focus {
    border-color: var(--secondary-color);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

/* ==========================================
   BADGES E ETIQUETAS - FÁCIL EDIÇÃO
   ========================================== */

/* ===== BADGES BÁSICOS ===== */
/* Pequenas etiquetas para status, contadores, etc. */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1;
    border-radius: var(--border-radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.025em;
}

/* ===== BADGES POR TIPO ===== */
/* Cores específicas para diferentes tipos de badges */
.badge.bg-primary {
    background-color: var(--primary-color);     /* Edite aqui a cor de fundo do badge primário */
    color: white;
}

.badge.bg-secondary {
    background-color: var(--secondary-color);   /* Edite aqui a cor de fundo do badge secundário */
    color: white;
}

.badge.bg-success {
    background-color: var(--success-color);     /* Edite aqui a cor de fundo do badge de sucesso */
    color: white;
}

.badge.bg-warning {
    background-color: var(--warning-color);     /* Edite aqui a cor de fundo do badge de aviso */
    color: white;
}

.badge.bg-danger {
    background-color: var(--danger-color);      /* Edite aqui a cor de fundo do badge de perigo */
    color: white;
}

.badge.bg-info {
    background-color: var(--info-color);        /* Edite aqui a cor de fundo do badge de informação */
    color: white;
}

/* ==========================================
   ALERTAS E NOTIFICAÇÕES - FÁCIL EDIÇÃO
   ========================================== */

/* ===== ALERTA BÁSICO ===== */
/* Estrutura base para todos os alertas */
.alert {
    padding: 1rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: var(--border-radius);
    position: relative;
}

/* ===== ALERTAS POR TIPO ===== */
/* Cores específicas para diferentes tipos de alertas */

/* Alerta de Sucesso - Operações bem-sucedidas */
.alert-success {
    background-color: var(--success-light);     /* Edite aqui a cor de fundo do alerta de sucesso */
    border-color: var(--success-color);         /* Edite aqui a cor da borda do alerta de sucesso */
    color: var(--success-hover);                /* Edite aqui a cor do texto do alerta de sucesso */
}

/* Alerta de Aviso - Atenção necessária */
.alert-warning {
    background-color: var(--warning-light);     /* Edite aqui a cor de fundo do alerta de aviso */
    border-color: var(--warning-color);         /* Edite aqui a cor da borda do alerta de aviso */
    color: var(--warning-hover);                /* Edite aqui a cor do texto do alerta de aviso */
}

/* Alerta de Perigo - Erros e problemas */
.alert-danger {
    background-color: var(--danger-light);      /* Edite aqui a cor de fundo do alerta de perigo */
    border-color: var(--danger-color);          /* Edite aqui a cor da borda do alerta de perigo */
    color: var(--danger-hover);                 /* Edite aqui a cor do texto do alerta de perigo */
}

/* Alerta de Informação - Dicas e informações */
.alert-info {
    background-color: var(--info-light);        /* Edite aqui a cor de fundo do alerta de informação */
    border-color: var(--info-color);            /* Edite aqui a cor da borda do alerta de informação */
    color: var(--info-hover);                   /* Edite aqui a cor do texto do alerta de informação */
}

/* ===== BOTÃO DE FECHAR ALERTAS ===== */
/* Botão X para fechar alertas dismissíveis */
.alert-dismissible .btn-close {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    padding: 1.25rem 1rem;
    background: none;
    border: none;
    font-size: 1.25rem;
    opacity: 0.5;
    cursor: pointer;
}

.alert-dismissible .btn-close:hover {
    opacity: 0.75;                              /* Edite aqui a opacidade do botão fechar no hover */
}

/* Stats */
.stats-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin: 20px 0;
}

.stat-card {
    background: white;
    padding: 20px;
    border-radius: var(--border-radius-lg);
    text-align: center;
    box-shadow: var(--shadow);
    transition: transform 0.3s ease;
    border: 1px solid var(--gray-200);
}

.stat-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
}

/* ==========================================
   FORMULÁRIOS ADMIN - FÁCIL EDIÇÃO
   ========================================== */

/* ===== CAMPOS DE ENTRADA (INPUTS) ===== */
/* Campos de texto, email, senha, etc. */
.form-control {
    display: block;
    width: 100%;
    padding: 0.75rem 1rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--gray-900);                      /* Edite aqui a cor do texto nos inputs */
    background-color: white;                     /* Edite aqui a cor de fundo dos inputs */
    background-image: none;
    border: 1px solid var(--gray-300);          /* Edite aqui a cor da borda dos inputs */
    border-radius: var(--border-radius);
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-control:focus {
    color: var(--gray-900);
    background-color: white;
    border-color: var(--primary-color);         /* Edite aqui a cor da borda quando input está focado */
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(var(--primary-rgb), 0.25);
}

.form-control:disabled,
.form-control[readonly] {
    background-color: var(--gray-100);          /* Edite aqui a cor de fundo dos inputs desabilitados */
    opacity: 1;
}

/* ===== CAMPOS DE SELEÇÃO (SELECTS) ===== */
/* Dropdowns e listas de seleção */
.form-select {
    display: block;
    width: 100%;
    padding: 0.75rem 2.25rem 0.75rem 1rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--gray-900);                      /* Edite aqui a cor do texto nos selects */
    background-color: white;                     /* Edite aqui a cor de fundo dos selects */
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 6 7 7 7-7'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    background-size: 16px 12px;
    border: 1px solid var(--gray-300);          /* Edite aqui a cor da borda dos selects */
    border-radius: var(--border-radius);
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    appearance: none;
}

.form-select:focus {
    border-color: var(--primary-color);         /* Edite aqui a cor da borda quando select está focado */
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(var(--primary-rgb), 0.25);
}

/* ===== LABELS E TEXTOS DE AJUDA ===== */
/* Rótulos e textos explicativos dos formulários */
.form-label {
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: var(--gray-700);                      /* Edite aqui a cor dos labels dos formulários */
}

.form-text {
    margin-top: 0.25rem;
    font-size: 0.875em;
    color: var(--gray-600);                      /* Edite aqui a cor dos textos de ajuda */
}

/* ===== GRUPOS DE INPUTS ===== */
/* Inputs com ícones ou texto adicional */
.input-group {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 100%;
}

.input-group-text {
    display: flex;
    align-items: center;
    padding: 0.75rem 1rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--gray-700);                      /* Edite aqui a cor do texto dos grupos de input */
    text-align: center;
    white-space: nowrap;
    background-color: var(--gray-100);          /* Edite aqui a cor de fundo dos grupos de input */
    border: 1px solid var(--gray-300);          /* Edite aqui a cor da borda dos grupos de input */
    border-radius: var(--border-radius);
}

/* ===== VALIDAÇÃO DE FORMULÁRIOS ===== */
/* Estados de sucesso e erro nos campos */
.is-valid {
    border-color: var(--success-color);         /* Edite aqui a cor da borda para campos válidos */
}

.is-valid:focus {
    border-color: var(--success-color);
    box-shadow: 0 0 0 0.2rem rgba(var(--success-rgb), 0.25);
}

.is-invalid {
    border-color: var(--danger-color);          /* Edite aqui a cor da borda para campos inválidos */
}

.is-invalid:focus {
    border-color: var(--danger-color);
    box-shadow: 0 0 0 0.2rem rgba(var(--danger-rgb), 0.25);
}

.valid-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 0.875em;
    color: var(--success-color);                 /* Edite aqui a cor das mensagens de sucesso */
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 0.875em;
    color: var(--danger-color);                  /* Edite aqui a cor das mensagens de erro */
}

.was-validated .is-valid ~ .valid-feedback,
.was-validated .is-invalid ~ .invalid-feedback {
    display: block;
}

/* ==========================================
   TABELAS ADMIN - FÁCIL EDIÇÃO
   ========================================== */

/* ===== TABELA BÁSICA ===== */
/* Estrutura base para todas as tabelas */
.table {
    width: 100%;
    margin-bottom: 1rem;
    color: var(--gray-900);                      /* Edite aqui a cor do texto das tabelas */
    vertical-align: top;
    border-color: var(--gray-200);               /* Edite aqui a cor das bordas das tabelas */
}

.table > :not(caption) > * > * {
    padding: 0.75rem;                           /* Edite aqui o espaçamento interno das células */
    background-color: var(--bs-table-bg);
    border-bottom-width: 1px;
    box-shadow: inset 0 0 0 9999px var(--bs-table-accent-bg);
}

.table > tbody {
    vertical-align: inherit;
}

/* ===== CABEÇALHO DAS TABELAS ===== */
/* Títulos e cabeçalhos das colunas */
.table > thead {
    vertical-align: bottom;
    background-color: var(--gray-50);            /* Edite aqui a cor de fundo do cabeçalho da tabela */
    color: var(--gray-800);                      /* Edite aqui a cor do texto do cabeçalho da tabela */
    font-weight: 600;                            /* Edite aqui o peso da fonte do cabeçalho */
}

/* ===== EFEITOS DE TABELA ===== */
/* Listras alternadas e hover */
.table-striped > tbody > tr:nth-of-type(odd) > td,
.table-striped > tbody > tr:nth-of-type(odd) > th {
    --bs-table-accent-bg: var(--gray-50);       /* Edite aqui a cor das listras alternadas */
}

.table-hover > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > th {
    --bs-table-accent-bg: var(--gray-100);      /* Edite aqui a cor do hover nas linhas da tabela */
}

/* ===== TABELAS COLORIDAS ===== */
/* Tabelas com cores temáticas */

/* Tabela Primária */
.table-primary {
    --bs-table-bg: var(--primary-light);        /* Edite aqui a cor de fundo da tabela primária */
    --bs-table-striped-bg: rgba(var(--primary-rgb), 0.05);
    --bs-table-hover-bg: rgba(var(--primary-rgb), 0.1);
    border-color: var(--primary-color);         /* Edite aqui a cor da borda da tabela primária */
}

/* Tabela de Sucesso */
.table-success {
    --bs-table-bg: var(--success-light);        /* Edite aqui a cor de fundo da tabela de sucesso */
    --bs-table-striped-bg: rgba(var(--success-rgb), 0.05);
    --bs-table-hover-bg: rgba(var(--success-rgb), 0.1);
    border-color: var(--success-color);         /* Edite aqui a cor da borda da tabela de sucesso */
}

/* Tabela de Aviso */
.table-warning {
    --bs-table-bg: var(--warning-light);        /* Edite aqui a cor de fundo da tabela de aviso */
    --bs-table-striped-bg: rgba(var(--warning-rgb), 0.05);
    --bs-table-hover-bg: rgba(var(--warning-rgb), 0.1);
    border-color: var(--warning-color);         /* Edite aqui a cor da borda da tabela de aviso */
}

/* Tabela de Perigo */
.table-danger {
    --bs-table-bg: var(--danger-light);         /* Edite aqui a cor de fundo da tabela de perigo */
    --bs-table-striped-bg: rgba(var(--danger-rgb), 0.05);
    --bs-table-hover-bg: rgba(var(--danger-rgb), 0.1);
    border-color: var(--danger-color);          /* Edite aqui a cor da borda da tabela de perigo */
}

/* Tabela de Informação */
.table-info {
    --bs-table-bg: var(--info-light);           /* Edite aqui a cor de fundo da tabela de informação */
    --bs-table-striped-bg: rgba(var(--info-rgb), 0.05);
    --bs-table-hover-bg: rgba(var(--info-rgb), 0.1);
    border-color: var(--info-color);            /* Edite aqui a cor da borda da tabela de informação */
}

/* ==========================================
   PAGINAÇÃO - FÁCIL EDIÇÃO
   ========================================== */

/* ===== ESTRUTURA DA PAGINAÇÃO ===== */
/* Navegação entre páginas */
.pagination {
    display: flex;
    padding-left: 0;
    list-style: none;
    border-radius: var(--border-radius);
}

/* ===== LINKS DE PÁGINA ===== */
/* Botões de navegação da paginação */
.page-link {
    position: relative;
    display: block;
    color: var(--primary-color);                /* Edite aqui a cor dos links de paginação */
    text-decoration: none;
    background-color: white;                     /* Edite aqui a cor de fundo dos links de paginação */
    border: 1px solid var(--gray-300);          /* Edite aqui a cor da borda dos links de paginação */
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    padding: 0.5rem 0.75rem;
}

.page-link:hover {
    z-index: 2;
    color: var(--primary-hover);                /* Edite aqui a cor dos links no hover */
    background-color: var(--gray-100);          /* Edite aqui a cor de fundo dos links no hover */
    border-color: var(--gray-300);
}

.page-link:focus {
    z-index: 3;
    color: var(--primary-hover);
    background-color: var(--gray-100);
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(var(--primary-rgb), 0.25);
}

/* ===== PÁGINA ATIVA ===== */
/* Página atual selecionada */
.page-item.active .page-link {
    z-index: 3;
    color: white;                                /* Edite aqui a cor do texto da página ativa */
    background-color: var(--primary-color);     /* Edite aqui a cor de fundo da página ativa */
    border-color: var(--primary-color);         /* Edite aqui a cor da borda da página ativa */
}

/* ===== PÁGINA DESABILITADA ===== */
/* Páginas que não podem ser clicadas */
.page-item.disabled .page-link {
    color: var(--gray-400);                      /* Edite aqui a cor do texto das páginas desabilitadas */
    pointer-events: none;
    background-color: white;                     /* Edite aqui a cor de fundo das páginas desabilitadas */
    border-color: var(--gray-300);               /* Edite aqui a cor da borda das páginas desabilitadas */
}

/* ==========================================
   BREADCRUMBS (MIGALHAS DE PÃO) - FÁCIL EDIÇÃO
   ========================================== */

/* ===== ESTRUTURA DO BREADCRUMB ===== */
/* Navegação hierárquica */
.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    list-style: none;
    background-color: var(--gray-100);          /* Edite aqui a cor de fundo do breadcrumb */
    border-radius: var(--border-radius);
}

.breadcrumb-item {
    display: flex;
    color: var(--gray-700);                      /* Edite aqui a cor do texto dos itens do breadcrumb */
}

.breadcrumb-item + .breadcrumb-item {
    padding-left: 0.5rem;
}

.breadcrumb-item + .breadcrumb-item::before {
    float: left;
    padding-right: 0.5rem;
    color: var(--gray-400);                      /* Edite aqui a cor do separador do breadcrumb */
    content: "/";                                /* Edite aqui o símbolo separador (/, >, etc.) */
}

/* ===== ITEM ATIVO DO BREADCRUMB ===== */
/* Página atual no breadcrumb */
.breadcrumb-item.active {
    color: var(--gray-600);                      /* Edite aqui a cor do item ativo do breadcrumb */
}

/* ==========================================
   LAYOUT PERSONALIZADO (MIGRADO DO BANCO)
   ========================================== */

/* ===== APLICAÇÃO DAS CONFIGURAÇÕES MIGRADAS ===== */
/* Configurações de sidebar */
.sidebar {
    width: var(--sidebar-width) !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 1000 !important;
    height: calc(100vh - 60px) !important;
    max-height: calc(100vh - 60px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-bottom: 20px !important;
}

/* Configurações do conteúdo principal */
.main-content {
    margin-left: var(--sidebar-width) !important;
    width: calc(100% - var(--sidebar-width)) !important;
    min-height: 100vh !important;
    padding: 20px !important;
    padding-bottom: 80px !important;
}

/* Configurações do rodapé */
footer {
    background-color: var(--footer-background) !important;
    color: var(--footer-font-color) !important;
    font-size: var(--footer-font-size) !important;
}

/* Configurações do logo da primeira coluna */
.first-column-logo {
    width: var(--first-column-logo-width) !important;
    height: var(--first-column-logo-height) !important;
}

/* Aplicação das cores primárias e secundárias migradas */
.btn-primary {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

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

.navbar-brand {
    color: var(--primary-color) !important;
}

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

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

.stat-value {
    font-size: 2.5rem;
    font-weight: bold;
    color: var(--primary-color);
}

.stat-label {
    color: #666;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Progress Bar */
.progress-container {
    margin: 20px 0;
}

.progress {
    height: 10px;
    border-radius: 5px;
    background-color: #e9ecef;
    overflow: hidden;
}

.progress-bar {
    transition: width 0.3s ease;
    background: linear-gradient(45deg, var(--success-color), #2ecc71);
}

/* Modal Styles */
.modal-content {
    border-radius: 15px;
    border: none;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.modal-header {
    background: linear-gradient(45deg, var(--primary-color), var(--secondary-color));
    color: white;
    border-radius: 15px 15px 0 0;
}

.modal-body {
    padding: 30px;
}

/* Form Styles */
.form-control {
    border-radius: 8px;
    border: 2px solid #e9ecef;
    padding: 12px 15px;
    transition: all 0.3s ease;
}

.form-control:focus {
    border-color: var(--secondary-color);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

.form-label {
    font-weight: 600;
    color: var(--dark-color);
    margin-bottom: 8px;
}

/* Table Styles */
.table {
    background: white;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.table thead th {
    background: var(--primary-color);
    color: white;
    border: none;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.table tbody tr:hover {
    background-color: #f8f9fa;
}

/* Alert Styles */
.alert {
    border-radius: 10px;
    border: none;
    padding: 15px 20px;
    margin-bottom: 20px;
}

.alert-success {
    background: linear-gradient(45deg, #d4edda, #c3e6cb);
    color: #155724;
}

.alert-danger {
    background: linear-gradient(45deg, #f8d7da, #f5c6cb);
    color: #721c24;
}

.alert-warning {
    background: linear-gradient(45deg, #fff3cd, #ffeaa7);
    color: #856404;
}

.alert-info {
    background: linear-gradient(45deg, #d1ecf1, #bee5eb);
    color: #0c5460;
}

/* Sidebar */
.sidebar {
    background: linear-gradient(180deg, #1e3c72 0%, #2a5298 50%, #1e3c72 100%);
    min-height: 100vh;
    height: 100vh;
    padding: 20px 0;
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.15);
    position: fixed;
    top: 0;
    left: 0;
    width: var(--sidebar-width, 250px);
    overflow-y: auto;
    z-index: 1000;
    border-right: 3px solid rgba(255, 255, 255, 0.1);
}

.sidebar .nav-link {
    color: rgba(255, 255, 255, 0.85);
    padding: 14px 20px;
    margin: 3px 0;
    border-radius: 0 30px 30px 0;
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.sidebar .nav-link::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    transition: left 0.5s ease;
}

.sidebar .nav-link:hover::before {
    left: 100%;
}

.sidebar .nav-link:hover,
.sidebar .nav-link.active {
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0.25));
    color: #ffffff;
    transform: translateX(5px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.sidebar .nav-link i {
    width: 20px;
    margin-right: 10px;
}

/* Sidebar Header */
.sidebar-header {
    padding: 20px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.15);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
    margin-bottom: 10px;
}

.sidebar-header h4 {
    color: #ffffff;
    font-weight: 700;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
    margin-bottom: 0;
}

/* User info in sidebar */
.user-info-sidebar {
    margin-top: 15px;
    padding: 12px 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.05);
    border-radius: 8px;
}

.user-info-sidebar small {
    font-size: 0.75rem;
    opacity: 0.8;
    color: rgba(255, 255, 255, 0.7);
}

.user-info-sidebar strong {
    font-size: 0.9rem;
    display: block;
    margin-top: 2px;
    color: #ffffff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

/* Seções do Menu */
.nav-section {
    margin: 25px 0;
    border-top: 2px solid rgba(255, 255, 255, 0.15);
    padding-top: 18px;
    position: relative;
}

.nav-section::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 20px;
    right: 20px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
}

.nav-section-title {
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    padding: 10px 20px;
    margin-bottom: 8px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
    border-radius: 0 20px 20px 0;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.nav-section .nav-link {
    padding-left: 35px;
    font-size: 0.88rem;
    margin-left: 10px;
    border-radius: 0 25px 25px 0;
}

.nav-section .nav-link:hover,
.nav-section .nav-link.active {
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.3));
    color: #ffffff;
    border-left: 4px solid #ffd700;
    transform: translateX(8px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
}

/* Footer Styles */
.footer {
    position: fixed !important;
    bottom: 0 !important;
    left: 250px !important;
    right: 0 !important;
    z-index: 1000 !important;
    margin: 0 !important;
    padding: 12px 20px !important;
    width: calc(100% - 250px) !important;
    background: linear-gradient(135deg, #1e3c72 0%, #2a5298 50%, #1e3c72 100%);
    border-top: 3px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.15);
    backdrop-filter: blur(10px);
}

.footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
}

.footer .container-fluid {
    color: rgba(255, 255, 255, 0.9);
}

.footer .col-md-4 {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
}

.footer .first-column-logo {
    filter: brightness(1.1) contrast(1.1);
    transition: all 0.3s ease;
    max-width: 100%;
    height: auto;
}

.footer .first-column-logo:hover {
    transform: scale(1.05);
    filter: brightness(1.2) contrast(1.2);
}

/* Responsive footer logo sizing */
@media (max-width: 768px) {
    .footer .first-column-logo {
        max-height: 40px;
    }
}

.footer small {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.8rem;
    line-height: 1.4;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.footer .text-center {
    text-align: center !important;
}

/* Navegação do sidebar */
.sidebar-nav {
    padding-bottom: 20px;
}

/* Customização da scrollbar do sidebar */
.sidebar::-webkit-scrollbar {
    width: 6px;
}

.sidebar::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1);
}

.sidebar::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.3);
    border-radius: 3px;
}

.sidebar::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.5);
}

/* Dashboard Cards */
.dashboard-card {
    background: white;
    border-radius: 10px;
    padding: 15px;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
    border-left: 3px solid var(--primary-color);
}

.dashboard-card:hover {
    transform: translateY(-3px);
}

.dashboard-card .icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: white;
    margin-bottom: 10px;
}

.dashboard-card .number {
    font-size: 1.8rem;
    font-weight: bold;
    color: var(--primary-color);
}

.dashboard-card .label {
    color: #666;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Responsive */
@media (max-width: 768px) {
    .hero-section {
        padding: 50px 0;
    }
    
    .display-4 {
        font-size: 2.5rem;
    }
    
    .stats-container {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .typing-text {
        font-size: 16px;
        padding: 20px;
    }
}

@media (max-width: 576px) {
    .stats-container {
        grid-template-columns: 1fr;
    }
    
    .btn-lg {
        padding: 12px 25px;
        font-size: 1rem;
    }
}

/* Loading Spinner */
.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid #f3f3f3;
    border-top: 4px solid var(--primary-color);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 20px auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Main Content Layout */
.main-content {
    margin-left: 250px;
    padding: 15px;
    min-height: 100vh;
    background-color: #f8f9fa;
    width: calc(100% - 250px);
}

.main-content .container-fluid {
    padding: 0 !important;
    margin: 0 !important;
}

.main-content .py-4 {
    padding-top: 0.5rem !important;
    padding-bottom: 1rem !important;
}

.main-content h1, .main-content h2, .main-content h3 {
    margin-top: 0 !important;
    margin-bottom: 0.75rem !important;
}

.main-content .d-flex.justify-content-between.align-items-center.mb-4 {
    margin-bottom: 0.75rem !important;
}

.main-content .mb-4 {
    margin-bottom: 0.75rem !important;
}

/* Responsive adjustments for main content */
@media (max-width: 768px) {
    .main-content {
        margin-left: 0;
        width: 100%;
        padding: 15px;
    }
}

/* Utilities */
.text-primary { color: var(--primary-color) !important; }
.text-secondary { color: var(--secondary-color) !important; }
.text-success { color: var(--success-color) !important; }
.text-warning { color: var(--warning-color) !important; }
.text-danger { color: var(--danger-color) !important; }
.text-info { color: var(--info-color) !important; }

.bg-primary { background-color: var(--primary-color) !important; }
.bg-secondary { background-color: var(--secondary-color) !important; }
.bg-success { background-color: var(--success-color) !important; }
.bg-warning { background-color: var(--warning-color) !important; }
.bg-danger { background-color: var(--danger-color) !important; }
.bg-info { background-color: var(--info-color) !important; }

.shadow-custom {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1) !important;
}

.border-radius-custom {
    border-radius: 15px !important;
}

/* Print Styles */
@media print {
    .no-print {
        display: none !important;
    }
    
    body {
        background: white !important;
        color: black !important;
    }
    
    .card, .table {
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }
}