:root{font-family:Inter,PingFang SC,Hiragino Sans GB,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--ink: #17324d;--muted: #60748a;--blue: #2478d4;--blue-deep: #0d5fb8;--blue-soft: #eaf4ff;--blue-glass: rgba(36, 120, 212, .14);--glass: rgba(255, 255, 255, .68);--line: rgba(37, 103, 168, .15);color:var(--ink);background:#f5f8fc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(52,136,224,.16),transparent 34rem),radial-gradient(circle at 86% 12%,rgba(123,190,255,.14),transparent 28rem),linear-gradient(180deg,#f8fbff,#edf5fc)}button{font:inherit}img{max-width:100%;display:block}.app-shell{width:min(1500px,calc(100% - 32px));margin:0 auto;padding:32px 0 56px}.hero{min-height:250px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:end;padding:46px 0 26px}.hero__content{max-width:900px}.eyebrow,.section-kicker{margin:0 0 10px;color:#6b8197;font-size:.74rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.hero h1{margin:0;font-size:clamp(3.2rem,7vw,7rem);line-height:1;letter-spacing:0}.hero__intro{max-width:760px;margin:22px 0 0;color:var(--muted);font-size:1.02rem;line-height:1.8}.hero__stats{display:grid;gap:10px}.hero__stats span{min-width:128px;padding:10px 14px;border:1px solid var(--line);border-radius:22px;background:#ffffff9e;color:#215c96;font-weight:700;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.planner-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,390px);gap:18px;align-items:start}.map-panel,.spot-detail{border:1px solid var(--line);border-radius:30px;background:linear-gradient(145deg,#ffffffbd,#f6fbff94);box-shadow:0 28px 70px #1744711f;-webkit-backdrop-filter:blur(26px) saturate(128%);backdrop-filter:blur(26px) saturate(128%)}.map-panel{position:relative;min-height:790px;padding:16px}.map-panel__header{position:relative;z-index:8;display:flex;gap:14px;align-items:center;justify-content:space-between;padding:4px 4px 14px}.map-panel__header h2,.spot-detail h2,.sidebar__top h2,.sidebar-section-title h3{margin:0}.map-panel__header p:last-child{max-width:440px;margin:0;color:var(--muted);line-height:1.7;font-size:.92rem}.map-search{position:relative;width:min(620px,calc(100% - 470px))}.map-filter{display:flex;gap:8px;align-items:center;padding:6px;border:1px solid var(--line);border-radius:999px;background:#ffffff9e;box-shadow:0 14px 34px #17508a1a;-webkit-backdrop-filter:blur(18px) saturate(125%);backdrop-filter:blur(18px) saturate(125%)}.map-filter button{min-height:40px;border:0;border-radius:999px;background:transparent;color:#3d668b;cursor:pointer;font-weight:850;padding:0 14px;transition:background .16s ease,color .16s ease,transform .16s ease}.map-filter button:hover{transform:translateY(-1px)}.map-filter button.is-active{background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff}.map-search input{width:100%;min-height:52px;border:1px solid var(--line);border-radius:999px;background:#ffffffc7;color:var(--ink);font-size:1rem;font-weight:750;outline:none;padding:0 20px;box-shadow:0 16px 36px #17508a1a;-webkit-backdrop-filter:blur(18px) saturate(125%);backdrop-filter:blur(18px) saturate(125%);transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}.map-search input:focus{border-color:#2478d47a;box-shadow:0 20px 46px #1463b729;background:#ffffffe6}.map-search__results{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:20;display:grid;gap:6px;padding:8px;border:1px solid var(--line);border-radius:20px;background:#ffffffe6;box-shadow:0 24px 60px #1744712e;-webkit-backdrop-filter:blur(22px) saturate(130%);backdrop-filter:blur(22px) saturate(130%)}.map-search__results button{display:grid;gap:3px;width:100%;border:0;border-radius:16px;background:transparent;color:var(--ink);cursor:pointer;padding:10px 12px;text-align:left}.map-search__results button:hover{background:var(--blue-soft)}.map-search__results span,.map-search__results p{margin:0;color:var(--muted);font-size:.82rem}.zoom-slider{position:absolute;z-index:5;top:92px;right:28px;display:flex;gap:16px;align-items:center;width:min(430px,calc(100% - 56px));padding:12px 16px;border:1px solid var(--line);border-radius:999px;background:#ffffffc2;-webkit-backdrop-filter:blur(24px) saturate(128%);backdrop-filter:blur(24px) saturate(128%);box-shadow:0 18px 44px #17508a24}.zoom-slider button,.sidebar__top button{min-width:38px;height:38px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;cursor:pointer;font-size:1.45rem;font-weight:800;line-height:1;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;box-shadow:0 10px 24px #2478d43d}.zoom-slider button:hover,.sidebar__top button:hover{transform:translateY(-1px);filter:brightness(1.04)}.zoom-slider input{width:100%;accent-color:var(--blue);cursor:pointer}.zoom-slider strong{min-width:54px;color:#426881;font-size:1rem;font-weight:800;text-align:center}.map-viewport{position:relative;height:680px;overflow:hidden;border:1px solid var(--line);border-radius:26px;background:#e8f2fb;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.map-viewport:active,.map-viewport.is-dragging{cursor:grabbing}.map-content{position:absolute;top:0;right:0;bottom:0;left:0}.map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.map-tile{position:absolute;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.city-label{position:absolute;transform:translate(-50%,-50%);z-index:1;display:grid;justify-items:center;padding:8px 16px;border:1px solid var(--line);border-radius:999px;background:#ffffffdb;color:var(--ink);-webkit-backdrop-filter:blur(16px) saturate(125%);backdrop-filter:blur(16px) saturate(125%);pointer-events:none;box-shadow:0 10px 26px #17508a24}.city-label strong{font-size:1.2rem}.city-label span{color:var(--muted);font-size:.72rem;font-weight:700}.spot-marker{position:absolute;z-index:3;width:22px;height:22px;padding:0;border:0;border-radius:999px;background:transparent;transform:translate(-50%,-50%) scale(var(--marker-scale, 1));transform-origin:center;cursor:pointer;pointer-events:auto;transition:transform .16s ease,opacity .16s ease}.spot-marker__dot{position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:inherit;background:var(--blue);box-shadow:0 0 0 4px #ffffffd6,0 0 0 6px #2478d42e,0 5px 14px #17508a33;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}.spot-marker--level-1 .spot-marker__dot{top:5px;right:5px;bottom:5px;left:5px;background:#0b78ff}.spot-marker--level-2 .spot-marker__dot{top:6px;right:6px;bottom:6px;left:6px;background:#52a7ff}.spot-marker--level-3 .spot-marker__dot{top:7px;right:7px;bottom:7px;left:7px;background:#9acbff}.spot-marker--shopping .spot-marker__dot{background:#ff9f1c;box-shadow:0 0 0 4px #ffffffdb,0 0 0 6px #ff9f1c38,0 5px 14px #a5570833}.spot-marker.is-muted{opacity:.34}.spot-marker:hover .spot-marker__dot,.spot-marker.is-selected .spot-marker__dot{transform:scale(1.35);background:#005bd8;box-shadow:0 0 0 4px #ffffffeb,0 0 0 9px #2478d429,0 10px 24px #1463b742}.spot-marker--shopping:hover .spot-marker__dot,.spot-marker--shopping.is-selected .spot-marker__dot{background:#ef6c00;box-shadow:0 0 0 4px #ffffffeb,0 0 0 9px #ff9f1c2e,0 10px 24px #a5570847}.spot-marker__tooltip{position:absolute;left:50%;bottom:23px;min-width:max-content;padding:7px 9px;border:1px solid var(--line);border-radius:14px;background:#ffffffeb;color:var(--ink);box-shadow:0 12px 24px #17508a24;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);opacity:0;pointer-events:none;transform:translate(-50%,5px);transition:opacity .15s ease,transform .15s ease}.spot-marker__tooltip small{display:block;color:var(--muted);font-size:.7rem;margin-top:2px}.spot-marker:hover .spot-marker__tooltip{opacity:1;transform:translate(-50%)}.spot-marker__label{position:absolute;left:22px;top:-2px;min-width:max-content;padding:4px 7px;border-radius:12px;background:#ffffffe6;color:var(--ink);font-size:.7rem;font-weight:800;pointer-events:none;box-shadow:0 8px 18px #17508a24}.airport-marker{position:absolute;z-index:2;display:flex;gap:6px;align-items:center;padding:6px 9px 6px 7px;border:1px solid rgba(255,104,165,.24);border-radius:999px;background:#ffffffd1;color:#b82778;font-size:.72rem;font-weight:850;pointer-events:none;transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(14px) saturate(130%);backdrop-filter:blur(14px) saturate(130%);box-shadow:0 10px 24px #b8277824}.airport-marker span{display:grid;width:22px;height:22px;place-items:center;border-radius:999px;background:#ff6bb0;color:#fff;font-size:.78rem;line-height:1}.airport-marker strong{white-space:nowrap}.map-reset,.map-attribution{position:absolute;z-index:4;border-radius:999px;background:#ffffffe6;color:#235f9a;-webkit-backdrop-filter:blur(14px) saturate(125%);backdrop-filter:blur(14px) saturate(125%);box-shadow:0 10px 24px #17508a24}.map-reset{left:14px;top:14px;border:0;padding:9px 13px;cursor:pointer;font-weight:800;transition:transform .16s ease,background .16s ease}.map-reset:hover{background:#fff;transform:translateY(-1px)}.map-attribution{right:10px;bottom:10px;padding:5px 8px;font-size:.72rem;text-decoration:none}.spot-detail{position:sticky;top:18px;overflow:hidden}.spot-detail--empty{min-height:560px;display:grid;align-content:center;gap:20px;padding:22px}.empty-detail-visual{position:relative;min-height:250px;border:1px solid var(--line);border-radius:26px;background:radial-gradient(circle at 24% 24%,rgba(36,120,212,.16),transparent 84px),radial-gradient(circle at 72% 62%,rgba(107,183,255,.18),transparent 108px),linear-gradient(135deg,#ffffffc7,#ebf6ffb8);overflow:hidden}.empty-detail-visual span{position:absolute;padding:8px 12px;border-radius:999px;background:#ffffffc7;color:#24649e;font-size:.76rem;font-weight:850;letter-spacing:.08em;box-shadow:0 12px 28px #17508a1f}.empty-detail-visual span:nth-child(1){top:44px;right:42px}.empty-detail-visual span:nth-child(2){left:54px;bottom:52px}.empty-detail-visual span:nth-child(3){right:70px;bottom:38px}.empty-detail-visual span:nth-child(4){left:42px;top:50px}.empty-detail-body h2{margin:0 0 12px;font-size:2rem}.empty-detail-body p:last-child{margin:0;color:var(--muted);line-height:1.8}.spot-detail__carousel-shell{position:relative;height:240px;overflow:hidden;border-radius:28px 28px 0 0;background:#e8f2fb}.spot-detail__carousel{position:relative;height:100%;display:flex;overflow:hidden;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;background:#e8f2fb}.spot-detail__carousel::-webkit-scrollbar{display:none}.spot-detail__carousel img{flex:0 0 100%;height:100%;width:100%;object-fit:cover;scroll-snap-align:start}.spot-detail__image-fallback{position:relative;flex:0 0 100%;height:100%;display:grid;align-content:end;gap:8px;padding:26px;overflow:hidden;color:#fff;scroll-snap-align:start;background:radial-gradient(circle at 78% 20%,rgba(255,255,255,.26),transparent 120px),radial-gradient(circle at 18% 28%,rgba(92,172,255,.7),transparent 150px),linear-gradient(135deg,#1f74d1,#0d3c7e)}.spot-detail__image-fallback--shopping{background:radial-gradient(circle at 78% 20%,rgba(255,255,255,.3),transparent 120px),radial-gradient(circle at 18% 28%,rgba(255,199,102,.8),transparent 150px),linear-gradient(135deg,#f59b22,#a64b00)}.spot-detail__image-fallback:before{content:"";position:absolute;inset:auto -20% -42% -20%;height:74%;border-radius:50% 50% 0 0;background:#ffffff24;transform:rotate(-3deg)}.spot-detail__image-fallback span,.spot-detail__image-fallback strong,.spot-detail__image-fallback small{position:relative;z-index:1}.spot-detail__image-fallback span{width:max-content;padding:7px 12px;border-radius:999px;background:#ffffff38;font-weight:850;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.spot-detail__image-fallback strong{max-width:86%;font-size:2.05rem;line-height:1.1}.spot-detail__image-fallback small{font-weight:850;letter-spacing:.14em;opacity:.84}.spot-detail__city-pill,.spot-detail__image-count{position:absolute;padding:6px 10px;border-radius:999px;background:#ffffffb8;color:var(--ink);font-weight:800;-webkit-backdrop-filter:blur(14px) saturate(125%);backdrop-filter:blur(14px) saturate(125%)}.spot-detail__city-pill{left:14px;bottom:14px}.spot-detail__image-count{right:14px;top:14px;color:#245d94}.spot-detail__dots{position:absolute;left:50%;bottom:16px;display:flex;gap:6px;align-items:center;padding:6px 8px;border:1px solid rgba(255,255,255,.36);border-radius:999px;background:#ffffff8a;-webkit-backdrop-filter:blur(16px) saturate(130%);backdrop-filter:blur(16px) saturate(130%);transform:translate(-50%)}.spot-detail__dots button{width:7px;height:7px;padding:0;border:0;border-radius:999px;background:#17324d52;cursor:pointer;transition:width .18s ease,background .18s ease,transform .18s ease}.spot-detail__dots button.is-active{width:22px;background:var(--blue)}.spot-detail__body{padding:18px}.spot-detail__title{display:flex;justify-content:space-between;gap:12px}.spot-detail__title h2{font-size:1.7rem}.spot-detail__title p:last-child{margin:6px 0 0;color:var(--muted)}.spot-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}.spot-meta span{padding:11px;border:1px solid var(--line);border-radius:18px;background:#fff9;color:#3f6685;line-height:1.5}.spot-meta strong{display:block;color:var(--ink);font-size:.76rem}.spot-detail__desc,.spot-detail__why,.spot-tip,.service-panel p,.trip-hints p{color:var(--muted);line-height:1.75}.brand-list{display:grid;gap:10px;margin:16px 0;padding:14px;border:1px solid rgba(255,159,28,.18);border-radius:22px;background:radial-gradient(circle at top right,rgba(255,184,77,.18),transparent 130px),#ffffff9e}.brand-list strong{color:var(--ink);font-size:.82rem}.brand-list div{display:flex;flex-wrap:wrap;gap:8px}.brand-list span{padding:7px 10px;border-radius:999px;background:#fff4e0e6;color:#a35b00;font-size:.78rem;font-weight:800}.spot-tip{padding:11px 12px;border-left:3px solid #78b8ff;background:#eaf4ffad;border-radius:0 18px 18px 0}.primary-action{width:100%;min-height:46px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;cursor:pointer;font-weight:850;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;box-shadow:0 16px 34px #2478d438}.primary-action:hover{transform:translateY(-1px);filter:brightness(1.04)}.primary-action:disabled{cursor:default;background:#a8bed2;box-shadow:none;transform:none}.sidebar-launcher{position:fixed;z-index:20;right:22px;bottom:22px;display:grid;gap:2px;padding:12px 16px;border:1px solid rgba(255,255,255,.36);border-radius:22px;background:linear-gradient(135deg,#2478d4f5,#0d5fb8f5);color:#fff;box-shadow:0 18px 44px #1463b742;cursor:pointer;-webkit-backdrop-filter:blur(18px) saturate(130%);backdrop-filter:blur(18px) saturate(130%);transition:transform .18s ease,box-shadow .18s ease}.sidebar-launcher:hover{transform:translateY(-2px);box-shadow:0 22px 54px #1463b74d}.sidebar-launcher span:first-child{font-weight:850}.sidebar-launcher span:last-child{color:#ffffffbd;font-size:.78rem}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#0c223a2e;opacity:0;pointer-events:none;transition:opacity .18s ease}.sidebar-backdrop.is-open{opacity:1;pointer-events:auto}.sidebar{position:fixed;z-index:31;top:14px;right:14px;bottom:14px;width:min(430px,calc(100vw - 28px));display:flex;flex-direction:column;border:1px solid var(--line);border-radius:30px;background:#f8fcffdb;box-shadow:0 30px 80px #17447138;-webkit-backdrop-filter:blur(28px) saturate(132%);backdrop-filter:blur(28px) saturate(132%);transform:translate(calc(100% + 24px));transition:transform .22s ease}.sidebar.is-open{transform:translate(0)}.sidebar__top{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:18px}.sidebar-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 18px 14px}.sidebar-tabs button,.segmented-control button{border:1px solid var(--line);border-radius:999px;background:#ffffff94;color:#3d668b;cursor:pointer;font-weight:800}.sidebar-tabs button{min-height:42px}.sidebar-tabs button.is-active,.segmented-control button.is-active{background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff}.sidebar__content{min-height:0;overflow:auto;padding:0 18px 20px}.sidebar-section-title{margin:8px 0 14px}.trip-summary{display:flex;justify-content:space-between;align-items:center;padding:13px;border-radius:20px;background:var(--blue-soft);color:#28649c}.trip-summary strong{color:var(--ink)}.segmented-control{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}.segmented-control button{min-height:38px}.empty-state{padding:26px 18px;border:1px dashed rgba(36,120,212,.28);border-radius:22px;color:var(--muted);text-align:center}.empty-state p{margin:0 0 6px;color:var(--ink);font-weight:800}.trip-list{display:grid;gap:10px;padding:0;margin:0;list-style:none}.trip-list li{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:20px;background:#ffffff8f}.trip-list strong,.trip-list span{display:block}.trip-list span{margin-top:4px;color:var(--muted);font-size:.82rem;line-height:1.5}.trip-list button{border:0;border-radius:999px;background:#fff0ed;color:#a2402a;cursor:pointer;font-weight:800;padding:8px 10px}.trip-hints{display:grid;gap:8px;margin-top:14px}.route-action{width:100%;min-height:48px;margin-top:12px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;cursor:pointer;font-size:1rem;font-weight:850;box-shadow:0 16px 34px #2478d438;transition:transform .18s ease,filter .18s ease}.route-action:hover{transform:translateY(-1px);filter:brightness(1.04)}.route-result{display:grid;gap:12px;margin-top:16px;padding:14px;border:1px solid var(--line);border-radius:22px;background:#ffffff9e}.route-result section{padding:12px;border-radius:18px;background:#eaf4ffb8}.route-result h4{margin:0 0 10px;color:var(--ink)}.route-result ol{display:grid;gap:8px;margin:0;padding-left:20px}.route-result li strong,.route-result li span{display:block}.route-leg{display:grid;gap:3px;margin:9px 0 10px;padding:10px 12px;border:1px solid rgba(36,120,212,.14);border-radius:16px;background:#ffffffb8}.route-leg b{color:#1d5f9c;font-size:.8rem}.route-leg span{color:var(--ink);font-weight:800}.route-leg small{color:var(--muted);line-height:1.5}.route-result li span,.route-result p{color:var(--muted);line-height:1.6}.route-result p{margin:0}.trip-hints p{margin:0;padding:10px 12px;border-radius:18px;background:#eaf4ffb3}.service-subtitle{color:var(--ink);font-weight:850}.service-panel ul{display:grid;gap:8px;padding:0;margin:14px 0 0;list-style:none}.service-panel li{padding:10px 12px;border:1px solid var(--line);border-radius:18px;background:#ffffff8c;color:#3f6685}@media(max-width:1120px){.planner-layout{grid-template-columns:1fr}.spot-detail{position:static;display:grid;grid-template-columns:320px 1fr}.spot-detail--empty{grid-template-columns:1fr}.spot-detail__carousel-shell{height:100%;min-height:300px}}@media(max-width:760px){.app-shell{width:min(100% - 18px,1500px);padding-top:16px}.hero{min-height:0;grid-template-columns:1fr;padding:24px 0 16px}.hero__stats{grid-template-columns:repeat(2,1fr)}.hero__stats span{min-width:0;text-align:center;font-size:.82rem}.map-panel{min-height:auto;padding:10px}.map-panel__header{display:grid;gap:10px;padding-right:0}.map-panel__header p:last-child{margin-top:8px}.map-search{width:100%}.map-filter{width:100%;justify-content:space-between}.map-filter button{flex:1;padding:0 8px;font-size:.82rem}.zoom-slider{position:static;width:100%;margin:10px 0;gap:10px;padding:10px}.zoom-slider button{min-width:34px;height:34px;font-size:1.2rem}.zoom-slider strong{min-width:46px;font-size:.9rem}.map-viewport{height:68vh;min-height:520px}.city-label{padding:6px 9px}.city-label strong{font-size:1rem}.spot-detail{grid-template-columns:1fr}.spot-detail__carousel-shell{min-height:210px}.spot-meta{grid-template-columns:1fr}.sidebar{top:auto;left:8px;right:8px;bottom:8px;width:auto;max-height:86vh;transform:translateY(calc(100% + 20px))}.sidebar.is-open{transform:translateY(0)}}
