*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f1117;--card: #1a1d27;--text: #e2e4e9;--muted: #6b7080;--accent: #3b82f6;--border: #2a2d3a;--btn-bg: #252836;--input-bg: #252836;--green: #22c55e;--yellow: #eab308;--red: #ef4444;--orange: #f97316}html.light{--bg: #f0f2f5;--card: #ffffff;--text: #1a1d27;--muted: #8b90a0;--border: #dde0e7;--btn-bg: #e8eaef;--input-bg: #f5f6f8}body{font-family:JetBrains Mono,SF Mono,Menlo,monospace;background:var(--bg);color:var(--text);height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}#app{display:flex;flex-direction:column;height:100%;overflow:hidden}.hidden{display:none!important}.btn{padding:8px 16px;border-radius:10px;border:none;background:var(--btn-bg);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn.active{background:var(--accent);color:#fff}.btn.green{background:var(--green);color:#fff}.btn.yellow{background:var(--yellow);color:#fff}.btn.red{background:var(--red);color:#fff}.btn.login{color:#6366f1;font-size:11px;padding:6px 10px}.topbar{padding:0 14px;display:flex;align-items:center;justify-content:space-between;background:var(--card);border-bottom:1px solid var(--border);z-index:1000;flex-shrink:0;height:44px}.topbar-left{display:flex;align-items:center;gap:8px}.status-dot{width:10px;height:10px;border-radius:50%;background:#ef4444}.status-dot.active{background:#22c55e;box-shadow:0 0 8px #22c55e}.status-dot.paused{background:#eab308}.topbar-title{font-size:14px;font-weight:700;letter-spacing:1px}.topbar-right{display:flex;gap:6px;align-items:center}.user-badge{font-size:9px;color:#22c55e;padding:4px 8px;background:#1a2e1a;border-radius:6px;letter-spacing:.5px}html.light .user-badge{background:#e8f5e8}.map-overlay{position:absolute;z-index:1000;background:var(--card);border:1px solid var(--border);border-radius:8px;font-size:11px;padding:4px 10px}.gps-badge{top:10px;left:10px;opacity:.85}.speed-legend{bottom:14px;left:14px;display:flex;gap:8px;font-size:10px;padding:6px 10px;opacity:.9}.legend-item{display:flex;align-items:center;gap:3px}.legend-dot{width:8px;height:8px;border-radius:2px}.follow-btn{position:absolute;bottom:14px;right:14px;z-index:1000;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 2px 12px #0000004d;padding:0}.elevation-panel{height:100px;background:var(--card);border-top:1px solid var(--border);padding:6px 10px;flex-shrink:0}.stats-panel{background:var(--card);border-top:1px solid var(--border);padding:10px 14px;flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;text-align:center}.stat-label{font-size:9px;color:var(--muted);letter-spacing:1px;margin-bottom:2px}.stat-value{font-size:20px;font-weight:800;line-height:1}.stat-unit{font-size:9px;color:var(--muted)}.stats-extra{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}.controls{background:var(--card);border-top:1px solid var(--border);padding:10px 14px 16px;display:flex;gap:8px;flex-shrink:0}.controls .btn{padding:12px;border-radius:12px;font-size:15px}.controls .btn.wide{flex:1}.start-panel{display:flex;flex-direction:column;gap:8px;width:100%}.start-hint{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--muted);padding:0 2px}.start-hint.ready{color:var(--green)}.start-hint.blocked{color:var(--yellow)}.btn.tiny{padding:6px 10px;font-size:11px;border-radius:999px}.save-sheet-wrap{position:fixed;left:0;right:0;bottom:0;z-index:2500;padding:10px 12px calc(env(safe-area-inset-bottom,0px) + 12px);background:linear-gradient(to top,rgba(15,17,23,.98),rgba(15,17,23,.78) 75%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.save-sheet{width:min(100%,760px);max-height:min(78dvh,calc(100dvh - 128px));margin:0 auto;display:flex;flex-direction:column;overflow:hidden;background:color-mix(in srgb,var(--card) 92%,transparent);border:1px solid var(--border);border-radius:24px}.save-sheet-scroll{overflow:auto;padding:0 14px 10px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.save-sheet-handle{flex-shrink:0;width:42px;height:5px;border-radius:999px;margin:12px auto;background:color-mix(in srgb,var(--muted) 55%,transparent)}.save-sheet-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.save-sheet-kicker{font-size:10px;color:var(--muted);letter-spacing:1.4px;margin-bottom:4px}.save-sheet-title{font-size:18px;font-weight:800}.save-sheet-icon{width:42px;height:42px;border-radius:14px;background:var(--btn-bg);display:flex;align-items:center;justify-content:center;font-size:22px}.save-sheet-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.save-stat-card{padding:12px;background:color-mix(in srgb,var(--btn-bg) 78%,transparent);border:1px solid var(--border);border-radius:16px}.save-stat-label{font-size:10px;color:var(--muted);letter-spacing:1px;margin-bottom:6px}.save-stat-value{font-size:18px;font-weight:800;line-height:1.1}.save-meta-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:14px;font-size:11px;color:var(--muted)}.save-meta-row span{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 10px;border-radius:12px;background:color-mix(in srgb,var(--btn-bg) 68%,transparent)}.save-meta-row strong{color:var(--text)}.save-sheet-section{margin-bottom:14px}.save-sheet-section-last{margin-bottom:0}.save-section-label{font-size:11px;color:var(--muted);letter-spacing:1.1px;margin-bottom:8px}.save-type-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.save-type-pill{display:flex;align-items:center;justify-content:center;gap:8px;min-width:0;padding:11px 10px;border-radius:14px;border:1px solid var(--border)}.save-type-pill.selected{box-shadow:inset 0 0 0 1px currentColor}.save-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--text);font-size:13px;font-family:inherit;outline:none}.save-actions{flex-shrink:0;display:flex;gap:10px;padding:12px 14px 14px;border-top:1px solid var(--border);background:color-mix(in srgb,var(--card) 96%,transparent)}.save-primary,.save-secondary{flex:1;padding:14px 16px;border-radius:16px}@media(min-width:900px){.save-sheet-wrap{left:16px;right:16px;bottom:14px;padding:0;background:transparent}.save-sheet{margin-left:auto;margin-right:auto;max-width:720px;max-height:min(76dvh,760px);box-shadow:0 20px 48px #00000047}}@media(max-width:640px){.save-type-grid,.save-meta-row{grid-template-columns:repeat(2,minmax(0,1fr))}}.app-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;display:flex;align-items:center;justify-content:center;padding:18px;background:#00000085;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.app-modal{width:min(100%,420px);background:var(--card);border:1px solid var(--border);border-radius:22px;box-shadow:0 24px 60px #0000006b;padding:18px}.app-modal-title{font-size:21px;font-weight:800;margin-bottom:8px}.app-modal-message{color:var(--text);line-height:1.45;font-size:14px}.app-modal-body{margin-top:14px}.modal-field-group+.modal-field-group{margin-top:10px}.modal-label{display:block;font-size:11px;letter-spacing:1px;color:var(--muted);margin-bottom:6px}.modal-input{display:block}.app-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.app-modal-btn{min-width:96px}.sidebar{position:absolute;top:0;right:0;width:80%;max-width:320px;height:100%;background:var(--card);z-index:2000;border-left:1px solid var(--border);display:flex;flex-direction:column;box-shadow:-4px 0 20px #0000004d}.sidebar-header{padding:0 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;height:44px;flex-shrink:0;background:var(--card)}.sidebar-body{flex:1;overflow:auto;padding:8px 12px}.trip-card{padding:10px 12px;border-radius:10px;background:var(--btn-bg);margin-bottom:8px;cursor:pointer;border:1px solid var(--border)}.trip-card.active{border:2px solid var(--accent)}.trip-name{font-weight:600;font-size:13px}.trip-meta{font-size:10px;color:var(--muted);margin-top:2px}.trip-delete{background:none;border:none;color:#ef4444;font-size:10px;cursor:pointer;padding:2px 6px;font-family:inherit;margin-top:4px}.empty-msg{color:var(--muted);text-align:center;margin-top:40px;font-size:12px}.stats-page{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--bg);z-index:3000;display:flex;flex-direction:column;overflow:hidden}.stats-page-header{padding:0 14px;background:var(--card);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;height:44px}.stats-page-body{flex:1;overflow:auto;padding:16px}.stats-section{margin-bottom:20px}.stats-section-title{font-size:10px;color:var(--muted);letter-spacing:1.5px;margin-bottom:10px;font-weight:700}.stats-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:10px}.stats-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.stats-row-label{font-size:12px;color:var(--muted)}.stats-row-value{font-size:14px;font-weight:700}.stats-bar-container{height:6px;background:var(--border);border-radius:3px;margin-top:4px;overflow:hidden}.stats-bar{height:100%;border-radius:3px;background:var(--accent);transition:width .3s}.stats-tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--card);flex-shrink:0}.stats-tab{flex:1;padding:10px;text-align:center;font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;font-family:inherit;background:none;border-top:none;border-left:none;border-right:none}.stats-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.trip-summary-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4000;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .3s ease}.trip-summary-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px 24px;width:90%;max-width:340px;box-shadow:0 8px 40px #0006;transition:transform .3s ease;position:relative;overflow:hidden}.trip-summary-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.trip-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.trip-summary-stat{text-align:center}.trip-summary-stat-value{font-size:22px;font-weight:800;line-height:1.2}.trip-summary-stat-label{font-size:9px;color:var(--muted);letter-spacing:1px;margin-top:2px}.trip-summary-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--accent);animation:summaryCountdown 4s linear forwards}@keyframes summaryCountdown{0%{width:100%}to{width:0%}}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:6000;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:10px 18px;font-size:13px;font-weight:600;box-shadow:0 8px 28px #00000059;cursor:pointer;animation:toastIn .25s ease-out;white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-badge{font-size:9px;color:var(--yellow);padding:3px 7px;background:#eab3081f;border-radius:6px;letter-spacing:.5px;font-weight:700}.sidebar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1999;background:#00000059}
