:root{color-scheme:dark;font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;--bg-0: #08111d;--bg-1: #0f1f34;--panel: rgba(21, 36, 57, .68);--panel-strong: rgba(26, 45, 72, .82);--line: rgba(164, 203, 255, .18);--text: #e8f2ff;--muted: #9fb3cc;--accent: #3f8cff;--accent-2: #f97316}*{box-sizing:border-box}html,body,#root{margin:0;width:100%;height:100%;overflow-x:hidden}body{color:var(--text);background:radial-gradient(circle at 6% 10%,rgba(116,168,255,.22),transparent 38%),radial-gradient(circle at 96% 92%,rgba(122,245,204,.14),transparent 40%),linear-gradient(145deg,var(--bg-0) 0%,var(--bg-1) 100%);overflow:hidden}.app-shell{height:100vh;display:grid;grid-template-columns:350px 1fr;gap:14px;padding:16px;overflow:hidden}.glass-panel{border:1px solid var(--line);border-radius:16px;background:linear-gradient(155deg,rgba(34,57,88,.62),var(--panel));-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px)}.left-sidebar{padding:14px;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden}.brand-block{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:11px}.brand-actions{display:inline-flex;align-items:center;gap:1px;flex-shrink:0}.brand-copy{min-width:0;flex:1}.brand-title{margin:0;font-size:.98rem;line-height:1.2;white-space:nowrap}.brand-subtitle{margin:4px 0 0;color:var(--muted);font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-intro .brand-subtitle{opacity:0;transform:translateY(8px);transition:opacity .62s cubic-bezier(.22,1,.36,1) 0ms,transform .62s cubic-bezier(.22,1,.36,1) 0ms}.page-intro.is-ready .brand-subtitle{opacity:1;transform:translateY(0)}.route-list-wrap{flex:1;overflow:visible;padding-right:4px}.mobile-route-toggle{display:none}.sidebar-scroll-region{display:block}.mobile-route-list-panel{min-height:0}.mobile-route-panel-footer{display:none}.page-intro .route-list-wrap,.page-intro .map-area,.page-intro .detail-area{opacity:0;transform:translateY(4px);transition:opacity .48s cubic-bezier(.22,1,.36,1),transform .48s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}.page-intro .map-area{transition:opacity .52s cubic-bezier(.22,1,.36,1) .14s,transform .52s cubic-bezier(.22,1,.36,1) .14s}.page-intro .detail-area{transition-delay:.34s}.page-intro .route-list-wrap{transition-delay:.26s}.page-intro.is-ready .route-list-wrap,.page-intro.is-ready .map-area,.page-intro.is-ready .detail-area{opacity:1;transform:translateY(0)}.sidebar-footer{margin-top:24px;padding:0 4px 4px;display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;font-size:12px;font-weight:500;letter-spacing:.02em;color:#a0b6d28f}.sidebar-footer-copy{text-align:center}.feedback-link{border:0;background:transparent;color:#a8bddba8;padding:2px 0;display:inline-flex;align-items:center;gap:6px;line-height:1;font-size:11px;font-weight:450;cursor:pointer;transition:color .14s ease}.feedback-link:hover{color:#c4d8f4e6}.feedback-link-icon{width:14px;height:14px;display:inline-flex;align-items:center;justify-content:center;color:#b0caecbd}.feedback-link-icon svg{width:100%;height:100%;display:block}.feedback-link-text{white-space:nowrap}.route-group{margin-bottom:10px;border:1px solid rgba(150,190,240,.16);border-radius:12px;background:#0a121e85}.route-group.active{border-color:#3f8cff8c}.route-group-button{width:100%;border:0;border-bottom:1px solid rgba(143,176,221,.12);border-radius:12px 12px 0 0;background:#111e306b;color:inherit;text-align:left;padding:10px 11px;cursor:pointer}.route-group-button>div{min-width:0}.group-zh{margin:0;font-size:.96rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-en{margin:4px 0 0;color:var(--muted);font-size:.8rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-meta{margin-top:8px;display:flex;gap:12px;align-items:center;color:#d7e7ff;font-size:.78rem}.hot-level{color:var(--accent-2)}.group-tagline{margin-top:6px;color:var(--muted);font-size:.78rem}.group-route{margin-top:6px;color:#c7dbf8;font-size:.76rem;text-align:left;overflow-wrap:anywhere;word-break:break-word;white-space:normal;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2}.variant-list{padding:10px;display:grid;gap:8px}.variant-card{border:1px solid rgba(143,176,221,.2);border-radius:10px;background:#111c2db3;color:inherit;text-align:left;padding:10px;cursor:pointer;line-height:1.35}.variant-card.active{border-color:var(--accent);background:#1c365aa3;box-shadow:inset 0 0 0 1px #3f8cff52}.variant-head{display:flex;justify-content:space-between;gap:8px;align-items:center;min-width:0}.variant-head strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.variant-en{color:var(--muted);font-size:.75rem;margin-top:2px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.variant-meta{margin-top:6px;display:grid;grid-template-columns:1fr auto;align-items:center;justify-content:space-between;font-size:.78rem;color:#d5e5ff;gap:8px}.variant-meta-left{text-align:left}.variant-meta-right{text-align:right;white-space:nowrap;display:inline-flex;align-items:center;gap:8px}.variant-hot{font-size:.72rem}.variant-route{margin-top:6px;color:#c7dbf8;font-size:.76rem;line-height:1.35;text-align:left;overflow-wrap:anywhere;word-break:break-word;white-space:normal;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2}.fav-dot{color:var(--accent);font-size:.74rem}.shell-bag-entry{border:1px solid rgba(63,140,255,.45);border-radius:9px;background:#182d40ad;color:inherit;font-weight:500;font-size:.82rem;line-height:1;padding:6px 8px;display:flex;align-items:center;flex-shrink:0;gap:6px;cursor:pointer}.header-icon-button,.shell-bag-entry-icononly{width:42px;height:42px;padding:0;margin-top:0;border:none;background:transparent;box-shadow:none;justify-content:center;border-radius:0;position:relative;display:inline-flex;align-items:center;cursor:pointer;transition:opacity .14s ease,transform .14s ease}.header-icon-button:hover,.shell-bag-entry-icononly:hover{opacity:.92;transform:translateY(-1px)}.header-icon-button{color:#a9c5ecc7}.header-icon-button-icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center}.header-icon-button-icon svg{width:100%;height:100%;display:block}.history-entry-icon-image{width:100%;height:100%;display:block;object-fit:contain;object-position:center;image-rendering:-webkit-optimize-contrast}.history-entry-button{margin-right:-2px;top:1px}.shell-bag-icon{display:inline-flex;color:#9ac5ff;line-height:0}.shell-bag-entry-icononly .shell-bag-icon{width:28px;height:28px;transform:translateY(0)}.shell-bag-custom-icon{width:100%;height:100%;display:block;object-fit:contain;object-position:center;filter:none}.shell-bag-count{margin-left:auto;min-width:18px;text-align:center;border-radius:999px;background:#3f8cff47;padding:1px 6px;font-size:.72rem}.shell-bag-entry-icononly .shell-bag-count{position:absolute;top:2px;right:2px;transform:translate(26%,-22%);margin-left:0;min-width:14px;height:14px;padding:0 3px;line-height:12px;font-size:.58rem;font-weight:600;border-radius:999px;border:1px solid rgba(157,189,233,.33);background:#0a1423e6;color:#e8f1ff;display:inline-flex;align-items:center;justify-content:center;pointer-events:none}.right-main{display:flex;flex-direction:column;gap:14px;height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:2px}.map-area,.detail-area{padding:14px;min-height:0}.map-area{flex:0 0 clamp(380px,46vh,440px);overflow:hidden}.detail-area{flex:0 0 auto;overflow:visible}.map-view{height:100%;display:flex;flex-direction:column}.map-head h2{margin:0}.map-head p{margin:4px 0 8px;color:var(--muted);font-size:.9rem}.map-canvas{flex:1;border-radius:12px;border:1px solid rgba(123,164,219,.2);background:#070c1259;overflow:hidden;position:relative}.real-map .maplibregl-canvas-container,.real-map .maplibregl-canvas{width:100%!important;height:100%!important}.real-map .maplibregl-ctrl-bottom-right{margin:0 8px 8px 0}.map-placeholder{display:grid;place-items:center;height:100%;color:var(--muted)}.map-status-badge{position:absolute;top:12px;right:12px;z-index:14;display:inline-flex;flex-direction:column;align-items:flex-end;gap:2px;padding:7px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#091222c2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 22px #0309122e;color:#f4f8fff0;font-size:.72rem;line-height:1.2;letter-spacing:.03em;text-align:right;max-width:min(220px,calc(100% - 24px));opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .18s ease,transform .18s ease}.map-status-badge.visible{opacity:1;transform:translateY(0)}.map-status-badge-title{font-weight:600}.map-status-badge-note{color:#d6e2f4c2;font-size:.68rem;letter-spacing:.02em}.route-marker-popup .maplibregl-popup-content{background:#091222f0;color:#fff;border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:8px 10px;box-shadow:0 10px 24px #03091273}.route-marker-popup .maplibregl-popup-tip{border-top-color:#091222f0;border-bottom-color:#091222f0}.popup-title{font-size:.84rem;color:#fff}.popup-sub{margin-top:2px;font-size:.74rem;color:#ffffffc7}.popup-label{font-size:.7rem;letter-spacing:.04em;color:#ffffff9e;margin-bottom:2px}.route-marker{width:22px;height:22px;padding:0;border:0;background:transparent;position:relative;border-radius:999px;cursor:pointer;display:grid;place-items:center}.route-marker-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;border:1.5px solid rgba(255,255,255,.9);background:#0912225c;box-shadow:0 4px 10px #09122242}.route-marker-core{width:12px;height:12px;border-radius:999px;background:#091222e0;border:1px solid rgba(232,240,255,.68);display:grid;place-items:center;position:relative;z-index:1}.route-marker-dot{width:5px;height:5px;border-radius:999px;background:#d8b07a}.route-detail-empty{min-height:200px;display:grid;place-items:center;color:var(--muted)}.route-detail{height:auto;overflow:visible}.detail-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.detail-top{padding-bottom:10px;border-bottom:1px solid rgba(143,176,221,.18)}.detail-main{min-width:0;flex:1}.detail-side{width:180px;display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.detail-rates{display:grid;gap:9px;width:100%}.detail-rate-block{display:grid;gap:5px;justify-items:end}.detail-rate-block span{font-size:.78rem;color:var(--muted)}.detail-rate-block strong{color:#ffd39a;font-size:.9rem;line-height:1}.difficulty-bars{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;width:120px}.difficulty-bars i{display:block;height:7px;border-radius:4px;background:#8ba5c452}.difficulty-bars i.active{background:linear-gradient(90deg,#f4ae5cf2,#ec7038f2)}.detail-header h2{margin:0}.detail-header p{margin:0;color:var(--muted)}.detail-title{font-size:1.28rem;font-weight:700;color:#f2f7ff;line-height:1.2}.detail-subtitle{margin-top:5px!important;font-size:.86rem;color:#e8f2ffb8!important;overflow-wrap:anywhere}.detail-route-line{margin-top:8px!important;color:#dbe9ff!important;font-size:.88rem;line-height:1.4;overflow-wrap:anywhere}.detail-summary{margin-top:10px!important;font-size:.86rem;line-height:1.45;color:#e8f2ffd6!important}.route-hook{margin-top:18px;margin-bottom:18px;display:inline-flex;align-items:stretch;gap:12px;width:fit-content;max-width:min(78%,820px);padding:0;border-radius:0;border:none;background:transparent;box-shadow:none}.route-hook-line{width:2px;border-radius:999px;background:#84b0f557;flex-shrink:0}.route-hook-body{display:grid;gap:5px;min-width:0}.route-hook-kicker{display:inline-flex;align-items:center;min-width:0}.route-hook-kicker-text{font-size:10.5px;letter-spacing:.03em;text-transform:none;font-weight:400;color:#b8cff08f;line-height:1}.route-hook-text{margin:0;color:#d4e0efd1;font-size:14px;font-weight:430;line-height:1.42;overflow-wrap:anywhere}.route-hook-line-text{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-favorite-btn{margin-top:40px}@media (max-width: 1080px){.route-hook{max-width:100%;align-items:flex-start}}.detail-branch-note{margin-top:10px!important;font-size:.83rem;color:#e8f2ffdb!important}.favorite-btn{border:1px solid rgba(122,245,204,.45);border-radius:10px;background:#13303799;color:inherit;padding:8px 10px;cursor:pointer;white-space:nowrap;justify-self:end}.detail-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:16px 0 12px}.detail-stats>div{border:1px solid rgba(143,176,221,.2);border-radius:10px;padding:10px;background:#0e192aa6}.detail-stats span{color:var(--muted);font-size:.78rem;display:block;margin-bottom:6px}.detail-stats strong{font-size:.92rem}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-block{border:1px solid rgba(143,176,221,.2);border-radius:10px;padding:10px;background:#0e192aa6}.detail-block h3{margin:0 0 8px;font-size:.9rem}.detail-block p,.detail-block li{color:#d9e8ff;font-size:.88rem}.detail-block ul{margin:0;padding-left:18px;display:grid;gap:5px}.keep-together{white-space:nowrap}.empty-field{margin:0;color:var(--muted)}.drawer-root{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:38}.drawer-root.open{pointer-events:auto}.drawer-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#02070c6b;opacity:0}.drawer-root.open .drawer-backdrop{opacity:1}.drawer-panel{position:absolute;top:0;right:0;width:min(420px,94vw);height:100%;border-left:1px solid rgba(255,255,255,.14);border-radius:20px 0 0 20px;background:#091222f5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transform:translate(100%);display:flex;flex-direction:column}.drawer-root.open .drawer-panel{transform:translate(0)}.drawer-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;border-bottom:1px solid rgba(255,255,255,.12);padding:14px}.drawer-header h3{margin:0;color:#fff}.drawer-header p{margin:4px 0 0;font-size:.82rem;color:#ffffffd6}.drawer-actions{display:flex;gap:8px}.drawer-actions button{border:1px solid rgba(255,255,255,.22);background:#ffffff0f;color:#ffffffeb;border-radius:8px;padding:6px 9px;cursor:pointer;white-space:nowrap}.drawer-actions button:disabled{opacity:.45;cursor:default}.drawer-content{padding:12px 12px 16px;display:grid;gap:10px;overflow:auto}.drawer-item{border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:10px;display:grid;gap:8px;background:#ffffff0f}.drawer-item-head{display:grid;gap:2px}.drawer-item-head strong{color:#fff;font-size:.95rem}.drawer-item-head span{color:#ffffffeb;font-size:.86rem}.drawer-item-sub{margin:0;color:#ffffffc7;font-size:.76rem}.drawer-item-meta{display:flex;flex-wrap:wrap;gap:6px}.drawer-item-meta span{color:#ffffffeb;font-size:.75rem;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;border-radius:999px;padding:2px 8px}.drawer-item-note{margin:0;color:#ffffffd1;font-size:.8rem;line-height:1.4}.drawer-item-actions{display:flex;justify-content:space-between;gap:8px}.drawer-item-actions button{border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#ffffff0f;color:#ffffffeb;text-align:center;padding:7px 10px;cursor:pointer;flex:1}.drawer-empty{color:#dce8f8c2;font-size:14px;line-height:1.5;font-weight:400;text-align:center}.history-modal-root{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:22px;pointer-events:none;z-index:46}.history-modal-root.open{pointer-events:auto}.history-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#040a13ad;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);opacity:0;transition:opacity .22s ease}.history-modal-root.open .history-modal-backdrop{opacity:1}.history-modal-panel{position:relative;width:min(980px,94vw);max-height:78vh;display:flex;flex-direction:column;border-radius:22px;border:1px solid rgba(164,203,255,.18);background:linear-gradient(160deg,#13233af0,#0b1627eb);box-shadow:0 30px 64px #030a156b,0 0 0 1px #6897d50f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);opacity:0;transform:translateY(14px);transition:opacity .22s ease,transform .24s cubic-bezier(.22,1,.36,1);overflow:hidden}.history-modal-root.open .history-modal-panel{opacity:1;transform:translateY(0)}.history-modal-header{display:flex;justify-content:space-between;gap:28px;align-items:flex-start;padding:28px 34px 20px 38px;border-bottom:1px solid rgba(164,203,255,.12)}.history-modal-heading{min-width:0;max-width:720px;margin-left:54px}.history-modal-kicker{margin:0 0 12px;font-size:.62rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#b0c6e480}.history-modal-header h3{margin:0;max-width:12ch;font-size:18px;line-height:1.14;letter-spacing:.12em;color:#f5f9ff;text-wrap:balance}.history-modal-subtitle{margin:14px 0 0;max-width:40ch;font-size:.78rem;line-height:1.58;letter-spacing:.01em;color:#c0d2e99e;text-wrap:pretty}.history-modal-close{width:30px;height:30px;border:1px solid rgba(164,203,255,.18);border-radius:10px;background:#0f1c2e9e;color:#d6e4f7bd;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.history-modal-close:hover{border-color:#a4cbff42;background:#14243ac7;color:#e7f0fce6;transform:translateY(-1px)}.history-modal-close svg{width:12px;height:12px;display:block}.history-modal-body{overflow:auto;padding:18px 38px 34px;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:rgba(171,191,217,.22) rgba(8,16,28,.18)}.history-modal-body::-webkit-scrollbar{width:8px}.history-modal-body::-webkit-scrollbar-track{background:#08101c29;border-radius:999px}.history-modal-body::-webkit-scrollbar-thumb{background:#abbfd938;border-radius:999px;border:2px solid transparent;background-clip:content-box}.history-modal-body::-webkit-scrollbar-thumb:hover{background:#bacce34d;background-clip:content-box}.history-timeline{list-style:none;margin:0;padding:6px 0 0;display:grid;gap:0}.history-timeline-item{position:relative;display:grid;grid-template-columns:28px minmax(0,1fr);gap:26px;padding:0 0 42px}.history-timeline-item:last-child{padding-bottom:0}.history-timeline-item:after{content:"";position:absolute;top:16px;left:10px;bottom:-8px;width:1px;background:linear-gradient(180deg,#88b4f085,#88b4f014)}.history-timeline-item:last-child:after{display:none}.history-timeline-marker{width:17px;height:17px;margin-top:3px;border-radius:999px;border:1px solid rgba(188,215,249,.6);background:radial-gradient(circle at center,#e2edfff2 0,#e2edfff2 26%,#6b9ee3e6 27%,#6b9ee3e6 62%,#152a45fa 63%);box-shadow:0 0 0 5px #3f8cff14;position:relative;z-index:1}.history-timeline-content{padding-top:1px;max-width:900px;padding-right:18px}.history-timeline-content h4{margin:0;max-width:28ch;font-size:.98rem;line-height:1.48;letter-spacing:.01em;color:#f2f7ff;text-wrap:pretty}.history-timeline-content p{margin:15px 0 0;max-width:58em;font-size:.92rem;line-height:1.9;letter-spacing:.01em;color:#d2e0f3d1;text-wrap:pretty;text-align:justify;text-justify:inter-ideograph;text-align-last:left}.history-timeline-content p+p{margin-top:16px}.feedback-modal-root{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:18px;pointer-events:none;z-index:24}.feedback-modal-root.open{pointer-events:auto}.feedback-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#050c169e;opacity:0;transition:opacity .18s ease}.feedback-modal-root.open .feedback-modal-backdrop{opacity:1}.feedback-modal-panel{width:min(452px,92vw);border-radius:14px;border:1px solid rgba(162,194,232,.22);background:linear-gradient(170deg,#101e31f5,#0a1423f5);box-shadow:0 18px 44px #030a155c,0 0 0 1px #6897d50d;opacity:0;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease;position:relative}.feedback-modal-root.open .feedback-modal-panel{opacity:1;transform:translateY(0)}.feedback-modal-header{padding:14px 16px 8px}.feedback-modal-header h3{margin:0;font-size:1rem;color:#f0f6ff}.feedback-modal-header p{margin:6px 0 0;font-size:.82rem;line-height:1.45;color:#c4d6edd1}.feedback-form{display:grid;gap:9px;padding:0 16px 14px}.feedback-field{display:grid;gap:6px}.feedback-field span{font-size:.79rem;color:#bcd2efdb}.feedback-field select,.feedback-field textarea,.feedback-field input{width:100%;border:1px solid rgba(145,179,221,.28);border-radius:10px;background:#091221c2;color:#e7f1ff;font-size:.84rem;line-height:1.4;padding:9px 10px;outline:none}.feedback-field textarea{min-height:120px;max-height:200px;resize:vertical}.feedback-field select:focus,.feedback-field textarea:focus,.feedback-field input:focus{border-color:#90baf194;box-shadow:0 0 0 1px #90baf138}.feedback-field input::placeholder,.feedback-field textarea::placeholder{color:#a2b7d48f}.feedback-error{margin:0;color:#ffc5bf;font-size:.76rem}.feedback-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:1px}.feedback-cancel-btn,.feedback-submit-btn{border-radius:9px;padding:7px 12px;font-size:.82rem;cursor:pointer;border:1px solid transparent}.feedback-cancel-btn{border-color:#8caacf4d;background:#122133ad;color:#d4e2f5db}.feedback-submit-btn{border-color:#6aa3ea5c;background:#214674ad;color:#e8f3ff}.feedback-cancel-btn:hover{border-color:#9fbfe57a;color:#e4effff2}.feedback-submit-btn:hover{border-color:#8fbcf685;background:#265286b8}.feedback-toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,8px);border:1px solid rgba(151,184,223,.28);background:#0a1627eb;color:#e2eefff2;border-radius:10px;font-size:.82rem;line-height:1.4;padding:9px 14px;box-shadow:0 8px 24px #040b1659;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:25;max-width:min(92vw,560px)}.feedback-toast.show{opacity:1;transform:translate(-50%)}@media (max-width: 1080px){body{overflow:auto}.app-shell{height:auto;grid-template-columns:1fr;overflow:visible}.left-sidebar{min-height:auto;max-height:56vh;overflow:auto}.right-main{min-height:auto;height:auto;overflow:visible}.map-area{flex:0 0 auto;min-height:300px}.detail-side{width:100%;align-items:flex-start}.detail-rates{width:100%;grid-template-columns:1fr 1fr}.detail-rate-block{justify-items:start}.detail-grid,.detail-stats{grid-template-columns:1fr}.sidebar-footer{gap:5px}}@media (max-width: 768px){html,body,#root{width:100%;max-width:100%;min-width:0;overflow-x:hidden}.app-shell{width:100%;max-width:none;min-width:0;margin:0 auto;padding:10px 12px;gap:10px;overflow-x:hidden}.app-shell>*{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.left-sidebar{max-height:none;overflow:hidden;padding:12px;width:100%;max-width:none;box-sizing:border-box}.right-main{width:100%;max-width:none;min-width:0;box-sizing:border-box;padding-right:0;margin-inline:auto}.brand-block{margin-bottom:8px;align-items:center}.brand-actions{gap:1px}.brand-title{white-space:normal;font-size:.94rem}.brand-subtitle{white-space:normal;line-height:1.35;margin-top:5px;font-size:.72rem}.header-icon-button,.shell-bag-entry-icononly{width:42px;height:42px;flex-shrink:0}.header-icon-button-icon{width:25px;height:25px}.shell-bag-entry-icononly .shell-bag-icon{width:27px;height:27px}.shell-bag-entry-icononly .shell-bag-count{top:1px;right:1px}.mobile-route-toggle{width:100%;display:inline-flex;align-items:center;justify-content:center;min-height:40px;border:1px solid rgba(145,179,221,.24);border-radius:10px;background:#101c2e8a;color:#dbe8f9e6;font-size:.8rem;font-weight:500;margin:2px 0 8px;cursor:pointer}.mobile-route-list-panel{max-height:0;overflow:hidden;opacity:0;transition:max-height .22s ease,opacity .18s ease}.sidebar-scroll-region{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.mobile-route-list-panel{min-height:0;flex:1;display:flex;flex-direction:column}.mobile-route-list-panel.open{max-height:58vh;overflow:hidden;opacity:1;margin-bottom:2px;display:flex;flex-direction:column}.mobile-route-list-panel.open .route-list-wrap{overflow:auto;flex:1;min-height:0;padding-right:0}.sidebar-footer{display:none}.mobile-route-panel-footer{display:flex;flex-direction:column;align-items:center;gap:5px;margin-top:26px;padding:23px 4px 13px;border-top:1px solid rgba(142,176,220,.14);color:#9db4d085;font-size:11px}.mobile-route-panel-footer .feedback-link{font-size:10.5px;color:#a5bcd89e}.route-list-wrap{padding-right:0;width:100%;max-width:100%;min-width:0}.route-group,.route-group-button,.variant-list,.variant-card,.variant-head,.variant-meta,.variant-meta-left,.variant-meta-right{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.map-area{flex:0 0 auto;min-height:250px;padding:12px;width:100%;max-width:none;margin-inline:auto;box-sizing:border-box}.detail-area{padding:12px;width:100%;max-width:none;margin-inline:auto;box-sizing:border-box}.map-view,.map-canvas,.route-detail,.detail-main,.detail-side,.detail-stats,.detail-grid,.detail-stats>div,.detail-block,.drawer-content,.drawer-item,.drawer-item-head,.drawer-item-sub,.drawer-item-note{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.detail-header{flex-direction:column;align-items:stretch;gap:14px}.detail-side{width:100%;flex-direction:row;align-items:flex-end;justify-content:space-between;gap:10px}.detail-rates{grid-template-columns:1fr;flex:1;min-width:0;gap:10px;margin-bottom:9px}.detail-rate-block{justify-items:start}.detail-favorite-btn{margin-top:0;width:auto;min-width:108px;max-width:none;min-height:34px;height:34px;padding-inline:14px;font-size:13px;font-weight:600;line-height:1;white-space:nowrap;align-self:auto;transform:translateY(-7px)}.detail-top{margin-top:7px;margin-bottom:11px}.detail-stats{margin-top:9px}.detail-title{font-size:1.1rem;line-height:1.3;overflow-wrap:anywhere}.detail-subtitle,.detail-route-line{line-height:1.5;overflow-wrap:anywhere}.detail-stats,.detail-grid{gap:12px}.detail-block p,.detail-block li{font-size:.84rem;line-height:1.68;text-wrap:pretty;line-break:loose;overflow-wrap:normal;word-break:normal}.detail-block ul{padding-left:15px;gap:6px}.route-hook{width:100%;max-width:100%;min-width:0}.route-hook-line{align-self:stretch;margin-block:4px}.route-hook-text{width:100%;max-width:100%;min-width:0}.route-hook-line-text{white-space:normal;overflow:visible;text-overflow:clip;text-wrap:pretty;line-break:loose;overflow-wrap:normal;word-break:normal}.empty-field,.route-hook-text{text-wrap:pretty;line-break:loose;overflow-wrap:normal;word-break:normal}.drawer-root{z-index:52}.drawer-backdrop{background:#030a14ad;transition:opacity .18s ease}.drawer-panel{top:0;right:0;left:0;bottom:0;width:100%;max-height:none;height:100dvh;border-left:none;border-top:none;border-radius:16px 16px 0 0;transform:translateY(20px);opacity:0;transition:transform .22s cubic-bezier(.22,1,.36,1),opacity .18s ease}.drawer-root:not(.open) .drawer-panel{visibility:hidden;pointer-events:none;transform:translateY(20px);opacity:0}.drawer-root.open .drawer-panel{visibility:visible;transform:translateY(0);opacity:1}.drawer-header{padding:12px}.drawer-actions button{min-height:36px}.drawer-content{padding:10px 12px calc(12px + env(safe-area-inset-bottom));overflow-x:hidden}.drawer-item-actions{flex-direction:column}.drawer-item-actions button{min-height:38px}.drawer-empty{font-size:13px}.history-modal-root{padding:14px}.history-modal-panel{width:93vw;max-height:78vh;border-radius:18px}.history-modal-header{padding:22px 24px 16px 26px;gap:16px}.history-modal-header h3{max-width:none;font-size:1.24rem}.history-modal-heading{margin-left:20px}.history-modal-subtitle{margin-top:12px;max-width:34ch;font-size:.74rem;line-height:1.62;text-wrap:balance;word-break:keep-all;overflow-wrap:normal}.history-modal-body{padding:12px 26px 24px}.history-timeline-item{grid-template-columns:24px minmax(0,1fr);gap:18px;padding-bottom:30px}.history-timeline-item:after{left:8px;bottom:-6px}.history-timeline-marker{width:15px;height:15px}.history-timeline-content h4{font-size:.99rem}.history-timeline-content p{margin-top:12px;font-size:.9rem;line-height:1.84}.feedback-modal-root{padding:10px;align-items:end}.feedback-modal-panel{width:100%;max-height:min(86dvh,760px);display:flex;flex-direction:column}.feedback-form{overflow:auto;padding-bottom:calc(14px + env(safe-area-inset-bottom))}.feedback-field select,.feedback-field textarea,.feedback-field input{min-height:40px}.feedback-field textarea{min-height:120px}.feedback-actions{position:sticky;bottom:0;padding-top:8px;background:linear-gradient(180deg,#0c182800,#0c1828f5 28%)}.feedback-cancel-btn,.feedback-submit-btn{min-height:38px}}@media (min-width: 769px){.sidebar-footer{display:flex}.mobile-route-panel-footer{display:none}}@media (max-width: 480px){.app-shell{width:100%;max-width:none;padding:8px 12px;gap:8px}.left-sidebar,.map-area,.detail-area{padding:10px}.map-area{min-height:228px}.map-head p{font-size:.82rem}.route-group-button{padding:9px 10px}.variant-card{padding:9px}.detail-title{font-size:1.03rem}.detail-subtitle{font-size:.82rem}.route-hook-text{font-size:13px}.history-modal-root{padding:10px}.history-modal-panel{width:92vw;border-radius:16px}.history-modal-header{padding:18px 16px 14px}.history-modal-body{padding:10px 16px 20px 18px}.feedback-modal-panel{max-height:88dvh}}@media (prefers-reduced-motion: reduce){.page-intro .brand-subtitle,.page-intro .route-list-wrap,.page-intro .map-area,.page-intro .detail-area{opacity:1;transform:none;transition:none;will-change:auto}}@media (min-width: 1024px){html,body,#root{height:100%;overflow:hidden}.app-shell{height:100vh;overflow:hidden}.left-sidebar,.right-main{height:100%;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:rgba(170,190,215,.22) transparent;overflow-y:auto;overflow-x:hidden}.left-sidebar::-webkit-scrollbar,.right-main::-webkit-scrollbar{width:8px;height:8px}.left-sidebar::-webkit-scrollbar-track,.right-main::-webkit-scrollbar-track{background:transparent}.left-sidebar::-webkit-scrollbar-thumb,.right-main::-webkit-scrollbar-thumb{min-height:44px;border:2px solid transparent;background:#aabed738;background-clip:content-box;border-radius:999px}.left-sidebar::-webkit-scrollbar-thumb:hover,.right-main::-webkit-scrollbar-thumb:hover{background:#b9cde457;background-clip:content-box}.left-sidebar::-webkit-scrollbar-thumb:active,.right-main::-webkit-scrollbar-thumb:active{background:#c8daee6b;background-clip:content-box}}
