/* HOME — apenas estilos específicos da página.
   O “casco” dos cards e a tipografia ficam idênticos aos outros módulos. */

/* ====== KPIs (cards do topo) ====== */
.summary-cards-row{
  display:grid;
  grid-template-columns:repeat(4, minmax(240px,1fr));
  gap:16px;
  margin-bottom:16px;
}

.summary-card{
  background:#fff;
  border:1px solid var(--bs-border-color);
  border-radius:12px;
  padding:16px 20px;
  box-shadow:0 4px 12px rgba(25,70,133,.06);
  display:flex; align-items:center; gap:1rem;
  min-width:220px;
}
.summary-card .icon{ font-size:2.25rem; color:var(--fnp-blue); margin-bottom:.25rem; }
.summary-card h6{ margin:0 0 .25rem; color:#6c757d; font-size:.95rem; font-weight:600; }
.summary-card .value{ font-size:1.6rem; font-weight:700; color:var(--fnp-blue); }
.summary-card .sub-value{ font-size:.85rem; color:#6c757d; }

/* Responsivo */
@media (max-width:1199.98px){ .summary-cards-row{ grid-template-columns:repeat(3,1fr);} }
@media (max-width:991.98px){  .summary-cards-row{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:575.98px){  .summary-cards-row{ grid-template-columns:1fr;} }

/* ====== Blocos de conteúdo (gráfico / tabelas) ====== */
.chart-card,
.table-card{
  background:#fff;
  border:1px solid var(--bs-border-color);
  border-radius:12px;
  padding:16px 20px;
  box-shadow:0 4px 12px rgba(25,70,133,.06);
  margin-bottom:16px;
}

.chart-card>h5,
.table-card>h5{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin:0 0 12px 0;
  color:var(--fnp-blue);
  font-weight:700;
  font-size:1.125rem; /* ~18px */
  line-height:1.25;
}

/* Controles no cabeçalho dos cards */
.chart-card .chart-controls,
.table-card .table-controls{ display:flex; gap:.75rem; }

.chart-card .chart-controls .btn-group,
.table-card .table-controls .btn-group{
  border:1px solid var(--bs-border-color);
  border-radius:.375rem;
  overflow:hidden;
}

.chart-card .chart-controls .btn,
.table-card .table-controls .btn{
  padding:.25rem .75rem;
  font-size:.8rem;
  color:var(--fnp-blue);
  background:#fff;
  border-radius:0;
}

.chart-card .chart-controls .btn.active,
.table-card .table-controls .btn.active{
  background:var(--fnp-blue);
  color:#fff;
  border-color:var(--fnp-blue);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.075);
}

/* ====== Toggle (2000 e 2023) ====== */
.toggle-container{
  display:flex; border:1px solid #ccc; border-radius:5px;
  overflow:hidden; background:#fff; font-size:14px;
}
.toggle-option{
  padding:10px 20px; cursor:pointer; color:var(--fnp-blue); transition:.3s;
}
.toggle-option:hover{ background:#dde4ed; }
.toggle-option.active{ background:var(--fnp-blue); color:#fff; font-weight:bold; }

/* Diferença %: cores por sinal */
.summary-card .value.positive { color: #16a34a; } /* verde */
.summary-card .value.negative { color: #dc2626; } /* vermelho */
.summary-card .value.neutral  { color: var(--fnp-blue); } /* zero */

.btn-info-tooltip {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  line-height: 1 !important;
  box-shadow: none !important;
  outline: none !important;
}

.btn-info-tooltip:focus,
.btn-info-tooltip:hover,
.btn-info-tooltip:active {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

/* 1. Container da Sidebar (Garante espaçamento e largura fixa) */
.sidebar {
    flex: 0 0 280px; /* Mantém a largura idêntica à das outras páginas */
    background-color: #ffffff !important;
    padding: 1.5rem; /* O espaçamento precioso que estava faltando! */
    border-right: 1px solid #dee2e6;
    box-shadow: 2px 0 5px rgba(25, 70, 133, 0.12);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    z-index: 10;
}

/* Títulos principais (Filtros, Configurações de Visualização, etc.) */
.sidebar h1, 
.sidebar h2, 
.sidebar h3, 
.sidebar h4, 
.sidebar h5, 
.sidebar h6 {
    color: #103758 !important; 
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important; 
}

/* Tamanhos proporcionais */
.sidebar h4 { font-size: 1.2rem !important; margin-bottom: 0.5rem !important; }
.sidebar h6 { font-size: 0.95rem !important; margin-bottom: 0.5rem !important; }

/* Nomes dos campos (Faixa Populacional, Região, UF, etc.) */
.sidebar .form-label,
.sidebar label {
    display: block !important;
    margin: 0 0 0.5rem 0 !important;
    color: #103758 !important; 
    font-family: 'Inter', sans-serif !important;
    font-weight: 600 !important; 
    font-size: 0.9rem !important;
}

/* Opções dos Radio Buttons */
.sidebar .form-check-label {
    display: inline-block !important;
    color: #334155 !important;
    font-weight: 400 !important;
    font-size: 0.9rem !important;
    margin-bottom: 0 !important;
}

/* 2. Configuração do Grupo (Input + Botão na mesma linha) */
.sidebar .input-group {
    display: flex !important;
    align-items: stretch !important;
    width: 100% !important;
    flex-wrap: nowrap !important;
    margin-bottom: 1rem; /* Espaço entre um filtro e outro */
}

/* 3. O SELECT (LADO ESQUERDO) - Cinza Claro */
.sidebar .form-select,
.sidebar select {
    /* Reset do comportamento visual */
    display: block; 
    width: 100%;
    
    /* Altura e Espaçamento Corretos */
    height: calc(1.8125rem + 2px);
    padding: .25rem .5rem;
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.5;
    
    /* CORES: Fundo Branco e Borda Cinza */
    background-color: #ffffff !important;
    border: 1px solid #d1d5db !important;
    color: #374151 !important;
    
    /* Remove estilos nativos */
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;

    /* Seta do Select (Cinza Escuro) */
    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='%23374151' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 0.75rem center !important;
    background-size: 16px 12px !important;
    
    /* Arredondamento Padrão */
    border-radius: 0.375rem !important;
}

/* 4. AJUSTE QUANDO DENTRO DE GRUPO (Com Lupa) */
.sidebar .input-group .form-select,
.sidebar .input-group select {
    /* Remove a borda direita e o arredondamento direito para colar na lupa */
    border-right: none !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    
    flex: 1 1 auto;
    width: 1% !important; /* Força ocupar o espaço */
    min-width: 0;
}

/* Estado de Foco */
.sidebar .form-select:focus,
.sidebar select:focus {
    border-color: #194685 !important;
    border-right: none !important;
    outline: none !important;
    box-shadow: 0 0 0 0.25rem rgba(25, 70, 133, 0.1);
    z-index: 2;
}

/* 5. A LUPA (LADO DIREITO) - Azul FNP */
.sidebar .input-group > .btn,
.sidebar .input-group > button {
    /* Cores: Fundo Branco, Borda Azul */
    background-color: #ffffff !important;
    color: #194685 !important;
    border: 1px solid #194685 !important;
    
    /* A borda esquerda do botão faz a divisória */
    border-left: 1px solid #194685 !important;
    margin-left: -1px !important; /* Sobrepõe a borda cinza do select */
    
    /* Arredondamento só na direita */
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 0.375rem !important;
    border-bottom-right-radius: 0.375rem !important;
    
    padding: .25rem .75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    cursor: pointer;
}

/* ==========================================================================
   BOTÃO LIMPAR PESQUISA - CORREÇÃO (PROTEGE OS ÍCONES "i")
   ========================================================================== */

/* Aplica o estilo Azul Sólido apenas aos botões de ação principais.
   EXCLUI explicitamente:
   1. Botões dentro de input-group (Lupas)
   2. Botões com a classe .btn-info-tooltip (Ícones "i")
*/

.sidebar .btn:not(.input-group .btn):not(.btn-info-tooltip),
.sidebar button:not(.input-group button):not(.btn-info-tooltip),
.sidebar a.btn:not(.btn-info-tooltip) {
    /* Layout: Ocupar 100% da largura */
    display: block;
    width: 100% !important; 
    margin-top: 1rem;
    
    /* Cores: Azul FNP Sólido */
    background-color: #194685 !important;
    border: 1px solid #194685 !important;
    color: #ffffff !important;
    
    /* Estética */
    font-weight: 600;
    padding: 0.375rem 0.75rem;
    font-size: 0.9rem;
    border-radius: 6px;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 2px 5px rgba(25, 70, 133, 0.15);
    transition: all 0.2s ease-in-out;
    cursor: pointer;
}

/* Hover (Mouse em cima) */
.sidebar .btn:not(.input-group .btn):not(.btn-info-tooltip):hover,
.sidebar button:not(.input-group button):not(.btn-info-tooltip):hover,
.sidebar a.btn:not(.btn-info-tooltip):hover {
    background-color: #123361 !important; /* Azul mais escuro */
    border-color: #123361 !important;
    color: #ffffff !important;
}

/* Clique (Ativo) */
.sidebar .btn:not(.input-group .btn):not(.btn-info-tooltip):active,
.sidebar button:not(.input-group button):not(.btn-info-tooltip):active,
.sidebar a.btn:not(.btn-info-tooltip):active {
    background-color: #0d264d !important;
    border-color: #0d264d !important;
}