/* ============================================================
   Portal da Transparência · SOMAR — Serviços de Obras de Maricá
   Design institucional, responsivo e acessível (WCAG 2.1 AA)
   ============================================================ */
:root{
  --azul:#002040;        /* azul-marinho institucional SOMAR */
  --azul-2:#0a3a5e;
  --azul-3:#1b6ca8;
  --azul-claro:#e9eef4;
  --acento:#c00010;      /* vermelho da marca SOMAR */
  --acento-2:#e23b40;
  --dourado:#c00010;     /* acento institucional = vermelho da marca */
  --verde:#1e8e5a;
  --vermelho:#c0392b;
  --laranja:#d97706;
  --cinza-bg:#f4f6f9;
  --cinza-borda:#dde3ea;
  --cinza-txt:#41505f;
  --cinza-claro:#6b7a8a;
  --texto:#1f2a36;
  --branco:#ffffff;
  --sombra:0 1px 3px rgba(16,40,64,.08),0 4px 16px rgba(16,40,64,.06);
  --sombra-2:0 6px 24px rgba(16,40,64,.12);
  --raio:12px;
  --raio-s:8px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  color:var(--texto);
  background:var(--cinza-bg);
  line-height:1.55;
  font-size:16px;
}
a{color:var(--azul-3);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

.skip-link{position:absolute;left:-999px;top:0;background:var(--dourado);color:var(--azul);padding:10px 16px;z-index:100;border-radius:0 0 8px 0;font-weight:600}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--dourado);outline-offset:2px;border-radius:4px}

/* ----------------------------------------------- CABEÇALHO */
.cabecalho{background:var(--branco);box-shadow:var(--sombra);position:sticky;top:0;z-index:50;border-top:4px solid var(--acento)}
.cab-grid{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:12px;padding-bottom:12px}
.cab-marca{display:flex;align-items:center;gap:14px;text-decoration:none}
.cab-logo-img{display:block;height:54px;width:auto}
.cab-selo{text-align:right;display:flex;flex-direction:column;gap:2px}
.selo-portal{background:var(--azul);color:var(--branco);padding:6px 14px;border-radius:20px;font-size:.82rem;font-weight:600}
.cab-selo small{color:var(--cinza-claro);font-size:.72rem}

