/* =========================================================================
   Padrão de Interface ATI-TO  (RN06/07: azul #2E5790, Roboto, etc.)
   ========================================================================= */
:root{
  --azul:#2E5790;            /* RN07.2 cor padrão azul */
  --azul-esc:#244873;
  --azul-claro:#4887E0;
  --azul-sec:#8EB3E6;
  --verde:#4B9528;           /* RN019 ativo */
  --amarelo:#F6C72C;         /* RN07.3 */
  --vermelho:#D83139;        /* RN019 excluído */
  --cinza:#AFAFAF;           /* RN019 inativo */
  --bg:#EEF1F5;
  --branco:#fff;
  --borda:#C8CCD4;           /* borda acinzentada dos componentes */
  --texto:#1f2733;
  --texto-suave:#5b6472;
  --radius:6px;
  --header-h:64px;
  --side-w:260px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:"Roboto","Segoe UI",sans-serif;
  background:var(--bg); color:var(--texto);
  font-size:16px;                       /* RN013: nunca < 16px */
}
a{color:inherit;text-decoration:none}

/* ----------------------------- shell grid ------------------------------ */
.app{
  display:grid;
  grid-template-columns:var(--side-w) 1fr;
  grid-template-rows:var(--header-h) 1fr auto;
  grid-template-areas:"topbar topbar" "sidebar content" "footer footer";
  min-height:100vh;
  transition:grid-template-columns .2s ease;
}
.app.collapsed{grid-template-columns:0 1fr}
.app.collapsed .sidebar{display:none}   /* recolhe por completo (some texto e cor) */

/* ------------------------------ header --------------------------------- */
.topbar{
  grid-area:topbar; background:var(--branco);
  border-bottom:1px solid var(--borda);
  display:flex; align-items:stretch;
  position:sticky; top:0; z-index:30;
}
.topbar-brand{
  width:var(--side-w); min-width:var(--side-w);
  display:flex; align-items:center; gap:12px;
  padding:0 18px; border-right:1px solid var(--borda);
  transition:opacity .2s;
}
.brand-img{width:38px;height:38px;object-fit:contain}
.brand-name{
  color:var(--azul); font-weight:700; line-height:1.1;
  font-size:16px; text-transform:uppercase; letter-spacing:.02em;
}
.topbar-actions{flex:1;display:flex;align-items:center;gap:16px;padding:0 22px}
.hamburger{
  border:none;background:transparent;cursor:pointer;color:var(--azul);
  width:44px;height:44px;border-radius:var(--radius);display:grid;place-items:center;
}
.hamburger:hover{background:#eef2f8}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:18px}
.user-field{display:flex;flex-direction:column;gap:2px}
.user-field label{font-size:16px;color:var(--texto-suave);font-weight:500}
.user-field select{
  border:1px solid var(--borda);border-radius:var(--radius);
  height:40px;padding:0 10px;background:var(--branco);font-size:16px;color:var(--texto);
  min-width:130px;
}
.avatar{
  width:42px;height:42px;border-radius:50%;background:var(--azul);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:18px;
}

/* ------------------------------ sidebar -------------------------------- */
.sidebar{
  grid-area:sidebar; background:var(--azul); color:#fff;
  display:flex;flex-direction:column;gap:6px;padding:18px 14px;
  min-width:0; overflow:hidden;        /* recolhe junto: recorta texto/itens */
  transition:transform .2s;
}
.sidebar-org{padding:6px 10px 14px;border-bottom:1px solid rgba(255,255,255,.18);margin-bottom:8px}
.org-name{font-size:16px;font-weight:700;line-height:1.3;letter-spacing:.02em}
.org-profile{font-size:14px;opacity:.8;margin-top:4px;letter-spacing:.06em}
.menu{display:flex;flex-direction:column;gap:4px}
.menu-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius);
  color:#fff;font-weight:500;font-size:16px;cursor:pointer;transition:background .15s;
}
.menu-item .material-icons{font-size:20px}
.menu-item:hover{background:rgba(255,255,255,.12)}
.menu-item.active{background:var(--azul-esc);font-weight:700}

