*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0f172a;--s1:#1e293b;--s2:#263548;--bd:#334155;--bl:#3b82f6;--bll:#60a5fa;--gn:#22c55e;--yw:#f59e0b;--rd:#ef4444;--tx:#e2e8f0;--tm:#94a3b8;--ac:#6366f1}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--tx);min-height:100vh}
a{color:inherit;text-decoration:none}
.hdr{background:var(--s1);border-bottom:1px solid var(--bd);padding:0 20px;display:flex;align-items:center;gap:12px;height:52px;position:sticky;top:0;z-index:100}
.hdr-logo{width:30px;height:30px;background:var(--bl);border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:12px;color:#fff;flex-shrink:0}
.hdr-ttl{font-size:13px;font-weight:700}.hdr-sub{font-size:10px;color:var(--tm)}
.hdr-sep{flex:1}
.bc{font-size:11px;color:var(--tm);display:flex;align-items:center;gap:5px}
.bc .bca{color:var(--bll)}.bc a{cursor:pointer}.bc a:hover{color:var(--tx)}
.btn-bk{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:var(--s2);border:1px solid var(--bd);border-radius:6px;color:var(--tx);font-size:11px;cursor:pointer;transition:.2s;text-decoration:none}
.btn-bk:hover{background:var(--bd)}

.hc{padding:24px 20px}
.sec-t{font-size:11px;font-weight:600;color:var(--tm);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pcard{background:var(--s1);border:1px solid var(--bd);border-radius:10px;padding:18px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;text-decoration:none;color:inherit;display:block}
.pcard:hover:not(.dis){border-color:var(--bl);transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,130,246,.15)}
.pcard.dis{opacity:.4;cursor:not-allowed;pointer-events:none}
.pcard.sp{border-color:var(--ac);background:linear-gradient(135deg,#1e293b,#1e1b4b)}
.pcard.sp:hover{border-color:#818cf8;box-shadow:0 6px 20px rgba(99,102,241,.2)}
.pcard.lv{border-color:rgba(59,130,246,.4)}
.pnum{font-size:24px;font-weight:900;color:var(--bl);line-height:1;margin-bottom:7px}
.pcard.sp .pnum{color:#818cf8}.pcard.dis .pnum{color:var(--tm)}
.pnm{font-size:11px;color:var(--tm);line-height:1.4}
.cbdg{position:absolute;top:10px;right:10px;padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700}
.bdg-na{background:#374151;color:#9ca3af}.bdg-dev{background:rgba(59,130,246,.12);color:var(--bll)}.bdg-lv{background:rgba(34,197,94,.12);color:#86efac}

.shdr{padding:18px 20px 0;display:flex;align-items:flex-start;gap:12px}
.shdr h1{font-size:18px;font-weight:700}.shdr p{font-size:11px;color:var(--tm);margin-top:3px}
.sbdy{padding:16px 20px 28px}

.fbar{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:12px 14px;display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:16px}
.fg{display:flex;flex-direction:column;gap:3px}.fl{font-size:10px;color:var(--tm)}
.fs{background:var(--s2);border:1px solid var(--bd);border-radius:5px;color:var(--tx);padding:5px 8px;font-size:11px;cursor:pointer;min-width:140px}
.fs[type=submit]{background:var(--bl);border-color:var(--bl);color:#fff;font-weight:600}

.krow{display:grid;gap:12px;margin-bottom:16px}
.kc{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:14px 16px}
.kl{font-size:10px;color:var(--tm);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.kv{font-size:28px;font-weight:800;line-height:1}.ks{font-size:10px;color:var(--tm);margin-top:5px}
.kb{border-left:3px solid var(--bl)}.kbl .kv{color:var(--bll)}
.ky{border-left:3px solid var(--yw)}.kyl .kv{color:var(--yw)}
.kg{border-left:3px solid var(--gn)}.kgl .kv{color:var(--gn)}
.kr{border-left:3px solid var(--rd)}.krl .kv{color:#f87171}

.sc{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:14px;margin-bottom:14px}
.st{font-size:12px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:7px}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

table{width:100%;border-collapse:collapse;font-size:11px}
th{text-align:left;padding:7px 10px;color:var(--tm);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--bd)}
td{padding:9px 10px;border-bottom:1px solid rgba(51,65,85,.4)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}

.sb{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700}
.br{background:rgba(239,68,68,.15);color:#fca5a5}.by{background:rgba(245,158,11,.15);color:#fcd34d}
.bg{background:rgba(34,197,94,.15);color:#86efac}.bb{background:rgba(59,130,246,.15);color:#93c5fd}
.bgr{background:rgba(148,163,184,.15);color:var(--tm)}

.tl{display:inline-flex;align-items:center;gap:5px}
.tld{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.tlr{background:var(--rd);box-shadow:0 0 5px rgba(239,68,68,.5)}
.tly{background:var(--yw);box-shadow:0 0 5px rgba(245,158,11,.5)}
.tlg{background:var(--gn);box-shadow:0 0 5px rgba(34,197,94,.5)}

.rb{padding:2px 7px;border-radius:4px;font-size:9px;font-weight:700}
.rc{background:rgba(239,68,68,.2);color:#f87171;border:1px solid rgba(239,68,68,.3)}
.ri{background:rgba(245,158,11,.2);color:#fbbf24;border:1px solid rgba(245,158,11,.3)}
.rr{background:rgba(34,197,94,.2);color:#4ade80;border:1px solid rgba(34,197,94,.3)}

.pb{height:5px;background:var(--bd);border-radius:3px;overflow:hidden;margin-top:5px}
.pf{height:100%;border-radius:3px}

.crow{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:16px}
.cc{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:14px}
.ct{font-size:12px;font-weight:600;margin-bottom:3px}.cst{font-size:10px;color:var(--tm);margin-bottom:12px}

.fd{background:linear-gradient(135deg,#1e293b,#1a1f35);border:1px solid var(--bd);border-radius:8px;padding:16px;width:100%}

.tag{display:inline-block;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:600}
.ta{background:rgba(99,102,241,.2);color:#a5b4fc}.tv{background:rgba(59,130,246,.2);color:#93c5fd}

.cgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.cadc{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:14px}
.cadt{font-size:12px;font-weight:600;margin-bottom:10px;color:#818cf8}
.cadi{padding:5px 0;font-size:11px;color:var(--tm);border-bottom:1px solid rgba(51,65,85,.4);display:flex;justify-content:space-between;align-items:center}
.cadi:last-child{border-bottom:none}.ctg{background:var(--s2);padding:1px 5px;border-radius:3px;font-size:9px;color:var(--bll)}

.nacc{margin-bottom:8px;border:1px solid var(--bd);border-radius:7px;overflow:hidden}
.nacc-hdr{background:var(--s2);padding:8px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:600;user-select:none;transition:.2s}
.nacc-hdr:hover{background:rgba(59,130,246,.08)}
.nacc-body{display:none;padding:8px 12px;background:var(--bg)}
.nacc-body.open{display:block}
.nrow{display:flex;align-items:flex-start;gap:8px;padding:5px 0;border-bottom:1px solid rgba(51,65,85,.3);font-size:10px}
.nrow:last-child{border-bottom:none}
.nnum{color:var(--bll);font-weight:700;flex-shrink:0;width:26px;font-size:9px}
.ntxt{color:var(--tm);line-height:1.4;flex:1}
.ntxt strong{color:var(--tx)}
.ndoc{display:inline-flex;align-items:center;justify-content:center;width:24px;height:20px;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0;cursor:pointer;user-select:none;transition:.15s;border:1px solid transparent}
.ndoc.nok{background:rgba(34,197,94,.15);color:var(--gn);border-color:rgba(34,197,94,.35);cursor:default}
.ndoc.nmiss{background:rgba(245,158,11,.12);color:var(--yw);border-color:rgba(245,158,11,.3)}
.ndoc.nmiss:hover{background:rgba(245,158,11,.22);color:#fbbf24}
.ndoc.nok:hover{background:rgba(34,197,94,.22)}

.muni-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;max-height:260px;overflow-y:auto;padding-right:4px}
.muni-item{padding:5px 7px;font-size:10px;color:var(--tm);border-bottom:1px solid rgba(51,65,85,.25);display:flex;justify-content:space-between;align-items:center}
.muni-item:hover{color:var(--tx);background:rgba(255,255,255,.02)}

.dvs{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:55vh;gap:12px}
.dvi{font-size:56px}.dvt{font-size:18px;font-weight:700;color:var(--tm)}.dvs2{font-size:12px;color:var(--tm);opacity:.7;text-align:center;max-width:520px}

.mov{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:9999;display:none;align-items:center;justify-content:center}
.mov.op{display:flex}
.mod{background:var(--s1);border:1px solid var(--bd);border-radius:14px;padding:22px;width:560px;max-height:80vh;overflow-y:auto}
.mhdr{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.mcls{background:var(--s2);border:1px solid var(--bd);color:var(--tx);border-radius:5px;padding:3px 9px;cursor:pointer}
.docr{display:flex;align-items:center;gap:8px;padding:7px;background:var(--s2);border-radius:5px;margin-bottom:5px;font-size:11px}

.t2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}

@media (max-width:1100px){
    .pgrid{grid-template-columns:repeat(2,1fr)}
    .crow{grid-template-columns:1fr}
    .cgrid{grid-template-columns:1fr}
    .t2{grid-template-columns:1fr}
}

.c10map{height:420px;width:100%;border-radius:7px;border:1px solid var(--bd);background:#0a1224;margin-top:4px}
.c10map .leaflet-popup-content-wrapper{background:#f1f5f9;color:#0f172a;border-radius:6px;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.c10map .leaflet-popup-tip{background:#f1f5f9}
.c10map .leaflet-container{font-family:'Segoe UI',system-ui,sans-serif;background:#0a1224}
.c10map .leaflet-control-attribution{background:rgba(15,23,42,.7);color:var(--tm);font-size:9px}
.c10map .leaflet-control-attribution a{color:var(--bll)}
.maplg{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;padding:8px 12px;background:var(--s2);border-radius:6px;font-size:10px;color:var(--tm);align-items:center}
.maplg-i{display:inline-flex;align-items:center;gap:5px}
.maplg-dot{width:9px;height:9px;border-radius:50%;display:inline-block;border:1px solid rgba(0,0,0,.4)}
.maplg-seg{width:18px;height:3px;background:#f43f5e;display:inline-block;border-radius:2px;box-shadow:0 0 4px rgba(244,63,94,.6)}

.mod-lg{width:720px;max-width:92vw}
.bnaf{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bnaf-c{background:var(--s2);border:1px solid var(--bd);border-radius:7px;overflow:hidden;display:flex;flex-direction:column}
.bnaf-h{padding:7px 10px;background:rgba(59,130,246,.08);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;gap:8px}
.bnaf-t{font-size:11px;font-weight:700;color:var(--bll);letter-spacing:.04em}
.bnaf-s{font-size:9px;color:var(--tm)}
.bnaf-b{padding:10px;min-height:130px;display:flex;align-items:center;justify-content:center}
.phold{font-size:10px;color:var(--tm);text-align:center;padding:14px 8px;border:1px dashed var(--bd);border-radius:5px;width:100%;line-height:1.5}
.phold-ok{color:#86efac;border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.05)}
.phold-w{color:#fcd34d;border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.05)}
.phold-l{font-size:11px;color:var(--tm);font-style:italic;padding:10px 12px;background:var(--s2);border:1px dashed var(--bd);border-radius:5px}
.mftr{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:1px solid var(--bd)}
.btn-pr{background:var(--bl);border-color:var(--bl);color:#fff}
.btn-pr:hover{background:var(--bll);border-color:var(--bll)}

@media (max-width:680px){.bnaf{grid-template-columns:1fr}}

.pgr{display:flex;gap:5px;justify-content:center;align-items:center;margin-top:14px;flex-wrap:wrap}
.pgb{padding:5px 10px;background:var(--s2);border:1px solid var(--bd);border-radius:5px;color:var(--tx);font-size:11px;cursor:pointer;text-decoration:none;transition:.15s}
.pgb:hover{background:var(--bd);border-color:var(--bll);color:var(--bll)}
.pga{background:var(--bl);border-color:var(--bl);color:#fff;font-weight:600}
.pga:hover{background:var(--bl);border-color:var(--bl);color:#fff}
.pgd{opacity:.35;pointer-events:none}
.pgs{color:var(--tm);font-size:11px;padding:0 4px}

.gtl{position:relative;padding:18px 6px 6px;overflow-x:auto}
.gtl-axis{position:absolute;left:6px;right:6px;top:46px;height:2px;background:var(--bd);border-radius:1px}
.gtl-points{position:relative;display:flex;gap:18px;min-width:100%;padding:0 4px}
.gtl-pt{flex:1 0 78px;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}
.gtl-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--s1);box-shadow:0 0 0 1px var(--bd);margin-top:32px}
.gtl-bl{background:var(--bl);box-shadow:0 0 0 1px var(--bl),0 0 8px rgba(59,130,246,.5)}
.gtl-gn{background:var(--gn);box-shadow:0 0 0 1px var(--gn),0 0 8px rgba(34,197,94,.5)}
.gtl-yw{background:var(--yw);box-shadow:0 0 0 1px var(--yw),0 0 8px rgba(245,158,11,.5)}
.gtl-rd{background:var(--rd);box-shadow:0 0 0 1px var(--rd),0 0 8px rgba(239,68,68,.5)}
.gtl-tm{background:var(--tm);box-shadow:0 0 0 1px var(--tm)}
.gtl-v{font-size:11px;font-weight:700;color:var(--tx);margin-top:6px}
.gtl-d{font-size:9px;color:var(--tm);margin-top:2px;white-space:nowrap}

/* Sub-nav tabs (Produto D) */
.dtabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.dtab{display:inline-flex;align-items:center;gap:5px;padding:6px 11px;background:var(--s1);border:1px solid var(--bd);border-radius:6px;font-size:11px;color:var(--tm);cursor:pointer;transition:.15s;text-decoration:none}
.dtab:hover{background:var(--s2);color:var(--tx);border-color:var(--bl)}
.dtab.on{background:rgba(59,130,246,.12);border-color:var(--bl);color:var(--bll);font-weight:600}

/* Heatmap obra × mês */
.hm{display:grid;gap:1px;background:var(--bd);border:1px solid var(--bd);border-radius:6px;overflow:hidden;font-size:10px}
.hm-row{display:grid;grid-template-columns:260px repeat(12,1fr);background:var(--s1)}
.hm-h{padding:6px 4px;color:var(--tm);font-weight:600;font-size:9px;text-transform:uppercase;letter-spacing:.05em;background:var(--s2);text-align:center}
.hm-h.l{text-align:left;padding-left:10px}
.hm-l{padding:6px 10px;color:var(--tx);font-size:10px;background:var(--s1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hm-c{padding:6px 4px;text-align:center;color:#fff;font-weight:700;font-size:10px}
.hm-c.e0{background:var(--s2);color:var(--tm)}
.hm-c.e1{background:rgba(34,197,94,.18);color:#86efac}
.hm-c.e2{background:rgba(34,197,94,.4);color:#fff}
.hm-c.e3{background:rgba(245,158,11,.45);color:#fff}
.hm-c.e4{background:rgba(239,68,68,.55);color:#fff}
.hm-c.e5{background:rgba(239,68,68,.85);color:#fff}

/* Gantt */
.gantt-wrap{overflow-x:auto;padding-bottom:8px}
.gantt{min-width:900px;background:var(--s1);border:1px solid var(--bd);border-radius:6px}
.gantt-row{display:grid;grid-template-columns:300px 1fr;border-bottom:1px solid rgba(51,65,85,.5)}
.gantt-row:last-child{border-bottom:none}
.gantt-row.h{background:var(--s2);border-bottom:1px solid var(--bd)}
.gantt-name{padding:8px 10px;font-size:11px;color:var(--tx);display:flex;flex-direction:column;gap:2px;overflow:hidden;border-right:1px solid var(--bd)}
.gantt-name .gn-t{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-name .gn-s{font-size:9px;color:var(--tm)}
.gantt-track{position:relative;height:40px}
.gantt-axis{position:relative;height:30px;font-size:9px;color:var(--tm)}
.gantt-axis span{position:absolute;top:8px;transform:translateX(-50%);white-space:nowrap}
.gantt-bar{position:absolute;top:10px;height:20px;border-radius:4px;display:flex;align-items:center;padding:0 6px;font-size:9px;color:#fff;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.gantt-today{position:absolute;top:0;bottom:0;width:1px;background:var(--rd);box-shadow:0 0 6px rgba(239,68,68,.6);z-index:3;pointer-events:none}
.gantt-today::after{content:'hoje';position:absolute;top:-12px;left:3px;font-size:9px;color:#fca5a5;font-weight:700;white-space:nowrap}
.gst-em_execucao{background:var(--yw)}
.gst-vencida{background:var(--rd)}
.gst-concluida{background:var(--gn)}
.gst-agendada{background:var(--bl)}
.gst-sem_plano{background:var(--bd)}
.gst-sem_cronograma{background:var(--bd)}

/* Treemap PER */
.tm{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.tm-cell{background:var(--s2);border:1px solid var(--bd);border-radius:6px;padding:12px 10px;color:var(--tx);font-size:11px;display:flex;flex-direction:column;justify-content:space-between;min-height:96px;transition:.15s}
.tm-cell:hover{border-color:var(--bl);transform:translateY(-1px)}
.tm-code{font-size:10px;color:var(--tm);font-weight:600;letter-spacing:.04em}
.tm-desc{font-size:11px;color:var(--tx);line-height:1.3;margin:5px 0 7px}
.tm-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:6px}
.tm-qty{font-size:22px;font-weight:800;color:var(--bll);line-height:1}
.tm-fd{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;background:rgba(245,158,11,.15);color:var(--yw)}
.tm-fd.b{background:rgba(34,197,94,.15);color:#86efac}
.tm-fd.r{background:rgba(239,68,68,.15);color:#fca5a5}

/* Funil */
.fun{display:flex;flex-direction:column;align-items:center;gap:5px;padding:14px}
.fun-row{border-radius:6px;padding:12px 16px;color:#fff;font-weight:700;display:flex;justify-content:space-between;align-items:center;gap:14px;min-height:46px}
.fun-row .l{font-size:13px}
.fun-row .v{font-size:20px;font-weight:900}
.fun-row .p{font-size:10px;opacity:.85;margin-left:6px}

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

/* ==== Polimento visual (mai/2026) ==== */

/* Gantt-axis: labels mensais sobrepostos -> rotacionar -45° */
.gantt-axis{height:46px}
.gantt-axis span{top:8px;transform:translate(-50%,0) rotate(-45deg);transform-origin:50% 0;font-size:9px;letter-spacing:.02em}

/* KPIs responsivos: sobrescreve grid-template-columns inline em telas estreitas */
@media (max-width:900px){
    .krow[style*="grid-template-columns"]{grid-template-columns:repeat(3,1fr)!important}
}
@media (max-width:680px){
    .krow[style*="grid-template-columns"]{grid-template-columns:repeat(2,1fr)!important}
    .kv{font-size:22px}
    .kl{font-size:9px}
    .ks{font-size:9px}
}
@media (max-width:420px){
    .krow[style*="grid-template-columns"]{grid-template-columns:1fr!important}
}

/* Quebra suave de strings longas (nomes de arquivos, IDs) dentro de cards */
.kc,.bnaf-c,.cadi,.sc{overflow-wrap:anywhere}

/* Long word fix para .gn-t Obra · Rodovia em gantt mobile */
.gantt-name{min-width:0}

/* Tabela responsiva: tabelas soltas dentro de cards ganham scroll horizontal em telas estreitas */
@media (max-width:900px){
    .sc > table{display:block;overflow-x:auto;white-space:nowrap;width:auto}
    .sc > table th,.sc > table td{white-space:nowrap}
}

/* Timeline gtl: scroll horizontal limpo */
.gtl{scrollbar-color:var(--bd) var(--bg)}

/* Mobile: filtros (fbar) ficam em uma coluna */
@media (max-width:680px){
    .fbar{flex-direction:column;align-items:stretch}
    .fbar .fg{width:100%}
    .fbar .fs{width:100%;min-width:0}
}

/* Mobile: dtabs já tem flex-wrap, mas garante tamanho mínimo confortável */
@media (max-width:680px){
    .dtabs{gap:5px}
    .dtab{font-size:10px;padding:5px 9px}
}

/* Foco visível em links/botões para acessibilidade básica */
a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,.dtab:focus-visible,.pcard:focus-visible{outline:2px solid var(--bl);outline-offset:2px;border-radius:6px}

/* Hover mais nítido nas linhas de tabela clicáveis */
tr[onclick]{cursor:pointer}
tr[onclick]:hover td{background:rgba(59,130,246,.06)}

/* Modal: max-width responsiva e backdrop blur */
.mod{max-width:92vw}
.mov{backdrop-filter:blur(2px)}

/* Estado vazio com ícone centralizado */
.dvs{text-align:center}

/* Mobile: krow gerais (sem inline) -> auto-fit */
@media (max-width:680px){
    .krow:not([style*="grid-template-columns"]){grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
}

/* Foto da inspeção C10 (modal) */
.bnaf-img{display:block;width:100%;border-radius:5px;overflow:hidden;background:#0a1224;line-height:0}
.bnaf-img img{display:block;width:100%;max-height:240px;object-fit:cover;cursor:zoom-in;transition:transform .25s}
.bnaf-img:hover img{transform:scale(1.02)}

