*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{background:#f0f2f5;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}#map{height:100vh}.sidebar{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:hsla(0,0%,100%,.88);border:1px solid hsla(0,0%,100%,.5);border-radius:18px;box-shadow:0 4px 24px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);overflow:hidden;position:fixed;right:16px;top:16px;transition:transform .3s ease,opacity .3s ease;width:272px;z-index:1000}.sidebar-header{background:rgba(248,250,252,.4);justify-content:space-between;padding:24px 24px 16px}.brand,.sidebar-header{align-items:center;display:flex}.brand{gap:10px}.brand-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:26px}.brand-text{background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;color:#1e293b;font-size:22px;font-weight:800;letter-spacing:-.03em;-webkit-text-fill-color:transparent}.calendar-btn-top{align-items:center;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;box-shadow:0 1px 3px rgba(0,0,0,.02);display:flex;font-size:18px;justify-content:center;padding:8px 10px;text-decoration:none;transition:all .15s}.calendar-btn-top:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:0 4px 12px rgba(0,0,0,.05);transform:translateY(-1px)}.sidebar-subtitle{color:#9ca3af;font-size:12px;font-weight:500;margin-top:2px}.sidebar-body{max-height:calc(100vh - 270px);overflow-y:auto;padding:14px 14px 6px}.sidebar-nav{background:rgba(248,250,252,.4);border-bottom:1px solid rgba(0,0,0,.05);box-sizing:border-box;display:flex;gap:6px;padding:12px 16px;width:100%}.nav-tab{border-radius:10px;color:#64748b;flex:1;font-size:13.5px;font-weight:600;padding:10px 0;text-align:center;text-decoration:none;transition:all .15s}.nav-tab:hover{background:rgba(0,0,0,.03);color:#1e293b}.nav-tab.active{background:rgba(99,102,241,.1);color:#4f46e5}.filter-group{margin-bottom:14px}.filter-group-label{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.08em;margin-bottom:6px;padding:0 8px;text-transform:uppercase}.filter-option{align-items:center;border-radius:12px;cursor:pointer;display:flex;margin-bottom:2px;padding:9px 10px;transition:background .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.filter-option:hover{background:rgba(99,102,241,.07)}.filter-option.active{background:rgba(99,102,241,.1)}.filter-radio{-moz-appearance:none;appearance:none;-webkit-appearance:none;border:2px solid #d1d5db;border-radius:50%;cursor:pointer;flex-shrink:0;height:17px;margin-right:10px;position:relative;transition:all .15s ease;width:17px}.filter-radio:checked{border-color:#6366f1}.filter-radio:checked:after{background:#6366f1;border-radius:50%;content:"";height:8px;left:2.5px;position:absolute;top:2.5px;width:8px}.filter-icon{font-size:15px;line-height:1;margin-right:8px}.filter-label{color:#374151;font-size:13.5px;font-weight:500}.sidebar-legend{border-top:1px solid rgba(0,0,0,.05);padding:14px 22px 18px}.legend-title{color:#b0b8c4;font-size:10px;font-weight:700;letter-spacing:.08em;margin-bottom:10px;text-transform:uppercase}.legend-items{display:flex;gap:14px}.legend-item{align-items:center;display:flex;gap:5px}.legend-swatch{border-radius:4px;height:13px;width:13px}.legend-swatch.good{background:rgba(34,197,94,.65);border:1.5px solid rgba(22,163,74,.7)}.legend-swatch.decent{background:rgba(234,179,8,.65);border:1.5px solid rgba(202,138,4,.7)}.legend-swatch.bad{background:rgba(239,68,68,.65);border:1.5px solid rgba(220,38,38,.7)}.legend-text{color:#6b7280;font-size:11.5px;font-weight:500}.sidebar-footer{background:rgba(248,250,252,.6);border-top:1px solid rgba(0,0,0,.05);color:#94a3b8;font-size:10.5px;padding:12px 22px;text-align:center}.rain-toggle-container{align-items:center;background:#f0f9ff;border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;padding:12px 24px}.rain-toggle-label{color:#0369a1;font-size:14px;font-weight:600}.switch{display:inline-block;height:24px;position:relative;width:44px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#cbd5e1;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.3s}.slider:before{background-color:#fff;bottom:3px;content:"";height:18px;left:3px;width:18px}input:checked+.slider{background-color:#0284c7}input:checked+.slider:before{transform:translateX(20px)}.slider.round{border-radius:24px}.slider.round:before{border-radius:50%}.zoom-message{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:rgba(15,23,42,.78);border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,.25);color:#f1f5f9;display:flex;font-size:13px;font-weight:500;gap:10px;left:50%;letter-spacing:-.01em;padding:12px 24px;pointer-events:none;position:fixed;top:24px;transform:translateX(-50%);transition:opacity .35s ease,transform .35s ease;z-index:999}.zoom-message.hidden{opacity:0;transform:translateX(-50%) translateY(-12px)}.search-trigger{align-items:center;background:#fff;border:none;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.1);cursor:pointer;display:flex;flex-shrink:0;height:34px;justify-content:center;margin-right:4px;pointer-events:auto;transition:all .2s ease;width:34px}.search-trigger:hover{background:#f1f5f9;box-shadow:0 2px 8px rgba(0,0,0,.15);transform:scale(1.05)}.search-trigger:active{transform:scale(.97)}.search-trigger svg{height:15px;stroke:#1e293b;width:15px}.search-container{display:none;left:50%;max-width:calc(100vw - 48px);position:fixed;top:24px;transform:translateX(-50%);width:340px;z-index:1002}.search-container.open{display:block}.search-input-wrap{align-items:center;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:rgba(15,23,42,.92);border:1px solid hsla(0,0%,100%,.1);border-radius:14px;box-shadow:none;display:flex;padding:4px 6px 4px 14px}.search-input-wrap svg{flex-shrink:0;height:16px;margin-right:10px;stroke:#94a3b8;width:16px}.search-input{background:transparent;border:none;color:#f1f5f9;flex:1;font-family:Inter,sans-serif;font-size:13.5px;font-weight:500;letter-spacing:-.01em;outline:none;padding:10px 0}.search-input::-moz-placeholder{color:#64748b}.search-input::placeholder{color:#64748b}.search-close-btn{align-items:center;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;font-size:12px;justify-content:center;line-height:1;padding:6px 8px;transition:all .15s}.search-close-btn:hover{background:hsla(0,0%,100%,.15);color:#e2e8f0}.search-results{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:rgba(15,23,42,.94);border:1px solid hsla(0,0%,100%,.08);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.3);margin-top:6px;max-height:260px;overflow:hidden;overflow-y:auto}.search-results:empty{display:none}.search-result-item{align-items:flex-start;border-bottom:1px solid hsla(0,0%,100%,.04);cursor:pointer;display:flex;gap:10px;padding:11px 14px;transition:background .12s ease}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:rgba(99,102,241,.15)}.search-result-icon{flex-shrink:0;font-size:15px;margin-top:1px}.search-result-text{display:flex;flex-direction:column;gap:2px;min-width:0}.search-result-name{color:#f1f5f9;font-size:13px;font-weight:600}.search-result-detail,.search-result-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-detail{color:#64748b;font-size:11px}.search-no-results{padding:16px 14px}.search-loading,.search-no-results{color:#64748b;font-size:12.5px;text-align:center}.search-loading{padding:14px}.search-results::-webkit-scrollbar{width:4px}.search-results::-webkit-scrollbar-track{background:transparent}.search-results::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.1);border-radius:2px}.tip-container{align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:hsla(0,0%,100%,.92);border:1px solid #fff;border-radius:24px;bottom:32px;box-shadow:0 8px 30px rgba(0,0,0,.1);color:#334155;display:flex;font-size:13.5px;font-weight:600;height:48px;justify-content:center;left:50%;letter-spacing:-.01em;overflow:hidden;position:fixed;transform:translateX(-50%);transition:width .6s cubic-bezier(.4,0,.2,1);width:300px;z-index:998}.tip-text{transition:opacity .25s ease;white-space:nowrap}.tip-text.fade-out{opacity:0}#tipMeasurer{padding:0 56px;position:absolute;visibility:hidden;white-space:nowrap}#tipMeasurer,.tile-loader{font-size:13.5px;font-weight:600;letter-spacing:-.01em}.tile-loader{align-items:center;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:rgba(15,23,42,.82);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.3);color:#f1f5f9;display:flex;gap:12px;left:50%;opacity:0;padding:12px 28px 12px 22px;pointer-events:none;position:fixed;top:24px;transform:translateX(-50%);transform:translateX(-50%) translateY(-14px);transition:opacity .35s ease,transform .35s ease;z-index:1001}.tile-loader.visible{opacity:1;transform:translateX(-50%) translateY(0)}.tile-loader-spinner{animation:tile-spin .7s linear infinite;border:2.5px solid hsla(0,0%,100%,.2);border-radius:50%;border-top-color:#a5b4fc;flex-shrink:0;height:18px;width:18px}@keyframes tile-spin{to{transform:rotate(1turn)}}.ol-zoom{bottom:32px;left:16px;top:auto}.ol-zoom button{backdrop-filter:blur(8px);background:hsla(0,0%,100%,.88);border:1px solid rgba(0,0,0,.08);border-radius:10px;color:#374151;cursor:pointer;font-size:18px;height:36px;margin:2px 0;transition:background .15s ease;width:36px}.ol-zoom button:hover{background:#fff}.ol-attribution{background:hsla(0,0%,100%,.6)!important;border-radius:6px;font-size:10px;padding:2px 6px}.my-location-btn{display:none}@media (max-width:1024px){.my-location-btn{align-items:center;background:#fff;border:none;border-radius:28px;bottom:96px;box-shadow:0 4px 16px rgba(0,0,0,.15);color:#4f46e5;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:24px;transition:transform .2s ease;width:56px;z-index:990}.my-location-btn:active{transform:scale(.95)}.my-location-btn svg{height:24px;width:24px}.my-location-btn.locating svg{animation:location-pulse 1.5s infinite}}@keyframes location-pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.ol-popup{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:hsla(0,0%,100%,.95);border:1px solid rgba(0,0,0,.05);border-radius:16px;bottom:16px;box-shadow:0 10px 30px rgba(0,0,0,.12);left:-110px;padding:16px;position:absolute;width:220px}.ol-popup:after,.ol-popup:before{border:solid transparent;content:" ";height:0;pointer-events:none;position:absolute;top:100%;width:0}.ol-popup:after{border-top-color:hsla(0,0%,100%,.95);border-width:10px;left:110px;margin-left:-10px}.ol-popup:before{border-top-color:rgba(0,0,0,.05);border-width:11px;left:110px;margin-left:-11px}.ol-popup-closer{color:#9ca3af;font-size:14px;position:absolute;right:14px;text-decoration:none;top:14px;transition:color .15s}.ol-popup-closer:hover{color:#4b5563}.ol-popup-closer:after{content:"âœ–"}.popup-title{color:#1e293b;font-size:14px;font-weight:700;letter-spacing:-.01em;margin-bottom:12px}.nav-links{display:flex;flex-direction:column;gap:8px}.nav-link{align-items:center;background:#f8fafc;border:1px solid transparent;border-radius:12px;color:#334155;display:flex;font-size:13px;font-weight:600;gap:12px;padding:10px 14px;text-decoration:none;transition:all .15s}.nav-link:hover{background:#fff;border-color:#e2e8f0;box-shadow:0 2px 8px rgba(0,0,0,.04);transform:translateY(-1px)}.nav-icon{height:18px;width:18px}.welcome-backdrop{align-items:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:rgba(0,0,0,.45);display:flex;inset:0;justify-content:center;opacity:1;padding:24px;position:fixed;transition:opacity .35s ease;z-index:2000}.welcome-backdrop.hidden{opacity:0;pointer-events:none}.welcome-modal{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:hsla(0,0%,100%,.95);border:1px solid hsla(0,0%,100%,.6);border-radius:24px;box-shadow:0 24px 80px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.04);max-width:420px;padding:36px 32px 28px;transform:translateY(0) scale(1);transition:transform .35s ease,opacity .35s ease;width:100%}.welcome-backdrop.hidden .welcome-modal{opacity:0;transform:translateY(16px) scale(.97)}.welcome-emoji{display:block;font-size:40px;margin-bottom:16px}.welcome-title{background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;color:#1e293b;font-size:20px;font-weight:800;letter-spacing:-.02em;margin-bottom:16px;-webkit-text-fill-color:transparent}.welcome-body{color:#475569;font-size:14px;line-height:1.7;margin-bottom:24px}.welcome-body p{margin-bottom:10px}.welcome-body p:last-child{margin-bottom:0}.welcome-feature{align-items:flex-start;background:#f8fafc;border-radius:12px;color:#334155;display:flex;font-size:13.5px;gap:10px;line-height:1.5;margin-bottom:8px;padding:10px 14px}.welcome-feature:last-child{margin-bottom:0}.welcome-feature-icon{flex-shrink:0;font-size:16px;margin-top:1px}.welcome-features,.welcome-source{margin-bottom:24px}.welcome-source{background:rgba(99,102,241,.05);border-left:3px solid #a5b4fc;border-radius:10px;color:#94a3b8;font-size:11.5px;line-height:1.6;padding:10px 14px}.welcome-btn{background:linear-gradient(135deg,#6366f1,#818cf8);border:none;border-radius:14px;box-shadow:0 4px 16px rgba(99,102,241,.3);color:#fff;cursor:pointer;display:block;font-family:Inter,sans-serif;font-size:15px;font-weight:700;letter-spacing:-.01em;padding:14px;transition:all .2s ease;width:100%}.welcome-btn:hover{box-shadow:0 6px 24px rgba(99,102,241,.4);transform:translateY(-1px)}.welcome-btn:active{transform:translateY(0)}.mobile-close-btn{background:none;border:none;color:#9ca3af;cursor:pointer;display:block;font-size:24px;line-height:1;padding:0 8px}.sidebar{border-radius:24px 24px 0 0;bottom:-100%;right:0;top:auto!important;transition:bottom .35s cubic-bezier(.4,0,.2,1);width:100%}.sidebar.mobile-open{bottom:0}@media (min-width:1025px){.mobile-close-btn,.mobile-toggle-btn{display:none}.sidebar{border-radius:18px;bottom:auto;right:16px;top:16px!important;transition:transform .3s ease,opacity .3s ease;width:272px}}@media (max-width:1024px){.sidebar-body{max-height:50vh}.ol-zoom{bottom:100px}.tip-container{display:none!important}}.rain-tooltip{backdrop-filter:blur(4px);background:rgba(0,0,0,.8);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;box-shadow:0 4px 6px rgba(0,0,0,.1);color:#fff;display:none;font-family:system-ui,-apple-system,sans-serif;font-size:13px;padding:6px 10px;pointer-events:none;white-space:nowrap}.top-nav{background-color:#fff;box-shadow:0 2px 4px rgba(0,0,0,.1);left:0;position:fixed;top:0;width:100%;z-index:10000}.top-nav-content{align-items:center;display:flex;height:60px;justify-content:space-between;padding:0 16px}.top-nav .brand-text{color:#2e7d32;font-size:1.5rem;font-weight:700;margin:0}.top-nav-links{display:flex;gap:16px;margin-left:32px}.top-nav-links .nav-tab{border-radius:6px;color:#2e7d32;font-size:1rem;font-weight:600;padding:8px 16px;text-decoration:none;transition:background-color .2s}.top-nav-links .nav-tab.active,.top-nav-links .nav-tab:hover{background-color:rgba(46,125,50,.1)}.top-burger{background:none;border:none;color:#2e7d32;cursor:pointer;display:none;padding:0}.mobile-nav-dropdown{background:#fff;box-shadow:0 4px 6px rgba(0,0,0,.1);display:none;flex-direction:column;left:0;position:absolute;top:100%;width:100%;z-index:9999}.mobile-nav-dropdown.open{display:flex}.mobile-nav-dropdown .nav-tab{border-bottom:1px solid #eee;color:#2e7d32;font-weight:600;padding:16px;text-decoration:none}.mobile-nav-dropdown .nav-tab.active{background-color:rgba(46,125,50,.1)}.mobile-toggle-btn{align-items:center;background:#2e7d32;border:none;border-radius:28px;bottom:24px;box-shadow:0 4px 16px rgba(46,125,50,.4);color:#fff;cursor:pointer;display:none;font-size:24px;height:56px;justify-content:center;position:fixed;right:24px;transition:transform .2s;width:56px;z-index:990}.mobile-toggle-btn:active{transform:scale(.95)}@media (max-width:1024px){.mobile-toggle-btn{display:flex}}@media (max-width:768px){.desktop-only{display:none!important}.top-burger{display:block}}.top-loader{background-color:transparent;bottom:0;height:2px;left:0;overflow:hidden;position:absolute;width:100%}.top-loader.visible{background-color:rgba(46,125,50,.2)}.top-loader-bar{background-color:#2e7d32;display:none;height:100%;left:-50%;position:absolute;width:50%}.top-loader.visible .top-loader-bar{animation:loader-slide 1.5s linear infinite;display:block}@keyframes loader-slide{0%{left:-50%;width:50%}50%{left:25%;width:50%}to{left:100%;width:50%}}#map{left:0;position:absolute;width:100%}#map,.sidebar{height:calc(100vh - 60px);top:60px}.search-container,.zoom-message{top:76px}.info-page-container{background-color:#f8fafc;height:100vh;overflow-y:auto;padding:80px 20px 40px}.info-content{background:#fff;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.05);margin:0 auto;max-width:800px;padding:40px}.info-content h1{color:#2e7d32;font-size:2rem;margin-bottom:24px;margin-top:0}.info-content h2{border-bottom:2px solid #e8f5e9;color:#1b5e20;font-size:1.5rem;margin-bottom:16px;margin-top:32px;padding-bottom:8px}.info-content h3{color:#388e3c;font-size:1.2rem;margin-bottom:12px;margin-top:24px}.info-content li,.info-content p{color:#334155;font-size:1.05rem;line-height:1.6;margin-bottom:16px}.info-content ul{margin-bottom:24px;padding-left:24px}.top-nav-right{align-items:center;display:flex;flex-grow:1;gap:12px;justify-content:flex-end}.top-search{margin-right:8px;position:relative;width:250px}.top-search .search-input-wrap{align-items:center;background:#f1f5f9;border:1px solid transparent;border-radius:20px;display:flex;padding:6px 12px;transition:all .2s}.top-search .search-input-wrap:focus-within{border-color:#2e7d32}.top-search .search-input{background:transparent;border:none;color:#333;font-size:.95rem;outline:none;padding:4px 8px;width:100%}.top-search svg{color:#64748b;height:18px;width:18px}.top-search .search-close-btn{background:none;border:none;color:#94a3b8;cursor:pointer;display:none;font-size:14px}.top-search .search-input:not(:-moz-placeholder)+.search-close-btn{display:block}.top-search .search-input:not(:placeholder-shown)+.search-close-btn{display:block}.top-search .search-results{background:#fff;border-radius:8px;box-shadow:0 10px 25px rgba(0,0,0,.1);left:0;margin-top:8px;max-height:400px;overflow-y:auto;position:absolute;top:100%;width:100%;z-index:10001}.top-search .search-result-name{color:#1e293b}.top-search .search-no-results,.top-search .search-result-detail{color:#64748b}.top-search .search-result-item.selected,.top-search .search-result-item:hover{background:#f1f5f9}@media (max-width:768px){.brand{display:none!important}.top-nav-content{flex-wrap:nowrap;height:60px;padding:0 16px}.top-nav-right{margin-left:12px;margin-top:0;width:100%}.top-search{margin-right:0;width:100%}.top-loader{bottom:0}.mobile-nav-dropdown{top:60px}.search-container{display:none!important}}