/* ------------------------------ content -------------------------------- */
.content{grid-area:content;padding:16px 22px 20px;min-width:0;overflow-x:hidden}
.page{display:none;flex-direction:column;gap:14px}
.page.active{display:flex}
.breadcrumb{
  display:flex;align-items:center;gap:6px;color:var(--texto-suave);font-size:16px;
}
.breadcrumb .material-icons{font-size:18px}
.breadcrumb span{margin:0 2px}
.page-title{
  font-size:1.5rem;font-weight:700;color:#1f2733;margin:0 0 2px;   /* RN012: 1.5rem, título em preto */
  text-transform:uppercase;letter-spacing:.01em;                   /* título em caixa alta */
}

/* ------------------------- filtros (fieldset) -------------------------- */
.filtros{
  border:1px solid var(--borda);            /* borda acinzentada */
  background:var(--branco);                  /* fundo branco */
  border-radius:var(--radius);
  padding:12px 18px 14px;margin:0;
}
.filtros legend{font-weight:700;color:var(--azul);padding:0 8px;font-size:16px}
.filtros-grid{
  display:flex;flex-wrap:wrap;gap:12px 16px;align-items:flex-end;   /* RN09.2 linha única */
}
.filtro{display:flex;flex-direction:column;gap:6px;flex:1 1 200px;min-width:180px}
.filtro label{font-size:16px;font-weight:700;color:var(--texto)}  /* RN014: labels 16px negrito */
.filtro select,.filtro input{
  height:44px;border:1px solid var(--borda);border-radius:var(--radius);
  padding:0 12px;font-size:16px;background:var(--branco);color:var(--texto);width:100%;  /* RN017/RN030 */
}
.filtro select:focus,.filtro input:focus{outline:2px solid var(--azul-sec);border-color:var(--azul)}
/* RN032 — combobox com busca (Tom Select) para filtros com mais de 12 itens */
.filtro .ts-wrapper{width:100%}
.filtro .ts-control{min-height:44px;border:1px solid var(--borda);border-radius:var(--radius);
  padding:4px 10px;font-size:16px;background:var(--branco);color:var(--texto)}
