*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#map{width:100vw;height:calc(100vh - 100px);position:absolute;top:100px;left:0;touch-action:pan-x pan-y}#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#fffffff2;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;transition:opacity .3s ease-in-out}#loading-overlay.hidden{opacity:0;pointer-events:none}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{margin-top:20px;font-size:16px;color:#666;font-weight:500}.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:0 8px 24px #00000026;padding:0;overflow:hidden;animation:popupFadeIn .3s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.leaflet-popup-content{margin:20px 24px;line-height:1.6;min-width:200px}.leaflet-popup-tip-container{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.leaflet-popup-content h3{margin:0 0 16px;font-size:20px;font-weight:700;color:#1a1a1a;letter-spacing:-.02em;line-height:1.3;border-bottom:2px solid #4CAF50;padding-bottom:10px}.leaflet-popup-content p{margin:0 0 16px;font-size:15px;color:#555;line-height:1.7;max-height:300px;overflow-y:auto;overflow-x:hidden;padding-right:8px}.leaflet-popup-content p::-webkit-scrollbar{width:6px}.leaflet-popup-content p::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.leaflet-popup-content p::-webkit-scrollbar-thumb{background:#4caf50;border-radius:3px}.leaflet-popup-content p::-webkit-scrollbar-thumb:hover{background:#45a049}.leaflet-popup-content button.play-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:14px 24px;margin-top:12px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;min-height:48px;box-shadow:0 2px 8px #4caf504d;position:relative;overflow:hidden}.leaflet-popup-content button.play-btn:before{content:"▶ ";margin-right:6px;font-size:14px}.leaflet-popup-content button.play-btn.paused:before{content:"⏸ "}.leaflet-popup-content button.play-btn.playing{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 2px 8px #4caf504d}50%{box-shadow:0 4px 16px #4caf5099}}.leaflet-popup-content button.play-btn.loading{background:linear-gradient(135deg,#9e9e9e,#757575);cursor:wait}.leaflet-popup-content button.play-btn.loading:before{content:"⏳ ";display:inline-block;animation:rotate 1s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.leaflet-popup-content button.play-btn:hover{background:linear-gradient(135deg,#45a049,#3d8b40);box-shadow:0 4px 12px #4caf5066;transform:translateY(-2px)}.leaflet-popup-content button.play-btn:active{background:linear-gradient(135deg,#3d8b40,#357a38);box-shadow:0 1px 4px #4caf504d;transform:translateY(0)}.leaflet-popup-content button.play-btn:disabled{background:linear-gradient(135deg,#ccc,#999);cursor:not-allowed;box-shadow:none}.custom-marker-container{background:transparent!important;border:none!important}@keyframes markerFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.marker-wrapper{display:flex;flex-direction:column;align-items:center;cursor:pointer;animation:markerFloat 3s ease-in-out infinite;transition:transform .2s ease}.marker-wrapper:hover{animation-play-state:paused;transform:translateY(-8px) scale(1.08)}.marker-label{background-color:#fffffff2;color:#333;font-size:13px;font-weight:600;padding:6px 12px;border-radius:14px;white-space:normal;box-shadow:0 2px 8px #00000026;margin-bottom:6px;border:1px solid rgba(0,0,0,.08);letter-spacing:.3px;line-height:1.5;text-align:center;max-width:180px;min-width:60px;word-break:keep-all}.marker-icon{width:72px;height:72px;filter:drop-shadow(0 3px 8px rgba(0,0,0,.25));transition:filter .2s ease}.marker-wrapper:hover .marker-icon{filter:drop-shadow(0 3px 8px rgba(0,0,0,.35))}.marker-wrapper:hover .marker-label{background-color:#fff;box-shadow:0 3px 12px #0003}.error-message{position:fixed;top:20px;left:50%;transform:translate(-50%);background-color:#f44336;color:#fff;padding:16px 24px;border-radius:8px;box-shadow:0 4px 12px #f443364d;font-size:15px;font-weight:500;z-index:10000;animation:slideDown .3s ease-out;max-width:90%;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:374px){.leaflet-popup-content-wrapper{max-width:85vw}.leaflet-popup-content{margin:16px 18px}.leaflet-popup-content h3{font-size:17px;margin-bottom:12px}.leaflet-popup-content p{font-size:13px;line-height:1.6;max-height:180px}.leaflet-popup-content button.play-btn{padding:12px 20px;font-size:14px;min-height:44px}.loading-spinner{width:40px;height:40px}.loading-text{font-size:14px}}@media(min-width:375px)and (max-width:600px){.leaflet-popup-content-wrapper{max-width:90vw}.leaflet-popup-content h3{font-size:18px}.leaflet-popup-content p{font-size:14px;max-height:200px}.leaflet-popup-content button.play-btn{padding:13px 22px;font-size:15px}}@media(min-width:601px)and (max-width:768px){.leaflet-popup-content-wrapper{max-width:420px}.leaflet-popup-content h3{font-size:20px}.leaflet-popup-content p{font-size:15px}}@media(min-width:769px)and (max-width:1024px){.leaflet-popup-content-wrapper{max-width:480px}.leaflet-popup-content h3{font-size:22px}.leaflet-popup-content p{font-size:16px}}@media(min-width:1025px){.leaflet-popup-content-wrapper{max-width:520px}.leaflet-popup-content{margin:24px 28px}.leaflet-popup-content h3{font-size:24px;margin-bottom:18px}.leaflet-popup-content p{font-size:16px;margin-bottom:18px}.leaflet-popup-content button.play-btn{font-size:17px;padding:15px 28px}}@media(orientation:landscape)and (max-height:500px){.leaflet-popup-content{margin:12px 16px}.leaflet-popup-content h3{font-size:16px;margin-bottom:8px}.leaflet-popup-content p{font-size:13px;margin-bottom:10px;line-height:1.5}.leaflet-popup-content button.play-btn{padding:10px 18px;font-size:14px;min-height:40px}}@supports (-webkit-touch-callout: none){.leaflet-popup-content{-webkit-overflow-scrolling:touch}.leaflet-popup-content button.play-btn{-webkit-tap-highlight-color:rgba(76,175,80,.3)}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.leaflet-popup-content-wrapper{box-shadow:0 8px 24px #0003}.marker-label{font-size:12px;padding:5px 10px;max-width:160px;line-height:1.4}.marker-icon{width:64px;height:64px}}@media print{#loading-overlay,.error-message{display:none!important}#map{position:relative;width:100%;height:auto}}.map-title-container{background:transparent!important;border:none!important}.map-title-overlay{font-size:32px;font-weight:700;color:#fff;text-align:center;padding:12px 24px;background:#00000080;border-radius:12px;white-space:nowrap;text-shadow:2px 2px 4px rgba(0,0,0,.8),-1px -1px 2px rgba(0,0,0,.6);pointer-events:none;position:relative;z-index:400;box-shadow:0 4px 12px #0000004d}@media(min-width:769px){.map-title-overlay{font-size:36px;padding:14px 28px}}@media(min-width:481px)and (max-width:768px){.map-title-overlay{font-size:28px;padding:10px 20px}}@media(max-width:480px){.map-title-overlay{font-size:22px;padding:8px 16px;border-radius:8px}}@media(prefers-reduced-motion:reduce){.map-title-overlay{transition:none!important}}.lang-toggle-btn{position:fixed;left:12px;bottom:12px;z-index:1000;width:48px;height:48px;padding:12px;font-size:15px;font-weight:600;color:#333;background-color:#fff;border:2px solid #4CAF50;border-radius:8px;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.lang-toggle-btn:hover{background-color:#4caf50;color:#fff;box-shadow:0 4px 12px #4caf504d;transform:translateY(-2px)}.lang-toggle-btn:active{transform:translateY(0);box-shadow:0 1px 4px #4caf504d}@media(max-width:768px){.lang-toggle-btn{width:44px;height:44px;font-size:14px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.detail-page{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fff;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;z-index:10000}.detail-header{position:sticky;top:0;left:0;width:100%;height:60px;background-color:#fff;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;padding:0 12px;z-index:100;box-shadow:0 2px 4px #0000000d}.back-btn{display:flex;align-items:center;gap:6px;min-width:80px;min-height:44px;padding:8px 16px;background-color:transparent;border:none;color:#4caf50;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;border-radius:8px}.back-btn:hover{background-color:#f5f5f5}.back-btn:active{background-color:#e0e0e0;transform:scale(.98)}.back-icon{font-size:20px;font-weight:700}.detail-header .lang-toggle-btn{position:static;margin:0}.detail-content{max-width:800px;margin:0 auto;padding:0}.detail-image-wrapper{width:100%;max-height:400px;overflow:hidden;background-color:#f5f5f5}.detail-image{width:100%;height:auto;display:block;object-fit:cover;max-height:400px}.detail-image:not([src]),.detail-image[src=""]{min-height:300px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.top-navbar{position:fixed;top:0;left:0;right:0;height:60px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a;z-index:1000}@supports not (backdrop-filter: blur(10px)){.top-navbar{background:#fffffffa}}.navbar-content{display:flex;justify-content:space-between;align-items:center;height:100%;padding:0 24px;max-width:1920px;margin:0 auto}.navbar-brand{display:flex;align-items:center;gap:12px}.navbar-logo{width:24px;height:24px}.navbar-title{font-size:18px;font-weight:500;color:#333;white-space:nowrap}.navbar-actions{display:flex;align-items:center;gap:16px}.sponsor-logo{height:44px;width:auto;padding:6px 0;object-fit:contain;transition:opacity .3s ease}.sponsor-logo:hover{opacity:.8}.notice-bar{position:fixed;top:60px;left:0;right:0;height:40px;background-color:#fff9e6;border-bottom:1px solid #E0E0E0;display:flex;align-items:center;justify-content:center;z-index:900}.notice-bar-text{font-size:14px;color:#666;line-height:1.5}@media(max-width:768px){.top-navbar{height:50px}.navbar-content{padding:0 16px}.navbar-logo{width:20px;height:20px}.navbar-title{font-size:14px}#map{top:86px;height:calc(100vh - 86px)}.sponsor-logo{height:38px;padding:5px 0}.notice-bar{top:50px;height:36px}.notice-bar-text{font-size:13px}}@media(max-width:480px){.navbar-title{font-size:12px}.navbar-brand{gap:8px}.sponsor-logo{height:34px;padding:4px 0}}.detail-title{margin:24px 20px 12px;font-size:26px;font-weight:700;color:#1a1a1a;line-height:1.3;letter-spacing:-.02em}.detail-audio{width:calc(100% - 40px);margin:16px 20px 20px;border-radius:8px;outline:none}.detail-description{margin:0 20px 24px;font-size:16px;line-height:1.8;color:#555;white-space:pre-line}.detail-description p{margin-bottom:16px}.detail-audio::-webkit-media-controls-panel{background-color:#f5f5f5}@media(max-width:767px){.detail-title{font-size:24px;margin:20px 16px 12px}.detail-description{font-size:15px;line-height:1.7;margin:0 16px 20px}.detail-audio{width:calc(100% - 32px);margin:0 16px 24px}.detail-image-wrapper,.detail-image{max-height:300px}}@media(min-width:768px){.detail-header{padding:0 24px}.detail-title{font-size:32px;margin:32px 24px 20px}.detail-description{font-size:17px;line-height:1.8;margin:0 24px 28px}.detail-audio{width:calc(100% - 48px);margin:0 24px 40px}}@media(orientation:landscape)and (max-height:500px){.detail-image-wrapper,.detail-image{max-height:40vh}.detail-title{font-size:22px;margin:16px 16px 12px}.detail-description{font-size:14px;line-height:1.6;margin:0 16px 16px}}
