body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;width:100%}.App,body,html{overflow:hidden}.App{height:100vh;position:relative;width:100vw}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.globe-container{display:flex;flex:1 1;flex-direction:column;height:auto;overflow:hidden;position:relative;width:100%;z-index:1}.globe-container>*{flex:1 1;width:100%}.cesium-viewer{height:100%!important;width:100%!important}.cesium-widget{backface-visibility:hidden;-webkit-backface-visibility:hidden}.cesium-widget,.cesium-widget canvas{height:100%!important;transform:translateZ(0);-webkit-transform:translateZ(0);width:100%!important}.cesium-widget canvas{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;image-rendering:-webkit-optimize-contrast;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;image-rendering:pixelated;will-change:transform}.loading-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1000}.loading-spinner{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000004d;font-size:16px;padding:20px}.weather-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:calc(100vh - 120px);max-width:320px;min-width:300px;overflow-y:auto;padding:16px;position:absolute;right:20px;top:80px;z-index:100}.layer-switcher{bottom:20px;display:flex;gap:8px;left:20px;position:absolute;z-index:100}.layer-switcher button{background:#ffffffe6;border:none;border-radius:4px;color:#333;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.layer-switcher button:hover{background:#fff;box-shadow:0 2px 8px #00000026}.layer-switcher button.active{background:#1890ff;border:1px solid #1890ffe6;box-shadow:0 0 8px #1890ff80,inset 0 0 8px #1890ff33;color:#fff;transform:translateY(-1px)}.cesium-viewer-cesiumWidgetContainer{height:100%!important;width:100%!important}.cesium-viewer-animationContainer,.cesium-viewer-fullscreenContainer,.cesium-viewer-timelineContainer,.cesium-viewer-toolbar,.cesium-viewer-vrContainer,.cesium-widget-credits{display:none!important}.status-indicators{display:flex;flex-direction:column;gap:8px;left:20px;position:absolute;top:20px;z-index:800}.cloud-style-indicator,.current-model-indicator,.current-time-indicator,.playing-indicator{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;border:1px solid #ffffff1a;border-radius:20px;color:#fff;font-size:12px;font-weight:500;padding:6px 12px;text-align:center}.current-model-indicator{background:#1890ffcc;border-color:#1890ff4d}.current-time-indicator{background:#000c;font-family:Courier New,monospace}.playing-indicator{animation:pulse 1.5s ease-in-out infinite;background:#52c41acc;border-color:#52c41a4d}.cloud-style-indicator{background:#ffa726cc;border-color:#ffa7264d;font-weight:600}@media (max-width:1200px){.status-indicators{left:10px;top:10px}.weather-controls{max-width:300px;min-width:280px;right:10px;top:60px}}@media (max-width:768px){.status-indicators{flex-direction:row;justify-content:space-between;left:10px;position:fixed;right:10px;top:10px}.cloud-style-indicator,.current-model-indicator,.current-time-indicator,.playing-indicator{font-size:10px;padding:4px 8px}.weather-controls{left:10px;max-width:none;min-width:auto;position:fixed;right:10px;top:50px}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.weather-parameter-selector{align-items:flex-end;background:#0000;border-radius:8px;display:flex;flex-direction:column;max-width:180px;min-width:180px;padding:8px;z-index:100}.weather-parameter-list{display:grid;grid-template-columns:1fr;justify-items:flex-end;width:100%}.weather-parameter-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;gap:6px;justify-content:flex-end;padding:2px;text-align:left;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.weather-parameter-item:hover{background:#0000;border-color:#0000}.weather-parameter-item.active{background:#1890ff26;border:1px solid #1890ffb3;box-shadow:0 0 10px #1890ff4d;transform:translateY(-1px)}.weather-parameter-item.active:hover{background:#1890ff33;border:1px solid #1890ffcc;box-shadow:0 0 12px #1890ff66;transform:translateY(-2px)}.weather-parameter-text{background:#00000040;border-radius:4px;color:#fff;font-size:13px;font-weight:500;margin-right:0;padding:2px 6px;transition:all .2s ease}.weather-parameter-item.active .weather-parameter-text{background:#00000073;color:#fff;font-weight:600;text-shadow:0 0 4px #1890ff99}.weather-parameter-icon{flex-shrink:0;font-size:13px;transition:all .2s ease}.weather-parameter-item.active .weather-parameter-icon{filter:drop-shadow(0 0 4px rgba(255,255,255,.6));transform:scale(1.1)}.basemap-selector-list{display:flex;flex-direction:column;gap:4px;width:100%}.map-layer-button{align-items:center;background:#0000;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;gap:4px;justify-content:flex-end;padding:6px 10px;text-align:left;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.map-layer-button:hover{background:#ffffff1a}.map-layer-button.active{background:#1890ff99;border:1px solid #1890ffe6;box-shadow:0 0 8px #1890ff66,inset 0 0 8px #1890ff33;transform:translateY(-1px)}.map-layer-button.active:hover{background:#1890ffb3;border:1px solid #1890ff;box-shadow:0 0 12px #1890ff99,inset 0 0 10px #1890ff4d;transform:translateY(-2px)}.map-layer-text{background:#0000004d;border-radius:6px;color:#fff;font-size:12px;font-weight:500;margin-right:0;padding:2px;transition:all .2s ease}.map-layer-button.active .map-layer-text{background:#0009;color:#fff;font-weight:600;text-shadow:0 1px 2px #000c}.map-layer-icon{flex-shrink:0;font-size:16px;transition:all .2s ease}.map-layer-button.active .map-layer-icon{filter:drop-shadow(0 0 4px rgba(255,255,255,.6));transform:scale(1.1)}.controls-panel{-ms-overflow-style:none;bottom:120px;display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 40px);overflow-y:auto;position:absolute;right:20px;scrollbar-width:none;z-index:1000}.controls-panel::-webkit-scrollbar{display:none}.left-panel-content{scrollbar-color:#667eea80 #ffffff1a;scrollbar-width:thin}.left-panel-content::-webkit-scrollbar{height:6px;width:6px}.left-panel-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.left-panel-content::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px}.left-panel-content::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#5a6fd8,#6a42a0)}.right-panel-scrollable{scrollbar-color:#667eea80 #ffffff1a;scrollbar-width:thin}.right-panel-scrollable::-webkit-scrollbar{height:6px;width:6px}.right-panel-scrollable::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.right-panel-scrollable::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px}.right-panel-scrollable::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#5a6fd8,#6a42a0)}.railway-layer-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:1fr;justify-items:flex-end;width:100%}.railway-layer-grid .map-layer-button{font-size:11px;padding:2px}@media (max-width:768px){.controls-panel{max-width:calc(100vw - 20px);right:10px;top:10px}.weather-parameter-selector{max-width:120px;min-width:100px}.map-layer-text,.weather-parameter-text{font-size:12px;padding:3px 6px}.map-layer-icon,.weather-parameter-icon{font-size:14px}}@media (max-width:480px){.weather-parameter-selector{max-width:110px;min-width:90px}.map-layer-text,.weather-parameter-text{font-size:11px;padding:2px 5px}.map-layer-icon,.weather-parameter-icon{font-size:12px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.pressure-level-dropdown{animation:fadeIn .2s ease;background-color:#fff;border:1px solid #d0d0d0;border-radius:6px;box-shadow:0 4px 12px #00000026;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.pressure-level-option{align-items:flex-start;background-color:initial;border:none;border-bottom:1px solid #f0f0f0;color:#333;cursor:pointer;display:flex;flex-direction:column;font-size:11px;padding:8px 12px;text-align:left;transition:background-color .15s ease;width:100%}.pressure-level-option:hover{background-color:#f5f5f5}.pressure-level-option.active{background-color:#e6f7ff;color:#1890ff}.pressure-level-option.active:hover{background-color:#e6f7ff}.pressure-level-trigger{align-items:center;background-color:#fff;border:1px solid #d0d0d0;border-radius:4px;cursor:pointer;display:flex;font-size:11px;justify-content:space-between;padding:6px 8px;transition:all .2s ease;width:100%}.pressure-level-trigger:hover{background-color:#f6f8ff;border-color:#1890ff}.pressure-level-trigger-arrow{transition:transform .2s ease}.pressure-level-trigger-arrow.open{transform:rotate(180deg)}@media (max-width:768px){.pressure-level-dropdown{max-height:150px}.pressure-level-option{font-size:10px;padding:6px 10px}.pressure-level-trigger{font-size:10px;padding:5px 6px}}.main-content{display:flex;flex-direction:column;height:100vh;position:relative;transition:width .3s ease,margin-right .3s ease;width:100%}.main-content.with-settings-panel{margin-right:25vw;width:75vw}.settings-toggle-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:none;border-radius:50%;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;position:fixed;right:20px;top:20px;transition:all .3s ease;width:40px;z-index:2100}.main-content.with-settings-panel~.settings-toggle-button{right:calc(25vw + 20px)}.settings-toggle-button:hover{background:#fff;box-shadow:0 6px 20px #0003;transform:scale(1.05)}.settings-toggle-button[data-panel-visible=true]{background:#1890ffe6;color:#fff}.settings-toggle-button[data-panel-visible=true]:hover{background:#1890ff;box-shadow:0 6px 20px #1890ff66;transform:scale(1.05)}.settings-panel{-webkit-backdrop-filter:blur(15px) saturate(120%);backdrop-filter:blur(15px) saturate(120%);background:linear-gradient(135deg,#0d192bf2,#14284beb 25%,#19325fe6 50%,#1e3c73e0 75%,#234687d9);border-left:1px solid #64c8ff66;box-shadow:-4px 0 30px #0096ff33,inset 1px 0 0 #64c8ff1a;color:#e8f4ff;height:100vh;overflow-y:auto;position:fixed;right:0;top:0;transition:right .3s ease;width:25vw;z-index:2000}.settings-panel.visible{right:0}.settings-panel:not(.visible){right:-25vw}.settings-panel-content{height:100%;overflow-y:auto;padding:12px}.map-container{transition:width .3s ease}.settings-panel .ant-collapse-item{background:linear-gradient(145deg,#0f1e3299,#192d4666)!important;border:1px solid #64c8ff4d!important;border-radius:8px!important;box-shadow:0 4px 15px #0096ff1a,inset 0 1px 0 #64c8ff1a!important;margin-bottom:12px!important}.settings-panel .ant-collapse-header{background:linear-gradient(90deg,#142850b3,#1e3c7880)!important;border-bottom:1px solid #64c8ff33!important;border-radius:8px 8px 0 0!important;color:#e8f4ff!important}.settings-panel .ant-collapse-content{background:linear-gradient(180deg,#0a192d4d,#0f1e3733)!important;border-radius:0 0 8px 8px!important}.settings-panel .ant-tabs{color:#e8f4ff}.settings-panel .ant-tabs-tab{background:linear-gradient(145deg,#0f1e3266,#192d464d)!important;border:1px solid #64c8ff33!important;border-radius:6px!important;color:#e8f4ffb3!important;margin-right:4px!important}.settings-panel .ant-tabs-tab:hover{background:linear-gradient(145deg,#192d4699,#23375066)!important;border-color:#64c8ff66!important;box-shadow:0 2px 8px #0096ff33!important;color:#e8f4ffe6!important}.settings-panel .ant-tabs-tab-active{background:linear-gradient(145deg,#1e3c78b3,#28468280)!important;border-color:#64c8ff99!important;box-shadow:0 4px 12px #0096ff4d,inset 0 1px 0 #64c8ff33!important;color:#e8f4ff!important}.settings-panel .ant-tabs-content-holder{background:none!important}.settings-panel .ant-select{color:#e8f4ff}.settings-panel .ant-select-selector{background:linear-gradient(145deg,#0f1e3280,#192d464d)!important;border:1px solid #64c8ff66!important;box-shadow:inset 0 1px 3px #0000004d,0 1px 3px #0096ff1a!important;color:#e8f4ff!important}.settings-panel .ant-select-selector:hover{border-color:#64c8ff99!important;box-shadow:0 0 8px #0096ff4d!important}.settings-panel .ant-select-arrow{color:#64c8ffcc!important}.settings-panel .ant-picker{background:linear-gradient(145deg,#0f1e3280,#192d464d)!important;border:1px solid #64c8ff66!important;box-shadow:inset 0 1px 3px #0000004d,0 1px 3px #0096ff1a!important;color:#e8f4ff!important}.settings-panel .ant-picker:hover{border-color:#64c8ff99!important;box-shadow:0 0 8px #0096ff4d!important}.settings-panel .ant-picker-input>input{background:#0000!important;color:#e8f4ff!important}.settings-panel .ant-picker-suffix{color:#64c8ffcc!important}.settings-panel .ant-card{background:linear-gradient(145deg,#0f1e3299,#192d4666)!important;border:1px solid #64c8ff4d!important;box-shadow:0 4px 15px #0096ff1a!important}.settings-panel .ant-descriptions-item-label{color:#e8f4ffcc!important}.settings-panel .ant-descriptions-item-content{color:#e8f4ff!important}.settings-panel .parameter-group-title{color:#e8f4ff!important;font-weight:600!important;text-shadow:0 1px 3px #0096ff4d!important}.settings-panel .parameter-card{background:linear-gradient(145deg,#0f1e3299,#192d4666)!important;border:1px solid #64c8ff4d!important;box-shadow:0 4px 15px #0096ff1a,inset 0 1px 0 #64c8ff1a!important;transition:all .3s ease!important}.settings-panel .parameter-card:hover{border-color:#64c8ff80!important;box-shadow:0 6px 20px #0096ff33,inset 0 1px 0 #64c8ff33!important;transform:translateY(-2px)!important}.settings-panel .parameter-card.selected{background:linear-gradient(145deg,#1e3c78cc,#28468299)!important;border-color:#64c8ffcc!important;box-shadow:0 8px 25px #0096ff4d,inset 0 2px 0 #64c8ff4d!important}.settings-panel .parameter-card-label{color:#e8f4ff!important;text-shadow:0 1px 2px #00000080!important}.settings-panel .ant-btn-primary{background:linear-gradient(145deg,#1e3c78e6,#285096cc)!important;border:1px solid #64c8ff99!important;box-shadow:0 4px 15px #0096ff33!important;color:#e8f4ff!important;text-shadow:0 1px 2px #0000004d!important}.settings-panel .ant-btn-primary:hover{background:linear-gradient(145deg,#285096,#325aaae6)!important;border-color:#64c8ffcc!important;box-shadow:0 6px 20px #0096ff66!important;transform:translateY(-1px)!important}.settings-panel .ant-btn-primary.ant-btn-loading{background:linear-gradient(145deg,#142850cc,#1e3c78b3)!important}.settings-panel .ant-switch{background:#0f1e32cc!important;border:1px solid #64c8ff4d!important}.settings-panel .ant-switch-checked{background:linear-gradient(90deg,#1e3c78e6,#0096ffcc)!important;border-color:#64c8ff99!important;box-shadow:0 2px 8px #0096ff4d!important}.settings-panel .ant-slider-rail{background:#0f1e3299!important;border:1px solid #64c8ff33!important}.settings-panel .ant-slider-track{background:linear-gradient(90deg,#1e3c78cc,#0096ff99)!important;box-shadow:0 1px 4px #0096ff4d!important}.settings-panel .ant-slider-handle{background:linear-gradient(145deg,#285096,#0096ffe6)!important;border:2px solid #64c8ffcc!important;box-shadow:0 4px 12px #0096ff66!important}.settings-panel .ant-slider-handle:hover{box-shadow:0 6px 16px #0096ff99!important}.settings-panel .ant-tabs-tabpane[data-node-key=weather] *,.settings-panel .ant-tabs-tabpane[data-node-key=weather] div,.settings-panel .ant-tabs-tabpane[data-node-key=weather] span{color:#e8f4ff!important}.settings-panel .ant-tabs-tab-btn{color:#e8f4ffcc!important}.settings-panel .ant-select-selection-item,.settings-panel .ant-tabs-tab-active .ant-tabs-tab-btn{color:#e8f4ff!important}.settings-panel .ant-select-selection-placeholder{color:#e8f4ff99!important}.settings-panel .ant-picker-input input::placeholder{color:#e8f4ff80!important}.settings-panel .ant-avatar,.settings-panel .ant-btn span{color:#e8f4ff!important}.settings-panel .ant-tag{background:linear-gradient(145deg,#1e3c7899,#28468266)!important;border:1px solid #64c8ff66!important;color:#e8f4ff!important}.settings-panel .ant-tabs-tabpane[data-node-key=user] .ant-card-body *,.settings-panel .ant-tabs-tabpane[data-node-key=user] .ant-descriptions-item,.settings-panel .ant-tabs-tabpane[data-node-key=user] .ant-descriptions-item-content,.settings-panel .ant-tabs-tabpane[data-node-key=user] .ant-descriptions-item-label,.settings-panel>.settings-panel-content>.ant-config-provider>.ant-tabs>.ant-tabs-nav *{color:#e8f4ff!important}.settings-panel .ant-collapse-content-box>div{gap:8px!important;grid-template-columns:repeat(2,1fr)!important}@media (max-width:1200px){.main-content.with-settings-panel{margin-right:30vw;width:70vw}.settings-panel{width:30vw}.settings-panel:not(.visible){right:-30vw}.settings-panel .ant-collapse-content-box>div{grid-template-columns:repeat(2,1fr)!important}.main-content.with-settings-panel~.settings-toggle-button{right:calc(30vw + 20px)}}@media (max-width:768px){.main-content.with-settings-panel{margin-right:40vw;width:60vw}.settings-panel{width:40vw}.settings-panel:not(.visible){right:-40vw}.settings-panel .ant-collapse-content-box>div{grid-template-columns:repeat(1,1fr)!important}.main-content.with-settings-panel~.settings-toggle-button{right:calc(40vw + 15px)}.settings-toggle-button{font-size:16px;height:36px;right:15px;top:15px;width:36px}}@media (max-width:480px){.main-content.with-settings-panel{margin-right:100vw;width:0}.settings-panel{width:100vw}.settings-panel:not(.visible){right:-100vw}.settings-panel .ant-collapse-content-box>div{grid-template-columns:repeat(2,1fr)!important}.settings-toggle-button{font-size:14px;height:32px;right:10px;top:10px;width:32px}}.text-white{color:#fff!important}.model-selector-bar{background:#444;border-radius:12px;bottom:36px;gap:4px;height:24px;left:auto;margin:0;min-width:0;padding:0 4px;position:absolute;right:46px;top:auto;transform:none;z-index:1200}.model-pill{background:#444;border-radius:10px;font-size:12px;height:22px;min-width:36px;padding:0 8px}.model-label{font-size:12px;font-weight:600;letter-spacing:.2px;margin-right:1px}.model-resolution{font-size:9px;margin-bottom:0;margin-left:1px}.parameter-group{margin-bottom:16px}.parameter-group-title{font-size:12px;font-weight:600;letter-spacing:.3px;margin-bottom:6px}.parameter-card-grid{grid-gap:8px 12px;grid-row-gap:12px;display:grid;gap:8px 12px;grid-template-columns:repeat(4,1fr);row-gap:12px}@media (max-width:1200px){.parameter-card-grid{gap:8px 12px;grid-template-columns:repeat(4,1fr);row-gap:12px}}@media (max-width:768px){.parameter-card-grid{gap:6px 10px;grid-template-columns:repeat(2,1fr);row-gap:10px}}.parameter-card{align-items:center;background:#222;border:1px solid #0000;border-radius:6px;box-shadow:0 1px 4px #0000001a;color:#fff;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:40px;min-width:40px;overflow:hidden;position:relative;transition:box-shadow .2s,border .2s,transform .15s,background .2s}.parameter-card:hover{border-color:#1890ff;box-shadow:0 4px 16px #1890ff2e;transform:translateY(-2px) scale(1.03)}.parameter-card.selected{background:linear-gradient(135deg,#1890ff 60%,#36cfc9);border-color:#1890ff;box-shadow:0 0 0 1px #1890ff,0 4px 16px #1890ff2e;color:#fff}.parameter-card-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.15));font-size:16px;margin-bottom:2px}.parameter-card-label{font-size:9px;font-weight:500;letter-spacing:.2px;margin-top:2px;text-align:center;text-shadow:0 1px 2px #0000001f}.weather-particle-legend{animation:fadeInUp .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000d9;border:1px solid #fff3;border-radius:8px;bottom:80px;box-shadow:0 4px 12px #0000004d;color:#fff;font-size:12px;max-width:250px;min-width:200px;padding:14px;position:absolute;right:10px;z-index:1000}.weather-particle-legend-title{align-items:center;display:flex;font-weight:700;gap:6px;margin-bottom:10px}.weather-particle-legend-description{font-size:10px;line-height:1.4;margin-bottom:12px;opacity:.9}.weather-particle-color-bar{border:1px solid #ffffff4d;border-radius:3px;height:16px;margin-bottom:10px;position:relative}.weather-particle-color-scale{background-color:#ffffff80;height:100%;position:absolute;top:0;transform:translateX(-50%);width:1px}.weather-particle-values{display:flex;font-size:10px;justify-content:space-between;margin-top:4px;opacity:.8}.weather-particle-size-indicator{align-items:center;display:flex;font-size:10px;gap:4px;margin-bottom:8px;opacity:.7}.particle-size-demo{background-color:#fff;border-radius:50%}.particle-size-small{height:4px;width:4px}.particle-size-large{height:8px;width:8px}.weather-particle-metadata{border-top:1px solid #fff3;font-size:10px;opacity:.7;padding-top:8px}.weather-particle-special-effect{color:#87ceeb;font-size:9px;font-style:italic;margin-top:6px;opacity:.6}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.particle-system-container{-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);will-change:transform}@keyframes precipitationFall{0%{opacity:.8;transform:translateY(-10px)}to{opacity:.3;transform:translateY(10px)}}.precipitation-particle{animation:precipitationFall 2s linear infinite}@keyframes temperaturePulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.temperature-particle-hot{animation:temperaturePulse 3s ease-in-out infinite}@keyframes humidityShimmer{0%,to{opacity:.7}50%{opacity:1}}.humidity-particle-high{animation:humidityShimmer 4s ease-in-out infinite}@keyframes pressureWave{0%,to{opacity:.8;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}.pressure-particle-extreme{animation:pressureWave 5s ease-in-out infinite}.weather-image-layer--enhanced{filter:brightness(1) contrast(1.2)}.inspection-panel-tabs .ant-tabs-tab-btn,.right-panel-tabs .ant-tabs-tab-btn{color:#fff}.inspection-panel-tabs .ant-tabs-tab-active .ant-tabs-tab-btn,.right-panel-tabs .ant-tabs-tab-active .ant-tabs-tab-btn{color:#1677ff}.inspection-panel-tabs .ant-tabs-nav-more,.inspection-panel-tabs .ant-tabs-nav-more .anticon,.inspection-panel-tabs .ant-tabs-nav-more .anticon svg,.inspection-panel-tabs .ant-tabs-nav-more:focus,.inspection-panel-tabs .ant-tabs-nav-more:focus .anticon,.inspection-panel-tabs .ant-tabs-nav-more:focus .anticon svg,.inspection-panel-tabs .ant-tabs-nav-more:hover,.inspection-panel-tabs .ant-tabs-nav-more:hover .anticon,.inspection-panel-tabs .ant-tabs-nav-more:hover .anticon svg,.right-panel-tabs .ant-tabs-nav-more,.right-panel-tabs .ant-tabs-nav-more .anticon,.right-panel-tabs .ant-tabs-nav-more .anticon svg,.right-panel-tabs .ant-tabs-nav-more:focus,.right-panel-tabs .ant-tabs-nav-more:focus .anticon,.right-panel-tabs .ant-tabs-nav-more:focus .anticon svg,.right-panel-tabs .ant-tabs-nav-more:hover,.right-panel-tabs .ant-tabs-nav-more:hover .anticon,.right-panel-tabs .ant-tabs-nav-more:hover .anticon svg{fill:#fff;color:#fff}.ant-modal-header{padding:16px 24px!important}.ant-modal-title{font-size:16px!important;font-weight:600!important}.ant-modal-close{color:#ffffffa6!important}.ant-modal-close:hover{color:#fffffff2!important}.ant-modal-body{padding:20px 24px!important}.ant-modal-body h1,.ant-modal-body h2,.ant-modal-body h3,.ant-modal-body h4{color:#fffffff2!important}.ant-modal-body strong{color:#ffffffe6!important}.ant-modal-body div,.ant-modal-body p,.ant-modal-body span{color:#ffffffd9!important}.ant-input,.ant-select-selector{background-color:#1e325a66!important;border-color:#cbd5e133!important;color:#ffffffd9!important}.ant-input:focus,.ant-select-focused .ant-select-selector{border-color:#1890ff80!important;box-shadow:0 0 0 2px #1890ff1a!important}.ant-input::placeholder{color:#ffffff73!important}.ant-modal-wrap{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.ant-drawer-content,.ant-drawer-header{background-color:#0f172af2!important}.ant-drawer-header{border-bottom:1px solid #cbd5e11a!important}.ant-drawer-title{color:#fffffff2!important}.ant-drawer-body{color:#ffffffd9!important}.ant-drawer-body,.ant-popover-inner{background-color:#0f172af2!important}.ant-popover-inner{border:1px solid #cbd5e133!important}.ant-popover-inner-content{color:#ffffffd9!important}.ant-popover-arrow-content{background-color:#0f172af2!important;border-color:#cbd5e133!important}.ant-tooltip-inner{background-color:#0f172af2!important;color:#ffffffd9!important}.ant-tooltip-arrow-content{border-top-color:#0f172af2!important}.logout-confirm-modal .ant-btn-default,.logout-confirm-modal .ant-btn-default span,.logout-confirm-modal .ant-btn-default:focus,.logout-confirm-modal .ant-btn-default:focus span,.logout-confirm-modal .ant-btn-default:hover,.logout-confirm-modal .ant-btn-default:hover span{color:#0f172ae0!important}.logout-confirm-modal .ant-btn-dangerous,.logout-confirm-modal .ant-btn-dangerous span,.logout-confirm-modal .ant-btn-primary.ant-btn-dangerous,.logout-confirm-modal .ant-btn-primary.ant-btn-dangerous span{color:#fff!important}:host,:root{--ol-background-color:#fff;--ol-accent-background-color:#f5f5f5;--ol-subtle-background-color:#80808040;--ol-partial-background-color:#ffffffbf;--ol-foreground-color:#333;--ol-subtle-foreground-color:#666;--ol-brand-color:#0af}.ol-box{background-color:#ffffffbf;background-color:var(--ol-partial-background-color);border:1.5px solid #fff;border:1.5px solid var(--ol-background-color);border-radius:2px;box-sizing:border-box}.ol-mouse-position{position:absolute;right:8px;top:8px}.ol-scale-line{background:#ffffffbf;background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid #666;border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:#333;color:var(--ol-foreground-color);font-size:10px;margin:1px;text-align:center;transition:all .25s;will-change:contents,width}.ol-scale-bar{bottom:8px;left:8px;position:absolute}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{background-color:#333;background-color:var(--ol-foreground-color);float:right;height:15px;width:1px;z-index:10}.ol-scale-step-text{bottom:-5px;font-size:10px;z-index:11}.ol-scale-step-text,.ol-scale-text{color:#333;color:var(--ol-foreground-color);position:absolute;text-shadow:-1.5px 0 #ffffffbf,0 1.5px #ffffffbf,1.5px 0 #ffffffbf,0 -1.5px #ffffffbf;text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{bottom:25px;font-size:12px;text-align:center}.ol-scale-singlebar{border:1px solid #333;border:1px solid var(--ol-foreground-color);box-sizing:border-box;height:10px;position:relative;z-index:9}.ol-scale-singlebar-even{background-color:#666;background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:#fff;background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-unselectable,.ol-viewport{-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:grabbing}.ol-grab{cursor:move;cursor:grab}.ol-control{background-color:#80808040;background-color:var(--ol-subtle-background-color);border-radius:4px;position:absolute}.ol-zoom{left:.5em;top:.5em}.ol-rotate{right:.5em;top:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;transition:opacity .25s linear,visibility 0s linear .25s;visibility:hidden}.ol-zoom-extent{left:.5em;top:4.643em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{background-color:#fff;background-color:var(--ol-background-color);border:none;border-radius:2px;color:#666;color:var(--ol-subtle-foreground-color);display:block;font-size:inherit;font-weight:700;height:1.375em;line-height:.4em;margin:1px;padding:0;text-align:center;text-decoration:none;width:1.375em}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:focus,.ol-control button:hover{color:#333;color:var(--ol-foreground-color);outline:1px solid #666;outline:1px solid var(--ol-subtle-foreground-color);text-decoration:none}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{align-items:center;bottom:.5em;display:flex;flex-flow:row-reverse;max-width:calc(100% - 1.3em);right:.5em;text-align:right}.ol-attribution a{color:#666;color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{color:#333;color:var(--ol-foreground-color);font-size:12px;margin:0;padding:1px .5em;text-shadow:0 0 2px #fff;text-shadow:0 0 2px var(--ol-background-color)}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:#ffffffbf;background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{border-radius:4px 0 0;bottom:0;right:0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{height:200px;left:.5em;top:4.5em}.ol-zoomslider button{height:10px;position:relative}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{bottom:.5em;left:.5em}.ol-overviewmap.ol-uncollapsible{border-radius:0 4px 0 0;bottom:0;left:0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid #666;border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:#80808040;background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted #666;border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}.inspection-list-panel{background:#142846f2;border-radius:4px;color:#fff;display:flex;flex-direction:column;font-size:14px;height:100%;overflow:hidden}.inspection-list-header{align-items:center;background:#1e3c64cc;border-bottom:1px solid #6496c84d;display:flex;justify-content:space-between;padding:10px 12px}.inspection-list-header .stats{display:flex;flex:1 1;gap:16px}.inspection-list-header .stat-item{align-items:center;background:#32507880;border-radius:4px;display:flex;flex-direction:column;padding:4px 8px}.inspection-list-header .stat-label{color:#c8dcf0cc;font-size:13px;margin-bottom:4px}.inspection-list-header .stat-value{color:#64b5f6;font-size:16px;font-weight:700}.inspection-list-header .stat-item.online .stat-value{color:#4caf50}.inspection-list-header .stat-item.offline .stat-value{color:#f44336}.inspection-list-filters{background:#193250cc;border-bottom:1px solid #6496c833;padding:10px 12px}.inspection-list-filters .filter-row{display:flex;gap:8px;margin-bottom:8px}.inspection-list-filters .filter-row:last-child{margin-bottom:0}.inspection-list-filters .ant-input,.inspection-list-filters .ant-select{background:#28466ecc!important;border-color:#6496c84d!important;color:#fff!important}.inspection-list-filters .ant-select-selector{background:#28466ecc!important;border-color:#6496c84d!important}.inspection-list-filters .ant-select-arrow{color:#c8dcf0b3!important}.inspection-list-filters .ant-select-selector .ant-select-selection-item{color:#fff!important}.inspection-list-filters .ant-select-selection-placeholder{color:#c8dcf099!important}.inspection-list-filters .ant-select-focused .ant-select-selector{background:#28466ecc!important;border-color:#6496c880!important}.inspection-list-filters .ant-select-selector input{color:#fff!important}.inspection-list-filters .ant-select-selector input::placeholder{color:#c8dcf099!important}.ant-select-dropdown.ant-select-dropdown{background:#fff!important;border:1px solid #c896644d!important}.ant-select-dropdown .ant-select-item{color:#000!important}.ant-select-dropdown .ant-select-item-option{background:#0000!important;color:#000!important}.ant-select-dropdown .ant-select-item-option:hover{background:#f5f5f5!important}.ant-select-dropdown .ant-select-item-option-selected{background:#e6f7ff!important;color:#1890ff!important}.ant-select-dropdown .ant-select-item-option-selected:after{color:#1890ff!important}.inspection-list-error{background:#f4433633;border-bottom:1px solid #f4433666;color:#ff9800;font-size:13px;padding:8px 12px}.inspection-list-container{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-x:hidden;overflow-y:auto;padding:8px 0}.inspection-list-loading{align-items:center;color:#c8dcf0b3;display:flex;height:200px;justify-content:center}.inspection-list-loading .ant-spin-spinning{color:#64b5f6}.inspection-list{display:flex;flex:1 1;flex-direction:column;gap:0}.inspection-list-item{background:#1e375a80;border-bottom:1px solid #6496c826;border-radius:4px;cursor:pointer;margin:0 8px 4px;padding:10px 12px;transition:all .2s ease}.inspection-list-item:hover{background:#32507899;box-shadow:0 2px 8px #6496dc33}.inspection-list-item.selected{background:#6496c84d;border-left:3px solid #64b5f6;padding-left:9px}.inspection-item-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px}.inspection-item-avatar{background-position:50%;background-size:cover;border-radius:50%;flex-shrink:0;height:24px;width:24px}.inspection-item-title{align-items:center;display:flex;flex:1 1;gap:6px;min-width:0}.inspection-item-title .inspection-name{color:#64b5f6;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inspection-item-title .inspection-imei{color:#c8dcf099;font-size:13px;white-space:nowrap}.inspection-item-status{align-items:center;display:flex;flex-shrink:0;gap:6px}.inspection-item-status .ant-badge{font-size:13px}.inspection-item-status .ant-tag{font-size:13px;margin:0;padding:2px 6px}.inspection-item-summary{display:flex;flex-wrap:wrap;font-size:13px;gap:12px;margin-bottom:8px}.inspection-item-summary .summary-item{align-items:center;display:flex;gap:4px}.inspection-item-summary .summary-item .label{color:#c8dcf0b3}.inspection-item-summary .summary-item .value{color:#fff;font-weight:500}.inspection-item-summary .summary-item.offline-info .label{color:#f44336cc}.inspection-item-summary .summary-item.offline-info .value{color:#ff9800}.inspection-item-details{background:#3250784d;border-left:2px solid #90caf9;border-radius:4px;font-size:13px;margin-bottom:8px;padding:8px}.inspection-item-details .detail-row{align-items:center;border-bottom:1px solid #6496c826;display:flex;justify-content:space-between;margin-bottom:6px;padding-bottom:6px}.inspection-item-details .detail-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.inspection-item-details .detail-row .label{color:#c8dcf0b3;min-width:70px}.inspection-item-details .detail-row .value{color:#90caf9;flex:1 1;text-align:right;word-break:break-all}.inspection-item-footer{border-top:1px solid #6496c826;display:flex;gap:4px;justify-content:flex-end;padding-top:6px}.inspection-item-footer .ant-btn{color:#64b5f6!important;height:auto;min-width:50px;padding:2px 8px}.inspection-item-footer .ant-btn:hover{background:#6496c833;color:#90caf9!important}.inspection-session-sublist{background:#0f172a9e;border:1px solid #6496c82e;border-radius:8px;margin:8px 0 10px;padding:10px}.inspection-session-sublist-header{align-items:center;color:#cbd5e1;display:flex;font-size:13px;font-weight:600;justify-content:space-between;margin-bottom:8px}.inspection-session-sublist-header-actions{align-items:center;display:flex;gap:6px}.inspection-session-sublist-header-actions .ant-btn{color:#cfe7ff!important;padding-inline:4px}.inspection-session-sublist-empty,.inspection-session-sublist-loading{color:#c8dcf0b8;font-size:13px;padding:10px 0;text-align:center}.inspection-session-sublist-items{display:flex;flex-direction:column;gap:8px}.inspection-session-subitem{background:#1e375a85;border:1px solid #94a3b829;border-radius:6px;display:flex;gap:10px;justify-content:space-between;padding:8px 10px}.inspection-session-subitem-main{flex:1 1;min-width:0}.inspection-session-subitem-title{color:#fff!important;font-weight:600;margin-bottom:6px;word-break:break-all}.inspection-session-subitem-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.inspection-session-subitem-meta .ant-tag{color:#fff!important}.inspection-session-subitem-time{color:#c8dcf0b8;font-size:12px}.inspection-session-subitem-actions{display:flex;flex-direction:column;flex-shrink:0;gap:4px;justify-content:center}.inspection-session-subitem-actions .ant-btn{color:#cfe7ff!important}.inspection-list-container::-webkit-scrollbar,.right-panel-scrollable::-webkit-scrollbar{width:6px}.inspection-list-container::-webkit-scrollbar-track,.right-panel-scrollable::-webkit-scrollbar-track{background:#28466e4d;border-radius:3px}.inspection-list-container::-webkit-scrollbar-thumb,.right-panel-scrollable::-webkit-scrollbar-thumb{background:#6496c866;border-radius:3px;-webkit-transition:all .2s ease;transition:all .2s ease}.inspection-list-container::-webkit-scrollbar-thumb:hover,.right-panel-scrollable::-webkit-scrollbar-thumb:hover{background:#6496c899}.right-panel-scrollable{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto}.weather-report-tabs .ant-tabs-tab-remove{color:#fff!important}.weather-report-tabs .ant-tabs-tab{color:#f1f5f9}.weather-report-tabs .ant-tabs-tab-remove:before{color:#fff}.inspection-item-status .ant-badge-status-text{color:#fff!important;font-size:13px}.inspection-list-loading-more{align-items:center;color:#c8dcf0b3;display:flex;font-size:14px;gap:8px;justify-content:center;padding:12px}.inspection-list-loading-more .ant-spin-spinning{color:#64b5f6}.inspection-list-end{align-items:center;background:#3250784d;border-radius:4px;border-top:1px solid #6496c826;color:#c8dcf099;display:flex;font-size:14px;justify-content:center;margin:8px;padding:12px}@media (max-width:768px){.inspection-list-header .stats{gap:8px}.inspection-list-item{padding:8px 10px}.inspection-item-summary{gap:8px}.inspection-list-filters .filter-row{flex-wrap:wrap}}.ant-modal-content{background-color:#0f172af2!important;border:1px solid #cbd5e133!important}.ant-modal-header{background-color:#0f172af2!important;border-bottom:1px solid #cbd5e11a!important}.ant-modal-title{color:#fffffff2!important;font-weight:600}.ant-modal-close-x{color:#ffffffa6!important}.ant-modal-close-x:hover{color:#fffffff2!important}.ant-modal-body{background-color:#0f172af2!important;color:#ffffffd9!important}.ant-modal h4{color:#fffffff2!important}.ant-modal strong{color:#ffffffe6!important}.ant-modal div{color:#ffffffd9!important}.ant-modal-body>div>div{background-color:#1e325a66!important;border-color:#cbd5e126!important}.ant-modal-body div[style*="padding: 16px"]{background-color:#1e325a4d!important;border-color:#cbd5e126!important}.ant-modal-body>div>div:first-child{background-color:#1890ff1a!important;border-color:#1890ff33!important}.ant-modal-body>div>div:nth-child(2){background-color:#667eea1a!important;border-color:#667eea33!important}.ant-modal-body>div>div:nth-child(3){background-color:#52c41a1a!important;border-color:#52c41a33!important}.ant-modal-body>div>div:nth-child(4){background-color:#ffa7261a!important;border-color:#ffa72633!important}.ant-modal-body>div>div:nth-child(5){background-color:#0d6efd1a!important;border-color:#0d6efd33!important}.ant-modal-body>div>div:nth-child(6){background-color:#d3adf71a!important;border-color:#d3adf733!important}.ant-modal-body>div>div:last-child{border-top-color:#cbd5e11a!important;color:#ffffffa6!important}.ant-modal-mask{background-color:#00000080!important}.ant-modal-body p,.ant-modal-body span{color:#ffffffd9!important}.weather-summary-panel{overflow:hidden;position:relative;transition:all .3s ease}.weather-summary-panel:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-1px)}.weather-summary-panel.loading{opacity:.8}.weather-summary-panel.error{background-color:#ef44440d;border-color:#ef44444d}.weather-summary-panel.no-data{opacity:.6}.weather-summary-panel .metric-card{transition:all .2s ease}.weather-summary-panel .metric-card:hover{background-color:#ffffff26!important;transform:scale(1.02)}.weather-summary-panel .status-excellent{animation:pulse-excellent 2s infinite}.weather-summary-panel .status-severe{animation:pulse-severe 1.5s infinite}@keyframes pulse-excellent{0%,to{box-shadow:0 0 5px #22c55e4d}50%{box-shadow:0 0 15px #22c55e99}}@keyframes pulse-severe{0%,to{box-shadow:0 0 5px #ef444466}50%{box-shadow:0 0 20px #ef4444cc}}@media (max-width:768px){.weather-summary-panel{padding:12px}.weather-summary-panel .metric-grid{gap:6px;grid-template-columns:1fr}}.weather-summary-panel::-webkit-scrollbar{width:4px}.weather-summary-panel::-webkit-scrollbar-track{background:#ffffff1a;border-radius:2px}.weather-summary-panel::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.weather-summary-panel::-webkit-scrollbar-thumb:hover{background:#ffffff80}.weather-forecast-panel .ant-drawer-content-wrapper{box-shadow:0 -4px 12px #0f172acc!important;left:310px!important;right:310px!important;width:auto!important}.weather-forecast-panel .ant-drawer-body{background:#0f172af2;height:100%;overflow:hidden;padding:8px 12px 10px}.weather-forecast-panel .ant-drawer-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:none;color:#fff}.weather-forecast-panel .ant-drawer-close,.weather-forecast-panel .ant-drawer-header .ant-drawer-title{color:#fff}.weather-forecast-panel .ant-drawer-close:hover{background:#ffffff1a;color:#fff}.weather-forecast-panel .ant-card{border:1px solid #e8e8e8;border-radius:6px;box-shadow:0 1px 3px #00000014;transition:all .2s ease}.weather-forecast-panel .ant-card:hover{box-shadow:0 3px 6px #0000001f;transform:translateY(-1px)}.weather-forecast-panel .ant-tabs{height:100%;overflow:hidden}.weather-forecast-panel .ant-tabs-content,.weather-forecast-panel .ant-tabs-tabpane{height:100%}.weather-forecast-panel ::-webkit-scrollbar{height:6px;width:6px}.weather-forecast-panel ::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.weather-forecast-panel ::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px}.weather-forecast-panel ::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#5a6fd8,#6a42a0)}@media (max-width:768px){.weather-forecast-panel{height:30vh!important}.weather-forecast-panel .ant-drawer-body{padding:8px 12px 14px}.weather-forecast-panel .ant-card{min-width:100px!important}}.weather-forecast-panel .ant-spin-container{min-height:100px}.weather-forecast-panel .forecast-card-content{align-items:center;display:flex;flex-direction:column;gap:4px}.weather-forecast-panel .weather-icon{animation:gentle-bounce 2s ease-in-out infinite}@keyframes gentle-bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-3px)}60%{transform:translateY(-1px)}}.weather-forecast-panel .forecast-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);background-clip:text;-webkit-background-clip:text;font-weight:600}.time-interval-select-dropdown{background-color:#fff!important;border-radius:6px!important;box-shadow:0 4px 12px #00000026!important}.time-interval-select-dropdown .ant-select-item{background-color:#fff!important;border-radius:4px!important;color:#333!important;margin:2px 4px!important;padding:8px 12px!important;transition:all .2s ease!important}.time-interval-select-dropdown .ant-select-item:hover{background-color:#f0f9ff!important;color:#1890ff!important}.time-interval-select-dropdown .ant-select-item-option-selected{background-color:#e6f7ff!important;color:#1890ff!important;font-weight:600!important}.ant-select-selector{background-color:#fff!important;border:1px solid #d9d9d9!important;border-radius:4px!important;color:#333!important}.ant-select-selector:hover{border-color:#40a9ff!important}.ant-select-focused .ant-select-selector{border-color:#1890ff!important;box-shadow:0 0 0 2px #1890ff33!important}.ant-select-arrow{color:#666!important}.ant-select-focused .ant-select-arrow{color:#1890ff!important}.satellite-timeline-bar .ant-select .ant-select-selection-item,.weather-forecast-panel .ant-select .ant-select-selection-item{color:#333!important;font-weight:500!important}@media (max-width:768px){.time-interval-select-dropdown{max-width:200px!important}.time-interval-select-dropdown .ant-select-item{font-size:12px!important;padding:6px 8px!important}}@media (prefers-color-scheme:dark){.time-interval-select-dropdown{background-color:#1f1f1f!important;border-color:#434343!important}.time-interval-select-dropdown .ant-select-item{background-color:#1f1f1f!important;color:#e0e0e0!important}.time-interval-select-dropdown .ant-select-item:hover{background-color:#2c2c2c!important;color:#40a9ff!important}.time-interval-select-dropdown .ant-select-item-option-selected{background-color:#003a8c!important;color:#91d5ff!important}}.timeline-control{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#000000d9;border:1px solid #ffffff1a;border-radius:8px;bottom:20px;box-shadow:0 4px 20px #0000004d;color:#fff;left:20px;min-width:300px;padding:12px 20px;position:absolute;right:20px;z-index:1000}.timeline-main-panel{align-items:center;display:flex;flex-wrap:nowrap;gap:20px}.playback-controls{flex-shrink:0}.play-pause-button{align-items:center;background:#ff8c00;border:none;border-radius:50%;box-shadow:0 2px 8px #ff8c004d;display:flex;height:40px;justify-content:center;width:40px}.play-pause-button:hover{background:orange;box-shadow:0 4px 12px #ff8c0066;transform:scale(1.05)}.play-pause-button .anticon{color:#fff;font-size:18px}.timeline-slider-container{flex:1 1;margin:0}.current-time-display{color:#ff8c00;font-size:13px;font-weight:500;margin-bottom:8px}.timeline-slider{margin:0}.timeline-slider .ant-slider-rail{background:#fff3;border-radius:3px;height:6px}.timeline-slider .ant-slider-track{background:#ff8c00;border-radius:3px;height:6px}.timeline-slider .ant-slider-handle{background:#fff;border:3px solid #ff8c00;box-shadow:0 2px 8px #ff8c004d;height:16px;margin-top:-5px;width:16px}.timeline-slider .ant-slider-handle:focus,.timeline-slider .ant-slider-handle:hover{border-color:orange;box-shadow:0 4px 12px #ff8c0066}.timeline-slider .ant-slider-mark-text{color:#fffc;font-size:12px;font-weight:500;transform:translateX(-50%);white-space:nowrap}.timeline-slider .ant-slider-mark-text-active{color:#ff8c00;font-weight:600}.speed-control,.speed-selector{display:none!important}.control-button,.current-time,.quick-jump-button,.quick-time-jumps,.setting-item,.speed-label,.time-range,.timeline-info,.timeline-settings{display:none}@media (max-width:768px){.timeline-control{left:10px;margin-right:0;padding:8px 12px;right:10px}.timeline-main-panel{gap:12px}.play-pause-button{height:36px;width:36px}.current-time-display{font-size:12px}}.ant-tooltip-inner{background:#000000e6;border-radius:4px;color:#fff;font-size:12px}.ant-tooltip-arrow:before{background:#000000e6;border:none}.ant-select-dropdown{background:#000000e6;border:1px solid #fff3;border-radius:4px}.ant-select-item{background:#0000;color:#fff}.ant-select-item:hover{background:#ffffff1a}.ant-select-item-option-selected{background:#1890ff33}.custom-timeline{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background:#0000!important;border-radius:8px;bottom:0;box-shadow:0 2px 8px #00000026;filter:none!important;left:50%;max-width:900px;min-width:400px;padding:0;position:fixed;transform:translateX(-50%);width:100vw;z-index:1000}.timeline-main-panel{background:#393939;border-radius:8px;box-shadow:none}.custom-playback{align-items:center;display:flex;margin-right:4px}.custom-play-btn{align-items:center;background:#222!important;border:none;border-radius:50%!important;box-shadow:0 2px 8px #0000002e;display:flex;font-size:18px!important;height:32px!important;justify-content:center;width:32px!important}.custom-slider-container{flex:1 1;height:40px;margin:0 8px;min-width:200px;overflow:visible;position:relative}.timeline-bubble-row{height:26px;left:0;pointer-events:none;position:absolute;top:-30px;width:100%;z-index:10}.timeline-bubble-wrapper{left:0;pointer-events:none;position:absolute;top:0;transition:left 1s linear;width:80px;z-index:2}.timeline-bubble{background:#fffbe6;border-radius:6px;box-shadow:0 2px 8px #0000002e;color:#333;display:inline-block;font-size:13px;font-weight:500;max-width:120px;min-width:60px;padding:2px 10px;position:relative;text-align:center;white-space:nowrap}.timeline-bubble-arrow{border:7px solid #0000;border-bottom:7px solid #fffbe6;border-top:none;filter:drop-shadow(0 2px 2px rgba(0,0,0,.1));height:0;left:50%;position:absolute;top:100%;transform:translateX(-50%) rotate(180deg);width:0}.timeline-ticks-row{align-items:flex-end;background:#393939;border:1px solid #444;border-radius:6px;box-shadow:0 1px 2px #00000014;display:flex;height:28px;justify-content:space-between;margin-top:0;position:relative;z-index:1}.timeline-tick{border-right:1px solid #555;color:#bbb;cursor:pointer;flex:1 1;font-size:12px;font-weight:400;padding:3px 0 0;position:relative;text-align:center;transition:color .2s;-webkit-user-select:none;user-select:none}.timeline-tick:last-child{border-right:none}.timeline-tick.active{background:#222;border-radius:6px 6px 0 0;box-shadow:0 2px 8px #0000001a;color:#ffb300;font-weight:600}.timeline-tick:hover{background:#444;color:#fff}.speed-control{margin-left:8px}.speed-selector .ant-select-selector{background:#222!important;border:none!important;color:#ffb300!important;font-size:12px!important;font-weight:600;height:24px!important;min-height:24px!important;padding:0 6px!important}.time-interval-selector .ant-select-selector{align-items:center!important;background:#333!important;border:none!important;border-radius:6px!important;box-shadow:0 2px 8px #0000002e!important;color:#fff!important;display:flex!important;font-size:14px!important;height:32px!important;justify-content:center!important;padding:0 8px!important}.time-interval-selector .ant-select-selection-item{align-items:center!important;color:#fff!important;display:flex!important;height:100%!important;line-height:1!important;margin:0!important;padding:0!important;position:relative!important;top:-2px!important}.time-interval-selector *,.time-interval-selector .ant-select-selector *,.time-interval-selector .ant-select-selector .ant-select-selection-item,.time-interval-selector span.ant-select-selection-item{color:#fff!important}.time-interval-selector .ant-select-arrow{color:#fff!important;margin-left:4px!important}.time-interval-selector:hover .ant-select-selector{background:#333!important}.time-interval-dropdown,.time-interval-dropdown *,.time-interval-selector,.time-interval-selector *{animation-duration:0s!important;transition:none!important}.time-interval-dropdown{background:#333!important;min-width:70px!important}.time-interval-dropdown .rc-virtual-list{min-width:50px!important}.time-interval-dropdown .ant-select-item{background:#333!important;color:#fff!important;min-width:50px!important;padding:5px 12px!important}.time-interval-dropdown .ant-select-item:hover{background:#444!important;color:#fff!important}.time-interval-dropdown .ant-select-item-option-selected{background:#1890ff!important;color:#fff!important;font-weight:600!important}.time-interval-dropdown .ant-select-item-option-selected .ant-select-item-option-content{color:#fff!important}.timeline-markers-container{left:0;pointer-events:none;position:absolute;right:0}.timeline-marker{border-radius:50%;cursor:pointer;pointer-events:auto;position:absolute;transition:all .3s cubic-bezier(.4,0,.2,1)}.timeline-marker:hover{box-shadow:0 0 12px #fff9!important;transform:translateX(-50%) scale(1.5)!important;z-index:10!important}.timeline-marker.current{animation:marker-pulse 2s ease-in-out infinite}@keyframes marker-pulse{0%,to{opacity:1;transform:translateX(-50%) scale(1)}50%{opacity:.8;transform:translateX(-50%) scale(1.2)}}.timeline-marker.key-point{background:#fffc!important}.timeline-labels-container{left:0;pointer-events:none;position:absolute;right:0}.timeline-label{font-family:Consolas,Monaco,monospace;pointer-events:none;position:absolute;text-shadow:0 1px 2px #00000080;transition:opacity .3s ease;-webkit-user-select:none;user-select:none}.timeline-label.key-point{color:#ffffffe6!important;font-size:12px!important;font-weight:600!important}.preview-bubble{animation:bubble-appear .2s ease-out;background:#000000e6;border-radius:6px;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:12px;padding:6px 12px;pointer-events:none;position:absolute;white-space:nowrap;z-index:100}@keyframes bubble-appear{0%{opacity:0;transform:translateX(-50%) translateY(-5px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.timeline-hover-tooltip{borderRadius:6px;animation:tooltip-appear .2s ease-out;background:#000000e6;box-shadow:0 2px 8px #0000004d;color:#fff;font-size:12px;padding:6px 12px;pointer-events:none;position:absolute;white-space:nowrap;z-index:100}@keyframes tooltip-appear{0%{opacity:0;transform:translateX(-50%) translateY(-5px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.custom-slider-container.dragging,.custom-slider-container.dragging *{cursor:grabbing!important;-webkit-user-select:none;user-select:none}.custom-slider-container.dragging .timeline-bubble,.custom-slider-container.dragging .timeline-marker{transition:none!important}@media (max-width:768px){.custom-timeline{bottom:0;min-width:320px}.custom-slider-container{height:38px}.timeline-marker{height:8px!important;width:8px!important}.timeline-marker.current{height:12px!important;width:12px!important}.timeline-label{font-size:9px!important}.timeline-label.key-point{font-size:10px!important}.preview-bubble,.timeline-hover-tooltip{font-size:11px;padding:4px 8px}}@media (prefers-contrast:high){.timeline-marker{border-width:2px!important}.timeline-label{text-shadow:0 0 4px #000,0 1px 2px #000}}@media (prefers-reduced-motion:reduce){.preview-bubble,.timeline-hover-tooltip,.timeline-label,.timeline-marker{animation:none!important;transition:none!important}.timeline-marker.current{animation:none!important}}.model-selector{bottom:20px;max-width:280px;min-width:200px;position:absolute;right:20px;z-index:900}.model-selector-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:8px;box-shadow:0 4px 20px #00000026}.model-selector-card .ant-card-body{padding:8px 12px}.model-selector-header{margin-bottom:8px}.model-compact-view{align-items:center;display:flex;justify-content:space-between}.current-model-display{align-items:center;color:#1890ff;display:flex;font-size:13px;font-weight:500}.details-toggle{align-items:center;color:#666;display:flex;font-size:12px;height:20px;justify-content:center;padding:0;width:20px}.details-toggle:hover{background:#1890ff1a;color:#1890ff}.current-model-status{background:#f0f2f5cc;border-radius:6px;margin-bottom:12px;padding:8px 12px}.current-model-status .ant-space{flex-wrap:wrap;justify-content:space-between;width:100%}.model-details-collapse{margin-bottom:12px}.model-details-collapse .ant-collapse-item{background:#fafafa80;border:none;border-radius:6px;margin-bottom:8px}.model-details-collapse .ant-collapse-header{background:#1890ff0d;border-radius:6px 6px 0 0;padding:8px 12px}.model-details-collapse .ant-collapse-content-box{padding:12px}.model-details{display:flex;flex-direction:column;gap:8px}.detail-row{align-items:flex-start;border-bottom:1px solid #0000000f;display:flex;justify-content:space-between;padding:4px 0}.detail-row:last-child{border-bottom:none}.parameters-list{display:flex;flex-wrap:wrap;gap:4px;max-width:180px}.models-comparison{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.comparison-item{background:#fff9;border:1px solid #0000000f;border-radius:4px;padding:8px}.comparison-header{align-items:center;display:flex;gap:6px;margin-bottom:4px}.comparison-details{color:#666;font-size:11px}.quick-model-switches{border-top:1px solid #0000000f;padding-top:12px}.quick-switch-button{border-radius:4px;font-size:11px;height:28px;padding:0 8px;transition:all .2s ease}.quick-switch-button:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.quick-switch-button.ant-btn-primary{background:linear-gradient(135deg,#1890ff,#36cfc9);border:none}.ant-select-dropdown{border:1px solid #00000014;border-radius:8px;box-shadow:0 6px 24px #0000001f}.ant-select-item-group{color:#1890ff;font-size:12px;font-weight:600;padding:8px 12px 4px}.ant-select-item-option{border-radius:4px;margin:2px 8px;padding:8px 12px}.ant-select-item-option:hover{background:#1890ff14}.ant-select-item-option-selected{background:#1890ff26;font-weight:500}.ant-select-item-option-selected .model-name{color:#1890ff}.ant-badge-status-success{background-color:#52c41a}.ant-badge-status-warning{background-color:#faad14}.ant-badge-status-error{background-color:#ff4d4f}@media (max-width:768px){.model-selector{bottom:100px;max-width:200px;right:10px}.models-comparison{grid-template-columns:1fr}.current-model-status .ant-space{align-items:flex-start;flex-direction:column;gap:4px}.quick-model-switches .ant-space{justify-content:flex-start}}.model-selector-card{animation:fadeInLeft .3s ease-out}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.model-selector.loading{opacity:.6;pointer-events:none}.model-selector.loading:after{background:#fffc;border-radius:8px;bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:10}.model-details-collapse .ant-collapse-content{transition:all .3s ease}.model-details-collapse .ant-collapse-item-active .ant-collapse-header{background:#1890ff1a}.model-selector-bar{align-items:center;background:#555;border-radius:24px;box-shadow:0 2px 8px #00000014;gap:8px;justify-content:flex-end;margin:0 260px 12px auto;min-width:320px;width:-webkit-fit-content;width:fit-content}.model-pill,.model-selector-bar{display:flex;flex-direction:row;padding:0}.model-pill{align-items:flex-end;background:#0000;border:none;border-radius:20px;cursor:pointer;height:20px;margin:0;min-width:70px;outline:none;position:relative;transition:background .2s,color .2s}.model-pill.selected{background:linear-gradient(90deg,#e6a100 90%,#e6a100);box-shadow:0 2px 8px #e6a1001f;color:#fff;padding:0 6px}.model-label{color:#fff;font-size:16px;line-height:1;margin-right:0}.model-resolution{color:#ccc;font-size:13px;font-weight:400;line-height:1;margin-bottom:2px;margin-left:2px}.model-pill.selected .model-label{color:#fff}.model-pill.selected .model-resolution{color:#fff;opacity:.8}@media (max-width:600px){.model-selector-bar{gap:4px;min-width:0;padding:2px}.model-pill{height:32px;min-width:48px;padding:0 10px}.model-label{font-size:15px}.model-resolution{font-size:10px}}:-webkit-full-screen .model-selector-bar,:fullscreen .model-selector-bar{bottom:24px!important;left:auto!important;position:fixed!important;right:24px!important;top:auto!important;z-index:9999!important}.model-selector-topbar{border-radius:16px 16px 0 0;box-shadow:0 2px 8px #0000001a;color:#fff;padding-bottom:6px;padding-top:6px}.model-selector-topbar .ant-switch,.model-selector-topbar .model-top-btn,.model-selector-topbar label,.model-selector-topbar span{color:#fff!important}.model-selector-topbar .ant-switch-checked{background:#e6a100!important}.model-top-btn{align-items:center;background:#0000!important;border:none;border-radius:8px;box-shadow:none;color:#fff;display:flex;justify-content:center;outline:none;padding:4px 8px;transition:background .2s}.model-top-btn.selected,.model-top-btn:hover{background:#ffffff1a!important;color:#fff}.model-top-btn svg{fill:#fff;background:none!important}.model-selector-topbar>div{background:#3c3c3ceb;border-radius:12px;box-shadow:0 2px 8px #0000001a;color:#fff;margin-bottom:8px;padding:6px 8px}.model-selector-topbar>div:last-child{margin-bottom:0}
/*# sourceMappingURL=main.5f65d1a4.css.map*/