@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;900&family=Inter:wght@400;500;600;700&display=swap";
:root{--primary:#fdd239;--secondary:#006093;--bg:#fdfbf2;--black:#000;--hotel-color:#006093;--cafe-color:#e67e22}*{box-sizing:border-box;margin:0;padding:0}html,body,#__next{background:var(--bg);width:100%;height:100%;font-family:Noto Sans JP,Inter,sans-serif;overflow:hidden}.leaflet-container{z-index:1;width:100%;height:100vh}.custom-marker-hotel,.custom-marker-cafe{cursor:pointer;border:3px solid #000;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s;display:flex;box-shadow:3px 3px #000}.custom-marker-hotel{background:var(--hotel-color);color:#fff;width:40px;height:40px}.custom-marker-cafe{background:var(--cafe-color);color:#fff;width:40px;height:40px}.custom-marker-hotel:hover,.custom-marker-cafe:hover{transform:scale(1.1);z-index:1000!important}.custom-cluster-icon{background-color:var(--primary);color:#000;border:3px solid #000;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:16px;font-weight:800;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:4px 4px #000}.custom-cluster-icon:hover{transform:translate(2px,2px);box-shadow:2px 2px #000}.leaflet-popup-content-wrapper{border:2px solid #000!important;border-radius:12px!important;padding:0!important;box-shadow:4px 4px #000!important}.leaflet-popup-content{min-width:180px;margin:0!important}.leaflet-popup-tip{box-shadow:none!important;border:2px solid #000!important}.spot-popup-name{color:var(--secondary);cursor:pointer;text-align:center;border-radius:10px;padding:12px 16px;font-size:14px;font-weight:700;transition:background .2s}.spot-popup-name:hover{background:var(--primary);color:#000}.map-overlay{z-index:1000;pointer-events:none;position:fixed}.map-overlay>*{pointer-events:auto}.hamburger-btn{z-index:1100;position:fixed;top:16px;right:16px}.location-btn{z-index:1100;position:fixed;bottom:32px;right:16px}.filter-popup{z-index:1100;position:fixed;top:72px;right:16px}.leaflet-control-attribution{font-size:10px!important}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:var(--secondary);border-radius:4px}.detail-image{object-fit:cover;border-bottom:2px solid #000;width:100%;height:200px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-pulse{animation:1.5s ease-in-out infinite pulse}
