:root{font-family:Microsoft YaHei,PingFang SC,Noto Sans SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#eef5ff;background:#070b13;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #070b13;--surface: rgba(12, 18, 30, .82);--surface-strong: rgba(14, 22, 36, .94);--surface-soft: rgba(255, 255, 255, .055);--line: rgba(207, 221, 244, .13);--line-strong: rgba(125, 183, 255, .38);--text: #f6f9ff;--muted: rgba(225, 233, 248, .66);--soft: rgba(225, 233, 248, .46);--mint: #7db7ff;--mint-deep: #3f7cff;--blue: #58d0ff;--amber: #ffcb69;--rose: #ff6f87;--panel-shadow: 0 28px 90px rgba(0, 0, 0, .34);--sharp-shadow: 0 16px 44px rgba(0, 0, 0, .26)}*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);background:radial-gradient(circle at 20% 8%,rgba(125,183,255,.18),transparent 31%),radial-gradient(circle at 78% 18%,rgba(255,203,105,.12),transparent 27%),linear-gradient(140deg,#060a12,#08111f 48%,#17141d);overflow-x:hidden}body:before{position:fixed;inset:0;z-index:-2;background:linear-gradient(115deg,rgba(255,255,255,.05),transparent 34%),radial-gradient(circle at 50% 130%,rgba(98,168,255,.14),transparent 40%);content:"";pointer-events:none}body:after{position:fixed;inset:0;z-index:-1;opacity:.42;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:linear-gradient(#000 0 58%,transparent 96%);mask-image:linear-gradient(#000 0 58%,transparent 96%);content:"";pointer-events:none}button,input,select{font:inherit}button{cursor:pointer}.app-shell{position:relative;width:min(1520px,100%);margin:0 auto;padding:28px}.app-shell:before{position:fixed;right:-58px;bottom:4vh;z-index:-1;color:#ffffff09;font-size:clamp(96px,14vw,220px);font-weight:900;line-height:.82;text-align:right;white-space:pre;content:"KM\aROUTE";pointer-events:none}.ambient-grid,.orbital-ring{display:none}.system-label{display:inline-flex;align-items:center;gap:8px;color:var(--mint);font-size:12px;font-weight:900;letter-spacing:0}.system-label:before{width:7px;height:7px;border-radius:999px;background:var(--amber);box-shadow:0 0 20px #ffcb69b8;content:""}.section-kicker{color:var(--mint);font-size:12px;font-weight:900}.app-header{position:relative;overflow:hidden;display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:28px;min-height:300px;margin-bottom:22px;padding:36px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(95deg,rgba(255,255,255,.08),transparent 55%),radial-gradient(circle at 85% 34%,rgba(125,183,255,.18),transparent 28%),linear-gradient(135deg,#0c1321f5,#070b13eb);box-shadow:var(--panel-shadow);-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px);animation:surface-in .52s ease both}.app-header:before{position:absolute;inset:auto 0 0;height:1px;background:linear-gradient(90deg,transparent,rgba(125,183,255,.72),rgba(255,203,105,.72),transparent);content:""}.app-header:after{position:absolute;top:-120px;right:-70px;width:430px;height:430px;border:1px solid rgba(125,183,255,.16);border-radius:50%;background:radial-gradient(circle,transparent 0 38%,rgba(125,183,255,.075) 38.5% 39%,transparent 39.5% 100%),conic-gradient(from 210deg,transparent 0 75%,rgba(125,183,255,.18),transparent 86% 100%);opacity:.95;content:"";animation:slow-spin 16s linear infinite}.hero-copy,.hero-instrument{position:relative;z-index:1}.hero-copy{display:grid;align-content:center}.app-header h1{max-width:780px;margin:16px 0 12px;color:#fff;font-size:clamp(42px,5.4vw,72px);line-height:1.02;letter-spacing:0;text-wrap:balance}.app-header p{max-width:690px;margin:0;color:var(--muted);font-size:17px;line-height:1.8}.author-credit{display:inline-flex;align-items:center;margin-left:14px;padding:3px 9px;border:1px solid rgba(125,183,255,.22);border-radius:999px;background:#ffffff0d;color:#e1e9f8c7;font-size:13px;font-weight:800;white-space:nowrap}.hero-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}.hero-tags span{min-height:34px;display:inline-flex;align-items:center;gap:8px;padding:0 13px;border:1px solid rgba(125,183,255,.22);border-radius:999px;background:#ffffff0f;color:#f7fffcd1;font-size:13px;font-weight:850;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.hero-tags svg{color:var(--amber)}.hero-instrument{align-self:center;min-height:215px;display:grid;align-content:center;gap:8px;padding:26px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:linear-gradient(155deg,#ffffff21,#ffffff09),#09101dd1;box-shadow:inset 0 1px #ffffff1f,var(--sharp-shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.hero-instrument:before{position:absolute;top:22px;right:22px;width:76px;height:76px;border:1px solid rgba(125,183,255,.24);border-radius:50%;background:linear-gradient(90deg,transparent 48%,rgba(125,183,255,.28) 49% 51%,transparent 52%),linear-gradient(0deg,transparent 48%,rgba(125,183,255,.2) 49% 51%,transparent 52%);content:""}.hero-instrument svg{color:var(--amber)}.hero-instrument strong{color:#fff;font-size:76px;line-height:.92}.hero-instrument span{color:#fff;font-size:21px;font-weight:900}.hero-instrument small{color:var(--muted);font-size:14px}.workspace-grid{display:grid;grid-template-columns:350px minmax(0,1fr);gap:18px;align-items:start}.form-panel,.result-panel,.spots-section{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:18px;background:var(--surface);box-shadow:var(--panel-shadow);-webkit-backdrop-filter:blur(26px);backdrop-filter:blur(26px);animation:surface-in .52s ease both}.form-panel:before,.result-panel:before,.spots-section:before{position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent,var(--mint),rgba(255,203,105,.86),transparent);content:""}.form-panel{position:sticky;top:18px}.search-form{display:grid;gap:18px;padding:24px}.panel-heading,.timeline-header,.section-heading,.spot-card-top,.timeline-main{display:flex;justify-content:space-between;gap:16px;align-items:center}.panel-heading{align-items:flex-start;padding-bottom:16px;border-bottom:1px solid var(--line)}.panel-heading strong{display:block;margin-top:7px;color:#fff;font-size:22px}label,.form-group{display:grid;gap:8px}label>span,.form-group>span{display:inline-flex;align-items:center;gap:7px;color:#f7fffcd1;font-size:13px;font-weight:850}label svg{color:var(--mint)}.field-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}input,select{width:100%;min-height:50px;border:1px solid rgba(207,221,244,.14);border-radius:12px;background:#040d0fb8;color:#fff;padding:0 14px;outline:none;box-shadow:inset 0 1px #ffffff0e;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease,transform .16s ease}select option{color:#111827}input:focus,select:focus{border-color:#7db7ffad;background:#08101deb;box-shadow:0 0 0 4px #7db7ff1a,inset 0 1px #ffffff14}.segmented-control{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.segmented-control button,.primary-button{min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(207,221,244,.14);border-radius:12px;color:#f7fffcbd;background:#ffffff0d;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease,box-shadow .16s ease}.segmented-control button:hover,.primary-button:hover{transform:translateY(-2px)}.segmented-control button.active{border-color:#7db7ff94;background:#7db7ff21;color:#fff;font-weight:900;box-shadow:0 0 0 1px #7db7ff14,0 16px 34px #00000038}.primary-button{position:relative;overflow:hidden;border:0;background:linear-gradient(135deg,#7db7ff,#58d0ff 56%,#ffd36d);color:#07101d;font-size:16px;font-weight:950;box-shadow:0 18px 44px #4f97ff3d}.primary-button:after{position:absolute;inset:0;background:linear-gradient(110deg,transparent 0 36%,rgba(255,255,255,.46) 47%,transparent 59% 100%);content:"";pointer-events:none;transform:translate(-120%);animation:button-sheen 4.2s ease-in-out infinite}.primary-button:disabled{cursor:not-allowed;opacity:.72;transform:none}.preference-badge,.spot-type{display:inline-flex;align-items:center;min-height:30px;padding:0 11px;border:1px solid rgba(125,183,255,.2);border-radius:999px;background:#7db7ff1c;color:var(--mint);font-size:12px;font-weight:900;white-space:nowrap}.route-result{padding:16px}.route-dashboard{position:relative;display:block;margin-bottom:16px}.route-map-panel,.result-empty{min-height:620px;position:relative;overflow:hidden;border:1px solid rgba(207,221,244,.14);border-radius:16px;background:radial-gradient(circle at 38% 32%,rgba(125,183,255,.13),transparent 34%),radial-gradient(circle at 80% 76%,rgba(255,203,105,.08),transparent 25%),linear-gradient(135deg,#08111f,#0b1728 58%,#151922);box-shadow:var(--sharp-shadow)}.route-map-panel:before,.result-empty:before{position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,transparent 0 42%,rgba(255,255,255,.055) 48%,transparent 56% 100%),radial-gradient(circle at 50% 50%,transparent 0 48%,rgba(255,255,255,.045) 49%,transparent 50%);content:"";pointer-events:none;mix-blend-mode:screen}.route-map-panel:after,.result-empty:after{position:absolute;inset:16px;border:1px solid rgba(255,255,255,.09);border-radius:12px;pointer-events:none;content:""}.route-map-panel.practical-panel,.result-empty.practical-panel{background:#e8edf2}.route-map-panel.practical-panel:before,.result-empty.practical-panel:before{opacity:.16}.route-map-panel.practical-panel:after,.result-empty.practical-panel:after{border-color:#3341551f}.result-empty{display:block;min-height:680px}.result-empty .route-map{min-height:680px}.empty-copy{position:absolute;right:34px;bottom:34px;width:min(390px,calc(100% - 68px));display:grid;gap:10px;padding:24px;border:1px solid rgba(255,255,255,.15);border-radius:16px;background:#051012c2;color:var(--muted);box-shadow:var(--sharp-shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.empty-copy svg{color:var(--amber)}.empty-copy span{color:var(--mint);font-size:12px;font-weight:950}.empty-copy h2{margin:0;color:#fff;font-size:32px}.empty-copy p{margin:0;line-height:1.75}.route-map{position:relative;width:100%;min-height:620px;height:100%;color:#fff}.map-mode-switch{position:absolute;top:18px;left:22px;z-index:8;display:inline-grid;grid-template-columns:repeat(2,minmax(0,1fr));width:min(260px,calc(100% - 180px));min-width:220px;padding:4px;border:1px solid rgba(207,221,244,.16);border-radius:999px;background:#060c16ad;box-shadow:0 12px 28px #00000038;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transform:none}.map-mode-switch button{min-height:30px;border:0;border-radius:999px;background:transparent;color:#e1e9f8b8;font-size:12px;font-weight:900;white-space:nowrap}.map-mode-switch button.active{background:#fff;color:#132033;box-shadow:0 8px 18px #0003}.practical-panel .map-mode-switch{border-color:#1f29371f;background:#ffffffe6;box-shadow:0 10px 26px #0f172a1f}.practical-panel .map-mode-switch button{color:#64748b}.practical-panel .map-mode-switch button.active{background:#1677ff;color:#fff}.map-base-layer{position:absolute;inset:0;background:linear-gradient(35deg,rgba(255,255,255,.025) 12%,transparent 12% 24%,rgba(255,255,255,.022) 24% 36%,transparent 36%),linear-gradient(125deg,transparent 0 36%,rgba(125,183,255,.05) 36.5% 37.2%,transparent 37.7%),#071422}.map-lake-shape{position:absolute;left:19%;bottom:-13%;width:39%;height:32%;border:1px solid rgba(98,168,255,.25);border-radius:48% 52% 42% 58%;background:radial-gradient(circle at 45% 20%,rgba(125,183,255,.23),transparent 54%),linear-gradient(135deg,#62a8ff2b,#62a8ff0a),repeating-linear-gradient(140deg,rgba(255,255,255,.045) 0 1px,transparent 1px 12px);opacity:.82}.map-district-fill{position:absolute;border:1px solid rgba(207,221,244,.045);background:linear-gradient(135deg,rgba(255,255,255,.055),transparent 65%),#ffffff05;opacity:.68;pointer-events:none}.district-fill-a{left:10%;top:13%;width:32%;height:34%;border-radius:34% 66% 44% 56%}.district-fill-b{right:12%;top:18%;width:34%;height:32%;border-radius:58% 42% 60% 40%}.district-fill-c{right:8%;bottom:14%;width:34%;height:35%;border-radius:50% 50% 38% 62%}.map-grid-layer{position:absolute;inset:0;background:linear-gradient(0deg,rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:linear-gradient(#000 0 86%,transparent 100%);mask-image:linear-gradient(#000 0 86%,transparent 100%)}.map-scan{position:absolute;inset:-26%;background:conic-gradient(from 0deg,transparent,rgba(125,183,255,.13),transparent 15%);opacity:.24;animation:slow-spin 14s linear infinite;transform-origin:50% 50%}.map-origin{position:absolute;left:48%;top:47%;z-index:2;display:inline-flex;align-items:center;gap:7px;padding:7px 10px;border:1px solid rgba(125,183,255,.2);border-radius:999px;background:#060c16a8;color:#f7fffcb3;font-size:12px;font-weight:900;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translate(-50%,-50%)}.map-origin span{width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 6px #7db7ff1f,0 0 18px #7db7ff9e}.map-compass{position:absolute;right:22px;top:22px;z-index:5;width:36px;height:36px;display:grid;place-items:center;border:1px solid rgba(207,221,244,.16);border-radius:50%;background:#060c16a8;color:var(--amber);font-size:12px;font-weight:950;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-compass:before{position:absolute;top:-7px;width:0;height:0;border-right:5px solid transparent;border-bottom:9px solid var(--amber);border-left:5px solid transparent;content:""}.map-zoom-control{position:absolute;right:22px;top:68px;z-index:5;overflow:hidden;display:grid;width:36px;border:1px solid rgba(207,221,244,.14);border-radius:10px;background:#060c16a8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-zoom-control span{height:32px;display:grid;place-items:center;color:#eef5ffd1;font-size:18px;font-weight:900}.map-zoom-control span+span{border-top:1px solid rgba(207,221,244,.11)}.map-line-layer{position:absolute;inset:0;width:100%;height:100%}.map-lake-line{fill:none;stroke:#62a8ff73;stroke-width:1.2;stroke-linecap:round;filter:drop-shadow(0 0 12px rgba(98,168,255,.28))}.map-road{fill:none;stroke-linejoin:round;stroke-linecap:round}.map-road.arterial{stroke:#ffffff3b;stroke-width:4;filter:drop-shadow(0 0 8px rgba(125,183,255,.1))}.map-road.main-road{stroke:#b9cbe433;stroke-width:2.2}.map-road.minor-road{stroke:#cfddf426;stroke-width:1.1;stroke-dasharray:5 8}.route-polyline{stroke:url(#routeGradient);stroke-width:3.9;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 14px rgba(255,203,105,.46));stroke-dasharray:190;stroke-dashoffset:190;animation:route-draw .95s ease forwards}.route-casing{stroke:#050c16eb;stroke-width:9;opacity:.85;filter:none}.route-glow{stroke-width:11;opacity:.18;filter:blur(1px)}.route-trace{stroke:#ffffffe0;stroke-width:2.1;stroke-dasharray:12 138;stroke-dashoffset:0;opacity:0;filter:drop-shadow(0 0 10px rgba(255,203,105,.75));animation:route-draw .7s ease forwards,route-pulse 2.4s linear .8s infinite}.map-district{position:absolute;color:#ffffff0e;font-size:clamp(36px,4.6vw,62px);font-weight:950;line-height:1;pointer-events:none}.district-a{top:13%;left:10%}.district-b{top:13%;right:9%}.district-c{right:9%;bottom:18%}.district-d{left:12%;bottom:13%}.map-marker{position:absolute;z-index:6;display:inline-flex;align-items:center;gap:8px;transform:translate(-14px,-14px);animation:marker-in .42s ease both;animation-delay:var(--delay, 0ms)}.map-marker span{width:32px;height:32px;display:grid;place-items:center;border:2px solid rgba(255,255,255,.92);border-radius:50%;background:var(--amber);color:#07101d;font-size:13px;font-weight:950;box-shadow:0 0 0 8px #ffcb6924,0 0 24px #ffcb696b}.map-marker.active span{animation:marker-breathe 2.8s ease-in-out infinite}.map-marker strong{max-width:148px;padding:7px 10px;border:1px solid rgba(255,255,255,.12);border-radius:10px;background:#060c16cc;color:#fff;font-size:12px;line-height:1.25;white-space:nowrap;box-shadow:0 12px 26px #00000042;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-street-label,.map-poi-dot{position:absolute;z-index:3;pointer-events:none}.map-street-label{padding:3px 7px;border-radius:999px;background:#060c1666;color:#e1e9f852;font-size:11px;font-weight:850;transform:translate(-50%,-50%)}.map-poi-dot{display:inline-flex;align-items:center;gap:5px;transform:translate(-4px,-4px);opacity:.62}.map-poi-dot.muted{opacity:0}.map-poi-dot span{width:8px;height:8px;border:1px solid rgba(125,183,255,.8);border-radius:50%;background:#7db7ff94;box-shadow:0 0 12px #7db7ff47}.map-poi-dot small{padding:3px 6px;border-radius:7px;background:#060c1685;color:#e1e9f875;font-size:10px;font-weight:850;white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.map-caption{position:absolute;left:22px;bottom:22px;display:grid;gap:4px;padding:16px 18px;border:1px solid rgba(255,255,255,.14);border-radius:14px;background:#051012b3;color:var(--muted);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.map-caption span{color:var(--mint);font-size:12px;font-weight:950}.map-caption strong{color:#fff;font-size:28px}.map-data-strip{position:absolute;top:64px;left:22px;z-index:4;display:flex;flex-wrap:wrap;gap:8px;max-width:calc(100% - 44px)}.map-data-strip span{min-height:28px;display:inline-flex;align-items:center;padding:0 10px;border:1px solid rgba(207,221,244,.12);border-radius:999px;background:#060c1694;color:#e1e9f8b8;font-size:11px;font-weight:900;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.map-scale{position:absolute;right:22px;bottom:22px;z-index:5;display:inline-grid;gap:4px;min-width:82px;color:#e1e9f8b3;font-size:11px;font-weight:900;text-align:center}.map-scale span{height:5px;border-right:2px solid rgba(225,233,248,.72);border-bottom:2px solid rgba(225,233,248,.72);border-left:2px solid rgba(225,233,248,.72)}.route-map.practical-map{color:#172033;background:linear-gradient(0deg,rgba(51,65,85,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(51,65,85,.035) 1px,transparent 1px),#edf2f6;background-size:48px 48px}.route-map.practical-map .map-base-layer{background:linear-gradient(32deg,transparent 0 20%,rgba(255,255,255,.5) 20.5% 23%,transparent 23.5%),linear-gradient(118deg,transparent 0 38%,rgba(206,214,223,.7) 38.5% 39.2%,transparent 39.7%),#edf2f6}.route-map.practical-map .map-lake-shape{border-color:#4c9ad63d;background:linear-gradient(135deg,#79beeb80,#b5def773),repeating-linear-gradient(140deg,rgba(255,255,255,.45) 0 1px,transparent 1px 12px);opacity:.92}.route-map.practical-map .map-district-fill{border-color:#4e5b6f1a;background:linear-gradient(135deg,rgba(255,255,255,.48),transparent 70%),#dde5ec8c;opacity:.9}.route-map.practical-map .map-grid-layer{background:linear-gradient(0deg,rgba(71,85,105,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(71,85,105,.035) 1px,transparent 1px);background-size:44px 44px}.route-map.practical-map .map-origin{border-color:#1677ff38;background:#ffffffeb;color:#334155;box-shadow:0 8px 18px #0f172a1a}.route-map.practical-map .map-origin span{background:#1677ff;box-shadow:0 0 0 6px #1677ff1f,0 0 18px #1677ff4d}.route-map.practical-map .map-compass,.route-map.practical-map .map-zoom-control,.route-map.practical-map .map-data-strip span{border-color:#1f29371f;background:#ffffffe6;color:#334155;box-shadow:0 8px 18px #0f172a1a}.route-map.practical-map .map-compass{color:#ef4444}.route-map.practical-map .map-compass:before{border-bottom-color:#ef4444}.route-map.practical-map .map-zoom-control span{color:#334155}.route-map.practical-map .map-zoom-control span+span{border-top-color:#1f29371a}.route-map.practical-map .map-district{display:none}.route-map.practical-map .map-lake-line{stroke:#2e90cc80}.route-map.practical-map .map-road.arterial{stroke:#fffffff5;stroke-width:5.4;filter:drop-shadow(0 0 0 rgba(0,0,0,0))}.route-map.practical-map .map-road.main-road{stroke:#ffffffe6;stroke-width:3.4}.route-map.practical-map .map-road.minor-road{stroke:#a0aec0d1;stroke-width:1.4;stroke-dasharray:none}.route-map.practical-map .route-casing{stroke:#fffffff5;stroke-width:9;opacity:1}.route-map.practical-map .route-polyline{stroke:#1677ff;stroke-width:4;filter:drop-shadow(0 2px 5px rgba(22,119,255,.28))}.route-map.practical-map .route-glow{stroke:#1677ff38;stroke-width:12;opacity:.36}.route-map.practical-map .route-trace{stroke:#ffffffe6;stroke-width:2}.route-map.practical-map .map-street-label{background:#ffffffad;color:#475569a8}.route-map.practical-map .map-poi-dot{opacity:.9}.route-map.practical-map .map-poi-dot.muted{opacity:0}.route-map.practical-map .map-poi-dot span{border-color:#1677ff;background:#fff;box-shadow:inset 0 0 0 2px #1677ff,0 2px 6px #0f172a24}.route-map.practical-map .map-poi-dot small,.route-map.practical-map .map-marker strong{border-color:#1f29371a;background:#fffffff0;color:#1f2937;box-shadow:0 8px 18px #0f172a1a}.route-map.practical-map .map-marker span{border-color:#fff;background:#1677ff;color:#fff;box-shadow:0 0 0 4px #1677ff21,0 8px 18px #0f172a2e}.route-map.practical-map .map-marker.active span{animation:none}.route-map.practical-map .map-scale{color:#475569}.route-map.practical-map .map-scale span{border-color:#475569b8}.route-map.real-map-ready>:not(.amap-layer-shell):not(.map-fullscreen-button){display:none}.internal-map.real-map-ready>:not(.amap-layer-shell):not(.internal-navigation-overlay):not(.map-fullscreen-button):not(.map-next-direction-card):not(.location-alert-card){display:none}.amap-layer-shell,.amap-real-layer{position:absolute;inset:0}.amap-layer-shell{z-index:7;overflow:hidden;border-radius:inherit;pointer-events:none}.amap-layer-shell.map-visible{pointer-events:auto}.map-fullscreen-button{position:absolute;top:16px;right:16px;z-index:18;min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;border:1px solid rgba(207,221,244,.16);border-radius:999px;background:#060c16bd;color:#fff;font-size:12px;font-weight:900;box-shadow:0 12px 26px #0000003d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}.map-fullscreen-button:hover{border-color:#7db7ff6b;background:#142238db;transform:translateY(-1px)}.route-map.practical-map .map-fullscreen-button{right:62px}.route-map.practical-map .map-fullscreen-button,.internal-map.practical-map .map-fullscreen-button{border-color:#1f29371f;background:#fffffff0;color:#172033;box-shadow:0 10px 24px #0f172a24}.route-map.practical-map .map-fullscreen-button:hover,.internal-map.practical-map .map-fullscreen-button:hover{border-color:#1677ff47;background:#fff}.route-map:fullscreen,.internal-map:fullscreen{width:100vw;height:100vh;min-height:100vh;margin:0;border:0;border-radius:0}.route-map:fullscreen .map-fullscreen-button,.internal-map:fullscreen .map-fullscreen-button{top:22px;right:22px;min-height:40px;padding:0 15px}.internal-map:fullscreen .internal-navigation-overlay{right:24px;bottom:24px;left:24px;grid-template-columns:minmax(200px,.9fr) minmax(320px,1.4fr) auto;padding:16px}.amap-real-layer{background:#edf2f6}.amap-layer-shell:not(.map-visible) .amap-real-layer{display:none}.amap-status-card{position:absolute;right:16px;bottom:16px;z-index:8;max-width:min(300px,calc(100% - 32px));padding:10px 12px;border:1px solid rgba(31,41,55,.12);border-radius:10px;background:#ffffffeb;color:#334155;font-size:12px;font-weight:850;line-height:1.5;box-shadow:0 12px 24px #0f172a24;pointer-events:auto}.amap-custom-marker{display:inline-flex;align-items:center;gap:7px;transform:translateY(-2px)}.amap-custom-marker span{width:28px;height:28px;display:grid;place-items:center;border:2px solid #ffffff;border-radius:50%;background:#1677ff;color:#fff;font-size:12px;font-weight:950;box-shadow:0 0 0 5px #1677ff24,0 9px 18px #0f172a33}.amap-custom-marker.start span{background:#f59e0b;box-shadow:0 0 0 5px #f59e0b29,0 9px 18px #0f172a33}.amap-custom-marker.internal.active span{background:#ff8a00;box-shadow:0 0 0 6px #ff8a0033,0 10px 20px #0f172a38}.amap-custom-marker.internal.next span{background:#0ea5e9}.amap-custom-marker strong{max-width:146px;padding:6px 9px;border:1px solid rgba(31,41,55,.1);border-radius:9px;background:#fffffff0;color:#172033;font-size:12px;font-weight:900;line-height:1.25;white-space:nowrap;box-shadow:0 9px 18px #0f172a1f}.amap-custom-marker.internal strong{max-width:128px}.amap-custom-marker.internal.active strong{border-color:#ff8a003d;color:#7c2d12}.amap-route-arrow{width:34px;height:34px;display:grid;place-items:center;border:2px solid #ffffff;border-radius:50%;background:#ff8a00;box-shadow:0 0 0 6px #ff8a002e,0 10px 22px #0f172a3d;transform:rotate(var(--arrow-angle, 0deg));pointer-events:none}.amap-route-arrow span{position:relative;width:17px;height:4px;border-radius:999px;background:#fff}.amap-route-arrow span:after{position:absolute;top:50%;right:-1px;border-top:7px solid transparent;border-bottom:7px solid transparent;border-left:9px solid #ffffff;content:"";transform:translateY(-50%)}.amap-nav-hint{position:relative;width:min(330px,72vw);display:grid;gap:4px;padding:11px 13px 12px;border:1px solid rgba(22,119,255,.16);border-radius:12px;background:#fffffff5;box-shadow:0 16px 36px #0f172a2e,inset 0 1px #ffffffbf;color:#172033;pointer-events:none}.amap-nav-hint:before{position:absolute;left:18px;bottom:-8px;width:16px;height:16px;border-right:1px solid rgba(22,119,255,.14);border-bottom:1px solid rgba(22,119,255,.14);background:#fffffff5;content:"";transform:rotate(45deg)}.amap-nav-hint span{color:#1677ff;font-size:11px;font-weight:950}.amap-nav-hint strong{overflow:hidden;color:#0f172a;font-size:14px;font-weight:950;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.amap-nav-hint small{overflow:hidden;color:#64748b;font-size:12px;font-weight:850;text-overflow:ellipsis;white-space:nowrap}.amap-user-marker{display:inline-flex;align-items:center;gap:7px;transform:translateY(-2px);white-space:nowrap}.amap-user-marker span{position:relative;width:28px;height:28px;border:3px solid #ffffff;border-radius:50%;background:#1677ff;box-shadow:0 0 0 7px #1677ff2e,0 10px 22px #0f172a3d}.amap-user-marker span:after{position:absolute;inset:7px;border-radius:inherit;background:#fff;content:""}.amap-user-marker.demo span,.amap-user-marker.outside span{background:#94a3b8;box-shadow:0 0 0 7px #64748b29,0 10px 22px #0f172a33}.amap-user-marker.outside span{background:#f59e0b;box-shadow:0 0 0 7px #f59e0b33,0 10px 22px #0f172a38}.amap-user-marker strong{min-width:64px;padding:7px 10px;border:1px solid rgba(31,41,55,.12);border-radius:999px;background:#fffffff5;color:#172033;font-size:12px;font-weight:950;box-shadow:0 10px 22px #0f172a24;white-space:nowrap}.amap-user-marker.demo strong,.amap-user-marker.outside strong{color:#475569}.amap-user-marker.outside strong{color:#7c2d12}.practical-panel .map-caption{border-color:#1f29371f;background:#ffffffe6;color:#64748b;box-shadow:0 10px 24px #0f172a1f}.practical-panel .map-caption span{color:#1677ff}.practical-panel .map-caption strong{color:#172033}.result-command{position:absolute;top:18px;right:72px;bottom:18px;z-index:12;overflow:hidden;display:grid;align-content:start;gap:16px;width:min(360px,calc(100% - 36px));max-height:calc(100% - 36px);padding:23px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,#ffffff17,#ffffff09),#090f1ce0;box-shadow:0 24px 70px #02060f6b;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.result-command:after{position:absolute;inset:0;background:radial-gradient(circle at 30% 12%,rgba(125,183,255,.16),transparent 34%),linear-gradient(135deg,transparent 0 62%,rgba(255,203,105,.08));content:"";pointer-events:none}.result-command>*{position:relative;z-index:1}.result-command h2{margin:0;color:#fff;font-size:28px;line-height:1.18}.result-score{min-width:0;padding:20px 18px;border:1px solid rgba(125,183,255,.16);border-radius:15px;background:radial-gradient(circle at 22% 18%,rgba(125,183,255,.2),transparent 40%),linear-gradient(135deg,#7db7ff24,#58d0ff1a),#060c16db;color:#fff;text-align:center;box-shadow:var(--sharp-shadow)}.result-score:before{display:block;width:112px;height:112px;margin:0 auto -102px;border-radius:50%;background:conic-gradient(from -90deg,var(--amber) 0 74%,rgba(255,255,255,.08) 74% 100%),#ffffff0a;content:"";opacity:.26}.result-score span{display:block;margin-bottom:4px;color:var(--muted);font-size:12px;font-weight:850}.result-score strong{color:#fff;font-size:60px;line-height:1}.result-command-meta{display:grid;gap:10px}.result-command-meta span{min-height:38px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border:1px solid rgba(207,221,244,.12);border-radius:11px;background:#ffffff0e;color:var(--muted);font-size:13px;font-weight:850}.algorithm-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.algorithm-metrics div{min-width:0;padding:11px 12px;border:1px solid rgba(125,183,255,.15);border-radius:12px;background:linear-gradient(135deg,rgba(125,183,255,.09),transparent 76%),#060c167a}.algorithm-metrics span{display:block;margin-bottom:5px;color:#e1e9f894;font-size:11px;font-weight:900}.algorithm-metrics strong{color:#fff;font-size:22px;line-height:1}.algorithm-metrics .constraint-tags{grid-column:1 / -1;border-color:#ffcb6929;background:linear-gradient(135deg,rgba(255,203,105,.1),transparent 72%),#060c167a}.algorithm-metrics .constraint-tags p{margin:0;color:#ffe6b4eb;font-size:13px;font-weight:900}.route-status-strip{display:flex;flex-wrap:wrap;gap:8px}.route-status-strip span{min-height:28px;display:inline-flex;align-items:center;padding:0 9px;border:1px solid rgba(255,203,105,.18);border-radius:999px;background:#ffcb6913;color:#ffe6b4e6;font-size:12px;font-weight:900}.summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:18px}.summary-card{position:relative;overflow:hidden;display:grid;gap:8px;padding:16px;border:1px solid var(--line);border-radius:15px;background:linear-gradient(150deg,rgba(255,255,255,.09),transparent 70%),#ffffff0b;box-shadow:var(--sharp-shadow);transition:transform .16s ease,border-color .16s ease,background-color .16s ease}.summary-card:after{position:absolute;top:0;right:0;width:54px;height:54px;background:linear-gradient(135deg,rgba(125,183,255,.16),transparent 70%);content:""}.summary-card svg{position:relative;z-index:1;color:var(--mint)}.summary-card span{color:var(--muted);font-size:13px}.summary-card strong{color:#fff;font-size:29px}.summary-card small{margin-left:4px;color:var(--muted);font-size:13px;font-weight:700}.summary-card:hover{border-color:#7db7ff47;background:linear-gradient(150deg,rgba(125,183,255,.1),transparent 70%),#ffffff0d;transform:translateY(-3px)}.notice-stack{display:grid;gap:10px;margin:16px 0 22px}.notice{display:flex;gap:10px;align-items:flex-start;padding:13px 15px;border-radius:13px;font-size:14px;line-height:1.6}.notice.success{border:1px solid rgba(125,183,255,.23);background:#7db7ff17;color:#edf7f4eb}.notice.warning{border:1px solid rgba(255,203,105,.26);background:#ffcb6917;color:#ffefcff2}.notice svg{flex:0 0 auto;margin-top:3px}.comparison-panel{margin:0 0 22px;padding:16px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(135deg,rgba(125,183,255,.075),transparent 70%),#ffffff09;box-shadow:var(--sharp-shadow)}.comparison-heading{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;margin-bottom:13px}.comparison-heading h3{margin:5px 0 0;color:#fff;font-size:20px}.comparison-heading p{max-width:370px;margin:0;color:var(--muted);font-size:13px;line-height:1.55;text-align:right}.comparison-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:11px}.comparison-card{display:grid;gap:12px;min-width:0;padding:14px;border:1px solid rgba(207,221,244,.11);border-radius:14px;background:#060c166b}.comparison-card.active{border-color:#ffcb6957;background:linear-gradient(135deg,rgba(255,203,105,.12),transparent 72%),#060c167a}.comparison-card-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.comparison-card-head strong{color:#fff;font-size:15px}.comparison-card-head span{flex:0 0 auto;min-height:24px;display:inline-flex;align-items:center;padding:0 8px;border:1px solid rgba(255,203,105,.22);border-radius:999px;background:#ffcb6917;color:#ffe6b4eb;font-size:11px;font-weight:900}.comparison-route-line{min-height:46px;color:#e1e9f8c7;font-size:13px;font-weight:800;line-height:1.55}.comparison-route-line span{display:inline}.comparison-route-line i{margin:0 6px;color:#7db7ffcc;font-style:normal}.comparison-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.comparison-stats span{min-height:27px;display:inline-flex;align-items:center;justify-content:center;padding:0 7px;border:1px solid rgba(207,221,244,.1);border-radius:999px;background:#ffffff0d;color:var(--soft);font-size:11px;font-weight:900;white-space:nowrap}.timeline-header{padding-top:18px;border-top:1px solid var(--line)}.timeline-header h3{margin:5px 0 0;color:#fff;font-size:22px}.timeline-header span:last-child{color:var(--soft);font-size:14px;font-weight:850}.route-timeline{position:relative;display:grid;gap:14px;margin:20px 0 0;padding:0;list-style:none}.route-timeline:before{position:absolute;top:24px;bottom:24px;left:18px;width:3px;border-radius:999px;background:linear-gradient(180deg,var(--mint),var(--blue),var(--amber),var(--rose));content:""}.timeline-item{position:relative;display:grid;grid-template-columns:38px minmax(0,1fr);gap:14px}.timeline-index{z-index:1;width:38px;height:38px;display:grid;place-items:center;border:2px solid rgba(255,255,255,.82);border-radius:50%;background:var(--amber);color:#07101d;font-weight:950;box-shadow:0 0 0 7px #ffcb691f}.timeline-content{position:relative;overflow:hidden;padding:17px;border:1px solid var(--line);border-radius:15px;background:#ffffff0b;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.timeline-content:before{position:absolute;top:0;bottom:0;left:0;width:4px;background:linear-gradient(180deg,var(--mint),var(--amber));content:""}.timeline-content:hover{border-color:#7db7ff57;background:#7db7ff0e;box-shadow:var(--sharp-shadow);transform:translateY(-2px)}.timeline-main h4{margin:0;color:#fff;font-size:19px}.timeline-main span,.route-meta span,.spot-facts span,.spot-rating{display:inline-flex;gap:6px;align-items:center}.timeline-main span{color:#91bfff;font-size:14px;font-weight:900;white-space:nowrap}.route-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.route-meta span{min-height:28px;padding:0 9px;border:1px solid rgba(207,221,244,.1);border-radius:999px;background:#ffffff0e;color:var(--muted);font-size:13px;font-weight:800}.route-level-label{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:8px 10px;border:1px solid rgba(125,183,255,.14);border-radius:999px;background:#7db7ff13;color:#e1e9f8b8;font-size:12px;font-weight:900}.route-level-label svg{color:var(--blue)}.internal-route-panel{position:relative;overflow:hidden;margin-top:14px;padding:14px;border:1px solid rgba(207,221,244,.12);border-radius:14px;background:linear-gradient(135deg,rgba(125,183,255,.08),transparent 62%),#060c1673}.internal-route-panel:not([open]){background:#060c165c}.internal-route-panel:before{position:absolute;inset:0 auto 0 0;width:3px;background:linear-gradient(180deg,var(--blue),var(--amber));content:""}.internal-route-head,.internal-route-foot{display:flex;justify-content:space-between;gap:12px;align-items:center}.internal-route-head{cursor:pointer;list-style:none}.internal-route-head::-webkit-details-marker{display:none}.internal-route-head:after{width:24px;height:24px;display:grid;place-items:center;border:1px solid rgba(207,221,244,.12);border-radius:50%;color:var(--amber);font-size:14px;content:"+"}.internal-route-panel[open] .internal-route-head:after{content:"-"}.internal-route-head span{display:inline-flex;align-items:center;gap:7px;color:#fff;font-size:14px;font-weight:950}.internal-route-head span svg{color:var(--amber)}.internal-route-head strong{color:#e1e9f8ad;font-size:13px;font-weight:850}.internal-map{position:relative;overflow:hidden;min-height:470px;margin-top:13px;border:1px solid rgba(207,221,244,.13);border-radius:13px;background:radial-gradient(circle at 22% 18%,rgba(125,183,255,.13),transparent 32%),radial-gradient(circle at 76% 80%,rgba(255,203,105,.08),transparent 26%),linear-gradient(135deg,#07101ef5,#081727f0 58%,#121416e6);box-shadow:inset 0 1px #ffffff14,0 18px 46px #0000003d}.internal-map:after{position:absolute;inset:12px;border:1px solid rgba(255,255,255,.07);border-radius:10px;content:"";pointer-events:none}.internal-map-grid,.internal-map-terrain,.internal-map-water,.internal-map-base,.internal-map-scan,.internal-map-line-layer{position:absolute;inset:0}.internal-map-base{background:linear-gradient(28deg,rgba(255,255,255,.025) 10%,transparent 10% 22%,rgba(255,255,255,.02) 22% 34%,transparent 34%),linear-gradient(118deg,transparent 0 44%,rgba(125,183,255,.04) 44.5% 45%,transparent 45.5%),#060e1ad6}.internal-map-grid{background:linear-gradient(0deg,rgba(255,255,255,.032) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);background-size:28px 28px}.internal-map-terrain{background:repeating-radial-gradient(circle at 51% 50%,transparent 0 46px,rgba(125,183,255,.048) 47px 48px,transparent 49px 72px),linear-gradient(118deg,transparent 0 45%,rgba(255,203,105,.045) 45.5% 46%,transparent 46.5% 100%);opacity:.78}.internal-map-water{inset:auto -8% -16% auto;width:36%;height:42%;border:1px solid rgba(98,168,255,.22);border-radius:52% 48% 42% 58%;background:linear-gradient(135deg,#62a8ff2e,#62a8ff0a),repeating-linear-gradient(145deg,rgba(255,255,255,.055) 0 1px,transparent 1px 12px);opacity:.72}.internal-map-zone{position:absolute;z-index:2;min-width:64px;padding:4px 7px;border:1px solid rgba(207,221,244,.08);border-radius:8px;background:#ffffff07;color:#e1e9f842;font-size:11px;font-weight:900;text-align:center;pointer-events:none}.zone-a{left:16%;top:66%}.zone-b{left:48%;top:28%}.zone-c{right:13%;bottom:19%}.internal-map-scan{inset:-34%;background:conic-gradient(from 22deg,transparent,rgba(125,183,255,.13),transparent 16%);opacity:.2;animation:slow-spin 18s linear infinite}.internal-map-title{position:absolute;top:16px;left:16px;z-index:4;display:grid;gap:4px;max-width:min(270px,calc(100% - 32px));padding:11px 13px;border:1px solid rgba(207,221,244,.12);border-radius:11px;background:#060c16b3;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.internal-map-title span{color:var(--mint);font-size:11px;font-weight:950}.internal-map-title strong{overflow:hidden;color:#fff;font-size:17px;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.internal-map-path-bg{fill:none;stroke:#cfddf42b;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}.internal-map-path-bg.main{stroke:#ffffff38;stroke-width:3.2}.internal-map-path-bg.secondary{stroke:#62a8ff3d;stroke-width:2.3;filter:drop-shadow(0 0 10px rgba(98,168,255,.22))}.internal-map-path-bg.branch{stroke:#cfddf421;stroke-width:1.1;stroke-dasharray:4 7}.internal-map-polyline{stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 12px rgba(255,203,105,.38));stroke-dasharray:190;stroke-dashoffset:190;animation:route-draw .85s ease forwards}.internal-map-polyline.glow{stroke-width:9;opacity:.16;filter:blur(1px)}.internal-map-polyline.trace{stroke:#ffffffe0;stroke-width:1.8;stroke-dasharray:10 128;stroke-dashoffset:0;opacity:0;filter:drop-shadow(0 0 10px rgba(88,208,255,.6));animation:route-draw .62s ease forwards,route-pulse 2.7s linear .7s infinite}.internal-segment-arrow{stroke:#ffffff7a;stroke-width:1.7;stroke-linecap:round;opacity:.42;filter:drop-shadow(0 0 8px rgba(88,208,255,.28))}.internal-segment-arrow.done{stroke:#58d0ffe0;opacity:.72}.internal-segment-arrow.active{stroke:#ffcb69;stroke-width:2.8;opacity:1;filter:drop-shadow(0 0 14px rgba(255,203,105,.56))}.internal-map-marker{position:absolute;z-index:5;display:grid;grid-template-columns:27px max-content;grid-template-rows:auto auto;column-gap:8px;align-items:center;max-width:190px;transform:translate(-13px,-13px);animation:marker-in .36s ease both;animation-delay:var(--delay, 0ms)}.internal-map-marker span{grid-row:1 / 3;width:27px;height:27px;display:grid;place-items:center;border:2px solid rgba(255,255,255,.9);border-radius:50%;background:var(--amber);color:#07101d;font-size:12px;font-weight:950;box-shadow:0 0 0 7px #ffcb6924,0 0 20px #ffcb696b}.internal-map-marker strong,.internal-map-marker small{min-width:0;padding:4px 8px;border:1px solid rgba(255,255,255,.11);background:#060c16b8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.internal-map-marker strong{max-width:136px;border-radius:9px 9px 0 0;color:#fff;font-size:12px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.internal-map-marker small{max-width:162px;border-top:0;border-radius:0 0 9px 9px;color:#e1e9f89e;font-size:11px;line-height:1.25;white-space:nowrap}.internal-map-marker.label-left{grid-template-columns:max-content 27px;transform:translate(calc(-100% + 13px),-13px)}.internal-map-marker.label-left span{grid-column:2}.internal-map-marker.label-left strong,.internal-map-marker.label-left small{grid-column:1}.internal-map-marker.label-left strong{grid-row:1}.internal-map-marker.label-left small{grid-row:2}.internal-map-marker.label-up{transform:translate(-13px,calc(-100% + 13px))}.internal-map-marker.label-left.label-up{transform:translate(calc(-100% + 13px),calc(-100% + 13px))}.internal-map-marker.is-current span{background:#fff;color:#1677ff;box-shadow:0 0 0 5px #1677ff38,0 0 24px #58d0ff80}.internal-map-marker.is-next span{background:#1677ff;color:#fff;box-shadow:0 0 0 5px #1677ff33,0 12px 22px #1677ff42}.internal-current-pin{position:absolute;z-index:7;display:inline-flex;align-items:center;gap:8px;transform:translate(-13px,-48px);pointer-events:none}.internal-current-pin span{position:relative;width:27px;height:27px;border:3px solid #ffffff;border-radius:50%;background:#1677ff;box-shadow:0 0 0 7px #1677ff2e,0 10px 22px #00000047}.internal-current-pin span:before{position:absolute;inset:-11px;border:1px solid rgba(88,208,255,.36);border-radius:inherit;content:"";animation:location-pulse 1.8s ease-out infinite}.internal-current-pin span:after{position:absolute;inset:7px;border-radius:inherit;background:#fff;content:""}.internal-current-pin.demo span,.internal-current-pin.outside span,.internal-current-pin.failed span,.internal-current-pin.locating span{background:#94a3b8;box-shadow:0 0 0 7px #94a3b829,0 10px 22px #00000038}.internal-current-pin.outside span,.internal-current-pin.failed span{background:#f59e0b;box-shadow:0 0 0 7px #f59e0b33,0 10px 22px #0000003d}.internal-current-pin strong{padding:6px 9px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#060c16c7;color:#fff;font-size:12px;font-weight:950;box-shadow:0 10px 22px #0000003d;white-space:nowrap}.internal-current-pin.demo strong,.internal-current-pin.outside strong,.internal-current-pin.failed strong,.internal-current-pin.locating strong{color:#e2e8f0}.location-alert-card{position:absolute;top:158px;right:64px;z-index:18;width:min(460px,calc(100% - 96px));display:grid;gap:5px;padding:12px 14px;border:1px solid rgba(245,158,11,.28);border-radius:14px;background:#0f172ae0;color:#fff;box-shadow:0 18px 38px #00000047,inset 0 1px #ffffff1f;pointer-events:none;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.location-alert-card span{color:#ffcb69;font-size:12px;font-weight:950}.location-alert-card strong{color:#fff;font-size:14px;font-weight:950;line-height:1.35}.location-alert-card small{color:#e2e8f0b8;font-size:12px;font-weight:850;line-height:1.35}.location-alert-card.locating{border-color:#1677ff3d}.location-alert-card.locating span{color:#7db7ff}.internal-map.practical-map .location-alert-card,.internal-map.real-map-ready .location-alert-card{border-color:#f59e0b38;background:#fffffff5;color:#0f172a;box-shadow:0 18px 38px #0f172a29,inset 0 1px #ffffffc2}.internal-map.practical-map .location-alert-card strong,.internal-map.real-map-ready .location-alert-card strong{color:#0f172a}.internal-map.practical-map .location-alert-card small,.internal-map.real-map-ready .location-alert-card small{color:#64748b}.map-direction-callout{position:absolute;z-index:12;display:grid;grid-template-columns:34px minmax(0,230px);gap:10px;align-items:center;max-width:min(320px,calc(100% - 36px));padding:10px 12px;border:1px solid rgba(255,203,105,.32);border-radius:12px;background:#0a1019db;box-shadow:0 18px 36px #00000052,0 0 0 1px #ffffff0a;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transform:translate(18px,-50%);pointer-events:none}.map-direction-callout.label-left{transform:translate(calc(-100% - 18px),-50%)}.map-direction-callout.label-up{transform:translate(18px,calc(-100% - 12px))}.map-direction-callout.label-left.label-up{transform:translate(calc(-100% - 18px),calc(-100% - 12px))}.map-direction-arrow{position:relative;width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#ffcb69,#ff8a00);box-shadow:0 0 0 7px #ffcb6924,0 10px 22px #ff8a0042;transform:rotate(var(--angle, 0deg))}.map-direction-arrow:before{position:absolute;top:50%;left:9px;width:15px;height:3px;border-radius:999px;background:#07101d;content:"";transform:translateY(-50%)}.map-direction-arrow:after{position:absolute;top:50%;right:8px;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:8px solid #07101d;content:"";transform:translateY(-50%)}.map-direction-callout div{min-width:0;display:grid;gap:3px}.map-direction-callout div>span{color:#ffcb69;font-size:11px;font-weight:950}.map-direction-callout strong{overflow:hidden;color:#fff;font-size:14px;font-weight:950;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.map-direction-callout small{color:#e1e9f8b8;font-size:12px;font-weight:850}.map-turn-pin{position:absolute;z-index:12;display:inline-flex;align-items:center;gap:6px;padding:6px 8px 6px 6px;border:1px solid rgba(22,119,255,.22);border-radius:999px;background:#fffffff0;color:#172033;box-shadow:0 10px 24px #0f172a2e;transform:translate(-50%,-50%);cursor:pointer}.map-turn-pin span{position:relative;width:22px;height:22px;border-radius:50%;background:#1677ff;transform:rotate(var(--angle, 0deg))}.map-turn-pin span:before{position:absolute;top:10px;left:6px;width:9px;height:2px;border-radius:999px;background:#fff;content:""}.map-turn-pin span:after{position:absolute;top:6px;right:5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:6px solid #ffffff;content:""}.map-turn-pin strong{color:#172033;font-size:12px;font-weight:950}.map-turn-pin small{color:#64748b;font-size:11px;font-weight:850;white-space:nowrap}.map-next-direction-card{position:absolute;top:16px;right:64px;z-index:17;width:min(460px,calc(100% - 96px));min-height:132px;display:grid;grid-template-columns:78px minmax(0,1fr);gap:13px;align-items:start;padding:13px 14px;border:1px solid rgba(255,203,105,.28);border-radius:16px;background:linear-gradient(135deg,#ffffff1f,#ffffff0b),#060c16cc;box-shadow:0 20px 44px #00000042,inset 0 1px #ffffff1f;color:#fff;pointer-events:none;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.map-next-direction-card:before{position:absolute;inset:0;border-radius:inherit;background:linear-gradient(90deg,rgba(255,203,105,.16),transparent 42%);content:"";pointer-events:none}.next-direction-icon{position:relative;z-index:1;width:78px;height:78px;display:grid;place-items:center;border:2px solid rgba(255,255,255,.9);border-radius:22px;background:linear-gradient(135deg,#ffcb69,#ff8a00);box-shadow:0 0 0 8px #ff8a0024,0 14px 30px #ff8a0038}.next-direction-icon:after{position:absolute;inset:9px;border:1px solid rgba(7,16,29,.14);border-radius:16px;content:""}.next-direction-icon i{position:relative;z-index:1;width:40px;height:8px;border-radius:999px;background:#07101d;transform:rotate(var(--angle, 0deg));transition:transform .22s ease}.next-direction-icon i:after{position:absolute;top:50%;right:-3px;border-top:13px solid transparent;border-bottom:13px solid transparent;border-left:18px solid #07101d;content:"";transform:translateY(-50%)}.next-direction-copy{position:relative;z-index:1;min-width:0;display:grid;gap:6px}.next-direction-copy>span{color:#ffcb69;font-size:12px;font-weight:950}.next-direction-copy>strong{color:#fff;font-size:26px;font-weight:950;line-height:1}.next-direction-copy>small{overflow:hidden;color:#eef5ffdb;font-size:14px;font-weight:900;line-height:1.32;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.next-direction-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-top:2px}.next-direction-stats span{min-width:0;display:grid;gap:2px;padding:7px 8px;border:1px solid rgba(255,203,105,.16);border-radius:10px;background:#ffffff0f}.next-direction-stats b{overflow:hidden;color:#ffcb69c2;font-size:10px;font-weight:950;line-height:1;text-overflow:ellipsis;white-space:nowrap}.next-direction-stats i{overflow:hidden;color:#fff;font-size:12px;font-style:normal;font-weight:950;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.map-next-direction-card.arrived{border-color:#58d0ff47}.map-next-direction-card.arrived .next-direction-icon{background:linear-gradient(135deg,#58d0ff,#1677ff);box-shadow:0 0 0 8px #1677ff24,0 14px 30px #1677ff38}.internal-map-metrics,.internal-map-gates{position:absolute;z-index:4;display:flex;flex-wrap:wrap;gap:7px;max-width:calc(100% - 32px)}.internal-map-metrics{top:16px;right:16px;justify-content:flex-end}.internal-map-gates{right:16px;bottom:116px}.internal-map-metrics span,.internal-map-gates span{min-height:26px;display:inline-flex;align-items:center;padding:0 9px;border:1px solid rgba(207,221,244,.12);border-radius:999px;background:#060c16a3;color:#e1e9f8bd;font-size:12px;font-weight:850;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.internal-map-gates span{border-color:#ffcb6929;background:#ffcb6913;color:#ffe6b4d6}.internal-map-scale{position:absolute;left:16px;bottom:16px;z-index:4;display:inline-grid;gap:4px;width:72px;color:#e1e9f8a8;font-size:11px;font-weight:900;text-align:center}.internal-map-scale span{height:5px;border-right:2px solid rgba(225,233,248,.62);border-bottom:2px solid rgba(225,233,248,.62);border-left:2px solid rgba(225,233,248,.62)}.internal-navigation-overlay{position:absolute;right:14px;bottom:14px;left:14px;z-index:10;display:grid;grid-template-columns:minmax(150px,.78fr) minmax(260px,1.42fr) auto;gap:12px;align-items:center;padding:13px;border:1px solid rgba(207,221,244,.16);border-radius:12px;background:#060c16d1;box-shadow:0 18px 36px #00000057;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.nav-location-block,.nav-next-block{min-width:0;display:grid;gap:4px}.nav-location-block span,.nav-next-block span{display:inline-flex;align-items:center;gap:6px;color:#7db7ff;font-size:11px;font-weight:950}.nav-location-block strong,.nav-next-block strong{overflow:hidden;color:#fff;font-size:15px;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.nav-next-block strong{white-space:normal}.nav-location-block small,.nav-next-block small{overflow:hidden;color:#e1e9f8ad;font-size:12px;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}.nav-next-block small{white-space:normal}.nav-step-detail{display:flex;flex-wrap:wrap;gap:6px}.nav-next-block .nav-step-detail span{min-height:24px;display:inline-flex;align-items:center;padding:0 8px;border:1px solid rgba(125,183,255,.18);border-radius:999px;background:#7db7ff1a;color:#e8f2ffe0;font-size:11px;font-weight:900}.nav-action-group{display:flex;gap:8px}.nav-action-group button{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 12px;border:1px solid rgba(125,183,255,.24);border-radius:999px;background:#7db7ff1f;color:#e8f2ff;font-size:12px;font-weight:900;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease;white-space:nowrap}.nav-action-group button:hover{border-color:#7db7ff75;background:#7db7ff33;transform:translateY(-1px)}.nav-action-group button.active{border-color:#ffcb696b;background:#ffcb6924;color:#fff2cf}.nav-progress-track{grid-column:1 / -1;overflow:hidden;height:4px;border-radius:999px;background:#cfddf41f}.nav-progress-track span{height:100%;display:block;border-radius:inherit;background:linear-gradient(90deg,#7db7ff,#58d0ff,#ffcb69);transition:width .26s ease}.turn-step-panel{grid-column:1 / -1;display:grid;gap:8px;padding:10px;border:1px solid rgba(125,183,255,.13);border-radius:11px;background:#ffffff0b}.turn-step-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.turn-step-head span{color:#7db7ff;font-size:11px;font-weight:950}.turn-step-head strong{min-width:0;overflow:hidden;color:#e1e9f8d1;font-size:12px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.turn-step-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:7px}.turn-step-item{min-width:0;display:grid;grid-template-columns:26px minmax(0,1fr);grid-template-rows:auto auto;column-gap:8px;row-gap:2px;align-items:start;padding:9px;border:1px solid rgba(207,221,244,.1);border-radius:10px;background:#060c1657;color:#e8f2ff;text-align:left;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}.turn-step-item:hover{border-color:#7db7ff52;background:#7db7ff1a}.turn-step-item>span{grid-row:1 / 3;width:26px;height:26px;display:grid;place-items:center;border-radius:50%;background:#7db7ff29;color:#9fcaff;font-size:11px;font-weight:950}.turn-step-item strong{min-width:0;overflow:hidden;color:#fff;font-size:12px;font-weight:900;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.turn-step-item small{color:#e1e9f89e;font-size:11px;font-weight:800;line-height:1.25}.turn-step-item.active{border-color:#ffcb696b;background:#ffcb6921;box-shadow:inset 0 0 0 1px #ffcb6914,0 10px 22px #ffcb6914}.turn-step-item.active>span{background:#ffcb69;color:#07101d}.turn-step-item.done{border-color:#58d0ff33}.turn-step-item.done>span{background:#58d0ff2e;color:#c8f2ff}.internal-step-strip{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:7px}.internal-step-chip{min-width:0;display:grid;grid-template-columns:24px minmax(0,1fr);grid-template-rows:auto auto;column-gap:8px;align-items:center;padding:8px;border:1px solid rgba(207,221,244,.12);border-radius:10px;background:#ffffff0a;color:#e8f2ff;text-align:left;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease}.internal-step-chip:hover{border-color:#7db7ff57;background:#7db7ff1a;transform:translateY(-1px)}.internal-step-chip span{grid-row:1 / 3;width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:#7db7ff24;color:#9fcaff;font-size:11px;font-weight:950}.internal-step-chip strong,.internal-step-chip small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.internal-step-chip strong{color:#fff;font-size:12px;font-weight:950}.internal-step-chip small{color:#e1e9f89e;font-size:11px;font-weight:800}.internal-step-chip.active{border-color:#ffcb6961;background:#ffcb691f;box-shadow:inset 0 0 0 1px #ffcb6914}.internal-step-chip.active span{background:#ffcb69;color:#07101d}.internal-step-chip.done{border-color:#58d0ff38}.internal-step-chip.done span{background:#58d0ff2e;color:#c8f2ff}.nav-next-preview{grid-column:1 / -1;overflow:hidden;padding-top:2px;color:#e1e9f894;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.internal-map.practical-map{border-color:#1f29371f;background:#eef2f5;box-shadow:inset 0 1px #ffffffbf,0 16px 34px #0000002e}.internal-map.practical-map:after{border-color:#1f29371a}.internal-map.practical-map .internal-map-base{background:linear-gradient(27deg,transparent 0 28%,rgba(255,255,255,.68) 28.5% 31%,transparent 31.5%),linear-gradient(117deg,transparent 0 42%,rgba(205,214,224,.68) 42.5% 43.1%,transparent 43.6%),#eef2f5}.internal-map.practical-map .internal-map-grid{background:linear-gradient(0deg,rgba(71,85,105,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(71,85,105,.035) 1px,transparent 1px);background-size:30px 30px}.internal-map.practical-map .internal-map-terrain{background:linear-gradient(150deg,rgba(221,232,224,.74),transparent 48%),repeating-radial-gradient(circle at 52% 50%,transparent 0 48px,rgba(116,129,145,.06) 49px 50px,transparent 51px 76px);opacity:.9}.internal-map.practical-map .internal-map-water{border-color:#4b9ad638;background:linear-gradient(135deg,#97cdee94,#c4e6f97a),repeating-linear-gradient(145deg,rgba(255,255,255,.5) 0 1px,transparent 1px 12px);opacity:.92}.internal-map.practical-map .internal-map-zone{border-color:#1f293717;background:#ffffff8f;color:#47556994}.internal-map.practical-map .internal-map-title,.internal-map.practical-map .internal-map-metrics span,.internal-map.practical-map .internal-map-gates span{border-color:#1f29371a;background:#ffffffe6;box-shadow:0 8px 18px #0f172a1a}.internal-map.practical-map .internal-map-title span{color:#1677ff}.internal-map.practical-map .internal-map-title strong,.internal-map.practical-map .internal-map-metrics span{color:#172033}.internal-map.practical-map .internal-map-gates span{color:#7c4a03}.internal-map.practical-map .internal-map-path-bg.main{stroke:#fffffffa;stroke-width:4.5}.internal-map.practical-map .internal-map-path-bg.secondary{stroke:#ffffffe6;stroke-width:3.4;filter:none}.internal-map.practical-map .internal-map-path-bg.branch{stroke:#94a3b8cc;stroke-width:1.5;stroke-dasharray:none}.internal-map.practical-map .internal-map-polyline{stroke:#1677ff!important;stroke-width:3.8;filter:drop-shadow(0 2px 5px rgba(22,119,255,.24))}.internal-map.practical-map .internal-map-polyline.glow{stroke:#1677ff38!important;stroke-width:10;opacity:.36}.internal-map.practical-map .internal-map-polyline.trace{stroke:#ffffffe6!important}.internal-map.practical-map .internal-segment-arrow{stroke:#1677ff85;filter:none}.internal-map.practical-map .internal-segment-arrow.active{stroke:#ff8a00;filter:drop-shadow(0 2px 5px rgba(255,138,0,.28))}.internal-map.practical-map .internal-map-marker span{border-color:#fff;background:#1677ff;color:#fff;box-shadow:0 0 0 4px #1677ff1f,0 8px 18px #0f172a29}.internal-map.practical-map .internal-map-marker strong,.internal-map.practical-map .internal-map-marker small{border-color:#1f29371a;background:#fffffff0;color:#1f2937;box-shadow:0 8px 18px #0f172a1a}.internal-map.practical-map .internal-map-marker small{color:#64748b}.internal-map.practical-map .internal-map-scale{color:#475569}.internal-map.practical-map .internal-map-scale span{border-color:#475569b8}.internal-map.practical-map .map-next-direction-card,.internal-map.real-map-ready .map-next-direction-card{border-color:#1677ff24;background:#fffffff5;box-shadow:0 18px 38px #0f172a29,inset 0 1px #ffffffc2;color:#0f172a}.internal-map.practical-map .map-next-direction-card:before,.internal-map.real-map-ready .map-next-direction-card:before{background:linear-gradient(90deg,rgba(22,119,255,.09),transparent 48%)}.internal-map.practical-map .next-direction-copy>span,.internal-map.real-map-ready .next-direction-copy>span{color:#1677ff}.internal-map.practical-map .next-direction-copy>strong,.internal-map.real-map-ready .next-direction-copy>strong{color:#0f172a}.internal-map.practical-map .next-direction-copy>small,.internal-map.real-map-ready .next-direction-copy>small{color:#334155}.internal-map.practical-map .next-direction-stats span,.internal-map.real-map-ready .next-direction-stats span{border-color:#1677ff1c;background:#1677ff0e}.internal-map.practical-map .next-direction-stats b,.internal-map.real-map-ready .next-direction-stats b{color:#1677ff}.internal-map.practical-map .next-direction-stats i,.internal-map.real-map-ready .next-direction-stats i{color:#0f172a}.spots-section{margin-top:22px;padding:24px}.section-heading{align-items:end;margin-bottom:20px}.section-heading h2{margin:7px 0 0;color:#fff;font-size:30px}.section-heading p{max-width:560px;margin:0;color:var(--muted);line-height:1.7}.spots-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.spot-card{position:relative;overflow:hidden;min-height:286px;display:flex;flex-direction:column;padding:16px;border:1px solid var(--line);border-radius:16px;background:#ffffff0b;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.spot-card:before{position:absolute;inset:0 0 auto;height:2px;background:var(--spot-accent, var(--mint));content:""}.spot-card:nth-child(2n){--spot-accent: var(--blue)}.spot-card:nth-child(3n){--spot-accent: var(--amber)}.spot-card:nth-child(4n){--spot-accent: var(--rose)}.spot-card:hover{border-color:#7db7ff52;background:#7db7ff0d;box-shadow:var(--sharp-shadow);transform:translateY(-4px)}.spot-visual{position:relative;min-height:96px;margin:-2px -2px 14px;overflow:hidden;border:1px solid rgba(207,221,244,.12);border-radius:13px;background:linear-gradient(135deg,rgba(125,183,255,.18),transparent 54%),radial-gradient(circle at 82% 18%,rgba(255,203,105,.18),transparent 34%),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(180deg,rgba(255,255,255,.036) 1px,transparent 1px),#060c16b8;background-size:auto,auto,24px 24px,24px 24px,auto}.spot-visual:before{position:absolute;inset:12px;border:1px solid rgba(255,255,255,.075);border-radius:9px;content:""}.spot-visual:after{position:absolute;right:-26px;bottom:-44px;width:132px;height:132px;border:1px solid rgba(255,203,105,.26);border-radius:50%;content:""}.spot-visual span{position:absolute;right:14px;bottom:11px;color:#fff;font-size:33px;font-weight:950;line-height:1}.spot-visual strong{position:absolute;left:13px;bottom:10px;color:#ffffff29;font-size:50px;font-weight:950;line-height:.9}.spot-card[data-spot=dianchi-haigeng-park] .spot-visual,.spot-card[data-spot=yunnan-nationalities-village] .spot-visual{background:linear-gradient(135deg,rgba(98,168,255,.2),transparent 52%),radial-gradient(circle at 82% 20%,rgba(255,203,105,.15),transparent 34%),repeating-linear-gradient(150deg,rgba(255,255,255,.055) 0 1px,transparent 1px 14px),#060c16bd}.spot-card[data-spot=yunnan-museum] .spot-visual,.spot-card[data-spot=guandu-old-town] .spot-visual{background:linear-gradient(135deg,rgba(255,203,105,.2),transparent 48%),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(180deg,rgba(255,255,255,.035) 1px,transparent 1px),#14120db8;background-size:auto,24px 24px,24px 24px,auto}.spot-rating{color:var(--amber);font-weight:900}.spot-card h3{margin:14px 0 8px;color:#fff;font-size:20px}.spot-card p{flex:1;margin:0;color:var(--muted);line-height:1.65}.spot-facts{display:grid;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);color:#f7fffcc2;font-size:13px;font-weight:800}@keyframes slow-spin{to{transform:rotate(360deg)}}@keyframes route-draw{to{stroke-dashoffset:0}}@keyframes route-pulse{0%{opacity:0;stroke-dashoffset:0}12%,72%{opacity:.86}to{opacity:0;stroke-dashoffset:-150}}@keyframes marker-breathe{0%,to{box-shadow:0 0 0 8px #ffcb6924,0 0 24px #ffcb696b}50%{box-shadow:0 0 0 12px #ffcb6914,0 0 34px #ffcb6994}}@keyframes marker-in{0%{opacity:0;transform:translate(-14px,-4px) scale(.78)}to{opacity:1;transform:translate(-14px,-14px) scale(1)}}@keyframes location-pulse{0%{opacity:.72;transform:scale(.68)}to{opacity:0;transform:scale(1.6)}}@keyframes surface-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes button-sheen{0%,66%{transform:translate(-120%)}to{transform:translate(120%)}}@media(max-width:1260px){.workspace-grid{grid-template-columns:340px minmax(0,1fr)}.route-dashboard{display:grid;grid-template-columns:1fr;gap:16px}.result-command{position:relative;inset:auto;width:auto;max-height:none;grid-template-columns:minmax(0,1fr) 220px;align-items:start}.route-map-panel,.route-map{min-height:520px}.result-score{grid-row:span 2}.result-command-meta{grid-column:1 / -1;grid-template-columns:repeat(3,minmax(0,1fr))}.summary-grid,.spots-grid,.comparison-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:920px){.app-shell{padding:16px}.app-header,.workspace-grid{grid-template-columns:1fr}.app-header{min-height:auto;padding:26px}.hero-instrument{min-height:170px}.form-panel{position:static}}@media(max-width:620px){.app-shell{padding:12px}.app-header{padding:20px}.app-header h1{font-size:36px}.app-header p{font-size:15px}.author-credit{margin:10px 0 0}.hero-instrument strong{font-size:58px}.field-row,.summary-grid,.spots-grid,.comparison-grid,.algorithm-metrics,.section-heading,.comparison-heading,.timeline-main,.result-command,.result-command-meta,.route-dashboard{grid-template-columns:1fr}.panel-heading,.section-heading,.comparison-heading,.timeline-header,.timeline-main,.internal-route-head{align-items:flex-start;flex-direction:column}.route-result,.spots-section,.search-form{padding:16px}.comparison-heading p{max-width:none;text-align:left}.comparison-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.route-map,.route-map-panel{min-height:360px}.result-empty,.result-empty .route-map{min-height:540px}.empty-copy{right:18px;bottom:18px;width:calc(100% - 36px);padding:18px}.map-caption{left:18px;bottom:18px}.map-data-strip{top:16px;left:16px}.map-data-strip span{min-height:24px;font-size:10px}.map-marker strong{display:none}.map-district{font-size:32px}.timeline-main span{white-space:normal}.internal-route-panel{padding:12px}.internal-map{min-height:560px}.map-next-direction-card{top:58px;right:10px;left:10px;width:auto;min-height:auto;grid-template-columns:52px minmax(0,1fr);gap:9px;padding:9px;border-radius:14px}.next-direction-icon{width:52px;height:52px;border-radius:16px;box-shadow:0 0 0 5px #ff8a0021,0 10px 22px #ff8a002e}.next-direction-icon i{width:28px;height:6px}.next-direction-icon i:after{border-top-width:9px;border-bottom-width:9px;border-left-width:13px}.next-direction-copy{gap:4px}.next-direction-copy>span{font-size:11px}.next-direction-copy>strong{font-size:20px}.next-direction-copy>small{font-size:12px;-webkit-line-clamp:1}.next-direction-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px}.next-direction-stats span{padding:5px 6px;border-radius:8px}.next-direction-stats b{font-size:9px}.next-direction-stats i{font-size:10px}.internal-map-title,.internal-map-metrics,.internal-map-gates{left:12px;right:12px;justify-content:flex-start;max-width:calc(100% - 24px)}.internal-map-metrics{top:76px}.internal-map-gates{bottom:178px}.internal-map-marker strong,.internal-map-marker small{display:none}.internal-navigation-overlay{grid-template-columns:1fr;gap:9px}.internal-map:fullscreen .map-fullscreen-button{top:12px;right:12px;min-height:34px;padding:0 12px;border-radius:999px;font-size:13px}.internal-map:fullscreen .map-next-direction-card{top:56px;right:10px;left:10px;width:auto}.location-alert-card,.internal-map:fullscreen .location-alert-card{top:150px;right:10px;left:10px;width:auto;padding:9px 10px;border-radius:12px}.location-alert-card strong{font-size:12px;display:-webkit-box;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical}.location-alert-card small{display:none}.internal-map:fullscreen .internal-navigation-overlay{right:10px;bottom:10px;left:10px;max-height:30vh;grid-template-columns:1fr;gap:8px;padding:10px;overflow-y:auto;border-radius:14px}.internal-map:fullscreen .nav-location-block small,.internal-map:fullscreen .nav-next-block small,.internal-map:fullscreen .nav-next-preview{display:none}.internal-map:fullscreen .nav-location-block strong,.internal-map:fullscreen .nav-next-block strong{font-size:15px;line-height:1.25}.internal-map:fullscreen .nav-step-detail{overflow-x:auto;flex-wrap:nowrap;padding-bottom:1px}.internal-map:fullscreen .nav-step-detail span{flex:0 0 auto}.internal-map:fullscreen .nav-action-group{grid-template-columns:repeat(3,minmax(0,1fr))}.internal-map:fullscreen .nav-action-group button{min-height:32px;padding:0 7px;font-size:11px}.internal-map:fullscreen .nav-progress-track{height:3px}.internal-step-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.turn-step-head{align-items:flex-start;flex-direction:column}.turn-step-list{grid-template-columns:1fr}.nav-next-preview{white-space:normal}.nav-action-group{display:grid;grid-template-columns:1fr 1fr}.nav-action-group button{min-width:0;padding:0 8px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important}}
