.detail-panel-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000004d;z-index:2000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:background .35s ease,backdrop-filter .35s ease}.detail-panel{position:relative;width:calc(100vw - 140px);max-width:calc(100vw - 140px);height:calc(100vh - 120px);max-height:calc(100vh - 120px);background:#07192ef2;border:1px solid rgba(66,148,234,.4);border-radius:16px;box-shadow:0 12px 48px #00000080;overflow:visible;animation:panelSlideIn .3s ease-out;transform-origin:center center;display:flex;flex-direction:column;transition:width .3s ease,max-width .3s ease,height .35s ease,max-height .35s ease}.detail-panel-header{display:flex;align-items:center;justify-content:space-between;padding:clamp(8px,1vw,12px) clamp(12px,1.5vw,16px);border-bottom:1px solid rgba(255,255,255,.1);background:linear-gradient(135deg,#4294ea26,#667eea26);min-height:clamp(48px,6vw,56px);position:relative;gap:clamp(4px,.5vw,8px)}.detail-panel-title-section{display:flex;align-items:center;gap:clamp(4px,.5vw,8px);flex:1;min-width:0;padding-right:clamp(36px,4vw,44px);flex-wrap:nowrap}.detail-panel-header-extra{display:flex;align-items:center;gap:clamp(6px,.8vw,12px);font-size:clamp(11px,1vw,16px);color:#ffffffe6;flex-shrink:1;min-width:0;flex-wrap:nowrap;max-width:100%}.header-coord{cursor:pointer;padding:clamp(1px,.2vw,2px) clamp(4px,.5vw,6px);border-radius:clamp(2px,.3vw,4px);transition:background .2s ease;font-size:clamp(10px,1vw,16px);white-space:nowrap}.header-coord:hover{background:#ffffff1a}.header-dates{display:flex;gap:clamp(2px,.3vw,4px);align-items:center;overflow-x:auto;overflow-y:hidden;min-width:0;flex:1;scrollbar-width:thin;scrollbar-color:rgba(66,148,234,.4) rgba(255,255,255,.05)}.header-dates::-webkit-scrollbar{height:3px}.header-dates::-webkit-scrollbar-track{background:#ffffff0d;border-radius:1.5px}.header-dates::-webkit-scrollbar-thumb{background:#4294ea66;border-radius:1.5px}.header-dates::-webkit-scrollbar-thumb:hover{background:#4294ea99}.header-coords{display:flex;align-items:center;gap:clamp(4px,.6vw,12px);height:clamp(28px,3.5vw,36px);white-space:nowrap;flex-shrink:0;overflow:hidden}.header-coord-label{font-size:clamp(10px,1vw,15px);color:#fffc;margin-right:clamp(2px,.3vw,4px);line-height:clamp(24px,3vw,36px);white-space:nowrap;flex-shrink:0;overflow:hidden;text-overflow:ellipsis}.header-coord-value{font-size:clamp(10px,1vw,16px);color:#ffffffe6;line-height:clamp(24px,3vw,36px);font-weight:500;white-space:nowrap;flex-shrink:0;overflow:hidden;text-overflow:ellipsis}.header-dates-section{display:flex;align-items:center;gap:clamp(4px,.6vw,10px);flex:1;min-width:0;overflow:hidden}.header-dates-label{font-size:clamp(10px,1vw,14px);color:#fffc;line-height:clamp(24px,3vw,36px);margin-bottom:0;white-space:nowrap;flex-shrink:0;overflow:hidden}.header-date{padding:clamp(2px,.3vw,4px) clamp(3px,.4vw,8px);border-radius:clamp(2px,.3vw,4px);background:#ffffff1a;cursor:pointer;transition:all .2s ease;font-size:clamp(9px,.7vw,13px);height:clamp(24px,3vw,36px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1px;min-width:clamp(28px,3.5vw,48px);flex-shrink:0}.header-date-timezone{font-size:clamp(8px,.6vw,10px);color:#ffffffb3;font-weight:400}.header-timezone-badge{color:#ffffffe6;font-size:clamp(9px,.8vw,14px);font-weight:600;flex-shrink:0;white-space:nowrap;line-height:clamp(24px,3vw,36px);display:flex;align-items:center;padding:0 clamp(4px,.6vw,8px)}.header-view-toggle{height:clamp(28px,3vw,36px);border:none;background:#ffffff1a;border-radius:clamp(4px,.5vw,8px);cursor:pointer;display:flex;align-items:center;gap:6px;color:#fffc;transition:all .2s ease;padding:0 12px;flex-shrink:0;animation:togglePulse 2s ease-in-out infinite}@keyframes togglePulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.4)}}.header-view-toggle:hover{background:#fff3}.header-view-toggle.table{color:#4294ea}.header-view-toggle.chart{color:#66d9ff}.header-view-toggle-text{font-size:clamp(11px,1vw,13px);font-weight:500;white-space:nowrap}.header-date:hover{background:#fff3}.header-date.active{background:#4294eacc}.detail-panel-title{margin:0;font-size:clamp(12px,1.2vw,18px);font-weight:600;color:#fff;display:flex;align-items:center;gap:clamp(4px,.6vw,8px);line-height:clamp(24px,3vw,36px);white-space:nowrap;flex-shrink:0}.title-icon{display:inline-block;width:20px;height:20px;margin-right:6px;vertical-align:middle;object-fit:contain}.detail-panel-close{position:absolute;top:12px;right:16px;width:clamp(28px,3vw,36px);height:clamp(28px,3vw,36px);border:none;background:#ffffff1a;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease;padding:0;flex-shrink:0;z-index:10}.detail-panel-close:hover{background:#fff3;transform:scale(1.1)}.detail-panel-close:active{transform:scale(.95)}.detail-panel-collapse{position:absolute;top:-16px;left:50%;transform:translate(-50%);width:72px;height:28px;border:1px solid rgba(255,255,255,.25);background:#ffffff1f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#ffffffd9;transition:all .25s ease;padding:0;flex-shrink:0;z-index:2001;box-shadow:0 4px 16px #0000004d,inset 0 1px #ffffff26}.detail-panel-collapse:hover{background:#ffffff38;border-color:#fff6;box-shadow:0 4px 20px #00000059,inset 0 1px #fff3}.detail-panel-collapse:active{transform:translate(-50%) scale(.92)}.detail-panel-collapsed{max-height:50vh!important;height:50vh;transition:max-height .35s ease,height .35s ease}.detail-panel-collapsed .detail-panel-content{overflow:hidden!important}.detail-panel-overlay-transparent{background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;pointer-events:none;align-items:flex-end!important;justify-content:center;padding-bottom:120px}.detail-panel-overlay-transparent .detail-panel-collapsed{pointer-events:auto}.detail-panel-overlay-dragging{background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;pointer-events:none}.detail-panel-overlay-dragging .detail-panel{pointer-events:auto}.detail-panel-dragged{animation:none!important}.detail-panel-dragged .detail-panel-header{cursor:grab}.detail-panel-dragged .detail-panel-header:active{cursor:grabbing}.detail-panel-narrow{width:fit-content!important;min-width:600px;max-width:calc(100vw - 40px)!important;transition:width .3s ease,max-width .3s ease}.detail-panel:not(.detail-panel-collapsed){height:calc(100vh - 120px);max-height:calc(100vh - 120px);transition:max-height .35s ease,height .35s ease}.detail-panel-content{padding:16px 24px;overflow:auto;color:#fff;display:flex;flex-direction:column;flex:1;min-height:0;border-radius:0 0 16px 16px}.forecast-table-wrap{display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0}.forecast-table-title{font-size:15px;font-weight:600;color:#ffffffe6;margin-bottom:12px;flex-shrink:0}.forecast-table-unit{font-size:12px;font-weight:400;color:#ffffff80;margin-left:4px}.forecast-table-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:16px;color:#ffffff80;font-size:14px}.forecast-error{color:#d2b464f2;font-size:16px;min-height:150px}.forecast-loading-spinner{width:32px;height:32px;border:3px solid rgba(66,148,234,.2);border-top-color:#4294eae6;border-radius:50%;animation:spinnerRotate .8s linear infinite}@keyframes spinnerRotate{to{transform:rotate(360deg)}}.forecast-table-scroll{flex:1;overflow:auto;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.forecast-table{border-collapse:collapse;width:max-content;min-width:100%;font-size:14px}.forecast-table thead{position:sticky;top:0;z-index:10}.forecast-th{padding:8px 2px;text-align:center;color:#fff9;background:#07192efa;border-bottom:1px solid rgba(66,148,234,.3);border-right:1px solid rgba(255,255,255,.02);white-space:nowrap;min-width:36px;font-weight:400}.forecast-th-date{position:sticky;left:0;z-index:11;min-width:110px;width:110px;background:#07192efa;border-right:1px solid rgba(66,148,234,.2);color:#fffc;text-align:left;padding-left:12px}.forecast-th-major{border-left:1px solid rgba(66,148,234,.2);color:#ffffffd9;background:#4294ea0f}.forecast-tr{cursor:pointer;transition:background .15s}.forecast-tr:hover{background:#4294ea14}.forecast-td-element{position:sticky;left:0;z-index:2;background:#07192ef2;border-right:1px solid rgba(66,148,234,.2);border-bottom:1px solid rgba(255,255,255,.06);padding:6px 10px;text-align:left;white-space:nowrap;min-width:110px;width:110px}.element-icon{display:inline-block;width:18px;height:18px;margin-right:6px;vertical-align:middle;object-fit:contain}.element-name{font-size:15px;font-weight:500;color:#ffffffe6}.element-unit{font-size:13px;color:#ffffff80;margin-left:4px}.element-unit-clickable{color:#4294eae6;transition:color .2s,transform .1s;padding:2px 4px;border-radius:3px;-webkit-user-select:none;user-select:none}.forecast-td-element-clickable{cursor:pointer;transition:background .15s}.forecast-td-element-clickable:hover{background:#4294ea14}.forecast-td-element-clickable:active{background:#4294ea26}.forecast-td-element-clickable .element-icon,.forecast-td-element-clickable .element-name{transition:transform .1s}.forecast-td-element-clickable:active .element-icon,.forecast-td-element-clickable:active .element-name{transform:scale(.95)}.forecast-td-selected{background:#4294ea29!important}.forecast-th-selected{background:#4294ea3d!important;color:#fffffff2!important}.forecast-th-middle{background:#4294ea4d!important;color:#fff!important;box-shadow:inset 0 0 12px #4294ea66}.forecast-td-middle{background:#4294ea1f!important;border-left:1px solid rgba(66,148,234,.3);border-right:1px solid rgba(66,148,234,.3)}.forecast-td-date{position:sticky;left:0;z-index:2;background:#07192ef2;border-right:1px solid rgba(66,148,234,.2);border-bottom:1px solid rgba(255,255,255,.06);padding:4px 6px;text-align:center;white-space:nowrap}.forecast-date-label{font-size:12px;font-weight:600;color:#ffffffe6}.forecast-weekday{font-size:10px;color:#ffffff73;margin-top:1px}.forecast-td{padding:6px 2px;text-align:center;border-bottom:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.02);vertical-align:middle;min-width:36px}.forecast-cell-weather{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.weather-icon-img{width:36px;height:36px;object-fit:contain}.forecast-td-empty{background:#0000001a}.forecast-no-data{color:#ffffff2e;font-size:12px}.forecast-level-badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:13px;font-weight:400;line-height:1.4;margin-bottom:2px;white-space:nowrap}.forecast-cell-value{font-size:15px;color:#ffffffd9;white-space:nowrap;line-height:1.3}.forecast-cell-dir{font-size:13px;color:#ffffff73;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;margin-top:1px}.forecast-cell-period{font-size:11px;color:#ffffff59;margin-top:1px}.detail-panel-placeholder{display:flex;align-items:center;justify-content:center;min-height:200px;color:#fff9;font-size:14px}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes panelSlideIn{0%{transform:scale(.6);opacity:0}50%{transform:scale(.95);opacity:.5}to{transform:scale(1);opacity:1}}.detail-panel-content::-webkit-scrollbar,.forecast-table-scroll::-webkit-scrollbar{width:6px;height:6px}.detail-panel-content::-webkit-scrollbar-track,.forecast-table-scroll::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.detail-panel-content::-webkit-scrollbar-thumb,.forecast-table-scroll::-webkit-scrollbar-thumb{background:#4294ea66;border-radius:3px}.detail-panel-view-toggle{position:absolute;top:50%;right:56px;transform:translateY(-50%);display:flex;align-items:center;gap:6px;padding:6px 14px;border:none;background:#0000004d;border-radius:8px;color:#ffffffb3;font-size:13px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.detail-panel-view-toggle:hover{background:#4294ea4d;color:#fffffff2}.detail-panel-view-toggle svg{flex-shrink:0}.forecast-chart-container{display:flex;flex-direction:column;height:100%;min-height:300px;border-radius:8px;border:1px solid rgba(255,255,255,.08);overflow:hidden}.forecast-chart-wrapper{flex:1;min-height:250px;background:#0003}.forecast-chart-svg{display:block}.chart-element-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;border-radius:6px;color:#ffffffb3;font-size:13px;cursor:pointer;transition:all .2s ease}.chart-element-btn:hover{background:#ffffff1a;border-color:#4294ea66}.chart-element-btn.active{background:#4294ea4d;border-color:#4294ea99;color:#fffffff2}.chart-element-icon{width:16px;height:16px;object-fit:contain}.chart-title{font-size:14px;font-weight:600}.detail-panel-content::-webkit-scrollbar-thumb:hover,.forecast-table-scroll::-webkit-scrollbar-thumb:hover{background:#4294ea99}.detail-panel-content,.forecast-table-scroll{scrollbar-width:thin;scrollbar-color:rgba(66,148,234,.4) rgba(255,255,255,.05)}@media (max-width: 1200px){.detail-panel{max-width:calc(100vw - 200px)}.detail-panel-narrow{max-width:calc(100vw - 200px)!important}}@media (max-width: 768px){.detail-panel{width:90vw;max-width:calc(100vw - 100px)}.detail-panel-narrow{width:90vw!important;min-width:90vw;max-width:calc(100vw - 40px)!important}.detail-panel-header{padding:16px 20px}.detail-panel-title{font-size:16px}.detail-panel-content{padding:20px}}.detail-view-toggle{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;margin-bottom:12px;background:#00000026;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.view-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;border-radius:6px;color:#ffffffb3;font-size:13px;cursor:pointer;transition:all .2s ease}.view-toggle-btn:hover{background:#ffffff1a;border-color:#4294ea66}.view-toggle-btn.active{background:#4294ea4d;border-color:#4294ea99;color:#fffffff2}.forecast-chart-view{display:flex;flex-direction:column;flex:1;min-height:0;border-radius:8px;border:1px solid rgba(255,255,255,.08);overflow:hidden}.forecast-chart-view .forecast-chart-wrapper{flex:1;background:#0003;width:100%;height:100%;min-height:280px}.detail-panel:not(.detail-panel-collapsed) .forecast-chart-view .forecast-chart-wrapper{flex:1;min-height:280px;height:100%}.detail-panel-collapsed .forecast-chart-view .forecast-chart-wrapper{min-height:180px}.forecast-chart-elements{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#00000026;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap}.forecast-chart-element-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;border-radius:6px;color:#fff9;font-size:11px;cursor:pointer;transition:all .2s ease;min-width:50px}.forecast-chart-element-btn:hover{background:#ffffff1a;border-color:#4294ea66;color:#fffc}.forecast-chart-element-btn.active{background:#4294ea4d;border-color:#4294ea99;color:#fffffff2}.forecast-chart-element-icon{width:18px;height:18px;object-fit:contain}.mobile-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:3000;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mobile-detail-panel{position:relative;width:100%;max-width:100%;height:calc(100vh - 60px);max-height:calc(100vh - 60px);background:#07192efa;border-radius:12px 12px 0 0;box-shadow:0 -4px 24px #0006;overflow:hidden;animation:mobilePanelSlideUp .3s ease-out;display:flex;flex-direction:column}@supports (height: 100dvh){.mobile-detail-panel{height:95dvh;max-height:95dvh}}@keyframes mobilePanelSlideUp{0%{margin-bottom:-100vh;opacity:0}to{margin-bottom:0;opacity:1}}.mobile-detail-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:linear-gradient(135deg,#4294ea33,#667eea26);border-bottom:1px solid rgba(66,148,234,.3);min-height:26px;flex-shrink:0}.mobile-detail-header-title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#fff}.mobile-detail-title-icon{display:inline-block;width:14px;height:14px;margin-right:4px;vertical-align:middle;object-fit:contain}.mobile-detail-close{width:22px;height:22px;border:none;background:#ffffff1a;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease;padding:0;flex-shrink:0}.mobile-detail-header-right{display:flex;align-items:center;gap:8px}.mobile-detail-close:hover{background:#fff3;transform:scale(1.05)}.mobile-detail-close:active{transform:scale(.95)}.mobile-detail-coords{display:flex;flex-direction:column;padding:6px 12px;background:#4294ea14;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;gap:6px}.mobile-coord-display{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;background:#4294ea26;border-radius:6px;cursor:pointer;transition:background .2s ease}.mobile-coord-display:active{background:#4294ea40}.mobile-coord-format-label{font-size:10px;color:#4294eae6;background:#4294ea33;padding:2px 6px;border-radius:4px;font-weight:500;white-space:nowrap}.mobile-coord-format-value{font-size:13px;color:#fffffff2;font-family:Roboto Mono,monospace;letter-spacing:.5px;text-align:center}.mobile-coord-input-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.mobile-coord-item{display:flex;align-items:center;gap:4px}.mobile-coord-label{font-size:12px;color:#fff9;white-space:nowrap}.mobile-coord-input{width:72px;padding:3px 6px;font-size:12px;color:#ffffffe6;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:4px;outline:none;font-family:Roboto Mono,monospace}.mobile-coord-input:focus{border-color:#4294ea99;background:#ffffff26}.mobile-coord-input::placeholder{color:#ffffff4d;font-size:11px}.mobile-coord-query-btn{padding:4px 12px;font-size:12px;font-weight:500;color:#fff;background:#4294eacc;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .2s ease}.mobile-coord-query-btn:active{background:#4294ea}.mobile-timezone-badge{font-size:11px;color:#4294eae6;background:#4294ea26;padding:4px 10px;border-radius:12px;font-weight:500;white-space:nowrap}.mobile-detail-dates-section{padding:4px 6px;background:#07192ef2;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.mobile-dates-scroll{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}.mobile-dates-scroll::-webkit-scrollbar{display:none}.mobile-date-item{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:44px;padding:6px 8px;background:#ffffff14;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.1)}.mobile-date-item:active{transform:scale(.95)}.mobile-date-item.active{background:#4294eae6;border-color:#4294ea80;box-shadow:0 2px 8px #4294ea4d}.mobile-date-day{font-size:12px;font-weight:600;color:#ffffffe6}.mobile-date-item.active .mobile-date-day{color:#fff}.mobile-date-weekday{font-size:10px;color:#ffffff80;margin-top:1px}.mobile-date-item.active .mobile-date-weekday{color:#fffc}.mobile-detail-content{flex:1;overflow-y:auto;padding:4px 0 16px;color:#fff;scrollbar-width:thin;scrollbar-color:rgba(66,148,234,.4) rgba(255,255,255,.05)}.mobile-detail-content::-webkit-scrollbar{width:4px}.mobile-detail-content::-webkit-scrollbar-track{background:#ffffff0d}.mobile-detail-content::-webkit-scrollbar-thumb{background:#4294ea66;border-radius:2px}.mobile-detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px;color:#fff9;font-size:14px}.mobile-fetch-error{color:#d2b464f2;font-size:16px}.mobile-loading-spinner{width:40px;height:40px;border:3px solid rgba(66,148,234,.2);border-top-color:#4294eae6;border-radius:50%;animation:mobileSpinnerRotate .8s linear infinite}@keyframes mobileSpinnerRotate{to{transform:rotate(360deg)}}.mobile-table-wrap{display:flex;flex-direction:column;overflow:hidden;flex:1;width:100%}.mobile-table-scroll{flex:1;overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(66,148,234,.4) rgba(255,255,255,.05);width:100%}.mobile-table-scroll::-webkit-scrollbar{width:6px;height:6px}.mobile-table-scroll::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.mobile-table-scroll::-webkit-scrollbar-thumb{background:#4294ea66;border-radius:3px}.mobile-forecast-table{border-collapse:collapse;width:max-content;min-width:100%;font-size:13px;margin:0}.mobile-forecast-table thead{position:sticky;top:0;z-index:50}.mobile-th-element{position:sticky;left:0;z-index:100;min-width:90px;width:90px;padding:4px 10px;text-align:left;color:#fffc;background:#07192e;border-bottom:1px solid rgba(66,148,234,.3);border-right:1px solid rgba(66,148,234,.2);font-weight:500}.mobile-th-hour{padding:4px 2px;text-align:center;color:#fff9;background:#07192efa;border-bottom:1px solid rgba(66,148,234,.3);border-right:1px solid rgba(255,255,255,.02);white-space:nowrap;min-width:32px;font-weight:400}.mobile-th-major{border-left:1px solid rgba(66,148,234,.2);color:#ffffffd9;background:#4294ea0f}.mobile-td-element{position:sticky;left:0;z-index:99;background:#07192e;border-right:1px solid rgba(66,148,234,.2);border-bottom:1px solid rgba(255,255,255,.06);padding:6px 10px;text-align:left;white-space:nowrap;min-width:90px;width:90px;transition:all .3s ease}.mobile-td-icon{display:inline-block;width:16px;height:16px;margin-right:6px;vertical-align:middle;object-fit:contain}.mobile-td-name{font-size:13px;font-weight:500;color:#ffffffe6}.mobile-td-short{font-size:13px;font-weight:600;color:#ffffffe6;display:none}.mobile-td-unit{font-size:11px;color:#ffffff80;margin-left:4px}.mobile-td-unit-clickable{color:#4294eae6;transition:color .2s,transform .1s;padding:2px 4px;border-radius:3px;-webkit-user-select:none;user-select:none}.mobile-td-element-clickable{cursor:pointer;transition:background .15s}.mobile-td-element-clickable:active{background:#4294ea26}.mobile-td-element-clickable .mobile-td-icon,.mobile-td-element-clickable .mobile-td-name,.mobile-td-element-clickable .mobile-td-short{transition:transform .1s}.mobile-td-element-clickable:active .mobile-td-icon,.mobile-td-element-clickable:active .mobile-td-name,.mobile-td-element-clickable:active .mobile-td-short{transform:scale(.95)}.mobile-table-scroll.scrolled .mobile-td-element{min-width:50px!important;width:50px!important;padding:6px 4px!important;text-align:center!important;left:0!important;z-index:99!important;background:#07192e!important;transition:all .2s ease;white-space:nowrap!important}.mobile-table-scroll.scrolled .mobile-td-name,.mobile-table-scroll.scrolled .mobile-td-unit{display:none!important}.mobile-table-scroll.scrolled .mobile-td-short{display:inline!important;font-size:12px}.mobile-table-scroll.scrolled .mobile-td-icon{display:inline-block!important;width:14px!important;height:14px!important;margin-right:3px!important;vertical-align:middle!important}.mobile-th-element .element-full{display:inline}.mobile-th-element .element-short{display:none;font-weight:600}.mobile-table-scroll.scrolled .mobile-th-element{min-width:50px!important;width:50px!important;padding:4px!important;text-align:center!important;left:0!important;z-index:100!important;background:#07192e!important;transition:all .2s ease;white-space:nowrap!important}.mobile-table-scroll.scrolled .mobile-th-element .element-full{display:none!important}.mobile-table-scroll.scrolled .mobile-th-element .element-short{display:inline!important;font-size:13px}.mobile-table-scroll.scrolled .mobile-th-element .th-element-icon{display:inline-block!important}.mobile-td-data{padding:5px 2px;text-align:center;border-bottom:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.02);vertical-align:middle;min-width:32px}.mobile-td-data.empty{background:#0000001a}.mobile-no-data{color:#ffffff2e;font-size:12px}.mobile-weather-icon-small{width:28px;height:28px;object-fit:contain}.mobile-level-badge-small{display:inline-block;padding:1px 5px;border-radius:3px;font-size:16px;font-weight:400;line-height:1.3;margin-bottom:2px;white-space:nowrap}.mobile-td-value{font-size:16px;color:#ffffffd9;white-space:nowrap;line-height:1.3;font-family:Roboto Mono,monospace}.mobile-td-dir{font-size:11px;color:#ffffff73;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;margin-top:1px}.mobile-td-period{font-size:10px;color:#ffffff59}.mobile-td-selected{background:#4294ea29!important}.mobile-th-selected,.mobile-th-middle{background:#4294ea3d!important;color:#fffffff2!important}.mobile-td-middle{background:#4294ea29!important}.mobile-detail-placeholder{display:flex;align-items:center;justify-content:center;min-height:200px;color:#ffffff80;font-size:14px}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-detail-panel{padding-bottom:env(safe-area-inset-bottom)}.mobile-detail-content{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}@media (max-width: 360px){.mobile-detail-header{padding:10px 12px;min-height:48px}.mobile-detail-header-title{font-size:16px}.mobile-detail-coords{padding:8px 12px}.mobile-detail-dates-section{padding:10px 12px}.mobile-date-item{min-width:50px;padding:8px 10px}.mobile-date-day{font-size:13px}.mobile-detail-content{padding:12px}.mobile-data-cards{grid-template-columns:1fr;gap:10px}.mobile-data-card{padding:12px}.mobile-card-value{font-size:18px}}@media (max-height: 500px) and (orientation: landscape){.mobile-detail-panel{height:calc(100vh - 40px);max-height:calc(100vh - 40px);border-radius:12px 12px 0 0}.mobile-detail-header{min-height:44px;padding:8px 16px}.mobile-detail-dates-section{padding:8px 16px}.mobile-data-cards{grid-template-columns:repeat(3,1fr)}}@supports (height: 100dvh){@media (max-height: 500px) and (orientation: landscape){.mobile-detail-panel{height:95dvh;max-height:95dvh}}}.mobile-detail-header-center{flex:1;display:flex;justify-content:center}.mobile-detail-view-toggle{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#ffffff1a;border:none;border-radius:6px;color:#ffffffb3;font-size:12px;cursor:pointer;transition:all .2s ease;animation:mobileTogglePulse 2s ease-in-out infinite}@keyframes mobileTogglePulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.4)}}.mobile-detail-view-toggle:hover{background:#ffffff26;color:#ffffffe6}.mobile-detail-view-toggle.show-chart,.mobile-detail-view-toggle.show-table{color:#66d9ff}.mobile-detail-view-toggle svg{width:14px;height:14px}.mobile-chart-view{display:flex;flex-direction:column;height:100%}.mobile-chart-container{flex:1;min-height:200px;background:#ffffff08;border-radius:8px;padding:8px;margin-bottom:12px}.mobile-forecast-chart-wrapper{width:100%;height:100%;min-height:180px}.mobile-chart-elements{display:flex;flex-wrap:wrap;gap:8px;padding:8px;justify-content:center;max-width:340px;margin:0 auto}.mobile-chart-element-btn{width:60px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff9;font-size:11px;cursor:pointer;transition:all .2s ease;min-width:50px}.mobile-chart-element-btn:hover{background:#ffffff1f;color:#fffc}.mobile-chart-element-btn.active{background:#4294ea4d;border-color:#4294ea80;color:#fff}.mobile-chart-element-icon{width:18px;height:18px;object-fit:contain}.wind-layer-switch-wrap{position:relative;z-index:1000;display:flex;gap:24px;align-items:center}.checkbox-wrapper{font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;color:#ffffffd9;-webkit-user-select:none;user-select:none}.checkbox-wrapper .toggle{position:relative;display:block;width:44px;height:24px;background:#ffffff26;border-radius:12px;cursor:pointer;border:2px solid rgba(255,255,255,.2);transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;margin:0;outline:none;box-shadow:inset 0 2px 4px #0003}.checkbox-wrapper .toggle:hover{border-color:#ffffff80;box-shadow:inset 0 2px 4px #0003,0 0 8px #4294ea4d}.checkbox-wrapper .toggle.checked{background:linear-gradient(135deg,#4294ea,#2d7dd2);border-color:#4294ea;box-shadow:0 2px 8px #4294ea66}.checkbox-wrapper .toggle-slider{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 2px 6px #0000004d;transition:transform .3s cubic-bezier(.4,0,.2,1)}.checkbox-wrapper .toggle.checked .toggle-slider{transform:translate(20px);box-shadow:0 2px 8px #0006}.checkbox-wrapper .toggle:active .toggle-slider{transform:scale(.95)}.checkbox-wrapper .toggle.checked:active .toggle-slider{transform:translate(20px) scale(.95)}.model-switch-wrapper{position:relative;display:flex;gap:0;background:#ffffff26;border-radius:12px;padding:2px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 2px 4px #0003;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.model-switch-wrapper .model-option{flex:1;min-width:32px;height:28px;background:transparent;border:none;border-radius:0;padding:0;margin:0;outline:none;cursor:pointer;font-size:13px;font-weight:500;color:#ffffffd9;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.model-switch-wrapper .model-option:first-child{border-radius:10px 0 0 10px}.model-switch-wrapper .model-option:last-child{border-radius:0 10px 10px 0}.model-switch-wrapper .model-option:hover{color:#fffffff2;background:#ffffff14}.model-switch-wrapper .model-option.active{background:linear-gradient(135deg,#4294ea,#2d7dd2);color:#fff;box-shadow:0 2px 8px #4294ea66;font-weight:600}.model-switch-wrapper .model-option:active{transform:scale(.96)}.timezone-switch-wrapper{position:relative;display:flex;gap:0;background:#ffffff26;border-radius:12px;padding:2px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 2px 4px #0003;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.timezone-switch-wrapper .timezone-option{flex:1;min-width:36px;height:28px;background:transparent;border:none;border-radius:0;padding:0;margin:0;outline:none;cursor:pointer;font-size:13px;font-weight:500;color:#ffffffd9;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;letter-spacing:.5px;-webkit-user-select:none;user-select:none}.timezone-switch-wrapper .timezone-option:first-child{border-radius:10px 0 0 10px}.timezone-switch-wrapper .timezone-option:last-child{border-radius:0 10px 10px 0}.timezone-switch-wrapper .timezone-option:hover{color:#fffffff2;background:#ffffff14}.timezone-switch-wrapper .timezone-option.active{background:linear-gradient(135deg,#4294ea,#2d7dd2);color:#fff;box-shadow:0 2px 8px #4294ea66;font-weight:600}.timezone-switch-wrapper .timezone-option:active{transform:scale(.96)}.color-legend-wrap{position:absolute;bottom:127px;right:60px;z-index:1000;display:flex;flex-direction:column;gap:4px;align-items:flex-start}.color-legend-title{font-size:13px;color:#ffffffd9;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.5)}.color-legend-header{display:flex;align-items:center;gap:8px}.color-legend-gradient{position:relative;display:flex;height:20px;width:180px;border-radius:4px;overflow:visible;box-shadow:0 2px 8px #0000004d;cursor:crosshair}.color-segment{flex:1;height:100%;border-left:1px solid rgba(255,255,255,.1)}.color-segment:first-child{border-left:none}.color-legend-cursor{position:absolute;top:-8px;transform:translate(-50%);pointer-events:none;z-index:10}.color-legend-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:4px 8px;background:#000000d9;color:#fff;font-size:12px;font-weight:500;border-radius:4px;white-space:nowrap;box-shadow:0 2px 8px #0006;pointer-events:none;margin-bottom:4px}.color-legend-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#000000d9}.color-legend-cursor:before{content:"";position:absolute;top:20px;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #fff;box-shadow:0 -1px 2px #0000004d}.color-legend-labels{display:flex;justify-content:space-between;margin-left:43px;width:180px;font-size:11px;color:#ffffffb3;font-weight:500}.color-legend-min,.color-legend-max{text-shadow:0 1px 2px rgba(0,0,0,.5)}.color-legend-unit{font-size:12px;color:#ffffffd9;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.5);min-width:32px}.color-legend-unit.clickable{cursor:pointer;padding:2px 6px;border-radius:4px;background:#ffffff1a;transition:background .2s}.color-legend-unit.clickable:hover{background:#fff3}.color-legend-unit.clickable:active{background:#ffffff4d}.fronts-legend-wrapper{position:absolute;bottom:200px;right:12px;z-index:1000}@media (min-width: 769px){.fronts-legend-wrapper{bottom:170px;right:60px}}.fronts-legend-btn{display:flex;align-items:center;justify-content:center;padding:4px 8px;background:#07192ee6;border:1px solid rgba(66,148,234,.4);border-radius:10px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000004d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);min-width:44px;height:28px}.fronts-legend-btn:hover{background:#4294ea4d}.fronts-legend-btn-text{font-size:12px;color:#ffffffe6;font-weight:500}.fronts-legend-container{background:#07192ef2;border-radius:12px;padding:12px 16px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(66,148,234,.4);box-shadow:0 4px 16px #0006;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.fronts-legend-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.fronts-legend-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#ffffffb3;font-size:12px;cursor:pointer;transition:all .2s ease}.fronts-legend-close:hover{background:#fff3;color:#fff}@media (min-width: 769px){.fronts-legend-btn{background:#07192ee6;border:1px solid rgba(66,148,234,.4);min-width:48px;height:26px}.fronts-legend-btn:hover{background:#4294ea4d}.fronts-legend-btn-text{color:#ffffffe6;font-size:12px}.fronts-legend-container{background:#07192ef2;border:1px solid rgba(66,148,234,.4)}.fronts-legend-title{color:#ffffffe6}.fronts-legend-close{background:#ffffff1a;color:#ffffffb3}.fronts-legend-close:hover{background:#fff3;color:#fff}}.fronts-legend-title{font-size:13px;font-weight:600;color:#ffffffe6;text-align:center;flex:1}@media (min-width: 769px){.fronts-legend-title{color:#ffffffe6}.fronts-legend-close{background:#ffffff1a;color:#ffffffb3}.fronts-legend-close:hover{background:#fff3;color:#fff}}.fronts-legend-items{display:flex;flex-direction:column;gap:6px}.fronts-legend-item{display:flex;align-items:center;gap:8px}.fronts-legend-line{position:relative;width:60px;height:3px;border-radius:2px;display:flex;align-items:center}.fronts-legend-symbols{position:absolute;top:-12px;left:0;display:flex;align-items:flex-end;gap:2px}.fronts-legend-label{font-size:11px;font-weight:500;white-space:nowrap}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;z-index:2000;display:flex;justify-content:flex-end;animation:fadeIn .2s ease}.settings-panel{width:360px;max-width:100%;height:100%;background:#1a1a2e;box-shadow:-4px 0 20px #0000004d;animation:slideIn .3s ease;display:flex;flex-direction:column;overflow:hidden}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.settings-header h2{margin:0;font-size:20px;font-weight:600;color:#fff}.settings-close-btn{background:none;border:none;color:#888;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.settings-close-btn:hover{color:#fff}.settings-content{flex:1;overflow-y:auto;padding:20px 24px}.settings-section{margin-bottom:32px}.settings-section h3{font-size:14px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#ffffff0d;border-radius:12px}.settings-item-info{display:flex;flex-direction:column;gap:4px}.settings-item-title{font-size:16px;font-weight:500;color:#fff}.settings-item-desc{font-size:13px;color:#aaa;line-height:1.4}.settings-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.settings-switch input{opacity:0;width:0;height:0}.settings-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#444;border-radius:28px;transition:.3s}.settings-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}.settings-switch input:checked+.settings-slider{background:#4294ea}.settings-switch input:checked+.settings-slider:before{transform:translate(24px)}.settings-params{display:flex;flex-direction:column;gap:12px}.param-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff0d;border-radius:8px}.param-label{font-size:14px;color:#aaa}.param-value{font-size:16px;font-weight:600;color:#4294ea;margin-right:4px}.param-input{width:60px;padding:6px 8px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff1a;color:#fff;font-size:14px;font-weight:600;color:#4294ea;text-align:center}.param-input:focus{outline:none;border-color:#4294ea;background:#4294ea33}.param-input:disabled{opacity:.5;cursor:not-allowed}.param-input::-webkit-outer-spin-button,.param-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.param-input[type=number]{-moz-appearance:textfield}.settings-description{margin-top:16px;padding:16px;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.settings-description:first-of-type{margin-top:20px}.description-title{font-size:14px;font-weight:600;color:#888;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.description-text{font-size:13px;color:#aaa;line-height:1.7;margin:0;text-align:justify}.description-list{list-style:none;margin:0;padding:0}.description-list li{position:relative;padding:6px 0 6px 16px;font-size:13px;color:#aaa;line-height:1.5}.description-list li:before{content:"•";position:absolute;left:0;color:#4294ea;font-weight:700}@media (max-width: 768px){.settings-panel{width:100%}}.bottom-switches-container{position:absolute;bottom:80px;right:60px;z-index:1000;display:flex;align-items:center;gap:16px;pointer-events:auto}.mobile-bottom-panel{position:fixed;bottom:0;left:0;right:0;z-index:1000;display:flex;flex-direction:column;background:transparent;pointer-events:none}.mobile-bottom-panel>*{pointer-events:auto}.mobile-wind-layer-switch{padding:6px 12px;background:#07192ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(66,148,234,.3);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.mobile-wind-layer-switch::-webkit-scrollbar{display:none}.mobile-wind-layer-switch .wind-layer-switch-wrap{display:flex;gap:8px;align-items:center;justify-content:space-between;width:100%}.mobile-wind-layer-switch .wind-layer-switch-wrap .checkbox-wrapper:nth-child(3){display:none}.mobile-wind-layer-switch .checkbox-wrapper{font-size:clamp(10px,2.5vw,12px);font-weight:500;display:flex;align-items:center;gap:4px;color:#ffffffd9;-webkit-user-select:none;user-select:none;flex-shrink:1}.mobile-wind-layer-switch .checkbox-wrapper .toggle{position:relative;display:block;width:clamp(32px,8vw,40px);height:clamp(18px,4.5vw,22px);background:#ffffff26;border-radius:11px;cursor:pointer;border:2px solid rgba(255,255,255,.2);transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;margin:0;outline:none;box-shadow:inset 0 2px 4px #0003;flex-shrink:0;-webkit-tap-highlight-color:transparent}.mobile-wind-layer-switch .checkbox-wrapper .toggle:active{border-color:#4294ea99;box-shadow:inset 0 2px 4px #0003,0 0 0 3px #4294ea4d}.mobile-wind-layer-switch .checkbox-wrapper .toggle.checked{background:linear-gradient(135deg,#4294ea,#2d7dd2);border-color:#4294ea;box-shadow:0 2px 8px #4294ea66}.mobile-wind-layer-switch .checkbox-wrapper .toggle-slider{position:absolute;top:2px;left:2px;width:clamp(10px,2.8vw,14px);height:clamp(10px,2.8vw,14px);background:#fff;border-radius:50%;box-shadow:0 2px 6px #0000004d;transition:transform .3s cubic-bezier(.4,0,.2,1)}.mobile-wind-layer-switch .checkbox-wrapper .toggle.checked .toggle-slider{transform:translate(clamp(10px,4vw,14px))}.mobile-wind-layer-switch .model-switch-wrapper{position:relative;display:flex;gap:0;background:#ffffff26;border-radius:8px;padding:2px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:inset 0 2px 4px #0003;overflow:hidden;flex-shrink:0}.mobile-wind-layer-switch .model-switch-wrapper .model-option{flex:1;min-width:clamp(24px,6vw,32px);height:clamp(20px,5vw,24px);background:transparent;border:none;border-radius:0;padding:0 4px;margin:0;outline:none;cursor:pointer;font-size:clamp(10px,2.5vw,12px);font-weight:500;color:#ffffffd9;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;letter-spacing:.5px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.mobile-wind-layer-switch .model-switch-wrapper .model-option:active{background:#4294ea33}.mobile-wind-layer-switch .model-switch-wrapper .model-option:first-child{border-radius:8px 0 0 8px}.mobile-wind-layer-switch .model-switch-wrapper .model-option:last-child{border-radius:0 8px 8px 0}.mobile-wind-layer-switch .model-switch-wrapper .model-option.active{background:linear-gradient(135deg,#4294ea,#2d7dd2);color:#fff;box-shadow:0 2px 8px #4294ea66;font-weight:600}.date-block-bar{padding:4px 8px;background:#07192ef2;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-top:1px solid rgba(66,148,234,.3)}.date-blocks{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:4px 0}.date-blocks::-webkit-scrollbar{display:none}.date-block{flex-shrink:0;min-width:44px;padding:8px 12px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.15);-webkit-tap-highlight-color:transparent;outline:none}.date-block:active{background:#4294ea4d;box-shadow:0 0 0 2px #4294ea66}.date-block.active{background:#3b82f6e6;color:#fff;border-color:#3b82f680;box-shadow:0 2px 8px #3b82f666}.date-block.disabled{background:#64646426;color:#96969666;cursor:not-allowed;opacity:.4;border-color:#64646433}.time-block-bar{padding:2px 12px 0;background:#07192ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2)}.time-blocks{display:flex;gap:6px;padding:0;overflow-x:hidden}.time-block{flex:1;min-width:0;height:36px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#ffffff14;color:#ffffffb3;border:1px solid rgba(255,255,255,.1);-webkit-tap-highlight-color:transparent;outline:none}.time-block:active{background:#4294ea4d;box-shadow:0 0 0 2px #4294ea66}.time-block.active{background:#667eeae6;color:#fff;border-color:#667eea80;box-shadow:0 2px 6px #667eea4d}.time-block.disabled{background:#64646426;color:#96969666;cursor:not-allowed;opacity:.4;border-color:#64646433}.update-time{text-align:center;padding:4px 6px 8px;padding-bottom:calc(8px + env(safe-area-inset-bottom));font-size:11px;color:#ffffff80;background:#07192ef2}.mobile-header{position:fixed;top:0;left:0;right:0;z-index:1001;height:48px;background:#07192ee6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(66,148,234,.2)}.mobile-header-left{position:absolute;left:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:6px;font-size:16px;font-weight:400;color:#fff}.mobile-header-left img{width:20px;height:20px;display:block}.mobile-header-left .header-divider{color:#ffffff80;font-size:14px}.mobile-header-left .header-subtitle{font-size:16px;font-weight:400}.mobile-header-right{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}.header-action-btn{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:0 12px;border:none;border-radius:14px;font-size:12px;background:#ffffff1a;color:#ffffffe6;cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none}.header-action-btn:active{background:#4294ea4d;box-shadow:0 0 0 2px #4294ea66}.map-model-switch{position:fixed;top:60px;right:12px;z-index:1000;display:flex;gap:0;background:#07192ee6;border-radius:8px;padding:1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000004d;overflow:hidden;border:1px solid rgba(66,148,234,.3)}.map-model-btn{min-width:28px;height:22px;background:transparent;border:none;border-radius:0;padding:0 6px;font-size:11px;font-weight:500;color:#ffffffd9;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;outline:none}.map-model-btn:active{background:#4294ea4d}.map-model-btn:first-child{border-radius:7px 0 0 7px}.map-model-btn:last-child{border-radius:0 7px 7px 0}.map-model-btn.active{background:linear-gradient(135deg,#4294ea,#2d7dd2);color:#fff;box-shadow:0 2px 8px #4294ea66;font-weight:600}.mobile-fixed-popup{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,calc(-100% - 15px))!important;bottom:auto!important;right:auto!important;z-index:2000!important;pointer-events:auto!important}.mobile-fixed-popup .mapboxgl-popup-tip{display:block!important;border-top-color:inherit!important}.mobile-fixed-marker{z-index:2001!important}.mobile-map-hint{position:fixed;top:60%;left:50%;transform:translate(-50%,-50%);z-index:999;display:flex;flex-direction:column;align-items:center;color:#ffffffe6;text-shadow:0 1px 3px rgba(0,0,0,.7);pointer-events:none}.mobile-map-hint .hint-arrow-row{display:flex;align-items:center;gap:10px}.mobile-map-hint .hint-text{font-size:14px;font-weight:500;white-space:nowrap}.mobile-map-hint .hint-arrow{filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.mobile-map-hint .hint-arrow-up{transform:rotate(0);margin-bottom:2px}.mobile-map-hint .hint-arrow-down{transform:rotate(180deg);margin-top:2px}.mobile-map-hint .hint-arrow-left{transform:rotate(-90deg)}.mobile-map-hint .hint-arrow-right{transform:rotate(90deg)}.blinking{animation:blink 2s ease-in-out infinite}.mobile-live-indicator{position:absolute;top:8px;right:36px;display:flex;align-items:center;gap:4px;padding:3px 8px;background:#4caf5033;border-radius:12px;font-size:10px;color:#4caf50;animation:fadeIn .3s ease}.mobile-live-indicator:before{content:"";width:5px;height:5px;background:#4caf50;border-radius:50%;animation:blink 1s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.hourly-time-selector{padding:2px 12px 0;background:#07192ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2)}.hourly-time-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:4px 0;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;scroll-snap-type:x mandatory}.hourly-time-scroll::-webkit-scrollbar{display:none}.hourly-time-block{flex-shrink:0;min-width:48px;height:36px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#ffffff14;color:#ffffffb3;border:1px solid rgba(255,255,255,.1);-webkit-tap-highlight-color:transparent;outline:none;scroll-snap-align:center}.hourly-time-block:active{background:#4294ea4d;box-shadow:0 0 0 2px #4294ea66}.hourly-time-block.active{background:#667eeae6;color:#fff;border-color:#667eea80;box-shadow:0 2px 6px #667eea4d;transform:scale(1.05)}.hourly-time-block.disabled{background:#64646426;color:#96969666;cursor:not-allowed;opacity:.4;border-color:#64646433}.timeline-container{position:relative;height:30px;padding:0 45px}.progress-line{position:relative;width:100%;height:4px;background:#fff3;border-radius:2px;cursor:pointer;overflow:visible}.avbl{position:absolute;left:0;top:0;height:100%;width:100%;background:#4294ea4d;border-radius:2px}.premium{position:absolute;right:0;top:0;height:100%;background:#ffbe434d;border-radius:2px}.played{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#4294ea,#1860a0);border-radius:2px;transition:width .1s ease-out}.anim-allowed .played{transition:width .3s cubic-bezier(.4,0,.2,1)}.free{position:absolute;left:0;top:0;height:100%;background:#4294ea99;border-radius:2px}.current-marker{position:absolute;left:0;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#fff;border-radius:50%;cursor:grab;z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));box-shadow:0 0 0 3px #4294ea80}.current-marker:active{cursor:grabbing}.daily-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#ffffffb3;border-radius:50%;z-index:3;opacity:.7;cursor:pointer;transition:width .15s ease,height .15s ease,opacity .15s ease,background .15s ease,box-shadow .15s ease,filter .15s ease}.daily-marker:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%}.daily-marker:hover,.daily-marker.active{width:14px;height:14px;background:#fff;opacity:1;z-index:10;filter:drop-shadow(0 0 8px rgba(66,148,234,.8));box-shadow:0 0 0 3px #4294ea99;transform:translate(-50%,-50%)}.daily-marker.selected{width:12px;height:12px;background:#fff;opacity:1;z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));box-shadow:0 0 0 3px #4294ea80;pointer-events:auto}.intermediate-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:6px;height:6px;background:#ffffff80;border-radius:50%;z-index:2;opacity:.5;cursor:pointer;transition:width .15s ease,height .15s ease,opacity .15s ease,background .15s ease,box-shadow .15s ease,filter .15s ease}.intermediate-marker:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%}.intermediate-marker:hover,.intermediate-marker.active{width:14px;height:14px;background:#fff;opacity:1;z-index:10;filter:drop-shadow(0 0 8px rgba(66,148,234,.8));box-shadow:0 0 0 3px #4294ea99;transform:translate(-50%,-50%)}.intermediate-marker.selected{width:12px;height:12px;background:#fff;opacity:1;z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));box-shadow:0 0 0 3px #4294ea80;pointer-events:auto}.time-mark{position:absolute;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;pointer-events:none;z-index:5}.time-mark-label{font-size:11px;color:#fffc;margin-top:2px;font-family:Arial,sans-serif;font-weight:600}.timecode{position:absolute;top:-35px;left:0;transform:translate(-50%);background:#07192ef2;color:#fff;padding:6px 12px;border-radius:6px;font-size:13px;white-space:nowrap;cursor:grab;z-index:5;box-shadow:0 4px 12px #0006;border:1px solid rgba(66,148,234,.5);transition:left .1s ease-out}.timecode.anim-allowed{transition:left .3s cubic-bezier(.4,0,.2,1)}.timecode .box{display:flex;align-items:center;gap:4px}.ghost-timecode{opacity:0;pointer-events:none;background:#07192ee6;border:1px solid rgba(66,148,234,.8);transition:opacity .2s ease,left .1s cubic-bezier(.25,.46,.45,.94);z-index:6;box-shadow:0 4px 12px #0006;top:-45px}.progress-line:hover .ghost-timecode{opacity:1}.tooltip--up:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(7,25,46,.95)}.play-pause{position:absolute;top:-12px;left:5px;width:32px;height:32px;background:#07192ecc;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 4px 12px #0000004d;border:2px solid rgba(66,148,234,.5);transition:all .3s ease}.play-pause:hover{background:#4294eacc;transform:scale(1.05)}.play-pause:active{transform:scale(.95)}#calendar{position:absolute;left:45px;right:45px;top:6px;height:30px;white-space:nowrap;overflow:hidden}.loading{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.loading--variant-gray{border-color:#fff3;border-top-color:#4294ea}.size-l{width:16px;height:16px}.premium-flag{display:inline-block;width:12px;height:12px;background:linear-gradient(135deg,#ffbe43,#ff8c00);border-radius:2px;margin-left:4px}@media (max-width: 768px){.timeline-container{height:26px;padding:0 40px}.timecode{font-size:12px;padding:4px 8px;top:-30px}.progress-line{height:3px}#calendar div{font-size:11px;padding:4px 0 0 6px}.play-pause{width:28px;height:28px;top:-10px;left:4px}}@media (prefers-color-scheme: dark){.progress-line{background:#ffffff26}}.current-timeline-container{position:relative;height:30px;padding:0 45px}.current-timeline-container .progress-line{position:relative;width:100%;height:4px;background:#fff3;border-radius:2px;cursor:pointer;overflow:visible}.current-timeline-container .avbl{position:absolute;left:0;top:0;height:100%;width:100%;background:#4294ea4d;border-radius:2px}.current-timeline-container .premium{position:absolute;right:0;top:0;height:100%;background:#ffbe434d;border-radius:2px}.current-timeline-container .played{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#4294ea,#1860a0);border-radius:2px;transition:width .1s ease-out}.current-timeline-container .anim-allowed .played{transition:width .3s cubic-bezier(.4,0,.2,1)}.current-timeline-container .free{position:absolute;left:0;top:0;height:100%;background:#4294ea99;border-radius:2px}.current-timeline-container .current-marker{position:absolute;left:0;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#fff;border-radius:50%;cursor:grab;z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));box-shadow:0 0 0 3px #4294ea80}.current-timeline-container .current-marker:active{cursor:grabbing}.current-timeline-container .daily-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#ffffffb3;border-radius:50%;pointer-events:none;z-index:3;opacity:.7;cursor:pointer;transition:all .3s ease}.current-timeline-container .daily-marker.selected{width:12px;height:12px;background:#fff;opacity:1;z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));box-shadow:0 0 0 3px #4294ea80;pointer-events:auto}.current-timeline-container .intermediate-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:4px;height:4px;background:#fff6;border-radius:50%;pointer-events:none;z-index:2;opacity:.4;cursor:pointer;transition:all .3s ease}.current-timeline-container .intermediate-marker.three-hour-marker{width:6px;height:6px;background:#ffffff80;opacity:.5}.current-timeline-container .intermediate-marker.selected{width:12px;height:12px;background:#fff;opacity:1;z-index:10;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));box-shadow:0 0 0 3px #4294ea80;pointer-events:auto}.current-timeline-container .time-mark{position:absolute;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;pointer-events:none;z-index:5}.current-timeline-container .time-mark-label{font-size:11px;color:#fffc;margin-top:2px;font-family:Arial,sans-serif;font-weight:600}.current-timeline-container .timecode{position:absolute;top:-35px;left:0;transform:translate(-50%);background:#07192ef2;color:#fff;padding:6px 12px;border-radius:6px;font-size:13px;white-space:nowrap;cursor:grab;z-index:5;box-shadow:0 4px 12px #0006;border:1px solid rgba(66,148,234,.5);transition:left .1s ease-out}.current-timeline-container .timecode.anim-allowed{transition:left .3s cubic-bezier(.4,0,.2,1)}.current-timeline-container .timecode .box{display:flex;align-items:center;gap:4px}.current-timeline-container .ghost-timecode{opacity:0;pointer-events:none;background:#07192ee6;border:1px solid rgba(66,148,234,.8);transition:opacity .2s ease,left .1s cubic-bezier(.25,.46,.45,.94);z-index:6;box-shadow:0 4px 12px #0006}.current-timeline-container .progress-line:hover .ghost-timecode{opacity:1}.current-timeline-container .tooltip--up:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(7,25,46,.95)}.current-timeline-container .play-pause{position:absolute;top:-12px;left:5px;width:32px;height:32px;background:#07192ecc;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 4px 12px #0000004d;border:2px solid rgba(66,148,234,.5);transition:all .3s ease}.current-timeline-container .play-pause:hover{background:#4294eacc;transform:scale(1.05)}.current-timeline-container .play-pause:active{transform:scale(.95)}.current-timeline-container #calendar{position:absolute;left:45px;right:45px;top:6px;height:30px;white-space:nowrap;overflow:hidden}.current-timeline-container .loading{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.current-timeline-container .loading--variant-gray{border-color:#fff3;border-top-color:#4294ea}.current-timeline-container .size-l{width:16px;height:16px}.current-timeline-container .premium-flag{display:inline-block;width:12px;height:12px;background:linear-gradient(135deg,#ffbe43,#ff8c00);border-radius:2px;margin-left:4px}@media (max-width: 768px){.current-timeline-container{height:26px;padding:0 40px}.current-timeline-container .timecode{font-size:12px;padding:4px 8px;top:-30px}.current-timeline-container .progress-line{height:3px}.current-timeline-container #calendar div{font-size:11px;padding:4px 0 0 6px}.current-timeline-container .play-pause{width:28px;height:28px;top:-10px;left:4px}}@media (prefers-color-scheme: dark){.current-timeline-container .progress-line{background:#ffffff26}}.area-button-wrap{position:absolute;bottom:120px;left:20px;display:flex;flex-direction:row;gap:8px;z-index:100}.area-button{position:relative;border-radius:6px;padding:4px 12px;border:1px solid #4294EA;font-size:12px;text-transform:uppercase;letter-spacing:1px;background:#07192ecc;color:#fff;overflow:hidden;box-shadow:0 0 0 0 transparent;transition:all .2s ease-in;cursor:pointer}.area-button:hover{background:#4294ea;transition:all .2s ease-out}.area-button:hover:before{animation:sh02 .5s 0s linear}.area-button:before{content:"";display:block;width:0px;height:86%;position:absolute;top:7%;left:0%;opacity:0;background:#fff;box-shadow:0 0 50px 30px #fff;transform:skew(-20deg)}@keyframes sh02{0%{opacity:0;left:0%}50%{opacity:1}to{opacity:0;left:100%}}.area-button:active{box-shadow:0 0 0 0 transparent;transition:box-shadow .2s ease-in}@media (max-width: 768px){.area-button-wrap{bottom:100px}.area-button{padding:3px 10px;font-size:11px}}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:transparent;display:flex;align-items:center;justify-content:center;z-index:9999;pointer-events:none}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 30px;background:#000000a6;border-radius:12px;box-shadow:0 4px 20px #0000004d}.loading-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.2);border-top-color:#4294ea;border-radius:50%;animation:spin .8s linear infinite}.loading-text{margin-top:12px;color:#fff;font-size:13px;font-weight:400;text-align:center;white-space:nowrap}@media (max-width: 768px){.loading-spinner{width:28px;height:28px}.loading-text{font-size:12px}}@font-face{font-family:iconfont;src:url(//at.alicdn.com/t/c/font_2623931_9kg94c3eotc.eot?t=1738123456789);src:url(//at.alicdn.com/t/c/font_2623931_9kg94c3eotc.eot?t=1738123456789#iefix) format("embedded-opentype"),url(//at.alicdn.com/t/c/font_2623931_9kg94c3eotc.woff2?t=1738123456789) format("woff2"),url(//at.alicdn.com/t/c/font_2623931_9kg94c3eotc.woff?t=1738123456789) format("woff"),url(//at.alicdn.com/t/c/font_2623931_9kg94c3eotc.ttf?t=1738123456789) format("truetype"),url(//at.alicdn.com/t/c/font_2623931_9kg94c3eotc.svg?t=1738123456789#iconfont) format("svg")}.iconfont{font-family:iconfont!important;font-size:18px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.layerBar{position:absolute;top:40px;left:20px;padding:6px 0 6px 8px;border-radius:9px;pointer-events:none;z-index:1100}.layerBar-bg{position:absolute;z-index:1;top:0;bottom:0;left:0;width:30px;background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:9px;box-shadow:0 4px 12px #0000004d}.layerItem{position:relative;z-index:2;display:flex;align-items:center;cursor:pointer;width:fit-content;pointer-events:visiblePainted;margin-bottom:8px;transition:all .3s cubic-bezier(.4,0,.2,1)}.layerItem:not(:first-child){margin-top:8px}.layerIcon{display:flex;align-items:center;justify-content:center;color:#fff;position:relative;width:20px;height:20px}.layerIcon span{font-size:18px;line-height:1;display:inline-block;z-index:3}.layerIcon img{position:relative;z-index:3}.layerIcon-img{width:18px;height:18px;position:relative;z-index:3}.layerIcon-emoji{font-size:16px;position:relative;z-index:3}.layerItem.selected .layerIcon:before{content:" ";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;background-color:#4294ea;z-index:2;animation:circlePop .3s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes circlePop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}50%{transform:translate(-50%,-50%) scale(1.1);opacity:1}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.layerText{padding:4px 10px;border-radius:12px;margin-left:11px;font-size:14px;color:#fffefe;font-weight:500;opacity:0;transform:translate(-10px);transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:6px}.unitText{font-size:11px;color:#fff9;font-weight:400}.layerItem:hover .layerText{background-color:#4294ea;opacity:1;transform:translate(0);transition:background-color .2s ease-out}.layerItem:hover .layerIcon:before{content:" ";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;background-color:#4294ea;z-index:2;transition:all .25s cubic-bezier(.4,0,.2,1)}.layerItem.selected .layerText{opacity:1;transform:translate(0)}.layerItem.selected:hover .layerText{background-color:#4294ea4d}.tooltip{position:absolute;left:calc(100% + 15px);top:50%;transform:translateY(-50%);background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(66,148,234,.5);border-radius:8px;padding:10px 14px;min-width:140px;z-index:2000;opacity:0;animation:tooltipFadeIn .2s ease;box-shadow:0 4px 16px #0006}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(-5px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.tooltipTitle{color:#fff;font-size:14px;font-weight:600;margin-bottom:4px}.tooltipCategory{color:#ffffffb3;font-size:12px}@media (max-width: 768px){.layerBar{position:fixed;top:56px;bottom:160px;left:8px;padding:8px 0 8px 6px;display:flex;flex-direction:column;justify-content:space-evenly}.layerBar-bg{width:32px;border-radius:8px;height:100%;top:0;bottom:0}.layerItem{margin-bottom:0;flex-shrink:0}.layerItem:not(:first-child){margin-top:0}.layerIcon{width:20px;height:20px}.layerIcon span{font-size:20px}.layerIcon-img{width:20px;height:20px}.layerIcon-emoji{font-size:18px}.layerText{font-size:12px;padding:3px 8px;margin-left:8px}.layerItem.selected .layerIcon:before{width:26px;height:26px}.layerText{opacity:0;transform:translate(-10px)}.layerItem:active .layerText,.layerItem.selected .layerText{opacity:1;transform:translate(0)}.layerItem:hover .layerIcon:before{width:26px;height:26px}.layerItem:hover .layerText{background-color:#4294ea;opacity:1;transform:translate(0);transition:background-color .2s ease-out}}.weather-layer-popup{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important}.weather-layer-popup .mapboxgl-popup-content{--popup-border-color: rgba(66, 148, 234, 1);background:#07192e80!important;border:3px solid var(--popup-border-color)!important;border-radius:8px!important;padding:3px 6px!important;box-shadow:none!important;position:relative;overflow:visible}.popup-hover-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#07192ed9;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .2s ease;border-radius:6px;cursor:pointer;font-size:20px;font-weight:600;color:#fff;z-index:10;pointer-events:auto;-webkit-user-select:none;user-select:none;pointer-events:none}.popup-detail-btn{position:relative;width:100%;display:flex;align-items:center;justify-content:center;gap:4px;background:transparent;color:#4294ea;border:none;padding:4px 8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px;border-radius:6px;z-index:30}.popup-detail-btn:hover{color:#667eea;text-decoration:underline}.popup-detail-btn:active{color:#4294ea}.detail-query-text{display:inline-block;animation:text-blink 1.2s ease-in-out infinite}@keyframes text-blink{0%,to{color:#4294ea}50%{color:#66b3ff}}.weather-layer-popup .mapboxgl-popup-tip{--popup-border-color: rgba(66, 148, 234, 1);align-self:center;border-left:9px solid transparent!important;border-right:9px solid transparent!important;border-top:10px solid var(--popup-border-color)!important;border-bottom:none!important;width:0!important;height:0!important;z-index:1;background:transparent!important}.weather-layer-popup .mapboxgl-popup-tip:before{position:absolute;bottom:4px;left:50%;content:"";display:inline-block;border-left:9px solid transparent;border-right:9px solid transparent;border-top:10px solid rgba(7,25,46,.6);transform:translate(-50%)}.weather-layer-popup .mapboxgl-popup-close-button{--popup-border-color: rgba(66, 148, 234, 1);color:#ffffffb3!important;font-size:20px!important;padding:8px!important;line-height:1!important;border-radius:50%!important;border:2px solid transparent!important;transition:all .2s ease!important;outline:none!important;box-shadow:none!important}.weather-layer-popup .mapboxgl-popup-close-button:hover{color:var(--popup-border-color)!important;border-color:var(--popup-border-color)!important;outline:none!important;box-shadow:none!important}.weather-layer-popup .mapboxgl-popup-close-button:focus{color:var(--popup-border-color)!important;border-color:var(--popup-border-color)!important;outline:none!important;box-shadow:none!important}.weather-layer-popup .custom-close-btn{transition:all .2s ease!important}.weather-layer-popup .custom-close-btn:hover{transform:scale(1.1)!important;box-shadow:0 4px 12px #0006!important}.value-content{display:flex;flex-direction:column;align-items:flex-start;gap:4px;color:#fff;font-family:Arial,sans-serif;font-size:14px;font-weight:500}.value-val{padding:3px 10px;display:inline-block}.value-angle{display:inline-block;width:16px;height:16px;border:2px solid #fff;border-radius:50%;flex-shrink:0}.typhoon-control-panel{position:absolute;top:90px;left:120px;width:280px;max-height:calc(100vh - 120px);background:#0006;border-radius:12px;padding:20px;font-size:14px;z-index:1000;box-shadow:0 8px 32px #0000004d;color:#e6f7ff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);transition:all .3s ease;overflow:hidden;display:flex;flex-direction:column;pointer-events:auto}.typhoon-control-panel:hover{box-shadow:0 12px 40px #0006}.control-panel-header{margin-bottom:12px}.control-panel-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#00a8ff;display:flex;align-items:center;gap:8px}.control-panel-header h3 .iconfont{font-size:1.2rem}.control-panel-content{display:flex;flex-direction:column;gap:12px;overflow-y:auto;overflow-x:hidden;flex:1}.control-group{display:flex;align-items:center;gap:8px}.year-select{width:75px;background:#eaececcc;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#08374d;padding:6px 24px 6px 8px;font-size:.85rem;font-weight:500;transition:all .3s ease;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2308374d' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.year-select:focus{outline:none;border-color:#00a8ff;box-shadow:0 0 0 3px #00a8ff33}.year-select:hover{border-color:#00a8ff}.year-select option{background:#eaececf2;color:#08374d;padding:10px 12px;border-radius:6px}.year-select option:hover,.year-select option:checked{background:#00a8ff;color:#fff}.control-buttons{display:flex;gap:5px;align-items:center}.control-buttons-inline{display:flex;gap:5px;align-items:center;flex-wrap:nowrap}.btn{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.btn-small{padding:4px 10px;font-size:.85rem}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.btn-secondary:active{transform:translateY(0)}.loading-indicator{text-align:center;padding:15px;color:#00a8ff;font-weight:500;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.typhoon-checkboxes{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:4px;max-height:400px;padding-right:5px}.typhoon-checkboxes::-webkit-scrollbar{width:6px}.typhoon-checkboxes::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.typhoon-checkboxes::-webkit-scrollbar-thumb{background:#ffffff80;border-radius:3px}.typhoon-checkboxes::-webkit-scrollbar-thumb:hover{background:#ffffffb3}.typhoon-checkbox-item{display:flex;align-items:center}.typhoon-checkbox-item label{display:flex;align-items:center;width:100%;padding:6px 8px;margin:0;cursor:pointer;border-radius:6px;transition:all .2s ease;font-size:.9rem;line-height:1.4}.typhoon-checkbox-item label:hover{background:#ffffff0d}.typhoon-checkbox-item input[type=checkbox]{margin:0 8px 0 0;width:16px;height:16px;flex-shrink:0;accent-color:#00a8ff;cursor:pointer}.typhoon-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.current-badge{display:inline-flex;align-items:center;padding:2px 8px;margin-left:8px;font-size:.75rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b6b,#ee5a24);border-radius:12px;white-space:nowrap;box-shadow:0 2px 4px #ff6b6b4d}.no-data{text-align:center;padding:30px 20px;color:#a0a0a0}.no-data p{margin:0;font-size:.9rem}.no-active-typhoon{text-align:center;padding:20px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.no-active-typhoon p{margin:4px 0;font-size:.85rem;color:#a0a0a0}.no-active-typhoon .sub-text{font-size:.8rem;color:gray;margin-top:8px}@media (max-width: 768px){.typhoon-control-panel{width:240px;top:70px;left:10px;max-height:calc(100vh - 90px)}.control-panel-header h3{font-size:1rem}.typhoon-checkboxes{max-height:300px}}@media (prefers-color-scheme: dark){.typhoon-control-panel{background:#0006;border-color:#ffffff26}.year-select{background:#ffffff1a;color:#fff;border-color:#fff3;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}.year-select option{background:#282828f2;color:#fff}.typhoon-checkbox-item label{color:#e0e0e0}}.typhoon-info-panel{position:absolute;top:70px;right:60px;width:280px;height:420px;max-height:calc(100vh - 420px);background:#0006;border-radius:12px;padding:20px;font-size:14px;z-index:999;box-shadow:0 8px 32px #0003;color:#e0e0e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);transition:all .3s ease;overflow:hidden;display:flex;flex-direction:column;pointer-events:auto}.typhoon-info-panel:hover{box-shadow:0 12px 40px #0006}.info-panel-header{margin-bottom:12px}.info-panel-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#00a8ff;display:flex;align-items:center;gap:8px}.info-panel-header h3 .iconfont{font-size:1.2rem}.divider{height:2px;background:linear-gradient(90deg,#00a8ff,transparent);margin:8px 0 0;width:100%}.info-panel-content{flex:1;overflow-y:auto;padding-right:5px}.info-panel-content::-webkit-scrollbar{width:6px}.info-panel-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.info-panel-content::-webkit-scrollbar-thumb{background:#ffffff80;border-radius:3px}.info-panel-content::-webkit-scrollbar-thumb:hover{background:#ffffffb3}.no-selection{text-align:center;padding:40px 20px;color:#a0a0a0}.no-selection p{margin:8px 0;font-size:.9rem}.no-selection .sub-text{font-size:.8rem;color:gray;margin-top:12px}.typhoon-list{display:flex;flex-direction:column;gap:16px}.typhoon-info-card{background:#ffffff08;border-radius:8px;padding:16px;border:1px solid rgba(255,255,255,.05);transition:all .2s ease}.typhoon-info-card:hover{background:#ffffff0d;border-color:#ffffff1a}.typhoon-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.typhoon-header h4{margin:0;font-size:1rem;font-weight:600;color:#fff}.typhoon-number{font-size:.9rem;color:#a0a0a0;font-weight:500}.typhoon-status{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.status-item,.position-item,.update-item{display:flex;align-items:center;justify-content:space-between;font-size:.9rem}.status-item .label,.position-item .label,.update-item .label{color:#a0a0a0;font-weight:500}.status-item .value,.position-item .value,.update-item .value{color:#fff;font-weight:600;text-align:right}.typhoon-position{margin-bottom:12px}.typhoon-position h5,.typhoon-land-info h5{margin:0 0 8px;font-size:.9rem;font-weight:600;color:#00a8ff;text-transform:uppercase;letter-spacing:.5px}.landed{color:#ff6b6b;font-weight:600}.not-landed{color:#4ecdc4;font-weight:600}.typhoon-update{margin-bottom:4px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.typhoon-land-info{padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.land-list{display:flex;flex-direction:column;gap:6px}.land-item{display:flex;align-items:center;gap:8px;font-size:.85rem;padding:4px 8px;background:#ffffff08;border-radius:4px}.land-number{color:#ff6b6b;font-weight:600;min-width:20px}.land-position{flex:1;color:#e0e0e0;font-weight:500}.land-time{color:#a0a0a0;font-weight:500;font-size:.8rem}@media (max-width: 768px){.typhoon-info-panel{width:240px;left:10px;max-height:calc(100vh - 400px)}.typhoon-info-card{padding:12px}.typhoon-header h4{font-size:.95rem}.status-item,.position-item,.update-item{font-size:.85rem}}@media (prefers-color-scheme: dark){.typhoon-info-panel{background:#0006;border-color:#ffffff26}.typhoon-info-card{background:#ffffff05;border-color:#ffffff14}}.typhoon-legend{position:absolute;bottom:170px;right:60px;background:#0006;border-radius:12px;padding:12px;width:360px;z-index:800;box-shadow:0 8px 32px #0000004d;color:#e0e0e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);transition:all .3s ease;overflow:hidden}.typhoon-legend:hover{box-shadow:0 12px 40px #0006}.typhoon-legend-toggle{display:none;position:fixed;right:8px;bottom:165px;width:32px;height:32px;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);cursor:pointer;z-index:850;box-shadow:0 4px 12px #0000004d;transition:all .3s ease;color:#fff;font-size:14px;font-weight:500}.typhoon-legend-toggle:hover{background:#4294ea99;transform:scale(1.1)}.typhoon-legend-close{display:none;position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;font-size:16px;cursor:pointer;z-index:10;transition:all .2s ease}.typhoon-legend-close:hover{background:#fff3}.mobile-only{display:none}@media (max-width: 768px){.mobile-only{display:block}}.legend-section{margin-bottom:12px}.legend-section:last-child{margin-bottom:0}.legend-title{margin:0 0 8px;font-size:.9rem;font-weight:600;color:#00a8ff;text-transform:uppercase;letter-spacing:.5px}.intensity-row{display:flex;align-items:center;gap:12px}.intensity-item{display:flex;flex-direction:column;align-items:center;gap:4px}.intensity-icon{width:28px;height:28px;object-fit:contain;transition:transform .2s ease}.intensity-icon:hover{transform:scale(1.1)}.intensity-name{font-size:.7rem;color:#e0e0e0;font-weight:500;white-space:nowrap;text-align:center}.agency-list{display:grid;grid-template-columns:repeat(4,1fr);gap:6px 8px}.agency-item{display:flex;align-items:center;gap:6px;padding:4px 6px;background:#ffffff08;border-radius:4px;transition:all .2s ease}.agency-item:hover{background:#ffffff0d;transform:translate(2px)}.agency-color{width:20px;height:3px;flex-shrink:0;border-radius:2px;box-shadow:0 1px 3px #0000004d;transition:transform .2s ease}.agency-item:hover .agency-color{transform:scaleX(1.1)}.agency-name{flex:1;font-size:.7rem;color:#e0e0e0;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.typhoon-legend-toggle{display:block}.typhoon-legend{position:fixed;bottom:165px;right:8px;left:auto;padding:10px;width:auto;max-width:280px;font-size:12px;display:none;opacity:0;transform:scale(.9);transform-origin:bottom right}.typhoon-legend.expanded{display:block;opacity:1;transform:scale(1)}.legend-title{font-size:.85rem;margin-bottom:6px;padding-right:28px}.intensity-row{gap:6px;flex-wrap:wrap;justify-content:flex-start}.intensity-item{gap:2px}.intensity-icon{width:22px;height:22px}.intensity-name{font-size:.65rem}.agency-list{grid-template-columns:repeat(2,1fr);gap:4px 6px}.agency-item{padding:3px 6px}.agency-color{width:16px;height:3px}.agency-name{font-size:.7rem}.typhoon-legend-close{display:block}}@media (prefers-color-scheme: dark){.typhoon-legend{background:#0006;border-color:#ffffff26}.intensity-item{filter:brightness(1.1)}.agency-item{background:#ffffff05}.agency-item:hover{background:#ffffff0a}}@media print{.typhoon-legend{display:none}}.mobile-typhoon-panel{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:800}.mobile-typhoon-panel>*{pointer-events:none}.mobile-typhoon-control{position:absolute;top:90px;right:8px;pointer-events:auto}.mobile-typhoon-dropdown{width:100px;max-height:50vh;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:12px;box-shadow:0 4px 20px #00000080;overflow:hidden;display:flex;flex-direction:column}.mobile-typhoon-dropdown-header{display:flex;align-items:center;gap:6px;padding:8px;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-year-select{flex:1;background:#0009;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;padding:4px 8px;font-size:12px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.mobile-year-select option{background:#1e1e1ef2;color:#fff}.mobile-typhoon-actions{display:flex;gap:4px}.mobile-action-btn{padding:4px 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:11px;cursor:pointer;transition:all .15s ease}.mobile-action-btn:active{background:#00a8ff66}.mobile-typhoon-loading{text-align:center;padding:10px;color:#00a8ff;font-size:12px}.mobile-typhoon-list{flex:1;overflow-y:auto;padding:4px}.mobile-typhoon-list::-webkit-scrollbar{width:4px}.mobile-typhoon-list::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.mobile-typhoon-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:12px;color:#fffc;transition:background .15s ease}.mobile-typhoon-item:active,.mobile-typhoon-item.selected{background:#00a8ff26}.mobile-typhoon-item input[type=checkbox]{width:14px;height:14px;accent-color:#00a8ff;flex-shrink:0}.mobile-typhoon-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-current-badge{padding:1px 6px;font-size:10px;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b6b,#ee5a24);border-radius:8px;flex-shrink:0}.mobile-no-data{text-align:center;padding:20px;color:#fff6;font-size:12px}.mobile-typhoon-legend-wrapper{position:absolute;top:60px;left:8px;pointer-events:auto;z-index:10}.mobile-typhoon-legend-btn{display:flex;align-items:center;justify-content:center;padding:4px 10px;background:#000000bf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000004d}.mobile-typhoon-legend-btn span{font-size:12px;color:#ffffffe6;font-weight:500}.mobile-typhoon-legend-btn:active{background:#00a8ff4d}.mobile-typhoon-legend-container{background:#000000e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:10px 12px;box-shadow:0 4px 16px #0006;animation:mobileLegendSlide .2s ease;max-height:55vh;overflow-y:auto;width:200px}@keyframes mobileLegendSlide{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.mobile-typhoon-legend-container::-webkit-scrollbar{width:4px}.mobile-typhoon-legend-container::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.mobile-typhoon-legend-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-typhoon-legend-title{font-size:13px;font-weight:600;color:#ffffffe6;flex:1}.mobile-typhoon-legend-close{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#ffffffb3;font-size:11px;cursor:pointer;transition:all .15s ease}.mobile-typhoon-legend-close:active{background:#fff3;color:#fff}.mobile-legend-section{margin-bottom:8px}.mobile-legend-section:last-child{margin-bottom:0}.mobile-legend-section-title{font-size:11px;color:#00a8ff;font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.mobile-intensity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.mobile-intensity-item{display:flex;align-items:center;gap:3px;padding:3px 4px;background:#ffffff08;border-radius:4px}.mobile-intensity-icon{width:16px;height:16px;object-fit:contain;flex-shrink:0}.mobile-intensity-name{font-size:10px;color:#fffc;white-space:nowrap}.mobile-agency-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px}.mobile-agency-item{display:flex;align-items:center;gap:4px;padding:2px 4px}.mobile-agency-color{width:14px;height:3px;flex-shrink:0;border-radius:1px}.mobile-agency-name{font-size:10px;color:#fffc}.mobile-typhoon-info-wrapper{position:absolute;bottom:40px;left:8px;right:8px;pointer-events:auto}.mobile-typhoon-info-toggle{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#000c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000004d}.mobile-typhoon-info-toggle:active{background:#000000e6}.mobile-info-toggle-left{display:flex;align-items:center;gap:6px;color:#fff;font-size:13px;font-weight:500}.mobile-info-toggle-left svg{color:#00a8ff}.mobile-info-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;background:#00a8ff;color:#fff;border-radius:9px}.mobile-typhoon-info-content{margin-top:6px;max-height:40vh;overflow-y:auto;animation:mobileInfoSlideUp .2s ease;border-radius:12px;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);box-shadow:0 -4px 20px #0006}@keyframes mobileInfoSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-typhoon-info-content::-webkit-scrollbar{width:4px}.mobile-typhoon-info-content::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.mobile-typhoon-info-card{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.mobile-typhoon-info-card:last-child{border-bottom:none}.mobile-info-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08)}.mobile-info-typhoon-name{font-size:14px;font-weight:600;color:#fff}.mobile-info-typhoon-ename{font-size:12px;color:#ffffff80;margin-left:4px}.mobile-info-typhoon-id{font-size:11px;color:#fff6;font-weight:500}.mobile-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin-bottom:6px}.mobile-info-cell{display:flex;flex-direction:column;align-items:center;padding:4px 2px;background:#ffffff0a;border-radius:6px}.mobile-info-cell-label{font-size:10px;color:#ffffff73;margin-bottom:1px}.mobile-info-cell-value{font-size:12px;font-weight:600;color:#fff}.mobile-info-cell-value.landed{color:#ff6b6b}.mobile-info-cell-value.not-landed{color:#4ecdc4}.mobile-info-position,.mobile-info-update{display:flex;align-items:center;gap:6px;padding:3px 0}.mobile-info-pos-label{font-size:10px;color:#fff6;min-width:30px;flex-shrink:0}.mobile-info-pos-value{font-size:11px;color:#ffffffd9;font-weight:500}.mobile-info-land{margin-top:4px;padding-top:4px;border-top:1px solid rgba(255,255,255,.08)}.mobile-land-item{display:flex;align-items:center;justify-content:space-between;padding:2px 4px;font-size:11px;color:#ffffffb3}.mobile-land-pos{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-land-time{color:#fff6;font-size:10px;flex-shrink:0;margin-left:6px}@media (prefers-color-scheme: dark){.mobile-typhoon-control-toggle{background:#000c}}.typhoon-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .3s ease;pointer-events:none}.typhoon-loading-content{background:#112240d9;padding:40px 60px;border-radius:12px;box-shadow:0 4px 20px #0006;text-align:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:slideUp .3s ease}.typhoon-loading-spinner{width:60px;height:60px;margin:0 auto 20px;border:4px solid rgba(255,255,255,.1);border-top-color:#00a8ff;border-radius:50%;animation:spin 1s linear infinite}.typhoon-loading-content p{margin:0;font-size:1.1rem;font-weight:500;color:#fff;letter-spacing:.5px}.typhoon-time-display{position:absolute;top:20px;right:160px;background:#00a8ff1a;border:1px solid rgba(0,168,255,.3);border-radius:20px;padding:8px 16px;display:flex;align-items:center;gap:8px;z-index:100;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:all .3s ease}.typhoon-time-display:hover{background:#00a8ff33;border-color:#00a8ff80;box-shadow:0 2px 8px #00a8ff4d}.time-label{font-size:.85rem;color:#a8d8ea;font-weight:500}.time-value{font-size:.9rem;color:#fff;font-weight:600;font-family:Courier New,monospace}.typhoon-marker{position:relative;display:flex;align-items:center;justify-content:center;z-index:100;transition:transform .2s ease}.typhoon-marker:hover{transform:scale(1.1);z-index:200}.typhoon-marker img{display:block;pointer-events:none}.mapboxgl-popup{z-index:2000}.mapboxgl-popup-content{background:transparent!important;border-radius:10px;padding:0;box-shadow:none;font-size:13px;min-width:auto;max-width:none}.mapboxgl-popup-close-button{display:none}.mapboxgl-popup-tip{border-top-color:#0a1428b3!important}.typhoon-popup .typhoon-title{font-weight:700;font-size:1.1em;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.1)}.typhoon-popup .typhoon-info-item{margin:4px 0;display:flex;align-items:flex-start;line-height:1.5}.typhoon-popup .typhoon-info-label{font-weight:600;margin-right:8px;min-width:80px;color:#333}.typhoon-popup .typhoon-info-value{color:#666;word-break:break-word;flex:1}@media (max-width: 768px){.typhoon-loading-content{padding:30px 40px}.typhoon-loading-spinner{width:50px;height:50px}.typhoon-loading-content p{font-size:1rem}.typhoon-time-display{top:15px;right:90px;padding:6px 12px}.time-label{font-size:.8rem}.time-value{font-size:.85rem}}@media (prefers-color-scheme: dark){.typhoon-time-display{background:#00a8ff26;border-color:#00a8ff66}.typhoon-time-display:hover{background:#00a8ff40;border-color:#00a8ff99}.typhoon-popup.mapboxgl-popup-content{background:#fffffffa;color:#000}}@media print{.typhoon-loading-overlay,.typhoon-time-display{display:none}}.typhoon-marker:focus{outline:2px solid #00a8ff;outline-offset:2px}.typhoon-marker[aria-label]:hover:after{content:attr(aria-label);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:4px 8px;border-radius:4px;font-size:.8rem;white-space:nowrap;margin-bottom:4px;z-index:1000}.radar-controls{position:absolute;top:70px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;background:#07192ed9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;border:1px solid rgba(66,148,234,.3);box-shadow:0 4px 16px #0000004d;z-index:100}.radar-timestamp{font-size:14px;font-weight:600;color:#fff;min-width:50px;text-align:center}.radar-buttons{display:flex;gap:4px}.radar-buttons button{width:32px;height:32px;border:1px solid rgba(66,148,234,.5);border-radius:6px;background:#07192ecc;color:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.radar-buttons button:hover{background:#4294ea4d;border-color:#4294eacc}.radar-buttons button.loading{opacity:.6;cursor:wait}.radar-buttons button#radar-playBtn{width:36px;font-size:16px}.mapboxgl-popup.radar-popup{border-radius:12px;padding:0}.mapboxgl-popup.radar-popup .mapboxgl-popup-content{background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:0}.mapboxgl-popup.radar-popup .mapboxgl-popup-tip,.mapboxgl-popup.radar-popup .mapboxgl-popup-close-button{display:none}.radar-popup-content{color:#fff}.radar-popup-content .custom-close-btn{position:absolute;top:-20px;right:-12px;width:24px;height:24px;border:2px solid;background:#000000d9;color:#fff;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:auto;box-shadow:0 2px 8px #0000004d}.radar-popup-content .lng-lat-display{color:#ffffffb3;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.15);font-size:12px}.radar-popup-content .coord-display{display:inline-block}.radar-legend-wrapper{position:absolute;bottom:220px;right:12px;z-index:100}.radar-legend-btn{display:flex;align-items:center;justify-content:center;padding:4px 8px;background:#07192ee6;border:1px solid rgba(66,148,234,.4);border-radius:10px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000004d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);min-width:44px;height:28px}.radar-legend-btn:hover{background:#4294ea4d}.radar-legend-btn-text{font-size:12px;color:#ffffffe6;font-weight:500}.radar-legend-container{background:#07192ef2;border-radius:12px;padding:12px 16px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(66,148,234,.4);box-shadow:0 4px 16px #0006;animation:radarSlideIn .2s ease}@keyframes radarSlideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.radar-legend-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.radar-legend-title{font-size:13px;font-weight:600;color:#ffffffe6;text-align:center;flex:1}.radar-legend-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:50%;color:#ffffffb3;font-size:12px;cursor:pointer;transition:all .2s ease}.radar-legend-close:hover{background:#fff3;color:#fff}.radar-legend-items{display:flex;flex-direction:column;gap:6px}.radar-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#ffffffe6}.radar-legend-color{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}@media (min-width: 769px){.radar-legend-btn{background:#07192ee6;border:1px solid rgba(66,148,234,.4);min-width:48px;height:26px}.radar-legend-btn:hover{background:#4294ea4d}.radar-legend-btn-text{color:#ffffffe6}.radar-legend-container{background:#07192ef2;border:1px solid rgba(66,148,234,.4)}.radar-legend-title{color:#ffffffe6}.radar-legend-close{background:#ffffff1a;color:#ffffffb3}.radar-legend-close:hover{background:#fff3;color:#fff}.radar-legend-item{color:#ffffffe6}}.satellite-controls{position:absolute;bottom:130px;right:20px;display:flex;align-items:center;gap:10px;background:#07192ee6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 14px;border-radius:20px;border:1px solid rgba(66,148,234,.3);box-shadow:0 4px 16px #0000004d;z-index:1000}.satellite-timestamp{color:#fff;font-size:14px;font-weight:500;min-width:50px;text-align:center}.satellite-buttons{display:flex;align-items:center;gap:6px}.satellite-buttons button{width:28px;height:28px;border:none;border-radius:50%;background:#4294eacc;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.satellite-buttons button:hover{background:#4294ea;transform:scale(1.1)}.satellite-buttons button:active{transform:scale(.95)}.satellite-hour-selector{position:absolute;bottom:90px;right:20px;display:flex;gap:6px;background:#07192ee6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6px 10px;border-radius:16px;border:1px solid rgba(66,148,234,.3);box-shadow:0 4px 16px #0000004d;z-index:1000}.hour-btn{padding:4px 10px;border:none;border-radius:12px;background:transparent;color:#ffffffb3;font-size:12px;cursor:pointer;transition:all .2s ease}.hour-btn:hover{background:#4294ea4d;color:#fff}.hour-btn.active{background:#4294eae6;color:#fff;font-weight:500}.satellite-timeline{position:absolute;bottom:30px;left:50%;transform:translate(-50%);display:flex;gap:4px;background:#07192ee6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 14px;border-radius:12px;border:1px solid rgba(66,148,234,.3);box-shadow:0 4px 16px #0000004d;z-index:1000;max-width:calc(100vw - 445px);overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth}.satellite-timeline::-webkit-scrollbar{height:6px}.satellite-timeline::-webkit-scrollbar-track{background:#0000004d;border-radius:3px}.satellite-timeline::-webkit-scrollbar-thumb{background:#4294ea99;border-radius:3px}.satellite-timeline::-webkit-scrollbar-thumb:hover{background:#4294eae6}.satellite-timeline{scrollbar-width:thin;scrollbar-color:rgba(66,148,234,.6) rgba(0,0,0,.3)}.timeline-block{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:6px 10px;background:#ffffff1a;border-radius:6px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.timeline-block:hover{background:#4294ea66;border-color:#4294ea80}.timeline-block.active{background:#4294eae6;border-color:#4294ea}.block-time{color:#ffffffe6;font-size:11px;white-space:nowrap}.timeline-block.active .block-time{color:#fff;font-weight:500}@media (max-width: 768px){.satellite-controls{bottom:220px;right:12px;left:auto;padding:4px 6px;gap:4px;border-radius:16px}.satellite-timestamp{font-size:11px;font-weight:500;color:#ffffffe6;min-width:auto}.satellite-buttons button{width:26px;height:26px;font-size:18px}.satellite-hour-selector{bottom:190px;right:12px;left:auto;justify-content:flex-end;padding:5px 8px;border-radius:12px}.hour-btn{padding:3px 8px;font-size:11px}.satellite-timeline{bottom:145px;left:auto;right:12px;transform:none;max-width:280px;width:auto;padding:8px 10px;border-radius:10px}.timeline-block{padding:5px 8px;border-radius:5px}.block-time{font-size:10px}}.tide-panel-overlay{position:fixed;left:0;top:0;width:100vw;height:100vh;background:#00000080;z-index:9999;animation:fadeIn .3s ease-out}.tide-panel{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:80%;max-width:1200px;max-height:90vh;background:linear-gradient(180deg,#141e30fa,#243b55fa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #00000080;overflow-y:auto;z-index:10000;animation:fadeInScale .3s ease-out}@keyframes fadeInScale{0%{transform:translate(-50%,-50%) scale(.9);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.tide-panel-header{position:relative;display:flex;align-items:center;padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.1);background:#0003;gap:16px}.tide-panel-title{display:flex;align-items:center;gap:12px;margin-right:auto}.tide-panel-title h2{margin:0;font-size:22px;font-weight:600;color:#fff;letter-spacing:.5px}.port-name-en{font-size:15px;color:#fff9;font-weight:400}.tide-status-inline{display:flex;align-items:center;gap:20px;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:24px;font-size:20px;font-weight:700}.status-badge.rising{background:#ff572240;color:#ff8a65}.status-badge.falling{background:#4caf5040;color:#81c784}.current-height-inline{font-size:20px;color:#ffffffe6;font-weight:700}.timezone-label{font-size:14px;color:#fff9;margin-right:12px;white-space:nowrap;padding:6px 12px;background:#ffffff1a;border-radius:6px;border:1px solid rgba(255,255,255,.2)}.tide-close-btn{width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;font-size:28px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.tide-close-btn:hover{background:#fff3;transform:scale(1.1)}.date-selector{display:flex;gap:8px;padding:12px 20px;overflow-x:auto;border-bottom:1px solid rgba(255,255,255,.1)}.date-btn{flex-shrink:0;padding:8px 16px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fffc;font-size:13px;cursor:pointer;border-radius:20px;transition:all .2s;white-space:nowrap}.date-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.date-btn.active{background:linear-gradient(135deg,#4fc3f7,#29b6f6);border-color:transparent;color:#fff;font-weight:600;box-shadow:0 2px 8px #4fc3f766}.tide-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;gap:16px;color:#ffffffb3}.loading-spinner{width:40px;height:40px;border:3px solid rgba(79,195,247,.2);border-top-color:#4fc3f7;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tide-error{padding:40px 24px;text-align:center;color:#ff6b6b;font-size:14px}.tide-table-container,.tide-chart-container{padding:14px 20px}.tide-section-title{margin:0 0 12px;font-size:15px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1px}.tide-table-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.tide-table-row{display:contents}.tide-cell{background:#0003;border-radius:12px;padding:14px 12px;border:1px solid rgba(255,255,255,.1);transition:all .2s;text-align:center}.tide-cell:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0006;border-color:#fff3}.tide-cell.high-tide{border-top:4px solid #FF5722}.tide-cell.low-tide{border-top:4px solid #4CAF50}.tide-cell.empty{opacity:.2}.tide-type{font-size:16px;font-weight:700;color:#fff9;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.tide-cell.high-tide .tide-type{color:#ff8a65}.tide-cell.low-tide .tide-type{color:#81c784}.tide-time{font-size:28px;font-weight:700;color:#fff;margin-bottom:4px;font-family:SF Mono,Consolas,monospace;line-height:1}.tide-height{font-size:22px;font-weight:700;color:#4fc3f7;font-family:SF Mono,Consolas,monospace;line-height:1}.tide-empty{font-size:32px;color:#fff3;padding:10px 0}.tide-chart{background:#0003;border-radius:12px;padding:14px;overflow:hidden;position:relative}.tide-chart svg{cursor:crosshair}.tide-tooltip{position:absolute;pointer-events:none;background:#000000e6;border:1px solid rgba(79,195,247,.5);border-radius:8px;padding:8px 12px;color:#fff;font-size:13px;white-space:nowrap;z-index:10;box-shadow:0 4px 12px #0000004d}.tide-tooltip-time{font-weight:600;color:#4fc3f7;margin-bottom:4px}.tide-tooltip-height{font-family:SF Mono,Consolas,monospace;font-size:15px}.chart-legend{display:flex;justify-content:center;gap:24px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#fffc}.legend-color{width:12px;height:12px;border-radius:50%}.legend-color.high{background:#ff5722}.legend-color.low{background:#4caf50}.legend-color.current{background:gold;border:2px dashed #FFD700}@media (max-width: 768px){.tide-panel{width:100%;height:100vh;max-height:100vh;border-radius:0;transform:none;top:0;left:0;animation:fadeIn .3s ease-out}.tide-panel-header{flex-wrap:wrap;padding:12px 16px;gap:8px}.tide-panel-title{width:100%;margin-bottom:8px}.tide-panel-title h2{font-size:18px}.port-name-en{font-size:13px}.tide-status-inline{position:relative;left:auto;top:auto;transform:none;width:100%;justify-content:center;gap:12px}.status-badge{padding:6px 14px;font-size:16px}.current-height-inline{font-size:16px}.timezone-label{position:absolute;top:12px;right:56px;font-size:12px;padding:4px 8px}.tide-close-btn{position:absolute;top:12px;right:16px;width:36px;height:36px;font-size:24px}.date-selector{padding:12px 16px;gap:6px}.date-btn{padding:6px 12px;font-size:12px}.tide-table-container,.tide-chart-container{padding:16px}.tide-section-title{font-size:14px;margin-bottom:12px}.tide-table-grid{grid-template-columns:repeat(2,1fr);gap:10px}.tide-cell{padding:14px 12px}.tide-type{font-size:12px;margin-bottom:6px}.tide-time{font-size:24px;margin-bottom:4px}.tide-height{font-size:20px}.tide-chart{padding:12px}.tide-tooltip{font-size:12px;padding:6px 10px}.tide-tooltip-height{font-size:13px}.chart-legend{gap:16px;margin-top:12px;padding-top:12px}.legend-item{font-size:11px}.legend-color{width:10px;height:10px}}.tide-panel::-webkit-scrollbar{width:6px}.tide-panel::-webkit-scrollbar-track{background:#ffffff0d}.tide-panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.tide-panel::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.custom-toast-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:10000;pointer-events:auto;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.custom-toast{min-width:320px;max-width:500px;background:#141e32fa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:24px 32px;box-shadow:0 8px 32px #00000080,0 0 0 1px #ffffff1a;display:flex;align-items:center;gap:16px;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.custom-toast.warning{border:2px solid rgba(255,193,7,.5);box-shadow:0 8px 32px #ffc10733,0 0 0 1px #ffc1074d}.custom-toast.error{border:2px solid rgba(244,67,54,.5);box-shadow:0 8px 32px #f4433633,0 0 0 1px #f443364d}.custom-toast.success{border:2px solid rgba(76,175,80,.5);box-shadow:0 8px 32px #4caf5033,0 0 0 1px #4caf504d}.custom-toast.loading{border:2px solid rgba(66,148,234,.5);box-shadow:0 8px 32px #4294ea33,0 0 0 1px #4294ea4d}.toast-icon{font-size:32px;flex-shrink:0;animation:pulse 1.5s ease-in-out infinite;display:flex;align-items:center;justify-content:center}.loading-spinner-small{width:28px;height:28px;border:3px solid rgba(255,255,255,.2);border-top-color:#4294ea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.toast-message{flex:1;color:#fff;font-size:16px;font-weight:500;line-height:1.5;letter-spacing:.3px}.toast-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border:none;background:#ffffff1a;color:#ffffffb3;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.toast-close:hover{background:#fff3;color:#fff;transform:rotate(90deg)}.route-plan-panel{position:fixed;top:60px;right:20px;width:520px;max-height:calc(100vh - 80px);background:#07192ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;border:1px solid rgba(66,148,234,.3);box-shadow:0 8px 32px #0006;z-index:1500;display:flex;flex-direction:column;overflow:hidden}.route-plan-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid rgba(66,148,234,.2);background:#4294ea1a}.route-plan-dragged .route-plan-header{cursor:grab}.route-plan-dragged .route-plan-header:active{cursor:grabbing}.route-plan-header h3{margin:0;font-size:16px;font-weight:600;color:#fff}.close-btn{width:28px;height:28px;border:none;background:#ffffff1a;border-radius:50%;color:#ffffffb3;font-size:20px;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#fff3;color:#fff}.route-plan-content{padding:12px 16px;overflow-y:auto;flex:1}.time-selector{margin-bottom:12px}.time-label,.speed-label{display:block;font-size:13px;font-weight:500;color:#ffffffe6;margin-bottom:6px;letter-spacing:.3px}.time-inputs{display:flex;gap:8px}.time-input-group{flex:1;position:relative}.time-select{width:100%;height:32px;padding:0 28px 0 12px;background:#ffffff14;border:1px solid rgba(66,148,234,.3);border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;outline:none;transition:all .25s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234294EA' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:12px}.time-select:hover{background-color:#ffffff1f;border-color:#4294ea80;box-shadow:0 2px 8px #4294ea33}.time-select:focus{border-color:#4294ea;box-shadow:0 0 0 3px #4294ea26,0 2px 8px #4294ea40;background-color:#ffffff26}.time-select option{background:#07192efa;color:#fff;padding:8px 12px;font-weight:500}.time-select option:hover{background:#4294ea4d}.speed-input-section{margin-bottom:14px}.speed-controls{display:flex;align-items:center;gap:12px}.speed-input-wrapper{display:flex;align-items:center;gap:6px;flex:0 0 auto}.speed-input{width:60px;height:28px;padding:0 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:13px;outline:none;transition:all .2s ease}.speed-input:hover{border-color:#4294ea80}.speed-input:focus{border-color:#4294ea;box-shadow:0 0 0 2px #4294ea33}.speed-input::placeholder{color:#fff6;font-size:12px}.speed-unit{font-size:13px;color:#ffffffb3;min-width:20px}.action-buttons{display:flex;gap:6px;flex:1}.action-btn{padding:5px 10px;background:#4294ea26;border:1px solid rgba(66,148,234,.3);border-radius:5px;color:#4294ea;font-size:12px;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.action-btn:hover{background:#4294ea40;border-color:#4294ea80}.query-btn{background:linear-gradient(135deg,#ff980040,#ff572240);border:2px solid rgba(255,152,0,.8);color:#ff9800;font-weight:600;box-shadow:0 0 8px #ff98004d;position:relative}.query-btn:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:5px;padding:2px;background:linear-gradient(135deg,#ff9800,#ff5722);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.6}.query-btn:hover,.query-btn.active{background:linear-gradient(135deg,#ff980066,#ff572266);border-color:#ff9800;box-shadow:0 0 16px #ff980099;transform:translateY(-1px)}.new-route-btn{background:#00bcd433;border-color:#00bcd466;color:#00bcd4}.new-route-btn:hover,.new-route-btn.active{background:#00bcd466;border-color:#00bcd4cc;box-shadow:0 0 12px #00bcd480}.edit-route-btn{background:#ff980033;border-color:#ff980066;color:#ff9800}.edit-route-btn:hover,.edit-route-btn.active{background:#ff980066;border-color:#ff9800cc;box-shadow:0 0 12px #ff980080}.import-btn{background:#28a74526;border-color:#28a7454d;color:#28a745}.import-btn:hover{background:#28a74540;border-color:#28a74580}.export-btn{background:#ffc10726;border-color:#ffc1074d;color:#ffc107}.export-btn:hover{background:#ffc10740;border-color:#ffc10780}.clear-btn{background:#00bcd433;border-color:#00bcd466;color:#00bcd4}.clear-btn:hover{background:#00bcd466;border-color:#00bcd4cc;box-shadow:0 0 12px #00bcd480}.route-table-section{margin-top:6px}.route-info{display:flex;gap:20px;padding:10px 12px;background:#4294ea1a;border:1px solid rgba(66,148,234,.2);border-radius:6px;margin-bottom:10px}.info-item{display:flex;align-items:center;gap:6px}.info-label{font-size:13px;color:#ffffffb3;font-weight:500}.info-value{font-size:13px;color:#fff;font-weight:600}.table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.table-header h4{margin:0;font-size:13px;font-weight:500;color:#ffffffe6}.table-actions{display:flex;gap:8px}.format-switch-btn{padding:5px 10px;background:#4caf5033;border:1px solid rgba(76,175,80,.5);border-radius:5px;color:#66bb6a;font-size:12px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.format-switch-btn:hover{background:#4caf5059;border-color:#4caf50b3;color:#81c784;box-shadow:0 2px 8px #4caf504d}.add-point-btn{padding:5px 10px;background:#4294ea33;border:1px solid rgba(66,148,234,.4);border-radius:5px;color:#4294ea;font-size:12px;cursor:pointer;transition:all .2s ease}.add-point-btn:hover{background:#4294ea4d;border-color:#4294ea}.route-table-wrapper{border:1px solid rgba(66,148,234,.2);border-radius:8px;overflow:hidden;background:#0003}.route-table{width:100%;border-collapse:collapse;font-size:12px}.route-table thead{background:#4294ea26}.route-table th{padding:7px 4px;text-align:center;font-weight:500;color:#ffffffe6;border-bottom:1px solid rgba(66,148,234,.2)}.route-table td{padding:6px 4px;text-align:center;color:#ffffffd9;border-bottom:1px solid rgba(255,255,255,.05)}.route-table tbody tr:hover{background:#4294ea1a}.route-table tbody tr:last-child td{border-bottom:none}.td-index{width:40px;font-weight:500;color:#4294ea}.td-name{width:80px}.td-lat,.td-lng{width:90px}.td-lat-deg,.td-lng-deg,.td-lat-min,.td-lng-min{width:60px}.td-speed{width:50px}.td-remaining{width:85px;color:#fff9}.td-action{width:50px}.table-input{width:100%;height:26px;padding:0 5px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;font-size:12px;outline:none;transition:all .2s ease;text-align:center}.td-lat-deg .table-input,.td-lat-min .table-input,.td-lng-deg .table-input,.td-lng-min .table-input,.td-speed .table-input{padding:0 4px;font-size:11px}.table-input:hover{border-color:#4294ea80}.table-input:focus{border-color:#4294ea;background:#ffffff1f}.table-input::placeholder{color:#ffffff4d;font-size:11px}.delete-btn{padding:3px 8px;background:#dc354533;border:1px solid rgba(220,53,69,.4);border-radius:4px;color:#dc3545;font-size:11px;cursor:pointer;transition:all .2s ease}.delete-btn:hover:not(:disabled){background:#dc35454d;border-color:#dc3545}.delete-btn:disabled{opacity:.3;cursor:not-allowed}@media (max-width: 768px){.route-plan-panel{top:50%;left:50%;right:auto;transform:translate(-50%,-50%);width:90%;max-width:500px;max-height:80vh}.time-inputs{flex-wrap:wrap}.time-input-group{min-width:calc(50% - 5px)}.route-table-wrapper{overflow-x:auto}.route-table{min-width:500px}}.route-plan-content::-webkit-scrollbar,.route-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.route-plan-content::-webkit-scrollbar-track,.route-table-wrapper::-webkit-scrollbar-track{background:#00000026;border-radius:4px;margin:4px 0}.route-plan-content::-webkit-scrollbar-thumb,.route-table-wrapper::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#4294ea99,#2d7dd299);border-radius:4px;border:1px solid rgba(66,148,234,.3);transition:all .3s ease}.route-plan-content::-webkit-scrollbar-thumb:hover,.route-table-wrapper::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#4294ead9,#2d7dd2d9);box-shadow:0 0 8px #4294ea66}.route-plan-content::-webkit-scrollbar-thumb:active,.route-table-wrapper::-webkit-scrollbar-thumb:active{background:linear-gradient(180deg,#4294eaf2,#2d7dd2f2)}.route-plan-content::-webkit-scrollbar-corner,.route-table-wrapper::-webkit-scrollbar-corner{background:#0000001a}.route-marker{position:absolute;width:24px;height:24px;background:#4294ea;border:1.5px solid rgba(255,255,255,.5)!important;outline:none!important;border-radius:4px;box-shadow:0 1px 4px #0003;display:flex;align-items:center;justify-content:center;cursor:move;transform:translate(-50%,-50%)}.route-marker:hover{background:#5ba3f0;box-shadow:0 2px 8px #4294ea4d}.route-marker .marker-content{width:100%;height:100%;display:flex;align-items:center;justify-content:center;pointer-events:none;border:none!important;outline:none!important}.route-marker span{color:#fff;font-size:12px;font-weight:600;pointer-events:none;border:none!important;outline:none!important}.route-hover-marker{position:absolute;transform:translate(-50%,-50%);pointer-events:none}.forecast-marker{position:absolute;cursor:pointer;pointer-events:auto}.forecast-marker:hover{z-index:1000}.forecast-popup{background:#07192ef2!important;color:#fff!important;border:2px solid #2196F3!important;border-radius:8px!important;box-shadow:0 4px 16px #0006!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:320px!important;min-width:260px!important}.forecast-popup .mapboxgl-popup-content{width:100%!important;max-width:320px!important;overflow:hidden!important}.forecast-popup strong{color:#2196f3!important;font-weight:600}.forecast-popup .mapboxgl-popup-close-button{color:#fff!important;background:#ffffff1a!important;border-radius:50%!important;width:24px!important;height:24px!important;padding:0!important;line-height:24px!important;text-align:center!important}.forecast-popup .mapboxgl-popup-close-button:hover{background:#fff3!important}.forecast-marker{box-shadow:0 2px 6px #0000004d;transition:width .2s ease,height .2s ease,box-shadow .2s ease}.forecast-marker-hover{width:20px!important;height:20px!important;box-shadow:0 4px 12px #00000080!important}.forecast-marker-active{z-index:1001!important;width:20px!important;height:20px!important;animation:forecast-pulse 1.5s ease-in-out infinite}@keyframes forecast-pulse{0%,to{box-shadow:0 0 #ffffffb3,0 0 8px 2px #fff6}50%{box-shadow:0 0 0 12px #fff0,0 0 16px 4px #fff0}}.custom-select{position:relative;width:100%;-webkit-user-select:none;user-select:none}.custom-select-trigger{width:100%;height:32px;padding:0 28px 0 12px;background:#ffffff14;border:1px solid rgba(66,148,234,.3);border-radius:6px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;outline:none;transition:all .25s ease;display:flex;align-items:center;justify-content:space-between}.custom-select-trigger:hover{background-color:#ffffff1f;border-color:#4294ea80;box-shadow:0 2px 8px #4294ea33}.custom-select-trigger.open{border-color:#4294ea;box-shadow:0 0 0 3px #4294ea26,0 2px 8px #4294ea40;background-color:#ffffff26}.select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-arrow{position:absolute;right:10px;color:#4294ea;transition:transform .25s ease;display:flex;align-items:center}.custom-select-trigger.open .select-arrow{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#07192efa;border:1px solid rgba(66,148,234,.3);border-radius:6px;box-shadow:0 4px 16px #0006;z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.select-options{max-height:200px;overflow-y:auto;padding:4px 0}.select-option{padding:8px 12px;color:#ffffffd9;font-size:13px;cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.select-option:hover{background:#4294ea26;color:#fff;border-left-color:#4294ea}.select-option.selected{background:#4294ea40;color:#fff;font-weight:600;border-left-color:#4294ea}.select-option.selected:hover{background:#4294ea4d}.select-options::-webkit-scrollbar{width:8px}.select-options::-webkit-scrollbar-track{background:#00000026;border-radius:4px;margin:4px 0}.select-options::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#4294ea99,#2d7dd299);border-radius:4px;border:1px solid rgba(66,148,234,.3);transition:all .3s ease}.select-options::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#4294ead9,#2d7dd2d9);box-shadow:0 0 8px #4294ea66}.select-options::-webkit-scrollbar-thumb:active{background:linear-gradient(180deg,#4294eaf2,#2d7dd2f2)}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}button{margin:0;padding:0;border:none;background:none;font-family:inherit;font-size:inherit;line-height:1;cursor:pointer}#root{width:100%;height:100%}.mapboxgl-ctrl-attrib,.mapboxgl-ctrl-logo{display:none!important}.desktop-header{position:absolute;top:26px;left:50%;transform:translate(-50%);display:flex;align-items:center;font-size:22px;font-weight:600;color:#fff;text-align:center;z-index:100;text-shadow:0 2px 8px rgba(0,0,0,.5);pointer-events:none}.desktop-model-time{position:absolute;top:20px;right:380px;display:flex;align-items:center;padding:8px 16px;z-index:100;gap:8px}.desktop-route-plan-btn{position:absolute;top:20px;right:260px;padding:8px 20px;background:linear-gradient(90deg,#03a9f4,#f441a5,#ffeb3b,#03a9f4);background-size:400%;border:none;border-radius:20px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;z-index:150;transition:all .3s ease;white-space:nowrap;overflow:hidden}.desktop-route-plan-btn:before{content:"";position:absolute;left:-5px;right:-5px;top:-5px;bottom:-5px;background:linear-gradient(90deg,#03a9f4,#f441a5,#ffeb3b,#03a9f4);background-size:400%;border-radius:25px;filter:blur(15px);z-index:-1;opacity:0;transition:opacity .3s ease}.desktop-route-plan-btn:after{content:"";position:absolute;top:-50%;left:-60%;width:60%;height:200%;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0) 44%,rgba(255,255,255,.25) 47%,rgba(255,255,255,.5) 50%,rgba(255,255,255,.25) 53%,rgba(255,255,255,0) 56%,transparent 60%);transform:skew(-25deg);pointer-events:none;opacity:0}@keyframes flowLight{to{background-position:-400% 0}}@keyframes mirrorSweep{0%{left:-60%;opacity:0}5%{opacity:1}40%{opacity:1}to{left:160%;opacity:0}}.desktop-route-plan-btn:hover{animation:none;filter:brightness(1.3) saturate(1.2);box-shadow:0 0 20px #ffffff4d,0 0 40px #03a9f433}.desktop-route-plan-btn:hover:before{animation:none;opacity:1}.desktop-route-plan-btn:hover:after{animation:mirrorSweep 1.5s ease-in-out infinite}.desktop-route-plan-btn:active{transform:scale(.98)}.desktop-model-time-label{font-size:14px;color:#ffffffb3;white-space:nowrap}.desktop-model-time-value{font-size:16px;color:#fff;font-weight:500;white-space:nowrap}.desktop-mode-switch{position:absolute;top:20px;right:70px;display:flex;background-color:#0009;border-radius:8px;overflow:hidden;z-index:100;box-shadow:0 2px 8px #0000004d}.mode-btn{padding:10px 20px;border:none;background-color:transparent;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;border-right:1px solid rgba(255,255,255,.1)}.mode-btn:last-child{border-right:none}.mode-btn.active{background-color:#3b82f6e6}.mode-btn:not(.active):hover{background-color:#ffffff1a}.desktop-settings-btn{position:absolute;top:20px;right:20px;padding:10px 12px;display:flex;align-items:center;justify-content:center;background:#0009;border:none;border-radius:8px;cursor:pointer;z-index:100;transition:all .3s ease;box-shadow:0 2px 8px #0000004d}.desktop-settings-btn:hover{background:#3b82f6e6}.desktop-settings-btn:active{transform:scale(.95)}@media (max-width: 768px){.desktop-header,.desktop-model-time,.desktop-mode-switch,.desktop-route-plan-btn,.desktop-settings-btn{display:none!important}}.route-marker{width:30px;height:30px;cursor:pointer}.marker-content{width:30px;height:30px;background:linear-gradient(135deg,#4294ea,#2d7dd2);border:2px solid #fff;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;box-shadow:0 2px 8px #0000004d;transition:all .2s ease}.route-marker:hover .marker-content{transform:scale(1.1);box-shadow:0 4px 12px #4294ea80}.mobile-container{width:750px!important;height:1624px!important;position:relative;overflow:hidden;background:#000}@media (max-width: 768px) and (max-height: 1700px){.mobile-container{width:100vw!important;height:100vh!important}}@media (min-width: 769px){body:has(.mobile-container){display:flex;justify-content:center;align-items:center;min-height:100vh;background:#1a1a2e}}
