@import"https://fonts.googleapis.com/css2?family=Public+Sans:wght@400;500;600;700;800&family=Noto+Sans+SC:wght@400;500;700&display=swap";:root{--primary: #ec5b13;--accent-blue: #0055a4;--primary-strong: #d44d0f;--ink: #1f2937;--muted: #64748b;--surface: #ffffff;--surface-soft: #fff8f2;--bg: #f8f6f6;--line: #e8e1dc}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Public Sans,Noto Sans SC,sans-serif;color:var(--ink);height:100vh;overflow:hidden;background:radial-gradient(circle at 8% 10%,#ffe5d4 0,transparent 34%),radial-gradient(circle at 92% 90%,#ffd8bf 0,transparent 32%),var(--bg)}.app-shell{height:100vh;padding:16px;display:flex;flex-direction:column;gap:14px}.topbar{background:linear-gradient(135deg,#fff,#fff5ee);border:1px solid var(--line);border-radius:18px;padding:10px 16px;display:flex;align-items:center;justify-content:flex-start;box-shadow:0 8px 30px #3a231414}.topbar-left{display:none}.topbar h1{font-size:22px;font-weight:800;letter-spacing:-.01em;text-align:left}.layout{flex:1;min-height:0;display:grid;grid-template-columns:360px 1fr;gap:14px}.sidebar-panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;display:flex;flex-direction:column;min-height:0;box-shadow:0 10px 28px #24191214}.sidebar-head{padding:18px;border-bottom:1px solid var(--line)}.sidebar-head h2{font-size:24px;margin-bottom:6px}.sidebar-head p{color:var(--muted);font-size:13px;line-height:1.5;margin-bottom:14px}.search-box{background:#fff;border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;gap:8px;padding:8px 10px}.search-box input{border:0;outline:none;width:100%;font-size:14px;background:transparent}.category-filter{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.category-chip{border:1px solid #ebded6;background:#fff;color:#6b7280;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.category-chip:hover{border-color:#f2c2a5;color:var(--primary)}.category-chip.active{background:#fff0e7;border-color:#f2b996;color:var(--primary)}.location-list{flex:1;min-height:0;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}.modern-scroll::-webkit-scrollbar{width:6px}.modern-scroll::-webkit-scrollbar-thumb{background:#d6cbc4;border-radius:999px}.location-row{border:1px solid #e7e2dd;border-radius:14px;background:#fff;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;overflow:hidden;display:flex;align-items:stretch;gap:12px;min-height:132px;padding:8px}.location-row:hover{transform:translateY(-2px);border-color:#efc2a7;box-shadow:0 10px 22px #4c30211f}.location-row.active{border-color:var(--primary);box-shadow:0 0 0 2px #ec5b1326}.location-main{min-width:0;display:flex;flex-direction:column;justify-content:center;gap:9px;padding:2px 2px 2px 0;flex:1}.location-thumb-wrap{width:110px;flex-shrink:0}.location-thumb{width:110px;height:116px;border-radius:10px;object-fit:cover;display:block}.location-thumb.placeholder{background:linear-gradient(135deg,#f5f5f5,#ececec);color:#9ca3af;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;width:110px;height:116px;border-radius:10px}.location-meta{display:flex;justify-content:space-between;align-items:center;gap:8px}.tag{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:11px;background:#fff2e8;color:var(--primary);font-weight:700}.location-name{font-size:15px;font-weight:700;margin-bottom:0;white-space:normal;line-height:1.4;max-height:2.8em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.location-snippet{font-size:12px;color:#64748b;line-height:1.55;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;text-overflow:ellipsis}.location-actions{margin-top:0}.detail-btn{border:none;background:transparent;color:var(--accent-blue);padding:0;border-radius:0;font-size:13px;font-weight:700;cursor:pointer}.detail-btn:hover{color:#003f7a;text-decoration:underline}.empty-state{border:1px dashed #d4ccc7;border-radius:12px;padding:20px;text-align:center;color:var(--muted);font-size:14px}.reset-search-btn{margin-top:10px;border:1px solid #f4c3a6;background:#fff5ee;color:var(--primary);padding:7px 12px;border-radius:9px;font-size:12px;font-weight:700;cursor:pointer}.map-panel{position:relative;border-radius:18px;overflow:hidden;border:1px solid #d9d5d1;box-shadow:0 12px 28px #291e161f}#map{width:100%;height:100%}.map-status-card{position:absolute;top:18px;left:18px;max-width:360px;padding:14px 16px;border-radius:14px;background:#fffaf6f5;border:1px solid rgba(236,91,19,.18);box-shadow:0 10px 24px #311d121f;color:var(--ink);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:700}.map-status-card strong{display:block;font-size:14px;margin-bottom:4px}.map-status-card p{font-size:13px;line-height:1.5;color:var(--muted)}.map-inline-status{position:absolute;top:18px;right:18px;max-width:min(360px,calc(100% - 36px));padding:10px 14px;border-radius:12px;color:#fff;font-size:13px;line-height:1.5;box-shadow:0 10px 24px #1412102e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:700}.map-inline-status.info{background:#0f172ac7}.map-inline-status.success{background:#0f766edb}.map-inline-status.error{background:#b91c1cdb}.map-fab-group{position:absolute;right:12px;bottom:12px;display:flex;flex-direction:column;gap:8px;z-index:600}.map-fab{width:40px;height:40px;border:1px solid #ddd6d0;background:#fff;border-radius:999px;box-shadow:0 6px 12px #18120d26;color:#334155;display:flex;align-items:center;justify-content:center;cursor:pointer}.map-fab-icon{width:20px;height:20px}@media(max-width:980px){body{overflow:hidden;background:#f8f6f6}.app-shell{height:100vh;min-height:100vh;padding:0;gap:0}.topbar{border-radius:0;border-left:none;border-right:none;box-shadow:none;min-height:54px;padding:8px 12px;justify-content:center;position:relative}.topbar-left{display:none}.topbar h1{font-size:18px;line-height:1.2;max-width:92vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.layout{display:flex;flex-direction:column;flex:1;min-height:0}.map-panel{order:1;height:40vh;min-height:220px;border-radius:0;border-left:none;border-right:none;box-shadow:none}.sidebar-panel{order:2;min-height:0;flex:1;border-radius:0;border-left:none;border-right:none;box-shadow:none}.sidebar-head{padding:12px 14px}.sidebar-head h2{font-size:20px;margin-bottom:8px}.sidebar-head p{display:none}.category-filter{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;margin-top:8px}.category-filter::-webkit-scrollbar{display:none}.category-chip{flex-shrink:0}.location-list{padding:10px 12px;gap:10px}.location-row{transform:none;min-height:108px;border-radius:12px}.location-thumb-wrap{width:88px}.location-thumb,.location-thumb.placeholder{width:88px;height:88px;border-radius:10px}.location-main{gap:4px}.location-name{font-size:14px}.location-snippet{display:none}.location-meta{justify-content:flex-start}.location-actions{flex-shrink:0}.detail-btn{font-size:12px}.map-fab-group{right:10px;bottom:10px}}.detail-overlay[data-v-ce8b61a6]{position:fixed;inset:0;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.detail-overlay.is-visible[data-v-ce8b61a6]{opacity:1;visibility:visible}.detail-modal[data-v-ce8b61a6]{background:#fff;width:min(900px,94vw);max-height:92vh;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;position:relative;box-shadow:0 24px 50px #0c090759;transform:translateY(20px);transition:transform .3s ease}.detail-overlay.is-visible .detail-modal[data-v-ce8b61a6]{transform:translateY(0)}.close-btn[data-v-ce8b61a6]{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;background:#0000007a;color:#fff;border:none;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background .2s}.close-btn[data-v-ce8b61a6]:hover{background:#000c}.banner[data-v-ce8b61a6]{aspect-ratio:2 / 1;height:auto;max-height:450px;min-height:260px;background:#f2f2f2;position:relative;flex-shrink:0}.carousel[data-v-ce8b61a6]{width:100%;height:100%;position:relative}.banner-img[data-v-ce8b61a6]{width:100%;height:100%;object-fit:cover;display:block}.nav-btn[data-v-ce8b61a6]{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffd9;border:none;width:40px;height:40px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;color:#333;z-index:3}.nav-btn[data-v-ce8b61a6]:hover{background:#fff}.nav-btn.prev[data-v-ce8b61a6]{left:15px}.nav-btn.next[data-v-ce8b61a6]{right:15px}.dots[data-v-ce8b61a6]{position:absolute;bottom:15px;left:0;right:0;display:flex;justify-content:center;gap:8px;z-index:3}.dot[data-v-ce8b61a6]{width:8px;height:8px;border-radius:50%;background:#ffffff80;cursor:pointer;transition:background .2s}.dot.active[data-v-ce8b61a6]{background:#fff;transform:scale(1.18)}.banner-gradient[data-v-ce8b61a6]{position:absolute;inset:0;background:linear-gradient(180deg,#0000000d,#000000b8);pointer-events:none}.banner-caption[data-v-ce8b61a6]{position:absolute;left:24px;right:24px;bottom:20px;color:#fff;z-index:2;pointer-events:none}.badge[data-v-ce8b61a6]{display:inline-block;padding:4px 9px;border-radius:999px;background:#ec5b13f2;font-size:11px;font-weight:700;margin-bottom:8px}.banner-caption h2[data-v-ce8b61a6]{font-size:30px;line-height:1.2;margin-bottom:6px}.banner-caption p[data-v-ce8b61a6]{font-size:14px;opacity:.9}.no-image[data-v-ce8b61a6]{height:100%;display:flex;align-items:center;justify-content:center;color:#999;flex-direction:column;gap:6px}.no-image h2[data-v-ce8b61a6]{font-size:28px;color:#1f2937}.content-wrap[data-v-ce8b61a6]{padding:22px;display:grid;grid-template-columns:1.5fr minmax(220px,.8fr);gap:18px;overflow-y:auto}.content-main[data-v-ce8b61a6]{display:flex;flex-direction:column;gap:16px}.content-block[data-v-ce8b61a6]{border:1px solid #f0e8e4;border-radius:14px;padding:16px;background:#fff}.content-block h3[data-v-ce8b61a6],.info-side h3[data-v-ce8b61a6]{font-size:18px;margin-bottom:10px}.desc[data-v-ce8b61a6]{color:#475569;line-height:1.75;font-size:14px;white-space:pre-line}.thumb-grid[data-v-ce8b61a6]{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.thumb[data-v-ce8b61a6]{border:2px solid transparent;border-radius:10px;overflow:hidden;padding:0;cursor:pointer;background:#f8fafc;height:80px}.thumb img[data-v-ce8b61a6]{width:100%;height:100%;object-fit:cover;display:block}.thumb.active[data-v-ce8b61a6],.thumb[data-v-ce8b61a6]:hover{border-color:#ec5b13}.info-side[data-v-ce8b61a6]{background:#f9f6f5;border:1px solid #efe4de;border-radius:14px;padding:16px;align-self:flex-start;width:100%}.info-item[data-v-ce8b61a6]{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.info-item span[data-v-ce8b61a6]{color:#6b7280;font-size:12px}.info-item strong[data-v-ce8b61a6]{color:#111827;font-size:14px;word-break:break-word}.nav-btn-panel[data-v-ce8b61a6]{width:100%;background:linear-gradient(135deg,#ec5b13,#ff8446);border:none;border-radius:12px;color:#fff;padding:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.mobile-only[data-v-ce8b61a6]{display:none}.mobile-nav-sticky[data-v-ce8b61a6]{padding:14px 16px;background:#fff;border-top:1px solid #eee;box-shadow:0 -4px 10px #0000000d}.nav-btn-full[data-v-ce8b61a6]{width:100%;background:linear-gradient(135deg,#ec5b13,#ff7a3a);color:#fff;border:none;padding:14px;border-radius:12px;font-size:1.05rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}.nav-btn-full[data-v-ce8b61a6]:active{background:#d84f0f}.map-selector-overlay[data-v-ce8b61a6]{position:absolute;inset:0;background:#0006;z-index:100;display:flex;align-items:flex-end;justify-content:center}.map-selector[data-v-ce8b61a6]{width:100%;background:#fff;border-top-left-radius:20px;border-top-right-radius:20px;padding:20px;animation:slideUp-ce8b61a6 .3s ease-out}@keyframes slideUp-ce8b61a6{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeInScale-ce8b61a6{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media(min-width:769px){.map-selector-overlay[data-v-ce8b61a6]{align-items:center}.map-selector[data-v-ce8b61a6]{width:400px;border-radius:20px;animation:fadeInScale-ce8b61a6 .2s ease-out;box-shadow:0 10px 25px #0003}}.selector-header[data-v-ce8b61a6]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.selector-header h3[data-v-ce8b61a6]{margin:0;font-size:1.2rem;color:#333}.close-selector[data-v-ce8b61a6]{background:none;border:none;font-size:1.2rem;color:#999;cursor:pointer}.map-options[data-v-ce8b61a6]{display:flex;gap:10px}.map-option[data-v-ce8b61a6]{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 2px;border:1px solid #eee;border-radius:12px;background:#fcfcfc;cursor:pointer;transition:all .2s;min-width:0;font-size:.85rem;white-space:nowrap}.map-option[data-v-ce8b61a6]:active{background:#f0f0f0;transform:scale(.98)}.map-icon[data-v-ce8b61a6]{font-size:1.8rem}.wechat-prompt-overlay[data-v-ce8b61a6]{position:fixed;inset:0;background:#000000d9;z-index:20000;display:flex;justify-content:center;align-items:flex-start;color:#fff}.wechat-prompt-content[data-v-ce8b61a6]{width:100%;padding-top:20px;display:flex;flex-direction:column;align-items:center;position:relative}.wechat-arrow[data-v-ce8b61a6]{position:absolute;top:10px;right:30px;font-size:50px;font-weight:700;transform:rotate(-10deg);color:#4cd964}.wechat-text[data-v-ce8b61a6]{margin-top:80px;text-align:center;font-size:1.2rem;line-height:1.8}.wechat-text p[data-v-ce8b61a6]{margin:10px 0}.highlight[data-v-ce8b61a6]{color:#4cd964;font-weight:700;font-size:1.3rem;background:#ffffff1a;padding:2px 8px;border-radius:4px}.wechat-close[data-v-ce8b61a6]{margin-top:50px;background:transparent;border:1px solid white;color:#fff;padding:10px 30px;border-radius:25px;font-size:1rem;cursor:pointer;transition:all .2s}.wechat-close[data-v-ce8b61a6]:active{background:#fff;color:#000}.image-preview-overlay[data-v-ce8b61a6]{position:fixed;inset:0;z-index:22000;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:20px}.image-preview[data-v-ce8b61a6]{max-width:min(1200px,92vw);max-height:88vh;object-fit:contain;border-radius:10px;box-shadow:0 12px 36px #00000073}.image-preview-close[data-v-ce8b61a6]{position:fixed;top:18px;right:18px;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:#00000080;color:#fff;cursor:pointer;font-size:14px}@media(max-width:768px){.detail-modal[data-v-ce8b61a6]{width:100%;height:100%;max-height:100vh;border-radius:0}.banner[data-v-ce8b61a6]{height:250px}.nav-btn[data-v-ce8b61a6]{display:none}.banner-caption[data-v-ce8b61a6]{left:16px;right:16px;bottom:14px}.banner-caption h2[data-v-ce8b61a6]{font-size:24px}.content-wrap[data-v-ce8b61a6]{display:block;padding:16px}.info-side[data-v-ce8b61a6]{display:none}.mobile-only[data-v-ce8b61a6]{display:block}}
