: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}.sheet-toggle{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:12px;overflow:auto;border-bottom:1px solid #e4e8e1;padding:12px 18px 10px}.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}.filter-title strong{font-size:13px}.filter-actions{display:flex;gap:6px}.filter-actions button{border-radius:6px;padding:3px 7px;color:#2f664f;background:#e7f2ec;font-size:12px;cursor:pointer}.check-grid{display:flex;flex-wrap:wrap;gap:7px}.filter-check{position:relative;display:inline-flex;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;max-width:138px;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:176px;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-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{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%}.sidebar{position:absolute;right:0;bottom:0;left:0;z-index:12;min-height:0;height:22dvh;overflow:hidden;border-top:1px solid #d7ddd5;border-right:0;border-radius:8px 8px 0 0;box-shadow:0 -12px 32px #17201c29;transition:height .22s ease}.sidebar.sheet-state-map{height:22dvh}.sidebar.sheet-state-middle{height:58dvh}.sidebar.sheet-state-full{height:88dvh}.sheet-toggle{display:flex;flex:0 0 auto;width:100%;min-height:36px;align-items:center;justify-content:center;border-bottom:1px solid #e4e8e1;color:#2f664f;background:#fbfcfa;font-size:13px;font-weight:700;cursor:pointer}.sheet-toggle:before{width:28px;height:4px;margin-right:8px;border-radius:999px;background:#b8c4bd;content:""}.sidebar-header{flex:0 0 auto;padding:10px 14px 9px}.eyebrow{display:none}h1{font-size:20px}.summary{margin-top:4px;font-size:12px}.sidebar.sheet-state-map .sidebar-header,.sidebar.sheet-state-map .filter-status,.sidebar.sheet-state-map .city-list{display:none}.filter-panel{display:grid;flex:0 0 auto;max-height:18dvh;gap:8px;overflow:hidden;padding:9px 12px 8px}.filter-block{display:grid;grid-template-columns:38px minmax(0,1fr);align-items:center;gap:5px}.filter-title{min-height:16px}.filter-title strong{font-size:12px}.check-grid{flex-wrap:nowrap;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.check-grid::-webkit-scrollbar{display:none}.filter-check{flex:0 0 auto}.filter-check span{max-width:106px;min-height:32px;padding:8px 9px;font-size:12px}.filter-status{flex:0 0 auto;border-top:1px solid #f0f2ee;padding:7px 14px}.city-list{flex:1;min-height:0;padding:8px 10px calc(10px + env(safe-area-inset-bottom))}.city-section{margin-bottom:10px}.city-title{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:8px;max-width:calc(100% - 20px);padding:9px 10px;font-size:12px}}@media (max-width: 420px){.sidebar,.sidebar.sheet-state-map{height:23dvh}.sidebar.sheet-state-middle{height:60dvh}.sidebar.sheet-state-full{height:89dvh}.filter-panel{max-height:15dvh}.spot-button em{min-width:46px;text-align:center}}
