/* ============================================
   INCÊNDIOS RURAIS — Stylesheet v2
   Mobile-first, bottom nav, card list mobile
   ============================================ */
:root{--text:#0f172a;--muted:#64748b;--muted2:#94a3b8;--border:rgba(15,23,42,.1);--border2:#e2e8f0;--shadow:0 8px 32px rgba(15,23,42,.08);--shadow2:0 1px 3px rgba(15,23,42,.06);--shadow-lg:0 20px 50px rgba(15,23,42,.12);--radius:16px;--radius-sm:10px;--radius-xs:6px;--red:#dc2626;--red-dark:#b91c1c;--red-deep:#991b1b;--blue:#2563eb;--green:#16a34a;--amber:#f59e0b;--orange:#f97316;--font:'DM Sans',ui-sans-serif,system-ui,-apple-system,sans-serif;--headerH:56px;--bottomH:0px}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{height:100%}
body{margin:0;font-family:var(--font);color:var(--text);font-size:14px;line-height:1.5;overflow-x:hidden;background:radial-gradient(ellipse 1200px 800px at 12% -10%,rgba(59,130,246,.1),transparent 55%),radial-gradient(ellipse 1000px 700px at 88% 0%,rgba(220,38,38,.1),transparent 55%),linear-gradient(180deg,#f8fafc,#f1f5f9);padding-bottom:var(--bottomH)}
@supports(padding:max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}}
img,svg,canvas{max-width:100%;height:auto}

/* === TYPOGRAPHY === */
h1,h2,h3,h4,h5,h6,p{margin:0}
h1{font-size:2rem;line-height:1.2;font-weight:800}
h2{font-size:1.75rem;line-height:1.25;font-weight:800}
h3{font-size:1.5rem;line-height:1.3;font-weight:700}
h4{font-size:1.25rem;line-height:1.35;font-weight:700}
h5{font-size:1.1rem;line-height:1.4;font-weight:700}
h6{font-size:1rem;line-height:1.45;font-weight:700}
p{font-size:1rem;line-height:1.6}

/* === HEADER === */
header{position:sticky;top:0;z-index:1000;padding-top:env(safe-area-inset-top)}
.topbar{height:var(--headerH);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 16px;background:rgba(255,255,255,.88);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--border);box-shadow:0 1px 3px rgba(15,23,42,.04)}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#fff,#f1f5f9);display:grid;place-items:center;border:1px solid var(--border);flex-shrink:0}
.brandTitle{font-weight:800;font-size:15px;letter-spacing:-.2px}
.rightInfo{display:flex;align-items:center;gap:8px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.9);font-size:12px;font-weight:600;color:var(--muted)}
.dotLive{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 3px rgba(220,38,38,.15);animation:livePulse 2s ease-in-out infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 3px rgba(220,38,38,.15)}50%{box-shadow:0 0 0 6px rgba(220,38,38,.06)}}

