: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{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;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)}.control-block{padding:14px 16px;min-width:220px}.control-title{font-size:13px;font-weight:700;margin-bottom:10px;color:#f7f9fb;letter-spacing:.02em}.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}.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}.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)}.header--compact{padding:10px 14px 8px}.header--compact .title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:0}.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)}}.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}.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}.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:min(920px,calc(100vw - 36px));left:18px;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}}
