@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.main{display:flex;flex:1;overflow:hidden}.map-area{flex:1;position:relative;border-right:1px solid #C4B898;background:var(--bg)}.leaflet-map{width:100%;height:100%;background:#b0c8dc}.topbar{display:flex;align-items:center;gap:0;height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;z-index:1000;position:relative}.topbar:before{content:"";display:block;width:3px;height:100%;background:var(--amber);flex-shrink:0}.topbar-brand{display:flex;align-items:center;gap:12px;padding:0 16px;flex-shrink:0;border-right:1px solid var(--border);height:100%}.topbar-icon{font-size:18px;line-height:1}.topbar-title{font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--amber)}.topbar-sub{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;padding:0 16px;border-right:1px solid var(--border);height:100%;display:flex;align-items:center}.topbar-center{flex:1;display:flex;justify-content:center;align-items:center}.badge{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border:1px solid;border-radius:var(--radius-sm)}.badge-warn{background:var(--amber-dim);color:var(--amber);border-color:#bf9a1059}.badge-ok{background:var(--green-dim);color:var(--land);border-color:#626f4759}.predict-btn{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:8px 18px;border-radius:var(--radius-sm);border:1px solid var(--amber);background:var(--amber-dim);color:var(--amber);cursor:pointer;transition:background .1s,color .1s;flex-shrink:0;margin-right:16px}.predict-btn:hover{background:var(--amber);color:var(--surface)}.predict-btn:active{opacity:.8}.predict-btn.loading{opacity:.4;cursor:default;pointer-events:none}.hero-bar{display:flex;align-items:center;height:var(--herobar-h);background:var(--bg);border-bottom:1px solid #C4B898;flex-shrink:0;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:#7a6840;text-transform:uppercase;padding:0;overflow:hidden}.hero-card{display:flex;align-items:center;gap:8px;padding:0 16px;height:100%;flex:1;border-right:1px solid #C4B898}.hero-card:last-child{border-right:none}.hero-icon{font-size:13px;line-height:1}.hero-text{display:flex;flex-direction:column;gap:1px}.hero-stat{font-family:var(--font-mono);font-size:11px;font-weight:600;color:#1c2b1e;letter-spacing:.04em}.hero-sub{font-size:9px;color:#8a7848;letter-spacing:.06em}.hero-divider{display:none}.side-panel{width:var(--panel-w);flex-shrink:0;background:var(--surface);border-left:none;overflow-y:auto;display:flex;flex-direction:column;gap:0;scrollbar-width:thin;scrollbar-color:var(--border2) var(--surface)}.section-label{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:8px}.weather-card{padding:12px 14px;border-bottom:1px solid var(--border);background:var(--surface)}.weather-card.skeleton{height:120px;background:var(--surface2);animation:pulse 1.4s ease-in-out infinite}.weather-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.weather-condition{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--water)}.weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.weather-stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 9px;display:flex;align-items:center;gap:7px}.weather-stat.highlight{border-color:#bf9a1066;background:var(--amber-dim)}.stat-icon{font-size:13px;line-height:1}.stat-label{font-family:var(--font-ui);font-size:10px;color:var(--text2);flex:1;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text)}.weather-alert{margin-top:8px;padding:6px 9px;background:var(--amber-dim);border:1px solid rgba(191,154,16,.35);border-left:2px solid var(--amber);color:var(--amber);font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase}.alert-list{padding:12px 14px;flex:1}.alert-count{margin-left:auto;font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.08em;background:var(--red-dim);color:var(--red);border:1px solid rgba(196,48,80,.35);border-radius:var(--radius-sm);padding:2px 7px}.alert-banner{margin:8px 0;padding:7px 10px;background:var(--red-dim);border:1px solid rgba(196,48,80,.35);border-left:2px solid var(--red);color:var(--red);font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.zone-list{display:flex;flex-direction:column;gap:0;margin-top:8px;border:1px solid var(--border)}.zone-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--surface2);border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;text-align:left;width:100%}.zone-row:last-child{border-bottom:none}.zone-row:hover{background:var(--surface-hover)}.zone-row-left{display:flex;align-items:center;gap:8px}.zone-row-name{font-family:var(--font-ui);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--text)}.zone-row-right{display:flex;align-items:center;gap:8px}.zone-row-pct{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text2);min-width:36px;text-align:right}.dot{width:8px;height:8px;flex-shrink:0}.dot-high{background:var(--red);transform:rotate(45deg)}.dot-med-high{background:var(--orange);clip-path:polygon(50% 0%,100% 100%,0% 100%);border-radius:0}.dot-med{background:var(--amber);border-radius:0}.dot-low{background:var(--land);border-radius:50%}.risk-badge{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid}.risk-high{background:var(--red-dim);color:var(--red);border-color:#c4305059}.risk-med-high{background:var(--orange-dim);color:var(--orange);border-color:#c8682c59}.risk-med{background:var(--amber-dim);color:var(--amber);border-color:#bf9a1059}.risk-low{background:var(--green-dim);color:var(--land);border-color:#626f4759}.zone-detail{padding:12px 14px;border-top:1px solid var(--border)}.zone-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.zone-detail-name{font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text);margin-bottom:5px}.close-btn{font-family:var(--font-mono);font-size:11px;background:var(--surface3);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text2);padding:3px 8px;cursor:pointer;letter-spacing:.04em;transition:color .1s,border-color .1s}.close-btn:hover{color:var(--text);border-color:var(--border-hi)}.risk-meter-wrap{height:4px;background:var(--surface3);border-radius:0;overflow:hidden;margin-bottom:5px}.risk-meter-bar{height:100%;border-radius:0;transition:width .5s ease}.risk-pct-label{font-family:var(--font-mono);font-size:10px;color:var(--text2);letter-spacing:.04em;margin-bottom:14px;text-transform:uppercase}.recommendations{list-style:none;display:flex;flex-direction:column;gap:4px;margin-top:8px}.recommendations li{padding:7px 10px;background:var(--surface2);border:1px solid var(--border);border-left:2px solid var(--land);font-family:var(--font-body);font-size:12px;line-height:1.45;color:var(--text2)}.factors{display:flex;flex-direction:column;gap:9px}.factor-row{display:flex;flex-direction:column;gap:3px}.factor-top{display:flex;justify-content:space-between;align-items:baseline}.factor-label{font-family:var(--font-ui);font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}.factor-value{font-family:var(--font-mono);font-size:12px;font-weight:600}.factor-track{height:3px;background:var(--surface3);border-radius:0;overflow:hidden}.factor-fill{height:100%;border-radius:0;transition:width .6s cubic-bezier(.4,0,.2,1)}.factor-note{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.03em}.briefing-card{background:var(--surface2);border-bottom:1px solid var(--border);border-left:2px solid var(--water);padding:11px 14px;margin:0}.briefing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.briefing-label{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--water)}.briefing-badge{display:flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:9px;font-weight:600;background:var(--water-dim);color:var(--text);padding:2px 7px;border:1px solid rgba(87,143,202,.35);border-radius:var(--radius-sm);letter-spacing:.06em}.briefing-text{font-family:var(--font-body);font-size:12px;line-height:1.6;color:var(--text2);margin:0 0 8px}.briefing-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.04em}.briefing-refresh{margin-left:auto;background:none;border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--water);font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;cursor:pointer;transition:border-color .1s,background .1s}.briefing-refresh:hover{border-color:var(--water);background:var(--water-dim)}.briefing-loading{color:var(--muted)}.briefing-spinner{font-family:var(--font-mono);font-size:11px;color:var(--water);margin-top:5px;letter-spacing:.06em;animation:pulse 1.5s infinite}.live-dot{display:inline-block;width:6px;height:6px;background:var(--amber);border-radius:0;margin:0 3px 0 4px;vertical-align:middle;animation:blink 1.2s step-end infinite}.live-text{font-family:var(--font-mono);font-size:9px;font-weight:600;color:var(--amber);letter-spacing:.1em;vertical-align:middle}.leaflet-tooltip-dark{background:var(--surface)!important;border:1px solid var(--border2)!important;color:var(--text)!important;border-radius:var(--radius-sm)!important;padding:6px 10px!important;font-family:var(--font-mono)!important;font-size:11px!important;letter-spacing:.03em!important;box-shadow:none!important}.zone-tooltip strong{display:block;margin-bottom:2px;color:var(--text);text-transform:uppercase;font-size:10px;letter-spacing:.06em}.map-legend{background:var(--surface)!important;border:1px solid var(--border2)!important;border-radius:var(--radius-sm)!important;padding:10px 12px!important;font-family:var(--font-mono)!important;font-size:10px!important;color:var(--text)!important;box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}.legend-title{font-family:var(--font-mono);font-weight:600;font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.legend-row{display:flex;align-items:center;gap:8px;margin-bottom:5px;color:var(--text2);font-size:10px;letter-spacing:.03em}.swatch{width:10px;height:10px;border-radius:0;flex-shrink:0}.track-swatch{background:var(--water);border-radius:0;height:2px;width:14px;border:none}.collar-legend{background:var(--surface)!important;border:1px solid var(--border2)!important;border-radius:var(--radius-sm)!important;padding:9px 11px!important;min-width:180px!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:none!important}.collar-legend-title{font-family:var(--font-mono);font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--water);margin-bottom:7px}.collar-row{display:flex;align-items:center;gap:7px;margin-bottom:4px;font-size:10px}.collar-dot{width:7px;height:7px;border-radius:0;flex-shrink:0;transform:rotate(45deg)}.collar-id{font-family:var(--font-mono);font-size:10px;color:var(--text2);font-weight:600;min-width:44px}.collar-park{font-family:var(--font-mono);color:var(--muted);font-size:9px}.park-label{background:transparent!important;border:none!important}.park-label span{font-family:var(--font-mono);font-size:9px;font-weight:600;color:#1c2b1eb3;text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;text-shadow:0 1px 4px rgba(237,228,204,.95),0 -1px 4px rgba(237,228,204,.95);pointer-events:none}.leaflet-control-zoom{border:1px solid var(--border2)!important;border-radius:var(--radius-sm)!important;overflow:hidden;box-shadow:none!important}.leaflet-control-zoom a{background:var(--surface)!important;color:var(--text2)!important;border-bottom:1px solid var(--border)!important;font-family:var(--font-mono)!important;font-size:14px!important;line-height:26px!important;width:26px!important;height:26px!important;transition:background .1s,color .1s!important}.leaflet-control-zoom a:hover{background:var(--surface2)!important;color:var(--text)!important}.leaflet-control-attribution{background:#ede4cceb!important;color:#6a5a30!important;font-size:9px!important;font-family:var(--font-mono)!important;letter-spacing:.03em!important}.leaflet-control-attribution a{color:var(--water)!important}@media (max-width: 900px){:root{--panel-w: 260px}.topbar-sub{display:none}}@media (max-width: 640px){.main{flex-direction:column}.map-area{flex:none;height:55vh;width:100%;border-right:none;border-bottom:1px solid #C4B898}.side-panel{width:100%;height:45vh;overflow-y:auto}.topbar{padding:0}.topbar-sub,.topbar-center,.hero-bar,.map-legend{display:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #EDE4CC;--bg2: #E5DAC0;--bg3: #DAD0B2;--surface: #1C2B1E;--surface2: #253529;--surface3: #141F16;--surface-hover:#2F4130;--border: rgba(220,235,210,.13);--border2: rgba(220,235,210,.24);--border-hi: rgba(220,235,210,.4);--text: #E0ECD8;--text2: #8AAE84;--muted: #587252;--land: #5A8C3E;--water: #3D7FAA;--land-dim: rgba(90,140,62,.18);--water-dim: rgba(61,127,170,.18);--orange: #C8732A;--cyan: #3D7FAA;--amber: #CFA030;--red: #BE3A20;--green: #5A8C3E;--accent: #CFA030;--orange-dim: rgba(200,115,42,.16);--cyan-dim: rgba(61,127,170,.18);--amber-dim: rgba(207,160,48,.16);--red-dim: rgba(190,58,32,.16);--green-dim: rgba(90,140,62,.18);--font-ui: "IBM Plex Sans Condensed", "Helvetica Neue", Arial, sans-serif;--font-body: "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;--panel-w: 340px;--topbar-h: 48px;--herobar-h: 34px;--radius: 0px;--radius-sm: 2px}html,body,#root{height:100%;font-family:var(--font-ui);background:var(--bg);color:var(--text);font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased}
