
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#17172a;--bg2:#1e1e33;--bg3:#28283e;--bg4:#33334a;
  --text:#cdd6f4;--text2:#b3bdd7;--text3:#9aa3bd;
  --accent:#89b4fa;--accent2:#b4befe;
  --green:#1a9641;--lgreen:#a6d96a;--yellow:#ffffbf;
  --orange:#fdae61;--red:#d7191c;--border:#3a3a55;
  --chart-demand:#cc79a7;--chart-supply:#56b4e9;--chart-gap:#e69f00;--chart-added:#009e73;
  --c-flood:#3b82f6;--c-zoning:#8b5cf6;--c-transit:#06b6d4;
  --c-vacancy:#f59e0b;--c-assemblage:#10b981;--c-env:#ef4444;
  --gap-warn:#fdae61;--gap-severe:#d7191c;--surplus:#a6d96a;
  --map-overlay-top:16px;--map-overlay-left:64px;
}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}
body{line-height:1.5}

/* ── APP GRID ─────────────────────────────────────────────────────────── */
#app{display:grid;grid-template-rows:56px 1fr 84px;grid-template-columns:320px 1fr 0px;height:100vh;width:100vw}
#app.detail-open{grid-template-columns:320px 1fr 340px}
header{grid-column:1/-1;background:linear-gradient(to bottom,var(--bg2),var(--bg));display:flex;align-items:center;padding:0 22px;border-bottom:1px solid var(--border);gap:16px}
header h1{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;letter-spacing:-0.005em}
header .subtitle{font-size:11px;color:var(--text3);letter-spacing:0.2px}
header .spacer{flex:1}
header .header-btn{min-height:32px;font-size:11px;padding:6px 12px;border-radius:5px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;transition:all 0.15s;font-weight:500;letter-spacing:0.1px}
header .header-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}

/* ── TABS ─────────────────────────────────────────────────────────────── */
.tab-strip{display:flex;gap:2px;margin-left:18px}
.tab-btn{font-size:11.5px;line-height:1.15;padding:7px 14px;border-radius:6px 6px 0 0;border:1px solid transparent;background:transparent;color:var(--text3);cursor:pointer;font-weight:500;letter-spacing:0.2px;transition:all 0.15s;position:relative;top:1px}
.tab-btn:hover{color:var(--text);background:rgba(137,180,250,0.06)}
.tab-btn.active{color:var(--text);background:var(--bg);border-color:var(--border) var(--border) var(--bg);box-shadow:0 2px 0 var(--bg);font-weight:600}

/* ── BASEMAP TOGGLE (header) ─────────────────────────────────────────── */
.basemap-toggle{display:flex;background:var(--bg3);border-radius:5px;padding:2px;border:1px solid var(--border)}
.basemap-btn{font-size:10.5px;line-height:1.1;min-height:32px;padding:6px 10px;border:none;background:transparent;color:var(--text3);cursor:pointer;border-radius:3px;font-weight:500;letter-spacing:0.1px;transition:all 0.15s}
.basemap-btn:hover{color:var(--text)}
.basemap-btn.active{background:var(--accent);color:var(--bg);font-weight:600}

/* Satellite-visible parcel overlays: slightly lighter panels w/ stronger blur */
body[data-basemap="satellite"] .hero-wrap,
body[data-basemap="satellite"] .legend,
body[data-basemap="satellite"] #chart-wrap,
body[data-basemap="satellite"] #absorption-badge{background:rgba(23,23,36,0.82);backdrop-filter:blur(14px) saturate(140%)}

/* Dim the satellite imagery so data overlays read clearly. Applies only to the
   satellite tile layer via a container-level filter; labels tile on top stays full-brightness. */
body[data-basemap="satellite"] .leaflet-tile-pane .leaflet-layer:first-child img{filter:brightness(0.55) saturate(0.8) contrast(0.95)}

/* ── UNIVERSAL TOOLTIP SYSTEM (data-tip attribute) ──────────────────── */
[data-tip]{position:relative}
[data-tip]::after{display:none!important}
#global-tooltip{
  position:fixed;left:0;top:0;z-index:2147483000;max-width:min(280px,calc(100vw - 20px));
  padding:7px 9px;border-radius:6px;border:1px solid rgba(137,180,250,0.34);
  background:rgba(16,20,36,0.98);color:#e7efff;box-shadow:0 16px 36px rgba(0,0,0,0.68),0 0 0 1px rgba(255,255,255,0.035);
  font-size:11px;font-weight:400;line-height:1.42;text-transform:none;letter-spacing:normal;text-align:left;
  pointer-events:none;opacity:0;visibility:hidden;transition:opacity 0.12s ease;overflow-wrap:anywhere;
}
#global-tooltip.visible{opacity:1;visibility:visible}

