#mapbox-container{position:relative;height:90vh;width:100%}@media (max-width:768px){#mapbox-container{height:80vh !important}}#map{position:absolute;top:0;bottom:0;width:100%}#loading-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.1);z-index:1000}.town-label{color:#333;font-size:12px;font-weight:600;text-shadow:1px 1px 2px #fff,-1px -1px 2px #fff,1px -1px 2px #fff,-1px 1px 2px #fff;pointer-events:none;white-space:nowrap;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif}#bottom-menu{position:absolute;bottom:0;left:0;right:0;background:transparent!important;box-shadow:0 -2px 10px rgba(0,0,0,.1);max-height:120px;overflow-y:auto;z-index:10}#bottom-menu:before{content:'';position:absolute;bottom:0;left:0;right:0;height:150px;background:linear-gradient(to bottom,rgba(0,0,0,0) 5%,rgba(0,0,0,.3) 30%,rgba(0,0,0,.6) 70%,rgba(0,0,0,.9) 100%);pointer-events:none;z-index:-1}#menu-items{display:flex;flex-wrap:wrap;padding:10px;gap:10px;align-items:center;justify-content:center;position:relative;z-index:1}.menu-item{padding:8px 16px;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);cursor:pointer;font-size:17px;white-space:nowrap;color:#fff!important;border:1px solid rgba(255,255,255,.5);border-radius:inherit;font-family:'Oswald';transition:all .2s ease}.menu-item:hover{background:#007cbf;color:#fff;border-color:#007cbf;transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,123,191,.3)}.menu-item.active{background:#007cbf;color:#fff;border-color:#007cbf;box-shadow:0 2px 4px rgba(0,123,191,.3)}.menu-item.active:hover{background:#0056b3;border-color:#0056b3}.menu-separator{width:1px;height:20px;background:rgba(255,255,255,.3);margin:0 5px}.view-all-button{padding:15px 30px;background:#007cbf;color:#fff;border-radius:0;cursor:pointer;font-size:17px;border:2px solid #007cbf;font-family:'Oswald';font-weight:500;white-space:nowrap;transition:all .2s ease}.view-all-button:hover{background:#0056b3;border-color:#0056b3;box-shadow:0 4px 8px rgba(0,123,191,.3);transform:translateY(-2px)}.custom-popup{position:absolute;left:20px;top:50%;transform:translateY(-50%);background:#fff;border-radius:0;box-shadow:0 4px 20px rgba(0,0,0,.2);padding:0;width:300px;z-index:1000;display:none;max-height:80vh;overflow-y:auto;text-align:center}.custom-popup.active{display:block;animation:slideIn .3s ease-out}@keyframes slideIn{from{opacity:0;transform:translateY(-50%) translateX(-20px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}.popup-close{position:absolute;top:10px;right:10px;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(0,0,0,.7);border:2px solid #fff;color:#fff;padding:0;transition:all .2s ease}.popup-close:hover{background:#000;transform:scale(1.1);color:#fff}.popup-close svg{width:20px;height:20px}.popup-close:hover{background:#f0f0f0;color:#333}.popup-title{font-size:20px;font-weight:700;margin-bottom:15px;color:#fff;padding-right:0;position:absolute;top:155px;text-align:center;font-family:'Oswald';left:0;right:0;overflow:hidden;z-index:999}.popup-title:before{position:absolute;top:58%;overflow:hidden;width:48%;height:.8px;content:'\a0';background-color:#ffffff99;margin-left:-50%;text-align:right}.popup-title:after{position:absolute;top:58%;overflow:hidden;width:48%;height:.8px;content:'\a0';background-color:#ffffff99;margin-left:2%}.popup-image{width:100%;height:200px;background:#ddd;margin-bottom:15px;display:flex;align-items:center;justify-content:center;color:#999;border-radius:0;overflow:hidden}.popup-image img{width:100%;height:100%;object-fit:cover}.grid_column_content img{margin-bottom:0!important}.popup-description{font-size:14px;line-height:1.6;color:#666;margin-bottom:0;text-align:center;padding:10px 15px}.popup-button{display:inline-block;padding:6px;color:#007cbf;text-decoration:none;border-radius:4px;margin-bottom:15px}.popup-button:hover{background:#fff;text-decoration:none;color:#007cbf}.mapboxgl-ctrl-top-right{top:10px;right:10px}.mapboxgl-ctrl-group{background:rgba(255,255,255,.9);box-shadow:0 2px 4px rgba(0,0,0,.1)}#bottom-menu::-webkit-scrollbar{height:6px}#bottom-menu::-webkit-scrollbar-track{background:#f1f1f1}#bottom-menu::-webkit-scrollbar-thumb{background:#888;border-radius:3px}#bottom-menu::-webkit-scrollbar-thumb:hover{background:#555}div#bottom-menu{position:absolute;bottom:0;width:100%;height:80px;background:0 0;display:flex;align-items:center;padding:0 20px;box-sizing:border-box;overflow-x:auto;gap:10px;z-index:1000;justify-content:center}div#bottom-menu{position:absolute;bottom:0;width:100%;height:80px;background:rgb(255 255 255/2%);box-shadow:0 -2px 10px rgba(0,0,0,.1);display:flex;align-items:center;padding:0 20px;box-sizing:border-box;overflow-x:auto;gap:10px;z-index:1000;justify-content:center}.popup-backdrop{display:none}#mobile-menu-overlay{display:none}.mobile-view-all-btn{display:none}@media (max-width:768px){#bottom-menu{display:none !important;visibility:hidden !important}#mobile-menu-overlay{display:flex !important;flex-direction:row;flex-wrap:nowrap;position:absolute;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(10px);z-index:100;overflow-x:auto;overflow-y:hidden;padding:12px 0;padding-bottom:calc(12px + env(safe-area-inset-bottom, 0));gap:8px;align-items:center;-webkit-overflow-scrolling:touch;scrollbar-width:thin;min-height:50px;box-shadow:0 -2px 10px rgba(0,0,0,.3)}#mobile-menu-overlay:before,#mobile-menu-overlay:after{content:'';position:absolute;top:0;bottom:0;width:15px;pointer-events:none;z-index:1}#mobile-menu-overlay:before{left:0;background:linear-gradient(to right,rgba(0,0,0,.85),transparent)}#mobile-menu-overlay:after{right:0;background:linear-gradient(to left,rgba(0,0,0,.85),transparent)}#mobile-menu-overlay .menu-link{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;background:rgba(255,255,255,.1);color:#fff;font-size:14px;text-decoration:none;border:1px solid rgba(255,255,255,.3);border-radius:4px;transition:all .2s ease;white-space:nowrap;cursor:pointer;flex:0 0 auto;min-width:fit-content}#mobile-menu-overlay .menu-link:first-child{margin-left:12px}#mobile-menu-overlay .menu-link:last-child{margin-right:12px}#mobile-menu-overlay .menu-link:hover,#mobile-menu-overlay .menu-link.active{background:#007cbf;border-color:#007cbf;box-shadow:0 2px 8px rgba(0,123,191,.4)}#mobile-menu-overlay .view-all-link{display:none !important}.mobile-view-all-btn{display:block;position:absolute;top:calc(10px + env(safe-area-inset-top, 0));left:calc(10px + env(safe-area-inset-left, 0));background:#007cbf;color:#fff;padding:8px 16px;border:none;border-radius:4px;font-size:14px;font-weight:600;z-index:1001;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.2);transition:all .2s ease}.mobile-view-all-btn:hover,.mobile-view-all-btn:active{background:#0056b3;transform:scale(1.05)}#mobile-menu-overlay::-webkit-scrollbar{height:4px}#mobile-menu-overlay::-webkit-scrollbar-track{background:rgba(255,255,255,.1)}#mobile-menu-overlay::-webkit-scrollbar-thumb{background:rgba(255,255,255,.5);border-radius:2px}#mobile-menu-overlay::-webkit-scrollbar{width:3px}#mobile-menu-overlay::-webkit-scrollbar-track{background:0 0}#mobile-menu-overlay::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:3px}.popup-backdrop{display:none;position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:999;opacity:0;transition:opacity .3s ease}.popup-backdrop.active{display:block;opacity:1}.custom-popup{position:absolute;left:0;right:0;top:auto;bottom:0;transform:translateY(100%);width:100%;max-width:100%;border-radius:16px 16px 0 0;max-height:65vh;padding-top:30px;padding-bottom:env(safe-area-inset-bottom,20px);margin-bottom:50px}.custom-popup:before{content:'';position:absolute;top:12px;left:50%;transform:translateX(-50%);width:40px;height:4px;background:#ccc;border-radius:2px}@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}.custom-popup.active{transform:translateY(0);animation:slideUp .3s ease-out}.popup-close{width:44px;height:44px}.popup-title{font-size:18px;top:145px}.popup-description{font-size:14px;padding:12px 20px}.popup-button{padding:10px 20px;font-size:14px;font-weight:600}}@media (min-width:769px){#mobile-menu-overlay{display:none !important}.mobile-view-all-btn{display:none !important}}@media (max-width:480px){#mobile-menu-overlay{padding:10px 0;padding-bottom:calc(10px + env(safe-area-inset-bottom, 0));gap:6px;min-height:45px}#mobile-menu-overlay .menu-link{font-size:13px;padding:6px 12px}.mobile-view-all-btn{padding:6px 12px;font-size:13px;top:calc(8px + env(safe-area-inset-top, 0));left:calc(8px + env(safe-area-inset-left, 0))}#mobile-menu-overlay::-webkit-scrollbar{height:3px}.popup-close{position:absolute;top:10px;right:10px;width:42px;height:42px}.custom-popup{max-height:65vh;margin-bottom:45px}.popup-title{font-size:17px;padding-right:50px}.popup-description{font-size:13px;padding:10px 15px}}.popup-backdrop{display:none}@media print{#bottom-menu,.custom-popup,.mapboxgl-ctrl-group{display:none !important}}