@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap";.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}}.fishing-map-container{position:relative;width:100%;height:100%;min-height:100vh;min-height:100dvh;background:var(--bg-primary);z-index:var(--z-base);isolation:isolate}.fishing-map{width:100%;height:100%;min-height:100vh;min-height:100dvh;background:var(--bg-primary)}.map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;height:100dvh;background:var(--bg-primary);color:var(--text-secondary);font-family:var(--font-mono)}.loading-icon{display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}.loading-spinner-icon{animation:spin 1s linear infinite}.loading-text{font-size:var(--text-base);color:var(--text-secondary);letter-spacing:.05em}.spot-marker{cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.spot-marker:hover{transform:scale(1.15)}.spot-marker.active .marker-dot{animation:breathe 2s var(--ease-water) infinite}.spot-marker.marker-pulse-excellent .marker-glow{animation:pulse-excellent 2s var(--ease-water) infinite}@keyframes pulse-excellent{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:.8;transform:translate(-50%,-50%) scale(1.3)}}.spot-cluster{position:relative}.cluster-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;background:var(--color-water);opacity:.25;filter:blur(8px);border-radius:50%;animation:breathe 3s var(--ease-water) infinite}.cluster-circle{display:flex;align-items:center;justify-content:center;background:var(--gray-3);border:2px solid var(--color-water);border-radius:50%;box-shadow:var(--glow-water);position:relative;z-index:1}.cluster-count{font-family:var(--font-mono);font-size:var(--text-base);font-weight:700;color:var(--text-primary)}.spot-popup .leaflet-popup-content-wrapper{background:var(--gray-2);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--glow-water);padding:0}.spot-popup .leaflet-popup-content{margin:0;font-family:var(--font-mono)}.spot-popup .leaflet-popup-tip{background:var(--gray-2);border:1px solid var(--border-primary)}.popup-content{padding:var(--space-4);min-width:180px}.popup-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.popup-emoji{font-size:1.25rem}.popup-name{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.popup-species{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-3)}.popup-btn{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-water);color:var(--gray-1);border:none;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.popup-btn:hover{background:var(--accent-10);box-shadow:var(--glow-water)}.map-widgets-top-left{position:absolute;top:var(--map-widget-inset-top);left:var(--map-widget-inset-left);display:flex;flex-direction:column;gap:var(--map-widget-stack-gap);z-index:var(--z-map-overlay);pointer-events:none}.map-widgets-top-left>*{pointer-events:auto}.map-widgets-top-right{position:absolute;top:var(--map-widget-inset-top);right:var(--map-widget-inset-right);display:flex;flex-direction:column;align-items:flex-end;gap:var(--map-widget-stack-gap);z-index:var(--z-map-overlay);pointer-events:none}.map-widgets-top-right>*{pointer-events:auto}.map-widgets-bottom-left{position:absolute;bottom:var(--map-widget-inset-bottom);left:var(--map-widget-inset-left);display:flex;flex-direction:column-reverse;gap:var(--map-widget-stack-gap);z-index:var(--z-map-overlay);pointer-events:none}.map-widgets-bottom-left>*{pointer-events:auto}.map-widgets-bottom-right{position:absolute;bottom:var(--map-widget-inset-bottom);right:var(--map-widget-inset-right);display:flex;flex-direction:column-reverse;align-items:flex-end;gap:var(--map-widget-stack-gap);z-index:var(--z-map-overlay);pointer-events:none}.map-widgets-bottom-right>*{pointer-events:auto}.map-widgets-bottom-center{position:absolute;bottom:var(--map-widget-inset-bottom);left:var(--map-widget-inset-left);right:var(--map-widget-inset-right);display:flex;flex-direction:column-reverse;gap:var(--map-widget-stack-gap);z-index:var(--z-map-overlay);pointer-events:none}.map-widgets-bottom-center>*{pointer-events:auto}.fire-notice-widget{position:relative;width:180px;background:linear-gradient(135deg,#1e1e1ef2,#281914f2);border:1px solid rgba(220,38,38,.4);border-radius:var(--radius-lg);padding:var(--space-3);z-index:var(--z-map-overlay);box-shadow:0 4px 20px #0006,0 0 20px #dc262626;pointer-events:auto}.fire-notice-content{display:flex;align-items:flex-start;gap:var(--space-2);margin-bottom:var(--space-2)}.fire-notice-icon{font-size:1.5rem;line-height:1;filter:drop-shadow(0 0 4px rgba(255,100,0,.5))}.fire-notice-text{display:flex;flex-direction:column;gap:2px}.fire-notice-text strong{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:#fbbf24;letter-spacing:.02em}.fire-notice-text span{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary)}.fire-notice-attribution{font-family:var(--font-mono);font-size:9px;color:var(--text-muted);text-align:center;padding-top:var(--space-2);border-top:1px solid rgba(255,255,255,.1);margin-top:var(--space-2)}.fire-notice-attribution a{color:#f87171;text-decoration:none}.fire-notice-attribution a:hover{text-decoration:underline}.sky-dome-widget{display:none;position:relative;width:180px;background:var(--gray-2);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-3);box-shadow:var(--shadow-lg);pointer-events:auto}.sky-dome-svg{width:100%;height:80px;display:block}.sky-direction-label{font-family:var(--font-mono);font-size:10px;fill:var(--text-muted);font-weight:600}.sky-sun-marker{position:absolute;transform:translate(-50%,-50%);font-size:1.25rem;filter:drop-shadow(0 0 8px #fbbf24);animation:sun-glow 2s ease-in-out infinite;pointer-events:none}@keyframes sun-glow{0%,to{filter:drop-shadow(0 0 8px #fbbf24)}50%{filter:drop-shadow(0 0 12px #fbbf24)}}.sky-times{display:flex;justify-content:space-between;margin-top:var(--space-2);font-family:var(--font-mono);font-size:var(--text-xs)}.sky-time{color:var(--text-muted)}.sky-time.sunrise{color:var(--color-sunrise)}.sky-time.current{color:var(--text-primary);font-weight:600}.sky-time.sunset{color:var(--color-sunset)}.sky-altitude{text-align:center;margin-top:var(--space-1);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary)}.map-legend{position:relative;display:flex;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--gray-2);border:1px solid var(--border-primary);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--gray-11);box-shadow:var(--shadow-lg)}.legend-item{display:flex;align-items:center;gap:var(--space-2)}.legend-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 6px currentColor}.legend-dot.pier{background:var(--color-spot-pier);box-shadow:0 0 6px var(--color-spot-pier)}.legend-dot.rocks{background:var(--color-spot-rocks);box-shadow:0 0 6px var(--color-spot-rocks)}.legend-dot.beach{background:var(--color-spot-beach);box-shadow:0 0 6px var(--color-spot-beach)}.legend-dot.custom{background:var(--color-spot-custom);box-shadow:0 0 6px var(--color-spot-custom)}.spot-marker.custom .marker-dot{animation:pulse-purple 1.5s var(--ease-water) infinite}@keyframes pulse-purple{0%,to{box-shadow:0 0 8px #bfa6d9}50%{box-shadow:0 0 16px #bfa6d9,0 0 24px #bfa6d980}}.popup-coords{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.map-hint{position:absolute;bottom:calc(var(--map-widget-inset-bottom) + var(--space-14, 56px));left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-4);background:var(--gray-2);border:1px solid var(--border-primary);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);color:#c0c8d0;z-index:calc(var(--z-map-overlay) + 1);box-shadow:var(--shadow-lg);pointer-events:none;opacity:.9;animation:hint-fade 3s ease-in-out infinite}@keyframes hint-fade{0%,to{opacity:.7}50%{opacity:.95}}.map-attribution{position:absolute;bottom:calc(var(--safe-area-bottom) + var(--space-2));right:calc(var(--safe-area-right) + var(--space-2));z-index:var(--z-map-overlay);display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:9px;font-family:var(--font-mono);color:var(--text-muted);opacity:.7;transition:opacity .2s ease}.map-attribution:hover{opacity:1}.map-attribution a{color:var(--text-muted);text-decoration:none;padding:1px 4px;border-radius:var(--radius-sm);transition:all .15s ease}.map-attribution a:hover{color:var(--text-link);background:var(--gray-3)}.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow-lg)!important}.leaflet-control-zoom a{background:var(--gray-2)!important;color:var(--gray-12)!important;border:1px solid var(--border-primary)!important;font-family:var(--font-mono)!important;font-weight:700!important;font-size:18px!important}.leaflet-control-zoom a:hover{background:var(--gray-3)!important}.leaflet-control-attribution{background:var(--gray-2)!important;color:var(--text-muted)!important;font-family:var(--font-mono)!important;font-size:10px!important;padding:2px 6px!important}.leaflet-control-attribution a{color:var(--text-link)!important}.leaflet-popup-close-button{color:var(--text-secondary)!important;font-size:20px!important;width:24px!important;height:24px!important;padding:4px!important;top:8px!important;right:8px!important}.leaflet-popup-close-button:hover{color:var(--text-primary)!important;background:var(--bg-tertiary)!important;border-radius:var(--radius-sm)}.leaflet-control-layers{background:var(--bg-secondary)!important;border:1px solid var(--border-primary)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;color:var(--text-primary)!important}.leaflet-control-layers-toggle{background-color:var(--bg-secondary)!important;border:1px solid var(--border-primary)!important}.leaflet-control-layers-expanded{padding:var(--space-2) var(--space-3)!important}.leaflet-control-layers-separator{border-top-color:var(--border-primary)!important}.leaflet-control-scale-line{background:var(--bg-secondary)!important;border-color:var(--border-primary)!important;color:var(--text-secondary)!important;font-family:var(--font-mono)!important;font-size:10px!important}.leaflet-touch-zoom{border:2px solid var(--accent-primary)!important;background:#a6ddd91a!important}.emergency-controls{position:relative;display:flex;gap:var(--space-2)}.emergency-toggle:hover,.audio-toggle:hover{transform:scale(1.02);box-shadow:0 4px 12px #0000004d}.nearby-alerts-widget{position:absolute;bottom:var(--map-widget-inset-bottom);left:var(--map-widget-inset-left);right:var(--map-widget-inset-right);z-index:var(--z-map-overlay)}.nearby-alerts-btn.request{display:flex;align-items:center;gap:12px;width:100%;padding:14px 18px;background:linear-gradient(135deg,#dc2626e6,#b91c1cf2);border:1px solid rgba(248,113,113,.4);border-radius:14px;color:#fff;font-family:var(--font-mono);cursor:pointer;box-shadow:0 4px 24px #dc262659,inset 0 1px #ffffff1a;transition:all .2s ease;text-align:left}.nearby-alerts-btn.request:hover{transform:translateY(-2px);box-shadow:0 8px 32px #dc262673}.nearby-alerts-btn.request:active{transform:translateY(0)}.request-content{display:flex;flex-direction:column;gap:2px}.request-title{font-size:14px;font-weight:600;letter-spacing:.01em}.request-subtitle{font-size:11px;opacity:.8;font-weight:400}.nearby-alerts-btn .spinning{animation:spin 1s linear infinite}.nearby-alerts-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#1e1e1ee6;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text-secondary);font-size:13px}.retry-btn{margin-left:auto;padding:4px 10px;background:#ffffff1a;border:none;border-radius:6px;color:#fff;font-size:12px;cursor:pointer}.nearby-alerts-container{background:#141414f2;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nearby-alerts-summary{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;background:transparent;border:none;color:#fff;font-family:var(--font-mono);font-size:13px;cursor:pointer;transition:background .2s ease}.nearby-alerts-summary:hover{background:#ffffff0d}.nearby-alerts-summary.has-emergency{background:#dc262633;animation:emergency-pulse-bg 2s ease-in-out infinite}.nearby-alerts-summary.danger-close{background:#dc262680;border-left:4px solid #dc2626;animation:danger-flash 1s ease-in-out infinite}@keyframes danger-flash{0%,to{background:#dc262666}50%{background:#dc262699}}.critical-text{color:#fecaca}.critical-text strong{color:#ef4444;text-transform:uppercase;animation:text-pulse 1s ease-in-out infinite}@keyframes text-pulse{0%,to{opacity:1}50%{opacity:.7}}.safe-text{color:#86efac}@keyframes emergency-pulse-bg{0%,to{background:#dc262626}50%{background:#dc262640}}.summary-left{display:flex;align-items:center;gap:8px}.emergency-text{color:#fca5a5}.emergency-text strong{color:#f87171}.summary-right{display:flex;align-items:center;gap:10px;color:var(--text-secondary)}.alert-count{font-size:11px;padding:2px 8px;background:#ffffff1a;border-radius:10px}.expand-icon{font-size:10px;transition:transform .2s ease}.expand-icon.expanded{transform:rotate(180deg)}.nearby-alerts-list{border-top:1px solid rgba(255,255,255,.1);max-height:200px;overflow-y:auto}.alert-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:#fff;font-family:var(--font-mono);font-size:12px;cursor:pointer;text-align:left;transition:background .15s ease}.alert-item:hover{background:#ffffff0d}.alert-item:last-child{border-bottom:none}.alert-item.emergency{background:#dc26261a}.alert-item.emergency:hover{background:#dc262633}.alert-item.watch-act{background:#f59e0b1a}.alert-item-left{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.alert-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.alert-item.emergency .alert-badge{color:#f87171}.alert-item.watch-act .alert-badge{color:#fbbf24}.alert-item.advice .alert-badge{color:#60a5fa}.alert-location{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert-item-right{display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.alert-distance{font-weight:600;color:#fff}.more-alerts{padding:8px 14px;text-align:center;font-size:11px;color:var(--text-muted)}.support-button-float{position:relative;display:flex;align-items:center;gap:6px;padding:10px 14px;background:linear-gradient(135deg,#ec4899e6,#db2777f2);border:1px solid rgba(244,114,182,.4);border-radius:20px;color:#fff;font-family:var(--font-mono);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #db27774d;transition:all .2s ease}.support-button-float:hover{transform:translateY(-2px);box-shadow:0 6px 20px #db277766}.support-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-toast);padding:var(--space-4)}.support-modal{position:relative;width:100%;max-width:360px;background:linear-gradient(180deg,#1a1a2e,#16162a);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:var(--space-6);box-shadow:0 20px 60px #00000080}.support-modal-close{position:absolute;top:var(--space-3);right:var(--space-3);padding:8px;background:#ffffff1a;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.support-modal-close:hover{background:#ffffff26;color:#fff}.support-modal-header{text-align:center;margin-bottom:var(--space-5)}.support-icon{color:#f472b6;margin-bottom:var(--space-3)}.support-modal-header h3{font-family:var(--font-mono);font-size:18px;font-weight:700;color:#fff;margin:0 0 var(--space-2) 0}.support-modal-header p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0}.support-coffee-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;background:linear-gradient(135deg,#ec4899e6,#db2777f2);border:1px solid rgba(244,114,182,.5);border-radius:12px;color:#fff;font-family:var(--font-mono);font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px #db27774d;transition:all .2s ease;margin-top:var(--space-4);margin-bottom:var(--space-4)}.support-coffee-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #db277766}.support-coffee-btn:active{transform:translateY(0)}.amount-btn .label{font-size:11px;color:var(--text-secondary)}.support-custom-btn{width:100%;padding:var(--space-3);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--text-secondary);font-family:var(--font-mono);font-size:13px;cursor:pointer;transition:all .2s ease;margin-bottom:var(--space-4)}.support-custom-btn:hover{background:#ffffff1a;color:#fff}.support-note{font-size:11px;color:var(--text-muted);text-align:center;margin:0 0 var(--space-3) 0}.support-dismiss{width:100%;padding:var(--space-2);background:transparent;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;transition:color .2s ease}.support-dismiss:hover{color:var(--text-secondary)}@media(max-width:767px){.map-legend{justify-content:center;font-size:var(--text-xs)}.map-widgets-bottom-left{right:var(--map-widget-inset-right)}.support-button-float{padding:8px 12px;font-size:12px}}.mode-toggle{position:relative;display:flex;align-items:center;gap:6px;padding:8px 14px;background:#1e1e1ee6;border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#fff;font-family:var(--font-mono);font-size:12px;font-weight:500;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease}.mode-toggle:hover{background:#323232f2;border-color:#ffffff4d}.mode-toggle.fire{background:#dc262626;border-color:#f8717166}.mode-toggle.fishing{background:#8cd4d426;border-color:#8cd4d466}.mode-toggle-icon{font-size:14px}.mode-toggle-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px}.my-location-btn{position:absolute;top:calc(var(--map-widget-inset-top) + var(--map-btn-size, 40px) + var(--space-2));right:var(--map-widget-inset-right);display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#1e1e1ee6;border:1px solid rgba(255,255,255,.2);border-radius:10px;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease;z-index:var(--z-map-overlay)}.my-location-btn:hover:not(:disabled){background:#323232f2;transform:scale(1.05)}.my-location-btn.active{background:#3b82f6e6;border-color:#60a5fa80;box-shadow:0 0 12px #3b82f666}.my-location-btn .spin{animation:spin 1s linear infinite}.ranked-spots{position:absolute;bottom:var(--map-widget-inset-bottom);left:var(--map-widget-inset-left);right:var(--map-widget-inset-right);z-index:var(--z-modal);background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;transition:all var(--duration-normal) var(--ease-default)}.ranked-spots.collapsed{bottom:calc(var(--safe-area-bottom) + var(--space-card-gap))}.ranked-spots-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-card-gap);background:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:background var(--duration-fast) var(--ease-default)}.ranked-spots-header:hover{background:var(--surface-card-hover)}.ranked-spots-header:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.ranked-header-left{display:flex;align-items:center;gap:var(--space-card-gap-compact)}.ranked-title{font-size:var(--type-callout);font-weight:600;text-transform:capitalize}.ranked-header-right{display:flex;align-items:center;gap:var(--space-card-gap-compact);color:var(--text-secondary)}.top-score{font-size:var(--type-body);font-weight:700;font-family:var(--font-mono)}.ranked-species-selector{display:flex;gap:var(--space-card-gap-compact);padding:0 var(--space-card-gap) var(--space-card-gap-compact);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.ranked-species-selector::-webkit-scrollbar{display:none}.ranked-species-chip{flex-shrink:0;min-height:var(--size-touch-min);padding:var(--space-card-gap-compact) var(--space-card-gap);font-size:var(--type-caption);font-weight:500;color:var(--text-tertiary);background:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap;display:flex;align-items:center}.ranked-species-chip:hover{color:var(--text-secondary);border-color:var(--border-medium)}.ranked-species-chip.active{color:var(--brand-text);background:var(--brand-subtle);border-color:var(--brand-primary)}.ranked-species-chip:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.ranked-spots-list{max-height:220px;overflow-y:auto;border-top:1px solid var(--border-subtle)}.ranked-spot-row{display:flex;align-items:center;gap:var(--space-card-gap-compact);padding:var(--space-card-gap-compact) var(--space-card-gap);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--duration-fast) var(--ease-default);position:relative}.ranked-spot-row:hover{background:var(--surface-card-hover)}.ranked-spot-row:last-child{border-bottom:none}.ranked-spot-row:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.spot-rank{width:var(--size-icon-sm);height:var(--size-icon-sm);display:flex;align-items:center;justify-content:center;font-size:var(--type-caption);font-weight:700;color:var(--text-tertiary);background:var(--surface-subtle);border-radius:var(--radius-full);flex-shrink:0}.ranked-spot-row:first-child .spot-rank{color:var(--brand-text);background:var(--brand-subtle)}.spot-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-map-gap)}.spot-info .spot-name{font-size:var(--type-caption);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spot-info .spot-type{font-size:var(--type-footnote);color:var(--text-tertiary);text-transform:capitalize}.spot-metrics{display:flex;align-items:center;gap:var(--space-card-gap-compact);flex-shrink:0}.spot-score{font-size:var(--type-body);font-weight:700;font-family:var(--font-mono);min-width:28px;text-align:right}.spot-travel{font-size:var(--type-caption);color:var(--text-secondary);font-family:var(--font-mono);min-width:32px;text-align:right}.spot-nav-btn{display:flex;align-items:center;justify-content:center;width:var(--size-touch-min);height:var(--size-touch-min);background:var(--surface-subtle);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);flex-shrink:0}.spot-nav-btn:hover{background:var(--accent-subtle);border-color:var(--accent-primary);color:var(--accent-primary)}.spot-nav-btn:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.nav-options{position:absolute;right:var(--space-card-gap);top:100%;z-index:var(--z-elevated);display:flex;flex-direction:column;min-width:140px;background:var(--bg-elevated);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden}.nav-options button{padding:var(--space-card-gap-compact) var(--space-card-gap);font-size:var(--type-caption);color:var(--text-primary);background:transparent;border:none;text-align:left;cursor:pointer;transition:background var(--duration-fast) var(--ease-default)}.nav-options button:hover{background:var(--surface-card-hover)}.nav-options button:not(:last-child){border-bottom:1px solid var(--border-subtle)}.nav-options button:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.ranked-hint{display:flex;align-items:center;justify-content:center;gap:var(--space-input-gap);padding:var(--space-card-gap-compact);font-size:var(--type-caption);color:var(--text-muted);border-top:1px solid var(--border-subtle)}.ranked-hint.location-needed{color:var(--text-tertiary)}.no-spots-message{padding:var(--space-card-padding);text-align:center;font-size:var(--type-caption);color:var(--text-tertiary)}@media(min-width:768px){.ranked-spots{left:auto;right:var(--page-gutter);width:320px;bottom:var(--page-gutter)}}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);max-width:400px;width:calc(100% - var(--space-8));pointer-events:none}.toast-wrapper{pointer-events:auto;animation:toast-slide-in var(--duration-normal) var(--ease-out) forwards}.toast-wrapper--removing{animation:toast-slide-out var(--duration-fast) var(--ease-out) forwards}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--surface-panel);border:1px solid var(--border-primary);box-shadow:var(--shadow-lg);font-size:var(--font-size-sm);color:var(--text-primary)}.toast__icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-md);border-radius:var(--radius-full)}.toast__message{flex:1;line-height:var(--line-height-normal)}.toast__close{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:var(--font-size-lg);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.toast__close:hover{color:var(--text-primary);background:var(--surface-card-hover)}.toast__close:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.toast--info{background:var(--status-info-bg);border-color:var(--status-info-border)}.toast--info .toast__icon{color:var(--status-info-text)}.toast--success{background:var(--status-success-bg);border-color:var(--status-success-border)}.toast--success .toast__icon{color:var(--status-success-text)}.toast--warning{background:var(--status-warning-bg);border-color:var(--status-warning-border)}.toast--warning .toast__icon{color:var(--status-warning-text)}.toast--error{background:var(--status-error-bg);border-color:var(--status-error-border)}.toast--error .toast__icon{color:var(--status-error-text)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media(prefers-reduced-motion:reduce){.toast-wrapper,.toast-wrapper--removing{animation:none}.toast-wrapper{opacity:1}.toast-wrapper--removing{opacity:0}}@media(max-width:480px){.toast-container{left:var(--space-3);right:var(--space-3);width:auto;max-width:none}.toast{padding:var(--space-3)}}.share-prompt{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-panel);background:var(--bg-elevated);border-top:1px solid var(--border-primary);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom));box-shadow:var(--shadow-lg);animation:share-slide-up var(--duration-slow) var(--ease-out)}@keyframes share-slide-up{0%{transform:translateY(100%);opacity:0}60%{transform:translateY(-4px)}to{transform:translateY(0);opacity:1}}@media(prefers-reduced-motion:reduce){.share-prompt{animation:none}}.share-prompt-close{position:absolute;top:var(--space-3);right:var(--space-3);display:flex;align-items:center;justify-content:center;width:var(--space-8);height:var(--space-8);background:transparent;border:none;border-radius:var(--radius-full);color:var(--text-tertiary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.share-prompt-close:hover:not(:disabled){background:var(--surface-card-hover);color:var(--text-secondary)}.share-prompt-close:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.share-prompt-close:disabled{opacity:.5;cursor:not-allowed}.share-prompt-content{max-width:400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-2)}.share-prompt-icon{display:flex;align-items:center;justify-content:center;width:var(--space-12);height:var(--space-12);background:var(--brand-subtle);border-radius:var(--radius-full);color:var(--brand-primary);margin-bottom:var(--space-1)}.share-prompt-title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.share-prompt-text{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:var(--leading-normal)}.share-prompt-actions{width:100%;margin-top:var(--space-2)}.share-btn-primary{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-weight:600;color:var(--text-on-accent);background:var(--brand-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.share-btn-primary:hover:not(:disabled){background:var(--brand-hover)}.share-btn-primary:disabled{opacity:.7;cursor:not-allowed}.share-btn-primary:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.share-prompt-secondary{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-2)}.share-btn-text{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary);background:transparent;border:none;cursor:pointer;transition:color var(--duration-fast) var(--ease-default)}.share-btn-text:hover:not(:disabled){color:var(--text-secondary)}.share-btn-text:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.share-btn-text:disabled{opacity:.5;cursor:not-allowed}@media(max-width:767px){.share-prompt{padding:var(--space-3);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom))}.share-prompt-title{font-size:var(--text-base)}.share-prompt-text{font-size:var(--text-xs)}}.wave-loader{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6)}.wave-loader__ripples{position:relative;width:60px;height:60px}.wave-loader__ripple{position:absolute;inset:0;border:2px solid var(--color-water);border-radius:50%;opacity:0;animation:ripple 2.5s ease-out infinite}.wave-loader__ripple:nth-child(2){animation-delay:.5s}.wave-loader__ripple:nth-child(3){animation-delay:1s}@keyframes ripple{0%{transform:scale(.5);opacity:.8}to{transform:scale(1.5);opacity:0}}.wave-loader__message{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);letter-spacing:.02em}@media(prefers-reduced-motion:reduce){.wave-loader__ripple{animation:none;opacity:.3;transform:scale(1)}}.layer-toggles{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle)}.layer-chip{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);min-height:44px;background:var(--gray-3);border:1px solid var(--border-subtle);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) ease}.layer-chip:hover{background:var(--gray-4);color:var(--text-secondary)}.layer-chip.active{background:var(--accent-3);border-color:var(--accent-6);color:var(--accent-11)}.layer-chip.active svg{color:var(--color-water)}.layer-chip svg{flex-shrink:0}.factor-breakdown{margin-top:var(--space-3)}.factor-breakdown-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3);background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease}.factor-breakdown-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.factor-breakdown-toggle:focus-visible{outline:2px solid var(--accent-7);outline-offset:2px}.factor-breakdown-toggle-text{text-transform:uppercase;letter-spacing:.05em}.factor-breakdown-content{margin-top:var(--space-3);padding:var(--space-3);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.factor-breakdown-content{animation:none}}.factor-section{margin-bottom:var(--space-4);padding:var(--space-2)}.factor-section:last-child{margin-bottom:0}.factor-section-header{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);padding-bottom:var(--space-2);margin-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.factor-section--helping .factor-section-header{color:var(--score-go)}.factor-section--hurting .factor-section-header{color:var(--score-skip)}.factor-section-count{font-weight:500;opacity:.7}.factor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}@media(max-width:767px){.factor-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:360px){.factor-grid{grid-template-columns:1fr}}.factor-card{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-2);background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle);min-height:80px;text-align:center;transition:border-color .15s ease,background .15s ease;cursor:pointer;font-family:inherit;width:100%}.factor-card:hover{border-color:var(--border-default)}.factor-card:focus-visible{outline:2px solid var(--accent-7);outline-offset:2px}.factor-card--expanded{grid-column:1 / -1;background:var(--bg-elevated);align-items:stretch}.factor-card-summary{display:flex;flex-direction:column;align-items:center;width:100%}.factor-card--expanded .factor-card-summary{flex-direction:row;justify-content:flex-start;gap:var(--space-2)}.factor-card--helping{border-left:3px solid var(--score-go)}.factor-card--neutral{border-left:3px solid var(--text-muted)}.factor-card--hurting{border-left:3px solid var(--score-skip)}.factor-card-icon{font-size:18px;margin-bottom:var(--space-1)}.factor-card--expanded .factor-card-icon{margin-bottom:0}.factor-card-label{font-family:var(--font-mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:var(--space-1)}.factor-card--expanded .factor-card-label{margin-bottom:0}.factor-card-value{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1);font-variant-numeric:tabular-nums}.factor-card--expanded .factor-card-value{margin-bottom:0}.factor-card-status{font-family:var(--font-mono);font-size:10px;font-weight:600}.factor-card-status--helping{color:var(--score-go)}.factor-card-status--neutral{color:var(--text-muted)}.factor-card-status--hurting{color:var(--score-skip)}.factor-card-education{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border-subtle);text-align:left;font-size:12px;line-height:1.5}.factor-edu-what,.factor-edu-why{margin-bottom:var(--space-1);color:var(--text-secondary)}.factor-edu-what strong,.factor-edu-why strong{color:var(--text-primary)}.factor-edu-tip{color:var(--text-primary);font-style:italic;background:var(--bg-subtle);padding:var(--space-2);border-radius:var(--radius-sm);margin-top:var(--space-2)}.factor-card-education--empty{color:var(--text-muted);font-style:italic}.factor-breakdown-empty{text-align:center;padding:var(--space-4);color:var(--text-muted);font-size:13px}.fishing-verdict{margin-top:var(--space-3);background:var(--gray-2);border-radius:var(--radius-lg);border:1px solid var(--border-primary);overflow:hidden}.safety-warning{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--error-2);border-left:3px solid var(--error-9);color:var(--error-11);font-size:12px;font-weight:600}.safety-warning--minor{background:var(--warning-2);border-left-color:var(--warning-9);color:var(--warning-11)}.verdict-hero{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:linear-gradient(135deg,var(--gray-3),var(--gray-2));border-bottom:1px solid var(--border-subtle)}.verdict-emoji{font-size:2rem;line-height:1}.verdict-text{display:flex;flex-direction:column;gap:2px}.verdict-phrase{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-primary)}.verdict-reason{font-family:var(--font-mono);font-size:11px;color:var(--color-water)}.verdict-factors{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.factor-badge{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2);background:var(--gray-2)}.factor-icon{position:relative;font-size:14px;line-height:1}.trend-indicator{position:absolute;top:-4px;right:-6px;font-size:10px;color:var(--warning-9);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.factor-label{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.factor-value{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-primary)}.factor-context{font-weight:500;color:var(--text-muted);font-size:10px;font-style:italic}.factor-badge.good .factor-value{color:var(--score-go)}.factor-badge.fair .factor-value{color:var(--score-maybe)}.factor-badge.marginal .factor-value{color:var(--score-skip)}.factor-badge.neutral .factor-value{color:var(--text-secondary)}.factor-badge.excellent .factor-value{color:var(--score-go)}.factor-badge.poor .factor-value{color:var(--status-error)}.factor-badge.good{border-bottom:2px solid var(--score-go)}.factor-badge.fair{border-bottom:2px solid var(--score-maybe)}.factor-badge.marginal{border-bottom:2px solid var(--score-skip)}.factor-badge.neutral{border-bottom:2px solid var(--text-muted)}.factor-badge.excellent{border-bottom:2px solid var(--score-go)}.factor-badge.poor{border-bottom:2px solid var(--status-error)}.factor-badge--hero{padding:var(--space-3) var(--space-2);border-left:3px solid var(--accent-9);box-shadow:0 2px 8px #46b9af26}.factor-badge--hero.good{box-shadow:0 2px 12px #46b9af40,0 0 20px #46b9af1a}.factor-badge--hero .factor-icon{font-size:18px}.factor-badge--hero .factor-value{font-size:12px;font-weight:700}.factor-icon--animated{animation:gentle-bob 2s ease-in-out infinite}@keyframes gentle-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@media(prefers-reduced-motion:reduce){.factor-icon--animated{animation:none}}.golden-windows{padding:var(--space-3);border-bottom:1px solid var(--border-subtle)}.windows-title{display:block;font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2)}.windows-list{display:flex;flex-direction:column;gap:var(--space-1)}.window{display:flex;justify-content:space-between;align-items:center;padding:6px var(--space-2);border-radius:var(--radius-sm);background:var(--gray-3)}.window-golden{background:linear-gradient(90deg,#fbbf2426,#fbbf240d);border-left:3px solid var(--status-warning)}.window-good{background:linear-gradient(90deg,#7eb8b826,#7eb8b80d);border-left:3px solid var(--color-water)}.window-time{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-primary)}.window-reason{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary)}.window-until{font-weight:500;color:var(--text-muted);font-size:10px}.now-vs-best{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--gray-3);border-radius:var(--radius-md);margin-bottom:var(--space-2);font-family:var(--font-mono);font-size:12px}.now-chip{padding:2px 8px;background:var(--bg-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:600}.vs-divider{color:var(--text-muted)}.best-chip{padding:2px 8px;background:linear-gradient(90deg,#fbbf2433,#fbbf241a);border-radius:var(--radius-sm);color:#fbbf24;font-weight:600}.detail-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-1);width:100%;padding:var(--space-2);background:transparent;border:none;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.detail-toggle:hover{background:var(--gray-3);color:var(--text-secondary)}.verdict-detail{padding:var(--space-4);background:var(--gray-3);border-top:1px solid var(--border-subtle)}.detail-section{margin-bottom:var(--space-4);padding:var(--space-3);background:var(--bg-subtle);border-radius:var(--radius-md)}.detail-section:last-child{margin-bottom:0}.detail-label{display:block;font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-1)}.detail-value{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.detail-secondary{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);margin-left:var(--space-2)}.detail-row{display:flex;align-items:baseline}.detail-row-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.activity-bar-container{display:flex;align-items:center;gap:var(--space-2)}.activity-bar{flex:1;height:8px;background:var(--gray-4);border-radius:var(--radius-full);position:relative;overflow:visible}.activity-fill{height:100%;background:linear-gradient(90deg,var(--color-water),#f472b6);border-radius:var(--radius-full);transition:width .5s ease}.activity-threshold{position:absolute;top:0;bottom:0;display:flex;flex-direction:column;align-items:center;transform:translate(-50%)}.activity-threshold-line{width:2px;height:100%;background:var(--score-go);border-radius:1px}.activity-threshold-label{position:absolute;top:-18px;font-size:9px;font-family:var(--font-mono);color:var(--score-go);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.activity-value{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-primary);min-width:36px;text-align:right}.wind-scale{position:relative;height:16px;margin-top:var(--space-1);background:linear-gradient(90deg,var(--score-go) 0% 25%,var(--score-maybe) 25% 50%,var(--score-skip) 50% 75%,var(--status-error) 75% 100%);border-radius:var(--radius-sm);overflow:visible}.wind-marker{position:absolute;top:-4px;width:3px;height:24px;background:#fff;border-radius:2px;transform:translate(-50%);box-shadow:0 0 4px #00000080;z-index:1}.scale-label{position:absolute;bottom:-16px;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary)}.scale-label.calm{left:12%}.scale-label.breezy{left:50%;transform:translate(-50%)}.scale-label.rough{right:8%}.wind-bar-container{margin-top:var(--space-2)}.wind-bar{position:relative;height:8px;background:var(--gray-4);border-radius:var(--radius-full);overflow:visible}.wind-bar-gradient{position:absolute;inset:0;background:linear-gradient(90deg,var(--score-go) 0%,var(--score-go) 20%,var(--score-maybe) 40%,var(--score-skip) 60%,var(--status-error) 80%,var(--status-error) 100%);border-radius:var(--radius-full);opacity:.3}.wind-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--score-go) 0%,var(--score-maybe) 50%,var(--score-skip) 75%,var(--status-error) 100%);border-radius:var(--radius-full);transition:width .3s ease}.wind-bar-marker{position:absolute;top:-2px;width:4px;height:12px;background:var(--text-primary);border-radius:var(--radius-sm);transform:translate(-50%);box-shadow:0 0 4px #0000004d}.wind-scale-labels{display:flex;justify-content:space-between;margin-top:var(--space-1);font-size:9px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.tide-times-row{display:flex;gap:var(--space-4)}.tide-time{display:flex;flex-direction:column;gap:1px}.tide-type{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary)}.tide-value{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--text-primary)}.moon-display{display:flex;align-items:flex-start;gap:var(--space-2)}.moon-emoji{font-size:20px;line-height:1}.moon-info{display:flex;flex-direction:column;gap:2px}.moon-phase{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-primary)}.moon-tip{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);font-style:italic}.peaks-row{display:flex;gap:var(--space-3)}.peak{font-family:var(--font-mono);font-size:11px;padding:3px 8px;border-radius:var(--radius-sm)}.peak.major{background:#fbbf2426;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.peak.minor{background:#7eb8b826;color:var(--color-water);border:1px solid rgba(126,184,184,.3)}@media(max-width:767px){.verdict-factors{grid-template-columns:repeat(4,1fr)}.factor-badge{padding:6px 4px}.factor-icon{font-size:12px}.verdict-hero{padding:var(--space-2)}.verdict-emoji{font-size:1.75rem}.verdict-phrase{font-size:14px}}.sun-finder-ar{position:fixed;inset:0;z-index:var(--z-toast);background:var(--gray-1);display:flex;flex-direction:column}.ar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--gray-2);border-bottom:1px solid var(--border-primary);z-index:var(--z-elevated)}.ar-title{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.ar-title svg{color:#fbbf24}.ar-spot-name{font-weight:400;color:var(--text-secondary);font-size:var(--text-sm)}.ar-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--gray-3);border:none;border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer}.ar-permission,.ar-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-6);text-align:center}.ar-permission svg,.ar-error svg{color:var(--color-water)}.ar-permission h3{font-family:var(--font-display);font-size:var(--text-xl);color:var(--text-primary);margin:0}.ar-permission p,.ar-error p{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);max-width:280px}.ar-permission-btn,.ar-retry-btn{padding:var(--space-3) var(--space-6);min-height:44px;background:var(--color-water);color:var(--gray-1);border:none;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;cursor:pointer}.ar-viewport{flex:1;position:relative;overflow:hidden}.ar-sky{position:absolute;inset:0;background:linear-gradient(to bottom,#0c1929,#1a365d,#2563eb 60%,#60a5fa,#93c5fd);transform:translateY(calc(var(--sky-tilt, 45deg) * -.5));transition:transform .1s ease-out}.ar-horizon{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5) 20%,rgba(255,255,255,.8) 50%,rgba(255,255,255,.5) 80%,transparent);transition:top .1s ease-out}.ar-horizon:before{content:"HORIZON";position:absolute;left:var(--space-4);top:var(--space-2);font-family:var(--font-mono);font-size:10px;color:#fff9;letter-spacing:.1em}.ar-compass{position:absolute;bottom:calc(var(--space-6) + var(--safe-area-bottom));left:50%;transform:translate(-50%);width:120px;height:120px}.compass-ring{width:100%;height:100%;border:2px solid rgba(255,255,255,.3);border-radius:50%;position:relative;transition:transform .1s ease-out}.compass-ring:before{content:"";position:absolute;top:50%;left:50%;width:8px;height:8px;background:var(--color-water);border-radius:50%;transform:translate(-50%,-50%)}.compass-ring:after{content:"";position:absolute;top:10px;left:50%;width:2px;height:15px;background:#ef4444;transform:translate(-50%)}.compass-n,.compass-e,.compass-s,.compass-w{position:absolute;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:700;color:#fff}.compass-n{top:-25px;left:50%;transform:translate(-50%);color:#ef4444}.compass-e{right:-20px;top:50%;transform:translateY(-50%)}.compass-s{bottom:-25px;left:50%;transform:translate(-50%)}.compass-w{left:-20px;top:50%;transform:translateY(-50%)}.ar-sun{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;transition:left .1s ease-out,top .1s ease-out;pointer-events:none}.ar-sun-ball{width:60px;height:60px;background:radial-gradient(circle at 30% 30%,#fff7a1,#fbbf24 40%,#f59e0b);border-radius:50%;box-shadow:0 0 30px 10px #fbbf24cc,0 0 60px 20px #fbbf2480,0 0 100px 40px #fbbf244d;animation:sun-pulse 2s ease-in-out infinite}@keyframes sun-pulse{0%,to{box-shadow:0 0 30px 10px #fbbf24cc,0 0 60px 20px #fbbf2480,0 0 100px 40px #fbbf244d}50%{box-shadow:0 0 40px 15px #fbbf24e6,0 0 80px 30px #fbbf2499,0 0 120px 50px #fbbf2466}}.ar-sun-label{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:#fef3c7;background:#000000b3;padding:4px 12px;border-radius:var(--radius-full);margin-top:var(--space-2);border:1px solid rgba(251,191,36,.5)}.ar-moon{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;transition:left .1s ease-out,top .1s ease-out;pointer-events:none}.ar-moon-emoji{font-size:2.5rem;filter:drop-shadow(0 0 15px #e2e8f0) drop-shadow(0 0 30px #94a3b8)}.ar-moon-label{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:#e2e8f0;background:#000000b3;padding:4px 12px;border-radius:var(--radius-full);margin-top:var(--space-2);border:1px solid rgba(148,163,184,.5)}.ar-wind{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.ar-wind-arrow{position:absolute;top:50%;left:50%;width:150px;height:4px;background:linear-gradient(90deg,transparent 0%,rgba(96,165,250,.3) 30%,rgba(96,165,250,.8) 100%);transform-origin:left center;transition:transform .3s ease-out}.ar-wind-arrow:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);border:8px solid transparent;border-left:12px solid rgba(96,165,250,.8)}.ar-wind-label{position:absolute;top:calc(50% + 30px);left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:var(--text-sm);color:#60a5fa;background:#00000080;padding:4px 12px;border-radius:var(--radius-full);white-space:nowrap}.ar-cast-zone{position:absolute;bottom:180px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.ar-cast-arc{width:200px;height:100px;border:3px dashed rgba(126,184,184,.6);border-bottom:none;border-radius:100px 100px 0 0;position:relative}.ar-cast-arc:before{content:"CAST ZONE";position:absolute;top:-20px;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:10px;color:var(--color-water);letter-spacing:.1em;background:#00000080;padding:2px 8px;border-radius:var(--radius-full)}.ar-cast-optimal{position:absolute;top:10px;left:50%;transform:translate(-50%) rotate(var(--cast-angle, 0deg));width:4px;height:60px;background:linear-gradient(to top,transparent,var(--color-water));transform-origin:bottom center}.ar-cast-optimal:after{content:"→";position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:1.5rem;color:var(--accent-9);font-weight:700}.ar-sun-indicator{position:absolute;top:var(--space-4);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);background:#0009;border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);color:#fff}.ar-sun-hint{font-size:var(--text-xs);color:#fbbf24}.ar-night{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);background:linear-gradient(to bottom,#0c1929,#1e293b)}.ar-night span{font-size:4rem}.ar-night p{font-family:var(--font-mono);font-size:var(--text-base);color:var(--text-secondary);margin:0}.ar-night-times{font-size:var(--text-sm)!important;color:#fcd34d!important}.ar-indicators{position:absolute;top:var(--space-4);left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:var(--space-2)}.ar-indicator{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) var(--space-4);background:#000c;border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:#e2e8f0}.ar-indicator.sun{border:1px solid rgba(251,191,36,.5)}.ar-indicator.moon{border:1px solid rgba(148,163,184,.5)}.ar-indicator-hint{font-size:var(--text-xs);color:#fbbf24;margin-top:2px}.ar-night-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;padding:var(--space-4);background:#000000b3;border-radius:var(--radius-lg)}.ar-night-message p{font-family:var(--font-mono);font-size:var(--text-base);color:var(--text-secondary);margin:0}.ar-night-message .ar-night-times{color:#fcd34d;font-size:var(--text-sm);margin-top:var(--space-2)}.ar-info-panel{position:absolute;top:var(--space-4);right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:#000c;border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);border:1px solid rgba(126,184,184,.3)}.ar-info-row{display:flex;justify-content:space-between;gap:var(--space-4);color:#e2e8f0;font-weight:500}.ar-info-row span:last-child{color:#7eb8b8}.ar-desktop-controls{position:absolute;bottom:calc(var(--space-6) + var(--safe-area-bottom));left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.ar-nav-buttons{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.ar-nav-row{display:flex;gap:var(--space-6)}.ar-nav-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#000000b3;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);color:#fff;font-size:1.5rem;cursor:pointer;transition:all .15s ease}.ar-nav-btn:hover{background:#60a5fa80;border-color:#60a5facc}.ar-nav-btn:active{transform:scale(.95)}.ar-jump-buttons{display:flex;gap:var(--space-2)}.ar-jump-btn{padding:var(--space-2) var(--space-4);background:#000000b3;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-full);color:#fff;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .15s ease}.ar-jump-btn:hover{background:#60a5fa80;border-color:#60a5facc}.ar-jump-btn.sun:hover{background:#fbbf2466;border-color:#fbbf24cc}.ar-jump-btn.moon:hover{background:#94a3b866;border-color:#94a3b8cc}.ar-desktop-hint{font-family:var(--font-mono);font-size:var(--text-xs);color:#ffffff80;text-align:center}@media(max-width:767px){.ar-compass{width:100px;height:100px;bottom:calc(var(--space-4) + var(--safe-area-bottom))}.ar-sun-emoji{font-size:2.5rem}.ar-info-panel{font-size:var(--text-xs);padding:var(--space-2)}.ar-desktop-controls{display:none}}.attribution-line{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--bg-subtle);border-radius:var(--radius-sm);margin:var(--space-2) 0;font-family:var(--font-mono);font-size:11px;line-height:1.4}.attribution-label{color:var(--text-secondary);font-weight:600;white-space:nowrap}.attribution-factors{color:var(--text-primary);display:flex;flex-wrap:wrap;align-items:center}.attribution-factor{white-space:nowrap}.attribution-separator{color:var(--text-muted)}.attribution-more{color:var(--accent-9);background:transparent;border:none;padding:var(--space-1) var(--space-2);margin-left:var(--space-1);font-family:var(--font-mono);font-size:11px;font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s ease;white-space:nowrap}.attribution-more:hover{background:var(--accent-3)}.attribution-more:focus-visible{outline:2px solid var(--accent-7);outline-offset:2px}@media(max-width:360px){.attribution-line{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.attribution-more{margin-left:0;margin-top:var(--space-1)}}.conditions-chart{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.conditions-chart--loading,.conditions-chart--empty{min-height:200px;display:flex;align-items:center;justify-content:center}.conditions-chart--empty p{color:var(--text-muted);font-size:var(--text-sm)}.chart-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.chart-date{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.chart-controls{display:flex;gap:var(--space-1)}.chart-pill{padding:var(--space-1) var(--space-2);font-size:11px;font-weight:500;color:var(--text-tertiary);background:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);min-height:28px}.chart-pill:hover{color:var(--text-secondary);border-color:var(--border-medium)}.chart-pill.active{color:var(--text-primary);background:var(--surface-card-hover);border-color:var(--accent-primary)}.species-selector{display:flex;gap:var(--space-2);padding:var(--space-2) 0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.species-selector::-webkit-scrollbar{display:none}.species-chip{flex-shrink:0;padding:var(--space-1) var(--space-3);font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--surface-subtle);border:1px solid var(--border-primary);border-radius:var(--radius-full);cursor:pointer;transition:all var(--duration-fast) var(--ease-default);white-space:nowrap}.species-chip:hover{color:var(--text-primary);background:var(--surface-card-hover);border-color:var(--border-medium)}.species-chip.active{color:var(--brand-text);background:var(--brand-subtle);border-color:var(--brand-primary)}.chart-scroll-container{width:100%;height:180px;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border-primary) transparent}.chart-scroll-container::-webkit-scrollbar{height:4px}.chart-scroll-container::-webkit-scrollbar-track{background:transparent}.chart-scroll-container::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-full)}.chart-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--border-medium)}.chart-scroll-content{height:100%;min-width:100%}.chart-container{width:100%;height:180px;touch-action:pan-y;-webkit-user-select:none;user-select:none}.chart-skeleton{width:100%;height:180px;background:linear-gradient(90deg,var(--surface-subtle) 25%,var(--surface-card) 50%,var(--surface-subtle) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.chart-tooltip{background:var(--chart-tooltip-bg);border:1px solid var(--chart-tooltip-border);border-radius:var(--radius-md);padding:var(--space-2);min-width:120px;box-shadow:var(--shadow-lg)}.chart-tooltip-time{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1);padding-bottom:var(--space-1);border-bottom:1px solid var(--border-subtle)}.chart-tooltip-score{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-subtle)}.tooltip-score-value{font-size:24px;font-weight:700;font-family:var(--font-mono);color:var(--chart-line-score)}.tooltip-score-label{font-size:11px;color:var(--text-secondary);font-style:italic}.chart-tooltip-metrics{display:flex;flex-direction:column;gap:4px}.tooltip-row{display:flex;justify-content:space-between;gap:var(--space-2)}.tooltip-label{font-size:11px;color:var(--text-secondary)}.tooltip-value{font-size:11px;font-weight:500;color:var(--text-primary);font-family:var(--font-mono);font-variant-numeric:tabular-nums}.chart-tooltip-confidence{margin-top:var(--space-1);padding-top:var(--space-1);border-top:1px solid var(--border-subtle);font-size:11px;color:var(--text-secondary);text-align:center}.chart-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);padding-top:var(--space-2);border-top:1px solid var(--border-subtle)}.legend-item{display:flex;align-items:center;gap:var(--space-1)}.legend-line{width:16px;height:3px;border-radius:2px}.legend-line--score{background:var(--chart-line-score)}.legend-line--solunar{background:var(--chart-line-solunar)}.legend-line--wind{background:var(--chart-line-wind);background:repeating-linear-gradient(90deg,var(--chart-line-wind) 0,var(--chart-line-wind) 4px,transparent 4px,transparent 6px)}.legend-line--waves{background:var(--chart-line-waves)}.legend-label{font-size:11px;color:var(--text-secondary)}.chart-hint{text-align:center;font-size:11px;color:var(--text-tertiary);margin:0}@media(max-width:767px){.conditions-chart{padding:var(--space-2);gap:var(--space-1)}.chart-scroll-container,.chart-container{height:160px}.chart-header{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.chart-controls{width:100%;justify-content:flex-start}.chart-pill{min-height:32px;padding:var(--space-1) var(--space-3)}.chart-legend{gap:var(--space-2)}}.cookie-consent{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-modal-backdrop);background:var(--surface-panel);border-top:var(--border-width-thin) solid var(--border-primary);padding:var(--space-4);box-shadow:0 -4px 20px #0000004d;transform:translateY(100%);opacity:0;transition:transform .3s ease-out,opacity .3s ease-out}.cookie-consent.visible{transform:translateY(0);opacity:1}.cookie-consent.hidden{transform:translateY(100%);opacity:0;pointer-events:none}.cookie-consent-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-4)}@media(min-width:768px){.cookie-consent-inner{flex-direction:row;align-items:center;justify-content:space-between}}.cookie-consent-content{flex:1}.cookie-consent-content h3{font-size:var(--type-subhead);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.cookie-consent-content p{font-size:var(--type-callout);line-height:var(--leading-normal);color:var(--text-secondary);margin:0}.cookie-consent-content a{color:var(--text-link);text-decoration:underline;text-underline-offset:2px}.cookie-consent-content a:hover{color:var(--text-link-hover)}.cookie-consent-buttons{display:flex;gap:var(--space-3);flex-shrink:0}.cookie-consent-btn{padding:var(--space-btn-padding-y) var(--space-btn-padding-x);border-radius:var(--radius-button);font-size:var(--type-callout);font-weight:var(--font-medium);cursor:pointer;transition:background .15s ease,transform .1s ease;border:none;min-width:100px}.cookie-consent-btn:active{transform:scale(.98)}.cookie-consent-btn-accept{background:var(--accent-primary);color:var(--text-on-accent)}.cookie-consent-btn-accept:hover{background:var(--accent-hover)}.cookie-consent-btn-decline{background:var(--surface-card);color:var(--text-secondary);border:var(--border-width-thin) solid var(--border-primary)}.cookie-consent-btn-decline:hover{background:var(--surface-card-hover);color:var(--text-primary)}@media(max-width:767px){.cookie-consent{padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom))}.cookie-consent-buttons{width:100%}.cookie-consent-btn{flex:1}}@media(prefers-reduced-motion:reduce){.cookie-consent,.cookie-consent-btn{transition:none}}.species-badges{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-3)}.species-badges__compact{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.species-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:11px;font-weight:500;transition:background-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.species-badge:hover{transform:translateY(-1px)}.species-badge__icon{flex-shrink:0}.species-badge__name{text-transform:capitalize}.species-badge__score{font-weight:700;margin-left:auto}.species-badge__label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.species-badge--excellent{background:var(--species-excellent-bg);color:var(--species-excellent-text)}.species-badge--good{background:var(--species-good-bg);color:var(--species-good-text)}.species-badge--fair{background:var(--species-fair-bg);color:var(--species-fair-text)}.species-badge--poor{background:var(--species-poor-bg);color:var(--species-poor-text)}.species-badges__toggle{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out);min-height:44px}.species-badges__toggle:hover{background:var(--bg-muted);border-color:var(--border-medium)}.species-badges__toggle:focus-visible{outline:2px solid var(--brand-7);outline-offset:2px}.species-badges__expanded{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-3);background:var(--bg-elevated);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.species-badges__tier{display:flex;flex-direction:column;gap:var(--space-2)}.species-badges__tier-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin:0;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.species-badges__tier--excellent .species-badges__tier-label{background:var(--species-excellent-bg);color:var(--species-excellent-text)}.species-badges__tier--good .species-badges__tier-label{background:var(--species-good-bg);color:var(--species-good-text)}.species-badges__tier--fair .species-badges__tier-label{background:var(--species-fair-bg);color:var(--species-fair-text)}.species-badges__tier--poor .species-badges__tier-label{background:var(--species-poor-bg);color:var(--species-poor-text)}.species-badges__tier-list{display:flex;flex-direction:column;gap:var(--space-1);padding-left:var(--space-2)}.species-badges__tier-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-1) 0;font-size:12px}.species-badges__tier-name{color:var(--text-primary);text-transform:capitalize}.species-badges__tier-score{font-family:var(--font-mono);font-weight:600;color:var(--text-secondary)}.species-badges__feedback{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.species-badges__feedback-label{font-size:12px;color:var(--text-muted)}.species-badges__feedback-buttons{display:flex;gap:var(--space-2)}.species-badges__feedback-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.species-badges__feedback-btn:hover:not(:disabled){background:var(--bg-muted);border-color:var(--border-medium)}.species-badges__feedback-btn:focus-visible{outline:2px solid var(--brand-7);outline-offset:2px}.species-badges__feedback-btn.active{background:var(--brand-7);border-color:var(--brand-7);color:#fff}.species-badges__feedback-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.species-badges__compact{flex-direction:column;align-items:stretch}.species-badge{width:100%}.species-badges__toggle{width:100%;justify-content:center}}.catch-logger-backdrop{position:fixed;inset:0;z-index:var(--z-drawer);background:var(--bg-overlay, hsla(0, 0%, 0%, .6));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.catch-logger{position:fixed;bottom:0;left:0;right:0;z-index:calc(var(--z-drawer) + 1);max-height:90vh;overflow-y:auto;background:var(--bg-elevated);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-xl);display:flex;flex-direction:column}@media(prefers-reduced-motion:reduce){.catch-logger{transition:none}}.catch-logger-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--border-primary);flex-shrink:0}.catch-logger-title{display:flex;align-items:center;gap:var(--space-2);margin:0;font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.catch-logger-title svg{color:var(--brand-primary)}.catch-logger-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;border-radius:var(--radius-full);color:var(--text-tertiary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.catch-logger-close:hover:not(:disabled){background:var(--surface-card-hover);color:var(--text-secondary)}.catch-logger-close:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.catch-logger-close:disabled{opacity:.5;cursor:not-allowed}.catch-logger-content{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-4)}.catch-logger-photo-section{width:100%}.photo-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8) var(--space-4);background:var(--surface-card);border:2px dashed var(--border-secondary);border-radius:var(--radius-lg);text-align:center}.photo-upload-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:var(--brand-subtle);border:none;border-radius:var(--radius-md);color:var(--brand-primary);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.photo-upload-btn:hover{background:var(--brand-primary);color:var(--text-on-accent)}.photo-upload-btn:focus-within{outline:2px solid var(--brand-primary);outline-offset:2px}.photo-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.photo-hint{font-size:var(--text-xs);color:var(--text-tertiary)}.photo-preview-container{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-card)}.photo-preview{width:100%;height:100%;object-fit:cover}.photo-clear-btn{position:absolute;top:var(--space-2);right:var(--space-2);display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--bg-overlay, hsla(0, 0%, 0%, .6));border:none;border-radius:var(--radius-full);color:var(--text-on-accent);cursor:pointer;transition:background var(--duration-fast) var(--ease-default)}.photo-clear-btn:hover:not(:disabled){background:var(--status-error)}.photo-clear-btn:focus-visible{outline:2px solid var(--text-on-accent);outline-offset:2px}.catch-logger-section{display:flex;flex-direction:column;gap:var(--space-2)}.section-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.section-label svg{color:var(--text-tertiary)}.species-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.species-chip{padding:var(--space-2) var(--space-3);min-height:44px;min-width:44px;background:var(--surface-card);border:1px solid var(--border-primary);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.species-chip:hover:not(:disabled){background:var(--surface-card-hover);border-color:var(--border-secondary)}.species-chip.active{background:var(--brand-primary);border-color:var(--brand-primary);color:var(--text-on-accent)}.species-chip:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.species-chip:disabled{opacity:.5;cursor:not-allowed}.custom-species-input{width:100%;padding:var(--space-3);margin-top:var(--space-2);background:var(--surface-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);outline:none;transition:border-color var(--duration-fast) var(--ease-default)}.custom-species-input:focus{border-color:var(--brand-primary)}.custom-species-input::placeholder{color:var(--text-placeholder)}.size-slider-container{display:flex;flex-direction:column;gap:var(--space-1)}.size-slider{width:100%;height:var(--space-2);background:var(--surface-card);border-radius:var(--radius-full);appearance:none;cursor:pointer}.size-slider::-webkit-slider-thumb{appearance:none;width:var(--space-6);height:var(--space-6);background:var(--brand-primary);border-radius:var(--radius-full);cursor:grab;transition:transform var(--duration-fast) var(--ease-default)}.size-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.size-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}.size-slider::-moz-range-thumb{width:var(--space-6);height:var(--space-6);background:var(--brand-primary);border:none;border-radius:var(--radius-full);cursor:grab}.size-slider:focus-visible{outline:2px solid var(--brand-primary);outline-offset:4px}.size-markers{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-tertiary)}.notes-input{width:100%;padding:var(--space-3);background:var(--surface-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-base);font-family:inherit;color:var(--text-primary);resize:none;outline:none;transition:border-color var(--duration-fast) var(--ease-default)}.notes-input:focus{border-color:var(--brand-primary)}.notes-input::placeholder{color:var(--text-placeholder)}.catch-logger-error{padding:var(--space-3);background:var(--status-error-subtle);border:1px solid var(--status-error);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--status-error)}.catch-spot-info{padding:var(--space-2) var(--space-3);background:var(--surface-card);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--text-tertiary);text-align:center}.catch-spot-info strong{color:var(--text-secondary)}.catch-logger-actions{display:flex;gap:var(--space-3);padding:var(--space-4);padding-bottom:calc(var(--space-4) + var(--safe-area-bottom));border-top:1px solid var(--border-primary);flex-shrink:0}.catch-btn-secondary,.catch-btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:48px;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.catch-btn-secondary{background:var(--surface-card);color:var(--text-secondary)}.catch-btn-secondary:hover:not(:disabled){background:var(--surface-card-hover)}.catch-btn-primary{background:var(--brand-primary);color:var(--text-on-accent)}.catch-btn-primary:hover:not(:disabled){background:var(--brand-hover)}.catch-btn-secondary:focus-visible,.catch-btn-primary:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.catch-btn-secondary:disabled,.catch-btn-primary:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.spin{animation:none}}@media(max-width:767px){.catch-logger-header{padding:var(--space-3)}.catch-logger-content{padding:var(--space-3);gap:var(--space-3)}.catch-logger-actions{padding:var(--space-3);padding-bottom:calc(var(--space-3) + var(--safe-area-bottom))}.photo-placeholder{padding:var(--space-6) var(--space-3)}}.catch-card{position:relative;display:flex;flex-direction:column;background:var(--surface-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--duration-fast) var(--ease-default)}.catch-card:hover{box-shadow:var(--shadow-md)}.catch-card.compact{flex-direction:row;gap:var(--space-3)}.catch-card.compact .catch-card-photo{width:var(--space-20, 80px);height:var(--space-20, 80px);flex-shrink:0}.catch-card.compact .catch-card-content{padding:var(--space-2)}.catch-card-photo{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--bg-subtle)}.catch-card-photo img{width:100%;height:100%;object-fit:cover}.catch-card-content{flex:1;padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.catch-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.catch-card-species{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.catch-card-species svg{color:var(--brand-primary)}.catch-card-size{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--surface-card-hover);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--text-secondary)}.catch-card-size svg{color:var(--text-tertiary)}.catch-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-3)}.catch-card-spot,.catch-card-time{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-tertiary)}.catch-card-notes{margin:0;font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.catch-card-conditions{display:inline-flex;padding:var(--space-1) var(--space-2);background:var(--brand-subtle);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500;color:var(--brand-primary);align-self:flex-start}.catch-card-actions{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-top:1px solid var(--border-primary)}.catch-action-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.catch-action-btn:hover{background:var(--surface-card-hover);color:var(--text-secondary)}.catch-action-btn.delete:hover{background:var(--status-error-subtle);color:var(--status-error)}.catch-action-btn:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.catch-card-confirm{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4);background:var(--bg-overlay-heavy, hsla(0, 0%, 0%, .85));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-on-accent);font-size:var(--text-sm);text-align:center;z-index:1}.confirm-error{color:var(--status-error);font-size:var(--text-xs)}.confirm-actions{display:flex;gap:var(--space-2)}.confirm-btn{padding:var(--space-2) var(--space-4);min-height:44px;min-width:80px;font-size:var(--text-sm);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-default)}.confirm-btn.cancel{background:var(--surface-card);color:var(--text-primary)}.confirm-btn.cancel:hover:not(:disabled){background:var(--surface-card-hover)}.confirm-btn.delete{background:var(--status-error);color:var(--text-on-accent)}.confirm-btn.delete:hover:not(:disabled){filter:brightness(1.1)}.confirm-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-btn:focus-visible{outline:2px solid var(--text-on-accent);outline-offset:2px}.panel-backdrop{position:fixed;inset:0;background:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-panel)}.spot-panel{position:fixed;bottom:0;left:0;right:0;max-height:85vh;background:var(--gray-2);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);box-shadow:0 -8px 32px #0006;z-index:calc(var(--z-panel) + 1);overflow-y:auto;overscroll-behavior:contain;padding-bottom:max(var(--safe-area-bottom),16px)}.panel-handle{width:36px;height:4px;background:var(--gray-5);border-radius:var(--radius-full);margin:var(--space-2) auto}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle)}.panel-title-row{display:flex;align-items:center;gap:var(--space-2)}.panel-emoji{font-size:1.5rem}.panel-titles{display:flex;flex-direction:column;gap:1px}.panel-title{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.panel-type{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--color-water);text-transform:uppercase;letter-spacing:.08em}.panel-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--gray-3);border:none;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) ease}.panel-close:hover{background:var(--gray-4);color:var(--text-primary)}.panel-score{display:flex;align-items:baseline;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--score-color);background:linear-gradient(135deg,var(--score-color),color-mix(in srgb,var(--score-color),transparent 40%));margin:var(--space-2) var(--space-3);border-radius:var(--radius-md)}.score-value{font-family:var(--font-mono);font-size:24px;font-weight:700;color:var(--gray-1);font-variant-numeric:tabular-nums}.score-label{font-family:var(--font-mono);font-size:11px;color:var(--gray-2);opacity:.9}.panel-species{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.panel-species svg{width:12px;height:12px;color:var(--color-water)}.panel-coords{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3);font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.panel-coords svg{width:12px;height:12px;color:var(--spot-custom)}.condition-card.chlorophyll-optimal{border-color:var(--status-good-border);background:var(--status-good-bg)}.condition-card.chlorophyll-optimal .condition-icon{color:var(--status-good-text)}.condition-card.chlorophyll-transition{border-color:var(--color-water);background:#8cd4d41a}.condition-card.chlorophyll-transition .condition-icon{color:var(--color-water)}.condition-card.chlorophyll-productive{border-color:#90c990;background:#90c9901a}.condition-card.chlorophyll-productive .condition-icon{color:#90c990}.condition-card.chlorophyll-low{border-color:var(--status-warning-border);background:var(--status-warning-bg)}.condition-card.chlorophyll-low .condition-icon{color:var(--status-warning-text)}.condition-card.chlorophyll-murky{border-color:var(--status-error-border);background:var(--status-error-bg)}.condition-card.chlorophyll-murky .condition-icon{color:var(--status-error-text)}.panel-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6);color:var(--text-muted);font-family:var(--font-mono);font-size:11px}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-primary);border-top-color:var(--color-water);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.panel-error{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6);color:var(--status-error-text);font-family:var(--font-mono);font-size:11px;text-align:center}.panel-error svg{width:20px;height:20px;color:var(--status-error)}.retry-btn{margin-top:var(--space-1);padding:8px var(--space-3);min-height:44px;background:var(--gray-3);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--duration-fast) ease}.retry-btn:hover{background:var(--gray-4)}.panel-content{padding:var(--space-3)}.conditions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);margin-bottom:var(--space-3)}.condition-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--gray-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.condition-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--gray-4);border-radius:var(--radius-sm);color:var(--color-water);flex-shrink:0}.condition-icon svg{width:18px;height:18px}.condition-data{display:flex;flex-direction:column;gap:1px}.condition-value{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text-primary);line-height:1}.condition-label{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-secondary)}.conditions-grid.secondary{margin-top:var(--space-1);gap:var(--space-1)}.condition-card.compact{padding:6px var(--space-2);gap:var(--space-2)}.condition-icon.small{width:28px;height:28px}.condition-icon.small svg{width:14px;height:14px}.condition-value.small{font-size:14px;font-weight:600}.panel-section{padding:var(--space-3);margin-bottom:var(--space-2);border-top:1px solid var(--border-subtle)}.section-title{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin:0 0 var(--space-2) 0}.tide-times{display:flex;gap:var(--space-3)}.tide-item{display:flex;flex-direction:column;gap:1px}.tide-label{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary)}.tide-time{font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.solunar-bar{height:6px;background:var(--gray-4);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-1)}.solunar-fill{height:100%;background:linear-gradient(90deg,var(--color-water),var(--brand-9));border-radius:var(--radius-full);transition:width .5s ease}.solunar-info{display:flex;flex-direction:column;gap:var(--space-1)}.moon-phase{display:flex;align-items:center;gap:var(--space-1);font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-secondary)}.moon-phase svg{width:12px;height:12px;color:var(--accent-7)}.solunar-peaks{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-secondary)}.panel-notes{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);line-height:1.4;margin:0}.panel-actions{display:flex;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:10px var(--space-3);min-height:44px;font-family:var(--font-mono);font-size:11px;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) ease}.action-btn svg{width:14px;height:14px}.action-btn.primary{background:var(--color-water);color:var(--gray-1)}.action-btn.primary:hover{background:var(--accent-10);box-shadow:var(--glow-water)}.action-btn.secondary{background:var(--gray-3);color:var(--text-primary);border:1px solid var(--border-primary)}.action-btn.secondary:hover{background:var(--gray-4)}@media(max-width:767px){.spot-panel{max-height:90vh}.panel-header,.panel-content{padding:var(--space-2)}.conditions-grid{grid-template-columns:repeat(2,1fr)}.panel-actions{flex-direction:column;gap:var(--space-1)}.action-btn{padding:10px var(--space-3)}}.spot-catches-list{display:flex;flex-direction:column;gap:var(--space-2)}.install-prompt{position:fixed;bottom:0;left:0;right:0;padding:var(--space-3);padding-bottom:var(--layout-safe-padding-bottom);background:var(--gray-2);border-top:1px solid var(--border-primary);box-shadow:0 -4px 24px #0000004d;z-index:var(--z-drawer);animation:slide-up-bounce var(--duration-slow) var(--ease-out) forwards}.install-prompt-content{display:flex;align-items:flex-start;gap:var(--space-3);max-width:600px;margin:0 auto}.install-prompt-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-water);display:flex;align-items:center;justify-content:center;flex-shrink:0}.install-prompt-icon svg{width:28px;height:28px;color:var(--gray-1)}.install-prompt-text{flex:1;min-width:0}.install-prompt-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 2px}.install-prompt-description{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);margin:0;line-height:1.4}.install-prompt-actions{display:flex;flex-direction:column;gap:var(--space-1);flex-shrink:0}.install-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:12px var(--space-4);min-height:44px;background:var(--color-water);border:none;border-radius:var(--radius-button);font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--gray-1);cursor:pointer;transition:all var(--duration-fast) ease;white-space:nowrap}.install-btn:hover{background:var(--accent-10);box-shadow:var(--glow-water)}.install-btn:active{transform:scale(.98)}.install-btn svg{width:16px;height:16px}.dismiss-btn{padding:10px var(--space-3);min-height:44px;background:transparent;border:none;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:color var(--duration-fast) ease}.dismiss-btn:hover{color:var(--text-secondary)}@media(max-width:767px){.install-prompt{padding:var(--space-2);padding-bottom:calc(var(--space-2) + var(--safe-area-bottom))}.install-prompt-content{gap:var(--space-2)}.install-prompt-icon{width:40px;height:40px}.install-prompt-icon svg{width:24px;height:24px}.install-prompt-title{font-size:14px}.install-prompt-description{font-size:10px}.install-btn{padding:8px var(--space-3);font-size:11px}}@media(prefers-reduced-motion:reduce){.install-prompt{animation:none}}.skeleton{background:var(--gray-4);border-radius:var(--radius-sm);position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,hsla(220 20% 100% / .08) 50%,transparent 100%);animation:shimmer 1.8s var(--ease-water) infinite;background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;width:100%}.skeleton-text.xs{height:10px}.skeleton-text.sm{height:12px}.skeleton-text.md{height:16px}.skeleton-text.lg{height:20px}.skeleton-text.xl{height:24px}.skeleton-text.w-full{width:100%}.skeleton-text.w-3\/4{width:75%}.skeleton-text.w-1\/2{width:50%}.skeleton-text.w-1\/3{width:33%}.skeleton-text.w-1\/4{width:25%}.skeleton-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--gray-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.skeleton-card-header{display:flex;align-items:center;gap:var(--space-2)}.skeleton-avatar{width:36px;height:36px;border-radius:var(--radius-sm);flex-shrink:0}.skeleton-card-title{flex:1;display:flex;flex-direction:column;gap:4px}.skeleton-card-body{display:flex;flex-direction:column;gap:var(--space-2)}.skeleton-conditions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.skeleton-condition-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--gray-3);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.skeleton-condition-icon{width:36px;height:36px;border-radius:var(--radius-sm);flex-shrink:0}.skeleton-condition-data{flex:1;display:flex;flex-direction:column;gap:4px}.skeleton-score{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--gray-4);border-radius:var(--radius-md)}.skeleton-score-value{width:48px;height:28px;border-radius:var(--radius-sm)}.skeleton-score-label{width:80px;height:12px;border-radius:var(--radius-sm)}.skeleton-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.skeleton-emoji{width:24px;height:24px;border-radius:var(--radius-sm)}.skeleton-titles{flex:1;display:flex;flex-direction:column;gap:4px}@media(prefers-reduced-motion:reduce){.skeleton:after{animation:none;background:#ffffff0d}}:root{--gray-1: hsl(215 25% 18%);--gray-2: hsl(215 22% 22%);--gray-3: hsl(215 20% 28%);--gray-4: hsl(215 18% 34%);--gray-5: hsl(215 15% 42%);--gray-6: hsl(215 12% 50%);--gray-7: hsl(215 10% 58%);--gray-8: hsl(215 8% 66%);--gray-9: hsl(215 6% 74%);--gray-10: hsl(215 5% 82%);--gray-11: hsl(215 4% 90%);--gray-12: hsl(215 5% 96%);--gray-a1: hsla(220 20% 100% / .03);--gray-a2: hsla(220 20% 100% / .05);--gray-a3: hsla(220 20% 100% / .08);--gray-a4: hsla(220 20% 100% / .1);--gray-a5: hsla(220 20% 100% / .14);--gray-a6: hsla(220 20% 100% / .18);--gray-a7: hsla(220 20% 100% / .22);--gray-a8: hsla(220 20% 100% / .24);--gray-a9: hsla(220 20% 100% / .32);--gray-a10: hsla(220 20% 100% / .44);--gray-a11: hsla(220 20% 100% / .56);--gray-a12: hsla(220 20% 100% / .9);--brand-1: hsl(15 30% 12%);--brand-2: hsl(15 35% 18%);--brand-3: hsl(15 40% 26%);--brand-4: hsl(15 45% 36%);--brand-5: hsl(15 50% 48%);--brand-6: hsl(15 55% 60%);--brand-7: hsl(15 60% 70%);--brand-8: hsl(15 65% 76%);--brand-9: hsl(15 70% 80%);--brand-10: hsl(15 75% 85%);--brand-11: hsl(15 80% 90%);--brand-12: hsl(15 85% 95%);--brand-a1: hsla(15 70% 80% / .01);--brand-a2: hsla(15 70% 80% / .02);--brand-a3: hsla(15 70% 80% / .05);--brand-a4: hsla(15 70% 80% / .08);--brand-a5: hsla(15 70% 80% / .12);--brand-a6: hsla(15 70% 80% / .18);--brand-a7: hsla(15 70% 80% / .25);--brand-a8: hsla(15 70% 80% / .35);--brand-a9: hsla(15 70% 80% / .5);--brand-a10: hsla(15 70% 80% / .65);--brand-a11: hsla(15 70% 80% / .8);--brand-a12: hsla(15 70% 80% / .93);--accent-1: hsl(175 20% 12%);--accent-2: hsl(175 22% 18%);--accent-3: hsl(175 24% 26%);--accent-4: hsl(175 26% 36%);--accent-5: hsl(175 28% 48%);--accent-6: hsl(175 32% 58%);--accent-7: hsl(175 36% 66%);--accent-8: hsl(175 40% 72%);--accent-9: hsl(175 45% 76%);--accent-10: hsl(175 50% 82%);--accent-11: hsl(175 55% 88%);--accent-12: hsl(175 60% 94%);--accent-a1: hsla(175 45% 76% / .01);--accent-a2: hsla(175 45% 76% / .02);--accent-a3: hsla(175 45% 76% / .05);--accent-a4: hsla(175 45% 76% / .08);--accent-a5: hsla(175 45% 76% / .12);--accent-a6: hsla(175 45% 76% / .18);--accent-a7: hsla(175 45% 76% / .25);--accent-a8: hsla(175 45% 76% / .35);--accent-a9: hsla(175 45% 76% / .5);--accent-a10: hsla(175 45% 76% / .65);--accent-a11: hsla(175 45% 76% / .8);--accent-a12: hsla(175 45% 76% / .93);--success-1: hsl(160 50% 8%);--success-2: hsl(160 50% 12%);--success-3: hsl(160 50% 18%);--success-4: hsl(160 50% 25%);--success-5: hsl(160 50% 35%);--success-6: hsl(160 50% 45%);--success-7: hsl(160 50% 55%);--success-8: hsl(160 50% 65%);--success-9: hsl(160 50% 75%);--success-10: hsl(160 50% 80%);--success-11: hsl(160 50% 85%);--success-12: hsl(160 50% 95%);--warning-1: hsl(40 70% 8%);--warning-2: hsl(40 70% 12%);--warning-3: hsl(40 70% 18%);--warning-4: hsl(40 70% 25%);--warning-5: hsl(40 70% 35%);--warning-6: hsl(40 70% 45%);--warning-7: hsl(40 70% 60%);--warning-8: hsl(40 70% 70%);--warning-9: hsl(40 75% 75%);--warning-10: hsl(40 75% 80%);--warning-11: hsl(40 75% 85%);--warning-12: hsl(40 75% 95%);--error-1: hsl(0 50% 8%);--error-2: hsl(0 50% 12%);--error-3: hsl(0 50% 18%);--error-4: hsl(0 50% 25%);--error-5: hsl(0 50% 35%);--error-6: hsl(0 50% 45%);--error-7: hsl(0 50% 60%);--error-8: hsl(0 50% 70%);--error-9: hsl(0 55% 78%);--error-10: hsl(0 55% 82%);--error-11: hsl(0 55% 85%);--error-12: hsl(0 55% 95%);--info-1: hsl(200 60% 8%);--info-2: hsl(200 60% 12%);--info-3: hsl(200 60% 18%);--info-4: hsl(200 60% 25%);--info-5: hsl(200 60% 35%);--info-6: hsl(200 60% 45%);--info-7: hsl(200 60% 60%);--info-8: hsl(200 60% 70%);--info-9: hsl(200 65% 78%);--info-10: hsl(200 65% 82%);--info-11: hsl(200 65% 85%);--info-12: hsl(200 65% 95%);--spot-pier: hsl(175 50% 70%);--spot-rocks: hsl(15 65% 75%);--spot-beach: hsl(45 55% 70%);--spot-swimming: hsl(200 55% 70%);--spot-custom: hsl(270 40% 75%);--water-shallow: hsl(175 50% 85%);--water-medium: hsl(175 45% 76%);--water-deep: hsl(175 32% 58%)}:root{--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--space-32: 128px;--space-5: 20px;--space-7: 28px;--space-dense-0: 0;--space-dense-0_5: 2px;--space-dense-1: 4px;--space-dense-1_5: 6px;--space-dense-2: 8px;--space-dense-3: 12px;--space-dense-4: 16px;--space-map-0: 0;--space-map-0_5: 2px;--space-map-1: 4px;--space-map-1_5: 6px;--space-map-2: 8px}:root{--font-display: "JetBrains Mono", monospace;--font-sans: "JetBrains Mono", -apple-system, BlinkMacSystemFont, monospace;--font-mono: "JetBrains Mono", Monaco, Consolas, monospace;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 28px;--font-size-4xl: 32px;--font-size-rem-xs: .75rem;--font-size-rem-sm: .875rem;--font-size-rem-base: 1rem;--font-size-rem-md: 1rem;--font-size-rem-lg: 1.125rem;--font-size-rem-xl: 1.25rem;--font-size-rem-2xl: 1.5rem;--font-size-rem-3xl: 1.875rem;--font-size-rem-4xl: 2.25rem;--font-size-dense-xs: 10px;--font-size-dense-sm: 11px;--font-size-dense-base: 12px;--font-size-map-micro: 9px;--font-size-map-tiny: 10px;--font-size-map-xs: 11px;--font-size-map-sm: 12px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-light: 300;--font-weight-extrabold: 800;--font-weight-black: 900;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--line-height-none: 1;--line-height-snug: 1.3;--line-height-loose: 2;--line-height-dense: 1.2;--line-height-map: 1.1;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--letter-spacing-wider: .05em;--letter-spacing-tighter: -.05em;--letter-spacing-widest: .1em}:root{--size-icon-xs: 16px;--size-icon-sm: 20px;--size-icon-md: 24px;--size-icon-lg: 28px;--size-icon-xl: 36px;--size-icon-dense-xs: 14px;--size-icon-dense-sm: 18px;--size-icon-dense-md: 20px;--size-icon-map-xs: 12px;--size-icon-map-sm: 16px;--size-icon-map-md: 20px;--size-touch-min: 44px;--size-touch-comfortable: 48px;--size-touch-large: 56px;--size-touch-dense-min: 36px;--size-touch-dense-comfortable: 40px;--size-touch-map-min: 32px;--size-header: 52px;--size-nav-bottom: 56px;--size-panel-handle: 4px;--size-modal-close: 44px;--size-modal-close-icon: 20px;--size-header-dense: 44px;--size-nav-bottom-dense: 48px;--size-map-control: 32px;--size-map-marker: 24px;--size-map-cluster: 40px}:root{--duration-instant: .1s;--duration-fast: .25s;--duration-normal: .4s;--duration-slow: .6s;--duration-slower: .8s;--duration-slowest: 1.2s;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-elastic: cubic-bezier(.68, -.55, .27, 1.55);--ease-water: cubic-bezier(.25, .46, .45, .94);--transition-fast: var(--duration-fast) var(--ease-out);--transition-normal: var(--duration-normal) var(--ease-out);--transition-slow: var(--duration-slow) var(--ease-out);--transition-spring: var(--duration-slow) var(--ease-elastic);--transition-water: var(--duration-normal) var(--ease-water);@keyframes breathe{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.85}}@keyframes ripple{0%{transform:scale(1);opacity:.6}to{transform:scale(2.5);opacity:0}}@keyframes glow-pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes slide-up-bounce{0%{transform:translateY(100%);opacity:0}70%{transform:translateY(-8px);opacity:1}to{transform:translateY(0);opacity:1}}@keyframes pop-in{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes tide{0%,to{transform:translate(0)}50%{transform:translate(3px)}}}:root{--bg-primary: var(--gray-1);--bg-secondary: var(--gray-2);--bg-tertiary: var(--gray-3);--bg-elevated: var(--gray-3);--bg-overlay: hsla(220 20% 10% / .6);--bg-overlay-heavy: hsla(220 20% 10% / .85);--text-primary: var(--gray-12);--text-secondary: var( --gray-11 );--text-tertiary: var(--gray-9);--text-muted: var(--gray-8);--text-disabled: var(--gray-7);--text-on-accent: var(--gray-1);--text-link: var(--accent-9);--text-link-hover: var(--accent-10);--surface-card: hsla(220 20% 100% / .06);--surface-card-hover: hsla(220 20% 100% / .1);--surface-card-active: var(--gray-a5);--surface-card-border: var(--gray-a6);--surface-subtle: hsla(220 20% 100% / .04);--surface-panel: var(--gray-2);--surface-modal: var(--gray-2);--surface-input: var(--gray-3);--border-subtle: hsla(220 20% 100% / .05);--border-primary: hsla(220 20% 100% / .12);--border-secondary: hsla(220 20% 100% / .08);--border-medium: hsla(220 20% 100% / .18);--border-strong: hsla(220 20% 100% / .25);--border-focus: var(--accent-9);--border-focus-ring: var(--accent-a5);--brand-primary: var(--brand-9);--brand-primary-light: var(--brand-10);--brand-hover: var(--brand-10);--brand-active: var(--brand-8);--brand-subtle: var(--brand-a3);--brand-text: var(--brand-11);--accent-primary: var(--accent-9);--accent-primary-light: var(--accent-10);--accent-hover: var(--accent-10);--accent-active: var(--accent-8);--accent-subtle: var(--accent-a3);--status-success: var(--success-7);--status-success-text: var(--success-9);--status-success-bg: hsla(160 50% 55% / .15);--status-success-border: hsla(160 50% 55% / .25);--status-warning: var(--warning-7);--status-warning-text: var(--warning-9);--status-warning-bg: hsla(40 70% 60% / .15);--status-warning-border: hsla(40 70% 60% / .25);--status-error: var(--error-7);--status-error-text: var(--error-9);--status-error-bg: hsla(0 50% 60% / .15);--status-error-border: hsla(0 50% 60% / .25);--status-info: var(--info-7);--status-info-text: var(--info-9);--status-info-bg: hsla(200 60% 60% / .15);--status-info-border: hsla(200 60% 60% / .25);--success: var(--status-success);--warning: var(--status-warning);--error: var(--status-error);--info: var(--status-info);--color-water: var(--accent-9);--color-water-deep: var(--accent-6);--color-water-light: var(--accent-11);--color-spot-pier: var(--spot-pier);--color-spot-rocks: var(--spot-rocks);--color-spot-beach: var(--spot-beach);--color-spot-swimming: var(--spot-swimming);--color-spot-custom: var(--spot-custom);--color-condition-good: var(--status-success);--color-condition-fair: var(--status-warning);--color-condition-poor: var(--status-error);--color-solunar-peak: var(--brand-9);--color-solunar-minor: var(--accent-7);--color-tide-high: var(--accent-9);--color-tide-low: var(--accent-6);--score-go: var(--success-6);--score-maybe: var(--warning-6);--score-skip: var(--error-6);--score-go-bg: hsla(160 50% 60% / .18);--score-maybe-bg: hsla(45 65% 65% / .15);--score-skip-bg: hsla(0 45% 65% / .15);--water-deep: hsl(224 76% 40%);--water-primary: hsl(189 94% 37%);--water-light: hsl(189 94% 43%);--species-excellent-bg: var(--water-deep);--species-excellent-text: hsl(0 0% 100%);--species-excellent-border: hsl(224 76% 50%);--species-good-bg: var(--water-primary);--species-good-text: hsl(0 0% 100%);--species-good-border: hsl(189 94% 45%);--species-fair-bg: hsl(215 16% 47%);--species-fair-text: hsl(0 0% 100%);--species-fair-border: hsl(215 16% 55%);--species-poor-bg: hsl(215 20% 65%);--species-poor-text: hsl(222 47% 17%);--species-poor-border: hsl(215 20% 72%);--glow-water: 0 0 24px hsla(175 45% 76% / .25);--glow-water-strong: 0 0 32px hsla(175 45% 76% / .4);--glow-catch: 0 0 18px hsla(15 70% 80% / .3);--glow-moon: 0 0 40px hsla(45 60% 90% / .2);--glow-pier: 0 0 14px hsla(175 50% 70% / .4);--glow-rocks: 0 0 14px hsla(15 65% 75% / .4);--glow-beach: 0 0 14px hsla(45 55% 70% / .4);--glow-activity-peak: 0 0 20px hsla(15 70% 80% / .5);--glow-activity-minor: 0 0 12px hsla(175 45% 76% / .3);--orange-primary: var(--brand-primary);--orange-light: var(--brand-primary-light);--orange-dark: var(--brand-active);--chart-line-score: var(--brand-9);--chart-line-solunar: var(--accent-9);--chart-line-wind: var(--info-9);--chart-line-waves: var(--text-secondary);--chart-line-swell: var(--accent-7);--chart-line-temp: var(--warning-9);--chart-line-activity: var(--success-9);--chart-confidence-full: 1;--chart-confidence-high: .85;--chart-confidence-medium: .65;--chart-confidence-low: .45;--chart-confidence-minimal: .3;--chart-grid: hsla(220 20% 100% / .06);--chart-grid-strong: hsla(220 20% 100% / .12);--chart-axis-text: var(--text-tertiary);--chart-axis-line: var(--border-subtle);--chart-tooltip-bg: var(--surface-modal);--chart-tooltip-border: var(--border-medium);--chart-tooltip-text: var(--text-primary);--chart-now-line: var(--brand-9);--chart-tide-high: var(--accent-9);--chart-tide-low: var(--info-7);--chart-golden-window: hsla(45 70% 65% / .25);--chart-golden-label: hsl(45 75% 50%);--chart-major-peak: var(--brand-9);--chart-minor-peak: var(--accent-7);--chart-area-tide: hsla(175 45% 76% / .15);--chart-area-solunar: hsla(15 70% 80% / .12);--color-sunrise: hsl(45 80% 60%);--color-sunset: hsl(25 90% 55%)}:root{--space-card-padding: var(--space-4);--space-card-gap: var(--space-3);--space-card-gap-compact: var(--space-2);--space-modal-padding: var(--space-5);--space-modal-padding-mobile: var(--space-4);--space-modal-padding-desktop: var(--space-6);--space-modal-header-padding: var(--space-5) var(--space-6);--space-modal-header-gap: var(--space-3);--space-modal-footer-padding: var(--space-4) var(--space-6);--space-modal-gap: var(--space-4);--space-modal-gap-tight: var(--space-3);--space-section-gap: var(--space-6);--space-section-padding: var(--space-6);--space-input-padding-x: var(--space-4);--space-input-padding-y: var(--space-3);--space-input-gap: var(--space-2);--space-btn-padding-x: var(--space-4);--space-btn-padding-y: var(--space-3);--space-btn-gap: var(--space-2);--space-header-gap: var(--space-3);--page-gutter: var(--space-4);--bottom-nav-height: 56px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--layout-header-offset: calc(var(--size-header) + var(--safe-area-top));--layout-bottom-offset: calc( var(--bottom-nav-height) + var(--safe-area-bottom) );--layout-safe-padding-top: calc(var(--space-3) + var(--safe-area-top));--layout-safe-padding-bottom: calc(var(--space-3) + var(--safe-area-bottom));--layout-safe-padding-left: calc(var(--page-gutter) + var(--safe-area-left));--layout-safe-padding-right: calc( var(--page-gutter) + var(--safe-area-right) );--map-widget-inset-top: calc(var(--layout-header-offset) + var(--space-1));--browser-toolbar-buffer: 56px;--map-widget-inset-bottom: calc( var(--safe-area-bottom) + var(--browser-toolbar-buffer) );--map-widget-inset-left: calc(var(--page-gutter) + var(--safe-area-left));--map-widget-inset-right: calc(var(--page-gutter) + var(--safe-area-right));--map-widget-stack-gap: var(--space-2);--dynamic-header-height: var(--size-header, 52px);--dynamic-navbar-height: 0px;--dynamic-safe-top: calc(var(--layout-header-offset) + var(--space-2));--dynamic-safe-bottom: calc(var(--safe-area-bottom) + var(--space-2));--dynamic-available-height: calc( 100dvh - var(--dynamic-safe-top) - var(--dynamic-safe-bottom) );--smart-card-max-height: var(--dynamic-available-height);--smart-card-top: var(--dynamic-safe-top);--smart-card-bottom: var(--dynamic-safe-bottom);--density-row-height: 56px;--density-row-padding: var(--space-3);--density-row-gap: var(--space-3);--row-height-list: 56px;--row-height-dense: 32px;--row-height-dense-mobile: 34px;--row-height-map: 28px;--space-map-padding: var(--space-map-1);--space-map-gap: var(--space-map-0_5);--space-map-control-gap: var(--space-map-1);--space-map-label-padding: var(--space-map-0_5) var(--space-map-1)}[data-density=dense]{--density-row-height: var(--row-height-dense);--density-row-padding: var(--space-dense-1);--density-row-gap: var(--space-dense-1);--space-card-padding: var(--space-dense-2);--space-card-gap: var(--space-dense-1)}@media(max-width:767px){[data-density=dense]{--density-row-height: var(--row-height-dense-mobile)}}[data-density=map]{--density-row-height: var(--row-height-map);--density-row-padding: var(--space-map-0_5);--density-row-gap: var(--space-map-0_5);--space-card-padding: var(--space-map-1);--space-card-gap: var(--space-map-0_5);--space-modal-padding: var(--space-map-1);--space-modal-gap: var(--space-map-0_5)}:root{--type-display: var(--font-size-4xl);--type-title: var(--font-size-2xl);--type-heading: var(--font-size-xl);--type-subhead: 17px;--type-body: 15px;--type-callout: var(--font-size-base);--type-caption: var(--font-size-sm);--type-footnote: var(--font-size-sm);--text-xs: var(--font-size-rem-xs);--text-sm: var(--font-size-rem-sm);--text-base: var(--font-size-rem-base);--text-md: var(--font-size-rem-md);--text-lg: var(--font-size-rem-lg);--text-xl: var(--font-size-rem-xl);--text-2xl: var(--font-size-rem-2xl);--text-3xl: var(--font-size-rem-3xl);--text-4xl: var(--font-size-rem-4xl);--font-normal: var(--font-weight-normal);--font-medium: var(--font-weight-medium);--font-semibold: var(--font-weight-semibold);--font-bold: var(--font-weight-bold);--leading-tight: var(--line-height-tight);--leading-normal: var(--line-height-normal);--leading-relaxed: var(--line-height-relaxed);--tracking-tight: var(--letter-spacing-tight);--tracking-normal: var(--letter-spacing-normal);--tracking-wide: var(--letter-spacing-wide);--tracking-wider: var(--letter-spacing-wider);--density-type-body: var(--type-body);--density-type-caption: var(--type-caption);--density-leading: var(--leading-normal)}[data-density=dense]{--density-type-body: var(--font-size-dense-base);--density-type-caption: var(--font-size-dense-sm);--density-leading: var(--line-height-dense);--type-body: var(--font-size-dense-base);--type-caption: var(--font-size-dense-sm);--leading-normal: var(--line-height-dense)}[data-density=map]{--density-type-body: var(--font-size-map-sm);--density-type-caption: var(--font-size-map-xs);--density-leading: var(--line-height-map);--type-body: var(--font-size-map-sm);--type-caption: var(--font-size-map-xs);--type-footnote: var(--font-size-map-tiny);--leading-normal: var(--line-height-map);--leading-tight: var(--line-height-map)}:root{--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-modal: 0 24px 80px rgba(0, 0, 0, .5);--shadow-panel: 0 -4px 20px rgba(0, 0, 0, .3);--shadow-card: 0 4px 12px rgba(0, 0, 0, .2);--z-base: 0;--z-elevated: 10;--z-dropdown: 100;--z-sticky: 200;--z-map-overlay: 450;--z-overlay: 500;--z-modal-backdrop: 1000;--z-modal: 1001;--z-panel: 1100;--z-drawer: 1500;--z-toast: 2000;--z-tooltip: 2100}:root{--radius-none: 0;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--radius-button: var(--radius-md);--radius-input: var(--radius-md);--radius-card: var(--radius-sm);--radius-modal: var(--radius-xl);--radius-chip: var(--radius-full);--radius-badge: var(--radius-sm);--radius-avatar: var(--radius-full);--radius-tooltip: var(--radius-sm);--radius-panel: var(--radius-md);--border-width-0: 0;--border-width-hairline: .5px;--border-width-thin: 1px;--border-width-medium: 2px;--border-width-thick: 3px}:root{--weight-subtle: var(--gray-a3);--weight-primary: var(--gray-a6);--weight-medium: var(--gray-a8);--weight-strong: var(--gray-7);--border-weight-subtle: var(--border-subtle);--border-weight-primary: var(--border-primary);--border-weight-medium: var(--border-medium);--border-weight-strong: var(--border-strong);--bg-weight-subtle: var(--surface-subtle);--bg-weight-primary: var(--surface-card);--bg-weight-medium: var(--surface-card-hover);--bg-weight-strong: var(--bg-elevated);--text-weight-subtle: var(--text-muted);--text-weight-primary: var(--text-secondary);--text-weight-medium: var(--text-primary);--text-weight-strong: var(--text-primary);--space-weight-subtle: var(--space-1);--space-weight-primary: var(--space-2);--space-weight-medium: var(--space-3);--space-weight-strong: var(--space-4);--type-weight-subtle: var(--font-normal);--type-weight-primary: var(--font-medium);--type-weight-medium: var(--font-semibold);--type-weight-strong: var(--font-bold);--elevation-weight-subtle: var(--shadow-sm);--elevation-weight-primary: var(--shadow-md);--elevation-weight-medium: var(--shadow-lg);--elevation-weight-strong: var(--shadow-xl);--hierarchy-border-standard: var(--border-weight-primary);--hierarchy-border-dense: var(--border-weight-medium);--hierarchy-border-map: var(--border-weight-strong);--hierarchy-text-standard: var(--text-weight-primary);--hierarchy-text-dense: var(--text-weight-medium);--hierarchy-text-map: var(--text-weight-strong)}[data-density=dense]{--hierarchy-border: var(--hierarchy-border-dense);--hierarchy-text: var(--hierarchy-text-dense);--border-weight-primary: var(--border-weight-medium);--text-weight-primary: var(--text-weight-medium)}[data-density=map]{--hierarchy-border: var(--hierarchy-border-map);--hierarchy-text: var(--hierarchy-text-map);--border-weight-primary: var(--border-weight-strong);--text-weight-primary: var(--text-weight-strong);--bg-weight-primary: var(--bg-weight-medium)}:root{--density-row-height-standard: 56px;--density-row-height-dense: 32px;--density-row-height-dense-mobile: 34px;--density-row-height-map: 28px;--density-cell-padding-standard: var(--space-3);--density-cell-padding-dense: var(--space-dense-1);--density-cell-padding-map: var(--space-map-0_5);--density-font-body-standard: var(--type-body);--density-font-body-dense: var(--font-size-dense-base);--density-font-body-map: var(--font-size-map-sm);--density-font-caption-standard: var(--type-caption);--density-font-caption-dense: var(--font-size-dense-sm);--density-font-caption-map: var(--font-size-map-xs);--density-font-label-standard: var(--type-caption);--density-font-label-dense: var(--font-size-dense-sm);--density-font-label-map: var(--font-size-map-tiny);--density-leading-standard: var(--leading-normal);--density-leading-dense: var(--line-height-dense);--density-leading-map: var(--line-height-map);--density-icon-standard: var(--size-icon-md);--density-icon-dense: var(--size-icon-dense-md);--density-icon-map: var(--size-icon-map-sm);--density-touch-standard: var(--size-touch-min);--density-touch-dense: var(--size-touch-dense-min);--density-touch-map: var(--size-touch-map-min)}[data-density=dense]{--density-row-height: var(--density-row-height-dense);--density-cell-padding: var(--density-cell-padding-dense);--density-font-body: var(--density-font-body-dense);--density-font-caption: var(--density-font-caption-dense);--density-font-label: var(--density-font-label-dense);--density-leading: var(--density-leading-dense);--density-icon: var(--density-icon-dense);--density-touch: var(--density-touch-dense)}@media(max-width:767px){[data-density=dense]{--density-row-height: var(--density-row-height-dense-mobile)}}[data-density=map]{--density-row-height: var(--density-row-height-map);--density-cell-padding: var(--density-cell-padding-map);--density-font-body: var(--density-font-body-map);--density-font-caption: var(--density-font-caption-map);--density-font-label: var(--density-font-label-map);--density-leading: var(--density-leading-map);--density-icon: var(--density-icon-map);--density-touch: var(--density-touch-map);--text-primary: var(--gray-12);--text-secondary: var(--gray-11);--border-primary: var(--gray-a8)}:root{--map-overlay-padding: var(--space-map-1);--map-overlay-gap: var(--space-map-0_5);--map-overlay-border-radius: var(--radius-sm);--map-label-font-size: var(--font-size-map-sm);--map-label-font-weight: var(--font-weight-medium);--map-label-line-height: var(--line-height-map);--map-label-color: var(--text-primary);--map-label-bg: var(--bg-elevated);--map-label-small-font-size: var(--font-size-map-xs);--map-label-micro-font-size: var( --font-size-map-tiny );--map-marker-size: var(--size-map-marker);--map-marker-size-small: 20px;--map-marker-size-large: 32px;--map-cluster-size: var(--size-map-cluster);--map-control-size: var(--size-map-control);--map-control-gap: var(--space-map-1);--map-control-padding: var(--space-map-0_5);--map-popup-padding: var(--space-map-1);--map-popup-gap: var(--space-map-0_5);--map-popup-font-size: var(--font-size-map-sm);--map-popup-border-radius: var(--radius-sm);--map-legend-padding: var(--space-map-1);--map-legend-gap: var(--space-map-0_5);--map-legend-font-size: var(--font-size-map-xs);--map-legend-item-gap: var(--space-map-1);--map-panel-padding: var(--space-map-1);--map-panel-gap: var(--space-map-0_5);--map-panel-header-padding: var(--space-map-1);--map-panel-content-padding: var(--space-map-1);--map-widget-bg: var(--bg-elevated);--map-widget-border: var(--border-primary);--map-widget-border-radius: var(--radius-lg);--map-widget-shadow: var(--shadow-lg);--map-widget-backdrop-blur: 8px;--map-btn-size: 40px;--map-btn-size-sm: 32px;--map-btn-padding: var(--space-2);--map-btn-border-radius: var(--radius-md);--map-btn-bg: rgba(30, 30, 30, .9);--map-btn-bg-hover: rgba(50, 50, 50, .95);--map-btn-bg-active: var(--brand-primary);--map-animation-duration: var(--duration-normal);--map-animation-easing: var(--ease-out);--map-pulse-duration: 2s}[data-density=map]{--map-label-color: var(--gray-12);--map-label-bg: var(--gray-2);--map-popup-bg: var(--gray-2);--map-popup-border: var(--border-primary);--map-overlay-border: var(--border-primary);--map-legend-border: var(--border-primary)}:root{--gray-1: hsl(215 25% 18%);--gray-2: hsl(215 22% 22%);--gray-3: hsl(215 20% 28%);--gray-4: hsl(215 18% 34%);--gray-5: hsl(215 15% 42%);--gray-6: hsl(215 12% 50%);--gray-7: hsl(215 10% 58%);--gray-8: hsl(215 8% 66%);--gray-9: hsl(215 6% 74%);--gray-10: hsl(215 5% 82%);--gray-11: hsl(215 4% 90%);--gray-12: hsl(215 5% 96%);--brand-1: hsl(15 30% 12%);--brand-2: hsl(15 35% 18%);--brand-3: hsl(15 40% 26%);--brand-4: hsl(15 45% 36%);--brand-5: hsl(15 50% 48%);--brand-6: hsl(15 55% 60%);--brand-7: hsl(15 60% 70%);--brand-8: hsl(15 65% 76%);--brand-9: hsl(15 70% 80%);--brand-10: hsl(15 75% 85%);--brand-11: hsl(15 80% 90%);--brand-12: hsl(15 85% 95%);--accent-1: hsl(175 20% 12%);--accent-2: hsl(175 22% 18%);--accent-3: hsl(175 24% 26%);--accent-4: hsl(175 26% 36%);--accent-5: hsl(175 28% 48%);--accent-6: hsl(175 32% 58%);--accent-7: hsl(175 36% 66%);--accent-8: hsl(175 40% 72%);--accent-9: hsl(175 45% 76%);--accent-10: hsl(175 50% 82%);--accent-11: hsl(175 55% 88%);--accent-12: hsl(175 60% 94%);--gray-a1: hsla(220 20% 100% / .03);--gray-a2: hsla(220 20% 100% / .05);--gray-a3: hsla(220 20% 100% / .08);--gray-a4: hsla(220 20% 100% / .1);--gray-a5: hsla(220 20% 100% / .14);--gray-a6: hsla(220 20% 100% / .18);--gray-a8: hsla(220 20% 100% / .24);--brand-a3: hsla(15 70% 80% / .15);--brand-a5: hsla(15 70% 80% / .25);--accent-a3: hsla(175 45% 76% / .15);--accent-a5: hsla(175 45% 76% / .25);--text-primary: var(--gray-12);--text-secondary: var(--gray-10);--text-tertiary: var(--gray-9);--text-muted: var(--gray-8);--text-link: var(--accent-9);--text-link-hover: var(--accent-10);--bg-primary: var(--gray-1);--bg-secondary: var(--gray-2);--bg-tertiary: var(--gray-3);--bg-elevated: var(--gray-3);--bg-overlay: hsla(220 20% 10% / .6);--surface-card: hsla(220 20% 100% / .06);--surface-card-hover: hsla(220 20% 100% / .1);--surface-panel: var(--gray-2);--border-primary: hsla(220 20% 100% / .12);--border-secondary: hsla(220 20% 100% / .08);--border-subtle: hsla(220 20% 100% / .05);--border-focus: var(--accent-9);--brand-primary: var(--brand-9);--brand-hover: var(--brand-10);--status-success: hsl(160 45% 55%);--status-success-text: hsl(160 50% 75%);--status-success-bg: hsla(160 45% 55% / .15);--status-warning: hsl(40 70% 60%);--status-warning-text: hsl(40 75% 75%);--status-warning-bg: hsla(40 70% 60% / .15);--status-error: hsl(0 50% 60%);--status-error-text: hsl(0 55% 78%);--status-error-bg: hsla(0 50% 60% / .15);--status-info: hsl(200 60% 60%);--status-info-text: hsl(200 65% 78%);--status-info-bg: hsla(200 60% 60% / .15);--color-water: var(--accent-9);--color-water-deep: var(--accent-6);--color-water-light: var(--accent-11);--color-spot-pier: hsl(175 50% 70%);--color-spot-rocks: hsl(15 65% 75%);--color-spot-beach: hsl(45 55% 70%);--color-spot-swimming: hsl(200 55% 70%);--color-condition-good: var(--status-success);--color-condition-fair: var(--status-warning);--color-condition-poor: var(--status-error);--color-solunar-peak: var(--brand-9);--color-solunar-minor: var(--accent-7);--color-tide-high: var(--accent-9);--color-tide-low: var(--accent-6);--white-03: rgba(255, 255, 255, .03);--white-06: rgba(255, 255, 255, .06);--white-10: rgba(255, 255, 255, .1);--white-20: rgba(255, 255, 255, .2);--black-60: rgba(0, 0, 0, .5);--glow-water: 0 0 24px hsla(175 45% 76% / .25);--glow-water-strong: 0 0 32px hsla(175 45% 76% / .4);--glow-catch: 0 0 18px hsla(15 70% 80% / .3);--glow-moon: 0 0 40px hsla(45 60% 90% / .2);--glow-pier: 0 0 14px hsla(175 50% 70% / .4);--glow-rocks: 0 0 14px hsla(15 65% 75% / .4);--glow-beach: 0 0 14px hsla(45 55% 70% / .4);--glow-activity-peak: 0 0 20px hsla(15 70% 80% / .5);--glow-activity-minor: 0 0 12px hsla(175 45% 76% / .3);--score-go: hsl(160 50% 60%);--score-maybe: hsl(45 65% 65%);--score-skip: hsl(0 45% 65%);--score-go-bg: hsla(160 50% 60% / .18);--score-maybe-bg: hsla(45 65% 65% / .15);--score-skip-bg: hsla(0 45% 65% / .15)}:root{--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-card-padding: var(--space-4);--space-card-gap: var(--space-3);--space-panel-padding: var(--space-4);--space-section-gap: var(--space-6);--page-gutter: var(--space-4);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}:root{--font-display: "JetBrains Mono", monospace;--font-sans: "JetBrains Mono", -apple-system, BlinkMacSystemFont, monospace;--font-mono: "JetBrains Mono", Monaco, Consolas, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.2;--leading-normal: 1.5;--leading-relaxed: 1.75;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em}:root{--radius-none: 0;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-panel: 0 -4px 20px rgba(0, 0, 0, .3);--shadow-card: 0 4px 12px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-base: 0;--z-elevated: 10;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 1000;--z-panel: 1100;--z-toast: 2000}:root{--duration-instant: .1s;--duration-fast: .25s;--duration-normal: .4s;--duration-slow: .6s;--duration-slower: .8s;--duration-slowest: 1.2s;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-elastic: cubic-bezier(.68, -.55, .27, 1.55);--ease-water: cubic-bezier(.25, .46, .45, .94);--panel-slide-up: translateY(100%);--panel-slide-active: translateY(0);--panel-duration: var(--duration-slow);--panel-ease: var(--ease-out);--marker-hover-scale: 1.15;--marker-duration: var(--duration-fast)}@keyframes breathe{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.85}}@keyframes ripple{0%{transform:scale(1);opacity:.6}to{transform:scale(2.5);opacity:0}}@keyframes glow-pulse{0%,to{box-shadow:var(--glow-water)}50%{box-shadow:var(--glow-water-strong)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes slide-up-bounce{0%{transform:translateY(100%);opacity:0}70%{transform:translateY(-8px);opacity:1}to{transform:translateY(0);opacity:1}}@keyframes pop-in{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes tide{0%,to{transform:translate(0)}50%{transform:translate(3px)}}@keyframes number-pop{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.1);opacity:1}to{transform:scale(1)}}.animate-breathe{animation:breathe 3s var(--ease-water) infinite}.animate-ripple{animation:ripple 2s var(--ease-out) infinite}.animate-glow{animation:glow-pulse 2.5s var(--ease-water) infinite}.animate-float{animation:float 3s var(--ease-in-out) infinite}.animate-pop-in{animation:pop-in var(--duration-slow) var(--ease-bounce) forwards}.animate-slide-up{animation:slide-up-bounce var(--duration-slow) var(--ease-out) forwards}.animate-tide{animation:tide 4s var(--ease-water) infinite}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}html,body,#root{height:100%;width:100%}html{scroll-padding-top:var(--layout-header-offset);scroll-padding-bottom:var(--dynamic-safe-bottom, var(--safe-area-bottom))}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-primary)}.app-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-sticky);display:flex;align-items:center;justify-content:space-between;padding:calc(var(--space-3) + var(--safe-area-top)) var(--layout-safe-padding-right) var(--space-3) var(--layout-safe-padding-left);background:var(--gray-2);border-bottom:1px solid var(--border-primary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-header h1{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:#f0f4f8;letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.3)}.tagline{font-family:var(--font-mono);font-size:var(--text-sm);color:#b0b8c4;letter-spacing:.1em;text-transform:lowercase}.app-main{flex:1;padding-top:var(--layout-header-offset);height:100vh;height:100dvh}.selected-spot-bar{position:fixed;bottom:var(--map-widget-inset-bottom);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--gray-2);border:1px solid var(--border-primary);border-radius:var(--radius-full);box-shadow:var(--glow-water);font-family:var(--font-mono);z-index:calc(var(--z-sticky) + 1);animation:slide-up-bounce var(--duration-slow) var(--ease-out) forwards}.spot-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.spot-type{font-size:var(--text-sm);font-weight:500;color:var(--color-water);text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;background:var(--accent-a3);border-radius:var(--radius-full)}@keyframes slide-up-bounce{0%{transform:translate(-50%) translateY(100%);opacity:0}70%{transform:translate(-50%) translateY(-8px);opacity:1}to{transform:translate(-50%) translateY(0);opacity:1}}@media(max-width:767px){.app-header{padding:calc(var(--space-3) + var(--safe-area-top)) var(--layout-safe-padding-right) var(--space-3) var(--layout-safe-padding-left)}.app-header h1{font-size:var(--text-base)}.selected-spot-bar{left:var(--space-4);right:var(--space-4);transform:none;justify-content:center}@keyframes slide-up-bounce{0%{transform:translateY(100%);opacity:0}70%{transform:translateY(-8px);opacity:1}to{transform:translateY(0);opacity:1}}}.smart-card{max-height:var(--smart-card-max-height);overflow-y:auto;overscroll-behavior:contain}.smart-card--top{position:fixed;top:var(--smart-card-top);left:var(--layout-safe-padding-left);right:var(--layout-safe-padding-right)}.smart-card--bottom{position:fixed;bottom:var(--smart-card-bottom);left:var(--layout-safe-padding-left);right:var(--layout-safe-padding-right)}.smart-card--fill{position:fixed;top:var(--smart-card-top);bottom:var(--smart-card-bottom);left:var(--layout-safe-padding-left);right:var(--layout-safe-padding-right)}.smart-card--center{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);max-height:var(--smart-card-max-height);max-width:calc(100vw - var(--layout-safe-padding-left) - var(--layout-safe-padding-right))}:root{--blue-primary: #0077be;--blue-secondary: #0099e6;--green-success: #10b981;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-900: #111827;--text-primary: #1f2937;--text-secondary: #6b7280;--bg-primary: #ffffff;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:var(--text-base);line-height:1.5;color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer}
