*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-width: 320px;--bg: #1a1a2e;--bg-surface: #16213e;--bg-hover: #1f3460;--text: #e0e0e0;--text-muted: #888;--accent: #0f9b8e;--accent-hover: #12c4b3;--danger: #e74c3c;--danger-hover: #ff6b6b;--border: #2a2a4a;--radius: 6px}html,body{height:100%;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}#app{display:flex;height:100%;width:100%}#sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}#map-container{flex:1;position:relative}.sidebar-header{padding:16px;border-bottom:1px solid var(--border)}.social-links{display:flex;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}.social-link{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,color .15s}.social-link:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.sidebar-header h1{font-size:18px;font-weight:600;letter-spacing:.5px}.waypoint-list{flex:1;overflow-y:auto;padding:8px}.waypoint-item{display:flex;align-items:center;gap:8px;padding:10px 12px;margin-bottom:4px;background:var(--bg);border-radius:var(--radius);-webkit-user-select:none;user-select:none;transition:background .15s}.waypoint-item:hover{background:var(--bg-hover)}.waypoint-item.waypoint-inactive{opacity:.58;background:color-mix(in srgb,var(--bg) 75%,#64748b 25%)}.waypoint-item.waypoint-inactive .waypoint-index{background:#64748b2e;border-color:#94a3b873;color:#94a3b8}.waypoint-marker.inactive{opacity:.55;filter:grayscale(.8)}.waypoint-item.sortable-ghost{opacity:.4}.waypoint-item.sortable-chosen,.waypoint-item.sortable-drag{cursor:grabbing}.waypoint-index{width:34px;min-height:38px;border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 16%,transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);color:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:12px;font-weight:700;flex-shrink:0;cursor:grab;touch-action:none}.waypoint-index:before{content:"⋮⋮";font-size:10px;line-height:.7;letter-spacing:-2px;opacity:.75}.waypoint-index:hover{background:color-mix(in srgb,var(--accent) 24%,transparent);border-color:var(--accent)}.waypoint-coords{font-size:11px;color:var(--text-muted)}.waypoint-actions-row{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.wp-action-btn{padding:2px 6px;border:1px solid var(--border);border-radius:3px;background:var(--bg-surface);color:var(--text-muted);font-size:10px;font-family:inherit;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap;line-height:1.4}.wp-action-btn:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent)}.wp-open-gmaps:hover{border-color:#4285f4;color:#8ab4f8}.waypoint-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;font-size:16px;line-height:1;transition:color .15s,background .15s}.waypoint-remove:hover{color:var(--danger);background:#e74c3c1a}.waypoint-actions{display:flex;gap:6px;padding:8px 8px 0}.action-btn{flex:1;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s;font-family:inherit}.action-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent)}.action-btn:disabled{opacity:.35;cursor:not-allowed}.delete-all-btn:hover:not(:disabled){border-color:var(--danger);color:var(--danger);background:#e74c3c14}.waypoint-input-row{display:flex;gap:6px;padding:8px 8px 0}.waypoint-input{flex:1;min-width:0;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:12px;font-family:inherit;transition:border-color .15s}.waypoint-input::placeholder{color:var(--text-muted);font-size:11px}.waypoint-input:focus{outline:none;border-color:var(--accent)}.waypoint-input-btn{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--accent);color:#fff;font-size:18px;line-height:1;cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit;padding:0}.waypoint-input-btn:hover:not(:disabled){background:var(--accent-hover)}.waypoint-input-btn:disabled{opacity:.5;cursor:not-allowed}.route-info{border-top:1px solid var(--border);overflow-y:auto;max-height:50%;flex-shrink:0}.route-summary{font-size:14px;font-weight:600;color:var(--text);text-align:center;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg)}.route-calculating{font-size:13px;color:var(--text-muted);text-align:center;padding:12px}.maneuver-list{padding:4px 0}.leg-divider{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);padding:8px 12px 4px}.maneuver-item{display:flex;align-items:flex-start;gap:8px;padding:6px 12px;transition:background .15s}.maneuver-item:hover{background:var(--bg-hover)}.maneuver-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;color:var(--accent)}.maneuver-body{flex:1;min-width:0}.maneuver-instruction{font-size:13px;line-height:1.4}.maneuver-street{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.maneuver-dist{font-size:11px;color:var(--text-muted);flex-shrink:0;padding-top:2px}.empty-state{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:13px;line-height:1.5}.help-overlay{position:fixed;inset:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center}.help-overlay .help-card{position:relative;width:min(440px,90vw);max-height:80vh;overflow-y:auto;padding:20px 20px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;font-size:13px;line-height:1.65;color:var(--text-secondary);box-shadow:0 8px 32px #00000080}.help-overlay .help-card h2{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text-primary)}.help-overlay .help-card h3{margin:16px 0 4px;font-size:13px;font-weight:600;color:var(--text-primary)}.help-overlay .help-card p{margin:4px 0}.help-overlay .help-card em{font-style:normal;font-weight:500}.help-overlay .help-intro{color:var(--text-muted)}.help-overlay .help-note{color:var(--accent);font-weight:500}.help-overlay .help-farewell{margin-top:14px!important;font-style:italic;color:var(--text-muted)}.help-overlay .help-card-close{position:absolute;top:10px;right:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;color:var(--text-muted);font-size:18px;line-height:1;-webkit-user-select:none;user-select:none}.help-overlay .help-card-close:hover{background:var(--bg-hover);color:var(--text-primary)}.maplibregl-ctrl-group{background:var(--bg-surface)!important;border-color:var(--border)!important}.maplibregl-ctrl-group button{background-color:transparent!important}.maplibregl-ctrl-group button+button{border-top-color:var(--border)!important}.maplibregl-ctrl-group button:hover{background-color:var(--bg-hover)!important}.maplibregl-ctrl-group button span{filter:invert(1)}#toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(20px);padding:10px 20px;border-radius:var(--radius);font-size:13px;font-weight:500;z-index:9999;pointer-events:none;opacity:0;transition:opacity .3s,transform .3s;max-width:400px;text-align:center}.toast-visible{opacity:1!important;transform:translate(-50%) translateY(0)!important}.toast-error{background:#c0392b;color:#fff}.toast-success{background:#27ae60;color:#fff}.toast-info{background:var(--bg-surface);color:var(--text);border:1px solid var(--border)}.connection-status{display:inline-block;width:8px;height:8px;border-radius:50%;margin-left:8px;vertical-align:middle;transition:background .3s}.connection-status.connected{background:#27ae60}.connection-status.disconnected{background:#e74c3c}.streamer-status{font-size:12px;margin-top:6px;padding:3px 6px;border-radius:var(--radius);display:inline-block}.streamer-live{color:#27ae60;background:#27ae601f}.streamer-offline{color:var(--text-muted)}.add-position-btn{display:block;width:100%;margin-top:8px;padding:7px 12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;text-align:left}.add-position-btn:hover{background:var(--accent-hover)}.waypoint-info{flex:1;min-width:0}.waypoint-label{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text;border-radius:3px;padding:1px 3px;margin:-1px -3px;transition:background .1s}.waypoint-label:hover{background:var(--bg-hover)}.waypoint-label-input{width:100%;font-size:13px;background:var(--bg);color:var(--text);border:1px solid var(--accent);border-radius:3px;padding:1px 4px;outline:none;font-family:inherit}.context-menu{position:fixed;z-index:10000;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #00000080;min-width:180px;padding:4px 0;-webkit-user-select:none;user-select:none}.context-menu-item{padding:8px 14px;font-size:13px;cursor:pointer;color:var(--text);transition:background .1s}.context-menu-item:hover{background:var(--bg-hover)}.context-menu-danger{color:var(--danger)}.context-menu-danger:hover{background:#e74c3c1f}.context-menu-separator{height:1px;background:var(--border);margin:4px 0}.theme-select{position:absolute;bottom:24px;left:12px;z-index:100;padding:6px 24px 6px 10px;background:var(--bg-surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #0006;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:background-color .15s,border-color .15s}.theme-select:hover{background-color:var(--bg-hover);border-color:var(--accent)}.theme-select:focus{outline:none;border-color:var(--accent)}.theme-select option{background:var(--bg-surface);color:var(--text)}.user-count-inline{margin-left:6px;font-size:11px;font-weight:600;color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:1px 6px;vertical-align:middle}.follow-toggle-btn{position:absolute;top:110px;right:10px;z-index:100;width:29px;height:29px;background:var(--bg-surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:16px;line-height:1;cursor:pointer;box-shadow:0 0 0 2px #0000001a;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,border-color .15s,color .15s}.follow-toggle-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.follow-toggle-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.sidebar-toggle-btn{display:none;position:absolute;top:10px;left:10px;z-index:501;width:36px;height:36px;background:var(--bg-surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:18px;line-height:1;cursor:pointer;box-shadow:0 2px 8px #0006;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.sidebar-toggle-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.help-toggle-btn{position:absolute;top:150px;right:10px;z-index:100;width:29px;height:29px;background:var(--bg-surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;line-height:1;cursor:pointer;box-shadow:0 0 0 2px #0000001a;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.help-toggle-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:499}.sidebar-overlay.visible{display:block}@media(max-width:768px){.sidebar-toggle-btn{display:flex}#sidebar{position:fixed;left:calc(-1 * var(--sidebar-width) - 20px);top:0;height:100%;z-index:500;transition:left .3s ease;box-shadow:4px 0 16px #00000080}#sidebar.sidebar-open{left:0}}.history-panel{background:var(--bg-secondary);border-bottom:1px solid var(--border);max-height:280px;overflow-y:auto}.history-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-secondary)}.history-close{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.history-close:hover{color:var(--text-primary)}.history-list{padding:4px 0}.history-item{padding:8px 12px;cursor:pointer;border-left:3px solid transparent;transition:background .1s}.history-item:hover{background:var(--bg-hover)}.history-item-selected{background:var(--bg-hover);border-left-color:#3b82f6}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.history-date{font-size:12px;color:var(--text-secondary)}.history-platform{font-size:10px;padding:1px 5px;background:var(--bg-tertiary);border-radius:3px;color:var(--text-muted);text-transform:uppercase}.history-title{font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.history-meta{font-size:11px;color:var(--text-muted)}.history-btn{margin-left:auto}.streamer-marker{position:relative}.streamer-heading-arrow{position:absolute;left:50%;bottom:100%;transform-origin:center calc(100% + 24px);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:14px solid #0f9b8e;margin-left:-8px;margin-bottom:4px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6));transition:transform .3s ease;pointer-events:none}.live-eta{background:#0f9b8e1a;border:1px solid rgba(15,155,142,.25);border-radius:6px;padding:8px 10px;margin-bottom:8px}.live-eta-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--accent);margin-bottom:4px}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.3}}.live-eta-stats{display:flex;gap:6px;font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.live-eta-saved{font-size:11px;color:var(--text-muted);margin-top:4px;font-variant-numeric:tabular-nums}