.filtro .ts-control input{font-size:16px}
.ts-wrapper.focus .ts-control{outline:2px solid var(--azul-sec);border-color:var(--azul);box-shadow:none}
.ts-dropdown{font-size:16px;border-color:var(--borda)}
.ts-dropdown .active{background:var(--azul-sec);color:#fff}
.ts-dropdown .ts-dropdown-content{max-height:280px}
.filtro-acoes{display:flex;gap:12px;align-items:flex-end;flex:0 0 auto}

/* -------------------------------- botões ------------------------------- */
.btn{
  height:44px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;padding:0 18px;font-size:16px;font-weight:500;
  font-family:inherit;
}
.btn .material-icons{font-size:19px}
.btn-primary{background:var(--azul);color:#fff}
.btn-primary:hover{background:var(--azul-esc)}
.btn-secondary{background:#fff;color:var(--azul);border-color:var(--azul)}  /* RN019.2 secondary */
.btn-secondary:hover{background:#eef2f8}

/* -------------------------------- KPIs --------------------------------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpis-6{grid-template-columns:repeat(6,1fr)}
.kpi{
  background:#fff;border:1px solid var(--borda);border-radius:var(--radius);
  padding:12px 16px;display:flex;flex-direction:column;gap:2px;min-width:0;
  box-shadow:0 2px 6px rgba(16,40,80,.05);
}
.kpi-value{font-size:30px;font-weight:700;color:var(--azul);line-height:1.05}
.kpi-label{font-size:16px;color:var(--texto);font-weight:500}
.kpi-unit{font-size:16px;color:var(--texto-suave);text-transform:lowercase}

/* -------------------------------- grids -------------------------------- */
.grid{display:grid;gap:14px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{
  background:#fff;border:1px solid var(--borda);border-radius:var(--radius);
  padding:14px 16px;display:flex;flex-direction:column;gap:10px;
  box-shadow:0 2px 6px rgba(16,40,80,.05);
  min-width:0;min-height:0;      /* permite encolher no grid (sem barra horizontal) */
}
.card-full{grid-column:1 / -1}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-weight:700;color:var(--texto);font-size:16px}
/* canvas em posição absoluta: não empurra a largura da coluna do grid */
.chart-wrap{position:relative;height:210px;min-width:0}
.chart-wrap.chart-wrap-tall{height:300px}
.chart-wrap canvas{position:absolute;inset:0;width:100%!important;height:100%!important}
.chart-wrap.clickable canvas{cursor:pointer}

/* -------------------- cross-filter (seleção interativa) ---------------- */
.xf-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  background:#eef3fb;border:1px solid #cfe0f5;border-radius:var(--radius);padding:8px 12px}
.xf-bar .xf-titulo{font-size:16px;color:var(--azul);font-weight:700;display:flex;align-items:center;gap:6px}
.xf-bar .xf-titulo .material-icons{font-size:18px}
.xf-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--azul-sec);
  color:var(--azul-esc);border-radius:16px;padding:3px 6px 3px 10px;font-size:16px}
.xf-chip b{font-weight:700}
.xf-chip .x{cursor:pointer;display:grid;place-items:center;width:18px;height:18px;border-radius:50%;
  background:#eef3fb;color:var(--azul)}
.xf-chip .x:hover{background:var(--vermelho);color:#fff}
.xf-clear{margin-left:auto;background:#fff;border:1px solid var(--borda);border-radius:var(--radius);
  color:var(--vermelho);font-size:16px;font-weight:500;cursor:pointer;padding:6px 12px;font-family:inherit;
  display:inline-flex;align-items:center;gap:6px}
.xf-clear:hover{background:#fff0f1}
.xf-clear .material-icons{font-size:17px}

/* tabela clicável p/ cross-filter */
.datagrid tbody tr.sel-row{cursor:pointer}
.datagrid tbody tr.sel-row:hover{background:#eaf1fb}
.datagrid tbody tr.xf-on{background:#dcebfb!important;box-shadow:inset 3px 0 0 var(--azul)}
.card-note{font-size:16px;color:var(--texto-suave);border-top:1px dashed #e3e7ee;padding-top:8px;margin-top:auto}

/* ------------------------------- mapa TO ------------------------------- */
.map-wrap{position:relative;height:210px;min-width:0;border:1px solid #e8ebf1;border-radius:var(--radius);overflow:hidden;background:#f7f9fc}
.leaflet-container{background:#f7f9fc;font-family:inherit;outline:none}
.map-muni-tip{
  background:#fff;border:1px solid var(--borda);border-radius:6px;
  padding:5px 9px;font-size:13px;color:var(--texto);box-shadow:0 4px 14px rgba(16,40,80,.18);
}
.map-muni-tip b{color:var(--azul)}
.map-legend{
  background:rgba(255,255,255,.92);border:1px solid var(--borda);border-radius:6px;
  padding:6px 8px;font-size:11px;color:var(--texto-suave);line-height:1.5;
}
.map-legend i{display:inline-block;width:14px;height:10px;margin-right:6px;vertical-align:middle;border-radius:2px}

/* ----------------------------- exportação ------------------------------ */
.export{position:relative}
.export-btn{
  height:34px;border:1px solid var(--borda);background:#fff;border-radius:var(--radius);
  display:inline-flex;align-items:center;gap:6px;padding:0 10px;cursor:pointer;
  color:var(--azul);font-size:16px;font-weight:500;font-family:inherit;
}
.export-btn:hover{background:#eef2f8}
.export-btn .material-icons{font-size:18px}
.export-menu{
  position:absolute;right:0;top:38px;background:#fff;border:1px solid var(--borda);
  border-radius:var(--radius);box-shadow:0 8px 24px rgba(16,40,80,.16);
  min-width:210px;z-index:20;overflow:hidden;display:none;
}
.export-menu.open{display:block}
.export-menu-title{font-size:14px;color:var(--texto-suave);padding:8px 12px 4px;text-transform:uppercase;letter-spacing:.04em}
.export-menu button{
  width:100%;text-align:left;border:none;background:#fff;padding:10px 12px;cursor:pointer;
  display:flex;align-items:center;gap:10px;font-size:16px;color:var(--texto);font-family:inherit;
}
.export-menu button:hover{background:#eef2f8}
.export-menu button small{margin-left:auto;color:var(--texto-suave);font-size:14px}

/* ------------------------------ datagrid ------------------------------- */
.table-wrap{overflow:auto;flex:1;min-width:0}
.card-table .table-wrap{max-height:210px}      /* alinha altura com os gráficos */
.card-full .table-wrap{max-height:430px}       /* lista grande rola dentro do card (RN018.3) */
.datagrid{width:100%;border-collapse:collapse;font-family:"Roboto Condensed","Roboto",sans-serif}
.datagrid th,.datagrid td{
  padding:10px 12px;text-align:left;border-bottom:1px solid #e8ebf1;font-size:16px;  /* RN016 */
}
.datagrid th{font-weight:700;color:var(--azul);position:sticky;top:0;background:#f6f8fb;white-space:nowrap}
.datagrid td.num,.datagrid th.num{text-align:right}
.datagrid tbody tr:nth-child(even){background:#fafbfd}
.datagrid tbody tr:hover{background:#eef4fb}

/* badges de situação (RN019.1) */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:13px;font-weight:500}
.badge::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.badge.ativo,.badge.ativa,.badge.vigente{color:#1d6b13;background:#e3f3da}
.badge.em_analise,.badge.a_vencer{color:#8a6d0b;background:#fdf3d2}
.badge.inativo,.badge.inativa{color:#5a5a5a;background:#ececec}
.badge.nao_credenciado,.badge.vencida,.badge.vencido{color:#a31920;background:#fbdcde}

/* ----------------------------- paginação ------------------------------- */
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid #e8ebf1;padding-top:12px;flex-wrap:wrap}
.reg-info{font-size:16px;color:var(--texto-suave)}
.paginacao{display:flex;gap:4px;flex-wrap:wrap}
.paginacao button{
  min-width:38px;height:38px;border:1px solid var(--borda);background:#fff;border-radius:var(--radius);
  cursor:pointer;font-size:16px;color:var(--texto);font-family:inherit;
}
.paginacao button:hover:not(:disabled){background:#eef2f8}
.paginacao button.active{background:var(--azul);color:#fff;border-color:var(--azul);font-weight:700}
.paginacao button:disabled{opacity:.45;cursor:default}

/* ------------------------------- toasts -------------------------------- */
.toasts{position:fixed;top:18px;right:18px;display:flex;flex-direction:column;gap:10px;z-index:90}
.toast{
  min-width:260px;max-width:360px;padding:12px 14px;border-radius:var(--radius);
  display:flex;align-items:center;gap:10px;font-size:16px;box-shadow:0 8px 24px rgba(0,0,0,.16);
  animation:slidein .2s ease;
}
.toast.info{background:#B4CDF2;color:#143564}      /* RN035 */
.toast.success{background:#78CB52;color:#fff}
.toast.warning{background:#FFE098;color:#644114}
.toast.danger{background:#FFCDD2;color:#B71C1C}
.toast .close{margin-left:auto;cursor:pointer;opacity:.7}
@keyframes slidein{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}

/* ----------------------- rodapé governamental (RN05) ------------------- */
.gov-footer{grid-area:footer;background:#fff;border-top:1px solid var(--borda)}
.gov-footer iframe{width:100%;height:74px;border:0;display:block}
.gov-fallback .gov-wrap{
  max-width:1280px;margin:0 auto;min-height:64px;display:flex;align-items:center;
  justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 22px;color:#333;font-size:16px;
}
.gov-fallback .gov-text{display:flex;align-items:center;gap:14px}
.gov-fallback .gov-bandeira{height:34px;width:auto}
.gov-fallback .gov-lines{display:flex;flex-direction:column;line-height:1.25}
.gov-fallback .gov-lines b{font-weight:500}
.gov-fallback .gov-ati{color:#5b6472}
.gov-fallback .gov-ati b{color:var(--azul);font-weight:700}

/* ---------------------------- responsividade --------------------------- */
@media (max-width:1200px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .kpis,.kpis-6{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .app{grid-template-columns:0 1fr}
  .sidebar{position:fixed;top:var(--header-h);bottom:0;width:var(--side-w);z-index:40;transform:translateX(-100%)}
  .app.show-menu .sidebar{transform:none}
  .topbar-brand{width:auto;min-width:0;border-right:none}
  .grid-3{grid-template-columns:1fr}
  .kpis,.kpis-6{grid-template-columns:repeat(2,1fr)}
  .user-field{display:none}
}
@media (max-width:600px){
  .filtro{flex:1 1 100%}
  .kpis,.kpis-6{grid-template-columns:1fr}
}
