:root{--bg: #0f1720;--panel: rgba(18, 27, 38, .88);--panel-soft: rgba(24, 35, 49, .82);--border: rgba(255,255,255,.1);--text: #ecf1f7;--muted: #a8b4c2;--accent: #c6a464;--shadow: 0 18px 42px rgba(0,0,0,.28);--tap-min: 44px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px}*{box-sizing:border-box}html,body{margin:0;height:100%;background:linear-gradient(180deg,#0f1720,#111927);color:var(--text);font-family:Inter,Noto Sans SC,PingFang SC,sans-serif}body{display:flex;flex-direction:column}#root{display:flex;flex-direction:column;flex:1;min-height:0}.header{position:relative;z-index:100;padding:16px 14px 12px;border-bottom:1px solid var(--border);background:#090f18e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.title{font-size:20px;font-weight:700;letter-spacing:.02em;margin:0 0 6px}.subtitle{margin:0;color:var(--muted);font-size:13px}.map-shell{position:relative;z-index:1;flex:1}#map{width:100%;height:100%}.floating-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text)}.header--compact{padding:10px 14px 8px}.header--compact .title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:0}.control-block{padding:14px 16px;min-width:220px}.control-title{font-size:13px;font-weight:700;margin-bottom:10px;color:#f7f9fb;letter-spacing:.02em}.control-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.control-title-row .control-title{margin-bottom:0}.toggle-all-btn{font-size:11px;padding:2px 8px;border-radius:4px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s ease}.toggle-all-btn:hover{border-color:var(--accent);color:var(--accent)}.toggle-all-btn--active{background:#3898ff1f;border-color:#3898ff;color:#3898ff}.filter-section-divider-row{display:flex;align-items:center;gap:8px;margin:8px 0}.filter-section-divider-row .filter-section-divider{flex:1;margin:0}.toggle-all-pill{font-size:11px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;white-space:nowrap;transition:all .15s ease}.toggle-all-pill:hover{border-color:var(--accent);color:var(--accent)}.toggle-all-pill--active{background:#3898ff1f;border-color:#3898ff;color:#3898ff}.filter-list{display:grid;gap:8px;max-height:320px;overflow:auto;padding-right:6px}.filter-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);min-height:var(--tap-min);cursor:pointer}.filter-item input{accent-color:var(--accent);width:18px;height:18px;cursor:pointer}.swatch{width:12px;height:12px;border-radius:999px;flex:none;border:1px solid rgba(255,255,255,.3)}.top-search{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:1000;width:calc(100vw - 20px)}.search-wrap{display:flex;gap:8px;padding:10px}.search-wrap input{flex:1;border:0;outline:0;background:#ffffff0f;color:var(--text);border-radius:var(--radius-md);padding:12px 14px;font-size:14px;min-height:var(--tap-min)}.search-wrap button,.mode-btn{border:0;cursor:pointer;border-radius:var(--radius-md);padding:12px 14px;font-size:13px;font-weight:600;color:#14181f;background:linear-gradient(135deg,#d7bb82,#f0d7a3);min-height:var(--tap-min)}.mode-btn{width:100%;margin-top:12px}.stats-panel{padding:14px 16px;min-width:220px}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.stat-item{background:var(--panel-soft);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px}.stat-label{font-size:12px;color:var(--muted);margin-bottom:4px}.stat-value{font-size:20px;font-weight:700}.legend-card{position:absolute;left:10px;bottom:10px;z-index:1000;width:calc(100vw - 20px)}.legend-wrap{display:flex;flex-wrap:wrap;gap:12px 16px;padding:12px 16px;align-items:center}.legend-item{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-size:12px}.coverage-note{padding:0 16px 14px;color:var(--muted);font-size:12px}.legend-version{float:right;opacity:.5;font-size:11px}.search-dropdown{list-style:none;margin:0;padding:4px 0;max-height:260px;overflow-y:auto;border-top:1px solid var(--border)}.search-dropdown-item{display:flex;flex-direction:column;gap:2px;padding:10px 14px;cursor:pointer;min-height:var(--tap-min);justify-content:center;transition:background .12s}.search-dropdown-item:hover,.search-dropdown-item.highlighted{background:#c6a4641f}.search-item-name{font-size:14px;color:var(--text);font-weight:500}.search-item-en{font-size:12px;color:var(--muted)}.filter-pills{display:flex;flex-wrap:wrap;gap:10px;padding:4px 0}.filter-pill{display:inline-flex;align-items:center;gap:8px;min-height:var(--tap-min);padding:8px 16px;border-radius:999px;border:1.5px solid var(--border);background:#ffffff0a;color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .18s ease;-webkit-tap-highlight-color:transparent}.filter-pill:active{transform:scale(.95)}.filter-pill--active{background:color-mix(in srgb,var(--pill-color) 18%,transparent);border-color:var(--pill-color);color:var(--text);box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-color) 25%,transparent)}.filter-pill-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;opacity:.5;transition:opacity .18s}.filter-pill--active .filter-pill-dot{opacity:1}.filter-pill-label{white-space:nowrap}.filter-section-divider{height:1px;background:var(--border);margin:12px 0}.venue-filter-segment{display:flex;gap:0;border-radius:8px;overflow:hidden;border:1px solid var(--border);margin-bottom:12px}.venue-segment-btn{flex:1;padding:8px 4px;font-size:12px;font-weight:500;background:transparent;border:none;color:var(--muted);cursor:pointer;transition:all .18s ease;white-space:nowrap}.venue-segment-btn:not(:last-child){border-right:1px solid var(--border)}.venue-segment-btn--active{background:var(--accent, #4386D6);color:#fff}.venue-segment-btn:active{transform:scale(.96)}.legend-card--compact{position:static;width:100%;display:flex;flex-direction:column;gap:8px;padding:8px 0}.legend-scroll{display:flex;gap:10px;overflow-x:auto;overflow-y:hidden;padding:8px 16px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}.legend-scroll::-webkit-scrollbar{display:none}.legend-chip{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;scroll-snap-align:start;padding:6px 12px;border-radius:999px;background:#ffffff0f;border:1px solid var(--border)}.legend-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.legend-chip-text{font-size:12px;color:var(--text);white-space:nowrap}.legend-info-btn{align-self:flex-end;width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--panel-soft);color:var(--muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:0 16px;transition:background .15s}.legend-info-btn:active{background:#ffffff14}.legend-compact-note{padding:4px 16px 8px;font-size:12px;color:var(--muted);animation:fade-in .2s ease-out}.marker-dot{width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.92);box-shadow:0 8px 18px #00000052;position:relative}.marker-dot.new:after{content:"NEW";position:absolute;left:50%;top:-13px;transform:translate(-50%);font-size:8px;font-weight:700;background:linear-gradient(135deg,#c89e39,#f5de9c);color:#3b2d00;padding:1px 4px;border-radius:999px;border:1px solid rgba(255,255,255,.55)}.marker-dot.new{border-color:#f5d77d;box-shadow:0 0 0 3px #e8c2512e,0 8px 18px #00000052}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#101821;color:var(--text)}.popup{min-width:250px}.popup h3{margin:0 0 6px;font-size:16px}.popup .en{color:var(--muted);font-size:12px;margin-bottom:8px}.popup .tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.popup .tag{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:4px 8px;font-size:11px;background:#ffffff14;color:var(--text)}.popup .line{margin:6px 0;font-size:12px;line-height:1.55}.popup a{color:#9fcbff;text-decoration:none}.leaflet-control-container .leaflet-top.leaflet-left,.leaflet-control-container .leaflet-top.leaflet-right{margin-top:112px}.cluster-badge{background:#1b2636eb;color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:999px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 12px 24px #00000038}.user-loc-icon{background:none!important;border:none!important}.user-loc-wrapper{position:relative;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.user-loc-pulse{position:absolute;width:32px;height:32px;border-radius:50%;background:#3898ff2e;animation:loc-pulse 2s cubic-bezier(.4,0,.2,1) infinite;will-change:transform,opacity}.user-loc-dot{position:relative;width:14px;height:14px;border-radius:50%;background:#3898ff;border:2.5px solid #fff;box-shadow:0 2px 8px #3898ff73,0 0 0 1px #3898ff1f;z-index:2}.user-loc-cone{position:absolute;top:0;left:50%;width:0;height:0;margin-left:-10px;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:22px solid rgba(56,152,255,.35);transform-origin:center 24px;will-change:transform;z-index:1;filter:blur(.5px)}.user-loc-accuracy{fill:#3898ff14;stroke:#3898ff40;stroke-width:1.5}@keyframes loc-pulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(2.2);opacity:0}to{transform:scale(2.2);opacity:0}}.loc-btn-container{border:none!important;background:none!important;box-shadow:none!important}.loc-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px #00000047;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.loc-btn:active{transform:scale(.9)}.loc-btn:hover{background:var(--panel-soft)}.loc-btn--locating{color:#3898ff;border-color:#3898ff80;animation:loc-btn-pulse 1.5s ease-in-out infinite}.loc-btn--tracking{color:#3898ff;background:#3898ff1f;border-color:#3898ff;box-shadow:0 0 0 3px #3898ff26,0 4px 16px #00000047}.loc-btn-spin{animation:loc-spin 1.2s linear infinite}@keyframes loc-btn-pulse{0%,to{box-shadow:0 0 #3898ff4d,0 4px 16px #00000047}50%{box-shadow:0 0 0 6px #3898ff00,0 4px 16px #00000047}}@keyframes loc-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loc-error-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);z-index:10000;background:#1e1e1ee0;color:#fff;font-size:13px;font-weight:500;padding:8px 16px;border-radius:20px;pointer-events:none;white-space:nowrap;animation:loc-toast-in .2s ease-out}@keyframes loc-toast-in{0%{opacity:0;transform:translate(-50%) translateY(6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mobile-shell .leaflet-bottom.leaflet-right{margin-bottom:190px}.mobile-shell{display:flex;flex-direction:column;height:100dvh;height:100vh;position:relative;overflow:hidden;overscroll-behavior:none;touch-action:manipulation}.mobile-search-area{position:relative;z-index:1000;padding:0 10px}.mobile-search-area .top-search{position:relative;top:auto;left:auto;transform:none;width:100%;margin-top:8px}.mobile-map-container{flex:1;position:relative;min-height:0;contain:strict}.mobile-map-container #map{width:100%;height:100%}.mobile-fab-group{position:fixed;right:12px;bottom:24px;z-index:1100;display:flex;flex-direction:column;gap:10px}.mobile-fab-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px #0000004d;transition:transform .15s,background .15s}.mobile-fab-btn:active{transform:scale(.92)}.mobile-fab-btn.active{background:#c6a4642e;border-color:var(--accent)}.fab-icon{font-size:18px;line-height:1}.bottom-sheet-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;pointer-events:none}.bottom-sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;pointer-events:auto;animation:fade-in .2s ease-out}.bottom-sheet{position:absolute;bottom:0;left:0;right:0;height:85dvh;height:85vh;background:var(--panel);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--border);border-bottom:none;box-shadow:0 -12px 48px #00000059;pointer-events:auto;display:flex;flex-direction:column;will-change:transform;contain:layout}.bottom-sheet-handle{padding:12px 16px 8px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;flex-shrink:0}.bottom-sheet-handle:active{cursor:grabbing}.bottom-sheet-handle-bar{width:36px;height:4px;border-radius:2px;background:#ffffff40;margin:0 auto 8px}.bottom-sheet-title{font-size:15px;font-weight:600;color:var(--text);text-align:center}.bottom-sheet-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 4px 16px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.bottom-sheet-content .floating-card{border:none;box-shadow:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0}.bottom-sheet-content .legend-card{position:static;width:100%}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.mobile-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2500;display:flex;align-items:flex-end}.mobile-popup-card{position:relative;width:100%;max-height:70dvh;max-height:70vh;background:var(--panel);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--border);border-bottom:none;box-shadow:0 -12px 48px #0006;padding:20px 18px calc(20px + env(safe-area-inset-bottom,0px));overflow-y:auto;overscroll-behavior:contain;animation:slide-up .3s cubic-bezier(.32,.72,0,1)}.mobile-popup-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--panel-soft);color:var(--muted);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.mobile-popup-close:active{background:#ffffff14}.mobile-popup-name{margin:0 0 4px;font-size:20px;font-weight:700;color:var(--text);padding-right:44px}.mobile-popup-en{margin:0 0 12px;font-size:13px;color:var(--muted)}.mobile-popup-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.mobile-popup-tag{display:inline-flex;align-items:center;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:500;background:#ffffff14;color:var(--text)}.mobile-popup-tag--new{background:linear-gradient(135deg,#c89e39,#f5de9c);color:#3b2d00;font-weight:700}.mobile-popup-details{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.mobile-popup-row{display:flex;gap:10px;font-size:14px;line-height:1.5}.mobile-popup-row--note{padding-top:4px}.mobile-popup-label{flex-shrink:0;width:56px;color:var(--muted);font-size:13px;font-weight:500}.mobile-popup-value{color:var(--text);flex:1;word-break:break-word}.mobile-popup-link{display:inline-flex;align-items:center;gap:4px;color:#9fcbff;font-size:14px;font-weight:500;text-decoration:none;padding:8px 0}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-shell{padding-top:env(safe-area-inset-top,0px)}.mobile-fab-group{bottom:calc(24px + env(safe-area-inset-bottom,0px));right:calc(12px + env(safe-area-inset-right,0px))}.bottom-sheet{padding-bottom:env(safe-area-inset-bottom,0px)}@media(min-width:768px){.header{padding:18px 20px 14px}.title{font-size:22px}}@media(min-width:1024px){.header{padding:18px 24px 14px}.title{font-size:24px}.top-search{top:18px;width:min(460px,calc(100vw - 32px))}.control-block{min-width:260px}.stats-panel{min-width:240px}.legend-card{width:calc(100vw - 390px);left:290px;bottom:18px}.leaflet-control-container .leaflet-top.leaflet-left,.leaflet-control-container .leaflet-top.leaflet-right{margin-top:88px}.filter-item{min-height:0}.filter-item input{width:initial;height:initial}.search-wrap input,.search-wrap button,.mode-btn{min-height:0}}.dynamic-title{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px;margin:0;font-size:20px;font-weight:700;letter-spacing:.02em;line-height:1.3}.dynamic-title--compact{font-size:14px;gap:4px;white-space:nowrap;overflow:hidden}.dynamic-title-sep{color:var(--muted);margin:0 2px}.dynamic-title-suffix{white-space:nowrap}.dynamic-title-version{font-size:11px;color:var(--muted);margin-left:8px;font-weight:400}.seg-picker{position:relative;display:inline-flex}.seg-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;border:1.5px solid var(--border);background:#ffffff0a;color:var(--muted);font-size:inherit;font-weight:600;font-family:inherit;cursor:default;transition:all .18s ease;-webkit-tap-highlight-color:transparent;white-space:nowrap}.seg-chip--interactive{cursor:pointer;color:var(--text)}.seg-chip--interactive:hover{background:#ffffff14;border-color:#ffffff2e}.seg-chip--interactive:active{transform:scale(.97)}.seg-chip--active{background:#c6a4641f;border-color:var(--accent);color:var(--accent)}.seg-chip-label{line-height:1.2}.seg-chip-caret{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:.6;margin-left:2px;transition:transform .18s ease}.seg-chip--active .seg-chip-caret{transform:rotate(180deg)}.seg-chip--mobile{padding:3px 8px;font-weight:600}.seg-dropdown{position:fixed;min-width:140px;max-width:280px;list-style:none;margin:0;padding:6px 0;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 12px 36px #00000059;z-index:9000;animation:seg-dropdown-in .18s ease-out}.seg-dropdown-item{padding:10px 16px;font-size:14px;font-weight:500;color:var(--text);cursor:pointer;transition:background .12s}.seg-dropdown-item:hover{background:#c6a4641a}.seg-dropdown-item--selected{color:var(--accent);font-weight:600}@keyframes seg-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.seg-sheet-list{list-style:none;margin:0;padding:0}.seg-sheet-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;font-size:16px;font-weight:500;color:var(--text);cursor:pointer;transition:background .12s;min-height:var(--tap-min);border-bottom:1px solid var(--border)}.seg-sheet-item:last-child{border-bottom:none}.seg-sheet-item:active{background:#ffffff0f}.seg-sheet-item--selected{color:var(--accent);font-weight:600;background:#c6a46414}.seg-sheet-item-label{flex:1}.seg-sheet-item-check{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--accent)}.error-boundary-fallback{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:24px}.error-boundary-card{background:var(--card);border-radius:16px;padding:32px;max-width:400px;text-align:center;box-shadow:0 8px 32px #0006}.error-boundary-card h2{margin:0 0 12px;font-size:22px;font-weight:600;color:#f44336}.error-boundary-detail{margin:0 0 20px;font-size:14px;color:var(--muted);font-family:monospace;word-break:break-all}.error-boundary-recovering{color:var(--accent);font-size:14px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.error-boundary-btn{background:var(--accent);color:#1a1a1a;border:none;border-radius:8px;padding:12px 24px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .15s,background .15s}.error-boundary-btn:hover{background:#d4b080;transform:translateY(-1px)}.error-boundary-btn:active{transform:translateY(0)}
