/* ============================================================
   Property inspector overlay + parcel map chrome
   ============================================================ */
.prop-inspector-overlay { position:fixed; inset:0; z-index:200; display:grid; place-items:center; padding:28px;
  background:color-mix(in srgb, var(--bg-void) 72%, transparent); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); }
.prop-inspector { width:min(1180px, 96vw); height:min(760px, 92vh); display:flex; flex-direction:column;
  background:var(--bg-elev); border:1px solid var(--sv-ink-500); border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:0 30px 90px -24px rgba(0,0,0,0.7); }

/* header */
.pi-head { display:flex; align-items:flex-start; justify-content:space-between; gap:18px; padding:16px 20px; border-bottom:1px solid var(--rule); flex:none; }
.pi-head-l { display:flex; flex-direction:column; gap:5px; }
.pi-head-l h3 { font-size:17px; font-weight:600; color:var(--fg); letter-spacing:0.02em; }
.pi-muni { font-size:12.5px; color:var(--fg-mid); }
.pi-head-r { display:flex; align-items:center; gap:16px; }
.pi-score { display:flex; align-items:baseline; gap:6px; }
.pis-val { font-family:var(--font-display); font-weight:600; font-size:34px; line-height:1; letter-spacing:-0.03em; }
.pis-lab { font-size:10px; letter-spacing:0.08em; text-transform:uppercase; color:var(--fg-mute); }

