/* Ficheiro: css/style.css */

/* :root e modo escuro */
:root {
    --cor-primaria: #0d2e5b;
    --cor-secundaria: #d9534f;
    --cor-fundo-claro: #f0f2f5;
    --cor-fundo-caixa: #fff;
    --cor-texto-principal: #333;
    --cor-texto-secundario: #666;
    --cor-sombra: rgba(0,0,0,0.08);
    --cor-borda: #ddd;
    --cor-despacho: #f0ad4e;
    --cor-em-curso: #d9534f;
    --cor-em-resolucao: #0d2e5b;
    --cor-em-conclusao: #5cb85c;
    --cor-vigilancia: #777;
    --cor-default: #888;
}

body.dark-mode {
    --cor-primaria: #b3c5e0;
    --cor-secundaria: #f0ad4e;
    --cor-fundo-claro: #1c1c1c;
    --cor-fundo-caixa: #2c2c2c;
    --cor-texto-principal: #f0f0f0;
    --cor-texto-secundario: #ccc;
    --cor-sombra: rgba(255,255,255,0.05);
    --cor-borda: #444;
}

/* Animação de Carregamento (Shimmer) */
@keyframes shimmer {
    0% { background-position: -468px 0; }
    100% { background-position: 468px 0; }
}
.loading-shimmer {
    color: transparent !important;
    background: color-mix(in srgb, var(--cor-borda) 30%, transparent);
    background-image: linear-gradient(to right, color-mix(in srgb, var(--cor-borda) 30%, transparent) 8%, color-mix(in srgb, var(--cor-borda) 50%, transparent) 18%, color-mix(in srgb, var(--cor-borda) 30%, transparent) 33%);
    background-size: 800px 104px;
    animation: shimmer 1.5s infinite linear;
    border-radius: 4px;
}

/* Estilos Globais */
body { margin: 0; padding: 0; font-family: 'Poppins', sans-serif; background-color: var(--cor-fundo-claro); color: var(--cor-texto-principal); transition: background-color 0.3s, color 0.3s; }
h1, h2, h3, h4 { color: var(--cor-primaria); font-weight: 600; }
a { color: var(--cor-primaria); text-decoration: none; transition: color 0.2s; }
a:hover { text-decoration: underline; color: var(--cor-secundaria); }

/* Estrutura Principal */
.smpc-ocorrencias-section { padding: 40px 20px; }
.smpc-container { max-width: 1400px; margin: 0 auto; }

/* Cabeçalho */
.smpc-header { text-align: center; margin-bottom: 40px; display: flex; flex-direction: column; align-items: center; }
.smpc-logo { max-width: 150px; height: auto; margin-bottom: 15px; }
.smpc-title { font-size: 2.5em; font-weight: 700; margin: 0; display: inline-flex; align-items: center; gap: 15px; }
.smpc-last-updated { display: block; margin-top: 10px; font-size: 14px; color: var(--cor-texto-secundario); margin-bottom: 5px; height: 20px; }
.smpc-telegram-link { margin-top: 15px; font-size: 1em; color: var(--cor-texto-secundario); }
.smpc-telegram-link .fa-telegram { color: #0088cc; font-size: 1.2em; vertical-align: middle; margin-right: 5px; }

/* Grelha Superior (Contadores e Mapa) */
.smpc-top-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

/* Contadores */
.smpc-counters { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 20px; }
.smpc-counter-item { background-color: var(--cor-fundo-caixa); padding: 25px; border-radius: 12px; box-shadow: 0 4px 15px var(--cor-sombra); text-align: center; transition: transform 0.3s ease, box-shadow 0.3s ease; border: 1px solid var(--cor-borda); }
.smpc-counter-item.loading h3, .smpc-counter-item.loading p { min-height: 1em; }
.smpc-counter-item:hover { transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0,0,0,0.1); }
.smpc-counter-item i { font-size: 40px; color: var(--cor-secundaria); margin-bottom: 15px; display: block; transition: color 0.3s; }
.smpc-counter-item h3 { font-size: 2.2em; font-weight: 700; margin: 0; }
.smpc-counter-item p { font-size: 1em; color: var(--cor-texto-secundario); margin: 0; font-weight: 500; }