/* First-use guided walkthrough */
.guide-target{box-shadow:0 0 0 2px rgba(180,190,254,0.88),0 0 0 8px rgba(137,180,250,0.18)!important;border-radius:8px;transition:box-shadow 0.18s ease}
.onboarding-guide{position:fixed;top:70px;right:18px;left:auto;z-index:2147482500;width:min(410px,calc(100vw - 356px));max-height:calc(100vh - 96px);overflow:auto;padding:15px 16px 14px;border:1px solid rgba(137,180,250,0.28);border-radius:8px;background:rgba(18,22,38,0.96);color:var(--text);box-shadow:0 24px 70px rgba(0,0,0,0.64),0 0 0 1px rgba(255,255,255,0.035);backdrop-filter:blur(16px) saturate(140%)}
.onboarding-guide[hidden]{display:none!important}
.guide-close{position:absolute;top:7px;right:8px;width:28px;height:28px;border:0;border-radius:4px;background:transparent;color:var(--text3);font-size:17px;line-height:1;cursor:pointer}
.guide-close:hover{background:var(--bg3);color:var(--text)}
.guide-kicker{padding-right:30px;font-size:9px;font-weight:800;letter-spacing:1.1px;text-transform:uppercase;color:var(--accent2);margin-bottom:6px}
.guide-title{padding-right:30px;font-size:17px;line-height:1.18;font-weight:750;color:var(--text);letter-spacing:-0.01em;margin-bottom:8px}
.guide-body{font-size:11.5px;line-height:1.48;color:var(--text2);margin-bottom:10px}
.guide-list{display:grid;gap:6px;margin:0 0 12px 0;list-style:none}
.guide-list li{position:relative;padding-left:14px;font-size:10.5px;line-height:1.42;color:var(--text2)}
.guide-list li::before{content:"";position:absolute;left:0;top:0.58em;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.guide-look{font-size:9.5px;line-height:1.35;color:var(--text3);border-top:1px solid rgba(255,255,255,0.06);padding-top:9px;margin-bottom:12px}
.guide-look b{color:var(--text2)}
.guide-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.guide-btn{min-height:30px;border:1px solid rgba(137,180,250,0.22);border-radius:5px;background:var(--bg3);color:var(--text2);font-family:inherit;font-size:10px;font-weight:700;line-height:1.1;letter-spacing:0.25px;padding:7px 10px;cursor:pointer}
.guide-btn:hover,.guide-btn:focus-visible{background:var(--accent);border-color:var(--accent);color:var(--bg)}
.guide-btn:disabled{opacity:0.38;cursor:default}
.guide-btn:disabled:hover{background:var(--bg3);border-color:rgba(137,180,250,0.22);color:var(--text2)}
.guide-btn.primary{background:var(--accent);border-color:var(--accent);color:var(--bg)}
.guide-btn.subtle{background:transparent;border-color:transparent;color:var(--text3)}
.guide-btn.subtle:hover,.guide-btn.subtle:focus-visible{background:rgba(137,180,250,0.10);border-color:rgba(137,180,250,0.20);color:var(--text)}
.guide-progress{margin-left:auto;font-size:9.5px;color:var(--text3);white-space:nowrap}
.onboarding-guide.detail-demo{right:360px;width:min(390px,calc(100vw - 716px))}
body[data-tab="mesh"] .onboarding-guide{top:58px;left:18px;right:auto;width:min(410px,calc(100vw - 36px));background:rgba(4,11,17,0.82);border-color:rgba(137,180,250,0.22)}
body[data-tab="mesh"] #guide-btn{display:inline-flex!important;position:absolute;right:12px;top:5px;align-items:center;justify-content:center;min-height:30px}

/* Help icon that carries tooltips without cluttering sliders */
.help-ico{display:inline-flex;align-items:center;justify-content:center;min-width:20px;min-height:20px;width:20px;height:20px;border-radius:50%;background:rgba(137,180,250,0.15);color:var(--text2);font-size:10px;font-weight:800;cursor:help;margin-left:4px;vertical-align:middle;line-height:1;flex-shrink:0}
.help-ico:hover,.help-ico:focus-visible{background:var(--accent);color:var(--bg)}

/* Close buttons — universal style */
.panel-close{position:absolute;top:6px;right:6px;min-width:28px;min-height:28px;background:transparent;border:none;color:var(--text3);font-size:16px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:4px;opacity:0.75;transition:all 0.15s;z-index:2}
.panel-close:hover{opacity:1;background:var(--bg3);color:var(--text)}

/* ── SIDEBAR COLLAPSED STATE ────────────────────────────────────────── */
body.sidebar-collapsed #app{grid-template-columns:0 1fr 0}
body.sidebar-collapsed #app.detail-open{grid-template-columns:0 1fr 340px}
body.sidebar-collapsed #left-panel{display:none}
body.sidebar-collapsed #sidebar-toggle-btn{transform:rotate(180deg)}
#sidebar-toggle-btn{font-family:inherit;width:28px;padding:4px 0;transition:transform 0.25s}
.tab-pane{display:none}
.tab-pane.active{display:contents}
/* Sections tagged with data-tab attribute show only in their tab */
body[data-tab="gap"] [data-tab-only="zoning"],
body[data-tab="gap"] [data-tab-only="mesh"],
body[data-tab="zoning"] [data-tab-only="gap"],
body[data-tab="zoning"] [data-tab-only="mesh"],
body[data-tab="mesh"] [data-tab-only="gap"],
body[data-tab="mesh"] [data-tab-only="zoning"]{display:none!important}
#left-panel{grid-row:2;grid-column:1;background:var(--bg);border-right:1px solid var(--border);overflow-y:auto;padding:16px 14px;font-size:12px;scrollbar-width:thin;scrollbar-color:var(--bg3) transparent}
#left-panel::-webkit-scrollbar{width:6px}
#left-panel::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px}
#left-panel::-webkit-scrollbar-thumb:hover{background:var(--border)}
.sidebar-jump-nav{position:sticky;top:-16px;z-index:7;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin:-4px 0 14px;padding:8px 0 10px;background:linear-gradient(to bottom,var(--bg) 82%,rgba(23,23,42,0));backdrop-filter:blur(10px)}
.sidebar-jump-btn{border:1px solid rgba(137,180,250,0.14);border-radius:5px;background:rgba(30,30,51,0.92);color:var(--text2);font-size:9.5px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;padding:7px 6px;cursor:pointer;transition:all 0.15s}
.sidebar-jump-btn:hover,.sidebar-jump-btn:focus-visible{background:rgba(137,180,250,0.16);color:var(--text);border-color:rgba(137,180,250,0.34)}
.section{scroll-margin-top:62px}
#map-container{grid-row:2;grid-column:2;position:relative;overflow:hidden}
#map{width:100%;height:100%}
#envelope-field-wrap{position:absolute;inset:0;z-index:1200;background:#061015;overflow:hidden}
#native-envelope-root{position:absolute;inset:0;background:
  radial-gradient(circle at 18% 14%, rgba(137,180,250,0.12), transparent 28%),
  radial-gradient(circle at 80% 72%, rgba(176,208,233,0.07), transparent 26%),
  linear-gradient(180deg,#040b11 0%,#071119 100%);
  color:#dfeef8;overflow:hidden}
#native-envelope-root::before{content:"";position:absolute;inset:0;background:
  linear-gradient(rgba(255,255,255,0.018) 1px, transparent 1px),
  linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size:56px 56px;opacity:.18;pointer-events:none}
#native-envelope-three{position:absolute;inset:0;z-index:2}
#native-envelope-three canvas{display:block;width:100%;height:100%;outline:none;cursor:grab;touch-action:none}
#native-envelope-three canvas:active{cursor:grabbing}
.native-field-mode-tabs{position:absolute;top:18px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:6px;padding:5px;border:1px solid rgba(137,180,250,.16);border-radius:999px;background:rgba(4,11,17,.56);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 18px 42px rgba(0,0,0,.26)}
.native-field-mode-btn{min-height:32px;border:1px solid transparent;border-radius:999px;background:rgba(255,255,255,.026);color:rgba(215,230,244,.88);padding:7px 12px;font:700 10px/1.1 "Arial Narrow","Aptos Narrow",Arial,sans-serif;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:background .14s ease,color .14s ease,border-color .14s ease}
.native-field-mode-btn:hover{color:#dfeef8;background:rgba(79,140,255,.10)}
.native-field-mode-btn.active{color:#e8f5ff;background:rgba(79,140,255,.18);border-color:rgba(137,180,250,.28);box-shadow:0 0 22px rgba(79,140,255,.16)}
.native-export-controls{position:absolute;top:18px;right:22px;z-index:5;display:flex;gap:6px;padding:5px;border:1px solid rgba(137,180,250,.15);border-radius:999px;background:rgba(4,11,17,.42);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 18px 42px rgba(0,0,0,.22)}
.native-export-btn{min-height:32px;border:1px solid rgba(137,180,250,.18);border-radius:999px;background:rgba(255,255,255,.026);color:rgba(223,238,248,.86);padding:7px 10px;font:700 10px/1 "Arial Narrow","Aptos Narrow",Arial,sans-serif;letter-spacing:1px;text-transform:uppercase;cursor:pointer}
.native-export-btn:hover{color:#eef9ff;background:rgba(79,140,255,.13);border-color:rgba(137,180,250,.28)}
.native-context-card{position:absolute;left:24px;bottom:24px;z-index:5;width:min(360px,calc(100% - 48px));padding:16px 18px 15px;border:1px solid rgba(137,180,250,.16);border-radius:8px;background:rgba(4,11,17,.54);backdrop-filter:blur(16px) saturate(145%);box-shadow:0 22px 54px rgba(0,0,0,.32);pointer-events:none}
.native-context-kicker{font:700 9px/1 "Arial Narrow","Aptos Narrow",Arial,sans-serif;letter-spacing:1.2px;text-transform:uppercase;color:rgba(215,230,244,.82);margin-bottom:8px}
.native-context-title{font:700 18px/1.05 Baskerville,Georgia,serif;letter-spacing:.02em;color:#edf8ff;margin-bottom:7px}
.native-context-body{font:400 12px/1.45 Baskerville,Georgia,serif;color:rgba(236,247,255,.86)}
.native-context-meta{margin-top:10px;padding-top:9px;border-top:1px solid rgba(137,180,250,.12);display:flex;flex-wrap:wrap;gap:6px 12px;font:700 9.5px/1.2 "Arial Narrow","Aptos Narrow",Arial,sans-serif;letter-spacing:0.8px;text-transform:uppercase;color:rgba(215,230,244,.86)}
.native-scale-card{position:absolute;right:24px;bottom:24px;z-index:5;display:flex;align-items:center;gap:14px;padding:11px 13px;border:1px solid rgba(137,180,250,.14);border-radius:8px;background:rgba(4,11,17,.46);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 18px 42px rgba(0,0,0,.24);pointer-events:none}
.native-north{display:flex;flex-direction:column;align-items:center;gap:2px;font:700 10px/1 "Arial Narrow","Aptos Narrow",Arial,sans-serif;color:#dff5ff;letter-spacing:1.1px}
.native-north::before{content:"";width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:18px solid #dff5ff;filter:drop-shadow(0 0 8px rgba(79,196,255,.45))}
.native-scale-line{width:94px;height:14px;border-left:1px solid rgba(223,238,248,.8);border-right:1px solid rgba(223,238,248,.8);border-bottom:2px solid rgba(223,238,248,.8)}
.native-scale-label{font:700 9.5px/1 "Arial Narrow","Aptos Narrow",Arial,sans-serif;letter-spacing:1px;text-transform:uppercase;color:rgba(223,238,248,.74);text-align:center;margin-top:4px}
#right-panel{grid-row:2;grid-column:3;background:var(--bg);border-left:1px solid var(--border);overflow-y:auto;padding:14px;font-size:12px;display:none}
#app.detail-open #right-panel{display:block}
body[data-tab="mesh"] #app{grid-template-columns:0 1fr 0px;grid-template-rows:42px 1fr 0}
body[data-tab="mesh"] #app.detail-open{grid-template-columns:0 1fr 0px;grid-template-rows:42px 1fr 0}
body[data-tab="mesh"] header{background:#061015;border-bottom:0;justify-content:center;padding:0 12px}
body[data-tab="mesh"] header h1,
body[data-tab="mesh"] header .spacer,
body[data-tab="mesh"] .basemap-toggle,
body[data-tab="mesh"] .header-btn{display:none!important}
body[data-tab="mesh"] .tab-strip{margin-left:0}
body[data-tab="mesh"] .tab-btn{padding:6px 13px;border-radius:999px;top:0;background:rgba(255,255,255,0.025)}
body[data-tab="mesh"] .tab-btn.active{background:rgba(137,180,250,0.14);border-color:rgba(137,180,250,0.22);box-shadow:none}
body[data-tab="mesh"] [data-tip]::after{display:none!important}
body[data-tab="mesh"] #left-panel,
body[data-tab="mesh"] #right-panel,
body[data-tab="mesh"] #bottom-bar{display:none!important}
body[data-tab="mesh"] #hero-wrap,
body[data-tab="mesh"] #zoning-hero,
body[data-tab="mesh"] #hero-reopen-btn,
body[data-tab="mesh"] #zoning-hero-reopen-btn,
body[data-tab="mesh"] #chart-wrap,
body[data-tab="mesh"] #chart-reopen-btn,
body[data-tab="mesh"] #absorption-badge,
body[data-tab="mesh"] #absorption-reopen-btn,
body[data-tab="mesh"] #legend,
body[data-tab="mesh"] #legend-reopen-btn{display:none!important}

/* ── BOTTOM TIME SLIDER ───────────────────────────────────────────────── */
#bottom-bar{grid-column:1/-1;background:linear-gradient(to top,var(--bg2),var(--bg));border-top:1px solid var(--border);padding:12px 22px;display:flex;align-items:center;gap:18px;font-size:11px;color:var(--text2)}
#time-slider-wrap{flex:1;display:flex;align-items:center;gap:16px;position:relative;min-width:0}
#time-year{font-size:28px;font-weight:700;color:var(--text);min-width:72px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;line-height:1}
#time-slider-track{flex:1;position:relative;height:28px;display:flex;align-items:center}
#time-slider{width:100%;-webkit-appearance:none;appearance:none;height:6px;background:var(--bg4);border-radius:4px;outline:none;cursor:pointer;margin:0;transition:background 0.15s}
#time-slider:hover{background:var(--bg3)}
#time-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid var(--bg);box-shadow:0 0 0 2px var(--accent),0 2px 6px rgba(0,0,0,0.4);transition:transform 0.1s}
#time-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}
#time-slider::-webkit-slider-thumb:active{transform:scale(1.15)}
#time-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);cursor:pointer;border:3px solid var(--bg);box-shadow:0 0 0 2px var(--accent),0 2px 6px rgba(0,0,0,0.4)}
#time-dots{position:absolute;left:14px;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;display:flex;justify-content:space-between}
#time-dots span{width:3px;height:3px;border-radius:50%;background:var(--text3);opacity:0.4}
#time-readout{display:flex;gap:22px;font-size:12px;font-variant-numeric:tabular-nums}
#time-readout span{display:flex;align-items:baseline;gap:5px}
#time-readout b{color:var(--text);font-weight:600;font-size:14px}
#play-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg3);color:var(--text);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all 0.15s;flex-shrink:0}
#play-btn:hover{background:var(--accent);color:var(--bg);transform:scale(1.05)}
#play-btn:active{transform:scale(0.95)}

/* ── LOADING ──────────────────────────────────────────────────────────── */
#loading{position:fixed;inset:0;background:rgba(30,30,46,0.96);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity 0.3s}
#loading.hidden{opacity:0;pointer-events:none;visibility:hidden}
#loading .spinner{width:42px;height:42px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#loading p{margin-top:14px;color:var(--text2);font-size:13px}
#loading .sub{color:var(--text3);font-size:11px;margin-top:4px}

/* ── DATA WARNING BANNER ─────────────────────────────────────────────── */
.warn-banner{background:rgba(253,174,97,0.12);border:1px solid rgba(253,174,97,0.4);color:var(--orange);padding:8px 30px 8px 12px;border-radius:5px;font-size:11px;margin-bottom:10px;line-height:1.4;position:relative}
.warn-banner b{color:#ffd899}
.warn-dismiss{position:absolute;top:4px;right:6px;background:none;border:none;color:var(--orange);font-size:16px;cursor:pointer;padding:2px 6px;line-height:1;opacity:0.6}
.warn-dismiss:hover{opacity:1}

/* ── SECTION STYLING ─────────────────────────────────────────────────── */
.section{margin-bottom:16px}
.section-title{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--text2);letter-spacing:1.1px;margin-bottom:10px;display:flex;align-items:center;justify-content:flex-start;gap:4px;cursor:pointer;user-select:none;transition:color 0.15s}
.section-title:hover{color:var(--text)}
.section-title::after{content:'';display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text3);transition:transform 0.2s;flex-shrink:0;margin-left:auto}
.section.collapsed .section-title::after{transform:rotate(-90deg)}
.section.collapsed .section-body{display:none}
.section-sub{font-weight:400;font-size:9.5px;text-transform:none;color:var(--text3);letter-spacing:0.1px}
.scope-badge{display:inline-flex;align-items:center;gap:3px;margin-left:6px;padding:2px 6px;border-radius:999px;border:1px solid rgba(137,180,250,0.20);background:rgba(137,180,250,0.08);color:var(--accent2);font-size:8px;font-weight:800;letter-spacing:0.7px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}
.scope-badge.display{border-color:rgba(166,173,200,0.18);background:rgba(166,173,200,0.07);color:var(--text3)}
.preset-note,.control-note{font-size:10px;line-height:1.45;color:var(--text3);margin-top:8px}
.preset-note b,.control-note b{color:var(--text2);font-weight:600}

/* ── SCENARIO PRESETS ─────────────────────────────────────────────────── */
.preset-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;margin-bottom:10px}
.preset-btn{padding:11px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg2);color:var(--text2);cursor:pointer;transition:all 0.18s cubic-bezier(.2,.6,.2,1);font-size:11px;text-align:left;position:relative;overflow:hidden}
.preset-btn:hover{background:var(--bg3);color:var(--text);border-color:var(--text3);transform:translateY(-1px)}
.preset-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent);box-shadow:0 2px 8px rgba(137,180,250,0.25)}
.preset-btn .preset-name{font-weight:600;font-size:12px;display:block;margin-bottom:2px;letter-spacing:-0.005em}
.preset-btn .preset-desc{font-size:9px;text-transform:uppercase;letter-spacing:0.9px;opacity:0.75;font-weight:600}
.preset-btn.active .preset-desc{opacity:0.95}
.preset-drift{display:inline-block;padding:2px 7px;border-radius:4px;background:var(--orange);color:var(--bg);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;vertical-align:1px}
.preset-drift.pulse{animation:pulsehi 0.6s ease-out 1}
@keyframes pulsehi{0%{transform:scale(1.3);box-shadow:0 0 0 4px rgba(253,174,97,0.4)}100%{transform:scale(1);box-shadow:0 0 0 0 rgba(253,174,97,0)}}
.reset-preset-btn{font-size:10px;padding:3px 8px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--text2);cursor:pointer;margin-left:8px;transition:all 0.15s}
.reset-preset-btn:hover{background:var(--bg3);color:var(--text);border-color:var(--text3)}

/* ── SLIDERS ─────────────────────────────────────────────────────────── */
.slider-row{margin-bottom:9px;position:relative}
.slider-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px;font-size:10.5px;gap:4px}
.slider-label .label-text{display:flex;align-items:center;gap:5px;flex:1;min-width:0}
.slider-label .label-text .color-dot{flex-shrink:0}
.slider-label .label-text .label-main{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slider-label .pct{font-weight:600;min-width:38px;text-align:right;color:var(--text);font-size:11px}
.slider-label .preset-hint{font-size:9px;color:var(--text3);margin-right:4px;font-variant-numeric:tabular-nums}
.slider-label .reset-slider{font-size:10px;color:var(--text3);cursor:pointer;padding:1px 4px;border-radius:3px;display:none}
.slider-label .reset-slider:hover{color:var(--text);background:var(--bg3)}
.slider-row.drifted .reset-slider{display:inline-block}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:3px;outline:none;cursor:pointer;background:var(--bg3);transition:background 0.08s}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;border:2px solid var(--bg);box-shadow:0 1px 4px rgba(0,0,0,0.4);transition:transform 0.1s}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
input[type=range]::-webkit-slider-thumb:active{transform:scale(1.25)}
input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;cursor:pointer;border:2px solid var(--bg);box-shadow:0 1px 4px rgba(0,0,0,0.4)}
input[type=range]:disabled{opacity:0.4;cursor:not-allowed}
.slider-caption{font-size:9.5px;color:var(--text3);margin-top:2px;font-style:italic}
.slider-contribution{font-size:9.5px;color:var(--text2);text-align:right;font-variant-numeric:tabular-nums}