/* body split */
.pi-body { flex:1; display:grid; grid-template-columns:1.55fr 1fr; min-height:0; }
@media (max-width:900px){ .pi-body { grid-template-columns:1fr; } }
.pi-map { position:relative; border-right:1px solid var(--rule); min-height:0; background:#06070A; display:flex; flex-direction:column; }
.pi-maparea { position:relative; flex:1; min-height:0; }
@media (max-width:900px){ .pi-body { grid-template-columns:1fr; } .pi-maparea { min-height:340px; } }
.pi-side { overflow-y:auto; padding:18px; min-height:0; }
.pi-side::-webkit-scrollbar { width:7px; } .pi-side::-webkit-scrollbar-thumb { background:var(--sv-ink-600); border-radius:6px; }

/* breadcrumb */
.pi-crumb { display:flex; align-items:center; gap:6px; font-size:9px; letter-spacing:0.08em; text-transform:uppercase; color:var(--fg-mute); margin-bottom:2px; }
.pi-crumb b { color:var(--fg-soft); } .pi-crumb .cyan { color:var(--sv-cyan); }
.pi-crumb svg { opacity:0.5; }

/* expanded mode */
.prop-inspector.expanded { width:97vw; height:95vh; }

/* lens bar */
.pm-lensbar { display:flex; align-items:center; gap:6px; padding:9px 12px; border-bottom:1px solid var(--rule); background:color-mix(in srgb, var(--bg) 50%, transparent); flex:none; flex-wrap:wrap; z-index:5; }
.pm-lens-lab { font-size:8.5px; letter-spacing:0.14em; color:var(--fg-mute); margin-right:4px; }
.pm-lens { font-family:var(--font-mono); font-size:10px; letter-spacing:0.03em; padding:6px 10px; border:1px solid var(--rule); border-radius:5px; background:var(--bg); color:var(--fg-soft); cursor:pointer; transition:all 140ms; }
.pm-lens:hover { color:var(--fg); border-color:var(--sv-ink-500); }
.pm-lens.on { background:color-mix(in srgb, var(--sv-coral) 16%, transparent); color:var(--sv-coral); border-color:color-mix(in srgb, var(--sv-coral) 45%, transparent); }

/* layer source tooltip */
.layer-src { color:var(--fg-mute); cursor:help; display:inline-flex; margin-left:4px; }
.layer-src:hover { color:var(--sv-cyan); }
.layer-tip { width:180px; bottom:calc(100% + 6px); left:auto; right:0; transform:translateY(4px); text-transform:none; line-height:1.5; }
.layer-tip b { color:var(--sv-cyan); } .layer-src:hover .layer-tip { transform:translateY(0); }
.pi-layers .layer-row { display:flex; align-items:center; }

/* uso/esg category legend */
.pm-cats { display:flex; flex-direction:column; gap:5px; margin-top:8px; }
.pm-cat { display:flex; align-items:center; gap:7px; font-size:10.5px; color:var(--fg-soft); }
.pm-cat i { width:11px; height:11px; border-radius:3px; flex:none; }

/* exception banner */
.pm-exception { position:absolute; top:12px; left:50%; transform:translateX(-50%); z-index:6; display:flex; align-items:center; gap:8px;
  font-size:11px; padding:7px 13px; border-radius:20px; white-space:nowrap; backdrop-filter:blur(8px);
  background:color-mix(in srgb, var(--bg-elev) 88%, transparent); border:1px solid; }
.pm-exception.bad { color:var(--risk-critical); border-color:color-mix(in srgb, var(--risk-critical) 45%, transparent); }
.pm-exception.warn { color:var(--sv-warn); border-color:color-mix(in srgb, var(--sv-warn) 45%, transparent); }

/* toolbar */
.pm-toolbar { position:absolute; top:12px; right:14px; z-index:5; display:flex; flex-direction:column; gap:5px; }
.pm-tool { display:flex; align-items:center; gap:7px; padding:7px 10px; border:1px solid var(--rule); border-radius:6px; cursor:pointer; transition:all 140ms;
  background:color-mix(in srgb, var(--bg-elev) 84%, transparent); backdrop-filter:blur(6px); color:var(--fg-soft);
  font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.04em; text-transform:uppercase; justify-content:flex-start; }
.pm-tool:hover { color:var(--fg); border-color:var(--sv-ink-500); }
.pm-tool.on { background:color-mix(in srgb, var(--sv-cyan) 16%, transparent); color:var(--sv-cyan); border-color:color-mix(in srgb, var(--sv-cyan) 45%, transparent); }
.pm-basemap { top:auto; bottom:12px; right:14px; }
.pm-measure, .pm-tool-hint { position:absolute; top:188px; right:14px; z-index:5; font-size:9px; letter-spacing:0.06em; color:var(--fg);
  background:color-mix(in srgb, var(--bg-void) 78%, transparent); padding:6px 10px; border-radius:5px; border:1px solid var(--rule); max-width:200px; line-height:1.5; }
.pm-tool-hint { color:var(--sv-cyan); }

/* curtain (A/B) */
.pm-curtain { position:absolute; inset:0; z-index:5; pointer-events:none; }
.pm-curtain::before { content:""; position:absolute; left:50%; top:0; bottom:46px; width:1.5px; background:rgba(246,244,238,0.8); transform:translateX(-50%); }
.pm-curtain-a, .pm-curtain-b { position:absolute; top:46px; font-size:9px; padding:3px 7px; border-radius:4px; background:color-mix(in srgb, var(--bg-void) 75%, transparent); color:#F6F4EE; }
.pm-curtain-a { left:calc(50% - 46px); } .pm-curtain-b { left:calc(50% + 8px); color:var(--sv-cyan); }

/* timeline */
.pm-timeline { flex:none; display:flex; align-items:center; gap:12px; padding:10px 14px; border-top:1px solid var(--rule); background:color-mix(in srgb, var(--bg) 55%, transparent); z-index:5; }
.pm-play { width:30px; height:30px; flex:none; border:1px solid var(--rule); border-radius:6px; background:var(--bg-elev); color:var(--sv-coral); cursor:pointer; display:grid; place-items:center; }
.pm-play:hover { border-color:var(--sv-coral); }
.pm-tl-track { flex:1; position:relative; min-width:0; }
.pm-spark { width:100%; height:34px; display:block; }
.pm-events { position:absolute; top:0; left:0; right:0; height:34px; pointer-events:none; }
.pm-ev { position:absolute; top:-2px; transform:translateX(-50%); background:none; border:none; cursor:pointer; pointer-events:auto; padding:4px; }
.pm-ev-dot { display:block; width:7px; height:7px; border-radius:50%; border:1.5px solid var(--bg); }
.pm-tl-range { -webkit-appearance:none; appearance:none; width:100%; height:3px; border-radius:2px; background:var(--sv-ink-600); outline:none; cursor:pointer; margin:2px 0 0; }
.pm-tl-range::-webkit-slider-thumb { -webkit-appearance:none; width:13px; height:13px; border-radius:50%; background:var(--sv-coral); border:2px solid var(--bg-elev); cursor:pointer; }
.pm-tl-range::-moz-range-thumb { width:11px; height:11px; border-radius:50%; background:var(--sv-coral); border:2px solid var(--bg-elev); cursor:pointer; }
.pm-years { display:flex; justify-content:space-between; font-size:8px; color:var(--fg-mute); margin-top:3px; }
.pm-years .on { color:var(--sv-coral); }
.pm-tl-right { flex:none; display:flex; align-items:center; gap:8px; }
.pm-ndvi-now { font-size:9px; color:var(--fg-soft); letter-spacing:0.04em; }
.pm-cmp { display:flex; align-items:center; gap:5px; font-family:var(--font-mono); font-size:9px; letter-spacing:0.04em; padding:6px 9px; border:1px solid var(--rule); border-radius:5px; background:var(--bg-elev); color:var(--fg-soft); cursor:pointer; }
.pm-cmp.on { background:color-mix(in srgb, var(--sv-cyan) 16%, transparent); color:var(--sv-cyan); border-color:color-mix(in srgb, var(--sv-cyan) 45%, transparent); }
.pm-cmp-sel { background:var(--bg-elev); border:1px solid var(--rule); border-radius:5px; color:var(--fg); font-family:var(--font-mono); font-size:9px; padding:5px 6px; cursor:pointer; }
@media (max-width:600px){ .pm-tl-right { display:none; } }

/* region inset in 02 */
.pi-vs-grid { display:grid; grid-template-columns:1fr 132px; gap:14px; align-items:start; }
@media (max-width:520px){ .pi-vs-grid { grid-template-columns:1fr; } }
.region-inset { border:1px solid var(--rule); border-radius:7px; overflow:hidden; background:var(--bg-void); padding:6px; position:relative; }
.ri-cap { display:block; font-size:7px; letter-spacing:0.06em; color:var(--fg-mute); margin-top:4px; text-align:center; }

/* selected cell card */
.pi-cellcard { background:color-mix(in srgb, var(--sv-cyan) 6%, transparent); border:1px solid color-mix(in srgb, var(--sv-cyan) 25%, transparent); border-radius:8px; padding:12px; margin-bottom:16px; }
.pi-cellcard .pi-sec-h { display:flex; align-items:center; justify-content:space-between; margin-bottom:9px; }
.cell-x { background:none; border:none; color:var(--fg-mute); cursor:pointer; padding:0; display:inline-flex; }
.cell-grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--rule-soft); border-radius:6px; overflow:hidden; }
.cell-grid > div { background:var(--bg-elev); padding:8px 10px; display:flex; flex-direction:column; gap:3px; }
.cell-grid span { font-family:var(--font-mono); font-size:8px; letter-spacing:0.06em; text-transform:uppercase; color:var(--fg-mute); }
.cell-grid b { font-size:15px; color:var(--fg); font-weight:600; }

