@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
:root{
  --primaria:#0c1322; --primaria2:#16223b;
  --verde:#16a34a; --verde2:#15803d; --vermelho:#e11d48; --azul:#2563eb; --roxo:#9333ea; --accent:#4f46e5;
  --cinza:#6b7480; --cinza-claro:#eef1f7; --bg:#f4f6fb; --borda:#e8ebf2; --texto:#0f172a;
  --card:#ffffff; --surface-2:#fafbfe; --topbar:rgba(255,255,255,.82);
  --r:16px; --r-sm:10px;
  --sh:0 1px 2px rgba(16,24,40,.04),0 8px 24px -12px rgba(16,24,40,.16);
  --sh-sm:0 1px 2px rgba(16,24,40,.06);
}
[data-theme="dark"]{
  --primaria:#0a1020; --primaria2:#0f1830;
  --cinza:#9aa7bd; --cinza-claro:#1b2740; --bg:#0b1220; --borda:#243349; --texto:#e7ecf6;
  --card:#121b30; --surface-2:#172238; --topbar:rgba(18,27,48,.85);
  --sh:0 1px 2px rgba(0,0,0,.25),0 10px 28px -14px rgba(0,0,0,.6);
  --sh-sm:0 1px 2px rgba(0,0,0,.3);
  color-scheme:dark;
}
[data-theme="dark"] input,[data-theme="dark"] select,[data-theme="dark"] textarea{background:var(--card);color:var(--texto)}
[data-theme="dark"] .btn-cinza{background:var(--card);color:#cbd5e1;border-color:var(--borda)}
[data-theme="dark"] .md-body code,[data-theme="dark"] .tag{background:#1b2740}
[data-theme="dark"] .track,[data-theme="dark"] .prog{background:#22304d}
[data-theme="dark"] .campo-erro{background:#241018;border-color:#7f1d1d}
[data-theme="dark"] .login-wrap{background:var(--bg)}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;color:var(--texto);background:var(--bg);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* Layout */
.layout{display:flex;min-height:100vh}
.sidebar{width:248px;background:linear-gradient(180deg,var(--primaria),var(--primaria2));color:#aeb9c9;flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;padding:8px 12px}
.sidebar .logo{padding:14px 10px 16px;display:flex;align-items:center;gap:10px;font-weight:700;font-size:19px;color:#fff}
.sidebar .logo img{width:20px;height:20px}
.logo-mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--verde),#22c55e);display:grid;place-items:center;box-shadow:0 6px 16px -6px var(--verde);flex-shrink:0}
.sidebar .nav{flex:1;overflow-y:auto}
.sidebar .sec{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#64748b;font-weight:600;margin:14px 12px 6px}
.nav a svg{width:18px;height:18px;opacity:.92;flex-shrink:0}
.nav a .badge{margin-left:auto;background:var(--verde);color:#fff;font-size:10.5px;font-weight:700;border-radius:20px;padding:1px 8px}
.sb-user{margin:6px 2px 2px;display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:rgba(255,255,255,.05)}
.sb-user .sb-av{width:34px;height:34px;border-radius:50%;background:#1f2a44;color:#fff;display:grid;place-items:center;font-weight:600;overflow:hidden;background-size:cover;background-position:center;flex-shrink:0}
.sb-user .sb-av img{width:100%;height:100%;object-fit:cover}
.sb-user .sb-nome{color:#fff;font-weight:600;font-size:13px;line-height:1.2}
.sb-user .sb-papel{color:#7c8aa3;font-size:12px}
/* menu recolhido */
.collapse-btn{display:none;background:none;border:1px solid var(--borda);border-radius:10px;width:36px;height:36px;cursor:pointer;color:var(--texto)}
@media(min-width:861px){.collapse-btn{display:grid;place-items:center}}
.layout.collapsed .sidebar{width:74px}
.layout.collapsed .sidebar .logo-txt{display:none}
.layout.collapsed .sidebar .logo{justify-content:center}
.layout.collapsed .sidebar .sec{font-size:0;text-align:center;margin:12px 0 4px}
.layout.collapsed .sidebar .sec::after{content:"•••";font-size:10px;letter-spacing:1px;color:#475569}
.layout.collapsed .nav a{justify-content:center;padding:11px 0;gap:0}
.layout.collapsed .nav a span,.layout.collapsed .nav a .badge{display:none}
.layout.collapsed .nav a.ativo::before{left:-12px}
.layout.collapsed .sb-user{justify-content:center}
.layout.collapsed .sb-user>div{display:none}
.menu-btn{margin:4px 4px 14px;background:var(--verde);color:#fff;border:0;border-radius:11px;padding:11px;font-weight:600;display:flex;gap:8px;align-items:center;justify-content:center;box-shadow:0 8px 18px -10px var(--verde)}
.nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;color:#aeb9c9;font-weight:500;font-size:14.5px;border-radius:11px;margin:2px 0;position:relative;transition:.15s}
.nav a .ic{width:20px;text-align:center}
.nav a.ativo{background:rgba(34,197,94,.14);color:#fff}
.nav a.ativo::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:0 4px 4px 0;background:var(--verde)}
.nav a:hover{background:rgba(255,255,255,.05);color:#fff}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.hamburguer{display:none;background:none;border:0;font-size:24px;cursor:pointer;color:var(--texto);padding:0 6px;line-height:1}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:40}
.sb-overlay.on{display:block}
.topbar{background:var(--topbar);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--borda);padding:14px 24px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:5}
.topbar .titulo{flex:1}
.topbar h1{margin:0;font-size:22px}
.breadcrumb{font-size:13px;color:var(--cinza);margin-top:2px}
.breadcrumb a{color:var(--cinza)}
.chip-org{background:var(--cinza-claro);border:1px solid var(--borda);border-radius:10px;padding:8px 14px;font-weight:600;font-size:14px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--primaria2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;overflow:hidden;background-size:cover;background-position:center}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar-lg{width:96px;height:96px;border-radius:50%;background:var(--cinza-claro);color:var(--cinza);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:34px;overflow:hidden;flex-shrink:0;background-size:cover;background-position:center;border:1px solid var(--borda)}
.avatar-lg img{width:100%;height:100%;object-fit:cover}

.conteudo{padding:24px;flex:1}

/* Componentes */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid transparent;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s}
.btn-verde{background:var(--verde);color:#fff;box-shadow:0 8px 18px -10px var(--verde)}
.btn-verde:hover{background:var(--verde2)}
.btn-cinza{background:#fff;color:#374151;border-color:var(--borda)}
.btn-cinza:hover{background:var(--cinza-claro)}
.btn-vermelho{background:var(--vermelho);color:#fff}
.btn-sm{padding:7px 12px;font-size:13px}

.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.busca{flex:1;min-width:220px;max-width:420px;position:relative}
.busca input{width:100%;padding:11px 14px;border:1px solid var(--borda);border-radius:10px;font-size:15px}

.card{background:var(--card);border:1px solid var(--borda);border-radius:var(--r);padding:0;overflow:hidden;box-shadow:var(--sh)}
.card.pad{padding:20px}

table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:13px 18px;font-size:14px}
thead th{color:var(--cinza);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--borda)}
tbody tr{border-top:1px solid var(--borda)}
tbody tr:hover{background:var(--surface-2)}
td.acoes{text-align:right;color:var(--cinza)}

.prog{height:8px;width:120px;background:#e5e7eb;border-radius:999px;overflow:hidden;display:inline-block;vertical-align:middle}
.prog>span{display:block;height:100%}
.prog.verde>span{background:var(--verde)}
.prog.azul>span{background:var(--azul)}

.status{font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px}
.status.em_campo{background:#dcfce7;color:#166534}
.status.rascunho{background:#fef9c3;color:#854d0e}
.status.encerrada{background:#e0e7ff;color:#3730a3}
.status.arquivada{background:#f3f4f6;color:#6b7280}

.vazio{text-align:center;color:var(--cinza);padding:48px}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--primaria)}
.login-card{background:var(--card);border-radius:18px;width:380px;max-width:92%;padding:32px;box-shadow:0 20px 40px rgba(0,0,0,.25)}
.login-card .logo{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:700;color:var(--primaria);justify-content:center;margin-bottom:6px}
.login-card .logo img{width:40px;height:40px}
.login-card .sub{text-align:center;color:var(--cinza);font-size:13px;margin-bottom:22px}
.campo{margin-bottom:16px}
.campo label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}
.campo input{width:100%;padding:12px;border:1px solid var(--borda);border-radius:10px;font-size:15px}
.erro{background:#fee2e2;color:#991b1b;padding:10px 14px;border-radius:10px;font-size:14px;margin-bottom:14px}
.muted{color:var(--cinza);font-size:12px;text-align:center;margin-top:16px}

/* Boot */
.boot{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--cinza)}

/* Abas do formulário (contexto de um formulário) */
.form-chrome{margin-bottom:18px}
.form-chrome h2{margin:0 0 10px;font-size:20px}
.abas{display:flex;gap:4px;border-bottom:2px solid var(--borda);flex-wrap:wrap}
.abas a{padding:10px 16px;font-weight:600;color:var(--cinza);border-bottom:3px solid transparent;margin-bottom:-2px}
.abas a:hover{color:var(--texto)}
.abas a.on{color:var(--verde);border-bottom-color:var(--verde)}

/* Topbar dropdowns */
.tb-actions{display:flex;align-items:center;gap:12px;position:relative}
.dropdown{position:relative}
.dropmenu{position:absolute;right:0;top:48px;background:var(--card);border:1px solid var(--borda);border-radius:12px;box-shadow:0 12px 30px rgba(0,0,0,.15);min-width:240px;z-index:30;overflow:hidden}
.dropmenu .greet{padding:14px 16px;color:var(--cinza);font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--borda)}
.dropmenu a,.dropmenu button{display:flex;gap:10px;align-items:center;width:100%;text-align:left;padding:12px 16px;background:none;border:0;font-size:14px;cursor:pointer;color:var(--texto)}
.dropmenu a:hover,.dropmenu button:hover{background:var(--cinza-claro)}
.org-search{padding:10px;border-bottom:1px solid var(--borda)}
.org-search input{width:100%;padding:8px 10px;border:1px solid var(--borda);border-radius:8px}
.org-item{padding:10px 16px;cursor:pointer}
.org-item:hover{background:var(--cinza-claro)}
.org-item.sel{background:var(--verde);color:#fff;font-weight:600}
.chip-org{cursor:pointer;display:flex;align-items:center;gap:8px}
.avatar{cursor:pointer}

/* Modal */
.modal-back{position:fixed;inset:0;background:rgba(17,24,39,.55);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}
.modal{background:var(--card);border-radius:16px;width:560px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--borda)}
.modal-head h3{margin:0;font-size:20px}
.modal-body{padding:20px 24px;overflow:auto}
.modal-foot{padding:16px 24px;border-top:1px solid var(--borda);display:flex;gap:12px;align-items:center}
.modal-body .campo{margin-bottom:14px}
.modal-body label{display:block;font-size:14px;font-weight:600;margin-bottom:6px}
.modal-body input,.modal-body select,.modal-body textarea{width:100%;padding:10px 12px;border:1px solid var(--borda);border-radius:10px;font-size:15px}
.modal-body input[type=checkbox],.modal-body input[type=radio]{width:18px;height:18px;flex:none;padding:0;margin:0;accent-color:var(--verde)}
.modal-body .toggle-row{display:flex;align-items:center;gap:10px}
.modal-body .toggle-row label{margin:0;flex:1}

/* Toast tipos */
.toast{transition:opacity .3s}
.toast-ok{background:#111827}
.toast-erro{background:var(--vermelho)}
.toast-aviso{background:#b45309}

/* Painéis e barras (dashboard) */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--borda);border-radius:var(--r);padding:18px;box-shadow:var(--sh)}
.kpi .v{font-size:28px;font-weight:700;letter-spacing:-.02em}
.kpi .l{color:var(--cinza);font-size:13px}
.kpi-ic{width:40px;height:40px;border-radius:12px;display:inline-grid;place-items:center;font-size:18px;margin-bottom:8px}
.kpi-ic.ic-ok{background:#dcfce7}.kpi-ic.ic-amber{background:#fef3c7}.kpi-ic.ic-indigo{background:#e0e7ff}.kpi-ic.ic-red{background:#fee2e2}
.kpi-hi{background:linear-gradient(135deg,var(--verde),#22c55e);color:#fff;border:0}
.kpi-hi .l{color:#dcfce7}
.kpi-hi .kpi-ic{background:rgba(255,255,255,.18)}
.kpi-bar{height:6px;border-radius:20px;background:rgba(255,255,255,.28);margin-top:12px;overflow:hidden}
.kpi-bar span{display:block;height:100%;background:#fff;border-radius:20px}
.seg{display:inline-flex;background:var(--bg);border:1px solid var(--borda);border-radius:10px;padding:3px;gap:2px}
.seg button{border:0;background:transparent;padding:6px 12px;border-radius:8px;font-weight:600;font-size:12px;color:var(--cinza);cursor:pointer}
.seg button.on{background:var(--card);color:var(--texto);box-shadow:var(--sh-sm)}
.mini-ava{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--cinza-claro);color:#334155;font-weight:600;font-size:11px;margin-right:8px;vertical-align:middle}
/* paginação */
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:16px}
.pager-info{color:var(--cinza);font-size:13px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pager-info b{color:var(--texto)}
.pager-persel{border:1px solid var(--borda);border-radius:8px;background:var(--card);color:var(--texto);padding:4px 6px;font-size:13px;margin-left:4px}
.pager-nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.pg-num,.pg-arw{min-width:34px;height:34px;padding:0 8px;border:1px solid var(--borda);background:var(--card);color:var(--texto);border-radius:9px;font-weight:600;font-size:13px;cursor:pointer}
.pg-num:hover,.pg-arw:hover{background:var(--surface-2)}
.pg-num.on{background:var(--verde);border-color:var(--verde);color:#fff}
.pg-arw[disabled]{opacity:.4;cursor:default}
.pg-ell{padding:0 4px;color:var(--cinza)}
/* ordenação por coluna */
th.th-sort{cursor:pointer;user-select:none;white-space:nowrap}
th.th-sort:hover{color:var(--texto)}
th.th-sort.on{color:var(--verde)}
.th-arw{font-size:10px}
/* tabelas roláveis em telas estreitas */
.tbl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:680px){ .card>table,.tbl-scroll>table{min-width:560px} }
.paineis{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}
.painel{background:var(--card);border:1px solid var(--borda);border-radius:var(--r);padding:18px;box-shadow:var(--sh)}
.painel h3{margin:0 0 14px;font-size:15px}
.barra-item{margin-bottom:12px}
.barra-top{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}
.barra{height:8px;background:#eef2f7;border-radius:999px;overflow:hidden}
.barra>span{display:block;height:100%}
.barra-click{cursor:pointer;padding:6px;border-radius:8px;transition:background .15s}
.barra-click:hover{background:#f0fdf4}
.barra-ativa{background:#ecfdf5;box-shadow:inset 0 0 0 2px var(--verde)}
.chip-filtro{display:inline-flex;align-items:center;gap:6px;background:#ecfdf5;border:1px solid var(--verde);color:#166534;padding:6px 12px;border-radius:999px;font-size:13px;cursor:pointer}
.chip-filtro b{color:var(--vermelho)}
.chip-filtro:hover{background:#dcfce7}

/* Dropdown "Valores aceitos" (condicional das perguntas) */
.dep-dd{position:relative}
.dep-panel{margin-top:8px;background:var(--card);border:1px solid var(--borda);border-radius:10px;box-shadow:0 6px 18px rgba(0,0,0,.08);padding:8px}
.dep-busca{width:100%;padding:8px 10px;border:1px solid var(--borda);border-radius:8px;margin:6px 0 8px}
.dep-list{max-height:180px;overflow:auto}
.dep-panel .dep-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:8px;cursor:pointer;font-size:14px;margin:0;font-weight:500}
.dep-panel .dep-row:hover{background:var(--cinza-claro)}
.dep-panel .dep-row input[type=checkbox]{width:18px;height:18px;flex:none;margin:0;accent-color:var(--verde)}
.dep-panel .dep-all{border-bottom:1px solid var(--borda);margin-bottom:4px;font-weight:600}
.muted-sm{font-size:12px;color:var(--cinza)}
#mapa{height:420px;border-radius:14px;overflow:hidden;border:1px solid var(--borda)}
.legenda{display:flex;gap:16px;flex-wrap:wrap;margin:10px 0;font-size:13px}
.legenda span{display:inline-flex;align-items:center;gap:6px}
.dot{width:12px;height:12px;border-radius:50%;display:inline-block}
.row-flex{display:flex;gap:16px;flex-wrap:wrap}
.row-flex>*{flex:1;min-width:300px}
.toggle-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--borda)}
.toggle-row label{margin:0;flex:1}
.tag{font-size:11px;background:var(--cinza-claro);padding:2px 8px;border-radius:6px;color:var(--cinza)}
.spin{display:inline-block;width:22px;height:22px;border:3px solid #ddd;border-top-color:var(--verde);border-radius:50%;animation:gira .8s linear infinite}
@keyframes gira{to{transform:rotate(360deg)}}

/* Botão "..." e popover de ações */
.btn-dots{background:none;border:0;font-size:20px;color:var(--cinza);cursor:pointer;padding:4px 10px;border-radius:8px;line-height:1}
.btn-dots:hover{background:var(--cinza-claro)}
.popover-menu{position:absolute;z-index:200;background:var(--card);border:1px solid var(--borda);border-radius:12px;box-shadow:0 12px 30px rgba(0,0,0,.18);min-width:190px;padding:6px;overflow:hidden}
.popover-menu button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:0;padding:10px 12px;font-size:14px;border-radius:8px;cursor:pointer;color:var(--texto)}
.popover-menu button:hover{background:var(--cinza-claro)}
.popover-menu .pop-perigo{color:var(--vermelho)}
.popover-menu .pop-sep{height:1px;background:var(--borda);margin:6px 4px}

/* Impressão / export PDF do dashboard */
@media print{
  .sidebar,.topbar,.toolbar,.btn,.no-print{display:none !important}
  .main,.conteudo{padding:0 !important}
  .painel,.kpi,.card{break-inside:avoid;box-shadow:none}
  body{background:#fff}
  #mapa{height:360px}
}
.print-head{display:none}
@media print{.print-head{display:block;text-align:center;margin-bottom:16px}}

/* Ficha técnica + tabelas auxiliares */
.ficha-tbl{width:100%;border-collapse:collapse}
.ficha-tbl td{padding:6px 8px;border-bottom:1px solid var(--borda);vertical-align:top;font-size:14px}
.ficha-tbl tr:last-child td{border-bottom:0}
.tbl-mini{width:100%;border-collapse:collapse;font-size:13px}
.tbl-mini th,.tbl-mini td{padding:4px 8px;border-bottom:1px solid var(--borda)}
.tbl-mini th{color:var(--cinza);font-weight:600;text-align:left}
@media print{.ficha-tec{break-inside:avoid;page-break-inside:avoid}}
.chk{display:inline-flex;align-items:center;gap:6px;font-size:14px;cursor:pointer;line-height:2}
.chk input{width:auto;margin:0}

/* Opções do formulário web (Responder) */
.opcao-r{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--borda);border-radius:10px;margin-bottom:8px;cursor:pointer}
.opcao-r:hover{background:var(--cinza-claro)}
/* Orientação ao pesquisador (instrução exibida na coleta) */
.orientacao{background:#fef3c7;color:#92400e;font-weight:700;font-size:12px;padding:6px 10px;border-radius:8px;margin-bottom:8px;display:inline-block;text-transform:uppercase;letter-spacing:.3px}

/* Markdown renderizado (docs no modal) */
.md-body{font-size:14px;line-height:1.6;color:var(--texto)}
.md-body h1{font-size:24px;margin:18px 0 10px;border-bottom:2px solid var(--borda);padding-bottom:6px}
.md-body h2{font-size:19px;margin:20px 0 8px}
.md-body h3{font-size:16px;margin:16px 0 6px}
.md-body p{margin:8px 0}
.md-body code{background:var(--cinza-claro);padding:2px 6px;border-radius:6px;font-size:13px}
.md-body pre{background:#0f172a;color:#e2e8f0;padding:14px;border-radius:10px;overflow:auto;font-size:13px}
.md-body pre code{background:none;color:inherit;padding:0}
.cod-bloco{background:#0f172a;color:#e2e8f0;padding:12px;border-radius:10px;overflow:auto;max-height:280px;font-size:12.5px;white-space:pre-wrap;word-break:break-word;margin:6px 0 14px;font-family:ui-monospace,Menlo,Consolas,monospace}
.campo-erro{background:#fff5f5;border:1px solid var(--vermelho,#dc2626);border-radius:10px;padding:10px;margin-left:-10px;margin-right:-10px}
.campo-erro>label{color:var(--vermelho,#dc2626)}
/* IA multi-provider */
.ia-prov-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.ia-prov{border:2px solid var(--borda);border-radius:12px;padding:12px;cursor:pointer;transition:.15s;background:var(--card)}
.ia-prov:hover{border-color:var(--cinza)}
.ia-prov.sel{border-color:var(--pc,#6b46ff);box-shadow:0 0 0 3px color-mix(in srgb,var(--pc,#6b46ff) 18%,transparent)}
.ia-prov-h{display:flex;align-items:center;gap:10px}
.ia-prov-h .ia-ic{font-size:22px;line-height:1}
.ia-prov-h strong{display:block;font-size:14px}
.ia-prov-h span{font-size:11px;color:var(--cinza)}
.ia-prov p{margin:8px 0 0;font-size:12px;color:var(--cinza)}
.ia-cfg{border:1px solid var(--borda);border-radius:12px;padding:14px;background:var(--surface-2)}
.ia-cfg h4{margin:0 0 10px;font-size:13px}
/* Chat IA */
.ia-msg{display:flex}
.ia-msg.user{justify-content:flex-end}
.ia-bolha{max-width:78%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5;white-space:normal;overflow-wrap:anywhere}
.ia-msg.user .ia-bolha{background:var(--primaria,#1e293b);color:#fff;border-bottom-right-radius:4px}
.ia-msg.bot .ia-bolha{background:var(--cinza-claro,#f1f5f9);color:var(--texto,#0f172a);border-bottom-left-radius:4px}
.ia-bolha p{margin:6px 0}.ia-bolha ul,.ia-bolha ol{margin:6px 0;padding-left:20px}
.ia-bolha table{border-collapse:collapse;font-size:13px;margin:8px 0}
.ia-bolha th,.ia-bolha td{border:1px solid var(--borda);padding:4px 8px}
.ia-bolha code{background:rgba(0,0,0,.06);padding:1px 5px;border-radius:5px}
.md-body table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}
.md-body th,.md-body td{border:1px solid var(--borda);padding:8px 10px;text-align:left}
.md-body th{background:var(--cinza-claro)}
.md-body a{color:var(--verde);font-weight:600}
.md-body ul,.md-body ol{padding-left:22px;margin:8px 0}
.md-body blockquote{border-left:4px solid var(--verde);margin:10px 0;padding:4px 14px;color:var(--cinza);background:#f9fafb}
.modal.modal-lg{max-width:920px;width:920px}

/* ===== Responsividade ===== */
@media (max-width: 860px){
  .sidebar{position:fixed;left:0;top:0;height:100vh;width:260px;transform:translateX(-100%);transition:transform .25s ease;z-index:50}
  .sidebar.aberto{transform:none;box-shadow:6px 0 24px rgba(0,0,0,.25)}
  .hamburguer{display:block}
  .topbar{gap:10px;padding:12px 16px}
  .topbar h1{font-size:18px}
  .breadcrumb{display:none}
  .conteudo{padding:16px 12px}
  .paineis{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr}
  /* tabelas roláveis no mobile */
  .card{overflow-x:auto}
  table{min-width:560px}
  .toolbar{gap:8px}
  .busca{min-width:140px}
  .row-flex{flex-direction:column}
  .row-flex>*{min-width:0;width:100%}
  .chip-org{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .modal{width:100%}
  .modal.modal-lg{width:100%}
  .dropmenu{min-width:200px}
}
@media (max-width: 480px){
  .kpis{grid-template-columns:1fr}
  .login-card{padding:24px}
  .abas{overflow-x:auto}
  .abas a{white-space:nowrap}
}

/* ===== Form controls melhorados (editor e modais) ===== */
.conteudo .campo input:not([type=checkbox]):not([type=radio]),
.conteudo .campo select,
.conteudo .campo textarea{
  width:100%;padding:11px 12px;border:1px solid var(--borda);border-radius:10px;
  font-size:15px;font-family:inherit;background-color:var(--card);color:var(--texto);
  transition:border-color .15s, box-shadow .15s}
.conteudo .campo textarea,.modal-body textarea{min-height:84px;resize:vertical;line-height:1.5}
.conteudo .campo input:focus,.conteudo .campo select:focus,.conteudo .campo textarea:focus,
.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{
  outline:none;border-color:var(--verde);box-shadow:0 0 0 3px rgba(22,163,74,.15)}
.conteudo .campo input::placeholder,.conteudo .campo textarea::placeholder,
.modal-body input::placeholder,.modal-body textarea::placeholder{color:#9ca3af}

/* select com seta custom */
.conteudo .campo select,.modal-body select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:36px}

/* toggle/switch */
.toggle-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--borda)}
.toggle-row label{margin:0;flex:1;cursor:pointer;font-weight:500}
.toggle-row input[type=checkbox]{
  appearance:none;-webkit-appearance:none;width:44px;height:24px;border-radius:999px;
  background:#cbd5e1;position:relative;cursor:pointer;transition:background .2s;flex:none;margin:0;padding:0}
.toggle-row input[type=checkbox]::after{
  content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;
  background:#fff;transition:left .2s;box-shadow:0 1px 2px rgba(0,0,0,.35)}
.toggle-row input[type=checkbox]:checked{background:var(--verde)}
.toggle-row input[type=checkbox]:checked::after{left:22px}

/* ===== Visual consistente p/ TODOS os selects/inputs/textarea do conteúdo (filtros, toolbars, etc.) ===== */
.conteudo select,
.conteudo textarea,
.conteudo input[type=text],
.conteudo input[type=date],
.conteudo input[type=number],
.conteudo input[type=email],
.conteudo input[type=password],
.conteudo input[type=search]{
  border:1px solid var(--borda);border-radius:10px;font-family:inherit;font-size:14px;
  background-color:var(--card);color:var(--texto);padding:10px 12px;line-height:1.3;
  transition:border-color .15s, box-shadow .15s}
.conteudo select:focus,.conteudo textarea:focus,
.conteudo input[type=text]:focus,.conteudo input[type=date]:focus,.conteudo input[type=number]:focus,
.conteudo input[type=email]:focus,.conteudo input[type=password]:focus,.conteudo input[type=search]:focus{
  outline:none;border-color:var(--verde);box-shadow:0 0 0 3px rgba(22,163,74,.15)}
.conteudo select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;background-size:14px;padding-right:34px}
/* datas com aparência alinhada */
.conteudo input[type=date]{min-width:150px}

/* ===== Responsividade de tabelas dentro de painéis (dashboard) ===== */
.painel{overflow-x:auto}
@media (max-width:860px){
  .painel table{min-width:480px}
  .painel{ -webkit-overflow-scrolling:touch }
}

/* chips de bairros (gestão na tela Regiões) */
.chip-bairro{display:inline-flex;align-items:center;gap:8px;background:var(--cinza-claro);border:1px solid var(--borda);border-radius:999px;padding:6px 12px;font-size:13px}
.chip-bairro b{color:var(--vermelho);cursor:pointer;font-weight:700}