/* ── CHECKBOXES ───────────────────────────────────────────────────────── */
.check-group{display:flex;flex-wrap:wrap;gap:4px 8px}
.check-item{display:flex;align-items:center;gap:5px;font-size:10.5px;cursor:pointer;line-height:1.3}
.check-item input{accent-color:var(--accent);cursor:pointer}
.layer-toggle-list{display:flex;flex-direction:column;gap:7px}
.layer-toggle-item{align-items:flex-start;gap:7px;margin-bottom:0}
.layer-toggle-item .scope-badge{margin-left:0;font-size:7.5px;padding:1px 5px}
.layer-toggle-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.layer-toggle-title{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.layer-toggle-help{font-size:9.5px;line-height:1.35;color:var(--text3)}
.color-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.color-swatch{width:11px;height:3px;border-radius:2px;display:inline-block;flex-shrink:0}
.color-swatch.line-solid{background:var(--swatch-color)!important}
.color-swatch.line-dashed{height:4px;background:repeating-linear-gradient(90deg,var(--swatch-color) 0 5px,transparent 5px 8px)!important}

/* ── DUAL RANGE ───────────────────────────────────────────────────────── */
.dual-range-wrap{position:relative;height:24px;margin:4px 0}
.dual-range-wrap input[type=range]{position:absolute;width:100%;pointer-events:none;background:transparent;height:5px;top:9px}
.dual-range-wrap input[type=range]::-webkit-slider-thumb{pointer-events:all}
.range-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text3)}