/* protocol badge */
.pi-protocol { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:11px 13px; margin-bottom:16px; cursor:pointer;
  border:1px solid var(--rule); border-radius:8px; background:var(--bg); transition:border-color 150ms; }
.pi-protocol:hover { border-color:var(--sv-coral); }
.pp-l { display:flex; flex-direction:column; gap:3px; }
.pp-l .mono { font-size:8px; letter-spacing:0.1em; color:var(--fg-mute); }
.pp-l b { font-size:12px; color:var(--fg); font-weight:500; }
.pp-tier { font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.04em; padding:4px 9px; border-radius:5px; border:1px solid; white-space:nowrap; }
.pp-tier.act-aceitar { color:var(--risk-low); border-color:color-mix(in srgb, var(--risk-low) 45%, transparent); background:color-mix(in srgb, var(--risk-low) 8%, transparent); }
.pp-tier.act-condicionar { color:var(--sv-warn); border-color:color-mix(in srgb, var(--sv-warn) 45%, transparent); }
.pp-tier.act-recusar { color:var(--risk-critical); border-color:color-mix(in srgb, var(--risk-critical) 45%, transparent); }

/* sinistro timeline year buttons */
.sin-yr { background:none; border:none; cursor:pointer; padding:0; display:inline-flex; flex-direction:column; align-items:center; gap:4px; }
.sin-dot.now { outline:2px solid var(--sv-coral); outline-offset:1px; }

