:root{color:#243033;font-synthesis:none;text-rendering:optimizelegibility;background:#f7f3ec;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(135deg,#e2efebd1,#faf7efcc 48%,#eff5f7d1),#f7f3ec;min-width:320px;min-height:100vh;margin:0}button{font:inherit;cursor:pointer;border:0}main{width:min(1180px,100% - 32px);margin:0 auto;padding:22px 0 56px}.site-header{z-index:20;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);justify-content:space-between;align-items:center;gap:20px;padding:14px 0 18px;display:flex;position:sticky;top:0}.site-header h1,.hero h2,.section-heading h2,.drawer-header h2,.modal-body h2,.info-modal h2{letter-spacing:0;margin:0}.site-header h1{color:#1d2c30;font-size:clamp(22px,3vw,30px)}.eyebrow{color:#66847c;letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px;font-size:12px;font-weight:700}.site-header nav,.city-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.primary-button,.ghost-button,.danger-button,.city-filters button{border-radius:999px;min-height:42px;padding:0 18px;font-weight:700;transition:transform .16s,box-shadow .16s,background .16s}.primary-button{color:#fff;background:#2f6f78;box-shadow:0 10px 22px #2f6f7838}.ghost-button,.city-filters button{color:#2d4c50;background:#ffffffb8;border:1px solid #5b7c762e}.danger-button{color:#9b3c34;background:#fde8e3}.primary-button:hover,.ghost-button:hover,.danger-button:hover,.city-filters button:hover{transform:translateY(-1px)}.ghost-button span{color:#fff;background:#d88b45;border-radius:99px;place-items:center;min-width:22px;height:22px;margin-left:8px;font-size:12px;display:inline-grid}.hero{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:28px;padding:28px 0 24px;display:grid}.hero-copy h2{color:#203135;max-width:520px;font-size:clamp(36px,5vw,58px);line-height:1.05}.hero-copy p:last-child{color:#4f6467;max-width:620px;margin:16px 0 0;font-size:17px;line-height:1.75}.hero-tags{flex-wrap:wrap;gap:8px;margin-top:18px;display:flex}.hero-tags span{color:#35585d;background:#ffffffad;border:1px solid #51777924;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:800}.city-filters{justify-content:flex-end}.city-filters button.active{color:#fff;background:#29484e;box-shadow:0 10px 22px #29484e29}.map-shell{background:#ffffff94;border:1px solid #53747024;border-radius:24px;margin-top:14px;padding:16px;box-shadow:0 24px 70px #3d4b4c1f}.section-heading{justify-content:space-between;align-items:center;gap:18px;margin-bottom:14px;display:flex}.section-heading h2{font-size:26px}.map-toolbar{background:#ffffffbd;border:1px solid #43656924;border-radius:999px;align-items:center;gap:10px;padding:8px;display:flex;box-shadow:0 12px 28px #2e414414}.map-toolbar button{color:#fff;background:#2f6f78;border-radius:50%;place-items:center;width:34px;height:34px;font-size:20px;font-weight:900;display:grid}.map-toolbar input{accent-color:#2f6f78;width:130px}.map-toolbar span{color:#4e6266;min-width:44px;font-size:13px;font-weight:800}.map-viewport{background:#bfdce4;border:1px solid #4f6e6f1f;border-radius:18px;height:min(72vh,720px);min-height:560px;overflow:auto;box-shadow:inset 0 0 0 1px #ffffff61}.map-canvas{width:max(100%, calc(1280px * var(--zoom)));height:calc(1024px * var(--zoom));background:#d7e2dd;min-height:620px;position:relative;overflow:hidden}.osm-tile-layer,.osm-tile-layer img{position:absolute}.osm-tile-layer{background:#d7e2dd;inset:0;overflow:hidden}.osm-tile-layer img{object-fit:cover;filter:saturate(.86)contrast(.96)brightness(1.03);-webkit-user-select:none;user-select:none;display:block}.osm-attribution{z-index:3;color:#44565a;background:#ffffffc2;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:700;position:absolute;bottom:8px;right:10px}.city-node,.spot-node{position:absolute;transform:translate(-50%,-50%)}.city-node{z-index:2;color:#162a2e;border:1px solid color-mix(in srgb, var(--city-color) 34%, white);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#ffffffb3;border-radius:999px;align-items:center;gap:7px;padding:7px 12px;display:flex;box-shadow:0 8px 18px #2d46471f}.city-node strong{font-size:19px}.city-node span{background:var(--city-color);width:12px;height:12px;box-shadow:0 0 0 4px color-mix(in srgb, var(--city-color) 18%, transparent);border-radius:50%}.city-node.muted{opacity:.28}.spot-node{z-index:4;color:#27373a;border:1px solid color-mix(in srgb, var(--spot-color) 26%, white);background:#ffffffe6;border-radius:999px;align-items:center;gap:7px;min-width:30px;min-height:30px;padding:6px;transition:transform .16s,box-shadow .16s,background .16s;display:flex;box-shadow:0 8px 20px #344a4c24}.spot-node:hover,.spot-node.selected{transform:translate(-50%,-50%)scale(1.04);box-shadow:0 12px 26px #344a4c33}.spot-node.selected{background:color-mix(in srgb, var(--spot-color) 16%, white);border-color:var(--spot-color)}.dot{background:var(--spot-color);width:16px;height:16px;box-shadow:0 0 0 4px color-mix(in srgb, var(--spot-color) 20%, transparent);border-radius:50%;flex:none}.spot-label{text-overflow:ellipsis;white-space:nowrap;max-width:132px;font-size:12px;font-weight:700;display:none;overflow:hidden}.quick-toggle{color:#fff;background:var(--spot-color);border-radius:50%;flex:none;place-items:center;width:23px;height:23px;font-weight:800;display:none}.spot-node.zoomed .spot-label,.spot-node.zoomed .quick-toggle,.spot-node:hover .spot-label,.spot-node:hover .quick-toggle,.spot-node.selected .spot-label,.spot-node.selected .quick-toggle{display:grid}.spot-node:hover,.spot-node.zoomed,.spot-node.selected{padding-right:7px}.map-hint{color:#64777a;margin:12px 4px 0;font-size:13px;line-height:1.6}.overlay,.drawer-backdrop{z-index:40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a262a57;display:grid;position:fixed;inset:0}.spot-modal,.info-modal{background:#fffdfa;border-radius:24px;width:min(760px,100% - 32px);max-height:min(86vh,860px);margin:auto;position:relative;overflow:auto;box-shadow:0 28px 80px #16232647}.spot-image{justify-content:flex-start;align-items:end;min-height:230px;padding:22px;display:flex}.spot-image span{color:#fff;background:#141e2261;border-radius:999px;padding:8px 14px;font-weight:800}.modal-body,.info-modal{padding:24px}.modal-title-row,.drawer-header,.route-summary{justify-content:space-between;align-items:start;gap:18px;display:flex}.modal-title-row h2,.drawer-header h2,.info-modal h2{font-size:30px}.pill{border-radius:999px;flex:none;padding:8px 12px;font-size:13px;font-weight:800}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:22px 0;display:grid}.detail-grid div{background:#f6f4ee;border-radius:16px;padding:14px}dt{color:#738083;font-size:12px;font-weight:800}dd{color:#2f3d40;margin:7px 0 0;line-height:1.6}.wide{width:100%}.close-button{z-index:2;color:#2c3b3e;background:#ffffffbd;border-radius:50%;place-items:center;width:38px;height:38px;font-size:24px;display:grid;position:absolute;top:14px;right:16px;box-shadow:0 8px 18px #2d404221}.drawer-backdrop{pointer-events:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:#1a262a00;transition:background .18s}.drawer-backdrop.open{pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1a262a4d}.trip-drawer{background:#fffdfa;justify-self:end;width:min(460px,100%);height:100%;padding:24px;transition:transform .22s;overflow:auto;transform:translate(100%);box-shadow:-24px 0 70px #16232633}.drawer-backdrop.open .trip-drawer{transform:translate(0)}.drawer-header{margin-bottom:20px}.drawer-header .close-button{position:static}.empty-state{color:#4f6266;background:#f4f1e9;border-radius:18px;padding:26px;line-height:1.7}.empty-state p{margin:8px 0 0}.selected-list{gap:10px;margin-bottom:16px;display:grid}.selected-item{background:#f6f4ee;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:13px;display:flex}.selected-item strong,.selected-item span{display:block}.selected-item span{color:#6b797b;margin-top:5px;font-size:13px}.selected-item button{color:#a0493c;background:#fde9e1;border-radius:10px;flex:none;padding:8px 10px;font-weight:800}.route-result{border-top:1px solid #e7e0d4;margin-top:18px;padding-top:18px}.route-summary{margin-bottom:18px}.route-summary div{background:#eef4f2;border-radius:16px;flex:1;padding:14px}.route-summary span{color:#69797b;font-size:12px;font-weight:800;display:block}.route-summary strong{margin-top:6px;font-size:20px;display:block}.score-高{color:#2f7b5f}.score-中{color:#b46c2e}.score-低{color:#b1433b}.route-result h3{margin:0 0 12px}.route-result ol{gap:10px;margin:0;padding:0;list-style:none;display:grid}.route-result li{background:#f7f4ed;border-radius:15px;grid-template-columns:64px 1fr;align-items:start;gap:12px;padding:12px;display:grid}.route-result time{color:#2f6f78;font-weight:900}.route-result li span{color:#6b797b;margin-top:4px;font-size:13px;display:block}.route-note{color:#465a5d;background:#f0eadc;border-radius:16px;margin:14px 0 0;padding:14px;line-height:1.7}.info-modal{width:min(720px,100% - 32px)}.info-content{color:#425357;gap:14px;margin-top:18px;line-height:1.75;display:grid}.info-content p,.info-content ul{margin:0}.info-content ul{padding-left:20px}.price-example{background:#eef5f2;border-radius:16px;padding:16px}.price-example small{color:#718082}@media (width<=820px){main{width:min(100% - 20px,1180px);padding-top:12px}.site-header,.hero,.section-heading{grid-template-columns:1fr;display:grid}.site-header nav,.city-filters{justify-content:flex-start}.hero{padding-top:22px}.hero-copy h2{font-size:42px}.map-toolbar{border-radius:16px;justify-self:start;width:100%}.map-toolbar input{flex:1;min-width:90px}.map-shell{border-radius:18px;padding:10px}.map-viewport{height:68vh;min-height:520px}.map-canvas{width:max(920px, calc(1280px * var(--zoom)));height:calc(1024px * var(--zoom));min-height:620px}.city-node{padding:6px 9px}.city-node strong{font-size:16px}.spot-label{font-size:12px}.detail-grid{grid-template-columns:1fr}.spot-image{min-height:190px}}