/* Desktop nav */
.desktopNav{display:flex;align-items:center;gap:4px}
.menuBtn{display:inline-flex;align-items:center;justify-content:center;padding:7px 14px;border:1px solid transparent;border-radius:8px;background:0;font-family:var(--font);font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;white-space:nowrap}
.menuBtn:hover{background:rgba(15,23,42,.04);color:var(--text)}
.menuBtn.active{background:var(--text);color:#fff;border-color:var(--text)}

/* === MAIN === */
main{width:100%;max-width:100%;margin:0 auto;padding:16px 20px 24px}

/* === KPI CARDS === */
.kpiGrid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px}
.kpiCard{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;background:#fff;border-radius:var(--radius);padding:20px 16px;border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;overflow:hidden}
.kpiCard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.kpiTop{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.kpiTopInline{flex-direction:row}
.kpiIcon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px solid var(--border);flex-shrink:0}
.kpiLabel{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.kpiValue{font-size:34px;font-weight:800;letter-spacing:-1.5px;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}
.kpiCard.total{background:linear-gradient(135deg,var(--red),var(--red-dark));border-color:rgba(185,28,28,.4)}
.kpiCard.total .kpiLabel{color:rgba(255,255,255,.85)}
.kpiCard.total .kpiValue{color:#fff}
.kpiCard.total .kpiIcon{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.2)}

/* === PANEL === */
.panel{background:rgba(255,255,255,.92);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;backdrop-filter:blur(8px);margin-bottom:16px}

/* === FILTERS === */
.filterMenuBar{display:none;align-items:center;gap:10px;margin-bottom:12px}
.filterMenuBtn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-family:var(--font);font-size:13px;font-weight:700;color:var(--text);cursor:pointer}
.filterSummary{font-size:12px;color:var(--muted);font-weight:600}
.filtersCard.is-collapsed{display:none}
.filters{display:grid;gap:10px;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr 1fr .9fr;margin-bottom:12px}
.field label{display:block;font-size:11px;color:var(--muted);margin-bottom:4px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.filters .field label{font-size:9px;letter-spacing:.2px;margin-bottom:3px}
input,select{width:100%;padding:10px 12px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;background:#fff;color:var(--text);outline:0;transition:border-color .15s,box-shadow .15s}
.filters input,.filters select{font-size:12px;padding:7px 9px;line-height:1.35}
input:focus,select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1)}

/* === TOOLBAR === */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.btnrow{display:flex;gap:8px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:var(--radius-sm);border:1px solid var(--red-dark);background:linear-gradient(180deg,var(--red),var(--red-dark));color:#fff;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px rgba(220,38,38,.15)}
.btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.secondary{background:#fff;color:var(--text);border:1px solid var(--border2);box-shadow:var(--shadow2)}
.btn.secondary:hover{background:#f8fafc}
.btn.notify-on{background:linear-gradient(180deg,var(--green),#15803d);border-color:#166534;color:#fff}
.meta{font-size:12px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.sep{opacity:.4}
#statusMsg{display:block;margin:0 0 12px;padding:12px 14px;border:1px solid var(--border2);background:#fff;border-radius:var(--radius-sm);color:var(--muted);font-size:13px}
#notifyHelper{margin:0 0 12px;padding:12px 16px;border:1px solid rgba(185,28,28,.12);background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(254,242,242,.96));border-radius:var(--radius-sm);color:#7f1d1d;font-size:13px;line-height:1.5}
#pushStatusBar{display:none;margin:0 0 10px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px}
#pushStatusBar.active{display:flex;flex-direction:column;gap:4px}

/* === TABLE (desktop) === */
.tableWrap{border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;background:#fff;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow2)}
.occTable{width:100%;min-width:1060px;border-collapse:separate;border-spacing:0;font-size:13px;table-layout:fixed}
.occTable thead th{position:sticky;top:0;z-index:2;background:linear-gradient(180deg,#f8fafc 0%,#f1f5f9 100%);color:#475569;font-size:10px;font-weight:800;text-align:center;padding:11px 8px;border-bottom:1px solid rgba(15,23,42,.1);white-space:nowrap;letter-spacing:.04em;text-transform:uppercase;vertical-align:middle;box-shadow:0 1px 0 rgba(15,23,42,.06)}
.occTable thead th:first-child{border-top-left-radius:var(--radius)}
.occTable thead th:last-child{border-top-right-radius:var(--radius)}
.occTable .th-sort{cursor:pointer;user-select:none;transition:background .12s,color .12s}
.occTable .th-sort:hover{background:#e2e8f0;color:var(--text)}
.occTable .th-sort .th-inner{display:inline-flex;align-items:center;justify-content:center;gap:4px;max-width:100%}
.occTable .th-text{text-align:left;padding-left:12px;padding-right:10px}
.occTable .th-num,.occTable .td-num{text-align:center;font-variant-numeric:tabular-nums;width:2.75rem;min-width:2.5rem;max-width:3rem;padding-left:4px;padding-right:4px}
.occTable .th-estado{width:180px;min-width:180px;max-width:180px}
.arr{font-size:9px;opacity:.55;font-weight:800}
.occTable tbody td{padding:11px 8px;border-top:1px solid rgba(15,23,42,.05);text-align:center;vertical-align:middle;font-size:13px;line-height:1.35;color:var(--text);overflow:hidden;text-overflow:ellipsis}
.occTable tbody td:nth-child(2),.occTable tbody td:nth-child(7),.occTable thead .th-text{text-align:left}
.occTable tbody td:nth-child(2){padding-left:12px}
.occTable tbody td:nth-child(7){padding-left:12px;color:#334155}
.occTable .td-estado{text-align:center;padding:8px 10px;vertical-align:middle;width:180px;min-width:180px;max-width:180px;overflow:visible}
.occTable .td-num{font-weight:700;font-size:13px;color:#1e293b}
.occTable tbody tr{cursor:pointer;transition:background .12s,box-shadow .12s}
.occTable tbody tr:hover{background:rgba(37,99,235,.055)}
.occTable tbody tr:nth-child(even){background:rgba(248,250,252,.85)}
.occTable tbody tr:nth-child(even):hover{background:rgba(37,99,235,.055)}
.occTable tbody tr.selected{background:rgba(220,38,38,.07);box-shadow:inset 3px 0 0 var(--red)}
.row2date{display:flex;flex-direction:column;gap:3px;text-align:center;align-items:center}
.row2date .d1{font-weight:800;font-size:12px;letter-spacing:-.02em;color:var(--text)}
.row2date .d2{font-size:11px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums}
.clamp2{overflow:hidden;}
.occTable td.table-empty,.occTable .table-empty{text-align:center;padding:28px 16px;color:var(--muted);font-weight:600;font-size:13px;background:rgba(248,250,252,.6)}
.estadoBadge.estadoBadge--table{max-width:100%;width:100%;min-height:26px;margin:0 auto;justify-content:center;align-items:center;flex-wrap:nowrap;gap:6px;box-shadow:0 1px 3px rgba(15,23,42,.12);border:1px solid rgba(255,255,255,.22)}
.estadoBadge.estadoBadge--table .dot{flex-shrink:0}
.estadoBadge.estadoBadge--table .estadoBadge__txt{white-space:normal;overflow:visible;line-height:1.25;word-break:break-word;flex:1 1 auto;min-width:0;text-align:left;font-size:11px;font-weight:800;letter-spacing:.02em}
tfoot td.prociv-totals{text-align:right;font-weight:800;padding:12px 16px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-top:2px solid rgba(185,28,28,.35);font-size:12px;letter-spacing:.02em;color:#334155}

/* === MOBILE CARD LIST === */
.mobileCardList{display:none;flex-direction:column;gap:10px}
.occCard{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px;box-shadow:var(--shadow2);cursor:pointer;transition:transform .12s,box-shadow .12s;position:relative;overflow:hidden}
.occCard:active{transform:scale(.98)}
.occCard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px}
.occCard.st-curso::before{background:var(--red)}
.occCard.st-resolucao::before{background:var(--blue)}
.occCard.st-conclusao::before{background:var(--green)}
.occCard.st-despacho::before{background:var(--orange)}
.occCard.st-vigilancia::before{background:var(--amber)}
.occCardHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}
.occCardNature{font-size:14px;font-weight:800;color:var(--text);line-height:1.2}
.occCardBadge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--radius-xs);font-size:10px;font-weight:700;color:#fff;white-space:nowrap;flex-shrink:0}
.occCardBadge.st-curso{background:var(--red)}
.occCardBadge.st-resolucao{background:var(--blue)}
.occCardBadge.st-conclusao{background:var(--green)}
.occCardBadge.st-despacho{background:var(--orange)}
.occCardBadge.st-vigilancia{background:var(--amber)}
.occCardLocation{font-size:12px;color:var(--muted);margin-bottom:8px;line-height:1.3}
.occCardMeta{display:flex;gap:12px;font-size:12px;color:var(--text);font-weight:600}
.occCardMeta span{display:flex;align-items:center;gap:3px}
.occCardDate{font-size:11px;color:var(--muted2);margin-top:6px}

/* === STATUS BADGES === */
.statusBadge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:var(--radius-xs);font-weight:700;font-size:11px;color:#fff;border:0;white-space:nowrap}
.statusBadge.estado-curso{background:var(--red)}
.statusBadge.estado-resolucao{background:var(--blue)}
.statusBadge.estado-conclusao{background:var(--green)}
.statusBadge.estado-despacho{background:var(--orange)}
.statusBadge.estado-vigilancia{background:var(--amber)}
.estadoBadge,.badge-estado{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-weight:800;font-size:12px;color:#fff}
.estadoBadge .dot,.badge-estado .dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.9)}
.estadoBadge--curso{background:linear-gradient(180deg,var(--red),var(--red-dark))}
.estadoBadge--resolucao{background:linear-gradient(180deg,var(--blue),#1d4ed8)}
.estadoBadge--conclusao{background:linear-gradient(180deg,var(--green),#15803d)}
.estadoBadge--vigilancia{background:linear-gradient(180deg,var(--amber),#d97706)}
.estadoBadge--despacho{background:linear-gradient(180deg,var(--orange),#ea580c)}

/* === PAGER === */
.pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px}
.pbtn{padding:9px 16px;border:1px solid var(--border2);border-radius:var(--radius-sm);background:#fff;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:all .12s}
.pbtn:hover{background:#f8fafc;transform:translateY(-1px)}
.pbtn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.pinfo{font-size:13px;color:var(--muted);font-weight:600}

/* === TOTALS CARDS === */
.sectionTitle{font-weight:800;letter-spacing:.5px;text-transform:uppercase;font-size:11px;color:var(--muted);margin-bottom:10px}
#sec-estados{margin-bottom:16px}
.stateTotalsBar{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.stateCard{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow2);min-width:0}
.stateCard .left{display:flex;align-items:center;gap:8px;min-width:0}
.stateCard .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.stateCard .label{font-size:12px;font-weight:700;color:var(--text)}
.stateCard .val{font-size:20px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums}
.stateCard.vigilancia{background:linear-gradient(90deg,rgba(245,158,11,.1),#fff 65%);border-color:rgba(245,158,11,.2)}
.stateCard.vigilancia .dot{background:var(--amber)}
.stateCard.curso{background:linear-gradient(90deg,rgba(220,38,38,.1),#fff 65%);border-color:rgba(220,38,38,.2)}
.stateCard.curso .dot{background:var(--red)}
.stateCard.resolucao{background:linear-gradient(90deg,rgba(37,99,235,.08),#fff 65%);border-color:rgba(37,99,235,.18)}
.stateCard.resolucao .dot{background:var(--blue)}
.stateCard.concluida{background:linear-gradient(90deg,rgba(22,163,74,.08),#fff 65%);border-color:rgba(22,163,74,.18)}
.stateCard.concluida .dot{background:var(--green)}
.mapTotalsLayout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(520px,1fr);gap:16px;align-items:stretch;margin-bottom:16px}
.dashboardCol{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.dashboardCol .panel{margin-bottom:0}
.subRegionGrid,.natureGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.subRegionCard,.natureCard{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow2);min-width:0}
.subRegionCard .name,.natureCard .name{font-size:12px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.subRegionCard .val,.natureCard .val{font-size:18px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums;flex-shrink:0}
.natureCard .left{display:flex;align-items:center;gap:8px;min-width:0}
.natureCard .dot{width:8px;height:8px;border-radius:50%;background:var(--muted2);flex-shrink:0}

/* === MAP === */
.mapSection{margin:0}
.mapCard{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;padding:12px}
.mapTotalsLayout .mapCard{height:100%;display:flex;flex-direction:column}
.mapHeaderRow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.mapHeaderTitle{font-size:14px;font-weight:800;color:var(--text)}
.mapHeaderSub{font-size:12px;color:var(--muted);margin-top:2px}
.mapLegend{display:flex;gap:6px;flex-wrap:wrap}
.mapLegendItem{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-family:var(--font);font-size:11px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .12s}
.mapLegendItem.is-active{color:var(--text);border-color:rgba(15,23,42,.18);box-shadow:0 4px 12px rgba(0,0,0,.06)}
.mapLegendItem:not(.is-active){opacity:.45}
.mapLegendItem .sw{width:8px;height:8px;border-radius:50%;display:inline-block}
.sw.curso{background:var(--red)}.sw.despacho{background:var(--orange)}.sw.resolucao{background:var(--blue)}.sw.concluida{background:var(--green)}.sw.risco{background:linear-gradient(135deg,#16a34a,#f59e0b,#dc2626)}
#occMap{width:100%;height:520px;border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.mapTotalsLayout #occMap{height:100%;min-height:760px}
.leaflet-popup-content{margin:10px 12px;font-family:var(--font)}
.leaflet-control-zoom,
.leaflet-control-attribution{display:none!important}
.mapPopupTitle{font-size:13px;font-weight:800;color:var(--text);margin-bottom:4px}
.mapPopupMeta{font-size:11px;color:#4b5563;line-height:1.45}
.mapPopupBadge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:800;color:#fff;margin-top:6px}
.fireMapMarkerWrap{background:transparent!important;border:0!important}
.fireMapMarker{width:28px;height:28px;display:block;position:relative;color:var(--fire-color,#dc2626);filter:drop-shadow(0 3px 8px rgba(0,0,0,.2));animation:fireMarkerPulse 1.5s ease-in-out infinite}
.fireMapMarkerSvg{width:100%;height:100%;display:block;pointer-events:none}
@keyframes fireMarkerPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* === MODAL === */
.occModal{position:fixed;inset:0;z-index:3000;display:none}
.occModal.open{display:block}
.occBackdrop{position:absolute;inset:0;background:rgba(2,6,23,.55);backdrop-filter:blur(4px)}
.occDialog{position:relative;width:min(860px,calc(100vw - 16px));max-height:calc(100dvh - 16px);margin:calc(env(safe-area-inset-top) + 8px) auto 8px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 24px 70px rgba(0,0,0,.28);overflow:hidden;display:flex;flex-direction:column}
.occHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;background:linear-gradient(135deg,var(--red-dark),var(--red-deep));color:#fff;min-height:48px;flex-shrink:0}
.occHTitle{display:flex;align-items:center;gap:8px;min-width:0;flex:1;overflow:hidden}
.occTitleNature{color:#fff;font-size:14px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.occTitleState{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:10px;font-weight:800;color:#fff;border:1px solid rgba(255,255,255,.25);flex-shrink:0}
.occClose{width:36px;height:36px;min-width:36px;border-radius:var(--radius-sm);background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;padding:0}
.occClose:hover{background:rgba(255,255,255,.2)}
.occBody{padding:12px;overflow:auto;-webkit-overflow-scrolling:touch;flex:1;background:linear-gradient(180deg,#fff,#f8fafc)}
/* Popup card */
.ppCard{border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--border)}
.ppTop{display:none}
.ppGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px;align-items:start}
.ppSpan2{grid-column:1/-1}
.ppPanel{border:1px solid var(--border);border-radius:12px;background:#fff;padding:10px}
.ppPanelTitle{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.ppPanelTitle .t{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
.ppRows{display:flex;flex-direction:column;gap:6px}
.ppRow{display:flex;gap:8px;align-items:center;padding:8px;border-radius:10px;background:rgba(15,23,42,.02);border:1px solid rgba(15,23,42,.05)}
.ppIco{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,.04);border:1px solid var(--border);font-size:14px;flex-shrink:0}
.ppKV{min-width:0;display:flex;flex-direction:column;gap:1px}
.ppK{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase}
.ppV{font-size:13px;font-weight:700;color:var(--text);word-break:break-word}
.ppV a{font-weight:800;text-decoration:none;color:var(--blue)}
.ppS{font-size:11px;color:var(--muted)}
.ppInlineRow .ppKV{flex:1;min-width:0}
.ppInlineText{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ppInlineName{font-weight:700}
.ppInlineEnd{margin-left:auto;display:inline-flex;align-items:center;gap:6px}
.ppInlineKm{font-size:10px;font-weight:700;padding:2px 6px;border-radius:999px;background:#f1f5f9;border:1px solid var(--border);color:var(--muted)}
.ppInlineAction{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;background:#fff;border:1px solid var(--border);text-decoration:none;font-size:14px}
.ppStats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ppStat{padding:10px;border-radius:12px;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid var(--border);text-align:center}
.ppStat:nth-child(1){border-top:3px solid var(--red)}
.ppStat:nth-child(2){border-top:3px solid var(--blue)}
.ppStat:nth-child(3){border-top:3px solid var(--green)}
.ppStat .v{font-size:24px;font-weight:800;color:var(--text);line-height:1}
.ppStat .k{margin-top:6px;font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase}
.ppTimelineWrap{margin-top:16px;border-top:1px solid var(--border);padding-top:14px}
.ppTimelineTitle{font-size:13px;font-weight:800;color:var(--text);margin-bottom:12px}
.ppTimeline{display:flex;flex-direction:column;gap:8px}
.ppTimelineItem{display:grid;grid-template-columns:20px 1fr;gap:10px;align-items:flex-start}
.ppTimelineRail{display:flex;flex-direction:column;align-items:center;height:100%}
.ppTimelineDot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:6px}
.ppTimelineLine{width:2px;flex:1;min-height:30px;margin-top:4px;border-radius:2px;background:linear-gradient(180deg,rgba(148,163,184,.35),rgba(148,163,184,.1))}
.ppTimelineCard{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid rgba(148,163,184,.18);border-radius:12px;padding:10px 12px}
.ppTimelineTopRow{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}
.ppTimelineDate{font-size:12px;font-weight:800;color:var(--text)}
.ppTimelineStatus{display:inline-flex;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:800}
.ppTimelineMeta{font-size:11px;color:var(--muted)}
.ppTimelineSep{color:#cbd5e1;margin:0 3px}
.ppTimelineEmpty{border:1px dashed rgba(148,163,184,.3);border-radius:12px;padding:14px;font-size:12px;color:var(--muted);background:#f8fafc;text-align:center}
.meteoGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.meteoItem{display:flex;align-items:center;gap:8px;padding:8px;border-radius:10px;background:rgba(15,23,42,.02);border:1px solid var(--border)}
.meteoIcon{font-size:18px;flex-shrink:0}
.meteoLabel{font-size:10px;font-weight:700;color:var(--muted)}
.meteoValue{font-size:13px;font-weight:800;color:var(--text)}
.riskHero{position:relative;display:flex;align-items:center;gap:14px;padding:14px;border-radius:14px;border:1px solid rgba(148,163,184,.12);background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(248,250,252,.95));box-shadow:0 12px 24px rgba(15,23,42,.06)}
.riskHeroGlow{display:none}
.riskHeroIcon{font-size:28px}
.riskHeroBody{display:flex;flex-direction:column;gap:4px;min-width:0}
.riskHeroLabel{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.riskBadge,.riskHeroBadge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:800;border:1px solid var(--border)}
.risk-low{background:rgba(22,163,74,.1);color:#166534;border-color:rgba(22,163,74,.2)}
.risk-moderate{background:rgba(245,158,11,.1);color:#92400e;border-color:rgba(245,158,11,.2)}
.risk-high{background:rgba(249,115,22,.1);color:#9a3412;border-color:rgba(249,115,22,.2)}
.risk-very-high{background:rgba(220,38,38,.1);color:#991b1b;border-color:rgba(220,38,38,.2)}
.risk-max{background:#7f1d1d;color:#fff;border-color:#7f1d1d}
.risk-na{background:rgba(100,116,139,.08);color:#475569;border-color:rgba(100,116,139,.18)}
.riskHero.risk-low{background:linear-gradient(135deg,rgba(236,253,245,.98),rgba(209,250,229,.9))}
.riskHero.risk-moderate{background:linear-gradient(135deg,rgba(254,252,232,.98),rgba(254,240,138,.85))}
.riskHero.risk-high{background:linear-gradient(135deg,rgba(255,247,237,.98),rgba(253,186,116,.85))}
.riskHero.risk-very-high{background:linear-gradient(135deg,rgba(254,242,242,.98),rgba(252,165,165,.85))}
.riskHero.risk-max{background:linear-gradient(135deg,rgba(127,29,29,.95),rgba(185,28,28,.95))}
.ppActions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:#fff}
.ppBtn{display:flex;align-items:center;justify-content:center;gap:6px;min-height:42px;border-radius:var(--radius-sm);padding:10px;font-family:var(--font);font-size:12px;font-weight:700;text-decoration:none;cursor:pointer;border:1px solid var(--border);background:#f8fafc;color:var(--text);transition:filter .12s}
.ppBtnIcon{width:16px;height:16px;object-fit:contain;flex-shrink:0}
.ppBtn:hover{filter:brightness(.97)}
.ppBtn.map{background:rgba(220,38,38,.06);border-color:rgba(220,38,38,.15)}
.ppBtn.waze{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.15)}
.ppBtn.wa{background:#25d366;color:#fff;border-color:#25d366}
.ppBtn.copy.copied{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.25)}

/* === FOOTER === */
footer{width:100%;max-width:100%;margin:0 auto;padding:16px 20px 24px;color:var(--muted);font-size:13px;text-align:center}
footer a.footerTextLink{color:var(--red-dark);text-decoration:none;font-weight:700}
footer a.footerTextLink:hover{color:var(--red);text-decoration:none}
.footerSocial{display:flex;gap:12px;align-items:center;justify-content:center;padding:14px 0 4px;flex-wrap:wrap}
.footerSocial a,.footerSocial button{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:linear-gradient(180deg,#ffffff,#f1f5f9);border:1px solid #d5dbe5;box-shadow:0 2px 8px rgba(15,23,42,.12),inset 0 1px 0 rgba(255,255,255,.9);text-decoration:none;color:#0f172a;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease}
.footerSocial a svg,.footerSocial button svg,.footerSocial a img,.footerSocial button img{width:28px;height:28px}
.footerSocial a img,.footerSocial button img{object-fit:contain;transform:scale(1.2);filter:contrast(1.18) saturate(1.18)}
.footerSocial a:hover,.footerSocial button:hover{transform:translateY(-2px);background:linear-gradient(180deg,#ffffff,#e9eef5);box-shadow:0 6px 14px rgba(15,23,42,.14),inset 0 1px 0 rgba(255,255,255,.95)}
.footerSocial a:active,.footerSocial button:active{transform:translateY(0);box-shadow:0 2px 6px rgba(15,23,42,.12),inset 0 1px 0 rgba(255,255,255,.85)}
.footerHandle{display:inline-flex;align-items:center;padding:8px 14px;border-radius:999px;background:#fff;border:1px solid var(--border);color:var(--text);font-weight:700;font-size:13px}

/* === BOTTOM NAV (mobile only) === */
.bottomNav{display:none}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1100px){
  .kpiGrid{grid-template-columns:repeat(3,1fr)}
  .filters{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:900px){
  :root{--bottomH:72px}
  .desktopNav{display:none}
  .filterMenuBar{display:flex}
  main{padding:12px 12px calc(12px + var(--bottomH))}
  .kpiGrid{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpiCard:last-child{grid-column:1/-1}
  .kpiCard{padding:14px 12px}
  .kpiIcon{width:44px;height:44px;font-size:20px}
  .kpiValue{font-size:28px}
  .filters{grid-template-columns:1fr;gap:8px}
  .toolbar{flex-direction:column;align-items:stretch}
  .btnrow{flex-direction:row;flex-wrap:wrap}
  .btn,.pbtn{min-height:44px}
  .panel{padding:12px}
  .stateTotalsBar{grid-template-columns:repeat(2,1fr);gap:6px}
  .mapTotalsLayout{grid-template-columns:1fr;gap:12px}
  .dashboardCol{grid-template-columns:1fr;gap:12px}
  .subRegionGrid,.natureGrid{grid-template-columns:repeat(2,1fr);gap:6px}
  .mapSection{margin:0}
  #occMap{height:420px}
  .mapTotalsLayout #occMap{height:420px;min-height:420px}
  .mapHeaderRow{flex-direction:column;align-items:flex-start}
  /* Show cards, hide table */
  .desktopOnly{display:none}
  .mobileCardList{display:flex}
  /* Modal */
  .occDialog{width:calc(100vw - 10px)}
  .ppGrid{grid-template-columns:1fr}
  .ppActions{grid-template-columns:1fr 1fr}
  /* Bottom nav */
  .bottomNav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:2000;height:calc(var(--bottomH) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:rgba(255,255,255,.94);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(15,23,42,.06);align-items:center;justify-content:space-around}
  .bnItem{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;background:0;border:0;font-family:var(--font);font-size:10px;font-weight:600;color:var(--muted);cursor:pointer;transition:color .12s;-webkit-tap-highlight-color:transparent;position:relative}
  .bnItem svg{stroke-width:1.8}
  .bnItem.active{color:var(--red)}
  .bnItem.active::after{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:24px;height:3px;border-radius:0 0 3px 3px;background:var(--red)}
  footer{padding-bottom:calc(24px + var(--bottomH))}
}

@media(max-width:640px){
  .ppStats{grid-template-columns:1fr}
  .meteoGrid{grid-template-columns:1fr}
  .ppTimelineTopRow{flex-direction:column;align-items:flex-start;gap:4px}
  .ppActions{grid-template-columns:1fr}
}

@media(max-width:480px){
  main{padding:8px 8px calc(8px + var(--bottomH))}
  .kpiGrid{grid-template-columns:1fr 1fr}
  .kpiCard{padding:12px 10px}
  .kpiIcon{width:38px;height:38px;font-size:18px}
  .kpiValue{font-size:24px}
  .brandTitle{font-size:13px}
  input,select{font-size:16px}
  .filters input,.filters select{font-size:16px;padding:10px 12px}
  .occTitleNature{font-size:12px}
  .occTitleState{font-size:9px;padding:3px 8px}
  #occMap{height:320px}
  .mapTotalsLayout #occMap{height:320px;min-height:320px}
}

/* === LEGAL (privacidade / termos) === */
body.legalPage .topbar .brand a.logo{display:grid;place-items:center;text-decoration:none}
body.legalPage .legalMain{max-width:720px;margin:0 auto;padding:24px 20px 40px}
body.legalPage .legalBox h1{margin-bottom:8px}
body.legalPage .legalBox h2{margin:1.35em 0 .5em;font-size:1.15rem}
body.legalPage .legalBox p,.legalBox li{font-size:14px;line-height:1.65;color:var(--text)}
body.legalPage .legalBox ul{padding-left:1.25rem;margin:.5em 0 1em}
body.legalPage .legalBox li{margin:.35em 0}
body.legalPage .legalMeta{font-size:13px;color:var(--muted);margin-bottom:1.25rem}
body.legalPage .legalNav{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border2);font-size:14px;font-weight:600}
body.legalPage a.legalInline{color:var(--red-dark);text-decoration:none;font-weight:700}
body.legalPage a.legalInline:hover{color:var(--red);text-decoration:none}
body.legalPage a.legalFootLink{color:var(--red-dark);text-decoration:none;font-weight:700}
body.legalPage a.legalFootLink:hover{color:var(--red);text-decoration:none}
.footerLegal{margin-top:8px;font-size:12px;font-weight:600}
.footerLegal a.footerTextLink{color:var(--red-dark);font-weight:700;text-decoration:none}
.footerLegal a.footerTextLink:hover{color:var(--red);text-decoration:none}