/* evidence + vistoria modals */
.ev-panel, .vist-panel { width:min(440px, 94vw); }
.ev-h { display:flex; align-items:center; gap:9px; margin-bottom:12px; }
.ev-h b { flex:1; font-size:14px; color:var(--fg); }
.ev-meta { border:1px solid var(--rule); border-radius:8px; overflow:hidden; }
.ev-row { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:9px 12px; border-bottom:1px solid var(--rule-soft); }
.ev-row:last-child { border-bottom:none; }
.ev-row .mono { font-size:9px; letter-spacing:0.06em; text-transform:uppercase; color:var(--fg-mute); }
.ev-row b { font-size:12px; color:var(--fg); }
.vist-check { display:flex; flex-direction:column; gap:8px; margin-top:6px; }
.vist-item { display:flex; align-items:center; gap:10px; padding:9px 11px; border:1px solid var(--rule); border-radius:7px; font-size:12px; color:var(--fg-mid); cursor:pointer; }
.vist-item .lcheck { width:16px; height:16px; border:1px solid var(--rule); border-radius:4px; flex:none; }

/* parcel map */
.parcel-canvas-wrap { position:absolute; inset:0; }
.parcel-canvas { position:absolute; inset:0; }
.parcel-canvas .maplibregl-ctrl-attrib { font-family:var(--font-mono); font-size:8.5px; background:color-mix(in srgb, var(--bg) 70%, transparent); color:var(--fg-mute); }
.parcel-loading { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; gap:11px; color:var(--fg-soft); z-index:3; }
.parcel-loading .mono { font-size:10px; letter-spacing:0.12em; text-transform:uppercase; }

.pm-proj { position:absolute; top:12px; left:14px; z-index:4; font-size:9px; letter-spacing:0.1em; text-transform:uppercase; color:var(--fg-soft);
  background:color-mix(in srgb, var(--bg-void) 60%, transparent); padding:4px 8px; border-radius:4px; }
.pm-coord { position:absolute; bottom:14px; left:14px; z-index:4; display:flex; align-items:center; gap:7px;
  background:color-mix(in srgb, var(--bg-void) 60%, transparent); padding:5px 9px; border-radius:4px; }