/* ----------------------------------------------- NAVEGAÇÃO */
.navbar{background:var(--azul)}
.nav-inner{display:flex;align-items:center}
.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:1rem;padding:12px 0;cursor:pointer;font-weight:600}
.nav-lista{list-style:none;display:flex;flex-wrap:wrap;margin:0;padding:0;gap:2px}
.nav-lista a{
  display:flex;align-items:center;gap:8px;color:#cfe0ee;padding:14px 16px;font-size:.92rem;font-weight:500;
  border-bottom:3px solid transparent;transition:.15s;
}
.nav-lista a:hover{color:#fff;background:rgba(255,255,255,.07);text-decoration:none}
.nav-lista a.ativo{color:#fff;border-bottom-color:var(--dourado)}
.tag-item{background:rgba(255,255,255,.16);color:#fff;font-size:.68rem;padding:1px 7px;border-radius:10px;font-weight:700}
.nav-lista a.ativo .tag-item{background:var(--dourado);color:var(--azul)}

/* ----------------------------------------------- CONTEÚDO */
.conteudo{padding:32px 20px 60px}
.view-head{margin-bottom:24px}
.view-head h1{font-size:1.9rem;margin:.2em 0 .25em;color:var(--azul);line-height:1.2}
.subtitulo{font-size:1.02rem;color:var(--cinza-txt);max-width:80ch;margin:.2em 0}
.fundamentacao{font-size:.85rem;color:var(--cinza-claro);margin:.4em 0 0;font-style:italic}
.secao-badge{display:inline-block;background:var(--azul-claro);color:var(--azul);font-weight:700;font-size:.8rem;padding:5px 12px;border-radius:20px;border:1px solid #cfe0ee}

h1{font-weight:700}

/* ----------------------------------------------- KPIs */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:16px;margin-bottom:28px}
.kpi{background:var(--branco);border-radius:var(--raio);padding:20px;box-shadow:var(--sombra);border-left:5px solid var(--azul-3);position:relative}
.kpi .num{font-size:2.1rem;font-weight:800;color:var(--azul);line-height:1}
.kpi .rotulo{font-size:.82rem;color:var(--cinza-claro);margin-top:6px;display:block}
.kpi.k-and{border-left-color:var(--azul-3)}
.kpi.k-conc{border-left-color:var(--verde)}
.kpi.k-paral{border-left-color:var(--laranja)}
.kpi.k-val{border-left-color:var(--dourado)}
.kpi .num.menor{font-size:1.5rem}

/* ----------------------------------------------- CARDS / PAINEL */
.card{background:var(--branco);border-radius:var(--raio);padding:22px 24px;box-shadow:var(--sombra);margin-bottom:22px}
.card-titulo{font-size:1.05rem;color:var(--azul);margin:0 0 16px;font-weight:700}
.painel-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}
.painel-grid .card{margin-bottom:0}
.card-largo{grid-column:1 / -1}

/* ----------------------------------------------- GRÁFICO DONUT */
.grafico-donut{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.donut-svg{flex:0 0 auto}
.donut-legenda{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.donut-legenda li{display:flex;align-items:center;gap:10px;font-size:.92rem}
.donut-legenda .ponto{width:14px;height:14px;border-radius:4px;flex:0 0 auto}
.donut-legenda b{margin-left:auto;color:var(--azul);font-variant-numeric:tabular-nums}

/* ----------------------------------------------- BARRAS */
.barras{display:flex;flex-direction:column;gap:12px}
.barra-item{display:grid;grid-template-columns:1fr;gap:4px}
.barra-topo{display:flex;justify-content:space-between;font-size:.88rem}
.barra-topo b{color:var(--azul);font-variant-numeric:tabular-nums}
.barra-trilho{background:var(--cinza-bg);border-radius:6px;height:14px;overflow:hidden;border:1px solid var(--cinza-borda)}
.barra-fill{height:100%;background:linear-gradient(90deg,var(--azul-3),var(--azul-2));border-radius:6px 0 0 6px;min-width:2px;transition:width .6s ease}
.barra-fill.verde{background:linear-gradient(90deg,#27ae60,var(--verde))}
.barra-fill.dourado{background:linear-gradient(90deg,#f5c451,var(--dourado))}

/* ----------------------------------------------- FINANCEIRO */
.fin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.fin-item{padding:16px;background:var(--cinza-bg);border-radius:var(--raio-s);border:1px solid var(--cinza-borda)}
.fin-item .fin-val{font-size:1.5rem;font-weight:800;color:var(--azul);font-variant-numeric:tabular-nums}
.fin-item .fin-rot{font-size:.82rem;color:var(--cinza-claro)}
.fin-item.destaque{background:var(--azul);border-color:var(--azul)}
.fin-item.destaque .fin-val,.fin-item.destaque .fin-rot{color:#fff}
.fin-barra{grid-column:1/-1;margin-top:6px}

/* ----------------------------------------------- ATALHOS */
.atalho-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.atalho{display:flex;align-items:center;gap:14px;background:var(--branco);border:1px solid var(--cinza-borda);border-radius:var(--raio);padding:16px 18px;box-shadow:var(--sombra);transition:.15s}
.atalho:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--sombra-2);border-color:var(--azul-3)}
.atalho-num{font-size:1.3rem;font-weight:800;color:var(--branco);background:var(--azul);border-radius:10px;padding:10px 12px;min-width:52px;text-align:center}
.atalho-txt{font-size:.92rem;color:var(--texto);font-weight:500}

/* ----------------------------------------------- TABELAS / FERRAMENTAS */
.tabela-wrap{background:var(--branco);border-radius:var(--raio);box-shadow:var(--sombra);overflow:hidden;margin-bottom:14px}
.ferramentas{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:18px 20px;border-bottom:1px solid var(--cinza-borda);background:#fbfcfe}
.campo{display:flex;flex-direction:column;gap:4px}
.campo label{font-size:.74rem;font-weight:600;color:var(--cinza-claro);text-transform:uppercase;letter-spacing:.4px}
.campo input,.campo select{
  border:1px solid var(--cinza-borda);border-radius:var(--raio-s);padding:9px 12px;font-size:.92rem;background:#fff;color:var(--texto);min-width:150px;font-family:inherit;
}
.campo input:focus,.campo select:focus{border-color:var(--azul-3)}
.campo.busca input{min-width:240px}
.ferramentas .espaco{flex:1 1 auto}
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--azul-3);background:var(--azul-3);color:#fff;padding:9px 16px;border-radius:var(--raio-s);font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s}
.btn:hover{background:var(--azul-2);text-decoration:none}
.btn.sec{background:#fff;color:var(--azul-3)}
.btn.sec:hover{background:var(--azul-claro)}

.tabela-scroll{overflow-x:auto}
table.dados{width:100%;border-collapse:collapse;font-size:.9rem}
table.dados th,table.dados td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--cinza-borda);vertical-align:top}
table.dados thead th{background:var(--azul);color:#fff;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.3px;position:sticky;top:0;white-space:nowrap;cursor:pointer;user-select:none}
table.dados thead th .seta{opacity:.5;font-size:.7rem;margin-left:4px}
table.dados thead th[aria-sort="ascending"] .seta,table.dados thead th[aria-sort="descending"] .seta{opacity:1;color:var(--dourado)}
table.dados thead th.nao-ord{cursor:default}
table.dados tbody tr:nth-child(even){background:#fafbfd}
table.dados tbody tr:hover{background:var(--azul-claro)}
table.dados td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
table.dados td.obj{min-width:260px;max-width:420px}
.cel-os{font-variant-numeric:tabular-nums;font-weight:600;color:var(--azul);white-space:nowrap}

/* badges de status */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.76rem;font-weight:700;white-space:nowrap}
.badge.and{background:#e3f0fb;color:var(--azul-3)}
.badge.conc{background:#e3f6ec;color:var(--verde)}
.badge.paral{background:#fff1e0;color:#b45309}

/* mini barra de progresso na célula */
.prog{display:flex;align-items:center;gap:8px;min-width:120px}
.prog-trilho{flex:1;height:8px;background:var(--cinza-bg);border-radius:5px;overflow:hidden;border:1px solid var(--cinza-borda)}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--azul-3),var(--azul-2));border-radius:5px}
.prog-fill.full{background:linear-gradient(90deg,#27ae60,var(--verde))}
.prog-num{font-size:.8rem;font-variant-numeric:tabular-nums;color:var(--cinza-txt);min-width:42px;text-align:right}

/* rodapé da tabela / paginação */
.tabela-rodape{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;padding:14px 20px}
.resultado-info{font-size:.86rem;color:var(--cinza-claro)}
.resultado-info b{color:var(--azul)}
.paginacao{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.paginacao button{border:1px solid var(--cinza-borda);background:#fff;color:var(--azul);min-width:36px;height:36px;border-radius:var(--raio-s);cursor:pointer;font-size:.86rem;font-family:inherit}
.paginacao button:hover:not(:disabled){background:var(--azul-claro)}
.paginacao button.atual{background:var(--azul);color:#fff;border-color:var(--azul)}
.paginacao button:disabled{opacity:.4;cursor:not-allowed}
.vazio{padding:40px;text-align:center;color:var(--cinza-claro)}

/* indicador de atualidade */
.atualidade{display:inline-flex;align-items:center;gap:7px;font-size:.8rem;padding:5px 12px;border-radius:20px;font-weight:600;margin-bottom:14px}
.atualidade .pt{width:9px;height:9px;border-radius:50%}
.atualidade.ok{background:#e3f6ec;color:var(--verde)}
.atualidade.ok .pt{background:var(--verde)}
.atualidade.alerta{background:#fff4e0;color:var(--laranja)}
.atualidade.alerta .pt{background:var(--laranja)}

/* ----------------------------------------------- BLOCOS */
.bloco-titulo{font-size:1.15rem;color:var(--azul);margin:30px 0 6px;font-weight:700}
.bloco-nota{font-size:.9rem;color:var(--cinza-claro);margin:0 0 14px}

/* ----------------------------------------------- DECLARAÇÕES */
.declaracoes{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.declaracao{background:#e3f6ec;border:1px solid #b8e6cc;border-radius:var(--raio);padding:18px 20px;display:flex;gap:14px;align-items:flex-start}
.declaracao .ic{font-size:1.4rem;line-height:1}
.declaracao b{color:var(--verde)}
.declaracao p{margin:.2em 0 0;font-size:.9rem;color:var(--cinza-txt)}

/* ----------------------------------------------- SOBRE / CONFORMIDADE */
.sobre-orgao{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.sobre-item{background:var(--cinza-bg);border-radius:var(--raio-s);padding:14px 16px;border:1px solid var(--cinza-borda)}
.sobre-item .rot{font-size:.74rem;text-transform:uppercase;letter-spacing:.4px;color:var(--cinza-claro);font-weight:600}
.sobre-item .val{font-size:.98rem;color:var(--texto);margin-top:3px}
.conformidade{display:flex;flex-direction:column;gap:14px}
.conf-item{display:grid;grid-template-columns:64px 1fr auto;gap:16px;align-items:center;padding:16px;border:1px solid var(--cinza-borda);border-radius:var(--raio);background:#fbfcfe}
.conf-num{font-size:1.3rem;font-weight:800;color:#fff;background:var(--azul);border-radius:10px;padding:12px 0;text-align:center}
.conf-num.obrig{background:var(--laranja)}
.conf-desc strong{display:block;color:var(--azul);margin-bottom:2px}
.conf-desc span{font-size:.88rem;color:var(--cinza-txt)}
.conf-status{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--verde);white-space:nowrap}
.conf-status .ck{background:var(--verde);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.8rem}
.verificacao-lista{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:8px}
.verificacao-lista li{font-size:.94rem;color:var(--cinza-txt)}
.downloads-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.dl{display:flex;align-items:center;gap:12px;border:1px solid var(--cinza-borda);border-radius:var(--raio-s);padding:13px 15px;background:#fff;transition:.15s}
.dl:hover{text-decoration:none;border-color:var(--azul-3);background:var(--azul-claro)}
.dl .ic{font-size:1.3rem}
.dl .nm{font-size:.9rem;font-weight:600;color:var(--azul)}
.dl .ds{font-size:.76rem;color:var(--cinza-claro)}

/* ----------------------------------------------- RODAPÉ */
.rodape{background:var(--azul);color:#cfe0ee;margin-top:40px}
.rodape-marcas{background:#fff}
.rodape-marcas-inner{display:flex;align-items:center;justify-content:center;gap:30px;padding:22px 20px;flex-wrap:wrap}
.rm-somar{height:48px;width:auto}
.rm-marica{height:38px;width:auto}
.rm-sep{width:1px;height:38px;background:var(--cinza-borda)}
.rodape-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;padding:34px 20px}
.rodape-grid strong{color:#fff}
.rodape-grid a{color:var(--dourado)}
.rodape-base{background:rgba(0,0,0,.18);font-size:.82rem;padding:14px 0;text-align:center;color:#9fbdd6}

/* ----------------------------------------------- MAPA */
.mapa-wrap{background:var(--branco);border-radius:var(--raio);box-shadow:var(--sombra);overflow:hidden;margin-bottom:16px}
.mapa-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:16px 18px;border-bottom:1px solid var(--cinza-borda);background:#fbfcfe}
.mapa-corpo{position:relative}
.mapa-canvas{height:620px;width:100%;z-index:1;background:#e9eef4}
.mapa-legenda{position:absolute;right:14px;bottom:22px;z-index:500;background:rgba(255,255,255,.96);border:1px solid var(--cinza-borda);border-radius:10px;padding:12px 14px;box-shadow:var(--sombra-2);font-size:.8rem;max-width:230px}
.mapa-legenda h4{margin:0 0 8px;font-size:.74rem;color:var(--azul);text-transform:uppercase;letter-spacing:.4px}
.mapa-legenda .lg{display:flex;align-items:center;gap:8px;margin:5px 0}
.mapa-legenda .pt{width:14px;height:14px;border-radius:50%;flex:0 0 auto;border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.18)}
.mapa-legenda .pt.aprox{opacity:.5}
.mapa-legenda .obs{margin-top:9px;color:var(--cinza-claro);font-size:.72rem;line-height:1.4}
.mk{border-radius:50%;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.45)}
.mk-aprox{opacity:.72}
.leaflet-popup-content{margin:12px 15px;font-size:.86rem;line-height:1.45}
.pop-tit{font-weight:700;color:var(--azul);font-size:.95rem;margin-bottom:5px}
.pop-badge{display:inline-block;padding:2px 9px;border-radius:12px;font-size:.7rem;font-weight:700;margin-bottom:7px}
.pop-row{margin:3px 0;color:var(--texto)}
.pop-row b{color:var(--cinza-claro);font-weight:600}
.pop-fonte{margin-top:8px;padding-top:7px;border-top:1px solid var(--cinza-borda);font-size:.72rem;color:var(--cinza-claro)}
.mapa-nota-aprox{color:var(--laranja);font-weight:600}

/* ----------------------------------------------- RESPONSIVO */
@media (max-width:860px){
  .painel-grid{grid-template-columns:1fr}
  .declaracoes{grid-template-columns:1fr}
  .mapa-canvas{height:460px}
  .mapa-legenda{right:8px;bottom:8px;max-width:170px;font-size:.74rem;padding:9px 10px}
  .nav-toggle{display:block}
  .nav-lista{display:none;flex-direction:column;width:100%;padding-bottom:8px}
  .nav-lista.aberto{display:flex}
  .nav-lista a{padding:12px 4px;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav-lista a.ativo{border-bottom-color:var(--dourado)}
  .cab-titulo strong{font-size:1.3rem}
  .conf-item{grid-template-columns:54px 1fr;grid-template-rows:auto auto}
  .conf-status{grid-column:1/-1}
}
@media (max-width:560px){
  .view-head h1{font-size:1.45rem}
  .cab-selo{display:none}
  .cab-logo-img{height:42px}
  .rm-somar{height:38px}
  .rm-marica{height:30px}
  .ferramentas{padding:14px}
  .campo input,.campo select,.campo.busca input{min-width:0;width:100%}
  .campo{flex:1 1 100%}
}
@media print{
  .navbar,.ferramentas,.paginacao,.skip-link,.atalhos,.nav-toggle{display:none!important}
  .view[hidden]{display:block!important}
  body{background:#fff}
}
