:root{--bg:#f5f5f5;--text:#111;--text-muted:#444;--text-dim:#666;--accent:#3b82f6;--accent-bg:#3b82f6;--accent-text:#fff;--surface:#fff;--surface-alt:#f0f0f0;--border:#ddd;--card-bg:#fff;--card-red-bg:#fff5f5;--input-bg:#fff;--input-text:#1a1a1a;--active-bg:#eff6ff;--active-border:#3b82f6;--status-green:#16a34a}.app.dark{--bg:#0a0e1a;--text:#e0e0e0;--text-muted:#888;--text-dim:#666;--accent:#60a5fa;--accent-bg:#60a5fa;--accent-text:#0a0e1a;--surface:#141824;--surface-alt:#101420;--border:#2a2e3a;--card-bg:#141824;--card-red-bg:#1a1014;--input-bg:#141824;--input-text:#fff;--active-bg:#1a2540;--active-border:#60a5fa;--status-green:#4ade80}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:450}.app.dark body,.app.dark{font-weight:400}.app{background:var(--bg);max-width:480px;min-height:100vh;color:var(--text);flex-direction:column;gap:24px;margin:0 auto;padding:20px 16px;display:flex;position:relative}header{text-align:center;padding:0 56px;position:relative}header h1{color:var(--accent);letter-spacing:2px;font-size:2rem}.tagline{color:var(--text-muted);margin-top:4px;font-size:.85rem}.help-toggle{background:var(--surface);border:1px solid var(--border);cursor:pointer;width:40px;min-width:40px;height:40px;min-height:40px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.1rem;font-weight:700;line-height:1;display:flex;position:absolute;top:50%;left:0;transform:translateY(-50%)}.help-toggle:active{background:var(--surface-alt)}.theme-toggle{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;min-width:48px;min-height:48px;padding:10px 14px;font-size:1.3rem;line-height:1;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%)}.destination-input{flex-direction:column;gap:10px;display:flex}.dest-row{gap:8px;display:flex}.dest-row input{border:1px solid var(--border);background:var(--input-bg);color:var(--input-text);border-radius:10px;flex:1;min-height:50px;padding:14px 16px;font-size:1.05rem}.dest-row input::placeholder{color:var(--text-dim)}.dest-row button{background:var(--accent-bg);color:var(--accent-text);cursor:pointer;border:none;border-radius:10px;min-width:60px;min-height:50px;padding:14px 24px;font-size:1.05rem;font-weight:700}.destination-input button:disabled{opacity:.4;cursor:default}.quick-picks{flex-wrap:wrap;gap:8px;display:flex}.quick-pick{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:20px;min-height:44px;padding:12px 18px;font-size:.95rem}.quick-pick:disabled{opacity:.4;cursor:default}.popular-btn{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);cursor:pointer;border-radius:10px;min-height:48px;padding:12px;font-size:1rem}.popular-btn:disabled{opacity:.4;cursor:default}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);-webkit-overflow-scrolling:touch;border-bottom:none;border-radius:16px 16px 0 0;width:100%;max-width:480px;max-height:92vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;border-radius:16px 16px 0 0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex;position:sticky;top:0}.modal-header:before{content:"";background:var(--border);border-radius:2px;width:36px;height:4px;position:absolute;top:6px;left:50%;transform:translate(-50%)}.modal-header h2{color:var(--text);margin:0;font-size:1.1rem}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:40px;min-height:40px;padding:8px;font-size:1.2rem;display:flex}.modal-close:active{background:var(--surface-alt)}.modal-body{padding:16px;padding-bottom:max(16px, env(safe-area-inset-bottom));color:var(--text-muted);flex-direction:column;gap:8px;font-size:.95rem;line-height:1.5;display:flex}.help-body{text-align:left;gap:14px}.help-body section h3{color:var(--text);margin-bottom:6px;font-size:1rem}.help-body section p{margin:0}.help-body hr{border:none;border-top:1px solid var(--border);margin:2px 0}.help-body ul{flex-direction:column;gap:6px;margin:0;padding-left:20px;display:flex}.help-install-btn{background:var(--accent-bg);width:100%;color:var(--accent-text);cursor:pointer;border:none;border-radius:10px;min-height:48px;margin-top:10px;padding:12px 18px;font-size:1rem;font-weight:700;display:block}.help-install-steps{background:var(--surface-alt);border-radius:8px;margin-top:10px;padding:10px 14px}.help-install-steps ol{flex-direction:column;gap:6px;margin:6px 0 0;padding-left:20px;display:flex}.help-install-steps li{line-height:1.5}.help-installed-note{color:var(--status-green);margin-top:8px;font-weight:500}.modal-body .quick-pick{text-align:left;border-radius:10px;width:100%;min-height:48px;padding:14px 16px;font-size:1rem}.dest-active{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:10px;padding:14px;display:flex}.dest-label{text-align:center;color:var(--accent);margin:0;font-size:1rem}.dest-address{text-align:center;color:var(--text-muted);margin:0;font-size:.85rem}.dest-actions{flex-direction:column;gap:8px;display:flex}.dest-actions-row{gap:8px;display:flex}.action-btn{border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:4px;min-height:48px;padding:12px 8px;font-size:.95rem;font-weight:500;transition:background .15s,border-color .15s;display:flex}.action-btn:active{background:var(--active-bg);border-color:var(--active-border)}.action-btn.clear-dest{color:#f44;border-color:#ff44444d}.action-btn.clear-dest:active{background:#ff44441a}.collapse-toggle{width:100%;color:var(--text-dim);cursor:pointer;letter-spacing:.3px;background:0 0;border:none;border-radius:8px;min-height:44px;padding:12px;font-size:.85rem}.collapse-toggle:active{background:var(--surface-alt)}.no-stations{text-align:center;color:var(--text-muted);padding:20px 0;font-size:.95rem}.error{color:#f44;margin-top:4px;font-size:.85rem}.mode-toggle{border:1px solid var(--border);border-radius:8px;gap:0;display:flex;overflow:hidden}.mode-toggle button{background:var(--surface);color:var(--text-muted);cursor:pointer;border:none;flex:1;min-height:48px;padding:12px;font-size:.95rem;transition:all .2s}.mode-toggle button.active{background:var(--accent-bg);color:var(--accent-text);font-weight:700}.voice-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.voice-controls button{border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:10px;flex:1;min-height:48px;padding:12px 18px;font-size:1rem}.voice-controls button.active{color:#2e7d32;background:#e8f5e9;border-color:#4caf50}.app.dark .voice-controls button.active{color:#81c784;background:#4caf5026;border-color:#4caf5080}.voice-controls button.inactive{color:#f44;border-color:#f44}.last-spoken{text-align:center;width:100%;color:var(--text-dim);font-size:.85rem;font-style:italic}.poll-controls{flex-wrap:wrap;align-items:center;gap:10px;width:100%;font-size:1rem;display:flex}.poll-controls label{color:var(--text-muted);font-size:.95rem}.poll-controls select{border:1px solid var(--border);background:var(--input-bg);color:var(--input-text);border-radius:10px;min-height:48px;padding:12px 14px;font-size:1rem}.poll-hint{width:100%;color:var(--text-dim);margin-top:-2px;font-size:.8rem}.controls-toolbar{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;padding:14px;display:flex}.toolbar-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.controls-toolbar .mode-toggle{border-radius:10px}.controls-toolbar .mode-toggle button{background:var(--surface-alt)}.controls-toolbar .mode-toggle button.active{background:var(--accent-bg);color:var(--accent-text)}.station-list{flex-direction:column;gap:12px;display:flex}.station-card{background:var(--card-bg);border-left:5px solid;border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);content-visibility:auto;contain-intrinsic-size:auto 110px;word-break:break-word;border-radius:12px;padding:16px;position:relative;overflow:hidden}.station-card.green{border-color:var(--status-green)}.station-card.yellow{border-color:#ffc107}.station-card.red{background:var(--card-red-bg);border-color:#f44}.station-card.flash{animation:.5s ease-in-out 3 flash-pulse}.station-card.longpress{animation:.8s ease-out forwards longpress-glow}.station-card.green.longpress{--glow-color:var(--status-green)}.station-card.yellow.longpress{--glow-color:#ffc107}.station-card.red.longpress{--glow-color:#f44}@keyframes longpress-glow{0%{box-shadow:0 0 0 3px var(--glow-color), 0 0 18px 4px var(--glow-color)}to{box-shadow:none}}@keyframes flash-pulse{0%,to{opacity:1}50%{opacity:.4}}.tag{background:var(--status-green);color:#fff;border-radius:6px;padding:4px 8px;font-size:.7rem;font-weight:700;position:absolute;top:10px;right:10px}.app.dark .tag{color:#000}.station-card h3{color:var(--text);margin-bottom:8px;padding-right:70px;font-size:1.05rem}.station-link{color:inherit;text-decoration:none}.station-link:hover,.station-link:active{text-decoration:underline}.station-stats{color:var(--text-muted);flex-wrap:wrap;gap:6px 12px;font-size:.95rem;display:flex}.station-stats .docks{color:var(--status-green);font-weight:700}.station-card.yellow .station-stats .docks{color:#ffc107}.station-card.red .station-stats .docks{color:#f44}.bike-types{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.bike-type{letter-spacing:.02em;border:1.5px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:6px 14px;font-size:.9rem;font-weight:700;display:inline-flex}.bike-type.mechanical{color:#2e7d32;background:#e8f5e9;border-color:#a5d6a7}.bike-type.ebike{color:#1565c0;background:#e3f2fd;border-color:#90caf9}.app.dark .bike-type.mechanical{color:#81c784;background:#4caf5026;border-color:#4caf5059}.app.dark .bike-type.ebike{color:#64b5f6;background:#42a5f526;border-color:#42a5f559}.station-distances{color:var(--text-dim);flex-wrap:wrap;gap:6px 12px;margin-top:6px;font-size:.85rem;display:flex}.hint{color:var(--text-dim);text-align:center;font-size:.85rem;line-height:1.4}.hint-box{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:12px;font-size:.95rem;line-height:1.5}.hint-box strong{color:var(--text)}footer{color:var(--text-muted);border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:6px;margin-top:auto;padding:16px 0;font-size:.85rem;display:flex}.gps-accuracy{color:var(--text-dim);font-size:.85rem}.gps-error{color:#f44}.credit{text-align:center;color:var(--text-dim);padding:12px 0 8px;font-size:.85rem}.credit a{color:var(--accent);text-decoration:none}.credit a:hover{text-decoration:underline}.dock-me-btn{border:2px solid var(--accent);background:var(--accent-bg);width:100%;color:var(--accent-text);cursor:pointer;letter-spacing:.5px;border-radius:12px;min-height:56px;padding:16px;font-size:1.1rem;font-weight:700}.dock-me-btn:disabled{opacity:.4;cursor:default}.map-view{border:1px solid var(--border);border-radius:12px;width:100%;height:280px;overflow:hidden}.eta{color:var(--accent);font-weight:600}.app{padding-top:max(20px, env(safe-area-inset-top));padding-bottom:max(20px, env(safe-area-inset-bottom));padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}.quick-pick:active,.popular-btn:active,.dock-me-btn:active{opacity:.8;transform:scale(.98)}.mode-toggle button:active{opacity:.85}.modal-overlay{animation:.15s ease-out fade-in}.modal{animation:.2s ease-out slide-up}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.install-banner{background:var(--surface);border:1px solid var(--accent);border-radius:12px;flex-direction:column;gap:12px;padding:14px;display:flex;position:relative}.install-content{align-items:center;gap:10px;padding-right:28px;display:flex}.install-icon{flex-shrink:0;font-size:1.5rem}.install-text{flex-direction:column;gap:2px;font-size:.9rem;display:flex}.install-text strong{color:var(--text)}.install-text span{color:var(--text-muted);font-size:.8rem}.install-actions{gap:8px;display:flex}.install-btn{background:var(--accent-bg);color:var(--accent-text);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;flex:1;min-height:44px;padding:10px 18px;font-size:.95rem;font-weight:700}.install-dismiss{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;min-width:28px;min-height:28px;padding:4px;font-size:1.1rem;display:flex;position:absolute;top:10px;right:10px}.ios-install-steps ol{flex-direction:column;gap:10px;margin:10px 0;padding-left:20px;display:flex}.ios-install-steps li{line-height:1.5}.ios-icon{font-size:1.1rem}.ios-note{background:var(--surface-alt);color:var(--text-muted);border-radius:8px;padding:10px 12px;font-size:.85rem}.voice-commands{flex-direction:column;gap:8px;width:100%;display:flex}.voice-cmd-row{align-items:center;gap:8px;display:flex}.voice-cmd-btn{border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;min-height:48px;padding:12px 18px;font-size:1rem;transition:all .2s;display:flex}.voice-cmd-btn.listening{color:#2e7d32;background:#e8f5e9;border-color:#4caf50;animation:2s ease-in-out infinite pulse-border}.app.dark .voice-cmd-btn.listening{color:#81c784;background:#4caf5026;border-color:#4caf5080}@keyframes pulse-border{0%,to{border-color:#4caf50;box-shadow:0 0 #4caf5066}50%{border-color:#81c784;box-shadow:0 0 0 4px #4caf5000}}.voice-cmd-feedback{text-align:center;width:100%;color:var(--accent);min-height:1.2em;font-size:.85rem;font-style:italic}.voice-cmd-help-toggle{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:4px;font-size:.8rem;text-decoration:underline}.voice-cmd-help{background:var(--surface-alt);color:var(--text-muted);border-radius:8px;padding:10px 14px;font-size:.82rem;line-height:1.6}.voice-cmd-help code{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:1px 5px;font-size:.8rem}
