*{margin:0;padding:0;box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.session-provider-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;text-align:center;background-color:#f5f5f5}.session-provider-error-heading{color:#d32f2f;margin-bottom:16px}.session-provider-error-message{color:#666;margin-bottom:24px;max-width:600px}.session-provider-error-button{padding:10px 20px;font-size:16px;background-color:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.session-provider-error-button:hover{background-color:#1565c0}.session-provider-error-button:active{background-color:#0d47a1}.navigation{background-color:#2c3e50;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.nav-brand h2{margin:0;color:#3498db}.nav-links{display:flex;list-style:none;margin:0;padding:0;gap:2rem}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .3s}.nav-link:hover,.nav-link.active{background-color:#3498db}.nav-user-section{display:flex;align-items:center;gap:.75rem;margin-left:1rem;padding-left:1rem;border-left:1px solid rgba(255,255,255,.2)}.nav-username{color:#ecf0f1;font-weight:500;font-size:.9rem;text-decoration:none;padding:.25rem .5rem;border-radius:4px;transition:color .2s ease}.nav-username:hover,.nav-username-active{color:#3498db}.nav-logout-btn{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;padding:.35rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s ease,border-color .2s ease;font-family:inherit}.nav-logout-btn:hover{background-color:#e74c3ccc;border-color:#e74c3ccc}@media (max-width: 768px){.navigation{flex-direction:column;gap:1rem}.nav-links{gap:1rem}}@media (prefers-color-scheme: dark){.navigation{background-color:#2c3e50}}.region-map-page{padding:1rem;min-height:100vh;display:flex;flex-direction:column;overflow-y:auto}.region-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem}.region-title{margin:0;font-size:28px;font-weight:600;color:#ecf0f1;display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap;flex:1;min-width:0}.region-title.centered{margin:0;font-size:28px;font-weight:600;color:#ecf0f1;text-align:center;display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap}.country-flag{display:inline-flex;align-items:center;height:30px;max-width:50px}.country-flag img{height:100%;width:auto;max-width:100%;border-radius:4px;box-shadow:0 2px 4px #0003;display:block}.place-controls-container{margin-bottom:.25rem;padding:.25rem .75rem;background:#fffffff2;border-radius:8px;box-shadow:0 2px 8px #0000001a}.map-container-wrapper{flex-shrink:0;height:650px;margin-bottom:0}.visited-places-container{padding:.5rem 1rem;background-color:#1a1a1a;border-radius:8px;margin-bottom:2rem}.loading-message,.no-places-message{text-align:center;padding:2rem;color:#9ca3af;font-size:16px}@media (max-width: 768px){.place-controls-container{margin-bottom:.125rem;padding:.25rem .5rem}.map-container-wrapper{height:450px}.visited-places-container{padding:.5rem;margin-bottom:1rem}}.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}}.map-wrapper{position:relative;width:100%;height:100%;margin-top:0;border-radius:0;overflow:visible;box-shadow:none;transform:translateZ(0);will-change:transform}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite}.map-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fffc;z-index:1000;pointer-events:all}.map-loading-box{background:#fffffff2;padding:24px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;align-items:center;gap:12px}.map-loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.map-loading-text{font-size:14px;color:#333;font-weight:500}.map-error-overlay{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#ff00001a;color:#d32f2f;padding:8px 16px;border-radius:4px;border:1px solid #d32f2f;z-index:1000;font-size:14px}.map-expand-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fffc;z-index:2000;pointer-events:all}.map-selected-region-controls{position:absolute;bottom:20px;left:20px;right:20px;z-index:1000;pointer-events:auto}.map-legend-container{position:absolute;top:20px;right:20px;z-index:999;pointer-events:auto}.leaflet-map{border-radius:0;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.leaflet-container{background:#f8f9fa;font-family:inherit;height:100%!important;transform:translateZ(0)}.leaflet-zoom-animated{transform:translateZ(0)}.leaflet-layer{image-rendering:-webkit-optimize-contrast;image-rendering:optimizeSpeed}.leaflet-control-zoom a{background-color:#fff;color:#2c3e50;border:none;box-shadow:0 2px 8px #00000026;border-radius:4px;width:30px;height:30px;line-height:30px;text-align:center;text-decoration:none;font-size:18px;font-weight:700;transition:all .3s ease}.leaflet-control-zoom a:hover{background-color:#3498db;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.leaflet-control-zoom{margin:20px}.leaflet-control-attribution{background:#fffc;font-size:11px;line-height:1.4;border-radius:4px;padding:2px 5px}.leaflet-control-attribution a{color:#3498db;text-decoration:none}.leaflet-control-attribution a:hover{color:#2980b9;text-decoration:underline}@media (max-width: 768px){.map-wrapper{height:500px;margin-top:1rem;border-radius:8px}.leaflet-map{border-radius:8px}.leaflet-control-zoom{margin:10px}.leaflet-control-zoom a{width:25px;height:25px;line-height:25px;font-size:16px}}@media (prefers-color-scheme: dark){.leaflet-container{background:#2c3e50}.leaflet-control-zoom a{background-color:#2c3e50;color:#ecf0f1}.leaflet-control-zoom a:hover{background-color:#3498db;color:#fff}.leaflet-control-attribution{background:#2c3e50e6;color:#ecf0f1}.leaflet-control-attribution a{color:#3498db}}.place-popup{min-width:200px;max-width:300px}.place-popup-name{margin:0 0 8px;font-size:16px;font-weight:600;color:#333}.place-popup-type{margin:0 0 8px;font-size:14px;color:#666}.place-popup-properties{margin:8px 0;font-size:14px}.place-popup-properties ul{margin:4px 0 0;padding-left:16px;list-style-type:none}.place-popup-properties li{margin:2px 0;font-size:13px;color:#555}.mark-as-visited-button{transition:background-color .2s ease}.mark-as-visited-button:hover{background-color:#45a049!important}.visited-indicator{font-weight:500;text-align:center}.leaflet-popup-content-wrapper{border-radius:8px}.leaflet-popup-content{margin:12px 16px}.selected-region-controls{background:#2c3e50;border:1px solid #34495e;border-radius:8px;padding:12px;margin-top:16px;box-shadow:0 2px 8px #0000004d}.region-info{position:relative;display:flex;align-items:center;min-height:32px}.region-text{width:100%;text-align:center}.region-name{margin:0 0 4px;font-size:18px;font-weight:600;color:#ecf0f1;line-height:1.3}.region-type{margin:0;font-size:14px;color:#bdc3c7;font-style:italic}.region-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);display:flex;gap:12px}.expand-button,.collapse-button .go-to-region-button{padding:6px 12px;border:1px solid #4a6a7c;border-radius:4px;background:#34495e;color:#ecf0f1;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:70px}.expand-button:disabled,.collapse-button:disabled,.go-to-region-button:disabled{background:#2c3e50;color:#7f8c8d;border-color:#354d5f;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.selected-region-controls{padding:10px;margin-top:12px}.region-info{flex-direction:column;min-height:auto;gap:12px}.region-text{width:100%}.region-name{font-size:16px}.expand-button,.collapse-button,.go-to-region-button{min-width:70px}}.add-visit-popup-overlay{position:fixed;inset:0;background:#14141ed9;display:flex;align-items:center;justify-content:center;z-index:1000}.add-visit-popup-form{background:#23232b;color:#fff;padding:2rem 2.5rem;border-radius:12px;box-shadow:0 4px 32px #0006;min-width:320px;max-width:90vw;display:flex;flex-direction:column;gap:1.2rem}.add-visit-popup-form h3{margin:0 0 .5rem;font-weight:600;font-size:1.3rem;text-align:center}.add-visit-popup-field{display:flex;flex-direction:column;gap:.3rem}.add-visit-popup-field label{font-size:1rem}.add-visit-popup-form input,.add-visit-popup-form select{background:#181820;color:#fff;border:1px solid #444;border-radius:6px;padding:.4rem .7rem;font-size:1rem}.add-visit-popup-actions{display:flex;justify-content:flex-end;gap:1rem}.add-visit-popup-actions button{background:#3a3a4d;color:#fff;border:none;border-radius:6px;padding:.5rem 1.2rem;font-size:1rem;cursor:pointer;transition:background .2s}.add-visit-popup-actions button:hover{background:#50506a}.place-popup{min-width:200px;max-width:300px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative}.place-popup-close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:18px;font-weight:700;color:#666;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.place-popup-close:hover{background-color:#f0f0f0;color:#333}.place-popup-name{margin:0 0 8px;font-size:16px;font-weight:600;color:#333;line-height:1.3;padding-right:24px}.place-popup-type{margin-bottom:8px;font-size:14px;color:#555}.place-popup-type strong{color:#333}.place-popup-properties{margin-bottom:8px;font-size:14px;color:#555}.place-popup-properties strong{color:#333;display:block;margin-bottom:4px}.place-popup-properties-list{margin:0;padding-left:16px;list-style-type:none}.place-popup-property{margin-bottom:2px;font-size:13px;line-height:1.4}.place-popup-property strong{color:#333;display:inline;margin-right:4px}.place-popup-coordinates{margin-bottom:12px;font-size:13px;color:#666;font-family:Courier New,monospace}.place-popup-coordinates strong{color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.geometry-type-label{font-size:11px;color:#888;font-style:italic;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.place-popup-actions{margin-top:12px;display:flex;justify-content:center}.mark-as-visited-button{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s ease,transform .1s ease;min-width:120px}.mark-as-visited-button:hover{background-color:#45a049;transform:translateY(-1px)}.mark-as-visited-button:active{transform:translateY(0)}.mark-as-visited-button:focus{outline:2px solid #4caf50;outline-offset:2px}.visited-indicator{display:flex;align-items:center;justify-content:center;padding:8px 16px;background-color:#e8f5e8;color:#2e7d32;border-radius:6px;font-size:14px;font-weight:500;min-width:120px}.visited-indicator.clickable{cursor:pointer;transition:background-color .2s ease,color .2s ease,transform .1s ease}.visited-indicator.clickable:hover{background-color:#ffebee;color:#c62828;transform:translateY(-1px)}.visited-indicator.clickable:active{transform:translateY(0)}.visited-checkmark{margin-right:6px;font-size:16px;font-weight:700}@media (max-width: 480px){.place-popup{max-width:250px;padding:10px}.place-popup-name{font-size:15px}.mark-as-visited-button,.visited-indicator{min-width:100px;font-size:13px;padding:6px 12px}}.place-popup{animation:popupFadeIn .2s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.view-switcher{display:flex;background:#ffffff1a;border-radius:8px;padding:4px;gap:2px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.view-switcher-button{padding:8px 16px;border:none;border-radius:6px;background:transparent;color:#ecf0f1;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px}.view-switcher-button:hover:not(:disabled){background:#ffffff1a}.view-switcher-button.active{background:#fff3;color:#fff;font-weight:600}.view-switcher-button:disabled{opacity:.5;cursor:not-allowed}.view-switcher-button:disabled:hover{background:transparent}.place-type-selector{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.place-type-label{font-weight:600;font-size:.9rem;color:#374151}.place-type-select{padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;font-size:.9rem;color:#374151;cursor:pointer;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.place-type-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.place-type-select:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.place-type-loading{font-size:.8rem;color:#6b7280;font-style:italic}.place-type-error{font-size:.8rem;color:#dc2626;font-weight:500}.place-filters{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.place-filters-header{flex-shrink:0}.place-filters-title{font-weight:600;font-size:.9rem;color:#374151}.place-filters-grid{display:flex;gap:1rem;flex-wrap:wrap}.place-filter{display:flex;align-items:center;gap:.5rem;white-space:nowrap}.place-filter-label{font-weight:500;font-size:.8rem;color:#6b7280;text-transform:capitalize}.place-filter-select{padding:.375rem;border:1px solid #d1d5db;border-radius:.25rem;background-color:#fff;font-size:.8rem;color:#374151;cursor:pointer;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.place-filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.place-filter-select:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}@media (max-width: 768px){.place-filters{flex-direction:column;align-items:flex-start;gap:.75rem}.place-filters-grid{flex-direction:column;gap:.75rem;width:100%}.place-filter{flex-direction:column;align-items:flex-start;gap:.25rem}}.place-controls{display:flex;flex-direction:row;align-items:flex-start;gap:.5rem;padding:.5rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:.25rem;flex-wrap:wrap}.place-controls-main-row{display:flex;flex-direction:row;align-items:center;gap:1rem;flex:1;min-width:0}.place-controls-messages{width:100%;order:10}.place-controls-loading{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#6b7280;font-style:italic}.place-controls-error{padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;color:#dc2626;font-size:.9rem;font-weight:500}.show-places-button{padding:.75rem 1.5rem;background-color:#3b82f6;color:#fff;border:none;border-radius:.375rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s ease-in-out,transform .1s ease-in-out}.show-places-button:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px)}.show-places-button:active:not(:disabled){transform:translateY(0)}.show-places-button:disabled{background-color:#9ca3af;cursor:not-allowed;transform:none}.show-places-button:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}@media (max-width: 768px){.place-controls{padding:.75rem;gap:.75rem}}.visited-places-list{margin-bottom:0}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:16px}.place-types-list{display:flex;flex-direction:column;gap:12px}.place-type-section{background-color:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;overflow:hidden}.place-type-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background-color:transparent;border:none;cursor:pointer;transition:background-color .2s}.place-type-header:hover{background-color:#333}.place-type-header-left{display:flex;align-items:center;gap:12px}.place-type-name-text{font-size:16px;font-weight:600;color:#e0e0e0}.place-image-placeholder{width:100%;height:180px;background:linear-gradient(135deg,#3a3a3a,#2a2a2a);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:background .2s}.place-image-placeholder.loading{cursor:wait}.image-text{color:#9ca3af;font-size:14px;font-weight:500}.place-image{width:100%;height:180px;object-fit:cover;transition:opacity .2s}.place-card-info{padding:12px 16px}.place-card-name{margin:0;font-size:16px;font-weight:600;color:#e0e0e0;line-height:1.3;flex:1}.remove-visit-button{background:none;border:none;color:#9ca3af;font-size:18px;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s ease,transform .1s ease;flex-shrink:0}.remove-visit-button:hover{color:#ef4444;transform:scale(1.1)}.remove-visit-button:active{transform:scale(1)}.place-card-coordinates{font-size:13px;color:#9ca3af;font-family:Courier New,monospace}.visit-timeline-container{background-color:#1a1a1a;border-radius:8px;padding:1rem}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.timeline-title{font-size:1.1rem;font-weight:600;color:#e0e0e0;margin:0}.timeline-date-range{font-size:.875rem;color:#9ca3af}.timeline-total-days{margin-left:.5rem;color:#6b7280}.timeline-wrapper{position:relative;width:100%;height:60px;overflow:hidden;background-color:#2a2a2a;border-radius:4px;margin-bottom:.75rem}.timeline-track{position:relative;height:100%;width:100%}.timeline-period{position:absolute;height:100%;border-right:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:opacity .2s;cursor:pointer}.timeline-period:hover{opacity:.8}.period-label{font-size:.7rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 .5rem}.mini-timeline-container{margin-bottom:1rem}.mini-timeline-wrapper{position:relative;width:100%;height:30px;background-color:#2a2a2a;border-radius:4px;overflow:hidden}.mini-timeline-track{position:relative;height:100%;width:100%}.mini-timeline-period{position:absolute;height:100%;border-right:1px solid rgba(255,255,255,.1)}.zoom-window{position:absolute;top:0;height:100%;background-color:#60a5fa33;border:2px solid #60a5fa;border-radius:4px;cursor:move;display:flex}.zoom-window-handle{position:absolute;top:0;width:8px;height:100%;background-color:#60a5fa;cursor:ew-resize;z-index:2}.zoom-window-handle:hover{background-color:#3b82f6}.zoom-window-handle-start{left:0;border-radius:4px 0 0 4px}.zoom-window-handle-end{right:0;border-radius:0 4px 4px 0}.zoom-window-middle{flex:1;cursor:move}.zoom-window-middle:hover{background-color:#60a5fa4d}.timeline-legend{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding-top:.75rem;border-top:1px solid #3a3a3a}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:1rem;height:1rem;border-radius:2px;border:1px solid rgba(255,255,255,.2)}.legend-label{font-size:.875rem;color:#e0e0e0}.timeline-empty{text-align:center;padding:2rem;color:#6b7280;font-style:italic}@media (max-width: 768px){.timeline-header{flex-direction:column;align-items:stretch}.timeline-controls{justify-content:center}.timeline-wrapper{height:60px}}.region-visits-list{margin-top:1rem;padding:1.5rem;background-color:#2c3e50f2;border-radius:8px;box-shadow:0 4px 12px #00000026}.region-visits-list h3{margin:0 0 1rem;color:#ecf0f1;font-size:1.2rem;font-weight:600}@media (max-width: 768px){.region-visits-list{padding:1rem}}.date-inputs,.date-display{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end}.date-text{color:#ecf0f1;font-size:.85rem;white-space:nowrap}@media (max-width: 768px){.visit-header{flex-direction:column;align-items:flex-start;gap:.5rem}.visit-info{width:100%}.visit-actions{width:100%;justify-content:space-between}.date-inputs{flex-direction:column;gap:.25rem;justify-content:flex-start}.date-input{width:100%}.children-counter{font-size:.65rem;padding:.2rem .4rem}}@media (max-width: 480px){.visit-children{padding-left:.5rem;margin-left:1rem}.visit-children .visit-children{margin-left:.5rem}.expand-icon{font-size:.9rem;width:18px;height:18px}}.pie-chart-container{background:transparent;border-radius:.5rem;padding:1rem;margin-bottom:1rem;max-width:100%;display:flex;flex-direction:column;align-items:center}.pie-chart-title{font-size:1.125rem;font-weight:600;color:#f9fafb;margin:0 0 .5rem;text-align:center}.pie-chart-total{font-size:.875rem;font-weight:500;color:#e5e7eb;margin:.5rem 0 0;text-align:center}.pie-chart-wrapper{position:relative;height:250px;width:100%;max-width:100%}.pie-chart-empty{height:300px;display:flex;align-items:center;justify-content:center;color:#d1d5db;font-size:.875rem}.pie-chart-empty p{margin:0}@media (max-width: 768px){.pie-chart-wrapper{height:250px}.pie-chart-container{padding:1rem}.pie-chart-title{font-size:1rem}}.profile-page{max-width:100%;padding:0 1rem}.profile-page-header{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.profile-username-with-flag{display:flex;align-items:center;gap:.75rem}.profile-home-flag{width:36px;height:24px;object-fit:cover;border-radius:2px;flex-shrink:0}.profile-edit-btn{background-color:#374151;color:#d1d5db;border:1px solid #4b5563;padding:.4rem 1rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s,color .2s}.profile-edit-btn:hover{background-color:#4b5563;color:#e5e7eb}.profile-page h1{font-size:2rem;font-weight:700;color:#e5e7eb;margin:0;text-align:center}.profile-page h2{font-size:1.5rem;font-weight:600;color:#e5e7eb;margin-bottom:1.5rem;text-align:center}.other-profile-notice{background-color:#374151;border:1px solid #4b5563;border-radius:8px;padding:1rem;margin-bottom:2rem;text-align:center}.other-profile-notice p{color:#9ca3af;margin:0;font-size:.95rem}.loading-message,.error-message{text-align:center;padding:2rem;color:#666;font-size:1.1rem}.profile-map-section{margin-bottom:3rem;padding:0 1rem}.profile-map-container{width:100%;height:500px;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0000004d;margin:0 auto;max-width:1400px}.profile-tabs-container{margin-top:2rem;padding:0 1rem}.profile-tabs-nav{display:flex;gap:0;border-bottom:2px solid #374151;justify-content:center}.profile-tab-btn{background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;padding:.75rem 1.5rem;color:#9ca3af;font-size:.95rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s;font-family:inherit;white-space:nowrap}.profile-tab-btn:hover{color:#e5e7eb}.profile-tab-btn.active{color:#3b82f6;border-bottom-color:#3b82f6}.profile-tab-content{padding-top:1.5rem}.profile-stats-section{margin-top:0}.charts-section{margin-top:3rem;width:100%;padding:0 1rem}.charts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;justify-content:center;justify-items:center;max-width:1200px;margin:0 auto}.no-charts-message{text-align:center;color:#e5e7eb;font-size:1.125rem;margin:3rem 0;padding:2rem;background-color:#374151;border-radius:8px;border:1px solid #4b5563}.bar-chart-header-with-buttons{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:2rem}.bar-chart-header-with-buttons h3{margin:0;font-size:1.25rem;color:#e5e7eb}.level-toggle-buttons{display:flex;gap:.5rem}.level-button{padding:.5rem 1rem;background-color:#374151;color:#e5e7eb;border:1px solid #4b5563;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.level-button:hover:not(:disabled){background-color:#4b5563;border-color:#6b7280}.level-button.active{background-color:#6b7280;border-color:#9ca3af;color:#fff}.level-button:disabled{opacity:.5;cursor:not-allowed}.profile-regions-tab{width:100%}.profile-regions-list{display:flex;flex-direction:column;gap:.35rem}.profile-region-row{display:flex;align-items:center;gap:.65rem;padding:.75rem;border:1px solid #374151;border-radius:6px;transition:filter .15s;margin-bottom:.2rem}.profile-region-row:hover{filter:brightness(1.25)}.profile-region-expand{background:none;border:none;color:#9ca3af;cursor:pointer;padding:0;width:1rem;font-size:.65rem;line-height:1;transition:transform .2s,color .2s;flex-shrink:0}.profile-region-expand:hover{color:#e5e7eb}.profile-region-expand.expanded{transform:rotate(90deg)}.profile-region-expand.invisible{visibility:hidden;cursor:default;pointer-events:none}.profile-region-flag{width:24px;height:16px;object-fit:cover;border-radius:2px;flex-shrink:0}.profile-region-name{flex:1;font-size:.875rem;font-weight:500;color:#e5e7eb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-region-stat{font-size:.75rem;color:#9ca3af;flex-shrink:0;min-width:4.5rem;text-align:right}.profile-trips-tab{width:100%}.profile-trips-list{display:flex;flex-direction:column;gap:.5rem}.profile-trip-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:.9rem 1.25rem;background-color:#1f2937;border:1px solid #374151;border-radius:8px;transition:background-color .15s,border-color .15s}.profile-trip-row.clickable{cursor:pointer}.profile-trip-row.clickable:hover{background-color:#253548;border-color:#4b5563}.profile-trip-name{font-weight:600;color:#e5e7eb;font-size:.975rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-trip-dates{color:#9ca3af;font-size:.875rem;white-space:nowrap;text-align:right}.profile-trip-flags{display:flex;gap:.3rem;align-items:center;justify-content:center;flex-wrap:wrap}.profile-trip-flag{width:28px;height:19px;object-fit:cover;border-radius:2px}.profile-tab-empty{text-align:center;padding:3rem 2rem;color:#9ca3af;font-size:1rem;background-color:#1f2937;border:1px solid #374151;border-radius:8px}@media (max-width: 768px){.profile-page h1{font-size:1.5rem}.profile-page h2{font-size:1.25rem}.profile-map-container{height:400px}.bar-chart-header-with-buttons{flex-direction:column;align-items:flex-start;gap:1rem}.level-toggle-buttons{width:100%;justify-content:center}.level-button{flex:1}}.place-statistics-page{max-width:1400px;margin:0 auto;padding:2rem}.place-statistics-page h1{color:#e5e7eb;font-size:2rem;margin-bottom:2rem;text-align:center}.loading-message,.no-data-message{text-align:center;padding:3rem 2rem;color:#9ca3af;font-size:1.125rem;background-color:#374151;border-radius:8px;border:1px solid #4b5563}.no-data-message{margin-top:2rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.place-type-card{background-color:#1f2937;border:1px solid #374151;border-radius:12px;padding:1.5rem;transition:all .3s ease;box-shadow:0 1px 3px #0003;cursor:pointer}.place-type-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;border-color:#4b5563;background-color:#253548}.place-type-card .place-type-header{margin:0 -1.5rem 1.5rem;padding:0 1.5rem 1rem;border-bottom:2px solid #374151}.place-type-card .place-type-icon{font-size:1.5rem;color:#60a5fa;flex-shrink:0;transition:transform .3s ease}.place-type-card:hover .place-type-icon{transform:scale(1.15)}.place-type-card .place-type-name{color:#60a5fa;font-size:1.5rem;font-weight:600;margin:0;display:flex;align-items:center;justify-content:center;gap:.5rem}.stats-row{display:flex;justify-content:space-around;gap:1rem}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1}.stat-value{font-size:2.5rem;font-weight:700;color:#10b981;line-height:1}.stat-label{font-size:.875rem;color:#9ca3af;text-align:center;text-transform:uppercase;letter-spacing:.05em}@media (max-width: 768px){.place-statistics-page{padding:1rem}.place-statistics-page h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.place-type-card{padding:1.25rem}.place-type-name{font-size:1.25rem}.stat-value{font-size:2rem}}@media (max-width: 480px){.stats-row{flex-direction:column;gap:1.5rem}.stat-item{padding:1rem 0;border-bottom:1px solid #374151}.stat-item:last-child{border-bottom:none}}.yearly-travel-days-bar-chart{background-color:#1f2937;border-radius:12px;padding:24px;margin-bottom:24px}.yearly-travel-days-bar-chart .bar-chart-title{color:#f3f4f6;font-size:1.25rem;font-weight:600;margin-bottom:20px;text-align:center}.yearly-travel-days-bar-chart .bar-chart-container{position:relative;width:100%}.yearly-travel-days-bar-chart .bar-chart-wrapper{position:relative;height:300px;width:100%}.yearly-travel-days-bar-chart .bar-chart-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#9ca3af;font-size:1rem}@media (max-width: 768px){.yearly-travel-days-bar-chart{padding:16px;margin-bottom:16px}.yearly-travel-days-bar-chart .bar-chart-title{font-size:1.125rem;margin-bottom:16px}.yearly-travel-days-bar-chart .bar-chart-wrapper{height:250px}}@media (max-width: 480px){.yearly-travel-days-bar-chart{padding:12px}.yearly-travel-days-bar-chart .bar-chart-title{font-size:1rem;margin-bottom:12px}.yearly-travel-days-bar-chart .bar-chart-wrapper{height:220px}}.extreme-point-card{background:transparent;border-radius:.5rem;padding:1rem;margin-bottom:1rem;max-width:100%;overflow:hidden}.extreme-points-title{font-size:1.125rem;font-weight:600;color:#f9fafb;margin:0 0 1rem;text-align:center}.extreme-points-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;width:100%}.extreme-point-item{background:#374151;border:1px solid #4b5563;border-radius:.5rem;padding:1rem;transition:all .2s ease}.extreme-point-item:hover{background:#4b5563;border-color:#6b7280;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.extreme-point-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.extreme-point-coordinate-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.extreme-point-coordinate{font-size:1.125rem;font-weight:700;color:#fbbf24;font-family:Courier New,monospace;flex:1}.extreme-point-flags{margin-left:.5rem;display:flex;align-items:center;gap:.25rem}.extreme-point-flags .flag-image{width:40px;height:25px;object-fit:cover;border-radius:2px;border:1px solid #6b7280;display:block}.extreme-point-flags .country-code-fallback{width:32px;height:21px;display:flex;align-items:center;justify-content:center;background-color:#4b5563;color:#e5e7eb;font-size:10px;border-radius:2px;border:1px solid #6b7280}.extreme-point-location{font-size:.875rem;color:#d1d5db;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.extreme-points-loading,.extreme-points-error,.extreme-points-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:#d1d5db;font-size:.875rem}.extreme-points-error{color:#f87171}.extreme-points-loading p,.extreme-points-error p,.extreme-points-empty p{margin:0;text-align:center}@media (max-width: 768px){.extreme-points-grid{grid-template-columns:1fr;gap:.75rem}.extreme-point-item{padding:.75rem}.extreme-points-title{font-size:1rem}.direction-title{font-size:.75rem}.extreme-point-coordinate{font-size:1rem}.extreme-point-flags .region-flag-image,.extreme-point-flags .country-flag-image{width:28px;height:19px}.extreme-point-flags .country-code-fallback{width:28px;height:19px;font-size:9px}.extreme-point-location{font-size:.8125rem}}@media (max-width: 480px){.extreme-point-card{padding:.75rem}.extreme-points-grid{gap:.5rem}.extreme-point-item{padding:.5rem}.extreme-point-header{gap:.375rem;margin-bottom:.5rem}.direction-icon{font-size:1rem}.direction-title{font-size:.6875rem}.extreme-point-coordinate{font-size:.875rem;margin-bottom:.375rem}.extreme-point-coordinate-row{margin-bottom:.375rem}.extreme-point-flags .region-flag-image,.extreme-point-flags .country-flag-image{width:24px;height:16px}.extreme-point-flags .country-code-fallback{width:24px;height:16px;font-size:8px}.extreme-point-location{font-size:.75rem}}.country-days-bar-chart{border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.bar-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.bar-chart-title{color:#f9fafb;font-size:1.25rem;font-weight:600;text-align:center;margin:0;flex:1}.bar-chart-pagination{display:flex;align-items:center;gap:.5rem}.pagination-button{background-color:#374151;color:#f9fafb;border:1px solid #4b5563;border-radius:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;transition:background-color .2s}.pagination-button:hover:not(:disabled){background-color:#4b5563}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:#e5e7eb;font-size:.875rem;min-width:50px;text-align:center}.country-flags-row{position:relative;height:60px;display:flex;align-items:flex-start}.country-flag-item:hover .country-flag-image{opacity:.8}.country-flag-item:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#1f2937f2;color:#e5e7eb;padding:6px 10px;border-radius:4px;font-size:.875rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s ease;transition-delay:.2s;z-index:10;margin-bottom:8px;border:1px solid #4b5563;box-shadow:0 4px 6px #0000004d}.country-flag-item:hover:after{opacity:1;transition-delay:0s}.country-flag-image{width:40px;height:27px;object-fit:cover;border-radius:2px;border:1px solid #6b7280;box-shadow:0 1px 3px #0000001a}.country-total{margin-top:4px;font-size:.75rem;font-weight:600;color:#e5e7eb;text-align:center;background-color:#00000080;padding:2px 4px;border-radius:3px;min-width:20px}.country-code-fallback{width:40px;height:27px;display:flex;align-items:center;justify-content:center;background-color:#4b5563;color:#e5e7eb;font-size:10px;border-radius:2px;border:1px solid #6b7280}@media (max-width: 768px){.country-days-bar-chart{padding:1rem}.bar-chart-header{flex-direction:column;gap:.75rem}.bar-chart-title{font-size:1.125rem}.bar-chart-wrapper{height:300px}.country-flag-image{width:32px;height:21px}.country-total{font-size:.6875rem}.country-code-fallback{width:32px;height:21px;font-size:8px}}@media (max-width: 480px){.bar-chart-wrapper{height:250px}.country-flag-image{width:28px;height:19px}.country-code-fallback{width:28px;height:19px;font-size:7px}}.place-type-countries-chart{border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.bar-chart-title{color:#f9fafb;font-size:1.25rem;font-weight:600;margin-bottom:1rem;text-align:center}.bar-chart-container{position:relative}.bar-chart-wrapper{height:400px;margin-bottom:1rem}.bar-chart-empty{height:200px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-style:italic}.country-flags-row{position:relative;display:flex;align-items:flex-start;overflow:hidden}.country-flag-item{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translate(-50%)}.country-flag-image{object-fit:cover;border-radius:2px;border:1px solid #6b7280;box-shadow:0 1px 3px #0000001a}.country-total{margin-top:4px;font-weight:600;color:#e5e7eb;text-align:center;background-color:#00000080;border-radius:3px}.country-code-fallback{display:flex;align-items:center;justify-content:center;background-color:#4b5563;color:#e5e7eb;border-radius:2px;border:1px solid #6b7280}@media (max-width: 768px){.place-type-countries-chart{padding:1rem}.bar-chart-wrapper{height:300px}}@media (max-width: 480px){.bar-chart-wrapper{height:250px}}.extreme-places-card{background:transparent;border-radius:.5rem;padding:1rem;margin-bottom:1rem;max-width:100%;overflow:hidden}@media (min-width: 1400px){.extreme-places-grid{max-width:1200px;margin:0 auto}}.extreme-places-title{font-size:1.125rem;font-weight:600;color:#f9fafb;margin:0 0 1rem;text-align:center}.extreme-places-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;width:100%}.extreme-place-item{background:#374151;border:1px solid #4b5563;border-radius:.5rem;padding:1rem;transition:all .2s ease}.extreme-place-item:hover{background:#4b5563;border-color:#6b7280;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.extreme-place-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.direction-icon{font-size:1.25rem;line-height:1}.direction-title{font-size:.875rem;font-weight:600;color:#e5e7eb;text-transform:uppercase;letter-spacing:.05em}.extreme-place-coordinate-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;gap:.5rem}.extreme-place-coordinate{font-size:1.125rem;font-weight:700;color:#fbbf24;font-family:Courier New,monospace;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.extreme-place-flags{margin-left:.5rem;display:flex;align-items:center;gap:.25rem}.extreme-place-flags .flag-image{width:40px;height:25px;object-fit:cover;border-radius:2px;border:1px solid #6b7280;display:block}.extreme-place-flags .country-code-fallback{width:40px;height:25px;display:flex;align-items:center;justify-content:center;background-color:#4b5563;color:#e5e7eb;font-size:10px;border-radius:2px;border:1px solid #6b7280}.extreme-place-name{font-size:.875rem;color:#d1d5db;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;font-weight:500}.extreme-places-empty{display:flex;align-items:center;justify-content:center;min-height:150px;color:#9ca3af;font-size:.875rem;font-style:italic}@media (max-width: 1200px){.extreme-places-grid{gap:.75rem}.extreme-place-item{padding:.875rem}}@media (max-width: 768px){.extreme-places-grid{gap:.5rem}.extreme-place-item{padding:.75rem}.extreme-place-coordinate{font-size:1rem}.extreme-place-flags .flag-image,.extreme-place-flags .country-code-fallback{width:32px;height:20px}.direction-title{font-size:.75rem}.extreme-place-name{font-size:.8125rem}}@media (max-width: 600px){.extreme-places-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}}@media (max-width: 480px){.extreme-place-coordinate{font-size:.9375rem}.extreme-place-flags .flag-image,.extreme-place-flags .country-code-fallback{width:28px;height:18px}.extreme-place-item{padding:.625rem}.direction-title{font-size:.6875rem}.extreme-place-name{font-size:.75rem}}@media (max-width: 360px){.extreme-places-grid{grid-template-columns:1fr}}.place-property-pie-charts{margin-top:2rem;display:flex;flex-direction:column;align-items:center;width:100%}.charts-title{color:#fff;font-size:1.5rem;margin-bottom:1.5rem;font-weight:600;text-align:center}.pie-charts-grid{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:2rem;justify-content:center;max-width:1400px;width:100%}.pie-chart-card{background:#2a2a2a;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000004d;display:flex;flex-direction:column;align-items:center;width:450px;max-width:100%}.chart-title{color:#fff;font-size:1.1rem;margin-bottom:1.5rem;font-weight:500;text-transform:capitalize;text-align:center;width:100%;flex-shrink:0}.pie-chart-container{position:relative;width:300px;height:300px;flex-shrink:0;display:flex;align-items:center;justify-content:center}@media (max-width: 1200px){.pie-charts-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media (max-width: 768px){.pie-charts-grid{grid-template-columns:1fr;gap:1.5rem}.pie-chart-container{height:300px}}.place-properties-charts{margin-bottom:40px}.properties-charts-title{font-size:20px;font-weight:600;color:#e0e0e0;margin:0 0 30px;text-align:left}.property-chart{margin-bottom:40px;background-color:#2a2a2a;padding:24px;border-radius:8px;border:1px solid #3a3a3a}.property-chart-title{font-size:18px;font-weight:600;color:#fff;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #4a4a4a}.property-bars-container{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.property-bar-item{display:grid;grid-template-columns:280px 1fr;gap:16px;align-items:center;padding:4px 0}.place-info{display:flex;align-items:center;gap:10px;overflow:hidden}.place-rank{font-size:13px;color:#9ca3af;font-weight:600;min-width:32px;text-align:right;flex-shrink:0}.place-flag{width:28px;height:19px;object-fit:cover;border-radius:2px;flex-shrink:0;box-shadow:0 1px 3px #0000004d;border:1px solid #6b7280}.place-name{font-size:14px;color:#e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.bar-wrapper{position:relative;height:36px;background-color:#1a1a1a;border-radius:4px;overflow:hidden}.property-bar{height:100%;background:linear-gradient(90deg,#5a8c69,#6a9c79);border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:12px;min-width:60px;transition:width .3s ease}.bar-value{font-size:14px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.property-bars-container::-webkit-scrollbar{width:8px}.property-bars-container::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.property-bars-container::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}.property-bars-container::-webkit-scrollbar-thumb:hover{background:#5a5a5a}.pagination-controls{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid #4a4a4a}.pagination-button{padding:8px 16px;background-color:#4a7c59;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.pagination-button:hover:not(:disabled){background-color:#5a8c69}.pagination-button:disabled{background-color:#3a3a3a;color:#6b7280;cursor:not-allowed}.pagination-info{font-size:14px;color:#d1d5db;font-weight:500}@media (max-width: 1024px){.property-bar-item{grid-template-columns:230px 1fr}.pagination-controls{flex-wrap:wrap;gap:12px}.pagination-info{order:3;width:100%;text-align:center}}@media (max-width: 768px){.property-chart{padding:16px}.property-bar-item{grid-template-columns:160px 1fr;gap:12px}.place-flag{width:24px;height:16px}.place-name{font-size:13px}.bar-wrapper{height:32px}.bar-value{font-size:13px}}@media (max-width: 480px){.property-bar-item{grid-template-columns:1fr;gap:8px}.place-info{justify-content:space-between}.bar-wrapper{height:28px}.bar-value{font-size:12px;padding-right:8px}}.places-by-country-list{margin-bottom:40px}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.list-title{font-size:20px;font-weight:600;color:#e0e0e0;margin:0}.list-controls{display:flex;gap:12px}.control-button{padding:8px 16px;background-color:#3a3a3a;color:#e0e0e0;border:1px solid #4a4a4a;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.control-button:hover{background-color:#4a4a4a;border-color:#5a5a5a}.countries-list{display:flex;flex-direction:column;gap:12px}.country-section{background-color:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;overflow:hidden}.country-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background-color:transparent;border:none;cursor:pointer;transition:background-color .2s}.country-header:hover{background-color:#333}.country-header-left{display:flex;align-items:center;gap:12px}.expand-icon{font-size:12px;color:#9ca3af;transition:transform .2s;display:inline-block;width:16px}.expand-icon.expanded{transform:rotate(90deg)}.country-flag-small{width:32px;height:21px;object-fit:cover;border-radius:2px;border:1px solid #6b7280;box-shadow:0 1px 3px #0000004d}.country-name-text{font-size:16px;font-weight:600;color:#e0e0e0}.place-count-badge{padding:4px 12px;background-color:#4a7c59;color:#fff;border-radius:12px;font-size:14px;font-weight:600}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:16px 20px 20px;background-color:#1a1a1a}.place-card{background-color:#2a2a2a;border:1px solid #3a3a3a;border-radius:6px;overflow:hidden;transition:all .2s}.place-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d;border-color:#4a4a4a}.place-image-link{display:block;text-decoration:none}.place-image-placeholder{width:100%;height:180px;background:linear-gradient(135deg,#3a3a3a,#2a2a2a);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#9ca3af;transition:background .2s}.place-image-placeholder:hover{background:linear-gradient(135deg,#4a4a4a,#3a3a3a)}.place-image-placeholder.loading{color:#6b7280;font-size:14px}.image-icon{font-size:32px}.image-text{font-size:13px;font-weight:500}.place-image{width:100%;height:180px;object-fit:contain;background-color:#1a1a1a;transition:opacity .2s}.place-image:hover{opacity:.9}.place-card-info{padding:12px 14px}.place-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}.place-card-name{font-size:15px;font-weight:600;color:#fff;margin:0;line-height:1.3;flex:1}.remove-visit-button{flex-shrink:0;width:24px;height:24px;padding:0;background-color:#ef4444;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1}.remove-visit-button:hover{background-color:#dc2626;transform:scale(1.05)}.remove-visit-button:active{transform:scale(.95)}.place-card-coordinates{font-size:12px;color:#9ca3af;font-family:Courier New,monospace}@media (max-width: 768px){.list-header{flex-direction:column;align-items:flex-start}.list-controls{width:100%}.control-button{flex:1}.places-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding:12px 16px 16px}.country-header{padding:12px 16px}.place-image,.place-image-placeholder{height:160px}}@media (max-width: 480px){.places-grid{grid-template-columns:1fr}.place-image,.place-image-placeholder{height:200px}}.place-type-page{display:flex;height:100vh;background-color:#1a1a1a;color:#e0e0e0}.place-types-sidebar{width:280px;background-color:#2a2a2a;border-right:1px solid #3a3a3a;display:flex;flex-direction:column;overflow-y:auto}.home-button{margin:20px;padding:12px 16px;background-color:#3a3a3a;color:#e0e0e0;border:1px solid #4a4a4a;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.home-button:hover{background-color:#4a4a4a;border-color:#5a5a5a}.sidebar-title{margin:0 20px 16px;font-size:16px;font-weight:600;color:#b0b0b0;text-transform:uppercase;letter-spacing:.5px}.place-types-list{display:flex;flex-direction:column;gap:4px;padding:0 12px 20px}.place-type-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;background-color:transparent;border:none;border-radius:6px;color:#e0e0e0;cursor:pointer;transition:all .2s;text-align:left}.sidebar-type-icon{font-size:18px;color:#60a5fa;flex-shrink:0}.place-type-item.active .sidebar-type-icon{color:#fff}.place-type-item:hover{background-color:#3a3a3a}.place-type-item.active{background-color:#4a7c59;font-weight:600}.place-type-item.active:hover{background-color:#5a8c69}.type-name{font-size:14px;flex:1}.type-count{font-size:13px;font-weight:600;padding:2px 8px;background-color:#ffffff1a;border-radius:12px;min-width:28px;text-align:center}.place-type-item.active .type-count{background-color:#fff3}.place-type-content{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:30px 40px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;gap:20px}.page-title{margin:0;font-size:32px;font-weight:700;color:#fff;display:flex;align-items:center;gap:12px}.page-title-icon{font-size:36px;color:#60a5fa;flex-shrink:0}.property-filters{display:flex;flex-wrap:wrap;gap:15px;align-items:center}.property-filter{display:flex;align-items:center;gap:8px}.property-filter label{font-size:14px;font-weight:500;color:#b0b0b0;white-space:nowrap}.property-filter select{padding:6px 10px;background-color:#2a2a2a;color:#e0e0e0;border:1px solid #4a4a4a;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;min-width:120px}.property-filter select:hover{background-color:#3a3a3a;border-color:#5a5a5a}.property-filter select:focus{outline:none;border-color:#4a7c59}.section-title{margin:0 0 20px;font-size:20px;font-weight:600;color:#e0e0e0}.chart-section,.extreme-section,.properties-section,.places-list-section{margin-bottom:40px}.map-section{flex:1;display:flex;flex-direction:column;min-height:500px}.map-container{flex:1;border-radius:8px;overflow:hidden;border:1px solid #3a3a3a;background-color:#2a2a2a;min-height:500px}.places-map{width:100%;height:100%}.no-places-message{display:flex;align-items:center;justify-content:center;height:100%;font-size:16px;color:gray}.loading-message,.error-message{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:gray}.error-message{color:#d95f5f}.place-types-sidebar::-webkit-scrollbar,.country-bars-container::-webkit-scrollbar,.place-type-content::-webkit-scrollbar{width:8px}.place-types-sidebar::-webkit-scrollbar-track,.country-bars-container::-webkit-scrollbar-track,.place-type-content::-webkit-scrollbar-track{background:#1a1a1a}.place-types-sidebar::-webkit-scrollbar-thumb,.country-bars-container::-webkit-scrollbar-thumb,.place-type-content::-webkit-scrollbar-thumb{background:#4a4a4a;border-radius:4px}.place-types-sidebar::-webkit-scrollbar-thumb:hover,.country-bars-container::-webkit-scrollbar-thumb:hover,.place-type-content::-webkit-scrollbar-thumb:hover{background:#5a5a5a}@media (max-width: 1024px){.place-types-sidebar{width:240px}.place-type-content{padding:20px 30px}.country-bar-item{grid-template-columns:160px 1fr}}@media (max-width: 768px){.place-type-page{flex-direction:column}.place-types-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid #3a3a3a}.place-types-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.place-type-content{padding:20px}.page-title{font-size:24px}}.trip-card{background:#2c3e50;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:1px solid #34495e}.trip-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000040}.trip-card-header{display:flex;flex-direction:column;gap:12px}.trip-name-date-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.trip-card-delete-btn{background:none;border:none;color:#95a5a6;font-size:1.5rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s ease;flex-shrink:0}.trip-card-delete-btn:hover{color:#e74c3c}.trip-name{margin:0;font-size:1.25rem;font-weight:600;color:#ecf0f1;line-height:1.3;flex:1}.trip-flags{display:flex;gap:4px;align-items:center;justify-content:center;flex-wrap:wrap}.trip-flag{width:32px;height:21px;object-fit:cover;border-radius:2px;border:1px solid rgba(255,255,255,.1)}.trip-dates{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.trip-start-date,.trip-end-date{font-size:.875rem;color:#bdc3c7;font-weight:600;text-align:right}.trip-card-dates{display:flex;justify-content:center;align-items:center}.trip-date-range{font-size:.875rem;color:#bdc3c7;font-weight:600;text-align:center}.trip-visit-counters{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;margin-top:8px;justify-content:center}.level-group{display:flex;flex-direction:column;gap:4px;align-items:center}.level-label{font-size:.6875rem;font-weight:600;color:#95a5a6;text-transform:uppercase;letter-spacing:.5px;line-height:1}.visit-counters-row{display:flex;gap:4px;align-items:center}.level-divider{width:1px;height:40px;background-color:#4a5568;margin:0 4px;align-self:stretch}.visit-counter{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.75rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.visit-counter:hover{transform:scale(1.1);box-shadow:0 2px 8px #0000004d}@media (max-width: 768px){.trip-card{padding:16px}.trip-name{font-size:1.125rem}.trip-flags{gap:3px}.trip-flag{width:28px;height:19px}.trip-visit-counters{gap:6px}.level-group{gap:3px}.level-label{font-size:.625rem}.visit-counters-row{gap:3px}.level-divider{height:36px;margin:0 3px}.visit-counter{width:20px;height:20px;font-size:.6875rem}.trip-date-range{font-size:.8125rem}}.trips-page{padding:2rem;max-width:1200px;margin:0 auto}.trips-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.trips-header h1{margin:0;color:#2c3e50;font-size:2.5rem;font-weight:600}.add-trip-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.add-trip-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.add-trip-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.trips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #fcc}.loading-message{text-align:center;padding:2rem;color:#666;font-size:1.1rem}.empty-state{text-align:center;padding:4rem 2rem;color:#666;font-size:1.1rem;grid-column:1 / -1}.empty-state p{margin:0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.modal-header h2{margin:0;color:#2c3e50;font-size:1.5rem}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.close-btn:hover{background:#f0f0f0}.close-btn:disabled{opacity:.6;cursor:not-allowed}.trip-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#2c3e50;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.cancel-btn{background:#f8f9fa;color:#666;border:1px solid #ddd;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#e9ecef}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.create-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.create-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.create-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.trips-page{padding:1rem}.trips-header{flex-direction:column;gap:1rem;text-align:center}.trips-header h1{font-size:2rem}.trips-grid{grid-template-columns:1fr}.modal-content{width:95%;margin:1rem}.form-actions{flex-direction:column}}.trip-page{padding:1rem;min-height:100vh;height:100vh;display:flex;flex-direction:column;background-color:#1c2731}.trip-header{padding:1.5rem;background-color:#2c3e50f2;border-radius:8px;margin-bottom:1rem;box-shadow:0 4px 12px #00000026}.trip-info{display:flex;flex-direction:column;gap:.5rem;align-items:center;text-align:center}.back-btn{background:none;border:none;color:#667eea;cursor:pointer;font-size:1rem;padding:.5rem 0;transition:color .2s;align-self:flex-start}.back-btn:hover{color:#764ba2}.trip-info h1{margin:0;color:#ecf0f1;font-size:2rem;font-weight:600}.trip-dates{margin:0;color:#7f8c8d;font-size:1.1rem}.map-controls{margin-bottom:1rem;padding:1.5rem;background-color:#2c3e50f2;border-radius:8px;box-shadow:0 4px 12px #00000026}.visit-type-section{display:flex;align-items:center;justify-content:center}.map-container{position:relative;flex:1;min-height:0;height:auto;width:100%}.trip-page-overflow{padding:0 1rem 1rem;background-color:#1c2731;display:flex;flex-direction:column;gap:1rem}.loading-message{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:#ecf0f1}.error-message{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:1rem;padding:2rem;text-align:center}.error-message p{margin:0;color:#e74c3c;font-size:1.2rem}.error-message .back-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.error-message .back-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.trip-page .map-wrapper{height:100%;width:100%}.visit-type-section h3{margin:0 0 1rem;color:#ecf0f1;font-size:1.1rem;font-weight:600;text-align:center}.loading,.error{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:18px;color:#ecf0f1}.error{flex-direction:column;gap:16px}.error button{padding:8px 16px;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background .2s ease}.error button:hover{background:#c0392b}.trip-actions{padding:1rem;display:flex;justify-content:center;gap:1rem}.delete-trip-btn{background:transparent;color:#95a5a6;border:1px solid #95a5a6;padding:.5rem 1.25rem;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.delete-trip-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c}.save-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.save-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.trip-page{padding:.5rem}.trip-page-overflow{padding:0 .5rem .5rem}.trip-header{padding:1rem}.trip-info h1{font-size:1.5rem}.trip-dates{font-size:1rem}.map-controls{padding:1rem}}@media (min-width: 769px){.trip-page{padding:1.5rem 2rem}.trip-page .map-wrapper{border-radius:12px;box-shadow:0 8px 32px #0000001a;width:100%;height:100%}}@media (min-width: 1200px){.trip-page{padding:2rem 3rem}}@media (max-width: 480px){.trip-header{padding:.75rem}.trip-info h1{font-size:1.3rem}}.trip-visits-list{margin-top:1rem;padding:1.5rem;background-color:#2c3e50f2;border-radius:8px;box-shadow:0 4px 12px #00000026}.trip-visits-list h3{margin:0 0 1rem;color:#ecf0f1;font-size:1.2rem;font-weight:600}.no-visits{color:#bdc3c7;font-style:italic;margin:0;text-align:center;padding:2rem}.visits-container{display:flex;flex-direction:column;gap:.5rem}.visit-item{background-color:#34495ecc;border:1px solid #4a6a7c;border-radius:6px;padding:.75rem;transition:all .2s ease}.visit-item:hover{background-color:#34495e;border-color:#5d7b8c}.visit-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.visit-header.clickable{cursor:pointer;transition:background-color .2s ease;border-radius:6px;margin:-.25rem;padding:.25rem}.visit-header.clickable:hover{background-color:#ecf0f10d}.visit-header.clickable:hover .expand-icon{color:#ecf0f1;transform:scale(1.1)}.visit-info{display:flex;align-items:center;gap:.5rem;flex:1}.expand-icon{color:#bdc3c7;font-size:.8rem;width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease;-webkit-user-select:none;user-select:none}.visit-details{display:flex;align-items:center;gap:.75rem}.visit-flag-container{display:flex;align-items:center;justify-content:center;flex-shrink:0}.visit-flag{width:20px;height:15px;border-radius:2px;box-shadow:0 1px 3px #0000004d;object-fit:cover}.visit-name{color:#ecf0f1;font-weight:500;font-size:.9rem}.visit-type-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.children-counter{padding:.25rem .5rem;border-radius:12px;font-size:.7rem;font-weight:500;color:#bdc3c7;background-color:#34495e99;border:1px solid #4a6a7c;white-space:nowrap}.visit-actions{display:flex;align-items:center;gap:.75rem;justify-content:flex-end}.date-inputs{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end}.date-input{background-color:#2c3e50cc;border:1px solid #4a6a7c;border-radius:4px;padding:.25rem .5rem;color:#ecf0f1;font-size:.8rem;width:120px;flex-shrink:0}.date-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.date-separator{color:#bdc3c7;font-size:.8rem;flex-shrink:0}.remove-button{background:#e74c3c;border:none;color:#fff;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.remove-button:hover{background:#c0392b}.visit-children{margin-top:.5rem;margin-left:1.5rem;padding-left:1rem;border-left:2px solid #4a6a7c;position:relative;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.visit-children:before{content:"";position:absolute;left:-2px;top:-.5rem;bottom:0;width:2px;background:linear-gradient(180deg,#4a6a7c 0%,transparent 100%)}.visit-children .visit-item{background-color:#34495e99;border-color:#4a6a7cb3}.visit-children .visit-item:hover{background-color:#34495ecc;border-color:#5d7b8c}.visit-children .visit-children{margin-left:1rem}.visit-children .visit-children .visit-item{background-color:#34495e66;border-color:#4a6a7c80}.visit-children .visit-children .visit-item:hover{background-color:#34495e99}.indent-0{margin-left:0}.indent-1{margin-left:1rem}.indent-2{margin-left:2rem}.indent-3{margin-left:3rem}@media (max-width: 768px){.trip-visits-list{padding:1rem}.visit-header{flex-direction:column;align-items:flex-start;gap:.5rem}.visit-info{width:100%}.visit-actions{width:100%;justify-content:space-between}.date-inputs{flex-direction:column;gap:.25rem;justify-content:flex-start}.date-input{width:100%}.children-counter{font-size:.65rem;padding:.2rem .4rem}}@media (max-width: 480px){.visit-children{padding-left:.5rem;margin-left:1rem}.visit-children .visit-children,.indent-1,.indent-2,.indent-3{margin-left:.5rem}.expand-icon{font-size:.9rem;width:18px;height:18px}}.flag-collection{min-height:100vh;background-color:#1c2731;padding:2rem 0}.flag-collection-container{max-width:100%;margin:0 auto;padding:0 2rem}.flag-collection-header{margin-bottom:2rem}.flag-collection-title{font-size:2.5rem;font-weight:700;color:#f8f9fa;margin-bottom:.5rem}.flag-collection-subtitle{font-size:1.125rem;color:#d1d5db}.visit-type-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;font-size:.875rem}.legend-item{display:flex;align-items:center;gap:.5rem;color:#e5e7eb}.legend-color{width:1rem;height:1rem;border-radius:.25rem}.country-list{display:flex;flex-direction:column;gap:15px;width:100%}.country-card{display:flex;flex-direction:column;gap:15px}.country-header{display:flex;align-items:center;padding:15px 20px;background-color:#2a2a2a;border-radius:8px;color:#ffffffde;transition:all .2s ease;cursor:pointer}.country-header:hover{background-color:#333;transform:translateY(-2px);box-shadow:0 2px 4px #0000004d}.country-flag-container{width:60px;height:40px;margin-right:20px;border:1px solid #444;border-radius:4px;overflow:hidden;background-color:#2a2a2a}.country-flag-container img{width:100%;height:100%;object-fit:cover}.country-info{flex:1}.country-name{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.25rem;text-shadow:0 1px 2px rgba(0,0,0,.5)}.country-details{color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.5)}.expand-arrow{color:#fff;font-size:1.25rem;transition:transform .2s ease;text-shadow:0 1px 2px rgba(0,0,0,.5)}.expand-arrow.expanded{transform:rotate(90deg)}.regions-container{margin-left:2rem;margin-top:1rem}.regions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(7rem,1fr));gap:1rem;margin-bottom:1rem}.region-item{display:flex;flex-direction:column;align-items:center}.region-flag-container{width:180px;height:120px;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.region-flag-container img{width:100%;height:100%;object-fit:contain}.region-flag-container:hover{transform:scale(1.05)}.region-name{margin-top:.5rem;font-size:.875rem;text-align:center;font-weight:500;color:#e5e7eb;max-width:7rem;word-break:break-words;line-height:1.2}.empty-state{text-align:center;padding:3rem}.empty-state-text{color:#9ca3af;font-size:1.25rem}.loading-state{min-height:100vh;background-color:#1c2731;display:flex;align-items:center;justify-content:center}.loading-text{font-size:1.25rem;color:#d1d5db}.regions-list{margin-top:2rem;background-color:#374151;border-radius:.5rem;padding:1.5rem}.regions-list-title{font-size:1.125rem;font-weight:600;color:#e5e7eb;margin-bottom:1rem;margin-top:0}.regions-list-items{display:flex;flex-direction:column;gap:.75rem}.region-list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#4b5563;border-radius:.375rem;transition:background-color .2s ease}.region-list-item:hover{background-color:#6b7280}.region-name-text{color:#f9fafb;font-weight:500;flex:1}.no-flag-label{color:#9ca3af;font-size:.875rem;font-style:italic}.regions-loading{text-align:center;color:#9ca3af;font-style:italic;padding:2rem}@media (max-width: 640px){.region-list-item{flex-direction:column;align-items:flex-start;gap:.5rem}.no-flag-label{align-self:flex-end}}@media (min-width: 640px){.flag-collection-container{padding:0 2.5rem}.regions-grid{grid-template-columns:repeat(auto-fill,minmax(8rem,1fr))}.region-name{max-width:8rem}}@media (min-width: 768px){.flag-collection-container{padding:0 3rem}.regions-grid{grid-template-columns:repeat(auto-fill,minmax(9rem,1fr))}.region-name{max-width:9rem}}@media (min-width: 1024px){.flag-collection-container{padding:0 4rem}.regions-grid{grid-template-columns:repeat(auto-fill,minmax(10rem,1fr))}.region-name{max-width:10rem}}@media (min-width: 1280px){.flag-collection-container{padding:0 5rem}.regions-grid{grid-template-columns:repeat(auto-fill,minmax(11rem,1fr))}.region-name{max-width:11rem}}.regions-without-flags-link{color:#60a5fa;cursor:pointer;text-decoration:underline;transition:color .2s ease;position:relative;display:inline-block}.regions-without-flags-link:hover{color:#93c5fd}.regions-without-flags-link[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#1f2937;color:#fff;padding:.5rem;border-radius:.375rem;font-size:.875rem;font-weight:400;text-decoration:none;white-space:pre-line;min-width:200px;max-width:400px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:1000;pointer-events:none}.regions-without-flags-link[data-tooltip]:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(1px);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #1f2937;z-index:1001;pointer-events:none}.regions-by-type{display:flex;flex-direction:column;gap:1.5rem}.region-type-section{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.region-type-info{flex:1}.region-type-title-row{display:flex;align-items:center;gap:1rem}.region-type-name{font-size:1.125rem;font-weight:600;color:#f8f9fa;margin:0}.region-type-counters{font-size:.875rem;color:#9ca3af;flex-shrink:0}.region-type-header.no-expand{cursor:default}.region-type-header.no-expand:hover{background-color:#2a2a2a;transform:none;box-shadow:none}.login-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);background-color:#242424;padding:2rem}.login-card{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 4px 20px #0000001a;width:100%;max-width:420px}.login-title{font-size:1.75rem;font-weight:700;color:#2c3e50;margin:0 0 .25rem;text-align:center}.login-subtitle{font-size:.95rem;color:#7f8c8d;margin:0 0 1.75rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-form .form-group{display:flex;flex-direction:column;gap:.4rem}.login-form .form-group label{font-size:.85rem;font-weight:600;color:#34495e;text-transform:uppercase;letter-spacing:.5px}.login-form .form-group input{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;outline:none;font-family:inherit}.login-form .form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db26}.login-form .form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.login-error{background:#fdeaea;color:#c0392b;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;border:1px solid #f5c6cb}.login-submit-btn{padding:.85rem;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s ease,transform .1s ease;font-family:inherit}.login-submit-btn:hover:not(:disabled){opacity:.9}.login-submit-btn:active:not(:disabled){transform:scale(.98)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-switch{margin-top:1.5rem;text-align:center;font-size:.9rem;color:#7f8c8d}.login-switch p{margin:0}.login-switch-btn{background:none;border:none;color:#3498db;font-weight:600;cursor:pointer;font-size:.9rem;padding:0;text-decoration:underline;font-family:inherit}.login-switch-btn:hover{color:#2980b9}@media (max-width: 480px){.login-card{padding:1.5rem}.login-title{font-size:1.5rem}}.home-region-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1.5rem}.home-region-modal{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:2rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.home-region-modal-title{font-size:1.25rem;font-weight:700;color:#e5e7eb;margin:0}.home-region-modal-subtitle{font-size:.875rem;color:#9ca3af;margin:-.5rem 0 0}.home-region-form-group{display:flex;flex-direction:column;gap:.4rem}.home-region-form-group label{font-size:.875rem;font-weight:500;color:#d1d5db}.home-region-form-group input,.home-region-form-group select{padding:.65rem .9rem;background-color:#111827;border:1px solid #374151;border-radius:8px;color:#e5e7eb;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;appearance:auto}.home-region-form-group input:focus,.home-region-form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.home-region-form-group input:disabled,.home-region-form-group select:disabled{opacity:.5;cursor:not-allowed}.home-region-form-group select option{background-color:#1f2937;color:#e5e7eb}.home-region-modal-error{background-color:#450a0a;border:1px solid #7f1d1d;color:#fca5a5;padding:.75rem 1rem;border-radius:8px;font-size:.875rem}.home-region-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.25rem}.home-region-skip-btn{background:none;border:1px solid #4b5563;color:#9ca3af;padding:.6rem 1.25rem;border-radius:8px;font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .2s,color .2s}.home-region-skip-btn:hover:not(:disabled){border-color:#6b7280;color:#e5e7eb}.home-region-save-btn{background-color:#3b82f6;color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background-color .2s,opacity .2s}.home-region-save-btn:hover:not(:disabled){background-color:#2563eb}.home-region-save-btn:disabled{opacity:.5;cursor:not-allowed}.settings-page{max-width:680px;margin:2rem auto;padding:0 1rem}.settings-card{background-color:#1f2937;border:1px solid #374151;border-radius:12px;padding:2rem}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:.75rem}.settings-header h1{font-size:1.75rem;font-weight:700;color:#e5e7eb;margin:0}.settings-back-btn{background:none;border:1px solid #4b5563;color:#9ca3af;padding:.4rem .9rem;border-radius:6px;cursor:pointer;font-size:.875rem;transition:border-color .2s,color .2s}.settings-back-btn:hover{border-color:#6b7280;color:#e5e7eb}.settings-form{display:flex;flex-direction:column;gap:2rem}.settings-section{display:flex;flex-direction:column;gap:1rem}.settings-section h2{font-size:1rem;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .25rem;padding-bottom:.5rem;border-bottom:1px solid #374151}.settings-section-hint{color:#6b7280;font-size:.875rem;margin:-.5rem 0 0}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.875rem;font-weight:500;color:#d1d5db}.form-group input,.form-group select{padding:.65rem .9rem;background-color:#111827;border:1px solid #374151;border-radius:8px;color:#e5e7eb;font-size:.95rem;transition:border-color .2s,box-shadow .2s;appearance:auto}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.form-group input:disabled,.form-group select:disabled{opacity:.5;cursor:not-allowed}.form-group select option{background-color:#1f2937;color:#e5e7eb}.home-region-dropdowns{display:flex;flex-direction:column;gap:1rem}.settings-clear-region-btn{align-self:flex-start;background:none;border:1px solid #4b5563;color:#9ca3af;padding:.35rem .75rem;border-radius:6px;cursor:pointer;font-size:.8rem;transition:border-color .2s,color .2s}.settings-clear-region-btn:hover:not(:disabled){border-color:#ef4444;color:#ef4444}.settings-error{background-color:#450a0a;border:1px solid #7f1d1d;color:#fca5a5;padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.settings-success{background-color:#052e16;border:1px solid #14532d;color:#86efac;padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.settings-actions{display:flex;justify-content:flex-end}.settings-save-btn{background-color:#3b82f6;color:#fff;border:none;padding:.7rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s,opacity .2s}.settings-save-btn:hover:not(:disabled){background-color:#2563eb}.settings-save-btn:disabled{opacity:.5;cursor:not-allowed}.users-page{padding:2rem;max-width:1200px;margin:0 auto}.users-page h1{font-size:2rem;font-weight:700;color:#2c3e50;margin-bottom:1.5rem;text-align:center}.loading-message,.error-message,.no-users-message{text-align:center;padding:2rem;color:#7f8c8d;font-size:1.1rem}.error-message{color:#e74c3c;background-color:#fadbd8;border-radius:8px;padding:1rem}.users-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 10px #00000014}.users-list{list-style:none;padding:0;margin:0}.user-item{display:flex;align-items:center;padding:1rem;border-bottom:1px solid #ecf0f1;transition:background-color .2s;cursor:pointer}.user-item:last-child{border-bottom:none}.user-item:hover{background-color:#e3f2fd}.user-info{display:flex;align-items:center;gap:.75rem}.user-name{font-size:1.1rem;font-weight:500;color:#2c3e50}.user-home-flag{width:28px;height:19px;object-fit:cover;border-radius:2px;flex-shrink:0}@media (max-width: 768px){.users-page{padding:1rem}.users-page h1{font-size:1.5rem}.user-name{font-size:1rem}}#root{height:100vh;overflow:hidden}#root>div{height:100%;display:flex;flex-direction:column}main{flex:1;min-height:0;overflow:auto}.map-page{height:100%;display:flex;flex-direction:column}.map-page h1{margin:0 0 .5rem;font-size:2rem;font-weight:600}.map-container{position:relative;flex:1;min-height:0;height:auto;margin-top:0;max-width:none;width:100%}