/* ── SEARCH ──────────────────────────────────────────────────────────── */
.search-input{width:100%;padding:6px 9px;border-radius:4px;border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:11.5px;outline:none}
.search-input:focus{border-color:var(--accent)}

/* ── MUNI TOTAL ──────────────────────────────────────────────────────── */
.muni-total{font-size:10.5px;color:var(--text2);padding-top:8px;margin-top:6px;border-top:1px dashed var(--border)}
.muni-total b{color:var(--text)}
.muni-missing{color:var(--text3);font-style:italic;font-size:9.5px}
.muni-stackbar{width:100%;height:14px;border-radius:3px;overflow:hidden;display:flex;margin-top:6px;background:var(--bg3);box-shadow:inset 0 0 0 1px rgba(255,255,255,0.04)}
.muni-stackbar-seg{height:100%;transition:flex-basis 0.18s ease-out,flex-grow 0.18s ease-out}
.muni-stackbar-seg:hover{filter:brightness(1.15)}
.muni-stacklegend{display:flex;flex-wrap:wrap;gap:4px 10px;margin-top:6px;font-size:9.5px;color:var(--text3)}
.muni-stacklegend .tag{display:flex;align-items:center;gap:4px}
.muni-stacklegend .swatch{width:8px;height:8px;border-radius:2px;display:inline-block;flex-shrink:0}

/* ── SUPPLY TOTAL ────────────────────────────────────────────────────── */
.supply-total{font-size:10.5px;color:var(--text2);text-align:right;padding-top:5px;margin-top:4px;border-top:1px dashed var(--border)}
.supply-total b{color:var(--text)}