/* Mapa e Legenda */
#map { height: 450px; width: 100%; border-radius: 12px; box-shadow: 0 4px 15px var(--cor-sombra); position: relative; border: 1px solid var(--cor-borda); background-color: #eee; }
.map-legend { position: absolute; top: 10px; right: 10px; background-color: rgba(255, 255, 255, 0.9); padding: 10px 15px; border-radius: 8px; box-shadow: 0 2px 10px var(--cor-sombra); z-index: 1000; border: 1px solid var(--cor-borda); }
body.dark-mode .map-legend { background-color: rgba(44, 44, 44, 0.9); }
.map-legend h4 { margin: 0 0 10px; font-size: 1em; }
.map-legend ul { list-style: none; padding: 0; margin: 0; }
.map-legend li { display: flex; align-items: center; margin-bottom: 5px; font-size: 14px; color: var(--cor-texto-secundario); }
.map-legend .legend-color-box { width: 12px; height: 12px; border-radius: 50%; margin-right: 10px; }
.legend-color-box.status-despacho { background-color: var(--cor-despacho); }
.legend-color-box.status-em-curso { background-color: var(--cor-em-curso); }
.legend-color-box.status-em-resolucao { background-color: var(--cor-em-resolucao); }
.legend-color-box.status-em-conclusao { background-color: var(--cor-em-conclusao); }
.legend-color-box.status-vigilancia { background-color: var(--cor-vigilancia); }
.legend-color-box.status-default { background-color: var(--cor-default); }
.custom-div-icon.status-despacho svg path { fill: var(--cor-despacho); }
.custom-div-icon.status-em-curso svg path { fill: var(--cor-em-curso); }
.custom-div-icon.status-em-resolucao svg path { fill: var(--cor-em-resolucao); }
.custom-div-icon.status-em-conclusao svg path { fill: var(--cor-em-conclusao); }
.custom-div-icon.status-vigilancia svg path { fill: var(--cor-vigilancia); }
.custom-div-icon.status-default svg path { fill: var(--cor-default); }
.custom-div-icon svg path { fill-opacity: 0.9; stroke: #fff; stroke-width: 1px; transition: fill 0.3s ease; }

/* Filtros */
.smpc-filters-container { background-color: var(--cor-fundo-caixa); padding: 20px 25px; border-radius: 12px; box-shadow: 0 4px 15px var(--cor-sombra); border: 1px solid var(--cor-borda); margin-bottom: 40px; }
.smpc-primary-filters { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px; }
.smpc-scope-selector { display: flex; align-items: center; flex-wrap: wrap; gap: 15px; }
.smpc-filter-label { font-weight: 500; font-size: 1em; color: var(--cor-texto-secundario); white-space: nowrap; }
.smpc-btn-group { display: flex; gap: 10px; }
.smpc-btn-scope { background-color: var(--cor-fundo-caixa); color: var(--cor-texto-principal); border: 1px solid var(--cor-borda); padding: 10px 25px; cursor: pointer; font-size: 1em; font-weight: 500; transition: all 0.2s ease-in-out; border-radius: 8px; }
.smpc-btn-scope:hover:not(.active):not(:disabled) { background-color: var(--cor-fundo-claro); border-color: var(--cor-primaria); color: var(--cor-primaria); }
.smpc-btn-scope.active { background-color: var(--cor-primaria); color: white; font-weight: 600; border-color: var(--cor-primaria); transform: translateY(-2px); box-shadow: 0 4px 10px var(--cor-sombra); }
.smpc-btn-scope:disabled { cursor: not-allowed; opacity: 0.5; }
.smpc-advanced-filter-toggle { margin-left: auto; }
.smpc-btn-link { background: none; border: none; color: var(--cor-primaria); cursor: pointer; font-size: 1em; padding: 5px; border-radius: 5px; transition: background-color 0.2s; white-space: nowrap; }
.smpc-btn-link:hover { background-color: var(--cor-fundo-claro); text-decoration: underline; }
.smpc-btn-link i { margin-right: 5px; }
.smpc-advanced-filters-panel { margin-top: 20px; padding-top: 20px; border-top: 1px dashed var(--cor-borda); transition: max-height 0.4s ease-out, opacity 0.4s ease-out, margin-top 0.4s, padding-top 0.4s, visibility 0.4s; overflow: hidden; max-height: 500px; opacity: 1; visibility: visible; }
.smpc-advanced-filters-panel.hidden { max-height: 0; opacity: 0; margin-top: 0; padding-top: 0; border-top: none; visibility: hidden; }
.smpc-filter-row { display: flex; flex-wrap: wrap; gap: 20px; }
.smpc-filter-group { flex: 1; min-width: 200px; }
.smpc-filter-group label { display: block; font-weight: 600; margin-bottom: 8px; font-size: 14px; color: var(--cor-texto-secundario); }
.smpc-filter-group select { width: 100%; padding: 12px; border: 1px solid var(--cor-borda); border-radius: 8px; background-color: var(--cor-fundo-claro); color: var(--cor-texto-principal); font-size: 1em; transition: border-color 0.3s, box-shadow 0.3s; }
.smpc-filter-group select:focus { outline: none; border-color: var(--cor-primaria); box-shadow: 0 0 0 3px color-mix(in srgb, var(--cor-primaria) 20%, transparent); }

/* Botões Genéricos */
.smpc-btn { border: none; padding: 12px 20px; border-radius: 8px; cursor: pointer; font-size: 14px; font-weight: 500; transition: background-color 0.2s, transform 0.2s; display: inline-flex; align-items: center; gap: 8px; }
.smpc-btn:hover:not(:disabled) { transform: translateY(-2px); }
.smpc-btn:disabled { cursor: not-allowed; opacity: 0.6; }
.smpc-btn-primary { background-color: var(--cor-primaria); color: white; }
.smpc-btn-primary:hover:not(:disabled) { background-color: color-mix(in srgb, var(--cor-primaria) 85%, black); }
.smpc-btn-secondary { background-color: var(--cor-fundo-caixa); color: var(--cor-texto-principal); border: 1px solid var(--cor-borda); }
.smpc-btn-secondary:hover:not(:disabled) { background-color: var(--cor-fundo-claro); border-color: var(--cor-primaria); }

/* Barra de Ações */
.smpc-actions-bar { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 20px; margin-top: 40px; margin-bottom: 20px; }
.smpc-status-pills { display: flex; gap: 10px; flex-wrap: wrap; }
.smpc-table-actions { display: flex; gap: 15px; flex-wrap: wrap; justify-content: flex-end; }
.status-pill { background-color: var(--cor-fundo-caixa); border: 1px solid var(--cor-borda); color: var(--cor-texto-secundario); padding: 10px 18px; border-radius: 25px; cursor: pointer; font-size: 14px; font-weight: 500; transition: all 0.2s ease-in-out; }
.status-pill:hover:not(:disabled) { border-color: var(--cor-primaria); color: var(--cor-primaria); }
.status-pill.active { color: #fff; border-color: transparent; font-weight: 600; }
.status-pill.active.status-despacho, .status-badge.status-despacho { background-color: var(--cor-despacho); }
.status-pill.active.status-em-curso, .status-badge.status-em-curso { background-color: var(--cor-em-curso); }
.status-pill.active.status-em-resolucao, .status-badge.status-em-resolucao { background-color: var(--cor-em-resolucao); }
.status-pill.active.status-em-conclusao, .status-badge.status-em-conclusao { background-color: var(--cor-em-conclusao); }
.status-pill.active.status-vigilancia, .status-badge.status-vigilancia { background-color: var(--cor-vigilancia); }
.status-pill.active.status-default, .status-badge.status-default { background-color: var(--cor-default); }

/* Tabela */
.table-responsive-smpc { overflow-x: auto; background-color: var(--cor-fundo-caixa); border-radius: 12px; box-shadow: 0 4px 15px var(--cor-sombra); border: 1px solid var(--cor-borda); }
.smpc-table { width: 100%; border-collapse: collapse; overflow: hidden; }
.smpc-table th, .smpc-table td { padding: 15px 18px; text-align: left; border-bottom: 1px solid var(--cor-borda); }
.smpc-table tbody tr:last-child td { border-bottom: none; }
.smpc-table th { background-color: var(--cor-fundo-claro); font-weight: 600; white-space: nowrap; cursor: pointer; user-select: none; transition: background-color 0.2s; }
.smpc-table th:hover { background-color: color-mix(in srgb, var(--cor-fundo-claro) 80%, black); }
.smpc-table th .sort-icon { margin-left: 8px; font-size: 0.9em; color: var(--cor-texto-secundario); }
.smpc-table tbody tr { cursor: pointer; transition: background-color 0.2s ease; }
.smpc-table tbody tr:hover { background-color: var(--cor-fundo-claro); }
.status-badge { display: inline-block; padding: 6px 14px; border-radius: 18px; color: #fff; font-weight: 500; font-size: 12px; text-align: center; white-space: nowrap; }
.smpc-empty-state td { padding: 60px 20px; text-align: center; color: var(--cor-texto-secundario); }
.smpc-empty-state i { font-size: 4em; margin-bottom: 15px; display: block; }

/* Paginação */
.smpc-pagination { display: flex; justify-content: center; align-items: center; gap: 15px; margin-top: 30px; }
.pagination-btn { background-color: var(--cor-primaria); color: white; border: none; padding: 10px 20px; border-radius: 8px; cursor: pointer; font-size: 1em; font-weight: 600; transition: background-color 0.2s ease, box-shadow 0.2s ease; box-shadow: 0 4px 8px var(--cor-sombra); }
.pagination-btn:hover:not(:disabled) { background-color: color-mix(in srgb, var(--cor-primaria) 85%, black); box-shadow: 0 6px 12px var(--cor-sombra); }
.pagination-btn:disabled { background-color: #ccc; color: #999; cursor: not-allowed; box-shadow: none; }
#page-info { font-size: 1em; font-weight: 500; color: var(--cor-texto-principal); }

/* Gráficos */
.smpc-chart-container { background-color: var(--cor-fundo-caixa); padding: 25px; border-radius: 12px; box-shadow: 0 4px 15px var(--cor-sombra); margin-top: 40px; display: flex; flex-wrap: wrap; gap: 30px; align-items: flex-start; border: 1px solid var(--cor-borda); }
.chart-box { position: relative; height: 450px; width: 100%; }
.chart-box-bar { flex: 2; min-width: 300px; }
.chart-box-doughnut { flex: 1; min-width: 250px; max-width: 350px; margin: 0 auto; }
.chart-title { font-weight: 600; margin-top: 0; margin-bottom: 20px; text-align: center; }

/* Rodapé */
.smpc-source-note { text-align: center; margin-top: 40px; padding-top: 20px; border-top: 1px dashed var(--cor-borda); font-size: 14px; color: var(--cor-texto-secundario); }

/* Botões Flutuantes */
#back-to-top, #theme-toggle { position: fixed; border: none; border-radius: 50%; width: 45px; height: 45px; font-size: 20px; cursor: pointer; box-shadow: 0 2px 10px rgba(0,0,0,0.2); transition: opacity 0.3s, transform 0.3s, background-color 0.3s; z-index: 1001; }
#back-to-top { display: none; bottom: 20px; right: 20px; background-color: var(--cor-primaria); color: white; }
#theme-toggle { top: 20px; right: 20px; background-color: var(--cor-fundo-caixa); color: var(--cor-primaria); border: 1px solid var(--cor-borda); }
#back-to-top:hover, #theme-toggle:hover { transform: scale(1.1); }

/* Media Queries */
@media (min-width: 768px) {
    .smpc-counters {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 992px) { 
    .smpc-top-grid { grid-template-columns: 1fr; } 
    .smpc-actions-bar { flex-direction: column; align-items: stretch; } 
    .smpc-status-pills { justify-content: center; } 
    .smpc-primary-filters { justify-content: center; } 
    .smpc-advanced-filter-toggle { margin-left: 0; } 
}

/* --- ALTERAÇÕES DEFINITIVAS PARA A TABELA RESPONSIVA --- */
@media (max-width: 768px) {
    .smpc-table thead { display: none; }
    .smpc-table, .smpc-table tbody, .smpc-table tr, .smpc-table td { display: block; width: 100%; }
    .smpc-table tr { margin-bottom: 15px; border: 1px solid var(--cor-borda); border-radius: 8px; padding: 10px; box-shadow: 0 2px 5px var(--cor-sombra); }
    
    .smpc-table td {
        display: block; /* Mudar para layout de bloco simples */
        text-align: left; /* Alinhar todo o texto à esquerda */
        padding: 8px 5px;
        border-bottom: 1px dashed var(--cor-borda);
    }

    .smpc-table td:last-child { border-bottom: none; }
    
    .smpc-table td::before {
        content: attr(data-label);
        display: block; /* Faz com que o rótulo ocupe a sua própria linha */
        font-weight: 600;
        color: var(--cor-primaria);
        font-size: 0.8em; /* Rótulo ligeiramente mais pequeno */
        margin-bottom: 4px; /* Espaço entre o rótulo e o valor */
    }
    
    .smpc-table td[data-label="Mapa"] { 
        text-align: center;
    }
    .smpc-table td[data-label="Mapa"]::before { display: none; }
    #map { height: 350px; }
}
/* --- FIM DAS ALTERAÇÕES --- */

@media print { body { background-color: #fff !important; color: #000 !important; font-family: Arial, sans-serif; } :root { --cor-primaria: #000; --cor-secundaria: #333; --cor-texto-principal: #000; --cor-texto-secundario: #333; } .smpc-main-actions, #prociv-filters-container, .smpc-actions-bar, #prociv-pagination-controls, #back-to-top, #theme-toggle, .smpc-table .smpc-map-header-cell, .smpc-telegram-link { display: none !important; } .smpc-ocorrencias-section { padding: 0; } .smpc-header { margin-bottom: 20px; border-bottom: 2px solid #000; padding-bottom: 10px; } .smpc-title { font-size: 22pt; color: #000 !important; } .smpc-last-updated { font-size: 10pt; color: #333 !important; } .smpc-top-grid, .smpc-chart-container { grid-template-columns: 1fr !important; flex-direction: column; page-break-inside: avoid; } .smpc-table, #map, .smpc-chart-container { box-shadow: none; border: 1px solid #ccc; page-break-before: always; } .chart-box { max-height: 500px; page-break-inside: avoid; } #map { height: 500px !important; } .leaflet-control-container { display: none; } .smpc-table thead { display: table-header-group !important; } .smpc-table, .smpc-table tbody, .smpc-table tr, .smpc-table td { display: revert !important; width: auto; } .smpc-table td::before { content: none !important; } .smpc-table, .smpc-table th, .smpc-table td { border: 1px solid #ccc; font-size: 9pt; color: #000 !important; padding: 8px; } .smpc-table th { background-color: #eee !important; } .status-badge { color: #000 !important; background-color: transparent !important; border: none; padding: 0; font-weight: normal; border-radius: 0; } a { color: #000 !important; text-decoration: none; } a[href]::after { content: none !important; } }

