@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@500;600;700;800&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}}:root{--color-primary-50: #E6F4F8;--color-primary-100: #C0E4ED;--color-primary-200: #96D3E1;--color-primary-300: #6CC1D5;--color-primary-400: #4DB4CC;--color-primary-500: #2EA6C3;--color-primary-600: #2895B2;--color-primary-700: #1F7F9B;--color-primary-800: #186A84;--color-primary-900: #0E4A5F;--color-secondary-50: #FFF0ED;--color-secondary-100: #FFD9D1;--color-secondary-200: #FFB9AC;--color-secondary-300: #FF9987;--color-secondary-400: #FF7F6A;--color-secondary-500: #FF654D;--color-secondary-600: #F55A43;--color-secondary-700: #E84C38;--color-secondary-800: #D93E2D;--color-secondary-900: #C12918;--color-accent-50: #FFF8E7;--color-accent-100: #FFEFC4;--color-accent-200: #FFE49D;--color-accent-300: #FFD976;--color-accent-400: #FFCF58;--color-accent-500: #FFC53A;--color-accent-600: #FFB834;--color-accent-700: #FFA62C;--color-accent-800: #FF9424;--color-accent-900: #FF7514;--color-success-50: #ECFDF5;--color-success-100: #D1FAE5;--color-success-200: #A7F3D0;--color-success-500: #10B981;--color-success-600: #059669;--color-success-700: #047857;--color-warning-50: #FFFBEB;--color-warning-100: #FEF3C7;--color-warning-200: #FDE68A;--color-warning-500: #F59E0B;--color-warning-600: #D97706;--color-warning-700: #B45309;--color-error-50: #FEF2F2;--color-error-100: #FEE2E2;--color-error-200: #FECACA;--color-error-500: #EF4444;--color-error-600: #DC2626;--color-error-700: #B91C1C;--color-info-50: #EFF6FF;--color-info-100: #DBEAFE;--color-info-200: #BFDBFE;--color-info-500: #3B82F6;--color-info-600: #2563EB;--color-info-700: #1D4ED8;--color-neutral-0: #FFFFFF;--color-neutral-50: #FAFAF9;--color-neutral-100: #F5F5F4;--color-neutral-200: #E7E5E4;--color-neutral-300: #D6D3D1;--color-neutral-400: #A8A29E;--color-neutral-500: #78716C;--color-neutral-600: #57534E;--color-neutral-700: #44403C;--color-neutral-800: #292524;--color-neutral-900: #1C1917;--text-primary: var(--color-neutral-900);--text-secondary: var(--color-neutral-600);--text-tertiary: var(--color-neutral-500);--text-disabled: var(--color-neutral-400);--text-on-primary: var(--color-neutral-0);--text-on-secondary: var(--color-neutral-0);--text-on-dark: var(--color-neutral-100);--bg-primary: var(--color-neutral-0);--bg-secondary: var(--color-neutral-50);--bg-tertiary: var(--color-neutral-100);--bg-dark: var(--color-neutral-900);--bg-overlay: rgba(28, 25, 23, .6);--bg-overlay-light: rgba(255, 255, 255, .85);--glass-bg: rgba(255, 255, 255, .75);--glass-bg-strong: rgba(255, 255, 255, .9);--glass-border: rgba(255, 255, 255, .3);--glass-blur: 20px;--gradient-primary: linear-gradient(135deg, var(--color-primary-500) 0%, var(--color-primary-700) 100%);--gradient-secondary: linear-gradient(135deg, var(--color-secondary-400) 0%, var(--color-secondary-600) 100%);--gradient-accent: linear-gradient(135deg, var(--color-accent-400) 0%, var(--color-accent-600) 100%);--gradient-hero: linear-gradient(135deg, #1F7F9B 0%, #2EA6C3 50%, #4DB4CC 100%);--gradient-hero-overlay: linear-gradient(180deg, rgba(28, 25, 23, .4) 0%, rgba(28, 25, 23, .7) 100%);--gradient-card: linear-gradient(180deg, var(--color-neutral-0) 0%, var(--color-neutral-50) 100%);--gradient-shimmer: linear-gradient(90deg, var(--color-neutral-200) 0%, var(--color-neutral-100) 50%, var(--color-neutral-200) 100%);--border-light: var(--color-neutral-200);--border-medium: var(--color-neutral-300);--border-strong: var(--color-neutral-400);--border-focus: var(--color-primary-400);--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-display: "Plus Jakarta Sans", "Inter", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs: clamp(.7rem, .65rem + .25vw, .75rem);--text-sm: clamp(.8rem, .75rem + .25vw, .875rem);--text-base: clamp(.9rem, .85rem + .25vw, 1rem);--text-lg: clamp(1rem, .95rem + .25vw, 1.125rem);--text-xl: clamp(1.1rem, 1rem + .5vw, 1.25rem);--text-2xl: clamp(1.25rem, 1.1rem + .75vw, 1.5rem);--text-3xl: clamp(1.5rem, 1.25rem + 1.25vw, 1.875rem);--text-4xl: clamp(1.75rem, 1.4rem + 1.75vw, 2.25rem);--text-5xl: clamp(2rem, 1.5rem + 2.5vw, 3rem);--text-6xl: clamp(2.5rem, 1.75rem + 3.75vw, 3.75rem);--text-7xl: clamp(3rem, 2rem + 5vw, 4.5rem);--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--font-black: 900;--leading-none: 1;--leading-tight: 1.2;--leading-snug: 1.35;--leading-normal: 1.5;--leading-relaxed: 1.65;--leading-loose: 2;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--tracking-widest: .1em;--space-0: 0;--space-px: 1px;--space-0-5: .125rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-14: 3.5rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-28: 7rem;--space-32: 8rem;--container-xs: 20rem;--container-sm: 36rem;--container-md: 48rem;--container-lg: 64rem;--container-xl: 80rem;--container-2xl: 90rem;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--radius-none: 0;--radius-sm: .375rem;--radius-base: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(28, 25, 23, .04);--shadow-sm: 0 1px 3px 0 rgba(28, 25, 23, .06), 0 1px 2px -1px rgba(28, 25, 23, .06);--shadow-base: 0 4px 6px -1px rgba(28, 25, 23, .07), 0 2px 4px -2px rgba(28, 25, 23, .05);--shadow-md: 0 10px 15px -3px rgba(28, 25, 23, .08), 0 4px 6px -4px rgba(28, 25, 23, .05);--shadow-lg: 0 20px 25px -5px rgba(28, 25, 23, .08), 0 8px 10px -6px rgba(28, 25, 23, .04);--shadow-xl: 0 25px 50px -12px rgba(28, 25, 23, .15);--shadow-2xl: 0 35px 60px -15px rgba(28, 25, 23, .2);--shadow-inner: inset 0 2px 4px 0 rgba(28, 25, 23, .04);--shadow-float: 0 8px 30px rgba(28, 25, 23, .12), 0 4px 10px rgba(28, 25, 23, .06);--shadow-float-lg: 0 16px 50px rgba(28, 25, 23, .15), 0 8px 20px rgba(28, 25, 23, .08);--shadow-primary: 0 10px 40px -10px rgba(46, 166, 195, .35);--shadow-primary-strong: 0 15px 50px -10px rgba(46, 166, 195, .45);--shadow-secondary: 0 10px 40px -10px rgba(255, 101, 77, .3);--shadow-accent: 0 10px 40px -10px rgba(255, 197, 58, .35);--shadow-success: 0 10px 30px -10px rgba(16, 185, 129, .3);--shadow-error: 0 10px 30px -10px rgba(239, 68, 68, .3);--shadow-glass: 0 8px 32px 0 rgba(28, 25, 23, .06);--duration-instant: 0ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--duration-slower: .5s;--duration-slowest: .7s;--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--ease-smooth: cubic-bezier(.23, 1, .32, 1);--transition-base: all var(--duration-normal) var(--ease-in-out);--transition-fast: all var(--duration-fast) var(--ease-in-out);--transition-slow: all var(--duration-slow) var(--ease-in-out);--transition-transform: transform var(--duration-normal) var(--ease-spring);--transition-opacity: opacity var(--duration-normal) var(--ease-in-out);--transition-shadow: box-shadow var(--duration-normal) var(--ease-in-out);--transition-colors: color var(--duration-fast) var(--ease-in-out), background-color var(--duration-fast) var(--ease-in-out), border-color var(--duration-fast) var(--ease-in-out);--z-base: 0;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-toast: 1080;--header-height: 72px;--header-height-mobile: 64px;--input-height-sm: 36px;--input-height-base: 44px;--input-height-lg: 52px;--input-height-xl: 60px;--button-height-sm: 36px;--button-height-base: 44px;--button-height-lg: 52px;--button-height-xl: 60px;--focus-ring: 0 0 0 3px rgba(46, 166, 195, .25);--focus-ring-strong: 0 0 0 4px rgba(46, 166, 195, .35);--focus-ring-error: 0 0 0 3px rgba(239, 68, 68, .25)}[data-theme=dark]{--text-primary: var(--color-neutral-100);--text-secondary: var(--color-neutral-400);--text-tertiary: var(--color-neutral-500);--text-disabled: var(--color-neutral-600);--bg-primary: var(--color-neutral-900);--bg-secondary: var(--color-neutral-800);--bg-tertiary: var(--color-neutral-700);--bg-overlay: rgba(0, 0, 0, .7);--bg-overlay-light: rgba(28, 25, 23, .85);--glass-bg: rgba(28, 25, 23, .75);--glass-bg-strong: rgba(28, 25, 23, .9);--glass-border: rgba(255, 255, 255, .1);--border-light: var(--color-neutral-700);--border-medium: var(--color-neutral-600);--border-strong: var(--color-neutral-500);--gradient-card: linear-gradient(180deg, var(--color-neutral-800) 0%, var(--color-neutral-900) 100%);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .2), 0 1px 2px -1px rgba(0, 0, 0, .2);--shadow-base: 0 4px 6px -1px rgba(0, 0, 0, .25), 0 2px 4px -2px rgba(0, 0, 0, .2);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -4px rgba(0, 0, 0, .2);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .3), 0 8px 10px -6px rgba(0, 0, 0, .15);--shadow-float: 0 8px 30px rgba(0, 0, 0, .35), 0 4px 10px rgba(0, 0, 0, .25)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--text-primary: var(--color-neutral-100);--text-secondary: var(--color-neutral-400);--bg-primary: var(--color-neutral-900);--bg-secondary: var(--color-neutral-800);--glass-bg: rgba(28, 25, 23, .75);--glass-border: rgba(255, 255, 255, .1);--border-light: var(--color-neutral-700)}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0}ul[role=list],ol[role=list]{list-style:none}body{min-height:100vh;font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-secondary);overflow-x:hidden}h1,h2,h3,h4,h5,h6,button,input,label{line-height:var(--leading-tight)}h1,h2,h3,h4,h5,h6{text-wrap:balance}a:not([class]){text-decoration-skip-ink:auto;color:currentColor}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit;color:inherit}textarea:not([rows]){min-height:10em}:target{scroll-margin-block:5ex}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight)}h1{font-size:var(--text-5xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight)}h2{font-size:var(--text-4xl);font-weight:var(--font-bold);line-height:var(--leading-tight)}h3{font-size:var(--text-2xl);font-weight:var(--font-semibold);line-height:var(--leading-snug)}h4{font-size:var(--text-xl);font-weight:var(--font-semibold);line-height:var(--leading-snug)}h5{font-size:var(--text-lg);font-weight:var(--font-medium)}h6{font-size:var(--text-base);font-weight:var(--font-medium)}p{margin:0;line-height:var(--leading-relaxed);color:var(--text-secondary)}p+p{margin-top:var(--space-4)}a{color:var(--color-primary-600);text-decoration:none;transition:var(--transition-colors)}a:hover{color:var(--color-primary-700)}a:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px;border-radius:var(--radius-sm)}strong,b{font-weight:var(--font-semibold)}small{font-size:var(--text-sm)}code{font-family:var(--font-mono);font-size:.9em;padding:.125rem .375rem;background-color:var(--color-neutral-100);border-radius:var(--radius-sm);color:var(--color-secondary-600)}button,input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit;margin:0;transition:var(--transition-base)}button{cursor:pointer;border:none;background:none;padding:0}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none;box-shadow:var(--focus-ring)}button:disabled{cursor:not-allowed;opacity:.5}input::placeholder,textarea::placeholder{color:var(--text-disabled);opacity:1}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-neutral-100);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--color-neutral-300);border-radius:var(--radius-full);border:2px solid var(--color-neutral-100)}::-webkit-scrollbar-thumb:hover{background:var(--color-neutral-400)}*{scrollbar-width:thin;scrollbar-color:var(--color-neutral-300) var(--color-neutral-100)}::selection{background-color:var(--color-primary-100);color:var(--color-primary-900)}.container{width:100%;max-width:var(--container-xl);margin-left:auto;margin-right:auto;padding-left:var(--space-6);padding-right:var(--space-6)}.container-narrow{max-width:var(--container-md)}.container-wide{max-width:var(--container-2xl)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.animate-fadeIn{animation:fadeIn var(--duration-normal) var(--ease-out)}.animate-fadeInUp{animation:fadeInUp var(--duration-slow) var(--ease-out)}.animate-fadeInDown{animation:fadeInDown var(--duration-slow) var(--ease-out)}.animate-scaleIn{animation:scaleIn var(--duration-normal) var(--ease-spring)}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-shimmer{animation:shimmer 1.5s infinite}.animate-float{animation:float 3s ease-in-out infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.transition-base{transition:var(--transition-base)}.transition-fast{transition:var(--transition-fast)}.transition-slow{transition:var(--transition-slow)}.transition-transform{transition:var(--transition-transform)}.transition-colors{transition:var(--transition-colors)}.hover-lift{transition:var(--transition-transform),var(--transition-shadow)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.hover-glow{transition:var(--transition-shadow)}.hover-glow:hover{box-shadow:var(--shadow-primary)}.hover-scale{transition:transform var(--duration-normal) var(--ease-spring)}.hover-scale:hover{transform:scale(1.02)}@media(max-width:1024px){html{font-size:15px}.container{padding-left:var(--space-5);padding-right:var(--space-5)}}@media(max-width:768px){html{font-size:14px}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}.grid-cols-2,.grid-cols-3,.grid-cols-4,.grid-3{grid-template-columns:repeat(1,minmax(0,1fr))}.container{padding-left:var(--space-4);padding-right:var(--space-4)}}@media(max-width:640px){.container{padding-left:var(--space-4);padding-right:var(--space-4)}}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px;border-radius:var(--radius-sm)}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary-600);color:var(--text-on-primary);padding:var(--space-2) var(--space-4);z-index:var(--z-tooltip);border-radius:0 0 var(--radius-base) 0;transition:top var(--duration-fast)}.skip-link:focus{top:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(prefers-contrast:high){:root{--shadow-xs: none;--shadow-sm: none;--shadow-base: 0 0 0 1px currentColor;--border-light: currentColor}}@media print{*,*:before,*:after{background:#fff!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}a,a:visited{text-decoration:underline}img{max-width:100%!important}@page{margin:2cm}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-6);height:var(--button-height-base);font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-semibold);line-height:1;text-decoration:none;white-space:nowrap;border-radius:var(--radius-lg);border:2px solid transparent;transition:var(--transition-base);cursor:pointer;-webkit-user-select:none;user-select:none}.btn:focus-visible{box-shadow:var(--focus-ring)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-500));color:var(--text-on-primary);box-shadow:var(--shadow-sm),var(--shadow-primary)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-700),var(--color-primary-600));box-shadow:var(--shadow-md),var(--shadow-primary);transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--color-secondary-500);color:var(--text-on-secondary);box-shadow:var(--shadow-sm),var(--shadow-secondary)}.btn-secondary:hover:not(:disabled){background:var(--color-secondary-600);box-shadow:var(--shadow-md),var(--shadow-secondary);transform:translateY(-2px)}.btn-accent{background:var(--gradient-accent);color:var(--color-neutral-900);box-shadow:var(--shadow-sm),var(--shadow-accent)}.btn-accent:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-500),var(--color-accent-700));box-shadow:var(--shadow-md),var(--shadow-accent);transform:translateY(-2px)}.btn-outline{background:transparent;color:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-outline:hover:not(:disabled){background:var(--color-primary-50);border-color:var(--color-primary-700);color:var(--color-primary-700)}.btn-ghost{background:transparent;color:var(--text-primary)}.btn-ghost:hover:not(:disabled){background:var(--color-neutral-100)}.btn-danger{background:var(--color-error-500);color:var(--text-on-primary);box-shadow:var(--shadow-sm)}.btn-danger:hover:not(:disabled){background:var(--color-error-600);transform:translateY(-2px)}.btn-sm{height:var(--button-height-sm);padding:0 var(--space-4);font-size:var(--text-sm);border-radius:var(--radius-base)}.btn-lg{height:var(--button-height-lg);padding:0 var(--space-8);font-size:var(--text-lg)}.btn-xl{height:var(--button-height-xl);padding:0 var(--space-10);font-size:var(--text-xl);border-radius:var(--radius-xl)}.btn-icon{padding:0;width:var(--button-height-base);aspect-ratio:1}.btn-icon.btn-sm{width:var(--button-height-sm)}.btn-icon.btn-lg{width:var(--button-height-lg)}.btn-full{width:100%}.card{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);padding:var(--space-6);transition:var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-interactive:active{transform:translateY(-2px)}.card-bordered{border:2px solid var(--border-medium);box-shadow:none}.card-elevated{box-shadow:var(--shadow-lg)}.card-flat{box-shadow:none;background:var(--bg-tertiary)}.card-header{padding-bottom:var(--space-4);border-bottom:1px solid var(--border-light);margin-bottom:var(--space-4)}.card-body{flex:1}.card-footer{padding-top:var(--space-4);border-top:1px solid var(--border-light);margin-top:var(--space-4)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.form-label-required:after{content:"*";color:var(--color-error-500);margin-left:var(--space-1)}.form-input,.form-textarea,.form-select{width:100%;height:var(--input-height-base);padding:0 var(--space-4);font-family:var(--font-primary);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-primary);border:2px solid var(--border-medium);border-radius:var(--radius-lg);transition:var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--border-strong)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--focus-ring)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-disabled)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.form-input.error,.form-textarea.error,.form-select.error{border-color:var(--color-error-500)}.form-input.error:focus,.form-textarea.error:focus,.form-select.error:focus{box-shadow:var(--focus-ring-error)}.form-textarea{height:auto;min-height:120px;padding-top:var(--space-3);padding-bottom:var(--space-3);resize:vertical}.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:var(--space-10)}.form-input-sm,.form-select-sm{height:var(--input-height-sm);padding:0 var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-base)}.form-input-lg,.form-select-lg{height:var(--input-height-lg);padding:0 var(--space-5);font-size:var(--text-lg)}.form-helper{display:block;margin-top:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary)}.form-error{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);font-size:var(--text-sm);color:var(--color-error-600);font-weight:var(--font-medium)}.form-success{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);font-size:var(--text-sm);color:var(--color-success-600);font-weight:var(--font-medium)}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);line-height:1;white-space:nowrap;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-secondary{background-color:var(--color-secondary-100);color:var(--color-secondary-700)}.badge-success{background-color:var(--color-success-100);color:var(--color-success-700)}.badge-warning{background-color:var(--color-warning-100);color:var(--color-warning-700)}.badge-error{background-color:var(--color-error-100);color:var(--color-error-700)}.badge-neutral{background-color:var(--color-neutral-200);color:var(--color-neutral-700)}.badge-lg{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4)}.spinner{width:48px;height:48px;border:4px solid var(--color-neutral-200);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:24px;height:24px;border-width:3px}.spinner-lg{width:64px;height:64px;border-width:5px}.loading-text{color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-medium)}.skeleton{background:linear-gradient(90deg,var(--color-neutral-200) 0%,var(--color-neutral-100) 50%,var(--color-neutral-200) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-base)}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-title{height:2em;width:60%;margin-bottom:var(--space-3)}.skeleton-card{height:200px}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid transparent;font-size:var(--text-sm)}.alert-icon{flex-shrink:0;font-size:var(--text-xl)}.alert-content{flex:1}.alert-title{font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.alert-info{background-color:var(--color-info-50);border-color:var(--color-info-200);color:var(--color-info-700)}.alert-success{background-color:var(--color-success-50);border-color:var(--color-success-200);color:var(--color-success-700)}.alert-warning{background-color:var(--color-warning-50);border-color:var(--color-warning-200);color:var(--color-warning-700)}.alert-error{background-color:var(--color-error-50);border-color:var(--color-error-200);color:var(--color-error-700)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-16) var(--space-6);min-height:400px}.empty-state-icon{font-size:80px;margin-bottom:var(--space-6);opacity:.5}.empty-state-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.empty-state-description{font-size:var(--text-base);color:var(--text-secondary);max-width:480px;margin-bottom:var(--space-6);line-height:var(--leading-relaxed)}.empty-state-action{margin-top:var(--space-4)}.tabs{display:flex;gap:var(--space-2);border-bottom:2px solid var(--border-light);margin-bottom:var(--space-6);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-3) var(--space-5);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-secondary);background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;transition:var(--transition-base);white-space:nowrap;position:relative;bottom:-2px}.tab:hover{color:var(--text-primary);background-color:var(--color-neutral-50)}.tab.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.divider{height:1px;background-color:var(--border-light);border:none;margin:var(--space-6) 0}.divider-thick{height:2px;background-color:var(--border-medium)}.divider-vertical{width:1px;height:auto;min-height:20px;background-color:var(--border-light);margin:0 var(--space-4)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-3);background-color:var(--color-neutral-900);color:var(--color-neutral-0);font-size:var(--text-xs);white-space:nowrap;border-radius:var(--radius-base);opacity:0;pointer-events:none;transition:opacity var(--duration-fast);margin-bottom:var(--space-2);z-index:var(--z-tooltip)}[data-tooltip]:hover:after{opacity:1}@media(max-width:768px){.btn{font-size:var(--text-sm)}.card{padding:var(--space-4)}.empty-state{padding:var(--space-8) var(--space-4);min-height:300px}.empty-state-icon{font-size:60px}}:root{--primary-color: #4A90E2;--secondary-color: #50C878;--danger-color: #E74C3C;--warning-color: #F39C12;--text-dark: #2C3E50;--text-light: #7F8C8D;--background: #F8F9FA;--white: #FFFFFF;--border-color: #E1E8ED;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-hover: 0 4px 16px rgba(0, 0, 0, .15);--transition: all .3s ease;--border-radius: 8px;--header-height: 70px}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--text-dark)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{color:var(--text-dark);margin-bottom:1rem}a{color:var(--primary-color);text-decoration:none;transition:color .3s ease}a:hover{color:var(--secondary-color)}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:all .3s ease}input,textarea,select{font-family:inherit;outline:none}.container{max-width:1200px;margin:0 auto;padding:0 20px}.card{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:24px;margin-bottom:24px;transition:box-shadow .3s ease}.card:hover{box-shadow:var(--shadow-hover)}.btn{padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease}.btn-primary{background-color:var(--primary-color);color:var(--white)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid rgba(74,144,226,.2);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.loading p{color:var(--text-light);font-size:16px}.error-card{background:var(--white);border-radius:var(--border-radius);padding:32px;text-align:center;box-shadow:var(--shadow);margin:40px auto;max-width:600px}.error-card .error-message{color:var(--danger-color);font-size:18px;margin-bottom:20px}@media(max-width:768px){body{font-size:14px}.container{padding:0 15px}.card{padding:16px;margin-bottom:16px}.btn{padding:10px 20px;font-size:14px}h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}}@media(max-width:480px){.container{padding:0 10px}.card{padding:12px}}.btn-primary:hover{background-color:#3a7bc8;transform:translateY(-2px);box-shadow:var(--shadow-hover)}.btn-secondary{background-color:var(--secondary-color);color:var(--white)}.btn-secondary:hover{background-color:#3fa65f;transform:translateY(-2px);box-shadow:var(--shadow-hover)}.btn-danger{background-color:var(--danger-color);color:var(--white)}.btn-danger:hover{background-color:#c0392b;transform:translateY(-2px);box-shadow:var(--shadow-hover)}.btn-outline{background-color:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-outline:hover{background-color:var(--primary-color);color:var(--white)}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-dark);font-size:14px}.form-input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:14px;transition:border-color .3s ease}.form-input:focus{border-color:var(--primary-color)}.form-textarea{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:14px;resize:vertical;min-height:100px;transition:border-color .3s ease}.form-textarea:focus{border-color:var(--primary-color)}.form-select{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:14px;background-color:var(--white);cursor:pointer;transition:border-color .3s ease}.form-select:focus{border-color:var(--primary-color)}.error-message{color:var(--danger-color);font-size:14px;margin-top:8px;display:flex;align-items:center;gap:4px}.success-message{color:var(--secondary-color);font-size:14px;margin-top:8px;display:flex;align-items:center;gap:4px}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-light)}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-primary{background-color:#4a90e21a;color:var(--primary-color)}.badge-success{background-color:#50c8781a;color:var(--secondary-color)}.badge-warning{background-color:#f39c121a;color:var(--warning-color)}.badge-danger{background-color:#e74c3c1a;color:var(--danger-color)}@media(max-width:768px){.container{padding:0 16px}.card{padding:16px}.btn{padding:10px 20px;font-size:13px}}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column-reverse;gap:var(--space-3);max-width:400px;width:calc(100vw - var(--space-8));pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-float-lg);border:1px solid var(--border-light);animation:toastEnter .3s var(--ease-spring);pointer-events:auto}.toast-exit{animation:toastExit .2s var(--ease-in) forwards}@keyframes toastEnter{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastExit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-success{border-left:4px solid var(--color-success-500)}.toast-success .toast-icon{color:var(--color-success-500);background:var(--color-success-50)}.toast-error{border-left:4px solid var(--color-error-500)}.toast-error .toast-icon{color:var(--color-error-500);background:var(--color-error-50)}.toast-warning{border-left:4px solid var(--color-warning-500)}.toast-warning .toast-icon{color:var(--color-warning-600);background:var(--color-warning-50)}.toast-info{border-left:4px solid var(--color-info-500)}.toast-info .toast-icon{color:var(--color-info-500);background:var(--color-info-50)}.toast-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-base);flex-shrink:0}.toast-content{flex:1;min-width:0}.toast-title{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1)}.toast-message{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-normal)}.toast-dismiss{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-base);color:var(--text-tertiary);transition:var(--transition-fast);flex-shrink:0;margin-left:var(--space-2)}.toast-dismiss:hover{background:var(--color-neutral-100);color:var(--text-primary)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;width:100%;background:linear-gradient(90deg,#ffffff4d,#fff9,#ffffff4d);background-size:200% 100%;border-radius:0 0 var(--radius-lg) var(--radius-lg);animation:toastProgress linear forwards,shimmerProgress 1s ease-in-out infinite}@keyframes toastProgress{0%{width:100%}to{width:0%}}@keyframes shimmerProgress{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-success .toast-progress{background:linear-gradient(90deg,var(--color-success-300),var(--color-success-500),var(--color-success-300));background-size:200% 100%}.toast-error .toast-progress{background:linear-gradient(90deg,var(--color-error-300),var(--color-error-500),var(--color-error-300));background-size:200% 100%}.toast-warning .toast-progress{background:linear-gradient(90deg,var(--color-warning-300),var(--color-warning-500),var(--color-warning-300));background-size:200% 100%}.toast-info .toast-progress{background:linear-gradient(90deg,var(--color-info-300),var(--color-info-500),var(--color-info-300));background-size:200% 100%}@media(max-width:480px){.toast-container{top:auto;bottom:var(--space-4);left:var(--space-4);right:var(--space-4);max-width:none;width:auto}@keyframes toastEnter{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes toastExit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-6);margin-bottom:var(--space-8);flex-wrap:wrap}.page-header-content{flex:1;min-width:0}.page-title{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight);margin:0 0 var(--space-2) 0}.page-title-icon{font-size:.85em;line-height:1}.page-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0;line-height:var(--leading-relaxed);max-width:600px}.page-header-action{flex-shrink:0}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-6)}.page-title{font-size:var(--text-2xl)}.page-subtitle{font-size:var(--text-base)}.page-header-action{width:100%}.page-header-action .btn{width:100%;justify-content:center}}.autocomplete-wrapper{position:relative;width:100%}.autocomplete-input-container{position:relative;display:flex;align-items:center}.autocomplete-icon{position:absolute;left:var(--space-md);color:var(--text-secondary);pointer-events:none;z-index:1}.autocomplete-input{padding-left:16px!important;padding-right:var(--space-xl)!important}.autocomplete-loading{position:absolute;right:var(--space-md);display:flex;align-items:center;justify-content:center}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-xs);padding:var(--space-sm);background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid var(--primary-color, #3b82f6);border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000026,0 4px 12px #0000001a,0 0 0 1px #3b82f61a;list-style:none;z-index:1000;max-height:320px;overflow-y:auto;animation:autocomplete-dropdown-appear .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes autocomplete-dropdown-appear{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.autocomplete-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s ease,color .15s ease;color:var(--text-primary)}.autocomplete-item:hover,.autocomplete-item--highlighted{background:var(--accent-gradient);color:#fff}.autocomplete-item:hover .autocomplete-item-icon,.autocomplete-item--highlighted .autocomplete-item-icon{color:#ffffffe6}.autocomplete-item-icon{flex-shrink:0;color:var(--text-secondary);transition:color .15s ease}.autocomplete-item-content{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden;min-width:0}.autocomplete-item-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--text-sm);line-height:1.4;font-weight:500}.autocomplete-item-type{font-size:.75rem;color:var(--text-muted);opacity:.8;transition:color .15s ease,opacity .15s ease}.autocomplete-item:hover .autocomplete-item-type,.autocomplete-item--highlighted .autocomplete-item-type{color:#ffffffd9;opacity:1}.autocomplete-empty{padding:var(--space-md);text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.autocomplete-dropdown::-webkit-scrollbar{width:6px}.autocomplete-dropdown::-webkit-scrollbar-track{background:transparent}.autocomplete-dropdown::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.autocomplete-dropdown::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(prefers-color-scheme:dark){.autocomplete-dropdown{background:linear-gradient(135deg,#1e293b,#0f172a);border-color:var(--primary-color, #3b82f6);box-shadow:0 10px 40px #0006,0 4px 12px #0000004d,0 0 0 1px #3b82f633}.autocomplete-item{color:#e2e8f0}.autocomplete-item-type{color:#94a3b8}}.breadcrumb{padding:var(--space-3) 0}.breadcrumb-list{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-1);list-style:none;margin:0;padding:0}.breadcrumb-item{display:flex;align-items:center;gap:var(--space-1)}.breadcrumb-link{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);text-decoration:none;padding:var(--space-1) var(--space-2);border-radius:var(--radius-base);transition:var(--transition-fast)}.breadcrumb-link:hover{color:var(--color-primary-600);background:var(--color-primary-50)}.breadcrumb-separator{color:var(--text-disabled);flex-shrink:0}.breadcrumb-current{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);padding:var(--space-1) var(--space-2)}[data-theme=dark] .breadcrumb-link:hover{background:var(--color-primary-900)}.bottom-navigation{display:none}@media(max-width:768px){.bottom-navigation{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:var(--z-sticky);background:var(--bg-primary);border-top:1px solid var(--border-light);box-shadow:0 -4px 20px #0000001a;padding:var(--space-2) var(--space-1);padding-bottom:max(var(--space-2),env(safe-area-inset-bottom));justify-content:space-around;align-items:center}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);color:var(--text-tertiary);text-decoration:none;border-radius:var(--radius-lg);transition:var(--transition-fast);min-width:56px}.bottom-nav-item:hover{color:var(--color-primary-600);background:var(--color-primary-50)}.bottom-nav-item.active{color:var(--color-primary-600)}.bottom-nav-item.active .bottom-nav-icon{background:var(--color-primary-100);transform:scale(1.1)}.bottom-nav-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);transition:var(--transition-fast)}.bottom-nav-label{font-size:var(--text-xs);font-weight:var(--font-medium);text-align:center;white-space:nowrap}body{padding-bottom:80px}}[data-theme=dark] .bottom-navigation{background:var(--bg-primary);border-color:var(--border-medium);box-shadow:0 -4px 20px #0000004d}[data-theme=dark] .bottom-nav-item:hover{background:var(--color-primary-900)}[data-theme=dark] .bottom-nav-item.active .bottom-nav-icon{background:var(--color-primary-800)}.photo-gallery{margin-top:var(--space-6)}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.gallery-item{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-lg);cursor:pointer;border:none;padding:0;background:none}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-normal) var(--ease-out)}.gallery-item:hover img{transform:scale(1.05)}.gallery-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;color:#fff;opacity:0;transition:opacity var(--duration-fast)}.gallery-item:hover .gallery-overlay{opacity:1}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:flex;align-items:center;justify-content:center;background:#000000f2;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-close{position:absolute;top:var(--space-4);right:var(--space-4);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;transition:var(--transition-fast)}.lightbox-close:hover{background:#fff3}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:var(--radius-full);color:#fff;cursor:pointer;transition:var(--transition-fast)}.lightbox-nav:hover{background:#fff3}.lightbox-prev{left:var(--space-4)}.lightbox-next{right:var(--space-4)}.lightbox-content{max-width:90vw;max-height:80vh;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.lightbox-content img{max-width:100%;max-height:75vh;object-fit:contain;border-radius:var(--radius-lg)}.lightbox-counter{color:#fff;font-size:var(--text-sm);font-weight:var(--font-medium)}@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.lightbox-nav{width:40px;height:40px}.lightbox-prev{left:var(--space-2)}.lightbox-next{right:var(--space-2)}}@media(max-width:480px){.gallery-grid{grid-template-columns:1fr}}.language-switcher{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 14px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .3s ease;box-shadow:0 2px 8px #667eea4d;min-width:70px;justify-content:center}.language-switcher:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea80;background:linear-gradient(135deg,#5a67d8,#6b46a0)}.language-switcher:active{transform:translateY(0);box-shadow:0 2px 6px #667eea4d}.language-switcher:focus-visible{outline:2px solid rgba(102,126,234,.8);outline-offset:2px}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-light);border-radius:var(--radius-base);cursor:pointer;transition:var(--transition-base);color:var(--text-primary)}.theme-toggle:hover{background-color:var(--color-neutral-100);border-color:var(--border-medium)}.theme-toggle:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.theme-toggle-icon{display:flex;align-items:center;justify-content:center;transition:transform var(--duration-normal) var(--ease-spring)}.theme-toggle-icon.light{color:var(--color-accent-500)}.theme-toggle-icon.dark{color:var(--color-primary-400)}.theme-toggle:hover .theme-toggle-icon{transform:rotate(15deg) scale(1.1)}[data-theme=dark] .theme-toggle{border-color:var(--border-light)}[data-theme=dark] .theme-toggle:hover{background-color:var(--color-neutral-800);border-color:var(--border-medium)}.user-dropdown{position:relative}.user-dropdown-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:transparent;border:1px solid transparent;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-base);color:var(--text-primary)}.user-dropdown-trigger:hover{background-color:var(--color-neutral-100);border-color:var(--border-light)}.user-dropdown-trigger:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary-500),var(--color-secondary-500));color:var(--text-on-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);letter-spacing:var(--tracking-wide);flex-shrink:0}.user-dropdown-name{font-weight:var(--font-medium);font-size:var(--text-sm);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown-arrow{display:flex;align-items:center;transition:transform var(--duration-normal) var(--ease-spring)}.user-dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:200px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);padding:var(--space-2);z-index:var(--z-dropdown);animation:dropdownSlide var(--duration-normal) var(--ease-spring)}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.user-dropdown-header{padding:var(--space-2) var(--space-3)}.user-dropdown-email{font-size:var(--text-xs);color:var(--text-secondary);word-break:break-all}.user-dropdown-divider{height:1px;background-color:var(--border-light);margin:var(--space-2) 0}.user-dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);border:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);text-decoration:none;border-radius:var(--radius-base);cursor:pointer;transition:var(--transition-fast)}.user-dropdown-item:hover{background-color:var(--color-neutral-100)}.user-dropdown-item:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:-2px}.user-dropdown-logout{color:var(--color-error-600)}.user-dropdown-logout:hover{background-color:var(--color-error-50)}@media(max-width:1024px){.user-dropdown-name{display:none}}[data-theme=dark] .user-dropdown-trigger:hover{background-color:var(--color-neutral-800);border-color:var(--border-light)}[data-theme=dark] .user-dropdown-menu{background:var(--bg-primary);border-color:var(--border-light)}[data-theme=dark] .user-dropdown-item:hover{background-color:var(--color-neutral-800)}[data-theme=dark] .user-dropdown-logout:hover{background-color:#ef444426}.scroll-progress-container{position:absolute;bottom:0;left:0;right:0;height:3px;background-color:transparent;overflow:hidden;z-index:1}.scroll-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-500) 0%,var(--color-secondary-500) 50%,var(--color-accent-500) 100%);transition:width 50ms linear;border-radius:0 var(--radius-full) var(--radius-full) 0}.scroll-progress-bar:after{content:"";position:absolute;top:0;right:0;width:100px;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4));opacity:.5}.header{position:fixed;top:0;left:0;right:0;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));box-shadow:var(--shadow-sm);z-index:var(--z-sticky);transition:var(--transition-base);border-bottom:1px solid var(--glass-border)}@supports not (backdrop-filter: blur(20px)){.header{background:var(--bg-primary)}}.header-scrolled{box-shadow:var(--shadow-md);background:var(--glass-bg-strong)}.header-container{max-width:var(--container-2xl);margin:0 auto;padding:0 var(--space-6);height:var(--header-height);display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;transition:var(--transition-base);flex-shrink:0}.logo:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:4px;border-radius:var(--radius-base)}.logo-icon{font-size:var(--text-3xl);line-height:1;transition:transform var(--duration-normal)}.logo:hover .logo-icon{transform:rotate(15deg) scale(1.1)}.logo-text{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-extrabold);background:linear-gradient(135deg,var(--color-primary-600),var(--color-secondary-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:var(--tracking-tight)}.nav{display:flex;align-items:center;gap:var(--space-2);flex:1;justify-content:center}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.header-user-dropdown{display:block}.nav-link-mobile-only{display:none}.nav-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:var(--text-primary);text-decoration:none;font-weight:var(--font-medium);font-size:var(--text-base);border-radius:var(--radius-lg);transition:var(--transition-base);white-space:nowrap;position:relative}.nav-link:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));transition:width var(--duration-normal)}.nav-link:hover{background-color:var(--color-primary-50);color:var(--color-primary-700)}.nav-link:hover:after{width:80%}.nav-link:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.nav-link-active{background-color:var(--color-primary-100);color:var(--color-primary-700);font-weight:var(--font-semibold)}.nav-link-signup{background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-500));color:var(--text-on-primary);box-shadow:var(--shadow-sm),var(--shadow-primary);font-weight:var(--font-semibold)}.nav-link-signup:hover{background:linear-gradient(135deg,var(--color-primary-700),var(--color-primary-600));color:var(--text-on-primary);transform:translateY(-2px);box-shadow:var(--shadow-md),var(--shadow-primary)}.nav-link-signup:after{display:none}.logout-btn{background:transparent;border:2px solid var(--color-error-500);color:var(--color-error-600);cursor:pointer;font-family:inherit;font-weight:var(--font-semibold)}.logout-btn:hover{background-color:var(--color-error-500);color:var(--text-on-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.logout-btn:after{display:none}.menu-toggle{display:none;background:none;border:none;padding:var(--space-2);cursor:pointer;border-radius:var(--radius-base);transition:var(--transition-base)}.menu-toggle:hover{background-color:var(--color-neutral-100)}.menu-toggle:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.hamburger{display:block;width:24px;height:2px;background-color:var(--text-primary);position:relative;transition:var(--transition-base);border-radius:2px}.hamburger:before,.hamburger:after{content:"";position:absolute;width:24px;height:2px;background-color:var(--text-primary);border-radius:2px;transition:var(--transition-base)}.hamburger:before{top:-8px}.hamburger:after{bottom:-8px}.hamburger.open{background-color:transparent}.hamburger.open:before{transform:rotate(45deg);top:0}.hamburger.open:after{transform:rotate(-45deg);bottom:0}.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--bg-overlay);z-index:calc(var(--z-sticky) - 1);animation:overlayFadeIn var(--duration-normal) var(--ease-out)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1024px){.nav-link{font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}}@media(max-width:768px){.header-container{height:var(--header-height-mobile);padding:0 var(--space-4)}.logo-text{font-size:var(--text-lg)}.header-actions{gap:var(--space-2)}.menu-toggle,.nav,.mobile-menu-overlay{display:none!important}}@media(max-width:480px){.logo-text{display:none}.header-container{padding:0 var(--space-3)}}[data-theme=dark] .header{background:#1c1917d9;border-bottom-color:#ffffff1a}[data-theme=dark] .header-scrolled{background:#1c1917f2}[data-theme=dark] .logo-text{background:linear-gradient(135deg,var(--color-primary-400),var(--color-secondary-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=dark] .nav-link{color:var(--color-neutral-100)}[data-theme=dark] .nav-link:hover{background-color:#2ea6c326;color:var(--color-primary-300)}[data-theme=dark] .nav-link-active{background-color:#2ea6c333;color:var(--color-primary-300)}[data-theme=dark] .hamburger,[data-theme=dark] .hamburger:before,[data-theme=dark] .hamburger:after{background-color:var(--color-neutral-100)}[data-theme=dark] .menu-toggle:hover{background-color:var(--color-neutral-800)}[data-theme=dark] .nav{background:transparent}[data-theme=dark] .logout-btn{border-color:var(--color-error-400);color:var(--color-error-400)}[data-theme=dark] .logout-btn:hover{background-color:var(--color-error-500);color:var(--text-on-primary)}.footer{background:var(--bg-dark);color:var(--text-on-dark);padding:var(--space-12) 0 var(--space-6);margin-top:auto}.footer-container{max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)}.footer-main{display:grid;grid-template-columns:1fr 2fr;gap:var(--space-10);padding-bottom:var(--space-8);border-bottom:1px solid rgba(255,255,255,.1)}.footer-brand{display:flex;flex-direction:column;gap:var(--space-4)}.footer-logo{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--text-on-dark);text-decoration:none;font-size:var(--text-xl);font-weight:var(--font-bold);font-family:var(--font-display);transition:var(--transition-colors)}.footer-logo:hover{color:var(--color-primary-300)}.footer-logo svg,.footer-logo .icon{color:var(--color-primary-400)}.footer-tagline{color:var(--color-neutral-400);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin:0;max-width:280px}.footer-nav{display:flex;gap:var(--space-12);justify-content:flex-end}.footer-nav-group{display:flex;flex-direction:column;gap:var(--space-3)}.footer-nav-group h4{color:var(--text-on-dark);font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-2)}.footer-nav-group a{color:var(--color-neutral-400);text-decoration:none;font-size:var(--text-sm);transition:var(--transition-colors)}.footer-nav-group a:hover{color:var(--color-primary-300)}.footer-bottom{padding-top:var(--space-6);display:flex;justify-content:center;align-items:center}.footer-copyright{color:var(--color-neutral-500);font-size:var(--text-sm);margin:0}@media(max-width:768px){.footer{padding:var(--space-8) 0 var(--space-4)}.footer-main{grid-template-columns:1fr;gap:var(--space-8);text-align:center}.footer-brand{align-items:center}.footer-logo{justify-content:center}.footer-tagline{text-align:center;max-width:none}.footer-nav{justify-content:center;gap:var(--space-8)}.footer-nav-group{align-items:center}}@media(max-width:480px){.footer-nav{flex-direction:column;gap:var(--space-6)}.footer-container{padding:0 var(--space-4)}}.place-card{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden;transition:var(--transition-base);cursor:pointer;display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit;position:relative}.place-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));opacity:0;transition:opacity var(--duration-normal)}.place-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-200)}.place-card:hover:before{opacity:1}.place-card:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.place-card:active{transform:translateY(-4px)}.place-card-image-container{position:relative;width:100%;height:180px;overflow:hidden;background:linear-gradient(135deg,var(--color-primary-100),var(--color-secondary-100))}.place-card-image{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out)}.place-card-image.loaded{opacity:1}.place-card:hover .place-card-image.loaded{transform:scale(1.05)}.place-image-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(90deg,var(--color-neutral-100) 0%,var(--color-neutral-200) 50%,var(--color-neutral-100) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;color:var(--color-primary-400);font-size:3rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.place-image-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-100),var(--color-secondary-100));color:var(--color-primary-500);font-size:3rem}.place-card-badge{position:absolute;top:var(--space-3);right:var(--space-3);z-index:2}.place-popular-badge{position:absolute;top:var(--space-3);left:var(--space-3);z-index:2;display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--text-on-primary);background:linear-gradient(135deg,#ff6b35,#f7931e);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.place-card-body{flex:1;padding:0 var(--space-5);padding-bottom:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.place-name{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:var(--leading-tight);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.place-location{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.place-location-icon{flex-shrink:0}.place-description{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}.place-card-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-light);background-color:var(--bg-secondary);gap:var(--space-3)}.place-rating{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold)}.rating-stars{font-size:var(--text-lg);line-height:1}.rating-value{color:var(--text-primary);font-family:var(--font-mono)}.rating-value-na{color:var(--text-disabled);font-weight:var(--font-normal);font-size:var(--text-sm)}.place-distance{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary);font-weight:var(--font-medium);padding:var(--space-1) var(--space-3);background-color:var(--color-neutral-100);border-radius:var(--radius-full)}.place-distance-icon{font-size:var(--text-base)}.place-image{width:100%;height:200px;object-fit:cover;background:linear-gradient(135deg,var(--color-primary-100),var(--color-secondary-100))}.place-image-placeholder{width:100%;height:200px;background:linear-gradient(135deg,var(--color-primary-100),var(--color-secondary-100));display:flex;align-items:center;justify-content:center;font-size:4rem}@media(max-width:768px){.place-card-header{padding:var(--space-4)}.place-icon{font-size:2.5rem}.place-card-body{padding:0 var(--space-4);padding-bottom:var(--space-3)}.place-name{font-size:var(--text-lg)}.place-card-footer{padding:var(--space-3) var(--space-4);flex-wrap:wrap}}@media(max-width:480px){.place-card:hover{transform:translateY(-2px)}}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-6)}@media(max-width:768px){.places-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}}@media(max-width:640px){.places-grid{grid-template-columns:1fr}}.place-card-skeleton{background:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-light);overflow:hidden;height:100%;display:flex;flex-direction:column;animation:fadeIn var(--duration-normal) var(--ease-out) both}.skeleton-shimmer{background:linear-gradient(90deg,var(--color-neutral-200) 0%,var(--color-neutral-100) 40%,var(--color-neutral-100) 60%,var(--color-neutral-200) 100%);background-size:300% 100%;animation:shimmer 1.5s infinite ease-in-out;border-radius:var(--radius-base)}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.skeleton-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-5);padding-bottom:var(--space-4)}.skeleton-icon{width:56px;height:56px;border-radius:var(--radius-lg)}.skeleton-badge{width:80px;height:24px;border-radius:var(--radius-full)}.skeleton-body{flex:1;padding:0 var(--space-5);padding-bottom:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.skeleton-title{height:24px;width:75%}.skeleton-location{height:18px;width:50%}.skeleton-description{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.skeleton-line{height:14px;width:100%}.skeleton-line--short{width:70%}.skeleton-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-light);background-color:var(--bg-secondary)}.skeleton-rating{width:60px;height:24px}.skeleton-distance{width:70px;height:24px;border-radius:var(--radius-full)}@media(max-width:768px){.skeleton-header{padding:var(--space-4)}.skeleton-icon{width:48px;height:48px}.skeleton-body{padding:0 var(--space-4);padding-bottom:var(--space-3)}.skeleton-footer{padding:var(--space-3) var(--space-4)}}.carousel-3d{position:relative;width:100%;padding:var(--space-8) 0;overflow:hidden}.carousel-3d__stage{perspective:1200px;perspective-origin:center center;cursor:grab;-webkit-user-select:none;user-select:none;padding:var(--space-6) 0}.carousel-3d__stage:active{cursor:grabbing}.carousel-3d__track{display:flex;justify-content:center;align-items:center;position:relative;height:380px;transform-style:preserve-3d}.carousel-3d__item{position:absolute;width:340px;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.25,.46,.45,.94),opacity .5s ease;will-change:transform,opacity;pointer-events:none}.carousel-3d__item--active{pointer-events:auto}.carousel-3d__item--active:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;background:linear-gradient(135deg,rgba(var(--color-primary-rgb, 99, 102, 241),.3),rgba(var(--color-secondary-rgb, 236, 72, 153),.2));border-radius:calc(var(--radius-xl) + 10px);z-index:-1;filter:blur(20px);opacity:0;transition:opacity .5s ease}.carousel-3d__item--active:hover:before{opacity:1}.carousel-3d__item:after{content:"";position:absolute;bottom:-60%;left:5%;right:5%;height:60%;background:linear-gradient(to bottom,rgba(var(--bg-primary-rgb, 255, 255, 255),.15),transparent 40%);transform:rotateX(180deg) scaleY(-1);mask-image:linear-gradient(to bottom,rgba(0,0,0,.3),transparent);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.3),transparent);pointer-events:none;border-radius:var(--radius-xl)}.carousel-3d__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:200;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--glass-bg-strong);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow-lg);transition:all .3s ease}.carousel-3d__nav:hover{background:var(--color-primary-500);color:var(--text-on-primary);transform:translateY(-50%) scale(1.1);box-shadow:var(--shadow-primary)}.carousel-3d__nav:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.carousel-3d__nav--prev{left:var(--space-4)}.carousel-3d__nav--prev svg,.carousel-3d__nav--prev .icon{transform:rotate(180deg)}.carousel-3d__nav--next{right:var(--space-4)}.carousel-3d__dots{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-6)}.carousel-3d__dot{width:10px;height:10px;border-radius:var(--radius-full);border:none;background:var(--color-neutral-300);cursor:pointer;transition:all .3s ease;padding:0}.carousel-3d__dot:hover{background:var(--color-primary-300);transform:scale(1.2)}.carousel-3d__dot--active{background:var(--color-primary-500);width:28px;border-radius:var(--radius-full)}.carousel-3d__dot:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.carousel-3d__progress{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:120px;height:3px;background:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden}.carousel-3d__progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary-500),var(--color-secondary-500));border-radius:var(--radius-full);animation:progress-fill linear forwards}@keyframes progress-fill{0%{width:0%}to{width:100%}}@media(max-width:1200px){.carousel-3d__item{width:320px}.carousel-3d__track{height:360px}}@media(max-width:1024px){.carousel-3d__item{width:300px}.carousel-3d__track{height:340px}.carousel-3d__nav{width:48px;height:48px}}@media(max-width:768px){.carousel-3d{padding:var(--space-4) 0}.carousel-3d__stage{perspective:800px;padding:var(--space-4) 0}.carousel-3d__item{width:280px}.carousel-3d__track{height:320px}.carousel-3d__nav{width:44px;height:44px}.carousel-3d__nav--prev{left:var(--space-2)}.carousel-3d__nav--next{right:var(--space-2)}.carousel-3d__dots{margin-top:var(--space-4)}}@media(max-width:480px){.carousel-3d__stage{perspective:600px}.carousel-3d__item{width:260px}.carousel-3d__track{height:300px}.carousel-3d__nav{width:40px;height:40px}.carousel-3d__dot{width:8px;height:8px}.carousel-3d__dot--active{width:24px}}@media(prefers-color-scheme:dark){.carousel-3d__nav{background:#282828d9;border-color:#ffffff1a}.carousel-3d__dot{background:var(--color-neutral-600)}.carousel-3d__progress{background:var(--color-neutral-700)}}@media(prefers-reduced-motion:reduce){.carousel-3d__item{transition:opacity .2s ease}.carousel-3d__progress-bar{animation:none;width:100%}}.hero{position:relative;width:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--text-on-primary)}.hero--small{min-height:300px;padding:var(--space-12) 0}.hero--medium{min-height:450px;padding:var(--space-16) 0}.hero--large{min-height:600px;padding:var(--space-20) 0 var(--space-24)}.hero--align-left .hero__content{text-align:left;align-items:flex-start}.hero--align-center .hero__content{text-align:center;align-items:center}.hero--align-right .hero__content{text-align:right;align-items:flex-end}.hero__background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero__bg-image{width:100%;height:100%;object-fit:cover;object-position:center}.hero__bg-gradient{width:100%;height:100%;background:var(--gradient-hero);background-size:200% 200%;animation:gradientShift 15s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:var(--hero-overlay-opacity, .5)}.hero--overlay-dark .hero__overlay{background:var(--gradient-hero-overlay)}.hero--overlay-light .hero__overlay{background:linear-gradient(180deg,#fffc,#fff9)}.hero--overlay-light{color:var(--text-primary)}.hero__pattern{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.5;pointer-events:none}.hero__container{position:relative;z-index:2;width:100%}.hero__content{display:flex;flex-direction:column;max-width:850px;margin:0 auto}.hero__title{font-family:var(--font-display);font-size:var(--text-6xl);font-weight:var(--font-extrabold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-5);text-shadow:0 4px 30px rgba(0,0,0,.2)}.hero__subtitle{font-size:var(--text-xl);font-weight:var(--font-medium);line-height:var(--leading-relaxed);opacity:.95;margin-bottom:var(--space-8);max-width:640px;color:inherit}.hero--align-center .hero__subtitle{margin-left:auto;margin-right:auto}.hero__actions{display:flex;flex-direction:column;gap:var(--space-6);width:100%;max-width:700px}.hero--align-center .hero__actions{margin-left:auto;margin-right:auto}.hero__wave{position:absolute;bottom:-1px;left:0;right:0;z-index:3;color:var(--bg-secondary);line-height:0}.hero__wave svg{width:100%;height:80px}@media(max-width:1024px){.hero--large{min-height:500px;padding:var(--space-16) 0 var(--space-20)}.hero__title{font-size:var(--text-5xl)}.hero__subtitle{font-size:var(--text-lg)}}@media(max-width:768px){.hero__globe-container{display:none!important}.hero--small{min-height:250px;padding:var(--space-10) 0}.hero--medium{min-height:350px;padding:var(--space-12) 0}.hero--large{min-height:450px;padding:var(--space-12) 0 var(--space-16)}.hero__title{font-size:var(--text-4xl);margin-bottom:var(--space-4)}.hero__subtitle{font-size:var(--text-base);margin-bottom:var(--space-6)}.hero__wave svg{height:50px}}@media(max-width:480px){.hero--large{min-height:400px}.hero__title{font-size:var(--text-3xl)}.hero__subtitle{font-size:var(--text-sm)}.hero__wave svg{height:40px}}.home-page{width:100%;min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.search-form{width:100%;max-width:720px}.search-container{display:flex;gap:var(--space-3);padding:var(--space-2);background:var(--glass-bg-strong);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:var(--radius-2xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-float-lg);transition:var(--transition-base)}.search-container:focus-within{box-shadow:var(--shadow-float-lg),var(--shadow-primary);border-color:var(--color-primary-300)}.search-input-wrapper{flex:1;display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-4);position:relative}.search-icon{color:var(--color-primary-500);flex-shrink:0}.search-input{flex:1;height:var(--input-height-lg);padding:0;border:none;background:transparent;font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--text-primary);outline:none}.search-input::placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.search-clear{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-neutral-200);color:var(--text-secondary);transition:var(--transition-fast);flex-shrink:0}.search-clear:hover{background:var(--color-neutral-300);color:var(--text-primary)}.search-button{flex-shrink:0;border-radius:var(--radius-xl)!important;padding:0 var(--space-6)!important;gap:var(--space-2)}.search-button-text{display:inline}.hero-quick-links{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:wrap;margin-top:var(--space-6)}.quick-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-full);color:var(--text-on-primary);font-size:var(--text-sm);font-weight:var(--font-medium);text-decoration:none;transition:var(--transition-base);border:1px solid rgba(255,255,255,.2)}.quick-link:hover{background:#ffffff40;transform:translateY(-2px);color:var(--text-on-primary);text-decoration:none}.content-section{padding:var(--space-16) 0;background:var(--bg-secondary)}.content-section--featured{background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%)}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-10);flex-wrap:wrap;gap:var(--space-4)}.section-header-content{display:flex;flex-direction:column;gap:var(--space-2)}.section-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--gradient-accent);color:var(--color-neutral-900);font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide);border-radius:var(--radius-full);width:fit-content}.section-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight);margin:0}.section-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0;max-width:500px}.place-card-wrapper{animation-fill-mode:both}.empty-state-wrapper{background:var(--bg-primary);border-radius:var(--radius-2xl);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.features-section{background:var(--bg-primary);padding:var(--space-20) 0;position:relative;overflow:hidden}.features-section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-light),transparent)}.features-header{text-align:center;margin-bottom:var(--space-12)}.features-header .section-title{margin-bottom:var(--space-3)}.features-header .section-subtitle{max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-8)}.feature-card{text-align:center;padding:var(--space-8);border-radius:var(--radius-2xl);background:var(--gradient-card);transition:var(--transition-base);border:1px solid var(--border-light);position:relative;animation-fill-mode:both}.feature-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-2xl);background:var(--gradient-primary);opacity:0;transition:opacity var(--duration-normal);z-index:0}.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-200)}.feature-card:hover:before{opacity:.03}.feature-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:var(--radius-xl);margin-bottom:var(--space-5);position:relative;z-index:1;transition:transform var(--duration-normal) var(--ease-spring)}.feature-card:hover .feature-icon-wrapper{transform:scale(1.1) rotate(-3deg)}.feature-icon--primary{background:linear-gradient(135deg,var(--color-primary-100),var(--color-primary-50))}.feature-icon--secondary{background:linear-gradient(135deg,var(--color-accent-100),var(--color-accent-50))}.feature-icon--accent{background:linear-gradient(135deg,var(--color-secondary-100),var(--color-secondary-50))}.feature-icon{font-size:2.5rem;line-height:1}.feature-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3);position:relative;z-index:1}.feature-description{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed);position:relative;z-index:1;margin:0}.cta-section{background:var(--gradient-hero);padding:var(--space-20) 0;position:relative;overflow:hidden}.cta-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.4}.cta-content{text-align:center;position:relative;z-index:1}.cta-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--text-on-primary);margin-bottom:var(--space-4)}.cta-description{font-size:var(--text-xl);color:var(--text-on-primary);opacity:.9;margin-bottom:var(--space-8);max-width:500px;margin-left:auto;margin-right:auto}.cta-actions{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}@media(max-width:1024px){.section-title{font-size:var(--text-3xl)}.places-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:768px){.content-section{padding:var(--space-12) 0}.search-container{flex-direction:column;gap:var(--space-2);padding:var(--space-3)}.search-input-wrapper{width:100%}.search-button{width:100%;justify-content:center}.hero-quick-links{flex-direction:column;align-items:center}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.section-title{font-size:var(--text-2xl)}.section-subtitle{font-size:var(--text-base)}.features-section{padding:var(--space-12) 0}.features-grid{grid-template-columns:1fr;gap:var(--space-6)}.feature-card{padding:var(--space-6)}.places-grid{grid-template-columns:1fr;gap:var(--space-4)}.cta-section{padding:var(--space-12) 0}.cta-title{font-size:var(--text-2xl)}.cta-description{font-size:var(--text-base)}}@media(max-width:480px){.search-input{font-size:var(--text-base);height:var(--input-height-base)}.search-button-text{display:none}.search-button{padding:0 var(--space-4)!important;min-width:auto}.quick-link{font-size:var(--text-xs);padding:var(--space-1-5) var(--space-3)}.feature-icon-wrapper{width:64px;height:64px}.feature-icon{font-size:2rem}.feature-title{font-size:var(--text-lg)}.section-badge{font-size:.65rem}}@media(prefers-color-scheme:dark){.search-container{background:#282828d9;border-color:#ffffff1a}.quick-link{background:#ffffff1a;border-color:#ffffff26}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.place-card-wrapper{animation:slideUpFade var(--duration-slow) var(--ease-out) both}.clear-button{display:inline-flex;align-items:center;gap:var(--space-2)}.auth-container{min-height:calc(100vh - var(--header-height));display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:var(--gradient-hero)}.auth-card{background:var(--bg-primary);border-radius:var(--radius-2xl);box-shadow:var(--shadow-float-lg);max-width:480px;width:100%;padding:var(--space-10);animation:slideUp var(--duration-slow) var(--ease-out)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-header h1{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.auth-header p{color:var(--text-secondary);font-size:var(--text-base);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-weight:var(--font-semibold);color:var(--text-primary);font-size:var(--text-sm)}.form-group input{padding:var(--space-3) var(--space-4);border:2px solid var(--border-medium);border-radius:var(--radius-lg);font-size:var(--text-base);transition:var(--transition-base);font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary)}.form-group input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--focus-ring)}.form-group input:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.form-group input.error{border-color:var(--color-error-500)}.form-group input.error:focus{border-color:var(--color-error-500);box-shadow:var(--focus-ring-error)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:var(--space-12)}.password-toggle{position:absolute;right:var(--space-3);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-base);color:var(--text-tertiary);transition:var(--transition-fast);cursor:pointer}.password-toggle:hover{background:var(--color-neutral-100);color:var(--text-primary)}.password-toggle:focus-visible{box-shadow:var(--focus-ring)}.field-error{color:var(--color-error-600);font-size:var(--text-sm);font-weight:var(--font-medium);display:flex;align-items:center;gap:var(--space-1)}.form-group small{color:var(--text-tertiary);font-size:var(--text-sm)}.error-message{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-error-50);border:1px solid var(--color-error-200);border-radius:var(--radius-lg);color:var(--color-error-700)}.error-message span{font-size:var(--text-xl)}.error-message p{margin:0;font-size:var(--text-sm)}.auth-footer{text-align:center;margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-light)}.auth-footer p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.auth-footer a{color:var(--color-primary-600);font-weight:var(--font-semibold);text-decoration:none;transition:var(--transition-colors)}.auth-footer a:hover{color:var(--color-primary-700);text-decoration:underline}.demo-credentials{margin-top:var(--space-8);padding:var(--space-5);background:linear-gradient(135deg,var(--color-info-50) 0%,var(--color-primary-50) 100%);border-radius:var(--radius-xl);border:1px solid var(--color-primary-100)}.demo-credentials h3{margin:0 0 var(--space-4) 0;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary-700);display:flex;align-items:center;gap:var(--space-2)}.demo-account{margin-bottom:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-light);transition:var(--transition-fast)}.demo-account:last-child{margin-bottom:0}.demo-account:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-sm)}.demo-account strong{display:block;margin-bottom:var(--space-2);color:var(--color-primary-600);font-size:var(--text-sm);font-weight:var(--font-semibold)}.demo-account-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.demo-account-header strong{margin-bottom:0}.quick-fill-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-on-primary);background:var(--gradient-primary);border:none;border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-fast);box-shadow:var(--shadow-sm)}.quick-fill-btn:hover{transform:scale(1.05);box-shadow:var(--shadow-md),var(--shadow-primary)}.quick-fill-btn:active{transform:scale(.98)}.demo-account p{margin:var(--space-1) 0;font-size:var(--text-sm);color:var(--text-secondary);font-family:var(--font-mono);background:var(--bg-tertiary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);display:inline-block}@media(max-width:768px){.auth-container{padding:var(--space-4);align-items:flex-start;padding-top:var(--space-8)}.auth-card{padding:var(--space-6);border-radius:var(--radius-xl)}.auth-header h1{font-size:var(--text-2xl)}.demo-credentials{padding:var(--space-4)}}@media(max-width:480px){.auth-card{padding:var(--space-5)}.auth-header{margin-bottom:var(--space-6)}.auth-form{gap:var(--space-4)}}.recommendations-page{min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.filters-section{margin-bottom:var(--space-6)}.filters-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-5);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);cursor:pointer;transition:var(--transition-base);box-shadow:var(--shadow-sm)}.filters-toggle:hover{background:var(--bg-secondary);border-color:var(--color-primary-300)}.filters-bar{max-height:0;overflow:hidden;opacity:0;transition:all var(--duration-slow) var(--ease-out)}.filters-bar--open{max-height:500px;opacity:1;margin-top:var(--space-4)}.filters-inline{display:flex;align-items:flex-end;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);width:100%}.filter-group{display:flex;flex-direction:column;gap:var(--space-1)}.filter-group--location{flex:1;min-width:180px}.filter-group--distance{width:120px;flex-shrink:0}.filter-group--sort{width:130px;flex-shrink:0}.filter-group--action{flex-shrink:0;padding-bottom:2px}.filter-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.filter-input{height:var(--input-height-base);padding:0 var(--space-3);border:2px solid var(--border-medium);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-primary);transition:var(--transition-base);width:100%}.filter-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--focus-ring)}.filter-select{height:var(--input-height-base);padding:0 var(--space-3);border:2px solid var(--border-medium);border-radius:var(--radius-lg);font-size:var(--text-sm);background:var(--bg-primary);transition:var(--transition-base);width:100%;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.filter-select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--focus-ring)}.filter-select:hover{border-color:var(--color-primary-300)}.apply-filters-btn{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;border:none;padding:var(--space-3) var(--space-5);font-weight:var(--font-semibold);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);box-shadow:0 2px 8px rgba(var(--color-primary-rgb, 59, 130, 246),.3)}.apply-filters-btn:hover{background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-700));transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb, 59, 130, 246),.4)}.results-section{padding:var(--space-8) 0 var(--space-16)}.results-header{margin-bottom:var(--space-6)}.results-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-6)}.recommendation-item{animation-fill-mode:both}.error-state,.info-state,.empty-state{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-12) var(--space-8);text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.info-state{border-left:4px solid var(--color-primary-500)}.info-icon,.empty-icon{font-size:4rem;margin-bottom:var(--space-5);line-height:1}.info-state h3,.empty-state h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.info-state p,.empty-state p{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-6)}.retry-button{margin-top:var(--space-4)}@media(max-width:768px){.filters-inline{flex-direction:column;align-items:stretch;gap:var(--space-3)}.filter-group--location{max-width:none}.filter-group--distance{width:100%}.filter-group--action{padding-bottom:0}.recommendations-grid{grid-template-columns:1fr}.results-section{padding:var(--space-6) 0 var(--space-12)}.info-state,.empty-state{padding:var(--space-8) var(--space-4)}}.place-details-page{min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-4);text-align:center;background:var(--bg-primary);border-radius:var(--radius-2xl);margin:var(--space-8) 0}.error-state h3{font-size:var(--text-xl);color:var(--text-primary)}.error-state p{color:var(--text-secondary)}.place-hero{position:relative;background:var(--gradient-hero);padding:var(--space-10) 0 var(--space-16);margin-bottom:calc(-1 * var(--space-10))}.place-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.place-hero-content{position:relative;z-index:2;max-width:var(--container-lg);padding:var(--space-10) 0 var(--space-16);animation-fill-mode:both}.back-link{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--text-on-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);text-decoration:none;margin-bottom:var(--space-5);padding:var(--space-2) var(--space-4);background:#ffffff26;border-radius:var(--radius-lg);opacity:.9;transition:var(--transition-fast)}.back-link:hover{opacity:1;color:var(--text-on-primary);background:#ffffff40}.place-category-badge{margin-bottom:var(--space-5)}.place-category-badge .badge{font-size:var(--text-base);padding:var(--space-2) var(--space-4)}.place-title{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:var(--font-black);color:var(--text-on-primary);margin-bottom:var(--space-4);text-shadow:0 2px 4px rgba(0,0,0,.1)}.place-meta{display:flex;gap:var(--space-6);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:var(--space-2);color:var(--text-on-primary);font-size:var(--text-lg);font-weight:var(--font-medium)}.meta-icon{font-size:var(--text-xl)}.meta-item--rating{background:#fff3;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rating-value{font-weight:var(--font-bold);font-size:var(--text-xl)}.rating-count{font-size:var(--text-sm);opacity:.8}.place-actions-bar{display:flex;gap:var(--space-3);flex-wrap:wrap;margin-top:calc(-1 * var(--space-20));margin-bottom:var(--space-10);animation-fill-mode:both}.action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--bg-primary);border:2px solid var(--border-light);border-radius:var(--radius-xl);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-decoration:none;box-shadow:var(--shadow-md)}.action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.action-btn .action-icon{font-size:var(--text-lg)}.action-btn .action-label{white-space:nowrap}.action-btn-favourite:hover{background:linear-gradient(135deg,#d3f9d8,#b2f2bb);border-color:#8ce99a;color:#2b8a3e}.action-btn-favourite.active{background:linear-gradient(135deg,#8ce99a,#69db7c);border-color:#51cf66;color:#1e7b34}.action-btn-dislike:hover{background:linear-gradient(135deg,#ffe3e3,#ffc9c9);border-color:#ffa8a8;color:#c92a2a}.action-btn-dislike.active{background:linear-gradient(135deg,#ffa8a8,#ff8787);border-color:#ff6b6b;color:#a61e1e}.action-btn-navigate:hover{background:linear-gradient(135deg,#fff3bf,#ffe066);border-color:#ffd43b;color:#e67700}.report-link{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-5);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-tertiary);background:transparent;border:none;cursor:pointer;transition:var(--transition-fast);border-radius:var(--radius-base)}.report-link:hover{color:var(--color-error-600);background:var(--color-error-50)}.navigate-btn-inline{text-decoration:none}.place-info-section{margin-bottom:var(--space-8)}.place-info-card{background:var(--bg-primary);padding:var(--space-6);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg)}.place-info-card h2{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-5)}.place-address-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.place-address-row .info-icon{font-size:var(--text-xl)}.place-address-row .info-value{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary)}.place-description-text p{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text-secondary)}.place-gallery-section{margin-bottom:var(--space-8)}.place-content-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5);margin-bottom:var(--space-8)}.place-description-card,.place-info-card{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);animation-fill-mode:both}.place-description-card{display:flex;align-items:flex-start;gap:var(--space-5)}.place-description-card h2{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-base);font-weight:var(--font-bold);color:var(--text-primary);margin:0;white-space:nowrap}.place-description-card p{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text-secondary);margin:0;flex:1}.place-info-card h3{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-4)}.info-list{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}.info-row{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.info-icon{font-size:1.5rem}.info-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.info-value{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary)}.reviews-section{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);animation-fill-mode:both}.reviews-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.reviews-header h2{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.review-form{background:var(--bg-tertiary);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6)}.star-rating{display:flex;flex-direction:row-reverse;justify-content:flex-end;gap:var(--space-1)}.star-btn{font-size:2rem;background:none;border:none;color:var(--color-neutral-300);cursor:pointer;transition:color var(--duration-fast);padding:0}.star-btn--active,.star-btn:hover,.star-btn:hover~.star-btn{color:var(--color-accent-500)}.reviews-list{display:grid;gap:var(--space-4)}.review-card{background:var(--bg-tertiary);border-radius:var(--radius-xl);padding:var(--space-5);animation-fill-mode:both;transition:var(--transition-base)}.review-card:hover{box-shadow:var(--shadow-md)}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);flex-wrap:wrap;gap:var(--space-3)}.review-user{display:flex;align-items:center;gap:var(--space-3);font-weight:var(--font-semibold);color:var(--text-primary)}.user-avatar{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:var(--text-on-primary);font-weight:var(--font-bold);border-radius:var(--radius-full)}.review-rating{display:flex;align-items:center;gap:var(--space-2)}.review-rating .stars{color:var(--color-accent-500);font-size:var(--text-lg)}.rating-number{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:var(--font-medium)}.review-comment{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text-secondary);margin-bottom:var(--space-4)}.review-date{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary)}.no-reviews{text-align:center;padding:var(--space-12)}.no-reviews-icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.5}.no-reviews h4{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:var(--space-2)}.no-reviews p{color:var(--text-tertiary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--space-4)}.modal-content{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-8);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-2xl);animation-fill-mode:both}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-light)}.modal-header h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.modal-close:hover{background:var(--color-neutral-200);color:var(--text-primary)}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6)}@media(max-width:1024px){.place-content-grid{grid-template-columns:1fr}}@media(max-width:768px){.place-hero{padding:var(--space-12) 0 var(--space-24)}.place-title{font-size:var(--text-3xl)}.place-meta{flex-direction:column;gap:var(--space-3)}.place-actions-bar{flex-direction:row;flex-wrap:wrap;justify-content:center;margin-top:calc(-1 * var(--space-24))}.place-actions-bar button,.place-actions-bar a{flex:1 1 auto;min-width:100px;max-width:150px}.place-description-card,.place-info-card,.reviews-section{padding:var(--space-5)}.reviews-header,.review-header{flex-direction:column;align-items:flex-start}.form-actions{flex-direction:column}.star-btn{font-size:1.5rem}}@media(max-width:480px){.place-hero{padding:var(--space-10) 0 calc(var(--space-32) + var(--space-20))}.place-title{font-size:var(--text-2xl)}.place-actions-bar{flex-direction:column;align-items:stretch;gap:var(--space-2);margin-top:calc(-1 * (var(--space-32) + var(--space-16)))}.place-actions-bar button,.place-actions-bar a{min-width:auto;max-width:none;width:100%}}.user-profile-page{min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.message-toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);margin-bottom:var(--space-6);font-weight:var(--font-medium);box-shadow:var(--shadow-md);animation-fill-mode:both}.message-toast--success{background:var(--color-success-50);color:var(--color-success-700);border:1px solid var(--color-success-200)}.message-toast--error{background:var(--color-error-50);color:var(--color-error-700);border:1px solid var(--color-error-200)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--space-8);padding-bottom:var(--space-16)}.profile-card,.settings-card{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);animation-fill-mode:both}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-5);border-bottom:1px solid var(--border-light)}.card-title{display:flex;align-items:center;gap:var(--space-3)}.card-icon{font-size:1.5rem}.card-header h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.info-grid{display:grid;gap:var(--space-4)}.info-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg);transition:var(--transition-base)}.info-item:hover{background:var(--bg-secondary)}.info-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.info-content{display:flex;flex-direction:column;gap:var(--space-1)}.info-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-tertiary)}.info-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.settings-list{display:grid;gap:var(--space-4)}.setting-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.setting-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.setting-content{flex:1;display:flex;justify-content:space-between;align-items:center}.setting-label{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary)}.setting-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.setting-status{font-size:var(--text-sm);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.setting-status--on{background:var(--color-success-100);color:var(--color-success-700)}.setting-status--off{background:var(--color-neutral-200);color:var(--text-tertiary)}.edit-form{display:grid;gap:var(--space-5)}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-5);border-top:1px solid var(--border-light)}.toggle-group{padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.toggle-label{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.toggle-info{display:flex;align-items:center;gap:var(--space-3)}.toggle-icon{font-size:1.25rem}.toggle-text{display:flex;flex-direction:column}.toggle-name{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--text-primary)}.toggle-description{font-size:var(--text-sm);color:var(--text-tertiary)}.toggle{position:relative;width:52px;height:28px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-neutral-300);border-radius:var(--radius-full);transition:var(--transition-base)}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:var(--radius-full);transition:var(--transition-base);box-shadow:var(--shadow-sm)}.toggle--active .toggle-slider{background-color:var(--color-success-500)}.toggle--active .toggle-slider:before{transform:translate(24px)}@media(max-width:768px){.profile-grid{grid-template-columns:1fr}.profile-card,.settings-card{padding:var(--space-5)}.card-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.info-item,.setting-item{flex-direction:column;align-items:flex-start;gap:var(--space-3);text-align:left}.setting-content{flex-direction:column;align-items:flex-start;gap:var(--space-2);width:100%}.toggle-label{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.toggle{align-self:flex-start}.form-actions{flex-direction:column}.form-actions button{width:100%}}.preferences-page{min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.page-actions{display:flex;justify-content:flex-end;margin-bottom:var(--space-8)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4);text-align:center}.loading-state p,.error-state p{font-size:var(--text-base);color:var(--text-secondary)}.preference-form{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-8);margin-bottom:var(--space-8);box-shadow:var(--shadow-lg);border:1px solid var(--border-light);animation-fill-mode:both}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-light)}.form-header h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.close-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.close-button:hover{background:var(--color-neutral-200);color:var(--text-primary)}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.category-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-base);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.category-chip:hover{border-color:var(--color-primary-300);background:var(--color-primary-50)}.category-chip--active{border-color:var(--color-primary-500);background:var(--color-primary-50);color:var(--color-primary-700)}.category-icon{font-size:var(--text-lg)}.category-name{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.price-range-inputs{display:flex;align-items:center;gap:var(--space-4)}.price-input-group{display:flex;align-items:center;flex:1;background:var(--bg-primary);border:2px solid var(--border-medium);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition-base)}.price-input-group:focus-within{border-color:var(--color-primary-500);box-shadow:var(--focus-ring)}.price-prefix{padding:0 var(--space-3);color:var(--text-tertiary);font-weight:var(--font-semibold);background:var(--bg-tertiary)}.price-input-group .form-input{border:none;border-radius:0}.price-input-group .form-input:focus{box-shadow:none}.price-separator{color:var(--text-tertiary);font-size:var(--text-lg)}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-light)}.profiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-6);padding-bottom:var(--space-16)}.profile-card{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-sm);border:2px solid var(--border-light);transition:var(--transition-base);animation-fill-mode:both}.profile-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-medium)}.profile-card--active{border-color:var(--color-success-500);box-shadow:0 0 0 4px var(--color-success-50)}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-light)}.profile-header h3{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.active-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-success-100);color:var(--color-success-700);font-size:var(--text-xs);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:var(--tracking-wide);border-radius:var(--radius-full)}.profile-content{margin-bottom:var(--space-5)}.profile-section{margin-bottom:var(--space-4)}.profile-section:last-child{margin-bottom:0}.profile-section h4{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-2)}.profile-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.profile-tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-primary-50);color:var(--color-primary-700);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full)}.no-data{font-size:var(--text-sm);color:var(--text-disabled);font-style:italic}.price-display{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);font-family:var(--font-mono);margin:0}.profile-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;padding-top:var(--space-4);border-top:1px solid var(--border-light)}.empty-state .empty-icon{font-size:4rem;margin-bottom:var(--space-5);line-height:1}.empty-state p{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-6)}@media(max-width:768px){.page-actions{justify-content:stretch}.page-actions button{width:100%}.preference-form{padding:var(--space-5)}.category-grid{grid-template-columns:repeat(2,1fr)}.price-range-inputs{flex-direction:column;gap:var(--space-3)}.price-separator{display:none}.profiles-grid{grid-template-columns:1fr}.profile-actions{flex-direction:column}.profile-actions button{width:100%}.form-actions{flex-direction:column}}.favourites-page{min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.error-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-error-50);border:1px solid var(--color-error-200);border-radius:var(--radius-lg);color:var(--color-error-700);margin-bottom:var(--space-6)}.error-banner p{margin:0;color:inherit}.tabs-container{margin-bottom:var(--space-8)}.tabs{display:flex;gap:var(--space-2);background:var(--bg-primary);padding:var(--space-2);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-6);background:transparent;border:none;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-secondary);cursor:pointer;transition:var(--transition-base)}.tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab--active{background:var(--gradient-primary);color:var(--text-on-primary);box-shadow:var(--shadow-primary)}.tab--active:hover{background:var(--gradient-primary);color:var(--text-on-primary)}.tab-icon{font-size:var(--text-lg)}.tab-label{display:inline}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-2);background:#fff3;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-bold)}.tab:not(.tab--active) .tab-count{background:var(--color-neutral-200);color:var(--text-secondary)}.tab-content{padding-bottom:var(--space-16);animation:fadeIn var(--duration-normal) var(--ease-out)}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-6)}.favourite-item{display:flex;flex-direction:column;animation-fill-mode:both}.item-actions{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-light);gap:var(--space-4)}.date-added{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-tertiary);font-weight:var(--font-medium)}.empty-state{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-16) var(--space-8);text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.empty-icon{font-size:5rem;margin-bottom:var(--space-6);opacity:.6;line-height:1}.empty-state h3{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-3)}.empty-state p{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}@media(max-width:768px){.tabs{flex-direction:column}.tab{justify-content:flex-start}.places-grid{grid-template-columns:1fr}.item-actions{flex-direction:column;align-items:stretch;gap:var(--space-3)}.date-added{justify-content:center}.empty-state{padding:var(--space-10) var(--space-4)}.empty-icon{font-size:4rem}}@media(max-width:480px){.tab-label{display:none}.tab{justify-content:center;padding:var(--space-3)}.tab-icon{font-size:var(--text-xl)}}.route-map-container{position:relative;border-radius:var(--radius-xl);overflow:hidden;background:var(--bg-tertiary);box-shadow:var(--shadow-sm)}.route-map{width:100%;height:300px;z-index:1}@media(min-width:768px){.route-map{height:350px}}.custom-marker{background:transparent;border:none}.marker-pin{width:30px;height:42px;position:relative;display:flex;align-items:center;justify-content:center;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 3px 10px #0000004d}.marker-pin--green{background:linear-gradient(135deg,#10b981,#059669)}.marker-pin--red{background:linear-gradient(135deg,#ef4444,#dc2626)}.marker-label{transform:rotate(45deg);font-size:14px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.map-popup{display:flex;flex-direction:column;gap:4px;min-width:150px}.map-popup strong{font-size:var(--text-sm);color:var(--text-primary);margin-bottom:2px}.popup-name{font-size:var(--text-base);font-weight:600;color:var(--color-primary-600)}.popup-coords{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-content{margin:12px 16px!important}.leaflet-popup-tip{box-shadow:var(--shadow-sm)!important}.map-empty-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;pointer-events:none}.map-empty-icon{font-size:3rem;margin-bottom:var(--space-3);opacity:.5}.map-empty-overlay p{font-size:var(--text-base);color:var(--text-secondary);margin:0}.leaflet-control-attribution{font-size:10px;background:#fffc!important;padding:2px 6px!important}.leaflet-control-zoom a{background:var(--bg-primary)!important;color:var(--text-primary)!important;border-color:var(--border-light)!important}.leaflet-control-zoom a:hover{background:var(--bg-tertiary)!important}.navigation-page{min-height:calc(100vh - var(--header-height));background:var(--bg-secondary)}.navigation-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);margin-bottom:var(--space-12)}.route-form-card,.route-results-card{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-base);border:1px solid var(--border-light)}.card-title{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.card-title h3{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0}.location-section{background:var(--bg-tertiary);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-4)}.section-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.section-icon{font-size:var(--text-lg)}.section-header h4{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.coords-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.location-input-wrapper{position:relative;display:flex;align-items:center}.location-input-wrapper .input-icon{position:absolute;left:var(--space-4);color:var(--text-tertiary);pointer-events:none}.location-input{padding-left:var(--space-10)!important;font-size:var(--text-base)}.resolved-location{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-success-50);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-success-700)}.resolved-location svg{color:var(--color-success-500)}.location-connector{display:flex;flex-direction:column;align-items:center;padding:var(--space-2) 0}.connector-line{width:2px;height:12px;background:var(--border-medium)}.connector-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-100);color:var(--color-primary-600);border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--font-bold)}.transport-section{margin-bottom:var(--space-6)}.transport-options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:var(--space-3)}.transport-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-base)}.transport-option:hover{border-color:var(--color-primary-300);background:var(--color-primary-50)}.transport-option--active{border-color:var(--color-primary-500);background:var(--color-primary-50);box-shadow:var(--shadow-primary)}.transport-icon{font-size:1.75rem}.transport-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-align:center}.transport-option--active .transport-label{color:var(--color-primary-700)}.error-message{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--color-error-50);color:var(--color-error-700);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium)}.results-column{display:flex;flex-direction:column}.empty-results{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-12);text-align:center;border:2px dashed var(--border-medium)}.empty-results .empty-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.5}.empty-results h3{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-results p{font-size:var(--text-base);color:var(--text-secondary)}.route-stats{display:grid;gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--bg-tertiary);border-radius:var(--radius-xl);transition:var(--transition-base)}.stat-card:hover{transform:translate(4px)}.stat-icon{font-size:2rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.stat-content{flex:1}.stat-label{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--space-1)}.stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-primary-600)}.route-points{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6);padding:var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.route-point{display:flex;align-items:center;gap:var(--space-3)}.point-marker{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-on-primary)}.point-marker--start{background:var(--color-secondary-500)}.point-marker--end{background:var(--color-primary-500)}.point-coords{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);cursor:help}.point-info{display:flex;flex-direction:column;gap:2px;flex:1}.point-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.point-name--loading{display:flex;align-items:center}.loading-skeleton{display:inline-block;width:140px;height:18px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.quick-routes-section{background:var(--bg-primary);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.quick-routes-section .section-title{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-6)}.quick-routes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}.quick-route-btn{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:var(--radius-xl);cursor:pointer;transition:var(--transition-base);text-align:left}.quick-route-btn:hover{border-color:var(--color-primary-300);background:var(--color-primary-50);transform:translateY(-2px);box-shadow:var(--shadow-md)}.route-emoji{font-size:2rem}.route-name{flex:1;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.route-arrow{color:var(--text-tertiary);transition:transform var(--duration-fast)}.quick-route-btn:hover .route-arrow{transform:translate(4px);color:var(--color-primary-500)}.route-error-warning{display:flex;gap:var(--space-4);padding:var(--space-5);margin-bottom:var(--space-6);background:linear-gradient(135deg,#fef2f2,#fecaca);border:2px solid #f87171;border-radius:var(--radius-xl);animation:shake .5s ease-in-out}.route-error-icon{font-size:2rem;flex-shrink:0}.route-error-content{flex:1}.route-error-content strong{display:block;font-size:var(--text-base);font-weight:var(--font-bold);color:#b91c1c;margin-bottom:var(--space-2)}.route-error-content p{font-size:var(--text-sm);color:#991b1b;margin:0;line-height:1.5}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}[data-theme=dark] .route-error-warning{background:linear-gradient(135deg,#450a0a,#7f1d1d);border-color:#dc2626}[data-theme=dark] .route-error-content strong{color:#fca5a5}[data-theme=dark] .route-error-content p{color:#fecaca}.route-error-warning--ferry{background:linear-gradient(135deg,#eff6ff,#bfdbfe);border-color:#3b82f6;animation:slideIn .3s ease-out}.route-error-warning--ferry .route-error-content strong{color:#1d4ed8}.route-error-warning--ferry .route-error-content p{color:#1e40af}@keyframes slideIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}[data-theme=dark] .route-error-warning--ferry{background:linear-gradient(135deg,#172554,#1e3a8a);border-color:#3b82f6}[data-theme=dark] .route-error-warning--ferry .route-error-content strong{color:#93c5fd}[data-theme=dark] .route-error-warning--ferry .route-error-content p{color:#bfdbfe}@media(max-width:1024px){.navigation-layout{grid-template-columns:1fr}}@media(max-width:768px){.coords-grid,.transport-options{grid-template-columns:1fr}.route-form-card,.route-results-card{padding:var(--space-5)}.stat-card{flex-direction:column;text-align:center}.quick-routes-grid{grid-template-columns:1fr}}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:80px;padding-bottom:40px}.page-container{max-width:1200px;margin:0 auto;padding:0 20px}.page-header{margin-bottom:32px}.page-title{font-size:32px;font-weight:700;color:var(--text-dark);margin-bottom:8px}.page-subtitle{font-size:16px;color:var(--text-light)}.grid{display:grid;gap:24px}.grid-2{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}@media(max-width:768px){.main-content{padding-top:70px;padding-bottom:20px}.page-container{padding:0 15px}.page-title{font-size:24px}.page-subtitle{font-size:14px}.grid-2,.grid-3{grid-template-columns:1fr}}@media(max-width:480px){.main-content{padding-top:65px;padding-bottom:15px}.page-container{padding:0 10px}.page-header{margin-bottom:20px}.page-title{font-size:20px;margin-bottom:6px}.page-subtitle{font-size:13px}.grid{gap:16px}}
