:root{
  --radius: 18px;
  --radius-sm: 12px;
  --shadow: 0 18px 50px rgba(15,35,71,.22);
  --shadow-soft: 0 14px 40px rgba(15,35,71,.16);

  /* Shared blues (requested) */
  --blue-950:#1253a8;
  --blue-900:#1253a8;
  --blue-850:#1253a8;
  --blue-800:#1253a8;
  --blue-700:#1253a8;
  --blue-600:#1253a8;

  --cyan-400:#1253a8;
  --mint-400:#1253a8;
  --violet-400:#1253a8;

  --text:#244E9C;
  --muted:rgba(234,241,255,.72);
  --border:rgba(255,255,255,.12);
  --border-strong:rgba(255,255,255,.18);
}

html,body{height:100%;}
body{
  margin:0;
  font-family:Poppins, Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  overflow:hidden;
}

*{box-sizing:border-box;}
a{color:inherit}

html[data-theme="dark"]{
  --app-bg: #000000;
  --surface: #0f0f0f;
  --surface-2: #161616;
  --card: #141414;
  --card-strong: #1a1a1a;
  --content-bg: #000000;
  --sb-bg: #0a0a0a;
  --sb-border: rgba(255,255,255,.12);
  --sb-icon: #ffffff;
  --text:#f5f5f5;
  --muted:rgba(255,255,255,.62);
  --border:rgba(255,255,255,.12);
  --border-strong:rgba(255,255,255,.2);
}


html[data-theme="light"]{
  /* requested: global background white, but cards/buttons/etc in the same blue tonality */
  --app-bg: #FFFFFF;
  --content-bg: transparent;

  /* UI surfaces in blue */
  --surface: #1253a8;
  --surface-2: #1253a8;
  --card: #1253a8;
  --card-strong: #1253a8;

  /* outer text (headers on white) */
  --text:#1253a8;
  --muted:rgba(36,78,156,.70);

  /* borders for blue components */
  --border:rgba(255,255,255,.16);
  --border-strong:rgba(255,255,255,.22);

  /* sidebar stays bluish, icons white */
  --sb-bg: #1253a8;
  --sb-border: rgba(255,255,255,.20);
  --sb-icon: #FFFFFF;
}


html[data-theme="light"] .card,
html[data-theme="light"] .btn,
html[data-theme="light"] .icon-btn,
html[data-theme="light"] .searchbox,
html[data-theme="light"] .drawer{
  color: #1253a8;
}
html[data-theme="light"] .crumb,
html[data-theme="light"] .crumb-sub,
html[data-theme="light"] .footer{
  color: var(--text);
}


.app{
  height:100%;
  display:flex;
  background: var(--app-bg);
}

/* Sidebar */
.sidebar{
  width: 320px;
  min-width: 320px;
  max-width: 320px;
  height:100%;
  display:flex;
  flex-direction:column;
  padding: 14px 14px 12px;
  background: var(--sb-bg);
  border-right:1px solid var(--sb-border);
  position:relative;
  overflow:hidden;
  /* Animação elástica suave */
  transition: width 0.52s cubic-bezier(0.34, 1.56, 0.64, 1),
              min-width 0.52s cubic-bezier(0.34, 1.56, 0.64, 1),
              max-width 0.52s cubic-bezier(0.34, 1.56, 0.64, 1),
              box-shadow 0.45s ease;
}

.sidebar .icon{ color: var(--sb-icon); }

/* --- Ajustes da Identidade Visual Paulo Afonso --- */

/* 1. Remove o ícone antigo (selo/casinha) */
.brand-mark {
  display: none !important;
}

/* 2. Estiliza a nova logo da prefeitura */
.brand-logo-img {
  max-width: 160px; /* Ajuste o tamanho conforme preferir */
  height: auto;
  display: block;
  transition: opacity 0.2s ease;
}

/* 3. Esconde a logo quando a barra lateral for minimizada */
.sidebar.collapsed .brand-logo-img {
  display: none !important;
}

/* 4. Ajusta o espaçamento do topo da barra lateral */
.sb-top {
  display: flex;
  align-items: center;
  gap: 15px; /* Espaço entre as 3 barras e a logo */
  padding: 6px 4px 10px;
}

.brand {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1;
  min-width: 0;
}





.sb-top{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 6px 4px 10px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  flex:1;
}
.brand-mark{
  width:42px;height:42px;
  border-radius:14px;
  display:grid;place-items:center;
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  flex:0 0 auto;
}
.brand-text{min-width:0;}
.brand-title{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#FFFFFF;}
.brand-subtitle{font-size:12px;opacity:.85;color:#FFFFFF;}

.sb-search{
  margin: 2px 4px 12px;
  position:relative;
}
.sb-search input{
  width:100%;
  height:40px;
  border-radius: 12px;
  padding: 0 12px 0 40px;
  border:1px solid rgba(255,255,255,.14);
  outline:none;
  background: rgba(255,255,255,.08);
  color:#FFFFFF;
}
.sb-search input::placeholder{color:rgba(255,255,255,.70)}
.sb-search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);opacity:.95}

.sb-scroll{
  flex:1;
  overflow:auto;
  padding: 0 2px 8px;
}
.sb-scroll::-webkit-scrollbar{width:8px}
.sb-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.sb-scroll::-webkit-scrollbar-track{background:transparent}

.sb-section{margin: 10px 2px 0;}
.sb-section-title{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  opacity:.78;
  margin: 6px 8px 8px;
  color:#FFFFFF;
}

.sb-list{display:flex;flex-direction:column;gap:8px}

.nav-item{
  height:46px;
  border-radius: 16px;
  padding: 0 6px;
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  cursor:pointer;
  user-select:none;
  position:relative;
}
.nav-item:hover{background: rgba(255,255,255,.10);}
.nav-item.active{background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.18);}

.nav-icon{
  width:32px;height:32px;
  border-radius:12px;
  display:grid;place-items:center;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  flex:0 0 auto;
}
.nav-icon .icon{color:#FFFFFF}

.nav-text{flex:1;min-width:0;color:#FFFFFF}
.nav-title{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#FFFFFF}
.nav-sub{font-size:11px;opacity:.82;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#FFFFFF}

.fav-btn{
  width:36px;height:36px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  display:grid;place-items:center;
}
.fav-btn .icon{opacity:.95;color:#FFFFFF}
.fav-btn.on{background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.20);}

.sb-bottom{
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.sb-base { display: none !important; }
.sb-base .pill{
  display:inline-flex;
  gap:6px;
  align-items:center;
  padding:10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  font-size:12px;
  color:#FFFFFF;
}
.sb-actions{display:flex;gap:8px}

/* Collapsed sidebar (fix overlap) */
.sidebar.collapsed{
  width: 86px;
  min-width: 86px;
  max-width: 86px;
  padding: 14px 10px 12px;
}
.sidebar.collapsed .brand-text,
.sidebar.collapsed .sb-search,
.sidebar.collapsed .sb-section-title,
.sidebar.collapsed .nav-text,
.sidebar.collapsed .fav-btn,
.sidebar.collapsed .sb-base{
  opacity: 0;
  pointer-events: none;
  max-width: 0;
  overflow: hidden;
  transition: opacity 0.2s ease, max-width 0.7s cubic-bezier(0.34, 1.56, 0.64, 1);
}
/* Quando expandida: textos voltam ao tamanho normal com fade suave */
.sidebar:not(.collapsed) .brand-text,
.sidebar:not(.collapsed) .sb-search,
.sidebar:not(.collapsed) .sb-section-title,
.sidebar:not(.collapsed) .nav-text,
.sidebar:not(.collapsed) .fav-btn,
.sidebar:not(.collapsed) .sb-base{
  opacity: 1;
  pointer-events: auto;
  max-width: 300px;
  overflow: hidden;
  transition: opacity 0.3s ease 0.38s, max-width 0.7s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.sidebar.collapsed .sb-top{justify-content:center;gap:0}
.sidebar.collapsed .brand{justify-content:center}
.sidebar.collapsed .nav-item{
  padding: 0;
  gap: 0;
  justify-content: center;
  align-items: center;
  height: 52px;
  width: 100%;
}
.sidebar.collapsed .nav-icon{
  width:40px;height:40px;border-radius:16px;
  flex: 0 0 40px;
  margin: 0 auto;
}
.sidebar.collapsed .sb-actions{justify-content:center;width:100%}
.sidebar.collapsed .sb-actions .icon-btn{width:40px;height:40px;border-radius:16px}
.sidebar.collapsed .sb-bottom{justify-content:center;gap:10px}

/* ── Map Toolbar ──────────────────────────────────────────────── */
/* ── Map Toolbar redesenhada ────────────────────────────────── */
.map-toolbar-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 2px 14px;
  flex-wrap: wrap;
}

/* Lado esquerdo: info + botões principais */
.map-toolbar-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
/* Lado direito: ações secundárias */
.map-toolbar-right {
  display: flex;
  align-items: center;
  gap: 6px;
}

.map-toolbar-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin-right: 6px;
}
.map-toolbar-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.map-toolbar-sub {
  font-size: 11px;
  color: var(--muted);
}
.map-tb-divider {
  width: 1px;
  height: 26px;
  background: var(--border);
  margin: 0 2px;
}

/* ── Botão principal (Camadas) — grande e chamativo ── */
.map-tb-btn {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 10px 18px;
  border-radius: 12px;
  border: 2px solid var(--pm-accent, #244E9C);
  background: #244E9C;
  color: var(--pm-accent, #244E9C);
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .18s, border-color .18s, box-shadow .18s, transform .14s;
  position: relative;
  white-space: nowrap;
  letter-spacing: .01em;
}
.map-tb-btn:hover {
  background: #244E9C;
  border-color: var(--pm-accent2, #244E9C);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(36,78,156,.22);
}
.map-tb-btn.active {
  background: #244E9C;
  border-color: #244E9C;
  color: #FFFFFF;
  box-shadow: 0 6px 20px rgba(36,78,156,.38);
  transform: translateY(-1px);
}
html[data-theme="light"] .map-tb-btn {
  border-color: #244E9C;
  color: #244E9C;
}
.map-tb-chevron {
  opacity: .6;
  flex-shrink: 0;
  transition: transform .25s cubic-bezier(0.34,1.56,0.64,1), opacity .18s;
}
.map-tb-btn.active .map-tb-chevron {
  transform: rotate(180deg);
  opacity: 1;
}
.map-tb-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--pm-accent, #244E9C);
  color: #FFFFFF;
  font-size: 9px;
  font-weight: 800;
  line-height: 1;
}
.map-tb-btn.active .map-tb-badge {
  background: rgba(255,255,255,.30);
}
.map-tb-badge:empty { display: none; }

/* ── Botões secundários: Satélite e Tela cheia ── */
.sat-toggle-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  border-radius: 12px;
  border: 2px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  color: #FFFFFF;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  backdrop-filter: blur(8px);
  transition: background .18s, border-color .18s, transform .14s, box-shadow .18s;
  white-space: nowrap;
}
.sat-toggle-btn:hover {
  background: rgba(255,255,255,.22);
  border-color: rgba(255,255,255,.45);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(15,35,71,.20);
}
.sat-toggle-btn.active {
  background: rgba(56,190,239,.28);
  border-color: rgba(56,190,239,.70);
  color: #244E9C;
  box-shadow: 0 0 20px rgba(56,190,239,.30);
}

/* Sat e fullscreen dentro da toolbar ficam no estilo da toolbar (não dentro do card azul) */
.map-toolbar-right .sat-toggle-btn {
  border-color: var(--border);
  background: var(--surface);
  color: var(--text);
  backdrop-filter: none;
}
.map-toolbar-right .sat-toggle-btn:hover {
  border-color: var(--pm-accent, #244E9C);
  background: rgba(36,78,156,.07);
  color: var(--pm-accent, #244E9C);
  box-shadow: 0 4px 14px rgba(36,78,156,.14);
}
.map-toolbar-right .sat-toggle-btn.active {
  background: #244E9C;
  border-color: #244E9C;
  color: #FFFFFF;
  box-shadow: 0 4px 16px rgba(56,190,239,.35);
}

.map-fullscreen-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  border-radius: 12px;
  border: 2px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .18s, border-color .18s, transform .14s, box-shadow .18s;
  white-space: nowrap;
}
.map-fullscreen-btn:hover {
  border-color: var(--pm-accent, #244E9C);
  background: rgba(36,78,156,.07);
  color: var(--pm-accent, #244E9C);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(36,78,156,.14);
}

/* Wrapper posicionado para o popup */
.map-tb-popup-wrap {
  position: relative;
}

/* Popup flutuante */
.map-tb-popup {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 500;
  width: 300px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 12px 40px rgba(15,35,71,.18), 0 3px 10px rgba(15,35,71,.10);
  overflow: hidden;
  opacity: 0;
  transform: translateY(-10px) scale(0.96);
  pointer-events: none;
  transition: opacity .24s cubic-bezier(0.34,1.56,0.64,1),
              transform .28s cubic-bezier(0.34,1.56,0.64,1);
}
.map-tb-popup.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.map-tb-popup-header {
  padding: 16px 18px 10px;
}
.map-tb-popup-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
}
.map-tb-popup-sub {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
}
.map-tb-popup-divider {
  height: 1px;
  background: var(--border);
  margin: 0 16px 10px;
}
.map-tb-cat-row {
  padding: 0 14px 10px;
}
.map-tb-layers-list {
  max-height: 340px;
  overflow-y: auto;
  padding: 0 8px 14px;
}
.map-tb-markers-list {
  padding: 8px 14px 14px;
  max-height: 320px;
  overflow-y: auto;
}
.map-tb-layers-list::-webkit-scrollbar,
.map-tb-markers-list::-webkit-scrollbar { width: 5px; }
.map-tb-layers-list::-webkit-scrollbar-thumb,
.map-tb-markers-list::-webkit-scrollbar-thumb {
  background: rgba(96,112,138,.22);
  border-radius: 999px;
}

html[data-theme="light"] .map-tb-popup {
  box-shadow: 0 12px 40px rgba(15,35,71,.10), 0 3px 10px rgba(15,35,71,.06);
}

/* Main */
.main{
  flex:1;
  height:100%;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  background: var(--content-bg);
}
.topbar{
  height:74px;
  display:flex;
  align-items:center;
  gap:14px;
  padding: 14px 18px;
}
.topbar-left{min-width:220px}
.crumb{font-size:16px;font-weight:800;letter-spacing:-.01em}
.crumb-sub{font-size:12px;opacity:.75;margin-top:3px}

.topbar-center{flex:1;display:flex;justify-content:center}
.searchbox{
  position:relative;
  width:min(740px, 100%);
  height:44px;
  display:flex;
  align-items:center;
  gap:10px;
  padding: 0 14px;
  border-radius: 16px;
  border:1px solid var(--border);
  background: var(--surface);
  backdrop-filter: blur(10px);
}
.searchbox input{
  flex:1;
  border:0;
  outline:none;
  background:transparent;
  color:inherit;
  padding-right:42px;
}
.pm-search-clear{
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  width:28px;
  height:28px;
  border:0;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(36,78,156,.10);
  color:#244E9C;
  cursor:pointer;
  transition:background .18s ease,color .18s ease,transform .18s ease;
  flex:0 0 auto;
  z-index:2;
}
.pm-search-clear:hover{
  background:rgba(36,78,156,.16);
  color:#244E9C;
  transform:translateY(-50%) scale(1.04);
}
.searchbox input::placeholder{color:var(--muted)}

.pm-search-results-scroll{
  max-height:320px;
  overflow:auto;
  padding:8px;
  scrollbar-gutter:stable;
}
.pm-search-results-scroll::-webkit-scrollbar{
  width:8px;
}
.pm-search-results-scroll::-webkit-scrollbar-thumb{
  background:rgba(36,78,156,.20);
  border-radius:999px;
}

.topbar-right{display:flex;align-items:center;gap:10px}

.tutu-popup{
  position:fixed;
  left:18px;
  bottom:18px;
  width:min(360px, calc(100vw - 28px));
  max-height:min(76vh, 600px);
  border-radius:20px;
  border:1px solid rgba(36,78,156,.12);
  background:#FFFFFF;
  box-shadow:0 18px 40px rgba(36,78,156,.20);
  color:#244E9C;
  overflow:visible;
  z-index:2500;
  display:none;
  flex-direction:column;
}
.tutu-popup.open{display:flex}
.tutu-chat-float{
  position:absolute;
  left:50%;
  top:-230px;
  transform:translateX(calc(-50% - 22px));
  z-index:5;
  pointer-events:none;
}
.tutu-chat-float-img{
  width:265px;
  height:265px;
  object-fit:contain;
  display:block;
  filter:drop-shadow(0 16px 22px rgba(36,78,156,.20));
  transform-origin:center bottom;
}
.tutu-chat-float-img.is-thinking{
  transform:none;
}
.tutu-popup-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.14);
  background:#244E9C;
  border-radius:20px 20px 0 0;
  cursor:grab;
  user-select:none;
  touch-action:none;
}
.tutu-popup-head.dragging{
  cursor:grabbing;
}
.tutu-popup-title{
  font-size:14px;
  font-weight:800;
  color:#FFFFFF;
}
.tutu-head-actions{
  display:flex;
  align-items:center;
  gap:6px;
}
.tutu-popup-sub{
  display:none;
}
.tutu-close-btn,
.tutu-min-btn,
.tutu-back-btn,
.tutu-send-btn,
.tutu-start-btn{
  border:0;
  cursor:pointer;
  font:inherit;
}
.tutu-min-btn,
.tutu-close-btn{
  width:26px;
  height:26px;
  border-radius:9px;
  display:grid;
  place-items:center;
  color:#FFFFFF;
  background:rgba(255,255,255,.14);
}
.tutu-popup-body{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:8px 9px 9px;
  opacity:1;
  transform:translateY(0);
}
#tutuHomeView[hidden],
#tutuChatView[hidden]{
  display:none !important;
}
#tutuHomeView:not([hidden]),
#tutuChatView:not([hidden]){
  display:flex;
  flex-direction:column;
}
.tutu-trash-btn{
  width:28px;
  height:28px;
  border:1px solid rgba(36,78,156,.12);
  border-radius:10px;
  background:#F7F9FD;
  color:#244E9C;
  display:grid;
  place-items:center;
  cursor:pointer;
}
.tutu-trash-btn:hover{
  background:#EEF4FF;
}
.tutu-visual{
  border-radius:16px;
  min-height:238px;
  padding:12px 12px 14px;
  background:#244E9C;
  border:1px solid rgba(36,78,156,.10);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
html[data-theme="light"] .tutu-visual{
  background:#eef1f6 !important;
  border-color:rgba(36,78,156,.14) !important;
}
.tutu-visual-badge{
  display:inline-flex;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(36,78,156,.10);
  color:#244E9C;
  font-size:10px;
  font-weight:700;
  letter-spacing:.02em;
}
.tutu-avatar{
  width:118px;
  height:118px;
  margin:14px auto 10px;
  border-radius:50%;
  background:#244E9C;
  box-shadow:0 0 0 6px rgba(36,78,156,.18);
  display:grid;
  place-items:center;
  flex:0 0 auto;
  position:relative;
  overflow:hidden;
}

/* Modo claro: disco colorido atrás da cabeça do Tutu (mesmas cores da faixa superior) */
html[data-theme="light"] .tutu-avatar::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background: conic-gradient(
    #244E9C 0deg 60deg,
    #38BEEF 60deg 120deg,
    #FCCF00 120deg 180deg,
    #E9561E 180deg 240deg,
    #47AB34 240deg 300deg,
    #005E34 300deg 360deg
  );
  z-index:0;
}
html[data-theme="light"] .tutu-avatar{
  box-shadow:
    0 0 0 6px rgba(36,78,156,.18),
    0 0 0 10px #ffffff !important;
}

.tutu-avatar img{
  position:relative;
  z-index:1;
  width:78% !important;
  height:78% !important;
  object-fit:contain !important;
}
.tutu-visual-text{
  text-align:center;
  font-size:11px;
  line-height:1.35;
  color:rgba(36,78,156,.78);
  margin-top:auto;
  width:100%;
}
.tutu-start-btn{
  width:100%;
  min-height:42px;
  border-radius:12px;
  background:#244E9C;
  color:#FFFFFF;
  font-weight:700;
  font-size:12px;
}
.tutu-chat-view{
  min-height:290px;
  position:relative;
  padding-top:8px;
}
#tutuHomeView{
  min-height:290px;
  justify-content:space-between;
}
#tutuHomeView.tutu-view-enter,
#tutuChatView.tutu-view-enter{
  animation:tutuViewFadeIn .22s ease both;
}
#tutuHomeView.tutu-view-leave,
#tutuChatView.tutu-view-leave{
  animation:tutuViewFadeOut .18s ease both;
}
.tutu-chat-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:2px;
}
.tutu-back-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 10px;
  border-radius:10px;
  background:#EEF4FF;
  color:#244E9C;
  font-size:12px;
  font-weight:700;
}
.tutu-chat-messages{
  flex:1;
  min-height:160px;
  max-height:380px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:0 2px 0 0;
}
.tutu-msg{
  max-width:85%;
  padding:9px 11px;
  border-radius:14px;
  font-size:11px;
  line-height:1.4;
}
.tutu-msg.bot{
  align-self:flex-start;
  background:#EEF4FF;
  border:1px solid rgba(36,78,156,.08);
  color:#244E9C;
}
.tutu-msg.typing{
  min-width:58px;
  display:flex;
  align-items:center;
  gap:6px;
}
.tutu-typing-dot{
  width:7px;
  height:7px;
  border-radius:999px;
  background:#244E9C;
  opacity:.35;
  animation:tutuTypingBounce 1s infinite ease-in-out;
}
.tutu-typing-dot:nth-child(2){animation-delay:.16s}
.tutu-typing-dot:nth-child(3){animation-delay:.32s}
.tutu-msg.user{
  align-self:flex-end;
  background:#244E9C;
  color:#FFFFFF;
}
.tutu-msg-rich{
  max-width:96%;
  padding:10px 12px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.tutu-msg-badge{
  align-self:flex-start;
  font-size:9px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#244E9C;
  background:rgba(36,78,156,.10);
  border:1px solid rgba(36,78,156,.18);
  padding:3px 8px;
  border-radius:999px;
}
.tutu-msg-text{
  font-size:11.5px;
  line-height:1.45;
  color:#244E9C;
}
.tutu-msg-list{
  margin:0;
  padding-left:16px;
  display:flex;
  flex-direction:column;
  gap:3px;
  font-size:11px;
  color:#244E9C;
}
.tutu-msg-list li{line-height:1.4;}
.tutu-msg-actions{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:2px;
}
.tutu-action-btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  height:28px;
  padding:0 11px;
  border-radius:999px;
  border:1px solid rgba(36,78,156,.22);
  background:#FFFFFF;
  color:#244E9C;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  transition:background .15s, border-color .15s, transform .12s;
}
.tutu-action-btn:hover{
  background:#244E9C;
  color:#FFFFFF;
  border-color:#244E9C;
}
.tutu-action-btn:active{transform:scale(.97)}
.tutu-msg-sources{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
  font-size:10px;
  color:#60708A;
  margin-top:2px;
}
.tutu-msg-sources-label{font-weight:700;color:#60708A}
.tutu-source-chip{
  background:#F3F6FB;
  border:1px solid #DCE5F2;
  color:#60708A;
  padding:2px 8px;
  border-radius:999px;
  font-size:10px;
}
.tutu-msg-divider{
  height:1px;
  background:rgba(36,78,156,.10);
  margin:2px 0;
}
.tutu-suggestions{
  align-self:flex-start;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:2px 0 6px;
  max-width:100%;
}
.tutu-suggest-chip{
  height:26px;
  padding:0 11px;
  border-radius:999px;
  border:1px dashed rgba(36,78,156,.30);
  background:transparent;
  color:#244E9C;
  font-size:10.5px;
  font-weight:600;
  cursor:pointer;
  transition:background .15s, border-color .15s, color .15s;
}
.tutu-suggest-chip:hover{
  background:#244E9C;
  color:#FFFFFF;
  border-color:#244E9C;
}
.tutu-chat-form{
  display:flex;
  gap:6px;
}
.tutu-chat-form input{
  flex:1;
  min-width:0;
  height:38px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(36,78,156,.12);
  outline:none;
  background:#F7F9FD;
  color:#244E9C;
  font-size:12px;
}
.tutu-chat-form input::placeholder{color:rgba(36,78,156,.45)}
.tutu-send-btn{
  min-width:64px;
  padding:0 12px;
  border-radius:12px;
  background:#244E9C;
  color:#FFFFFF;
  font-weight:700;
  font-size:12px;
}

@keyframes tutuViewFadeIn{
  from{opacity:0;transform:translateY(8px);}
  to{opacity:1;transform:translateY(0);}
}

@keyframes tutuViewFadeOut{
  from{opacity:1;transform:translateY(0);}
  to{opacity:0;transform:translateY(-6px);}
}

@keyframes tutuTypingBounce{
  0%, 80%, 100%{transform:translateY(0);opacity:.35;}
  40%{transform:translateY(-4px);opacity:1;}
}
.tutu-min-tab{
  position:fixed;
  left:104px;
  bottom:0;
  height:38px;
  padding:0 16px;
  border:1px solid rgba(36,78,156,.14);
  border-radius:14px 14px 0 0;
  background:#244E9C;
  color:#FFFFFF;
  font:inherit;
  font-weight:700;
  box-shadow:0 10px 24px rgba(36,78,156,.18);
  z-index:2495;
  cursor:pointer;
}
.tutu-min-tab[hidden]{
  display:none !important;
}

html[data-theme="light"] .tutu-popup{
  background:#FFFFFF;
}

@media (max-width: 720px){
  .tutu-popup{
    left:12px;
    right:12px;
    width:auto;
    bottom:12px;
  }
  .tutu-min-tab{
    left:12px;
    bottom:0;
  }
}

.content{
  flex:1;
  overflow:auto;
  padding: 8px 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
/* When .content holds censo-integrated, it must not add any spacing */
.content:has(.censo-integrated),
.content:has(.education-integrated-root) {
  padding: 0 !important;
  gap: 0 !important;
  overflow: hidden !important;
}
.content::-webkit-scrollbar{width:10px}
.content::-webkit-scrollbar-thumb{background:rgba(15,35,71,.18);border-radius:999px}
html[data-theme="dark"] .content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14)}
.content::-webkit-scrollbar-track{background:transparent}

.footer{
  padding: 10px 18px 14px;
  display:block;
  min-height:44px;
}

.footer.pm-app-footer {
  min-height: 0;
}

.icon-btn{
  width:44px;height:44px;
  border-radius: 16px;
  border:1px solid var(--border);
  background: var(--surface);
  display:grid;place-items:center;
  cursor:pointer;
  position:relative;
  backdrop-filter: blur(10px);
}
.icon-btn:hover{filter:brightness(1.06)}
.badge{
  position:absolute;
  right:8px; top:8px;
  font-size:11px;
  min-width:18px;
  height:18px;
  padding:0 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.22);
  display:grid;place-items:center;
}
html[data-theme="light"] .badge{
  background: rgba(36,78,156,.14);
  border-color: rgba(36,78,156,.18);
}

/* Cards */
.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.card{
  border-radius: var(--radius);
  border:1px solid var(--border);
  background: var(--surface);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-soft);
  overflow:hidden;
}
.card.blue{
  border-color: rgba(255,255,255,.12);
  background: var(--card);
  color:#FFFFFF;
}
html[data-theme="light"] .card.blue{
  border-color: rgba(255,255,255,.14);
  color:#FFFFFF;
}
.card.strong{ background: var(--card-strong); color:#FFFFFF; border-color: rgba(255,255,255,.16); }
.card .card-head{
  padding: 14px 16px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.card .card-title{
  font-weight:800;
  letter-spacing:-.01em;
  font-size:14px;
}
.card .card-sub{
  font-size:12px;
  opacity:.78;
  margin-top:4px;
}
.card .card-body{padding: 0 16px 14px;}
.kpi{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.kpi .kpi-val{font-size:26px;font-weight:900;line-height:1}
.kpi .kpi-lbl{font-size:12px;opacity:.82;margin-top:6px}
.kpi .kpi-delta{
  font-size:12px;
  font-weight:700;
  padding:6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
}
.kpi .spark{height:28px;margin-top:8px}

.btn{
  height:40px;
  border-radius: 12px;
  padding: 0 14px;
  border:1px solid var(--border);
  background: var(--surface);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:inherit;
}
.btn:hover{filter:brightness(1.06)}
.btn.primary{
  background: var(--card-strong);
  border-color: rgba(255,255,255,.16);
  color:#FFFFFF;
}
.pills{display:flex;gap:8px;flex-wrap:wrap}
.pill-btn{
  height:30px;
  border-radius: 999px;
  padding: 0 6px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.10);
  color: #244E9C;
  font-size:12px;
  cursor:pointer;
}
.pill-btn:hover{background: rgba(255,255,255,.14)}

/* Drawer */
.drawer-backdrop{
  position:fixed;inset:0;
  background: rgba(15,35,71,.45);
  opacity:0;
  pointer-events:none;
  transition: .18s ease;
}
.drawer{
  position:fixed;
  top:0; right:0;
  height:100%;
  width: 380px;
  max-width: calc(100vw - 24px);
  background: var(--surface-2);
  backdrop-filter: blur(14px);
  border-left:1px solid var(--border);
  transform: translateX(102%);
  transition: .22s ease;
  padding: 14px;
  display:flex;
  flex-direction:column;
  box-shadow: var(--shadow);
}
.drawer.open{transform: translateX(0)}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  padding: 6px 2px 10px;
}
.drawer-title{font-weight:900;font-size:16px}
.drawer-sub{font-size:12px;opacity:.75;margin-top:4px}
.drawer-body{padding: 4px 2px 10px; overflow:auto}
.drawer-body::-webkit-scrollbar{width:10px}
.drawer-body::-webkit-scrollbar-thumb{background:rgba(15,35,71,.18);border-radius:999px}
html[data-theme="dark"] .drawer-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14)}
.setting{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  padding: 12px 12px;
  border-radius: 18px;
  border:1px solid var(--border);
  background: var(--surface);
  margin-bottom:10px;
}
.setting-title{font-weight:800;font-size:13px}
.setting-desc{font-size:12px;opacity:.75;margin-top:4px;line-height:1.35}
.select{
  height:40px;border-radius:14px;
  border:1px solid var(--border);
  background: var(--surface);
  color:inherit;
  padding: 0 12px;
}
.divider{height:1px;background:var(--border);margin: 10px 0 12px}

/* Switch */
.switch{position:relative;width:48px;height:28px;display:inline-block}
.switch input{display:none}
.switch span{
  position:absolute;inset:0;
  border-radius:999px;
  background: rgba(15,35,71,.18);
  border:1px solid var(--border);
  transition:.18s ease;
}
html[data-theme="dark"] .switch span{background: rgba(255,255,255,.10)}
.switch span::after{
  content:"";
  position:absolute;
  width:22px;height:22px;
  border-radius:999px;
  top:50%;left:3px;
  transform: translateY(-50%);
  background: rgba(255,255,255,.92);
  transition:.18s ease;
}
html[data-theme="dark"] .switch span::after{background:#FFFFFF}
.switch input:checked + span{
  background: rgba(71,171,52,.26);
  border-color: rgba(71,171,52,.38);
}
.switch input:checked + span::after{left:23px}

/* Tooltip card */
.tooltip{
  position:fixed;
  z-index:50;
  min-width: 200px;
  max-width: 280px;
  padding: 10px 14px;
  border-radius: 12px;
  background: #244E9C;
  border:1px solid rgba(255,255,255,.20);
  box-shadow: 0 8px 28px rgba(15,35,71,.32), 0 2px 8px rgba(15,35,71,.20);
  color:#FFFFFF;
  opacity:0;
  transform: translateY(6px);
  pointer-events:none;
  transition: .12s ease;
}
.tooltip.show{opacity:1;transform: translateY(0)}
.tooltip .tt-title{font-weight:900;font-size:13px}
.tooltip .tt-sub{opacity:.82;font-size:12px;margin-top:4px;line-height:1.35}

/* Compact mode */
html.compact .topbar{height:64px}
html.compact .content{padding-top:6px}
html.compact .nav-item{height:44px}
html.compact .card .card-head{padding: 12px 14px 8px}
html.compact .card .card-body{padding: 0 14px 12px}

/* Reduced motion */
html.reduce-motion *{transition:none !important;animation:none !important}

/* Responsive */
@media (max-width: 980px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:30;transform: translateX(0)}
  .main{margin-left:320px}
}
@media (max-width: 820px){
  .sidebar{transform: translateX(-102%)}
  .sidebar.open{transform: translateX(0)}
  .main{margin-left:0}
}


html[data-theme="light"] .searchbox input::placeholder{color:rgba(255,255,255,.72)}
html[data-theme="light"] .badge{background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.18); color:#FFFFFF}


/* ---------- Light mode: keep page background white but surfaces blue ---------- */
[data-theme="light"] .sidebar,
[data-theme="light"] .topbar,
[data-theme="light"] .card,
[data-theme="light"] .drawer,
[data-theme="light"] .pill,
[data-theme="light"] .btn,
[data-theme="light"] .nav-item,
[data-theme="light"] .table,
[data-theme="light"] .chip,
[data-theme="light"] .mini-list{
  color: #244E9C;
}
[data-theme="light"] .crumb,
[data-theme="light"] .crumb-sub,
[data-theme="light"] .footer,
[data-theme="light"] .page-title{
  color: var(--blue-800);
}

/* ---------- Settings: map categories UI ---------- */
.input{
  width:100%;
  padding:10px 12px;
  border-radius: 12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.08);
  color: var(--text);
  outline:none;
}
.input::placeholder{ color: rgba(234,241,255,.65); }
[data-theme="light"] .input{
  background: rgba(255,255,255,.12);
  color:#FFFFFF;
}
.row{display:flex; align-items:center;}
.gap{gap:10px;}
.mini-list{display:flex; flex-direction:column; gap:10px; margin-top:12px;}
.mini-item{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.06);
}
.mini-item .left{display:flex; flex-direction:column; gap:2px;}
.mini-item .t{font-weight:700;}
.mini-item .s{opacity:.8; font-size:12px;}
.mini-actions{display:flex; gap:8px; align-items:center;}
.btn.small{padding:8px 10px; border-radius:12px; font-size:12px;}
.btn.danger{background: rgba(233,86,30,.18); border:1px solid rgba(233,86,30,.35);}

/* hide favorite star when sidebar is collapsed (extra safety) */
.sidebar.collapsed .fav-btn{ display:none !important; }

.chips{display:flex; flex-wrap:wrap; gap:10px;}
.chip{
  padding:8px 12px;
  border-radius: 999px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.06);
  cursor:pointer;
  user-select:none;
  font-weight:700;
  font-size:12px;
}
.chip.on{
  background: rgba(56,190,239,.14);
  border-color: rgba(56,190,239,.28);
}

/* ---------- Map: scroll interno + legenda ---------- */
.scroll-y{
  max-height: 340px;
  overflow:auto;
  padding-right:6px;
}
.scroll-y::-webkit-scrollbar{width:10px;}
.scroll-y::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.18);
  border-radius: 999px;
  border:3px solid transparent;
  background-clip: content-box;
}
.scroll-y::-webkit-scrollbar-track{background: transparent;}

.legend{
  margin-top:8px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.legend-row{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  opacity:.92;
}
.legend-row img{
  width:14px;
  height:14px;
  border-radius:4px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
}

@media (max-width: 980px){
  .scroll-y{ max-height: 420px; }
}


/* ==== SIMPLANE INSPIRED LIGHT THEME (cores, fontes e efeitos) ==== */
html[data-theme="light"]{
  --app-bg: #F3F6FB;
  --content-bg: #F3F6FB;
  --surface: #FFFFFF;
  --surface-2: #FFFFFF;
  --card: #FFFFFF;
  --card-strong: #244E9C;
  --text: #244E9C;
  --muted: rgba(36,78,156,.62);
  --border: rgba(36,78,156,.10);
  --border-strong: rgba(36,78,156,.14);
  --shadow: 0 18px 46px rgba(36,78,156,.14);
  --shadow-soft: 0 10px 26px rgba(36,78,156,.10);
  --accent: #244E9C;
  --accent-2: #244E9C;
  --topbar-bg: #244E9C;
  --topbar-text: #FFFFFF;
  --sb-bg: #244E9C;
  --sb-border: rgba(255,255,255,.10);
  --sb-icon: #FFFFFF;
}

html[data-theme="light"] body{
  color: #244E9C;
}

/* Topbar (faixa azul) */
html[data-theme="light"] .topbar{
  background: var(--topbar-bg);
  color: var(--topbar-text);
  border-bottom: 1px solid rgba(255,255,255,.16);
}
html[data-theme="light"] .crumb,
html[data-theme="light"] .crumb-sub{
  color: #FFFFFF;
}

/* Busca e ícones no topo */
html[data-theme="light"] .searchbox{
  background: rgba(255,255,255,.92);
  border-color: rgba(255,255,255,.35);
  color: #244E9C;
  box-shadow: 0 10px 22px rgba(36,78,156,.12);
}
html[data-theme="light"] .searchbox .icon{ color: #244E9C; }
html[data-theme="light"] .searchbox input::placeholder{ color: rgba(36,78,156,.55); }

html[data-theme="light"] .topbar .icon-btn{
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.22);
  color:#FFFFFF;
}
html[data-theme="light"] .topbar .icon-btn:hover{ filter: brightness(1.12); }
html[data-theme="light"] .topbar .badge{
  background: rgba(255,255,255,.88);
  border-color: rgba(255,255,255,.92);
  color: #244E9C;
}

/* Área principal */
html[data-theme="light"] .main{
  background: var(--content-bg);
}

/* Cards (brancos, suaves) */
html[data-theme="light"] .card{
  background: #FFFFFF;
  border-color: rgba(36,78,156,.10);
  color: var(--text);
  box-shadow: var(--shadow-soft);
}
html[data-theme="light"] .card .card-sub{ opacity: .72; }

/* Cards com destaque (mantém classe blue/strong, mas em tom claro) */
html[data-theme="light"] .card.blue{
  background: #244E9C;
  border-color: rgba(36,78,156,.18);
  color: var(--text);
}
html[data-theme="light"] .card.strong{
  background: #244E9C;
}

/* KPIs */
html[data-theme="light"] .kpi .kpi-delta{
  background: rgba(36,78,156,.10);
  border-color: rgba(36,78,156,.16);
  color: #244E9C;
}

/* Botões */
html[data-theme="light"] .btn{
  background: #FFFFFF;
  border-color: rgba(36,78,156,.14);
  color: #244E9C;
  box-shadow: 0 8px 18px rgba(36,78,156,.06);
}
html[data-theme="light"] .btn:hover{
  filter: none;
  transform: translateY(-1px);
}
html[data-theme="light"] .btn.primary{
  background: #244E9C;
  border-color: rgba(36,78,156,.22);
  color: #FFFFFF;
}
html[data-theme="light"] .btn.small{ box-shadow:none; transform:none; }

/* Chips / filtros */
html[data-theme="light"] .chip{
  background: #FFFFFF;
  border-color: rgba(36,78,156,.12);
  color: #244E9C;
}
html[data-theme="light"] .chip.on{
  background: #244E9C;
  border-color: rgba(36,78,156,.28);
  color: #FFFFFF;
}

/* Listas internas */
html[data-theme="light"] .mini-item{
  background: #FFFFFF;
  border-color: rgba(36,78,156,.10);
}

/* Inputs */
html[data-theme="light"] .input{
  background: rgba(255,255,255,.92);
  border-color: rgba(36,78,156,.12);
  color: #244E9C;
}
html[data-theme="light"] .input::placeholder{ color: rgba(36,78,156,.55); }

/* Sidebar: mantém escura e elegante */
html[data-theme="light"] .sidebar .icon-btn{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.16);
  color:#FFFFFF;
}
html[data-theme="light"] .sb-search input{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.16);
}

/* Scrollbar (light) */
html[data-theme="light"] .scroll-y::-webkit-scrollbar-thumb{
  background: rgba(36,78,156,.22);
  border: 3px solid transparent;
  background-clip: content-box;
}

/* Footer */
html[data-theme="light"] .footer{
  color: rgba(36,78,156,.70);
}

/* ======================================================
   DARK THEME: todo texto deve ser BRANCO
   ====================================================== */
html[data-theme="dark"] .card-title,
html[data-theme="dark"] .card-sub,
html[data-theme="dark"] .mini-item .t,
html[data-theme="dark"] .mini-item .s,
html[data-theme="dark"] .block-title,
html[data-theme="dark"] .drawer-title,
html[data-theme="dark"] .drawer-sub,
html[data-theme="dark"] .setting-title,
html[data-theme="dark"] .setting-desc,
html[data-theme="dark"] .chip,
html[data-theme="dark"] .btn:not(.primary),
html[data-theme="dark"] .pill-btn,
html[data-theme="dark"] .crumb,
html[data-theme="dark"] .crumb-sub,
html[data-theme="dark"] .kpi-val,
html[data-theme="dark"] .kpi-lbl,
html[data-theme="dark"] .legend-row {
  color: #FFFFFF;
}
html[data-theme="dark"] .card-sub,
html[data-theme="dark"] .mini-item .s,
html[data-theme="dark"] .setting-desc,
html[data-theme="dark"] .kpi-lbl,
html[data-theme="dark"] .crumb-sub {
  color: rgba(255,255,255,.80) !important;
}
html[data-theme="dark"] .input {
  color: #FFFFFF !important;
}
html[data-theme="dark"] .input::placeholder {
  color: rgba(255,255,255,.55) !important;
}
html[data-theme="dark"] .select {
  color: #FFFFFF !important;
}
html[data-theme="dark"] .footer {
  color: rgba(255,255,255,.70) !important;
}

/* ======================================================
   MAP PAGE: chips de categoria mais aparentes e clicáveis
   ====================================================== */
.chip {
  padding: 10px 16px;
  border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.10);
  cursor: pointer;
  user-select: none;
  font-weight: 700;
  font-size: 11px;
  transition: background .15s ease, border-color .15s ease, transform .10s ease, box-shadow .15s ease;
  box-shadow: 0 2px 8px rgba(15,35,71,.18);
  letter-spacing: .01em;
}
.chip:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.42);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(15,35,71,.24);
}
.chip:active { transform: translateY(0); }
.chip.on {
  background: rgba(56,190,239,.22);
  border-color: rgba(56,190,239,.55);
  color: #244E9C;
  box-shadow: 0 0 14px rgba(56,190,239,.22), 0 2px 8px rgba(15,35,71,.18);
}

html[data-theme="light"] .chip {
  background: #FFFFFF;
  border: 1.5px solid rgba(36,78,156,.18);
  color: #244E9C;
  box-shadow: 0 2px 8px rgba(36,78,156,.10);
}
html[data-theme="light"] .chip:hover {
  background: #F0F4FF;
  border-color: rgba(36,78,156,.38);
  box-shadow: 0 4px 14px rgba(36,78,156,.16);
}
html[data-theme="light"] .chip.on {
  background: #244E9C;
  border-color: rgba(36,78,156,.35);
  color: #FFFFFF;
  box-shadow: 0 4px 14px rgba(36,78,156,.28);
}

/* Mini-item (camadas) — mais aparente */
.mini-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-radius: 12px;
  border: 1.5px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.08);
  transition: background .15s ease, border-color .15s ease;
}
.mini-item:hover {
  background: rgba(255,255,255,.13);
  border-color: rgba(255,255,255,.26);
}
.mini-item .t { font-weight: 700; font-size: 13px; }
.mini-item .s { opacity: .80; font-size: 12px; margin-top: 2px; }

html[data-theme="light"] .mini-item {
  background: #FFFFFF;
  border: 1.5px solid rgba(36,78,156,.12);
  box-shadow: 0 2px 8px rgba(36,78,156,.06);
}
html[data-theme="light"] .mini-item:hover {
  background: #F5F8FF;
  border-color: rgba(36,78,156,.22);
}
html[data-theme="light"] .mini-item .t { color: #244E9C; }
html[data-theme="light"] .mini-item .s { color: rgba(36,78,156,.72); }

/* ======================================================
   SIDEBAR COLLAPSED: esconder seção de favoritos (estrela)
   ====================================================== */
.sidebar.collapsed #secFav,
.sidebar.collapsed .fav-btn {
  display: none !important;
}

/* ================================================================
   PANORAMA MUNICIPAL — ADIÇÕES v4
   Todos os fixes: estrela, dark mode texto, card hover, paleta
   ================================================================ */

/* ── 1. REMOVER ESTRELA (fav-btn) completamente ── */
.fav-btn { display: none !important; }

/* ── 2. DARK MODE — TODO TEXTO BRANCO, SEM EXCEÇÃO ── */
html[data-theme="dark"] body,
html[data-theme="dark"] .card,
html[data-theme="dark"] .card-title,
html[data-theme="dark"] .card-sub,
html[data-theme="dark"] .kpi-val,
html[data-theme="dark"] .kpi-lbl,
html[data-theme="dark"] .kpi-delta,
html[data-theme="dark"] .mini-item .t,
html[data-theme="dark"] .mini-item .s,
html[data-theme="dark"] .block-title,
html[data-theme="dark"] .block-desc,
html[data-theme="dark"] .drawer-title,
html[data-theme="dark"] .drawer-sub,
html[data-theme="dark"] .setting-title,
html[data-theme="dark"] .setting-desc,
html[data-theme="dark"] .chip,
html[data-theme="dark"] .btn,
html[data-theme="dark"] .pill-btn,
html[data-theme="dark"] .crumb,
html[data-theme="dark"] .crumb-sub,
html[data-theme="dark"] .legend-row,
html[data-theme="dark"] .legend-row span,
html[data-theme="dark"] .footer,
html[data-theme="dark"] .muted,
html[data-theme="dark"] td,
html[data-theme="dark"] th,
html[data-theme="dark"] .nav-title,
html[data-theme="dark"] .nav-sub,
html[data-theme="dark"] .sb-section-title,
html[data-theme="dark"] .brand-title,
html[data-theme="dark"] .brand-subtitle,
html[data-theme="dark"] .pill b,
html[data-theme="dark"] .pill { color: #FFFFFF !important; }

/* Sub-elementos levemente atenuados mas ainda brancos */
html[data-theme="dark"] .card-sub,
html[data-theme="dark"] .mini-item .s,
html[data-theme="dark"] .kpi-lbl,
html[data-theme="dark"] .crumb-sub,
html[data-theme="dark"] .setting-desc,
html[data-theme="dark"] .block-desc,
html[data-theme="dark"] .drawer-sub,
html[data-theme="dark"] .footer,
html[data-theme="dark"] .muted,
html[data-theme="dark"] .nav-sub { color: rgba(255,255,255,.75) !important; }

html[data-theme="dark"] .input,
html[data-theme="dark"] .select { color: #FFFFFF !important; }
html[data-theme="dark"] .input::placeholder { color: rgba(255,255,255,.45) !important; }

/* ── 3. CARDS MODO ESCURO — COR UNIFORME ── */
html[data-theme="dark"] .card.blue,
html[data-theme="dark"] .card.blue.strong {
  background: var(--pm-card-dark, var(--card)) !important;
}

/* ── 4. CARDS MODO CLARO — HOVER COM GROW + COR UNIFORME ── */
html[data-theme="light"] .card {
  background: #FFFFFF;
  border: 1px solid rgba(36,78,156,.08);
  box-shadow: 0 2px 12px rgba(36,78,156,.06);
  transition: transform .22s cubic-bezier(.34,1.56,.64,1),
              box-shadow .22s ease,
              border-color .18s ease !important;
}
html[data-theme="light"] .card:hover {
  transform: translateY(-4px) scale(1.012) !important;
  box-shadow: 0 22px 52px rgba(36,78,156,.20) !important;
  border-color: rgba(36,78,156,.22) !important;
  z-index: 2;
}
html[data-theme="light"] .card:active {
  transform: translateY(-1px) scale(1.006) !important;
}
/* Cards azuis no modo claro — mesma cor para todos */
html[data-theme="light"] .card.blue {
  background: var(--pm-card-blue, #244E9C) !important;
  border-color: rgba(255,255,255,.16) !important;
}
html[data-theme="light"] .card.blue:hover {
  border-color: rgba(255,255,255,.30) !important;
  box-shadow: 0 22px 52px rgba(36,78,156,.30) !important;
}
/* card.strong = mesmo gradiente, só mais escuro */
html[data-theme="light"] .card.blue.strong {
  background: var(--pm-card-strong, #244E9C) !important;
}
/* Texto branco dentro dos cards azuis */
html[data-theme="light"] .card.blue .card-title,
html[data-theme="light"] .card.blue .card-sub,
html[data-theme="light"] .card.blue .kpi-val,
html[data-theme="light"] .card.blue .kpi-lbl,
html[data-theme="light"] .card.blue .kpi-delta,
html[data-theme="light"] .card.blue .pill-btn,
html[data-theme="light"] .card.blue .btn:not(.primary),
html[data-theme="light"] .card.strong .card-title,
html[data-theme="light"] .card.strong .card-sub {
  color: #FFFFFF !important;
}
html[data-theme="light"] .card.blue .kpi-delta {
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.24);
}

/* ── 5. TOPBAR & SIDEBAR MODO CLARO (paleta) ── */
html[data-theme="light"] .topbar {
  background: var(--pm-topbar, #244E9C) !important;
  box-shadow: 0 2px 16px rgba(36,78,156,.22);
}
html[data-theme="light"] .sidebar {
  background: var(--pm-sb, #1253a8) !important;
}
html[data-theme="light"] .btn.primary {
  background: #244E9C !important;
  color: #FFFFFF !important;
}
html[data-theme="light"] .main { background: #F0F4FB; }

html[data-theme="light"] .topbar .icon-btn {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.20);
}
html[data-theme="light"] .topbar .icon-btn:hover {
  background: rgba(255,255,255,.22);
}

/* ── 6. SEARCHBOX MODO CLARO ── */
html[data-theme="light"] .searchbox {
  background: rgba(255,255,255,.96);
  border-color: rgba(255,255,255,.40);
  box-shadow: 0 4px 14px rgba(36,78,156,.14);
}
html[data-theme="light"] .searchbox input { color: #244E9C; }
html[data-theme="light"] .searchbox input::placeholder { color: rgba(36,78,156,.50); }
html[data-theme="light"] .searchbox .icon { color: #244E9C; }

/* ── 7. BUTTONS MODO CLARO ── */
html[data-theme="light"] .btn {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.14);
  color: #244E9C;
  box-shadow: 0 2px 8px rgba(36,78,156,.06);
}
html[data-theme="light"] .btn.primary {
  box-shadow: 0 4px 14px rgba(36,78,156,.28);
}
html[data-theme="light"] .btn.primary:hover {
  box-shadow: 0 8px 22px rgba(36,78,156,.38);
}

/* ── 8. ANIMAÇÕES GLOBAIS ── */
.btn, .icon-btn, .nav-item, .chip, .pill-btn, .fav-btn, .user-btn {
  transition: background .18s ease, border-color .18s ease,
              transform .12s ease, box-shadow .18s ease !important;
}
.btn:active:not(:disabled),
.icon-btn:active:not(:disabled),
.pill-btn:active:not(:disabled) {
  transform: scale(0.95) translateY(1px) !important;
  filter: brightness(.94);
}
.btn.primary { position: relative; overflow: hidden; }
.btn.primary::after {
  content: "";
  position: absolute; inset: 0;
  background: #FFFFFF;
  transform: translateX(-100%);
  transition: transform .4s ease;
}
.btn.primary:hover::after { transform: translateX(100%); }
.btn.primary:hover { transform: translateY(-2px); }

.icon-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(15,35,71,.18); }
.nav-item { transition: background .16s ease, transform .12s ease !important; }
.nav-item:hover { transform: translateX(2px); }
.nav-item:active { transform: translateX(0) scale(.98); }

/* Card hover — dark mode */
.card {
  transition: transform .22s cubic-bezier(.34,1.56,.64,1),
              box-shadow .22s ease,
              border-color .18s ease;
}
.card:hover {
  transform: translateY(-4px) scale(1.012);
  box-shadow: 0 24px 56px rgba(15,35,71,.22);
  z-index: 2;
}
html[data-theme="dark"] .card:hover {
  border-color: rgba(56,190,239,.20);
  box-shadow: 0 24px 56px rgba(15,35,71,.36), 0 0 30px rgba(56,190,239,.06);
}

/* ── 9. FADE DE ENTRADA DE PÁGINA ── */
@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.content { animation: fadeSlideIn .24s ease both; }
.grid > .card:nth-child(1) { animation: fadeSlideIn .22s ease .02s both; }
.grid > .card:nth-child(2) { animation: fadeSlideIn .22s ease .06s both; }
.grid > .card:nth-child(3) { animation: fadeSlideIn .22s ease .10s both; }
.grid > .card:nth-child(4) { animation: fadeSlideIn .22s ease .14s both; }
.grid > .card:nth-child(5) { animation: fadeSlideIn .22s ease .18s both; }
.grid > .card:nth-child(6) { animation: fadeSlideIn .22s ease .22s both; }
.grid > .card:nth-child(7) { animation: fadeSlideIn .22s ease .26s both; }

/* ── 10. PILL BUTTONS ── */
.pill-btn {
  display: inline-flex; align-items: center;
  height: 32px; border-radius: 999px; padding: 0 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
  font-size: 11px; font-weight: 600; cursor: pointer;
  user-select: none;
}
.pill-btn:hover { background: rgba(255,255,255,.16); transform: translateY(-1px); }
.pill-btn:active { transform: scale(.95); }
html[data-theme="light"] .pill-btn { background: rgba(36,78,156,.08); border-color: rgba(36,78,156,.14); color: #244E9C; }
html[data-theme="light"] .pill-btn:hover { background: rgba(36,78,156,.14); }
html[data-theme="light"] .card.blue .pill-btn { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.24); color: #FFFFFF; }

/* ── 11. DARK MODE BUTTONS ── */
html[data-theme="dark"] .btn.primary {
  background: #f5f5f5;
  color: #0a0a0a !important;
}
html[data-theme="dark"] .btn.primary:hover { box-shadow: 0 8px 22px rgba(0,0,0,.35); }

/* ── 12. CHIP ── */
.chip {
  padding: 10px 16px; border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.10);
  cursor: pointer; user-select: none;
  font-weight: 700; font-size: 12px;
  transition: background .15s, border-color .15s, transform .10s, box-shadow .15s;
}
.chip:hover { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.42); transform: translateY(-1px); }
.chip.on { background: rgba(56,190,239,.22); border-color: rgba(56,190,239,.55); color: #244E9C; }
html[data-theme="dark"] .chip.on { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.35); color: #f5f5f5; }
html[data-theme="light"] .chip { background: #FFFFFF; border: 1.5px solid rgba(36,78,156,.18); color: #244E9C; }
html[data-theme="light"] .chip:hover { background: #F0F4FF; }
html[data-theme="light"] .chip.on {
  background: #244E9C;
  color: #FFFFFF; border-color: transparent;
}

/* ── 13. MINI-ITEM (camadas) ── */
.mini-item { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-radius:14px; border:1.5px solid rgba(255,255,255,.16); background:rgba(255,255,255,.08); transition: background .15s, border-color .15s; }
.mini-item:hover { background:rgba(255,255,255,.13); border-color:rgba(255,255,255,.26); }
html[data-theme="light"] .mini-item { background:#FFFFFF; border:1.5px solid rgba(36,78,156,.12); box-shadow:0 2px 8px rgba(36,78,156,.06); }
html[data-theme="light"] .mini-item:hover { background:#F5F8FF; border-color:rgba(36,78,156,.22); }
html[data-theme="light"] .mini-item .t { color: #244E9C; }
html[data-theme="light"] .mini-item .s { color: rgba(36,78,156,.72); }

/* ── 14. BOTÃO DE USUÁRIO ── */
.user-btn {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 14px 6px 8px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  cursor: pointer; color: inherit; white-space: nowrap;
  transition: background .18s, border-color .18s, transform .12s, box-shadow .18s;
}
.user-btn:hover { background: rgba(255,255,255,.20); border-color: rgba(255,255,255,.35); transform: translateY(-1px); box-shadow: 0 4px 14px rgba(15,35,71,.18); }
.user-btn:active { transform: translateY(0); }
.user-avatar { width:34px; height:34px; border-radius:50%; background:#38BEEF; border:1.5px solid rgba(255,255,255,.28); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
html[data-theme="dark"] .user-avatar { background:#525252; border-color:rgba(255,255,255,.22); }
.user-initial { font-weight:800; font-size:14px; color:#FFFFFF; }
.user-info { text-align:left; }
.user-name { font-weight:700; font-size:13px; color:#FFFFFF; line-height:1.2; }
.user-role { font-size:11px; color:rgba(255,255,255,.78); margin-top:1px; }
.user-chevron { opacity:.72; flex:0 0 auto; color:#FFFFFF; transition:transform .18s; }
.user-btn:hover .user-chevron { transform:rotate(180deg); }

/* ── 15. SIDEBAR COLLAPSED: esconder favoritos ── */
.sidebar.collapsed #secFav,
.sidebar.collapsed .fav-btn { display: none !important; }

/* ── 16. MAP chips melhorados ── */
html[data-theme="light"] .chip { box-shadow: 0 2px 8px rgba(36,78,156,.10); }
html[data-theme="light"] .chip:hover { box-shadow: 0 4px 14px rgba(36,78,156,.16); }
html[data-theme="light"] .chip.on { box-shadow: 0 4px 14px rgba(36,78,156,.28); }

/* ── 17. SWITCH ── */
.switch span { transition: background .22s, border-color .22s; }
html[data-theme="dark"]  .switch input:checked + span { background: #737373; border-color: rgba(255,255,255,.35); }
html[data-theme="light"] .switch input:checked + span { background: #244E9C; border-color: rgba(36,78,156,.65); }

/* ── 18. SELETOR DE PALETA DE CORES ── */
.palette-picker {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px;
}
.palette-swatch {
  width: 40px; height: 40px; border-radius: 12px;
  border: 3px solid transparent; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: transform .15s, box-shadow .15s, border-color .15s;
  position: relative;
}
.palette-swatch:hover { transform: scale(1.14); box-shadow: 0 4px 14px rgba(15,35,71,.32); }
.palette-swatch.active {
  border-color: rgba(255,255,255,.90);
  box-shadow: 0 0 0 3px rgba(255,255,255,.28), 0 4px 12px rgba(15,35,71,.28);
  transform: scale(1.08);
}
html[data-theme="light"] .palette-swatch.active {
  border-color: rgba(15,35,71,.65);
  box-shadow: 0 0 0 3px rgba(15,35,71,.14), 0 4px 12px rgba(15,35,71,.20);
}
.palette-label-btn { display: none; } /* labels opcionais */

/* Setting block estilo */
.setting-block { padding: 14px 0 0; }
.setting-block .block-title { font-weight: 800; font-size: 13px; margin-bottom: 4px; }
.setting-block .block-desc { font-size: 12px; opacity: .75; margin-bottom: 10px; line-height: 1.5; }

/* Footer modo claro */
html[data-theme="light"] .footer { color: rgba(36,78,156,.70); }

/* Reduce-motion */
html.reduce-motion * { transition: none !important; animation: none !important; }


/* ================================================================
   USER MENU DROPDOWN
   ================================================================ */
.user-menu-backdrop {
  position: fixed; inset: 0; z-index: 900;
  pointer-events: none; opacity: 0;
}
.user-menu-backdrop.open {
  pointer-events: auto;
}
.user-menu {
  position: fixed;
  top: 64px; right: 16px;
  width: 260px;
  background: var(--surface);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  box-shadow: 0 20px 60px rgba(15,35,71,.38), 0 4px 16px rgba(15,35,71,.22);
  z-index: 901;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-12px) scale(.96);
  pointer-events: none;
  transition: opacity .22s cubic-bezier(.4,0,.2,1),
              transform .22s cubic-bezier(.34,1.56,.64,1);
}
html[data-theme="light"] .user-menu {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.10);
  box-shadow: 0 20px 60px rgba(36,78,156,.18), 0 4px 16px rgba(36,78,156,.10);
}
.user-menu.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.user-menu-header {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 18px 14px;
  background: #FFFFFF;
}
html[data-theme="light"] .user-menu-header {
  background: #F0F5FB;
  border-bottom: 1px solid rgba(18, 83, 168, 0.14);
}
.user-menu-avatar-lg {
  width: 46px; height: 46px; border-radius: 50%;
  background: #38BEEF;
  border: 2px solid rgba(255,255,255,.28);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 18px; color: #FFFFFF;
  flex: 0 0 auto;
}
html[data-theme="light"] .user-menu-avatar-lg {
  background: rgba(18, 83, 168, 0.1);
  border: 1px solid #1253a8;
  color: #1253a8;
}
.user-menu-name {
  font-weight: 700; font-size: 14px; color: #FFFFFF; line-height: 1.2;
}
html[data-theme="light"] .user-menu-name { color: #1253a8; }
.user-menu-role {
  font-size: 11px; color: rgba(255,255,255,.65); margin-top: 2px;
}
html[data-theme="light"] .user-menu-role { color: rgba(18, 83, 168, 0.62); }
.user-menu-access-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 700; margin-top: 5px;
  background: rgba(56,190,239,.15); border: 1px solid rgba(56,190,239,.30);
  color: #244E9C;
}
html[data-theme="light"] .user-menu-access-badge {
  background: rgba(36,78,156,.10); border-color: rgba(36,78,156,.22);
  color: var(--pm-accent, #244E9C);
}
.user-menu-divider {
  height: 1px; margin: 4px 0;
  background: rgba(255,255,255,.08);
}
html[data-theme="light"] .user-menu-divider { background: rgba(36,78,156,.08); }

.user-menu-item {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 12px 18px;
  background: none; border: none; cursor: pointer;
  font-family: inherit; font-size: 13px; font-weight: 500;
  color: rgba(255,255,255,.90);
  text-align: left;
  transition: background .15s, color .15s, padding-left .15s;
}
html[data-theme="light"] .user-menu-item { color: #244E9C; }
.user-menu-item:hover {
  background: rgba(255,255,255,.08);
  padding-left: 22px;
}
html[data-theme="light"] .user-menu-item:hover {
  background: rgba(36,78,156,.06);
  color: var(--pm-accent, #244E9C);
}
.user-menu-item svg { flex: 0 0 auto; opacity: .75; }
.user-menu-item.danger { color: #244E9C; }
.user-menu-item.danger:hover { background: rgba(233,86,30,.08); color: #244E9C; }
html[data-theme="light"] .user-menu-item.danger { color: #244E9C; }
html[data-theme="light"] .user-menu-item.danger:hover { background: rgba(233,86,30,.06); }

/* ================================================================
   MODAIS GERAIS
   ================================================================ */
.pm-modal-backdrop {
  position: fixed; inset: 0; z-index: 6000;
  background: rgba(36,78,156,.48);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.pm-modal-backdrop.open {
  opacity: 1; pointer-events: auto;
}
.pm-modal {
  width: 100%;
  background: var(--surface);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  box-shadow: 0 32px 80px rgba(15,35,71,.50);
  overflow: hidden;
  transform: translateY(20px) scale(.97);
  transition: transform .28s cubic-bezier(.34,1.56,.64,1);
}
html[data-theme="light"] .pm-modal {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.10);
  box-shadow: 0 32px 80px rgba(36,78,156,.22);
}
.pm-modal-backdrop.open .pm-modal {
  transform: translateY(0) scale(1);
}
.pm-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
html[data-theme="light"] .pm-modal-head { border-bottom-color: rgba(36,78,156,.08); }
.pm-modal-title {
  font-weight: 800; font-size: 16px; color: #FFFFFF;
}
html[data-theme="light"] .pm-modal-title { color: #244E9C; }
.pm-modal-close {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; padding: 7px; cursor: pointer; color: rgba(255,255,255,.75);
  transition: background .15s, color .15s, transform .15s;
  display: flex;
}
.pm-modal-close:hover { background: rgba(255,255,255,.16); color: #FFFFFF; transform: rotate(90deg); }
html[data-theme="light"] .pm-modal-close {
  background: rgba(36,78,156,.06); border-color: rgba(36,78,156,.10); color: #244E9C;
}
html[data-theme="light"] .pm-modal-close:hover { background: rgba(36,78,156,.12); color: #244E9C; }
.pm-modal-body { padding: 24px; }

/* ── Profile modal ── */
.profile-avatar-center {
  display: flex; justify-content: center; margin-bottom: 24px;
}
.profile-avatar-xl {
  width: 80px; height: 80px; border-radius: 50%;
  background: #38BEEF;
  border: 3px solid rgba(255,255,255,.28);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 32px; color: #FFFFFF;
  box-shadow: 0 8px 24px rgba(15,35,71,.28);
}
html[data-theme="light"] .profile-avatar-xl {
  background: #244E9C;
  border-color: rgba(36,78,156,.28);
}
.profile-info-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.profile-info-item { display: flex; flex-direction: column; gap: 4px; }
.profile-info-item.full { grid-column: span 2; }
.pii-label { font-size: 11px; font-weight: 600; color: rgba(255,255,255,.50); text-transform: uppercase; letter-spacing: .05em; }
html[data-theme="light"] .pii-label { color: rgba(36,78,156,.50); }
.pii-value { font-size: 14px; font-weight: 600; color: #FFFFFF; }
html[data-theme="light"] .pii-value { color: #244E9C; }
.pii-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 700;
  background: rgba(56,190,239,.15); border: 1px solid rgba(56,190,239,.30); color: #244E9C;
}
html[data-theme="light"] .pii-badge { background: rgba(36,78,156,.10); border-color: rgba(36,78,156,.22); color: var(--pm-accent,#244E9C); }
.pii-perms { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.pii-perm {
  padding: 4px 10px; border-radius: 8px; font-size: 12px; font-weight: 600;
}
.pii-perm.on { background: rgba(56,190,239,.12); color: #244E9C; border: 1px solid rgba(56,190,239,.25); }
.pii-perm.off { background: rgba(255,255,255,.06); color: rgba(255,255,255,.40); border: 1px solid rgba(255,255,255,.08); }
html[data-theme="light"] .pii-perm.on { background: rgba(36,78,156,.10); color: var(--pm-accent,#244E9C); border-color: rgba(36,78,156,.22); }
html[data-theme="light"] .pii-perm.off { background: rgba(36,78,156,.04); color: rgba(36,78,156,.35); border-color: rgba(36,78,156,.08); }

/* ── Change credentials form ── */
.cf-group { margin-bottom: 16px; }
.cf-label { display: block; font-size: 12px; font-weight: 600; color: rgba(255,255,255,.60); margin-bottom: 7px; }
html[data-theme="light"] .cf-label { color: rgba(36,78,156,.60); }
.cf-input {
  width: 100%; padding: 11px 14px;
  background: rgba(255,255,255,.07); border: 1.5px solid rgba(255,255,255,.14);
  border-radius: 12px; color: #FFFFFF;
  font-size: 13px; font-family: inherit; outline: none;
  transition: border-color .18s, background .18s, box-shadow .18s;
}
.cf-input:focus {
  border-color: rgba(56,190,239,.55);
  background: rgba(255,255,255,.10);
  box-shadow: 0 0 0 3px rgba(56,190,239,.10);
}
html[data-theme="light"] .cf-input {
  background: #F8FAFC; border-color: rgba(36,78,156,.14); color: #244E9C;
}
html[data-theme="light"] .cf-input:focus {
  border-color: var(--pm-accent,#244E9C);
  background: #FFFFFF; box-shadow: 0 0 0 3px rgba(36,78,156,.10);
}
.cf-error { font-size: 13px; color: #244E9C; min-height: 18px; margin-bottom: 8px; font-weight: 500; }
.cf-success { font-size: 13px; color: #244E9C; min-height: 18px; margin-bottom: 8px; font-weight: 600; }
.cf-btn {
  width: 100%; padding: 13px;
  background: #244E9C;
  color: #FFFFFF; border: none; border-radius: 12px;
  font-size: 14px; font-weight: 700; font-family: inherit;
  cursor: pointer;
  transition: transform .15s, box-shadow .2s;
  box-shadow: 0 4px 14px rgba(36,78,156,.30);
}
.cf-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(36,78,156,.40); }
.cf-btn:active { transform: scale(.97); }

/* ── Entry animation for modals ── */
@keyframes modalIn {
  from { opacity: 0; transform: scale(.94) translateY(16px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}


/* ================================================================
   NOVA PÁGINA DO MAPA — LAYOUT COMPLETO v6
   ================================================================ */

/* ── Wrapper da página ── */
/* ══ LAYOUT VISÃO GERAL ══ */
.dash-map-section {
  display: grid;
  grid-template-columns: 3fr 1fr;
  gap: 14px;
  align-items: stretch; /* estica ambas as colunas para a mesma altura */
}
.dash-map-col {
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.dash-map-col .map-card-fixed {
  flex: 1;
}

.dash-map-controls {
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.dash-map-controls .map-controls {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.dash-ctrl-col {
  height: calc(72vh + 54px);
  min-height: calc(400px + 54px);
  min-width: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.dash-ctrl-header {
  flex-shrink: 0;
  padding: 10px 16px 8px;
  border-bottom: 1px solid var(--border);
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  opacity: .45;
}

/* Área de scroll: contém os 3 cards empilhados */
.dash-ctrl-scroll {
  flex: 1 1 0;
  overflow-y: auto;
  min-height: 0;
  padding: 10px 8px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  scrollbar-width: thin;
  scrollbar-color: rgba(15,35,71,.15) transparent;
}
.dash-ctrl-scroll::-webkit-scrollbar { width: 5px; }
.dash-ctrl-scroll::-webkit-scrollbar-thumb {
  background: rgba(15,35,71,.15); border-radius: 999px;
}
html[data-theme="dark"] .dash-ctrl-scroll::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.18);
}

/* Cada card: ocupa a largura/altura do container e não colapsa */
.dash-ctrl-scroll .map-ctrl-card {
  flex-shrink: 0;
  width: 100%;
  height: auto;            /* cards empilhados no scroll */
  min-height: 110px;       /* evita "sumir" quando o conteúdo ainda vai renderizar */
  overflow: hidden;        /* mantém bordas arredondadas sem vazamento */
  transition: none !important;
  transform: none !important;
  cursor: default !important;
  background-clip: padding-box;
}

.dash-ctrl-scroll .map-ctrl-card:hover {
  transform: none !important;
  box-shadow: var(--shadow-soft) !important;
}

/* Lista de camadas ativas (card Categorias): altura livre */
.dash-ctrl-scroll #mapCard1 .map-active-list {
  max-height: 200px;
  overflow-y: auto;
}

/* Lista de layers (card Camadas): mostra tudo, scroll se muitas */
.dash-ctrl-scroll #mapCard2 .map-layers-list {
  max-height: 400px;
  overflow-y: auto;
}

/* Painel indicadores (card Indicadores): mostra tudo */
.dash-ctrl-scroll #mapCard3 .map-info-panel {
  max-height: 500px;
  overflow-y: auto;
}

/* Responsivo */
@media(max-width: 1100px){
  .dash-map-section { grid-template-columns: 1fr; }
  .dash-ctrl-col { height: 500px; }
}
@media(max-width: 640px){
  .dash-ctrl-col { height: 380px; }
}

.map-page {
  display: flex; flex-direction: column; gap: 20px;
}

/* ── MAP CARD: FIXO, SEM HOVER GROW ── */
.map-card-wrap .card,
.map-card-fixed {
  transition: none !important;
  transform: none !important;
  cursor: default !important;
  animation: none !important;
}
.map-card-fixed:hover {
  transform: none !important;
  box-shadow: none !important;
}
.map-card-fixed {
  border-radius: 20px;
  overflow: hidden;
  background: #244E9C !important;
  padding: 0 !important;
}
html[data-theme="light"] .map-card-fixed {
  background: #244E9C !important;
}

.map-card-top-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
}
.map-card-top-bar .card-title { font-size: 15px; font-weight: 700; color: #FFFFFF; }
.map-card-top-bar .card-sub   { font-size: 12px; color: rgba(255,255,255,.70); margin-top: 2px; }

.map-top-actions { display: flex; align-items: center; gap: 10px; }

/* Satellite toggle button */
.sat-toggle-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: 12px;
  border: 1.5px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color: #FFFFFF; font-family: inherit; font-size: 12px; font-weight: 700;
  cursor: pointer; backdrop-filter: blur(8px);
  transition: background .18s, border-color .18s, transform .15s, box-shadow .18s;
}
.sat-toggle-btn:hover {
  background: rgba(255,255,255,.20);
  border-color: rgba(255,255,255,.40);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(15,35,71,.20);
}
.sat-toggle-btn.active {
  background: rgba(56,190,239,.25);
  border-color: rgba(56,190,239,.60);
  color: #244E9C;
  box-shadow: 0 0 16px rgba(56,190,239,.25);
}
.sat-icon { display: flex; align-items: center; }

/* Fullscreen button */
.map-fullscreen-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 12px;
  border: 1.5px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.10);
  color: rgba(255,255,255,.85); font-family: inherit; font-size: 12px; font-weight: 600;
  cursor: pointer;
  transition: background .18s, transform .15s;
}
.map-fullscreen-btn:hover {
  background: rgba(255,255,255,.18);
  transform: translateY(-1px);
}

/* iframe wrap */
.map-frame-wrap {
  position: relative;
  height: 72vh; min-height: 400px;
}
.map-frame-wrap iframe {
  width: 100%; height: 100%; border: 0; display: block;
}

/* Floating satellite chip */
.sat-status-chip {
  position: absolute; bottom: 14px; left: 14px;
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(56,190,239,.22);
  border: 1px solid rgba(56,190,239,.50);
  color: #244E9C; font-size: 12px; font-weight: 700;
  backdrop-filter: blur(8px);
  animation: fadeSlideIn .2s ease;
}

/* ── 3-COLUMN CONTROLS ── */
.map-controls {
  display: grid;
  grid-template-columns: 260px 1fr 1fr;
  gap: 16px;
  align-items: stretch;
  height: 100%;
}

/* Ctrl cards */
.map-ctrl-card {
  border-radius: 18px; padding: 0;
  overflow: hidden; display: flex; flex-direction: column;
  height: 100%;
  transition: none !important;
  transform: none !important;
  cursor: default !important;
  box-shadow: none !important;
}
.map-ctrl-card:hover {
  transform: none !important;
  box-shadow: none !important;
}

.map-ctrl-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
html[data-theme="light"] .map-ctrl-header { border-bottom-color: rgba(36,78,156,.07); }

.map-ctrl-icon {
  width: 36px; height: 36px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 auto;
}
.cat-icon    { background: rgba(56,190,239,.15); color: #244E9C; }
.layers-icon { background: rgba(36,78,156,.15); color: #244E9C; }
.info-icon   { background: rgba(71,171,52,.15);  color: #47AB34; }
html[data-theme="light"] .cat-icon    { background: rgba(36,78,156,.10); color: var(--pm-accent,#244E9C); }
html[data-theme="light"] .layers-icon { background: rgba(36,78,156,.10); color: #244E9C; }
html[data-theme="light"] .info-icon   { background: rgba(0,94,52,.10);  color: #005E34; }

.map-ctrl-title { font-weight: 800; font-size: 14px; }
.map-ctrl-sub   { font-size: 11px; opacity: .65; margin-top: 2px; }
html[data-theme="dark"]  .map-ctrl-title { color: #FFFFFF; }
html[data-theme="light"] .map-ctrl-title { color: #244E9C; }

.map-ctrl-divider { height: 1px; margin: 4px 18px; background: rgba(255,255,255,.08); }
html[data-theme="light"] .map-ctrl-divider { background: rgba(36,78,156,.07); }

.map-ctrl-section-title {
  font-size: 9px; font-weight: 800; text-transform: uppercase;
  letter-spacing: .08em; opacity: .55;
  padding: 10px 18px 6px;
}

/* ── Category Chips ── */
.map-chips {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 12px 14px 4px;
}
.map-cat-chip {
  padding: 6px 14px; border-radius: 999px;
  font-size: 11px; font-weight: 700;
  border: 1.5px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.80);
  cursor: pointer; font-family: inherit;
  transition: background .15s, border-color .15s, transform .12s, color .15s;
}
.map-cat-chip:hover {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.30);
  transform: translateY(-1px);
  color: #FFFFFF;
}
.map-cat-chip.on {
  background: #244E9C;
  border-color: transparent; color: #FFFFFF;
  box-shadow: 0 4px 12px rgba(36,78,156,.30);
}
html[data-theme="light"] .map-cat-chip {
  background: #F1F5F9; border-color: rgba(36,78,156,.14); color: #244E9C;
}
html[data-theme="light"] .map-cat-chip:hover {
  background: #244E9C; color: #244E9C;
}
html[data-theme="light"] .map-cat-chip.on {
  background: #244E9C;
  color: #FFFFFF; border-color: transparent;
}

/* ── Active Layers List (card 1 bottom) ── */
.map-active-list { padding: 0 10px 8px; display: flex; flex-direction: column; gap: 5px; flex: 1; overflow-y: auto; min-height: 0; max-height: 180px; }
.map-active-empty {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 8px; font-size: 12px; opacity: .50;
}
.map-active-chip {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 10px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.10);
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.map-active-chip:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.20); }
html[data-theme="light"] .map-active-chip { background: rgba(36,78,156,.06); border-color: rgba(36,78,156,.12); }
html[data-theme="light"] .map-active-chip:hover { background: rgba(36,78,156,.12); }
.mac-dot {
  width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto;
  background: #244E9C;
  box-shadow: 0 0 6px rgba(56,190,239,.50);
}
html[data-theme="light"] .mac-dot { background: var(--pm-accent,#244E9C); box-shadow: none; }
.mac-label { flex: 1; font-size: 12px; font-weight: 600; color: rgba(255,255,255,.90); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
html[data-theme="light"] .mac-label { color: #244E9C; }
.mac-remove {
  background: rgba(255,255,255,.10); border: none; border-radius: 6px;
  padding: 3px; cursor: pointer; color: rgba(255,255,255,.60);
  transition: background .15s, color .15s;
  display: flex; align-items: center;
}
.mac-remove:hover { background: rgba(233,86,30,.25); color: #244E9C; }
html[data-theme="light"] .mac-remove { background: rgba(36,78,156,.08); color: rgba(36,78,156,.50); }

/* ── Card 1 bottom actions ── */
.map-ctrl-bottom { display: flex; gap: 8px; padding: 10px 14px 14px; margin-top: auto; }
.map-action-btn {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 10px; border-radius: 10px; border: none;
  font-family: inherit; font-size: 12px; font-weight: 700;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s, background .15s;
}
.map-action-btn.primary {
  background: #244E9C;
  color: #FFFFFF; box-shadow: 0 3px 10px rgba(36,78,156,.25);
}
.map-action-btn.primary:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(36,78,156,.35); }
.map-action-btn.danger {
  background: rgba(233,86,30,.12); color: #244E9C;
  border: 1px solid rgba(233,86,30,.22);
}
.map-action-btn.danger:hover { background: rgba(233,86,30,.20); transform: translateY(-1px); }
html[data-theme="light"] .map-action-btn.danger { background: rgba(233,86,30,.06); color: #244E9C; border-color: rgba(233,86,30,.15); }
html[data-theme="light"] .map-action-btn.danger:hover { background: rgba(233,86,30,.12); }

/* ── Card 2: Layer rows ── */
.map-layers-list { padding: 8px 12px; display: flex; flex-direction: column; gap: 6px; flex: 1; overflow-y: auto; min-height: 0; }
.map-layer-empty {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 32px 16px; text-align: center; opacity: .50;
}
.map-layer-empty p { font-size: 13px; font-weight: 600; }
.map-layer-empty small { font-size: 11px; }
.map-layer-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 12px;
  border: 1.5px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .12s;
}
.map-layer-row:hover {
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.16);
  transform: translateX(2px);
}
.map-layer-row.focused {
  border-color: rgba(56,190,239,.40);
  background: rgba(56,190,239,.08);
}
html[data-theme="light"] .map-layer-row {
  background: #F8FAFC; border-color: rgba(36,78,156,.10);
}
html[data-theme="light"] .map-layer-row:hover {
  background: #F1F5F9; border-color: rgba(36,78,156,.20);
}
html[data-theme="light"] .map-layer-row.focused {
  border-color: rgba(36,78,156,.35); background: rgba(36,78,156,.06);
}
.mlr-left { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.mlr-status-dot {
  width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto;
  transition: background .18s;
}
.mlr-status-dot.vis { background: #244E9C; box-shadow: 0 0 7px rgba(56,190,239,.50); }
.mlr-status-dot.hid { background: rgba(255,255,255,.22); }
html[data-theme="light"] .mlr-status-dot.vis { background: var(--pm-accent,#244E9C); box-shadow: none; }
html[data-theme="light"] .mlr-status-dot.hid { background: #EFF6FF; }
.mlr-title { font-size: 12px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mlr-sub   { font-size: 11px; opacity: .55; margin-top: 1px; }
html[data-theme="dark"]  .mlr-title { color: #FFFFFF; }
html[data-theme="light"] .mlr-title { color: #244E9C; }

/* ── Custom toggle switch (card 2) ── */
.map-toggle { position: relative; display: inline-block; width: 38px; height: 22px; flex: 0 0 auto; cursor: pointer; }
.map-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.map-toggle-track {
  position: absolute; inset: 0;
  background: rgba(255,255,255,.15);
  border-radius: 999px; border: 1.5px solid rgba(255,255,255,.20);
  transition: background .2s, border-color .2s;
}
.map-toggle input:checked ~ .map-toggle-track {
  background: #244E9C;
  border-color: transparent;
}
html[data-theme="light"] .map-toggle-track { background: #244E9C; border-color: rgba(36,78,156,.20); }
html[data-theme="light"] .map-toggle input:checked ~ .map-toggle-track {
  background: #244E9C;
}
.map-toggle-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: rgba(255,255,255,.60); transition: transform .2s, background .2s;
}
html[data-theme="light"] .map-toggle-thumb { background: #244E9C; }
.map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb {
  transform: translateX(16px); background: #FFFFFF;
}

/* ── Card 3: Info / Indicators ── */
.map-info-panel { flex: 1; overflow-y: auto; min-height: 0; padding: 8px 14px 14px; }

.map-info-empty {
  display: flex; flex-direction: column; align-items: center;
  gap: 12px; padding: 24px 18px; text-align: center;
  border: 1px solid rgba(36,78,156,.14);
  border-radius: 22px;
  background: #244E9C;
  opacity: 1;
}
.map-info-empty h4 { font-size: 14px; font-weight: 700; }
.map-info-empty p  { font-size: 12px; line-height: 1.5; }

/* Summary cards (multiple layers active) */
.map-info-summary { display: flex; flex-direction: column; gap: 8px; }
.mis-card {
  padding: 14px 16px; border-radius: 18px;
  border: 1px solid rgba(36,78,156,.14);
  background: #FFFFFF;
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .12s, box-shadow .18s;
}
.mis-card:hover {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.24);
  box-shadow: 0 14px 28px rgba(36,78,156,.10);
  transform: translateY(-1px);
}
html[data-theme="light"] .mis-card { background: #F8FAFC; border-color: rgba(36,78,156,.10); }
html[data-theme="light"] .mis-card:hover { background: #F1F5F9; border-color: rgba(36,78,156,.22); }
.mis-header { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px; }
.mis-title { font-size: 12px; font-weight: 700; flex: 1; }
html[data-theme="dark"]  .mis-title { color: #FFFFFF; }
html[data-theme="light"] .mis-title { color: #244E9C; }
.mis-count-badge {
  padding: 2px 9px; border-radius: 999px; font-size: 11px; font-weight: 800;
  background: rgba(56,190,239,.18); color: #244E9C;
  border: 1px solid rgba(56,190,239,.30);
}
html[data-theme="light"] .mis-count-badge { background: rgba(36,78,156,.10); color: var(--pm-accent,#244E9C); border-color: rgba(36,78,156,.20); }
.mis-legend { display: flex; flex-direction: column; gap: 3px; }
.mis-leg-row { display: flex; align-items: center; gap: 6px; font-size: 11px; opacity: .75; }
.mis-leg-more { font-size: 11px; opacity: .45; margin-top: 3px; }
.mis-no-legend { font-size: 11px; opacity: .50; }

/* Detail view */
.map-info-detail { display: flex; flex-direction: column; gap: 12px; }
.mid-title-bar { display: flex; align-items: center; gap: 10px; }
.mid-back {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 10px; border-radius: 8px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.75); font-size: 11px; font-weight: 600; font-family: inherit;
  cursor: pointer; transition: background .15s;
}
.mid-back:hover { background: rgba(255,255,255,.14); color: #FFFFFF; }
html[data-theme="light"] .mid-back { background: rgba(36,78,156,.07); border-color: rgba(36,78,156,.12); color: #244E9C; }
html[data-theme="light"] .mid-back:hover { background: rgba(36,78,156,.12); color: #244E9C; }
.mid-name { font-size: 13px; font-weight: 800; flex: 1; }
html[data-theme="dark"]  .mid-name { color: #FFFFFF; }
html[data-theme="light"] .mid-name { color: #244E9C; }

.mid-status-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.mid-status-pill {
  padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 700;
}
.mid-status-pill.vis { background: rgba(56,190,239,.15); color: #244E9C; border: 1px solid rgba(56,190,239,.30); }
.mid-status-pill.hid { background: rgba(255,255,255,.08); color: rgba(255,255,255,.55); border: 1px solid rgba(255,255,255,.12); }
html[data-theme="light"] .mid-status-pill.vis { background: rgba(36,78,156,.10); color: var(--pm-accent,#244E9C); border-color: rgba(36,78,156,.22); }
html[data-theme="light"] .mid-status-pill.hid { background: #F1F5F9; color: #244E9C; border-color: #244E9C; }
.mid-count-pill {
  display: flex; align-items: center; gap: 4px;
  padding: 4px 12px; border-radius: 999px; font-size: 12px; font-weight: 700;
  background: rgba(71,171,52,.12); color: #47AB34;
  border: 1px solid rgba(71,171,52,.28);
}
html[data-theme="light"] .mid-count-pill { background: rgba(0,94,52,.08); color: #005E34; border-color: rgba(0,94,52,.20); }

.mid-kpi-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.mid-kpi {
  padding: 14px 14px 12px; border-radius: 14px;
  background: rgba(255,255,255,.06); border: 1.5px solid rgba(255,255,255,.10);
  text-align: center;
}
html[data-theme="light"] .mid-kpi { background: #F8FAFC; border-color: rgba(36,78,156,.10); }
.mid-kpi-val   { font-size: 22px; font-weight: 800; color: #244E9C; }
html[data-theme="light"] .mid-kpi-val { color: var(--pm-accent,#244E9C); }
.mid-kpi-label { font-size: 11px; opacity: .55; margin-top: 2px; }

.mid-section-title { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; opacity: .50; margin-top: 4px; }
.mid-legend-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 4px; }
.mid-leg-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 10px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
  font-size: 11px; font-weight: 600;
}
html[data-theme="light"] .mid-leg-item { background: #F8FAFC; border-color: rgba(36,78,156,.10); color: #244E9C; }
.mid-leg-item img { border-radius: 4px; }
.mid-no-indicators {
  display: flex; align-items: center; gap: 10px;
  padding: 14px; border-radius: 12px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  opacity: .55; font-size: 12px;
}
html[data-theme="light"] .mid-no-indicators { background: #F8FAFC; border-color: rgba(36,78,156,.08); }

/* ── Responsive: stack on small screens ── */
@media (max-width: 1024px) {
  .map-controls { grid-template-columns: 1fr 1fr; }
  #mapCard3 { grid-column: span 2; }
}
@media (max-width: 700px) {
  .map-controls { grid-template-columns: 1fr; }
  #mapCard3 { grid-column: span 1; }
}

/* map card lock moved to FINAL FIX section */


/* ================================================================
   USER MANAGEMENT MODAL — v7
   ================================================================ */
.pm-modal-wide { max-width: 860px; }
.um-layout {
  display: grid;
  grid-template-columns: 230px 1fr;
  gap: 0;
  padding: 0 !important;
  min-height: 560px;
  max-height: 78vh;
}

/* ── Left: user list ── */
.um-list-panel {
  border-right: 1px solid rgba(255,255,255,.08);
  display: flex; flex-direction: column;
  overflow: hidden;
  min-height: 0;
}
html[data-theme="light"] .um-list-panel { border-right-color: rgba(36,78,156,.08); }

.um-list-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 16px 10px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
html[data-theme="light"] .um-list-header { border-bottom-color: rgba(36,78,156,.06); }
.um-panel-title { font-weight: 800; font-size: 13px; }
html[data-theme="dark"]  .um-panel-title { color: #FFFFFF; }
html[data-theme="light"] .um-panel-title { color: #244E9C; }

.um-list-filter {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  color: rgba(255,255,255,.72);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  user-select: none;
}
.um-list-filter input {
  width: 14px;
  height: 14px;
  accent-color: #244E9C;
  cursor: pointer;
}
html[data-theme="light"] .um-list-filter {
  border-bottom-color: rgba(36,78,156,.06);
  color: #244E9C;
}

.um-add-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 8px;
  border: 1.5px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.85); font-size: 12px; font-weight: 700; font-family: inherit;
  cursor: pointer;
  transition: background .15s, transform .12s;
}
.um-add-btn:hover { background: rgba(255,255,255,.15); transform: translateY(-1px); }
html[data-theme="light"] .um-add-btn {
  border-color: rgba(36,78,156,.20); background: rgba(36,78,156,.08); color: var(--pm-accent,#244E9C);
}
html[data-theme="light"] .um-add-btn:hover { background: rgba(36,78,156,.14); }

.um-user-list {
  flex: 1;
  min-height: 0;
  max-height: calc(78vh - 112px);
  overflow-y: auto;
  padding: 6px 8px;
  scrollbar-gutter: stable;
}
.um-user-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 10px; border-radius: 12px;
  cursor: pointer; transition: background .15s;
}
.um-user-item:hover { background: rgba(255,255,255,.06); }
.um-user-item.selected { background: rgba(56,190,239,.10); border: 1px solid rgba(56,190,239,.25); }
.um-user-item.me .um-user-name::after { content: " •"; color: #244E9C; }
html[data-theme="light"] .um-user-item:hover { background: rgba(36,78,156,.05); }
html[data-theme="light"] .um-user-item.selected { background: rgba(36,78,156,.08); border-color: rgba(36,78,156,.25); }
html[data-theme="light"] .um-user-item.me .um-user-name::after { color: var(--pm-accent,#244E9C); }

.um-user-av {
  width: 36px; height: 36px; border-radius: 50%; flex: 0 0 auto;
  background: #38BEEF;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 15px; color: #FFFFFF; overflow: hidden;
}
html[data-theme="light"] .um-user-av { background: #244E9C; }
.um-user-info { flex: 1; min-width: 0; }
.um-user-name { font-weight: 700; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
html[data-theme="dark"]  .um-user-name { color: #FFFFFF; }
html[data-theme="light"] .um-user-name { color: #244E9C; }
.um-user-meta { font-size: 11px; opacity: .55; margin-top: 1px; }
.um-user-arrow { opacity: .35; flex: 0 0 auto; }

/* ── Right: form ── */
.um-form-panel { overflow-y: auto; padding: 20px; display: flex; flex-direction: column; }
.um-form-placeholder {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; text-align: center; opacity: .40;
}
.um-form-placeholder p { font-size: 13px; }

/* Avatar */
.um-avatar-row { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.um-avatar-preview {
  width: 62px; height: 62px; border-radius: 50%;
  background: #38BEEF;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 800; color: #FFFFFF; overflow: hidden;
  flex: 0 0 auto;
}
html[data-theme="light"] .um-avatar-preview { background: #244E9C; }
.um-avatar-actions { display: flex; flex-direction: column; gap: 7px; }
.um-photo-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 14px; border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.85); font-size: 12px; font-weight: 700;
  cursor: pointer; transition: background .15s;
}
.um-photo-btn:hover { background: rgba(255,255,255,.14); }
html[data-theme="light"] .um-photo-btn {
  border-color: rgba(36,78,156,.20); background: rgba(36,78,156,.07); color: var(--pm-accent,#244E9C);
}
.um-photo-remove {
  background: none; border: none; font-size: 11px; opacity: .50; cursor: pointer;
  font-family: inherit; color: inherit; text-align: left; padding: 0;
  transition: opacity .15s;
}
.um-photo-remove:hover { opacity: .80; }

/* Section titles */
.um-section-title {
  font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
  opacity: .50; margin: 16px 0 8px;
  display: flex; align-items: center; gap: 8px;
}
.um-select-all {
  background: none; border: 1px solid rgba(255,255,255,.18); border-radius: 6px;
  padding: 2px 8px; font-size: 10px; font-weight: 700; font-family: inherit;
  color: rgba(255,255,255,.65); cursor: pointer; transition: background .15s;
}
.um-select-all:hover { background: rgba(255,255,255,.08); color: #FFFFFF; }
html[data-theme="light"] .um-select-all { border-color: rgba(36,78,156,.20); color: rgba(36,78,156,.60); }
html[data-theme="light"] .um-select-all:hover { background: rgba(36,78,156,.08); color: var(--pm-accent,#244E9C); }

/* Form grid */
.um-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.um-field { display: flex; flex-direction: column; gap: 5px; }
.um-field label { font-size: 11px; font-weight: 600; opacity: .55; }
.um-input {
  padding: 9px 12px; border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: #FFFFFF; font-size: 13px; font-family: inherit; outline: none;
  transition: border-color .18s, background .18s;
}
.um-input:focus { border-color: rgba(56,190,239,.45); background: rgba(255,255,255,.09); }
html[data-theme="light"] .um-input { background: #F8FAFC; border-color: rgba(36,78,156,.14); color: #244E9C; }
html[data-theme="light"] .um-input:focus { border-color: var(--pm-accent,#244E9C); background: #FFFFFF; box-shadow: 0 0 0 3px rgba(36,78,156,.08); }

/* Role cards */
.um-role-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.um-role-card {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 12px 8px; border-radius: 14px;
  border: 1.5px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  cursor: pointer; transition: border-color .15s, background .15s, transform .12s;
}
.um-role-card:hover { background: rgba(255,255,255,.08); transform: translateY(-1px); }
.um-role-card.selected, .um-role-card input:checked ~ * {
  border-color: rgba(56,190,239,.50) !important;
  background: rgba(56,190,239,.10) !important;
}
html[data-theme="light"] .um-role-card { background: #F8FAFC; border-color: rgba(36,78,156,.10); }
html[data-theme="light"] .um-role-card:hover { background: #F1F5F9; }
html[data-theme="light"] .um-role-card.selected { border-color: var(--pm-accent,#244E9C) !important; background: rgba(36,78,156,.08) !important; }
.um-role-card input { position: absolute; opacity: 0; pointer-events: none; }
.um-role-icon { font-size: 22px; }
.um-role-name { font-weight: 800; font-size: 12px; }
html[data-theme="dark"]  .um-role-name { color: #FFFFFF; }
html[data-theme="light"] .um-role-name { color: #244E9C; }
.um-role-desc { font-size: 10px; opacity: .55; text-align: center; line-height: 1.3; }

/* Permissions toggles */
.um-perms-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.um-perm-toggle {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 12px; border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  cursor: default;
}
html[data-theme="light"] .um-perm-toggle { background: #F8FAFC; border-color: rgba(36,78,156,.08); }
.um-perm-name { font-weight: 700; font-size: 12px; }
html[data-theme="dark"]  .um-perm-name { color: #FFFFFF; }
html[data-theme="light"] .um-perm-name { color: #244E9C; }
.um-perm-desc { font-size: 10px; opacity: .50; margin-top: 1px; }

/* Secretarias grid */
.um-sec-grid { display: flex; flex-wrap: wrap; gap: 6px; }
.um-sec-item {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  cursor: pointer; font-size: 12px; font-weight: 700;
  transition: background .15s, border-color .15s;
}
.um-sec-item:hover { background: rgba(255,255,255,.10); }
.um-sec-item input:checked ~ span { color: #244E9C; }
.um-sec-item input:checked + span { color: #244E9C; }
.um-sec-item:has(input:checked) { border-color: rgba(56,190,239,.40); background: rgba(56,190,239,.10); }
html[data-theme="light"] .um-sec-item { background: #F1F5F9; border-color: rgba(36,78,156,.12); color: #244E9C; }
html[data-theme="light"] .um-sec-item:has(input:checked) { border-color: var(--pm-accent,#244E9C); background: rgba(36,78,156,.10); color: var(--pm-accent,#244E9C); }
.um-sec-cb { position: absolute; opacity: 0; pointer-events: none; }

/* Form error & actions */

.um-form-help {
  margin-top: 10px;
  color: rgba(255,255,255,.62);
  font-size: 11px;
  line-height: 1.45;
}
html[data-theme="light"] .um-form-help { color: #244E9C; }
.um-input[type="email"], .um-input[type="password"], .um-input[type="text"], .um-input select, select.um-input {
  appearance: none;
}
.um-user-status {
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:11px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.72);
  margin-top:6px;
  width: fit-content;
}
.um-user-status.is-inactive {
  border-color: rgba(233,86,30,.28);
  background: rgba(233,86,30,.10);
  color: #244E9C;
}
html[data-theme="light"] .um-user-status {
  border-color: rgba(36,78,156,.10);
  background: #EEF2FF;
  color: #244E9C;
}
html[data-theme="light"] .um-user-status.is-inactive {
  border-color: rgba(233,86,30,.18);
  background: rgba(254,226,226,.95);
  color: #E9561E;
}
.um-form-error { font-size: 12px; color: #244E9C; min-height: 18px; margin-top: 8px; font-weight: 500; }
.um-form-actions { display: flex; gap: 8px; align-items: center; margin-top: 16px; border-top: 1px solid rgba(255,255,255,.08); padding-top: 14px; }
html[data-theme="light"] .um-form-actions { border-top-color: rgba(36,78,156,.08); }
.um-delete-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 9px 14px; border-radius: 10px; border: none;
  background: rgba(233,86,30,.12); color: #244E9C;
  font-size: 11px; font-weight: 700; font-family: inherit; cursor: pointer;
  border: 1px solid rgba(233,86,30,.22);
  transition: background .15s, transform .12s;
}
.um-delete-btn:hover { background: rgba(233,86,30,.22); transform: translateY(-1px); }
html[data-theme="light"] .um-delete-btn { background: rgba(233,86,30,.06); color: #244E9C; border-color: rgba(233,86,30,.15); }
.um-cancel-btn {
  padding: 9px 16px; border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.80); font-size: 13px; font-weight: 600; font-family: inherit;
  cursor: pointer; transition: background .15s;
}
.um-cancel-btn:hover { background: rgba(255,255,255,.10); }
html[data-theme="light"] .um-cancel-btn { background: #F1F5F9; border-color: rgba(36,78,156,.14); color: #244E9C; }
.um-save-btn {
  display: flex; align-items: center; gap: 7px; margin-left: auto;
  padding: 9px 20px; border-radius: 10px; border: none;
  background: #244E9C;
  color: #FFFFFF; font-size: 13px; font-weight: 700; font-family: inherit;
  cursor: pointer; box-shadow: 0 3px 12px rgba(36,78,156,.28);
  transition: transform .15s, box-shadow .18s;
}
.um-save-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(36,78,156,.38); }

/* ── Photo preview modal ── */
.photo-preview-wrap {
  position: relative; width: 120px; height: 120px;
  margin: 0 auto 8px; border-radius: 50%; overflow: hidden;
  cursor: pointer;
}
.photo-preview-avatar {
  width: 100%; height: 100%;
  background: #38BEEF;
  display: flex; align-items: center; justify-content: center;
  font-size: 46px; font-weight: 800; color: #FFFFFF;
}
html[data-theme="light"] .photo-preview-avatar { background: #244E9C; }
.photo-preview-overlay {
  position: absolute; inset: 0;
  background: rgba(15,35,71,.45);
  display: flex; align-items: center; justify-content: center;
  color: #FFFFFF; font-size: 11px; text-align: center; line-height: 1.4;
  opacity: 0; transition: opacity .2s;
}
.photo-preview-wrap:hover .photo-preview-overlay { opacity: 1; }

/* ── Toast notification ── */
.pm-toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(12px);
  background: #244E9C; color: #FFFFFF;
  padding: 10px 22px; border-radius: 12px;
  font-size: 13px; font-weight: 600;
  box-shadow: 0 8px 24px rgba(15,35,71,.30);
  opacity: 0; pointer-events: none;
  transition: opacity .25s, transform .25s;
  z-index: 9999; white-space: nowrap;
}
.pm-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
html[data-theme="light"] .pm-toast { background: #244E9C; }

/* ================================================================
   MAP LAYOUT — FINAL FIX v7
   ================================================================ */

/* Controls grid: equal height columns */
.map-controls {
  grid-template-columns: 240px 1fr 1fr !important;
  align-items: stretch !important;
  min-height: 0 !important;
}

/* Ctrl cards: base flex — altura controlada pelo container de scroll */
.map-ctrl-card {
  display: flex;
  flex-direction: column;
  overflow: visible;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

/* Internal scroll areas */
.map-active-list {
  flex: 0 0 auto !important;
  overflow-y: auto !important;
  min-height: 60px !important;
  max-height: 140px !important;
}
.map-layers-list {
  flex: 1 1 0 !important;
  overflow-y: auto !important;
  min-height: 0 !important;
}
.map-info-panel {
  flex: 1 1 0 !important;
  overflow-y: auto !important;
  min-height: 0 !important;
}

/* ONLY the blue map card (iframe card) freezes on hover */
.map-card-fixed,
.map-card-wrap > .card,
.map-card-fixed:hover,
.map-card-wrap > .card:hover {
  transform: none !important;
  box-shadow: none !important;
  transition: color .18s ease, border-color .18s ease !important;
  cursor: default !important;
  z-index: auto !important;
}

/* Flex helpers */
.map-ctrl-bottom    { margin-top: auto !important; flex-shrink: 0 !important; }
.map-ctrl-header    { flex-shrink: 0 !important; }
.map-chips          { flex-shrink: 0 !important; }
.map-ctrl-divider   { flex-shrink: 0 !important; }
.map-ctrl-section-title { flex-shrink: 0 !important; }


/* ================================================================
   v7 FINAL FIXES
   ================================================================ */

/* ── Confirm dialog ── */
.pm-confirm-backdrop {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(15,35,71,.55); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; pointer-events: none;
  transition: opacity .22s ease;
}
.pm-confirm-backdrop.open {
  opacity: 1; pointer-events: auto;
}
.pm-confirm-card {
  background: var(--surface, #244E9C);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 22px;
  padding: 32px 28px 24px;
  max-width: 380px; width: 100%;
  text-align: center;
  box-shadow: 0 32px 80px rgba(15,35,71,.50);
  transform: scale(.94) translateY(16px);
  transition: transform .28s cubic-bezier(.34,1.56,.64,1);
}
.pm-confirm-backdrop.open .pm-confirm-card { transform: scale(1) translateY(0); }
html[data-theme="light"] .pm-confirm-card {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.12);
  box-shadow: 0 24px 60px rgba(36,78,156,.22);
}
.pm-confirm-icon  { font-size: 36px; margin-bottom: 10px; }
.pm-confirm-title {
  font-weight: 800; font-size: 18px; margin-bottom: 8px;
  color: #FFFFFF;
}
html[data-theme="light"] .pm-confirm-title { color: #244E9C; }
.pm-confirm-msg   { font-size: 13px; line-height: 1.6; opacity: .70; margin-bottom: 24px; }
.pm-confirm-actions { display: flex; gap: 10px; justify-content: center; }
.pm-confirm-cancel {
  padding: 10px 20px; border-radius: 11px;
  border: 1.5px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.80); font-family: inherit; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: background .15s;
}
.pm-confirm-cancel:hover { background: rgba(255,255,255,.14); }
html[data-theme="light"] .pm-confirm-cancel {
  border-color: rgba(36,78,156,.18); background: #F1F5F9; color: #244E9C;
}
html[data-theme="light"] .pm-confirm-cancel:hover { background: #244E9C; }
.pm-confirm-ok {
  padding: 10px 22px; border-radius: 11px; border: none;
  background: #E9561E;
  color: #FFFFFF; font-family: inherit; font-size: 13px; font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(15,35,71,.22);
  transition: transform .14s, box-shadow .18s;
}
.pm-confirm-ok:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(15,35,71,.30); }

/* ── User Management Modal: scrollable form panel ── */
.um-layout {
  min-height: 0 !important;
  max-height: 78vh !important;
  overflow: hidden !important;
}
.um-list-panel {
  overflow: hidden !important;
  min-height: 0 !important;
}
.um-user-list {
  overflow-y: auto !important;
  min-height: 0 !important;
}
.um-form-panel {
  overflow-y: auto !important;
  max-height: 78vh !important;
  padding-bottom: 24px !important;
}

/* ── Ctrl cards (below map): restore hover grow, just freeze MAP card ── */
#mapCard1, #mapCard2, #mapCard3 {
  cursor: default !important;
  transform: none !important;        /* reset baseline */
  transition: transform .22s cubic-bezier(.34,1.56,.64,1),
              box-shadow .22s ease,
              border-color .18s ease !important;
}
/* They DO get hover grow now (via base .card:hover) */
/* The blue map iframe card NEVER grows */
.map-card-fixed,
.map-card-wrap > .card,
.map-card-fixed:hover,
.map-card-wrap > .card:hover {
  transform: none !important;
  box-shadow: none !important;
  cursor: default !important;
}


/* ================================================================
   SECRETARIA PAGE — Mini Map Card + Header Strip  (v8 final)
   ================================================================ */

.sec-page {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 4px 0;
  animation: fadeSlideIn .22s ease both;
}

/* ── Header strip ── */
.sec-header-strip {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 22px;
  border-radius: 18px;
  background: #244E9C;
  color: #FFFFFF;
  box-shadow: 0 6px 24px rgba(36,78,156,.25);
}
.sec-header-icon {
  width: 48px; height: 48px; border-radius: 14px;
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.22);
  display: flex; align-items: center; justify-content: center;
  flex: 0 0 auto;
  font-size: 20px;
}
.sec-header-icon .icon { color: #FFFFFF; }
.sec-header-title { font-weight: 800; font-size: 18px; line-height: 1.2; }
.sec-header-sub   { font-size: 12px; opacity: .72; margin-top: 3px; }

/* ── Mini map card ── */
.sec-map-card {
  border-radius: 20px;
  overflow: hidden;
  border: 1.5px solid rgba(255,255,255,.10);
  background: var(--surface, #244E9C);
  box-shadow: 0 4px 20px rgba(15,35,71,.18);
  transition: transform .22s cubic-bezier(.34,1.56,.64,1),
              box-shadow .22s ease;
}
.sec-map-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(15,35,71,.28);
}
html[data-theme="light"] .sec-map-card {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.10);
  box-shadow: 0 4px 20px rgba(36,78,156,.10);
}
html[data-theme="light"] .sec-map-card:hover {
  box-shadow: 0 12px 40px rgba(36,78,156,.18);
}

.sec-map-card-top {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
html[data-theme="light"] .sec-map-card-top { border-bottom-color: rgba(36,78,156,.08); }

.sec-map-card-title {
  display: flex; align-items: center; gap: 8px;
  font-weight: 800; font-size: 14px;
}
html[data-theme="dark"]  .sec-map-card-title { color: #FFFFFF; }
html[data-theme="light"] .sec-map-card-title { color: #244E9C; }
.sec-map-card-title svg { opacity: .75; }

.sec-map-card-sub { font-size: 12px; opacity: .60; margin-top: 3px; }

.sec-map-open-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 9px 18px; border-radius: 11px; border: none;
  background: #244E9C;
  color: #FFFFFF; font-family: inherit; font-size: 12px; font-weight: 700;
  cursor: pointer;
  box-shadow: 0 3px 12px rgba(36,78,156,.28);
  transition: transform .15s, box-shadow .18s, filter .15s;
  white-space: nowrap;
}
.sec-map-open-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(36,78,156,.38);
}
.sec-map-open-btn:active { transform: scale(.97); }

/* ── Map preview area ── */
.sec-map-preview {
  position: relative;
  height: 340px;
  cursor: pointer;
  overflow: hidden;
}
.sec-map-preview:hover .sec-map-overlay {
  opacity: 1;
}

/* The actual mini iframe (non-interactive, just visual) */
.sec-map-iframe {
  width: 100%; height: 100%; border: 0;
  display: block;
  pointer-events: none; /* clicks go to overlay */
  transform-origin: top left;
}

/* Semi-transparent overlay with call to action */
.sec-map-overlay {
  position: absolute; inset: 0; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  background: rgba(36,78,156,.52);
  backdrop-filter: blur(3px);
  opacity: 0;
  transition: opacity .25s ease;
}
.sec-map-overlay-content {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px; text-align: center; color: #FFFFFF;
}
.sec-map-overlay-icon {
  width: 64px; height: 64px; border-radius: 18px;
  background: rgba(255,255,255,.14);
  border: 1.5px solid rgba(255,255,255,.25);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 2px;
}
.sec-map-overlay-title { font-weight: 800; font-size: 18px; }
.sec-map-overlay-sub   { font-size: 13px; opacity: .75; }
.sec-map-overlay-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 22px; border-radius: 12px; border: none;
  background: #244E9C;
  color: #FFFFFF; font-family: inherit; font-size: 13px; font-weight: 700;
  cursor: pointer; margin-top: 4px;
  box-shadow: 0 4px 16px rgba(15,35,71,.30);
  transition: transform .14s, box-shadow .18s;
}
.sec-map-overlay-btn:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 8px 22px rgba(15,35,71,.38);
}
/* FIX: evitar painel abrir "vazio" visualmente (altura 0) */
#mapCard2 .map-layers-list,
#mapCard3 .map-info-panel{
  min-height: 120px;
}

/* FIX: alinhamento das bordas do container lateral (evita pontinhos/serrilhado) */
.dash-ctrl-col{
  background-clip: padding-box;
}
.dash-ctrl-scroll{
  background: var(--surface);
  scrollbar-gutter: stable both-edges;
}

/* Deixa o canto inferior direito limpo mesmo com scrollbar */
.dash-ctrl-col,
.dash-ctrl-scroll{
  border-radius: 20px;
}
.dash-ctrl-scroll{
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}



/* === v4 FIX: Camadas/Indicadores não podem colapsar quando vazios === */
#mapLayersList,
#mapInfoPanel{
  min-height: 140px;
}

/* Placeholder skeleton (quando mapa ainda está inicializando) */
.panel-placeholder{
  padding: 10px 10px 12px;
  display: grid;
  gap: 10px;
}
.panel-placeholder .ph-line{
  height: 12px;
  border-radius: 999px;
  background: rgba(36,78,156,.08);
}
.panel-placeholder .ph-line.short{
  width: 65%;
}

/* === v4 FIX: alinhamentos/cantos do painel lateral === */
.dash-ctrl-col{
  overflow: hidden; /* evita "pontinho" no canto por clipping/scroll */
  border-radius: var(--radius);
}
.dash-ctrl-scroll{
  scrollbar-gutter: stable both-edges;
  background-clip: padding-box;
}



/* === V5 FIX: Force decent height for Camadas/Indicadores cards (mapCard2/mapCard3) === */
#mapCard2, #mapCard3{
  min-height: 260px !important;
  height: 100% !important; /* ocupa toda a altura disponível */
  flex: 1 !important;
}
#mapCard2 .map-layers-list,
#mapCard3 #mapInfoPanel,
#mapLayersList,
#mapInfoPanel{
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: auto !important;
}

/* Make placeholders fill the available area so cards don't collapse visually */
#mapCard2 .panel-placeholder,
#mapCard3 .panel-placeholder{
  min-height: 160px !important;
}

/* If the right sidebar is constraining height, ensure it allows cards to show and scroll */
.map-panel .map-controls,
#mapControlsPanel .map-controls,
.controls-panel .map-controls{
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}
.map-panel .map-controls > .map-ctrl-card,
#mapControlsPanel .map-controls > .map-ctrl-card,
.controls-panel .map-controls > .map-ctrl-card{
  flex: 0 0 auto !important;
}

/* Keep nice rounded corners without “cutting” scrollbars */
#mapCard2, #mapCard3{
  overflow: hidden !important;
}
#mapLayersList::-webkit-scrollbar,
#mapInfoPanel::-webkit-scrollbar{
  width: 10px;
}


/* === FIX FINAL: Card "Camadas" não pode crescer infinito; usar scroll interno === */
#mapCard2{
  display:flex;
  flex-direction:column;
  min-height:260px;
  max-height:clamp(260px, 42vh, 520px);
  overflow:hidden; /* impede o card de ficar gigante */
}
#mapCard2 .map-ctrl-header{ flex:0 0 auto; }

/* a lista deve ocupar o espaço restante e rolar por dentro */
#mapLayersList{
  flex:1 1 auto;
  min-height:0;           /* essencial pra overflow funcionar em flex */
  overflow:auto;
  padding-right:6px;      /* evita texto colar no scroll */
  scrollbar-gutter: stable both-edges;
}

/* mantém os cards do painel alinhados */
#mapCard2, #mapCard3{
  width:100%;
}



/* === FIX v7: Card "Camadas" não pode crescer infinito; usa scroll interno === */
#mapCard2{
  /* mantém visual dos outros cards, mas limita altura */
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;

  /* tamanho padrão (parecido com os outros cards) */
  min-height:260px !important;
  max-height:clamp(260px, 42vh, 520px) !important;

  /* se algum lugar estiver forçando height:100%, deixa o max-height mandar */
  height:auto !important;
}

/* lista ocupa o restante do card e rola por dentro */
#mapCard2 > #mapLayersList{
  flex:1 1 auto !important;
  min-height:0 !important; /* essencial pra overflow funcionar em flex */
  overflow:auto !important;

  /* garante respiro e evita “vazamento” no canto inferior */
  padding-bottom:10px !important;
  scrollbar-gutter: stable both-edges;
}

/* Opcional: melhora toque/scroll no mobile */
#mapCard2 > #mapLayersList{
  -webkit-overflow-scrolling: touch;
}


/* === Collapsible Map Control Cards (start minimized) === */
.map-ctrl-card .map-ctrl-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
}

.map-ctrl-card .map-ctrl-head-left{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.map-ctrl-card .card-toggle{
  flex:0 0 auto;
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(36,78,156,.16);
  background:rgba(255,255,255,.65);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease;
}

.map-ctrl-card .card-toggle:hover{
  background:rgba(255,255,255,.9);
}

.map-ctrl-card .card-toggle svg{
  transition:transform .18s ease;
}

.map-ctrl-card.is-collapsed .card-toggle svg{
  transform:rotate(-90deg);
}

/* When collapsed: show only icon + title */
.map-ctrl-card.is-collapsed .map-ctrl-sub{
  display:none !important;
}

.map-ctrl-card.is-collapsed > :not(.map-ctrl-header){
  display:none !important;
}

/* Keep spacing tight when collapsed */
.map-ctrl-card.is-collapsed{
  padding-bottom: 0 !important;
}


/* === FIX v9: collapsed cards must be compact (same as Categorias) === */
#mapCard2.map-ctrl-card.is-collapsed,
#mapCard3.map-ctrl-card.is-collapsed{
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  overflow: hidden !important;
  padding-bottom: 0 !important;
}
/* keep the header height consistent when collapsed */
#mapCard2.map-ctrl-card.is-collapsed .map-ctrl-header,
#mapCard3.map-ctrl-card.is-collapsed .map-ctrl-header{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}
/* remove any leftover spacing from lists/panels */
#mapCard2.map-ctrl-card.is-collapsed #mapLayersList,
#mapCard3.map-ctrl-card.is-collapsed #mapInfoPanel{
  display:none !important;
  height:0 !important;
  min-height:0 !important;
  max-height:0 !important;
  overflow:hidden !important;
}



/* === FIX v10: header vertical centering in collapsed cards (Camadas/Indicadores) === */
/* Give all collapsed cards the same compact header height/padding so icon+title sit centered */
.map-ctrl-card.is-collapsed .map-ctrl-header{
  padding: 14px 18px !important;   /* symmetric padding -> centered look */
  min-height: 62px !important;
  align-items: center !important;
}
/* Remove any leftover bottom border spacing that can visually "drop" content */
.map-ctrl-card.is-collapsed .map-ctrl-header{
  border-bottom: 0 !important;
}

.map-ctrl-card.is-collapsed .map-ctrl-title{
  line-height: 1.2 !important;
  margin: 0 !important;
}
.map-ctrl-card.is-collapsed .map-ctrl-head-left{
  align-items: center !important;
}



.kpi-src{
  font-size: 11px;
  color: rgba(255,255,255,.78);
  margin-top: 6px;
}
.card.blue[data-kpi] .kpi-src{
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.card.blue.kpi-loading, .card.blue[data-kpi].kpi-loading{
  filter: saturate(.95);
}
.card.blue[data-kpi].kpi-loading .kpi-val{
  opacity: .7;
}


.btn-connect-censo{
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 600;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.12);
  color: #FFFFFF;
  cursor: pointer;
}
.btn-connect-censo:hover{
  background: rgba(255,255,255,.18);
}
.btn-connect-censo:disabled{
  opacity: .65;
  cursor: not-allowed;
}


#mapCard2 .map-ctrl-header,
#mapCard3 .map-ctrl-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;

  height: 64px !important;
  padding: 0 18px !important;
  box-sizing: border-box !important;
}

#mapCard2 .map-ctrl-header-left,
#mapCard3 .map-ctrl-header-left {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;

  transform: translateY(-2px);
}


#mapCard2 .map-ctrl-title,
#mapCard3 .map-ctrl-title {
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
}


#mapCard2 .map-ctrl-icon,
#mapCard3 .map-ctrl-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
}

#mapCard2 .map-ctrl-title h1,
#mapCard2 .map-ctrl-title h2,
#mapCard2 .map-ctrl-title h3,
#mapCard2 .map-ctrl-title h4,
#mapCard3 .map-ctrl-title h1,
#mapCard3 .map-ctrl-title h2,
#mapCard3 .map-ctrl-title h3,
#mapCard3 .map-ctrl-title h4 {
  line-height: 1 !important;
  margin: 0 !important;
}

/* ================================
   Censo 2022 integrado (escopado)
   ================================ */









.censo-integrated /* ── LAYOUT ── */
.app { min-height:100vh; display:flex; flex-direction:column; background:var(--app-bg); }

.censo-integrated /* ── TOPBAR ── */
.topbar {
  background:#244E9C;
  color:#FFFFFF; height:64px; display:flex; align-items:center;
  padding:0 22px; gap:14px; flex-shrink:0;
  border-bottom:1px solid rgba(255,255,255,.10);
  position:sticky; top:0; z-index:100;
}
.censo-integrated .topbar-title { font-size:15px; font-weight:800; letter-spacing:-.01em; }
.censo-integrated .topbar-sub { font-size:11px; color:rgba(255,255,255,.60); margin-top:2px; }
.censo-integrated .topbar-right { margin-left:auto; display:flex; align-items:center; gap:10px; }
.censo-integrated .live-badge {
  display:inline-flex; align-items:center; gap:5px; padding:4px 10px;
  border-radius:999px; background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.20); color:rgba(255,255,255,.90);
  font-size:11px; font-weight:600;
}
.censo-integrated .live-dot { width:6px; height:6px; background:#244E9C; border-radius:50%; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:.4} 50%{opacity:1} }
.censo-integrated .icon-btn {
  width:36px; height:36px; border-radius:10px; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08); display:grid; place-items:center;
  cursor:pointer; color:#FFFFFF; flex-shrink:0; transition:background .15s;
}
.censo-integrated .icon-btn:hover { background:rgba(255,255,255,.16); }
.censo-integrated .icon-btn svg { width:16px; height:16px; }

.censo-integrated /* ── TABS ── */
.tabs-bar {
  display:flex; align-items:center; gap:2px; padding:10px 18px 0;
  background:#FFFFFF; border-bottom:1px solid rgba(36,78,156,.10);
  flex-shrink:0; flex-wrap:wrap;
}

.censo-integrated .tab {
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 15px; border-radius:10px 10px 0 0;
  border:1px solid rgba(36,78,156,.18); border-bottom:none;
  background:#FFFFFF; color:rgba(36,78,156,.55);
  font-family:inherit; font-size:13px; font-weight:600;
  cursor:pointer; position:relative; bottom:-1px; transition:all .15s;
  white-space:nowrap;
}

.censo-integrated .tab svg { flex-shrink:0; opacity:.7; }
.censo-integrated .tab:hover { background:rgba(36,78,156,.07); color:#244E9C; }

.censo-integrated .tab.active {
  background:#EEF4FB; border:1px solid #244E9C; border-bottom:none;
  color:#244E9C; font-weight:700;
}


/* ── CONTENT (inside censo-integrated) ── */
.censo-integrated > .content,
/* source-content scroll handled in appended section below */

.censo-integrated /* ── SECTIONS ── */
.section { display:none; flex-direction:column; gap:18px; }
.censo-integrated .section.active { display:flex; animation:fadeUp .28s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

.censo-integrated /* ── GRID ── */
.grid { display:grid; grid-template-columns:repeat(12,1fr); gap:16px; }
.censo-integrated .col-5 { grid-column:span 5; }
.censo-integrated .col-6 { grid-column:span 6; }
.censo-integrated .col-7 { grid-column:span 7; }
.censo-integrated .col-12 { grid-column:span 12; }

.censo-integrated /* ── CARD ── */
.card {
  border-radius:var(--radius); border:1px solid var(--border);
  background:var(--card); box-shadow:var(--shadow); overflow:hidden;
}
.censo-integrated .card-head {
  padding:14px 16px 10px; display:flex; align-items:flex-start;
  justify-content:space-between; gap:10px;
}
.censo-integrated .card-title { font-weight:800; font-size:13px; color:var(--text); letter-spacing:-.01em; }
.censo-integrated .card-sub { font-size:11px; color:var(--muted); margin-top:2px; font-weight:500; }
.censo-integrated .card-body { padding:0 16px 14px; }
.censo-integrated .card-meta {
  font-size:10.5px; color:var(--accent); font-weight:700;
  padding:2px 8px; border-radius:999px;
  background:rgba(36,78,156,.10); border:1px solid rgba(36,78,156,.14);
  white-space:nowrap; flex-shrink:0;
}


.censo-integrated /* ── KPI GRID ── */
.kpi-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.censo-integrated .kpi-card {
  border-radius:var(--radius); border:1px solid var(--border);
  background:var(--card); padding:14px 16px 12px;
  box-shadow:var(--shadow); position:relative; overflow:hidden;
  transition:transform .16s ease;
}
.censo-integrated .kpi-card:hover { transform:translateY(-2px); }
.censo-integrated .kpi-accent { position:absolute; top:0; left:0; right:0; height:3px; border-radius:3px 3px 0 0; }
.censo-integrated .kpi-label { font-size:11px; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; margin-top:4px; }
.censo-integrated .kpi-val { font-size:22px; font-weight:900; line-height:1.2; margin-top:5px; letter-spacing:-.02em; }
.censo-integrated .kpi-detail { font-size:11px; color:var(--muted); margin-top:4px; font-weight:500; }

.censo-integrated /* ── BARS ── */
.bar-list { display:flex; flex-direction:column; gap:7px; }
.censo-integrated .bar-row { display:grid; grid-template-columns:140px 1fr 62px; align-items:center; gap:9px; padding:2px 4px; border-radius:6px; cursor:default; transition:background .1s; }
.censo-integrated .bar-row:hover { background:rgba(36,78,156,.05); }

.censo-integrated .bar-label { font-size:11px; font-weight:600; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.censo-integrated .bar-track { height:20px; background:rgba(36,78,156,.06); border-radius:6px; overflow:hidden; }

.censo-integrated .bar-fill {
  height:100%; border-radius:6px; display:flex; align-items:center;
  padding:0 7px; justify-content:flex-end; min-width:2px;
  transition:width .6s cubic-bezier(.22,.68,0,1.2);
}
.censo-integrated .bar-pct { font-size:10px; font-weight:800; color:#FFFFFF; text-shadow:0 1px 3px rgba(15,35,71,.3); white-space:nowrap; }
.censo-integrated .bar-val { font-size:11px; font-weight:700; color:var(--text); text-align:right; }
.censo-integrated .bar-scroll { max-height:300px; overflow-y:auto; padding-right:3px; scrollbar-width:thin; scrollbar-color:rgba(36,78,156,.2) transparent; }

.censo-integrated /* ── DONUT ── */
.donut-wrap { display:flex; align-items:center; gap:18px; }
.censo-integrated .donut-legend { display:flex; flex-direction:column; gap:5px; flex:1; min-width:0; }
.censo-integrated .legend-item { display:flex; align-items:center; gap:7px; font-size:11px; font-weight:600; color:var(--text); }
.censo-integrated .legend-dot { width:9px; height:9px; border-radius:50%; flex-shrink:0; }
.censo-integrated .religion-viz{display:flex;flex-direction:column;gap:14px;align-items:stretch;width:100%;padding:4px 0 2px;}
.censo-integrated .religion-stack{display:flex;height:22px;border-radius:999px;overflow:hidden;background:rgba(36,78,156,.08);border:1px solid rgba(36,78,156,.12);box-shadow:inset 0 1px 2px rgba(36,78,156,.04);}
.censo-integrated .religion-seg{height:100%;min-width:2px;position:relative;transition:transform .18s ease,filter .18s ease,opacity .18s ease;opacity:.96;}
.censo-integrated .religion-seg:hover{transform:translateY(-1px);filter:saturate(1.08) brightness(1.02);opacity:1;}
.censo-integrated .religion-grid{display:grid;grid-template-columns:1fr;gap:9px;}
.censo-integrated .religion-row{display:grid;grid-template-columns:minmax(0,1fr) 72px;gap:12px;align-items:center;}
.censo-integrated .religion-track{position:relative;height:14px;background:rgba(36,78,156,.07);border-radius:999px;overflow:hidden;}
.censo-integrated .religion-fill{height:100%;border-radius:999px;}
.censo-integrated .religion-label{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:11px;font-weight:600;color:var(--text);margin-bottom:4px;}
.censo-integrated .religion-label strong{font-weight:700;}
.censo-integrated .religion-val{font-size:11px;font-weight:700;color:var(--accent);text-align:right;}
.censo-integrated .legend-val { margin-left:auto; font-size:10px; color:var(--muted); font-weight:700; }

.censo-integrated /* ── PYRAMID ── */
.pyramid { display:flex; flex-direction:column; gap:3px; }
.censo-integrated .pyr-row { display:grid; grid-template-columns:1fr 46px 1fr; align-items:center; gap:4px; cursor:default; }
.censo-integrated .pyr-label { font-size:10px; color:var(--muted); text-align:center; font-weight:600; }
.censo-integrated .pyr-l { display:flex; justify-content:flex-end; }
.censo-integrated .pyr-r { display:flex; justify-content:flex-start; }
.censo-integrated .pyr-bar { height:13px; border-radius:4px; transition:width .6s cubic-bezier(.22,.68,0,1.2); }

.censo-integrated /* ── TABLE ── */
.tbl-wrap { overflow-x:auto; border-radius:10px; border:1px solid var(--border); }
.censo-integrated .dtbl { width:100%; border-collapse:collapse; font-size:11px; }
.censo-integrated .dtbl thead tr { background:rgba(36,78,156,.08); border-bottom:1px solid var(--border); }

.censo-integrated .dtbl th { padding:9px 11px; text-align:left; font-weight:800; font-size:10px; text-transform:uppercase; letter-spacing:.07em; color:var(--accent); white-space:nowrap; }
.censo-integrated .dtbl td { padding:8px 11px; border-bottom:1px solid var(--border); color:var(--text); font-weight:500; }
.censo-integrated .dtbl tbody tr:last-child td { border-bottom:none; }
.censo-integrated .dtbl tbody tr:hover td { background:rgba(36,78,156,.03); }
.censo-integrated .dtbl td.hl { font-weight:800; color:var(--accent); }
.censo-integrated .dtbl .rowhl td { background:rgba(36,78,156,.03); }
.censo-integrated .dtbl .rowhl td:first-child { border-left:3px solid #244E9C; padding-left:8px; }


.censo-integrated /* ── PAGE TITLE ── */
.page-title-row { display:flex; align-items:center; justify-content:space-between; gap:10px; }
.censo-integrated .page-title { font-size:19px; font-weight:900; color:var(--text); letter-spacing:-.02em; }
.censo-integrated .page-sub { font-size:11.5px; color:var(--muted); margin-top:3px; font-weight:500; }

.censo-integrated /* ── SOURCE TAG ── */
.source-tag { display:inline-flex; align-items:center; gap:6px; font-size:10px; color:var(--muted); margin-top:8px; font-weight:500; }
.censo-integrated .source-tag::before { content:'FONTE'; font-size:9px; font-weight:800; letter-spacing:.1em; color:var(--accent); }

.censo-integrated /* ── COMMENTARY ── */
.commentary {
  background: #38BEEF;
  border: 1px solid rgba(36,78,156,.13);
  border-left: 3px solid #244E9C;
  border-radius: 0 10px 10px 0;
  padding: 12px 16px;
  margin-top: 14px;
  font-size: 11.5px;
  color: var(--text);
  line-height: 1.65;
  animation: fadeIn .4s ease both;
}

.censo-integrated .commentary strong { color: #244E9C; font-weight: 700; }

html[data-theme="dark"] .commentary {
  background: #1a1a1a;
  border-color: rgba(255,255,255,.12);
  border-left-color: rgba(255,255,255,.35);
}
html[data-theme="dark"] .censo-integrated .commentary strong { color: #f5f5f5; }

.censo-integrated /* ── DATA ORIGIN ── */
.data-origin { margin-top:12px; border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.censo-integrated .do-title { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--accent); padding:7px 11px; background:rgba(36,78,156,.05); border-bottom:1px solid var(--border); }

.censo-integrated .do-table { width:100%; border-collapse:collapse; font-size:10.5px; }
.censo-integrated .do-table th { padding:5px 10px; text-align:left; font-weight:700; font-size:9px; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); background:rgba(36,78,156,.02); border-bottom:1px solid var(--border); }
.censo-integrated .do-table td { padding:5px 10px; border-bottom:1px solid var(--border); color:var(--text); font-weight:500; }
.censo-integrated .do-table tr:last-child td { border-bottom:none; }
.censo-integrated .do-table td.mono { font-family:'Courier New',monospace; font-size:9.5px; color:var(--accent); font-weight:600; }


.censo-integrated /* ── TOOLTIP ── */
.pm-tooltip {
  position:fixed; z-index:9999; pointer-events:none;
  min-width:160px; max-width:240px; padding:9px 13px; border-radius:10px;
  background:#244E9C;
  border:1px solid rgba(255,255,255,.18); box-shadow:0 12px 36px rgba(15,35,71,.4);
  color:#FFFFFF; opacity:0; transform:translateY(6px) scale(.97);
  transition:opacity .12s ease,transform .12s ease;
}
.censo-integrated .pm-tooltip.visible { opacity:1; transform:translateY(0) scale(1); }
.censo-integrated .pm-tt-title { font-size:12px; font-weight:800; margin-bottom:3px; }
.censo-integrated .pm-tt-body { font-size:11px; color:rgba(255,255,255,.75); font-weight:500; }

.censo-integrated /* ── FOOTER ── */
.footer {
  padding:10px 20px; font-size:10.5px; color:var(--muted);
  border-top:1px solid var(--border); display:flex;
  justify-content:space-between; background:#FFFFFF; flex-shrink:0;
}


.censo-integrated /* ── RESPONSIVE ── */
@media (max-width:1100px) { .kpi-grid { grid-template-columns:repeat(3,1fr); } .col-5,.col-7 { grid-column:span 6; } }
@media (max-width:760px)  { .kpi-grid { grid-template-columns:repeat(2,1fr); } .col-5,.col-6,.col-7 { grid-column:span 12; } .tabs-bar { gap:0; } .tab { font-size:12px; padding:7px 11px; } }


/* ===== Censo integrado: ajustes finos para o Panorama ===== */
.censo-integrated{ display:flex; flex-direction:column; gap:12px; }
.censo-integrated .tabs-bar{ position:sticky; top:10px; z-index:3; }
.censo-integrated .section{ display:none; }
.censo-integrated .section.active{ display:block; }
.censo-integrated #sec-mapa .dash-map-section{ margin-top:0; }




/* === FIX FINAL panorama integração === */
.censo-integrated .kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:18px;}
.censo-integrated .grid{gap:18px;}
.censo-integrated .grid > .card{margin-bottom:0;}
.dash-map-controls{min-width:320px;}
.dash-map-controls .map-controls{display:flex;flex-direction:column;gap:14px;}
.dash-map-controls .map-ctrl-card{width:100%;}
#sec-mapa .dash-map-section{align-items:start;}
#sec-mapa .dash-map-controls .map-ctrl-header{cursor:default;}
#sec-mapa .dash-map-controls .card-toggle{display:grid;}
#sec-mapa .dash-map-controls #mapLayersList,#sec-mapa .dash-map-controls #mapInfoPanel{overflow:auto;}

/* ===== FIX FINAL: barra branca colada na topbar azul ===== */
.censo-integrated{
  margin-top: -8px;
}
.censo-integrated .tabs-bar{
  margin: 0 -18px 0;
  padding: 10px 30px 0;
  border-radius: 0;
  position: sticky;
  top: 0;
  z-index: 5;
}


/* remove qualquer espaço entre barra azul e barra branca */
.tabs-bar,
.tabs,
.nav-tabs{
    margin-top:0 !important;
    top:0 !important;
}

/* remove espaço do container principal */
.main-content,
.content,
.dashboard,
.page-content{
    margin-top:0 !important;
    padding-top:0 !important;
}

/* impede conteúdo aparecer por trás ao scroll */
.tabs-bar{
    position:sticky;
    top:0;
    z-index:1000;
    background:#FFFFFF;
}

/* garante que não exista transparência */
.tabs-bar *{
    background:#FFFFFF;
}

/* ===== Map menu fixado e sempre aberto ===== */
.card-toggle,
.map-ctrl-bottom,
#mapActive,
#mapCard1 .map-ctrl-divider,
#mapCard1 .map-ctrl-section-title{
  display:none !important;
}

#mapCard1,
#mapCard2,
#mapCard3{
  overflow:hidden !important;
  display:flex !important;
  flex-direction:column !important;
}

#mapCard1 .map-ctrl-header,
#mapCard3 .map-ctrl-header{
  justify-content:flex-start !important;
  cursor:default !important;
}

#mapCard1 .map-chips{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  padding:14px;
}
@media (max-width: 1280px){
  #mapCard1 .map-chips{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}

.map-cat-tile{
  min-height:88px;
  border-radius:20px !important;
  padding:14px 10px !important;
  display:flex !important;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-align:center;
  font-weight:700;
  box-shadow:0 8px 20px rgba(36,78,156,.08);
}
.map-cat-tile .mct-icon{
  width:40px;height:40px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(36,78,156,.10);
  color:var(--pm-accent,#244E9C);
}
.map-cat-tile .mct-icon svg{ width:18px; height:18px; }
.map-cat-tile .mct-label{
  display:block;
  font-size:12px;
  line-height:1.25;
  white-space:normal;
}
html[data-theme="dark"] .map-cat-tile .mct-icon{
  background:rgba(255,255,255,.10);
  color:#FFFFFF;
}

#mapCard2{
  min-height:280px !important;
  max-height:clamp(280px, 36vh, 460px) !important;
  background:#FFFFFF !important;
  border:1px solid rgba(36,78,156,.10) !important;
}
#mapCard2 > #mapLayersList{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow:auto !important;
  padding:12px !important;
  scrollbar-gutter:stable both-edges;
}

#mapCard3{
  min-height:280px !important;
}
#mapCard3 > #mapInfoPanel{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
}

.map-layer-empty.compact-empty{
  min-height:200px;
  justify-content:center;
}

.dash-map-controls .map-controls{
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
}
.dash-map-controls .map-controls > .map-ctrl-card{
  width:100% !important;
  flex:0 0 auto !important;
}

/* ===== Ajuste fino do menu lateral do mapa ===== */
/* manter largura original e ajustar só alturas */
#mapCard1{
  min-height: 220px !important;
  max-height: 220px !important;
}
#mapCard1 .map-ctrl-header{
  padding-bottom: 8px !important;
}
#mapCard1 .map-chips{
  gap: 5px !important;
  padding: 5px 12px 12px !important;
}
.map-cat-tile{
  min-height: 1px !important;
  padding: 1px 1px !important;
  gap: 1px !important;
  border-radius: 18px !important;
}
.map-cat-tile .mct-icon{
  width: 40px !important;
  height: 40px !important;
  border-radius: 11px !important;
}
.map-cat-tile .mct-icon svg{
  width: 12px !important;
  height: 12px !important;
}
.map-cat-tile .mct-label{
  font-size: 11px !important;
  line-height: 1.15 !important;
}

/* card dos marcadores: mostrar exatamente 3 itens e scroll para os demais */
#mapCard2{
  min-height: 306px !important;
  max-height: 306px !important;
  height: 306px !important;
}
#mapCard2 > #mapLayersList{
  padding: 10px 12px !important;
  gap: 8px !important;
}
#mapCard2 .map-layer-row{
  min-height: 84px !important;
}

/* card de indicadores maior */
#mapCard3{
  min-height: 360px !important;
  max-height: 360px !important;
  height: 360px !important;
}
#mapCard3 > #mapInfoPanel{
  padding: 10px 14px 16px !important;
}

/* garantir os 3 cards visíveis na lateral */
.dash-ctrl-scroll,
.dash-map-controls{
  min-height: 0 !important;
}
.dash-map-controls{
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}




/* ===== AJUSTE FINAL DOS 3 CARDS AO LADO DO MAPA ===== */
/* Card superior: menor, com botões mais compactos */
#mapCard1{
  min-height: 176px !important;
  max-height: 176px !important;
  height: 176px !important;
}
#mapCard1 .map-ctrl-header{
  padding: 10px 14px 8px !important;
}
#mapCard1 .map-chips{
  gap: 8px !important;
  padding: 4px 12px 12px !important;
}
.map-cat-tile{
  min-height: 62px !important;
  padding: 8px 8px !important;
  gap: 6px !important;
  border-radius: 18px !important;
}
.map-cat-tile .mct-icon{
  width: 30px !important;
  height: 30px !important;
  border-radius: 10px !important;
}
.map-cat-tile .mct-icon svg{
  width: 13px !important;
  height: 13px !important;
}
.map-cat-tile .mct-label{
  font-size: 11px !important;
  line-height: 1.1 !important;
}

/* Card do meio: metade do tamanho atual */
#mapCard2{
  min-height: 164px !important;
  max-height: 164px !important;
  height: 164px !important;
}
#mapCard2 .map-ctrl-header{
  padding: 10px 14px 8px !important;
}
#mapCard2 > #mapLayersList{
  padding: 8px 12px 10px !important;
  gap: 6px !important;
}
#mapCard2 .map-layer-row,
#mapCard2 .mini-item{
  min-height: 46px !important;
  padding: 7px 12px !important;
  border-radius: 12px !important;
}
#mapCard2 .map-layer-row .t,
#mapCard2 .mini-item .t{
  font-size: 12px !important;
  line-height: 1.1 !important;
}
#mapCard2 .map-layer-row .s,
#mapCard2 .mini-item .s{
  font-size: 11px !important;
  line-height: 1.05 !important;
  margin-top: 2px !important;
}

/* Barras/toggles: um pouco mais grossas */
#mapCard2 .switch{
  width: 44px !important;
  height: 24px !important;
}
#mapCard2 .switch span{
  border-width: 1px !important;
}
#mapCard2 .switch span::after{
  width: 18px !important;
  height: 18px !important;
  left: 3px !important;
}
#mapCard2 .switch input:checked + span::after{
  left: 21px !important;
}

/* Card inferior: maior, sem mexer no conteúdo */
#mapCard3{
  min-height: 326px !important;
  max-height: 326px !important;
  height: 326px !important;
}
#mapCard3 > #mapInfoPanel{
  padding: 10px 14px 16px !important;
}

/* Garantir os 3 cards visíveis ao lado do mapa */
.dash-map-controls .map-controls{
  gap: 12px !important;
}
.dash-ctrl-scroll,
.dash-map-controls,
.dash-map-controls .map-controls,
.dash-map-controls .map-controls > .map-ctrl-card{
  min-height: 0 !important;
}

/* ===== AJUSTE FINAL DO CARD CATEGORIAS ===== */
#mapCard1{
  min-height: 168px !important;
  max-height: 168px !important;
  height: 168px !important;
  display: flex !important;
  flex-direction: column !important;
}
#mapCard1 .map-ctrl-header{
  padding: 10px 14px 8px !important;
  flex: 0 0 auto !important;
}
#mapCard1 .map-chips{
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  padding: 4px 12px 10px !important;
  gap: 8px !important;
  align-content: start !important;
  scrollbar-gutter: stable !important;
}
#mapCard1 .map-chips::-webkit-scrollbar{
  width: 6px;
}
#mapCard1 .map-chips::-webkit-scrollbar-thumb{
  background: rgba(36,78,156,.18);
  border-radius: 999px;
}
#mapCard1 .map-chips::-webkit-scrollbar-track{
  background: transparent;
}
#mapCard1 .map-cat-tile{
  min-height: 54px !important;
  padding: 7px 8px !important;
  gap: 5px !important;
  border-radius: 16px !important;
}
#mapCard1 .map-cat-tile .mct-icon{
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  border-radius: 8px !important;
}
#mapCard1 .map-cat-tile .mct-icon svg{
  width: 11px !important;
  height: 11px !important;
}
#mapCard1 .map-cat-tile .mct-label{
  font-size: 10.5px !important;
  line-height: 1.05 !important;
}


/* =========================================================
   AJUSTES FINAIS SOLICITADOS — CARDS AO LADO DO MAPA
   ========================================================= */

/* container lateral sem scroll da página */
.dash-ctrl-col{
  height: calc(72vh + 54px) !important;
  overflow: hidden !important;
}

.dash-ctrl-scroll{
  overflow: hidden !important;
  padding: 10px 8px 12px !important;
}

.dash-map-controls .map-controls{
  display:flex !important;
  flex-direction:column !important;
  gap:12px !important;
  height:100% !important;
}

/* -------------------------
   CARD 1 — CATEGORIAS
   ------------------------- */
#mapCard1{
  min-height: 180px !important;
  max-height: 180px !important;
  height: 186px !important;
  display:flex !important;
  flex-direction:column !important;
}

#mapCard1 .map-ctrl-header{
  flex:0 0 auto !important;
  min-height: 58px !important;
  padding: 10px 14px 8px !important;
}

#mapCard1 .map-chips{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:8px !important;
  padding: 4px 12px 10px !important;
  align-content:start !important;
  scrollbar-gutter: stable !important;
}

#mapCard1 .map-chips::-webkit-scrollbar{
  width:6px;
}
#mapCard1 .map-chips::-webkit-scrollbar-thumb{
  background: rgba(36,78,156,.18);
  border-radius:999px;
}
#mapCard1 .map-chips::-webkit-scrollbar-track{
  background: transparent;
}

#mapCard1 .map-cat-tile{
  min-height: 50px !important;
  height: 50px !important;
  padding: 6px 6px !important;
  gap: 4px !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 10px rgba(36,78,156,.06) !important;
}

#mapCard1 .map-cat-tile .mct-icon{
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  border-radius: 7px !important;
}

#mapCard1 .map-cat-tile .mct-icon svg{
  width: 10px !important;
  height: 10px !important;
}

#mapCard1 .map-cat-tile .mct-label{
  font-size: 10px !important;
  line-height: 1 !important;
}

/* -------------------------
   CARD 2 — MARCADORES
   ------------------------- */
#mapCard2{
  min-height: 180px !important;
  max-height: 180px !important;
  height: 150px !important;
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;
}

#mapCard2 .map-ctrl-header{
  flex:0 0 auto !important;
  min-height: 56px !important;
  padding: 8px 14px 6px !important;
}

#mapCard2 > #mapLayersList,
#mapCard2 .map-layers-list{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow:auto !important;
  padding: 6px 10px 8px !important;
  gap: 5px !important;
  scrollbar-gutter: stable !important;
  -webkit-overflow-scrolling: touch;
}

#mapCard2 .map-layer-row,
#mapCard2 .mini-item{
  min-height: 38px !important;
  padding: 6px 10px !important;
  border-radius: 10px !important;
}

#mapCard2 .mlr-left{
  gap: 8px !important;
}

#mapCard2 .mlr-status-dot{
  width: 8px !important;
  height: 8px !important;
}

#mapCard2 .mlr-title,
#mapCard2 .mini-item .t{
  font-size: 11px !important;
  line-height: 1.05 !important;
}

#mapCard2 .mlr-sub,
#mapCard2 .mini-item .s{
  font-size: 10px !important;
  line-height: 1.05 !important;
  margin-top: 1px !important;
}

/* toggle levemente mais grosso */
#mapCard2 .map-toggle{
  width: 40px !important;
  height: 24px !important;
}

#mapCard2 .map-toggle-track{
  border-width: 1px !important;
}

#mapCard2 .map-toggle-thumb{
  width: 18px !important;
  height: 18px !important;
  top: 2px !important;
  left: 2px !important;
}

#mapCard2 .map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb{
  transform: translateX(16px) !important;
}

#mapCard2 .switch{
  width: 42px !important;
  height: 24px !important;
}

#mapCard2 .switch span{
  border-width: 1px !important;
}

#mapCard2 .switch span::after{
  width: 18px !important;
  height: 18px !important;
  left: 2px !important;
}

#mapCard2 .switch input:checked + span::after{
  left: 20px !important;
}

/* -------------------------
   CARD 3 — INDICADORES
   ------------------------- */
#mapCard3{
  min-height: 335px !important;
  max-height: 335px !important;
  height: 352px !important;
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;
}

#mapCard3 > #mapInfoPanel,
#mapCard3 .map-info-panel{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow:auto !important;
  padding: 10px 14px 16px !important;
}

@media (max-width: 1280px){
  #mapCard1{
    min-height: 194px !important;
    max-height: 194px !important;
    height: 194px !important;
  }
  #mapCard3{
    min-height: 330px !important;
    max-height: 330px !important;
    height: 330px !important;
  }
}






/* ══════════════════════════════════════════════════════════════════
   SOURCE SWITCHER — IBGE / CAGED / TSE
══════════════════════════════════════════════════════════════════ */

/* 1. censo-integrated fills the .content area completely */
.censo-integrated {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  margin: 0;
}

/* ── Keyframes ── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-18px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(18px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(.94); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes barGrow {
  from { width: 0 !important; }
}
@keyframes pulse-soft {
  0%, 100% { opacity: 1; }
  50%       { opacity: .65; }
}

/* 2. Blue source-switcher bar */
.source-switcher {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  padding: 0 18px 0;
  background: var(--topbar-bg, #244E9C);
  flex-shrink: 0;
  margin-bottom: -1px; /* ensure tabs-bar border overlaps blue bar by 1px */
}

/* Barra de fontes (Mapa / ATLAS / … ou abas por secretaria): fixa no topo da área útil */
.censo-integrated > .source-switcher{
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
}

.source-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  border: 1px solid transparent;
  border-bottom: none;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.60);
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  border-radius: 10px 10px 0 0;
  cursor: pointer;
  position: relative;
  bottom: -1px;
  transition: background .2s ease, color .2s ease, transform .15s ease !important;
  white-space: nowrap;
  margin-top: 8px;
}

.source-btn svg {
  flex-shrink: 0;
  opacity: .75;
  transition: opacity .2s ease !important;
}

.source-btn:hover {
  background: rgba(255,255,255,.15);
  color: #FFFFFF;
  transform: translateY(-1px);
}
.source-btn:hover svg { opacity: 1; }

.source-btn.active {
  background: #EEF4FB;
  color: #244E9C;
  border-color: #244E9C;
  font-weight: 700;
  transform: none;
}

html[data-theme="dark"] .source-btn.active {
  background: #ffffff;
  color: #0a0a0a;
  border-color: rgba(255,255,255,.35);
}

/* 3. Source panel: IBGE panel scrolls at this level */
.source-panel {
  display: none;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
/* IBGE panel scrolls since it has no .source-content wrapper */
#panel-ibge {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  --ibge-p1:#244E9C;
  --ibge-p2:#38BEEF;
  --ibge-p3:#FCCF00;
  --ibge-p4:#E9561E;
  --ibge-p5:#47AB34;
  --ibge-p6:#005E34;
}
#panel-ibge::-webkit-scrollbar { width: 8px; }
#panel-ibge::-webkit-scrollbar-track { background: transparent; }
#panel-ibge::-webkit-scrollbar-thumb { background: rgba(36,78,156,.15); border-radius: 10px; }
html[data-theme="dark"] #panel-ibge::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); }

/* IBGE: paleta PMPA — KPI por posição na grade */
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+1) .kpi-accent{ background:var(--ibge-p1)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+2) .kpi-accent{ background:var(--ibge-p2)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+3) .kpi-accent{ background:var(--ibge-p3)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+4) .kpi-accent{ background:var(--ibge-p4)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+5) .kpi-accent{ background:var(--ibge-p5)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+6) .kpi-accent{ background:var(--ibge-p6)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+1) .kpi-val{ color:var(--ibge-p1)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+2) .kpi-val{ color:var(--ibge-p2)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+3) .kpi-val{ color:#1e3a5f!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+4) .kpi-val{ color:var(--ibge-p4)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+5) .kpi-val{ color:var(--ibge-p5)!important; }
#panel-ibge .kpi-grid .kpi-card:nth-child(6n+6) .kpi-val{ color:var(--ibge-p6)!important; }

/* KPI IBGE: contorno azul tipo Atlas */
#panel-ibge .kpi-grid .kpi-card{
  border-color:#244E9C !important;
}

.source-panel.active {
  display: flex;
  animation: fadeIn .22s ease both;
}

/* 4. White sub-tabs bar — identical to IBGE, zero gap from blue bar */
.source-panel > .tabs-bar {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 10px 18px 0;
  background: #FFFFFF;
  border-bottom: 1px solid rgba(36,78,156,.10);
  flex-shrink: 0;
  flex-wrap: wrap;
}

html[data-theme="dark"] .source-panel > .tabs-bar {
  background: #0a0a0a;
  border-bottom-color: rgba(255,255,255,.12);
}

.source-panel > .tabs-bar .tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 15px;
  border-radius: 10px 10px 0 0;
  border: 1px solid rgba(36,78,156,.2);
  border-bottom: none;
  background: #FFFFFF;
  color: rgba(36,78,156,.55);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  position: relative;
  bottom: -1px;
  transition: background .18s ease, color .18s ease, border-color .18s ease !important;
  white-space: nowrap;
}

html[data-theme="dark"] .source-panel > .tabs-bar .tab {
  border: 1px solid rgba(255,255,255,.22);
  border-bottom: none;
  background: rgba(255,255,255,.06);
  color: rgba(234,241,255,.55);
}

.source-panel > .tabs-bar .tab svg {
  transition: transform .2s ease, opacity .2s ease !important;
}

.source-panel > .tabs-bar .tab:hover {
  background: rgba(36,78,156,.07);
  color: #244E9C;
}
.source-panel > .tabs-bar .tab:hover svg {
  transform: scale(1.15);
  opacity: 1;
}

.source-panel > .tabs-bar .tab.active {
  background: #EEF4FB;
  border: 1px solid #244E9C;
  border-bottom: none;
  color: #244E9C;
  font-weight: 700;
}

html[data-theme="dark"] .source-panel > .tabs-bar .tab.active {
  background: rgba(56,190,239,.12);
  border: 1px solid rgba(56,190,239,.55);
  border-bottom: none;
  color: #E5F7FF;
}

.source-panel > .tabs-bar .tab::after,
.source-panel > .tabs-bar .tab::before { display: none !important; }

/* 5. source-content scrolls */
.source-content {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  scroll-behavior: smooth;
}

.source-content::-webkit-scrollbar { width: 8px; }
.source-content::-webkit-scrollbar-track { background: transparent; }
.source-content::-webkit-scrollbar-thumb { background: rgba(36,78,156,.15); border-radius: 10px; }
html[data-theme="dark"] .source-content::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); }

/* ══ IBGE sections — padding igual ao CAGED/TSE ══ */
#panel-ibge .section {
  padding: 20px 24px 40px;
}

/* ══ IBGE tabs-bar (inside panel-ibge) — treated same as sub-panel tabs ══ */
#panel-ibge > .tabs-bar {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 10px 18px 0;
  background: #FFFFFF;
  border-bottom: 1px solid rgba(36,78,156,.10);
  flex-shrink: 0;
  flex-wrap: wrap;
}

html[data-theme="dark"] #panel-ibge > .tabs-bar {
  background: #244E9C;
  border-bottom-color: rgba(255,255,255,.10);
}

/* 6. Stab / ttab sections */
.stab-section,
.ttab-section {
  display: none;
  padding: 20px 24px 40px;
}

.stab-section.active,
.ttab-section.active {
  display: block;
  animation: fadeUp .28s cubic-bezier(.22,1,.36,1) both;
}

/* ══════════════════════════════════
   ANIMATIONS — applied globally
══════════════════════════════════ */

/* Section / panel content entrance — animation removed */
.censo-integrated .section.active {
  animation: none !important;
}

/* KPI cards stagger — animations removed */
.censo-integrated .kpi-card,
.sub-kpi-card {
  animation: none !important;
}
.censo-integrated .kpi-card:nth-child(1), .sub-kpi-card:nth-child(1) { animation-delay: 0s; }
.censo-integrated .kpi-card:nth-child(2), .sub-kpi-card:nth-child(2) { animation-delay: 0s; }
.censo-integrated .kpi-card:nth-child(3), .sub-kpi-card:nth-child(3) { animation-delay: 0s; }
.censo-integrated .kpi-card:nth-child(4), .sub-kpi-card:nth-child(4) { animation-delay: 0s; }
.censo-integrated .kpi-card:nth-child(5), .sub-kpi-card:nth-child(5) { animation-delay: 0s; }

/* Cards entrance */
.censo-integrated .card {
  animation: fadeUp .35s cubic-bezier(.22,1,.36,1) both;
  transition: transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s ease !important;
}
.censo-integrated .card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover, 0 14px 40px rgba(36,78,156,.15)) !important;
}

/* Grid children stagger */
.censo-integrated .grid-2 > .card:nth-child(1),
.sub-grid-2 > .card:nth-child(1) { animation-delay: .06s; }
.censo-integrated .grid-2 > .card:nth-child(2),
.sub-grid-2 > .card:nth-child(2) { animation-delay: .13s; }
.censo-integrated .grid-3 > .card:nth-child(1),
.sub-grid-3 > .card:nth-child(1) { animation-delay: .06s; }
.censo-integrated .grid-3 > .card:nth-child(2),
.sub-grid-3 > .card:nth-child(2) { animation-delay: .12s; }
.censo-integrated .grid-3 > .card:nth-child(3),
.sub-grid-3 > .card:nth-child(3) { animation-delay: .18s; }

/* Page title row */
.page-title-row {
  animation: slideInLeft .3s cubic-bezier(.22,1,.36,1) both;
  animation-delay: .02s;
}

/* Tab hover lift */
.censo-integrated .tabs-bar .tab {
  transition: background .18s ease, color .18s ease, transform .15s ease !important;
}
.censo-integrated .tabs-bar .tab:hover {
  transform: translateY(-1px);
}
.censo-integrated .tabs-bar .tab svg {
  transition: transform .2s ease !important;
}
.censo-integrated .tabs-bar .tab:hover svg {
  transform: scale(1.18);
}
.censo-integrated .tabs-bar .tab.active svg {
  opacity: 1;
}

/* KPI card hover */
.censo-integrated .kpi-card {
  transition: transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s ease !important;
}
.censo-integrated .kpi-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 40px rgba(36,78,156,.15) !important;
}

/* sub-kpi-card hover */
.sub-kpi-card {
  transition: transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s ease !important;
}
.sub-kpi-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 40px rgba(36,78,156,.15) !important;
}

/* Source-btn pulse on active indicator (omit no Atlas: contorno já marca o ativo) */
.source-switcher .source-btn.active::after {
  display: none !important;
}
.source-btn.active::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 24px; height: 2px;
  background: #244E9C;
  border-radius: 2px 2px 0 0;
  animation: fadeIn .3s ease both;
}

/* Donut slices */
.censo-integrated .donut-slice {
  transition: transform .2s ease, opacity .2s ease !important;
  transform-origin: 90px 90px;
}
.censo-integrated .donut-slice:hover {
  transform: scale(1.06);
  opacity: 1 !important;
}

/* Bar rows (SVG bars) */
.censo-integrated rect[data-bar] {
  transition: opacity .2s ease !important;
}
.censo-integrated rect[data-bar]:hover { opacity: 1 !important; }

/* ══ SUB-PANEL KPI CARDS ══ */
.sub-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}

@media (max-width:1200px) { .sub-kpi-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px) { .sub-kpi-grid { grid-template-columns: 1fr 1fr; } }

.sub-kpi-card {
  background: var(--card, #FFFFFF);
  border: 1px solid var(--border, rgba(36,78,156,.09));
  border-radius: 12px;
  padding: 0 18px 16px;
  box-shadow: var(--shadow, 0 4px 18px rgba(36,78,156,.08));
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.sub-kpi-accent {
  position: relative;
  left: -18px;
  width: calc(100% + 36px);
  height: 4px;
  border-radius: 0;
  margin-bottom: 12px;
  flex-shrink: 0;
}

.sub-kpi-label {
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  margin-bottom: 6px;
}

.sub-kpi-val {
  font-size: 24px;
  font-weight: 900;
  line-height: 1.1;
  font-family: Poppins, sans-serif;
  color: var(--text);
  margin-bottom: 6px;
}

.sub-kpi-detail { font-size: 11px; color: var(--muted); }

/* Sub-panel grids */
.sub-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.sub-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; margin-bottom: 16px; }

@media (max-width:1100px) {
  .sub-grid-2, .sub-grid-3 { grid-template-columns: 1fr; }
}

/* Delta badges */
.delta-pos { display:inline-block; background:rgba(36,78,156,.10); color:#244E9C; padding:2px 8px; border-radius:20px; font-weight:700; border:1px solid rgba(36,78,156,.15); }
.delta-neg { display:inline-block; background:rgba(36,78,156,.14); color:#244E9C; padding:2px 8px; border-radius:20px; font-weight:700; border:1px solid rgba(36,78,156,.15); }
.delta-neu { display:inline-block; background:rgba(36,78,156,.10); color:#244E9C; padding:2px 8px; border-radius:20px; font-weight:700; border:1px solid rgba(36,78,156,.18); }

.stab-section .page-title-row,
.ttab-section .page-title-row { margin-bottom: 16px; }

.mb14 { margin-bottom: 14px !important; }

/* ── Insight / analysis boxes ── */
.insight-box {
  background: #38BEEF;
  border: 1px solid rgba(36,78,156,.13);
  border-left: 3px solid #244E9C;
  border-radius: 0 10px 10px 0;
  padding: 11px 15px;
  margin-top: 14px;
  font-size: 11.5px;
  line-height: 1.6;
  color: var(--text);
}
.insight-box strong { color: #244E9C; font-weight: 700; }
html[data-theme="dark"] .insight-box {
  background: #1a1a1a;
  border-color: rgba(255,255,255,.12);
  border-left-color: rgba(255,255,255,.35);
}
html[data-theme="dark"] .insight-box strong { color: #f5f5f5; }

.insight-box .ib-row {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  margin-top: 7px;
}
.ib-stat {
  display: flex;
  flex-direction: column;
  min-width: 80px;
}
.ib-stat-val {
  font-size: 15px;
  font-weight: 800;
  color: #244E9C;
  line-height: 1.1;
}
html[data-theme="dark"] .ib-stat-val { color: #e8e8e8; }
.ib-stat-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-top: 1px;
}
.ib-divider {
  width: 1px;
  background: rgba(36,78,156,.15);
  align-self: stretch;
}

/* ══════════════════════════════════════════════════════
   CHART TOOLTIP — cursor-following card
══════════════════════════════════════════════════════ */
#chart-tooltip {
  position: fixed;
  z-index: 99999;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px) scale(.97);
  transition: opacity .14s ease, transform .14s ease;
  max-width: 240px;
}
#chart-tooltip.visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.tip-inner {
  background: var(--card, #FFFFFF);
  border: 1px solid rgba(36,78,156,.14);
  border-radius: 11px;
  padding: 10px 13px;
  box-shadow: 0 8px 32px rgba(36,78,156,.18), 0 2px 8px rgba(36,78,156,.10);
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-size: 11.5px;
  line-height: 1.5;
  color: var(--text, #244E9C);
  min-width: 140px;
}
html[data-theme="dark"] .tip-inner {
  background: #244E9C;
  border-color: rgba(56,190,239,.22);
  box-shadow: 0 8px 32px rgba(15,35,71,.45), 0 2px 8px rgba(15,35,71,.3);
  color: #244E9C;
}
.tip-label {
  font-weight: 700;
  font-size: 11px;
  color: var(--text, #244E9C);
  margin-bottom: 6px;
  padding-bottom: 5px;
  border-bottom: 1px solid rgba(36,78,156,.10);
}
html[data-theme="dark"] .tip-label {
  color: #244E9C;
  border-bottom-color: rgba(56,190,239,.15);
}
.tip-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 3px;
  font-size: 11.5px;
}
.tip-val {
  font-weight: 800;
  font-size: 14px;
  line-height: 1;
}
.tip-muted {
  color: var(--muted, #244E9C);
  font-size: 10.5px;
}

/* ── Bar row hover ── */
.ibar-row {
  cursor: default;
  user-select: none;
}

/* ── Donut legend hover ── */
.donut-leg-row {
  user-select: none;
}

/* ── IBGE SVG bar charts (pyramid, racial) hover ── */
.censo-integrated svg .bar-seg,
.censo-integrated svg rect:not(.tl-hit):not(.ttl-hit) {
  transition: opacity .15s ease;
}

/* ══════════════════════════════════════════════════════════════════
   INCRA — Imóveis Rurais · Panorama Municipal v9
   Estilo das sub-abas e seções (padrão CAGED/TSE)
══════════════════════════════════════════════════════════════════ */

/* ── Panel INCRA scrolls igual ao IBGE ── */
#panel-incra {
  overflow-y: auto;
  overflow-x: hidden;
}
#panel-incra::-webkit-scrollbar { width: 8px; }
#panel-incra::-webkit-scrollbar-track { background: transparent; }
#panel-incra::-webkit-scrollbar-thumb { background: rgba(36,78,156,.15); border-radius: 10px; }
html[data-theme="dark"] #panel-incra::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); }

/* ── Seções internas INCRA ── */
.itab-section {
  display: none;
  padding: 20px 24px 40px;
}
.itab-section.active {
  display: block;
  animation: fadeIn .22s ease both;
}

/* ── Pill chip estilo INCRA (reaproveitado no app.js) ── */
.incra-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  border: 1.5px solid rgba(36,78,156,.14);
  background: rgba(36,78,156,.06);
  color: rgba(36,78,156,.65);
  transition: background .15s, border-color .15s, color .15s, transform .12s;
}
.incra-pill:hover {
  background: rgba(36,78,156,.10);
  border-color: rgba(36,78,156,.25);
  color: #244E9C;
  transform: translateY(-1px);
}
.incra-pill.on {
  background: #244E9C;
  border-color: transparent;
  color: #FFFFFF;
}
html[data-theme="dark"] .incra-pill {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.16);
  color: rgba(255,255,255,.75);
}
html[data-theme="dark"] .incra-pill:hover {
  background: rgba(56,190,239,.12);
  border-color: rgba(56,190,239,.30);
  color: #244E9C;
}
html[data-theme="dark"] .incra-pill.on {
  background: #244E9C;
  border-color: transparent;
  color: #FFFFFF;
}

/* ══════════════════════════════════════════════════════════════════
   SAÚDE APS — e-SUS · Panorama Municipal v9
══════════════════════════════════════════════════════════════════ */

#panel-saude { overflow-y:auto; overflow-x:hidden; }
#panel-saude::-webkit-scrollbar { width:8px; }
#panel-saude::-webkit-scrollbar-track { background:transparent; }
#panel-saude::-webkit-scrollbar-thumb { background:rgba(36,78,156,.15); border-radius:10px; }
html[data-theme="dark"] #panel-saude::-webkit-scrollbar-thumb { background:rgba(255,255,255,.12); }

.sautab-section { display:none; padding:20px 24px 40px; }
.sautab-section.active { display:block; animation:fadeIn .22s ease both; }

/* Sub-abas brancas */
#panel-saude .tabs-bar { display:flex; align-items:flex-end; padding:0 18px; background:#FFFFFF; border-bottom:1px solid rgba(36,78,156,.10); overflow-x:auto; scrollbar-width:none; flex-shrink:0; }
#panel-saude .tabs-bar::-webkit-scrollbar { display:none; }
html[data-theme="dark"] #panel-saude .tabs-bar { background:#0a0a0a; border-bottom-color:rgba(255,255,255,.10); }
#panel-saude .tab[data-sautab] { display:inline-flex; align-items:center; gap:7px; padding:13px 18px; border:1px solid transparent; border-bottom:none; border-radius:10px 10px 0 0; background:transparent; color:rgba(36,78,156,.50); font-family:inherit; font-size:13px; font-weight:600; cursor:pointer; position:relative; bottom:-1px; transition:background .18s,color .18s,border-color .18s; white-space:nowrap; }
#panel-saude .tab[data-sautab] svg { flex-shrink:0; opacity:.55; transition:opacity .15s; }
#panel-saude .tab[data-sautab]:hover { background:rgba(36,78,156,.07); color:#244E9C; }
#panel-saude .tab[data-sautab]:hover svg { opacity:.9; }
#panel-saude .tab[data-sautab].active { background:#F0F4FB; border-color:rgba(36,78,156,.12); color:#244E9C; font-weight:700; }
#panel-saude .tab[data-sautab].active svg { opacity:1; }
html[data-theme="dark"] #panel-saude .tab[data-sautab] { color:rgba(255,255,255,.45); }
html[data-theme="dark"] #panel-saude .tab[data-sautab]:hover { background:rgba(255,255,255,.08); color:#f5f5f5; }
html[data-theme="dark"] #panel-saude .tab[data-sautab].active { background:#ffffff; border-color:rgba(255,255,255,.12); color:#0a0a0a; }

/* Grid 12 colunas */
#panel-saude .sau-g { display:grid; grid-template-columns:repeat(12,1fr); gap:14px; margin-bottom:14px; }

/* Card azul */
#panel-saude .sau-card { border-radius:16px; border:1px solid rgba(255,255,255,.14); background:var(--card,#244E9C); color:#FFFFFF; overflow:hidden; box-shadow:0 4px 22px rgba(36,78,156,.12); transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s,border-color .18s; will-change:transform; }
#panel-saude .sau-card:hover { transform:translateY(-4px) scale(1.012); box-shadow:0 22px 52px rgba(36,78,156,.32); border-color:rgba(255,255,255,.28); z-index:2; }

/* Card branco */
#panel-saude .sau-card-w { border-radius:16px; border:1px solid rgba(36,78,156,.10); background:#FFFFFF; color:var(--text,#244E9C); overflow:hidden; box-shadow:0 2px 14px rgba(36,78,156,.07); transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s,border-color .18s; }
#panel-saude .sau-card-w:hover { transform:translateY(-4px) scale(1.012); box-shadow:0 18px 44px rgba(36,78,156,.14); border-color:rgba(36,78,156,.18); z-index:2; }
html[data-theme="dark"] #panel-saude .sau-card-w { background:#161616; border-color:rgba(255,255,255,.12); color:#f5f5f5; }
html[data-theme="dark"] #panel-saude .sau-card-w:hover { border-color:rgba(255,255,255,.22); }

/* Card internals */
#panel-saude .sau-ch { position:relative; width:100%; }
#panel-saude .sau-card-h { padding:14px 16px 10px; display:flex; align-items:flex-start; justify-content:space-between; gap:10px; flex-wrap:wrap; }
#panel-saude .sau-card-t { font-weight:800; font-size:14px; letter-spacing:-.01em; color:#FFFFFF; }
#panel-saude .sau-card-s { font-size:11px; color:rgba(255,255,255,.62); margin-top:3px; line-height:1.4; }
#panel-saude .sau-card-w .sau-card-t { color:#244E9C; }
#panel-saude .sau-card-w .sau-card-s { color:rgba(36,78,156,.55); }
html[data-theme="dark"] #panel-saude .sau-card-w .sau-card-t { color:#FFFFFF; }
html[data-theme="dark"] #panel-saude .sau-card-w .sau-card-s { color:rgba(255,255,255,.60); }
#panel-saude .sau-card-b { padding:0 16px 14px; }

/* KPI strip */
#panel-saude .sau-kpi-strip { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-bottom:14px; }
@media(max-width:1200px){#panel-saude .sau-kpi-strip{grid-template-columns:repeat(3,1fr);}}
@media(max-width:780px) {#panel-saude .sau-kpi-strip{grid-template-columns:repeat(2,1fr);}}
#panel-saude .sau-kc { border-radius:16px; border:1px solid rgba(255,255,255,.16); background:#244E9C; color:#FFFFFF; padding:16px; overflow:hidden; position:relative; transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s; will-change:transform; }
#panel-saude .sau-kc:hover { transform:translateY(-5px) scale(1.02); box-shadow:0 24px 56px rgba(36,78,156,.38); }
#panel-saude .sau-kc::after { content:''; position:absolute; top:-40px; right:-40px; width:120px; height:120px; border-radius:50%; background:rgba(255,255,255,.04); pointer-events:none; }
#panel-saude .sau-kc-ico { width:36px; height:36px; border-radius:12px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); display:grid; place-items:center; margin-bottom:12px; }
#panel-saude .sau-kc-v { font-size:26px; font-weight:900; line-height:1; letter-spacing:-.03em; color:#FFFFFF; }
#panel-saude .sau-kc-l { font-size:11px; color:rgba(255,255,255,.68); margin-top:6px; font-weight:500; }
#panel-saude .sau-kc-d { display:inline-flex; align-items:center; font-size:10px; font-weight:700; padding:3px 9px; border-radius:999px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.20); margin-top:8px; color:#244E9C; }

/* Highlight */
#panel-saude .sau-hi { border-radius:14px; padding:11px 14px; background:rgba(56,190,239,.07); border:1px solid rgba(56,190,239,.18); display:flex; gap:10px; align-items:flex-start; margin-bottom:14px; transition:box-shadow .2s,border-color .2s; }
#panel-saude .sau-hi:hover { box-shadow:0 4px 18px rgba(56,190,239,.12); border-color:rgba(56,190,239,.30); }
html[data-theme="light"] #panel-saude .sau-hi { background:rgba(36,78,156,.05); border-color:rgba(36,78,156,.14); }
#panel-saude .sau-hi-i { font-size:16px; flex-shrink:0; }
#panel-saude .sau-hi-t { font-size:12px; color:rgba(255,255,255,.68); line-height:1.6; }
html[data-theme="light"] #panel-saude .sau-hi-t { color:rgba(36,78,156,.65); }
#panel-saude .sau-hi-t strong { color:#FFFFFF; }
html[data-theme="light"] #panel-saude .sau-hi-t strong { color:#244E9C; }

/* Pills */
#panel-saude .sau-pills { display:flex; gap:6px; flex-wrap:wrap; }
#panel-saude .sau-pill { height:28px; border-radius:999px; padding:0 11px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.08); color:#FFFFFF; font-size:11px; font-weight:600; cursor:pointer; font-family:inherit; transition:background .15s,transform .10s; }
#panel-saude .sau-pill:hover { background:rgba(255,255,255,.18); transform:translateY(-1px); }
#panel-saude .sau-pill.on { background:rgba(56,190,239,.20); border-color:rgba(56,190,239,.50); color:#244E9C; }

/* Chips */
#panel-saude .sau-chips { display:flex; gap:6px; flex-wrap:wrap; }
#panel-saude .sau-chip { padding:5px 12px; border-radius:999px; border:1.5px solid rgba(255,255,255,.18); background:rgba(255,255,255,.07); cursor:pointer; user-select:none; font-weight:700; font-size:11px; color:rgba(255,255,255,.80); transition:all .15s; font-family:inherit; }
#panel-saude .sau-chip:hover { background:rgba(255,255,255,.15); transform:translateY(-1px); }
#panel-saude .sau-chip.on { background:rgba(56,190,239,.18); border-color:rgba(56,190,239,.50); color:#244E9C; }
#panel-saude .sau-card-w .sau-chip { background:rgba(36,78,156,.06); border-color:rgba(36,78,156,.14); color:#244E9C; }
#panel-saude .sau-card-w .sau-chip.on { background:#244E9C; border-color:transparent; color:#FFFFFF; }

/* Filter bar */
#panel-saude .sau-filter-bar { display:flex; align-items:center; gap:10px; flex-wrap:wrap; padding:10px 14px; border-radius:14px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); margin-bottom:14px; }
html[data-theme="light"] #panel-saude .sau-filter-bar { background:rgba(36,78,156,.04); border-color:rgba(36,78,156,.10); }
#panel-saude .sau-filter-lbl { font-size:11px; font-weight:700; color:rgba(255,255,255,.50); text-transform:uppercase; letter-spacing:.06em; flex-shrink:0; }
html[data-theme="light"] #panel-saude .sau-filter-lbl { color:rgba(36,78,156,.40); }
#panel-saude .sau-fsel { height:30px; padding:0 10px; border-radius:8px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.10); color:#FFFFFF; font-size:11px; font-family:inherit; cursor:pointer; min-width:130px; }
html[data-theme="light"] #panel-saude .sau-fsel { background:#FFFFFF; border-color:rgba(36,78,156,.18); color:#244E9C; }
#panel-saude .sau-fsel:focus { outline:2px solid rgba(56,190,239,.50); }
#panel-saude .sau-filter-reset { height:28px; padding:0 12px; border-radius:999px; border:1px solid rgba(255,255,255,.20); background:rgba(255,255,255,.08); color:rgba(255,255,255,.70); font-size:10px; font-weight:700; cursor:pointer; font-family:inherit; transition:all .15s; letter-spacing:.04em; }
#panel-saude .sau-filter-reset:hover { background:rgba(56,190,239,.15); border-color:rgba(56,190,239,.40); color:#244E9C; }
html[data-theme="light"] #panel-saude .sau-filter-reset { border-color:rgba(36,78,156,.15); background:rgba(36,78,156,.05); color:rgba(36,78,156,.55); }

/* Bars */
#panel-saude .sau-bars { display:flex; flex-direction:column; gap:7px; }
#panel-saude .sau-br { display:flex; align-items:center; gap:8px; }
#panel-saude .sau-bl { font-size:10px; color:rgba(255,255,255,.55); width:90px; text-align:right; flex-shrink:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#panel-saude .sau-bt { flex:1; background:rgba(255,255,255,.08); border-radius:4px; height:18px; overflow:hidden; }
#panel-saude .sau-bf { height:100%; border-radius:4px; display:flex; align-items:center; padding:0 7px; transition:width .65s cubic-bezier(.4,0,.2,1); }
#panel-saude .sau-bf span { font-size:10px; font-weight:600; color:rgba(255,255,255,.90); white-space:nowrap; }
#panel-saude .sau-card-w .sau-bl { color:rgba(36,78,156,.50); }
#panel-saude .sau-card-w .sau-bt { background:rgba(36,78,156,.07); }
#panel-saude .sau-card-w .sau-bf span { color:rgba(36,78,156,.85); }

/* Donut legend */
#panel-saude .sau-dleg { display:grid; grid-template-columns:1fr 1fr; gap:4px 10px; width:100%; }
#panel-saude .sau-dli { display:flex; align-items:center; gap:6px; font-size:11px; padding:2px 4px; border-radius:6px; cursor:default; min-width:0; }
#panel-saude .sau-dli:hover { background:rgba(255,255,255,.06); }
#panel-saude .sau-dld { width:9px; height:9px; border-radius:2px; flex-shrink:0; }
#panel-saude .sau-dln { flex:1; color:rgba(255,255,255,.65); font-size:10px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#panel-saude .sau-dlp { font-weight:800; font-size:11px; flex-shrink:0; }
#panel-saude .sau-card-w .sau-dln { color:rgba(36,78,156,.55); }

/* Table */
#panel-saude .sau-tbl { width:100%; border-collapse:collapse; font-size:11px; }
#panel-saude .sau-tbl th { font-size:10px; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.45); font-weight:600; padding:6px 8px; border-bottom:1px solid rgba(255,255,255,.10); text-align:left; }
#panel-saude .sau-tbl td { padding:8px 8px; border-bottom:1px solid rgba(255,255,255,.05); color:rgba(255,255,255,.88); }
#panel-saude .sau-tbl tr:last-child td { border-bottom:none; }
#panel-saude .sau-tbl tr:hover td { background:rgba(255,255,255,.04); }
#panel-saude .sau-tbl .n { font-weight:700; text-align:right; }
#panel-saude .sau-ds { width:8px; height:8px; border-radius:2px; display:inline-block; margin-right:5px; vertical-align:middle; }
#panel-saude .sau-card-w .sau-tbl th { color:rgba(36,78,156,.40); }
#panel-saude .sau-card-w .sau-tbl td { color:rgba(36,78,156,.85); }
#panel-saude .sau-card-w .sau-tbl td,#panel-saude .sau-card-w .sau-tbl th { border-bottom-color:rgba(36,78,156,.07); }
#panel-saude .sau-card-w .sau-tbl tr:hover td { background:rgba(36,78,156,.03); }

/* Progress */
#panel-saude .sau-plist { display:flex; flex-direction:column; gap:9px; }
#panel-saude .sau-prow { display:flex; align-items:center; gap:8px; }
#panel-saude .sau-plbl { font-size:10px; color:rgba(255,255,255,.58); width:110px; flex-shrink:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
#panel-saude .sau-pbar { flex:1; height:6px; background:rgba(255,255,255,.08); border-radius:4px; overflow:hidden; }
#panel-saude .sau-pfill { height:100%; border-radius:4px; transition:width .65s cubic-bezier(.4,0,.2,1); }
#panel-saude .sau-pval { font-size:10px; color:rgba(255,255,255,.55); min-width:52px; text-align:right; }
#panel-saude .sau-card-w .sau-plbl { color:rgba(36,78,156,.55); }
#panel-saude .sau-card-w .sau-pbar { background:rgba(36,78,156,.07); }
#panel-saude .sau-card-w .sau-pval { color:rgba(36,78,156,.50); }

/* Stacked band */
#panel-saude .sau-sband { display:flex; gap:2px; height:26px; border-radius:10px; overflow:hidden; margin:6px 0; }
#panel-saude .sau-sseg { display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:700; color:rgba(255,255,255,.85); }

/* CID/CIAP badges */
#panel-saude .sau-ciap { display:inline-flex; align-items:center; gap:5px; padding:3px 9px; border-radius:999px; font-size:10px; font-weight:700; background:rgba(71,171,52,.18); border:1px solid rgba(71,171,52,.35); color:#47AB34; }
#panel-saude .sau-cid  { display:inline-flex; align-items:center; gap:5px; padding:3px 9px; border-radius:999px; font-size:10px; font-weight:700; background:rgba(36,78,156,.10); border:1px solid rgba(36,78,156,.18); color:#244E9C; }

/* Responsive */
@media(max-width:1100px){#panel-saude .sau-g{grid-template-columns:1fr 1fr !important;}}
@media(max-width:780px) {#panel-saude .sau-g{grid-template-columns:1fr !important;}}

.mid-data-grid{
  display:grid;
  gap:10px;
  margin:12px 0 14px;
}
.mid-data-row{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:10px 12px;
  border:1px solid rgba(36,78,156,.10);
  border-radius:12px;
  background:#F8FAFC;
}
.mid-data-row span{
  font-size:11px;
  color:#244E9C;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.mid-data-row strong{
  font-size:14px;
  color:#244E9C;
  font-weight:700;
  word-break:break-word;
}

/* ══════════════════════════════════════════════════════════
   MAPA — layout sem scroll, tudo cabe na tela
   ══════════════════════════════════════════════════════════ */
.content:has(.map-page) {
  overflow: hidden !important;
  padding: 0 !important;
  gap: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}
.map-page {
  flex: 1 !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 300px !important;
  grid-template-rows: 1fr !important;
  gap: 12px !important;
  padding: 14px 18px !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.map-card-wrap {
  grid-column: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
.map-card-wrap > .card,
.map-card-wrap .map-card-fixed {
  flex: 1 !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
.map-card-wrap .map-frame-wrap {
  flex: 1 !important;
  min-height: 0 !important;
  height: auto !important;
  position: relative !important;
}
.map-card-wrap .map-frame-wrap iframe {
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  display: block !important;
}
/* iframe wrap — altura controlada pelo flex */
.map-frame-wrap { position: relative; }

/* ── CONTROLS ── */
.map-controls {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: stretch;
}

/* ══ ABA MAPA NO DASHBOARD ══ */
#panel-ibge:has(#sec-mapa.active) {
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa {
  flex: 1 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  animation: none !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .dash-map-section {
  flex: 1 !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: 1fr 460px !important;
  grid-template-rows: 1fr !important;
  gap: 12px !important;
  padding: 12px 18px !important;
  align-items: stretch !important;
  overflow: hidden !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .dash-map-col {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .map-card-fixed {
  flex: 1 !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .map-frame-wrap {
  flex: 1 !important;
  min-height: 0 !important;
  height: auto !important;
  position: relative !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .map-frame-wrap iframe {
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .dash-map-controls {
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  gap: 12px !important;
}
#panel-ibge:has(#sec-mapa.active) #sec-mapa .dash-map-controls .map-controls {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  flex: 1 !important;
  min-height: 0 !important;
}

/* ══ SEM HOVER GROW NO CARD DO MAPA ══ */
#sec-mapa .map-card-fixed,
#sec-mapa .map-card-fixed:hover,
#sec-mapa .dash-map-col .card,
#sec-mapa .dash-map-col .card:hover {
  transform: none !important;
  box-shadow: none !important;
  transition: none !important;
  cursor: default !important;
}

/* ══ CARD UNIFICADO (mapCard1) ══ */
#mapCard1 {
  /* Tamanho natural — não cresce além do conteúdo */
  flex: 0 0 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  padding: 0 !important;
}
#mapCard2 {
  display: none !important;
  flex: 0 !important;
}
#mapCard3 {
  flex: 0 0 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  height: auto !important;
}
/* Lista dentro do card — altura automática + scroll */
#mapCard1 .map-layers-list {
  flex: 0 0 auto !important;
  height: auto !important;
  max-height: 240px !important;
  overflow-y: auto !important;
  padding: 8px 12px 10px !important;
}
#mapCard1 .map-ctrl-header {
  flex-shrink: 0 !important;
  border-bottom: none !important;
  padding: 14px 18px 10px !important;
}
#mapCard1 .map-ctrl-divider {
  flex-shrink: 0 !important;
  height: 1px !important;
  background: rgba(36,78,156,.07) !important;
  margin: 0 !important;
  display: block !important;
}

/* ══ BOTÃO TRIGGER CATEGORIA ══ */
.map-cat-trigger {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 12px 6px 10px;
  border-radius: 999px;
  border: 1.5px solid rgba(36,78,156,.14);
  background: var(--surface, #F8FAFC);
  color: var(--pm-accent, #244E9C);
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(15,35,71,.06);
}
.map-cat-trigger:hover {
  border-color: var(--pm-accent, #244E9C);
  background: rgba(36,78,156,.05);
}
.map-cat-trigger.active {
  border-color: var(--pm-accent, #244E9C);
  background: var(--pm-accent, #244E9C);
  color: #FFFFFF;
  box-shadow: 0 4px 12px rgba(36,78,156,.25);
}
.map-cat-trigger svg { transition: transform .2s; flex-shrink: 0; }
.map-cat-trigger.active svg:last-child { transform: rotate(180deg); }

/* ══ DROPDOWN FLUTUANTE ══ */
.map-cat-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 999;
  min-width: 210px;
  max-height: 320px;
  background: #FFFFFF;
  border: 1px solid rgba(36,78,156,.10);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(36,78,156,.14);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px) scale(.97);
  transition: opacity .18s, transform .18s;
}
.map-cat-dropdown.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}
html[data-theme="dark"] .map-cat-dropdown {
  background: #244E9C;
  border-color: rgba(255,255,255,.10);
}
.map-cat-dropdown::before {
  content: 'Selecione uma categoria';
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted, #244E9C);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 10px 14px 6px;
  flex-shrink: 0;
}
.map-cat-dropdown-list {
  display: flex;
  flex-direction: column;
  padding: 4px 6px 6px;
  gap: 2px;
  overflow-y: auto;
  border-top: 1px solid rgba(36,78,156,.07);
}
.map-cat-dropdown-list::-webkit-scrollbar { width: 5px; }
.map-cat-dropdown-list::-webkit-scrollbar-thumb { background: rgba(36,78,156,.15); border-radius: 999px; }
.map-cat-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 9px 12px;
  border-radius: 9px;
  border: none;
  background: transparent;
  color: var(--fg, #244E9C);
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  transition: background .12s;
  width: 100%;
}
.map-cat-item:hover { background: rgba(36,78,156,.07); color: var(--pm-accent, #244E9C); }
.map-cat-item.on { background: rgba(36,78,156,.10); color: var(--pm-accent, #244E9C); font-weight: 700; }
.map-cat-item .item-check { margin-left: auto; flex-shrink: 0; }
html[data-theme="dark"] .map-cat-item { color: rgba(255,255,255,.80); }
html[data-theme="dark"] .map-cat-item:hover,
html[data-theme="dark"] .map-cat-item.on { background: rgba(255,255,255,.08); color: #FFFFFF; }

#mapCard1 .map-layers-list { max-height: 310px !important; }

/* Dropdown não cortado pelo card pai */
#mapCard1 { overflow: visible !important; }
#mapCard1 .map-ctrl-header { overflow: visible !important; position: relative; z-index: 100; }
.map-cat-dropdown { z-index: 9999 !important; }

/* Campo de busca no dropdown */
.map-cat-search-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-bottom: 1px solid rgba(36,78,156,.07);
  flex-shrink: 0;
}
.map-cat-search-wrap svg { flex-shrink: 0; color: var(--muted, #244E9C); }
.map-cat-search {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-size: 13px;
  color: var(--fg, #244E9C);
}
.map-cat-search::placeholder { color: var(--muted, #244E9C); }
html[data-theme="dark"] .map-cat-search { color: #FFFFFF; }

/* ══ INDICADORES — layout dados + imagem ══ */
.mid-feature-layout {
  display: flex;
  gap: 12px;
  padding: 12px 14px;
  align-items: flex-start;
}
.mid-data-col {
  flex: 1;
  min-width: 0;
}
.mid-img-col {
  flex-shrink: 0;
  width: 130px;
}
.map-info-detail-feature .mid-img-col{
  min-width:0;
  align-self:stretch;
}
/* Nome do local em destaque acima da imagem */
.mid-local-name {
  font-size: 13px;
  font-weight: 800;
  line-height: 1.3;
  color: var(--accent, #244E9C);
  margin-bottom: 8px;
  letter-spacing: -.1px;
}
html[data-theme="dark"] .mid-local-name {
  color: #244E9C;
}

.mid-img-card {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border, rgba(36,78,156,.10));
  background: var(--surface, #F8FAFC);
  width: 130px;
}
.pm-map-image-trigger{
  display:block;
  width:100%;
  max-width:100%;
  margin:0;
  padding:0;
  box-sizing:border-box;
  border-radius:18px;
  overflow:hidden;
  -webkit-appearance:none;
  appearance:none;
  cursor:pointer;
  text-align:center;
}
.pm-map-image-trigger:hover .pm-map-image-overlay,
.pm-map-image-trigger:focus-visible .pm-map-image-overlay{
  opacity:1;
}
.pm-map-image-overlay{
  position:absolute;
  left:0;
  top:0;
  right:0;
  bottom:0;
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:12px;
  background:#244E9C;
  color:#FFFFFF;
  font-size:12px;
  font-weight:800;
  letter-spacing:.02em;
  text-align:center;
  opacity:0;
  transition:opacity .2s ease;
  box-sizing:border-box;
  min-width:0;
  pointer-events:none;
}
.pm-map-image-overlay > span{
  flex:none;
  width:auto;
  max-width:calc(100% - 8px);
  margin:0;
  padding:8px 14px;
  border-radius:12px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.26);
  backdrop-filter:blur(8px);
  white-space:normal;
  line-height:1.25;
  word-break:break-word;
  overflow-wrap:anywhere;
  box-sizing:border-box;
  display:block;
  text-align:center;
}
.mid-img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  display: block;
}
.mid-img-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 120px;
  padding: 12px;
  color: var(--muted, #244E9C);
  text-align: center;
}
.mid-img-empty svg { opacity: .5; }
.mid-img-empty span {
  font-size: 11px;
  line-height: 1.35;
}

/* Data grid mais compacto */
.mid-data-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 0;
  border-bottom: 1px solid rgba(36,78,156,.05);
}
.mid-data-row:last-child { border-bottom: none; }
.mid-data-row span {
  font-size: 9px;
  color: var(--muted, #244E9C);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 600;
}
.mid-data-row strong {
  font-size: 13px;
  color: var(--fg, #244E9C);
  font-weight: 600;
  word-break: break-word;
}
html[data-theme="dark"] .mid-data-row strong { color: #FFFFFF; }
/* ===== Ajuste mapa: detalhe do ponto dentro do card Indicadores ===== */
#mapCard3{
  display:flex !important;
  flex-direction:column !important;
  min-height:0 !important;
}
#mapCard3 .map-info-panel{
  flex:1 1 auto !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overscroll-behavior:contain;
  scrollbar-gutter:stable;
}
#mapCard3 .map-info-panel::-webkit-scrollbar{
  width:8px;
}
#mapCard3 .map-info-panel::-webkit-scrollbar-thumb{
  background:rgba(36,78,156,.22);
  border-radius:999px;
}
.map-info-detail-feature{
  padding-bottom:4px;
}
.map-info-detail-feature .mid-title-bar{
  position:sticky;
  top:0;
  z-index:2;
  background:inherit;
  padding-bottom:8px;
}
.mid-feature-layout{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:0;
}
.mid-img-col,
.mid-img-card{
  width:100%;
}
.mid-img{
  width:100%;
  height:180px;
  object-fit:cover;
}
.mid-img-empty{
  height:160px;
}
.pm-image-lightbox{
  position:fixed;
  inset:0;
  z-index:12000;
  display:none;
}
.pm-image-lightbox.open{
  display:block;
}
.pm-image-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(42px);
  -webkit-backdrop-filter:blur(42px);
}
.pm-image-lightbox-dialog{
  position:absolute;
  inset:4vh 4vw;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}
.pm-image-lightbox-img{
  max-width:100%;
  max-height:100%;
  border-radius:24px;
  box-shadow:0 24px 60px rgba(36,78,156,.34);
  object-fit:contain;
  pointer-events:auto;
  background:#FFFFFF;
}
.pm-image-lightbox-close{
  position:absolute;
  top:10px;
  right:10px;
  width:42px;
  height:42px;
  border:0;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.62);
  color:#FFFFFF;
  cursor:pointer;
  box-shadow:0 10px 30px rgba(0,0,0,.28);
  pointer-events:auto;
}
.pm-image-lightbox-close:hover{
  background:rgba(0,0,0,.82);
}
body.pm-image-lightbox-open{
  overflow:hidden;
}
.mid-data-grid{
  margin:0;
  gap:8px;
}
.mid-data-row{
  padding:10px 12px;
  border:1px solid rgba(36,78,156,.10);
  border-radius:12px;
  background:#F8FAFC;
}
html[data-theme="dark"] .mid-data-row{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.10);
}
html[data-theme="dark"] .map-info-detail-feature .mid-title-bar{
  background:#244E9C;
}
html[data-theme="light"] .map-info-detail-feature .mid-title-bar{
  background:#FFFFFF;
}

/* ── OVERRIDE FINAL: card Indicadores sempre com altura do mapa ── */
/* Colocado no final para garantir precedência sobre todos os blocos anteriores */

.dash-map-section {
  display: grid !important;
  grid-template-columns: 3fr 1fr !important;
  gap: 14px !important;
  align-items: stretch !important;
}

.dash-map-col {
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.dash-map-controls {
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-self: stretch !important;
}

.dash-map-controls .map-controls {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  gap: 0 !important;
}

#mapCard3 {
  flex: 1 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

#mapCard3 #mapInfoPanel {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
}

/* ── Botões dentro da barra azul do card do mapa ── */
/* Satélite e Tela cheia voltam ao estilo branco original */
.map-card-top-bar .sat-toggle-btn {
  padding: 8px 14px !important;
  border: 1.5px solid rgba(255,255,255,.28) !important;
  background: rgba(255,255,255,.12) !important;
  color: #FFFFFF !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  backdrop-filter: blur(8px) !important;
}
.map-card-top-bar .sat-toggle-btn:hover {
  background: rgba(255,255,255,.22) !important;
  border-color: rgba(255,255,255,.50) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(15,35,71,.22) !important;
}
.map-card-top-bar .sat-toggle-btn.active {
  background: rgba(56,190,239,.28) !important;
  border-color: rgba(56,190,239,.70) !important;
  color: #244E9C !important;
  box-shadow: 0 0 20px rgba(56,190,239,.30) !important;
}
.map-card-top-bar .map-fullscreen-btn {
  padding: 8px 14px !important;
  border: 1.5px solid rgba(255,255,255,.20) !important;
  background: rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.90) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}
.map-card-top-bar .map-fullscreen-btn:hover {
  background: rgba(255,255,255,.20) !important;
  border-color: rgba(255,255,255,.40) !important;
  transform: translateY(-1px) !important;
}

/* ── Botão Camadas dentro da barra azul ── */
.map-tb-btn-inbar {
  padding: 8px 14px !important;
  border: 1.5px solid rgba(255,255,255,.30) !important;
  background: rgba(255,255,255,.14) !important;
  color: #FFFFFF !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border-radius: 12px !important;
  backdrop-filter: blur(8px) !important;
}
.map-tb-btn-inbar:hover {
  background: rgba(255,255,255,.24) !important;
  border-color: rgba(255,255,255,.55) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 14px rgba(15,35,71,.22) !important;
}
.map-tb-btn-inbar.active {
  background: rgba(56,190,239,.24) !important;
  border-color: rgba(56,190,239,.65) !important;
  color: #244E9C !important;
  box-shadow: 0 0 18px rgba(56,190,239,.25) !important;
}
.map-tb-btn-inbar .map-tb-badge {
  background: rgba(255,255,255,.25) !important;
  color: #FFFFFF !important;
}
.map-tb-btn-inbar.active .map-tb-badge {
  background: rgba(56,190,239,.30) !important;
  color: #244E9C !important;
}
/* Popup do botão Camadas dentro da barra azul abre para baixo */
#tbWrapLayers .map-tb-popup {
  top: calc(100% + 10px) !important;
  left: 0 !important;
  z-index: 600 !important;
}

/* ── Remover padding-top da seção mapa — estica até o topo ── */
#sec-mapa {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
.dash-map-section {
  margin-top: 0 !important;
}
/* map-toolbar-row não existe mais — garantia */
.map-toolbar-row {
  display: none !important;
}

/* ── Fix popup Camadas: texto visível + scroll interno ────────── */

/* Forçar altura máxima e scroll no popup de camadas */
.map-tb-layers-list {
  max-height: 340px !important;
  overflow-y: auto !important;
  padding: 0 10px 12px !important;
}

/* Corrigir cores dos itens dentro do popup (fundo claro/surface) */
.map-tb-popup .map-layer-row {
  background: var(--surface, #F8FAFC) !important;
  border: 1.5px solid var(--border, rgba(36,78,156,.10)) !important;
  color: var(--text, #244E9C) !important;
}
.map-tb-popup .map-layer-row:hover {
  background: rgba(36,78,156,.06) !important;
  border-color: rgba(36,78,156,.20) !important;
  transform: translateX(2px) !important;
}
.map-tb-popup .map-layer-row.focused {
  background: rgba(36,78,156,.08) !important;
  border-color: rgba(36,78,156,.30) !important;
}
.map-tb-popup .mlr-title {
  color: var(--text, #244E9C) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}
.map-tb-popup .mlr-sub {
  color: var(--muted, #244E9C) !important;
  opacity: 1 !important;
  font-size: 11px !important;
}
.map-tb-popup .mlr-status-dot.vis {
  background: var(--pm-accent, #244E9C) !important;
  box-shadow: 0 0 6px rgba(36,78,156,.40) !important;
}
.map-tb-popup .mlr-status-dot.hid {
  background: #EFF6FF !important;
}

/* Toggle dentro do popup */
.map-tb-popup .map-toggle-track {
  background: #244E9C !important;
  border-color: rgba(36,78,156,.18) !important;
}
.map-tb-popup .map-toggle input:checked ~ .map-toggle-track {
  background: var(--pm-accent, #244E9C) !important;
  border-color: var(--pm-accent, #244E9C) !important;
}
.map-tb-popup .map-toggle-thumb {
  background: #244E9C !important;
}
.map-tb-popup .map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb {
  background: #FFFFFF !important;
  transform: translateX(16px) !important;
}

/* Busca de categoria dentro do popup */
.map-tb-popup .map-cat-trigger {
  color: var(--text, #244E9C) !important;
  background: var(--surface, #F8FAFC) !important;
  border-color: var(--border, rgba(36,78,156,.12)) !important;
}
.map-tb-popup .map-cat-trigger:hover {
  border-color: var(--pm-accent, #244E9C) !important;
}

/* ── Fix DEFINITIVO popup Camadas — especificidade máxima ─────── */
html .map-tb-popup .map-layer-row {
  background: #FFFFFF !important;
  border: 1.5px solid rgba(36,78,156,.10) !important;
}
html[data-theme="light"] .map-tb-popup .map-layer-row,
html[data-theme="dark"]  .map-tb-popup .map-layer-row {
  background: #FFFFFF !important;
  border: 1.5px solid rgba(36,78,156,.10) !important;
}
html[data-theme="light"] .map-tb-popup .map-layer-row:hover,
html[data-theme="dark"]  .map-tb-popup .map-layer-row:hover {
  background: #F1F5F9 !important;
  border-color: rgba(36,78,156,.22) !important;
}
html[data-theme="light"] .map-tb-popup .mlr-title,
html[data-theme="dark"]  .map-tb-popup .mlr-title {
  color: #244E9C !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}
html[data-theme="light"] .map-tb-popup .mlr-sub,
html[data-theme="dark"]  .map-tb-popup .mlr-sub {
  color: #244E9C !important;
  opacity: 1 !important;
}
html[data-theme="light"] .map-tb-popup .mlr-status-dot.hid,
html[data-theme="dark"]  .map-tb-popup .mlr-status-dot.hid {
  background: #EFF6FF !important;
}
html[data-theme="light"] .map-tb-popup .mlr-status-dot.vis,
html[data-theme="dark"]  .map-tb-popup .mlr-status-dot.vis {
  background: #244E9C !important;
  box-shadow: 0 0 6px rgba(36,78,156,.35) !important;
}
html[data-theme="light"] .map-tb-popup .map-toggle-track,
html[data-theme="dark"]  .map-tb-popup .map-toggle-track {
  background: #244E9C !important;
  border-color: rgba(36,78,156,.18) !important;
}
html[data-theme="light"] .map-tb-popup .map-toggle input:checked ~ .map-toggle-track,
html[data-theme="dark"]  .map-tb-popup .map-toggle input:checked ~ .map-toggle-track {
  background: #244E9C !important;
  border-color: #244E9C !important;
}
html[data-theme="light"] .map-tb-popup .map-toggle-thumb,
html[data-theme="dark"]  .map-tb-popup .map-toggle-thumb {
  background: #244E9C !important;
}
html[data-theme="light"] .map-tb-popup .map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb,
html[data-theme="dark"]  .map-tb-popup .map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb {
  background: #FFFFFF !important;
}

/* FORÇA COR ESCURA EM TUDO DENTRO DO POPUP DE CAMADAS */
#tbPopupLayers * {
  color: #244E9C !important;
}
#tbPopupLayers .map-layer-row {
  background: #F8FAFC !important;
  border-color: rgba(36,78,156,.12) !important;
}
#tbPopupLayers .map-layer-row:hover {
  background: #EEF2F8 !important;
}
#tbPopupLayers .map-toggle-track {
  background: #244E9C !important;
}
#tbPopupLayers .map-toggle input:checked ~ .map-toggle-track {
  background: #244E9C !important;
}
#tbPopupLayers .map-toggle input:checked ~ .map-toggle-track * {
  color: #FFFFFF !important;
}
#tbPopupLayers .map-toggle-thumb {
  background: #244E9C !important;
}
#tbPopupLayers .map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb {
  background: #FFFFFF !important;
}

/* ── Popup Categorias na barra azul ── */
#tbPopupCat {
  left: 0 !important;
  top: calc(100% + 10px) !important;
}
/* chips de categoria dentro do novo popup */
.map-tb-cat-chips {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 280px;
  overflow-y: auto;
  padding-bottom: 4px;
}
/* fix cores no popup Categorias */
#tbPopupCat * { color: #244E9C !important; }
#tbPopupCat .map-cat-search-wrap {
  background: #F1F5F9 !important;
  border-color: rgba(36,78,156,.12) !important;
}
#tbPopupCat input {
  background: transparent !important;
  color: #244E9C !important;
}
#tbPopupCat input::placeholder { color: #244E9C !important; }

/* ── Popups padronizados: tamanho fixo + scroll interno ────────── */
.map-tb-popup-fixed {
  width: 300px !important;
  max-width: 300px !important;
  display: flex !important;
  flex-direction: column !important;
  max-height: 420px !important;
}
/* Header fixo — nunca esconde */
.map-tb-popup-fixed .map-tb-popup-header {
  flex-shrink: 0 !important;
  padding: 14px 16px 10px !important;
  border-bottom: 1px solid rgba(36,78,156,.08) !important;
  background: #FFFFFF !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 2 !important;
}
/* Corpo com scroll */
.map-tb-popup-body {
  flex: 1 !important;
  overflow-y: auto !important;
  min-height: 0 !important;
  padding: 10px 10px 12px !important;
}
.map-tb-popup-body::-webkit-scrollbar { width: 5px; }
.map-tb-popup-body::-webkit-scrollbar-thumb {
  background: rgba(36,78,156,.18);
  border-radius: 999px;
}
/* Busca dentro do popup Categorias */
#tbPopupCat .map-tb-popup-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 14px 14px !important;
}
#tbPopupCat .map-cat-search-wrap {
  flex-shrink: 0;
}
#tbPopupCat .map-tb-cat-chips {
  flex: 1;
  overflow-y: auto;
  max-height: 260px;
}
/* Chips de categoria — texto sempre visível */
#tbPopupCat * { color: #244E9C !important; }
#tbPopupCat .map-tb-popup-header * { color: #244E9C !important; }
/* Camadas — texto sempre visível */
#tbPopupLayers * { color: #244E9C !important; }
#tbPopupLayers .map-tb-popup-header * { color: #244E9C !important; }
#tbPopupLayers .map-layer-row {
  background: #F8FAFC !important;
  border-color: rgba(36,78,156,.10) !important;
}
#tbPopupLayers .map-layer-row:hover {
  background: #EEF2F8 !important;
}
#tbPopupLayers .map-toggle-track { background: #244E9C !important; }
#tbPopupLayers .map-toggle input:checked ~ .map-toggle-track {
  background: #244E9C !important;
}
#tbPopupLayers .map-toggle-thumb { background: #244E9C !important; }
#tbPopupLayers .map-toggle input:checked ~ .map-toggle-track .map-toggle-thumb {
  background: #FFFFFF !important;
}

/* ── Largura maior nos popups para texto não sobrepor toggle ── */
.map-tb-popup-fixed {
  width: 360px !important;
  max-width: 360px !important;
}
#tbPopupLayers .map-layer-row,
#tbPopupCat .map-layer-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
/* Título da camada não pode invadir o toggle */
#tbPopupLayers .mlr-title,
#tbPopupCat .mlr-title {
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: calc(100% - 60px) !important;
}

/* ── FIX: remover max-width que cortava títulos, só aumentar largura ── */
#tbPopupLayers .mlr-title,
#tbPopupCat .mlr-title {
  max-width: none !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
#tbPopupLayers .mlr-left,
#tbPopupCat .mlr-left {
  flex: 1 !important;
  min-width: 0 !important;
  overflow: hidden !important;
}
#tbPopupLayers .map-toggle,
#tbPopupCat .map-toggle {
  flex-shrink: 0 !important;
}
.map-tb-popup-fixed {
  width: 400px !important;
  max-width: 400px !important;
}

/* ── sec-mapa: visibilidade controlada pelo JS via style.display ── */


/* ── Controle de visibilidade dos painéis — regra única ── */
.source-panel { display: none !important; }
.source-panel.active { display: flex !important; }
/* sec-mapa: JS controla via style.display inline */

/* ── tabs-bar do IBGE some com o panel ── */
#panel-ibge:not(.active) .tabs-bar,
#panel-ibge:not(.active) .section,
#panel-ibge:not(.active) #sec-mapa {
  display: none !important;
  visibility: hidden !important;
}

/* ── Controle via data-active-source — CSS puro, máxima especificidade ── */
/* Quando IBGE não está ativo, esconder tabs internas e mapa */
.censo-integrated[data-active-source]:not([data-active-source="ibge"]) #panel-ibge,
.censo-integrated[data-active-source]:not([data-active-source="ibge"]) #panel-ibge * {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}
.censo-integrated[data-active-source="caged"] #panel-caged { display: flex !important; }
.censo-integrated[data-active-source="tse"]   #panel-tse   { display: flex !important; }
.censo-integrated[data-active-source="incra"] #panel-incra { display: flex !important; }
.censo-integrated[data-active-source="saude"] #panel-saude { display: flex !important; }
.censo-integrated[data-active-source="ibge"]  #panel-ibge  { display: flex !important; }

/* ── Fix vão gigante: panel-ibge some completamente ── */
.censo-integrated[data-active-source]:not([data-active-source="ibge"]) #panel-ibge {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  flex: none !important;
}
/* ══════════════════════════════════════════════════════════════
   NOVO LAYOUT DO MAPA — sidebar paleta Panorama + iframe
   ══════════════════════════════════════════════════════════════ */

/* sec-mapa: ocupa toda a área do panel-ibge */
#sec-mapa {
  display: flex !important;
  flex-direction: row !important;
  flex: 1 1 0 !important;
  min-height: 0 !important;
  height: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
}
#sec-mapa.active {
  display: flex !important;
}
.pm-map-layout {
  display: flex !important;
  flex: 1 !important;
  min-height: 0 !important;
  width: 100% !important;
  height: 100% !important;
  gap: 0 !important;
  overflow: hidden !important;
}

/* ── Sidebar esquerda — paleta Panorama ──────────────────── */
.pm-map-sidebar {
  width: 360px;
  min-width: 360px;
  max-width: 360px;
  height: 100%;
  display: flex;
  flex-direction: column;
  background: var(--surface, #FFFFFF);
  border-left: 1px solid var(--border, rgba(36,78,156,.10));
  border-right: none;
  overflow: hidden;
  flex-shrink: 0;
  z-index: 2;
  box-shadow: -2px 0 12px rgba(36,78,156,.08);
}
html[data-theme="dark"] .pm-map-sidebar {
  background: var(--surface, #244E9C);
  border-right-color: rgba(255,255,255,.08);
}

/* Header — gradiente azul do Panorama */
.pm-sb-header {
  padding: 14px 16px 12px;
  background: #244E9C;
  border-bottom: 1px solid rgba(255,255,255,.12);
  flex-shrink: 0;
}
.pm-sb-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 700;
  color: #FFFFFF;
  letter-spacing: .2px;
}
.pm-sb-title svg { opacity: .85; }
.pm-sb-sub {
  font-size: 11px;
  color: rgba(255,255,255,.60);
  margin-top: 3px;
  padding-left: 24px;
}

/* Abas — estilo Panorama */
.pm-sb-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border, rgba(36,78,156,.10));
  background:
    #FFFFFF;
  flex-shrink: 0;
  box-shadow: inset 0 -1px 0 rgba(36,78,156,.04);
}
html[data-theme="dark"] .pm-sb-tabs {
  border-bottom-color: rgba(255,255,255,.08);
  background: var(--surface, #244E9C);
}
.pm-sb-tab {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 14px 8px 12px;
  font-size: 10px;
  font-weight: 800;
  color: #244E9C;
  cursor: pointer;
  border: none;
  background: transparent;
  border-bottom: 3px solid transparent;
  transition: color .18s, border-color .18s, background .18s, box-shadow .18s;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-family: inherit;
}
.pm-sb-tab svg { opacity: .55; transition: opacity .18s; }
.pm-sb-tab:hover {
  color: #244E9C;
  background: #244E9C;
}
.pm-sb-tab:hover svg { opacity: .8; }
.pm-sb-tab.active {
  color: #244E9C;
  border-bottom-color: #244E9C;
  background:
    #244E9C;
  box-shadow: inset 0 -1px 0 rgba(36,78,156,.14);
}
.pm-sb-tab.active svg { opacity: 1; }
html[data-theme="dark"] .pm-sb-tab.active {
  color: #244E9C;
  border-bottom-color: #244E9C;
  background: rgba(56,190,239,.07);
}

/* Painéis */
.pm-sb-panel {
  display: none;
  flex: 1;
  flex-direction: column;
  overflow-y: auto;
  padding: 14px 14px 20px;
  gap: 12px;
  min-height: 0;
  background: var(--surface, #FFFFFF);
}
/* Painel unificado: Categorias + Camadas */
.pm-sb-panel.active { display: flex; }

/* Seção de categorias dentro do painel unificado — não cresce */
.pm-cat-section {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Card de camadas com scroll interno */
.pm-layers-card {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border, rgba(36,78,156,.10));
  border-radius: 10px;
  overflow: hidden;
  background: var(--surface, #FFFFFF);
}
html[data-theme="dark"] .pm-layers-card {
  border-color: rgba(255,255,255,.08);
  background: var(--surface2, #244E9C);
}
.pm-layers-card-head {
  flex-shrink: 0;
  padding: 8px 12px 7px;
  border-bottom: 1px solid var(--border, rgba(36,78,156,.08));
  font-size: 9px;
  font-weight: 700;
  color: var(--muted, #244E9C);
  letter-spacing: 1px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--bg, #F3F6FB);
}
html[data-theme="dark"] .pm-layers-card-head {
  background: rgba(255,255,255,.03);
  border-bottom-color: rgba(255,255,255,.07);
}
.pm-layers-card-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 6px 0;
}
.pm-layers-card-body::-webkit-scrollbar { width: 4px; }
.pm-layers-card-body::-webkit-scrollbar-track { background: transparent; }
.pm-layers-card-body::-webkit-scrollbar-thumb {
  background: rgba(36,78,156,.15);
  border-radius: 999px;
}
html[data-theme="dark"] .pm-layers-card-body::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.12);
}


.pm-sb-panel::-webkit-scrollbar { width: 5px; }
.pm-sb-panel::-webkit-scrollbar-track { background: transparent; }
.pm-sb-panel::-webkit-scrollbar-thumb {
  background: rgba(36,78,156,.15);
  border-radius: 999px;
}
html[data-theme="dark"] .pm-sb-panel::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.12);
}

/* Labels de seção */
.pm-sb-section-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--muted, #244E9C);
  letter-spacing: 1px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px;
  flex-shrink: 0;
}

/* Search */
.pm-sb-search {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--surface2, #F8FAFC);
  border: 1px solid var(--border, rgba(36,78,156,.10));
  border-radius: 8px;
  padding: 8px 12px;
  flex-shrink: 0;
  transition: border-color .18s;
}
.pm-sb-search:focus-within {
  border-color: var(--pm-accent, #244E9C);
}
.pm-sb-search svg { color: var(--muted, #244E9C); flex-shrink: 0; }
.pm-sb-search input {
  background: none;
  border: none;
  outline: none;
  font-family: inherit;
  font-size: 11px;
  color: var(--text, #244E9C);
  flex: 1;
  width: 100%;
}
.pm-sb-search input::placeholder { color: var(--muted, #244E9C); }

/* Grade de categorias — paleta Panorama */
.pm-cat-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 6px !important;
  padding: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}
#pmtab-categorias .map-cat-item {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 9px 10px !important;
  border-radius: 8px !important;
  border: 1.5px solid var(--border, rgba(36,78,156,.10)) !important;
  background: var(--surface2, #F8FAFC) !important;
  cursor: pointer !important;
  transition: all .18s !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: var(--text, #244E9C) !important;
  font-family: inherit !important;
  text-align: left !important;
  width: 100% !important;
}
#pmtab-categorias .map-cat-item:hover {
  border-color: var(--pm-accent, #244E9C) !important;
  background: rgba(36,78,156,.06) !important;
}
#pmtab-categorias .map-cat-item.on {
  background: rgba(36,78,156,.12) !important;
  border-color: var(--pm-accent, #244E9C) !important;
  color: var(--pm-accent, #244E9C) !important;
  font-weight: 700 !important;
}
#pmtab-categorias .item-check { margin-left: auto; color: var(--pm-accent, #244E9C); }
html[data-theme="dark"] #pmtab-categorias .map-cat-item {
  background: rgba(255,255,255,.05) !important;
  border-color: rgba(255,255,255,.09) !important;
  color: #244E9C !important;
}
html[data-theme="dark"] #pmtab-categorias .map-cat-item.on {
  background: rgba(56,190,239,.12) !important;
  border-color: rgba(56,190,239,.4) !important;
  color: #244E9C !important;
}

/* Lista de camadas — paleta Panorama */
.pm-layers-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  padding: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}
.pm-layers-list .map-layer-row {
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  align-items:center !important;
  gap:14px !important;
  background: #FFFFFF !important;
  border: 1.5px solid rgba(36,78,156,.62) !important;
  border-radius: 22px !important;
  padding: 16px 18px !important;
  box-shadow: 0 10px 26px rgba(36,78,156,.06) !important;
}
.pm-layers-list .map-layer-row:hover {
  background: #FFFFFF !important;
  border-color: rgba(36,78,156,.5) !important;
  transform: translateY(-1px) !important;
}
.pm-layers-list .map-layer-row.focused {
  border-color: rgba(36,78,156,.58) !important;
  box-shadow: 0 14px 28px rgba(36,78,156,.10) !important;
}
.pm-layers-list .mlr-left {
  min-width:0 !important;
}
.pm-layers-list .mlr-text {
  min-width:0 !important;
}
.pm-layers-list .mlr-title {
  color: #244E9C !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1.18 !important;
  letter-spacing: -.01em !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  max-width: 100% !important;
}
.pm-layers-list .mlr-sub {
  margin-top: 5px !important;
  color: #244E9C !important;
  font-size: 12px !important;
  line-height: 1.22 !important;
  opacity: 1 !important;
  max-width: 290px !important;
}
.pm-layers-list .map-layer-row.is-long-title {
  align-items: start !important;
}
.pm-layers-list .map-layer-row.is-long-title .mlr-title {
  max-width: 320px !important;
}
.pm-layers-list .map-layer-row.is-long-title .mlr-action {
  padding-top: 2px !important;
}
.pm-layers-list .mlr-action {
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  flex:0 0 auto !important;
}
.pm-layers-list .mlr-state {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: #244E9C !important;
  white-space: nowrap !important;
}
.pm-layers-list .map-toggle.map-toggle-iconic {
  width: 52px !important;
  height: 52px !important;
}
.pm-layers-list .map-toggle.map-toggle-iconic .map-toggle-track {
  width: 52px !important;
  height: 52px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius: 999px !important;
  background: #EDF3FF !important;
  border: 1px solid rgba(36,78,156,.9) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7) !important;
}
.pm-layers-list .map-toggle.map-toggle-iconic input:checked ~ .map-toggle-track {
  background: #244E9C !important;
  border-color: rgba(36,78,156,.85) !important;
}
.pm-layers-list .map-toggle-glyph {
  width: 26px !important;
  height: 26px !important;
  border-radius: 999px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  color: #244E9C !important;
  transition: transform .18s ease, color .18s ease, background .18s ease !important;
}
.pm-layers-list .map-toggle.map-toggle-iconic:hover .map-toggle-glyph {
  transform: translateX(1px) !important;
}
.pm-layers-list .map-toggle.map-toggle-iconic input:checked ~ .map-toggle-track .map-toggle-glyph {
  background: rgba(255,255,255,.68) !important;
  color: #244E9C !important;
}

html[data-theme="dark"] .pm-layers-list .map-layer-row {
  background: #244E9C !important;
  border-color: rgba(255,255,255,.12) !important;
  box-shadow: 0 12px 28px rgba(15,35,71,.18) !important;
}
html[data-theme="dark"] .pm-layers-list .map-layer-row:hover {
  border-color: rgba(36,78,156,.28) !important;
  background: #244E9C !important;
}
html[data-theme="dark"] .pm-layers-list .map-layer-row.focused {
  border-color: rgba(36,78,156,.34) !important;
}
html[data-theme="dark"] .pm-layers-list .mlr-title { color: #f5f5f5 !important; }
html[data-theme="dark"] .pm-layers-list .mlr-sub,
html[data-theme="dark"] .pm-layers-list .mlr-state { color: rgba(255,255,255,.62) !important; }
html[data-theme="dark"] .pm-layers-list .map-toggle.map-toggle-iconic .map-toggle-track {
  background: rgba(255,255,255,.07) !important;
  border-color: rgba(255,255,255,.12) !important;
}
html[data-theme="dark"] .pm-layers-list .map-toggle-glyph { color: #f0f0f0 !important; }
html[data-theme="dark"] .pm-layers-list .map-toggle.map-toggle-iconic input:checked ~ .map-toggle-track {
  background: #525252 !important;
  border-color: rgba(255,255,255,.28) !important;
}

/* Badge contador */
.pm-layer-count {
  font-size: 9px;
  background: rgba(36,78,156,.12);
  color: var(--pm-accent, #244E9C);
  padding: 2px 7px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
}

/* Painel Indicadores */
.pm-sb-info-label {
  font-size: 11px;
  color: var(--muted, #244E9C);
  padding: 8px 0 4px;
  font-style: italic;
}
.pm-info-panel { flex: 1 !important; overflow-y: auto !important; padding: 0 !important; }

/* Painel Satélite — paleta Panorama */
.pm-sat-options { display: flex; flex-direction: column; gap: 8px; }
.pm-sat-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1.5px solid var(--border, rgba(36,78,156,.10));
  background: var(--surface2, #F8FAFC);
  cursor: pointer;
  transition: all .18s;
  font-family: inherit;
  text-align: left;
}
.pm-sat-btn svg { flex-shrink: 0; color: var(--muted, #244E9C); }
.pm-sat-btn span { font-size: 13px; font-weight: 600; color: var(--text, #244E9C); display: block; }
.pm-sat-btn small { font-size: 10px; color: var(--muted, #244E9C); margin-top: 2px; display: block; }
.pm-sat-btn:hover { border-color: var(--pm-accent, #244E9C); background: rgba(36,78,156,.06); }
.pm-sat-btn.active { border-color: var(--pm-accent, #244E9C); background: rgba(36,78,156,.10); }
.pm-sat-btn.active svg { color: var(--pm-accent, #244E9C); }
.pm-sat-status {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px; border-radius: 8px;
  background: rgba(36,78,156,.08); border: 1px solid rgba(36,78,156,.25);
  color: var(--pm-accent, #244E9C); font-size: 11px; font-weight: 600; margin-top: 4px;
}

/* Botão tela cheia flutuante */
.pm-fullscreen-btn {
  position: absolute;
  top: 8px;
  right: 12px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(36,78,156,.75);
  backdrop-filter: blur(8px);
  color: #244E9C;
  cursor: pointer;
  transition: background .18s, border-color .18s;
  z-index: 10;
}
.pm-fullscreen-btn:hover {
  background: rgba(36,78,156,.9);
  border-color: rgba(36,78,156,.5);
  color: #244E9C;
}

/* ── Garantir que sec-mapa ocupe toda a área disponível ── */
#panel-ibge .tabs-bar { flex-shrink: 0; }
#sec-mapa.active {
  flex: 1;
  min-height: 0;
}








/* ══ MAPA FULL WIDTH — regra única e definitiva ══ */

/* sec-mapa ocupa todo o espaço disponível */
.censo-integrated #sec-mapa.active,
.censo-integrated .section#sec-mapa.active,
#panel-ibge #sec-mapa.active {
  display: flex !important;
  flex-direction: row !important;
  width: 100vw !important;          /* largura total da viewport */
  max-width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
  animation: none !important;
}

.pm-map-layout {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
  gap: 0 !important;
}

.pm-map-sidebar {
  flex: 0 0 360px !important;
  width: 360px !important;
  height: 100% !important;
}

.pm-map-area {
  flex: 1 1 auto !important;
  width: 0 !important;              /* flex cresce para preencher */
  min-width: 0 !important;
  height: 100% !important;
  position: relative !important;
  overflow: hidden !important;
}

/* ── Barra de camadas ativas (flutuante sobre o mapa) ── */
.pm-map-layout-wrap {
  position: relative;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.pm-map-top-controls {
  position: absolute;
  top: 8px;
  left: 300px;
  right: 16px;
  z-index: 25;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  gap: 10px;
  pointer-events: none;
}
.pm-active-bar {
  position: relative;
  flex: 0 1 min(820px, calc(100% - 156px));
  max-width: min(820px, calc(100% - 156px));
  pointer-events: all;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  max-height: 42px;
  height: 42px;
  background: #FFFFFF;
  backdrop-filter: blur(18px) saturate(145%);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  border: 1px solid rgba(255,255,255,.42);
  border-radius: 18px;
  padding: 6px 10px;
  box-shadow: 0 18px 42px rgba(36,78,156,.14), inset 0 1px 0 rgba(255,255,255,.38);
  overflow: hidden;
}
html[data-theme="dark"] .pm-active-bar {
  background: #161616;
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 12px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
}
.pm-active-bar-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 9px;
  font-weight: 800;
  color: var(--muted, #244E9C);
  letter-spacing: .7px;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.pm-active-bar-label svg { opacity: .75; }

.pm-active-empty {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.46);
  color: #244E9C;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
html[data-theme="dark"] .pm-active-empty {
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.72);
}
.pm-active-bar-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.54);
  color: var(--pm-accent, #244E9C);
  font-size: 10px;
  font-weight: 800;
  white-space: nowrap;
  flex-shrink: 0;
}
html[data-theme="dark"] .pm-active-bar-count {
  background: rgba(255,255,255,.1);
  color: #f0f0f0;
}
.pm-active-chips {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 5px;
  flex: 1;
  min-width: 0;
  max-height: 32px;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
}
.pm-active-chips::-webkit-scrollbar { display: none; }
.pm-active-clear {
  width: 22px;
  height: 22px;
  display: none;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.46);
  border-radius: 999px;
  background: #FFFFFF;
  color: #244E9C;
  cursor: pointer;
  padding: 0;
  flex: 0 0 auto;
  transition: transform .15s ease, background .15s ease, opacity .15s ease;
}
.pm-active-clear:hover {
  background: rgba(255,255,255,.9);
  transform: scale(1.04);
}
html[data-theme="dark"] .pm-active-clear {
  border-color: rgba(255,255,255,.12);
  background: #244E9C;
  color: #FFFFFF;
}
html[data-theme="dark"] .pm-active-clear:hover {
  background: rgba(255,255,255,.18);
}
.pm-active-chip {
  min-height: 22px;
  max-height: 28px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: 220px;
  padding: 3px 6px 3px 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.44);
  background: #FFFFFF;
  color: #244E9C;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
}
html[data-theme="dark"] .pm-active-chip {
  min-height: 22px;
  background: #244E9C;
  border-color: rgba(255,255,255,.10);
  color: #EFF6FF;
}
.pm-active-chip-text {
  font-size: 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pm-active-chip-x {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: 999px;
  background: rgba(36,78,156,.08);
  color: #244E9C;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: transform .15s ease, background .15s ease;
}
.pm-active-chip-x:hover {
  background: rgba(36,78,156,.16);
  transform: scale(1.05);
}
html[data-theme="dark"] .pm-active-chip-x {
  width: 16px;
  height: 16px;
  background: rgba(255,255,255,.14);
  color: #FFFFFF;
}
html[data-theme="dark"] .pm-active-chip-x:hover { background: rgba(255,255,255,.22); }


.pm-maptype-wrap {
  position: relative;
  pointer-events: all;
  flex: 0 0 auto;
}
.pm-maptype-trigger {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.42);
  border-radius: 18px;
  background: #FFFFFF;
  color: #244E9C;
  box-shadow: 0 18px 42px rgba(36,78,156,.14), inset 0 1px 0 rgba(255,255,255,.38);
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, transform .15s ease, box-shadow .18s ease, color .18s ease;
  backdrop-filter: blur(18px) saturate(145%);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
}
.pm-maptype-trigger:hover { transform: translateY(-1px); border-color: rgba(255,255,255,.56); box-shadow: 0 20px 44px rgba(36,78,156,.16), inset 0 1px 0 rgba(255,255,255,.42); background: #FFFFFF; color:#244E9C; }
.pm-maptype-trigger.active { background: #FFFFFF; color: #244E9C; border-color: rgba(255,255,255,.58); }
.pm-maptype-popover {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 272px;
  padding: 10px;
  border-radius: 22px;
  background: #FFFFFF;
  border: 1px solid rgba(255,255,255,.42);
  box-shadow: 0 20px 48px rgba(36,78,156,.16), inset 0 1px 0 rgba(255,255,255,.36);
  backdrop-filter: blur(18px) saturate(145%);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
  opacity: 0;
  transform: translateY(-6px) scale(.98);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.pm-maptype-popover.open { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.pm-maptype-grid { display: flex; flex-direction: column; gap: 8px; }
.pm-maptype-card { display:flex; align-items:center; gap:12px; width:100%; min-width:0; min-height:74px; padding:10px 12px; border-radius:16px; border:1px solid rgba(255,255,255,.44); background:#FFFFFF; cursor:pointer; transition:border-color .18s ease, background .18s ease, transform .15s ease, box-shadow .18s ease; text-align:left; }
.pm-maptype-card:hover { transform: translateY(-1px); border-color: rgba(255,255,255,.62); box-shadow: 0 10px 22px rgba(36,78,156,.12); }
.pm-maptype-card.active { border-color: rgba(36,78,156,.28); background: #FFFFFF; }
.pm-maptype-thumb { display:block; width:64px; min-width:64px; aspect-ratio:1 / 1; border-radius:16px; border:1px solid rgba(255,255,255,.55); box-shadow: inset 0 0 0 1px rgba(36,78,156,.05); flex:0 0 64px; }
.pm-maptype-thumb-normal {
  background-image: url('../img/Map 1.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #47AB34;
}
.pm-maptype-thumb-satellite { background-image: url('../img/maptype-satellite.png'); background-size: cover; background-position: center; background-repeat: no-repeat; background-color: #E9561E; }
.pm-maptype-thumb-legacy { background-image: url('../img/maptype-normal.png'); background-size: cover; background-position: center; background-repeat: no-repeat; background-color: #244E9C; filter: saturate(.78) contrast(.95) brightness(1.02); }
.pm-maptype-thumb-dark {
  background-image: url('../img/Dark_Map.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #244E9C;
  position: relative;
}
.pm-maptype-thumb-dark::before,
.pm-maptype-thumb-dark::after {
  content: "";
  position: absolute;
  inset: auto;
  background: rgba(246,248,251,.16);
  border-radius: 999px;
}
.pm-maptype-thumb-dark::before {
  width: 42px;
  height: 3px;
  left: 10px;
  top: 20px;
  transform: rotate(-18deg);
}
.pm-maptype-thumb-dark::after {
  width: 28px;
  height: 2px;
  right: 10px;
  bottom: 16px;
  transform: rotate(14deg);
}
.pm-maptype-name { display:block; flex:1 1 auto; min-width:0; font-size:14px; font-weight:800; color:#244E9C; text-align:left; line-height:1.1; white-space:nowrap; }
html[data-theme="dark"] .pm-maptype-trigger { background: #161616; border-color: rgba(255,255,255,.14); color:#f5f5f5; box-shadow: 0 12px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06); }
html[data-theme="dark"] .pm-maptype-trigger.active { background: #242424; border-color: rgba(255,255,255,.2); color:#ffffff; }
html[data-theme="dark"] .pm-maptype-popover { background: #141414; border-color: rgba(255,255,255,.12); box-shadow: 0 18px 36px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.04); }
html[data-theme="dark"] .pm-maptype-card { background: #1a1a1a; border-color: rgba(255,255,255,.1); }
html[data-theme="dark"] .pm-maptype-card.active { background: #2a2a2a; border-color: rgba(255,255,255,.22); }
html[data-theme="dark"] .pm-maptype-name { color:#f0f0f0; }

@media (max-width: 980px) {
  .pm-map-top-controls {
    top: 10px;
    left: 10px;
    right: 10px;
    gap: 8px;
  }
  .pm-active-bar {
    flex: 1 1 auto;
    max-width: none;
    gap: 6px;
    padding: 6px 8px;
  }
  .pm-maptype-popover { width: 248px; }
  .pm-active-bar-count {
    display: none;
  }
  .pm-active-chip {
  min-height: 22px;
    max-width: 190px;
  }
}



#mapFrame,
.pm-map-iframe {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  display: block !important;
}

/* =========================================================
   FIX DEFINITIVO — MAPA OCUPANDO TODA A ÁREA ÚTIL
   ========================================================= */
.main{
  min-width:0 !important;
  min-height:0 !important;
}

.content{
  min-width:0 !important;
  min-height:0 !important;
}

.content:has(.censo-integrated){
  display:flex !important;
  flex:1 1 auto !important;
  width:100% !important;
  height:100% !important;
  min-width:0 !important;
  min-height:0 !important;
  padding:0 !important;
  gap:0 !important;
  overflow:hidden !important;
}

.censo-integrated,
.censo-integrated > .content,
.censo-integrated .source-content,
.censo-integrated .section,
.censo-integrated .section.active,
.censo-integrated .source-panel,
.censo-integrated .source-panel.active,
#panel-ibge,
#panel-ibge.active{
  min-width:0 !important;
  min-height:0 !important;
}

.censo-integrated{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 auto !important;
  width:100% !important;
  height:100% !important;
  overflow:hidden !important;
}

#panel-ibge,
#panel-ibge.active,
.censo-integrated .source-panel.active{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 auto !important;
  width:100% !important;
  height:100% !important;
  overflow:hidden !important;
}

#sec-mapa,
#sec-mapa.active,
.censo-integrated #sec-mapa.active,
.censo-integrated .section#sec-mapa.active,
#panel-ibge #sec-mapa.active{
  display:flex !important;
  flex:1 1 auto !important;
  flex-direction:row !important;
  width:100% !important;
  max-width:100% !important;
  height:100% !important;
  min-width:0 !important;
  min-height:0 !important;
  padding:0 !important;
  margin:0 !important;
  overflow:hidden !important;
}

.pm-map-layout{
  position:relative !important;
  display:flex !important;
  flex:1 1 auto !important;
  flex-direction:row !important;
  width:100% !important;
  height:100% !important;
  min-width:0 !important;
  min-height:0 !important;
  gap:0 !important;
  overflow:hidden !important;
}

.pm-map-sidebar{
  flex:0 0 360px !important;
  width:360px !important;
  min-width:360px !important;
  max-width:360px !important;
  height:100% !important;
}

.pm-map-layout[data-sidebar-mode="biomas"] .pm-map-sidebar{
  display:none !important;
  flex:0 0 0 !important;
  width:0 !important;
  min-width:0 !important;
  max-width:0 !important;
  overflow:hidden !important;
  margin:0 !important;
  padding:0 !important;
  border-width:0 !important;
}

.pm-map-area{
  flex:1 1 auto !important;
  width:auto !important;
  min-width:0 !important;
  height:100% !important;
  position:relative !important;
  overflow:hidden !important;
}

#mapFrame,
.pm-map-iframe,
.pm-map-area iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
}

.pm-biomas-map-host{
  position:absolute;
  inset:0;
  z-index:16;
  display:none;
  background:#111827;
  overflow:hidden;
}
html[data-theme="light"] .pm-biomas-map-host{
  background:#f1f5f9;
}
.pm-biomas-map-host.is-active{
  display:block;
}
.pm-biomas-map-frame{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
  background:#111827;
}
html[data-theme="light"] .pm-biomas-map-frame{
  background:#f1f5f9;
}
.pm-biomas-map-mask-top,
.pm-biomas-map-mask-bottom{
  display:none !important;
}
.pm-biomas-map-empty{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px;
  text-align:center;
  color:#EFF6FF;
  font-size:15px;
  font-weight:700;
  line-height:1.6;
  background:transparent, #244E9C;
}
.pm-biomas-map-empty[hidden]{
  display:none !important;
}

.pm-map-layout[data-sidebar-mode="biomas"] #mapFrame{
  visibility:hidden;
  pointer-events:none;
}
.pm-map-layout[data-sidebar-mode="biomas"] .pm-maptype-wrap,
.pm-map-layout[data-sidebar-mode="biomas"] #pmStreetViewTrigger,
.pm-map-layout[data-sidebar-mode="biomas"] #pmTrafficFlowTrigger,
.pm-map-layout[data-sidebar-mode="biomas"] .pm-map-corner-right,
.pm-map-layout[data-sidebar-mode="biomas"] .pm-map-corner-bottom,
.pm-map-layout[data-sidebar-mode="biomas"] .pm-streetview-panel,
.pm-map-layout[data-sidebar-mode="biomas"] .pm-streetview-hint{
  display:none !important;
}


/* === Mapillary / Street View === */
.pm-map-top-controls{align-items:flex-start;}
.pm-maptop-right{display:flex;align-items:flex-start;gap:8px;position:relative;z-index:26;pointer-events:auto;}
.pm-streetview-trigger,.pm-traffic-trigger{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:52px;height:52px;padding:0 14px;border-radius:18px;border:1px solid rgba(36,78,156,.18);background:rgba(255,255,255,.98);box-shadow:0 10px 22px rgba(36,78,156,.12);color:#244E9C;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;pointer-events:auto;position:relative;z-index:27;}
.pm-streetview-trigger:hover,.pm-traffic-trigger:hover{transform:translateY(-1px);box-shadow:0 14px 26px rgba(36,78,156,.16);border-color:rgba(36,78,156,.30);color:#244E9C;}
.pm-streetview-trigger.active,.pm-traffic-trigger.active{background:#244E9C;color:#FFFFFF;border-color:rgba(36,78,156,.34);}
.pm-streetview-trigger svg,.pm-traffic-trigger svg{flex:0 0 auto;display:block;}
.pm-streetview-panel{position:absolute;inset:0;z-index:18;display:none;background:#111827;}
.pm-streetview-panel.open{display:block;}
.pm-streetview-viewer{position:absolute;inset:0;}
.pm-streetview-embed{position:absolute;inset:0;width:100%;height:100%;border:0;background:#111827;}
.pm-streetview-head{position:absolute;top:58px;left:14px;right:14px;z-index:22;display:flex;align-items:center;justify-content:space-between;gap:12px;pointer-events:none;}
.pm-streetview-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:16px;background:rgba(36,78,156,.78);backdrop-filter:blur(10px);color:#FFFFFF;font-size:12px;font-weight:700;letter-spacing:.01em;box-shadow:0 10px 24px rgba(15,35,71,.22);pointer-events:auto;}
.pm-streetview-close{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid rgba(255,255,255,.18);border-radius:14px;background:rgba(36,78,156,.82);color:#FFFFFF;cursor:pointer;box-shadow:0 10px 24px rgba(15,35,71,.22);pointer-events:auto;}
.pm-streetview-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:32px;text-align:center;color:#FFFFFF;font-size:14px;line-height:1.5;background:#244E9C;}
.pm-streetview-hint{position:absolute;left:14px;bottom:14px;z-index:20;display:none;align-items:center;gap:8px;padding:10px 14px;border-radius:14px;background:rgba(255,255,255,.96);color:#244E9C;font-size:12px;font-weight:700;box-shadow:0 10px 22px rgba(36,78,156,.12);}
.pm-streetview-hint.show{display:inline-flex;}
html[data-theme="dark"] .pm-traffic-trigger{background:#161616;border-color:rgba(255,255,255,.18);color:#f5f5f5;box-shadow:0 10px 26px rgba(0,0,0,.35);}
html[data-theme="dark"] .pm-traffic-trigger.active{background:#2a2a2a;color:#ffffff;border-color:rgba(255,255,255,.26);}
html[data-theme="dark"] .pm-streetview-hint{background:rgba(20,20,20,.95);color:#f5f5f5;box-shadow:0 10px 24px rgba(0,0,0,.45);}
@media (max-width: 900px){.pm-maptop-right{gap:6px;}.pm-streetview-trigger,.pm-traffic-trigger{padding:0 12px;}.pm-streetview-head{top:66px;}}

/* Fix clique do botão Street View */
.pm-map-top-controls .pm-maptop-right,
.pm-map-top-controls .pm-streetview-trigger,
.pm-map-top-controls .pm-traffic-trigger,
.pm-map-top-controls .pm-maptype-wrap,
.pm-map-top-controls .pm-maptype-trigger{pointer-events:auto !important;}
.pm-map-top-controls .pm-streetview-trigger,
.pm-map-top-controls .pm-traffic-trigger{touch-action:manipulation;}


/* ── Painel de raio ───────────────────────────────────────── */
.pm-radius-toolbar { display:flex; justify-content:flex-end; gap:10px; }
.pm-radius-activate,
.pm-radius-remove {
  min-height: 42px;
  padding: 0 18px;
  border-radius: 14px;
  font: 800 12px/1 inherit;
  letter-spacing: .01em;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.pm-radius-activate {
  background: #244E9C;
  color:#FFFFFF;
  border:1px solid rgba(36,78,156,.28);
  box-shadow: 0 12px 22px rgba(36,78,156,.18);
}
.pm-radius-activate:hover,
.pm-radius-remove:hover { transform: translateY(-1px); }
.pm-radius-activate.active {
  background: #F7FBFF;
  color:#244E9C;
  border-color: rgba(36,78,156,.22);
  box-shadow: 0 10px 22px rgba(36,78,156,.08);
}

.pm-radius-remove {
  background: #FFFFFF;
  color:#244E9C;
  border:1px solid rgba(36,78,156,.18);
  box-shadow: 0 10px 22px rgba(36,78,156,.05);
}
.pm-radius-remove:hover {
  background: #FFFFFF;
  border-color: rgba(36,78,156,.26);
}
html[data-theme="dark"] .pm-radius-remove { background:rgba(255,255,255,.06); color:#f0f0f0; border-color:rgba(255,255,255,.12); }

.pm-radius-control {
  background: #FFFFFF;
  border:1px solid rgba(36,78,156,.14);
  border-radius:20px;
  padding:14px 14px 12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
}
.pm-radius-row { display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:12px; color:#244E9C; margin-bottom:10px; }
.pm-radius-input-wrap { display:flex; align-items:center; gap:6px; }
.pm-radius-input-wrap input {
  width:84px; border:1px solid rgba(36,78,156,.16); border-radius:12px; background:#FFFFFF;
  color:#244E9C; font-weight:800; padding:8px 10px; text-align:center; font-family:inherit; font-size:13px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
html[data-theme="dark"] .pm-radius-input-wrap input { background:rgba(255,255,255,.06); color:#FFFFFF; border-color:rgba(255,255,255,.12); }
.pm-radius-range {
  -webkit-appearance:none; appearance:none; width:100%; height:8px; border-radius:999px; outline:none;
  background:#244E9C;
}
.pm-radius-range::-webkit-slider-thumb {
  -webkit-appearance:none; appearance:none; width:20px; height:20px; border-radius:50%; background:#244E9C; border:3px solid #FFFFFF; box-shadow:0 6px 14px rgba(36,78,156,.24); cursor:pointer;
}
.pm-radius-scale { display:flex; justify-content:space-between; margin-top:6px; font-size:10px; color:#244E9C; }
.pm-radius-status {
  margin-top:12px; padding:12px 13px; border-radius:14px; background:#244E9C; color:#244E9C; font-size:12px; line-height:1.5;
  border:1px solid rgba(36,78,156,.12);
}
html[data-theme="dark"] .pm-radius-status { background:rgba(255,255,255,.08); color:#f0f0f0; border-color:rgba(255,255,255,.12); }
.pm-radius-results { display:flex; flex-direction:column; gap:12px; }
.pm-radius-grid { display:grid; grid-template-columns:1fr; gap:8px; }
.pm-radius-metric {
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:center;
  gap:8px 10px;
  border-radius:18px; padding:12px 14px; border:1px solid rgba(36,78,156,.12);
  background: #FFFFFF;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.78);
}
.pm-radius-metric.pm-blue,
.pm-radius-metric.pm-green,
.pm-radius-metric.pm-lime,
.pm-radius-metric.pm-purple { background: #FFFFFF; }
.pm-radius-metric.pm-lime,
.pm-radius-metric.pm-purple { grid-column:1/-1; }
.pm-radius-metric-label { font-size:11px; margin-bottom:0; color:#244E9C; }
.pm-radius-metric-copy { display:flex; flex-direction:column; gap:3px; min-width:0; }
.pm-radius-metric-hint { font-size:10px; line-height:1.35; color:#244E9C; }
.pm-radius-metric-value { grid-column:1; font-size:18px; font-weight:800; color:#244E9C; }
.pm-radius-metric-head { display:grid; grid-template-columns:minmax(0,1fr) auto; align-items:center; gap:8px; margin-bottom:0; grid-column:1 / -1; }
.pm-radius-eye {
  min-width:92px; height:34px; padding:0 10px; border:1px solid rgba(36,78,156,.12); border-radius:999px; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:flex-start; gap:8px;
  font-size:11px; font-weight:800; line-height:1; transition:all .22s ease;
  background:#244E9C; color:#244E9C;
}
.pm-radius-eye:hover { transform:translateY(-1px); background:#244E9C; }
.pm-radius-eye.off { opacity:.88; }
.pm-radius-eye.on { color:#244E9C; border-color:rgba(36,78,156,.18); box-shadow:0 8px 16px rgba(36,78,156,.08); }
.pm-radius-eye-track {
  position:relative; width:36px; height:20px; border-radius:999px; flex:0 0 auto;
  background:rgba(36,78,156,.28); border:1px solid rgba(36,78,156,.24);
  transition:all .22s ease;
}
.pm-radius-eye-thumb {
  position:absolute; top:1px; left:1px; width:16px; height:16px; border-radius:50%;
  background:#FFFFFF; box-shadow:0 2px 6px rgba(36,78,156,.18);
  transition:transform .22s ease, background .22s ease;
}
.pm-radius-eye-text { white-space:nowrap; letter-spacing:.02em; }
.pm-radius-eye.on .pm-radius-eye-track {
  background:#244E9C;
  border-color:rgba(36,78,156,.28);
}
.pm-radius-eye.on .pm-radius-eye-thumb {
  transform:translateX(16px);
  background:#244E9C;
}
.pm-radius-metric.pm-lime .pm-radius-metric-label,
.pm-radius-metric.pm-purple .pm-radius-metric-label { font-size:12px; }
.pm-radius-metric.pm-lime .pm-radius-metric-value,
.pm-radius-metric.pm-purple .pm-radius-metric-value { grid-column:1 / -1; }
html[data-theme="dark"] .pm-radius-eye { background:rgba(255,255,255,.08); color:#FFFFFF; }
html[data-theme="dark"] .pm-radius-metric-hint { color:rgba(255,255,255,.58); }
html[data-theme="dark"] .pm-radius-eye-track { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.16); }
html[data-theme="dark"] .pm-radius-eye-thumb { background:#FFFFFF; }
html[data-theme="dark"] .pm-radius-eye.on .pm-radius-eye-track { background:rgba(255,255,255,.22); border-color:rgba(255,255,255,.32); }
html[data-theme="dark"] .pm-radius-eye.on .pm-radius-eye-thumb { background:#d4d4d4; }

.pm-radius-age-details {
  background:#FFFFFF; border:1px solid rgba(36,78,156,.12); border-radius:18px; overflow:hidden;
}
.pm-radius-age-details summary {
  list-style:none; cursor:pointer; padding:12px 14px; color:#244E9C; display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.pm-radius-age-details summary::-webkit-details-marker { display:none; }
.pm-radius-age-summary-copy { display:flex; flex-direction:column; gap:3px; min-width:0; }
.pm-radius-age-summary-copy strong { font-size:11px; font-weight:800; color:#244E9C; text-transform:uppercase; letter-spacing:.08em; }
.pm-radius-age-summary-copy small { font-size:10px; color:#244E9C; }
.pm-radius-age-summary-icon {
  width:28px; height:28px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(36,78,156,.12); color:#244E9C; background:#244E9C;
  transition:transform .22s ease, background .22s ease;
}
.pm-radius-age-details[open] .pm-radius-age-summary-icon { transform:rotate(90deg); }
.pm-radius-age-list { display:flex; flex-direction:column; gap:7px; padding:0 12px 12px; }
.pm-radius-age-item {
  display:flex; justify-content:space-between; align-items:center; padding:10px 12px; border-radius:14px; background:#244E9C; font-size:12px; border:1px solid rgba(36,78,156,.10); color:#244E9C;
}
html[data-theme="dark"] .pm-radius-age-item { background:rgba(255,255,255,.05); }
html[data-theme="dark"] .pm-radius-age-summary-copy strong { color:#f5f5f5; }
html[data-theme="dark"] .pm-radius-age-summary-copy small { color:rgba(255,255,255,.55); }
html[data-theme="dark"] .pm-radius-age-summary-icon { background:rgba(255,255,255,.08); color:#f0f0f0; border-color:rgba(255,255,255,.12); }
.pm-radius-nearest { display:flex; flex-direction:column; gap:8px; }
.pm-radius-socio-slot { margin-top:4px; min-width:0; }
.pm-radius-socio-slot:empty { display:none; }
.pm-radius-cross-slot { margin-top:4px; min-width:0; }
.pm-radius-cross-slot:empty { display:none; }

.pm-radius-cross{display:flex;flex-direction:column;gap:12px;padding:14px;border-radius:18px;background:#FFFFFF;border:1px solid rgba(36,78,156,.12);box-shadow:0 8px 18px rgba(36,78,156,.06);min-width:0;}
.pm-radius-cross-head{display:flex;flex-direction:column;gap:4px;min-width:0;}
.pm-radius-cross-eyebrow{align-self:flex-start;display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;}
.pm-radius-cross-title{font-size:15px;font-weight:900;color:#1F3D7A;letter-spacing:-.01em;line-height:1.25;overflow-wrap:break-word;}
.pm-radius-cross-sub{margin:0;font-size:12px;font-weight:600;color:#3A5995;line-height:1.5;overflow-wrap:break-word;}
.pm-radius-cross-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
.pm-radius-cross-kpi{display:flex;flex-direction:column;gap:4px;padding:11px 12px;border-radius:13px;background:#F6F9FF;border:1px solid rgba(36,78,156,.10);min-width:0;min-height:70px;}
.pm-radius-cross-kpi span{display:block;font-size:11px;font-weight:700;color:#5B719E;line-height:1.3;overflow-wrap:break-word;hyphens:auto;min-width:0;}
.pm-radius-cross-kpi strong{display:block;font-size:18px;font-weight:900;color:#1F3D7A;letter-spacing:-.02em;line-height:1.1;font-variant-numeric:tabular-nums;overflow-wrap:break-word;}
.pm-radius-cross-meta{font-size:12px;font-weight:600;color:#3A5995;line-height:1.45;padding:8px 12px;border-radius:10px;background:rgba(36,78,156,.06);}
.pm-radius-cross-meta strong{color:#1F3D7A;font-weight:800;}
.pm-radius-cross-block{display:flex;flex-direction:column;gap:8px;padding:10px 12px;border-radius:13px;background:#F6F9FF;border:1px solid rgba(36,78,156,.08);min-width:0;}
.pm-radius-cross-block > strong{font-size:11.5px;font-weight:900;letter-spacing:.05em;text-transform:uppercase;color:#244E9C;}
.pm-radius-cross-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px;}
.pm-radius-cross-list li{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:6px 10px;border-radius:9px;background:#FFFFFF;border:1px solid rgba(36,78,156,.08);min-width:0;}
.pm-radius-cross-list li span{font-size:11.5px;font-weight:700;color:#3A5995;line-height:1.4;flex:1;min-width:0;overflow-wrap:break-word;hyphens:auto;}
.pm-radius-cross-list li strong{font-size:12.5px;font-weight:900;color:#1F3D7A;font-variant-numeric:tabular-nums;white-space:nowrap;}
.pm-radius-cross-items{display:flex;flex-direction:column;gap:8px;}
.pm-radius-cross-item{padding:9px 11px;border-radius:11px;background:#FFFFFF;border:1px solid rgba(36,78,156,.08);min-width:0;}
.pm-radius-cross-item-body{display:flex;flex-direction:column;gap:2px;min-width:0;}
.pm-radius-cross-item-body strong{font-size:12.5px;font-weight:800;color:#1F3D7A;line-height:1.3;overflow-wrap:break-word;}
.pm-radius-cross-item-body span{font-size:11px;font-weight:600;color:#3A5995;line-height:1.4;overflow-wrap:break-word;}
.pm-radius-cross-item-body small{font-size:10.5px;font-weight:600;color:#5B719E;line-height:1.4;overflow-wrap:break-word;}
.pm-radius-cross-empty{margin:0;font-size:11.5px;font-weight:600;color:#5B719E;text-align:center;padding:6px 8px;}

.pm-radius-cross-usf .pm-radius-cross-eyebrow{background:rgba(36,78,156,.12);color:#244E9C;}
.pm-radius-cross-usf .pm-radius-cross{border-color:rgba(36,78,156,.16);}
.pm-radius-cross-edu .pm-radius-cross-eyebrow{background:rgba(12,155,110,.14);color:#0C9B6E;}
.pm-radius-cross-edu .pm-radius-cross-kpi{background:#F1FBF6;}
.pm-radius-cross-edu .pm-radius-cross-block{background:#F1FBF6;border-color:rgba(12,155,110,.14);}
.pm-radius-cross-vot .pm-radius-cross-eyebrow{background:rgba(233,86,30,.14);color:#B4360F;}
.pm-radius-cross-vot .pm-radius-cross-kpi{background:#FFF6F2;}
.pm-radius-cross-vot .pm-radius-cross-block{background:#FFF6F2;border-color:rgba(233,86,30,.14);}

html[data-theme="dark"] .pm-radius-cross{background:#1A2541;border-color:rgba(127,165,235,.18);box-shadow:0 8px 18px rgba(0,0,0,.25);}
html[data-theme="dark"] .pm-radius-cross-title{color:#FFFFFF;}
html[data-theme="dark"] .pm-radius-cross-sub{color:#B9CBED;}
html[data-theme="dark"] .pm-radius-cross-kpi,
html[data-theme="dark"] .pm-radius-cross-block,
html[data-theme="dark"] .pm-radius-cross-list li,
html[data-theme="dark"] .pm-radius-cross-item{background:rgba(255,255,255,.04);border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-radius-cross-kpi span,
html[data-theme="dark"] .pm-radius-cross-list li span,
html[data-theme="dark"] .pm-radius-cross-item-body span,
html[data-theme="dark"] .pm-radius-cross-item-body small{color:#9BB4E8;}
html[data-theme="dark"] .pm-radius-cross-kpi strong,
html[data-theme="dark"] .pm-radius-cross-list li strong,
html[data-theme="dark"] .pm-radius-cross-item-body strong,
html[data-theme="dark"] .pm-radius-cross-block > strong{color:#FFFFFF;}
html[data-theme="dark"] .pm-radius-cross-meta{background:rgba(127,165,235,.10);color:#D6E3FB;}
html[data-theme="dark"] .pm-radius-cross-meta strong{color:#FFFFFF;}
html[data-theme="dark"] .pm-radius-cross-usf .pm-radius-cross-eyebrow{background:rgba(127,165,235,.22);color:#E8EFFF;}
html[data-theme="dark"] .pm-radius-cross-edu .pm-radius-cross-eyebrow{background:rgba(52,211,153,.22);color:#A7F3D0;}
html[data-theme="dark"] .pm-radius-cross-edu .pm-radius-cross-kpi,
html[data-theme="dark"] .pm-radius-cross-edu .pm-radius-cross-block{background:rgba(52,211,153,.08);border-color:rgba(52,211,153,.20);}
html[data-theme="dark"] .pm-radius-cross-vot .pm-radius-cross-eyebrow{background:rgba(251,146,60,.22);color:#FED7AA;}
html[data-theme="dark"] .pm-radius-cross-vot .pm-radius-cross-kpi,
html[data-theme="dark"] .pm-radius-cross-vot .pm-radius-cross-block{background:rgba(251,146,60,.08);border-color:rgba(251,146,60,.20);}

@media (max-width:380px){
  .pm-radius-cross-kpis{grid-template-columns:1fr;}
  .pm-radius-cross-kpi{min-height:0;}
}
.pm-radius-nearest-item {
  background:#FFFFFF; border-radius:18px; padding:12px 14px; display:flex; flex-direction:column; gap:5px; border:1px solid rgba(36,78,156,.12);
}
.pm-radius-nearest-item span { font-size:11px; color:#244E9C; }
.pm-radius-nearest-item strong { font-size:12px; color:#244E9C; }
html[data-theme="dark"] .pm-radius-metric.pm-blue,
html[data-theme="dark"] .pm-radius-metric.pm-green,
html[data-theme="dark"] .pm-radius-metric.pm-lime,
html[data-theme="dark"] .pm-radius-metric.pm-purple,
html[data-theme="dark"] .pm-radius-nearest-item {
  border:1px solid rgba(255,255,255,.08);
}

.pm-action-hero,
.pm-action-list-wrap,
.pm-action-report-wrap,
.pm-report-builder-wrap{display:flex;flex-direction:column;gap:12px;background:#FFFFFF;border:1px solid rgba(36,78,156,.12);border-radius:20px;padding:14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.75);}
.pm-action-hero{margin-bottom:12px;}
.pm-action-scope-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:4px 0 8px;}
.pm-action-scope-btn{min-height:42px;padding:10px 12px;border-radius:14px;border:1px solid rgba(36,78,156,.12);background:#FFFFFF;color:#244E9C;font:800 12px/1.2 inherit;cursor:pointer;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease;}
.pm-action-scope-btn:hover{background:#F8FBFF;border-color:rgba(36,78,156,.2);}
.pm-action-scope-btn.active{background:linear-gradient(180deg,#244E9C 0%,#1F3F7F 100%);color:#FFFFFF;border-color:#244E9C;box-shadow:0 10px 22px rgba(36,78,156,.18);}
.pm-action-scope-hint{margin:0 0 10px;font-size:11px;line-height:1.45;color:rgba(36,78,156,.72);}
.pm-action-scope-badge{display:inline-flex;align-items:center;margin-left:6px;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.02em;vertical-align:middle;}
.pm-action-scope-badge.global{background:rgba(36,78,156,.12);color:#244E9C;}
.pm-action-scope-badge.personal{background:rgba(233,86,30,.12);color:#C44A12;}
.pm-action-cat-list{display:grid;gap:10px;}
.pm-action-cats{display:flex;flex-direction:column;gap:12px;}
.pm-action-cat-item{position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:64px;padding:16px 18px 16px 20px;border-radius:22px;border:1px solid color-mix(in srgb, var(--cat-color, #244E9C) 14%, rgba(36,78,156,.08));background:#FFFFFF;color:#244E9C;box-shadow:0 14px 28px rgba(36,78,156,.06);font:900 14px/1.2 inherit;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;text-align:left;overflow:hidden;}
.pm-action-cat-item::before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:5px;border-radius:999px;background:var(--cat-color, #244E9C);}
.pm-action-cat-item:hover{transform:translateY(-2px);border-color:color-mix(in srgb, var(--cat-color, #244E9C) 28%, rgba(36,78,156,.12));box-shadow:0 18px 34px rgba(36,78,156,.09);background:#FFFFFF;}
.pm-action-cat-item:focus-visible{outline:2px solid rgba(36,78,156,.22);outline-offset:2px;}
.pm-action-cat-label{font-size:15px;font-weight:900;color:#244E9C;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;}
.pm-action-cat-count{min-width:40px;height:40px;padding:0 14px;border-radius:999px;background:color-mix(in srgb, var(--cat-color, #244E9C) 14%, #FFFFFF 86%);color:var(--cat-color, #244E9C);font-size:13px;font-weight:900;text-align:center;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 18px rgba(36,78,156,.08);border:1px solid color-mix(in srgb, var(--cat-color, #244E9C) 18%, #FFFFFF 82%);}
.pm-action-create,.pm-action-clear,.pm-action-item-tools button,.pm-action-export{min-height:44px;padding:0 18px;border-radius:16px;border:1px solid rgba(36,78,156,.10);font:800 13px/1 inherit;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease;color:#244E9C;background:#FFFFFF;box-shadow:0 8px 18px rgba(36,78,156,.06);}
.pm-action-create{border-color:rgba(36,78,156,.16);color:#244E9C;}
.pm-action-create:hover{transform:translateY(-1px);background:#F8FBFF;}
.pm-action-create:active{box-shadow:0 8px 14px rgba(36,78,156,.12);}
.pm-action-create.active{background:#F7FBFF;color:#244E9C;}
.pm-action-clear,.pm-action-item-tools button,.pm-action-export{color:#244E9C;background:#FFFFFF;}
.pm-action-clear:hover,.pm-action-item-tools button:hover,.pm-action-export:hover{transform:translateY(-1px);border-color:rgba(36,78,156,.18);background:#F4F7FF;}
.pm-report-option-list,.pm-report-builder,.pm-report-batches,.pm-report-library{display:flex;flex-direction:column;gap:12px;}
.pm-report-option-card{
  --pm-card-accent:#244E9C;
  --pm-card-accent-soft:rgba(36,78,156,.10);
  --pm-card-accent-strong:#1F3F7F;
  display:grid;
  grid-template-rows:auto auto auto;
  gap:12px;
  padding:18px 18px 16px;
  border-radius:22px;
  border:1px solid rgba(36,78,156,.10);
  background:linear-gradient(180deg,#FFFFFF 0%,#FAFCFF 100%);
  color:#244E9C;
  cursor:pointer;
  text-align:left;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  box-shadow:0 14px 28px rgba(36,78,156,.06);
  transition:transform .18s ease, box-shadow .22s ease, border-color .22s ease;
}
.pm-report-option-card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:var(--pm-card-accent);
  border-radius:22px 22px 0 0;
  opacity:.92;
}
.pm-report-option-card::after{
  content:"";
  position:absolute;
  inset:auto -40px -40px auto;
  width:160px;height:160px;
  background:radial-gradient(closest-side,var(--pm-card-accent-soft),transparent 70%);
  z-index:-1;
  opacity:.85;
}
.pm-report-option-card:hover{
  transform:translateY(-2px);
  border-color:var(--pm-card-accent-soft);
  box-shadow:0 20px 40px rgba(36,78,156,.10);
}
.pm-report-option-card:focus-visible{
  outline:2px solid var(--pm-card-accent);
  outline-offset:3px;
}
.pm-report-option-head{
  display:flex;
  align-items:center;
  gap:10px;
}
.pm-report-option-icon{
  width:42px;height:42px;
  flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
  background:var(--pm-card-accent-soft);
  color:var(--pm-card-accent);
}
.pm-report-option-icon svg{display:block;}
.pm-report-option-tag{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
  color:var(--pm-card-accent);
  opacity:.85;
}
.pm-report-option-copy{display:flex;flex-direction:column;gap:6px;min-width:0;}
.pm-report-option-copy strong{
  font-size:17px;
  line-height:1.25;
  color:var(--pm-card-accent-strong);
  letter-spacing:-.005em;
  overflow-wrap:break-word;
  word-break:normal;
  hyphens:auto;
}
.pm-report-option-copy span{
  font-size:13px;
  line-height:1.55;
  color:rgba(36,78,156,.78);
  overflow-wrap:break-word;
  word-break:normal;
  hyphens:auto;
}
.pm-report-option-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  min-height:44px;
  padding:0 18px;
  border-radius:999px;
  background:var(--pm-card-accent);
  color:#FFFFFF;
  font-size:12.5px;
  font-weight:800;
  letter-spacing:.02em;
  line-height:1;
  text-align:center;
  box-shadow:0 10px 22px rgba(36,78,156,.18);
  transition:transform .14s ease, box-shadow .18s ease, filter .18s ease;
}
.pm-report-option-cta svg{flex:0 0 auto;}
.pm-report-option-card:hover .pm-report-option-cta{
  transform:translateY(-1px);
  filter:brightness(1.05);
  box-shadow:0 14px 28px rgba(36,78,156,.24);
}
.pm-report-option-card--population{--pm-card-accent:#244E9C;--pm-card-accent-soft:rgba(36,78,156,.12);--pm-card-accent-strong:#1F3F7F;}
.pm-report-option-card--health{--pm-card-accent:#0E8F4A;--pm-card-accent-soft:rgba(14,143,74,.14);--pm-card-accent-strong:#0B6F3A;}
.pm-report-option-card--voting{--pm-card-accent:#0E6CA8;--pm-card-accent-soft:rgba(14,108,168,.14);--pm-card-accent-strong:#0A4F7B;}
.pm-report-option-card--intel{--pm-card-accent:#6D38D8;--pm-card-accent-soft:rgba(109,56,216,.14);--pm-card-accent-strong:#4D27A0;}

/* =========================================================
   ÍNDICE POR TIPO (Saúde, Eleitoral, etc.)
   Aparece após clicar em "Criar agora" na home — mostra um
   hero do tipo, o CTA "Criar novo relatório" e a lista de
   relatórios salvos daquele tipo.
   ========================================================= */
.pm-report-type-index{
  --pm-card-accent:#244E9C;
  --pm-card-accent-soft:rgba(36,78,156,.12);
  --pm-card-accent-strong:#1F3F7F;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.pm-report-type-index--population{--pm-card-accent:#244E9C;--pm-card-accent-soft:rgba(36,78,156,.12);--pm-card-accent-strong:#1F3F7F;}
.pm-report-type-index--health{--pm-card-accent:#0E8F4A;--pm-card-accent-soft:rgba(14,143,74,.14);--pm-card-accent-strong:#0B6F3A;}
.pm-report-type-index--voting{--pm-card-accent:#0E6CA8;--pm-card-accent-soft:rgba(14,108,168,.14);--pm-card-accent-strong:#0A4F7B;}
.pm-report-type-index--intel{--pm-card-accent:#6D38D8;--pm-card-accent-soft:rgba(109,56,216,.14);--pm-card-accent-strong:#4D27A0;}
.pm-report-type-head{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:18px 18px 20px;
  border-radius:22px;
  background:linear-gradient(180deg,#FFFFFF 0%,#FAFCFF 100%);
  border:1px solid rgba(36,78,156,.10);
  box-shadow:0 14px 28px rgba(36,78,156,.06);
  overflow:hidden;
  isolation:isolate;
}
.pm-report-type-head::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:var(--pm-card-accent);
  opacity:.92;
}
.pm-report-type-head::after{
  content:"";
  position:absolute;
  inset:auto -50px -50px auto;
  width:180px;height:180px;
  background:radial-gradient(closest-side,var(--pm-card-accent-soft),transparent 70%);
  z-index:-1;
}
.pm-report-type-back{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid rgba(36,78,156,.16);
  background:#FFFFFF;
  color:var(--pm-card-accent-strong);
  font-size:12px;
  font-weight:800;
  cursor:pointer;
  transition:background .15s ease,border-color .15s ease,transform .15s ease;
}
.pm-report-type-back:hover{
  background:#F4F7FF;
  border-color:var(--pm-card-accent-soft);
  transform:translateX(-2px);
}
.pm-report-type-hero{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:14px;
}
.pm-report-type-icon{
  width:54px;height:54px;
  display:flex;align-items:center;justify-content:center;
  border-radius:16px;
  background:var(--pm-card-accent-soft);
  color:var(--pm-card-accent);
  flex:0 0 auto;
}
.pm-report-type-icon svg{display:block;}
.pm-report-type-hero-copy{display:flex;flex-direction:column;gap:4px;min-width:0;}
.pm-report-type-tag{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:800;
  color:var(--pm-card-accent);
  opacity:.85;
}
.pm-report-type-title{
  font-size:19px;
  line-height:1.2;
  font-weight:800;
  color:var(--pm-card-accent-strong);
  letter-spacing:-.005em;
  overflow-wrap:break-word;
  hyphens:auto;
}
.pm-report-type-subtitle{
  font-size:13px;
  line-height:1.55;
  color:rgba(36,78,156,.78);
  overflow-wrap:break-word;
}
.pm-report-type-create{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  min-height:50px;
  padding:0 18px;
  border-radius:18px;
  border:0;
  background:linear-gradient(135deg,var(--pm-card-accent) 0%,var(--pm-card-accent-strong) 100%);
  color:#FFFFFF;
  font-size:14px;
  font-weight:800;
  letter-spacing:.02em;
  cursor:pointer;
  box-shadow:0 14px 30px rgba(36,78,156,.20);
  transition:transform .14s ease, box-shadow .18s ease, filter .18s ease;
}
.pm-report-type-create:hover{
  transform:translateY(-1px);
  filter:brightness(1.05);
  box-shadow:0 18px 36px rgba(36,78,156,.26);
}
.pm-report-type-create:focus-visible{
  outline:2px solid var(--pm-card-accent);
  outline-offset:3px;
}
.pm-report-type-create svg{flex:0 0 auto;}
.pm-report-type-create svg:first-of-type{
  width:18px;height:18px;
}
.pm-report-type-saved{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:16px;
  border-radius:18px;
  background:#FFFFFF;
  border:1px solid rgba(36,78,156,.10);
  box-shadow:0 10px 22px rgba(36,78,156,.05);
}
.pm-report-type-saved-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.pm-report-type-saved-head strong{
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--pm-card-accent-strong);
  font-weight:800;
}
.pm-report-type-saved-empty{
  padding:18px 14px;
  border-radius:14px;
  background:var(--pm-card-accent-soft);
  color:var(--pm-card-accent-strong);
  font-size:13px;
  line-height:1.5;
  text-align:center;
}
.pm-report-type-saved .pm-report-library{margin:0;}

/* Dark theme — índice por tipo */
html[data-theme="dark"] .pm-report-type-head{
  background:linear-gradient(180deg,#1a1a1a 0%,#171717 100%) !important;
  border-color:rgba(255,255,255,.10) !important;
}
html[data-theme="dark"] .pm-report-type-back{
  background:#1e1e1e !important;
  color:#f0f0f0 !important;
  border-color:rgba(255,255,255,.16) !important;
}
html[data-theme="dark"] .pm-report-type-title{color:#fafafa !important;}
html[data-theme="dark"] .pm-report-type-subtitle{color:rgba(240,240,240,.78) !important;}
html[data-theme="dark"] .pm-report-type-icon{
  background:rgba(255,255,255,.08) !important;
  color:var(--pm-card-accent) !important;
}
html[data-theme="dark"] .pm-report-type-tag{color:var(--pm-card-accent) !important;}
html[data-theme="dark"] .pm-report-type-saved{
  background:#1a1a1a !important;
  border-color:rgba(255,255,255,.10) !important;
}
html[data-theme="dark"] .pm-report-type-saved-head strong{color:#fafafa !important;}
html[data-theme="dark"] .pm-report-type-saved-empty{
  background:rgba(255,255,255,.06) !important;
  color:#f0f0f0 !important;
}

/* =========================================================
   BUILDER REDESENHADO
   Aplica espaçamento, agrupamento e tipografia mais harmônicos.
   ========================================================= */
.pm-report-builder .pm-report-section-card{
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(36,78,156,.10);
  background:#FFFFFF;
  box-shadow:0 10px 22px rgba(36,78,156,.05);
  gap:14px;
}
.pm-report-builder .pm-action-browser-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:4px;
}
.pm-report-builder .pm-action-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.pm-report-builder .pm-action-field > span{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:800;
  color:rgba(36,78,156,.78);
}
.pm-report-builder .pm-action-field input[type="text"],
.pm-report-builder .pm-action-field input[type="number"],
.pm-report-builder .pm-action-field select,
.pm-report-builder .pm-action-field textarea{
  width:100%;
  padding:11px 13px;
  border-radius:12px;
  border:1px solid rgba(36,78,156,.16);
  background:#FAFCFF;
  color:#244E9C;
  font:600 13px/1.5 inherit;
  box-sizing:border-box;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.pm-report-builder .pm-action-field input:focus,
.pm-report-builder .pm-action-field select:focus,
.pm-report-builder .pm-action-field textarea:focus{
  outline:none;
  background:#FFFFFF;
  border-color:rgba(36,78,156,.45);
  box-shadow:0 0 0 4px rgba(36,78,156,.12);
}
.pm-report-builder .pm-action-field textarea{
  min-height:78px;
  resize:vertical;
  font:500 13px/1.55 inherit;
}
.pm-report-builder .pm-action-status{
  padding:12px 14px !important;
  border-radius:14px !important;
  background:#F2F6FF !important;
  border:1px solid rgba(36,78,156,.14) !important;
  color:#244E9C !important;
  font-size:12.5px;
  line-height:1.55;
}
.pm-report-builder .pm-report-radius-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 88px auto;
  align-items:center;
  gap:10px;
}
.pm-report-builder .pm-report-radius-row input[type="range"]{
  width:100%;
  accent-color:#244E9C;
}
.pm-report-builder .pm-report-radius-unit{
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  color:rgba(36,78,156,.7);
  text-transform:uppercase;
}
.pm-report-builder .pm-report-toolbar-main{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:10px;
  align-items:center;
  margin-top:4px;
}
.pm-report-builder .pm-report-toolbar-main .pm-action-clear{
  min-height:42px;
  padding:0 16px;
  border-radius:12px;
}
.pm-report-builder .pm-report-toolbar-main .pm-action-export{
  min-height:46px;
  padding:0 18px;
  border-radius:14px;
  background:linear-gradient(135deg,#244E9C 0%,#1F3F7F 100%);
  color:#FFFFFF;
  font:800 13px/1 inherit;
  letter-spacing:.02em;
  box-shadow:0 12px 26px rgba(36,78,156,.20);
  border:0;
  cursor:pointer;
  transition:transform .14s ease, box-shadow .18s ease, filter .18s ease;
}
.pm-report-builder .pm-report-toolbar-main .pm-action-export:hover{
  transform:translateY(-1px);
  filter:brightness(1.05);
  box-shadow:0 16px 32px rgba(36,78,156,.26);
}
.pm-report-builder .pm-report-summary-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;
}
.pm-report-builder .pm-action-kpi{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:12px 14px;
  border-radius:14px;
  background:#FAFCFF;
  border:1px solid rgba(36,78,156,.10);
}
.pm-report-builder .pm-action-kpi span{
  font-size:10.5px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(36,78,156,.7);
  font-weight:800;
}
.pm-report-builder .pm-action-kpi strong{
  font-size:16px;
  font-weight:800;
  color:#244E9C;
  line-height:1.2;
  overflow-wrap:break-word;
}
.pm-report-section-card{display:flex;flex-direction:column;gap:12px;padding:16px;border-radius:20px;border:1px solid rgba(36,78,156,.10);background:#FFFFFF;box-shadow:0 10px 22px rgba(36,78,156,.05);}
.pm-report-inline-remove{min-height:36px;padding:0 14px;border-radius:12px;border:1px solid rgba(36,78,156,.16);background:#FFFFFF;color:#244E9C;font:800 11px/1 inherit;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease;}
.pm-report-inline-remove:hover{border-color:rgba(233,86,30,.18);background:#FFF6F6;color:#E9561E;}
.pm-report-batch-card{cursor:default;}
.pm-action-back,
.pm-action-cat-back{min-height:38px;padding:0 14px;border-radius:14px;border:1px solid rgba(36,78,156,.08);background:#FFFFFF;color:#244E9C;font:800 12px/1 inherit;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease, background .18s ease,border-color .18s ease;box-shadow:0 8px 18px rgba(36,78,156,.06);}
.pm-action-back:hover,
.pm-action-cat-back:hover{transform:translateY(-1px);border-color:rgba(36,78,156,.18);box-shadow:0 12px 22px rgba(36,78,156,.09);background:#F8FBFF;}
.pm-action-cat-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap;}
.pm-report-panel-shell{display:grid;gap:12px;}
.pm-report-panel-shell .pm-action-field textarea{min-height:96px;}
.pm-report-open-radius{
  width:100%;
  min-height:44px;
  margin:0 0 12px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid rgba(36,78,156,.16);
  background:#FFFFFF;
  color:#244E9C;
  font:800 12px/1 inherit;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .18s ease, background .18s ease;
  box-shadow:0 10px 20px rgba(36,78,156,.08);
}
.pm-report-open-radius:hover{
  transform:translateY(-1px);
  background:#F8FBFF;
}
.pm-report-toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.pm-report-toolbar-main{display:flex;gap:10px;flex-wrap:wrap;}
.pm-report-toolbar-main .pm-action-create,
.pm-report-toolbar-main .pm-action-clear,
.pm-report-toolbar-main .pm-action-export,
.pm-report-toolbar-main .pm-action-back{flex:1 1 170px;}
.pm-report-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.pm-report-radius-row{display:grid;grid-template-columns:minmax(0,1fr) 92px 24px;align-items:center;gap:10px;}
.pm-report-radius-row input[type="range"]{width:100%;accent-color:#244E9C;}
.pm-report-radius-row input[type="number"]{width:100%;min-height:42px;padding:0 12px;border-radius:14px;border:1px solid rgba(36,78,156,.12);background:#FFFFFF;color:#244E9C;font:700 13px/1.2 inherit;}
.pm-report-radius-unit{font-size:12px;font-weight:700;color:#244E9C;letter-spacing:.02em;}
.pm-report-radius-control{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;}
.pm-report-radius-control input[type="range"]{width:100%;accent-color:#244E9C;}
.pm-report-radius-display{font-size:12px;font-weight:700;color:#244E9C;letter-spacing:.02em;white-space:nowrap;}
.pm-report-radius-display strong{font-size:15px;color:#244E9C;}
.pm-report-voting-picker{display:flex;flex-direction:column;gap:8px;}
.pm-report-voting-picker input[type="text"]{min-height:36px;padding:0 12px;border-radius:12px;border:1px solid rgba(36,78,156,.16);background:#FFFFFF;color:#244E9C;font:600 12px/1.2 inherit;}
.pm-report-voting-picker select{min-height:140px;padding:8px;border-radius:12px;border:1px solid rgba(36,78,156,.16);background:#FFFFFF;color:#244E9C;font:600 12px/1.45 inherit;}
.pm-report-voting-picker select option{padding:6px 8px;line-height:1.4;}
.pm-report-voting-picked{display:grid;gap:4px;padding:10px 12px;border-radius:12px;border:1px solid rgba(36,78,156,.16);background:#F4F8FF;color:#244E9C;font-size:12px;line-height:1.45;}
.pm-report-voting-picked strong{font-size:13px;font-weight:800;}

/* Map-based voting picker (new) */
.pm-voting-picker-field{display:flex;flex-direction:column;gap:8px;}
.pm-voting-picker-hint{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;align-items:flex-start;padding:14px 16px;border-radius:16px;border:1px dashed rgba(36,78,156,.32);background:linear-gradient(135deg,#F2F7FF 0%,#E8F0FF 100%);color:#244E9C;}
.pm-voting-picker-hint-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#FFFFFF;color:#244E9C;box-shadow:0 6px 18px rgba(36,78,156,.18);}
.pm-voting-picker-hint-copy{display:flex;flex-direction:column;gap:4px;min-width:0;}
.pm-voting-picker-hint-copy strong{font-size:13px;font-weight:800;line-height:1.35;color:#1F3D7A;}
.pm-voting-picker-hint-copy span{font-size:12px;line-height:1.55;color:#37528F;}

.pm-voting-picked-card{display:flex;flex-direction:column;min-width:0;border-radius:18px;border:1px solid rgba(36,78,156,.12);background:#FFFFFF;box-shadow:0 10px 28px rgba(20,40,80,.06);overflow:hidden;}
.pm-voting-picked-image{width:100%;aspect-ratio:16/10;min-height:120px;max-height:200px;background:#EDF2FB center/cover no-repeat;border:none;border-radius:0;}
.pm-voting-picked-image--empty{display:flex;align-items:center;justify-content:center;text-align:center;padding:16px;color:#7385AC;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:repeating-linear-gradient(45deg,#F2F6FE 0,#F2F6FE 6px,#E5ECF8 6px,#E5ECF8 12px);aspect-ratio:16/9;min-height:100px;max-height:160px;}
.pm-voting-picked-image--empty span{display:block;}
.pm-voting-picked-stack{display:flex;flex-direction:column;gap:8px;min-width:0;padding:14px 16px 16px;color:#244E9C;}
.pm-voting-picked-tag{display:inline-flex;align-self:flex-start;padding:3px 10px;border-radius:999px;background:rgba(36,78,156,.10);color:#244E9C;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;}
.pm-voting-picked-name{font-size:15px;font-weight:800;color:#1F3D7A;line-height:1.35;}
.pm-voting-picked-address{font-size:12px;font-weight:600;color:#4A6499;line-height:1.45;}
.pm-voting-picked-stats{display:flex;flex-direction:column;gap:4px;margin-top:2px;padding-top:10px;border-top:1px solid rgba(36,78,156,.10);}
.pm-voting-picked-stats span{font-size:11px;font-weight:600;color:#5B719E;line-height:1.4;}
.pm-voting-picked-change{width:100%;margin-top:6px;padding:11px 14px;border-radius:14px;border:1px solid rgba(36,78,156,.22);background:linear-gradient(180deg,#FFFFFF 0%,#F4F8FF 100%);color:#244E9C;font-size:12px;font-weight:800;cursor:pointer;letter-spacing:.02em;transition:background .15s ease,box-shadow .15s ease,transform .15s ease;box-shadow:0 2px 8px rgba(36,78,156,.08);}
.pm-voting-picked-change:hover{background:linear-gradient(180deg,#F8FBFF 0%,#E8F0FF 100%);box-shadow:0 4px 14px rgba(36,78,156,.14);transform:translateY(-1px);}
.pm-voting-picked-change:active{transform:translateY(0);}

/* Slider de raio — relatório eleitoral */
.pm-voting-radius-field .pm-voting-radius-slider{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px 16px;border-radius:16px;background:linear-gradient(165deg,#F8FAFF 0%,#EBF2FF 55%,#E3ECFB 100%);border:1px solid rgba(36,78,156,.14);box-shadow:inset 0 1px 0 rgba(255,255,255,.75);}
.pm-voting-radius-slider input[type="range"]{-webkit-appearance:none;appearance:none;width:100%;height:10px;border-radius:999px;background:linear-gradient(90deg,rgba(36,78,156,.34) 0%,rgba(36,78,156,.12) 100%);outline:none;cursor:pointer;}
.pm-voting-radius-slider input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:linear-gradient(145deg,#4A7FE0,#244E9C);border:3px solid #FFFFFF;box-shadow:0 2px 10px rgba(36,78,156,.4),0 0 0 1px rgba(36,78,156,.15);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;}
.pm-voting-radius-slider input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.06);box-shadow:0 3px 14px rgba(36,78,156,.45);}
.pm-voting-radius-slider input[type="range"]::-moz-range-track{height:10px;border-radius:999px;background:linear-gradient(90deg,rgba(36,78,156,.34) 0%,rgba(36,78,156,.12) 100%);}
.pm-voting-radius-slider input[type="range"]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:linear-gradient(145deg,#4A7FE0,#244E9C);border:3px solid #FFFFFF;box-shadow:0 2px 10px rgba(36,78,156,.4);cursor:pointer;}
.pm-voting-radius-value{display:flex;align-items:baseline;gap:3px;padding:8px 12px;border-radius:12px;background:#FFFFFF;border:1px solid rgba(36,78,156,.12);box-shadow:0 2px 6px rgba(36,78,156,.08);}
.pm-voting-radius-value strong{font-size:17px;font-weight:800;color:#244E9C;font-variant-numeric:tabular-nums;}
.pm-voting-radius-unit{font-size:12px;font-weight:700;color:#5B719E;}

.pm-voting-report-image{position:relative;margin:0 0 14px;border-radius:20px;overflow:hidden;border:1px solid rgba(36,78,156,.12);box-shadow:0 14px 28px rgba(20,40,80,.10);background:#EDF2FB;}
.pm-voting-report-image img{display:block;width:100%;height:auto;max-height:240px;object-fit:cover;}
.pm-voting-report-image::after{content:"";position:absolute;inset:auto 0 0 0;height:46%;background:linear-gradient(180deg,rgba(15,30,60,0) 0%,rgba(15,30,60,.55) 100%);pointer-events:none;}
.pm-voting-report-image-tag{position:absolute;top:12px;left:12px;padding:5px 12px;border-radius:999px;background:rgba(255,255,255,.94);color:#244E9C;font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 6px 18px rgba(20,40,80,.18);z-index:1;}

/* Preview do relatório eleitoral — estrutura completa */
.pm-voting-preview{display:flex;flex-direction:column;gap:14px;min-width:0;}
.pm-voting-preview-head{display:flex;align-items:flex-start;gap:12px;padding:0 2px;}
.pm-voting-preview-titles{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1;}
.pm-voting-preview-eyebrow{display:inline-flex;align-self:flex-start;padding:3px 10px;border-radius:999px;background:rgba(36,78,156,.10);color:#244E9C;font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;}
.pm-voting-preview-title{font-size:17px;font-weight:900;color:#1F3D7A;line-height:1.3;overflow-wrap:break-word;word-break:break-word;}
.pm-voting-preview-sub{font-size:13px;font-weight:700;color:#244E9C;line-height:1.4;overflow-wrap:break-word;word-break:break-word;}
.pm-voting-preview-meta{font-size:11px;font-weight:700;color:#5B719E;letter-spacing:.02em;}
.pm-voting-preview-objective{margin:0;padding:12px 14px;border-radius:14px;background:#F4F8FF;border:1px solid rgba(36,78,156,.10);color:#244E9C;font-size:12.5px;line-height:1.6;}

.pm-voting-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.pm-voting-kpi{position:relative;display:flex;flex-direction:column;gap:6px;padding:14px;border-radius:16px;background:linear-gradient(180deg,#FFFFFF 0%,#F7FAFF 100%);border:1px solid rgba(36,78,156,.10);box-shadow:0 6px 14px rgba(20,40,80,.04);overflow:hidden;min-width:0;}
.pm-voting-kpi::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:3px;background:linear-gradient(180deg,#4A7FE0,#244E9C);}
.pm-voting-kpi-label{font-size:10.5px;font-weight:800;letter-spacing:.04em;color:#5B719E;padding-left:10px;line-height:1.35;overflow-wrap:break-word;hyphens:auto;min-width:0;}
.pm-voting-kpi-value{font-size:22px;font-weight:900;color:#1F3D7A;font-variant-numeric:tabular-nums;padding-left:10px;line-height:1.1;overflow-wrap:break-word;min-width:0;}

.pm-voting-section{display:flex;flex-direction:column;gap:10px;padding:14px 16px;border-radius:18px;background:#FFFFFF;border:1px solid rgba(36,78,156,.10);box-shadow:0 6px 16px rgba(20,40,80,.04);min-width:0;}
.pm-voting-section-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0;}
.pm-voting-section-head strong{font-size:13.5px;font-weight:900;color:#1F3D7A;line-height:1.3;overflow-wrap:break-word;}
.pm-voting-section-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--pm-vsec,#244E9C);box-shadow:0 0 0 3px color-mix(in srgb,var(--pm-vsec,#244E9C) 18%,transparent);flex:0 0 auto;}
.pm-voting-section-tag{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;background:rgba(36,78,156,.08);color:#244E9C;font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-left:auto;}

.pm-voting-stat-list{display:flex;flex-direction:column;gap:0;list-style:none;margin:0;padding:0;}
.pm-voting-stat-list li{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px dashed rgba(36,78,156,.12);min-width:0;}
.pm-voting-stat-list li:last-child{border-bottom:0;padding-bottom:0;}
.pm-voting-stat-list li:first-child{padding-top:2px;}
.pm-voting-stat-list li span{font-size:12px;font-weight:700;color:#5B719E;line-height:1.4;flex:1;min-width:0;overflow-wrap:break-word;}
.pm-voting-stat-list li strong{font-size:14px;font-weight:900;color:#1F3D7A;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;}
.pm-voting-stat-list li strong em{display:inline-block;margin-left:4px;font-size:11px;font-weight:800;color:#244E9C;background:rgba(36,78,156,.10);padding:1px 7px;border-radius:999px;font-style:normal;letter-spacing:.02em;}

.pm-voting-rank{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.pm-voting-rank--empty{padding:12px 14px;border-radius:12px;background:#F4F8FF;color:#5B719E;font-size:12px;font-weight:700;text-align:center;}
.pm-voting-rank-item{display:grid;grid-template-columns:28px minmax(0,1fr);gap:12px;align-items:center;min-width:0;}
.pm-voting-rank-pos{width:28px;height:28px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:rgba(36,78,156,.10);color:#244E9C;font-size:12px;font-weight:900;font-variant-numeric:tabular-nums;}
.pm-voting-rank-body{display:flex;flex-direction:column;gap:5px;min-width:0;}
.pm-voting-rank-line{display:flex;align-items:baseline;justify-content:space-between;gap:10px;min-width:0;}
.pm-voting-rank-label{font-size:12px;font-weight:700;color:#1F3D7A;line-height:1.35;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pm-voting-rank-value{font-size:12px;font-weight:900;color:#1F3D7A;font-variant-numeric:tabular-nums;white-space:nowrap;}
.pm-voting-rank-value em{display:inline-block;margin-left:3px;font-size:10.5px;font-weight:800;color:#244E9C;background:rgba(36,78,156,.10);padding:1px 6px;border-radius:999px;font-style:normal;}
.pm-voting-rank-bar{height:6px;border-radius:999px;background:rgba(36,78,156,.10);overflow:hidden;}
.pm-voting-rank-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#4A7FE0,#244E9C);transition:width .3s ease;}
.pm-voting-rank--sky .pm-voting-rank-pos{background:rgba(14,165,233,.12);color:#0369A1;}
.pm-voting-rank--sky .pm-voting-rank-bar span{background:linear-gradient(90deg,#38BDF8,#0EA5E9);}
.pm-voting-rank--green .pm-voting-rank-pos{background:rgba(12,155,110,.12);color:#0C9B6E;}
.pm-voting-rank--green .pm-voting-rank-bar span{background:linear-gradient(90deg,#34D399,#0C9B6E);}
.pm-voting-rank--amber .pm-voting-rank-pos{background:rgba(245,158,11,.14);color:#B45309;}
.pm-voting-rank--amber .pm-voting-rank-bar span{background:linear-gradient(90deg,#FBBF24,#F59E0B);}

.pm-voting-age-chart{display:flex;flex-direction:column;gap:6px;}

/* ===== Relatório de Ação — componentes específicos (estilo elegante) ===== */
.pm-action-elegant .pm-voting-stat-list li strong{text-align:left;}

.pm-action-data-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.pm-action-data-card{position:relative;display:flex;flex-direction:column;gap:6px;padding:12px 14px 12px 18px;border-radius:14px;background:linear-gradient(180deg,#FFFFFF 0%,#F7FAFF 100%);border:1px solid rgba(36,78,156,.10);box-shadow:0 4px 10px rgba(20,40,80,.04);min-width:0;overflow:hidden;}
.pm-action-data-card::before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:3px;background:linear-gradient(180deg,#4A7FE0,#244E9C);}
.pm-action-data-label{font-size:10.5px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;color:#5B719E;line-height:1.35;}
.pm-action-data-value{font-size:14px;font-weight:800;color:#1F3D7A;line-height:1.45;overflow-wrap:break-word;word-break:break-word;white-space:normal;}
.pm-action-data-card-wide{grid-column:1 / -1;}

.pm-action-bullet-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;}
.pm-action-bullet-list li{position:relative;padding:10px 12px 10px 30px;border-radius:12px;background:#F4F8FF;border:1px solid rgba(36,78,156,.08);color:#244E9C;font-size:12.5px;line-height:1.55;font-weight:600;overflow-wrap:break-word;word-break:break-word;}
.pm-action-bullet-list li::before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#4A7FE0,#244E9C);box-shadow:0 0 0 3px rgba(36,78,156,.12);}

.pm-action-street-list{display:flex;flex-direction:column;gap:8px;}
.pm-action-street-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;border:1px solid rgba(36,78,156,.10);background:linear-gradient(180deg,#FFFFFF 0%,#F7FAFF 100%);box-shadow:0 4px 10px rgba(20,40,80,.04);min-width:0;}
.pm-action-street-info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1;}
.pm-action-street-info strong{font-size:13px;font-weight:800;color:#1F3D7A;line-height:1.35;text-align:left;overflow-wrap:break-word;word-break:break-word;white-space:normal;}
.pm-action-street-info span{font-size:11.5px;font-weight:600;color:#5B719E;line-height:1.45;overflow-wrap:break-word;word-break:break-word;}
.pm-action-street-tag{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border-radius:999px;font-size:10.5px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;flex:0 0 auto;}

html[data-theme="dark"] .pm-action-data-card{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-action-data-label{color:#9BB4E8;}
html[data-theme="dark"] .pm-action-data-value{color:#E8EFFF;}
html[data-theme="dark"] .pm-action-bullet-list li{background:rgba(36,78,156,.18);border-color:rgba(127,165,235,.20);color:#D6E3FB;}
html[data-theme="dark"] .pm-action-street-item{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-action-street-info strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-action-street-info span{color:#9BB4E8;}

@media (max-width:520px){
  .pm-action-data-grid{grid-template-columns:1fr;}
}

/* ===========================================================
 * Painel: Bairros · Indicadores Socioeconômicos (CadÚnico)
 * =========================================================== */
.pm-socio-panel{display:flex;flex-direction:column;gap:14px;}
.pm-socio-hero{position:relative;padding:18px 18px 16px;border-radius:20px;background:linear-gradient(135deg,#244E9C 0%,#3D6ED1 55%,#5C8DEC 100%);color:#FFFFFF;box-shadow:0 16px 32px -16px rgba(36,78,156,.55);overflow:hidden;}
.pm-socio-hero::before{content:"";position:absolute;inset:auto -40px -50px auto;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.22),rgba(255,255,255,0));pointer-events:none;}
.pm-socio-hero::after{content:"";position:absolute;inset:-30px auto auto -40px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.15),rgba(255,255,255,0));pointer-events:none;}
.pm-socio-eyebrow{display:inline-flex;align-items:center;align-self:flex-start;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.18);color:#FFFFFF;font-size:10.5px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;backdrop-filter:blur(8px);}
.pm-socio-title{display:block;font-size:18px;font-weight:900;line-height:1.2;margin:8px 0 6px;letter-spacing:-.01em;}
.pm-socio-sub{margin:0;font-size:12.5px;line-height:1.55;color:rgba(255,255,255,.92);font-weight:500;}

.pm-socio-card{display:flex;flex-direction:column;gap:10px;padding:14px 14px 12px;border-radius:18px;background:linear-gradient(180deg,#FFFFFF 0%,#F7FAFF 100%);border:1px solid rgba(36,78,156,.10);box-shadow:0 6px 14px rgba(20,40,80,.05);}
.pm-socio-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.pm-socio-card-head strong{font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-socio-reset{border:1px solid rgba(36,78,156,.22);background:rgba(255,255,255,.85);color:#244E9C;border-radius:999px;padding:5px 12px;font-size:10.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:.2s ease;}
.pm-socio-reset:hover{background:#244E9C;color:#FFFFFF;border-color:#244E9C;}
.pm-socio-label{font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-socio-select-wrap{position:relative;}
.pm-socio-select{width:100%;appearance:none;-webkit-appearance:none;background:#FFFFFF;border:1px solid rgba(36,78,156,.22);border-radius:14px;padding:11px 36px 11px 14px;font-size:13.5px;font-weight:700;color:#1F3D7A;cursor:pointer;outline:none;transition:.2s ease;}
.pm-socio-select:hover{border-color:rgba(36,78,156,.4);}
.pm-socio-select:focus{border-color:#244E9C;box-shadow:0 0 0 3px rgba(36,78,156,.18);}
.pm-socio-select-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#244E9C;pointer-events:none;}
.pm-socio-hint{font-size:11.5px;font-weight:600;line-height:1.45;color:#5B719E;background:rgba(36,78,156,.05);border-radius:10px;padding:8px 10px;}

.pm-socio-slider-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.pm-socio-slider-block{display:flex;flex-direction:column;gap:6px;min-width:0;}
.pm-socio-slider-block label{font-size:10.5px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#244E9C;line-height:1.35;}
.pm-socio-slider-block input[type="range"]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:linear-gradient(90deg,#244E9C 0%,#5C8DEC 100%);outline:none;cursor:pointer;}
.pm-socio-slider-block input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#FFFFFF;border:3px solid #244E9C;box-shadow:0 4px 10px rgba(20,40,80,.25);cursor:pointer;transition:.18s ease;}
.pm-socio-slider-block input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.1);}
.pm-socio-slider-block input[type="range"]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#FFFFFF;border:3px solid #244E9C;box-shadow:0 4px 10px rgba(20,40,80,.25);cursor:pointer;}
.pm-socio-slider-value{display:flex;align-items:baseline;gap:5px;font-size:12.5px;color:#5B719E;font-weight:600;}
.pm-socio-slider-value strong{color:#1F3D7A;font-size:14px;font-weight:900;}

.pm-socio-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:12px;border-radius:16px;background:linear-gradient(135deg,#F4F8FF 0%,#EAF1FF 100%);border:1px solid rgba(36,78,156,.12);}
.pm-socio-stat{display:flex;flex-direction:column;gap:2px;text-align:center;min-width:0;}
.pm-socio-stat span{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#5B719E;}
.pm-socio-stat strong{font-size:16px;font-weight:900;color:#244E9C;line-height:1.2;}

.pm-socio-legend{display:flex;flex-direction:column;gap:8px;padding:14px;border-radius:18px;background:#FFFFFF;border:1px solid rgba(36,78,156,.10);box-shadow:0 6px 14px rgba(20,40,80,.05);}
.pm-socio-legend-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:2px;}
.pm-socio-legend-head strong{font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-socio-legend-head span{font-size:11px;font-weight:700;color:#5B719E;}
.pm-socio-legend-row{display:flex;align-items:center;gap:10px;}
.pm-socio-swatch{display:inline-block;width:22px;height:22px;border-radius:6px;box-shadow:inset 0 0 0 1px rgba(36,78,156,.18),0 2px 4px rgba(20,40,80,.08);flex:0 0 auto;}
.pm-socio-legend-label{font-size:12.5px;font-weight:700;color:#1F3D7A;}
.pm-socio-foot{font-size:10.5px;line-height:1.5;color:#5B719E;background:rgba(36,78,156,.05);border-radius:10px;padding:8px 10px;margin-top:4px;}

/* Dark mode adaptations */
html[data-theme="dark"] .pm-socio-card{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-socio-card-head strong,
html[data-theme="dark"] .pm-socio-label,
html[data-theme="dark"] .pm-socio-slider-block label{color:#9BB4E8;}
html[data-theme="dark"] .pm-socio-reset{background:rgba(255,255,255,.06);border-color:rgba(127,165,235,.30);color:#D6E3FB;}
html[data-theme="dark"] .pm-socio-reset:hover{background:#244E9C;color:#FFFFFF;}
html[data-theme="dark"] .pm-socio-select{background:#1A2541;border-color:rgba(127,165,235,.30);color:#E8EFFF;}
html[data-theme="dark"] .pm-socio-select-icon{color:#9BB4E8;}
html[data-theme="dark"] .pm-socio-hint{background:rgba(36,78,156,.18);color:#D6E3FB;}
html[data-theme="dark"] .pm-socio-slider-value{color:#9BB4E8;}
html[data-theme="dark"] .pm-socio-slider-value strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-socio-stats{background:linear-gradient(135deg,rgba(36,78,156,.20) 0%,rgba(36,78,156,.10) 100%);border-color:rgba(127,165,235,.20);}
html[data-theme="dark"] .pm-socio-stat span{color:#9BB4E8;}
html[data-theme="dark"] .pm-socio-stat strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-socio-legend{background:#1A2541;border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-socio-legend-head strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-socio-legend-head span{color:#9BB4E8;}
html[data-theme="dark"] .pm-socio-legend-label{color:#E8EFFF;}
html[data-theme="dark"] .pm-socio-foot{background:rgba(36,78,156,.20);color:#9BB4E8;}

@media (max-width:520px){
  .pm-socio-slider-row{grid-template-columns:1fr;}
  .pm-socio-stats{grid-template-columns:1fr 1fr;}
}

/* Quando o painel socioeconômico está ativo, ocupar toda a aba */
#pmtab-categorias.pm-socio-fullscreen .pm-cat-section,
#pmtab-categorias.pm-socio-fullscreen .pm-layers-card-head{display:none !important;}
#pmtab-categorias.pm-socio-fullscreen .pm-layers-card{flex:1;min-height:0;display:flex;flex-direction:column;background:transparent;border:none;box-shadow:none;padding:0;margin:0;}
#pmtab-categorias.pm-socio-fullscreen .pm-layers-card-body{flex:1;min-height:0;padding:0;}
#pmtab-categorias.pm-socio-fullscreen .pm-layers-list{padding:4px 4px 12px;}

/* ===========================================================
 * Cruzamento socioeconômico (CadÚnico) nos relatórios
 * (preview no painel de Saúde / Votação / População)
 * Layout responsivo, sem overflow, com cards horizontais
 * label esquerda / valor direita para evitar quebras feias.
 * =========================================================== */
.pm-socio-cross{display:flex;flex-direction:column;gap:12px;padding:14px;border-radius:18px;background:linear-gradient(135deg,rgba(126,34,206,.07) 0%,rgba(36,78,156,.05) 60%,rgba(70,164,229,.05) 100%);border:1px solid rgba(126,34,206,.18);box-shadow:0 8px 18px rgba(36,78,156,.06);min-width:0;}
.pm-socio-cross-head{display:flex;flex-direction:column;gap:4px;min-width:0;}
.pm-socio-cross-eyebrow{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:rgba(126,34,206,.14);color:#7E22CE;font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;}
.pm-socio-cross-title{font-size:15px;font-weight:900;color:#1F3D7A;letter-spacing:-.01em;overflow-wrap:break-word;word-break:break-word;}
.pm-socio-cross-sub{margin:0;font-size:12.5px;font-weight:600;color:#3A5995;line-height:1.5;overflow-wrap:break-word;}

/* KPIs principais: cards verticais (label em cima, valor em baixo) — funciona em qualquer largura */
.pm-socio-cross-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
.pm-socio-cross-kpi{display:flex;flex-direction:column;justify-content:space-between;gap:6px;padding:11px 12px;border-radius:13px;background:#FFFFFF;border:1px solid rgba(36,78,156,.10);box-shadow:0 4px 10px rgba(20,40,80,.04);min-width:0;min-height:74px;}
.pm-socio-cross-kpi span{display:block;font-size:11.5px;font-weight:700;color:#5B719E;line-height:1.3;overflow-wrap:break-word;min-width:0;hyphens:auto;}
.pm-socio-cross-kpi strong{display:block;font-size:18px;font-weight:900;color:#244E9C;letter-spacing:-.02em;line-height:1.05;font-variant-numeric:tabular-nums;overflow-wrap:break-word;}

/* Highlights (cards menores): verticais para nunca quebrar letra-a-letra */
.pm-socio-cross-highlights{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
.pm-socio-cross-highlight{display:flex;flex-direction:column;gap:4px;padding:9px 11px;border-radius:11px;background:rgba(255,255,255,.85);border:1px dashed rgba(36,78,156,.18);min-width:0;min-height:64px;}
.pm-socio-cross-highlight span{display:block;min-width:0;font-size:11px;font-weight:600;color:#5B719E;line-height:1.3;overflow-wrap:break-word;hyphens:auto;}
.pm-socio-cross-highlight strong{display:block;font-size:14px;font-weight:900;color:#1F3D7A;letter-spacing:-.01em;font-variant-numeric:tabular-nums;overflow-wrap:break-word;}
.pm-socio-cross-highlight em{align-self:flex-start;font-style:normal;font-size:10px;font-weight:700;color:#7E22CE;background:rgba(126,34,206,.12);padding:2px 7px;border-radius:6px;white-space:nowrap;}

.pm-socio-cross-bairros{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:14px;background:#FFFFFF;border:1px solid rgba(36,78,156,.10);box-shadow:0 4px 10px rgba(20,40,80,.05);min-width:0;}
.pm-socio-cross-bairros-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.pm-socio-cross-bairros-head strong{font-size:11.5px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#244E9C;}
.pm-socio-cross-bairros-head span{font-size:11px;font-weight:700;color:#5B719E;}
.pm-socio-cross-bairro-list{display:flex;flex-direction:column;gap:6px;}
.pm-socio-cross-bairro-item{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;background:rgba(36,78,156,.04);border:1px solid rgba(36,78,156,.08);min-width:0;}
.pm-socio-cross-bairro-item > div{display:flex;flex-direction:column;gap:2px;min-width:0;}
.pm-socio-cross-bairro-item strong{font-size:12.5px;font-weight:800;color:#1F3D7A;overflow-wrap:break-word;word-break:break-word;line-height:1.3;}
.pm-socio-cross-bairro-item span{font-size:11px;font-weight:600;color:#5B719E;line-height:1.4;overflow-wrap:break-word;}
.pm-socio-cross-bairro-item em{font-style:normal;font-size:10.5px;font-weight:800;color:#7E22CE;background:rgba(126,34,206,.12);padding:3px 8px;border-radius:8px;white-space:nowrap;flex:0 0 auto;}
.pm-socio-cross-foot{font-size:10.5px;line-height:1.5;color:#5B719E;background:rgba(36,78,156,.05);border-radius:10px;padding:8px 10px;overflow-wrap:break-word;}

html[data-theme="dark"] .pm-socio-cross{background:linear-gradient(135deg,rgba(126,34,206,.16) 0%,rgba(36,78,156,.18) 60%,rgba(70,164,229,.12) 100%);border-color:rgba(127,165,235,.28);}
html[data-theme="dark"] .pm-socio-cross-eyebrow{background:rgba(127,165,235,.18);color:#D6E3FB;}
html[data-theme="dark"] .pm-socio-cross-title{color:#FFFFFF;}
html[data-theme="dark"] .pm-socio-cross-sub{color:#B9CBED;}
html[data-theme="dark"] .pm-socio-cross-kpi,
html[data-theme="dark"] .pm-socio-cross-bairros{background:#1A2541;border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-socio-cross-kpi span,
html[data-theme="dark"] .pm-socio-cross-highlight span,
html[data-theme="dark"] .pm-socio-cross-bairros-head span,
html[data-theme="dark"] .pm-socio-cross-bairro-item span{color:#9BB4E8;}
html[data-theme="dark"] .pm-socio-cross-kpi strong,
html[data-theme="dark"] .pm-socio-cross-highlight strong,
html[data-theme="dark"] .pm-socio-cross-bairros-head strong,
html[data-theme="dark"] .pm-socio-cross-bairro-item strong{color:#FFFFFF;}
html[data-theme="dark"] .pm-socio-cross-highlight{background:rgba(255,255,255,.04);border-color:rgba(127,165,235,.20);}
html[data-theme="dark"] .pm-socio-cross-highlight em,
html[data-theme="dark"] .pm-socio-cross-bairro-item em{background:rgba(127,165,235,.20);color:#E8EFFF;}
html[data-theme="dark"] .pm-socio-cross-bairro-item{background:rgba(255,255,255,.04);border-color:rgba(127,165,235,.16);}
html[data-theme="dark"] .pm-socio-cross-foot{background:rgba(36,78,156,.22);color:#B9CBED;}

/* Em telas muito apertadas, colapsa para 1 coluna (evita aperto extremo) */
@media (max-width:380px){
  .pm-socio-cross-kpis{grid-template-columns:1fr;}
  .pm-socio-cross-highlights{grid-template-columns:1fr;}
  .pm-socio-cross-kpi{min-height:0;}
  .pm-socio-cross-highlight{min-height:0;}
}

/* CadÚnico — relatório de população (prévia no painel) */
.pm-action-report-section--cadunico{margin-top:4px;}
.pm-cadu-pop{position:relative;overflow:hidden;border-radius:20px;background:linear-gradient(180deg,#FAFBFF 0%,#FFFFFF 52%);border:1px solid rgba(36,78,156,.14);box-shadow:0 12px 32px rgba(36,78,156,.08);min-width:0;}
.pm-cadu-pop::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:linear-gradient(90deg,#244E9C 0%,#38BEEF 32%,#FCCF00 65%,#E9561E 100%);}
.pm-cadu-pop-hero{display:flex;flex-direction:column;gap:14px;padding:18px 18px 14px;}
@media (min-width:520px){
  .pm-cadu-pop-hero{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:16px;}
}
.pm-cadu-pop-tag{align-self:flex-start;display:inline-flex;padding:5px 11px;border-radius:999px;background:rgba(36,78,156,.1);border:1px solid rgba(36,78,156,.16);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:#244E9C;}
.pm-cadu-pop-title{margin:8px 0 6px;font-size:17px;font-weight:900;color:#1a3d7a;letter-spacing:-.02em;line-height:1.2;}
.pm-cadu-pop-sub{margin:0;font-size:12.5px;font-weight:600;color:#3a5995;line-height:1.55;max-width:52ch;}
.pm-cadu-pop-summary{flex:0 1 auto;max-width:100%;padding:11px 14px;border-radius:14px;background:rgba(36,78,156,.06);border:1px solid rgba(36,78,156,.12);font-size:11.5px;font-weight:600;color:#244E9C;line-height:1.45;overflow-wrap:break-word;}
.pm-cadu-pop-body{padding:0 14px 6px;display:flex;flex-direction:column;gap:14px;}
.pm-cadu-group{padding:14px 14px 12px;border-radius:16px;background:#FFFFFF;border:1px solid rgba(36,78,156,.1);box-shadow:0 4px 14px rgba(20,40,80,.04);}
.pm-cadu-group-head{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(36,78,156,.1);}
.pm-cadu-group-head strong{display:block;font-size:11.5px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-cadu-group-head span{display:block;margin-top:4px;font-size:11.5px;font-weight:600;color:#5b719e;line-height:1.45;}
.pm-cadu-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(152px,1fr));gap:10px;}
.pm-cadu-tile{display:flex;gap:11px;align-items:flex-start;padding:12px 12px 11px;border-radius:14px;border:1px solid rgba(36,78,156,.1);background:#F8FAFF;border-left-width:4px;border-left-style:solid;min-width:0;}
.pm-cadu-tile--blue{border-left-color:#244E9C;}
.pm-cadu-tile--green{border-left-color:#0C9B6E;}
.pm-cadu-tile--sky{border-left-color:#38BEEF;}
.pm-cadu-tile--amber{border-left-color:#F59E0B;}
.pm-cadu-tile--pink{border-left-color:#E9561E;}
.pm-cadu-tile--purple{border-left-color:#7E22CE;}
.pm-cadu-tile--orange{border-left-color:#EA580C;}
.pm-cadu-tile-ico{flex:0 0 auto;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:rgba(36,78,156,.08);color:#244E9C;}
.pm-cadu-tile-ico svg{display:block;width:18px;height:18px;}
.pm-cadu-tile-body{min-width:0;display:flex;flex-direction:column;gap:4px;}
.pm-cadu-tile-label{font-size:10.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#5b719e;line-height:1.25;}
.pm-cadu-tile-value{font-size:18px;font-weight:900;color:#1a3d7a;letter-spacing:-.02em;line-height:1.1;font-variant-numeric:tabular-nums;overflow-wrap:break-word;}
.pm-cadu-tile-hint{font-size:11px;font-weight:600;color:#3a5995;line-height:1.35;}
.pm-cadu-bairros{margin:14px;padding:14px;border-radius:16px;background:#FFFFFF;border:1px solid rgba(36,78,156,.1);box-shadow:0 4px 14px rgba(20,40,80,.04);}
.pm-cadu-bairros-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:10px;}
.pm-cadu-bairros-head strong{font-size:11.5px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-cadu-bairros-head span{font-size:11px;font-weight:700;color:#5b719e;}
.pm-cadu-bairros-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px;border:1px solid rgba(36,78,156,.1);}
.pm-cadu-bairros-table{width:100%;border-collapse:collapse;font-size:12px;}
.pm-cadu-bairros-table thead th{text-align:left;padding:10px 11px;background:linear-gradient(180deg,#244E9C 0%,#1e3f7a 100%);color:#fff;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;}
.pm-cadu-bairros-table thead th:not(:first-child){text-align:right;}
.pm-cadu-bairros-table tbody td{padding:9px 11px;border-top:1px solid #e8eef8;color:#1a3d7a;font-weight:600;}
.pm-cadu-bairros-table tbody td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums;font-weight:700;}
.pm-cadu-bairros-table tbody tr:nth-child(even) td{background:#f6f9ff;}
.pm-cadu-pop-foot{margin:0;padding:12px 18px 16px;font-size:10.5px;line-height:1.5;color:#5b719e;border-top:1px solid rgba(36,78,156,.1);background:rgba(36,78,156,.03);}

html[data-theme="dark"] .pm-cadu-pop{background:linear-gradient(180deg,#141c2e 0%,#1a2541 55%);border-color:rgba(127,165,235,.22);box-shadow:0 12px 28px rgba(0,0,0,.25);}
html[data-theme="dark"] .pm-cadu-pop-tag{background:rgba(127,165,235,.14);border-color:rgba(127,165,235,.24);color:#D6E3FB;}
html[data-theme="dark"] .pm-cadu-pop-title{color:#FFFFFF;}
html[data-theme="dark"] .pm-cadu-pop-sub{color:#B9CBED;}
html[data-theme="dark"] .pm-cadu-pop-summary{background:rgba(36,78,156,.25);border-color:rgba(127,165,235,.2);color:#E8EFFF;}
html[data-theme="dark"] .pm-cadu-group{background:#1A2541;border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-cadu-group-head{border-bottom-color:rgba(127,165,235,.16);}
html[data-theme="dark"] .pm-cadu-group-head strong{color:#D6E3FB;}
html[data-theme="dark"] .pm-cadu-group-head span{color:#9BB4E8;}
html[data-theme="dark"] .pm-cadu-tile{background:rgba(255,255,255,.04);border-color:rgba(127,165,235,.16);}
html[data-theme="dark"] .pm-cadu-tile-ico{background:rgba(127,165,235,.14);color:#D6E3FB;}
html[data-theme="dark"] .pm-cadu-tile-label{color:#9BB4E8;}
html[data-theme="dark"] .pm-cadu-tile-value{color:#FFFFFF;}
html[data-theme="dark"] .pm-cadu-tile-hint{color:#B9CBED;}
html[data-theme="dark"] .pm-cadu-bairros{background:#1A2541;border-color:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-cadu-bairros-head strong{color:#D6E3FB;}
html[data-theme="dark"] .pm-cadu-bairros-head span{color:#9BB4E8;}
html[data-theme="dark"] .pm-cadu-bairros-table-wrap{border-color:rgba(127,165,235,.16);}
html[data-theme="dark"] .pm-cadu-bairros-table tbody td{color:#E8EFFF;border-top-color:rgba(127,165,235,.12);}
html[data-theme="dark"] .pm-cadu-bairros-table tbody tr:nth-child(even) td{background:rgba(255,255,255,.03);}
html[data-theme="dark"] .pm-cadu-pop-foot{color:#9BB4E8;border-top-color:rgba(127,165,235,.14);background:rgba(0,0,0,.15);}

/* ===========================================================
 * Popup do mapa para a camada socioeconômica (renderizado
 * dentro do iframe via ol.Overlay — estilo herdado globalmente).
 * =========================================================== */
.pm-socio-popup{padding:14px 16px 14px;font-family:Poppins,Arial,sans-serif;color:#1F3D7A;}
.pm-socio-popup-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding-bottom:8px;margin-bottom:10px;border-bottom:1px solid rgba(36,78,156,.12);}
.pm-socio-popup-head strong{font-size:14px;font-weight:900;color:#244E9C;letter-spacing:-.01em;}
.pm-socio-popup-head span{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#5B719E;}
.pm-socio-popup-hero{display:flex;flex-direction:column;gap:3px;padding:10px 12px;border-radius:12px;background:linear-gradient(135deg,rgba(36,78,156,.12) 0%,rgba(36,78,156,.04) 100%);margin-bottom:12px;}
.pm-socio-popup-hero strong{font-size:18px;font-weight:900;color:#244E9C;letter-spacing:-.02em;line-height:1.2;}
.pm-socio-popup-hero small{font-size:10.5px;font-weight:600;color:#5B719E;line-height:1.4;}
.pm-socio-popup-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px 12px;}
.pm-socio-popup-grid > div{display:flex;flex-direction:column;gap:1px;min-width:0;}
.pm-socio-popup-grid span{font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#5B719E;line-height:1.3;}
.pm-socio-popup-grid strong{font-size:12px;font-weight:800;color:#1F3D7A;line-height:1.35;display:flex;align-items:baseline;gap:5px;flex-wrap:wrap;}
.pm-socio-popup-grid strong em{font-style:normal;font-size:10px;font-weight:700;color:#244E9C;background:rgba(36,78,156,.12);padding:1px 6px;border-radius:6px;}

html[data-theme="dark"] .pm-voting-preview-objective{background:rgba(36,78,156,.18);border-color:rgba(127,165,235,.22);color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-preview-title{color:#FFFFFF;}
html[data-theme="dark"] .pm-voting-preview-sub{color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-preview-meta{color:#9BB4E8;}
html[data-theme="dark"] .pm-voting-preview-eyebrow{background:rgba(127,165,235,.18);color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-kpi{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.01) 100%);border-color:rgba(127,165,235,.18);box-shadow:0 6px 14px rgba(0,0,0,.25);}
html[data-theme="dark"] .pm-voting-kpi-label{color:#9BB4E8;}
html[data-theme="dark"] .pm-voting-kpi-value{color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-section{background:#1A2541;border-color:rgba(127,165,235,.18);box-shadow:0 6px 16px rgba(0,0,0,.30);}
html[data-theme="dark"] .pm-voting-section-head strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-section-tag{background:rgba(127,165,235,.18);color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-stat-list li{border-bottom-color:rgba(127,165,235,.16);}
html[data-theme="dark"] .pm-voting-stat-list li span{color:#9BB4E8;}
html[data-theme="dark"] .pm-voting-stat-list li strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-stat-list li strong em{background:rgba(127,165,235,.18);color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-rank-label{color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-rank-value{color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-rank-value em{background:rgba(127,165,235,.18);color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-rank-bar{background:rgba(127,165,235,.18);}
html[data-theme="dark"] .pm-voting-rank--empty{background:rgba(127,165,235,.10);color:#9BB4E8;}
html[data-theme="dark"] .pm-voting-rank-pos{background:rgba(127,165,235,.18);color:#D6E3FB;}

@media (max-width:420px){
  .pm-voting-kpi-grid{grid-template-columns:1fr;}
}

html[data-theme="dark"] .pm-voting-picker-hint{background:linear-gradient(135deg,rgba(36,78,156,.18) 0%,rgba(36,78,156,.10) 100%);border-color:rgba(127,165,235,.45);color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-picker-hint-icon{background:rgba(255,255,255,.08);color:#D6E3FB;box-shadow:0 6px 18px rgba(0,0,0,.35);}
html[data-theme="dark"] .pm-voting-picker-hint-copy strong{color:#FFFFFF;}
html[data-theme="dark"] .pm-voting-picker-hint-copy span{color:#B9CBED;}
html[data-theme="dark"] .pm-voting-picked-card{background:#1A2541;border-color:rgba(127,165,235,.18);box-shadow:0 14px 28px rgba(0,0,0,.40);}
html[data-theme="dark"] .pm-voting-picked-image{background-color:#22325A;}
html[data-theme="dark"] .pm-voting-picked-stack{color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-picked-name{color:#FFFFFF;}
html[data-theme="dark"] .pm-voting-picked-address{color:#B9CBED;}
html[data-theme="dark"] .pm-voting-picked-stats{border-top-color:rgba(127,165,235,.15);}
html[data-theme="dark"] .pm-voting-picked-stats span{color:#9BB4E8;}
html[data-theme="dark"] .pm-voting-picked-tag{background:rgba(127,165,235,.18);color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-picked-change{background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,rgba(255,255,255,.03) 100%);border-color:rgba(127,165,235,.35);color:#D6E3FB;}
html[data-theme="dark"] .pm-voting-picked-change:hover{background:rgba(127,165,235,.14);}
html[data-theme="dark"] .pm-voting-radius-field .pm-voting-radius-slider{background:linear-gradient(165deg,rgba(36,78,156,.22) 0%,rgba(26,37,65,.9) 100%);border-color:rgba(127,165,235,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.06);}
html[data-theme="dark"] .pm-voting-radius-slider input[type="range"]{background:linear-gradient(90deg,rgba(127,165,235,.45) 0%,rgba(127,165,235,.15) 100%);}
html[data-theme="dark"] .pm-voting-radius-slider input[type="range"]::-moz-range-track{background:linear-gradient(90deg,rgba(127,165,235,.45) 0%,rgba(127,165,235,.15) 100%);}
html[data-theme="dark"] .pm-voting-radius-value{background:rgba(255,255,255,.06);border-color:rgba(127,165,235,.22);}
html[data-theme="dark"] .pm-voting-radius-value strong{color:#E8EFFF;}
html[data-theme="dark"] .pm-voting-radius-unit{color:#9BB4E8;}
html[data-theme="dark"] .pm-voting-report-image{background:#1A2541;border-color:rgba(127,165,235,.18);}
.pm-report-actions-row .pm-action-back.is-active{background:#244E9C;color:#FFFFFF;border-color:#244E9C;}
.pm-report-selected-empty,.pm-report-preview-empty{display:grid;gap:6px;padding:8px 2px;color:#244E9C;font-size:13px;line-height:1.55;}
.pm-report-street-table{display:grid;gap:6px;margin-top:10px;}
.pm-report-street-head,.pm-report-street-row{display:grid;grid-template-columns:minmax(0,1fr) 120px;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;}
.pm-report-street-head{background:#EDF4FF;border:1px solid rgba(36,78,156,.10);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-report-street-row{border:1px solid rgba(36,78,156,.08);background:#FFFFFF;}
.pm-report-street-row strong{font-size:12px;line-height:1.45;color:#244E9C;}
.pm-report-street-row span{font-size:12px;line-height:1.45;color:#244E9C;font-weight:700;text-align:right;}
.pm-report-selected-list{display:flex;flex-direction:column;gap:8px;max-height:280px;overflow:auto;padding-right:4px;}
.pm-report-selected-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;border:1px solid rgba(36,78,156,.10);background:#FFFFFF;}
.pm-report-selected-copy{display:flex;flex-direction:column;gap:4px;min-width:0;}
.pm-report-selected-copy strong{font-size:13px;line-height:1.4;color:#244E9C;}
.pm-report-selected-copy span{font-size:11px;line-height:1.55;color:#244E9C;}
.pm-report-library-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:18px;border:1px solid rgba(36,78,156,.10);background:#FFFFFF;}
.pm-report-library-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;}
.pm-report-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:rgba(36,78,156,.08);color:#244E9C;font-size:11px;font-weight:800;}
.pm-report-preview-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.pm-report-preview-head .pm-action-progress-badge{background:rgba(233,86,30,.12);color:#E9561E;}
.pm-report-preview-actions{display:flex;gap:10px;flex-wrap:wrap;}
.pm-action-grid,
.pm-action-modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.pm-action-modal-sections{display:flex;flex-direction:column;gap:12px;margin-top:12px;}
.pm-action-field{display:flex;flex-direction:column;gap:6px;}
.pm-action-field span{font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#244E9C;}
.pm-action-field-hint{font-size:11px;line-height:1.5;color:#244E9C;}
.pm-action-field input,
.pm-action-field select,
.pm-action-field textarea{width:100%;border:1px solid rgba(36,78,156,.14);border-radius:14px;background:#FFFFFF;color:#244E9C;padding:11px 12px;font:600 13px/1.4 inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.85);}
.pm-action-field textarea{resize:vertical;min-height:86px;}
.pm-action-inline{display:flex;align-items:center;gap:8px;}
.pm-action-inline small{font-size:12px;color:#244E9C;font-weight:700;}
.pm-action-toolbar{display:flex;gap:10px;}
.pm-action-toolbar-end{justify-content:flex-end;flex-wrap:wrap;}
.pm-action-placement-tools{display:flex;gap:10px;flex-wrap:wrap;}
.pm-action-create,.pm-action-clear,.pm-action-item-tools button,.pm-action-export{min-height:42px;padding:0 16px;border-radius:14px;border:1px solid rgba(36,78,156,.16);font:800 12px/1 inherit;cursor:pointer;transition:transform .15s ease, box-shadow .18s ease, background .18s ease;}
.pm-action-create{background:#244E9C;color:#FFFFFF;box-shadow:0 12px 22px rgba(36,78,156,.18);}
.pm-action-create.active{background:#F7FBFF;color:#244E9C;}
.pm-action-clear,.pm-action-item-tools button,.pm-action-export{background:#FFFFFF;color:#244E9C;}
.pm-action-status{padding:12px 13px;border-radius:14px;background:#244E9C;color:#244E9C;font-size:12px;line-height:1.5;border:1px solid rgba(36,78,156,.12);}
.pm-action-modal{max-width:920px;}
.pm-action-modal .pm-modal-body{padding:20px;}
.pm-action-modal.pm-modal{position:relative;z-index:6001;max-height:min(92vh,960px);overflow:auto;}
.pm-action-list,.pm-action-report{display:flex;flex-direction:column;gap:12px;}
.pm-action-bulk-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:16px;border:1px solid rgba(36,78,156,.12);background:rgba(36,78,156,.04);}
.pm-action-bulk-check{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;color:#244E9C;cursor:pointer;user-select:none;}
.pm-action-bulk-check input{width:16px;height:16px;accent-color:#244E9C;cursor:pointer;}
.pm-action-bulk-delete{min-height:40px;padding:0 14px;border-radius:14px;border:1px solid rgba(198,74,18,.22);background:rgba(233,86,30,.08);color:#C44A12;font:800 12px/1 inherit;cursor:pointer;transition:background .18s ease,opacity .18s ease;}
.pm-action-bulk-delete:hover:not(:disabled){background:rgba(233,86,30,.14);}
.pm-action-bulk-delete:disabled{opacity:.45;cursor:not-allowed;}
.pm-action-empty{display:grid;gap:6px;justify-items:flex-start;padding:8px 2px;color:#244E9C;font-size:13px;line-height:1.5;}
.pm-action-item{position:relative;display:flex;flex-direction:column;gap:12px;padding:16px;border-radius:22px;border:1px solid color-mix(in srgb, var(--action-accent, #244E9C) 14%, rgba(36,78,156,.10));background:#FFFFFF;cursor:pointer;transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;overflow:hidden;}
.pm-action-item-selected{border-color:rgba(36,78,156,.28);box-shadow:0 0 0 2px rgba(36,78,156,.12);}
.pm-action-item-check{display:inline-flex;align-items:flex-start;padding-top:2px;flex:0 0 auto;cursor:pointer;}
.pm-action-item-check input{width:18px;height:18px;accent-color:#244E9C;cursor:pointer;}
.pm-action-item-head-copy{flex:1;min-width:0;}
.pm-action-item::before{content:"";position:absolute;left:0;top:16px;bottom:16px;width:4px;border-radius:999px;background:var(--action-accent, #244E9C);}
.pm-action-item:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(36,78,156,.09);border-color:color-mix(in srgb, var(--action-accent, #244E9C) 24%, rgba(36,78,156,.10));}
.pm-action-item-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;}
.pm-action-item-head .pm-action-item-check + .pm-action-item-head-copy{margin-left:0;}
.pm-action-item-title{font-size:18px;font-weight:900;color:#244E9C;letter-spacing:-.02em;}
.pm-action-item-sub{font-size:13px;color:#244E9C;line-height:1.55;}
.pm-action-item-progress{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;background:rgba(36,78,156,.10);color:#244E9C;font-size:11px;font-weight:800;}
.pm-action-item-progress-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex:0 0 auto;}
.pm-action-progress-edit{display:flex;flex-direction:column;align-items:flex-end;gap:4px;}
.pm-action-progress-edit small{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-action-progress-edit input{width:72px;height:34px;border:1px solid rgba(36,78,156,.14);border-radius:12px;background:#FFFFFF;color:#244E9C;padding:0 10px;text-align:center;font:800 12px/1 inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,.85);}
.pm-action-item-objective{font-size:14px;line-height:1.7;color:#244E9C;}
.pm-action-item-extra{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:12px;color:#244E9C;}
.pm-action-item-extra strong{color:#244E9C;font-size:12px;}
.pm-action-image-preview{display:flex;flex-direction:column;gap:10px;}
.pm-action-image-preview-card{display:flex;align-items:center;gap:12px;padding:12px;border-radius:16px;border:1px solid rgba(36,78,156,.12);background:#FFFFFF;}
.pm-action-image-preview-card img{width:92px;height:72px;object-fit:cover;border-radius:12px;border:1px solid rgba(36,78,156,.10);flex:0 0 auto;}
.pm-action-image-preview-meta{display:flex;flex:1;min-width:0;flex-direction:column;gap:8px;}
.pm-action-image-preview-meta strong{font-size:13px;line-height:1.4;color:#244E9C;word-break:break-word;}
.pm-action-image-preview-meta button{align-self:flex-start;min-height:34px;padding:0 12px;border-radius:12px;border:1px solid rgba(36,78,156,.16);background:#FFFFFF;color:#244E9C;font:800 11px/1 inherit;cursor:pointer;}
.pm-action-item-tools{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;}
.pm-action-item-tools-quad{grid-template-columns:repeat(2,minmax(0,1fr));}
.pm-action-item-tools button{padding:0 10px;min-height:38px;}
.pm-action-report-shell{display:flex;flex-direction:column;gap:12px;}
.pm-action-report-topbar{display:flex;align-items:center;justify-content:flex-start;}
.pm-action-report-wrap{display:none;}
.pm-action-item-image{position:relative;overflow:hidden;border-radius:16px;border:1px solid rgba(36,78,156,.10);background:#FFFFFF;}
.pm-action-item-image img{display:block;width:100%;max-height:168px;object-fit:cover;}
.pm-action-item-image-badge{position:absolute;right:10px;top:10px;display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:28px;padding:0 10px;border-radius:999px;background:rgba(36,78,156,.92);color:#FFFFFF;font-size:11px;font-weight:800;box-shadow:0 8px 18px rgba(36,78,156,.18);}
.pm-action-report-card{display:flex;flex-direction:column;gap:14px;min-width:0;}
.pm-action-report-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;}
.pm-action-report-title{font-size:18px;font-weight:900;color:#244E9C;}
.pm-action-report-sub{font-size:12px;color:#244E9C;}
.pm-action-progress-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:999px;background:rgba(36,78,156,.10);color:#244E9C;font-size:11px;font-weight:900;}
.pm-action-progress-track{height:10px;border-radius:999px;background:#244E9C;overflow:hidden;}
.pm-action-progress-track i{display:block;height:100%;border-radius:999px;background:#244E9C;}
.pm-action-objective{font-size:13px;line-height:1.65;color:#244E9C;}
.pm-action-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.pm-action-meta-chip{display:flex;flex-direction:column;gap:5px;padding:12px;border-radius:14px;border:1px solid rgba(36,78,156,.08);background:#FFFFFF;}
.pm-action-meta-chip span{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#244E9C;}
.pm-action-meta-chip strong{font-size:13px;line-height:1.55;color:#244E9C;}
.pm-action-meta-chip-wide{grid-column:1 / -1;}
.pm-action-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.pm-action-kpi{padding:12px;border-radius:16px;border:1px solid rgba(36,78,156,.08);background:#FFFFFF;min-width:0;overflow:hidden;display:flex;flex-direction:column;gap:4px;}
.pm-action-kpi span{display:block;font-size:11px;color:#244E9C;margin-bottom:0;overflow-wrap:break-word;line-height:1.35;hyphens:auto;min-width:0;}
.pm-action-kpi strong{display:block;font-size:18px;line-height:1.15;color:#244E9C;overflow-wrap:break-word;font-variant-numeric:tabular-nums;min-width:0;}
@media (max-width:520px){
  .pm-action-kpis{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:380px){
  .pm-action-kpis{grid-template-columns:1fr;}
}
.pm-action-report-section{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:18px;border:1px solid rgba(36,78,156,.08);background:#FFFFFF;min-width:0;}
.pm-action-report-image{overflow:hidden;border-radius:16px;border:1px solid rgba(36,78,156,.10);background:#FFFFFF;}
.pm-action-report-image img{display:block;width:100%;max-height:300px;object-fit:cover;}
.pm-action-report-image-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.pm-action-report-image-grid img{display:block;width:100%;height:220px;object-fit:cover;border-radius:16px;border:1px solid rgba(36,78,156,.10);}
.pm-action-bullets{margin:0;padding-left:18px;color:#244E9C;display:grid;gap:8px;font-size:13px;line-height:1.55;}
.pm-action-traffic-head{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.pm-action-traffic-summary{margin:0;color:#244E9C;font-size:12px;line-height:1.65;}
.pm-action-traffic-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.02em;white-space:nowrap;}
.pm-action-traffic-badge-low{background:rgba(71,171,52,.12);color:#005E34;}
.pm-action-traffic-badge-medium{background:rgba(233,86,30,.14);color:#E9561E;}
.pm-action-traffic-badge-high{background:rgba(233,86,30,.12);color:#E9561E;}
.pm-action-traffic-street-list{display:grid;grid-template-columns:1fr;gap:10px;}
.pm-action-traffic-street{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border-radius:14px;border:1px solid rgba(36,78,156,.08);background:#FFFFFF;}
.pm-action-traffic-street strong{display:block;font-size:13px;line-height:1.35;color:#244E9C;}
.pm-action-traffic-street span{display:block;margin-top:4px;font-size:11px;color:#244E9C;}
.pm-action-traffic-street em{font-style:normal;font-size:11px;font-weight:800;white-space:nowrap;}
.pm-action-traffic-street-tone-low{color:#005E34;}
.pm-action-traffic-street-tone-medium{color:#E9561E;}
.pm-action-traffic-street-tone-high{color:#E9561E;}
.pm-action-age-chart{display:flex;flex-direction:column;gap:8px;}
.pm-action-age-bar{display:grid;grid-template-columns:52px 1fr 64px;gap:10px;align-items:center;font-size:12px;color:#244E9C;}
.pm-action-age-track{height:10px;border-radius:999px;background:#244E9C;overflow:hidden;}
.pm-action-age-track i{display:block;height:100%;border-radius:999px;background:#244E9C;}
html[data-theme="dark"] .pm-action-hero,
html[data-theme="dark"] .pm-action-list-wrap,
html[data-theme="dark"] .pm-action-report-wrap,
html[data-theme="dark"] .pm-report-builder-wrap,
html[data-theme="dark"] .pm-report-section-card,
html[data-theme="dark"] .pm-report-option-card,
html[data-theme="dark"] .pm-report-library-item,
html[data-theme="dark"] .pm-report-selected-item,
html[data-theme="dark"] .pm-action-item,
html[data-theme="dark"] .pm-action-kpi,
html[data-theme="dark"] .pm-action-report-section,
html[data-theme="dark"] .pm-action-image-preview-card,
html[data-theme="dark"] .pm-action-item-image,
html[data-theme="dark"] .pm-action-report-image,
html[data-theme="dark"] .pm-action-meta-chip{border-color:rgba(255,255,255,.08);}
.pm-map-sidebar.pm-map-sidebar-action-collapsed{opacity:1;}
@media (max-width:900px){.pm-action-grid,.pm-action-modal-grid,.pm-action-kpis,.pm-action-item-tools,.pm-action-item-tools-quad,.pm-action-meta-grid,.pm-action-report-image-grid{grid-template-columns:1fr;}}
@media (max-width:900px){.pm-report-toolbar,.pm-report-summary-grid{grid-template-columns:1fr;}.pm-report-library-item,.pm-report-selected-item,.pm-report-preview-head{display:grid;grid-template-columns:1fr;}.pm-report-library-actions,.pm-report-preview-actions{justify-content:flex-start;}}

.pm-map-loading-overlay{position:absolute;inset:0;z-index:60;display:none;align-items:center;justify-content:center;background:#FFFFFF;opacity:0;visibility:hidden;pointer-events:none;}
.pm-map-loading-overlay.show{display:none;opacity:0;visibility:hidden;pointer-events:none;}
.pm-map-loading-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:28px 34px;border-radius:24px;background:rgba(255,255,255,.96);box-shadow:0 18px 42px rgba(36,78,156,.12);}
.pm-map-loading-title{font-size:18px;font-weight:700;color:#244E9C;letter-spacing:.01em;}
.pm-map-loading-spinner{width:54px;height:54px;border-radius:50%;border:4px solid rgba(36,78,156,.16);border-top-color:#244E9C;animation:pmSpin .85s linear infinite;}
@keyframes pmSpin{to{transform:rotate(360deg);}}


/* ===== Ajustes finais: botões do mapa e overlay ===== */
.pm-map-area.map-loading .pm-maptop-right,
.pm-map-area.map-loading .pm-active-bar,
.pm-map-area.map-loading .pm-map-corner-top-right,
.pm-map-area.map-loading .pm-map-corner-right,
.pm-map-area.map-loading .pm-map-corner-bottom{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
.pm-maptop-right{gap:10px;}
.pm-streetview-trigger,
.pm-maptype-trigger{width:52px;min-width:52px;height:52px;padding:0;border-radius:18px;border:1px solid rgba(36,78,156,.12);background:#FFFFFF;color:#244E9C;box-shadow:0 10px 22px rgba(36,78,156,.10);}
.pm-streetview-trigger:hover,
.pm-maptype-trigger:hover{border-color:rgba(36,78,156,.22);background:#FFFFFF;color:#244E9C;box-shadow:0 14px 26px rgba(36,78,156,.14);}
.pm-streetview-trigger.active,
.pm-maptype-trigger.active{background:#FFFFFF;color:#244E9C;border-color:rgba(36,78,156,.18);}
.pm-streetview-trigger svg{width:22px;height:22px;}
.pm-maptype-trigger svg{width:20px;height:20px;}
.pm-map-loading-title{color:#244E9C;}
.pm-map-loading-spinner{border-color:rgba(36,78,156,.16);border-top-color:#244E9C;}
html[data-theme="light"] .pm-map-loading-spinner{border-color:rgba(36,78,156,.16) !important;border-top-color:#244E9C !important;}
html[data-theme="dark"] .pm-map-loading-spinner{border-color:rgba(255,255,255,.18) !important;border-top-color:#FFFFFF !important;}
html[data-theme="dark"] .pm-streetview-trigger,
html[data-theme="dark"] .pm-maptype-trigger,
html[data-theme="dark"] .pm-streetview-trigger.active,
html[data-theme="dark"] .pm-maptype-trigger.active{background:#161616;color:#f5f5f5;border-color:rgba(255,255,255,.18);}


/* ===== Ajustes solicitados finais ===== */
.censo-integrated[data-active-source="mapa"]{gap:0 !important;}
/* Rodapé: oculto na área do mapa (como antes) */
body.map-source-active .footer.pm-app-footer,
body.map-source-active footer.footer.pm-app-footer,
body.pm-standalone-map .footer.pm-app-footer,
body.pm-standalone-map footer.footer.pm-app-footer {
  display: none !important;
}

body.map-source-active .content{padding:0 !important;}
body.map-source-active .main{min-height:0 !important;}
body.map-source-active .source-switcher{margin-bottom:0 !important;}
body.map-source-active #panel-mapa,
body.map-source-active #panel-mapa.active,
body.map-source-active #sec-mapa,
body.map-source-active #sec-mapa.active,
body.map-source-active .pm-map-layout,
body.map-source-active .pm-map-layout-wrap,
body.map-source-active .pm-map-area{height:100% !important; min-height:0 !important;}

.pm-map-top-controls{top:10px !important; left:16px !important; right:16px !important; align-items:flex-start !important; justify-content:flex-end !important;}
.pm-active-bar{min-height:40px !important; max-height:42px !important; height:42px !important; flex-wrap:nowrap !important; padding:4px 8px !important; border-radius:18px !important; flex:0 1 min(820px, calc(100% - 156px)) !important; max-width:min(820px, calc(100% - 156px)) !important;}
.pm-maptop-right{gap:8px !important; align-items:center !important;}
html[data-theme="dark"] .pm-streetview-trigger,
html[data-theme="dark"] .pm-maptype-trigger,
html[data-theme="dark"] .pm-streetview-trigger.active,
html[data-theme="dark"] .pm-maptype-trigger.active{
  width:48px !important;
  min-width:48px !important;
  height:48px !important;
  padding:0 !important;
  border-radius:18px !important;
  border:1px solid rgba(255,255,255,.22) !important;
  background:#161616 !important;
  color:#f5f5f5 !important;
  box-shadow:0 12px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06) !important;
  backdrop-filter:blur(18px) saturate(145%) !important;
  -webkit-backdrop-filter:blur(18px) saturate(145%) !important;
}
.pm-streetview-trigger:hover,
.pm-maptype-trigger:hover,
.pm-streetview-trigger.active,
.pm-maptype-trigger.active{
  background:#FFFFFF !important;
  color:#244E9C !important;
  border-color:rgba(255,255,255,.56) !important;
}
html[data-theme="dark"] .pm-streetview-trigger:hover,
html[data-theme="dark"] .pm-maptype-trigger:hover,
html[data-theme="dark"] .pm-streetview-trigger.active,
html[data-theme="dark"] .pm-maptype-trigger.active{
  background:#242424 !important;
  color:#ffffff !important;
  border-color:rgba(255,255,255,.3) !important;
}
.pm-streetview-trigger svg,
.pm-maptype-trigger svg{width:20px !important; height:20px !important;}

.sb-section#secFav,
#secRecent,
#recentList{display:none !important;}


/* ===== Street View: ícone novo + clique confiável ===== */
.pm-maptop-right{position:relative;z-index:40 !important;}
.pm-maptype-wrap{position:relative;z-index:40 !important;}
.pm-streetview-trigger,
.pm-maptype-trigger{position:relative;z-index:41 !important;pointer-events:auto !important;cursor:pointer !important;-webkit-tap-highlight-color:transparent;}
.pm-streetview-trigger svg{width:22px !important;height:22px !important;display:block;}
.pm-streetview-trigger.active{background:#244E9C !important;color:#244E9C !important;border-color:rgba(36,78,156,.42) !important;box-shadow:0 18px 42px rgba(36,78,156,.16), inset 0 1px 0 rgba(255,255,255,.30) !important;}
html[data-theme="dark"] .pm-streetview-trigger.active{background:#2a2a2a !important;color:#ffffff !important;border-color:rgba(255,255,255,.28) !important;box-shadow:0 12px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.08) !important;}

@media (max-width: 900px){
  .pm-map-top-controls{gap:8px !important;}
  .pm-active-bar{flex:1 1 auto !important;max-width:none !important;}
  .pm-maptype-popover{right:0 !important;width:232px !important;}
  .pm-maptype-name{font-size:14px !important;white-space:nowrap !important;}
}

/* ===== Correção final: seletor de tipo de mapa ===== */
.pm-maptype-wrap{
  position:relative !important;
  z-index:80 !important;
  flex:0 0 auto !important;
}
.pm-maptype-popover{
  position:absolute !important;
  top:calc(100% + 12px) !important;
  right:0 !important;
  width:260px !important;
  min-width:260px !important;
  padding:12px !important;
  border-radius:24px !important;
  overflow:hidden !important;
  opacity:0;
  transform:translateY(-6px) scale(.98);
  pointer-events:none;
}
.pm-maptype-popover.open{
  opacity:1 !important;
  transform:translateY(0) scale(1) !important;
  pointer-events:auto !important;
}
.pm-maptype-grid{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}
.pm-maptype-card{
  appearance:none !important;
  -webkit-appearance:none !important;
  width:100% !important;
  min-width:0 !important;
  min-height:unset !important;
  padding:10px !important;
  display:grid !important;
  grid-template-columns:84px minmax(0,1fr) !important;
  align-items:center !important;
  gap:12px !important;
  border-radius:18px !important;
  overflow:hidden !important;
  text-align:left !important;
}
.pm-maptype-thumb{
  display:block !important;
  width:84px !important;
  min-width:84px !important;
  height:64px !important;
  aspect-ratio:auto !important;
  border-radius:14px !important;
  background-size:cover !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  box-shadow:inset 0 0 0 1px rgba(36,78,156,.08) !important;
}
.pm-maptype-name{
  display:block !important;
  min-width:0 !important;
  white-space:normal !important;
  line-height:1.2 !important;
  font-size:13px !important;
  font-weight:800 !important;
}
@media (max-width: 900px){
  .pm-maptype-popover{
    width:228px !important;
    min-width:228px !important;
  }
  .pm-maptype-card{
    grid-template-columns:76px minmax(0,1fr) !important;
  }
  .pm-maptype-thumb{
    width:76px !important;
    min-width:76px !important;
    height:58px !important;
  }
}


/* ===== USF + APS: indicadores resumidos por unidade ===== */
.map-info-detail-health{padding-bottom:12px;}
/* Sidebar estreita: evita vazamento de grid/flex nos cards de ranking (eleitoral, saúde, educação) */
.map-info-detail-health .mid-feature-layout-health-premium{
  min-width:0;
  width:100%;
  box-sizing:border-box;
}
.map-info-detail-health .usf-health-box-premium{min-width:0;box-sizing:border-box;}
.map-info-detail-health .usf-health-insight-grid-premium{
  min-width:0;
  width:100%;
  max-width:100%;
}
.usf-health-title{margin-bottom:10px;font-size:18px;font-weight:800;line-height:1.2;color:var(--pm-accent, #244E9C);}
.usf-health-period{margin-top:-2px;font-size:11px;font-weight:700;letter-spacing:.02em;color:var(--muted, #244E9C);}
.usf-health-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.usf-health-kpi{padding:12px 12px;border-radius:14px;border:1px solid rgba(36,78,156,.10);background:#F8FAFC;display:flex;flex-direction:column;gap:4px;}
.usf-health-kpi span{font-size:11px;font-weight:600;color:var(--muted, #244E9C);}
.usf-health-kpi strong{font-size:20px;line-height:1;color:var(--text, #244E9C);}
.usf-health-kpi small{font-size:10px;color:var(--muted, #244E9C);}
.usf-health-insight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
.usf-health-box{padding:12px 12px;border-radius:14px;border:1px solid rgba(36,78,156,.10);background:#F8FAFC;}
.usf-health-box-full{width:100%;}
.usf-health-insight-grid > .usf-health-box-full,
.usf-health-insight-grid-premium > .usf-health-box-full{
  grid-column:1 / -1;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.usf-health-box-title{font-size:11px;font-weight:700;color:var(--muted, #244E9C);margin-bottom:6px;}
.usf-health-box-main{font-size:16px;font-weight:800;color:var(--text, #244E9C);}
.usf-health-box-sub{margin-top:4px;font-size:11px;color:var(--muted, #244E9C);}
.usf-health-highlight-list{display:flex;flex-direction:column;gap:8px;min-width:0;width:100%;box-sizing:border-box;}
.usf-health-highlight{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:4px 8px;padding:10px 12px;border-radius:12px;background:#F8FAFC;border:1px solid rgba(36,78,156,.08);min-width:0;box-sizing:border-box;width:100%;}
.usf-health-highlight span{font-size:12px;font-weight:600;color:var(--text, #244E9C);min-width:0;flex:1 1 auto;overflow-wrap:break-word;hyphens:auto;}
.usf-health-highlight strong{min-width:0;flex:0 0 auto;text-align:right;font-size:13px;color:var(--pm-accent, #244E9C);white-space:nowrap;margin-left:auto;font-variant-numeric:tabular-nums;}
.usf-health-empty{font-size:12px;color:var(--muted, #244E9C);}
html[data-theme="dark"] .usf-health-kpi, html[data-theme="dark"] .usf-health-highlight{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.10);}
html[data-theme="dark"] .usf-health-box{background:#141414;border-color:rgba(255,255,255,.12);}
html[data-theme="dark"] .usf-health-title{color:#f5f5f5;}
@media (max-width:860px){.usf-health-kpis{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:560px){.usf-health-kpis,.usf-health-insight-grid{grid-template-columns:1fr;}}

/* Fevereiro 2026 - card premium USF saúde */
.usf-health-header{display:flex;flex-direction:column;gap:8px;margin-bottom:10px;}
.usf-health-period-chip{display:inline-flex;align-items:center;align-self:flex-start;padding:6px 10px;border-radius:999px;background:#F0F5FB;border:1px solid #1253a8;font-size:11px;font-weight:700;color:#1253a8;}
.usf-health-image-card{
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 10px 26px rgba(36,78,156,.08);
}
.map-info-detail-feature .mid-feature-layout-health-premium .pm-map-image-trigger.mid-img-card{
  border-radius:18px;
}
.usf-health-period-premium{margin-top:2px;margin-bottom:2px;font-size:11px;font-weight:700;letter-spacing:.02em;color:#244E9C;}
.usf-health-kpis-premium{gap:12px;margin-top:2px;align-items:stretch;}
.usf-health-kpi-premium{padding:12px 12px;border-radius:16px;border:1px solid #1253a8;background:#FFFFFF;box-shadow:0 8px 20px rgba(18,83,168,.06);}
.map-info-detail-health .usf-health-kpi-textonly{display:flex;flex-direction:column;align-items:stretch;gap:6px;min-width:0;}
.map-info-detail-health .usf-health-kpi-label{font-size:11px;line-height:1.4;font-weight:600;color:#244E9C;white-space:normal;overflow-wrap:anywhere;word-break:break-word;}
.map-info-detail-health .usf-health-kpi-textonly strong{font-size:18px;font-weight:800;color:#1253a8;line-height:1.15;}
.map-info-detail-health .usf-health-kpi-textonly small{font-size:10px;font-weight:600;color:#244E9C;}
.map-info-detail-health .usf-health-kpi-premium{min-width:0;overflow:hidden;}
.map-info-detail-health .usf-health-kpis-premium{grid-template-columns:repeat(3,minmax(0,1fr));}
.map-info-detail-health .usf-health-kpi-icon,
.map-info-detail-health .usf-health-kpi-top{
  display:none!important;
}

/* Indicadores escola (educação): KPIs só texto, centralizados no card */
.map-info-detail-education .usf-health-kpis-premium .usf-health-kpi-textonly{
  align-items:center;
  text-align:center;
}
.map-info-detail-education .usf-health-kpi-label{
  width:100%;
  text-align:center;
}
.map-info-detail-education .usf-health-kpi-textonly strong,
.map-info-detail-education .usf-health-kpi-textonly small{
  display:block;
  width:100%;
  text-align:center;
}
.usf-health-kpi-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:6px;}
.usf-health-kpi-top > span:last-child{font-size:11px;line-height:1.35;color:#244E9C;font-weight:600;}
.usf-health-kpi-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;border:1px solid #1253a8;background:rgba(18,83,168,.06);font-size:12px;color:#1253a8;}
.usf-health-kpi-icon svg{width:17px;height:17px;display:block;stroke:currentColor;fill:none;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round;}
.usf-health-kpi-icon svg circle:not([fill]){stroke:currentColor;fill:none;}
.usf-health-kpi-icon-attendance,.usf-health-kpi-icon-vaccine,.usf-health-kpi-icon-exam,.usf-health-kpi-icon-absenteeism{border-color:#1253a8;color:#1253a8;background:rgba(18,83,168,.06);}
.usf-health-kpi-premium strong{font-size:17px;font-weight:800;color:#244E9C;}
.usf-health-kpi-premium small{font-weight:600;color:#244E9C;}
.usf-health-insight-grid-premium{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  width:100%;
  gap:12px;
}
.usf-health-box-premium{border-radius:16px;border:1px solid rgba(36,78,156,.08);background:#FFFFFF;box-shadow:0 8px 18px rgba(36,78,156,.05);}
.usf-health-highlight-premium{
  display:grid;
  grid-template-columns:26px minmax(0,1fr);
  grid-template-rows:auto auto;
  column-gap:10px;
  row-gap:2px;
  align-items:center;
  padding:10px 12px;
  border-radius:14px;
  background:#FFFFFF;
  border:1px solid rgba(36,78,156,.08);
  box-sizing:border-box;
  width:100%;
  min-width:0;
}
.usf-health-highlight-rank{
  grid-row:1 / span 2;
  align-self:center;
  display:flex;
  align-items:center;
  justify-content:center;
  width:26px;
  height:26px;
  border-radius:999px;
  background:rgba(36,78,156,.12);
  color:var(--pm-accent, #244E9C);
  font-size:11px;
  font-weight:800;
}
.usf-health-highlight-premium span{
  grid-column:2;
  grid-row:1;
  min-width:0;
  font-size:12px;
  line-height:1.35;
  font-weight:600;
  color:var(--text,#244E9C);
  overflow-wrap:break-word;
  word-break:normal;
  hyphens:auto;
}
.usf-health-highlight-premium strong{
  grid-column:2;
  grid-row:2;
  justify-self:end;
  font-size:15px;
  font-weight:800;
  color:var(--pm-accent,#244E9C);
  text-align:right;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
  letter-spacing:.01em;
}
html[data-theme="dark"] .usf-health-period-chip{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);color:#f0f0f0;}
html[data-theme="dark"] .usf-health-kpi-premium,
html[data-theme="dark"] .usf-health-highlight-premium,
html[data-theme="dark"] .usf-health-box-premium{background:#141414;border-color:rgba(255,255,255,.12);box-shadow:none;}
html[data-theme="dark"] .usf-health-kpi-icon,
html[data-theme="dark"] .usf-health-highlight-rank{border-color:rgba(255,255,255,.22);color:#f0f0f0;background:rgba(255,255,255,.08);}
.usf-health-street-table-wrap{margin-top:12px;border-radius:14px;border:1px solid rgba(36,78,156,.08);overflow:hidden;background:#FFFFFF;}
.usf-health-street-table{width:100%;border-collapse:collapse;}
.usf-health-street-table thead th{padding:10px 12px;background:rgba(36,78,156,.08);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#244E9C;text-align:left;}
.usf-health-street-table thead th:last-child,.usf-health-street-table tbody td:last-child{text-align:right;}
.usf-health-street-table tbody td{padding:10px 12px;border-top:1px solid rgba(36,78,156,.06);font-size:12px;line-height:1.35;color:#244E9C;vertical-align:top;}
.usf-health-street-table tbody tr:nth-child(even){background:rgba(36,78,156,.025);}
html[data-theme="dark"] .usf-health-street-table-wrap{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.10);}
html[data-theme="dark"] .usf-health-street-table thead th{background:rgba(255,255,255,.06);color:#f0f0f0;}
html[data-theme="dark"] .usf-health-street-table tbody td{border-top-color:rgba(255,255,255,.08);color:rgba(255,255,255,.82);}

/* === Dark mode sweep 2026-04-29 — base neutra (sem azul; alinhado ao tema monocromático) === */
html[data-theme="dark"] .source-panel,
html[data-theme="dark"] #panel-atlas,
html[data-theme="dark"] #panel-eleitorado,
html[data-theme="dark"] #panel-ibge{
  background:#0a0a0a !important;
}
html[data-theme="dark"] #panel-mapa{
  background:transparent !important;
}

html[data-theme="dark"] #panel-atlas,
html[data-theme="dark"] #panel-atlas .pm-native-host,
html[data-theme="dark"] #panel-atlas .pm-native-frame{
  background:transparent !important;
}

html[data-theme="dark"] .pm-sb-tab,
html[data-theme="dark"] .pm-map-sidebar,
html[data-theme="dark"] .pm-sb-panel,
html[data-theme="dark"] .pm-layers-card,
html[data-theme="dark"] .pm-layers-card-body,
html[data-theme="dark"] .pm-action-hero,
html[data-theme="dark"] .pm-action-list-wrap,
html[data-theme="dark"] .pm-action-report-wrap,
html[data-theme="dark"] .pm-report-builder-wrap,
html[data-theme="dark"] .pm-report-section-card,
html[data-theme="dark"] .pm-report-option-card,
html[data-theme="dark"] .pm-report-library-item,
html[data-theme="dark"] .pm-report-selected-item,
html[data-theme="dark"] .pm-action-item,
html[data-theme="dark"] .pm-action-kpi,
html[data-theme="dark"] .pm-action-report-section,
html[data-theme="dark"] .pm-action-image-preview-card,
html[data-theme="dark"] .pm-action-item-image,
html[data-theme="dark"] .pm-action-report-image,
html[data-theme="dark"] .pm-action-meta-chip,
html[data-theme="dark"] .pm-action-cat-item,
html[data-theme="dark"] .pm-report-street-row,
html[data-theme="dark"] .pm-report-street-head,
html[data-theme="dark"] .pm-action-traffic-street,
html[data-theme="dark"] .pm-map-loading-card{
  background:#161616 !important;
  border-color:rgba(255,255,255,.12) !important;
  color:#ececec !important;
  box-shadow:none !important;
}

html[data-theme="dark"] .pm-action-cat-item:hover,
html[data-theme="dark"] .pm-action-item:hover,
html[data-theme="dark"] .pm-report-option-card:hover,
html[data-theme="dark"] .pm-report-library-item:hover{
  border-color:rgba(255,255,255,.22) !important;
  box-shadow:0 16px 30px rgba(0,0,0,.45) !important;
}

html[data-theme="dark"] .pm-action-cat-label,
html[data-theme="dark"] .pm-action-item-title,
html[data-theme="dark"] .pm-action-report-title,
html[data-theme="dark"] .pm-report-option-copy strong,
html[data-theme="dark"] .pm-report-selected-copy strong,
html[data-theme="dark"] .pm-action-meta-chip strong,
html[data-theme="dark"] .pm-action-kpi strong,
html[data-theme="dark"] .pm-report-street-row strong,
html[data-theme="dark"] .pm-action-traffic-street strong,
html[data-theme="dark"] .pm-action-image-preview-meta strong,
html[data-theme="dark"] .pm-map-loading-title{
  color:#f5f5f5 !important;
}

html[data-theme="dark"] .pm-action-cat-desc,
html[data-theme="dark"] .pm-action-item-sub,
html[data-theme="dark"] .pm-action-item-objective,
html[data-theme="dark"] .pm-action-item-extra,
html[data-theme="dark"] .pm-action-report-sub,
html[data-theme="dark"] .pm-action-objective,
html[data-theme="dark"] .pm-action-bullets,
html[data-theme="dark"] .pm-action-traffic-summary,
html[data-theme="dark"] .pm-action-traffic-street span,
html[data-theme="dark"] .pm-report-option-copy span,
html[data-theme="dark"] .pm-report-selected-copy span,
html[data-theme="dark"] .pm-report-selected-empty,
html[data-theme="dark"] .pm-report-preview-empty,
html[data-theme="dark"] .pm-action-empty,
html[data-theme="dark"] .pm-report-radius-unit,
html[data-theme="dark"] .pm-action-field span,
html[data-theme="dark"] .pm-action-field-hint,
html[data-theme="dark"] .pm-report-street-head,
html[data-theme="dark"] .pm-report-street-row span,
html[data-theme="dark"] .pm-action-progress-edit small{
  color:rgba(255,255,255,.58) !important;
}

html[data-theme="dark"] .pm-action-cat-count,
html[data-theme="dark"] .pm-action-item-progress,
html[data-theme="dark"] .pm-action-progress-badge,
html[data-theme="dark"] .pm-report-chip{
  background:rgba(255,255,255,.08) !important;
  color:#e8e8e8 !important;
  border-color:rgba(255,255,255,.14) !important;
  box-shadow:none !important;
}

html[data-theme="dark"] .pm-action-create,
html[data-theme="dark"] .pm-action-export,
html[data-theme="dark"] .pm-action-clear,
html[data-theme="dark"] .pm-action-back,
html[data-theme="dark"] .pm-action-cat-back,
html[data-theme="dark"] .pm-action-item-tools button,
html[data-theme="dark"] .pm-report-inline-remove,
html[data-theme="dark"] .pm-radius-remove,
html[data-theme="dark"] .pm-radius-activate{
  border-color:rgba(255,255,255,.14) !important;
  box-shadow:none !important;
}

html[data-theme="dark"] .pm-action-clear,
html[data-theme="dark"] .pm-action-back,
html[data-theme="dark"] .pm-action-cat-back,
html[data-theme="dark"] .pm-action-item-tools button,
html[data-theme="dark"] .pm-action-export,
html[data-theme="dark"] .pm-report-inline-remove,
html[data-theme="dark"] .pm-radius-remove{
  background:#1e1e1e !important;
  color:#f0f0f0 !important;
}

html[data-theme="dark"] .pm-action-create,
html[data-theme="dark"] .pm-radius-activate{
  background:#f5f5f5 !important;
  color:#0a0a0a !important;
}
html[data-theme="dark"] .pm-report-option-cta{
  background:var(--pm-card-accent,#244E9C) !important;
  color:#FFFFFF !important;
}
html[data-theme="dark"] .pm-report-option-card{
  background:linear-gradient(180deg,#1a1a1a 0%,#171717 100%) !important;
  border-color:rgba(255,255,255,.10) !important;
  color:#f0f0f0 !important;
}
html[data-theme="dark"] .pm-report-option-copy strong{color:#fafafa !important;}
html[data-theme="dark"] .pm-report-option-copy span{color:rgba(240,240,240,.78) !important;}
html[data-theme="dark"] .pm-report-option-icon{
  background:rgba(255,255,255,.08) !important;
  color:var(--pm-card-accent,#5b8bd8) !important;
}
html[data-theme="dark"] .pm-report-option-tag{
  color:var(--pm-card-accent,#5b8bd8) !important;
  opacity:.95 !important;
}

html[data-theme="dark"] .pm-action-status,
html[data-theme="dark"] .pm-report-street-head,
html[data-theme="dark"] .pm-report-selected-empty,
html[data-theme="dark"] .pm-report-preview-empty{
  background:rgba(255,255,255,.06) !important;
  border-color:rgba(255,255,255,.14) !important;
  color:#d4d4d4 !important;
}

html[data-theme="dark"] .pm-action-field input,
html[data-theme="dark"] .pm-action-field select,
html[data-theme="dark"] .pm-action-field textarea,
html[data-theme="dark"] .pm-action-progress-edit input,
html[data-theme="dark"] .pm-report-radius-row input[type="number"]{
  background:#0a0a0a !important;
  border-color:rgba(255,255,255,.16) !important;
  color:#f5f5f5 !important;
  box-shadow:none !important;
}

html[data-theme="dark"] .pm-report-street-row,
html[data-theme="dark"] .pm-report-selected-item,
html[data-theme="dark"] .pm-report-library-item,
html[data-theme="dark"] .pm-action-meta-chip,
html[data-theme="dark"] .pm-action-kpi,
html[data-theme="dark"] .pm-action-traffic-street,
html[data-theme="dark"] .pm-action-image-preview-card,
html[data-theme="dark"] .pm-action-item-image,
html[data-theme="dark"] .pm-action-report-image{
  background:#141414 !important;
}

html[data-theme="dark"] .pm-map-corner-right,
html[data-theme="dark"] .pm-map-corner-bottom{
  color:rgba(255,255,255,.72) !important;
}

html[data-theme="dark"] .pm-map-compass,
html[data-theme="dark"] .pm-map-round-btn,
html[data-theme="dark"] .pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-distance-card,
html[data-theme="dark"] .pm-map-coords-card{
  background:#161616 !important;
  border-color:rgba(255,255,255,.14) !important;
  color:#ececec !important;
  box-shadow:0 16px 30px rgba(0,0,0,.4) !important;
}

html[data-theme="dark"] .pm-map-zoom-btn{
  background:transparent !important;
  color:rgba(255,255,255,.85) !important;
}

html[data-theme="dark"] .pm-map-zoom-btn:hover,
html[data-theme="dark"] .pm-map-round-btn:hover,
html[data-theme="dark"] .pm-map-compass:hover{
  background:rgba(255,255,255,.06) !important;
  color:#FFFFFF !important;
}

html[data-theme="dark"] .pm-map-distance-value,
html[data-theme="dark"] .pm-map-coords-meta{
  color:#f5f5f5 !important;
}

html[data-theme="dark"] .pm-map-coords-values{
  color:rgba(255,255,255,.72) !important;
}

html[data-theme="dark"] .pm-layers-list .map-layer-row,
html[data-theme="dark"] .map-layer-row{
  background:#141414 !important;
  border-color:rgba(255,255,255,.12) !important;
  color:#ececec !important;
}

html[data-theme="dark"] .pm-layers-list .map-layer-row:hover,
html[data-theme="dark"] .map-layer-row:hover,
html[data-theme="dark"] .pm-layers-list .map-layer-row.focused,
html[data-theme="dark"] .map-layer-row.focused{
  background:#1a1a1a !important;
  border-color:rgba(255,255,255,.2) !important;
}

html[data-theme="dark"] .pm-layers-list .map-layer-row,
html[data-theme="dark"] .pm-layers-list .map-layer-row:hover,
html[data-theme="dark"] .pm-layers-list .map-layer-row.focused{
  box-shadow:none !important;
}

html[data-theme="dark"] .pm-layers-list .mlr-title,
html[data-theme="dark"] .pm-layers-list .mlr-state,
html[data-theme="dark"] .pm-layers-list .map-layer-row .t{
  color:#f5f5f5 !important;
}

html[data-theme="dark"] .pm-layers-list .mlr-sub,
html[data-theme="dark"] .pm-layers-list .map-layer-row .s{
  color:rgba(255,255,255,.62) !important;
}

html[data-theme="dark"] .pm-action-cat-item,
html[data-theme="dark"] .pm-action-cat-item:hover,
html[data-theme="dark"] .pm-action-cat-item:focus-visible{
  background:#1a1a1a !important;
  border-color:rgba(255,255,255,.12) !important;
  box-shadow:none !important;
  color:#ececec !important;
}

html[data-theme="dark"] .pm-action-cat-label{
  color:#f5f5f5 !important;
}

html[data-theme="dark"] .pm-action-cat-desc{
  color:rgba(255,255,255,.62) !important;
}

html[data-theme="dark"] .pm-action-cat-count{
  background:rgba(255,255,255,.08) !important;
  border-color:rgba(255,255,255,.14) !important;
  color:#e8e8e8 !important;
}


.content:has(.education-integrated-root){
  display:flex !important;
  flex:1 1 auto !important;
  width:100% !important;
  height:100% !important;
  min-width:0 !important;
  min-height:0 !important;
}
.education-integrated-root,
.education-integrated-root .main,
.education-integrated-root .content,
.education-integrated-root .g2,
.education-integrated-root .g3,
.education-integrated-root .ccard,
.education-integrated-root .chart-wrap{
  min-width:0 !important;
}


/* PATCH v12 — restaurar scroll do painel IBGE */
.content:has(.censo-integrated){overflow:hidden !important;}
#panel-ibge, #panel-ibge.active{overflow-y:auto !important; overflow-x:hidden !important; -webkit-overflow-scrolling:touch;}
.censo-integrated[data-active-source="ibge"] #panel-ibge, .censo-integrated[data-active-source="ibge"] #panel-ibge.active{overflow-y:auto !important; overflow-x:hidden !important; height:100% !important;}


/* =========================================================
   PADRONIZAÇÃO GLOBAL DOS DASHBOARDS
   Base visual derivada do painel da Secretaria de Educação
========================================================= */
.censo-integrated{
  --edu-primary:#244E9C;
  --edu-primary-2:#244E9C;
  --edu-cyan:#244E9C;
  --edu-teal:#244E9C;
  --edu-violet:#244E9C;
  --edu-orange:#244E9C;
  --edu-amber:#244E9C;
  --edu-rose:#244E9C;
  --edu-bg:#EEF4FF;
  --edu-surface:#FFFFFF;
  --edu-surface-2:#F7FAFF;
  --edu-border:rgba(36,78,156,.12);
  --edu-shadow:0 8px 26px rgba(36,78,156,.08);
  --edu-shadow-hover:0 16px 38px rgba(36,78,156,.14);
  --edu-text:#244E9C;
  --edu-muted:#244E9C;
  font-family:Poppins, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:#EDF4FF;
}
html[data-theme="dark"] .censo-integrated{
  --edu-bg:#0a0a0a;
  --edu-surface:#111111;
  --edu-surface-2:#161616;
  --edu-border:rgba(255,255,255,.12);
  --edu-shadow:0 12px 28px rgba(0,0,0,.45);
  --edu-shadow-hover:0 18px 40px rgba(0,0,0,.55);
  --edu-text:#f5f5f5;
  --edu-muted:rgba(255,255,255,.62);
  background:#0a0a0a;
}
.censo-integrated .source-panel,
.censo-integrated .source-content,
.censo-integrated #panel-ibge,
.censo-integrated .section,
.censo-integrated .stab-section,
.censo-integrated .itab-section,
.censo-integrated .sautab-section,
.censo-integrated .ttab-section{
  background:transparent;
}
.censo-integrated .source-content,
.censo-integrated #panel-ibge{
  scrollbar-color:rgba(36,78,156,.18) transparent;
}
.censo-integrated .source-content::-webkit-scrollbar-thumb,
.censo-integrated #panel-ibge::-webkit-scrollbar-thumb{
  background:rgba(36,78,156,.18);
}
html[data-theme="dark"] .censo-integrated .source-content::-webkit-scrollbar-thumb,
html[data-theme="dark"] .censo-integrated #panel-ibge::-webkit-scrollbar-thumb{
  background:rgba(56,190,239,.18);
}

.censo-integrated .page-title-row{
  margin-bottom:18px;
  padding:18px 20px;
  border:1px solid var(--edu-border);
  border-radius:20px;
  background:#FFFFFF;
  box-shadow:var(--edu-shadow);
  backdrop-filter:blur(10px);
}
html[data-theme="dark"] .censo-integrated .page-title-row{
  background:#244E9C;
}
/* INCRA/CAFIR: remover barras de título em todas as abas */
#panel-incra .page-title-row{
  display:none !important;
}
#panel-incra .itab-section{
  padding-top:14px !important;
}
/* TSE: remover barra "Visão Geral..." e aproximar cards do topo */
#panel-tse .page-title-row{
  display:none !important;
}
#panel-tse .ttab-section{
  padding-top:10px !important;
}
/* TSE > Perfil do Eleitorado: garantir que o iframe nunca seja cortado.
   O dashboard tem ~6 seções longas, então precisamos de um piso bem alto. */
#panel-tse #ttab-perfil{
  padding-bottom:0 !important;
  min-height:4800px;
}
#panel-tse #tse-eleitorado-dashboard-host,
#panel-tse .tse-eleitorado-embed{
  width:100% !important;
  display:block !important;
  min-height:4800px !important;
  height:auto !important;
  overflow:visible !important;
}
#panel-tse #tse-eleitorado-dashboard-host > iframe.pm-native-frame{
  width:100% !important;
  min-height:4800px !important;
  display:block !important;
  border:0 !important;
  background:transparent !important;
}
#panel-incra .card .card-body{
  padding:8px 20px 20px !important;
}
#panel-incra #incra-timeline,
#panel-incra #incra-hist-full{
  min-height:310px;
}
#panel-incra #incra-tipo-bars,
#panel-incra #incra-faixa-count,
#panel-incra #incra-faixa-area,
#panel-incra #incra-dist-bars,
#panel-incra #incra-dist-media,
#panel-incra #incra-hist-tipo,
#panel-incra #incra-acumulado,
#panel-incra #incra-bars-faixas,
#panel-incra #incra-bars-area-tipo,
#panel-incra #incra-bars-distritos-v{
  min-height:300px;
}
#panel-incra #incra-stack-tipos,
#panel-incra #incra-cmp-bars,
#panel-incra #incra-cmp-linhas{
  min-height:320px;
}
#panel-incra #incra-heatmap{
  min-height:180px;
}
.censo-integrated .page-title{
  color:var(--edu-text);
  font-size:20px;
  font-weight:800;
  letter-spacing:-.02em;
}
.censo-integrated .page-sub{
  color:var(--edu-muted);
  font-size:12px;
  font-weight:500;
}
.censo-integrated .card-meta,
.censo-integrated .source-tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(36,78,156,.14);
  background:rgba(36,78,156,.06);
  color:var(--edu-primary);
  font-weight:700;
  letter-spacing:.02em;
}
html[data-theme="dark"] .censo-integrated .card-meta,
html[data-theme="dark"] .censo-integrated .source-tag{
  border-color:rgba(56,190,239,.18);
  background:rgba(56,190,239,.08);
  color:#38BEEF;
}

.censo-integrated .source-panel > .tabs-bar,
.censo-integrated #panel-ibge > .tabs-bar,
.censo-integrated #panel-saude .tabs-bar{
  position:sticky;
  top:0;
  z-index:24;
  gap:8px;
  padding:12px 18px 0;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid rgba(36,78,156,.10);
  box-shadow:0 10px 22px rgba(36,78,156,.06);
  backdrop-filter:blur(10px);
  flex-wrap:wrap;
}
html[data-theme="dark"] .censo-integrated .source-panel > .tabs-bar,
html[data-theme="dark"] .censo-integrated #panel-ibge > .tabs-bar,
html[data-theme="dark"] .censo-integrated #panel-saude .tabs-bar{
  background:rgba(36,78,156,.96);
  border-bottom-color:rgba(56,190,239,.10);
  box-shadow:0 12px 28px rgba(15,35,71,.28);
}
.censo-integrated .source-panel > .tabs-bar .tab,
.censo-integrated #panel-saude .tab[data-sautab],
.censo-integrated .tabs-bar .tab,
.censo-integrated #panel-ibge > .tabs-bar .tab{
  min-height:42px;
  padding:10px 16px;
  border-radius:14px 14px 0 0;
  border:1px solid rgba(36,78,156,.2);
  border-bottom:none;
  color:rgba(36,78,156,.58);
  font-size:13px;
  font-weight:700;
}
html[data-theme="dark"] .censo-integrated .source-panel > .tabs-bar .tab,
html[data-theme="dark"] .censo-integrated #panel-saude .tab[data-sautab],
html[data-theme="dark"] .censo-integrated #panel-ibge > .tabs-bar .tab{
  color:rgba(245,249,255,.62);
}
.censo-integrated .source-panel > .tabs-bar .tab:hover,
.censo-integrated #panel-saude .tab[data-sautab]:hover,
.censo-integrated #panel-ibge > .tabs-bar .tab:hover{
  background:rgba(36,78,156,.08);
  color:var(--edu-primary);
}
.censo-integrated .source-panel > .tabs-bar .tab.active,
.censo-integrated #panel-saude .tab[data-sautab].active,
.censo-integrated #panel-ibge > .tabs-bar .tab.active{
  background:#EEF4FB;
  border:1px solid #244E9C;
  border-bottom:none;
  color:var(--edu-primary);
  box-shadow:none;
}
html[data-theme="dark"] .censo-integrated .source-panel > .tabs-bar .tab.active,
html[data-theme="dark"] .censo-integrated #panel-saude .tab[data-sautab].active,
html[data-theme="dark"] .censo-integrated #panel-ibge > .tabs-bar .tab.active{
  background:rgba(56,190,239,.12);
  border:1px solid rgba(56,190,239,.55);
  border-bottom:none;
  color:#E5F7FF;
}

.censo-integrated .card,
.censo-integrated .sub-kpi-card,
.censo-integrated #panel-saude .sau-card,
.censo-integrated #panel-saude .sau-card-w,
.censo-integrated #panel-saude .sau-kc,
.censo-integrated .commentary,
.censo-integrated .insight-box{
  border-radius:20px;
  border:1px solid var(--edu-border);
  box-shadow:var(--edu-shadow);
}
.censo-integrated .card,
.censo-integrated .sub-kpi-card,
.censo-integrated #panel-saude .sau-card,
.censo-integrated #panel-saude .sau-card-w{
  background:#FFFFFF;
}
html[data-theme="dark"] .censo-integrated .card,
html[data-theme="dark"] .censo-integrated .sub-kpi-card,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-card,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-card-w{
  background:#244E9C;
}
.censo-integrated .card,
.censo-integrated .sub-kpi-card,
.censo-integrated #panel-saude .sau-card,
.censo-integrated #panel-saude .sau-card-w,
.censo-integrated #panel-saude .sau-kc{
  position:relative;
  overflow:hidden;
}
.censo-integrated .card::before,
.censo-integrated .sub-kpi-card::before,
.censo-integrated #panel-saude .sau-card::before,
.censo-integrated #panel-saude .sau-card-w::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:4px;
  background:#244E9C;
  opacity:.95;
}
.censo-integrated .card:hover,
.censo-integrated .sub-kpi-card:hover,
.censo-integrated #panel-saude .sau-card:hover,
.censo-integrated #panel-saude .sau-card-w:hover,
.censo-integrated #panel-saude .sau-kc:hover{
  box-shadow:var(--edu-shadow-hover) !important;
}
.censo-integrated .card-head,
.censo-integrated #panel-saude .sau-card-h{
  padding-top:18px;
}
.censo-integrated .card-title,
.censo-integrated #panel-saude .sau-card-t{
  color:var(--edu-text) !important;
  font-size:14px;
  font-weight:800;
  letter-spacing:-.02em;
}
.censo-integrated .card-sub,
.censo-integrated #panel-saude .sau-card-s,
.censo-integrated .commentary,
.censo-integrated .insight-box,
.censo-integrated .sub-kpi-detail,
.censo-integrated .kpi-detail{
  color:var(--edu-muted) !important;
}

.censo-integrated .kpi-card,
.censo-integrated .sub-kpi-card,
.censo-integrated #panel-saude .sau-kc{
  border-radius:20px;
}
.censo-integrated .kpi-card,
.censo-integrated .sub-kpi-card{
  background:#FFFFFF;
  border:1px solid var(--edu-border);
  box-shadow:var(--edu-shadow);
}
html[data-theme="dark"] .censo-integrated .kpi-card,
html[data-theme="dark"] .censo-integrated .sub-kpi-card{
  background:#244E9C;
}

/* TSE: cards KPI claros com contorno (evita “card todo azul” no escuro) */
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-card{
  background:rgba(255,255,255,.08) !important;
  border:1px solid rgba(56,190,239,.32) !important;
  box-shadow:0 8px 22px rgba(15,35,71,.35) !important;
}
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-val,
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-label{
  color:#E5F7FF !important;
}
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail,
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail .delta-neu,
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail .delta-pos,
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail .delta-neg{
  color:rgba(229,247,255,.88) !important;
}
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail .delta-neu,
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail .delta-pos,
html[data-theme="dark"] .censo-integrated #panel-tse .sub-kpi-detail .delta-neg{
  background:rgba(255,255,255,.12) !important;
  border-color:rgba(255,255,255,.22) !important;
}
.censo-integrated .kpi-label,
.censo-integrated .sub-kpi-label{
  color:var(--edu-muted);
  font-weight:700;
}
.censo-integrated .kpi-val,
.censo-integrated .sub-kpi-val{
  font-family:Poppins, sans-serif;
}

.censo-integrated .select,
.censo-integrated button.btn,
.censo-integrated .incra-pill,
.censo-integrated .chip,
.censo-integrated #panel-saude .sau-pill,
.censo-integrated #panel-saude .sau-chip,
.censo-integrated #panel-saude .sau-filter-reset,
.censo-integrated #panel-saude .sau-fsel,
.censo-integrated #panel-saude select.select,
.censo-integrated #panel-saude button.btn{
  border-radius:999px !important;
  font-family:inherit;
  font-weight:700;
}
.censo-integrated .select,
.censo-integrated #panel-saude .sau-fsel,
.censo-integrated #panel-saude select.select{
  min-height:36px;
  border:1px solid rgba(36,78,156,.14) !important;
  background:#FFFFFF !important;
  color:var(--edu-text) !important;
  box-shadow:0 4px 12px rgba(36,78,156,.05);
}
html[data-theme="dark"] .censo-integrated .select,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-fsel,
html[data-theme="dark"] .censo-integrated #panel-saude select.select{
  background:#244E9C !important;
  color:#F5F9FF !important;
  border-color:rgba(56,190,239,.16) !important;
}
.censo-integrated button.btn,
.censo-integrated .incra-pill,
.censo-integrated #panel-saude .sau-pill,
.censo-integrated #panel-saude .sau-chip,
.censo-integrated #panel-saude .sau-filter-reset{
  min-height:34px;
  border:1px solid rgba(36,78,156,.14) !important;
  background:rgba(36,78,156,.05) !important;
  color:var(--edu-primary) !important;
  box-shadow:none !important;
}
.censo-integrated button.btn:hover,
.censo-integrated .incra-pill:hover,
.censo-integrated #panel-saude .sau-pill:hover,
.censo-integrated #panel-saude .sau-chip:hover,
.censo-integrated #panel-saude .sau-filter-reset:hover{
  background:rgba(36,78,156,.10) !important;
  border-color:rgba(36,78,156,.20) !important;
  transform:translateY(-1px);
}
.censo-integrated .incra-pill.on,
.censo-integrated #panel-saude .sau-pill.on,
.censo-integrated #panel-saude .sau-chip.on,
.censo-integrated .chip.on{
  background:#244E9C !important;
  border-color:transparent !important;
  color:#FFFFFF !important;
}
html[data-theme="dark"] .censo-integrated button.btn,
html[data-theme="dark"] .censo-integrated .incra-pill,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-pill,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-chip,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-filter-reset{
  background:rgba(56,190,239,.08) !important;
  border-color:rgba(56,190,239,.16) !important;
  color:#38BEEF !important;
}

.censo-integrated #panel-saude .sau-filter-bar,
.censo-integrated #panel-saude .sau-hi,
.censo-integrated .commentary,
.censo-integrated .insight-box{
  background:#FFFFFF !important;
  border:1px solid rgba(36,78,156,.12) !important;
  border-left:4px solid var(--edu-primary) !important;
  color:var(--edu-text) !important;
}
html[data-theme="dark"] .censo-integrated #panel-saude .sau-filter-bar,
html[data-theme="dark"] .censo-integrated #panel-saude .sau-hi,
html[data-theme="dark"] .censo-integrated .commentary,
html[data-theme="dark"] .censo-integrated .insight-box{
  background:#244E9C !important;
  border-color:rgba(56,190,239,.14) !important;
}
.censo-integrated #panel-saude .sau-filter-bar{
  position:sticky;
  top:62px;
  z-index:12;
  padding:12px 14px;
  border-radius:18px;
  box-shadow:var(--edu-shadow);
}
.censo-integrated #panel-saude .sau-filter-lbl,
.censo-integrated #panel-saude .sau-hi-t,
.censo-integrated #panel-saude .sau-hi-t strong{
  color:var(--edu-text) !important;
}
.censo-integrated #panel-saude .sau-kc{
  background:#244E9C !important;
  border-color:transparent !important;
}
.censo-integrated #panel-saude .sau-kc:nth-child(2){background:#244E9C !important;}
.censo-integrated #panel-saude .sau-kc:nth-child(3){background:#244E9C !important;}
.censo-integrated #panel-saude .sau-kc:nth-child(4){background:#E9561E !important;}
.censo-integrated #panel-saude .sau-kc:nth-child(5){background:#244E9C !important;}
.censo-integrated #panel-saude .sau-kc:nth-child(6){background:#244E9C !important;}
.censo-integrated #panel-saude .sau-kc *,
.censo-integrated #panel-saude .sau-kc-v,
.censo-integrated #panel-saude .sau-kc-l,
.censo-integrated #panel-saude .sau-kc-d{color:#FFFFFF !important;}
.censo-integrated .kpi-ico svg{display:block;width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

.censo-integrated #panel-saude .sau-card.blue,
.censo-integrated #panel-saude .card.blue,
.censo-integrated .card.blue,
.censo-integrated .card.strong{
  background:#FFFFFF !important;
  color:var(--edu-text) !important;
  border:1px solid var(--edu-border) !important;
}
html[data-theme="dark"] .censo-integrated #panel-saude .sau-card.blue,
html[data-theme="dark"] .censo-integrated #panel-saude .card.blue,
html[data-theme="dark"] .censo-integrated .card.blue,
html[data-theme="dark"] .censo-integrated .card.strong{
  background:#244E9C !important;
}
.censo-integrated #panel-saude .sau-card.blue *,
.censo-integrated #panel-saude .card.blue *,
.censo-integrated .card.blue *,
.censo-integrated .card.strong *{
  color:inherit !important;
}
.censo-integrated #panel-saude .sau-tbl th,
.censo-integrated #panel-saude .sau-dln,
.censo-integrated #panel-saude .sau-bl,
.censo-integrated #panel-saude .sau-plbl,
.censo-integrated #panel-saude .sau-filter-lbl{
  color:var(--edu-muted) !important;
}
.censo-integrated #panel-saude .sau-bt,
.censo-integrated #panel-saude .sau-pbar{
  background:rgba(36,78,156,.08) !important;
}
.censo-integrated #panel-saude .sau-card-w .sau-bt,
.censo-integrated #panel-saude .sau-card-w .sau-pbar{
  background:rgba(36,78,156,.08) !important;
}

@media (max-width: 900px){
  .censo-integrated .page-title-row{padding:16px 16px; border-radius:18px;}
  .censo-integrated .page-title{font-size:18px;}
  .censo-integrated .source-panel > .tabs-bar,
  .censo-integrated #panel-ibge > .tabs-bar,
  .censo-integrated #panel-saude .tabs-bar{padding:10px 12px 0; gap:6px;}
  .censo-integrated #panel-saude .sau-filter-bar{top:58px;}
}


/* Embedded dashboards inside Visão Geral */
.embedded-dash-shell{display:flex;flex-direction:column;gap:14px;padding:18px;background:var(--panel-bg,#EEF3FA);height:100%;min-height:0;overflow:hidden}
.embedded-dash-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 2px}
.embedded-dash-frame{width:100%;flex:1;min-height:780px;border:1px solid rgba(36,78,156,.10);border-radius:18px;background:#EEF3FA;box-shadow:0 12px 28px rgba(36,78,156,.08),0 4px 12px rgba(36,78,156,.05)}
.source-panel[id^="panel-dash"]{overflow:auto;overflow-x:hidden;background:var(--panel-bg,#EEF3FA)}
.source-panel[id^="panel-dash"].active{display:flex!important}
@media (max-width:900px){.embedded-dash-shell{padding:12px}.embedded-dash-head{flex-direction:column;align-items:flex-start}.embedded-dash-frame{min-height:640px}}


/* Native external dashboards integrated into Visão Geral */
.source-panel[id^="panel-dash"]{overflow:auto;overflow-x:hidden;background:var(--panel-bg,#EEF3FA)}
.pm-native-host{width:100%;min-height:100%;display:block}
.pm-native-dashboard{min-height:100%;background:var(--panel-bg,#EEF3FA);color:var(--ink,#244E9C)}
.pm-native-dashboard .filter-bar{position:sticky;top:0;z-index:8;display:flex;align-items:center;width:100%;padding:12px 16px;background:#FFFFFF;border-bottom:1px solid rgba(36,78,156,.08);box-shadow:none}
.pm-native-dashboard .filter-bar-inner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}
.pm-native-dashboard .filter-label{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#244E9C}
.pm-native-dashboard .filter-select{height:36px;min-width:168px;border-radius:999px;border:1px solid #244E9C;background:#FFFFFF;color:#244E9C;padding:0 38px 0 14px;font:600 13px/1 Inter,system-ui,sans-serif;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235b7098' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.pm-native-dashboard .active-filters{min-height:46px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 16px;background:#F8FBFF;border-bottom:1px solid rgba(36,78,156,.06)}
.pm-native-dashboard .active-filters-label{font-size:12px;font-weight:600;color:#244E9C}
.pm-native-dashboard .content{max-width:none;margin:0;padding:16px}
.pm-native-dashboard .kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:16px}
.pm-native-dashboard .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pm-native-dashboard .grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pm-native-dashboard .section{display:block !important;margin-bottom:18px}
.pm-native-dashboard .section-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pm-native-dashboard .section-num{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:24px;border-radius:999px;background:#EEF4FF;color:#244E9C;font-size:11px;font-weight:800;letter-spacing:.06em;padding:0 10px}
.pm-native-dashboard .section-title{font-size:20px;font-weight:800;color:#244E9C}
.pm-native-dashboard .section-desc{font-size:13px;color:#244E9C;margin:0 0 10px 0}
.pm-native-dashboard .kpi-card,.pm-native-dashboard .card,.pm-native-dashboard .stat-box{background:#FFFFFF;border:1px solid #244E9C;border-radius:18px;box-shadow:0 10px 26px rgba(36,78,156,.08),0 2px 8px rgba(36,78,156,.04)}
.pm-native-dashboard .kpi-card{padding:18px 18px 16px;position:relative;overflow:hidden}
.pm-native-dashboard .kpi-card::before,.pm-native-dashboard .card::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:#244E9C}
.pm-native-dashboard .card{padding:18px;position:relative;overflow:hidden}
.pm-native-dashboard .kpi-icon{width:34px;height:34px;border-radius:12px;background:#EEF4FF;display:flex;align-items:center;justify-content:center;margin-bottom:10px;color:#244E9C}
.pm-native-dashboard .kpi-value,.pm-native-dashboard .stat-box-val{font-size:30px;line-height:1.05;font-weight:800;color:#244E9C;letter-spacing:-.03em}
.pm-native-dashboard .kpi-label,.pm-native-dashboard .card-title,.pm-native-dashboard .stat-box-lbl{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#244E9C;margin-top:6px;margin-bottom:0}
.pm-native-dashboard .kpi-detail,.pm-native-dashboard .stat-box-sub{font-size:12px;color:#244E9C;margin-top:6px}
.pm-native-dashboard .card-title-accent{color:#244E9C}
.pm-native-dashboard .insight{margin-top:14px;padding:14px 16px;border-radius:16px;background:#F5F9FF;border:1px solid #244E9C;border-left:4px solid #244E9C}
.pm-native-dashboard .insight-title{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#244E9C;margin-bottom:6px}
.pm-native-dashboard .insight p{font-size:13px;line-height:1.6;color:#244E9C}
.pm-native-dashboard .data-table{width:100%;border-collapse:collapse}
.pm-native-dashboard .data-table th{padding:10px 12px;background:#F5F8FE;border-bottom:1px solid #244E9C;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#244E9C;text-align:left}
.pm-native-dashboard .data-table td{padding:9px 12px;border-bottom:1px solid #EDF2FA;color:#244E9C;font-size:13px}
.pm-native-dashboard .data-table tr:last-child td{border-bottom:none}
.pm-native-dashboard .num{font-weight:700;color:#244E9C}
.pm-native-dashboard .badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 9px;border-radius:999px;font-size:11px;font-weight:800}
.pm-native-dashboard .badge-blue{background:#EDF4FF;color:#244E9C}.pm-native-dashboard .badge-green{background:#E8FAEF;color:#47AB34}.pm-native-dashboard .badge-amber{background:#FCCF00;color:#E9561E}.pm-native-dashboard .badge-red{background:#FFE5E5;color:#E9561E}
.pm-native-dashboard .footer{padding:22px 16px;border-top:1px solid #244E9C;color:#244E9C;font-size:12px;text-align:center}
.pm-native-dashboard canvas{max-width:100%}
.pm-native-dashboard #map{height:460px;min-height:460px}
.pm-native-loading,.pm-native-error{display:flex;align-items:center;justify-content:center;gap:10px;min-height:240px;color:#244E9C;font-weight:700}
.pm-native-loading .spinner{width:18px;height:18px;border-radius:50%;border:2px solid #244E9C;border-top-color:#244E9C;animation:spin .9s linear infinite}
@media (max-width:980px){.pm-native-dashboard .grid-2,.pm-native-dashboard .grid-3{grid-template-columns:1fr}.pm-native-dashboard .content{padding:12px}.pm-native-dashboard .filter-bar{padding:10px 12px}.pm-native-dashboard .active-filters{padding:10px 12px}.pm-native-dashboard .filter-select{min-width:150px}}


/* Fix scroll/render for external native dashboards */
.source-panel[id^="panel-dash"].active{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 auto !important;
  min-height:0 !important;
  height:100% !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  -webkit-overflow-scrolling:touch;
}

.pm-native-host{
  width:100%;
  min-height:100%;
  height:auto;
  display:block;
}

.pm-native-dashboard{
  min-height:100%;
  height:auto;
  display:block;
}

.pm-native-dashboard .content,
.pm-native-dashboard .section,
.pm-native-dashboard .grid-2,
.pm-native-dashboard .grid-3,
.pm-native-dashboard .kpi-grid{
  min-width:0;
}

.pm-native-dashboard canvas{
  display:block;
  width:100% !important;
}


/* iframe-based external dashboards */
.source-panel[id^="panel-dash"]:not(#panel-atlas){
  overflow:hidden;
  overflow-x:hidden;
  background:var(--panel-bg,#EEF3FA);
}
.pm-native-host{width:100%;display:block;padding:0;margin:0}
.pm-native-frame{display:block;width:100%;border:0;background:transparent;border-radius:0}


/* === EDUCATION GLOBAL UNIFICATION OVERRIDES === */
:root{
  --edu-blue-900:#244E9C;
  --edu-blue-800:#244E9C;
  --edu-blue-700:#244E9C;
  --edu-blue-600:#244E9C;
  --edu-blue-500:#244E9C;
  --edu-blue-300:#244E9C;
  --edu-blue-100:#EFF6FF;
  --edu-surface:#FFFFFF;
  --edu-surface-soft:#F8FBFF;
  --edu-border:#244E9C;
  --edu-text:#244E9C;
  --edu-muted:#244E9C;
}
html[data-theme="light"] body,
html[data-theme="light"] .app-shell,
html[data-theme="light"] .page-shell{background:#EEF4FB !important;color:var(--edu-text) !important;}
html[data-theme="light"] .panel-card,
html[data-theme="light"] .card,
html[data-theme="light"] .metric-card,
html[data-theme="light"] .content-card,
html[data-theme="light"] .section-card,
html[data-theme="light"] .pm-native-dashboard .card,
html[data-theme="light"] .pm-native-dashboard .panel,
html[data-theme="light"] .pm-native-dashboard .widget,
html[data-theme="light"] .pm-native-dashboard .kpi,
html[data-theme="light"] .dashboard-card{
  background:var(--edu-surface) !important;
  border:1px solid var(--edu-border) !important;
  box-shadow:0 4px 14px rgba(36,78,156,.06) !important;
  color:var(--edu-text) !important;
}
html[data-theme="light"] .pm-native-dashboard .filter-bar,
html[data-theme="light"] #panel-saude .sau-filter-bar,
html[data-theme="light"] .censo-integrated #panel-saude .sau-filter-bar{
  position:sticky !important;top:64px !important;z-index:40 !important;
  display:flex !important;align-items:center !important;gap:10px !important;flex-wrap:wrap !important;
  width:100% !important;padding:12px 16px !important;border-radius:18px !important;
  background:var(--edu-surface) !important;border:1px solid var(--edu-border) !important;
  box-shadow:0 8px 20px rgba(36,78,156,.08) !important;overflow:visible !important;
}
html[data-theme="light"] .pm-native-dashboard .filter-bar-inner{gap:10px !important}
html[data-theme="light"] .pm-native-dashboard .filter-label,
html[data-theme="light"] #panel-saude .sau-filter-lbl,
html[data-theme="light"] .censo-integrated #panel-saude .sau-filter-lbl{color:var(--edu-blue-900) !important;font-weight:800 !important;letter-spacing:.02em !important;text-transform:none !important}
html[data-theme="light"] .pm-native-dashboard .filter-select,
html[data-theme="light"] #panel-saude select,
html[data-theme="light"] #panel-saude .sau-select,
html[data-theme="light"] .censo-integrated #panel-saude select{
  height:38px !important;min-width:170px !important;padding:0 40px 0 14px !important;
  border-radius:999px !important;border:1px solid var(--edu-border) !important;background:#F6FAFF !important;
  color:var(--edu-text) !important;font:600 13px/1 Inter,system-ui,sans-serif !important;box-shadow:none !important;
}
html[data-theme="light"] .pm-native-dashboard .filter-select:focus,
html[data-theme="light"] #panel-saude select:focus,
html[data-theme="light"] .censo-integrated #panel-saude select:focus{outline:none !important;border-color:var(--edu-blue-600) !important;box-shadow:0 0 0 3px rgba(36,78,156,.12) !important}
html[data-theme="light"] .pm-native-dashboard .active-filters,
html[data-theme="light"] .active-filters{background:var(--edu-surface-soft) !important;border-bottom:1px solid rgba(36,78,156,.08) !important}
html[data-theme="light"] .filter-chip,
html[data-theme="light"] .chip,
html[data-theme="light"] .active-filter-chip{background:var(--edu-blue-100) !important;color:var(--edu-blue-900) !important;border:1px solid rgba(36,78,156,.18) !important}
html[data-theme="light"] .filter-chip-remove{background:var(--edu-blue-600) !important}
html[data-theme="light"] #panel-saude .sau-filter-reset,
html[data-theme="light"] .censo-integrated #panel-saude .sau-filter-reset,
html[data-theme="light"] .pm-native-dashboard .filter-clear{
  border:1px solid rgba(36,78,156,.18) !important;background:var(--edu-blue-100) !important;color:var(--edu-blue-800) !important;border-radius:999px !important;height:38px !important;padding:0 14px !important;font-weight:700 !important
}
html[data-theme="light"] #panel-saude .sau-filter-reset:hover,
html[data-theme="light"] .censo-integrated #panel-saude .sau-filter-reset:hover,
html[data-theme="light"] .pm-native-dashboard .filter-clear:hover{background:#E7F0FF !important;border-color:var(--edu-blue-600) !important;color:var(--edu-blue-900) !important}
html[data-theme="light"] #panel-saude .kpi,
html[data-theme="light"] .censo-integrated #panel-saude .kpi,
html[data-theme="light"] .pm-native-dashboard .kpi-card,
html[data-theme="light"] .pm-native-dashboard .kpi{
  background:#FFFFFF !important;
  color:var(--edu-text) !important;border:1px solid var(--edu-border) !important;box-shadow:0 6px 18px rgba(36,78,156,.07) !important;
}
html[data-theme="light"] #panel-saude .kpi::before,
html[data-theme="light"] .censo-integrated #panel-saude .kpi::before,
html[data-theme="light"] .pm-native-dashboard .kpi-card::before{content:'' !important;position:absolute !important;inset:0 auto auto 0 !important;width:100% !important;height:4px !important;background:#244E9C !important}
html[data-theme="light"] #panel-saude .kpi-val,
html[data-theme="light"] .pm-native-dashboard .kpi-value{color:var(--edu-blue-900) !important}
html[data-theme="light"] #panel-saude .kpi-lbl,
html[data-theme="light"] #panel-saude .kpi-sub,
html[data-theme="light"] .pm-native-dashboard .kpi-label,
html[data-theme="light"] .pm-native-dashboard .kpi-detail{color:var(--edu-muted) !important}
html[data-theme="light"] #panel-saude .kpi-ico,
html[data-theme="light"] .pm-native-dashboard .kpi-icon{background:var(--edu-blue-100) !important;color:var(--edu-blue-700) !important}
html[data-theme="light"] canvas,
html[data-theme="light"] svg .line-path,
html[data-theme="light"] svg .line-point{accent-color:var(--edu-blue-700) !important}
html[data-theme="light"] .badge-green,
html[data-theme="light"] .badge-red,
html[data-theme="light"] .badge-amber,
html[data-theme="light"] .badge-blue,
html[data-theme="light"] .status-badge,
html[data-theme="light"] .pill,
html[data-theme="light"] .legend-badge{background:var(--edu-blue-100) !important;color:var(--edu-blue-800) !important;border:1px solid rgba(36,78,156,.14) !important}
html[data-theme="light"] .insight,
html[data-theme="light"] .analysis-box{background:#F7FBFF !important;border:1px solid rgba(36,78,156,.16) !important;border-left:4px solid var(--edu-blue-600) !important}

/* Force unified blue theme on non-education dashboards */
#panel-ibge .kpi-card,
#panel-tse .sub-kpi-card,
#panel-caged .sub-kpi-card,
#panel-incra .sub-kpi-card,
.source-panel[id^="panel-dash"] iframe {
  border-color:#244E9C;
}

/* TSE: topo colorido por posição (sobrescreve inline nos .sub-kpi-accent) */
#panel-tse .sub-kpi-card::before{content:none !important;display:none !important;}
#panel-tse .sub-kpi-card{
  padding:12px 18px 16px !important;
}
#panel-tse .sub-kpi-card .sub-kpi-accent{
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  width:100% !important;
  height:4px !important;
  margin:0 !important;
  border-radius:0 !important;
}
#panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+1) .sub-kpi-accent{background:#244E9C!important;}
#panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+2) .sub-kpi-accent{background:#38BEEF!important;}
#panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+3) .sub-kpi-accent{background:#FCCF00!important;}
#panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+4) .sub-kpi-accent{background:#E9561E!important;}

/* INCRA: topo colorido por posição (sem faixa azul residual) */
#panel-incra .sub-kpi-card::before{content:none !important;display:none !important;}
#panel-incra .sub-kpi-grid{
  grid-template-columns:repeat(5, minmax(0,1fr)) !important;
  gap:10px !important;
}
#panel-incra .sub-kpi-card{
  padding:10px 12px 12px !important;
  min-width:0 !important;
}
#panel-incra .sub-kpi-card .sub-kpi-accent{
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  width:100% !important;
  height:4px !important;
  margin:0 !important;
  border-radius:0 !important;
}
#panel-incra .sub-kpi-grid .sub-kpi-card:nth-child(5n+1) .sub-kpi-accent{background:#244E9C!important;}
#panel-incra .sub-kpi-grid .sub-kpi-card:nth-child(5n+2) .sub-kpi-accent{background:#38BEEF!important;}
#panel-incra .sub-kpi-grid .sub-kpi-card:nth-child(5n+3) .sub-kpi-accent{background:#FCCF00!important;}
#panel-incra .sub-kpi-grid .sub-kpi-card:nth-child(5n+4) .sub-kpi-accent{background:#E9561E!important;}
#panel-incra .sub-kpi-grid .sub-kpi-card:nth-child(5n+5) .sub-kpi-accent{background:#47AB34!important;}
@media (max-width:1320px){
  #panel-incra .sub-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
}

#panel-ibge .source-tag, #panel-caged .source-tag, #panel-tse .source-tag, #panel-incra .source-tag {
  background:#EFF6FF; color:#244E9C; border:1px solid #244E9C;
}
#panel-ibge .commentary, #panel-caged .commentary, #panel-tse .commentary, #panel-incra .commentary {
  border-left-color:#244E9C;
  background:#F8FBFF;
}
#panel-ibge .card-meta, #panel-caged .card-meta, #panel-tse .card-meta, #panel-incra .card-meta {
  background:#EFF6FF; color:#244E9C; border-color:#244E9C;
}

/* Escuro: KPIs e metadados IBGE/TSE em escala de cinza */
html[data-theme="dark"] #panel-ibge .kpi-card,
html[data-theme="dark"] #panel-tse .sub-kpi-card,
html[data-theme="dark"] #panel-caged .sub-kpi-card,
html[data-theme="dark"] #panel-incra .sub-kpi-card{
  border-color:rgba(255,255,255,.14) !important;
}
html[data-theme="dark"] #panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+1) .sub-kpi-accent{background:#e5e5e5!important;}
html[data-theme="dark"] #panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+2) .sub-kpi-accent{background:#c4c4c4!important;}
html[data-theme="dark"] #panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+3) .sub-kpi-accent{background:#a3a3a3!important;}
html[data-theme="dark"] #panel-tse .sub-kpi-grid .sub-kpi-card:nth-child(4n+4) .sub-kpi-accent{background:#737373!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+1) .kpi-accent{background:#e5e5e5!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+2) .kpi-accent{background:#d4d4d4!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+3) .kpi-accent{background:#c4c4c4!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+4) .kpi-accent{background:#a3a3a3!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+5) .kpi-accent{background:#8a8a8a!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+6) .kpi-accent{background:#737373!important;}
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+1) .kpi-val,
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+2) .kpi-val,
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+3) .kpi-val,
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+4) .kpi-val,
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+5) .kpi-val,
html[data-theme="dark"] #panel-ibge .kpi-grid .kpi-card:nth-child(6n+6) .kpi-val{color:#f0f0f0!important;}
html[data-theme="dark"] #panel-ibge .source-tag,
html[data-theme="dark"] #panel-caged .source-tag,
html[data-theme="dark"] #panel-tse .source-tag,
html[data-theme="dark"] #panel-incra .source-tag{
  background:rgba(255,255,255,.06) !important;
  color:#f0f0f0 !important;
  border-color:rgba(255,255,255,.2) !important;
}
html[data-theme="dark"] #panel-ibge .commentary,
html[data-theme="dark"] #panel-caged .commentary,
html[data-theme="dark"] #panel-tse .commentary,
html[data-theme="dark"] #panel-incra .commentary{
  border-left-color:#ffffff !important;
  background:#0f0f0f !important;
}
html[data-theme="dark"] #panel-ibge .card-meta,
html[data-theme="dark"] #panel-caged .card-meta,
html[data-theme="dark"] #panel-tse .card-meta,
html[data-theme="dark"] #panel-incra .card-meta{
  background:rgba(255,255,255,.06) !important;
  color:#f0f0f0 !important;
  border-color:rgba(255,255,255,.2) !important;
}


#panel-benef-saude, #panel-car, #panel-empresarial, #panel-eleitorado { font-family:Poppins, Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
#panel-benef-saude *, #panel-car *, #panel-empresarial *, #panel-eleitorado * { font-family:inherit; }


/* === FIXES 2026-04-07 === */
#panel-saude-secretaria > #sesauIntegratedHost,
#panel-saude-secretaria .health-iframe-root{
  width:100%;
  display:block;
  min-height:0 !important;
}

#panel-saude-secretaria .health-iframe{
  display:block;
  width:100%;
  border:0;
  background:transparent;
}

#panel-atlas .pm-native-host,
.source-panel[id^="panel-dash"]:not(#panel-atlas) .pm-native-host{
  min-height:0 !important;
}

#panel-atlas .pm-native-frame,
.source-panel[id^="panel-dash"]:not(#panel-atlas) .pm-native-frame{
  min-height:0 !important;
  height:100% !important;
}

#panel-atlas .pm-native-frame{
  min-height:0 !important;
}


/* === FIXES 2026-04-07 v2 === */
#panel-saude-secretaria{
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
}
#panel-saude-secretaria:not(.active){
  display:none !important;
}
#panel-saude-secretaria.active{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 0% !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  -webkit-overflow-scrolling:touch;
}

#panel-atlas,
.source-panel[id^="panel-dash"]:not(#panel-atlas){
  overflow:hidden !important;
  min-height:0 !important;
  align-items:stretch !important;
}

#panel-atlas{
  background:transparent !important;
}

#panel-atlas.active{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 auto !important;
}
.source-panel[id^="panel-dash"]:not(#panel-atlas).active{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 0% !important;
  min-height:0 !important;
}
.source-panel[id^="panel-dash"]:not(#panel-atlas) .pm-native-host{
  width:100% !important;
  flex:1 1 0% !important;
  min-height:0 !important;
  height:auto !important;
  display:flex !important;
  flex-direction:column !important;
  overflow:hidden !important;
}
.source-panel[id^="panel-dash"]:not(#panel-atlas) .pm-native-frame{
  width:100% !important;
  flex:1 1 0% !important;
  min-height:0 !important;
  height:100% !important;
  max-height:100% !important;
  display:block !important;
  border:0 !important;
}

.censo-integrated.secretaria-source-only .source-panel.active[id^="panel-dash"]{
  flex:1 1 0% !important;
  min-height:0 !important;
  overflow:hidden !important;
}

#panel-dashda.active,
#panel-dashes.active{
  display:flex !important;
  flex-direction:column !important;
  flex:1 1 0% !important;
  min-height:0 !important;
  overflow:hidden !important;
}

#panel-atlas .pm-native-frame{
  width:100% !important;
  min-height:100% !important;
  height:100% !important;
  flex:1 1 auto !important;
  display:block !important;
  background:transparent !important;
}

#panel-atlas .pm-native-host{
  width:100% !important;
  min-height:0 !important;
  height:100% !important;
  flex:1 1 auto !important;
  display:flex !important;
  background:transparent !important;
}

/* === FINAL SCROLL FIXES 2026-04-07 === */
html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden !important;
}
body {
  overscroll-behavior: none;
}
.app,
.main,
.content,
.censo-integrated,
.source-panel,
.source-panel.active,
.source-content,
#panel-ibge,
#panel-caged,
#panel-tse,
#panel-incra,
#panel-saude-secretaria,
#panel-saude-secretaria.active,
.source-panel[id^="panel-dash"],
.health-iframe-root,
.health-iframe,
.education-integrated-root,
.education-integrated-root .main,
.education-integrated-root .content{
  max-width: 100% !important;
  min-width: 0 !important;
}

.content,
.source-panel,
.source-content,
#panel-ibge,
#panel-caged,
#panel-tse,
#panel-incra,
#panel-saude-secretaria,
.source-panel[id^="panel-dash"]{
  min-height: 0 !important;
}

.content:has(.censo-integrated),
.content:has(.education-integrated-root),
.content:has(.health-iframe-root){
  overflow: hidden !important;
  padding: 0 !important;
  gap: 0 !important;
}

/* Painéis internos: um scroll por área; painéis dash externos não rolam (scroll só no iframe) */
.censo-integrated .source-panel.active:not([id^="panel-dash"]),
.censo-integrated .source-content,
.censo-integrated #panel-ibge,
#panel-saude-secretaria.active{
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
}
.source-panel[id^="panel-dash"].active{
  overflow: hidden !important;
  -webkit-overflow-scrolling: touch;
}

/* Educação: garantir que a área role até o final */
.education-integrated-root{
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
}
.education-integrated-root .main{
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;
  background: transparent !important;
}
.education-integrated-root .content{
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding-bottom: 28px !important;
}
.education-integrated-root .tabs-bar,
.education-integrated-root .top-filters,
.censo-integrated .tabs-bar,
.censo-integrated .source-panel > .tabs-bar,
#panel-saude .sau-filter-bar{
  max-width: 100% !important;
}

/* Mata qualquer resquício de scroll horizontal */
.source-content *,
.education-integrated-root *,
.health-iframe-root *,
.censo-integrated *{
  max-width: 100%;
}

.source-panel[id^="panel-dash"] iframe,
#panel-saude-secretaria .health-iframe{
  overflow: hidden !important;
}


/* ===== Ajustes finos do Panorama — Sidebar + IBGE ===== */
.sidebar #btnCollapse{
  width:44px;
  height:44px;
  border-radius:16px;
  align-self:center;
  flex:0 0 44px;
}
.sidebar:not(.collapsed) #btnCollapse{
  background:#FFFFFF;
  border-color:rgba(36,78,156,.18);
}
.sidebar:not(.collapsed) #btnCollapse .icon{
  color:#244E9C;
}
.sidebar.collapsed #btnCollapse{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.14);
  margin-inline:auto;
}
.sidebar.collapsed .sb-top{
  align-items:center;
  justify-content:center;
}
.sidebar.collapsed .sb-top .brand{
  display:none !important;
}
.sidebar:not(.collapsed) .sb-top{
  align-items:center;
}

#panel-ibge .data-origin{
  display:none !important;
}
#panel-ibge .source-tag{
  display:inline-flex !important;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(36,78,156,.10);
  border:1px solid rgba(36,78,156,.18);
  color:#244E9C !important;
  font-weight:800 !important;
  font-size:11px !important;
  letter-spacing:.01em;
}
#panel-ibge .source-tag::before{
  content:"FONTE";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:3px 7px;
  border-radius:999px;
  background:#244E9C;
  color:#FFFFFF;
  font-size:9px;
  font-weight:900;
  letter-spacing:.08em;
}

.censo-integrated .bar-row{
  grid-template-columns:minmax(120px,150px) minmax(0,1fr) auto;
  gap:10px;
}
.censo-integrated .bar-track{
  height:21px;
}
.censo-integrated .bar-fill{
  justify-content:flex-end;
}
.censo-integrated .bar-meta{
  display:inline-flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  min-width:110px;
  white-space:nowrap;
}
.censo-integrated .bar-pct-out{
  font-size:11px;
  font-weight:800;
  color:#244E9C;
}
.censo-integrated .bar-sep{
  width:1px;
  height:14px;
  background:rgba(36,78,156,.22);
}
.censo-integrated .bar-val{
  font-size:11px;
  font-weight:800;
  color:var(--text);
  text-align:right;
}
.censo-integrated .bar-pct{
  display:none !important;
}

.censo-integrated .pyramid{
  gap:5px;
}
.censo-integrated .pyr-row{
  grid-template-columns:minmax(0,1fr) 62px minmax(0,1fr);
  gap:8px;
}
.censo-integrated .pyr-l,
.censo-integrated .pyr-r{
  min-width:0;
}
.censo-integrated .pyr-bar{
  min-width:2px;
  box-shadow:inset 0 -1px 0 rgba(255,255,255,.18);
}


/* TSE chart refinements */
.timeline-svg-wrap {
  min-height: 330px;
}
.timeline-svg-wrap svg {
  display: block;
  width: 100%;
}
#tse-presVotosBars .ibar-row,
#tse-faixaBars .ibar-row,
#tse-instrucaoBars .ibar-row,
#tse-bairrosBars .ibar-row,
#tse-estadoCivilBars .ibar-row {
  margin-bottom: 10px;
}
#tse-legendVotos .donut-leg-row,
#tse-legendGênero .donut-leg-row,
#tse-legendCivil .donut-leg-row {
  font-size: 12px;
}

/* ── Atlas: tabs-bar fixa, conteúdo rola internamente ── */

/* IBGE: ocultar card de título superior em todas as abas */
#panel-ibge .page-title-row {
  display: none !important;
}

/* Abas internas: ícones sem fundo, no mesmo padrão visual do Atlas */
#panel-ibge > .tabs-bar .tab svg,
#panel-tse > .tabs-bar .tab svg,
#panel-caged > .tabs-bar .tab svg,
#panel-incra > .tabs-bar .tab svg,
.censo-integrated #panel-ibge > .tabs-bar .tab svg,
.censo-integrated #panel-tse > .tabs-bar .tab svg,
.censo-integrated #panel-caged > .tabs-bar .tab svg,
.censo-integrated #panel-incra > .tabs-bar .tab svg {
  width: 14px !important;
  height: 14px !important;
  display: block !important;
  flex: 0 0 14px !important;
  background: transparent !important;
  fill: none !important;
  stroke: currentColor !important;
  color: inherit !important;
  opacity: .78 !important;
}
#panel-ibge > .tabs-bar .tab svg *,
#panel-tse > .tabs-bar .tab svg *,
#panel-caged > .tabs-bar .tab svg *,
#panel-incra > .tabs-bar .tab svg *,
.censo-integrated #panel-ibge > .tabs-bar .tab svg *,
.censo-integrated #panel-tse > .tabs-bar .tab svg *,
.censo-integrated #panel-caged > .tabs-bar .tab svg *,
.censo-integrated #panel-incra > .tabs-bar .tab svg * {
  fill: none !important;
  stroke: currentColor !important;
  background: transparent !important;
}
#panel-ibge > .tabs-bar .tab:hover svg,
#panel-ibge > .tabs-bar .tab.active svg,
#panel-tse > .tabs-bar .tab:hover svg,
#panel-tse > .tabs-bar .tab.active svg,
#panel-caged > .tabs-bar .tab:hover svg,
#panel-caged > .tabs-bar .tab.active svg,
#panel-incra > .tabs-bar .tab:hover svg,
#panel-incra > .tabs-bar .tab.active svg,
.censo-integrated #panel-ibge > .tabs-bar .tab:hover svg,
.censo-integrated #panel-ibge > .tabs-bar .tab.active svg,
.censo-integrated #panel-tse > .tabs-bar .tab:hover svg,
.censo-integrated #panel-tse > .tabs-bar .tab.active svg,
.censo-integrated #panel-caged > .tabs-bar .tab:hover svg,
.censo-integrated #panel-caged > .tabs-bar .tab.active svg,
.censo-integrated #panel-incra > .tabs-bar .tab:hover svg,
.censo-integrated #panel-incra > .tabs-bar .tab.active svg {
  opacity: 1 !important;
}

/* ── Unificação da cor dos valores de KPI em todos os painéis (light theme) ── */
html[data-theme="light"] .kpi-val,
html[data-theme="light"] .kpi .kpi-val,
html[data-theme="light"] .censo-integrated .kpi-val,
html[data-theme="light"] .sub-kpi-val,
html[data-theme="light"] .mid-kpi-val,
html[data-theme="light"] .pm-native-dashboard .kpi-value,
html[data-theme="light"] .pm-native-dashboard .stat-box-val {
  color: #244E9C !important;
}

/* IBGE: KPIs no mesmo padrão visual do Atlas */
.censo-integrated #panel-ibge .kpi-grid {
  grid-template-columns: repeat(auto-fit, minmax(175px, 1fr)) !important;
  gap: 16px !important;
  margin-bottom: 18px !important;
}
.censo-integrated #panel-ibge .kpi-card {
  position: relative !important;
  overflow: hidden !important;
  min-height: 104px !important;
  padding: 18px 20px 16px !important;
  border-radius: 16px !important;
  border: 1px solid #244E9C !important;
  background: #FFFFFF !important;
  box-shadow: var(--sh, 0 14px 40px rgba(36,78,156,.08)) !important;
  color: #244E9C !important;
  transform: none !important;
}
.censo-integrated #panel-ibge .kpi-card::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 4px !important;
  background: #244E9C !important;
  opacity: 1 !important;
}
.censo-integrated #panel-ibge .kpi-accent {
  display: none !important;
}
.censo-integrated #panel-ibge .kpi-label {
  margin: 3px 0 7px !important;
  color: #244E9C !important;
  font-family: Poppins, Inter, system-ui, sans-serif !important;
  font-size: 9.5px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
}
.censo-integrated #panel-ibge .kpi-val {
  margin: 0 0 6px !important;
  color: #244E9C !important;
  font-family: Poppins, Inter, system-ui, sans-serif !important;
  font-size: 24px !important;
  font-weight: 900 !important;
  line-height: 1.05 !important;
  letter-spacing: -.02em !important;
}
.censo-integrated #panel-ibge .kpi-detail {
  margin: 0 !important;
  color: #244E9C !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  line-height: 1.35 !important;
}
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi-card {
  background: #141414 !important;
  border-color: rgba(255,255,255,.14) !important;
  box-shadow: none !important;
  color: #ececec !important;
}
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi-card::before {
  background: #d4d4d4 !important;
}
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi-label {
  color: rgba(255,255,255,.68) !important;
}
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi-val {
  color: #f5f5f5 !important;
}
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi-detail {
  color: rgba(255,255,255,.62) !important;
}

/* ===== Aba Acao: overrides finais ===== */
#pmtab-acao .pm-action-cats{
  gap:14px !important;
}
#pmtab-acao .pm-action-cat-item{
  min-height:72px !important;
  padding:18px 20px 18px 24px !important;
  border-radius:24px !important;
  border:1px solid rgba(36,78,156,.12) !important;
  background:#FFFFFF !important;
  box-shadow:0 16px 28px rgba(36,78,156,.06) !important;
}
#pmtab-acao .pm-action-cat-item::before{
  width:6px !important;
  top:12px !important;
  bottom:12px !important;
  background:#244E9C !important;
}
#pmtab-acao .pm-action-cat-item:hover{
  border-color:rgba(36,78,156,.18) !important;
  background:#FFFFFF !important;
  box-shadow:0 20px 34px rgba(36,78,156,.09) !important;
}
#pmtab-acao .pm-action-cat-label{
  font-size:14px !important;
  font-weight:700 !important;
  color:#244E9C !important;
  letter-spacing:-.01em !important;
}
#pmtab-acao .pm-action-cat-copy{
  display:flex !important;
  flex-direction:column !important;
  gap:4px !important;
  min-width:0 !important;
  text-align:left !important;
}
#pmtab-acao .pm-action-cat-desc{
  font-size:11px !important;
  font-weight:500 !important;
  line-height:1.45 !important;
  color:#244E9C !important;
  white-space:normal !important;
}
#pmtab-acao .pm-action-cat-count{
  min-width:46px !important;
  height:46px !important;
  font-size:13px !important;
  font-weight:700 !important;
  color:#244E9C !important;
  background:#F8FBFF !important;
  border:1px solid rgba(36,78,156,.12) !important;
  box-shadow:0 12px 22px rgba(36,78,156,.10) !important;
}
#pmtab-acao .pm-action-list-wrap,
#pmtab-acao .pm-action-report-wrap,
#pmtab-acao .pm-action-hero{
  border-radius:24px !important;
  padding:16px !important;
}
#pmtab-acao .pm-action-item{
  border-radius:24px !important;
  padding:18px !important;
  box-shadow:0 16px 30px rgba(36,78,156,.08) !important;
}
#pmtab-acao .pm-action-item-title{
  font-size:17px !important;
  font-weight:700 !important;
  color:#244E9C !important;
}
#pmtab-acao .pm-action-item-sub{
  font-size:12px !important;
  line-height:1.55 !important;
  color:#244E9C !important;
}
#pmtab-acao .pm-action-item-objective{
  font-size:13px !important;
  line-height:1.65 !important;
  color:#244E9C !important;
}
#pmtab-acao .pm-action-item-tools button,
#pmtab-acao .pm-action-create,
#pmtab-acao .pm-action-clear,
#pmtab-acao .pm-action-export,
#pmtab-acao .pm-action-back,
#pmtab-acao .pm-action-cat-back{
  min-height:44px !important;
  border-radius:16px !important;
  font-size:12px !important;
  font-weight:700 !important;
  border:1px solid rgba(36,78,156,.14) !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:0 10px 20px rgba(36,78,156,.06) !important;
}
#pmtab-acao .pm-action-item-tools button:hover,
#pmtab-acao .pm-action-clear:hover,
#pmtab-acao .pm-action-export:hover,
#pmtab-acao .pm-action-back:hover,
#pmtab-acao .pm-action-cat-back:hover{
  background:#FFFFFF !important;
  border-color:rgba(36,78,156,.18) !important;
  color:#244E9C !important;
}
#pmtab-acao .pm-action-create{
  background:#244E9C !important;
  color:#FFFFFF !important;
  border-color:rgba(36,78,156,.26) !important;
  box-shadow:0 12px 24px rgba(36,78,156,.18) !important;
}
#pmtab-acao .pm-action-create:hover{
  background:#244E9C !important;
  color:#FFFFFF !important;
}
#pmtab-acao .pm-action-report-wrap[hidden],
#pmtab-acao .pm-action-list-wrap[hidden],
#pmtab-acao .pm-action-hero[hidden]{
  display:none !important;
}

html[data-theme="dark"] #pmtab-acao .pm-action-cat-item{
  border:1px solid rgba(255,255,255,.14) !important;
  background:#1a1a1a !important;
  box-shadow:none !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-cat-item:hover{
  border-color:rgba(255,255,255,.24) !important;
  background:#222222 !important;
  box-shadow:0 14px 28px rgba(0,0,0,.4) !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-cat-item::before{
  background:#d4d4d4 !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-cat-label{
  color:#f5f5f5 !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-cat-desc{
  color:rgba(255,255,255,.62) !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-cat-count{
  color:#0a0a0a !important;
  background:#e8e8e8 !important;
  border:1px solid rgba(255,255,255,.22) !important;
  box-shadow:none !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-list-wrap,
html[data-theme="dark"] #pmtab-acao .pm-action-report-wrap,
html[data-theme="dark"] #pmtab-acao .pm-action-hero{
  background:#141414 !important;
  border-color:rgba(255,255,255,.14) !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-item{
  background:#1a1a1a !important;
  border-color:rgba(255,255,255,.12) !important;
  color:#ececec !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-item-title{
  color:#f5f5f5 !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-item-sub,
html[data-theme="dark"] #pmtab-acao .pm-action-item-objective{
  color:rgba(255,255,255,.68) !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-item-tools button,
html[data-theme="dark"] #pmtab-acao .pm-action-clear,
html[data-theme="dark"] #pmtab-acao .pm-action-export,
html[data-theme="dark"] #pmtab-acao .pm-action-back,
html[data-theme="dark"] #pmtab-acao .pm-action-cat-back{
  background:#242424 !important;
  border-color:rgba(255,255,255,.16) !important;
  color:#f0f0f0 !important;
}
html[data-theme="dark"] #pmtab-acao .pm-action-create{
  background:#f0f0f0 !important;
  color:#0a0a0a !important;
  border-color:rgba(255,255,255,.35) !important;
}

html[data-theme="dark"] #pmtab-categorias .pm-layers-list .map-layer-row{
  background:#141414 !important;
  border:1.5px solid rgba(255,255,255,.12) !important;
  box-shadow:none !important;
}
html[data-theme="dark"] #pmtab-categorias .pm-layers-list .map-layer-row:hover,
html[data-theme="dark"] #pmtab-categorias .pm-layers-list .map-layer-row.focused{
  background:#1a1a1a !important;
  border-color:rgba(255,255,255,.2) !important;
  box-shadow:0 14px 28px rgba(0,0,0,.4) !important;
}
html[data-theme="dark"] #pmtab-categorias .pm-layers-list .mlr-title{
  color:#f5f5f5 !important;
}
html[data-theme="dark"] #pmtab-categorias .pm-layers-list .mlr-sub,
html[data-theme="dark"] #pmtab-categorias .pm-layers-list .mlr-state{
  color:rgba(255,255,255,.62) !important;
}
html[data-theme="dark"] #mapLayersList .map-layer-row,
html[data-theme="dark"] #mapLayersList.pm-layers-list .map-layer-row,
html[data-theme="dark"] #pmtab-categorias #mapLayersList .map-layer-row{
  background:#141414 !important;
  border:1.5px solid rgba(255,255,255,.12) !important;
  box-shadow:none !important;
}
html[data-theme="dark"] #mapLayersList .map-layer-row:hover,
html[data-theme="dark"] #mapLayersList .map-layer-row.focused,
html[data-theme="dark"] #mapLayersList.pm-layers-list .map-layer-row:hover,
html[data-theme="dark"] #mapLayersList.pm-layers-list .map-layer-row.focused,
html[data-theme="dark"] #pmtab-categorias #mapLayersList .map-layer-row:hover,
html[data-theme="dark"] #pmtab-categorias #mapLayersList .map-layer-row.focused{
  background:#1a1a1a !important;
  border-color:rgba(255,255,255,.2) !important;
  box-shadow:0 14px 28px rgba(0,0,0,.4) !important;
}
html[data-theme="dark"] #mapLayersList .mlr-title,
html[data-theme="dark"] #pmtab-categorias #mapLayersList .mlr-title{
  color:#f5f5f5 !important;
}
html[data-theme="dark"] #mapLayersList .mlr-sub,
html[data-theme="dark"] #mapLayersList .mlr-state,
html[data-theme="dark"] #pmtab-categorias #mapLayersList .mlr-sub,
html[data-theme="dark"] #pmtab-categorias #mapLayersList .mlr-state{
  color:rgba(255,255,255,.62) !important;
}

/* ===== IBGE: ocultar selos Tabela SIDRA ===== */
#panel-ibge .source-tag{
  display:none !important;
}
/* === Map overlay refresh 2026-04-29 === */
.pm-fullscreen-btn{display:none !important;}

.pm-map-top-controls{
  position:absolute;
  top:18px;
  left:18px;
  right:18px;
  z-index:28;
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
  pointer-events:none;
}

.pm-map-corner{position:absolute;z-index:29;pointer-events:none;}
.pm-map-corner > *{pointer-events:auto;}
.pm-map-corner-top-right{top:18px;right:18px;display:flex;flex-direction:row-reverse;align-items:flex-start;gap:10px;pointer-events:auto;}
.pm-map-corner-right{top:auto;bottom:84px;right:16px;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:auto;}
.pm-map-corner-bottom{right:16px;bottom:16px;display:flex;align-items:flex-end;gap:10px;pointer-events:auto;}
.pm-map-corner-bottom .pm-active-bar{
  flex:0 1 auto !important;
  width:clamp(260px, 42vw, 620px) !important;
  max-width:calc(100vw - 560px) !important;
  min-width:260px !important;
  background:rgba(255,255,255,.98) !important;
  border:1px solid rgba(36,78,156,.12) !important;
  color:#244E9C !important;
  box-shadow:0 10px 26px rgba(36,78,156,.12), 0 2px 8px rgba(36,78,156,.06) !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.pm-map-corner-bottom .pm-active-bar-label{
  color:#244E9C !important;
}
.pm-map-corner-bottom .pm-active-empty,
.pm-map-corner-bottom .pm-active-bar-count,
.pm-map-corner-bottom .pm-active-chip{
  background:rgba(241,245,249,.95) !important;
  border-color:rgba(36,78,156,.10) !important;
  color:#244E9C !important;
}
.pm-map-corner-bottom .pm-active-clear,
.pm-map-corner-bottom .pm-active-chip-x{
  background:rgba(36,78,156,.95) !important;
  border-color:rgba(36,78,156,.10) !important;
  color:#244E9C !important;
}
.pm-map-corner-bottom .pm-active-clear:hover,
.pm-map-corner-bottom .pm-active-chip-x:hover{
  background:#FFFFFF !important;
}

html[data-theme="dark"] .pm-map-corner-bottom .pm-active-bar{
  background:#161616 !important;
  border-color:rgba(255,255,255,.14) !important;
  color:#ececec !important;
  box-shadow:0 10px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04) !important;
}
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-bar-label{
  color:#f0f0f0 !important;
}
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-empty,
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-bar-count,
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-chip{
  background:rgba(255,255,255,.1) !important;
  border-color:rgba(255,255,255,.18) !important;
  color:#f5f5f5 !important;
}
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-clear,
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-chip-x{
  background:#2a2a2a !important;
  border-color:rgba(255,255,255,.2) !important;
  color:#f5f5f5 !important;
}
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-clear svg,
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-chip-x svg{
  stroke:#f5f5f5 !important;
  color:#f5f5f5 !important;
}
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-clear:hover,
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-chip-x:hover{
  background:rgba(255,255,255,.14) !important;
}

.pm-map-mode-wrap,
.pm-maptype-wrap{position:relative;}
.pm-maptop-right{display:flex;align-items:center;gap:10px;pointer-events:auto;}

.pm-map-mode-trigger,
.pm-maptype-trigger,
.pm-streetview-trigger,
.pm-traffic-trigger,
.pm-map-round-btn,
.pm-map-compass,
.pm-map-zoom-btn{
  border:1px solid rgba(36,78,156,.12) !important;
  background:rgba(255,255,255,.98) !important;
  color:#244E9C !important;
  box-shadow:0 10px 26px rgba(36,78,156,.12), 0 2px 8px rgba(36,78,156,.06) !important;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}

.pm-map-mode-trigger:hover,
.pm-maptype-trigger:hover,
.pm-streetview-trigger:hover,
.pm-traffic-trigger:hover,
.pm-map-round-btn:hover,
.pm-map-compass:hover,
.pm-map-zoom-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(36,78,156,.14), 0 3px 10px rgba(36,78,156,.08) !important;
  border-color:rgba(36,78,156,.28) !important;
  color:#244E9C !important;
}

.pm-maptype-trigger,
.pm-streetview-trigger,
.pm-traffic-trigger,
.pm-map-round-btn,
.pm-map-compass{
  width:46px !important;
  min-width:46px !important;
  height:46px !important;
  padding:0 !important;
  border-radius:999px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.pm-map-round-btn.active,
.pm-map-compass.active,
.pm-streetview-trigger.active,
.pm-traffic-trigger.active,
.pm-maptype-trigger.active{
  background:#244E9C !important;
  border-color:rgba(36,78,156,.32) !important;
}

.pm-map-round-btn.is-feedback{
  background:#244E9C !important;
  color:#244E9C !important;
}

.pm-map-mode-trigger{
  min-width:212px;
  height:46px;
  padding:0 16px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  font-size:13px;
  font-weight:900;
  line-height:1;
  letter-spacing:-.01em;
  color:#244E9C !important;
}

.pm-map-mode-popover,
.pm-maptype-popover{
  top:calc(100% + 10px) !important;
  right:0 !important;
  left:auto !important;
  padding:10px;
  border-radius:22px;
  border:1px solid rgba(36,78,156,.10);
  background:rgba(255,255,255,.98);
  box-shadow:0 22px 50px rgba(36,78,156,.16), 0 4px 16px rgba(36,78,156,.08);
}

.pm-map-mode-popover{display:none;width:280px;}
.pm-map-mode-popover.open{display:flex;flex-direction:column;gap:8px;}

.pm-map-mode-option{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(36,78,156,.66);
  background:#FFFFFF;
  text-align:left;
  cursor:pointer;
  color:#244E9C;
}

.pm-map-mode-option.active{
  border-color:rgba(36,78,156,.36);
  background:#244E9C;
}

.pm-map-mode-option-title{font-size:14px;font-weight:800;line-height:1.15;}
.pm-map-mode-option-sub{font-size:12px;line-height:1.4;color:#244E9C;}

.pm-maptype-popover{width:252px !important;}

.pm-map-compass{position:relative;overflow:hidden;}
.pm-map-compass-disc{
  position:relative;
  width:31px;
  height:31px;
  border-radius:50%;
  background:#244E9C;
  border:2px solid rgba(255,255,255,.96);
  box-shadow:0 2px 8px rgba(36,78,156,.24), inset 0 1px 0 rgba(255,255,255,.14);
}
.pm-map-compass-arrow{
  position:absolute;
  left:50%;
  top:4px;
  transform:translateX(-50%) rotate(calc(var(--pm-compass-rotation, 0rad) * -1));
  transform-origin:50% 68%;
  color:#E9561E;
}
.pm-map-compass-n{
  position:absolute;
  left:50%;
  top:2px;
  transform:translateX(-50%);
  color:#FFFFFF;
  font-size:9px;
  font-weight:900;
  letter-spacing:.08em;
}

.pm-map-zoom-pill{
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:22px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(36,78,156,.12);
  box-shadow:0 10px 26px rgba(36,78,156,.12), 0 2px 8px rgba(36,78,156,.06);
}
.pm-map-zoom-btn{
  width:46px;
  height:42px;
  padding:0;
  border:none !important;
  border-radius:0 !important;
  box-shadow:none !important;
}
.pm-map-zoom-btn + .pm-map-zoom-btn{
  border-top:1px solid rgba(36,78,156,.10) !important;
}

.pm-map-distance-card,
.pm-map-coords-card{
  min-height:50px;
  border-radius:16px;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(36,78,156,.10);
  box-shadow:0 14px 30px rgba(36,78,156,.14), 0 2px 8px rgba(36,78,156,.06);
}

.pm-map-distance-card{
  min-width:92px;
  padding:8px 10px 7px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:5px;
}
.pm-map-distance-value{
  text-align:center;
  font-size:13px;
  font-weight:800;
  color:#244E9C;
  line-height:1;
}
.pm-map-distance-scale{display:grid;grid-template-columns:auto 1fr auto;align-items:center;}
.pm-map-distance-line{display:block;height:2px;background:#244E9C;}
.pm-map-distance-tick{width:2px;height:7px;background:#244E9C;border-radius:999px;}

.pm-map-coords-card{
  width:204px;
  min-width:204px;
  max-width:204px;
  padding:9px 12px;
  display:flex;
  align-items:center;
  gap:10px;
}
.pm-map-coords-icon{
  width:24px;
  height:24px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#244E9C;
  color:#244E9C;
  flex:0 0 auto;
}
.pm-map-coords-grid{display:flex;flex-direction:column;gap:3px;min-width:0;}
.pm-map-coords-meta,
.pm-map-coords-values{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:center;}
.pm-map-coords-meta{font-size:11px;font-weight:800;text-transform:lowercase;color:#244E9C;}
.pm-map-coords-values{font-size:12px;color:#244E9C;line-height:1.15;}
.pm-map-coords-values span{
  display:block;
  min-width:0;
  white-space:nowrap;
  overflow:visible;
  text-overflow:unset;
  font-variant-numeric:tabular-nums;
}

.pm-biomas-panel{
  display:none;
  flex:1;
  min-height:0;
  overflow-y:auto;
  padding:18px 18px 22px;
  background:#FFFFFF;
}
.pm-biomas-head{display:grid;gap:10px;}
.pm-biomas-head-badge{
  align-self:flex-start;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(36,78,156,.92);
  color:#244E9C;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.pm-biomas-head-title{font-size:22px;font-weight:900;line-height:1.05;color:#244E9C;}
.pm-biomas-head-text{margin:0;font-size:14px;line-height:1.6;color:#244E9C;}
.pm-biomas-search{
  display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;
  background:rgba(255,255,255,.94);border:1px solid rgba(36,78,156,.72);color:#244E9C;
}
.pm-biomas-search input{
  flex:1;border:0;background:transparent;outline:none;color:#244E9C;font:600 13px/1.2 inherit;
}
.pm-biomas-search input::placeholder{color:#244E9C;}
.pm-biomas-active-wrap{
  display:grid;gap:10px;padding:14px;border-radius:18px;
  background:#FFFFFF;
  border:1px solid rgba(36,78,156,.7);
}
.pm-biomas-active-head{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12px;font-weight:800;color:#244E9C;letter-spacing:.04em;text-transform:uppercase;}
.pm-biomas-clear{
  border:0;background:transparent;color:#244E9C;font:700 11px/1 inherit;cursor:pointer;
}
.pm-biomas-active-list{display:flex;flex-wrap:wrap;gap:8px;}
.pm-biomas-active-empty{font-size:12px;color:#244E9C;line-height:1.45;}
.pm-biomas-active-chip{
  display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;border:1px solid rgba(36,78,156,.72);
  background:#FFFFFF;color:#244E9C;font:700 12px/1 inherit;cursor:pointer;
}
.pm-biomas-active-chip strong{color:#244E9C;font-size:10px;text-transform:uppercase;letter-spacing:.05em;}
.pm-biomas-active-dot{width:9px;height:9px;border-radius:999px;flex:0 0 9px;}
.pm-biomas-theme-list{display:grid;gap:10px;}
.pm-biomas-theme{
  border-radius:18px;border:1px solid rgba(36,78,156,.72);
  background:#FFFFFF;
  overflow:hidden;
}
.pm-biomas-theme-head{
  width:100%;display:flex;align-items:center;gap:12px;padding:14px 15px;border:0;background:transparent;cursor:pointer;text-align:left;
}
.pm-biomas-theme-swatch{width:12px;height:12px;border-radius:999px;box-shadow:0 0 0 4px rgba(36,78,156,.56);flex:0 0 12px;}
.pm-biomas-theme-copy{display:grid;gap:4px;min-width:0;flex:1;}
.pm-biomas-theme-title{font-size:15px;font-weight:800;color:#244E9C;line-height:1.1;}
.pm-biomas-theme-sub{font-size:12px;color:#244E9C;line-height:1.35;}
.pm-biomas-theme-meta{font-size:11px;font-weight:800;color:#244E9C;white-space:nowrap;}
.pm-biomas-theme-options{display:none;gap:8px;padding:0 14px 14px;}
.pm-biomas-theme.open .pm-biomas-theme-options{display:grid;}
.pm-biomas-option{
  display:flex;align-items:center;gap:10px;padding:12px 13px;border-radius:14px;border:1px solid rgba(36,78,156,.62);
  background:rgba(255,255,255,.82);cursor:pointer;text-align:left;
}
.pm-biomas-option-bullet{width:10px;height:10px;border-radius:999px;flex:0 0 10px;}
.pm-biomas-option-label{flex:1;min-width:0;font-size:12px;font-weight:700;color:#244E9C;}
.pm-biomas-option-state{font-size:11px;font-weight:800;color:#244E9C;white-space:nowrap;}
.pm-biomas-option.active{
  border-color:rgba(36,78,156,.34);
  background:#244E9C;
}
.pm-biomas-option.active .pm-biomas-option-state{color:#244E9C;}
.pm-biomas-empty{
  padding:18px;border-radius:18px;border:1px dashed rgba(36,78,156,.9);font-size:13px;color:#244E9C;background:rgba(255,255,255,.72);
}

html[data-theme="dark"] .pm-map-mode-trigger,
html[data-theme="dark"] .pm-maptype-trigger,
html[data-theme="dark"] .pm-streetview-trigger,
html[data-theme="dark"] .pm-traffic-trigger,
html[data-theme="dark"] .pm-map-round-btn,
html[data-theme="dark"] .pm-map-compass,
html[data-theme="dark"] .pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-distance-card,
html[data-theme="dark"] .pm-map-coords-card,
html[data-theme="dark"] .pm-map-mode-popover,
html[data-theme="dark"] .pm-maptype-popover{
  background:rgba(36,78,156,.94) !important;
  border-color:rgba(36,78,156,.18) !important;
  color:#244E9C !important;
  box-shadow:0 18px 36px rgba(15,35,71,.34), 0 3px 10px rgba(15,35,71,.18) !important;
}
html[data-theme="dark"] .pm-map-mode-option,
html[data-theme="dark"] .pm-biomas-active-wrap,
html[data-theme="dark"] .pm-biomas-theme,
html[data-theme="dark"] .pm-biomas-option,
html[data-theme="dark"] .pm-biomas-active-chip{
  background:#1a1a1a;
  border-color:rgba(255,255,255,.12);
  color:#f5f5f5;
}
html[data-theme="dark"] .pm-map-mode-option-sub,
html[data-theme="dark"] .pm-map-coords-values,
html[data-theme="dark"] .pm-biomas-head-text,
html[data-theme="dark"] .pm-biomas-theme-sub,
html[data-theme="dark"] .pm-biomas-active-empty{color:rgba(255,255,255,.55);}
html[data-theme="dark"] .pm-map-distance-value,
html[data-theme="dark"] .pm-map-coords-meta,
html[data-theme="dark"] .pm-biomas-head-title,
html[data-theme="dark"] .pm-biomas-theme-title,
html[data-theme="dark"] .pm-biomas-option-label{color:#f0f0f0;}
html[data-theme="dark"] .pm-map-zoom-btn + .pm-map-zoom-btn{border-top-color:rgba(255,255,255,.12) !important;}
html[data-theme="dark"] .pm-biomas-panel{background:#0f0f0f;}
html[data-theme="dark"] .pm-biomas-search{
  background:rgba(20,20,20,.96);
  border-color:rgba(255,255,255,.12);
  color:rgba(255,255,255,.75);
}
html[data-theme="dark"] .pm-biomas-search input{color:#f5f5f5;}
html[data-theme="dark"] .pm-biomas-search input::placeholder{color:rgba(255,255,255,.45);}
html[data-theme="dark"] .pm-biomas-active-head{color:#e5e5e5;}
html[data-theme="dark"] .pm-biomas-clear,
html[data-theme="dark"] .pm-biomas-option-state,
html[data-theme="dark"] .pm-biomas-active-chip strong{color:rgba(255,255,255,.62);}
html[data-theme="dark"] .pm-biomas-option.active{
  background:#2a2a2a;
  border-color:rgba(255,255,255,.22);
}
html[data-theme="dark"] .pm-biomas-option.active .pm-biomas-option-state,
html[data-theme="dark"] .pm-biomas-theme-meta{color:#d4d4d4;}
html[data-theme="dark"] .pm-biomas-empty{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12);
  color:rgba(255,255,255,.62);
}

/* ── Opacity control popover (posicionado via JS relativo ao botão na barra direita) ── */
.pm-map-opacity-card{
  position:absolute;
  top:auto;
  right:76px;
  bottom:84px;
  left:auto;
  width:248px;
  box-sizing:border-box;
  padding:14px 14px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.99);
  border:1px solid rgba(36,78,156,.14);
  box-shadow:0 18px 38px rgba(36,78,156,.18), 0 4px 14px rgba(36,78,156,.08);
  font-family:'Poppins', 'Inter', sans-serif;
  color:#0F2347;
  opacity:0;
  transform:translateX(8px) scale(.97);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:120;
  display:none;
}
.pm-map-opacity-card.open{
  display:block;
  opacity:1;
  transform:translateX(0) scale(1);
  pointer-events:auto;
}
.pm-map-opacity-card::after{
  content:"";
  position:absolute;
  top:18px;
  right:-6px;
  width:12px;
  height:12px;
  background:inherit;
  border-top:1px solid rgba(36,78,156,.14);
  border-right:1px solid rgba(36,78,156,.14);
  transform:rotate(45deg);
}
.pm-map-opacity-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:4px;
}
.pm-map-opacity-title{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:12.5px;
  font-weight:600;
  color:#244E9C;
  letter-spacing:.01em;
}
.pm-map-opacity-close{
  width:22px;
  height:22px;
  border-radius:6px;
  border:none;
  background:transparent;
  color:#60708A;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .15s ease, color .15s ease;
}
.pm-map-opacity-close:hover{background:rgba(36,78,156,.08); color:#244E9C;}
.pm-map-opacity-sub{
  font-size:11px;
  color:#60708A;
  margin-bottom:10px;
  line-height:1.35;
}
.pm-map-opacity-readout{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:8px;
}
.pm-map-opacity-value{
  font-size:22px;
  font-weight:700;
  color:#244E9C;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.pm-map-opacity-hint{
  font-size:11px;
  color:#60708A;
  text-transform:lowercase;
  letter-spacing:.01em;
}
.pm-map-opacity-slider-wrap{
  padding:4px 0 2px;
}
.pm-map-opacity-card input[type="range"]{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height:6px;
  background:linear-gradient(90deg, rgba(36,78,156,.18) 0%, #244E9C 100%);
  border-radius:999px;
  outline:none;
  cursor:pointer;
}
.pm-map-opacity-card input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#FFFFFF;
  border:2px solid #244E9C;
  box-shadow:0 2px 6px rgba(36,78,156,.28);
  cursor:grab;
  transition:transform .12s ease;
}
.pm-map-opacity-card input[type="range"]::-webkit-slider-thumb:active{cursor:grabbing; transform:scale(1.08);}
.pm-map-opacity-card input[type="range"]::-moz-range-thumb{
  width:18px;
  height:18px;
  border-radius:50%;
  background:#FFFFFF;
  border:2px solid #244E9C;
  box-shadow:0 2px 6px rgba(36,78,156,.28);
  cursor:grab;
}
.pm-map-opacity-ticks{
  display:flex;
  justify-content:space-between;
  margin-top:6px;
  font-size:10px;
  color:#8A99B5;
  letter-spacing:.04em;
}
html[data-theme="dark"] .pm-map-opacity-card{
  background:#1A1A1A;
  border-color:rgba(255,255,255,.12);
  color:#ECECEC;
  box-shadow:0 18px 38px rgba(0,0,0,.45);
}
html[data-theme="dark"] .pm-map-opacity-card::after{
  border-top-color:rgba(255,255,255,.12);
  border-right-color:rgba(255,255,255,.12);
}
html[data-theme="dark"] .pm-map-opacity-title{color:#E5E7EB;}
html[data-theme="dark"] .pm-map-opacity-value{color:#FFFFFF;}
html[data-theme="dark"] .pm-map-opacity-sub,
html[data-theme="dark"] .pm-map-opacity-hint,
html[data-theme="dark"] .pm-map-opacity-ticks{color:rgba(255,255,255,.55);}
html[data-theme="dark"] .pm-map-opacity-close{color:rgba(255,255,255,.6);}
html[data-theme="dark"] .pm-map-opacity-close:hover{background:rgba(255,255,255,.08); color:#FFFFFF;}
html[data-theme="dark"] .pm-map-opacity-card input[type="range"]{
  background:linear-gradient(90deg, rgba(255,255,255,.14) 0%, #38BEEF 100%);
}
html[data-theme="dark"] .pm-map-opacity-card input[type="range"]::-webkit-slider-thumb{
  background:#1A1A1A;
  border-color:#38BEEF;
}
html[data-theme="dark"] .pm-map-opacity-card input[type="range"]::-moz-range-thumb{
  background:#1A1A1A;
  border-color:#38BEEF;
}

@media (max-width: 980px){
  .pm-map-corner-top-right{top:12px;right:12px;gap:8px;}
  .pm-map-corner-right{top:auto;bottom:78px;right:12px;gap:8px;}
  .pm-map-corner-bottom{right:12px;bottom:12px;gap:8px;}
  .pm-map-corner-bottom .pm-active-bar{width:min(420px, calc(100vw - 330px)) !important;min-width:220px !important;max-width:none !important;}
  .pm-map-mode-trigger{min-width:190px;font-size:13px;padding:0 14px;}
  .pm-map-coords-card{width:190px;min-width:190px;max-width:190px;padding:9px 11px;}
  .pm-map-distance-card{min-width:84px;}
  .pm-map-opacity-card{width:228px;}
}

@media (max-width: 720px){
  .pm-map-corner-top-right{left:12px;right:12px;justify-content:flex-end;flex-wrap:wrap;}
  .pm-map-mode-trigger{min-width:170px;}
  .pm-map-corner-right{top:auto;right:12px;bottom:78px;}
  .pm-map-corner-bottom{left:12px;right:12px;bottom:12px;justify-content:flex-end;flex-wrap:wrap;}
  .pm-map-corner-bottom .pm-active-bar{order:3;flex:1 1 100% !important;width:100% !important;min-width:0 !important;max-width:none !important;}
}
/* === Dark mode polish 2026-04-29 — neutro (sem azul institucional) === */
html[data-theme="dark"] body,
html[data-theme="dark"] .main,
html[data-theme="dark"] .content,
html[data-theme="dark"] .app{
  background: var(--app-bg) !important;
  color: #ececec !important;
}

html[data-theme="dark"] .topbar{
  background: #0a0a0a !important;
  border-bottom: 1px solid rgba(255,255,255,.12) !important;
}

html[data-theme="dark"] .sidebar{
  background: #0a0a0a !important;
  border-right-color: rgba(255,255,255,.12) !important;
}

html[data-theme="dark"] .icon-btn,
html[data-theme="dark"] .btn,
html[data-theme="dark"] .nav-item,
html[data-theme="dark"] .fav-btn,
html[data-theme="dark"] .searchbox,
html[data-theme="dark"] .drawer,
html[data-theme="dark"] .user-menu,
html[data-theme="dark"] .pm-modal,
html[data-theme="dark"] .source-btn,
html[data-theme="dark"] .pm-map-sidebar,
html[data-theme="dark"] .pm-layers-card,
html[data-theme="dark"] .pm-sb-search,
html[data-theme="dark"] #pmtab-categorias .map-cat-item,
html[data-theme="dark"] .pm-radius-control,
html[data-theme="dark"] .pm-radius-metric,
html[data-theme="dark"] .pm-report-builder-wrap,
html[data-theme="dark"] .pm-sb-panel,
html[data-theme="dark"] .pm-map-mode-option{
  background: #141414 !important;
  color: #ececec !important;
  border-color: rgba(255,255,255,.14) !important;
}

html[data-theme="dark"] .source-btn.active,
html[data-theme="dark"] .pm-sb-tab.active,
html[data-theme="dark"] #pmtab-categorias .map-cat-item.on,
html[data-theme="dark"] .pm-maptype-card.active,
html[data-theme="dark"] .pm-map-mode-option.active{
  background: #f5f5f5 !important;
  border-color: rgba(255,255,255,.35) !important;
  color: #0a0a0a !important;
}

html[data-theme="dark"] .crumb,
html[data-theme="dark"] .card-title,
html[data-theme="dark"] .page-title,
html[data-theme="dark"] .nav-title,
html[data-theme="dark"] .pm-layers-card-head,
html[data-theme="dark"] .pm-sb-section-label,
html[data-theme="dark"] .pm-maptype-name,
html[data-theme="dark"] .pm-map-mode-trigger,
html[data-theme="dark"] .pm-map-mode-option-title,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .brand-title,
html[data-theme="dark"] .user-menu-name,
html[data-theme="dark"] .pii-value,
html[data-theme="dark"] .cf-label,
html[data-theme="dark"] .cf-input,
html[data-theme="dark"] .pm-radius-metric-value,
html[data-theme="dark"] .pm-radius-metric-label,
html[data-theme="dark"] .pm-radius-status,
html[data-theme="dark"] .pm-radius-row,
html[data-theme="dark"] .pm-radius-input-wrap span,
html[data-theme="dark"] .pm-map-coords-meta,
html[data-theme="dark"] .pm-map-distance-value{
  color: #f5f5f5 !important;
}

html[data-theme="dark"] .crumb-sub,
html[data-theme="dark"] .card-sub,
html[data-theme="dark"] .nav-sub,
html[data-theme="dark"] .brand-subtitle,
html[data-theme="dark"] .pm-map-coords-values,
html[data-theme="dark"] .pm-map-mode-option-sub,
html[data-theme="dark"] .pm-radius-metric-hint,
html[data-theme="dark"] .pm-radius-scale,
html[data-theme="dark"] .pm-layer-count,
html[data-theme="dark"] .map-layer-empty,
html[data-theme="dark"] .user-menu-role,
html[data-theme="dark"] .pii-label,
html[data-theme="dark"] .cf-input::placeholder,
html[data-theme="dark"] .pm-sb-info-label,
html[data-theme="dark"] .pm-maptype-card,
html[data-theme="dark"] .pm-maptype-popover,
html[data-theme="dark"] .pm-sb-search input::placeholder,
html[data-theme="dark"] .searchbox input::placeholder{
  color: rgba(255,255,255,.62) !important;
}

html[data-theme="dark"] .searchbox input,
html[data-theme="dark"] .sb-search input,
html[data-theme="dark"] .pm-sb-search input,
html[data-theme="dark"] .cf-input,
html[data-theme="dark"] .input,
html[data-theme="dark"] .select{
  color: #f5f5f5 !important;
  background: #0a0a0a !important;
  border-color: rgba(255,255,255,.14) !important;
}

html[data-theme="dark"] .source-switcher,
html[data-theme="dark"] .pm-sb-tabs,
html[data-theme="dark"] .pm-layers-card-head{
  background: #0a0a0a !important;
  border-color: rgba(255,255,255,.12) !important;
}

html[data-theme="dark"] .pm-map-sidebar,
html[data-theme="dark"] .pm-sb-panel,
html[data-theme="dark"] .pm-layers-card-body,
html[data-theme="dark"] #panel-mapa,
html[data-theme="dark"] #sec-mapa{
  background-color: transparent !important;
}

html[data-theme="dark"] .map-layer-row,
html[data-theme="dark"] .mini-item,
html[data-theme="dark"] .card,
html[data-theme="dark"] .kpi,
html[data-theme="dark"] .sub-kpi-card{
  background: #111111 !important;
  border-color: rgba(255,255,255,.14) !important;
  color: #ececec !important;
}

html[data-theme="dark"] .topbar .icon-btn,
html[data-theme="dark"] #btnTheme,
html[data-theme="dark"] #btnSettings,
html[data-theme="dark"] .sb-bottom .icon-btn{
  background: #141414 !important;
  border-color: rgba(255,255,255,.16) !important;
  color: #f5f5f5 !important;
}

/* TSE: complementos importados do dashboard Eleitorado */
.tse-mini-legend{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:10px;color:var(--muted,#244E9C);font-size:11px;font-weight:700}
.tse-mini-legend span{display:inline-flex;align-items:center;gap:6px}
.tse-mini-legend i,.tse-map-legend i{width:10px;height:10px;border-radius:999px;display:inline-block;flex:0 0 auto}
.tse-pyramid-row{display:grid;grid-template-columns:minmax(0,1fr) 58px minmax(0,1fr);align-items:center;gap:8px;margin-bottom:3px;min-height:16px}
.tse-pyramid-age{color:var(--muted,#244E9C);font-size:10px;font-weight:800;text-align:center}
.tse-pyramid-side{height:14px;display:flex;align-items:center}
.tse-pyramid-side.left{justify-content:flex-end}
.tse-pyramid-side.right{justify-content:flex-start}
.tse-pyramid-side span{height:14px;min-width:2px;border-radius:4px;position:relative}
.tse-pyramid-side.left span{background:#244E9C}
.tse-pyramid-side.right span{background:#E9561E}
.tse-pyramid-side b{position:absolute;top:-1px;color:var(--muted2,#244E9C);font-size:9px;line-height:14px;white-space:nowrap}
.tse-pyramid-side.left b{right:calc(100% + 4px)}
.tse-pyramid-side.right b{left:calc(100% + 4px)}
.tse-dual-row{display:grid;align-items:center;gap:10px;margin-bottom:8px}
.tse-dual-label{color:var(--muted,#244E9C);font-size:11.5px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tse-dual-bars{display:grid;gap:4px}
.tse-dual-track{height:15px;background:var(--bar-track,rgba(36,78,156,.16));border-radius:6px;position:relative;overflow:hidden}
.tse-dual-track span{display:block;height:100%;border-radius:inherit}
.tse-dual-track b{position:absolute;right:7px;top:0;line-height:15px;color:var(--text,#244E9C);font-size:10px;font-weight:900}
.tse-vbar-chart{height:260px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;align-items:end;padding:18px 6px 4px}
.tse-vbar-item{height:100%;display:grid;grid-template-rows:1fr auto;gap:9px;min-width:0}
.tse-vbar-plot{position:relative;display:flex;align-items:flex-end;justify-content:center;height:100%;border-bottom:1px solid var(--border,rgba(36,78,156,.24))}
.tse-vbar-plot span{width:min(100%,42px);min-height:3px;border-radius:8px 8px 3px 3px;box-shadow:0 10px 18px rgba(36,78,156,.14)}
.tse-vbar-plot b{position:absolute;top:0;left:50%;transform:translateX(-50%);font-size:11px;font-weight:900;white-space:nowrap}
.tse-vbar-label{min-height:30px;color:var(--muted,#244E9C);font-size:10px;font-weight:800;line-height:1.15;text-align:center;word-break:normal;overflow-wrap:anywhere}
.tse-data-table{width:100%;border-collapse:collapse;font-size:12px}
.tse-data-table th,.tse-data-table td{padding:8px 9px;border-bottom:1px solid var(--border,rgba(36,78,156,.2));color:var(--muted,#244E9C)}
.tse-data-table th{text-align:left;text-transform:uppercase;font-size:10px;letter-spacing:.04em;font-weight:900}
.tse-data-table td:last-child,.tse-data-table th:last-child{text-align:right;color:var(--text,#244E9C);font-weight:900}
.tse-map-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.tse-map-toolbar button{border:1px solid var(--border,rgba(36,78,156,.25));background:var(--insight-bg,#F8FBFF);color:var(--muted,#244E9C);border-radius:999px;padding:7px 12px;font-size:11px;font-weight:900;cursor:pointer}
.tse-map-toolbar button.active{background:#244E9C;border-color:#244E9C;color:#FFFFFF}
.tse-map-toolbar span{margin-left:auto;color:var(--muted,#244E9C);font-size:11px;font-weight:700}
.tse-locais-map{position:relative;height:360px;overflow:hidden;border-radius:14px;border:1px solid var(--border,rgba(36,78,156,.24));background:transparent,transparent,#FFFFFF}
.tse-locais-map::before{content:"";position:absolute;inset:0;background-image:#244E9C,#244E9C;background-size:48px 48px;opacity:.75}
.tse-map-point{position:absolute;transform:translate(-50%,-50%);border:2px solid rgba(255,255,255,.92);border-radius:999px;box-shadow:0 10px 22px rgba(36,78,156,.2);opacity:.82;cursor:pointer;transition:transform .15s ease,opacity .15s ease;z-index:2}
.tse-map-point:hover{transform:translate(-50%,-50%) scale(1.15);opacity:1;z-index:4}
.tse-map-legend{position:absolute;right:12px;bottom:12px;z-index:5;display:grid;gap:5px;min-width:190px;padding:11px 13px;border-radius:12px;background:rgba(255,255,255,.94);border:1px solid rgba(36,78,156,.24);color:#60708A;box-shadow:0 10px 24px rgba(36,78,156,.12);font-size:11px}
.tse-map-legend b{color:#244E9C;font-size:12px}
.tse-map-legend span{display:flex;align-items:center;gap:7px}
.tse-map-legend small{color:#244E9C;font-size:10px}
.tse-alert-metric{border:1px solid rgba(36,78,156,.18);border-radius:14px;background:var(--insight-bg,#F8FBFF);padding:18px;color:var(--muted,#244E9C)}
.tse-alert-metric strong{display:block;color:#244E9C;font-size:34px;line-height:1;margin-bottom:8px}
.tse-alert-metric span,.tse-findings{font-size:12px;line-height:1.65;color:var(--muted,#244E9C)}
.tse-findings{display:grid;gap:8px}
.tse-findings strong{color:#244E9C}
html[data-theme="dark"] .tse-locais-map{background:transparent,transparent,#0a0a0a}
html[data-theme="dark"] .tse-map-legend{background:rgba(10,10,10,.95);border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.85)}
html[data-theme="dark"] .tse-map-legend b{color:#f5f5f5}

/* === Map sidebar dark mode fix (neutro) === */
html[data-theme="dark"] .pm-map-sidebar{
  background:#0f0f0f !important;
  border-color:rgba(255,255,255,.12) !important;
}
html[data-theme="dark"] .pm-sb-panel{
  background:#0f0f0f !important;
}
html[data-theme="dark"] .pm-cat-section,
html[data-theme="dark"] .pm-cat-grid,
html[data-theme="dark"] #mapCatChips{
  background:transparent !important;
}
html[data-theme="dark"] #pmtab-categorias .map-cat-item{
  background:#161616 !important;
  border:1px solid rgba(255,255,255,.14) !important;
  color:#ececec !important;
}
html[data-theme="dark"] #pmtab-categorias .map-cat-item.on{
  background:#f5f5f5 !important;
  border-color:rgba(255,255,255,.35) !important;
  color:#0a0a0a !important;
}
html[data-theme="dark"] .pm-sb-section-label{color:rgba(255,255,255,.62) !important;}
html[data-theme="dark"] .pm-sb-search{
  background:#141414 !important;
  border-color:rgba(255,255,255,.14) !important;
}
html[data-theme="dark"] .pm-sb-search input{
  color:#f5f5f5 !important;
  background:transparent !important;
}
html[data-theme="dark"] .pm-sb-search input::placeholder{color:rgba(255,255,255,.45) !important;}
html[data-theme="dark"] .pm-layers-card{
  background:#0f0f0f !important;
  border-color:rgba(255,255,255,.12) !important;
}
html[data-theme="dark"] .pm-layers-card-head{
  background:#161616 !important;
  color:#f5f5f5 !important;
  border-color:rgba(255,255,255,.12) !important;
}
html[data-theme="dark"] #mapLayersList .map-layer-row,
html[data-theme="dark"] #pmtab-categorias .map-layer-row{
  background:#141414 !important;
  border:1.5px solid rgba(255,255,255,.14) !important;
  color:#ececec !important;
}
html[data-theme="dark"] #mapLayersList .mlr-title,
html[data-theme="dark"] #pmtab-categorias .mlr-title{color:#f5f5f5 !important;}
html[data-theme="dark"] #mapLayersList .mlr-sub,
html[data-theme="dark"] #pmtab-categorias .mlr-sub{color:rgba(255,255,255,.62) !important;}

/* === Map popup (ol-popup) dark/light mode === */
.ol-popup{
  background:#FFFFFF !important;
  border:1px solid rgba(36,78,156,.12) !important;
  box-shadow:0 8px 24px rgba(36,78,156,.14) !important;
  border-radius:14px !important;
  padding:14px 18px !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.ol-popup:after{border-top-color:#FFFFFF !important;}
.ol-popup:before{border-top-color:rgba(36,78,156,.12) !important;}
#popup-content{color:#244E9C !important;font-family:inherit !important;}
html[data-theme="dark"] .ol-popup{
  background:#141414 !important;
  border-color:rgba(255,255,255,.18) !important;
  box-shadow:0 8px 28px rgba(0,0,0,.55) !important;
  color:#ececec !important;
}
html[data-theme="dark"] .ol-popup:after{border-top-color:#141414 !important;}
html[data-theme="dark"] .ol-popup:before{border-top-color:rgba(255,255,255,.18) !important;}
html[data-theme="dark"] #popup-content{color:#ececec !important;}
html[data-theme="dark"] #popup-content *{color:#ececec !important;}
html[data-theme="dark"] #popup-content th,
html[data-theme="dark"] #popup-content strong{color:#ffffff !important;}

@media (max-width:760px){.tse-pyramid-row{grid-template-columns:minmax(0,1fr) 44px minmax(0,1fr);gap:5px}.tse-pyramid-side b{display:none}.tse-map-toolbar span{width:100%;margin-left:0}.tse-locais-map{height:300px}}

/* === PMPA 2026 brand refresh: minimal, flat, official palette === */
:root{
  --pmpa-blue:#244E9C;
  --pmpa-cyan:#38BEEF;
  --pmpa-orange:#E9561E;
  --pmpa-yellow:#FCCF00;
  --pmpa-green:#47AB34;
  --pmpa-green-dark:#005E34;
  --pmpa-ink:#244E9C;
  --pmpa-muted:#244E9C;
  --pmpa-line:#244E9C;
  --pmpa-bg:#F6F8FB;
  --pmpa-card:#FFFFFF;
  --radius:8px;
  --radius-sm:6px;
  --shadow:none;
  --shadow-soft:none;
  --blue-950:#244E9C;
  --blue-900:#244E9C;
  --blue-850:#244E9C;
  --blue-800:#244E9C;
  --blue-700:#244E9C;
  --blue-600:#244E9C;
  --cyan-400:#38BEEF;
  --mint-400:#47AB34;
  --violet-400:#E9561E;
  --text:#244E9C;
  --muted:#244E9C;
  --border:rgba(36,78,156,.14);
  --border-strong:rgba(36,78,156,.24);
  --app-bg:#F6F8FB;
  --content-bg:#F6F8FB;
  --surface:#FFFFFF;
  --surface-2:#FFFFFF;
  --card:#FFFFFF;
  --card-strong:#244E9C;
  --accent:#244E9C;
  --accent-2:#38BEEF;
  --pm-accent:#244E9C;
  --pm-accent2:#38BEEF;
  --pm-card-blue:#244E9C;
  --pm-card-dark:#244E9C;
  --pm-card-strong:#244E9C;
  --pm-topbar:#244E9C;
  --pm-sb:#1253a8;
  --topbar-bg:#244E9C;
  --topbar-text:#FFFFFF;
  --sb-bg:#244E9C;
  --sb-border:rgba(255,255,255,.18);
  --sb-icon:#FFFFFF;
}

html[data-theme="light"],
html[data-theme="dark"]{
  --app-bg:#F6F8FB !important;
  --content-bg:#F6F8FB !important;
  --surface:#FFFFFF !important;
  --surface-2:#FFFFFF !important;
  --card:#FFFFFF !important;
  --card-strong:#244E9C !important;
  --text:#244E9C !important;
  --muted:#244E9C !important;
  --border:rgba(36,78,156,.14) !important;
  --border-strong:rgba(36,78,156,.24) !important;
  --shadow:none !important;
  --shadow-soft:none !important;
  --sb-bg:#244E9C !important;
  --sb-border:rgba(255,255,255,.18) !important;
  --topbar-bg:#244E9C !important;
}

body,
.app,
.main,
.content{
  background:#F6F8FB !important;
  color:#244E9C !important;
}

.sidebar,
.topbar,
.mini-map-head,
.tutu-panel-head{
  background:#244E9C !important;
  background-image:none !important;
  box-shadow:none !important;
}

.card,
.dash-card,
.kpi,
.stat-card,
.drawer,
.panel,
.searchbox,
.empty-state,
.map-card,
.pm-biomas-panel,
.pm-biomas-active,
.pm-biomas-theme,
.pm-biomas-option,
.pm-map-mode-panel,
.ol-popup{
  background:#FFFFFF !important;
  background-image:none !important;
  border:1px solid rgba(36,78,156,.14) !important;
  border-radius:8px !important;
  box-shadow:none !important;
  color:#244E9C !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

.card.strong,
.card.blue,
.btn.primary,
.login-btn,
.pill.active,
.chip.on,
.pm-map-toolbar button.active,
.tse-map-toolbar button.active{
  background:#244E9C !important;
  background-image:none !important;
  border-color:#244E9C !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.btn,
.icon-btn,
.pill-btn,
.chip,
.input,
.select,
.form-input,
.sb-search input,
.searchbox input,
.pm-biomas-search,
.pm-biomas-active-chip,
.map-layer-row{
  background:#FFFFFF !important;
  background-image:none !important;
  border:1px solid rgba(36,78,156,.16) !important;
  border-radius:8px !important;
  box-shadow:none !important;
  color:#244E9C !important;
}

.btn:hover,
.icon-btn:hover,
.pill-btn:hover,
.chip:hover,
.nav-item:hover,
.map-layer-row:hover,
.pm-biomas-option:hover{
  background:#F0F7FD !important;
  transform:none !important;
  box-shadow:none !important;
}

.nav-item,
.nav-icon,
.fav-btn,
.brand-mark{
  background:rgba(255,255,255,.10) !important;
  background-image:none !important;
  border:1px solid rgba(255,255,255,.18) !important;
  border-radius:8px !important;
  box-shadow:none !important;
}

.nav-item.active,
.fav-btn.on{
  background:#38BEEF !important;
  border-color:#38BEEF !important;
  color:#244E9C !important;
}

.nav-item.active *,
.fav-btn.on *{
  color:#244E9C !important;
}

.crumb,
.crumb-sub,
.card .muted,
.muted,
.section-desc,
.pm-biomas-head-text,
.pm-biomas-theme-sub,
.pm-map-coords-values,
.tse-dual-label,
.tse-data-table th,
.tse-data-table td{
  color:#244E9C !important;
}

h1,h2,h3,h4,
.card-title,
.kpi-val,
.kpi-value,
.brand-title,
.pm-biomas-head-title,
.pm-biomas-theme-title,
.mlr-title,
.tse-alert-metric strong{
  color:#244E9C !important;
}

.sidebar h1,
.sidebar h2,
.sidebar h3,
.sidebar h4,
.sidebar .brand-title,
.sidebar .brand-subtitle,
.sidebar .sb-section-title,
.sidebar .nav-title,
.sidebar .nav-sub,
.sidebar .icon,
.topbar,
.topbar *,
.mini-map-head,
.mini-map-head *,
.tutu-panel-head,
.tutu-panel-head *{
  color:#FFFFFF !important;
}

a,
.accent,
.section-num,
.pm-biomas-active-head,
.pm-biomas-theme-meta,
.pm-biomas-option.active .pm-biomas-option-state,
.pm-map-coords-meta,
#popup-content strong{
  color:#244E9C !important;
}

.badge,
.access-badge,
.pct-i,
.bdg,
.tb-badge{
  background:#EAF7FD !important;
  border-color:rgba(56,190,239,.28) !important;
  color:#244E9C !important;
}

.divider,
.sep,
hr,
.card-line{
  background:rgba(36,78,156,.14) !important;
  border-color:rgba(36,78,156,.14) !important;
}

.spark,
.line-chart,
.bar-chart,
svg.chart,
.line-path,
.line-point{
  color:#244E9C !important;
  stroke:#244E9C;
}

.mini-bar,
.progress-bar{
  background:#38BEEF !important;
  background-image:none !important;
}

*{
  letter-spacing:normal;
}

/* PMPA 2026 final neutral pass */
:root,
html[data-theme="light"],
html[data-theme="dark"]{
  --pmpa-ink:#111827 !important;
  --pmpa-muted:#60708A !important;
  --pmpa-line:#DCE5F2 !important;
  --text:#111827 !important;
  --muted:#60708A !important;
  --border:rgba(36,78,156,.14) !important;
  --border-strong:rgba(36,78,156,.24) !important;
}

body,
.app,
.main,
.content,
.card,
.dash-card,
.kpi,
.stat-card,
.drawer,
.panel,
.searchbox,
.empty-state,
.map-card,
.pm-biomas-panel,
.pm-biomas-active,
.pm-biomas-theme,
.pm-biomas-option,
.pm-map-mode-panel,
.ol-popup,
.btn,
.icon-btn,
.pill-btn,
.chip,
.input,
.select,
.form-input,
.sb-search input,
.searchbox input,
.pm-biomas-search,
.pm-biomas-active-chip,
.map-layer-row{
  color:#111827 !important;
}

.crumb,
.crumb-sub,
.card .muted,
.muted,
.section-desc,
.pm-biomas-head-text,
.pm-biomas-theme-sub,
.pm-map-coords-values,
.tse-dual-label,
.tse-data-table th,
.tse-data-table td,
.kpi-sub,
.kpi-label,
.card-sub,
.nav-sub,
.footer,
.pm-biomas-active-empty,
.pm-biomas-option-state{
  color:#60708A !important;
}

h1,h2,h3,h4,
.card-title,
.kpi-val,
.kpi-value,
.brand-title,
.pm-biomas-head-title,
.pm-biomas-theme-title,
.mlr-title{
  color:#111827 !important;
}

.sidebar .brand-title,
.sidebar .brand-subtitle,
.sidebar .sb-section-title,
.sidebar .nav-title,
.sidebar .nav-sub,
.sidebar .icon{
  color:#FFFFFF !important;
}

.card,
.dash-card,
.kpi,
.stat-card,
.drawer,
.panel,
.searchbox,
.empty-state,
.map-card,
.pm-biomas-panel,
.pm-biomas-active,
.pm-biomas-theme,
.pm-biomas-option,
.pm-map-mode-panel,
.ol-popup,
.btn,
.icon-btn,
.pill-btn,
.chip,
.input,
.select,
.form-input,
.sb-search input,
.searchbox input,
.pm-biomas-search,
.pm-biomas-active-chip,
.map-layer-row{
  border-color:rgba(36,78,156,.14) !important;
}

html:not(.map-only) *,
html:not(.map-only) *::before,
html:not(.map-only) *::after{
  box-shadow:none !important;
  text-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

html:not(.map-only) .card,
html:not(.map-only) .dash-card,
html:not(.map-only) .kpi,
html:not(.map-only) .stat-card,
html:not(.map-only) .panel,
html:not(.map-only) .drawer,
html:not(.map-only) .modal,
html:not(.map-only) .searchbox,
html:not(.map-only) .btn,
html:not(.map-only) .icon-btn,
html:not(.map-only) .chip,
html:not(.map-only) .pill,
html:not(.map-only) .map-layer-row,
html:not(.map-only) .pm-biomas-panel,
html:not(.map-only) .pm-biomas-theme,
html:not(.map-only) .pm-biomas-option{
  background-image:none !important;
}

/* PMPA 2026 button/topbar repair: fixed colors only */
:root,
html[data-theme="light"],
html[data-theme="dark"]{
  --app-bg:#F6F8FB !important;
  --content-bg:#F6F8FB !important;
  --surface:#FFFFFF !important;
  --surface-2:#FFFFFF !important;
  --card:#FFFFFF !important;
  --card-strong:#244E9C !important;
  --topbar-bg:#244E9C !important;
  --sb-bg:#244E9C !important;
  --pm-topbar:#244E9C !important;
  --pm-sb:#1253a8 !important;
  --pm-card-blue:#244E9C !important;
  --pm-card-dark:#244E9C !important;
  --pm-card-strong:#244E9C !important;
}

.topbar,
.sidebar,
.mini-map-head,
.tutu-panel-head,
.source-panel > .topbar,
.censo-integrated .topbar,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .sidebar{
  background:#244E9C !important;
  background-image:none !important;
  color:#FFFFFF !important;
}

.tabs-bar,
.tabs,
.nav-tabs,
.source-panel > .tabs-bar,
#panel-ibge > .tabs-bar,
#panel-saude .tabs-bar{
  background:#FFFFFF !important;
  background-image:none !important;
  border-color:rgba(36,78,156,.14) !important;
}

button,
.btn,
.icon-btn,
.pill-btn,
.chip,
.source-btn,
.tab,
.map-tb-btn,
.sat-toggle-btn,
.map-fullscreen-btn,
.map-action-btn,
.pm-map-mode-trigger,
.pm-maptype-trigger,
.pm-map-round-btn,
.pm-map-zoom-btn,
.pm-active-clear,
.pm-active-chip-x,
.pm-action-item-tools button,
.pm-action-create,
.pm-action-clear,
.pm-action-export,
.pm-action-back,
.pm-action-cat-back,
.um-add-btn,
.um-photo-btn,
.um-delete-btn,
.um-cancel-btn,
.um-save-btn,
.cf-btn,
.sec-map-open-btn,
.sec-map-overlay-btn{
  min-width:max-content;
  background:#FFFFFF !important;
  background-image:none !important;
  border:1px solid rgba(36,78,156,.18) !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.icon-btn,
.map-fullscreen-btn,
.sat-toggle-btn,
.pm-map-round-btn,
.pm-map-zoom-btn,
.pm-active-clear,
.pm-active-chip-x{
  min-width:40px;
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

html[data-theme="light"] .topbar .icon-btn,
html[data-theme="light"] .topbar .btn,
html[data-theme="light"] .topbar .badge,
html[data-theme="light"] .topbar .user-btn,
html[data-theme="light"] .sidebar .icon-btn,
html[data-theme="light"] .sb-bottom .icon-btn{
  background:#FFFFFF !important;
  background-image:none !important;
  border-color:rgba(255,255,255,.34) !important;
  color:#244E9C !important;
}

html[data-theme="light"] .topbar .icon-btn *,
html[data-theme="light"] .topbar .btn *,
html[data-theme="light"] .topbar .badge *,
html[data-theme="light"] .topbar .user-btn *,
html[data-theme="light"] .sidebar .icon-btn *,
html[data-theme="light"] .sb-bottom .icon-btn *{
  color:#244E9C !important;
  stroke:#244E9C !important;
}

/* Modo escuro: perfil / ajuda na topbar — fundo escuro, texto e ícones claros */
html[data-theme="dark"] .topbar .user-btn,
html[data-theme="dark"] .topbar .icon-btn,
html[data-theme="dark"] .topbar .btn{
  background:#141414 !important;
  border-color:rgba(255,255,255,.2) !important;
  color:#f5f5f5 !important;
}
html[data-theme="dark"] .topbar .user-btn *,
html[data-theme="dark"] .topbar .icon-btn *,
html[data-theme="dark"] .topbar .btn *{
  color:#f5f5f5 !important;
  stroke:#f5f5f5 !important;
}
html[data-theme="dark"] .topbar .user-name{
  color:#f5f5f5 !important;
}
html[data-theme="dark"] .topbar .user-role{
  color:rgba(255,255,255,.65) !important;
}
html[data-theme="dark"] .topbar .user-chevron{
  color:rgba(255,255,255,.85) !important;
}

.btn.primary,
.map-action-btn.primary,
.pm-action-create,
.um-save-btn,
.cf-btn,
.sec-map-open-btn,
.sec-map-overlay-btn,
.nav-item.active,
.pm-sb-tab.active,
.pm-map-round-btn.active,
.pm-maptype-trigger.active,
.pm-map-mode-option.active{
  background:#244E9C !important;
  background-image:none !important;
  border-color:#244E9C !important;
  color:#FFFFFF !important;
}

.btn.primary *,
.map-action-btn.primary *,
.pm-action-create *,
.um-save-btn *,
.cf-btn *,
.sec-map-open-btn *,
.sec-map-overlay-btn *,
.nav-item.active *,
.pm-sb-tab.active *,
.pm-map-round-btn.active *,
.pm-maptype-trigger.active *,
.pm-map-mode-option.active *{
  color:#FFFFFF !important;
  stroke:#FFFFFF !important;
}

.nav-item,
.nav-icon,
.sidebar .brand-mark{
  background:rgba(255,255,255,.12) !important;
  background-image:none !important;
  border-color:rgba(255,255,255,.22) !important;
}

.nav-item:hover,
button:hover,
.btn:hover,
.icon-btn:hover,
.pill-btn:hover,
.chip:hover,
.source-btn:hover,
.tab:hover{
  filter:none !important;
  transform:none !important;
}

.map-tb-btn.active,
.chip.on,
.pill.active,
.sat-toggle-btn.active{
  background:#38BEEF !important;
  background-image:none !important;
  border-color:#38BEEF !important;
  color:#111827 !important;
}

.map-tb-btn.active *,
.chip.on *,
.pill.active *,
.sat-toggle-btn.active *{
  color:#111827 !important;
  stroke:#111827 !important;
}

/* PMPA 2026 header composition: segmented top bar + white source bar */
:root,
html[data-theme="light"],
html[data-theme="dark"]{
  --pm-topbar:#244E9C !important;
  --topbar-bg:#244E9C !important;
  --sb-bg:#244E9C !important;
}

.sidebar,
html[data-theme="dark"] .sidebar{
  background:#244E9C !important;
  background-image:none !important;
}

.topbar,
html[data-theme="dark"] .topbar,
.censo-integrated .topbar,
.source-panel > .topbar{
  background:#244E9C !important;
  background-image:linear-gradient(
    90deg,
    #244E9C 0 34%,
    #38BEEF 34% 56%,
    #FCCF00 56% 67%,
    #E9561E 67% 78%,
    #47AB34 78% 89%,
    #005E34 89% 100%
  ) !important;
  border-bottom:0 !important;
}

.source-switcher,
.tabs-bar,
.tabs,
.nav-tabs,
.source-panel > .tabs-bar,
#panel-ibge > .tabs-bar,
#panel-tse > .tabs-bar,
#panel-caged > .tabs-bar,
#panel-incra > .tabs-bar,
#panel-saude .tabs-bar,
.education-integrated-root .tabs-bar,
.health-integrated-root .tabs-bar{
  background:#FFFFFF !important;
  background-image:none !important;
  border-bottom:1px solid rgba(36,78,156,.14) !important;
  box-shadow:0 8px 18px rgba(36,78,156,.12) !important;
  position:relative;
  z-index:20;
}

.source-switcher{
  align-items:flex-end;
  padding-top:10px !important;
}

html:not(.map-only) .source-switcher,
html:not(.map-only) .tabs-bar,
html:not(.map-only) .tabs,
html:not(.map-only) .nav-tabs,
html:not(.map-only) .source-panel > .tabs-bar,
html:not(.map-only) #panel-ibge > .tabs-bar,
html:not(.map-only) #panel-tse > .tabs-bar,
html:not(.map-only) #panel-caged > .tabs-bar,
html:not(.map-only) #panel-incra > .tabs-bar,
html:not(.map-only) #panel-saude .tabs-bar,
html:not(.map-only) .education-integrated-root .tabs-bar,
html:not(.map-only) .health-integrated-root .tabs-bar{
  box-shadow:0 8px 18px rgba(36,78,156,.12) !important;
}

.source-switcher .source-btn,
.tabs-bar .tab,
.tabs-bar button,
.nav-tabs .tab{
  background:#FFFFFF !important;
  background-image:none !important;
  border:1px solid rgba(36,78,156,.14) !important;
  color:#244E9C !important;
}

/* Abas estilo Atlas: ativo = fundo claro + contorno azul (não preenchimento sólido) */
.source-switcher .source-btn.active,
.tabs-bar .tab.active,
.tabs-bar button.active,
.nav-tabs .tab.active{
  background:#EEF4FB !important;
  border:1px solid #244E9C !important;
  border-bottom:none !important;
  color:#244E9C !important;
  font-weight:700 !important;
}

/* TSE dark: barra superior preta */
html[data-theme="dark"] #panel-tse > .tabs-bar{
  background:#000000 !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
  box-shadow:none !important;
}
html[data-theme="dark"] #panel-tse > .tabs-bar .tab,
html[data-theme="dark"] #panel-tse > .tabs-bar button{
  background:#0a0a0a !important;
  color:#e5e7eb !important;
  border:1px solid rgba(255,255,255,.16) !important;
}
html[data-theme="dark"] #panel-tse > .tabs-bar .tab.active,
html[data-theme="dark"] #panel-tse > .tabs-bar button.active{
  background:#141414 !important;
  color:#ffffff !important;
  border:1px solid rgba(255,255,255,.28) !important;
}

.source-switcher .source-btn.active *,
.tabs-bar .tab.active *,
.tabs-bar button.active *,
.nav-tabs .tab.active *{
  color:#244E9C !important;
  stroke:#244E9C !important;
}

html[data-theme="dark"] .source-switcher .source-btn.active,
html[data-theme="dark"] .tabs-bar .tab.active,
html[data-theme="dark"] .tabs-bar button.active,
html[data-theme="dark"] .nav-tabs .tab.active{
  background:#ffffff !important;
  border:1px solid rgba(255,255,255,.35) !important;
  border-bottom:none !important;
  color:#0a0a0a !important;
}

html[data-theme="dark"] .source-switcher .source-btn.active *,
html[data-theme="dark"] .tabs-bar .tab.active *,
html[data-theme="dark"] .tabs-bar button.active *,
html[data-theme="dark"] .nav-tabs .tab.active *{
  color:#0a0a0a !important;
  stroke:#0a0a0a !important;
}

/* Force visible segmented PMPA topbar even when runtime styles repaint .topbar */
.topbar,
html[data-theme="light"] .topbar,
html[data-theme="dark"] .topbar{
  position:relative !important;
  isolation:isolate !important;
  overflow:hidden !important;
  background:#244E9C !important;
}

.topbar::before,
html[data-theme="light"] .topbar::before,
html[data-theme="dark"] .topbar::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:0 !important;
  pointer-events:none !important;
  background:linear-gradient(
    90deg,
    #244E9C 0%,
    #244E9C 34%,
    #38BEEF 34%,
    #38BEEF 56%,
    #FCCF00 56%,
    #FCCF00 67%,
    #E9561E 67%,
    #E9561E 78%,
    #47AB34 78%,
    #47AB34 89%,
    #005E34 89%,
    #005E34 100%
  ) !important;
}

.topbar > *,
html[data-theme="light"] .topbar > *,
html[data-theme="dark"] .topbar > *{
  position:relative !important;
  z-index:1 !important;
}

/* PMPA 2026 final polish requested: compact controls and cleaner map header */
.topbar-left .crumb,
html[data-theme="light"] .topbar-left .crumb,
html[data-theme="dark"] .topbar-left .crumb{
  color:#FFFFFF !important;
  font-weight:800 !important;
}

.topbar-left .crumb-sub,
html[data-theme="light"] .topbar-left .crumb-sub,
html[data-theme="dark"] .topbar-left .crumb-sub{
  color:rgba(255,255,255,.82) !important;
}

.searchbox,
html[data-theme="light"] .searchbox,
html[data-theme="dark"] .searchbox{
  height:38px !important;
  border-radius:999px !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:#FFFFFF !important;
  padding:0 16px !important;
}

.searchbox input,
.searchbox input:focus,
html[data-theme="light"] .searchbox input,
html[data-theme="dark"] .searchbox input{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  color:#244E9C !important;
  appearance:none !important;
  -webkit-appearance:none !important;
}

.searchbox .icon,
.searchbox svg,
.searchbox svg *{
  color:#244E9C !important;
  stroke:#244E9C !important;
}

.searchbox input::placeholder{
  color:rgba(36,78,156,.68) !important;
  text-shadow:none !important;
  -webkit-text-stroke:0 !important;
}

.source-switcher,
html:not(.map-only) .source-switcher{
  min-height:52px !important;
  height:52px !important;
  padding:0 20px !important;
  align-items:flex-end !important;
  box-shadow:0 6px 14px rgba(36,78,156,.10) !important;
}

.source-switcher .source-btn{
  height:46px !important;
  min-height:46px !important;
  padding:0 16px !important;
  margin-top:0 !important;
  border-radius:10px 10px 0 0 !important;
}

.sidebar.collapsed .nav-item,
html[data-theme="light"] .sidebar.collapsed .nav-item,
html[data-theme="dark"] .sidebar.collapsed .nav-item{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  min-height:46px !important;
  border-radius:999px !important;
  padding:0 !important;
  margin:0 auto !important;
  background:#FFFFFF !important;
  border:0 !important;
  box-shadow:none !important;
}

.sidebar.collapsed .nav-icon,
html[data-theme="light"] .sidebar.collapsed .nav-icon,
html[data-theme="dark"] .sidebar.collapsed .nav-icon{
  width:46px !important;
  height:46px !important;
  flex:0 0 46px !important;
  border-radius:999px !important;
  background:#FFFFFF !important;
  border:0 !important;
  box-shadow:none !important;
}

.sidebar.collapsed .nav-icon .icon,
.sidebar.collapsed .nav-icon svg,
.sidebar.collapsed .nav-icon svg *,
html[data-theme="light"] .sidebar.collapsed .nav-icon .icon,
html[data-theme="dark"] .sidebar.collapsed .nav-icon .icon{
  color:#244E9C !important;
  stroke:#244E9C !important;
}

.sidebar.collapsed .sb-bottom .icon-btn,
.sb-bottom #btnTheme,
.sb-bottom #btnSettings{
  width:34px !important;
  height:34px !important;
  min-width:34px !important;
  min-height:34px !important;
  border-radius:999px !important;
  padding:0 !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
}

.sidebar.collapsed .sb-bottom .icon-btn .icon,
.sb-bottom #btnTheme .icon,
.sb-bottom #btnSettings .icon{
  width:17px !important;
  height:17px !important;
  color:#244E9C !important;
}

.sidebar.collapsed .sb-actions{
  gap:8px !important;
}

.sidebar .nav-icon,
.sidebar .nav-icon .icon,
.sidebar .icon-btn,
.sidebar .icon-btn .icon{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}

.sidebar .nav-icon .icon svg,
.sidebar .icon-btn .icon svg{
  display:block !important;
  margin:0 !important;
}

.sidebar:not(.collapsed) .sb-search,
html[data-theme="light"] .sidebar:not(.collapsed) .sb-search,
html[data-theme="dark"] .sidebar:not(.collapsed) .sb-search{
  height:44px !important;
  border-radius:12px !important;
  background:#FFFFFF !important;
  border:0 !important;
  box-shadow:none !important;
}

.sidebar:not(.collapsed) .sb-search input,
.sidebar:not(.collapsed) .sb-search input::placeholder,
.sidebar:not(.collapsed) .sb-search .icon{
  color:#244E9C !important;
  opacity:1 !important;
}

.sidebar:not(.collapsed) .sb-search input::placeholder{
  color:rgba(36,78,156,.62) !important;
}

.sidebar:not(.collapsed) .nav-item,
html[data-theme="light"] .sidebar:not(.collapsed) .nav-item,
html[data-theme="dark"] .sidebar:not(.collapsed) .nav-item{
  min-height:58px !important;
  height:58px !important;
  border-radius:999px !important;
  padding:0 18px 0 8px !important;
  background:#FFFFFF !important;
  border:0 !important;
  box-shadow:none !important;
  color:#244E9C !important;
}

.sidebar:not(.collapsed) .nav-item.active,
html[data-theme="light"] .sidebar:not(.collapsed) .nav-item.active,
html[data-theme="dark"] .sidebar:not(.collapsed) .nav-item.active{
  background:#FFFFFF !important;
  border:0 !important;
  color:#244E9C !important;
}

.sidebar:not(.collapsed) .nav-icon,
html[data-theme="light"] .sidebar:not(.collapsed) .nav-icon,
html[data-theme="dark"] .sidebar:not(.collapsed) .nav-icon{
  width:34px !important;
  height:34px !important;
  flex:0 0 34px !important;
  border-radius:999px !important;
  background:#FFFFFF !important;
  border:0 !important;
  box-shadow:none !important;
  color:#244E9C !important;
}

.sidebar:not(.collapsed) .nav-icon .icon,
.sidebar:not(.collapsed) .nav-icon svg,
.sidebar:not(.collapsed) .nav-icon svg *,
.sidebar:not(.collapsed) .nav-title,
.sidebar:not(.collapsed) .nav-sub,
.sidebar:not(.collapsed) .nav-text{
  color:#244E9C !important;
  stroke:#244E9C !important;
}

.sidebar:not(.collapsed) .nav-sub{
  opacity:.72 !important;
  display:block !important;
  margin-top:2px !important;
  font-size:11px !important;
  line-height:1.15 !important;
}

.sidebar:not(.collapsed) .nav-title{
  line-height:1.15 !important;
}

.sidebar:not(.collapsed) .nav-text{
  display:flex !important;
  min-width:0 !important;
  flex-direction:column !important;
  justify-content:center !important;
}

.sidebar:not(.collapsed) .brand-logo-img{
  display:block !important;
  width:178px !important;
  max-width:178px !important;
  height:auto !important;
  object-fit:contain !important;
}

.sidebar:not(.collapsed) .sb-top{
  gap:14px !important;
}

/* PMPA logo lockup in the topbar title area */
.topbar-left,
html[data-theme="light"] .topbar-left,
html[data-theme="dark"] .topbar-left{
  display:grid !important;
  grid-template-columns:104px 1px minmax(118px, auto) !important;
  grid-template-rows:auto auto !important;
  align-items:center !important;
  column-gap:6px !important;
  row-gap:0 !important;
  min-width:284px !important;
  padding-left:0 !important;
  margin-left:-8px !important;
}

.topbar-pa-logo{
  grid-column:1 !important;
  grid-row:1 / span 2 !important;
  display:block !important;
  width:96px !important;
  max-width:96px !important;
  height:auto !important;
  object-fit:contain !important;
  justify-self:start !important;
}

.topbar-title-divider{
  grid-column:2 !important;
  grid-row:1 / span 2 !important;
  display:block !important;
  width:1px !important;
  height:44px !important;
  background:rgba(255,255,255,.72) !important;
}

.topbar-left .crumb{
  grid-column:3 !important;
  grid-row:1 !important;
  align-self:center !important;
  margin-left:12px !important;
  line-height:1 !important;
  margin-bottom:0 !important;
}

.topbar-left .crumb-sub{
  grid-column:3 !important;
  grid-row:2 !important;
  align-self:start !important;
  margin-left:12px !important;
  margin-top:-3px !important;
  line-height:1 !important;
}

/* Sidebar expandida: esconde logo mini + traço; título ocupa o canto esquerdo do topbar */
.app:has(#sidebar:not(.collapsed)) .topbar-pa-logo,
.app:has(#sidebar:not(.collapsed)) .topbar-title-divider{
  display:none !important;
}

.app:has(#sidebar:not(.collapsed)) .topbar-left,
html[data-theme="light"] .app:has(#sidebar:not(.collapsed)) .topbar-left,
html[data-theme="dark"] .app:has(#sidebar:not(.collapsed)) .topbar-left{
  grid-template-columns:minmax(120px, 1fr) !important;
  min-width:0 !important;
  margin-left:0 !important;
}

.app:has(#sidebar:not(.collapsed)) .topbar-left .crumb,
html[data-theme="light"] .app:has(#sidebar:not(.collapsed)) .topbar-left .crumb,
html[data-theme="dark"] .app:has(#sidebar:not(.collapsed)) .topbar-left .crumb{
  grid-column:1 !important;
  grid-row:1 !important;
  margin-left:0 !important;
}

.app:has(#sidebar:not(.collapsed)) .topbar-left .crumb-sub,
html[data-theme="light"] .app:has(#sidebar:not(.collapsed)) .topbar-left .crumb-sub,
html[data-theme="dark"] .app:has(#sidebar:not(.collapsed)) .topbar-left .crumb-sub{
  grid-column:1 !important;
  grid-row:2 !important;
  margin-left:0 !important;
}

/* Colorful map floating controls: use the PMPA palette instead of white */
.pm-maptype-trigger,
.pm-maptype-trigger.active,
html[data-theme="dark"] .pm-maptype-trigger,
html[data-theme="dark"] .pm-maptype-trigger.active{
  background:#244E9C !important;
  border-color:#244E9C !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-streetview-trigger,
.pm-streetview-trigger.active,
html[data-theme="dark"] .pm-streetview-trigger,
html[data-theme="dark"] .pm-streetview-trigger.active{
  background:#38BEEF !important;
  border-color:#38BEEF !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-traffic-trigger,
.pm-traffic-trigger.active,
html[data-theme="dark"] .pm-traffic-trigger,
html[data-theme="dark"] .pm-traffic-trigger.active{
  background:#E9561E !important;
  border-color:#E9561E !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-mode-trigger,
html[data-theme="dark"] .pm-map-mode-trigger{
  background:#005E34 !important;
  border-color:#005E34 !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-compass,
html[data-theme="dark"] .pm-map-compass{
  background:#244E9C !important;
  border-color:#244E9C !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-zoom-pill{
  background:#47AB34 !important;
  border-color:#47AB34 !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-zoom-btn{
  background:transparent !important;
  border-color:rgba(255,255,255,.34) !important;
  color:#FFFFFF !important;
}

.pm-map-zoom-btn + .pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-zoom-btn + .pm-map-zoom-btn{
  border-top-color:rgba(255,255,255,.42) !important;
}

#pmMapSearchBtn,
html[data-theme="dark"] #pmMapSearchBtn{
  background:#FCCF00 !important;
  border-color:#FCCF00 !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

#pmMapShareBtn,
html[data-theme="dark"] #pmMapShareBtn{
  background:#38BEEF !important;
  border-color:#38BEEF !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

#pmMapFullscreenBtn,
html[data-theme="dark"] #pmMapFullscreenBtn{
  background:#005E34 !important;
  border-color:#005E34 !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-distance-card,
html[data-theme="dark"] .pm-map-distance-card{
  background:#E9561E !important;
  border-color:#E9561E !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-coords-card,
html[data-theme="dark"] .pm-map-coords-card{
  background:#244E9C !important;
  border-color:#244E9C !important;
  color:#FFFFFF !important;
  box-shadow:none !important;
}

.pm-map-coords-icon{
  background:rgba(255,255,255,.20) !important;
  color:#FFFFFF !important;
}

.pm-map-distance-value,
.pm-map-coords-meta,
.pm-map-coords-values,
.pm-map-mode-label,
.pm-map-mode-trigger *,
.pm-map-distance-card *,
.pm-map-coords-card *,
.pm-maptype-trigger *,
.pm-streetview-trigger *,
.pm-traffic-trigger *,
.pm-map-compass *,
.pm-map-round-btn *,
.pm-map-zoom-btn *,
html[data-theme="dark"] .pm-map-distance-value,
html[data-theme="dark"] .pm-map-coords-meta,
html[data-theme="dark"] .pm-map-coords-values{
  color:#FFFFFF !important;
  stroke:#FFFFFF !important;
}

.pm-map-distance-line,
.pm-map-distance-tick{
  background:#FFFFFF !important;
  border-color:#FFFFFF !important;
}

.pm-maptype-trigger:hover,
.pm-streetview-trigger:hover,
.pm-traffic-trigger:hover,
.pm-map-mode-trigger:hover,
.pm-map-round-btn:hover,
.pm-map-compass:hover,
.pm-map-zoom-btn:hover{
  filter:none !important;
  transform:none !important;
  color:#244E9C !important;
  background:#FFFFFF !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
}

/* Compact PMPA map controls + palette-friendly color overrides */
.pm-maptype-trigger,
.pm-maptype-trigger.active,
.pm-streetview-trigger,
.pm-streetview-trigger.active,
.pm-traffic-trigger,
.pm-traffic-trigger.active,
.pm-map-round-btn,
.pm-map-round-btn.active,
.pm-map-compass,
html[data-theme="dark"] .pm-maptype-trigger,
html[data-theme="dark"] .pm-maptype-trigger.active,
html[data-theme="dark"] .pm-streetview-trigger,
html[data-theme="dark"] .pm-streetview-trigger.active,
html[data-theme="dark"] .pm-traffic-trigger,
html[data-theme="dark"] .pm-traffic-trigger.active,
html[data-theme="dark"] .pm-map-round-btn,
html[data-theme="dark"] .pm-map-round-btn.active,
html[data-theme="dark"] .pm-map-compass {
  width:40px !important;
  min-width:40px !important;
  height:40px !important;
  padding:0 !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-zoom-btn {
  width:38px !important;
  height:38px !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
}

.pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-zoom-pill {
  border-radius:999px !important;
  min-width:72px !important;
  padding:4px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
}

.pm-map-mode-trigger,
html[data-theme="dark"] .pm-map-mode-trigger {
  min-width:180px !important;
  height:40px !important;
  padding:0 12px !important;
  gap:8px !important;
  font-size:12px !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
}

#pmMapSearchBtn,
#pmMapShareBtn,
#pmMapFullscreenBtn,
html[data-theme="dark"] #pmMapSearchBtn,
html[data-theme="dark"] #pmMapShareBtn,
html[data-theme="dark"] #pmMapFullscreenBtn {
  width:40px !important;
  min-width:40px !important;
  height:40px !important;
  padding:0 !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.pm-map-distance-card,
.pm-map-coords-card,
html[data-theme="dark"] .pm-map-distance-card,
html[data-theme="dark"] .pm-map-coords-card {
  min-height:42px !important;
  padding:8px 10px !important;
}

.map-toolbar-row {
  gap:8px !important;
  padding:8px 2px 12px !important;
}

.map-tb-btn {
  gap:8px !important;
  padding:8px 14px !important;
  font-size:12px !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.map-tb-btn:hover {
  transform:none !important;
  box-shadow:none !important;
  background:#FFFFFF !important;
}

.map-tb-btn.active {
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.sat-toggle-btn,
html[data-theme="dark"] .sat-toggle-btn,
#pmMapSearchBtn,
#pmMapShareBtn,
#pmMapFullscreenBtn,
html[data-theme="dark"] #pmMapSearchBtn,
html[data-theme="dark"] #pmMapShareBtn,
html[data-theme="dark"] #pmMapFullscreenBtn {
  padding:7px !important;
  font-size:12px !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.map-toolbar-right .sat-toggle-btn {
  background:#FFFFFF !important;
  color:#244E9C !important;
}

.map-toolbar-right .sat-toggle-btn:hover,
#pmMapSearchBtn:hover,
#pmMapShareBtn:hover,
#pmMapFullscreenBtn:hover {
  background:#FFFFFF !important;
}

.map-toolbar-right .sat-toggle-btn.active,
#pmMapSearchBtn.active,
#pmMapShareBtn.active,
#pmMapFullscreenBtn.active {
  background:#FFFFFF !important;
  color:#244E9C !important;
}

.map-fullscreen-btn {
  padding:7px 12px !important;
  font-size:12px !important;
  border-radius:999px !important;
  border:1px solid transparent !important;
  border-top-color:#244E9C !important;
  border-left-color:#244E9C !important;
  border-bottom-color:#38BEEF !important;
  border-right-color:#38BEEF !important;
  background:#FFFFFF !important;
  color:#244E9C !important;
  box-shadow:none !important;
}

.map-fullscreen-btn:hover {
  background:#FFFFFF !important;
}

/* ═══════════════════════════════════════════════════════════════
   PMPA 2026 – Botões do mapa: ícones visíveis + bordas diagonais
   Borda: 3px transparent + gradient diagonal 50%/50% de 2 cores
   Anel branco: box-shadow 0 0 0 3px #FFF fora da borda
   ─────────────────────────────────────────────────────────────
   Combos diagonais (135deg = linha diagonal ↘):
     Bússola      → #244E9C ↘ #E9561E  (azul → laranja)
     Zoom         → #47AB34 ↘ #38BEEF  (verde → ciano)
     Pesquisa     → #FCCF00 ↘ #E9561E  (amarelo → laranja)
     Compartilhar → #38BEEF ↘ #244E9C  (ciano → azul)
     Tela cheia   → #E9561E ↘ #244E9C  (laranja → azul)
     Street View  → #E9561E ↘ #FCCF00  (laranja → amarelo)
     Tráfego      → #47AB34 ↘ #244E9C  (verde → azul)
     Tipo de mapa → #FCCF00 ↘ #47AB34  (amarelo → verde)
     Modo painel  → #244E9C ↘ #38BEEF  (azul → ciano)
   ═══════════════════════════════════════════════════════════════ */

/* ── Mixin: borda diagonal helper ────────────────────────────────
   Técnica: border:3px transparent + background com dois layers
   Layer 1 (topo): branco só dentro do padding-box → fundo branco
   Layer 2 (baixo): gradiente diagonal cobrindo border-box → borda
   box-shadow: 0 0 0 3px #FFF cria o anel branco externo
   ─────────────────────────────────────────────────────────────── */

/* ── Ícones visíveis: corrige stroke:#FFF em fundo branco ────── */
.pm-map-corner-right .pm-map-compass .pm-map-compass-arrow {
  color: #E9561E !important;
  stroke: #E9561E !important;
}
.pm-map-corner-right .pm-map-compass .pm-map-compass-n {
  color: #FFFFFF !important;
}
.pm-map-corner-right .pm-map-compass .pm-map-compass-disc {
  background: #244E9C !important;
}

#pmMapZoomIn *,
#pmMapZoomOut * {
  color: #47AB34 !important;
  stroke: #47AB34 !important;
}
#pmMapSearchBtn * {
  color: #E9561E !important;
  stroke: #E9561E !important;
}
#pmMapShareBtn * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
#pmMapFullscreenBtn * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
#pmStreetViewTrigger * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
#pmTrafficFlowTrigger * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
#pmMapTypeTrigger * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
#pmMapModeTrigger * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}

/* ── Bússola: #244E9C ↘ #E9561E (azul → laranja) ─────────────── */
.pm-map-corner-right .pm-map-compass,
html[data-theme="dark"] .pm-map-corner-right .pm-map-compass {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #E9561E 50%) border-box !important;
  box-shadow: none !important;
}
.pm-map-corner-right .pm-map-compass:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #E9561E 50%) border-box !important;
  box-shadow: none !important;
}

/* ── Zoom pill: #47AB34 ↘ #38BEEF (verde → ciano) ────────────── */
.pm-map-corner-right .pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-corner-right .pm-map-zoom-pill {
  min-width: 40px !important;
  width: 40px !important;
  padding: 2px !important;
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #47AB34 50%, #38BEEF 50%) border-box !important;
  box-shadow: none !important;
}
.pm-map-corner-right .pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-corner-right .pm-map-zoom-btn {
  width: 100% !important;
  min-width: unset !important;
  height: 38px !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #47AB34 !important;
}
.pm-map-corner-right .pm-map-zoom-btn + .pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-corner-right .pm-map-zoom-btn + .pm-map-zoom-btn {
  border-top: 1px solid rgba(71,171,52,.25) !important;
}
.pm-map-corner-right .pm-map-zoom-btn:hover,
html[data-theme="dark"] .pm-map-corner-right .pm-map-zoom-btn:hover {
  background: rgba(71,171,52,.07) !important;
  border-color: transparent !important;
}

/* ── Pesquisa: #FCCF00 ↘ #E9561E (amarelo → laranja) ─────────── */
#pmMapSearchBtn,
html[data-theme="dark"] #pmMapSearchBtn {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #FCCF00 50%, #E9561E 50%) border-box !important;
  box-shadow: none !important;
  color: #E9561E !important;
}
#pmMapSearchBtn:hover,
html[data-theme="dark"] #pmMapSearchBtn:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #FCCF00 50%, #E9561E 50%) border-box !important;
  box-shadow: none !important;
}

/* ── Compartilhar: #38BEEF ↘ #244E9C (ciano → azul) ─────────── */
#pmMapShareBtn,
html[data-theme="dark"] #pmMapShareBtn {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #38BEEF 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
#pmMapShareBtn:hover,
html[data-theme="dark"] #pmMapShareBtn:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #38BEEF 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
}

/* ── Tela cheia: #E9561E ↘ #244E9C (laranja → azul) ─────────── */
#pmMapFullscreenBtn,
html[data-theme="dark"] #pmMapFullscreenBtn {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #E9561E 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
#pmMapFullscreenBtn:hover,
html[data-theme="dark"] #pmMapFullscreenBtn:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #E9561E 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
}

/* ── Street View: #E9561E ↘ #FCCF00 (laranja → amarelo) ─────── */
#pmStreetViewTrigger,
html[data-theme="dark"] #pmStreetViewTrigger {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #E9561E 50%, #FCCF00 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
#pmStreetViewTrigger:hover,
html[data-theme="dark"] #pmStreetViewTrigger:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #E9561E 50%, #FCCF00 50%) border-box !important;
  box-shadow: none !important;
}
#pmStreetViewTrigger.active,
html[data-theme="dark"] #pmStreetViewTrigger.active {
  background:
    linear-gradient(#E9561E, #E9561E) padding-box,
    linear-gradient(135deg, #E9561E 50%, #FCCF00 50%) border-box !important;
  box-shadow: none !important;
}
#pmStreetViewTrigger.active * {
  color: #FFFFFF !important;
  stroke: #FFFFFF !important;
}

/* ── Tráfego: #47AB34 ↘ #244E9C (verde → azul) ──────────────── */
#pmTrafficFlowTrigger,
html[data-theme="dark"] #pmTrafficFlowTrigger {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #47AB34 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
#pmTrafficFlowTrigger:hover,
html[data-theme="dark"] #pmTrafficFlowTrigger:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #47AB34 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
}
#pmTrafficFlowTrigger.active,
html[data-theme="dark"] #pmTrafficFlowTrigger.active {
  background:
    linear-gradient(#47AB34, #47AB34) padding-box,
    linear-gradient(135deg, #47AB34 50%, #244E9C 50%) border-box !important;
  box-shadow: none !important;
}
#pmTrafficFlowTrigger.active * {
  color: #FFFFFF !important;
  stroke: #FFFFFF !important;
}

/* ── Tipo de mapa: #FCCF00 ↘ #47AB34 (amarelo → verde) ───────── */
#pmMapTypeTrigger,
html[data-theme="dark"] #pmMapTypeTrigger {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #FCCF00 50%, #47AB34 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
#pmMapTypeTrigger:hover,
html[data-theme="dark"] #pmMapTypeTrigger:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #FCCF00 50%, #47AB34 50%) border-box !important;
  box-shadow: none !important;
}

/* ── Modo painel: #244E9C ↘ #38BEEF (azul → ciano) ──────────── */
#pmMapModeTrigger,
html[data-theme="dark"] #pmMapModeTrigger {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #38BEEF 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
  min-width: 160px !important;
  font-weight: 700 !important;
}
#pmMapModeTrigger:hover,
html[data-theme="dark"] #pmMapModeTrigger:hover {
  border-color: transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #38BEEF 50%) border-box !important;
  box-shadow: none !important;
}

/* ── Barras inferiores: mesmo padrão de borda diagonal ─────────
   Active bar  → #244E9C ↘ #38BEEF  (azul → ciano)
   Distância   → #E9561E ↘ #FCCF00  (laranja → amarelo)
   Coordenadas → #244E9C ↘ #47AB34  (azul → verde)
   ─────────────────────────────────────────────────────────────── */

/* Camadas ativas bar */
.pm-active-bar {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #38BEEF 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
.pm-active-bar * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
html[data-theme="dark"] .pm-active-bar {
  border: 1px solid rgba(255,255,255,.14) !important;
  background: #161616 !important;
  background-image: none !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.45) !important;
  color: #f0f0f0 !important;
}
html[data-theme="dark"] .pm-active-bar * {
  color: #ececec !important;
  stroke: #ececec !important;
}
.pm-active-bar .pm-active-clear,
html[data-theme="dark"] .pm-active-bar .pm-active-clear {
  border: none !important;
  background: rgba(36,78,156,.08) !important;
  box-shadow: none !important;
}
html[data-theme="dark"] .pm-active-bar .pm-active-clear {
  background: rgba(255,255,255,.1) !important;
}

/* Distância (escala) */
#pmMapDistanceCard,
html[data-theme="dark"] #pmMapDistanceCard {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #E9561E 50%, #FCCF00 50%) border-box !important;
  box-shadow: none !important;
  color: #E9561E !important;
}
#pmMapDistanceCard *,
html[data-theme="dark"] #pmMapDistanceCard * {
  color: #E9561E !important;
  stroke: #E9561E !important;
  background-color: transparent !important;
}
#pmMapDistanceCard .pm-map-distance-line,
html[data-theme="dark"] #pmMapDistanceCard .pm-map-distance-line {
  background: #E9561E !important;
}
#pmMapDistanceCard .pm-map-distance-tick,
html[data-theme="dark"] #pmMapDistanceCard .pm-map-distance-tick {
  background: #E9561E !important;
}

/* Coordenadas */
#pmMapCoordsCard,
html[data-theme="dark"] #pmMapCoordsCard {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #47AB34 50%) border-box !important;
  box-shadow: none !important;
  color: #244E9C !important;
}
#pmMapCoordsCard *,
html[data-theme="dark"] #pmMapCoordsCard * {
  color: #244E9C !important;
  stroke: #244E9C !important;
}
#pmMapCoordsCard .pm-map-coords-icon,
html[data-theme="dark"] #pmMapCoordsCard .pm-map-coords-icon {
  background: rgba(36,78,156,.10) !important;
  color: #244E9C !important;
}

/* === Ajustes finais: barra ativa + dropdown modo do mapa === */
/* Mesma borda/contorno diagonal dos botoes do mapa (apenas modo claro) */
.pm-map-corner-bottom .pm-active-bar {
  border: 3px solid transparent !important;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(135deg, #244E9C 50%, #38BEEF 50%) border-box !important;
  box-shadow: none !important;
}
html[data-theme="dark"] .pm-map-corner-bottom .pm-active-bar {
  border: 1px solid rgba(255,255,255,.14) !important;
  background: #161616 !important;
  background-image: none !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.45) !important;
}

/* Mantem os botoes fixos e impede deslocamento ao abrir o dropdown */
.pm-map-corner-top-right {
  align-items: flex-start !important;
}
.pm-map-mode-wrap {
  position: relative !important;
  flex: 0 0 auto !important;
}
.pm-maptop-right {
  flex: 0 0 auto !important;
}

/* Dropdown de "Dados municipais" abrindo para a esquerda */
.pm-map-mode-popover {
  position: absolute !important;
  top: calc(100% + 10px) !important;
  right: 0 !important;
  left: auto !important;
  width: 360px !important;
  max-width: min(360px, calc(100vw - 24px)) !important;
  transform-origin: top right !important;
  z-index: 60 !important;
}

/* Corrige quebra de texto para tudo ficar dentro do card */
.pm-map-mode-option {
  min-width: 0 !important;
  align-items: flex-start !important;
}
.pm-map-mode-option-title,
.pm-map-mode-option-sub {
  display: block !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
.pm-map-mode-option-sub {
  line-height: 1.45 !important;
}

/* === Hotfix final: sidebar sem vazamento + abas coloridas === */

/* 1) Conter qualquer elemento dentro da sidebar */
.pm-map-sidebar,
.pm-map-sidebar * {
  box-sizing: border-box;
}
.pm-map-sidebar {
  overflow: hidden !important;
}
.pm-sb-panel {
  overflow-x: hidden !important;
  min-width: 0 !important;
}
.pm-sb-panel > * {
  min-width: 0 !important;
  max-width: 100% !important;
}

/* 2) Cards e linhas do painel sempre dentro da largura */
.pm-layers-card,
.pm-layers-card-head,
.pm-layers-card-body,
.pm-layers-list,
.pm-layers-list .map-layer-row,
.pm-radius-control,
.pm-action-hero,
.pm-action-list-wrap,
.pm-action-report-wrap,
.pm-report-builder-wrap,
.pm-report-section-card,
.pm-report-option-card,
.pm-report-library-item,
.pm-report-selected-item,
.pm-action-cat-item {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

/* Painel lateral: cartões claros só no tema claro (no escuro o dark-monochrome / regras dark aplicam) */
html[data-theme="light"] .pm-radius-control,
html[data-theme="light"] .pm-action-hero,
html[data-theme="light"] .pm-action-list-wrap,
html[data-theme="light"] .pm-action-report-wrap,
html[data-theme="light"] .pm-report-builder-wrap,
html[data-theme="light"] .pm-report-section-card,
html[data-theme="light"] .pm-report-option-card,
html[data-theme="light"] .pm-report-library-item,
html[data-theme="light"] .pm-report-selected-item,
html[data-theme="light"] .pm-action-cat-item {
  background: #FFFFFF !important;
  color: #244E9C !important;
}

/* 3) Texto sem estourar para fora */
.pm-action-cat-label,
.pm-report-selected-copy strong,
.pm-report-selected-copy span {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
/* Os cards principais (.pm-report-option-card) seguem o layout vertical
   definido acima: ícone + tag, copy e CTA largo. */

/* 4) Abas laterais ativas com cores diferentes (paleta da barra superior) */
.pm-sb-tab.active[data-pmtab="categorias"] {
  background: #47AB34 !important; /* Camadas */
  color: #FFFFFF !important;
  border-bottom-color: #47AB34 !important;
}
.pm-sb-tab.active[data-pmtab="indicadores"] {
  background: #38BEEF !important; /* Indicadores */
  color: #FFFFFF !important;
  border-bottom-color: #38BEEF !important;
}
.pm-sb-tab.active[data-pmtab="raio"] {
  background: #FCCF00 !important; /* Zona de Influencia */
  color: #244E9C !important;
  border-bottom-color: #FCCF00 !important;
}
.pm-sb-tab.active[data-pmtab="acao"] {
  background: #E9561E !important; /* Acao */
  color: #FFFFFF !important;
  border-bottom-color: #E9561E !important;
}
.pm-sb-tab.active[data-pmtab="relatorios"] {
  background: #005E34 !important; /* Relatorios */
  color: #FFFFFF !important;
  border-bottom-color: #005E34 !important;
}
.pm-sb-tab.active svg {
  opacity: 1 !important;
  stroke: currentColor !important;
}

/* 5) Barra de camadas ativas: X nao pode ficar todo azul */
.pm-active-bar .pm-active-clear,
.pm-active-bar .pm-active-chip-x,
html[data-theme="dark"] .pm-active-bar .pm-active-clear,
html[data-theme="dark"] .pm-active-bar .pm-active-chip-x {
  background: #FFFFFF !important;
  color: #244E9C !important;
  border: 1px solid rgba(36,78,156,.22) !important;
}
.pm-active-bar .pm-active-clear:hover,
.pm-active-bar .pm-active-chip-x:hover {
  background: #F4F7FF !important;
}

/* 6) Remove o botao/contador "0" da barra de camadas ativas */
.pm-active-bar-count {
  display: none !important;
}

/* === Ajustes finais v2: cards azuis residuais + cortes na lista === */

/* Remove botão antigo de notificações (legado) */
#btnNotif {
  display: none !important;
}

/* Remove contador legado e qualquer botão legado no header do card de camadas */
.pm-layers-card-head .pm-layer-count,
.pm-layers-card-head .card-toggle,
.pm-layers-card-head > button {
  display: none !important;
}

/* Corrige cortes dos cards de camadas (Bairros População Total/Faixa Etária) */
#pmtab-categorias .pm-layers-card-body {
  padding: 8px 10px 10px !important;
  overflow-x: hidden !important;
}
#pmtab-categorias #mapLayersList.pm-layers-list {
  gap: 10px !important;
  padding: 0 !important;
}
#pmtab-categorias #mapLayersList .map-layer-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 14px 14px !important;
  border-radius: 18px !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
}
#pmtab-categorias #mapLayersList .mlr-left,
#pmtab-categorias #mapLayersList .mlr-text {
  min-width: 0 !important;
}
#pmtab-categorias #mapLayersList .mlr-action {
  justify-self: end !important;
  margin-left: 6px !important;
}
#pmtab-categorias #mapLayersList .map-toggle.map-toggle-iconic,
#pmtab-categorias #mapLayersList .map-toggle.map-toggle-iconic .map-toggle-track {
  width: 44px !important;
  height: 44px !important;
}

/* Remove blocos totalmente azuis em cards dos painéis laterais */
#pmtab-raio .pm-radius-status,
#pmtab-acao .pm-action-status,
#pmtab-indicadores .map-info-empty {
  background: #F7FAFF !important;
  color: #244E9C !important;
  border: 1px solid rgba(36,78,156,.16) !important;
  box-shadow: none !important;
}

/* Aba Indicadores: painel e cards USF/eleitoral ocupam toda a largura útil (sem faixa vazia) */
#pmtab-indicadores.pm-sb-panel{
  align-items:stretch !important;
}
#pmtab-indicadores.pm-sb-panel > #mapInfoPanel{
  width:100% !important;
  max-width:100% !important;
  align-self:stretch !important;
  box-sizing:border-box !important;
}
#pmtab-indicadores #mapInfoPanel .map-info-detail,
#pmtab-indicadores #mapInfoPanel .map-info-detail-health,
#pmtab-indicadores #mapInfoPanel .mid-feature-layout-health-premium{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
}
#pmtab-indicadores #mapInfoPanel .usf-health-kpis-premium,
#pmtab-indicadores #mapInfoPanel .usf-health-insight-grid,
#pmtab-indicadores #mapInfoPanel .usf-health-insight-grid-premium,
#pmtab-indicadores #mapInfoPanel .usf-health-box-premium,
#pmtab-indicadores #mapInfoPanel .usf-health-highlight-list{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
}
#pmtab-indicadores #mapInfoPanel .usf-health-insight-grid-premium{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}
#pmtab-indicadores #mapInfoPanel .usf-health-insight-grid-premium > .usf-health-box-full{
  grid-column:1 / -1 !important;
}

/* Mantém CTA de relatórios legível no estilo claro */
#pmtab-relatorios .pm-report-option-cta {
  min-width: 0 !important;
  width: 100% !important;
}

/* === Ajustes finais v3: relatorios + demografico + faixas etarias + abas === */

/* Card azul restante em Relatorios */
#pmtab-relatorios .pm-action-status {
  background: #F7FAFF !important;
  color: #244E9C !important;
  border: 1px solid rgba(36,78,156,.16) !important;
  box-shadow: none !important;
}
#pmtab-relatorios .pm-action-status * {
  color: #244E9C !important;
}

/* Faixas etarias nao podem ficar em bloco azul */
.pm-radius-age-summary-icon {
  background: #EDF4FF !important;
  color: #244E9C !important;
  border-color: rgba(36,78,156,.20) !important;
}
.pm-radius-age-item {
  background: #F7FAFF !important;
  color: #244E9C !important;
  border: 1px solid rgba(36,78,156,.14) !important;
}
.pm-radius-age-item strong,
.pm-radius-age-item span {
  color: #244E9C !important;
}

/* Corrige corte de titulos dos cards demograficos */
#pmtab-categorias #mapLayersList .map-layer-row {
  overflow: visible !important;
  padding-right: 10px !important;
}
#pmtab-categorias #mapLayersList .mlr-title {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  line-height: 1.2 !important;
  padding-right: 6px !important;
}
#pmtab-categorias #mapLayersList .mlr-sub {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
}
#pmtab-categorias #mapLayersList .mlr-action {
  align-self: center !important;
}

/* Abas mais modernas, minimalistas e com cantos arredondados */
.pm-sb-tabs {
  display: flex !important;
  align-items: stretch !important;
  gap: 6px !important;
  padding: 6px !important;
  background: #F8FAFD !important;
  border-bottom: 1px solid rgba(36,78,156,.12) !important;
  box-shadow: none !important;
}
.pm-sb-tab {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  border: 1px solid rgba(36,78,156,.14) !important;
  border-radius: 12px !important;
  min-height: 64px !important;
  padding: 10px 6px 9px !important;
  background: #FFFFFF !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  letter-spacing: .03em !important;
  transition: transform .14s ease, border-color .18s ease, background .18s ease, color .18s ease !important;
}
.pm-sb-tab:hover {
  transform: translateY(-1px);
  background: #FFFFFF !important;
  border-color: rgba(36,78,156,.26) !important;
}
.pm-sb-tab.active {
  border-color: transparent !important;
  box-shadow: 0 8px 18px rgba(36,78,156,.12) !important;
}

/* Categorias com icones SVG e fundo branco */
#pmtab-categorias .map-cat-item {
  background: #FFFFFF !important;
}
#pmtab-categorias .map-cat-item .pm-cat-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #244E9C;
  flex: 0 0 auto;
}
#pmtab-categorias .map-cat-item .pm-cat-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Corrige corte dos cards especiais de bairros */
#pmtab-categorias #mapLayersList .map-layer-special {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
}
#pmtab-categorias #mapLayersList .map-layer-special > div:first-child {
  min-width: 0 !important;
}
#pmtab-categorias #mapLayersList .map-layer-special > div:first-child > div {
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  white-space: normal !important;
}
#pmtab-categorias #mapLayersList .mlr-state {
  display: none !important;
}

/* Indicadores: remove bloco azul residual */
#pmtab-indicadores .pm-action-status,
#pmtab-indicadores .pm-action-objective,
#pmtab-indicadores .map-info-empty {
  background: #FFFFFF !important;
  color: #244E9C !important;
  border: 1px solid rgba(36,78,156,.14) !important;
  box-shadow: none !important;
}
#pmtab-indicadores .pm-action-progress-track,
#pmtab-indicadores .pm-action-age-track {
  background: #EAF1FF !important;
  border: 1px solid rgba(36,78,156,.18) !important;
}
#pmtab-indicadores .pm-action-progress-track i,
#pmtab-indicadores .pm-action-age-track i {
  background: #244E9C !important;
}

/* === Mapa — contorno único #1253a8 (substitui gradientes / multi-cor nos flutuantes) === */
.pm-map-area .pm-maptype-trigger,
.pm-map-area .pm-maptype-trigger.active,
html[data-theme="dark"] .pm-map-area .pm-maptype-trigger,
html[data-theme="dark"] .pm-map-area .pm-maptype-trigger.active,
.pm-map-area .pm-streetview-trigger,
.pm-map-area .pm-streetview-trigger.active,
html[data-theme="dark"] .pm-map-area .pm-streetview-trigger,
html[data-theme="dark"] .pm-map-area .pm-streetview-trigger.active,
.pm-map-area .pm-traffic-trigger,
.pm-map-area .pm-traffic-trigger.active,
html[data-theme="dark"] .pm-map-area .pm-traffic-trigger,
html[data-theme="dark"] .pm-map-area .pm-traffic-trigger.active,
.pm-map-area .pm-map-compass,
html[data-theme="dark"] .pm-map-area .pm-map-compass,
.pm-map-area .pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-pill,
.pm-map-area .pm-map-round-btn,
.pm-map-area #pmMapSearchBtn,
.pm-map-area #pmMapShareBtn,
.pm-map-area #pmMapFullscreenBtn,
.pm-map-area #pmStreetViewTrigger,
.pm-map-area #pmTrafficFlowTrigger,
.pm-map-area #pmMapTypeTrigger,
.pm-map-area #pmMapModeTrigger,
html[data-theme="dark"] .pm-map-area .pm-map-round-btn,
html[data-theme="dark"] .pm-map-area #pmMapSearchBtn,
html[data-theme="dark"] .pm-map-area #pmMapShareBtn,
html[data-theme="dark"] .pm-map-area #pmMapFullscreenBtn,
html[data-theme="dark"] .pm-map-area #pmStreetViewTrigger,
html[data-theme="dark"] .pm-map-area #pmTrafficFlowTrigger,
html[data-theme="dark"] .pm-map-area #pmMapTypeTrigger,
html[data-theme="dark"] .pm-map-area #pmMapModeTrigger {
  border: 1px solid #1253a8 !important;
  border-top-color: #1253a8 !important;
  border-right-color: #1253a8 !important;
  border-bottom-color: #1253a8 !important;
  border-left-color: #1253a8 !important;
  background: #ffffff !important;
  color: #1253a8 !important;
  box-shadow: 0 8px 22px rgba(18, 83, 168, 0.09) !important;
  background-image: none !important;
}

.pm-map-area .pm-map-zoom-pill,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-pill {
  padding: 0 !important;
  overflow: hidden !important;
}
.pm-map-area .pm-map-zoom-pill #pmMapZoomIn,
.pm-map-area .pm-map-zoom-pill #pmMapZoomOut,
.pm-map-area .pm-map-zoom-pill .pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-pill #pmMapZoomIn,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-pill #pmMapZoomOut,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-pill .pm-map-zoom-btn {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

.pm-map-area #pmStreetViewTrigger.active,
.pm-map-area #pmTrafficFlowTrigger.active,
html[data-theme="dark"] .pm-map-area #pmStreetViewTrigger.active,
html[data-theme="dark"] .pm-map-area #pmTrafficFlowTrigger.active {
  background: #1253a8 !important;
  border-color: #1253a8 !important;
  color: #ffffff !important;
}
.pm-map-area #pmStreetViewTrigger.active *,
.pm-map-area #pmTrafficFlowTrigger.active *,
html[data-theme="dark"] .pm-map-area #pmStreetViewTrigger.active *,
html[data-theme="dark"] .pm-map-area #pmTrafficFlowTrigger.active * {
  color: #ffffff !important;
  stroke: #ffffff !important;
  fill: currentColor !important;
}

.pm-map-area .pm-map-zoom-btn + .pm-map-zoom-btn,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-btn + .pm-map-zoom-btn {
  border-top: 1px solid rgba(18, 83, 168, 0.22) !important;
}

.pm-map-area .pm-map-compass .pm-map-compass-arrow,
.pm-map-area .pm-map-compass .pm-map-compass-disc,
html[data-theme="dark"] .pm-map-area .pm-map-compass .pm-map-compass-arrow {
  color: #1253a8 !important;
  stroke: #1253a8 !important;
  fill: #1253a8 !important;
}
.pm-map-area .pm-map-compass .pm-map-compass-disc,
html[data-theme="dark"] .pm-map-area .pm-map-compass .pm-map-compass-disc {
  background: rgba(18, 83, 168, 0.08) !important;
}

.pm-map-area .pm-map-compass .pm-map-compass-n,
html[data-theme="dark"] .pm-map-area .pm-map-compass .pm-map-compass-n {
  color: #1253a8 !important;
}

.pm-map-area #pmMapZoomIn *,
.pm-map-area #pmMapZoomOut *,
.pm-map-area .pm-maptype-trigger *,
.pm-map-area .pm-streetview-trigger *,
.pm-map-area .pm-traffic-trigger *,
.pm-map-area .pm-map-round-btn *,
.pm-map-area #pmMapSearchBtn *,
.pm-map-area #pmMapShareBtn *,
.pm-map-area #pmMapFullscreenBtn *,
.pm-map-area #pmStreetViewTrigger *,
.pm-map-area #pmTrafficFlowTrigger *,
.pm-map-area #pmMapTypeTrigger *,
.pm-map-area #pmMapModeTrigger *,
html[data-theme="dark"] .pm-map-area #pmMapZoomIn *,
html[data-theme="dark"] .pm-map-area #pmMapZoomOut *,
html[data-theme="dark"] .pm-map-area .pm-maptype-trigger *,
html[data-theme="dark"] .pm-map-area .pm-streetview-trigger *,
html[data-theme="dark"] .pm-map-area .pm-traffic-trigger *,
html[data-theme="dark"] .pm-map-area .pm-map-round-btn *,
html[data-theme="dark"] .pm-map-area #pmMapSearchBtn *,
html[data-theme="dark"] .pm-map-area #pmMapShareBtn *,
html[data-theme="dark"] .pm-map-area #pmMapFullscreenBtn *,
html[data-theme="dark"] .pm-map-area #pmStreetViewTrigger *,
html[data-theme="dark"] .pm-map-area #pmTrafficFlowTrigger *,
html[data-theme="dark"] .pm-map-area #pmMapTypeTrigger *,
html[data-theme="dark"] .pm-map-area #pmMapModeTrigger * {
  color: #1253a8 !important;
  stroke: #1253a8 !important;
}

.pm-map-area #pmMapDistanceCard,
.pm-map-area #pmMapCoordsCard,
html[data-theme="dark"] .pm-map-area #pmMapDistanceCard,
html[data-theme="dark"] .pm-map-area #pmMapCoordsCard {
  border: 1px solid #1253a8 !important;
  background: #ffffff !important;
  color: #1253a8 !important;
  background-image: none !important;
  box-shadow: 0 8px 22px rgba(18, 83, 168, 0.09) !important;
}

.pm-map-area #pmMapDistanceCard .pm-map-distance-value,
.pm-map-area #pmMapCoordsCard .pm-map-coords-meta,
.pm-map-area #pmMapCoordsCard .pm-map-coords-values,
html[data-theme="dark"] .pm-map-area #pmMapDistanceCard .pm-map-distance-value,
html[data-theme="dark"] .pm-map-area #pmMapCoordsCard .pm-map-coords-meta,
html[data-theme="dark"] .pm-map-area #pmMapCoordsCard .pm-map-coords-values {
  color: #1253a8 !important;
}

.pm-map-area #pmMapDistanceCard .pm-map-distance-line,
.pm-map-area #pmMapDistanceCard .pm-map-distance-tick,
html[data-theme="dark"] .pm-map-area #pmMapDistanceCard .pm-map-distance-line,
html[data-theme="dark"] .pm-map-area #pmMapDistanceCard .pm-map-distance-tick {
  background: #1253a8 !important;
}

.pm-map-area #pmMapCoordsCard .pm-map-coords-icon,
html[data-theme="dark"] .pm-map-area #pmMapCoordsCard .pm-map-coords-icon {
  background: rgba(18, 83, 168, 0.1) !important;
  color: #1253a8 !important;
}

.pm-map-area #pmMapCoordsCard .pm-map-coords-icon *,
html[data-theme="dark"] .pm-map-area #pmMapCoordsCard .pm-map-coords-icon * {
  color: #1253a8 !important;
  stroke: #1253a8 !important;
}

.pm-map-area .pm-active-bar,
.pm-map-area .pm-map-corner-bottom .pm-active-bar {
  flex-wrap: nowrap !important;
  align-items: center !important;
  min-height: 40px !important;
  max-height: 42px !important;
  height: 42px !important;
  border: 1px solid #1253a8 !important;
  background: #ffffff !important;
  background-image: none !important;
  color: #1253a8 !important;
  box-shadow: 0 8px 22px rgba(18, 83, 168, 0.09) !important;
}
html[data-theme="dark"] .pm-map-area .pm-active-bar,
html[data-theme="dark"] .pm-map-area .pm-map-corner-bottom .pm-active-bar {
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  background: #161616 !important;
  background-image: none !important;
  color: #f0f0f0 !important;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.45) !important;
}

.pm-map-area .pm-active-bar .pm-active-bar-label,
.pm-map-area .pm-active-bar .pm-active-empty,
.pm-map-area .pm-active-bar .pm-active-chip,
.pm-map-area .pm-active-bar .pm-active-chip-text {
  color: #1253a8 !important;
  stroke: #1253a8 !important;
}
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-bar-label,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-empty,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-chip,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-chip-text {
  color: #ececec !important;
  stroke: #ececec !important;
}

.pm-map-area .pm-active-bar .pm-active-bar-label svg {
  stroke: #1253a8 !important;
  color: #1253a8 !important;
}
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-bar-label svg {
  stroke: #ececec !important;
  color: #ececec !important;
}

.pm-map-area .pm-active-bar .pm-active-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  overflow: visible !important;
  border: 1px solid rgba(18, 83, 168, 0.22) !important;
  background: #f8fafc !important;
}
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-chip {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.18) !important;
  color: #f5f5f5 !important;
}
.pm-map-area .pm-active-bar .pm-active-clear,
.pm-map-area .pm-active-bar .pm-active-chip-x {
  border: 1px solid rgba(18, 83, 168, 0.28) !important;
  background: #ffffff !important;
  color: #1253a8 !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  padding: 0 !important;
  flex-shrink: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  box-sizing: border-box !important;
}
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-clear,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-chip-x {
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  background: #2a2a2a !important;
  color: #f5f5f5 !important;
}
.pm-map-area .pm-active-bar .pm-active-clear svg,
.pm-map-area .pm-active-bar .pm-active-chip-x svg,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-clear svg,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-chip-x svg {
  width: 7px !important;
  height: 7px !important;
  max-width: 7px !important;
  max-height: 7px !important;
  stroke-width: 2.25 !important;
  flex-shrink: 0 !important;
  display: block !important;
}
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-clear svg,
html[data-theme="dark"] .pm-map-area .pm-active-bar .pm-active-chip-x svg {
  stroke: #f5f5f5 !important;
  color: #f5f5f5 !important;
}

.pm-map-area .pm-map-mode-popover,
.pm-map-area .pm-maptype-popover,
html[data-theme="dark"] .pm-map-area .pm-map-mode-popover,
html[data-theme="dark"] .pm-map-area .pm-maptype-popover {
  border: 1px solid #1253a8 !important;
  box-shadow: 0 12px 28px rgba(18, 83, 168, 0.12) !important;
}

.pm-map-area .pm-maptype-trigger:hover,
.pm-map-area .pm-streetview-trigger:hover,
.pm-map-area .pm-traffic-trigger:hover,
.pm-map-area .pm-map-round-btn:hover,
.pm-map-area .pm-map-zoom-btn:hover,
.pm-map-area .pm-map-compass:hover,
.pm-map-area #pmMapSearchBtn:hover,
.pm-map-area #pmMapShareBtn:hover,
.pm-map-area #pmMapFullscreenBtn:hover,
.pm-map-area #pmStreetViewTrigger:hover,
.pm-map-area #pmTrafficFlowTrigger:hover,
.pm-map-area #pmMapTypeTrigger:hover,
.pm-map-area #pmMapModeTrigger:hover,
html[data-theme="dark"] .pm-map-area .pm-maptype-trigger:hover,
html[data-theme="dark"] .pm-map-area .pm-streetview-trigger:hover,
html[data-theme="dark"] .pm-map-area .pm-traffic-trigger:hover,
html[data-theme="dark"] .pm-map-area .pm-map-round-btn:hover,
html[data-theme="dark"] .pm-map-area .pm-map-zoom-btn:hover,
html[data-theme="dark"] .pm-map-area .pm-map-compass:hover,
html[data-theme="dark"] .pm-map-area #pmMapSearchBtn:hover,
html[data-theme="dark"] .pm-map-area #pmMapShareBtn:hover,
html[data-theme="dark"] .pm-map-area #pmMapFullscreenBtn:hover,
html[data-theme="dark"] .pm-map-area #pmStreetViewTrigger:hover,
html[data-theme="dark"] .pm-map-area #pmTrafficFlowTrigger:hover,
html[data-theme="dark"] .pm-map-area #pmMapTypeTrigger:hover,
html[data-theme="dark"] .pm-map-area #pmMapModeTrigger:hover {
  border: 1px solid #1253a8 !important;
  filter: none !important;
}

/* Mantem a barra de camadas ativas dentro da area util do mapa.
   A largura antiga usava 100vw e podia avançar por baixo da sidebar aberta. */
.pm-map-area .pm-map-corner-bottom {
  left: 16px !important;
  right: 16px !important;
  width: auto !important;
  max-width: none !important;
}

.pm-map-area .pm-map-corner-bottom .pm-active-bar {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
}

.pm-map-area .pm-map-corner-bottom #pmMapDistanceCard,
.pm-map-area .pm-map-corner-bottom #pmMapCoordsCard {
  flex: 0 0 auto !important;
}

#btnSettings,
.sb-bottom #btnSettings {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  place-items: center !important;
  padding: 0 !important;
}

#btnSettings .icon,
#btnSettings .icon svg {
  display: block !important;
  width: 18px !important;
  height: 18px !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
}

/* CAFIR typography aligned with CAR dashboard */
#panel-incra {
  --car-typo-font: 'Poppins', Inter, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-family: var(--car-typo-font) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  text-rendering: optimizeLegibility !important;
}
#panel-incra,
#panel-incra * {
  font-family: var(--car-typo-font) !important;
  letter-spacing: 0 !important;
}
#panel-incra .section-title,
#panel-incra h2,
#panel-incra h3 {
  font-size: 1.1rem !important;
  font-weight: 600 !important;
}
#panel-incra .section-desc,
#panel-incra .commentary,
#panel-incra .card-body,
#panel-incra p,
#panel-incra li,
#panel-incra td,
#panel-incra th {
  font-size: .82rem !important;
  font-weight: 400 !important;
}
#panel-incra .card-title,
#panel-incra .card-head h3,
#panel-incra .card-head .title {
  font-size: .72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
}
#panel-incra .kpi-label,
#panel-incra .metric-label,
#panel-incra .stat-box-lbl {
  font-size: .68rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
}
#panel-incra .kpi-value,
#panel-incra .kpi-val,
#panel-incra .sub-kpi-val,
#panel-incra .metric-value,
#panel-incra .stat-box-val,
#panel-incra .big-number,
#panel-incra .number {
  font-size: 1.95rem !important;
  font-weight: 700 !important;
  line-height: 1.06 !important;
  letter-spacing: -.01em !important;
  color: #244E9C !important;
}
#panel-incra .sub-kpi-label,
#panel-incra .kpi-sub,
#panel-incra .sub-kpi-detail {
  font-size: .7rem !important;
  line-height: 1.25 !important;
  font-weight: 400 !important;
}
#panel-incra .sub-kpi-label {
  font-size: .68rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
}

/* Top map controls: subtle grow on hover (click affordance) */
.pm-map-top-controls .pm-map-mode-trigger,
.pm-map-top-controls .pm-maptype-trigger,
.pm-map-top-controls .pm-streetview-trigger,
.pm-map-top-controls .pm-traffic-trigger{
  transition:transform .16s ease, box-shadow .18s ease, border-color .18s ease !important;
}
.pm-map-top-controls .pm-map-mode-trigger:hover,
.pm-map-top-controls .pm-maptype-trigger:hover,
.pm-map-top-controls .pm-streetview-trigger:hover,
.pm-map-top-controls .pm-traffic-trigger:hover{
  transform:scale(1.06) !important;
}

/* Right-side map controls: grow on hover */
.pm-map-corner-right .pm-map-round-btn,
.pm-map-corner-right .pm-map-compass,
.pm-map-corner-right .pm-map-zoom-pill{
  transition:transform .16s ease, box-shadow .18s ease, border-color .18s ease !important;
  transform-origin:center center;
}
.pm-map-corner-right .pm-map-round-btn:hover,
.pm-map-corner-right .pm-map-compass:hover,
.pm-map-corner-right .pm-map-zoom-pill:hover{
  transform:scale(1.06) !important;
}

/* IBGE dark: fundo totalmente preto */
html[data-theme="dark"] .censo-integrated #panel-ibge,
html[data-theme="dark"] .censo-integrated #panel-ibge.active,
html[data-theme="dark"] .censo-integrated #panel-ibge .itab-section,
html[data-theme="dark"] .censo-integrated #panel-ibge #sec-mapa.active,
html[data-theme="dark"] .censo-integrated #panel-ibge > .tabs-bar,
html[data-theme="dark"] .censo-integrated #panel-ibge .card,
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi-card,
html[data-theme="dark"] .censo-integrated #panel-ibge .kpi,
html[data-theme="dark"] .censo-integrated #panel-ibge .insight,
html[data-theme="dark"] .censo-integrated #panel-ibge .commentary {
  background: #000000 !important;
}
