/* =============================================================================
   Painel de Auditoria — Amigos do Bem
   Identidade visual alinhada ao "Painel de Projetos" (tokens ADB).
   ============================================================================= */
:root{
  --adb-amarelo:#FFD000;
  --adb-amarelo-2:#e6bd00;
  --adb-laranja:#F58220;
  --adb-azul:#163E5C;
  --tinta:#111418;
  --tinta-2:#1b2026;
  --cinza-bg:#f3f4f6;
  --cinza-card:#ffffff;
  --cinza-borda:#e2e5ea;
  --cinza-borda-2:#d2d6dd;
  --texto:#1f2937;
  --texto-mid:#6b7280;
  --texto-fraco:#9aa1ab;
  --ok:#1a7f37; --ok-bg:#e9f6ec;
  --info:#0b69c7; --info-bg:#e7f1fb;
  --warn:#b9770a; --warn-bg:#fdf3e2;
  --err:#b42318; --err-bg:#fdecea;
  --roxo:#5b3fb0; --roxo-bg:#f0ecfb;
  --s1:0 1px 2px rgba(16,24,40,.06);
  --s2:0 4px 14px rgba(16,24,40,.10);
  --r:8px;
  --nav-w:236px;
  font-family:'Segoe UI',system-ui,-apple-system,'Inter',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--cinza-bg);color:var(--texto)}
body{font-size:14px;line-height:1.45}
a{color:var(--info);text-decoration:none}
button{font-family:inherit;cursor:pointer}
.hidden{display:none !important}

