.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.model-btn:focus-visible{box-shadow:0 0 0 3px #0066ff4d;outline:none}.day-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px #06f3;outline:none}.spot-row:focus-visible{background:var(--accent-light);outline:none}.settings-btn:focus-visible{box-shadow:0 0 0 3px #0066ff4d;outline:none}:root{--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--bg: #E8ECF4;--panel: rgba(255,255,255,.55);--panel-solid: #FFFFFF;--panel-glass: rgba(255,255,255,.55);--border: rgba(255,255,255,.25);--border-subtle: rgba(0,0,0,.04);--text: #1a1a2e;--text-secondary: #4A5E74;--muted: #64748b;--accent: #0066FF;--accent-hover: #0052CC;--accent-light: rgba(0,102,255,.08);--accent-glow: rgba(0,102,255,.2);--good: #00C48C;--good-bg: rgba(0,196,140,.1);--ok: #FFB020;--ok-bg: rgba(255,176,32,.1);--poor: #FF4D4F;--poor-bg: rgba(255,77,79,.1);--blend: #6366F1;--surface: rgba(0,0,0,.03);--glass-blur: blur(20px) saturate(1.4);--glass-border: rgba(255,255,255,.25);--glass-shadow: 0 8px 32px rgba(0,0,0,.08);--shadow-sm: 0 1px 3px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.06);--shadow-lg: 0 8px 32px rgba(0,0,0,.08);--shadow-xl: 0 16px 48px rgba(0,0,0,.12);--shadow-modal:0 24px 60px rgba(0,0,0,.18);--radius: 16px;--radius-sm: 10px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-numeric:tabular-nums}[data-theme=dark]{--bg: #070E1A;--panel: rgba(13,24,41,.65);--panel-solid: #0D1829;--panel-glass: rgba(13,24,41,.65);--surface: rgba(255,255,255,.06);--border: rgba(255,255,255,.06);--border-subtle: rgba(255,255,255,.03);--text: #E8EDF4;--text-secondary: #94A3B8;--muted: #5A7294;--accent: #00AAFF;--accent-hover: #33BBFF;--accent-light: rgba(0,170,255,.1);--accent-glow: rgba(0,170,255,.2);--good: #00E68A;--good-bg: rgba(0,230,138,.1);--ok: #FBBF24;--ok-bg: rgba(251,191,36,.1);--poor: #F87171;--poor-bg: rgba(248,113,113,.1);--blend: #818CF8;--glass-border: rgba(255,255,255,.06);--glass-shadow: 0 8px 32px rgba(0,0,0,.25);--shadow-sm: 0 1px 3px rgba(0,0,0,.15);--shadow-md: 0 4px 16px rgba(0,0,0,.2);--shadow-lg: 0 8px 32px rgba(0,0,0,.3);--shadow-xl: 0 16px 48px rgba(0,0,0,.4);--shadow-modal:0 24px 60px rgba(0,0,0,.5)}[data-theme=dark] body{background:var(--bg)}[data-theme=dark] .chart-tooltip,[data-theme=dark] .combined-tooltip{background:#0d1829e6;border-color:#ffffff14;color:#e8edf4}[data-theme=dark] .settings-panel{background:var(--bg)}[data-theme=dark] .settings-card,[data-theme=dark] .section,[data-theme=dark] .day-card{background:var(--panel)}[data-theme=dark] .best-window{background:#004e3b80;border-color:#065f46}[data-theme=dark] .best-window-title{color:#6ee7b7}[data-theme=dark] .best-window-detail{color:#a7f3d0}.gust-warning{background:var(--ok-bg);border:1px solid rgba(255,176,32,.3);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;gap:var(--sp-3)}.gust-warning-icon{font-size:18px}.gust-warning-title{font-size:12px;font-weight:700;color:#92400e}.gust-warning-detail{font-size:12px;color:#b45309}[data-theme=dark] .gust-warning{background:#451a0380;border-color:#92400e66}[data-theme=dark] .gust-warning-title{color:#fcd34d}[data-theme=dark] .gust-warning-detail{color:#fde68a}[data-theme=dark] .add-spot-btn{background:var(--accent-light);border-color:var(--accent)}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#0d1829 25%,#162236,#0d1829 75%);background-size:200% 100%}[data-theme=dark] .modal{background:var(--bg)}[data-theme=dark] .error-banner{background:#450a0a80;border-color:#7f1d1d80;color:#fca5a5}[data-theme=dark] .spot-list-input{background:#070e1a;border-color:#ffffff1a;color:#e8edf4}[data-theme=dark] .spot-list-row:hover{background:var(--accent-light)}[data-theme=dark] .model-btn--blend{border-color:transparent;background:transparent}[data-theme=dark] .titlebar-models-wrap{background:#070e1a80}[data-theme=dark] .model-btn:hover{background:var(--accent-light);color:var(--accent)}[data-theme=dark] .model-btn--active{box-shadow:0 2px 8px var(--accent-glow)}[data-theme=dark] .add-spot-btn-header{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}body{background:var(--bg);min-height:100vh;min-height:100dvh}body:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(0,102,255,.08),transparent),radial-gradient(ellipse 60% 50% at 80% 30%,rgba(0,196,140,.06),transparent),radial-gradient(ellipse 70% 40% at 50% 90%,rgba(139,92,246,.05),transparent),var(--bg);animation:auroraShift 25s ease-in-out infinite alternate}[data-theme=dark] body:before{background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(0,170,255,.06),transparent),radial-gradient(ellipse 60% 50% at 80% 30%,rgba(0,230,138,.04),transparent),radial-gradient(ellipse 70% 40% at 50% 90%,rgba(139,92,246,.03),transparent),var(--bg)}@keyframes auroraShift{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(20deg)}}.titlebar{background:var(--panel-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border);-webkit-app-region:drag;user-select:none;flex-shrink:0;padding:0;z-index:100;position:sticky;top:0}.titlebar-traffic-light-spacer{width:8px;flex-shrink:0;display:none}.titlebar-row{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-4);gap:var(--sp-3)}.titlebar-brand{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.titlebar-logo{font-size:18px;line-height:1}.titlebar-logo-img{width:32px;height:32px;object-fit:contain;border-radius:8px}.titlebar-title{font-size:17px;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,#06f,#0af,#00c48c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=dark] .titlebar-title{background:linear-gradient(135deg,#0af,#3bf,#00e68a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.titlebar-models{flex:1;display:flex;align-items:center;justify-content:center;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.titlebar-models::-webkit-scrollbar{display:none}.titlebar-models-wrap{display:inline-flex;align-items:center;gap:3px;background:#00000008;border-radius:var(--radius);padding:3px 4px;border:1px solid var(--border)}[data-theme=dark] .titlebar-models-wrap{background:#ffffff08}.titlebar-actions{display:flex;gap:var(--sp-2);align-items:center;flex-shrink:0}@media(min-width:769px){.titlebar-row{padding:var(--sp-3) var(--sp-6)}.app-shell{max-width:1150px;margin:12px auto;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl);border:1px solid var(--border);height:calc(100vh - 24px)!important}.titlebar{border-radius:var(--radius-xl) var(--radius-xl) 0 0}body{overflow:hidden}}[data-theme=dark] .app-shell{box-shadow:0 8px 40px #00000080}.titlebar-subtitle{font-size:11px;color:var(--muted)}.titlebar-nav{margin-left:auto;display:flex;align-items:center;gap:6px}.titlebar-divider{width:1px;height:16px;background:var(--border);margin:0 4px}.no-drag{-webkit-app-region:no-drag}.settings-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--panel-glass);backdrop-filter:var(--glass-blur);cursor:pointer;font-size:16px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;box-shadow:0 2px 8px #0000000a}[data-theme=dark] .settings-btn{color:var(--text-secondary)}[data-theme=dark] .modal-back{color:var(--accent)}@media(hover:hover){.settings-btn:hover,.model-chip:hover{background:var(--accent-light);color:var(--accent)}}.model-btn{padding:5px 12px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:11px;font-weight:600;letter-spacing:.03em;background:transparent;color:var(--muted);transition:all .2s ease;white-space:nowrap;min-height:30px}.model-btn:hover{background:var(--accent-light);color:var(--accent)}.model-btn--active{background:var(--accent);color:#fff;box-shadow:0 4px 16px var(--accent-glow)}.model-btn--active:hover{background:var(--accent-hover);color:#fff}.model-btn--blend{border:none}.model-btn--blend-active{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 4px 16px var(--accent-glow)}.model-chip-wrap{display:none;position:relative}.model-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;width:36px;height:36px;max-width:36px;max-height:36px;border-radius:50%;border:none;background:var(--panel-glass);backdrop-filter:var(--glass-blur);font-size:9px;font-weight:700;color:var(--muted);cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000000a;gap:0;padding:0;line-height:1;overflow:hidden;flex-shrink:0}.model-chip svg{opacity:.5;margin-top:-2px;width:7px;height:7px}.model-chip-label{letter-spacing:.03em}.model-chip-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:200;background:#ffffffeb;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:4px;box-shadow:0 8px 24px #0000001f;min-width:120px}[data-theme=dark] .model-chip-dropdown{background:#0d1829eb}.model-chip-option{display:block;width:100%;text-align:left;padding:8px 12px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:all .1s}.model-chip-option:hover{background:var(--accent-light);color:var(--accent)}.model-chip-option--active{color:var(--accent);font-weight:700}.model-chip--sm{width:30px;height:30px;font-size:8px}.manage-wrap{position:relative}.manage-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:200;background:#ffffffeb;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:3px;box-shadow:0 8px 24px #0000001f;white-space:nowrap}[data-theme=dark] .manage-dropdown{background:#0d1829eb}.manage-dropdown-item{display:flex;width:100%;align-items:center;gap:7px;padding:7px 10px;border:none;border-radius:6px;background:transparent;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .1s}.manage-dropdown-item svg{color:var(--muted);flex-shrink:0}@media(hover:hover){.manage-dropdown-item:hover{background:var(--accent-light);color:var(--accent)}.manage-dropdown-item:hover svg{color:var(--accent)}.manage-dropdown-item--danger:hover{background:var(--poor-bg);color:var(--poor)}.manage-dropdown-item--danger:hover svg{color:var(--poor)}}.edit-spots-backdrop{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#0000004d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:backdropFadeIn .25s ease-out}.edit-spots-modal{width:92%;max-width:420px;max-height:85dvh;display:flex;flex-direction:column;background:var(--bg);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-modal);overflow:hidden;animation:welcomeIn .5s cubic-bezier(.16,1,.3,1) both}.edit-spots-top{padding:28px 24px 20px;text-align:center;flex-shrink:0}.edit-spots-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--good));display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 4px 16px #06f3;color:#fff}.edit-spots-title{font-size:22px;font-weight:800;color:var(--text);margin-bottom:6px}.edit-spots-subtitle{font-size:14px;color:var(--text-secondary);line-height:1.5}.edit-spots-label{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:0 24px;margin-bottom:8px}.edit-spots-label:after{content:"";flex:1;height:1px;background:var(--glass-border)}.edit-spots-list{flex:1;overflow-y:auto;padding:0 24px;min-height:0}.edit-spot-row{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);transition:opacity .2s}.edit-spot-row:last-child{border-bottom:none}.edit-spot-row--disabled{opacity:.4}.edit-spot-row--dragging{opacity:.5}.edit-spot-row--over-above{box-shadow:inset 0 2px 0 var(--accent)}.edit-spot-row--over-below{box-shadow:inset 0 -2px 0 var(--accent)}.edit-spot-grip{color:var(--text-secondary);opacity:.3;flex-shrink:0;cursor:grab;display:flex;touch-action:none;padding:8px 4px;margin:-8px -4px}.edit-spot-grip:active{cursor:grabbing}.edit-spot-info{flex:1;min-width:0}.edit-spot-name{font-size:15px;font-weight:600;color:var(--text);border:none;background:transparent;outline:none;width:100%;padding:0;margin-bottom:2px;font-family:inherit}.edit-spot-name:focus{border-bottom:1.5px solid var(--accent);padding-bottom:2px}.edit-spot-meta{font-size:12px;color:var(--text-secondary)}.edit-spot-wind{font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--radius-full);flex-shrink:0;white-space:nowrap}.edit-spot-toggle{width:44px;height:26px;border-radius:13px;flex-shrink:0;background:var(--border);position:relative;transition:background .25s;cursor:pointer}.edit-spot-toggle--on{background:var(--accent)}.edit-spot-toggle:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 4px #00000026;transition:transform .25s cubic-bezier(.65,0,.35,1)}.edit-spot-toggle--on:after{transform:translate(18px)}.edit-spots-bottom{padding:16px 24px 24px;flex-shrink:0;border-top:1px solid var(--border);background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3)}.edit-spots-bottom-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.edit-spots-count{font-size:13px;color:var(--text-secondary)}.edit-spots-count b{color:var(--accent)}.edit-spots-remove{background:none;border:none;color:var(--poor);font-size:12px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}@media(hover:hover){.edit-spots-remove:hover{background:#ff4d4f14}}.edit-spots-btn-row{display:flex;gap:10px}.edit-spots-cancel{flex:0 0 auto;padding:14px 20px;border:none;border-radius:var(--radius);background:#0000000a;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}[data-theme=dark] .edit-spots-cancel{background:#ffffff0f}.edit-spots-cta{flex:1;padding:14px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 4px 16px #0066ff40}.edit-spots-cta:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}@media(hover:hover){.edit-spots-cta:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 6px 24px #0066ff59}}.model-segmented{display:flex;align-items:center;background:#0000000a;border-radius:var(--radius-full);padding:3px;margin:0 var(--sp-4) var(--sp-2);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.model-segmented::-webkit-scrollbar{display:none}[data-theme=dark] .model-segmented{background:#ffffff0f}.model-seg{flex:1;min-width:0;padding:6px 10px;border-radius:var(--radius-full);border:none;cursor:pointer;font-size:11px;font-weight:600;background:transparent;color:var(--muted);transition:all .2s ease;white-space:nowrap;letter-spacing:.02em}.model-seg:hover{color:var(--text)}.model-seg--active{background:#ffffffe0;color:var(--accent);box-shadow:0 1px 4px #00000014,0 1px 2px #0000000a}[data-theme=dark] .model-seg--active{background:#ffffff26;color:var(--accent);box-shadow:0 1px 4px #0000004d}.model-seg:active{transform:scale(.95)}.icon-round-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--panel-glass);backdrop-filter:var(--glass-blur);cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;box-shadow:0 2px 8px #0000000a}.icon-round-btn:active{transform:scale(.92)}.icon-round-btn:disabled{opacity:.25;cursor:default}.icon-round-btn--remove{background:transparent;box-shadow:none}@media(hover:hover){.icon-round-btn:hover{background:var(--accent-light);color:var(--accent)}.icon-round-btn--remove:hover{background:var(--poor-bg);color:var(--poor)}.icon-round-btn:disabled:hover{background:var(--panel-glass);color:var(--muted)}}.icon-btn{padding:3px 10px;border-radius:6px;border:1px solid var(--border);cursor:pointer;font-size:11px;font-weight:600;background:transparent;color:var(--muted);transition:all .15s}.icon-btn--active{background:var(--accent-light);color:var(--accent)}.sidebar{width:190px;background:var(--panel-glass);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}.sidebar-label{padding:var(--sp-3) var(--sp-4) var(--sp-2);font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;display:flex;align-items:center}.sidebar-list{flex:1;overflow-y:auto;position:relative}.sidebar-list:not(.sidebar-list--at-bottom):after{content:"";position:sticky;bottom:0;left:0;right:0;display:block;height:32px;pointer-events:none;background:linear-gradient(transparent,#ffffff80)}[data-theme=dark] .sidebar-list:not(.sidebar-list--at-bottom):after{background:linear-gradient(transparent,#070e1a80)}.sidebar-footer{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--border)}.spot-row{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);cursor:pointer;border-left:3px solid transparent;transition:all .15s ease;position:relative;min-height:48px}.spot-row:hover{background:#00000008;transform:translate(3px)}.spot-row--active:hover{background:var(--accent-light);transform:none}.spot-row--active{background:var(--accent-light);border-left-color:var(--accent)}.spot-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0;box-shadow:0 0 0 2px #0000000f}.spot-row-info{flex:1;min-width:0}.spot-row-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spot-row--active .spot-row-name{font-weight:700;color:var(--accent)}.spot-row-meta{font-size:11px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:3px}.spot-remove-btn{display:none;position:absolute;right:8px;background:none;border:none;cursor:pointer;font-size:10px;color:var(--muted);padding:4px 6px;border-radius:var(--radius-sm)}.spot-row:hover .spot-remove-btn{display:block}.spot-remove-btn:hover{background:var(--poor-bg);color:var(--poor)}.sidebar-edit-btn{display:none;padding:var(--sp-2) var(--sp-3);border:none;background:transparent;color:var(--accent);font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:color .15s}.spot-row--editing{background:#00000008;border-radius:var(--radius);border:1px solid var(--border);padding:var(--sp-2) var(--sp-2)!important;gap:4px!important}.add-spot-btn{width:100%;padding:var(--sp-2);border-radius:var(--radius);border:1.5px dashed var(--accent);background:var(--accent-light);color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.add-spot-btn:hover{background:var(--accent);color:#fff;border-style:solid}.add-spot-btn-header{padding:6px 14px;border-radius:var(--radius-full);border:none;background:var(--panel-glass);backdrop-filter:var(--glass-blur);color:var(--accent);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;display:none;align-items:center;gap:4px;box-shadow:0 2px 8px #0000000a}.add-spot-btn-header:hover{background:var(--accent);color:#fff}.highlight-add .add-spot-btn,.highlight-add .add-spot-btn-header,.highlight-add [aria-label="Add spot"]{animation:pulseAdd 1.2s ease-in-out 3}@keyframes pulseAdd{0%,to{box-shadow:0 0 #06f6}50%{box-shadow:0 0 0 10px #06f0}}.forecast-container{padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4)}.forecast-header{display:flex;align-items:baseline;gap:var(--sp-3);flex-wrap:wrap}.forecast-title{font-size:22px;font-weight:800;letter-spacing:-.02em}.forecast-country{font-size:13px;color:var(--muted)}.forecast-hint{margin-left:auto;font-size:12px;color:var(--muted);font-style:italic}.model-tag{font-size:10px;font-weight:700;letter-spacing:.04em;background:var(--accent-light);color:var(--accent);padding:3px 8px;border-radius:var(--radius-full)}.model-tag--blend{background:var(--accent-light);color:var(--accent)}.hero-card{position:relative;width:340px;max-width:100%;padding:6px 22px 28px;background:var(--panel-glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-radius:20px;border:1px solid var(--glass-border);box-shadow:0 4px 24px var(--glass-shadow-color, rgba(0,0,0,.06)),0 1px 2px var(--glass-shadow-color, rgba(0,0,0,.06));overflow:hidden;flex-shrink:0}.hero-card:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;border-radius:20px}.hero-card--poor:before{opacity:.13;background:radial-gradient(ellipse 120% 80% at 80% 90%,var(--poor) 0%,transparent 60%),radial-gradient(ellipse 100% 60% at 20% 100%,#FF8C42 0%,transparent 50%),radial-gradient(ellipse 80% 100% at 60% 80%,#FFB347 0%,transparent 55%),radial-gradient(ellipse 140% 50% at 50% 110%,#FF6B6B 0%,transparent 45%),linear-gradient(180deg,transparent 30%,rgba(255,77,79,.2) 100%)}.hero-card--ok:before{opacity:.1;background:radial-gradient(circle 60px at 50% 60%,transparent 55%,var(--ok) 57%,transparent 59%),radial-gradient(circle 100px at 50% 60%,transparent 55%,var(--ok) 57%,transparent 59%),radial-gradient(circle 140px at 50% 60%,transparent 55%,var(--ok) 57%,transparent 59%),radial-gradient(circle 180px at 50% 60%,transparent 55%,var(--ok) 57%,transparent 59%),radial-gradient(circle 220px at 50% 60%,transparent 55%,var(--ok) 57%,transparent 59%);animation:hero-ripple 3s ease-in-out infinite}@keyframes hero-ripple{0%,to{opacity:.08;transform:scale(1)}50%{opacity:.14;transform:scale(1.04)}}.hero-card--good:before{opacity:.12;background:repeating-linear-gradient(-45deg,transparent,transparent 12px,var(--good) 12px,var(--good) 14px);background-size:200% 200%;animation:hero-stripe-slide 90s linear infinite}@keyframes hero-stripe-slide{0%{background-position:0% 0%}to{background-position:100% 100%}}.hero-card--good:after{content:"";position:absolute;top:18px;right:24px;width:60px;height:80px;pointer-events:none;z-index:0;opacity:.07;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 80'%3E%3Cpath d='M30 0 L58 35 L30 55 L2 35Z' fill='%2300C48C'/%3E%3Cpath d='M30 55 Q32 65 28 80' stroke='%2300C48C' stroke-width='1.5' fill='none'/%3E%3Cpath d='M30 55 Q20 62 15 70' stroke='%2300C48C' stroke-width='1' fill='none' opacity='0.6'/%3E%3Cpath d='M30 55 Q40 62 45 70' stroke='%2300C48C' stroke-width='1' fill='none' opacity='0.6'/%3E%3C/svg%3E") no-repeat center/contain}.hero-hourly-row{display:flex;flex-direction:column;gap:var(--sp-4)}.hero-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;position:relative;z-index:1}.hero-location{font-size:14px;font-weight:600}.hero-updated{font-size:11px;color:var(--muted);margin-top:2px}.hero-model-badge{font-size:11px;font-weight:600;color:var(--muted);background:#0000000a;padding:4px 10px;border-radius:var(--radius-full)}[data-theme=dark] .hero-model-badge{background:#ffffff0f}.hero-top-right{display:flex;align-items:center;gap:6px}.hero-live-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;letter-spacing:.04em;color:#fff;background:#00c48c;padding:3px 10px 3px 8px;border-radius:100px}.hero-live-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:live-pulse 1.8s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.tide-sim-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.03em;color:#92400e;background:#fde68a;padding:2px 8px;border-radius:100px}[data-theme=dark] .tide-sim-badge{color:#fde68a;background:#fde68a26}.hero-body{display:flex;align-items:flex-end;gap:6px;position:relative;z-index:1;margin-top:-10px}.hero-dir{display:flex;flex-direction:column;align-items:center;gap:4px;width:56px;flex-shrink:0}.hero-dir svg{display:block}.hero-dir-label{font-size:13px;font-weight:700;color:var(--muted)}.hero-center{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1}.hero-wind-num{font-size:80px;font-weight:800;letter-spacing:-3px;line-height:1;font-variant-numeric:tabular-nums;min-width:2ch;text-align:center}.hero-wind-unit{font-size:14px;font-weight:600;color:var(--muted);margin-top:2px;text-align:center}.hero-stack{display:flex;flex-direction:column;gap:6px;width:80px;flex-shrink:0}.hero-stack-item{display:flex;justify-content:space-between;font-size:13px;line-height:1.3}.hero-stack-label{font-size:13px;font-weight:500;color:var(--muted)}.hero-stack-value{font-size:13px;font-weight:700;color:var(--text)}.hero-confidence{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:3px 8px;border-radius:var(--radius-full);position:relative;z-index:1}.hero-confidence--high{background:var(--good-bg);color:var(--good)}.hero-confidence--moderate{background:var(--ok-bg);color:var(--ok)}.hero-confidence--low{background:var(--poor-bg);color:var(--poor)}@media(min-width:769px){.hero-hourly-row{flex-direction:row;align-items:stretch;gap:var(--sp-4)}.hero-hourly-row .hero-card{flex:0 0 auto}.hero-hourly-row .hourly-strip{flex:1;min-width:0}}.hourly-strip{padding:16px 20px;background:var(--panel-glass);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.hourly-strip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.hourly-strip-title{font-size:13px;font-weight:600}.hourly-strip-link{font-size:12px;font-weight:500;color:var(--accent);cursor:pointer;background:none;border:none;text-decoration:none}.hourly-bars{display:flex;align-items:flex-end;gap:4px}.hourly-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}.hourly-bar-stack{width:100%;position:relative;display:flex;flex-direction:column;justify-content:flex-end}.hourly-bar{width:100%;border-radius:4px 4px 0 0;min-height:2px;transition:height .3s ease}.hourly-bar--gust{position:absolute;bottom:0;left:0;right:0;border-radius:4px 4px 0 0}.hourly-bar--wind{position:absolute;bottom:0;left:0;right:0;border-radius:4px 4px 0 0;z-index:1}.hourly-bar-label{font-size:9px;color:var(--muted);font-weight:500}.hourly-bar-value{font-size:10px;font-weight:700;color:var(--text)}.day-strip{display:flex;gap:10px;padding:0 var(--sp-5) var(--sp-5);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.day-strip::-webkit-scrollbar{display:none}.day-strip .day-card{flex-shrink:0;width:120px;scroll-snap-align:start}.day-strip-wrap{position:relative}.day-strip-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;width:32px;background:linear-gradient(to right,transparent,var(--bg));pointer-events:none;z-index:2}.day-strip-skeleton{display:flex;gap:10px;padding:0 var(--sp-5);overflow:hidden}.day-card{background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border-radius:var(--radius);border:1px solid var(--glass-border);padding:var(--sp-3) var(--sp-2);text-align:center;cursor:pointer;box-shadow:0 4px 16px #0000000a,inset 0 1px #ffffff1a;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative}.day-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014,inset 0 1px #ffffff26;border-color:#ffffff59}.day-card:active{transform:scale(.98)}.day-card-label{font-size:11px;color:var(--text-secondary);font-weight:700;margin-bottom:1px;text-transform:uppercase;letter-spacing:.04em}.day-card-date{font-size:10px;color:var(--muted);opacity:.8;margin-bottom:6px}.day-card-wind{font-size:22px;font-weight:800;margin-top:4px;line-height:1.1}.day-card-unit{font-size:10px;color:var(--muted);font-weight:500}.day-card-gust{font-size:10px;color:var(--muted);margin-top:4px;font-weight:600}.day-card-spread{font-size:9px;color:var(--blend);margin-top:2px;font-weight:600}.day-card-agreement{font-size:10px;margin-top:1px}.day-card-agreement--high{color:var(--good)}.day-card-agreement--moderate{color:var(--ok)}.day-card-agreement--low{color:var(--poor)}.day-card-hint{font-size:9px;color:var(--muted);margin-top:8px}.day-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.day-card:active{transform:scale(.97)}.day-card-sun{display:flex;gap:6px;justify-content:center;margin-top:5px}.day-card-sun-item{display:flex;align-items:center;gap:2px;font-size:9px;color:var(--muted)}.day-card-sun-icon{width:12px;height:12px;object-fit:contain}.day-card--today{border-color:var(--accent);border-width:1.5px}.day-card--selected{background:var(--accent-light);border-color:var(--accent);box-shadow:0 0 0 2px #0066ff26}.day-card-details{display:flex;gap:10px;justify-content:center;margin-top:6px}.day-card-detail{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:3px}.day-card-dot{width:6px;height:6px;border-radius:50%;display:inline-block}.section-label{padding:0 var(--sp-5);font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.tide-times{display:flex;gap:8px;margin-top:8px;overflow-x:auto}.tide-day{flex:1;text-align:center;min-width:0}.tide-day-label{font-size:10px;color:var(--muted);margin-bottom:2px}.tide-high{font-size:10px;font-weight:600;color:var(--good);line-height:1.4}.tide-low{font-size:10px;color:#92400e;font-weight:500;line-height:1.4}.tide-level{font-weight:400;opacity:.7}.section{background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border-radius:var(--radius-lg);border:1px solid var(--glass-border);padding:var(--sp-4) var(--sp-5);box-shadow:0 4px 16px #0000000a,inset 0 1px #ffffff1a;transition:box-shadow .25s ease}.recharts-legend-wrapper{width:100%!important;left:0!important;right:0!important;text-align:center!important}.recharts-default-legend{display:inline-flex!important;flex-wrap:wrap!important;justify-content:center!important;padding:0!important;margin:0 auto!important}.section-header{display:flex;align-items:baseline;gap:var(--sp-2);margin-bottom:var(--sp-3);flex-wrap:wrap}.section-header-right{margin-left:auto;display:flex;gap:10px;align-items:center}.section-icon{width:18px;height:18px;object-fit:contain;flex-shrink:0;align-self:center}.sun-bar-item{display:inline-flex;align-items:center;gap:3px;font-size:12px;color:var(--muted);font-weight:500}.sun-bar-icon{width:16px;height:16px;object-fit:contain}.section-title{font-size:13px;font-weight:700;color:var(--text)}.section-sub{font-size:11px;color:var(--muted)}.model-comparison{display:flex;gap:12px}.model-card{flex:1;border-radius:var(--radius);padding:12px;background:#00000005;border:1px solid var(--border);text-align:center;cursor:pointer;transition:all .15s}.model-card--active{background:var(--accent-light);border-color:var(--accent)}.model-card--blend{border-color:#6366f133}.model-card--blend-active{background:#6366f114;border-color:var(--blend)}.model-card-name{font-size:11px;font-weight:700;letter-spacing:.05em;color:var(--muted);margin-bottom:6px}.model-card--active .model-card-name{color:var(--accent)}.model-card--blend-active .model-card-name{color:var(--blend)}.model-card-wind{font-size:22px;font-weight:700}.model-card-unit{font-size:10px;color:var(--muted)}.model-card-spread{font-size:10px;color:var(--blend);margin-top:3px}.model-card-bar{margin-top:8px;height:3px;border-radius:2px}.model-strip{margin:0 var(--sp-5) var(--sp-5);padding:var(--sp-4) var(--sp-5);background:var(--panel-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.model-bar-unit{font-size:10px;color:var(--muted);text-align:right;margin-top:4px}.model-bar-row{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.03)}[data-theme=dark] .model-bar-row{border-bottom-color:#ffffff08}.model-bar-row:last-child{border:none}.model-bar-name{font-size:12px;font-weight:600;width:50px;color:var(--muted)}.model-bar-track{flex:1;height:6px;background:#0000000a;border-radius:3px;margin:0 12px;overflow:hidden}[data-theme=dark] .model-bar-track{background:#ffffff0a}.model-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.model-bar-value{font-size:13px;font-weight:700;width:40px;text-align:right}.chart-tooltip{background:var(--panel-glass);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-2) var(--sp-3);font-size:12px;box-shadow:var(--shadow-md)}.chart-tooltip-label{font-weight:700;margin-bottom:4px;color:var(--text)}.anemometer{display:flex;flex-direction:column;align-items:center;gap:4px}.anemometer-wind{font-size:15px;font-weight:700;line-height:1}.anemometer-unit{font-size:10px;font-weight:400;color:var(--muted)}.anemometer-meta{font-size:10px;color:var(--muted)}.skeleton{background:linear-gradient(90deg,#0000000a 25%,#00000012,#0000000a 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.error-banner{background:var(--poor-bg);border:1px solid rgba(255,77,79,.2);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);font-size:12px;color:var(--poor);font-weight:500}.map-placeholder{flex:1;position:relative;background:#00000008;overflow:hidden}.map-pin{position:absolute;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:var(--good);border:3px solid white;box-shadow:0 2px 8px #0003;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:10px;color:#fff;font-weight:700}.map-pin--selected{width:44px;height:44px}.map-pin-name{position:absolute;bottom:110%;left:50%;transform:translate(-50%);background:var(--panel-glass);backdrop-filter:blur(12px);padding:3px 7px;border-radius:5px;border:1px solid var(--border);font-size:11px;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-md)}.modal-backdrop{position:fixed;inset:0;z-index:300;background:#0000004d;backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);display:flex;align-items:center;justify-content:center}.modal{position:relative;width:min(820px,92vw);max-height:88vh;overflow-y:auto;background:var(--bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);padding:44px var(--sp-6) var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-4)}.modal-close-corner{position:absolute;top:8px;right:8px;z-index:10;width:32px;height:32px;border-radius:50%;border:none;background:var(--panel-glass);backdrop-filter:var(--glass-blur);cursor:pointer;font-size:14px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 2px 8px #0000000a}.modal-close-corner:hover{background:var(--accent-light);color:var(--accent)}.modal-header{display:flex;align-items:center;gap:var(--sp-3);flex-shrink:0}.modal-back{width:32px;height:32px;border:none;background:none;cursor:pointer;color:var(--accent);display:flex;align-items:center;justify-content:center;transition:opacity .15s;padding:0}.modal-back:hover{opacity:.7}.modal-title{font-size:22px;font-weight:800;letter-spacing:-.02em}.modal-subtitle{font-size:12px;color:var(--muted)}.section-header-center{flex:1;text-align:center;font-size:13px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-header-center{display:flex;align-items:center;gap:var(--sp-4);flex:1;justify-content:center}.modal-loading{text-align:center;padding:var(--sp-10);color:var(--muted);font-size:13px}.best-window{background:var(--good-bg);border:1px solid rgba(0,196,140,.2);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);display:flex;align-items:center;gap:var(--sp-3)}.best-window-icon{font-size:18px}.best-window-title{font-size:12px;font-weight:700;color:#166534}.best-window-detail{font-size:12px;color:#15803d}.add-spot-modal{width:min(1060px,96vw);height:min(700px,92vh);background:var(--bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;overflow:hidden;position:relative}.add-spot-map-wrap{flex:1;position:relative;overflow:hidden}.tab-switcher{display:flex;gap:var(--sp-1)}.tab-btn{padding:6px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:12px;font-weight:600;background:transparent;color:var(--muted);transition:all .15s}.tab-btn--active{background:var(--accent);color:#fff}.addspot-header{flex-shrink:0;background:var(--bg);border-bottom:1px solid var(--border);position:relative}.addspot-header-row{display:flex;align-items:center;justify-content:center;position:relative;padding:16px 20px 12px}.addspot-header-row .modal-back{position:absolute;left:20px}.addspot-done{position:absolute;right:20px}.addspot-close{width:30px;height:30px;border-radius:50%;border:none;background:#0000000d;color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}[data-theme=dark] .addspot-close{background:#ffffff0f}.addspot-close:hover{background:#0000001a}[data-theme=dark] .addspot-close:hover{background:#ffffff1f}.addspot-center{flex:1;text-align:center}.addspot-title{font-size:17px;font-weight:800;color:var(--text);display:flex;align-items:center;justify-content:center;gap:8px}.addspot-pin-badge{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--good));display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0066ff40;flex-shrink:0}.addspot-pin-badge svg{color:#fff}.addspot-subtitle{font-size:11px;color:var(--text-secondary);margin-top:2px}.addspot-done{padding:7px 16px;border:none;border-radius:var(--radius-full);background:var(--accent);color:#fff;font-size:12px;font-weight:700;cursor:pointer;flex-shrink:0;box-shadow:0 2px 8px #06f3;transition:all .15s}.addspot-done:hover{background:var(--accent-hover)}.addspot-tabs{display:flex;gap:0;padding:0 20px}.addspot-tab{flex:1;padding:10px 0;border:none;background:transparent;font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;position:relative;transition:color .2s;display:flex;align-items:center;justify-content:center;gap:4px}.addspot-tab--active{color:var(--accent)}.addspot-tab--active:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2.5px;background:var(--accent);border-radius:2px}.addspot-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:0 -8px 32px #0000001f;padding:0 24px 28px;z-index:1001;animation:addspotSheetUp .5s cubic-bezier(.16,1,.3,1) .3s both}@keyframes addspotSheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.addspot-sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--border);margin:10px auto 16px}.addspot-sheet-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.addspot-sheet-icon{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--good));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 16px #0066ff40}.addspot-sheet-icon svg{color:#fff}.addspot-sheet-title{font-size:18px;font-weight:800;color:var(--text)}.addspot-sheet-subtitle{font-size:13px;color:var(--text-secondary);margin-top:1px}.addspot-sheet-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:8px}.addspot-sheet-label:after{content:"";flex:1;height:1px;background:var(--glass-border)}.addspot-sheet-cards{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none}.addspot-sheet-cards::-webkit-scrollbar{display:none}.addspot-sheet-card{min-width:120px;padding:14px;background:var(--accent-light);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;flex-shrink:0;transition:all .15s;text-align:left}.addspot-sheet-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.addspot-sheet-card-flag{font-size:22px;margin-bottom:6px}.addspot-sheet-card-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}.addspot-sheet-card-count{font-size:11px;color:var(--text-secondary)}.addspot-sheet-actions{display:flex;gap:8px}.addspot-sheet-locate{flex:1;padding:12px;border:1.5px solid var(--accent);border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}.addspot-sheet-locate:hover{background:var(--accent-light)}.addspot-sheet-explore{padding:12px 20px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s}.addspot-sheet-explore:hover{background:var(--accent-hover)}.map-legend{position:absolute;bottom:16px;left:16px;z-index:1000;background:var(--panel-glass);backdrop-filter:blur(12px);border-radius:var(--radius-sm);padding:6px 10px;display:flex;gap:10px;align-items:center;font-size:10px;color:var(--muted)}.map-legend-item{display:flex;align-items:center;gap:3px}.map-legend-dot{width:7px;height:7px;border-radius:50%;display:inline-block}.map-legend-hint{color:var(--accent);margin-left:4px}.map-popup{padding:4px;min-width:160px}.map-popup-name{font-size:14px;font-weight:700;margin-bottom:2px}.map-popup-meta{font-size:11px;color:var(--muted);margin-bottom:10px}.map-popup-add-btn{margin-top:10px;width:100%;padding:8px;border-radius:var(--radius);border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s}.map-popup-add-btn:hover{background:var(--accent-hover)}.map-popup-add-btn:disabled{background:#0000000f;color:var(--muted);cursor:default}.map-popup-added{margin-top:10px;text-align:center;font-size:11px;color:var(--muted)}.map-popup-input{width:100%;padding:6px 8px;border-radius:6px;border:1px solid var(--border);font-size:12px;margin-top:8px;outline:none}.spot-list-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}.spot-list-search{padding:12px 16px;border-bottom:1px solid var(--border);position:relative}.spot-list-search-icon{position:absolute;left:26px;top:50%;transform:translateY(-50%);font-size:12px}.spot-list-input{width:100%;padding:8px 12px 8px 30px;box-sizing:border-box;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:12px;color:var(--text);outline:none;background:#00000005}.spot-list-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.spot-list{flex:1;overflow-y:auto}.spot-list-row{display:flex;align-items:center;gap:12px;padding:11px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:all .15s}.spot-list-row:hover{background:var(--accent-light)}.spot-list-row--added{opacity:.5;cursor:default}.spot-list-row--added:hover{background:transparent}.spot-list-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.spot-list-info{flex:1}.spot-list-name{font-size:13px;font-weight:600}.spot-list-meta{font-size:11px;color:var(--muted)}.spot-list-wind{text-align:right;font-size:13px}.spot-list-gust{font-size:10px;color:var(--muted)}.spot-list-check{font-size:11px;color:var(--muted)}.spot-list-plus{font-size:20px;color:var(--accent);font-weight:300}.flex{display:flex}.flex-col{flex-direction:column}.h-screen{height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.flex-1{flex:1}.items-center{align-items:center}.justify-center{justify-content:center}.bg-surface{background:var(--bg)}.text-muted{color:var(--muted)}.text-sm{font-size:13px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;height:100dvh;background:var(--bg);gap:var(--sp-4)}.loading-icon{font-size:40px;animation:breathe 2s ease-in-out infinite}.loading-icon-img{width:56px;height:56px;object-fit:contain;animation:breathe 2s ease-in-out infinite;filter:drop-shadow(0 4px 12px var(--accent-glow))}.loading-text{font-size:15px;color:var(--muted);font-weight:600;letter-spacing:.02em}@keyframes breathe{0%,to{transform:translateY(0) scale(1);opacity:1}50%{transform:translateY(-6px) scale(1.05);opacity:.8}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:0;padding:var(--sp-10) var(--sp-8);animation:welcomeIn .5s cubic-bezier(.16,1,.3,1) both}.empty-state-logo{width:56px;height:56px;border-radius:14px;box-shadow:var(--shadow-md);margin-bottom:20px}.empty-state-title{font-size:28px;font-weight:900;line-height:1.15;color:var(--text);margin-bottom:8px}.empty-state-title span{background:linear-gradient(135deg,var(--accent),var(--good));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.empty-state-sub{font-size:15px;color:var(--text-secondary);text-align:center;line-height:1.5;max-width:300px;margin-bottom:28px}.empty-state-btn{padding:14px 32px;border-radius:var(--radius);border:none;background:var(--accent);color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px var(--accent-glow)}.empty-state-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}.empty-state-geo{display:inline-flex;align-items:center;gap:6px;margin-top:14px;padding:10px 20px;border-radius:var(--radius);border:1.5px solid var(--glass-border);background:var(--panel-glass);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.empty-state-geo:hover{border-color:var(--accent);color:var(--accent)}.sidebar-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);font-size:10px;font-weight:700;margin-left:6px;padding:0 5px}.sidebar-empty{padding:var(--sp-6) var(--sp-4);text-align:center}.sidebar-empty-icon{font-size:24px;margin-bottom:6px}.sidebar-empty-text{font-size:11px;color:var(--muted)}.done-btn{padding:6px 16px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.done-btn:hover{background:var(--accent-hover)}.add-spot-toast{position:absolute;top:70px;left:50%;transform:translate(-50%);z-index:2000;background:#166534;color:#fff;padding:var(--sp-2) var(--sp-5);border-radius:var(--radius-full);font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:6px;animation:toast-in .3s ease-out}.add-spot-toast-icon{font-size:14px}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.kite-rec{display:flex;align-items:center;justify-content:space-between;background:var(--panel-glass);border:1px solid var(--border);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);gap:var(--sp-4)}.kite-rec-left{display:flex;align-items:center;gap:10px}.kite-rec-icon{font-size:22px}.kite-rec-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.kite-rec-detail{display:flex;align-items:baseline;gap:6px;margin-top:2px}.kite-rec-size{font-size:18px;font-weight:700;color:var(--text)}.kite-rec-weight{font-size:11px;color:var(--muted)}.kite-rec-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.kite-rec-badge{padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600}.kite-rec-wind{font-size:11px;color:var(--muted)}.wind-dir-strip{display:flex;justify-content:space-around;align-items:center;padding:6px 30px 2px;gap:2px}.wind-dir-item{display:flex;flex-direction:column;align-items:center;gap:1px}.wind-dir-label{font-size:9px;color:var(--muted);font-weight:600;letter-spacing:.02em}.spot-drag-handle{cursor:grab;font-size:10px;color:#0000001a;user-select:none;flex-shrink:0;transition:color .15s;line-height:1;letter-spacing:-1px}.spot-row:hover .spot-drag-handle{color:var(--muted)}.spot-row--dragging{opacity:.4;background:var(--accent-light)}.spot-row--dragover{box-shadow:0 -2px 0 0 var(--accent) inset}.view-toggle{display:inline-flex;gap:0;background:#00000008;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;margin-right:30px}[data-theme=dark] .view-toggle{background:#ffffff08}.view-toggle-btn{padding:6px 16px;border:none;cursor:pointer;font-size:11px;font-weight:600;background:transparent;color:var(--muted);transition:all .15s}.view-toggle-btn--active{background:var(--accent);color:#fff}.rotate-hint{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:500;color:var(--text-secondary);opacity:.6;letter-spacing:.02em;animation:rotate-hint-pulse 3s ease-in-out infinite}.rotate-hint-icon{animation:rotate-hint-tilt 3s ease-in-out infinite}@keyframes rotate-hint-tilt{0%,to{transform:rotate(0)}30%,50%{transform:rotate(90deg)}}@keyframes rotate-hint-pulse{0%,to{opacity:.4}30%,50%{opacity:.8}}.modal--landscape-combo{padding:max(var(--sp-2),env(safe-area-inset-top,0px)) max(var(--sp-3),env(safe-area-inset-right,0px)) max(var(--sp-2),env(safe-area-inset-bottom,0px)) max(var(--sp-3),env(safe-area-inset-left,0px))!important;gap:var(--sp-1)!important;width:100%!important;max-width:100%!important;max-height:100vh!important;max-height:100dvh!important;height:100dvh!important;border-radius:0!important;overflow-x:auto!important;overflow-y:auto!important;display:flex!important;flex-direction:column!important}.modal--landscape-combo .combined-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;flex:1;min-height:0}.modal--landscape-combo:before{display:none!important}.modal-backdrop--landscape{align-items:stretch!important;padding-top:0!important}.modal--landscape-combo .section{padding:var(--sp-2) var(--sp-3)}.combo-inline-nav{display:flex;align-items:center;gap:var(--sp-3);width:100%;white-space:nowrap;padding-top:30px}.combo-inline-day{font-size:12px;font-weight:700;color:var(--text);min-width:90px;text-align:center}.day-nav-btn--sm{width:24px;height:24px;padding:0}.day-nav-btn--sm svg{width:14px;height:14px}.combo-inline-close{width:26px;height:26px}.combined-table-wrap{display:flex;position:relative}.combined-yaxis{width:24px;flex-shrink:0;position:relative;height:136px}.combined-yaxis-label{position:absolute;right:2px;font-size:8px;color:var(--muted);transform:translateY(-50%)}.combined-table{flex:1;border-collapse:collapse;table-layout:fixed;margin-left:4px}.combined-tr{border-top:1px solid var(--border)}.combined-tr--hours{border-top:none}.combined-td{text-align:center;vertical-align:middle;padding:2px 0;font-size:9px;position:relative}.combined-hour{font-size:8px;color:var(--muted);font-weight:600}.combined-dir{font-size:7px;color:var(--muted);font-weight:600;display:block;line-height:1}.combined-tr-icon{position:absolute;left:-22px;top:50%;transform:translateY(-50%);font-size:11px}.combined-tr-img{width:16px;height:16px;object-fit:contain;display:block}.combined-tooltip{position:absolute;top:-4px;background:var(--panel-glass);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;font-size:12px;line-height:1.5;box-shadow:var(--shadow-md);pointer-events:none;z-index:10;white-space:nowrap;transform:translate(-50%)}.combined-tooltip-time{font-weight:700;font-size:13px;margin-bottom:2px}.tide-peak-bar{display:flex;gap:var(--sp-2);justify-content:center;padding:6px 0 2px;flex-wrap:wrap}.tide-peak{font-size:10px;font-weight:600;padding:3px 10px;border-radius:var(--radius-full)}.tide-peak--high{color:#166534;background:var(--good-bg)}.tide-peak--low{color:#92400e;background:var(--ok-bg)}.combined-data-tide-arrow{font-size:12px;font-weight:600;opacity:.45;line-height:1}.combined-data-tide-arrow--up{color:var(--good)}.combined-data-tide-arrow--down{color:var(--ok)}.combined-data-tide-peak{font-size:9px;font-weight:700;line-height:1.1;text-align:center}.combined-data-tide-peak--high{color:#166534}.combined-data-tide-peak--low{color:#92400e}[data-theme=dark] .tide-peak--high{color:#4ade80}[data-theme=dark] .tide-peak--low{color:#fbbf24}[data-theme=dark] .combined-data-tide-peak--high{color:#4ade80}[data-theme=dark] .combined-data-tide-peak--low{color:#fbbf24}.settings-panel{background:var(--bg);border-radius:var(--radius-xl);width:400px;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-modal);display:flex;flex-direction:column}.settings-header{display:flex;align-items:center;justify-content:center;position:relative;padding:var(--sp-5) var(--sp-4) var(--sp-3)}.settings-header .modal-back{position:absolute;left:var(--sp-4)}.settings-title{font-size:22px;font-weight:800;margin:0;color:var(--text);letter-spacing:-.02em}.settings-body{padding:0 var(--sp-3) var(--sp-4)}.settings-card{background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--sp-4);margin-bottom:var(--sp-3);box-shadow:0 2px 8px #00000008,inset 0 1px #ffffff1a}.settings-card:last-child{margin-bottom:0}.settings-card-row--toggle{display:flex;align-items:center;justify-content:space-between}.settings-card-divider{height:1px;background:var(--glass-border);margin:var(--sp-3) 0}.settings-section{margin-bottom:var(--sp-6)}.settings-section:last-child{margin-bottom:0}.feedback-section{border-top:none;padding:0;background:none;border:none;backdrop-filter:none;-webkit-backdrop-filter:none}.settings-footer{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0 16px;opacity:.5}.settings-footer-link{color:var(--muted);font-size:12px;text-decoration:none}.settings-footer-link:hover{text-decoration:underline;color:var(--accent)}.settings-footer-version{color:var(--muted);font-size:11px;font-weight:500}.settings-footer-brand{display:flex;align-items:center;gap:8px;margin-top:8px}.settings-footer-logo{width:32px;height:32px;border-radius:8px}.settings-footer-appname{font-size:16px;font-weight:700;color:var(--text);opacity:.6}.feedback-btn{width:100%;padding:12px 16px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel-glass);backdrop-filter:var(--glass-blur);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.feedback-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.feedback-btn-icon{display:flex;align-items:center;opacity:.6}.feedback-btn:hover .feedback-btn-icon{opacity:1}.feedback-form{background:var(--panel-glass);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:10px}.feedback-form-header{display:flex;align-items:flex-start;gap:10px}.feedback-textarea{width:100%;padding:12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;font-family:inherit;resize:vertical;transition:border-color .15s}.feedback-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0066ff14}.feedback-email{width:100%;padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:12px;font-family:inherit;transition:border-color .15s}.feedback-email::placeholder{color:var(--muted);font-style:italic}.feedback-email:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0066ff14}.feedback-actions{display:flex;gap:8px;justify-content:flex-end}.feedback-send-btn{padding:8px 20px;border-radius:var(--radius-full);border:none;background:var(--accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.feedback-send-btn:hover{box-shadow:0 2px 8px #0066ff4d}.feedback-send-btn:disabled{opacity:.5;cursor:default;box-shadow:none}.feedback-cancel-btn{padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.feedback-cancel-btn:hover{color:var(--text);border-color:var(--text)}.settings-label{font-size:13px;font-weight:700;color:var(--text);margin-bottom:var(--sp-1)}.settings-label--sm{font-size:11px;margin-bottom:4px}.settings-hint{font-size:11px;color:var(--muted);margin-bottom:var(--sp-2)}.settings-section--compact{margin-bottom:var(--sp-4)}.models-group-label{display:flex;align-items:center;gap:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text);margin:14px 0 6px;opacity:.6}.models-group-label:before,.models-group-label:after{content:"";flex:1;height:1px;background:var(--border)}.models-group-label:first-of-type{margin-top:4px}.models-group-hint{font-size:10px;color:var(--muted);opacity:.6;align-self:center;margin-top:6px}.models-row-compact{display:flex;gap:5px;flex-wrap:nowrap;align-items:center}.models-row-compact .toggle-chip{padding:5px 10px;font-size:11px;flex-shrink:0}.units-compact-row{display:flex;gap:0}.unit-group{flex:1;min-width:0;padding:0 12px;border-right:1px solid var(--border)}.unit-group:first-child{padding-left:0}.unit-group:last-child{border-right:none;padding-right:0}.unit-group .radio-btn{padding:5px 10px;font-size:11px}.units-compact-row>.unit-group>div{display:flex;gap:4px}.wind-slider-wrap{margin-top:var(--sp-3)}.wind-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,var(--poor) 0%,var(--ok) 40%,var(--good) 100%);outline:none;cursor:pointer}.wind-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--panel-solid);border:3px solid var(--accent);box-shadow:0 2px 8px #00000026;cursor:pointer;transition:transform .15s}.wind-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.wind-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--panel-solid);border:3px solid var(--accent);box-shadow:0 2px 8px #00000026;cursor:pointer}.wind-slider-labels{display:flex;justify-content:space-between;align-items:center;margin-top:var(--sp-2);font-size:11px;color:var(--muted)}.wind-slider-value{font-size:16px;font-weight:800;color:var(--good);letter-spacing:-.5px}.wind-range-slider{position:relative;height:46px;margin-top:8px}.wind-range-track{position:absolute;top:12px;left:0;right:0;height:5px;border-radius:3px}.wind-slider--dual{position:absolute;top:2px;left:0;width:100%;-webkit-appearance:none;appearance:none;background:transparent;pointer-events:none;margin:0;height:26px;z-index:2}.wind-slider--dual::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 1px 4px #0003;cursor:pointer;pointer-events:auto}.wind-slider--dual::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0003;cursor:pointer;pointer-events:auto;border:2px solid var(--accent)}.wind-range-slider .wind-slider-labels{position:absolute;bottom:0;left:0;right:0}.toggle-chip{padding:7px 16px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--panel-glass);color:var(--text-secondary);font-weight:600;font-size:12px;cursor:pointer;transition:all .2s;backdrop-filter:blur(12px)}.toggle-chip:hover{border-color:var(--muted)}.toggle-chip--active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}.toggle-chip--locked{cursor:default;opacity:.85}.radio-btn{padding:7px 16px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--panel-glass);color:var(--text-secondary);font-weight:600;font-size:12px;cursor:pointer;transition:all .2s}.radio-btn:hover{border-color:var(--muted)}.radio-btn--active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}@supports (padding-top: env(safe-area-inset-top)){.titlebar{padding-top:env(safe-area-inset-top)}}@media(max-width:768px){.app-shell{margin:6px;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 2px 16px #0000000f;border:1px solid var(--glass-border);height:calc(100vh - 12px)!important;height:calc(100dvh - 12px)!important}.titlebar{border-radius:var(--radius-xl) var(--radius-xl) 0 0}.titlebar-traffic-light-spacer{display:none}.titlebar{border-bottom:none}.titlebar-row{padding:var(--sp-2) var(--sp-3);gap:var(--sp-2)}.titlebar-actions{order:1}.titlebar .model-chip-wrap{display:block;order:2;margin-left:auto}.model-segmented{display:none}.flex.flex-1.overflow-hidden{flex-direction:column!important}.sidebar{width:100%!important;flex-direction:row;border-right:none;border-bottom:1px solid var(--border);overflow-x:auto;overflow-y:hidden;flex-shrink:0;max-height:none;background:var(--panel-glass);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);scrollbar-width:none;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.sidebar::-webkit-scrollbar{display:none}.sidebar-footer{display:none}.add-spot-btn-header{display:inline-flex}.sidebar-label{padding:var(--sp-2) var(--sp-3);white-space:nowrap;font-size:9px;display:none}.sidebar-list{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:var(--sp-2) var(--sp-3);gap:var(--sp-2);scrollbar-width:none}.sidebar-list::-webkit-scrollbar{display:none}.sidebar-list:after{display:none!important}.spot-row{flex-shrink:0;min-width:auto;white-space:nowrap;padding:var(--sp-2) var(--sp-3)!important;min-height:40px;border-left:none!important;border-radius:var(--radius-full);background:var(--surface);border:1px solid var(--border);gap:6px}.spot-row-name{font-size:13px}.spot-row-meta{display:none}.spot-row--active{border-left-color:transparent!important;border-bottom:none;background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 16px var(--accent-glow)}.spot-row--active:hover{background:var(--accent);transform:none}.spot-row--active .spot-row-name{color:#fff;font-weight:700}.spot-row--active .spot-dot{box-shadow:0 0 0 2px #fff6}.spot-row .spot-drag-handle{display:none}.spot-row .spot-remove-btn{display:none!important}.sidebar-edit-btn{display:flex;align-items:center}.spot-row--editing{min-height:40px;flex-shrink:0}.spot-row--editing .spot-row-name{font-size:12px;font-weight:600}main.flex-1{padding:0}.forecast-container{padding:var(--sp-4) var(--sp-3);gap:var(--sp-3)}.forecast-title{font-size:18px}.forecast-hint{display:none}.hero-card{width:100%}.section{padding:var(--sp-3);border-radius:var(--radius)}.section-header{padding:0 0 var(--sp-2) 0}.day-strip{display:flex!important;grid-template-columns:none!important;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:var(--sp-2);padding-bottom:var(--sp-1);scroll-snap-type:x mandatory;scrollbar-width:none}.day-strip::-webkit-scrollbar{display:none}.day-strip-skeleton{display:flex!important;grid-template-columns:none!important;overflow-x:auto;gap:var(--sp-2)}.day-card{min-width:100px;flex-shrink:0;scroll-snap-align:start;padding:var(--sp-3) var(--sp-2)}.day-card-wind{font-size:20px}.two-col{display:flex!important;flex-direction:column!important;grid-template-columns:none!important;gap:var(--sp-3)}.view-toggle-btn{padding:6px 14px;font-size:11px}.combined-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.combined-table-wrap::-webkit-scrollbar{display:none}.combined-table{min-width:500px}.modal,.add-spot-modal,.settings-panel{width:100%!important;max-width:100%!important;max-height:100%!important;border-radius:0!important;height:100%}.modal-backdrop{align-items:flex-end!important;padding-top:env(safe-area-inset-top,0px)}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;max-height:calc(100vh - env(safe-area-inset-top,20px) - 24px)!important;max-height:calc(100dvh - env(safe-area-inset-top,20px) - 24px)!important;padding:var(--sp-4) var(--sp-4) var(--sp-5);overflow-y:auto}.modal:before{display:none}.add-spot-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;height:calc(100vh - env(safe-area-inset-top,20px) - 24px)!important;height:calc(100dvh - env(safe-area-inset-top,20px) - 24px)!important}.settings-panel{border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;width:100%!important;max-height:calc(100dvh - env(safe-area-inset-top,20px) - 24px)!important}.settings-panel:before,.sh-panel:before,.log-modal:before{display:none}.sh-panel,.log-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0!important;width:100%!important;max-height:calc(100dvh - env(safe-area-inset-top,20px) - 24px)!important}@media(display-mode:standalone){.modal{max-height:calc(100dvh - env(safe-area-inset-top,47px) - 16px)!important}.add-spot-modal{height:calc(100dvh - env(safe-area-inset-top,47px) - 16px)!important}.settings-panel{max-height:calc(100dvh - env(safe-area-inset-top,47px) - 16px)!important}}.modal-header{flex-wrap:nowrap;gap:var(--sp-2);justify-content:center;position:relative}.modal-header .modal-back{position:absolute;left:0}.modal-title{font-size:18px}.modal-subtitle{font-size:11px}.hero-location,.section-header-center{max-width:10ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-panel{width:100%!important}.settings-header{padding:var(--sp-4) var(--sp-3) var(--sp-2);justify-content:center;position:relative}.settings-header .modal-back{position:absolute;left:var(--sp-3)}.settings-body{padding:0 var(--sp-3) var(--sp-4)}.settings-title{font-size:18px}}@media(max-width:400px){.model-seg{padding:4px 6px;font-size:9px}.day-card{min-width:85px}.day-card-wind{font-size:18px}.hero-wind-num{font-size:52px}.view-toggle-btn{padding:5px 12px;font-size:10px}.forecast-container{padding:var(--sp-3) var(--sp-2)}}.sun-strip{display:flex;align-items:center;justify-content:center;gap:16px;padding:6px 12px;background:var(--panel-glass);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:11px;color:var(--muted)}.sun-strip-item{display:flex;align-items:center;gap:4px}.sun-strip-icon{font-size:13px}.sun-strip-time{font-weight:600;color:var(--text)}.sun-strip-label{font-size:10px}.sun-strip-daylight{font-weight:600;color:var(--accent)}.kite-calc{background:var(--panel-glass);border-radius:var(--radius);border:1px solid var(--border);padding:var(--sp-4)}.kite-calc-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.kite-calc-title{font-size:13px;font-weight:700}.kite-calc-sub{font-size:11px;color:var(--muted)}.kite-calc-controls{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.kite-calc-input{width:70px;padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;text-align:center;outline:none;background:#00000005;color:var(--text)}.kite-calc-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.kite-calc-label{font-size:11px;color:var(--muted)}.kite-calc-result{display:flex;align-items:center;gap:12px;padding:var(--sp-3) var(--sp-4);background:linear-gradient(135deg,var(--accent-light),var(--good-bg));border-radius:var(--radius)}[data-theme=dark] .kite-calc-result{background:linear-gradient(135deg,#00aaff14,#00e68a14)}.kite-calc-size{font-size:28px;font-weight:800;color:var(--accent)}.kite-calc-unit{font-size:12px;color:var(--muted);font-weight:600}.kite-calc-range{font-size:11px;color:var(--muted)}.kite-calc-note{font-size:10px;color:var(--muted);margin-top:8px;font-style:italic}.share-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--panel-glass);color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.share-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.share-btn--copied{background:var(--good-bg);color:#166534;border-color:#00c48c4d}.day-nav{display:flex;align-items:center;gap:var(--sp-2)}.day-nav-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--panel-glass);backdrop-filter:var(--glass-blur);cursor:pointer;font-size:16px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 2px 8px #0000000a}.day-nav-btn:hover{background:var(--accent-light);color:var(--accent)}.day-nav-btn:disabled{opacity:.3;cursor:default}.day-nav-btn:disabled:hover{background:var(--panel-glass);color:var(--muted)}.theme-toggle{width:48px;height:26px;border-radius:13px;background:#0000001a;border:none;cursor:pointer;position:relative;transition:background .3s ease;flex-shrink:0}.theme-toggle--dark{background:var(--accent)}.theme-toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;font-size:11px;box-shadow:0 1px 3px #0000001f}.theme-toggle--dark .theme-toggle-knob{transform:translate(22px)}.ptr-indicator{text-align:center;padding:var(--sp-2);font-size:12px;color:var(--accent);font-weight:600;animation:ptr-fade .5s ease-out}@keyframes ptr-fade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.offline-banner{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);background:var(--ok-bg);border-bottom:1px solid rgba(255,176,32,.2);font-size:12px;font-weight:600;color:#92400e;animation:offline-slide .3s ease-out}[data-theme=dark] .offline-banner{background:#451a034d;border-bottom-color:#78350f4d;color:#fcd34d}.offline-dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 2px #ffb02040;animation:offline-pulse 2s ease-in-out infinite}.offline-age{font-weight:400;opacity:.75}@keyframes offline-slide{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes offline-pulse{0%,to{opacity:1}50%{opacity:.4}}.install-banner{position:fixed;bottom:0;left:0;right:0;padding:20px 20px calc(20px + env(safe-area-inset-bottom,0px));background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);box-shadow:0 -4px 24px #00000014;animation:install-banner-up .5s cubic-bezier(.16,1,.3,1) both;z-index:9000}[data-theme=dark] .install-banner{box-shadow:0 -4px 24px #00000059}@keyframes install-banner-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.install-banner-inner{display:flex;align-items:center;gap:14px}.install-banner-app-icon{width:48px;height:48px;border-radius:12px;flex-shrink:0;box-shadow:0 4px 12px #0066ff26}.install-banner-body{flex:1}.install-banner-title{font-size:15px;font-weight:800;color:var(--text);margin-bottom:3px}.install-banner-desc{font-size:12.5px;color:var(--text-secondary);line-height:1.5}.install-banner-desc b{color:var(--text)}.install-banner-share{display:inline-block;vertical-align:middle;width:18px;height:18px;color:var(--accent);margin:0 2px}.install-banner-share--pulse{animation:install-share-pulse 2s ease-in-out 1.5s 3}@keyframes install-share-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}.install-banner-actions{display:flex;gap:8px;margin-top:14px}.install-banner-btn{padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;border:none;font-family:inherit}.install-banner-btn--dismiss{background:none;color:var(--text-secondary);padding:10px 12px}.install-banner-btn--dismiss:hover{color:var(--text)}.install-banner-btn--cta{background:var(--accent);color:#fff;box-shadow:0 2px 8px #06f3}.install-banner-btn--cta:hover{box-shadow:0 4px 16px #0066ff4d}.day-card-hours{display:flex;gap:2px;justify-content:center;margin-top:4px}.day-card-hours-dot{width:5px;height:5px;border-radius:50%;background:#0000000f;transition:background .2s}.day-card-hours-dot--good{background:var(--good)}.day-card-hours-dot--ok{background:var(--ok)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.best-day-badge{position:absolute;top:-8px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--good),#059669);color:#fff;font-size:9px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;z-index:2;box-shadow:0 2px 6px #00c48c4d;letter-spacing:.02em}.wind-trend-bar{display:flex;align-items:center;justify-content:center;padding:6px 12px;font-size:11px;color:var(--muted)}.wind-trend-label{display:flex;align-items:center;gap:4px}.swipe-hint{text-align:center;font-size:11px;color:var(--muted);padding:var(--sp-1) 0 var(--sp-2);opacity:.6}.forecast-summary{font-size:13px;color:var(--text);padding:var(--sp-3) var(--sp-4);background:var(--panel-glass);border:1px solid var(--border);border-radius:var(--radius);font-weight:500;line-height:1.5}[data-theme=dark] .best-day-badge{box-shadow:0 2px 6px #0000004d}.forecast-container{animation:fadeSlideIn .3s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.section{animation:sectionFadeIn .35s ease-out both}.section:nth-child(1){animation-delay:0s}.section:nth-child(2){animation-delay:.06s}.section:nth-child(3){animation-delay:.06s}.section:nth-child(4){animation-delay:.12s}.section:nth-child(5){animation-delay:.18s}@keyframes sectionFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.day-card{animation:cardPopIn .3s ease-out both}.day-card:nth-child(1){animation-delay:0s}.day-card:nth-child(2){animation-delay:.03s}.day-card:nth-child(3){animation-delay:.06s}.day-card:nth-child(4){animation-delay:.09s}.day-card:nth-child(5){animation-delay:.12s}.day-card:nth-child(6){animation-delay:.15s}.day-card:nth-child(7){animation-delay:.18s}@keyframes cardPopIn{0%{opacity:0;transform:scale(.95) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-backdrop{animation:backdropFadeIn .25s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:modalSlideUp .35s cubic-bezier(.32,.72,0,1)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000014;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00000026}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#ffffff14}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#ffffff26}.section:hover{box-shadow:var(--shadow-md)}.spot-row:hover .spot-row-name{color:var(--accent)}.spot-row--active:hover .spot-row-name{color:inherit}.settings-btn:active{transform:scale(.92)}.model-btn:active{transform:scale(.95)}.community-card{background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:var(--sp-3);box-shadow:0 2px 8px #0000000f;animation:slideUp .3s ease}[data-theme=dark] .community-card{box-shadow:0 2px 8px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.community-card-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--good));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 2px 8px #0066ff26}.community-card-text{flex:1;min-width:120px}.community-card-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:2px}.community-card-sub{font-size:12px;color:var(--text-secondary);line-height:1.4}.community-card-actions{display:flex;gap:8px;width:100%}.community-card-share{flex:2;padding:10px 18px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 2px 8px #06f3;transition:all .15s}@media(hover:hover){.community-card-share:hover{box-shadow:0 4px 16px #0066ff4d}}.community-card-dismiss{flex:1;padding:10px 14px;border:none;border-radius:var(--radius);background:#0000000a;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}[data-theme=dark] .community-card-dismiss{background:#ffffff0f}@media(hover:hover){.community-card-dismiss:hover{background:#00000014}[data-theme=dark] .community-card-dismiss:hover{background:#ffffff1a}}.community-backdrop{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#0000004d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:backdropFadeIn .25s ease-out}.community-modal{width:92%;max-width:420px;display:flex;flex-direction:column;background:var(--bg);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-modal);overflow:hidden;animation:welcomeIn .5s cubic-bezier(.16,1,.3,1) both}.community-header{padding:28px 24px 20px;text-align:center;flex-shrink:0}.community-header-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--good));display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 4px 16px #06f3;color:#fff}.community-header-title{font-size:22px;font-weight:800;color:var(--text);margin-bottom:6px}.community-header-sub{font-size:14px;color:var(--text-secondary);line-height:1.5}.community-header-sub b{color:var(--text)}.community-spot-pill{display:flex;align-items:center;gap:10px;margin:0 24px;padding:12px 16px;background:#0066ff0d;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:600;color:var(--text)}[data-theme=dark] .community-spot-pill{background:#00aaff0f}.community-spot-pill svg{color:var(--accent);flex-shrink:0}.community-spot-coords{margin-left:auto;font-weight:400;font-size:12px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.community-fields{padding:20px 24px 0;display:flex;flex-direction:column;gap:16px}.community-field{display:flex;flex-direction:column;gap:6px}.community-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.community-input{width:100%;padding:12px 16px;border-radius:var(--radius);border:1.5px solid var(--border);background:#00000005;font-size:14px;color:var(--text);outline:none;font-family:inherit;transition:border-color .15s,box-shadow .15s}[data-theme=dark] .community-input{background:#ffffff0a}.community-input::placeholder{color:var(--text-secondary);opacity:.5}.community-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0066ff1a;background:var(--panel-solid)}[data-theme=dark] .community-input:focus{box-shadow:0 0 0 3px #00aaff1f;background:#ffffff0f}.community-textarea{width:100%;padding:12px 16px;border-radius:var(--radius);border:1.5px solid var(--border);background:#00000005;font-size:14px;color:var(--text);outline:none;resize:vertical;font-family:inherit;min-height:80px;transition:border-color .15s,box-shadow .15s}[data-theme=dark] .community-textarea{background:#ffffff0a}.community-textarea::placeholder{color:var(--text-secondary);opacity:.5}.community-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0066ff1a;background:var(--panel-solid)}[data-theme=dark] .community-textarea:focus{box-shadow:0 0 0 3px #00aaff1f;background:#ffffff0f}.community-charcount{font-size:11px;color:var(--text-secondary);text-align:right;margin-top:-4px}.community-actions{display:flex;gap:10px;padding:20px 24px 24px;border-top:1px solid var(--border);margin-top:20px}.community-btn{padding:14px 20px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .15s}.community-btn--secondary{flex:0 0 auto;background:#0000000a;color:var(--text-secondary)}@media(hover:hover){.community-btn--secondary:hover{background:#00000014}}[data-theme=dark] .community-btn--secondary{background:#ffffff0f}[data-theme=dark] .community-btn--secondary:hover{background:#ffffff1a}.community-btn--primary{flex:1;background:var(--accent);color:#fff;font-size:15px;font-weight:700;box-shadow:0 2px 8px #06f3}@media(hover:hover){.community-btn--primary:hover{box-shadow:0 4px 16px #0066ff4d}}.community-btn--primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.community-sent{text-align:center;padding:48px 28px}.community-sent-check{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#00c48c,#34d399);display:inline-flex;align-items:center;justify-content:center;color:#fff;margin-bottom:16px;box-shadow:0 4px 16px #00c48c40}.community-sent-title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:6px}.community-sent-sub{font-size:13px;color:var(--text-secondary);line-height:1.5}.community-sent-sub b{color:var(--text)}.community-badge{display:inline-block;font-size:9px;font-weight:700;padding:1px 5px;border-radius:4px;vertical-align:middle;background:#0066ff14;color:var(--accent);margin-left:6px}.welcome-backdrop{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#0000004d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.welcome-modal{width:92%;max-width:420px;max-height:85dvh;display:flex;flex-direction:column;background:var(--bg);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-modal);overflow:hidden;animation:welcomeIn .5s cubic-bezier(.16,1,.3,1) both}@keyframes welcomeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.welcome-top{padding:32px 28px 24px;text-align:center;flex-shrink:0}.welcome-logo-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:24px}.welcome-logo{width:44px;height:44px;border-radius:12px;box-shadow:var(--shadow-md)}.welcome-logo-text{font-size:22px;font-weight:800;color:var(--text)}.welcome-big-title{font-size:30px;font-weight:900;line-height:1.15;color:var(--text);margin:0 0 10px}.welcome-big-title span{background:linear-gradient(135deg,var(--accent),var(--good));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.welcome-desc{font-size:15px;color:var(--text-secondary);line-height:1.5;max-width:300px;margin:0 auto}.welcome-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:var(--sp-6) 0}.welcome-spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--glass-border);border-top-color:var(--accent);animation:spin .8s linear infinite}.welcome-hint{font-size:13px;color:var(--text-secondary)}.welcome-content{flex:1;overflow-y:auto;padding:0 24px;min-height:0}.welcome-nearby-label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.welcome-nearby-label:after{content:"";flex:1;height:1px;background:var(--glass-border)}.welcome-spot-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--glass-border);cursor:pointer;transition:background .15s}.welcome-spot-row:last-child{border-bottom:none}.welcome-spot-info{flex:1;min-width:0}.welcome-spot-name{font-size:15px;font-weight:600;color:var(--text);margin-bottom:2px}.welcome-spot-meta{font-size:12px;color:var(--text-secondary)}.welcome-dist-pill{font-size:11px;font-weight:600;color:var(--good);background:var(--good-bg);padding:4px 10px;border-radius:var(--radius-full);flex-shrink:0}.welcome-toggle{width:44px;height:26px;border-radius:13px;flex-shrink:0;background:var(--glass-border);position:relative;transition:background .25s;cursor:pointer}.welcome-toggle--on{background:var(--accent)}.welcome-toggle:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .25s cubic-bezier(.65,0,.35,1);box-shadow:0 2px 4px #00000026}.welcome-toggle--on:after{transform:translate(18px)}.welcome-toggle--locked{opacity:.5;cursor:default}.model-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.model-toggle-info{display:flex;flex-direction:column;min-width:0}.model-toggle-name{font-size:13px;font-weight:600;color:var(--text)}.model-toggle-desc{font-size:10px;color:var(--muted);opacity:.7}.welcome-bottom{padding:16px 24px 24px;flex-shrink:0;border-top:1px solid var(--glass-border);background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3)}.welcome-bottom-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.welcome-count{font-size:13px;color:var(--text-secondary)}.welcome-count b{color:var(--accent)}.welcome-clear{background:none;border:none;color:var(--text-secondary);font-size:12px;cursor:pointer;padding:2px 0;transition:color .15s}.welcome-clear:hover{color:var(--accent)}.welcome-cta{width:100%;padding:16px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;box-shadow:0 4px 16px #0066ff40}.welcome-cta:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0066ff59}.welcome-cta:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.sh-panel{background:var(--bg);border-radius:var(--radius-xl);width:min(520px,calc(100vw - 32px));height:calc(100dvh - 64px);max-height:calc(100dvh - 64px);display:flex;flex-direction:column;box-shadow:var(--shadow-modal);overflow:hidden}.sh-header{display:flex;align-items:center;justify-content:center;position:relative;padding:20px 24px 12px}.sh-header .modal-back{position:absolute;left:24px}.sh-title{font-size:22px;font-weight:800;color:var(--text);margin:0;letter-spacing:-.02em}.sh-stats{display:flex;background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin:0 16px 12px;padding:0}.sh-stat{flex:1;text-align:center;padding:18px 8px;position:relative}.sh-stat+.sh-stat:before{content:"";position:absolute;left:0;top:25%;height:50%;width:1px;background:var(--glass-border)}.sh-stat-value{font-size:28px;font-weight:800;color:var(--text);line-height:1.1}.sh-stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.sh-tabs{display:flex;gap:0;background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin:0 16px 12px;padding:4px;overflow:hidden}.sh-tab{flex:1;padding:8px 4px;background:none;border:none;border-radius:var(--radius);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;text-align:center;font-family:inherit;transition:all .15s}.sh-tab--active{color:var(--accent);background:var(--accent-light)}.sh-tab:hover:not(.sh-tab--active){color:var(--text)}.sh-body{padding:12px 16px;overflow-y:auto;flex:1}.sh-empty{text-align:center;padding:40px 0}.sh-empty-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.sh-empty-sub{font-size:13px;color:var(--muted)}.sh-group{margin-bottom:20px}.sh-group:last-child{margin-bottom:0}.sh-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sh-group-name{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.sh-group-count{font-size:11px;color:var(--muted);background:var(--panel-glass);padding:2px 8px;border-radius:10px;font-weight:600}.sh-card{position:relative;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:8px;padding:12px 14px;transition:box-shadow .15s}.sh-card:hover{box-shadow:0 2px 8px #0000000a}.sh-card-top{display:flex;align-items:flex-start;gap:12px}.sh-card-left{flex:1;min-width:0}.sh-card-spot{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:6px}.sh-card-wind-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-weight:700;font-size:14px}.sh-card-wind-num{font-variant-numeric:tabular-nums}.sh-card-wind-unit{font-size:11px;font-weight:600;opacity:.8}.sh-card-wind-dir{font-size:11px;font-weight:600;opacity:.8;margin-left:2px}.sh-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.sh-card-date{font-size:11px;color:var(--muted);white-space:nowrap}.sh-card-gear{font-size:11px;color:var(--accent);font-weight:600}.sh-stars{display:flex;gap:1px}.sh-card-delete{position:absolute;top:6px;right:6px;background:none;border:none;color:var(--muted);cursor:pointer;padding:2px;opacity:0;transition:opacity .15s}.sh-card:hover .sh-card-delete{opacity:.4}.sh-card-delete:hover{opacity:1!important;color:var(--poor)}.sh-card-notes{margin-top:8px}.sh-card-notes-divider{height:1px;background:var(--glass-border);margin-bottom:8px}.sh-card-notes-text{font-size:12px;color:var(--muted);line-height:1.4}.sh-show-more{background:none;border:none;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;padding:6px 0;font-family:inherit}.sh-show-more:hover{text-decoration:underline}[data-theme=dark] .sh-panel{background:var(--bg)}[data-theme=dark] .sh-card{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .sh-stats,[data-theme=dark] .sh-tabs,[data-theme=dark] .sh-group-count{background:var(--panel)}.log-modal{background:var(--bg);border-radius:var(--radius-xl);width:min(440px,calc(100vw - 32px));max-height:calc(100dvh - 48px);display:flex;flex-direction:column;box-shadow:var(--shadow-modal);overflow:hidden}.log-modal-header{display:flex;align-items:center;justify-content:center;position:relative;padding:20px 20px 12px}.log-modal-header .modal-back{position:absolute;left:20px}.log-modal-title{font-size:22px;font-weight:800;color:var(--text);margin:0;letter-spacing:-.02em}.log-modal-body{padding:0 12px 12px;overflow-y:auto;flex:1}.log-card{background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;box-shadow:0 2px 8px #00000008,inset 0 1px #ffffff1a}.log-card:last-child{margin-bottom:0}.log-card .log-field:last-child{margin-bottom:0}.log-field{margin-bottom:18px}.log-field:last-child{margin-bottom:0}.log-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:block}.log-cond-loading{font-weight:500;text-transform:none;letter-spacing:0;opacity:.7;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:.3}}.log-label-hint{font-weight:500;text-transform:none;letter-spacing:0}.log-dropdown-wrap{position:relative}.log-dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg);color:var(--text);font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s}.log-dropdown-trigger:focus,.log-dropdown-trigger:hover{border-color:var(--accent)}.log-dropdown-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#ffffffeb;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid var(--glass-border);border-radius:14px;box-shadow:var(--shadow-modal);z-index:10;max-height:220px;overflow-y:auto;padding:4px}.log-dropdown-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;border:none;background:none;color:var(--text);font-size:16px;font-weight:500;font-family:inherit;cursor:pointer;border-radius:10px;transition:background .12s;text-align:left}.log-dropdown-item:hover{background:var(--bg)}.log-dropdown-item--active{color:var(--accent);font-weight:700;background:color-mix(in srgb,var(--accent) 8%,transparent)}.log-dropdown-item-sub{font-size:13px;color:var(--muted);font-weight:400}[data-theme=dark] .log-dropdown-trigger{background:var(--surface)}[data-theme=dark] .log-dropdown-list{background:#0d1829eb;border-color:var(--glass-border)}[data-theme=dark] .log-dropdown-item:hover{background:var(--surface)}.log-select{width:100%;padding:12px 36px 12px 16px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg);color:var(--text);font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235A6E82' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;transition:border-color .15s}.log-select:focus{border-color:var(--accent)}.log-select option{font-size:16px;font-weight:500;padding:12px 8px}.log-input{padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg);color:var(--text);font-size:15px;font-weight:500;font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .15s}.log-input:focus{border-color:var(--accent)}.log-input--date{width:100%;margin-top:8px}.log-input--time{width:130px;text-align:center;font-variant-numeric:tabular-nums}.log-date-pills{display:flex;gap:6px}.log-date-pill{flex:1;padding:9px 4px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;text-align:center;font-family:inherit;transition:all .15s}.log-date-pill--active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}.log-time-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.log-time-stepper{display:flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:14px;padding:4px 10px;background:var(--bg)}.log-time-col{display:flex;flex-direction:column;align-items:center;gap:0}.log-time-digit{font-size:18px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;min-width:22px;text-align:center;line-height:1}.log-time-colon{font-size:18px;font-weight:700;color:var(--muted);margin:0 1px;align-self:center}.log-time-ampm{font-size:11px;font-weight:700;color:var(--muted);margin-left:4px;align-self:center}[data-theme=dark] .log-time-stepper{background:var(--surface);border-color:var(--glass-border)}.log-time-sep{font-size:13px;color:var(--muted);font-weight:500}.log-duration-badge{font-size:12px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);padding:5px 12px;border-radius:var(--radius-full);white-space:nowrap}.log-conditions{display:flex;gap:1px;border-radius:14px;overflow:hidden;border:1px solid var(--border)}.log-cond-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 8px;background:var(--bg)}.log-cond-step{display:flex;align-items:center;justify-content:center;width:28px;height:20px;border:none;background:none;color:var(--muted);cursor:pointer;padding:0;border-radius:6px;transition:color .15s,background .15s}.log-cond-step:hover{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.log-cond-step:active{color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,transparent)}.log-cond-value{font-size:20px;font-weight:800;color:var(--text);line-height:1;min-height:24px;display:flex;align-items:center}.log-cond-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.log-add-gear-link{background:none;border:1px dashed var(--border);border-radius:12px;color:var(--accent);font-size:13px;font-weight:600;padding:11px 14px;width:100%;cursor:pointer;font-family:inherit;text-align:center;transition:border-color .15s}.log-add-gear-link:hover{border-color:var(--accent)}.log-board-pills{display:flex;gap:6px;margin-top:8px}.log-board-pill{flex:1;padding:9px 4px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;text-align:center;font-family:inherit;transition:all .15s}.log-board-pill--active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}.log-stars{display:flex;gap:6px}.log-star{background:none;border:none;padding:4px;cursor:pointer;color:var(--muted);opacity:.4;transition:color .15s,transform .1s,opacity .15s}.log-star--active{color:#ffb020;opacity:1}.log-star:hover{transform:scale(1.15)}.log-textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;outline:none;resize:vertical;box-sizing:border-box;transition:border-color .15s}.log-textarea:focus{border-color:var(--accent)}.log-textarea::placeholder{color:var(--muted)}[data-theme=dark] .log-modal{background:var(--bg)}[data-theme=dark] .log-card{background:var(--panel)}[data-theme=dark] .log-select,[data-theme=dark] .log-input,[data-theme=dark] .log-cond-item,[data-theme=dark] .log-textarea{background:var(--surface)}.log-modal .edit-spots-bottom{background:var(--bg);backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:0 0 var(--radius-xl) var(--radius-xl);padding-bottom:max(24px,env(safe-area-inset-bottom,24px))}[data-theme=dark] .log-modal .edit-spots-bottom{background:var(--bg)}.log-session-btn{display:flex;align-items:center;gap:6px;margin:-6px auto 4px;padding:8px 20px;border:none;border-radius:20px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;background:color-mix(in srgb,var(--log-btn-color) 15%,var(--surface));color:var(--log-btn-color);border:1px solid color-mix(in srgb,var(--log-btn-color) 25%,transparent);transition:all .2s;position:relative;z-index:2}.log-session-btn:hover{background:color-mix(in srgb,var(--log-btn-color) 25%,var(--surface));transform:translateY(-1px);box-shadow:0 2px 8px color-mix(in srgb,var(--log-btn-color) 20%,transparent)}.log-session-btn:active{transform:translateY(0)}.log-session-btn svg{flex-shrink:0}.hero-card-wrap{position:relative;flex:0 0 auto}.log-session-btn--mobile{display:flex;position:absolute;bottom:-24px;left:0;right:0;justify-content:center;z-index:10;margin:0 auto;width:fit-content;backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);box-shadow:0 4px 20px color-mix(in srgb,var(--log-btn-color) 15%,transparent),0 1px 3px #0000000a}.log-session-btn--desktop{display:none}@media(min-width:769px){.hero-card-wrap{flex-shrink:0}.hero-card-wrap .hero-card{height:100%;box-sizing:border-box}.log-session-btn--mobile{display:none}.log-session-btn--desktop{display:flex}}[data-theme=dark] .log-session-btn{background:color-mix(in srgb,var(--log-btn-color) 12%,var(--surface));border-color:color-mix(in srgb,var(--log-btn-color) 20%,transparent)}[data-theme=dark] .log-session-btn:hover{background:color-mix(in srgb,var(--log-btn-color) 20%,var(--surface))}.quiver-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-2)}.quiver-add-link{background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;padding:4px 10px;border-radius:var(--radius-full);transition:all .15s}.quiver-add-link:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.quiver-sail-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}.quiver-sail-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--glass-border);transition:box-shadow .15s}.quiver-sail-row:hover{box-shadow:0 2px 8px #0000000a}.quiver-sail-size{font-size:22px;font-weight:800;color:var(--accent);min-width:48px;line-height:1}.quiver-sail-unit{font-size:12px;font-weight:600;color:var(--muted);margin-left:1px}.quiver-sail-info{flex:1;min-width:0}.quiver-sail-brand{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}.quiver-sail-type{font-size:11px;color:var(--muted);line-height:1.2;text-transform:uppercase;letter-spacing:.03em}.quiver-sail-remove{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;opacity:.4;transition:all .15s}.quiver-sail-remove:hover{opacity:1;color:var(--poor);background:color-mix(in srgb,var(--poor) 10%,transparent)}.quiver-add-form{margin-top:10px;padding:14px;background:var(--surface);border-radius:var(--radius-lg);border:1px solid color-mix(in srgb,var(--accent) 30%,var(--glass-border));box-shadow:0 2px 12px color-mix(in srgb,var(--accent) 8%,transparent)}.quiver-type-pills{display:flex;gap:6px;margin-bottom:12px}.quiver-type-pill{flex:1;padding:8px 4px;border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--bg);color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s}.quiver-type-pill--active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent)}.quiver-add-fields{display:flex;gap:8px;margin-bottom:10px}.quiver-brand-wrap{flex:1;position:relative}.quiver-input{width:100%;padding:10px 12px;border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--bg);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.quiver-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 12%,transparent)}.quiver-input--size{width:80px;flex-shrink:0;text-align:center}.quiver-brand-suggestions{position:absolute;top:100%;left:0;right:0;background:#ffffffeb;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border:1px solid var(--glass-border);border-radius:var(--radius-sm);margin-top:2px;z-index:10;box-shadow:0 4px 12px #0000001a}.quiver-brand-option{display:block;width:100%;padding:8px 10px;border:none;background:none;color:var(--text);font-size:13px;text-align:left;cursor:pointer;font-family:inherit}.quiver-brand-option:hover{background:color-mix(in srgb,var(--accent) 10%,transparent)}.quiver-add-actions{display:flex;gap:8px;margin-top:12px}.quiver-cancel-btn,.quiver-save-btn{flex:1;padding:10px 16px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .15s;text-align:center}.quiver-cancel-btn{background:var(--bg);color:var(--muted);border:1px solid var(--glass-border)}.quiver-cancel-btn:hover{color:var(--text);border-color:var(--text)}.quiver-save-btn{background:var(--accent);color:#fff;box-shadow:0 2px 8px #06f3}.quiver-save-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.quiver-save-btn:not(:disabled):hover{box-shadow:0 4px 12px #0066ff59}.quiver-board-toggles{display:flex;gap:8px;margin-top:4px}.quiver-board-toggle{flex:1;padding:12px 8px;border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--surface);color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s;font-family:inherit}.quiver-board-toggle--active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));color:var(--accent);box-shadow:0 2px 8px color-mix(in srgb,var(--accent) 12%,transparent)}.quiver-board-toggle:hover:not(.quiver-board-toggle--active){border-color:var(--muted);background:var(--bg)}.sh-link-btn{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:box-shadow .15s}.sh-link-btn:hover{box-shadow:0 2px 8px #0000000a}.sh-link-btn svg{color:var(--accent);flex-shrink:0}.sh-link-btn span:first-of-type{flex:1;text-align:left}.sh-link-count{font-size:12px;font-weight:700;color:var(--muted);background:color-mix(in srgb,var(--accent) 10%,transparent);padding:2px 8px;border-radius:10px}[data-theme=dark] .sh-link-btn,[data-theme=dark] .quiver-sail-row{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .quiver-add-form{background:var(--surface);border-color:var(--accent)}[data-theme=dark] .quiver-input{background:var(--bg)}[data-theme=dark] .quiver-brand-suggestions{background:#0d1829eb;border-color:var(--glass-border);box-shadow:0 4px 16px #0000004d}[data-theme=dark] .quiver-board-toggle{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .quiver-cancel-btn{background:var(--bg);border-color:var(--glass-border)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body.native-app{background:var(--bg)!important;margin:0!important;padding:0!important;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}.native-app input,.native-app textarea,.native-app [contenteditable]{-webkit-user-select:text;-webkit-touch-callout:default}body.native-app:before{display:none!important}.native-app .app-shell{max-width:none!important;margin:0!important;border:none!important;border-radius:0!important;box-shadow:none!important;height:100vh!important;height:100dvh!important}.native-app .titlebar{border-radius:0!important}.native-app .sidebar{border-radius:0!important;border-bottom:none!important}.native-app .modal,.native-app .add-spot-modal,.native-app .settings-panel,.native-app .sh-panel,.native-app .log-modal{border-radius:0!important;max-height:100dvh!important;height:100dvh!important;width:100%!important;max-width:100%!important}.native-app .modal-backdrop{padding-top:0!important;align-items:stretch!important}.native-ios .titlebar{padding-top:env(safe-area-inset-top)!important}.native-ios .modal-header,.native-ios .settings-header,.native-ios .sh-header,.native-ios .log-modal-header,.native-ios .addspot-header{padding-top:calc(env(safe-area-inset-top) + 8px)!important}.native-ios .modal,.native-ios .settings-panel,.native-ios .sh-panel,.native-ios .log-modal{padding-bottom:env(safe-area-inset-bottom)!important}.native-ios .modal,.native-ios .settings-panel,.native-ios .sh-panel,.native-ios .log-modal,.native-ios .add-spot-modal{animation-timing-function:cubic-bezier(.2,.9,.3,1)!important}.native-ios .sidebar-spot,.native-ios .settings-toggle,.native-ios .settings-unit-option,.native-ios .day-card,.native-ios .quiver-sail-row{min-height:44px}.native-android .titlebar{padding-top:env(safe-area-inset-top)!important}.native-android .modal-header,.native-android .settings-header,.native-android .sh-header,.native-android .log-modal-header,.native-android .addspot-header{padding-top:calc(env(safe-area-inset-top) + 8px)!important}.native-android .modal,.native-android .settings-panel,.native-android .sh-panel,.native-android .log-modal{padding-bottom:env(safe-area-inset-bottom)!important}.native-android .sidebar-spot,.native-android .settings-toggle,.native-android .settings-unit-option,.native-android .day-card,.native-android .quiver-sail-row{min-height:48px}.ptr-indicator{display:flex;align-items:center;justify-content:center;overflow:hidden;transition:height .2s ease}.ptr-spinner{animation:spin .8s linear infinite}.glance-trigger{display:none;flex-shrink:0;cursor:pointer;align-items:center;justify-content:center;transition:opacity .2s;border:none;background:transparent}.glance-trigger:active{opacity:.6}.modal--glance{display:flex;flex-direction:column;background:var(--bg)}.glance-list{flex:1;overflow-y:auto;padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4);-webkit-overflow-scrolling:touch}.glance-empty{text-align:center;padding:40px 0;color:var(--muted);font-size:14px}.glance-card{position:relative;background:var(--panel-glass);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border-radius:var(--radius-lg);border:1px solid var(--glass-border);padding:var(--sp-4) var(--sp-5) var(--sp-4) 24px;box-shadow:0 4px 16px #0000000a,inset 0 1px #ffffff1a;display:flex;flex-direction:column;gap:10px;flex:0 0 auto}[data-theme=dark] .glance-card{background:var(--panel)}.glance-card-header{display:flex;align-items:center;justify-content:space-between}.glance-card-spot{display:flex;align-items:center;gap:8px;min-width:0}.glance-card-name{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glance-card-meta{display:flex;align-items:center;gap:14px;flex-shrink:0}.glance-card-temp{font-size:13px;color:var(--muted);font-weight:600}.glance-card-wind{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:800}.glance-card-loading{height:50px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted)}.glance-bar-wrap{display:flex;align-items:center;gap:8px}.glance-bar{flex:1;display:flex;height:16px;border-radius:8px;overflow:hidden;gap:1.5px;background:var(--border)}.glance-bar-day{flex:1;display:flex;min-width:0;gap:0}.glance-bar-segment{flex:1;min-width:0;opacity:.85}.glance-bar-day:first-child .glance-bar-segment:first-child{border-radius:8px 0 0 8px}.glance-bar-day:last-child .glance-bar-segment:last-child{border-radius:0 8px 8px 0}.glance-day-labels{display:flex;padding-left:20px}.glance-day-label{flex:1;text-align:center;font-size:9px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;display:flex;align-items:center;justify-content:center;gap:2px}.glance-day-label--today{font-weight:800;color:var(--accent)}.glance-day-label svg{color:#5ba3e6;opacity:.7}.glance-card-handle{position:absolute;left:5px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--muted);opacity:.25;line-height:1;user-select:none;pointer-events:none}.glance-card-wrap{position:relative}.glance-drag-zone{position:absolute;left:0;top:0;bottom:0;width:36px;cursor:grab;z-index:10;-webkit-tap-highlight-color:transparent}.glance-drag-zone:active{cursor:grabbing}.glance-card-wrap--dragging{opacity:.3}.glance-card-wrap--over{box-shadow:0 -3px 0 0 var(--accent) inset}.glance-add-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 0;flex:0 0 auto;border:2px dashed var(--border);border-radius:var(--radius-lg);background:var(--panel-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--accent);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.glance-add-btn:hover{border-color:var(--accent);background:var(--accent-light)}.glance-add-btn:active{transform:scale(.98)}@media(max-width:768px){.glance-trigger{display:flex;width:58px;height:40px;align-self:center;position:relative}.glance-trigger:after{content:"";position:absolute;right:-24px;top:0;bottom:0;width:24px;background:linear-gradient(to right,rgba(255,255,255,.55),transparent);pointer-events:none;z-index:1}}@media(min-width:769px){.glance-trigger{display:none}}.glance-titlebar-btn{display:none}@media(min-width:769px){.glance-titlebar-btn{display:flex;border-radius:var(--radius);border:1px solid var(--border);background:var(--panel-solid);backdrop-filter:none;box-shadow:none}}
