@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.user-menu{display:flex;align-items:center;gap:12px;padding:8px 12px;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.user-info{display:flex;align-items:center;gap:8px}.user-name{font-size:14px;font-weight:500;color:#333}.user-badge{padding:2px 8px;font-size:11px;font-weight:600;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.admin-badge{background-color:#dc3545;color:#fff}.user-avatar{width:32px;height:32px;border-radius:50%;cursor:pointer;transition:transform .2s}.user-avatar:hover{transform:scale(1.05)}.user-menu-dropdown{margin-top:8px;min-width:200px;background-color:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026}.user-menu-signed-out{display:flex;align-items:center;gap:12px}.btn{padding:8px 16px;font-size:14px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-wrapper{width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:24px;color:#fff}.auth-header h1{font-size:28px;font-weight:700;margin-bottom:8px}.auth-header p{font-size:14px;opacity:.9}.clerk-card{border-radius:12px;box-shadow:0 8px 32px #0003}@media(max-width:768px){.user-menu{padding:6px 10px}.user-name{display:none}.auth-header h1{font-size:24px}}.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}}.ocean-map-container{position:relative;width:100%;height:100%}.ocean-map-header{position:absolute;top:0;left:0;right:0;z-index:1001;background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:14px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px #00000014,0 2px 12px #0000000f}.ocean-map-title{margin:0;font-size:17px;font-weight:700;color:#111827;letter-spacing:-.3px;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.grid-controls{position:absolute;top:80px;right:20px;z-index:1000}.control-panel{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 10px #0003;min-width:300px}.control-panel h2{margin:0 0 15px;font-size:18px;color:#333}.grid-info{background:#f5f5f5;padding:10px;border-radius:4px;margin-bottom:15px;font-size:13px}.grid-info p{margin:5px 0;color:#666}.grid-info strong{color:#333}.button-group{display:flex;gap:10px;margin-bottom:15px}.btn{flex:1;padding:10px 15px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background:#38f;color:#fff}.btn-primary:hover{background:#2670d8}.btn-secondary{background:#f44336;color:#fff}.btn-secondary:hover{background:#d32f2f}.info-box{background:#e3f2fd;padding:10px;border-radius:4px;font-size:12px}.info-box p{margin:3px 0;color:#1976d2}.map-controls{position:absolute;bottom:20px;left:20px;z-index:1000;background:#fff;padding:15px;border-radius:8px;box-shadow:0 2px 10px #0003}.vessel-marker{background:transparent!important;border:none!important;cursor:pointer;transition:transform .3s ease}.vessel-marker:hover{transform:scale(1.2)}.leaflet-popup-content{margin:8px 12px}.map-controls label{display:block;margin:5px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.map-controls input[type=checkbox]{margin-right:8px}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-wrapper{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:40px;max-width:500px;width:100%}.auth-header{text-align:center;margin-bottom:30px}.auth-header h1{font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 12px}.auth-header p{font-size:16px;color:#666;margin:0}.clerk-root{width:100%}.clerk-card{box-shadow:none!important;border:none!important}.btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;text-decoration:none;display:inline-block;transition:all .2s;cursor:pointer;border:none}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-secondary{background:#f3f4f6;color:#1a1a1a}.btn-secondary:hover{background:#e5e7eb}.admin-dashboard{padding:24px 32px;max-width:1800px;margin:0 auto;background-color:#f8f9fa;min-height:100vh}.admin-header{margin-bottom:32px}.admin-header h1{font-size:32px;font-weight:700;color:#2c3e50;margin-bottom:8px}.admin-header p{color:#6c757d;font-size:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px}.stat-card{background-color:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:36px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background-color:#f0f0f0;border-radius:12px}.stat-content{flex:1}.stat-content h3{font-size:14px;font-weight:600;color:#6c757d;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:28px;font-weight:700;color:#2c3e50;margin:0}.stat-subtitle{font-size:12px;color:#95a5a6}.admin-section{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{font-size:20px;font-weight:600;color:#2c3e50;margin:0}.search-box input{padding:8px 16px;border:1px solid #dee2e6;border-radius:6px;font-size:14px;width:300px}.search-box input:focus{outline:none;border-color:#007bff}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table thead{background-color:#f8f9fa}.users-table th{padding:12px;text-align:left;font-size:13px;font-weight:600;color:#495057;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #dee2e6}.users-table td{padding:12px;border-bottom:1px solid #f0f0f0;font-size:14px;color:#495057}.users-table tbody tr:hover{background-color:#f8f9fa}.role-select{padding:4px 8px;border:1px solid #dee2e6;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer}.role-select.role-admin{background-color:#dc3545;color:#fff;border-color:#dc3545}.role-select.role-moderator{background-color:#ffc107;color:#212529;border-color:#ffc107}.role-select.role-user{background-color:#28a745;color:#fff;border-color:#28a745}.tier-badge,.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tier-free{background-color:#e3f2fd;color:#1976d2}.tier-premium{background-color:#fff3e0;color:#f57c00}.tier-pro{background-color:#f3e5f5;color:#7b1fa2}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.actions-cell{display:flex;gap:8px}.btn-small{padding:4px 12px;font-size:12px;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#218838}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px}.btn-pagination{padding:8px 16px;font-size:14px;font-weight:500;background-color:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.btn-pagination:hover:not(:disabled){background-color:#0056b3}.btn-pagination:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.5}.pagination-info{font-size:14px;color:#495057;font-weight:500}.endpoint-stats{display:flex;flex-direction:column;gap:12px}.endpoint-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background-color:#f8f9fa;border-radius:6px}.endpoint-name{font-size:14px;color:#495057;font-weight:500;font-family:monospace}.endpoint-count{font-size:14px;color:#007bff;font-weight:600}.admin-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.admin-dashboard{padding:16px}.stats-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.search-box input{width:100%}.users-table{font-size:12px}.users-table th,.users-table td{padding:8px}}.admin-tabs{display:flex;gap:4px;border-bottom:2px solid #dee2e6;margin-bottom:28px}.admin-tab{padding:10px 20px;font-size:14px;font-weight:600;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;color:#6c757d;cursor:pointer;transition:all .2s;border-radius:6px 6px 0 0}.admin-tab:hover{background-color:#f8f9fa;color:#2c3e50}.admin-tab-active{color:#007bff;border-bottom-color:#007bff;background-color:#f0f7ff}.vt-container{display:flex;flex-direction:column;gap:20px}.vt-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px}.vt-header h2{font-size:22px;font-weight:700;color:#2c3e50;margin:0 0 4px}.vt-subtitle{color:#6c757d;font-size:14px;margin:0}.vt-action-buttons{display:flex;gap:10px;flex-wrap:wrap}.vt-btn{padding:9px 18px;font-size:13px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .18s;white-space:nowrap}.vt-btn:disabled{opacity:.55;cursor:not-allowed}.vt-btn-primary{background:#007bff;color:#fff}.vt-btn-primary:hover:not(:disabled){background:#0056b3}.vt-btn-secondary{background:#6c757d;color:#fff}.vt-btn-secondary:hover:not(:disabled){background:#545b62}.vt-btn-warning{background:#f0ad4e;color:#333}.vt-btn-warning:hover:not(:disabled){background:#ec971f}.vt-btn-approve{background:#27ae60;color:#fff}.vt-btn-approve:hover:not(:disabled){background:#1e8449}.vt-btn-danger{background:#dc3545;color:#fff}.vt-btn-danger:hover:not(:disabled){background:#bd2130}.vt-btn-approved{background:#a8d5b5;color:#155724;cursor:default}.vt-banner{padding:12px 16px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:8px}.vt-banner-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.vt-banner-error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.vt-banner-close{margin-left:auto;background:none;border:none;font-size:18px;cursor:pointer;color:inherit;opacity:.7;line-height:1}.vt-banner-close:hover{opacity:1}.vt-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.vt-summary-card{background:#fff;border-radius:10px;padding:14px 16px;box-shadow:0 1px 6px #00000014;display:flex;align-items:center;gap:12px}.vt-card-icon{font-size:26px}.vt-card-value{font-size:22px;font-weight:700;color:#2c3e50;line-height:1}.vt-card-label{font-size:11px;color:#6c757d;font-weight:500;text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.vt-card-fishing .vt-card-value{color:#c0392b}.vt-card-trawling .vt-card-value{color:#e74c3c}.vt-card-slow .vt-card-value{color:#e67e22}.vt-controls{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 1px 6px #00000014}.vt-control-group{display:flex;flex-direction:column;gap:5px}.vt-control-group label{font-size:11px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.4px}.vt-control-group select,.vt-control-group input[type=date]{padding:7px 10px;border:1px solid #ced4da;border-radius:5px;font-size:13px;background:#fff;min-width:160px}.vt-checkbox-group{flex-direction:row;align-items:center;gap:6px;padding-bottom:4px}.vt-checkbox-group label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#495057;text-transform:none;letter-spacing:0;cursor:pointer}.vt-legend-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;background:#fff;border-radius:10px;padding:12px 20px;box-shadow:0 1px 6px #00000014}.vt-legend-items{display:flex;gap:20px;flex-wrap:wrap}.vt-legend-item{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.vt-swatch{display:inline-block;width:28px;height:4px;border-radius:2px}.vt-swatch-fishing{background:#e74c3c}.vt-swatch-transit{background:#3498db}.vt-swatch-port{background:#7f8c8d}.vt-track-count{font-size:12px;color:#6c757d}.vt-map-wrap{position:relative;width:100%;height:1000px;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #0000001f}.vt-map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fffc;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;gap:12px}.vt-spinner{width:36px;height:36px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin .8s linear infinite}.vt-popup{min-width:240px;font-size:13px}.vt-popup-type{font-size:15px;font-weight:700;margin-bottom:10px;padding:4px 8px;border-radius:4px;display:inline-block}.vt-popup-type-fishing{background:#fde8e7;color:#c0392b}.vt-popup-type-transit{background:#e8f4fd;color:#2980b9}.vt-popup-type-port{background:#f0f0f0;color:#555}.vt-popup-table{width:100%;border-collapse:collapse}.vt-popup-table td{padding:3px 6px;vertical-align:top}.vt-popup-table td:first-child{color:#6c757d;font-weight:500;white-space:nowrap;padding-right:12px}.vt-vessel-table-wrap{background:#fff;border-radius:12px;padding:20px 24px;box-shadow:0 1px 6px #00000014}.vt-vessel-table-wrap h3{margin:0 0 14px;font-size:17px;font-weight:600;color:#2c3e50}.vt-vessel-table{width:100%;border-collapse:collapse;font-size:13px}.vt-vessel-table th{text-align:left;padding:9px 12px;background:#f8f9fa;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#495057;border-bottom:2px solid #dee2e6}.vt-vessel-table td{padding:9px 12px;border-bottom:1px solid #f0f0f0;color:#495057}.vt-vessel-table tbody tr:hover{background:#f8f9fa}.vt-row-selected{background:#e8f4fd!important}.vt-table-hint{font-size:12px;color:#95a5a6;margin:8px 0 0}.vt-approve-guide{background:#fffdf0;border:1px solid #f0e68c;border-radius:12px;padding:20px 24px}.vt-approve-guide h3{margin:0 0 12px;font-size:15px;font-weight:700;color:#856404}.vt-approve-guide ul{margin:0 0 12px;padding-left:20px;display:flex;flex-direction:column;gap:6px}.vt-approve-guide li{font-size:13px;color:#495057}.vt-approve-guide p{font-size:13px;color:#6c757d;margin:0}.vt-approve-guide code{background:#f0f0f0;padding:1px 5px;border-radius:3px;font-size:12px}.vt-approved-banner{margin-top:16px;background:#d4edda;color:#155724;padding:12px 16px;border-radius:8px;font-weight:600;font-size:14px;border:1px solid #c3e6cb}.admin-ocean-map-wrap{width:100%;height:calc(100vh - 160px);min-height:600px;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px #0000001f;position:relative}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;transition:background .2s ease,box-shadow .2s ease}.nav--scrolled{background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px #00000014,0 2px 12px #0000000d}.nav__inner{max-width:1120px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}.nav__logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}.nav__logo-text{font-size:16px;font-weight:700;color:#111827;letter-spacing:-.3px}.nav__links{display:flex;list-style:none;gap:4px;margin:0;padding:0}.nav__link{display:block;padding:6px 14px;font-size:14px;font-weight:500;color:#374151;text-decoration:none;border-radius:6px;transition:color .15s,background .15s}.nav__link:hover{color:#111827;background:#0000000d}.nav__actions{margin-left:auto;display:flex;align-items:center;gap:8px}.nav__signin{padding:6px 14px;font-size:14px;font-weight:500;color:#374151;text-decoration:none;border-radius:6px;transition:color .15s,background .15s}.nav__signin:hover{color:#111827;background:#0000000d}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;font-size:15px;font-weight:600;border-radius:8px;border:none;cursor:pointer;text-decoration:none;transition:all .15s ease;font-family:inherit}.btn--sm{padding:7px 16px;font-size:14px}.btn--lg{padding:14px 28px;font-size:16px;border-radius:10px}.btn--primary{background:#3b82f6;color:#fff}.btn--primary:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f659}.btn--outline{background:transparent;color:#3b82f6;border:1.5px solid #3b82f6}.btn--outline:hover{background:#eff6ff}.btn--outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}.btn--outline-white:hover{background:#ffffff1a;border-color:#fff}.nav__hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;background:none;border:none;cursor:pointer;margin-left:auto}.hamburger-line{display:block;width:20px;height:2px;background:#374151;border-radius:2px;transition:all .2s ease}.nav__mobile-menu{display:flex;flex-direction:column;gap:4px;padding:12px 16px 20px;background:#fff;border-top:1px solid #e5e7eb}.nav__mobile-link{display:block;padding:10px 12px;font-size:15px;font-weight:500;color:#374151;text-decoration:none;border-radius:8px;transition:background .15s}.nav__mobile-link:hover{background:#f3f4f6}.nav__mobile-divider{height:1px;background:#e5e7eb;margin:8px 0}@media(max-width:768px){.nav__links,.nav__actions{display:none}.nav__hamburger{display:flex}.nav--scrolled .nav__inner,.nav__inner{background:transparent}}.footer{background:#0c2340;color:#ffffffb3;padding:60px 24px 0}.footer__inner{max-width:1120px;margin:0 auto;display:flex;gap:80px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}.footer__brand{flex:0 0 240px}.footer__logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:#fff;font-size:16px;font-weight:700;letter-spacing:-.3px;margin-bottom:16px}.footer__tagline{font-size:14px;line-height:1.6;color:#ffffff8c;max-width:220px}.footer__cols{display:flex;gap:60px;flex:1}.footer__col h4{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#fff6;margin-bottom:16px}.footer__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.footer__col a{font-size:14px;color:#ffffffa6;text-decoration:none;transition:color .15s}.footer__col a:hover{color:#fff}.footer__bottom{max-width:1120px;margin:0 auto;padding:20px 0 24px;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:#ffffff59}.footer__bottom-links{display:flex;gap:20px}.footer__bottom-links a{color:#ffffff59;text-decoration:none;transition:color .15s}.footer__bottom-links a:hover{color:#ffffffb3}@media(max-width:768px){.footer__inner{flex-direction:column;gap:40px}.footer__brand{flex:none}.footer__cols{gap:32px;flex-wrap:wrap}.footer__bottom{flex-direction:column;gap:12px;text-align:center}}.home{min-height:100vh;background:#f5f3ef}.section-inner{max-width:1120px;margin:0 auto;padding:0 24px}.section-header{text-align:center;margin-bottom:56px}.section-title{font-size:clamp(28px,4vw,40px);font-weight:800;color:#111827;letter-spacing:-.5px;line-height:1.2;margin-bottom:16px}.section-sub{font-size:17px;color:#6b7280;max-width:560px;margin:0 auto;line-height:1.65}.hero{padding:120px 24px 80px;background:linear-gradient(160deg,#f0f7ff,#f5f3ef 60%);overflow:hidden}.hero__inner{max-width:1120px;margin:0 auto;display:flex;align-items:center;gap:64px}.hero__text{flex:1;min-width:0}.hero__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#3b82f6;margin-bottom:20px}.hero__eyebrow-dot{width:8px;height:8px;border-radius:50%;background:#16a34a;box-shadow:0 0 0 3px #16a34a33;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #16a34a33}50%{box-shadow:0 0 0 6px #16a34a1a}}.hero__headline{font-size:clamp(40px,6vw,68px);font-weight:900;line-height:1.05;letter-spacing:-2px;color:#111827;margin-bottom:20px}.hero__headline--accent{color:#3b82f6}.hero__sub{font-size:18px;line-height:1.65;color:#4b5563;max-width:480px;margin-bottom:36px}.hero__actions{display:flex;gap:12px;flex-wrap:wrap}.hero__disclaimer{margin-top:16px;font-size:13px;color:#9ca3af}.hero__visual{flex:0 0 380px}.app-preview{background:#fff;border-radius:20px;box-shadow:0 4px 6px #0000000a,0 20px 60px #0000001f;overflow:hidden;border:1px solid rgba(0,0,0,.06)}.app-preview__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #f3f4f6}.app-preview__title{font-size:14px;font-weight:700;color:#111827;letter-spacing:-.2px}.app-preview__badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:20px;padding:2px 10px}.app-preview__badge:before{content:"";width:6px;height:6px;border-radius:50%;background:#16a34a}.app-preview__spots{display:flex;flex-direction:column;gap:1px;background:#f3f4f6}.spot-card{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fff;transition:background .15s}.spot-card--top{background:#fffbeb}.spot-card__left{flex-shrink:0}.spot-card__score{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff}.spot-card__info{flex:1;min-width:0}.spot-card__name{font-size:13px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spot-card__meta{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap}.spot-chip{font-size:10px;font-weight:500;color:#374151;background:#f3f4f6;border-radius:4px;padding:2px 6px}.spot-chip--muted{color:#6b7280;background:#f9fafb}.spot-card__distance{font-size:12px;font-weight:500;color:#6b7280;flex-shrink:0}.app-preview__footer{padding:12px 20px 16px;border-top:1px solid #f3f4f6}.app-preview__env{display:flex;gap:16px;justify-content:space-between}.env-row{display:flex;flex-direction:column;align-items:center;gap:2px}.env-label{font-size:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em}.env-val{font-size:13px;font-weight:700;color:#111827}.trust{padding:48px 24px;background:#fff;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.trust__inner{max-width:1120px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:28px}.trust__label{font-size:14px;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.08em}.trust__stats{display:flex;align-items:center;gap:40px}.trust__stat{display:flex;flex-direction:column;align-items:center;gap:4px}.trust__stat-num{font-size:28px;font-weight:900;color:#111827;letter-spacing:-.5px}.trust__stat-desc{font-size:13px;color:#6b7280}.trust__divider{width:1px;height:40px;background:#e5e7eb}.features{padding:96px 24px;background:#f5f3ef}.features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.feature-card{background:#fff;border-radius:16px;padding:28px;border:1px solid #e5e7eb;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;display:flex;flex-direction:column;color:inherit}.feature-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px #00000014;border-color:#bfdbfe}.feature-card__icon{font-size:24px;color:#3b82f6;margin-bottom:16px;display:flex;align-items:center}.feature-card__title{font-size:16px;font-weight:700;color:#111827;margin-bottom:10px;letter-spacing:-.2px}.feature-card__body{font-size:14px;color:#6b7280;line-height:1.6;flex:1}.how-it-works{padding:96px 24px;background:#fff}.split-header{display:flex;align-items:flex-start;gap:40px;margin-bottom:40px}.split-header__lead{display:flex;flex-direction:column;align-items:flex-start;gap:16px;flex:2}.section-badge{display:inline-flex;align-items:center;gap:8px;background:#eff6ff;color:#3b82f6;border:1px solid #bfdbfe;padding:6px 16px;border-radius:100px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s}.section-badge:hover{background:#dbeafe;border-color:#93c5fd}.split-header__title{font-size:clamp(24px,4vw,36px);font-weight:900;color:#111827;letter-spacing:-1.5px;line-height:1.1;margin:0}.split-header__body{flex:1}.split-header__desc{font-size:16px;color:#4b5563;line-height:1.7;margin-bottom:20px}.split-header__link{display:inline-block;font-size:15px;font-weight:600;color:#111827;text-decoration:underline;text-underline-offset:4px;text-decoration-color:#3b82f6;text-decoration-thickness:2px;transition:color .15s}.split-header__link:hover{color:#3b82f6}.steps{display:flex;align-items:flex-start;gap:16px}.step{flex:1;text-align:center;padding:32px 24px;background:#f9fafb;border-radius:16px;border:1px solid #e5e7eb}.step__num{width:44px;height:44px;border-radius:50%;background:#3b82f6;color:#fff;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.step__title{font-size:17px;font-weight:700;color:#111827;margin-bottom:10px;letter-spacing:-.2px}.step__body{font-size:14px;color:#6b7280;line-height:1.65}.steps__arrow{flex-shrink:0;font-size:24px;color:#d1d5db;margin-top:54px}.cta-banner{padding:96px 24px;background:#0c2340;text-align:center}.cta-banner__title{font-size:clamp(28px,4vw,44px);font-weight:900;color:#fff;letter-spacing:-1px;margin-bottom:16px}.cta-banner__sub{font-size:17px;color:#fff9;line-height:1.65;margin-bottom:36px}.cta-banner__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}@media(max-width:960px){.hero__inner{flex-direction:column;gap:48px;text-align:center}.hero__sub{max-width:100%;margin:0 auto 36px}.hero__actions{justify-content:center}.hero__visual{flex:none;width:100%;max-width:420px;margin:0 auto}.features__grid{grid-template-columns:repeat(2,1fr)}.split-header{flex-direction:column;gap:24px}.split-header__lead{flex:none}}@media(max-width:640px){.hero{padding:100px 20px 60px}.features__grid{grid-template-columns:1fr}.steps{flex-direction:column}.steps__arrow{transform:rotate(90deg);margin:-4px auto}.pricing-cards{flex-direction:column;max-width:360px}.pricing-card--featured{transform:none}.trust__stats{flex-direction:column;gap:20px}.trust__divider{width:60px;height:1px}}.pricing-page{min-height:100vh;background:#f5f3ef}.pricing-hero{padding:120px 24px 64px;background:linear-gradient(160deg,#f0f7ff,#f5f3ef 60%)}.pricing-hero__title{font-size:clamp(36px,5vw,56px);font-weight:900;color:#111827;letter-spacing:-1.5px;margin:12px 0 16px}.pricing-hero__sub{font-size:18px;color:#4b5563;line-height:1.65}.billing-toggle{display:inline-flex;align-items:center;background:#e5e7eb;border-radius:100px;padding:4px;margin-top:28px;gap:2px}.billing-toggle__opt{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:100px;border:none;background:transparent;font-family:inherit;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.billing-toggle__opt--active{background:#fff;color:#111827;box-shadow:0 1px 4px #0000001a}.billing-toggle__badge{font-size:11px;font-weight:700;background:#d1fae5;color:#065f46;border-radius:100px;padding:2px 8px}.pricing-section{padding:56px 24px 80px}.pricing-tiers{display:flex;gap:20px;align-items:stretch}.tier-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;display:flex;flex-direction:column;overflow:hidden}.tier-card:first-child{flex:0 0 300px}.tier-card--pro{flex:1;border-color:#0c2340;box-shadow:0 8px 40px #0c234026}.tier-card__head{padding:28px 28px 0}.tier-label{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:100px;padding:3px 12px;margin-bottom:14px}.tier-label--popular{background:#eff6ff;color:#3b82f6;border-color:#bfdbfe;width:max-content}.tier-name{font-size:32px;font-weight:900;color:#111827;letter-spacing:-1px;margin:0 0 10px}.tier-desc{font-size:14px;color:#6b7280;line-height:1.6;margin:0}.tier-features{padding:20px 28px;display:flex;flex-direction:column;gap:8px;flex:1}.tier-features__sep{height:1px;background:#f3f4f6;margin:4px 0}.tier-feature{display:flex;align-items:center;gap:8px;font-size:14px}.tier-feature__icon{flex-shrink:0;font-size:16px}.tier-feature--yes{color:#111827}.tier-feature--yes .tier-feature__icon{color:#16a34a}.tier-feature--no{color:#9ca3af}.tier-feature--no .tier-feature__icon{color:#d1d5db}.tier-card__foot{display:flex;align-items:center;justify-content:space-between;padding:20px 28px 28px;border-top:1px solid #f3f4f6;margin-top:auto;gap:12px}.tier-price{font-size:36px;font-weight:900;color:#111827;letter-spacing:-1.5px;white-space:nowrap}.tier-price span{font-size:15px;font-weight:500;color:#6b7280;letter-spacing:0}.tier-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:100px;font-size:14px;font-weight:600;text-decoration:none;background:#f3f4f6;color:#111827;border:1px solid #e5e7eb;transition:background .15s,box-shadow .15s;white-space:nowrap}.tier-cta:hover{background:#e5e7eb}.tier-cta--primary{background:#16a34a;color:#fff;border-color:transparent}.tier-cta--primary:hover{background:#15803d;box-shadow:0 4px 14px #16a34a59}.tier-card__pro-inner{display:flex;flex:1}.tier-pro__info{flex:0 0 280px;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;padding:28px 0 0 28px}.tier-pro__info .tier-card__head{padding:0 28px}.tier-pro__annual{display:flex;align-items:center;gap:8px;padding:16px 28px 0 0;font-size:13px;color:#6b7280}.tier-pro__annual-badge{font-size:11px;font-weight:700;background:#fef3c7;color:#92400e;border:1px solid #fde68a;border-radius:100px;padding:2px 8px}.tier-pro__info .tier-card__foot{border-top-color:#e5e7eb;flex-direction:column;align-items:flex-start;gap:14px;padding:20px 28px 20px 0}.tier-pro__trial{font-size:12px;color:#9ca3af;padding:0 28px 20px 0;margin:0}.tier-pro__features{flex:1;padding:28px;display:flex;flex-direction:column;gap:10px}.tier-pro__features-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#9ca3af;margin:0 0 6px}.tier-feature--pro{color:#374151;font-size:14px}.tier-feature--pro .tier-feature__icon{color:#3b82f6}.faq{padding:80px 24px;background:#fff;border-top:1px solid #e5e7eb}.faq__inner{display:flex;gap:80px;align-items:flex-start}.faq__left{flex:0 0 280px;position:sticky;top:88px}.faq__title{font-size:clamp(28px,3vw,40px);font-weight:900;color:#111827;letter-spacing:-1px;line-height:1.15;margin-top:12px}.faq__right{flex:1;display:flex;flex-direction:column;gap:8px}.faq__item{background:#f9fafb;border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;transition:border-color .15s}.faq__item--open{background:#fff;border-color:#d1d5db;box-shadow:0 2px 12px #0000000f}.faq__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;font-size:15px;font-weight:600;color:#111827;transition:color .15s}.faq__q:hover{color:#3b82f6}.faq__item--open .faq__q{color:#111827}.faq__icon{flex-shrink:0;font-size:20px;color:#9ca3af;line-height:1}.faq__a{padding:0 20px 20px;font-size:15px;color:#4b5563;line-height:1.7;margin:0}.pricing-cta{padding:80px 24px;background:#f5f3ef}.pricing-cta__title{font-size:clamp(28px,4vw,40px);font-weight:900;color:#111827;letter-spacing:-1px;margin-bottom:12px}.pricing-cta__sub{font-size:16px;color:#6b7280;margin-bottom:28px}@media(max-width:960px){.pricing-tiers{flex-direction:column;max-width:560px;margin:0 auto}.tier-card:first-child{flex:none;width:100%}.tier-card__pro-inner{flex-direction:column}.tier-pro__info{flex:none;border-right:none;padding-right:16px;border-bottom:1px solid #e5e7eb}.faq__inner{flex-direction:column;gap:40px}.faq__left{flex:none;position:static}.tier-pro__annual{padding-bottom:16px}}.hiw-page{min-height:100vh;background:#f5f3ef;display:flex;flex-direction:column}.hiw-page__inner{max-width:1000px;margin:0 auto;padding:0 24px}.hiw-page__hero{padding:112px 24px 64px;background:linear-gradient(160deg,#f0f7ff,#f5f3ef 60%);text-align:center}.hiw-page__title{font-size:clamp(32px,5vw,52px);font-weight:900;color:#111827;letter-spacing:-1.5px;line-height:1.1;margin:0 0 16px}.hiw-page__sub{font-size:18px;color:#4b5563;line-height:1.65;max-width:520px;margin:0 auto}.hiw-page__video-section{padding:72px 24px;background:#fff;border-top:1px solid #e5e7eb}.hiw-video-header{text-align:center;margin-bottom:40px}.hiw-video-header__title{font-size:clamp(22px,3vw,32px);font-weight:800;color:#111827;letter-spacing:-.8px;margin-bottom:10px}.hiw-video-header__sub{font-size:16px;color:#6b7280;line-height:1.6}.video-placeholder{aspect-ratio:16 / 9;background:#0c2340;border-radius:16px;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 20px 60px #0c234033}.video-placeholder__inner{display:flex;flex-direction:column;align-items:center;gap:16px}.video-placeholder__icon{font-size:80px;color:#ffffff59;transition:color .2s}.video-placeholder:hover .video-placeholder__icon{color:#ffffffa6}.video-placeholder__label{font-size:14px;font-weight:500;color:#ffffff59;letter-spacing:.03em}.hiw-page__steps-section{padding:80px 24px;background:#f5f3ef}.hiw-steps-header{text-align:center;margin-bottom:64px}.hiw-steps-header__title{font-size:clamp(22px,3vw,32px);font-weight:800;color:#111827;letter-spacing:-.8px;margin-bottom:10px}.hiw-steps-header__sub{font-size:16px;color:#6b7280;line-height:1.6}.process-steps{display:flex;align-items:flex-start;gap:0}.process-connector{flex:1;border-top:2px dashed #c7d9f0;margin-top:76px;flex-shrink:1}.process-step{flex:0 0 220px;display:flex;flex-direction:column;align-items:center;text-align:center}.process-step__circle-wrap{position:relative;width:120px;height:120px;margin-bottom:20px}.process-step__num{position:absolute;top:-10px;left:-10px;width:28px;height:28px;border-radius:50%;background:#0c2340;color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;z-index:1;box-shadow:0 2px 8px #0c234040}.process-step__circle{width:100%;height:100%;border-radius:50%;background:#fff;border:2px solid #e0ecff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #3b82f614;transition:border-color .2s,box-shadow .2s}.process-step:hover .process-step__circle{border-color:#93c5fd;box-shadow:0 8px 28px #3b82f626}.process-step__img-placeholder{width:64px;height:64px;border-radius:16px;background:#eff6ff;display:flex;align-items:center;justify-content:center;font-size:30px;color:#3b82f6}.process-step__title{font-size:17px;font-weight:700;color:#111827;margin-bottom:10px;letter-spacing:-.2px}.process-step__desc{font-size:14px;color:#6b7280;line-height:1.65;max-width:200px}.hiw-page__cta{padding:80px 24px;background:#0c2340}.hiw-page__cta-title{font-size:clamp(26px,4vw,40px);font-weight:900;color:#fff;letter-spacing:-1px;margin-bottom:12px}.hiw-page__cta-sub{font-size:16px;color:#fff9;margin-bottom:28px}@media(max-width:768px){.process-steps{flex-direction:column;align-items:center;gap:0}.process-connector{width:2px;height:40px;border-top:none;border-left:2px dashed #c7d9f0;margin-top:0;flex:none}.process-step{flex:none;width:100%;max-width:300px}}.features-page{min-height:100vh;background:#f5f3ef}.fp-inner{max-width:1120px;margin:0 auto;padding:0 24px}.section-eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#3b82f6;margin-bottom:12px}.fp-hero{padding:112px 24px 80px;background:linear-gradient(160deg,#f0f7ff,#f5f3ef 60%);text-align:center}.fp-hero__title{font-size:clamp(36px,5vw,58px);font-weight:900;color:#111827;letter-spacing:-2px;line-height:1.08;margin:0 0 20px}.fp-hero__sub{font-size:18px;color:#4b5563;line-height:1.65;max-width:560px;margin:0 auto 36px}.fp-hero__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.fp-grid-section{padding:80px 24px;background:#fff;border-top:1px solid #e5e7eb}.fp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.fp-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:16px;padding:28px 24px;transition:transform .2s,box-shadow .2s,border-color .2s}.fp-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000012;border-color:#bfdbfe}.fp-card__icon{font-size:28px;color:#3b82f6;margin-bottom:14px;display:flex;align-items:center}.fp-card__title{font-size:16px;font-weight:700;color:#111827;margin-bottom:8px;letter-spacing:-.2px}.fp-card__body{font-size:14px;color:#6b7280;line-height:1.65}.fp-deep{padding:96px 24px;background:#f5f3ef}.fp-deep:nth-child(2n){background:#fff}.fp-deep__inner{display:flex;align-items:center;gap:80px}.fp-deep--flip .fp-deep__inner{flex-direction:row-reverse}.fp-deep__text{flex:1;min-width:0}.fp-deep__badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;border-radius:100px;padding:4px 12px;margin-bottom:16px}.fp-deep__title{font-size:clamp(24px,3.5vw,36px);font-weight:900;color:#111827;letter-spacing:-1px;line-height:1.15;margin-bottom:24px}.fp-deep__bullets{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:14px}.fp-deep__bullets li{font-size:15px;color:#4b5563;line-height:1.65;padding-left:20px;position:relative}.fp-deep__bullets li:before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:#3b82f6}.fp-deep__cta{display:inline-flex;align-items:center;gap:6px;font-size:15px;font-weight:600;color:#111827;text-decoration:underline;text-underline-offset:4px;text-decoration-color:#3b82f6;text-decoration-thickness:2px;transition:color .15s}.fp-deep__cta:hover{color:#3b82f6}.fp-deep__visual{flex:0 0 420px}.mock-card{background:#fff;border-radius:20px;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 4px 6px #0000000a,0 16px 48px #0000001a}.mock-card__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #f3f4f6}.mock-card__title{font-size:14px;font-weight:700;color:#111827;letter-spacing:-.2px}.mock-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.mock-badge--live{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0}.mock-badge--live:before{content:"● ";font-size:8px}.habitat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:16px 20px}.habitat-cell{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;opacity:.9}.mock-card__legend{display:flex;align-items:center;padding:10px 20px 16px;font-size:12px;color:#6b7280;gap:4px}.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}.trip-stops{display:flex;flex-direction:column;background:#f9fafb;gap:1px}.trip-stop{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fff}.trip-stop__num{width:24px;height:24px;border-radius:50%;background:#0c2340;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.trip-stop__info{flex:1;min-width:0}.trip-stop__name{font-size:13px;font-weight:600;color:#111827}.trip-stop__meta{font-size:11px;color:#9ca3af;margin-top:2px}.trip-stop__right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.trip-stop__score{font-size:16px;font-weight:900}.trip-stop__dist{font-size:11px;color:#9ca3af}.trip-totals{padding:12px 20px;border-top:1px solid #f3f4f6;display:flex;flex-direction:column;gap:6px}.trip-total-row{display:flex;justify-content:space-between;font-size:13px;color:#6b7280}.trip-total-row strong{color:#111827}.top-pick{display:flex;align-items:center;gap:16px;padding:20px 20px 16px}.top-pick__score-ring{width:72px;height:72px;border-radius:50%;border:3px solid #16a34a;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;background:#f0fdf4}.top-pick__score{font-size:24px;font-weight:900;color:#16a34a;line-height:1}.top-pick__score-label{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:#16a34a;font-weight:600}.top-pick__info{flex:1}.top-pick__name{font-size:16px;font-weight:800;color:#111827;letter-spacing:-.3px}.top-pick__species{font-size:12px;color:#6b7280;margin-bottom:6px}.top-pick__chips{display:flex;gap:6px;flex-wrap:wrap}.top-pick__chip{font-size:11px;font-weight:500;color:#374151;background:#f3f4f6;border-radius:4px;padding:2px 8px}.top-pick__env{display:flex;justify-content:space-around;padding:12px 20px 16px;border-top:1px solid #f3f4f6}.top-pick__env-row{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:12px;color:#9ca3af}.top-pick__env-row strong{font-size:14px;font-weight:700;color:#111827}.fp-cta{padding:96px 24px;background:#0c2340}.fp-cta__title{font-size:clamp(28px,4vw,44px);font-weight:900;color:#fff;letter-spacing:-1px;margin-bottom:12px}.fp-cta__sub{font-size:17px;color:#fff9;margin-bottom:28px}@media(max-width:960px){.fp-grid{grid-template-columns:repeat(2,1fr)}.fp-deep__inner,.fp-deep--flip .fp-deep__inner{flex-direction:column;gap:40px}.fp-deep__visual{flex:none;width:100%;max-width:480px;margin:0 auto}}@media(max-width:600px){.fp-grid{grid-template-columns:1fr}}.app{width:100%;height:100%;position:relative}*{margin:0;padding:0;box-sizing:border-box}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f3ef}#root{width:100%;min-height:100vh}.ocean-map-container{width:100vw;height:100vh}.leaflet-container{width:100%;height:100%}
