/* C:\Projetos\wcontrol\static\css\style.css */

/* --- 1. Variáveis de Cor e Configurações Globais --- */
:root {
    --bg-dark: #212529;
    --bg-card: #343a40;
    --border-color: #495057;
    --text-primary: #f8f9fa;
    --text-secondary: #adb5bd;
    --accent-blue: #0d6efd;
    --accent-green: #198754;
    --accent-yellow: #ffc107;
    --accent-red: #dc3545;
    --accent-gray: #6c757d; 
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; background-color: var(--bg-dark); color: var(--text-primary); }
.text-secondary { color: var(--text-secondary); }
.page-container { display: flex; min-height: 100vh; }
.sidebar { width: 260px; background-color: var(--bg-card); border-right: 1px solid var(--border-color); padding: 20px; display: flex; flex-direction: column; flex-shrink: 0; }
.main-content { flex-grow: 1; padding: 40px; overflow-y: auto; }
.sidebar-header { margin-bottom: 30px; padding-bottom: 20px; border-bottom: 1px solid var(--border-color); }
.sidebar-header h3 { font-size: 1.8rem; color: var(--text-primary); text-align: center; }
.sidebar-header h3 .fa-solid { color: var(--accent-blue); }
.sidebar-nav ul { list-style: none; }
.sidebar-nav li a { display: flex; align-items: center; gap: 15px; padding: 15px 10px; border-radius: 6px; color: var(--text-secondary); text-decoration: none; font-size: 1rem; font-weight: bold; transition: background-color 0.2s, color 0.2s; }
.sidebar-nav li a:hover, .sidebar-nav li a.active { background-color: rgba(13, 110, 253, 0.1); color: var(--text-primary); border-left: 3px solid var(--accent-blue); padding-left: 7px; }
.sidebar-nav li a .fa-solid { width: 20px; text-align: center; }
.sidebar .logout-link { margin-top: auto; }
.card { background-color: var(--bg-card); border: 1px solid var(--border-color); border-radius: 8px; padding: 30px; margin-bottom: 30px; }
.header-with-button { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; flex-wrap: wrap; gap: 10px;}
h1 { margin-bottom: 30px; font-size: 2.2rem; }
h2 { border-bottom: 1px solid var(--border-color); padding-bottom: 15px; margin-bottom: 25px; font-weight: 300; color: var(--text-secondary); }
.form-group label { color: var(--text-secondary); margin-bottom: 8px; font-size: 0.9rem; }
/* --- Bloco Modificado: Padronização da Altura dos Campos de Formulário --- */
/* A propriedade 'height' foi adicionada para garantir que todos os campos de formulário
   tenham uma altura consistente de 47px, o que facilitará o alinhamento com os botões. */