/* ── HERO NUMBERS (top-left of map, compact) ─────────────────────────── */
.hero-wrap{position:absolute;top:var(--map-overlay-top);left:var(--map-overlay-left);background:rgba(23,23,36,0.94);border:1px solid rgba(137,180,250,0.15);border-radius:10px;padding:12px 34px 12px 18px;z-index:1000;backdrop-filter:blur(10px);box-shadow:0 8px 24px rgba(0,0,0,0.4);max-width:calc(100% - 500px)}
.hero-wrap.hidden{display:none}
.hero-close{position:absolute;top:8px;right:8px;min-width:32px;min-height:32px;background:transparent;border:none;color:var(--text3);font-size:18px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:5px;transition:all 0.15s}
.hero-close:hover{background:var(--bg3);color:var(--text)}
.overlay-reopen-btn{position:absolute;top:var(--map-overlay-top);left:var(--map-overlay-left);min-height:34px;background:rgba(23,23,36,0.92);border:1px solid rgba(137,180,250,0.2);color:var(--text2);padding:7px 12px;border-radius:6px;font-size:10.5px;cursor:pointer;z-index:999;backdrop-filter:blur(8px);text-transform:uppercase;letter-spacing:0.65px;font-weight:700;transition:all 0.15s}
.overlay-reopen-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.hero-row{display:flex;gap:22px;align-items:flex-end}
.hero-answer{font-size:12px;line-height:1.35;color:var(--text);margin:0 18px 10px 0;max-width:540px}
.hero-answer b{color:var(--accent2)}
.hero-answer .warn{color:var(--orange);font-weight:700}
.hero-answer .closed{color:var(--lgreen);font-weight:700}
.hero-cell{text-align:left;position:relative;min-width:54px;border-radius:4px}
.hero-cell:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.hero-label{font-size:9px;text-transform:uppercase;color:var(--text2);letter-spacing:0.9px;margin-bottom:3px;font-weight:700;line-height:1.2}
.hero-val{font-size:30px;font-weight:700;color:var(--text);line-height:0.95;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;transition:color 0.2s}
.hero-unit{font-size:9px;color:var(--text2);margin-top:3px;text-transform:uppercase;letter-spacing:0.45px;font-weight:600}
.hero-val.gap-moderate{color:var(--gap-warn)}
.hero-val.gap-severe{color:var(--gap-severe)}
.hero-val.gap-surplus{color:var(--surplus)}
.hero-val.fade{animation:heroFade 0.22s ease-out}
@keyframes heroFade{0%{opacity:0.3;transform:translateY(-2px)}100%{opacity:1;transform:translateY(0)}}
.hero-divider{width:1px;background:linear-gradient(to bottom,transparent 0%,var(--border) 30%,var(--border) 70%,transparent 100%);align-self:stretch;margin:2px 0}
.hero-tooltip{display:none}
.hero-demand-bar{margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.06);display:flex;flex-direction:column;gap:5px}
.hero-demand-bar-label{font-size:8.5px;text-transform:uppercase;color:var(--text3);letter-spacing:0.9px;font-weight:600;display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.hero-demand-bar-label .lead{color:var(--text2);font-weight:500;text-transform:none;letter-spacing:0;text-align:right}
.hero-demand-bar-track{height:6px;display:flex;border-radius:3px;overflow:hidden;background:var(--bg3);box-shadow:inset 0 0 0 1px rgba(255,255,255,0.05)}
.hero-demand-bar-seg{height:100%;transition:flex-basis 0.22s ease-out,flex-grow 0.22s ease-out;position:relative}
.hero-demand-bar-seg:hover{filter:brightness(1.2)}
.hero-demand-bar-tags{display:flex;gap:10px;flex-wrap:wrap;font-size:9px;color:var(--text3)}
.hero-demand-bar-tags .tag{display:flex;align-items:center;gap:4px}
.hero-demand-bar-tags .swatch{width:7px;height:7px;border-radius:1px;flex-shrink:0}
.hero-demand-bar-tags .tag b{color:var(--text2);font-weight:600}
.hero-difference-note{margin-top:9px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.06);font-size:10px;line-height:1.35;color:var(--text3);max-width:520px}
.hero-difference-note b{color:var(--text2);font-weight:600}
.hero-exclusion-note{display:none;margin-top:8px;padding:8px 10px;border:1px solid rgba(253,174,97,0.22);border-radius:6px;background:rgba(253,174,97,0.08);font-size:10.5px;line-height:1.35;color:var(--text2);max-width:520px}
.hero-exclusion-note b{color:#ffd899;font-weight:700}
.hero-exclusion-note button{float:right;margin-left:10px;margin-top:-1px;min-height:24px;border:1px solid rgba(253,174,97,0.34);border-radius:4px;background:rgba(253,174,97,0.12);color:#ffd899;font-size:9px;line-height:1.1;font-weight:700;letter-spacing:0.65px;text-transform:uppercase;padding:5px 8px;cursor:pointer}
.hero-exclusion-note button:hover{background:rgba(253,174,97,0.22);border-color:rgba(253,174,97,0.52)}
.hero-narrative{margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,0.06);font-size:11px;line-height:1.45;color:var(--text2);max-width:520px}
.hero-narrative b{color:var(--accent2);font-weight:600}
.hero-narrative em{color:var(--orange);font-style:normal;font-weight:600}
.hero-narrative em.closes{color:var(--lgreen)}
.zoning-meter{margin-top:10px;padding-top:9px;border-top:1px solid rgba(255,255,255,0.06);display:flex;flex-direction:column;gap:6px}
.zoning-meter-label{display:flex;justify-content:space-between;gap:12px;font-size:9px;text-transform:uppercase;letter-spacing:0.9px;color:var(--text3);font-weight:700}
.zoning-meter-track{height:8px;border-radius:999px;background:var(--bg3);overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.05)}
.zoning-meter-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--lgreen));transition:width 0.18s ease-out}
.zoning-meter-note{font-size:10.5px;line-height:1.35;color:var(--text2)}
.zoning-meter-note b{color:var(--text)}
.zoning-chart-panel{margin-top:10px;padding-top:9px;border-top:1px solid rgba(255,255,255,0.06)}
.zoning-chart-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:5px}
.zoning-chart-title{font-size:9px;text-transform:uppercase;letter-spacing:0.9px;color:var(--text3);font-weight:700}
.zoning-chart-note{font-size:9.5px;color:var(--text3);text-align:right}
.zoning-chart-frame{width:100%;height:148px;position:relative}
.zoning-chart-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:5px;font-size:9.5px;color:var(--text2)}
.zoning-chart-legend span{display:flex;align-items:center;gap:5px}

/* Narrative styles now live in .hero-narrative (inside hero-wrap) */

/* ── GAP CHART (floats at top-right of map) ────────────────────────── */
#chart-wrap{position:absolute;top:16px;right:16px;width:380px;height:240px;background:rgba(23,23,36,0.94);border:1px solid rgba(137,180,250,0.15);border-radius:10px;padding:12px 14px 8px 14px;z-index:999;backdrop-filter:blur(10px);box-shadow:0 8px 24px rgba(0,0,0,0.4);transition:all 0.25s cubic-bezier(.2,.6,.2,1)}
#chart-wrap.collapsed{width:180px;height:40px;padding:10px 14px;cursor:pointer}
#chart-wrap.collapsed canvas,#chart-wrap.collapsed .chart-legend{display:none}
#chart-wrap.hidden{display:none}
#chart-reopen-btn{position:absolute;top:16px;right:16px;min-height:34px;background:rgba(23,23,36,0.92);border:1px solid rgba(137,180,250,0.2);color:var(--text2);padding:7px 12px;border-radius:6px;font-size:10.5px;cursor:pointer;z-index:999;backdrop-filter:blur(8px);text-transform:uppercase;letter-spacing:0.65px;font-weight:700;transition:all 0.15s}
#chart-reopen-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.chart-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.chart-title{font-size:10.5px;font-weight:700;text-transform:uppercase;color:var(--text2);letter-spacing:1px}
.chart-subtitle{font-size:9.5px;color:var(--text3);margin-left:8px;font-weight:400}
.chart-collapse{min-width:28px;min-height:28px;background:none;border:none;color:var(--text2);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:4px;line-height:1}
.chart-collapse:hover{background:var(--bg3);color:var(--text)}
.chart-legend{display:flex;gap:16px;font-size:9.5px;color:var(--text2);margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,0.05)}
.chart-legend span{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;transition:opacity 0.15s}
.chart-legend span:hover{color:var(--text)}
.chart-legend span.hidden{opacity:0.35;text-decoration:line-through}