.pm-coord .pm-pip { width:6px; height:6px; border-radius:50%; background:var(--sv-coral); }
.pm-coord .mono { font-size:10px; color:var(--fg); letter-spacing:0.04em; }
.pm-scale { position:absolute; bottom:14px; left:50%; transform:translateX(-50%); z-index:4; display:flex; align-items:center; gap:8px; }
.pm-scale-bar { display:flex; height:5px; border:1px solid rgba(246,244,238,0.7); }
.pm-scale-bar i { width:26px; height:100%; background:rgba(246,244,238,0.8); } .pm-scale-bar i.alt { background:transparent; }
.pm-scale .mono { font-size:9px; color:#F6F4EE; letter-spacing:0.06em; text-shadow:0 1px 3px #000; }
.pm-basemap { position:absolute; top:12px; right:14px; z-index:4; display:flex; border:1px solid var(--rule); border-radius:6px; overflow:hidden; }
.pm-basemap button { background:color-mix(in srgb, var(--bg-elev) 80%, transparent); border:none; border-right:1px solid var(--rule); color:var(--fg-soft);
  font-family:var(--font-mono); font-size:9.5px; padding:6px 10px; cursor:pointer; backdrop-filter:blur(6px); transition:all 130ms; }
.pm-basemap button:last-child { border-right:none; }
.pm-basemap button.on { background:color-mix(in srgb, var(--sv-cyan) 16%, transparent); color:var(--sv-cyan); }

/* layer panel inside map */
.pi-layers { position:absolute; left:14px; bottom:44px; width:226px; padding:11px; z-index:4; }
.pi-layers .layer-list { margin-bottom:8px; }
.pm-legend { border-top:1px solid var(--rule-soft); padding-top:10px; }
.pm-ramp { height:9px; border-radius:3px; margin-top:7px;
  background:linear-gradient(90deg, #1E1F4A, #2C3A8A, #2A6FA8, #1FA7B0, #5FD6A4, #D9F37C, #FFFAA8); }
.pm-ramp-lab { display:flex; justify-content:space-between; font-size:8.5px; color:var(--fg-mute); margin-top:4px; letter-spacing:0.06em; }

/* insights */
.pi-sec { padding-bottom:16px; margin-bottom:16px; border-bottom:1px solid var(--rule-soft); }
.pi-sec-h { font-size:9px; letter-spacing:0.13em; text-transform:uppercase; color:var(--sv-cyan); margin-bottom:11px; }
.pi-stats { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--rule-soft); border:1px solid var(--rule-soft); border-radius:6px; overflow:hidden; }
.pi-stat { background:var(--bg-elev); padding:10px 12px; display:flex; flex-direction:column; gap:4px; }
.ps-lab { font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--fg-mute); }
.ps-val { font-family:var(--font-display); font-weight:600; font-size:21px; line-height:1; letter-spacing:-0.02em; color:var(--fg); }
.ps-val small { font-size:11px; color:var(--fg-mute); font-weight:500; }
.ps-val.ps-sm { font-family:var(--font-body); font-size:13px; font-weight:500; }

.pi-flag { display:flex; align-items:center; gap:7px; margin-top:11px; padding:8px 10px; border-radius:6px; font-size:11.5px; }
.pi-flag.good { color:var(--risk-low); background:color-mix(in srgb, var(--risk-low) 9%, transparent); border:1px solid color-mix(in srgb, var(--risk-low) 30%, transparent); }
.pi-flag.bad { color:var(--risk-critical); background:color-mix(in srgb, var(--risk-critical) 9%, transparent); border:1px solid color-mix(in srgb, var(--risk-critical) 30%, transparent); }

.pi-rec { padding-top:4px; }
.pi-rec.fraud { background:color-mix(in srgb, var(--risk-critical) 6%, transparent); margin:0 -18px -18px; padding:16px 18px; }
.pi-rec p { font-size:12px; line-height:1.55; color:var(--fg-mid); margin:0; }

/* "open map" button in the side detail panel */
.pd-mapcta { display:flex; align-items:center; justify-content:center; gap:8px; width:100%; cursor:pointer;
  margin:0 0 4px; padding:11px; border:1px solid color-mix(in srgb, var(--sv-coral) 45%, transparent); border-radius:var(--radius);
  background:color-mix(in srgb, var(--sv-coral) 9%, transparent); color:var(--sv-coral);
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.06em; text-transform:uppercase; transition:all 150ms; }
.pd-mapcta:hover { background:color-mix(in srgb, var(--sv-coral) 16%, transparent); }