/* ---------- Botões ---------- */
.btn-primary{background:var(--tinta);color:#fff;border:none;border-radius:6px;padding:9px 16px;font-size:13px;font-weight:600;transition:background .15s}
.btn-primary:hover{background:#2a2f37}
.btn-primary:disabled{opacity:.6;cursor:default}
.btn-ghost{background:#fff;color:var(--texto-mid);border:1px solid var(--cinza-borda-2);border-radius:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:.15s}
.btn-ghost:hover{background:#f7f8fa;color:var(--texto)}
.btn-danger{background:#fff;color:var(--err);border:1px solid var(--err);border-radius:6px;padding:8px 14px;font-size:13px;font-weight:600}
.btn-danger:hover{background:var(--err-bg)}
.btn-ok{background:var(--ok);color:#fff;border:none;border-radius:6px;padding:8px 14px;font-size:13px;font-weight:600}
.btn-warn{background:var(--warn);color:#fff;border:none;border-radius:6px;padding:8px 14px;font-size:13px;font-weight:600}
.btn-sm{padding:6px 11px;font-size:12px}

/* ---------- Login ---------- */
#login{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 70% -10%, #233246 0%, var(--tinta) 60%)}
.login-box{background:#fff;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.35);padding:30px 30px 26px;width:380px;max-width:92vw}
.login-brand{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.login-logo{width:54px;height:54px;object-fit:contain;border-radius:9px}
.login-org{font-size:11px;font-weight:800;letter-spacing:.12em;color:var(--texto-fraco)}
.login-title{font-size:19px;font-weight:800;color:var(--tinta);line-height:1.1}
.login-sub{font-size:12px;color:var(--texto-mid)}
.login-form label{display:block;font-size:12px;font-weight:700;color:var(--texto-mid);margin:13px 0 5px}
.login-form input{width:100%;border:1px solid var(--cinza-borda-2);border-radius:7px;padding:11px 12px;font-size:14px;outline:none}
.login-form input:focus{border-color:var(--tinta)}
.login-form .btn-primary{width:100%;margin-top:20px;padding:11px}
.login-erro{color:var(--err);font-size:12.5px;min-height:16px;margin:10px 0 0;text-align:center}

/* ---------- Topbar ---------- */
#app{display:none}
#app.on{display:block}
.topbar{position:sticky;top:0;z-index:50;height:58px;background:var(--tinta);color:#fff;display:flex;align-items:center;gap:12px;padding:0 18px}
.top-logo{width:34px;height:34px;object-fit:contain;border-radius:7px;background:#fff;padding:2px}
.top-titles{line-height:1.05}
.top-title{font-size:15px;font-weight:800}
.top-sub{font-size:11px;color:#aeb6c2}
.top-spacer{flex:1}
.top-user{text-align:right;line-height:1.15}
.top-uname{font-size:13px;font-weight:700}
.top-urole{font-size:11px;color:#aeb6c2;text-transform:uppercase;letter-spacing:.04em}
.top-avatar{width:34px;height:34px;border-radius:50%;background:var(--adb-amarelo);color:var(--tinta);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px}
.topbar .btn-ghost{background:transparent;color:#cfd5de;border-color:#3a4250}
.topbar .btn-ghost:hover{background:#222936;color:#fff}

/* ---------- Shell ---------- */
.shell{display:flex;align-items:flex-start;max-width:1480px;margin:0 auto}
.sidenav{width:var(--nav-w);flex:none;background:#fff;border-right:1px solid var(--cinza-borda);min-height:calc(100vh - 58px);position:sticky;top:58px;padding:14px 10px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:7px;font-size:13.5px;font-weight:600;color:var(--texto-mid);cursor:pointer;margin-bottom:3px}
.nav-item:hover{background:#f4f5f7;color:var(--texto)}
.nav-item.sel{background:var(--tinta);color:#fff}
.nav-ico{width:20px;text-align:center;font-size:15px}
.nav-badge{margin-left:auto;background:var(--err);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:1px 7px}
.content{flex:1;min-width:0;padding:22px 26px 60px}

/* ---------- Views ---------- */
.view{display:none}
.view.on{display:block}
.view-head{margin-bottom:18px;display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px}
.view-head h1{font-size:22px;font-weight:800;color:var(--tinta);margin:0}
.view-desc{font-size:13px;color:var(--texto-mid);margin:2px 0 0;width:100%}
.view-actions{margin-left:auto;display:flex;gap:8px}

/* ---------- Filtros ---------- */
.filtros{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;align-items:center}
.filtros select,.filtros input{border:1px solid var(--cinza-borda-2);border-radius:7px;padding:8px 11px;font-size:13px;background:#fff;outline:none}
.filtros select:focus,.filtros input:focus{border-color:var(--tinta)}
.filtros .lbl{font-size:11px;font-weight:700;color:var(--texto-fraco);text-transform:uppercase;letter-spacing:.04em}

/* ---------- Cards KPI ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:20px}
.kpi{background:var(--cinza-card);border:1px solid var(--cinza-borda);border-radius:var(--r);padding:15px 16px;box-shadow:var(--s1)}
.kpi .v{font-size:27px;font-weight:800;color:var(--tinta);line-height:1}
.kpi .l{font-size:12px;color:var(--texto-mid);margin-top:6px}
.kpi.alerta{border-left:4px solid var(--err)}
.kpi.ok{border-left:4px solid var(--ok)}
.kpi.amarelo{border-left:4px solid var(--adb-amarelo)}
.kpi-sub{margin-top:8px;font-size:11.5px;color:var(--texto-mid)}
.kpi.clic{cursor:pointer;transition:box-shadow .12s,transform .12s}
.kpi.clic:hover{box-shadow:var(--s2);transform:translateY(-2px)}

/* Breadcrumb do drill de resultados */
.breadcrumb{display:flex;align-items:center;gap:7px;font-size:13.5px}
.bc-link{color:var(--info);cursor:pointer;font-weight:600}
.bc-link:hover{text-decoration:underline}
.bc-cur{color:var(--texto);font-weight:700}
.bc-sep{color:var(--texto-fraco)}
.sec-tit2{font-size:12px;font-weight:800;color:var(--texto-mid);text-transform:uppercase;letter-spacing:.05em;margin:22px 0 10px}
.sec-tit2 .hint{font-weight:500;text-transform:none;letter-spacing:0;color:var(--texto-fraco);font-size:11px}

/* Medidores (gauges) das unidades */
.gauges{display:flex;flex-wrap:wrap;gap:16px}
.gauge-card{background:var(--cinza-card);border:1px solid var(--cinza-borda);border-radius:12px;padding:16px 18px 14px;box-shadow:var(--s1);text-align:center;width:172px}
.gauge-card.clic{cursor:pointer;transition:box-shadow .12s,transform .12s}
.gauge-card.clic:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.gauge-svg{width:104px;height:104px;display:block;margin:0 auto}
.gauge-nome{font-weight:700;margin-top:9px;font-size:14px;color:var(--tinta)}
.gauge-sub{font-size:11.5px;color:var(--texto-mid);margin-top:3px}

/* ---------- Charts ---------- */
.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}
.chart-card{background:var(--cinza-card);border:1px solid var(--cinza-borda);border-radius:var(--r);padding:14px 16px 16px;box-shadow:var(--s1)}
.chart-card h3{font-size:13.5px;font-weight:700;color:var(--texto);margin:0 0 10px}
.chart-wrap{position:relative;height:230px}

/* ---------- Tabelas ---------- */
.tabela-wrap{background:#fff;border:1px solid var(--cinza-borda);border-radius:var(--r);overflow:hidden;box-shadow:var(--s1)}
table.grid{width:100%;border-collapse:collapse;font-size:13px}
table.grid th{background:#f7f8fa;text-align:left;padding:10px 12px;font-size:11px;font-weight:700;color:var(--texto-fraco);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--cinza-borda)}
table.grid td{padding:10px 12px;border-bottom:1px solid var(--cinza-borda)}
table.grid tbody tr{cursor:pointer}
table.grid tbody tr:hover{background:#fafbfc}
table.grid tbody tr:last-child td{border-bottom:none}
.vazio{padding:34px;text-align:center;color:var(--texto-fraco);font-size:13px}

/* ---------- Badges ---------- */
.badge{display:inline-block;font-size:10.5px;font-weight:700;border-radius:10px;padding:2px 9px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}
.badge.aberta{background:var(--err-bg);color:var(--err)}
.badge.em_tratamento{background:var(--warn-bg);color:var(--warn)}
.badge.resolvida{background:var(--ok-bg);color:var(--ok)}
.badge.rejeitada{background:#eef0f2;color:var(--texto-mid)}
.badge.risco-critico{background:var(--err-bg);color:var(--err)}
.badge.risco-alto{background:#fde7d0;color:#c2660c}
.badge.risco-medio{background:var(--warn-bg);color:var(--warn)}
.badge.risco-baixo{background:var(--info-bg);color:var(--info)}
.badge.migrada{background:var(--roxo-bg);color:var(--roxo)}
.pill-area{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--texto)}
.pill-area .dot{width:9px;height:9px;border-radius:50%}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;z-index:200;background:rgba(16,22,30,.55);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal[hidden]{display:none}
.modal-box{background:#fff;border-radius:12px;width:660px;max-width:96vw;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.modal-head{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--cinza-borda)}
.modal-head h2{font-size:17px;font-weight:800;color:var(--tinta);margin:0;flex:1}
.modal-x{background:none;border:none;font-size:24px;color:var(--texto-fraco);line-height:1;padding:0 4px}
.modal-x:hover{color:var(--texto)}
.modal-body{padding:18px 20px}
.modal-foot{display:flex;align-items:center;gap:8px;padding:14px 20px;border-top:1px solid var(--cinza-borda);background:#fafbfc;border-radius:0 0 12px 12px}
.modal-foot-right{margin-left:auto;display:flex;gap:8px}

/* Detalhe NC */
.dl{display:grid;grid-template-columns:130px 1fr;gap:6px 14px;font-size:13px;margin-bottom:6px}
.dl dt{color:var(--texto-fraco);font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;padding-top:2px}
.dl dd{margin:0;color:var(--texto)}
.sec-tit{font-size:12px;font-weight:800;color:var(--texto-mid);text-transform:uppercase;letter-spacing:.05em;margin:20px 0 9px;border-top:1px solid var(--cinza-borda);padding-top:14px}
.gut-box{display:inline-flex;gap:6px;align-items:center;background:#f7f8fa;border:1px solid var(--cinza-borda);border-radius:8px;padding:5px 11px;font-size:13px;font-weight:700}

/* Galeria de fotos */
.galeria{display:flex;flex-wrap:wrap;gap:10px}
.galeria .foto{position:relative;width:96px;height:96px;border-radius:8px;overflow:hidden;border:1px solid var(--cinza-borda);background:#f1f2f4}
.galeria .foto img{width:100%;height:100%;object-fit:cover;display:block}
.galeria .foto .rm{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:13px;line-height:1}
.up-area{border:1.5px dashed var(--cinza-borda-2);border-radius:9px;padding:14px;text-align:center;color:var(--texto-mid);font-size:13px;cursor:pointer}
.up-area:hover{border-color:var(--tinta);background:#fafbfc}

/* Comentários */
.coment{background:#f7f8fa;border:1px solid var(--cinza-borda);border-radius:8px;padding:9px 12px;margin-bottom:8px;font-size:13px}
.coment .meta{font-size:11px;color:var(--texto-fraco);margin-bottom:3px}
.coment .meta b{color:var(--texto-mid)}
.coment-form{display:flex;gap:8px;margin-top:6px}
.coment-form textarea{flex:1;border:1px solid var(--cinza-borda-2);border-radius:7px;padding:9px;font-size:13px;font-family:inherit;resize:vertical;min-height:42px;outline:none}
.coment-form textarea:focus{border-color:var(--tinta)}

/* Toast */
#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--tinta);color:#fff;padding:11px 20px;border-radius:9px;font-size:13.5px;box-shadow:var(--s2);z-index:500;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
#toast.on{opacity:1;transform:translateX(-50%) translateY(-4px)}
#toast.err{background:var(--err)}
#toast.ok{background:var(--ok)}

.aviso-info{background:var(--info-bg);border:1px solid #bcd9f5;color:#0a4f96;border-radius:8px;padding:10px 13px;font-size:12.5px;margin-bottom:14px}
.loading{padding:40px;text-align:center;color:var(--texto-fraco)}
@media(max-width:760px){
  .sidenav{display:none}
  .content{padding:16px}
  .dl{grid-template-columns:1fr}
}