/* ── NARRATIVE SUMMARY CARD (moved into left sidebar) ───────────────── */
#narrative-card{margin-top:14px;padding:12px 0 0;border-top:1px solid var(--border);font-size:11px;color:var(--text2);line-height:1.5}
#narrative-card h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.1px;color:var(--text2);margin-bottom:8px}
#narrative-card ul{list-style:none;padding:0}
#narrative-card li{margin-bottom:6px;position:relative;padding-left:12px}
#narrative-card li:last-child{margin-bottom:0}
#narrative-card li::before{content:'';position:absolute;left:2px;top:6px;width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:0.6}
#narrative-card li b{color:var(--text);font-weight:600}

/* ── ABSORPTION BADGE (tiny pill, map corner) ─────────────────────────── */
#absorption-badge{position:absolute;bottom:12px;left:12px;background:rgba(23,23,36,0.88);border:1px solid rgba(137,180,250,0.08);padding:5px 26px 5px 10px;border-radius:14px;font-size:10px;color:var(--text3);z-index:998;backdrop-filter:blur(8px);font-variant-numeric:tabular-nums}
#absorption-badge b{color:var(--text2);font-weight:600}
#absorption-badge .panel-close{top:1px;right:1px;font-size:13px;padding:1px 5px}
#absorption-reopen-btn,#legend-reopen-btn{position:absolute;bottom:12px;background:rgba(23,23,36,0.92);border:1px solid rgba(137,180,250,0.2);color:var(--text2);padding:5px 10px;border-radius:14px;font-size:10px;cursor:pointer;z-index:998;backdrop-filter:blur(8px);text-transform:uppercase;letter-spacing:0.6px;font-weight:600}
#absorption-reopen-btn{left:12px}
#legend-reopen-btn{right:12px}
#absorption-reopen-btn:hover,#legend-reopen-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}

/* ── LEGEND (bottom-right, compact) ───────────────────────────────── */
.legend{position:absolute;bottom:12px;right:16px;background:rgba(23,23,36,0.88);padding:8px 11px;border-radius:8px;z-index:1000;font-size:10px;color:var(--text);backdrop-filter:blur(8px);border:1px solid rgba(137,180,250,0.08);box-shadow:0 2px 8px rgba(0,0,0,0.3);max-width:200px}
.legend-title{font-weight:700;margin-bottom:8px;color:var(--text);text-transform:uppercase;letter-spacing:1px;font-size:9.5px}
.legend-group{margin-top:8px;padding-top:7px;border-top:1px solid rgba(255,255,255,0.06)}
.legend-group-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.9px;margin-bottom:4px;font-weight:600}
.legend-row{display:flex;align-items:center;gap:7px;margin-bottom:4px;line-height:1.3}
.legend-row:last-child{margin-bottom:0}
.legend-row .sub{color:var(--text2);font-size:9.5px;margin-left:auto;font-variant-numeric:tabular-nums}
.legend-swatch{width:14px;height:10px;border-radius:2px;display:inline-block;flex-shrink:0}
.legend-swatch.hatched{background:repeating-linear-gradient(45deg,rgba(127,66,66,0.5),rgba(127,66,66,0.5) 3px,transparent 3px,transparent 6px);border:1px dashed rgba(176,96,96,0.6)}
.legend-grades{display:flex;gap:3px;align-items:center}
.legend-grades .legend-swatch{width:10px;height:10px}
.legend-base-group{display:contents}
.legend-note{font-size:9px;line-height:1.35;color:var(--text3);margin:5px 0 4px}
.legend-note b{color:var(--text2);font-weight:600}
.map-hint{position:absolute;left:12px;bottom:48px;z-index:997;max-width:320px;padding:7px 10px;border-radius:8px;background:rgba(23,23,36,0.9);border:1px solid rgba(137,180,250,0.18);color:var(--text2);font-size:10.5px;line-height:1.35;backdrop-filter:blur(8px);box-shadow:0 2px 8px rgba(0,0,0,0.28)}
.map-hint b{color:var(--accent2)}
body[data-tab="mesh"] .map-hint{display:none!important}

/* Map hover popups: shared MapLibre/Leaflet styling */
.maplibregl-popup.map-hover-tooltip{z-index:1600;max-width:min(300px,calc(100vw - 24px))}
.maplibregl-popup.map-hover-tooltip .maplibregl-popup-content{
  background:rgba(16,20,36,0.98);
  color:#e7efff;
  border:1px solid rgba(137,180,250,0.34);
  border-radius:6px;
  box-shadow:0 16px 36px rgba(0,0,0,0.68),0 0 0 1px rgba(255,255,255,0.035);
  padding:7px 9px;
  font-size:11px;
  line-height:1.42;
}
.maplibregl-popup.map-hover-tooltip .maplibregl-popup-content b{color:#fff;font-weight:800}
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:rgba(16,20,36,0.98)}
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:rgba(16,20,36,0.98)}
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-left .maplibregl-popup-tip{border-right-color:rgba(16,20,36,0.98)}
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-right .maplibregl-popup-tip{border-left-color:rgba(16,20,36,0.98)}
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-top-left .maplibregl-popup-tip,
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-top-right .maplibregl-popup-tip{border-bottom-color:rgba(16,20,36,0.98)}
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-bottom-left .maplibregl-popup-tip,
.maplibregl-popup.map-hover-tooltip.maplibregl-popup-anchor-bottom-right .maplibregl-popup-tip{border-top-color:rgba(16,20,36,0.98)}

