:root{color:#16201c;font-family:Inter,Microsoft YaHei,PingFang SC,Helvetica Neue,Arial,sans-serif;background:#eef1ec}*{box-sizing:border-box}html,body{width:100%;height:100%;margin:0;overflow:hidden}button,input{font:inherit}button{border:0}#app{display:grid;grid-template-columns:minmax(300px,360px) 1fr;width:100%;height:100vh;overflow:hidden;background:#eef1ec}.sidebar{display:flex;flex-direction:column;min-height:0;height:100vh;overflow:hidden;border-right:1px solid #d7ddd5;background:#fbfcfa}.nav-toggle,.nav-close,.nav-overlay{display:none}.sidebar-header{padding:24px 22px 18px;border-bottom:1px solid #e4e8e1}.eyebrow{margin:0 0 8px;color:#4b6f5d;font-size:12px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;font-size:28px;line-height:1.18}.summary{margin:10px 0 0;color:#5d6862;font-size:14px}.filter-panel{display:grid;flex:0 0 auto;max-height:38vh;gap:8px;overflow:auto;border-bottom:1px solid #e4e8e1;padding:12px 18px 10px}.filter-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.filter-tab{display:grid;min-width:0;min-height:54px;align-content:center;gap:4px;border:1px solid #d6ded7;border-radius:8px;padding:7px 8px;color:#384941;background:#fff;text-align:left;cursor:pointer}.filter-tab strong,.filter-tab span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-tab strong{font-size:13px}.filter-tab span{color:#6d7b73;font-size:12px}.filter-tab.is-active{border-color:#2d8f68;background:#eef8f3}.filter-tab.is-active strong{color:#1d6c50}.filter-options{border:1px solid #e4e8e1;border-radius:8px;padding:8px;background:#fff}.filter-block{display:grid;gap:8px}.filter-title{display:flex;min-height:24px;align-items:center;justify-content:space-between;gap:8px;color:#384941;font-size:13px;cursor:pointer;list-style:none}.filter-title::-webkit-details-marker{display:none}.filter-title strong{font-size:13px}.filter-title span{flex:0 0 auto;color:#6d7b73;font-size:12px}.filter-title:after{width:7px;height:7px;transform:rotate(45deg);border-right:2px solid #7f8d85;border-bottom:2px solid #7f8d85;content:"";transition:transform .16s ease}.filter-block[open] .filter-title:after{transform:rotate(225deg)}.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:5px}.filter-check{position:relative;display:block;max-width:100%;cursor:pointer}.filter-check input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.filter-check span{display:block;width:100%;overflow:hidden;border:1px solid #d6ded7;border-radius:8px;padding:6px 9px;color:#516159;background:#fff;font-size:12px;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.filter-check input:checked+span{border-color:#2d8f68;color:#fff;background:#2d8f68}.filter-check input:focus-visible+span{box-shadow:0 0 0 3px #2d8f6829}.filter-status{margin:0;border-bottom:1px solid #e4e8e1;padding:8px 18px;color:#68756e;font-size:12px}.city-list{flex:1;min-height:0;overflow:auto;padding:14px}.city-section{margin-bottom:16px}.city-title{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:8px 4px;color:#2b3d35;background:#fbfcfa}.city-title strong{font-size:17px}.city-title span{min-width:28px;border-radius:999px;padding:2px 8px;color:#fff;background:#2d8f68;font-size:12px;text-align:center}.spot-button{display:flex;width:100%;min-height:58px;align-items:center;justify-content:space-between;gap:12px;margin:6px 0;border:1px solid #e0e5dc;border-radius:8px;padding:10px 12px;color:#1b2520;background:#fff;text-align:left;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease}.spot-button:hover{border-color:#92bda8;transform:translate(2px)}.spot-button.is-active{border-color:#1b7f5c;background:#eef8f3}.spot-button.is-missing{color:#7d817e;background:#f5f6f3;cursor:default}.spot-main{min-width:0}.spot-button strong{display:block;overflow:hidden;color:inherit;font-size:14px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.spot-button small{display:block;margin-top:4px;color:#66706a;font-size:12px}.spot-button .cluster-badge{width:fit-content;max-width:100%;border-radius:6px;padding:3px 6px;color:#236049;background:#e7f2ec}.spot-button em{flex:0 0 auto;border-radius:999px;padding:4px 8px;color:#2f664f;background:#e7f2ec;font-size:12px;font-style:normal}.spot-button.is-missing em{color:#8b6c24;background:#fff3cc}.map-area{position:relative;min-width:0;height:100vh;overflow:hidden}#map{width:100%;height:100vh}.notice{position:absolute;top:18px;left:50%;z-index:20;max-width:min(520px,calc(100% - 36px));transform:translate(-50%);border:1px solid #d8b15d;border-radius:8px;padding:12px 14px;color:#402d06;background:#fff7df;box-shadow:0 14px 40px #1f272324;font-size:14px}.map-marker{position:relative;width:24px;height:24px;cursor:pointer}.marker-dot{position:absolute;top:50%;left:50%;width:16px;height:16px;transform:translate(-50%,-50%);border:3px solid #ffffff;border-radius:50%;background:#e05b39;box-shadow:0 6px 18px #2c2c2c47}.marker-label{position:absolute;top:50%;left:26px;display:flex;max-width:220px;min-width:0;align-items:center;gap:6px;transform:translateY(-50%);border:1px solid rgba(32,47,40,.16);border-radius:8px;padding:6px 8px;color:#16201c;background:#fffffff0;box-shadow:0 8px 26px #1d27222e;font-size:13px;line-height:1.2;white-space:nowrap}.marker-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.marker-label.is-list{display:grid;min-width:110px;max-width:172px;gap:3px;padding:7px 9px;white-space:normal}.marker-label.is-list span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.marker-label b{flex:0 0 auto;border-radius:999px;padding:2px 5px;color:#fff;background:#287a5d;font-size:11px}.map-marker.is-active .marker-dot{animation:pulse 1.1s ease-out infinite;background:#2378c3}.map-marker.is-active .marker-label{border-color:#2378c3}.info-window{width:min(320px,72vw);color:#16201c}.info-window h2{margin:0 0 10px;font-size:18px}.info-window ul{display:grid;max-height:320px;gap:10px;margin:0;padding:0;overflow:auto;list-style:none}.info-window li{border-top:1px solid #e4e8e1;padding-top:9px}.info-window li:first-child{border-top:0;padding-top:0}.info-window strong{display:inline-block;margin-right:8px}.info-window span{border-radius:999px;padding:2px 6px;color:#fff;background:#287a5d;font-size:12px}.info-window p{margin:5px 0 0;color:#5d6862;font-size:13px}@keyframes pulse{0%{box-shadow:0 0 #2378c370}70%{box-shadow:0 0 0 14px #2378c300}to{box-shadow:0 0 #2378c300}}@media (max-width: 820px){html,body{height:100dvh}#app{position:relative;display:block;height:100dvh}.map-area{position:absolute;top:0;right:0;bottom:0;left:0;height:100dvh;min-height:0}#map{height:100%}.nav-toggle{position:absolute;top:calc(12px + env(safe-area-inset-top));left:12px;z-index:18;display:flex;width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:4px;border:1px solid rgba(22,32,28,.12);border-radius:8px;background:#fffffff5;box-shadow:0 10px 28px #18221e2e;cursor:pointer}.nav-toggle span{display:block;width:18px;height:2px;border-radius:999px;background:#294238}.nav-close{position:absolute;top:calc(12px + env(safe-area-inset-top));right:12px;z-index:2;display:flex;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid #d8dfd7;border-radius:8px;color:#2f443a;background:#fff;font-size:24px;line-height:1;cursor:pointer}.nav-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:24;display:block;width:100%;height:100%;opacity:0;visibility:hidden;background:#0f161347;transition:opacity .18s ease,visibility .18s ease}#app.nav-open .nav-overlay{opacity:1;visibility:visible}.sidebar{position:absolute;top:0;bottom:0;left:0;z-index:30;width:min(88vw,360px);min-height:0;height:100dvh;overflow:hidden;transform:translate(-102%);border-right:1px solid #d7ddd5;box-shadow:14px 0 34px #17201c2e;transition:transform .22s ease}#app.nav-open .sidebar{transform:translate(0)}.sidebar-header{flex:0 0 auto;padding:calc(18px + env(safe-area-inset-top)) 58px 12px 16px}.eyebrow{display:none}h1{font-size:20px}.summary{margin-top:4px;font-size:12px}.filter-panel{display:grid;flex:0 0 auto;max-height:42dvh;gap:8px;overflow:auto;padding:10px 12px}.filter-tabs{gap:5px}.filter-tab{min-height:48px;padding:7px;text-align:center}.filter-tab strong{font-size:13px}.filter-tab span{font-size:12px}.filter-options{padding:8px}.filter-block{display:block;border:1px solid #e4e8e1;border-radius:8px;padding:10px;background:#fff}.filter-block[open] .check-grid{margin-top:8px}.filter-title{min-height:26px}.filter-title strong{font-size:13px}.check-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px}.filter-check span{min-height:32px;padding:8px 9px;font-size:12px;line-height:1.2;text-align:center;white-space:normal}.filter-status{flex:0 0 auto;border-top:1px solid #f0f2ee;padding:7px 14px}.city-list{flex:1;min-height:0;overflow-x:hidden;padding:8px 10px calc(10px + env(safe-area-inset-bottom));overscroll-behavior:contain}.city-section{margin-bottom:10px}.city-title{position:static;z-index:auto;padding:6px 2px}.city-title strong{font-size:15px}.spot-button{min-height:54px;gap:8px;margin:5px 0;padding:9px 10px}.spot-button:hover{transform:none}.spot-button strong{font-size:14px}.spot-button small{font-size:11px}.spot-button em{padding:6px 8px;font-size:12px}.marker-label{left:22px;max-width:132px;padding:5px 7px;font-size:12px}.marker-label.is-list{min-width:96px;max-width:138px}.info-window{width:min(292px,82vw)}.info-window h2{font-size:16px}.notice{top:calc(64px + env(safe-area-inset-top));max-width:calc(100% - 20px);padding:9px 10px;font-size:12px}}@media (max-width: 420px){.sidebar{width:min(92vw,340px)}.filter-panel{max-height:40dvh}.spot-button em{min-width:46px;text-align:center}}
