*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-width:320px;--bg:#0b0e14;--bg-surface:#12161f;--bg-surface-2:#171c27;--bg-input:#1b2230;--bg-hover:#232b3b;--border:#242b39;--border-strong:#303847;--hover:#232b3b;--text:#e6e8ee;--text-soft:#b9bec9;--text-muted:#7c8394;--accent:#5ac8f5;--accent-strong:#7fd8ff;--accent-hover:#86dbff;--accent-soft:#5ac8f524;--accent-ring:#5ac8f559;--danger:#ff6b6b;--warning:#f6c453;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 12px 40px #00000073;--font:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "Cascadia Code", "Fira Code", Consolas, monospace;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}html,body{overscroll-behavior:none;-webkit-tap-highlight-color:transparent;width:100%;height:100%;overflow:hidden}body{height:100dvh}#root{width:100%;height:100%}:where(button,select,input,textarea,[role=button]):focus-visible{outline:2px solid var(--accent-ring);outline-offset:1px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app{width:100%;height:100%}.map-wrapper{width:100%;height:100%;position:relative;overflow:hidden}.map-container{width:100%;height:100%}.hamburger-btn{top:calc(14px + env(safe-area-inset-top,0px));left:calc(14px + env(safe-area-inset-left,0px));z-index:20;-webkit-backdrop-filter:blur(14px)saturate(140%);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:40px;height:40px;box-shadow:var(--shadow-md);background:#12161fc7;flex-direction:column;justify-content:center;align-items:center;gap:5px;transition:background .15s,border-color .15s,transform .15s;display:flex;position:absolute}.hamburger-btn:hover{border-color:var(--border-strong);background:#232b3bd9}.hamburger-btn:active{transform:scale(.97)}.hamburger-btn span{background:var(--text);border-radius:2px;width:18px;height:2px;transition:transform .25s,opacity .25s;display:block}.hamburger-btn.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger-btn.open span:nth-child(2){opacity:0}.hamburger-btn.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.controls{top:calc(14px + env(safe-area-inset-top,0px));left:calc(64px + env(safe-area-inset-left,0px));z-index:15;width:var(--sidebar-width);max-width:calc(100vw - 78px - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px));max-height:calc(100% - 28px - env(safe-area-inset-top,0px));-webkit-backdrop-filter:blur(18px)saturate(140%);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-lg);opacity:1;background:#12161fd1;flex-direction:column;gap:14px;padding:14px;transition:transform .25s,opacity .2s;display:flex;position:absolute;overflow-y:auto;transform:translate(0)}.controls:not(.open){opacity:0;pointer-events:none;transform:translate(-12px)}.status-badge-title{border-right:1px solid var(--border);flex-direction:column-reverse;justify-content:center;align-items:center;gap:0;padding-right:12px;display:flex}.status-badge-brand-row{align-items:center;gap:6px;display:inline-flex}.status-badge-brand{letter-spacing:.01em;color:var(--text);transform-origin:50%;padding:4px 0;font-size:15px;font-weight:700;line-height:1;display:inline-block;transform:translateY(-5px)scaleY(1.2)}.status-badge-stats{flex-direction:column;flex:1;justify-content:center;gap:4px;min-width:0;display:flex}.alpha-badge{z-index:1;letter-spacing:.06em;text-transform:uppercase;color:var(--bg);background:linear-gradient(135deg, var(--accent) 0%, var(--accent-strong) 100%);transform-origin:50%;box-shadow:0 2px 6px var(--accent-ring), inset 0 0 0 1px #ffffff4d;white-space:nowrap;-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:3px;margin-bottom:-5px;padding:1px 6px;font-size:8px;font-weight:700;display:inline-flex;position:relative;transform:translate(20px)rotate(20deg)}.loading-indicator{border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.controls section{flex-direction:column;gap:6px;display:flex}.controls label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:10px;font-weight:600}.controls select,.controls input[type=range]{width:100%}.controls select,.add-layer-level-select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;font-family:var(--font);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%237c8394' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:right 10px center;background-repeat:no-repeat;padding:8px 28px 8px 10px;transition:border-color .12s,background-color .12s}.controls select:hover,.add-layer-level-select:hover{border-color:var(--border-strong)}.controls select:focus,.add-layer-level-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.controls input[type=range]{appearance:none;background:var(--bg-input);cursor:pointer;border-radius:999px;height:4px;margin:8px 0}.controls input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:grab;border-radius:50%;width:14px;height:14px;transition:transform .1s;box-shadow:0 0 0 1px #0006}.controls input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.1)}.controls input[type=range]::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:14px;height:14px}.time-value{font-family:var(--mono);color:var(--accent);margin-left:4px;font-size:12px}.status-badge{top:calc(14px + env(safe-area-inset-top,0px));right:calc(14px + env(safe-area-inset-right,0px));z-index:15;-webkit-backdrop-filter:blur(14px)saturate(140%);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:180px;color:inherit;font:inherit;text-align:left;cursor:pointer;background:#12161fd1;flex-direction:row;align-items:stretch;gap:12px;padding:10px 14px;transition:background .15s,border-color .15s,transform .15s;display:flex;position:absolute}.status-badge:hover,.status-badge:focus-visible{border-color:var(--border-strong);background:#232b3bd9;outline:none}.status-badge:hover .status-badge-info,.status-badge:focus-visible .status-badge-info{color:var(--accent)}.status-badge-row{justify-content:space-between;align-items:baseline;gap:12px;font-size:12px;display:flex}.status-badge-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:9px;font-weight:700}.status-badge-value{font-family:var(--mono);color:var(--text);align-items:center;gap:6px;font-size:12px;font-weight:500;display:inline-flex}.status-badge-info{color:var(--text-muted);flex-shrink:0;transition:color .15s}.attribution-backdrop{z-index:40;-webkit-backdrop-filter:blur(6px);background:#06080db8;justify-content:center;align-items:center;padding:24px;display:flex;position:absolute;inset:0;overflow:auto}.attribution-page{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(640px,100%);max-height:100%;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.attribution-header{background:var(--bg-surface-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.attribution-header h2{color:var(--text);letter-spacing:.01em;margin:0;font-size:15px;font-weight:600}.attribution-body{color:var(--text);flex-direction:column;gap:20px;padding:18px;font-size:13px;line-height:1.5;display:flex;overflow-y:auto}.attribution-body a{color:var(--accent);text-decoration:none}.attribution-body a:hover{text-decoration:underline}.attribution-section h3{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin:0 0 8px;font-size:10px;font-weight:700}.attribution-subheading{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin:12px 0 6px;font-size:10px;font-weight:700}.attribution-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.attribution-empty{color:var(--text-muted);margin:0;font-style:italic}.attribution-model{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface-2);padding:12px 14px}.attribution-model.primary{border-color:var(--accent);background:var(--accent-soft)}.attribution-model-head{justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:4px;display:flex}.attribution-model-name{color:var(--text);font-weight:600}.attribution-model-id{font-family:var(--mono);color:var(--text-muted);font-size:11px}.attribution-model-desc{color:var(--text-soft);margin:4px 0}.attribution-model-meta{color:var(--text-muted);flex-wrap:wrap;gap:14px;font-size:12px;display:flex}.attribution-runs{border-top:1px dashed var(--border);margin-top:10px;padding-top:8px}.attribution-runs-head{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);align-items:center;gap:8px;margin-bottom:6px;font-size:10px;font-weight:700;display:flex}.attribution-runs-count{letter-spacing:0;color:var(--text-muted);background:var(--bg-input);border:1px solid var(--border);text-transform:none;border-radius:999px;padding:1px 8px;font-size:10px;font-weight:600}.attribution-runs-empty{color:var(--text-muted);font-size:12px;font-style:italic}.attribution-runs-list{flex-direction:column;gap:3px;max-height:180px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.attribution-runs-list li{font-family:var(--mono);color:var(--text);align-items:center;gap:8px;font-size:11px;display:flex}.attribution-run-id{white-space:nowrap}.attribution-run-badge{font-family:var(--font,inherit);text-transform:uppercase;letter-spacing:.08em;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:1px 7px;font-size:9px;font-weight:700;line-height:1.4}.attribution-run-size{font-family:var(--mono);color:var(--text-muted);margin-left:auto;font-size:10px}.model-info-page{width:min(720px,100%)}.model-info-stats{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.model-info-stat{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface-2);flex-direction:column;gap:4px;padding:10px 12px;display:flex}.model-info-stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:10px;font-weight:700}.model-info-stat-value{font-family:var(--mono);color:var(--text);font-size:13px}.model-info-forecast-range{font-family:var(--mono);color:var(--text-muted);margin:10px 0 0;font-size:11px}.model-info-sparkline{align-items:flex-end;gap:2px;height:34px;margin-top:12px;display:flex}.model-info-spark-bar{background:var(--accent);opacity:.7;border-radius:1px;flex:1;min-width:3px}.model-info-spark-bar:hover{opacity:1}.model-info-var-group{margin-bottom:10px}.model-info-var-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.model-info-var-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface-2);flex-direction:column;gap:4px;padding:10px 12px;display:flex}.model-info-var-row.unavailable{opacity:.55}.model-info-var-main{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.model-info-var-name{font-family:var(--mono);color:var(--text);font-size:12px;font-weight:600}.model-info-var-units{font-family:var(--mono);color:var(--text-muted);font-size:11px}.model-info-var-tag{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:1px 7px;font-size:9px;font-weight:700;line-height:1.4}.model-info-var-tag.muted{color:var(--text-muted);border-color:var(--border)}.model-info-var-desc{color:var(--text-soft);font-size:12px}.model-info-var-actions{flex-wrap:wrap;gap:6px;margin-top:2px;display:flex}.model-info-display-btn{color:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600;line-height:1.4;text-decoration:none;transition:background .12s,color .12s;display:inline-block}a.model-info-display-btn:hover,button.model-info-display-btn:hover:not(:disabled){background:var(--accent);color:var(--bg);text-decoration:none}.model-info-display-btn:disabled{color:var(--text-muted);border-color:var(--border);cursor:not-allowed}.bottom-stack{z-index:15;flex-direction:column;display:flex;position:absolute;bottom:0;left:0;right:0}.maplibregl-ctrl-bottom-right,.maplibregl-ctrl-bottom-left{z-index:16;bottom:calc(var(--bottom-stack-h,110px) + 8px)!important}.bottom-stack .time-bar{position:static}.time-bar{z-index:15;padding:10px 14px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));padding-left:calc(14px + env(safe-area-inset-left,0px));padding-right:calc(14px + env(safe-area-inset-right,0px));-webkit-backdrop-filter:blur(18px)saturate(140%);border-top:1px solid var(--border);background:#12161fe0;align-items:stretch;gap:10px;display:flex;position:absolute;bottom:0;left:0;right:0}.time-bar-scroll{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;touch-action:pan-x;overscroll-behavior-x:contain;flex:1;gap:14px;min-width:0;padding-bottom:2px;display:flex;overflow:auto hidden}.time-bar-scroll::-webkit-scrollbar{height:4px}.time-bar-scroll::-webkit-scrollbar-track{background:0 0}.time-bar-scroll::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:2px}.time-bar-day{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.time-bar-day+.time-bar-day{border-left:1px solid var(--border);padding-left:14px}.time-bar-day-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:9px;font-weight:700;font-family:var(--font);padding-left:2px}.time-bar-hours{align-items:stretch;gap:2px;display:flex}.time-bar-hour{background:var(--bg-input);border-radius:var(--radius-sm);min-height:34px;color:var(--text-soft);font-family:var(--mono);cursor:pointer;touch-action:manipulation;border:1px solid #0000;padding:6px 4px;font-size:12px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.time-bar-hour.labeled{min-width:28px}.time-bar-hour.tick{border:none;border-left:1px solid var(--border);background:0 0;border-radius:0;width:6px;min-width:6px;padding:6px 0}.time-bar-hour:hover{background:var(--bg-hover);color:var(--text)}.time-bar-hour.tick:hover{border-left-color:var(--accent);background:0 0}.time-bar-hour.active{background:var(--accent);color:var(--bg);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);font-weight:700}.time-bar-hour.tick.active{border-left:2px solid var(--accent);box-shadow:none;background:0 0}.play-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:36px;min-width:36px;height:36px;color:var(--accent);cursor:pointer;justify-content:center;align-self:center;align-items:center;transition:background .15s,border-color .15s,transform .1s;display:flex}.play-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.play-btn:active{transform:scale(.96)}.play-btn.warming-up{animation:1s ease-in-out infinite play-btn-warmup}@keyframes play-btn-warmup{0%,to{border-color:var(--border)}50%{border-color:var(--accent)}}.toggle-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toggle-group{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);gap:2px;padding:2px;display:inline-flex;overflow:hidden}.toggle-btn{color:var(--text-muted);font-size:12px;font-weight:500;font-family:var(--font);border-radius:calc(var(--radius-md) - 3px);cursor:pointer;background:0 0;border:none;padding:6px 12px;line-height:1.2;transition:background .12s,color .12s}.toggle-btn.active{background:var(--accent);color:var(--bg);font-weight:600}.toggle-btn:hover:not(.active){background:var(--bg-hover);color:var(--text)}.map-mode-group{flex-wrap:wrap;display:flex}.toggle-group.map-mode-group{gap:4px;padding:4px}.toggle-group.map-mode-group .toggle-btn{text-align:center;flex:auto;min-width:70px}.controls section>.layer-control+.layer-control{margin-top:8px}.layer-control{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface-2);cursor:default;flex-direction:column;gap:8px;padding:10px 12px;transition:border-color .12s,background .12s,transform .12s;display:flex}.layer-control:hover{border-color:var(--border-strong)}.layer-control.dragging{opacity:.5;border-color:var(--accent);background:var(--accent-soft);transform:scale(.99)}.layer-control>input[type=range]{margin:2px 0}.layer-header{align-items:center;gap:8px;display:flex}.layer-label-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text);flex:1;font-size:13px;font-weight:500;overflow:hidden}.layer-remove-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:16px;line-height:1;transition:color .12s,background .12s,border-color .12s;display:inline-flex}.layer-remove-btn:hover{color:var(--danger);background:#ff6b6b14;border-color:#ff6b6b4d}.layer-legend{margin-top:2px}.layer-legend .colormap-bar{border-radius:3px;width:100%;height:10px}.layer-legend .colormap-labels{margin-top:3px;font-size:10px}.layer-mode-group{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);flex-shrink:0;gap:2px;padding:2px;display:inline-flex}.layer-mode-btn{color:var(--text-muted);letter-spacing:.04em;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 7px;font-size:10px;font-weight:700;line-height:1.4;transition:background .12s,color .12s}.layer-mode-btn.active{background:var(--accent);color:var(--bg)}.layer-mode-btn:hover:not(.active){background:var(--bg-hover);color:var(--text)}.drag-handle{color:var(--text-muted);-webkit-user-select:none;user-select:none;cursor:grab;border-radius:3px;flex-shrink:0;padding:2px;font-size:11px;transition:color .12s,background .12s}.drag-handle:hover{color:var(--text);background:var(--bg-hover)}.layer-control.dragging .drag-handle{cursor:grabbing}.layer-sub-control{grid-template-columns:88px 1fr auto;align-items:center;gap:8px;display:grid}.layer-sub-control input[type=range]{width:100%;margin:0}.layer-sub-control>input[type=number],.layer-sub-control>select{grid-column:2/span 2}.layer-sub-label{letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;font-size:10px;font-weight:600}.layer-sub-input{background:var(--bg-input);width:100%;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:var(--mono);padding:5px 8px}.layer-sub-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.layer-color-input{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;justify-self:end;width:28px;height:22px;padding:0}.checkbox-label{color:var(--text);cursor:pointer;text-transform:none;letter-spacing:normal;flex:1;align-items:center;gap:6px;min-width:0;font-size:13px;font-weight:400;display:inline-flex;overflow:hidden}.checkbox-label input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:14px;height:14px}.text-muted{color:var(--text-muted);font-size:11px;font-weight:400}.colormap-section{gap:6px!important}.colormap-bar-wrapper{flex-direction:column;gap:4px;display:flex}.colormap-bar{border-radius:4px;width:100%;height:14px;display:block}.colormap-labels{font-size:11px;font-family:var(--mono);color:var(--text-muted);justify-content:space-between;display:flex}.meta-info{background:var(--bg-surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;gap:6px!important}.meta-row{font-size:12px;font-family:var(--mono);color:var(--text);justify-content:space-between;gap:10px;display:flex}.meta-label{color:var(--text-muted);font-family:var(--font)}.controls-footer{border-top:1px dashed var(--border);color:var(--text-muted);text-align:center;margin-top:auto;padding-top:10px;font-size:11px}.point-popup{bottom:calc(92px + env(safe-area-inset-bottom,0px));right:calc(24px + env(safe-area-inset-right,0px));width:340px;max-width:calc(100vw - 32px - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px));-webkit-backdrop-filter:blur(16px)saturate(140%);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:10;background:#12161feb;flex-direction:column;display:flex;position:absolute;overflow:hidden}.point-popup-header{background:var(--bg-surface-2);font-size:12px;font-family:var(--mono);color:var(--accent);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1;transition:color .12s}.close-btn:hover{color:var(--text)}.point-popup-body{max-height:60vh;padding:10px 14px 12px;overflow-y:auto}.multi-var-chart{margin-bottom:8px}.multi-var-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-top:1px solid var(--border);padding:6px 0 2px;font-size:10px;font-weight:700}.point-loading,.point-error,.point-chart-empty{text-align:center;color:var(--text-muted);padding:16px;font-size:13px}.point-error{color:var(--danger)}.point-chart{flex-direction:column;gap:6px;display:flex}.point-chart-focus{font-family:var(--mono);justify-content:space-between;align-items:baseline;gap:8px;min-height:16px;font-size:12px;display:flex}.point-chart-focus-time{color:var(--text-muted)}.point-chart-focus-value{color:var(--accent);font-weight:600}.point-chart-svg{touch-action:none;cursor:crosshair;width:100%;height:auto;display:block}.point-chart-axis{stroke:var(--border);stroke-width:1px;fill:none}.point-chart-zero{stroke:var(--border);stroke-width:1px;stroke-dasharray:2 3;fill:none}.point-chart-tick{fill:var(--text-muted);font-family:var(--mono);font-size:9px}.point-chart-line{stroke:var(--accent);stroke-width:1.6px;fill:none;stroke-linejoin:round;stroke-linecap:round}.point-chart-dot{fill:var(--accent);stroke:var(--bg-surface);stroke-width:1px}.point-chart-bar{fill:var(--accent);fill-opacity:.55;transition:fill-opacity .1s}.point-chart-bar.hover{fill-opacity:.8}.point-chart-bar.active{fill-opacity:1}.point-chart-bar.neg{fill:var(--danger)}.point-chart-marker{stroke:var(--accent);stroke-width:1px;stroke-dasharray:3 2;opacity:.7}.point-chart-marker.hover{stroke-dasharray:none;opacity:.9}.point-chart-stats{font-family:var(--mono);color:var(--text-muted);border-top:1px solid var(--border);justify-content:space-between;gap:8px;margin-top:2px;padding-top:4px;font-size:11px;display:flex}.point-chart-stats b{color:var(--text);margin-left:2px;font-weight:600}.flow-canvas-overlay{pointer-events:none;z-index:1;position:absolute;top:0;left:0}.layer-level-select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-family:var(--mono);cursor:pointer;flex:1;padding:5px 8px}.layer-level-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring);outline:none}.maplibregl-ctrl-bottom-right{bottom:calc(68px + env(safe-area-inset-bottom,0px));right:env(safe-area-inset-right,0px)}.maplibregl-ctrl-group{overflow:hidden;-webkit-backdrop-filter:blur(12px)!important;border:1px solid var(--border)!important;border-radius:var(--radius-md)!important;background:#12161fd9!important}.maplibregl-ctrl-group button{filter:invert(.82)}.click-indicator{background:var(--accent-soft);border:2px solid var(--accent);width:18px;height:18px;box-shadow:0 0 0 2px #0006, 0 0 12px var(--accent-ring);pointer-events:none;border-radius:50%;transform:translate(-50%,-50%)}.add-layer-btn{width:100%;color:var(--text-muted);border:1px dashed var(--border-strong);border-radius:var(--radius-md);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;letter-spacing:.02em;background:0 0;padding:10px;transition:background .12s,color .12s,border-color .12s}.add-layer-btn:hover{background:var(--bg-input);color:var(--accent);border-color:var(--accent)}.add-layer-section{border:1px solid var(--accent);border-radius:var(--radius-md);background:var(--bg-surface-2);padding:12px;gap:10px!important}.add-layer-section>label{color:var(--accent)}.add-layer-level-select{font-size:12px}.add-layer-mode-row{flex-direction:column;gap:6px;display:flex}.add-layer-mode-row .toggle-group{flex:none;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:3px;width:100%;padding:4px;display:grid}.add-layer-mode-row .toggle-btn{text-align:center;padding:6px 8px;font-size:11px}.add-layer-row{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.add-layer-confirm-btn{background:var(--accent);color:var(--bg);border-radius:var(--radius-md);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;border:none;padding:7px 16px;transition:background .12s,transform .1s}.add-layer-confirm-btn:hover:not(:disabled){background:var(--accent-hover)}.add-layer-confirm-btn:active:not(:disabled){transform:scale(.98)}.add-layer-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.add-layer-cancel-btn{color:var(--text-soft);border:1px solid var(--border);border-radius:var(--radius-md);font-size:12px;font-family:var(--font);cursor:pointer;background:0 0;padding:6px 14px;transition:background .12s,color .12s,border-color .12s}.add-layer-cancel-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border-strong)}.map-legend{bottom:calc(var(--bottom-stack-h,68px) + 12px + env(safe-area-inset-bottom,0px));left:calc(14px + env(safe-area-inset-left,0px));z-index:10;-webkit-backdrop-filter:blur(14px)saturate(140%);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);background:#12161fd9;max-width:220px;transition:width .2s;position:absolute;overflow:hidden}.map-legend-toggle{width:100%;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:10px;font-weight:700;font-family:var(--font);cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 12px;transition:color .15s;display:flex}.map-legend-toggle:hover{color:var(--text)}.map-legend-chevron{opacity:.7;margin-left:6px;font-size:8px}.map-legend-body{flex-direction:column;gap:10px;padding:0 12px 10px;display:flex}.map-legend-entry{flex-direction:column;gap:3px;display:flex}.map-legend-var{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:10px;font-weight:600;overflow:hidden}.map-legend-bar{border-radius:3px;width:100%;height:10px;display:block}.map-legend-range{font-size:10px;font-family:var(--mono);color:var(--text-muted);justify-content:space-between;align-items:baseline;display:flex}.map-legend-unit{color:var(--text-muted);opacity:.7;font-size:9px}@media (width<=600px){.time-bar{padding:8px 10px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));padding-left:calc(10px + env(safe-area-inset-left,0px));padding-right:calc(10px + env(safe-area-inset-right,0px));gap:8px}.time-bar-scroll{gap:10px}.time-bar-day+.time-bar-day{padding-left:10px}.controls{width:calc(100vw - 78px - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px))}.layer-sub-control{grid-template-columns:72px 1fr auto}.status-badge{z-index:10;min-width:0}}