/* Sending parcel popup: shared MapLibre/Leaflet styling */
.maplibregl-popup.sending-flood-popup{z-index:1105;max-width:min(320px,calc(100vw - 32px))}
.maplibregl-popup.sending-flood-popup .maplibregl-popup-content,
.leaflet-tooltip.sending-flood-popup{
  background:rgba(23,23,36,0.97);
  color:var(--text);
  border:1px solid rgba(137,180,250,0.24);
  border-radius:8px;
  box-shadow:0 14px 34px rgba(0,0,0,0.48);
  padding:10px 12px;
  font-size:11px;
  line-height:1.42;
}
.maplibregl-popup.sending-flood-popup .maplibregl-popup-content{min-width:236px}
.maplibregl-popup.sending-flood-popup .maplibregl-popup-close-button{
  color:var(--text2);
  font-size:17px;
  padding:4px 7px;
  border-radius:4px;
}
.maplibregl-popup.sending-flood-popup .maplibregl-popup-close-button:hover{background:rgba(137,180,250,0.12);color:var(--text)}
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:rgba(23,23,36,0.97)}
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:rgba(23,23,36,0.97)}
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-left .maplibregl-popup-tip{border-right-color:rgba(23,23,36,0.97)}
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-right .maplibregl-popup-tip{border-left-color:rgba(23,23,36,0.97)}
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-top-left .maplibregl-popup-tip,
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-top-right .maplibregl-popup-tip{border-bottom-color:rgba(23,23,36,0.97)}
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-bottom-left .maplibregl-popup-tip,
.maplibregl-popup.sending-flood-popup.maplibregl-popup-anchor-bottom-right .maplibregl-popup-tip{border-top-color:rgba(23,23,36,0.97)}
.sf-popup{min-width:218px;max-width:286px}
.sf-popup-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:5px;padding-right:10px}
.sf-popup-title{font-weight:800;color:var(--text);letter-spacing:0.2px}
.sf-popup-tag{flex-shrink:0;border:1px solid rgba(166,173,200,0.20);border-radius:999px;padding:2px 6px;color:var(--text3);font-size:8px;font-weight:800;letter-spacing:0.7px;text-transform:uppercase}
.sf-popup-address{color:var(--text2);margin-bottom:7px;line-height:1.35}
.sf-popup-row{display:grid;grid-template-columns:minmax(94px,auto) minmax(0,1fr);gap:8px;margin-top:3px}
.sf-popup-label{color:#b7c9df;font-weight:700}
.sf-popup-value{color:var(--text);min-width:0}
.sf-popup-note{margin-top:8px;padding-top:7px;border-top:1px solid rgba(255,255,255,0.08);color:var(--text2);font-size:10px;line-height:1.35}

/* ── RIGHT DETAIL PANEL ─────────────────────────────────────────────── */
.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.detail-header h2{font-size:14px;font-weight:600;line-height:1.3}
.close-btn{min-width:32px;min-height:32px;background:none;border:none;color:var(--text2);font-size:18px;cursor:pointer;padding:0 4px;border-radius:5px}
.close-btn:hover{color:var(--text)}
.grade-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;color:#000}
.grade-A{background:var(--green)}.grade-B{background:var(--lgreen)}.grade-C{background:var(--yellow)}.grade-D{background:var(--orange)}.grade-F{background:var(--red)}
#radar-container{width:100%;height:200px;margin:8px 0}
.detail-table{width:100%;font-size:11px;border-collapse:collapse}
.detail-table td{padding:3px 4px;border-bottom:1px solid var(--border)}
.detail-table td:first-child{color:var(--text2);width:42%}
.detail-table tr.detail-section-row td{padding:12px 4px 5px;border-bottom:none;color:var(--accent2);font-size:9px;font-weight:800;letter-spacing:1.1px;text-transform:uppercase}
.detail-table tr.detail-statement-row td{padding:8px 9px;border:1px solid rgba(137,180,250,0.14);border-radius:6px;background:rgba(137,180,250,0.06);display:table-cell;color:var(--text);font-size:11px;line-height:1.45}
.detail-table tr.detail-statement-row b{color:var(--accent2)}
.score-breakdown{margin-top:10px}
.score-row{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:10.5px}
.score-bar{flex:1;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.score-bar-fill{height:100%;border-radius:3px;transition:width 0.3s}
.score-val{min-width:30px;text-align:right;font-size:10px;color:var(--text2)}

/* ── VACANCY BADGES ─────────────────────────────────────────────────── */
.vac-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600}
.vac-Vacant{background:#ef4444;color:#fff}.vac-Parking{background:#f59e0b;color:#000}
.vac-Underutilized{background:#8b5cf6;color:#fff}.vac-Built{background:#6b7280;color:#fff}
.vac-Institutional{background:#374151;color:#9ca3af}

/* ── METHODOLOGY MODAL ───────────────────────────────────────────────── */
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.65);z-index:10000;display:none;align-items:center;justify-content:center}
#modal-overlay.open{display:flex}
#modal{background:var(--bg2);border:1px solid var(--border);border-radius:10px;max-width:720px;width:92%;max-height:85vh;overflow-y:auto;padding:28px;color:var(--text);font-size:13px;line-height:1.6;position:relative}
#modal h2{font-size:17px;margin-bottom:14px;color:var(--accent);letter-spacing:-0.01em}
#modal h3{font-size:13px;font-weight:700;margin-top:18px;margin-bottom:6px;color:var(--text);letter-spacing:0.01em}
#modal p,#modal li{color:var(--text2);margin-bottom:6px}
#modal ul{padding-left:20px}
#modal code{background:var(--bg3);padding:1px 5px;border-radius:3px;font-size:11px;color:var(--text);font-family:ui-monospace,Menlo,monospace}
#modal .modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--text2);font-size:22px;cursor:pointer}
#modal .modal-close:hover{color:var(--text)}
.source-grid{display:grid;grid-template-columns:minmax(120px,0.8fr) minmax(0,1.8fr) minmax(96px,0.75fr);gap:1px;margin:10px 0 12px;background:var(--border);border:1px solid var(--border);border-radius:6px;overflow:hidden;font-size:11.5px}
.source-grid div{background:var(--bg2);padding:7px 8px;line-height:1.35;color:var(--text2)}
.source-grid .head{background:var(--bg3);color:var(--text);font-weight:700;text-transform:uppercase;letter-spacing:0.6px;font-size:9px}
.source-grid .ok{color:var(--lgreen);font-weight:700}
.source-grid .warn{color:var(--orange);font-weight:700}
.source-grid code{font-size:10px}

/* ── LEAFLET OVERRIDES ────────────────────────────────────────────────── */
.leaflet-tooltip-pane{z-index:1600!important;pointer-events:none}
.leaflet-tooltip{
  background:rgba(16,20,36,0.98);
  border:1px solid rgba(137,180,250,0.34);
  color:#e7efff;
  border-radius:6px;
  font-size:11px;
  line-height:1.42;
  box-shadow:0 16px 36px rgba(0,0,0,0.68),0 0 0 1px rgba(255,255,255,0.035);
}
.leaflet-tooltip.map-hover-tooltip{
  max-width:min(300px,calc(100vw - 24px));
  padding:7px 9px;
  white-space:normal;
}
.leaflet-tooltip.map-hover-tooltip b{color:#fff;font-weight:800}
.leaflet-tooltip-top:before{border-top-color:rgba(137,180,250,0.34)}
.leaflet-tooltip-bottom:before{border-bottom-color:rgba(137,180,250,0.34)}
.leaflet-tooltip-left:before{border-left-color:rgba(137,180,250,0.34)}
.leaflet-tooltip-right:before{border-right-color:rgba(137,180,250,0.34)}
.leaflet-popup-content-wrapper{background:var(--bg2);color:var(--text);border:1px solid var(--border)}

/* Muni map labels */
.muni-label-wrap{background:transparent!important;border:none!important}
.muni-map-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-align:center;color:#b4befe;text-shadow:0 0 3px rgba(0,0,0,0.9),0 0 6px rgba(0,0,0,0.6);pointer-events:none;white-space:nowrap}
.muni-map-label.revere-label{font-size:13px;letter-spacing:2.5px;color:#fff}
.muni-map-label .muni-label-sub{font-size:8px;letter-spacing:1px;font-weight:500;color:var(--accent2);margin-top:1px;text-transform:uppercase}

/* ── RESPONSIVE ───────────────────────────────────────────────────────── */
@media(max-width:1280px){
  #chart-wrap{width:320px;height:220px}
  .hero-row{gap:18px}
  .hero-val{font-size:26px}
  .hero-wrap{max-width:calc(100% - 440px)}
}
#app.detail-open #chart-wrap{width:280px;height:220px}
#app.detail-open .hero-wrap{max-width:calc(100% - 400px);padding:10px 14px}
#app.detail-open .hero-row{gap:16px}
#app.detail-open .hero-val{font-size:24px}
@media(max-width:900px){
  #app,#app.detail-open{grid-template-columns:1fr;grid-template-rows:86px auto 1fr auto 80px}
  #app,header,#left-panel,#map-container,#bottom-bar{min-width:0;width:100%}
  header{display:grid;grid-template-columns:auto 1fr auto auto;grid-template-rows:auto auto;gap:6px;padding:7px 10px;overflow:visible;align-content:center}
  header::-webkit-scrollbar{display:none}
  header h1{display:none}
  header .spacer{display:none}
  .tab-strip{grid-column:1/-1;grid-row:1;margin-left:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;width:100%}
  .tab-btn{font-size:10px;line-height:1.2;min-height:42px;padding:7px 6px;white-space:normal;overflow-wrap:anywhere;min-width:0;border-radius:6px;top:0;text-align:center}
  .basemap-toggle{display:none}
  header .header-btn{min-height:32px;padding:5px 8px;white-space:nowrap;min-width:0}
  #sidebar-toggle-btn{grid-column:1;grid-row:2}
  #share-btn{grid-column:3;grid-row:2}
  #methodology-btn{grid-column:4;grid-row:2}
  #left-panel{grid-row:2;grid-column:1;max-height:230px;border-right:none;border-bottom:1px solid var(--border);padding:10px 14px}
  .sidebar-jump-nav{top:-10px;margin:0 0 12px;padding:6px 0 8px;width:100%;min-width:0}
  .sidebar-jump-btn{min-width:0;font-size:8.5px;padding:6px 4px}
  .section-title{flex-wrap:wrap;align-items:flex-start;gap:4px 6px;line-height:1.25;letter-spacing:0.75px}
  .section-title::after{margin-left:0;margin-top:4px}
  .section-sub{flex-basis:100%;font-size:9.5px;line-height:1.25}
  .scope-badge{margin-left:0;white-space:normal;line-height:1.15}
  .preset-btn{min-width:0}
  .preset-btn .preset-name{font-size:11px}
  .slider-label{align-items:flex-start;gap:6px}
  .slider-label .label-text{align-items:flex-start;flex-wrap:wrap;line-height:1.25}
  .slider-label .label-text .label-main{white-space:normal;overflow:visible;text-overflow:clip;overflow-wrap:anywhere}
  .slider-label .pct{flex-shrink:0;max-width:44%;overflow-wrap:anywhere;line-height:1.2}
  .check-item{min-height:28px;align-items:flex-start}
  .check-item input{margin-top:2px;min-width:16px;min-height:16px}
  #map-container{grid-row:3;grid-column:1;min-height:300px}
  body[data-tab="mesh"] #app,
  body[data-tab="mesh"] #app.detail-open{grid-template-columns:1fr;grid-template-rows:48px minmax(0,1fr)}
  body[data-tab="mesh"] header{min-height:48px;padding:4px 12px;align-content:center}
  body[data-tab="mesh"] .tab-strip{align-items:center}
  body[data-tab="mesh"] .tab-btn{min-height:34px}
  body[data-tab="mesh"] #map-container{grid-row:2;grid-column:1;min-height:0;height:100%}
  #right-panel{grid-row:4;grid-column:1;max-height:260px;border-left:none;border-top:1px solid var(--border)}
  #app.detail-open #right-panel{display:block}
  #bottom-bar{grid-row:5;padding:10px 12px;gap:10px}
  #time-slider-wrap{gap:8px}
  #time-year{font-size:24px;min-width:58px}
  #time-readout{display:none}
  #play-btn{width:34px;height:34px}
  #chart-wrap,#chart-reopen-btn{display:none!important}
  #narrative-card,#absorption-badge{position:static;margin:10px;width:auto}
  .hero-wrap{position:absolute;top:10px;left:58px;right:auto;margin:0;max-width:none;width:calc(100% - 68px);min-width:0;max-height:235px;overflow-y:auto;padding:10px 42px 10px 12px}
  .hero-answer{font-size:11px;margin:0 18px 8px 0}
  .hero-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px;align-items:start}
  .hero-cell{min-width:0}
  .hero-demand-bar,.hero-demand-bar-label,.hero-demand-bar-tags{min-width:0}
  .hero-divider{display:none}
  .hero-val{font-size:22px}
  .hero-label{font-size:8.5px;letter-spacing:0.55px;overflow-wrap:anywhere}
  .hero-unit{font-size:8.5px;letter-spacing:0.35px;overflow-wrap:anywhere}
  .hero-difference-note,.hero-exclusion-note,.hero-narrative{max-width:none}
  .overlay-reopen-btn{top:10px;left:58px;max-width:calc(100% - 68px);white-space:normal;line-height:1.2;text-align:left}
  .map-hint{display:none}
  .legend{right:10px;bottom:10px;max-width:min(240px,calc(100% - 20px));max-height:46vh;overflow:auto;padding:8px 10px;font-size:9.8px}
  .legend-title{font-size:8.5px;margin-bottom:5px;letter-spacing:0.8px}
  .legend-group{margin-top:6px;padding-top:6px}
  .legend-group-label{font-size:8px;line-height:1.25;margin-bottom:3px;letter-spacing:0.7px}
  .legend-row{gap:5px;margin-bottom:3px;line-height:1.2}
  .legend-row .sub{font-size:8.7px}
  .legend-swatch{width:10px;height:8px}
  .legend-note{font-size:8.3px;line-height:1.25;margin:4px 0}
  #legend-content.has-sending-flood-legend .legend-base-group{display:none}
  .sf-popup{max-width:250px}
  .sf-popup-row{grid-template-columns:1fr;gap:1px;margin-top:5px}
  .native-field-mode-tabs{top:14px;left:12px;right:12px;transform:none;justify-content:center;gap:4px}
  .native-field-mode-btn{flex:1;min-width:0;min-height:38px;padding:8px 6px;font-size:9px;letter-spacing:0.65px;line-height:1.15;white-space:normal;overflow-wrap:anywhere}
  .native-export-controls{top:66px;left:12px;right:12px;justify-content:flex-end}
  .native-export-btn{min-width:54px}
  .native-context-card{left:14px;right:14px;bottom:84px;width:auto}
  .native-context-title{font-size:17px}
  .native-context-body{font-size:12px}
  .native-scale-card{left:14px;right:auto;bottom:14px}
  .onboarding-guide{top:104px;left:12px;right:12px;width:auto;max-height:calc(100vh - 118px);padding:13px 14px}
  .onboarding-guide.detail-demo{right:12px;width:auto}
  body[data-tab="mesh"] .onboarding-guide{top:54px;left:12px;right:12px;width:auto;max-height:calc(100vh - 68px)}
  body[data-tab="mesh"] #guide-btn{right:8px;top:6px;min-height:28px;padding:5px 8px}
  .detail-header{gap:10px}
  .detail-table,.detail-table tbody,.detail-table tr,.detail-table td{display:block;width:100%}
  .detail-table td{padding:4px 2px}
  .detail-table td:first-child{width:100%;border-bottom:none;color:var(--text2);font-weight:700}
  .detail-table tr{padding:5px 0;border-bottom:1px solid var(--border)}
  .detail-table tr.detail-section-row{border-bottom:none}
  .source-grid{grid-template-columns:1fr}
  .source-grid .head{display:none}
}

@media(max-width:520px){
  #app,#app.detail-open{grid-template-rows:92px auto 1fr auto 78px}
  #left-panel{max-height:220px}
  .preset-strip{grid-template-columns:1fr}
  .hero-row{grid-template-columns:1fr;gap:9px}
  .hero-wrap{max-height:260px}
  .hero-val{font-size:21px}
  .legend{font-size:9.5px}
  .guide-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}
  .guide-progress{grid-column:1/-1;margin-left:0;text-align:right}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
}

/* ── PRINT ───────────────────────────────────────────────────────────── */
@media print{
  #left-panel,#right-panel,#bottom-bar,header,.leaflet-control-container,#absorption-badge{display:none!important}
  #app{display:block}
  #map-container{page-break-after:always}
  body{background:#fff;color:#000}
  .hero-wrap,#narrative,#chart-wrap,#narrative-card{background:#fff!important;color:#000!important;border:1px solid #ccc!important}
}

/* ── ARIA / FOCUS ────────────────────────────────────────────────────── */
input:focus-visible,button:focus-visible,.preset-btn:focus-visible,.help-ico:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
