/*!
 * Versão: 1.0.3
 * Data: 2026
 */

:root{
  --bg:#eef3f7;
  --card:#ffffff;
  --texto:#243b53;
  --muted:#66788a;
  --borda:#d8e1ea;
  --primaria:#30475e;
  --primaria-escura:#24384d;
  --azul:#2d8fd5;
  --azul-suave:#edf5fb;
  --verde:#2f9e44;
  --verde-suave:#edf8ef;
  --laranja:#d97706;
  --laranja-suave:#fff5e8;
  --cinza-botao:#f1f4f7;
  --sombra:0 4px 16px rgba(36, 59, 83, 0.08);
  --raio:10px;
}

*{
  box-sizing:border-box;
}

body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--bg);
  color:var(--texto);
}

.topo{
  background:linear-gradient(180deg, var(--primaria), var(--primaria-escura));
  color:#fff;
  padding:22px 20px;
}

.topo__inner{
  max-width:1280px;
  margin:0 auto;
}

.topo h1{
  margin:0 0 4px 0;
  font-size:28px;
}

.subtitulo{
  margin:0;
  opacity:.9;
  font-size:14px;
}

.container{
  max-width:1280px;
  margin:0 auto;
  padding:18px;
}

.dashboard{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:14px;
  margin-bottom:16px;
}

.kpi{
  background:var(--card);
  border:1px solid var(--borda);
  border-radius:var(--raio);
  box-shadow:var(--sombra);
  padding:14px 16px;
}

.kpi__label{
  display:block;
  font-size:12px;
  color:var(--muted);
  margin-bottom:8px;
  text-transform:uppercase;
  letter-spacing:.03em;
  font-weight:700;
}

.kpi__value{
  font-size:28px;
  font-weight:700;
}

.filtros{
  background:var(--card);
  border:1px solid var(--borda);
  border-radius:var(--raio);
  box-shadow:var(--sombra);
  padding:16px;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:14px;
  margin-bottom:14px;
}

.campo{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.campo--busca{
  grid-column:span 2;
}

.campo label{
  font-size:12px;
  color:var(--muted);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.campo input,
.campo select{
  width:100%;
  border:1px solid var(--borda);
  border-radius:8px;
  padding:10px 12px;
  background:#fff;
  font-size:14px;
  color:var(--texto);
}

.acoes-filtros{
  display:flex;
  flex-wrap:nowrap;
  gap:10px;
  align-items:flex-end; 
  justify-content:flex-start;
}

.acoes-filtros button{
  white-space:nowrap;
}

button{
  border:none;
  border-radius:8px;
  padding:10px 14px;
  cursor:pointer;
  font-weight:700;
  transition:.2s ease;
}

#limparFiltros{
  background:var(--cinza-botao);
  color:var(--texto);
  border:1px solid var(--borda);
}

#limparFiltros:hover{
  background:#e7edf3;
}

#exportarXlsx{
  background:var(--verde);
  color:#fff;
}

#exportarXlsx:hover{
  background:var(--verde-suave);
  color: var(--verde);
  border:1px solid var(--verde);
}

.barra-resultado{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin:6px 0 14px;
}

#contador{
  color:var(--muted);
  font-size:14px;
}

.mensagem-erro{
  background:#fff4f4;
  border:1px solid #f1c0c0;
  color:#8a1f1f;
  padding:14px;
  border-radius:10px;
  margin-bottom:16px;
}

.oculto{
  display:none;
}

.lista-eventos{
  background:var(--card);
  border:1px solid var(--borda);
  border-radius:var(--raio);
  box-shadow:var(--sombra);
  overflow:hidden;
}

.lista-eventos__header{
  display:grid;
  grid-template-columns:2.2fr 1.2fr 1fr;
  gap:16px;
  background:var(--primaria);
  color:#fff;
  padding:16px 18px;
  font-weight:700;
}

.lista-eventos__body{
  display:block;
}

.evento{
  display:grid;
  grid-template-columns:2.2fr 1.2fr 1fr;
  gap:16px;
  padding:18px;
  border-top:1px solid var(--borda);
  align-items:start;
  background:#fff;
}

.evento:first-child{
  border-top:none;
}

.evento--proximo{
  background:linear-gradient(90deg, #fffdf7 0%, #ffffff 16%);
  border-left:5px solid var(--laranja);
}

.evento__titulo{
  margin:0 0 10px 0;
  font-size:17px;
  line-height:1.35;
  color:var(--primaria);
}

.evento__badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#f3f6f9;
  border:1px solid #d9e1e8;
  font-size:12px;
  color:#425466;
}

.tag svg{
  width:13px;
  height:13px;
  fill:#6b7c8f;
}

.evento__linha{
  display:flex;
  align-items:flex-start;
  gap:8px;
  font-size:14px;
  color:#425466;
  line-height:1.5;
}

.evento__linha + .evento__linha{
  margin-top:8px;
}

.evento__linha svg{
  width:15px;
  height:15px;
  flex:0 0 15px;
  margin-top:2px;
  fill:var(--azul);
}

.evento__coluna{
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.evento__periodo{
  font-weight:700;
  color:var(--texto);
  margin-bottom:10px;
}

.evento__subinfo{
  font-size:14px;
  color:#425466;
  line-height:1.55;
}

.status-badge{
  display:inline-flex;
  align-items:center;
  gap:1px;
  margin-bottom:10px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
}

.status-badge--aprovada{
  background:var(--verde);
  color:var(--verde-suave);
}

.status-badge--executada{
  background:var(--azul);
  color:var(--azul-suave);
}

.status-badge--padrao{
  background:#eef2f6;
  color:#526273;
}

.destaque-proximo{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:10px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  background:var(--laranja-suave);
  color:var(--laranja);
}
.evento__acoes{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-start;
}

.botao-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  padding:10px 12px;
  border-radius:8px;
  font-size:14px;
  font-weight:700;
  transition:.2s ease;
}

.botao-link svg{
  width:15px;
  height:15px;
  fill:currentColor;
}

.botao-link--site{
  background:#eef5fb;
  color:#245b86;
  border:1px solid #cfe0ef;
}

.botao-link--site:hover{
  background:#dfeefa;
}

.botao-link--manifestacao{
  background:var(--verde-suave);
  color:var(--verde);
  border:1px solid #cfe9d4;
}

.botao-link--manifestacao:hover{
  background:#def2e2;
}

.vazio{
  padding:24px;
  text-align:center;
  color:var(--muted);
  background:#fff;
}

.paginacao{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:center;
  margin:18px 0 8px;
}

.paginacao button{
  background:#fff;
  border:1px solid var(--borda);
  color:var(--texto);
  min-width:42px;
}

.paginacao button:hover{
  background:#f0f5fb;
}

.paginacao button.ativo{
  background:var(--primaria);
  color:#fff;
  border-color:var(--primaria);
}

.paginacao button:disabled{
  opacity:.5;
  cursor:not-allowed;
}

@media (max-width: 980px){
  .campo--busca{
    grid-column:span 1;
  }

  .lista-eventos__header{
    display:none;
  }

  .evento{
    grid-template-columns:1fr;
    gap:14px;
  }

  .evento__acoes{
    flex-direction:row;
    flex-wrap:wrap;
  }
}