.form-group input, .form-group select.form-control, .form-group textarea.form-control { 
    background-color: var(--bg-dark); 
    border: 1px solid var(--border-color); 
    color: var(--text-primary); 
    padding: 12px; 
    border-radius: 6px; 
    font-size: 1rem; 
    width: 100%;
    height: 47px; /* Adicionado */
}
/* Ajuste para Textarea, que pode ter altura variável */
.form-group textarea.form-control {
    height: auto; /* Permite que o textarea cresça com a propriedade 'rows' */
}
.form-group input:focus, .form-group textarea.form-control:focus, .form-group select.form-control:focus { background-color: #2c3034; border-color: var(--accent-blue); outline: none; box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.25); }
.form-row { display: flex; gap: 25px; width: 100%; flex-wrap: wrap; margin-bottom: 20px; }
.form-row .form-group { flex: 1; min-width: 250px; }
.form-group-checkbox { display: flex; align-items: center; padding-top: 30px; }
.form-group-checkbox input { width: auto; margin-right: 10px; flex-shrink: 0; }
.form-group input:disabled, .form-group input[readonly] { background-color: #2c3034; opacity: 0.7; }
.form-group input[readonly] { cursor: pointer; }
.btn { padding: 12px 20px; border: none; border-radius: 6px; cursor: pointer; font-size: 1rem; font-weight: bold; text-decoration: none !important; display: inline-flex; align-items: center; text-align: center; transition: all 0.2s; }
.btn:hover { opacity: 0.9; transform: translateY(-1px); }
.btn-primary { background-color: var(--accent-blue); color: white; }
.btn-success { background-color: var(--accent-green); color: white; }
.btn-danger { background-color: var(--accent-red); color: white; }
.btn-warning { background-color: var(--accent-yellow); color: #212529; }
.btn-secondary { background-color: var(--accent-gray); color: white; } 
form button[type="submit"] { margin-top: 15px; }
.table-container { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
table th, table td { padding: 15px; border-bottom: 1px solid var(--border-color); text-align: left; vertical-align: middle; }
table thead th { background-color: rgba(0,0,0,0.2); color: var(--text-secondary); font-weight: 600; }
.action-buttons { display: flex; gap: 10px; flex-wrap: wrap; }

.action-buttons .btn {
    min-width: 110px;
    justify-content: center; 
}

/* --- Bloco Modificado: Padronização da Largura e Altura dos Botões de Filtro --- */
.form-group .btn {
    min-width: 110px;
    justify-content: center;
    height: 47px; /* Adicionado: Garante que os botões tenham a mesma altura dos campos de formulário */
}

.messages-container { position: fixed; top: 20px; right: 20px; z-index: 1000; width: 100%; max-width: 350px; }
.alert { padding: 15px; border-radius: 6px; color: white; margin-bottom: 10px; border: 1px solid rgba(0,0,0,0.2); box-shadow: 0 5px 15px rgba(0,0,0,0.2); display: flex; justify-content: space-between; align-items: center; }
.alert-success { background-color: #14482f; border-color: var(--accent-green); }
.alert-danger { background-color: #58151c; border-color: var(--accent-red); }
.alert-warning { background-color: #664d03; border-color: var(--accent-yellow); }
.alert-info { background-color: #055160; border-color: #6edff6; }
.alert-warning, .alert-warning p, .alert-warning strong { color: var(--text-primary) !important; }
.close-alert-btn { background: none; border: none; color: white; font-size: 1.2rem; cursor: pointer; opacity: 0.7; transition: opacity 0.2s; }
.close-alert-btn:hover { opacity: 1; }
.status-badge { padding: 4px 10px; border-radius: 12px; font-size: 12px; font-weight: bold; text-transform: uppercase; }
.status-ativa, .status-concluida { background-color: var(--accent-green); color: white; }
.status-inativa, .status-bloqueada, .status-pendente { background-color: #6c757d; color: white; }
.status-vencida { background-color: var(--accent-yellow); color: var(--bg-dark); }
.status-programada { background-color: var(--accent-blue); color: white; }
.semaforo-container { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 30px; margin-bottom: 40px; }
.semaforo-card { border-radius: 50%; width: 200px; height: 200px; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; margin: 0 auto; transition: transform 0.2s; }
.semaforo-card:hover { transform: scale(1.05); }
.semaforo-card h2 { font-size: 1.2rem; margin: 0; padding: 0; border: none; color: var(--text-primary); text-shadow: 1px 1px 2px rgba(0,0,0,0.4); }
.semaforo-count { font-size: 4rem; font-weight: bold; line-height: 1; color: white; text-shadow: 1px 1px 2px rgba(0,0,0,0.4); }
.semaforo-card p { font-size: 0.9rem; color: var(--text-primary); margin-top: 5px; text-shadow: 1px 1px 2px rgba(0,0,0,0.4); }

.semaforo-verde { background-color: var(--accent-green); color: white !important; }
.semaforo-amarelo { background-color: var(--accent-yellow); color: var(--bg-dark) !important; }
.semaforo-vermelho { background-color: var(--accent-red); color: white !important; }

.semaforo-amarelo h2, .semaforo-amarelo p, .semaforo-amarelo .semaforo-count { color: var(--bg-dark); text-shadow: none; }
.apontamento-item { display: flex; gap: 20px; padding: 20px 0; border-bottom: 1px solid var(--border-color); align-items: flex-start; }
.apontamento-item:first-of-type { padding-top: 0; }
.apontamento-item:last-of-type { border-bottom: none; padding-bottom: 0; }
.apontamento-foto { flex-shrink: 0; }
.apontamento-foto img { width: 100px; height: 100px; object-fit: cover; border-radius: 6px; border: 2px solid var(--border-color); }
.apontamento-info { flex-grow: 1; }
.apontamento-info p { margin: 4px 0; }
.apontamento-info p strong { font-weight: 500; }
.apontamento-info .text-secondary i { margin-right: 5px; }
.apontamento-actions { flex-shrink: 0; }
.login-body { display: flex; justify-content: center; align-items: center; }
.login-body .main-content { flex-grow: 0; padding: 20px; }
.login-card { width: 100%; max-width: 450px; }
.login-body .messages-container { left: 50%; transform: translateX(-50%); right: auto; }
.checkbox-list { display: flex; flex-direction: column; gap: 10px; max-height: 200px; overflow-y: auto; background-color: var(--bg-dark); padding: 10px; border-radius: 6px; border: 1px solid var(--border-color); }
.checkbox-item { display: flex; align-items: center; }
.checkbox-item input { margin-right: 10px; width: auto; flex-shrink: 0; }
.checkbox-item label { width: 100%; }
.progress-bar { width: 100%; background-color: var(--bg-dark); border-radius: 10px; overflow: hidden; border: 1px solid var(--border-color); }
.progress-bar-fill { height: 20px; background-color: var(--accent-green); color: white; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: bold; transition: width 0.5s ease-in-out; }

.modal-backdrop { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.7); z-index: 1040; display: none; justify-content: center; align-items: center; }
.modal-backdrop.show { display: flex; }
.modal-content { background-color: var(--bg-card); border: 1px solid var(--border-color); border-radius: 8px; width: 90%; max-width: 600px; max-height: 80vh; overflow-y: auto; display: flex; flex-direction: column; }
.modal-header { padding: 20px; border-bottom: 1px solid var(--border-color); display: flex; justify-content: space-between; align-items: center; }
.modal-header h2 { margin: 0; border: none; padding: 0; }
.modal-close-button { background: none; border: none; color: var(--text-secondary); font-size: 2rem; cursor: pointer; line-height: 1; }
.modal-body { padding: 30px; }
.modal-body p { margin-bottom: 15px; line-height: 1.6; }
.modal-body p strong { color: var(--text-secondary); }

a.view-details-link { color: var(--text-primary); text-decoration: none; cursor: pointer; font-weight: bold; transition: color 0.2s; }
a.view-details-link:hover { color: #a9c7ff; text-decoration: underline; }

.form-control[readonly].flatpickr-input {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke-width='1.5' stroke='%23f8f9fa'%3E%3Cpath d='M11.5 2.25v-1.5m-7 1.5v-1.5M2.5 5.25h11'/%3E%3Cpath d='M12.25 1.5h-8.5a1 1 0 0 0 -1 1v11a1 1 0 0 0 1 1h8.5a1 1 0 0 0 1-1v-11a1 1 0 0 0 -1-1z' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 16px;
}

input[type="date"].form-control {
    background-color: var(--bg-dark);
    color: var(--text-primary);
}

input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1);
    cursor: pointer;
}

/* --- Bloco Responsivo "Mobile-First" --- */
@media (max-width: 768px) {
    .page-container { flex-direction: column; }
    .sidebar { width: 100%; height: auto; border-right: none; border-bottom: 1px solid var(--border-color); }
    .main-content { padding: 20px; }
    h1 { font-size: 1.8rem; }
    .header-with-button { flex-direction: column; align-items: stretch; }
    .header-with-button .btn { width: 100%; }
    .semaforo-container { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; }
    .semaforo-card { width: 180px; height: 180px; }
    .semaforo-count { font-size: 3rem; }
    .apontamento-item { flex-direction: column; align-items: stretch; }
    
    .action-buttons .btn,
    .action-buttons form {
        width: 100%;
        display: block; 
    }
    .action-buttons .btn {
        width: 100%;
    }
    .action-buttons form + .btn, 
    .action-buttons .btn + form,
    .action-buttons .btn + .btn {
        margin-top: 10px; 
    }
    
    table thead { display: none; }
    table, table tbody, table tr, table td { display: block; width: 100%; }
    table tr { margin-bottom: 20px; border: 1px solid var(--border-color); border-radius: 6px; padding: 10px; }
    table td { padding: 10px; text-align: right; border-bottom: 1px dotted var(--border-color); position: relative; padding-left: 50%; }
    table td:last-child { border-bottom: none; }
    table td::before { content: attr(data-label); position: absolute; left: 10px; width: calc(50% - 20px); padding-right: 10px; font-weight: bold; text-align: left; color: var(--text-secondary); }
    table td.action-buttons { padding-left: 10px; text-align: left; }
    table td.action-buttons::before { display: none; }
}