:root{--bg:#0a1628;--panel:#0f1422;--panel2:#141a2b;--line:rgba(255,255,255,.08);--line2:rgba(255,255,255,.05);--txt:#e6edf3;--muted:#9aa4b2;--accent:#7ad7ff;--accent2:#1f6feb;--pink:#ff4d6d;--green:#36d399;--topbar-h:52px;--dock-collapsed:210px;--dock-expanded:64dvh}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;height:100%}body{font-family:Segoe UI,Microsoft JhengHei,system-ui,sans-serif;background:var(--bg);color:var(--txt);overflow:hidden;-webkit-text-size-adjust:100%;overscroll-behavior:none}.hidden{display:none!important}#app{display:flex;flex-direction:column;height:100dvh;width:100vw}#topbar{height:var(--topbar-h);flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:0 12px;background:linear-gradient(180deg,#0f1422f5,#0a101ceb);border-bottom:1px solid var(--line);position:relative;z-index:20}#app.playing #topbar{display:none}#topbar .brand{display:flex;align-items:center;gap:8px;font-weight:700;letter-spacing:.5px}#topbar .brand img{width:34px;height:34px;border-radius:8px}#topbar .brand span{font-size:18px;color:var(--accent)}#topbar .brand .ver{font-size:11px;font-weight:500;color:var(--muted);margin-left:4px;letter-spacing:0}.view-switch{margin-left:auto;display:flex;background:#0d1117;border:1px solid var(--line);border-radius:999px;padding:2px}.view-switch button{border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:600;padding:6px 16px;border-radius:999px;cursor:pointer;min-width:46px}.view-switch button.active{background:var(--accent2);color:#fff}.icon-btn{border:1px solid var(--line);background:#0d1117;color:var(--txt);width:38px;height:38px;border-radius:10px;font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.icon-btn:active{background:#1a2233}.icon-btn svg{display:block}#map-area{flex:1 1 auto;position:relative;overflow:hidden;background:#0c1220}.map-layer{position:absolute;inset:0;z-index:1}.leaflet-container{background:#0c1220!important;font-family:inherit}.leaflet-control-attribution{background:#0a101c99!important;color:#7e8a99!important;font-size:9px!important;padding:1px 6px!important}.leaflet-control-attribution a{color:#7ad7ff!important}.map-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;gap:6px;z-index:2;pointer-events:none;background:radial-gradient(circle at 50% 35%,rgba(122,215,255,.08),transparent 60%),repeating-linear-gradient(45deg,rgba(255,255,255,.015) 0 12px,transparent 12px 24px)}.ph-view{font-size:34px;font-weight:800;color:var(--accent);letter-spacing:2px}.ph-note{font-size:14px;color:var(--txt)}.ph-hint{font-size:11px;color:var(--muted);max-width:280px;line-height:1.5}.run-info{position:absolute;top:8px;left:10px;right:10px;z-index:5;display:flex;align-items:center;gap:10px;background:#12182480;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:6px 10px;pointer-events:none;font-variant-numeric:tabular-nums;text-shadow:0 1px 4px rgba(0,0,0,.85)}#app.playing #run-info{top:calc(8px + env(safe-area-inset-top))}.ri-avatar{width:44px;height:44px;flex:0 0 auto;border-radius:50%;object-fit:cover;border:2px solid #fff;box-shadow:0 1px 5px #0000008c;background:#0d1117}.ri-text{flex:0 0 auto;display:flex;flex-direction:column}.ri-chartwrap{flex:1 1 auto;min-width:0}.ri-chart-head{display:flex;align-items:baseline;gap:6px}.ri-metric{pointer-events:auto;cursor:pointer;user-select:none;font-size:11px;font-weight:700}.ri-metric-val{font-size:12px;color:#fff;font-weight:600}.ri-chart{width:100%;height:40px;display:block}.ri-row{display:flex;gap:6px;line-height:1.35}.ri-row span{font-size:11px;color:#cdd8e6}.ri-row b{font-size:11px;color:#fff;font-weight:700}.ri-title{font-size:13px;color:#fff;font-weight:600}.ri-sub{font-size:11px;color:#cdd8e6}.photo-card{position:absolute;bottom:26px;right:10px;left:auto;z-index:7;width:clamp(150px,42vw,200px);border-radius:12px;overflow:hidden;border:2px solid var(--accent);box-shadow:0 6px 20px #0009;background:#0d1117}.photo-card.left{left:10px;right:auto}.photo-card img{width:100%;display:block}.rec-btn{position:absolute;top:calc(3px + env(safe-area-inset-top));right:8px;z-index:8;display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:14px;border:1px solid rgba(255,255,255,.22);background:#0d1117c7;color:#dbe4ee;font-size:11px;font-weight:600;line-height:1.4;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s,border-color .15s}.rec-btn:hover{background:#283246e6;border-color:#ffffff59}.rec-btn .rec-dot{width:8px;height:8px;border-radius:50%;background:#ff4d6d;box-shadow:0 0 8px #ff4d6d99}.rec-btn.recording{background:#ff4d6d2e;border-color:#ff4d6d99;color:#fff}.rec-btn.recording .rec-dot{animation:rec-pulse 1s ease-in-out infinite}@keyframes rec-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.78)}}.fn-pop .leaflet-popup-content-wrapper{padding:0!important;overflow:hidden;border-radius:10px!important;background:#0d1117;box-shadow:0 4px 16px #0000008c}.fn-pop .leaflet-popup-content{margin:0!important;width:auto!important;line-height:0}.fn-pop .leaflet-popup-tip{background:#0d1117}.fn-iw{position:relative;width:168px;line-height:0}.fn-iw img{width:100%;display:block}.fn-iw-x{position:absolute;top:5px;right:5px;width:22px;height:22px;z-index:2;border-radius:50%;background:#0000008c;color:#fff;font-size:15px;line-height:22px;text-align:center;cursor:pointer}#photo-dock{flex:0 0 auto;z-index:15;background:linear-gradient(180deg,var(--panel2),var(--panel));border-top:1px solid var(--line);display:flex;flex-direction:column;height:var(--dock-collapsed);transition:height .28s ease}#photo-dock.expanded{height:var(--dock-expanded)}#dock-handle{flex:0 0 auto;height:16px;position:relative;cursor:pointer;user-select:none}#dock-handle .grip{position:absolute;top:6px;left:50%;transform:translate(-50%);width:40px;height:4px;border-radius:2px;background:#fff3}.playback{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:6px 14px 8px}.pb-btn{width:44px;height:44px;flex:0 0 auto;border:none;border-radius:50%;padding:0;cursor:pointer;background:linear-gradient(135deg,#3b86f7,#1f6feb);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px #1f6feb66}.pb-btn:active{transform:scale(.94)}.pb-btn svg{width:18px;height:18px;display:block}#pb-slider{flex:1 1 auto;min-width:0;height:6px;accent-color:var(--accent);margin:0}#pb-speed{flex:0 0 auto;background:#0d1117;color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:7px 8px;font-size:12px}.photo-strip{flex:1 1 auto;display:flex;gap:10px;padding:4px 12px 12px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.photo-strip::-webkit-scrollbar{display:none;width:0;height:0}#photo-dock.expanded .photo-strip{flex-wrap:wrap;overflow-x:hidden;overflow-y:auto;align-content:flex-start}.strip-empty{color:var(--muted);font-size:13px;align-self:center;padding:10px 16px;border:1px dashed var(--line);border-radius:10px;cursor:pointer}.strip-empty:active{background:#ffffff0d}.thumb{position:relative;flex:0 0 auto;width:118px;height:118px;border-radius:12px;overflow:hidden;border:2px solid transparent;background:#0d1117;cursor:pointer}#photo-dock.expanded .thumb{width:calc(50% - 5px);height:160px}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb.no-gps:after{content:"\7121GPS";position:absolute;bottom:0;left:0;right:0;font-size:10px;text-align:center;color:#ffd27a;background:#0000008c;padding:2px 0}.thumb.selected{border-color:var(--accent);box-shadow:0 0 0 2px #7ad7ff73}#sheet-backdrop{position:fixed;inset:0;background:#00000080;z-index:25}#settings-sheet{position:fixed;left:0;right:0;bottom:0;z-index:26;background:var(--panel2);border-top:1px solid var(--line);border-radius:18px 18px 0 0;padding:8px 18px calc(18px + env(safe-area-inset-bottom));max-height:88dvh;overflow-y:auto;box-shadow:0 -8px 30px #00000080;animation:sheet-up .25s ease}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-grip{width:42px;height:4px;border-radius:2px;background:#fff3;margin:4px auto 12px}#settings-sheet h2{font-size:15px;margin:0 0 14px;color:var(--accent)}#settings-sheet .set-h{font-size:13px;margin:18px 0 10px;padding:6px 0 4px;color:var(--accent);border-bottom:1px solid var(--line);letter-spacing:.5px}#settings-sheet .set-h:first-of-type{margin-top:6px}#settings-sheet .set-sub{font-size:12px;color:#b9d4ff;margin:12px 0 6px;font-weight:500}#settings-sheet .set-sub small{color:var(--muted);font-weight:400;margin-left:6px}#settings-sheet .check-row{display:flex;align-items:center;gap:8px;margin:4px 0 8px;font-size:13px;color:#dbe4ee;cursor:pointer}#settings-sheet .check-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}#settings-sheet select:disabled{opacity:.5;cursor:not-allowed}#settings-sheet #garmin-fetch{width:100%;margin:0 0 8px;padding:10px;font-size:13px}.load-status{font-size:12px;padding:6px 4px;min-height:18px;color:var(--green)}.load-status.err{color:var(--pink)}.trip-info{margin:10px 0 12px;padding:10px 12px;background:#36d3991a;border:1px solid rgba(54,211,153,.32);border-radius:10px;color:var(--green);font-size:13px;line-height:1.55}.trip-info b{color:#fff;font-weight:600}.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:6px 0 10px}.lib-empty{grid-column:1/-1;padding:14px;text-align:center;font-size:13px;color:var(--muted);border:1px dashed var(--line);border-radius:10px}.lib-card{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;background:#0d1117;border:1px solid var(--line);transition:transform .15s ease,box-shadow .15s ease}.lib-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000073;border-color:var(--accent)}.lib-card.active{border-color:var(--accent);box-shadow:0 0 0 2px #7ad7ff66}.lib-cover{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#1f2937}.lib-cover.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:34px}.lib-meta{padding:7px 10px 8px}.lib-title{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lib-date{font-size:11px;color:var(--muted);margin-top:2px}.lib-regions{font-size:11px;color:#9cc4ff;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lib-menu{position:absolute;top:6px;right:6px;width:26px;height:26px;border:none;border-radius:50%;background:#0009;color:#fff;font-size:14px;line-height:26px;padding:0;cursor:pointer}.lib-menu:hover{background:#000000d9}#personal-settings,#trip-library-page,#new-trip-page{position:fixed;inset:0;z-index:37;display:flex;flex-direction:column;background:var(--bg);color:var(--txt)}#personal-settings.hidden,#trip-library-page.hidden,#new-trip-page.hidden{display:none}.ps-bar{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:calc(10px + env(safe-area-inset-top)) 12px 10px;background:linear-gradient(180deg,var(--panel2),var(--panel));border-bottom:1px solid var(--line)}.ps-title{flex:1 1 auto;text-align:center;font-size:15px;font-weight:700;color:var(--accent)}.ps-body{flex:1 1 auto;overflow-y:auto;padding:8px 18px calc(18px + env(safe-area-inset-bottom))}.ps-body .set-h{font-size:13px;margin:18px 0 10px;padding:6px 0 4px;color:var(--accent);border-bottom:1px solid var(--line)}.ps-body .set-h:first-child{margin-top:8px}.ps-body .set-h small{color:var(--muted);font-weight:400;margin-left:6px;font-size:11px}.ps-body #garmin-fetch{width:100%;margin:0 0 8px;padding:10px;font-size:13px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;font-size:13px}.field>span{color:#b9d4ff;font-weight:500}.field select,.field input[type=file]{background:#0d1117;color:var(--txt);border:1px solid #30363d;border-radius:8px;padding:10px;font-size:14px;width:100%}.field-note{font-size:11px;color:var(--muted);line-height:1.5;margin-bottom:16px}.primary-btn,.ghost-btn{width:100%;border:none;border-radius:10px;padding:13px;font-size:15px;font-weight:600;cursor:pointer;margin-top:4px}.primary-btn{background:var(--accent2);color:#fff}.ghost-btn{background:transparent;color:var(--muted);border:1px solid var(--line);margin-bottom:8px}#loading{position:fixed;inset:0;z-index:40;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#0a101cc7;backdrop-filter:blur(3px);color:var(--txt);font-size:14px}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid rgba(122,215,255,.25);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(orientation:landscape)and (max-height:520px){.ph-hint{display:none}}#tag-editor{position:fixed;inset:0;z-index:35;display:flex;flex-direction:column;background:var(--bg);color:var(--txt)}.te-bar{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:calc(8px + env(safe-area-inset-top)) 12px 8px;background:linear-gradient(180deg,var(--panel2),var(--panel));border-bottom:1px solid var(--line)}.te-title{flex:1 1 auto;min-width:0;background:#0d1117;color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:15px;font-weight:600}.te-btn{flex:0 0 auto;border:none;background:var(--accent2);color:#fff;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer}.te-btn-ghost{flex:0 0 auto;border:1px solid var(--line);background:#0d1117;color:var(--muted);border-radius:10px;padding:10px 12px;font-size:14px;cursor:pointer}.te-body{flex:1 1 auto;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px;overscroll-behavior:contain}.te-body,.ps-body,#settings-sheet,.sv-note{scrollbar-width:thin;scrollbar-color:rgba(120,140,170,.35) transparent}.te-body::-webkit-scrollbar,.ps-body::-webkit-scrollbar,.sheet::-webkit-scrollbar,.sv-note::-webkit-scrollbar{width:8px;height:8px}.te-body::-webkit-scrollbar-track,.ps-body::-webkit-scrollbar-track,.sheet::-webkit-scrollbar-track,.sv-note::-webkit-scrollbar-track{background:transparent}.te-body::-webkit-scrollbar-thumb,.ps-body::-webkit-scrollbar-thumb,.sheet::-webkit-scrollbar-thumb,.sv-note::-webkit-scrollbar-thumb{background:#788caa4d;border-radius:8px;border:2px solid transparent;background-clip:padding-box;transition:background .15s ease}.te-body::-webkit-scrollbar-thumb:hover,.ps-body::-webkit-scrollbar-thumb:hover,.sheet::-webkit-scrollbar-thumb:hover,.sv-note::-webkit-scrollbar-thumb:hover{background:#b4c8e68c;background-clip:padding-box;border:2px solid transparent}.te-body::-webkit-scrollbar-thumb:active,.ps-body::-webkit-scrollbar-thumb:active,.sheet::-webkit-scrollbar-thumb:active,.sv-note::-webkit-scrollbar-thumb:active{background:var(--accent);background-clip:padding-box;border:2px solid transparent}.te-body::-webkit-scrollbar-corner,.ps-body::-webkit-scrollbar-corner,.sheet::-webkit-scrollbar-corner,.sv-note::-webkit-scrollbar-corner{background:transparent}.te-empty{color:var(--muted);text-align:center;padding:40px 16px;line-height:1.6}.te-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px}.te-card-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}.te-num{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--accent2);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.te-name{flex:1 1 auto;min-width:0;background:#0d1117;color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:14px;font-weight:600}.te-sug{flex:0 0 auto;border:1px solid var(--line);background:#0d1117;color:var(--accent);border-radius:8px;padding:8px 11px;font-size:12px;font-weight:600;cursor:pointer}.te-sug:active{background:#1a2233}.te-note{width:100%;resize:vertical;background:#0d1117;color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px;line-height:1.5;margin-bottom:10px;min-height:48px;max-height:50vh;overflow-y:auto}.te-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:7px}.te-thumb{position:relative;aspect-ratio:1/1;border-radius:9px;overflow:hidden;border:2px solid transparent;background:#0d1117;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.te-thumb:hover{transform:scale(1.14);z-index:3;border-color:var(--accent);box-shadow:0 6px 18px #0000008c}.te-thumb img{width:100%;height:100%;object-fit:cover;display:block}.te-thumb.cover{border-color:var(--accent)}.te-thumb.sel{border-color:#ffd84d;box-shadow:0 0 0 2px #ffd84d73}.te-thumb.sel:before{content:"\2713";position:absolute;top:5px;left:5px;z-index:2;width:22px;height:22px;border-radius:50%;background:#ffd84d;color:#06121f;font-size:13px;font-weight:800;line-height:22px;text-align:center}.te-bulkbar{flex:0 0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:6px 10px 0;background:var(--panel2);border:1px solid var(--accent);border-radius:14px;padding:8px 10px;box-shadow:0 -4px 16px #00000073}.te-bulkbar.hidden{display:none}.te-bulkbar .count{flex:1 1 auto;min-width:64px;font-size:12px;font-weight:700;color:var(--accent)}.te-bulkbar button{flex:0 0 auto;border:1px solid var(--line);background:#0d1117;color:var(--txt);border-radius:8px;padding:7px 10px;font-size:12px;cursor:pointer}.te-bulkbar button:hover{background:#1a2233}.te-bulkbar button:disabled{opacity:.32;cursor:not-allowed}.te-bulkbar button.danger{color:var(--pink);border-color:#ff4d6d66}.te-thumb[draggable=true]{cursor:grab}.te-thumb[draggable=true]:active{cursor:grabbing}.te-card.te-drop-target{outline:1px dashed rgba(122,215,255,.35);outline-offset:2px;transition:outline .12s ease,background .12s ease}.te-card.te-drop-over{outline:2px solid var(--accent);background:#7ad7ff14}.te-newgroup-zone{margin:8px 0 16px;padding:18px 14px;border:2px dashed var(--line);border-radius:14px;color:var(--muted);text-align:center;font-size:14px;font-weight:600;transition:all .15s ease}.te-newgroup-zone.te-drop-target{border-color:#ffd84d8c;color:#ffd84d}.te-newgroup-zone.te-drop-over{border-color:#ffd84d;background:#ffd84d1a;color:#fff;transform:scale(1.01)}.te-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 10px;background:#ffffff08;border:1px solid var(--line);border-radius:10px;margin-bottom:10px}.te-tools-label{font-size:12px;color:var(--muted);font-weight:600}.te-tools input[type=range]{flex:1 1 140px;min-width:90px;accent-color:var(--accent)}.te-tools #te-gap-val{font-size:12px;color:var(--accent);font-weight:700;min-width:60px;text-align:right;font-variant-numeric:tabular-nums}.te-tools #te-regroup{flex:0 0 auto;font-size:12px;padding:6px 10px}.te-tools-sep{margin-left:auto}.te-tools-skin{flex:0 0 auto;background:#0d1117;color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:6px 8px;font-size:12px}.te-tools-route{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--txt-dim);cursor:pointer;user-select:none;padding:2px 6px}.te-tools-route input{accent-color:var(--accent);cursor:pointer}.te-region-div{display:flex;align-items:center;gap:10px;padding:14px 0 8px}.te-region-label{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff0f;border:1px solid var(--line);border-radius:16px;font-size:13px;font-weight:600;color:#dbe4ee;letter-spacing:.3px}.te-region-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 8px #0006}.te-region-dot[data-ri="0"],.fn-region-c0{background:#3b82f6}.te-region-dot[data-ri="1"],.fn-region-c1{background:#f97316}.te-region-dot[data-ri="2"],.fn-region-c2{background:#10b981}.te-region-dot[data-ri="3"],.fn-region-c3{background:#ec4899}.te-region-dot[data-ri="4"],.fn-region-c4{background:#a855f7}.te-region-dot[data-ri="5"],.fn-region-c5{background:#06b6d4}.te-region-name{background:transparent;color:#fff;border:1px solid transparent;font:inherit;font-weight:700;padding:2px 6px;border-radius:6px;min-width:80px;max-width:180px;outline:none;text-align:center;cursor:text}.te-region-name:hover{background:#ffffff0d;border-color:#ffffff1f}.te-region-name:focus{background:#0000004d;border-color:var(--accent)}.te-region-jump{color:var(--muted);font-weight:500;font-size:12px;margin-left:2px}.transit-card{position:absolute;inset:0;z-index:25;pointer-events:none;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at center,#0d1117eb,#070b14fa);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);opacity:0;transition:opacity .6s ease}.transit-card.show{opacity:1}.transit-card.hidden{display:none}.transit-card .tc-content{text-align:center;color:#fff;transform:scale(.92);opacity:0;transition:transform .6s cubic-bezier(.22,.61,.36,1),opacity .6s ease}.transit-card.show .tc-content{transform:scale(1);opacity:1}.transit-card .tc-icon{font-size:72px;line-height:1;margin-bottom:14px;filter:drop-shadow(0 4px 14px rgba(255,229,77,.45));color:#ffe34d}.transit-card .tc-label{font-size:13px;letter-spacing:6px;text-transform:uppercase;opacity:.55;margin-bottom:10px}.transit-card .tc-name{font-size:38px;font-weight:700;letter-spacing:1.2px;margin-bottom:14px;text-shadow:0 2px 12px rgba(0,0,0,.7)}.transit-card .tc-from{font-size:13px;opacity:.55;letter-spacing:1px}.transit-card .tc-from-name{font-weight:500;opacity:.85;color:#9cc4ff}.transit-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.92);z-index:10;pointer-events:none;opacity:0;padding:14px 24px;border-radius:14px;background:#0d1117d9;color:#fff;font-size:18px;font-weight:700;letter-spacing:.5px;border:1px solid rgba(255,255,255,.18);box-shadow:0 12px 36px #0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:opacity .35s ease,transform .35s ease}.transit-banner.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.transit-banner.hidden{display:none}.te-thumb.tripcover:after{content:"\1f3f7";position:absolute;top:4px;right:4px;z-index:2;width:24px;height:24px;border-radius:50%;background:var(--accent2);color:#fff;font-size:12px;line-height:24px;text-align:center;box-shadow:0 2px 6px #00000080}.fn-modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px}.fn-modal-backdrop{position:absolute;inset:0;background:#060a12b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.fn-modal-card{position:relative;max-width:440px;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px 22px 18px;box-shadow:0 24px 60px #0000008c;animation:fn-modal-in .22s cubic-bezier(.22,.61,.36,1)}@keyframes fn-modal-in{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.fn-modal-icon{font-size:30px;line-height:1;margin-bottom:6px}.fn-modal-title{margin:0 0 10px;font-size:17px;font-weight:700;color:var(--accent)}.fn-modal-body{margin:0 0 20px;font-size:14px;line-height:1.65;color:#dbe4ee;white-space:pre-wrap}.fn-modal-actions{display:flex;gap:10px;justify-content:flex-end}.fn-modal-actions button{border:none;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:filter .12s ease,background .12s ease}.fn-modal-cancel{background:transparent;color:var(--muted);border:1px solid var(--line)}.fn-modal-cancel:hover{background:#ffffff0d;color:var(--txt)}.fn-modal-ok{background:var(--accent2);color:#fff}.fn-modal-ok:hover{filter:brightness(1.1)}.fn-modal-ok.danger{background:var(--pink)}.fn-modal-ok:focus,.fn-modal-cancel:focus{outline:2px solid var(--accent);outline-offset:2px}.te-thumb.missing{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:20px}.te-cover-badge{position:absolute;left:0;bottom:0;right:0;font-size:9px;text-align:center;color:#06121f;background:var(--accent);padding:1px 0;font-weight:700}.te-card-acts{display:flex;align-items:center;gap:8px;margin-top:10px}.te-count{flex:1 1 auto;font-size:12px;color:var(--muted)}.te-mini{border:1px solid var(--line);background:#0d1117;color:var(--txt);border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer}.te-mini.danger{color:var(--pink);border-color:#ff4d6d66}.te-foot{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:var(--panel2)}.te-status{flex:1 1 auto;font-size:12px;color:var(--green);text-align:right}.te-menu{position:fixed;z-index:36;min-width:150px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px #0000008c;overflow:hidden}.te-menu button{display:block;width:100%;text-align:left;border:none;background:transparent;color:var(--txt);padding:11px 14px;font-size:13px;cursor:pointer}.te-menu button:active{background:#ffffff0f}.te-menu button:disabled{color:var(--muted);opacity:.5}.te-menu button.danger{color:var(--pink)}.trip-banner{position:absolute;top:0;left:0;right:0;z-index:6;text-align:center;padding:5px 76px 5px 44px;font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(180deg,#0a101cd9,#0a101c66);text-shadow:0 1px 4px rgba(0,0,0,.8);pointer-events:none}#app.playing .trip-banner{padding-top:calc(5px + env(safe-area-inset-top))}#app.has-title .run-info{top:36px}#app.has-title.playing .run-info{top:calc(38px + env(safe-area-inset-top))}#story-view{position:fixed;inset:0;z-index:38;display:flex;flex-direction:column;background:#060a12f5;color:var(--txt);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.sv-top{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:12px 14px 8px}.sv-name{flex:1 1 auto;min-width:0;font-size:18px;font-weight:700;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sv-close{flex:0 0 auto;width:38px;height:38px;border:1px solid var(--line);background:#0d1117;color:#fff;border-radius:50%;font-size:18px;cursor:pointer}.sv-stage{flex:1 1 auto;min-height:0;overflow:hidden;padding:6px 14px;cursor:pointer;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;perspective:1300px;-webkit-perspective:1300px}.sv-photo-wrap{position:relative;flex:0 1 auto;min-width:0;min-height:0;max-width:100%;max-height:100%;width:100%;height:100%}.sv-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:14px;box-shadow:0 12px 38px #0000008c;opacity:0;transition:opacity .55s cubic-bezier(.22,.61,.36,1);will-change:opacity,transform;backface-visibility:hidden;-webkit-backface-visibility:hidden}.sv-photo.show{opacity:1}.sv-video{background:#000;object-fit:contain}@media(prefers-reduced-motion:reduce){.sv-photo{transition:opacity .25s ease}}.sv-note{flex:0 0 auto;width:100%;max-width:600px;font-size:16px;line-height:1.55;color:#fff;padding:12px 16px;background:#141a26e0;border:1px solid rgba(255,255,255,.15);border-radius:12px;max-height:22vh;overflow-y:auto;white-space:pre-wrap}.sv-note:empty{display:none}.sv-bar{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:20px;padding:10px 14px 18px}.sv-nav{width:46px;height:46px;border:1px solid rgba(255,255,255,.18);border-radius:50%;background:#ffffff1a;color:#fff;font-size:22px;line-height:1;padding:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:background .15s ease,transform .12s ease,opacity .15s ease}.sv-nav:hover{background:#fff3}.sv-nav:active{transform:scale(.92)}.sv-nav:disabled{opacity:.28;cursor:not-allowed}.sv-count{font-size:13px;color:#cdd8e6;min-width:54px;text-align:center;font-variant-numeric:tabular-nums;letter-spacing:.5px}.sv-top,.sv-bar,.sv-note{animation:sv-bar-in .55s cubic-bezier(.22,.61,.36,1) both}@keyframes sv-bar-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.set-link-btn{display:block;padding:10px 14px;background:var(--bg-2, #1a1f2e);border:1px solid var(--border, rgba(255,255,255,.12));border-radius:8px;color:var(--fg, #e8eaed);text-decoration:none;font-size:14px;transition:background .15s}.set-link-btn:hover{background:var(--bg-3, #232a3d);border-color:#7ad7ff66}.set-link-btn:active{transform:translateY(1px)}.map-loading-overlay{position:absolute;inset:0;background:#0a0e16c7;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:40;display:flex;align-items:center;justify-content:center;transition:opacity .4s}.map-loading-overlay.hidden{opacity:0;pointer-events:none}.mlo-content{display:flex;flex-direction:column;align-items:center;gap:18px;padding:28px 36px;background:#141a26f2;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:0 8px 32px #0006;min-width:240px}.mlo-spinner{width:36px;height:36px;border:3px solid rgba(122,215,255,.25);border-top-color:#7ad7ff;border-radius:50%;animation:mlo-spin .9s linear infinite}@keyframes mlo-spin{to{transform:rotate(360deg)}}.mlo-title{color:#fff;font-size:16px;font-weight:600;margin:0;text-align:center}.mlo-percent{color:#7ad7ff;font-size:32px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:1px;margin:0;line-height:1}.map-loading-overlay.mini{position:absolute;inset:auto 10px 12px auto;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;display:block;pointer-events:none}.map-loading-overlay.mini .mlo-content{flex-direction:row;align-items:center;gap:8px;padding:6px 10px;background:#141a26d1;border-radius:10px;min-width:0;box-shadow:0 2px 8px #00000059}.map-loading-overlay.mini .mlo-spinner{width:14px;height:14px;border-width:2px}.map-loading-overlay.mini .mlo-percent{font-size:12px;font-weight:600;color:#7ad7ff}.map-loading-overlay.mini .mlo-title{display:none}
