:root{--background:#101214;--surface:rgba(18,21,25,0.9);--surface-strong:rgba(248,250,252,0.96);--border:rgba(226,232,240,0.18);--text:#f8fafc;--text-dark:#111827;--muted:#a8b3c0;--accent:#36c08f;--accent-strong:#f4c430;--shadow:0 18px 48px rgba(0,0,0,0.26)}*{box-sizing:border-box}body,html{min-height:100%}body,html{background:var(--background)}body{margin:0;color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}button{font:inherit}.map-app{position:relative;height:100vh;height:100svh;min-height:100svh;overflow:hidden;background:var(--background)}.map-canvas{position:absolute;inset:0;width:100%;height:100%}.map-canvas .maplibregl-canvas:focus-visible,.map-canvas:focus-visible{outline:3px solid var(--accent-strong);outline-offset:-3px}.map-topbar{position:absolute;z-index:2;top:1rem;right:1rem;left:1rem;display:flex;min-height:5.25rem;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);pointer-events:auto}.map-title-group{display:grid;min-width:0;grid-gap:.2rem;gap:.2rem}.map-kicker,.panel-label{margin:0;color:var(--accent);font-size:.76rem;font-weight:700;line-height:1.2;letter-spacing:0;text-transform:uppercase}.map-title-group h1{margin:0;font-size:1.35rem;line-height:1.15}.map-title-group p:last-child{max-width:34rem;margin:0;color:var(--muted);font-size:.92rem;line-height:1.35}.layer-switch{display:grid;width:14rem;min-width:14rem;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.25rem;gap:.25rem;padding:.25rem;border:1px solid rgba(226,232,240,.16);border-radius:8px;background:rgba(4,7,10,.54)}.layer-switch-button{min-height:2.25rem;border:0;border-radius:6px;color:var(--muted);background:transparent;cursor:pointer;font-size:.88rem;font-weight:700;line-height:1}.layer-switch-button:hover{color:var(--text);background:rgba(248,250,252,.08)}.layer-switch-button[aria-pressed=true]{color:var(--text-dark);background:var(--surface-strong)}.map-side-panel{position:absolute;z-index:2;right:1rem;bottom:1rem;display:grid;width:min(19rem,calc(100vw - 2rem));grid-gap:.75rem;gap:.75rem;pointer-events:auto}.mood-legend,.region-panel{border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.region-panel{min-height:7.25rem;padding:.9rem 1rem}.region-panel h2{margin:.25rem 0 0;overflow-wrap:anywhere;font-size:1.14rem;line-height:1.2}.region-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.85rem;gap:.85rem;margin:.85rem 0 0}.region-metrics dt{color:var(--muted);font-size:.76rem;line-height:1.2}.region-metrics dd{margin:.18rem 0 0;overflow-wrap:anywhere;color:var(--text);font-size:1rem;font-weight:800;line-height:1.2}.mood-legend{padding:.85rem 1rem}.mood-band-list{display:grid;grid-gap:.45rem;gap:.45rem;margin:.7rem 0 0;padding:0;list-style:none}.mood-band-item{display:grid;min-height:1.55rem;grid-template-columns:.8rem minmax(0,1fr) auto;align-items:center;grid-gap:.55rem;gap:.55rem;color:var(--text);font-size:.86rem;line-height:1.2}.mood-band-swatch{width:.8rem;height:.8rem;border:1px solid rgba(248,250,252,.55);border-radius:999px}.mood-band-label{min-width:0;overflow-wrap:anywhere;font-weight:700}.mood-band-range{color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.maplibregl-ctrl-bottom-left{bottom:1rem;left:1rem}.maplibregl-ctrl-group{overflow:hidden;border:1px solid var(--border);border-radius:8px;background:var(--surface-strong);box-shadow:var(--shadow)}.maplibregl-ctrl-group button{width:2rem;height:2rem}@media (max-width:720px){.map-topbar{top:.75rem;right:.75rem;left:.75rem;flex-wrap:wrap;align-items:start;padding:.8rem}.map-title-group h1{font-size:1.16rem}.map-title-group p:last-child{font-size:.84rem}.layer-switch{width:100%;min-width:0}.map-side-panel{right:.75rem;bottom:.75rem;left:.75rem;width:auto;gap:.55rem}.region-panel{min-height:5.75rem}.mood-legend,.region-panel{padding:.8rem}.region-metrics{gap:.65rem}.maplibregl-ctrl-bottom-left{display:none}}