@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--bg0:#f6f3ec;--bg1:#e7f2f1;--ink:#0b1f22;--muted:#0b1f22ad;--line:#0b1f2224;--card:#ffffffb8;--card2:#ffffff9e;--shadow:#0b1f221f 0 16px 50px -18px;--accent:#0f766e;--accent2:#1d4ed8;--warn:#b45309;--danger:#b91c1c;--sans:"Space Grotesk", ui-sans-serif, system-ui;--mono:"IBM Plex Mono", ui-monospace, SFMono-Regular;font:16px/1.35 var(--sans);color:var(--ink);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{height:100%}body{background:radial-gradient(1000px 600px at 18% 12%, #0f766e29, transparent 55%), radial-gradient(900px 520px at 90% 18%, #1d4ed824, transparent 55%), radial-gradient(900px 520px at 35% 92%, #b453091a, transparent 55%), linear-gradient(180deg, var(--bg1), var(--bg0));margin:0;overflow:hidden}*{box-sizing:border-box}#root{height:100svh}h1,h2{letter-spacing:-.02em;margin:0;font-weight:600}h2{letter-spacing:.02em;text-transform:uppercase;font-size:14px}button,input{font:inherit}.app{max-width:none;margin:0;padding:0;position:fixed;inset:0;overflow:hidden}.app--ready{--enter:1}.topbar{border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:40;border-radius:16px;justify-content:space-between;align-items:flex-end;gap:14px;padding:14px 16px;display:flex;position:absolute;top:12px;left:12px;right:12px}.topbar__title{grid-template-rows:auto auto;grid-template-columns:38px 1fr;align-items:center;column-gap:10px;display:grid}.brand{border-radius:10px;grid-row:1/span 2;width:34px;height:34px;box-shadow:0 12px 28px -18px #0b1f2224}.kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:12px}.title{letter-spacing:-.03em;font-size:28px;line-height:1.05}.topbar__meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.meta{text-align:right}.meta--hero{text-align:left;background:#ffffff9e;border:1px solid #0b1f221f;border-radius:14px;padding:10px 12px}.meta--pill{text-align:left;background:#ffffff9e;border:1px solid #0b1f221f;border-radius:14px;min-width:190px;padding:10px 12px}.meta__label{color:var(--muted);font-size:12px}.meta__value{font-family:var(--mono);font-size:14px}.meta__value--big{letter-spacing:-.02em;font-size:18px}.meta__sub{color:#0b1f22ad;margin-top:4px;font-size:12px}.meta__row{align-items:center;gap:8px;display:inline-flex}.wxIcon{background:#0b1f220f;border-radius:10px;width:36px;height:36px}.btn{border:1px solid var(--line);cursor:pointer;background:#ffffffd9;border-radius:12px;padding:10px 12px;transition:transform .12s,background .12s,border-color .12s,box-shadow .14s}.btn:hover{border-color:#0b1f2247;transform:translateY(-1px);box-shadow:0 16px 34px -26px #0b1f2224}.btn:active{transform:translateY(0)}.main{grid-template-columns:1fr;align-items:start;gap:0;height:100%;margin-top:0;display:grid}.mapCard{box-shadow:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:0 0;border:0;border-radius:0;height:100%;position:relative;overflow:hidden}.mapCard:before,.panel:before{content:"";border-radius:inherit;pointer-events:none;opacity:.65;background:radial-gradient(900px 280px at 12% 0,#0f766e1a,#0000 55%),radial-gradient(900px 280px at 92% 0,#1d4ed81a,#0000 55%);position:absolute;inset:0}.mapCard:before{display:none}.gisDock{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffd9;border:1px solid #0b1f2229;border-radius:18px;padding:12px;position:absolute;bottom:54px;left:14px;right:14px;box-shadow:0 24px 60px -36px #0000002e}.gisDock__hd{border-bottom:1px solid #0b1f221f;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:10px;display:flex}.gisDock__title{font-weight:700}.gisDock__sub{font-family:var(--mono);color:#0b1f22b3;margin-top:4px;font-size:12px}.gisDock__grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;display:grid}.gisBlock{background:#ffffffa6;border:1px solid #0b1f221f;border-radius:14px;padding:10px}.gisBlock__title{letter-spacing:.08em;text-transform:uppercase;color:#0b1f22b3;margin-bottom:8px;font-size:12px}.gisRow{grid-template-columns:110px 1fr;align-items:center;gap:10px;margin-top:8px;font-size:13px;display:grid}.identify__title{margin-bottom:4px;font-weight:700}.identify__props{gap:6px;max-height:140px;margin-top:8px;display:grid;overflow:auto}.identify__row{grid-template-columns:120px 1fr;align-items:baseline;gap:10px;font-size:12px;display:grid}.identify__k{font-family:var(--mono);color:#0b1f22b8}.identify__v{font-family:var(--mono);color:#0b1f22e6;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mapCard__toolbar{left:12px;right:12px;top:calc(12px + var(--topbar-h,88px) + 10px);z-index:35;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb8;border:1px solid #0b1f2224;border-radius:16px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex;position:absolute;box-shadow:0 20px 60px -46px #0000002e}.toggles{flex-wrap:wrap;gap:10px;display:flex}.toggle{color:#0b1f22db;align-items:center;gap:8px;font-size:13px;display:inline-flex}.toggle input{width:16px;height:16px}.time{text-align:right;min-width:140px}.time__label{color:var(--muted);font-size:12px}.time__value{font-family:var(--mono);font-size:13px}.map{height:100%;min-height:100%}.map--loading{color:#0b1f22b3;font-family:var(--mono);background:linear-gradient(90deg,#0b1f220f 1px,#0000 1px) 0 0/48px 48px,linear-gradient(#0b1f220f 1px,#0000 1px) 0 0/48px 48px,#ffffff8c;place-items:center;display:grid}.mapWrap{height:100%;position:relative}.mapOverlay{pointer-events:none;position:absolute;inset:0}.mapOverlay--surveillance{mix-blend-mode:overlay;background:linear-gradient(90deg,#6ee7b70f 1px,#0000 1px) 0 0/48px 48px,linear-gradient(#6ee7b70d 1px,#0000 1px) 0 0/48px 48px}.mapWrap--surveillance .mapOverlay:before{content:"";background:radial-gradient(900px 520px,#10b98124,#0000 55%),linear-gradient(#0206171f,#02061700 55%,#0206171f);position:absolute;inset:0}.mapWrap--surveillance .mapOverlay:after{content:"";opacity:.45;background:linear-gradient(#0000 0,#10b9810d 50%,#0000 100%);animation:6.5s linear infinite scan;position:absolute;inset:0;transform:translateY(-60%)}@keyframes scan{0%{transform:translateY(-60%)}to{transform:translateY(60%)}}.hud{color:#ecfdf5eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#02061759;border:1px solid #6ee7b759;border-radius:12px;padding:10px;position:absolute;top:12px;left:12px;box-shadow:0 18px 40px -26px #00000040}.hud__row{justify-content:space-between;align-items:center;gap:10px;font-size:12px;display:flex}.hud__mono{font-family:var(--mono);opacity:.95;margin-top:6px}.hud__tag{font-family:var(--mono);letter-spacing:.06em;background:#10b98126;border:1px solid #6ee7b773;border-radius:999px;padding:2px 6px;font-size:11px}.hud__dim{opacity:.8}.mapCard__slider{border-top:1px solid var(--line);padding:10px 14px 14px}.slider{width:100%}.side{flex-direction:column;gap:14px;display:flex}.panel{border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:12px 14px 14px;position:relative;overflow:hidden}.panel__hd{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:10px;display:flex}.panel__sub{color:var(--muted);font-size:12px}.metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.metric{background:#ffffff8c;border:1px solid #0b1f221a;border-radius:12px;padding:10px;transition:transform .18s,border-color .18s,box-shadow .22s}.metric:hover{border-color:#0b1f222e;transform:translateY(-1px);box-shadow:0 18px 40px -30px #0b1f221a}.metric--city{background:radial-gradient(600px 120px at 10% 0,#1d4ed81f,#0000 55%),#ffffff8c}.metric--step{background:radial-gradient(600px 120px at 10% 0,#0f766e1a,#0000 55%),#ffffff8c}.metric--air{background:radial-gradient(600px 120px at 10% 0,#b453091a,#0000 55%),#ffffff8c}.metric--ocean{background:radial-gradient(600px 120px at 10% 0,#3b82f61f,#0000 55%),#ffffff8c}.metric__label{color:var(--muted);font-size:12px}.metric__value{font-family:var(--mono);letter-spacing:-.01em;margin-top:4px;font-size:14px}.days{grid-template-columns:1fr;gap:8px;display:grid}.day{background:#ffffff8c;border:1px solid #0b1f221a;border-radius:12px;padding:10px;transition:transform .18s,box-shadow .22s,border-color .18s}.day:hover{border-color:#0b1f222e;transform:translateY(-1px);box-shadow:0 18px 40px -30px #0b1f221a}@keyframes fadeUp{0%{opacity:0;filter:blur(2px);transform:translateY(8px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app--ready .topbar{animation:.52s cubic-bezier(.2,.8,.2,1) both fadeUp}.app--ready .mapCard{animation:.56s cubic-bezier(.2,.8,.2,1) 90ms both fadeUp}.app--ready .side>.panel,.app--ready .side>section{animation:.56s cubic-bezier(.2,.8,.2,1) both fadeUp}.app--ready .side>:first-child{animation-delay:.14s}.app--ready .side>:nth-child(2){animation-delay:.18s}.app--ready .side>:nth-child(3){animation-delay:.22s}.app--ready .side>:nth-child(4){animation-delay:.26s}.app--ready .side>:nth-child(5){animation-delay:.3s}.app--ready .side>:nth-child(6){animation-delay:.34s}.app--ready .metric{animation:.42s both fadeIn}@media (prefers-reduced-motion:reduce){.app--ready .topbar,.app--ready .mapCard,.app--ready .side>.panel,.app--ready .side>section,.app--ready .metric{animation:none!important}.metric,.day,.btn{transition:none!important}}.day__date{font-family:var(--mono);color:#0b1f22c2;font-size:12px}.day__row{justify-content:space-between;align-items:center;gap:10px;margin-top:6px;display:flex}.pill{color:#0b1f22eb;background:#0f766e14;border:1px solid #0b1f2224;border-radius:999px;padding:4px 8px;font-size:12px;display:inline-flex}.dim{color:var(--muted);font-size:13px}.insightControls{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.select{color:#0b1f22eb;background:#ffffffd1;border:1px solid #0b1f2229;border-radius:12px;padding:8px 10px;font-size:13px}.select:focus{border-color:#0f766e73;outline:none;box-shadow:0 0 0 4px #0f766e2e}.insights{gap:8px;display:grid}.insights__hd{letter-spacing:.1em;text-transform:uppercase;color:#0b1f229e;align-items:center;gap:10px;margin-top:8px;margin-bottom:2px;font-size:11px;display:flex}.insights__hd:after{content:"";background:linear-gradient(90deg,#0b1f221f,#0000);flex:auto;height:1px}.insight{--ins-accent:#0f766e8c;background:radial-gradient(800px 220px at 18% 0,#0f766e1a,#0000 55%),radial-gradient(700px 220px at 95% 0,#1d4ed814,#0000 55%),#ffffff94;border:1px solid #0b1f221f;border-radius:16px;padding:12px;position:relative;box-shadow:0 22px 60px -54px #00000024,inset 0 1px #0b1f220f}.insight:before{content:"";background:var(--ins-accent);opacity:.95;border-radius:16px 0 0 16px;width:4px;position:absolute;top:0;bottom:0;left:0}.insight__icon svg{display:block}.insight>summary{cursor:pointer;justify-content:space-between;align-items:center;gap:10px;list-style:none;display:flex}.insight>summary::-webkit-details-marker{display:none}.insight__title{font-size:13px;font-weight:650;line-height:1.15}.insight__titleLeft{align-items:center;gap:10px;min-width:0;display:inline-flex}.insight__icon{color:#0b1f22b8;background:#ffffffb3;border:1px solid #0b1f221f;border-radius:12px;flex:none;place-items:center;width:30px;height:30px;display:inline-grid}.insight--info .insight__icon{color:#0f766ef2}.insight--watch .insight__icon{color:#b45309f2}.insight--warning .insight__icon{color:#b91c1cf2}.insight__badge{font-family:var(--mono);letter-spacing:.02em;color:#0b1f22c7;text-transform:uppercase;background:#ffffffa8;border:1px solid #0b1f2224;border-radius:999px;flex:none;padding:4px 8px;font-size:11px}.insight__badge--info{background:#0f766e14;border-color:#0f766e33}.insight__badge--watch{background:#b453091a;border-color:#b453093d}.insight__badge--warning{background:#b91c1c1a;border-color:#b91c1c42}.insight__chev{opacity:.8;border-bottom:2px solid #0b1f2280;border-right:2px solid #0b1f2280;flex:none;width:10px;height:10px;transition:transform .16s;transform:rotate(45deg)}.insight[open] .insight__chev{transform:rotate(225deg)}.insight__summary{color:#0b1f22c7;margin-top:6px;font-size:13px}.insight__details{gap:6px;margin-top:8px;display:grid}.insight__detail{color:#0b1f22bd;padding-left:14px;font-size:12px;position:relative}.insight__detail:before{content:"";background:#0b1f2247;border-radius:999px;width:6px;height:6px;position:absolute;top:.55em;left:2px}.sprayViz{background:#ffffff9e;border:1px solid #0b1f221f;border-radius:14px;margin-top:10px;padding:10px}.sprayViz__bar{background:#0b1f2214;border-radius:999px;height:14px;position:relative;overflow:hidden}.sprayViz__segs{height:100%;display:grid}.sprayViz__seg{height:100%}.sprayViz__seg--ideal{background:linear-gradient(#0f766eeb,#0f766ea8)}.sprayViz__seg--ok{background:linear-gradient(#3b82f6b3,#3b82f66b)}.sprayViz__seg--bad{background:#0b1f221f}.sprayViz__best{pointer-events:none;border:1px solid #ffffffd9;border-radius:999px;position:absolute;top:-4px;bottom:-4px;box-shadow:0 18px 40px -28px #00000038,0 0 0 4px #0f766e47}.sprayViz__ticks{font-family:var(--mono);color:#0b1f229e;justify-content:space-between;gap:10px;margin-top:8px;font-size:11px;display:flex}.sprayViz__legend{color:#0b1f22ad;flex-wrap:wrap;gap:10px;margin-top:8px;font-size:11px;display:flex}.sprayViz__lg{align-items:center;gap:6px;display:inline-flex}.sprayViz__sw{border:1px solid #0b1f221f;border-radius:3px;width:10px;height:10px}.sprayViz__sw--ideal{background:#0f766ed9}.sprayViz__sw--ok{background:#3b82f699}.sprayViz__sw--bad{background:#0b1f2229}.insight--info{--ins-accent:#0f766e8c}.insight--watch{--ins-accent:#b4530999}.insight--warning{--ins-accent:#b91c1c9e}.panel--error{border-color:#b91c1c59}.airMarker{border:2px solid #ffffffe6;border-radius:999px;width:14px;height:14px;box-shadow:0 8px 18px -10px #00000040}.airMarker--pulse{position:relative}.airMarker--pulse:before{content:"";opacity:0;border:2px solid #fff9;border-radius:999px;animation:1.9s ease-out infinite pulse;position:absolute;inset:-10px;transform:scale(.75)}.airMarker--pulse:after{content:"";opacity:.25;filter:blur(.2px);background:radial-gradient(circle,#ffffff38,#0000 60%);border-radius:999px;position:absolute;inset:-20px}@keyframes pulse{0%{opacity:0;transform:scale(.6)}25%{opacity:.45}to{opacity:0;transform:scale(1.25)}}.hudKey{font-size:11px;font-family:var(--mono);opacity:.92;align-items:center;gap:6px;display:inline-flex}.hudDot{border:1px solid #ecfdf58c;border-radius:999px;width:10px;height:10px;box-shadow:0 12px 24px -18px #00000040}.hudDot--ag{background:#a7f3d0d9}.hudDot--mg{background:#5eead4a6}.hudDot--aq{background:#94a3b8a6}.hudDot--sst{background:#3b82f6b3}.hudDot--trees{background:#166534d9}.oceanMarkerWrap{align-items:center;gap:8px;display:inline-flex}.oceanMarker{background:radial-gradient(circle at 35% 35%,#bfdbfef2,#3b82f6e6);border:2px solid #ffffffe6;border-radius:999px;width:12px;height:12px;position:relative;box-shadow:0 10px 20px -12px #00000040}.oceanMarker:before{content:"";background:radial-gradient(circle,#3b82f62e,#0000 62%);border-radius:999px;position:absolute;inset:-12px}.oceanLabel{font-family:var(--mono);color:#eff6ffeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#02061752;border:1px solid #94a3b859;border-radius:10px;padding:4px 7px;font-size:12px}@media (width<=980px){.app{padding:12px}.topbar{flex-direction:column;align-items:flex-start}.topbar__meta{justify-content:space-between;width:100%}.main{grid-template-columns:1fr}.map{height:calc(100svh - 250px);min-height:420px}.gisDock{bottom:64px;left:10px;right:10px}.gisDock__grid{grid-template-columns:1fr}}.side--overlay{right:14px;top:calc(12px + var(--topbar-h,88px) + 10px + var(--toolbar-h,56px) + 12px);z-index:25;opacity:1;overscroll-behavior:contain;scrollbar-gutter:stable;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff94;border:1px solid #0b1f2224;border-radius:18px;flex-direction:column;gap:14px;width:clamp(300px,26vw,380px);max-width:calc(100% - 28px);max-height:none;padding:2px;transition:opacity .22s,transform .26s;display:flex;position:absolute;bottom:60px;overflow:auto;transform:translate(0);box-shadow:0 26px 70px -52px #0000002e}.side--hidden{opacity:0;pointer-events:none;transform:translate(18px)}.side--overlay .metric:hover,.side--overlay .day:hover{transform:none}.overlayStack{gap:10px;padding:10px;display:grid}.fold{background:#ffffff9e;border:1px solid #0b1f221f;border-radius:14px;overflow:hidden}.fold>summary{cursor:pointer;-webkit-user-select:none;user-select:none;letter-spacing:.02em;text-transform:uppercase;color:#0b1f22c7;background:radial-gradient(700px 140px at 12% 0,#0f766e1a,#0000 55%),radial-gradient(700px 140px at 92% 0,#1d4ed81a,#0000 55%);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:12px;font-weight:700;list-style:none;display:flex}.fold>summary::-webkit-details-marker{display:none}.fold>summary:after{content:"";opacity:.7;border-bottom:2px solid #0b1f228c;border-right:2px solid #0b1f228c;width:10px;height:10px;transition:transform .18s;transform:rotate(45deg)}.fold[open]>summary:after{transform:rotate(225deg)}.fold__body{padding:10px 12px 12px}.fold--error{border-color:#b91c1c40}.side--overlay .panel{box-shadow:none;background:0 0;border:0;padding:0}.panel--hud{background:#ffffffdb}.hudStrip{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb8;border:1px solid #0b1f2224;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:10px;display:flex;position:absolute;bottom:12px;left:14px;right:14px;box-shadow:0 20px 60px -46px #00000038}.hudStrip__left{flex-wrap:wrap;gap:8px;display:flex}.hudPill{font-family:var(--mono);background:#ffffffa8;border:1px solid #0b1f221f;border-radius:999px;padding:6px 8px;font-size:12px}.hudIcon{cursor:pointer;background:#ffffffd9;border:1px solid #0b1f2224;border-radius:12px;padding:8px 10px}@media (width<=980px){.side--overlay{width:auto;max-height:46svh;inset:auto 12px 70px}.hudStrip{bottom:10px;left:10px;right:10px}}
