:root{color-scheme:dark}body{margin:0;-webkit-font-smoothing:antialiased}*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f0f0f;--card-bg: #1a1a1a;--card-border: #2a2a2a;--text: #f0f0f0;--text-muted: #888;--accent: #e4002b;--badge-bg: #333}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app{max-width:480px;margin:0 auto;min-height:100dvh;padding-bottom:env(safe-area-inset-bottom,20px)}header{position:sticky;top:0;z-index:10;background:var(--bg);padding:16px;border-bottom:1px solid var(--card-border);display:flex;align-items:center;gap:8px}header h1{font-size:1.3rem;font-weight:700;color:var(--accent)}header .subtitle{flex:1;font-size:.82rem;color:var(--text-muted)}.refresh-btn{background:var(--card-bg);border:1px solid var(--card-border);color:var(--text);width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;padding-bottom:3px;position:relative}.refresh-btn:active{background:var(--card-border)}.refresh-btn:disabled:not(.spinning){opacity:.5}.refresh-btn.spinning{pointer-events:none;border-color:transparent}.refresh-btn.spinning .refresh-icon{opacity:.3}.refresh-btn.spinning:after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--card-border);border-top-color:var(--accent);animation:spin .8s linear infinite}.last-update{text-align:center;font-size:.75rem;color:var(--text-muted);padding:6px 16px}.filters{display:flex;gap:8px;padding:8px 16px 4px;overflow-x:auto}.pill{padding:6px 16px;border-radius:20px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-muted);font-size:.82rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.pill.active{background:var(--accent);border-color:var(--accent);color:#fff}main{padding:12px}.loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px}.spinner{width:36px;height:36px;border:3px solid var(--card-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{text-align:center;padding:40px 20px;color:var(--accent)}.error button{margin-top:12px;background:var(--accent);color:#fff;border:none;padding:10px 24px;border-radius:8px;font-size:.9rem;cursor:pointer}.empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.stops-list{display:flex;flex-direction:column;gap:10px}.stop-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:14px;cursor:pointer;transition:border-color .2s}.stop-card:active{border-color:#444}.stop-card.expanded{border-color:var(--accent)}.stop-header{display:flex;flex-direction:column;gap:8px}.stop-info{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.stop-info h2{font-size:1rem;font-weight:600}.category{font-size:.75rem;color:var(--text-muted)}.stop-info-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.distance{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.fav-btn{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:4px;line-height:1;color:#555;transition:transform .15s,color .15s}.fav-btn.active{color:#f87171}.fav-btn:active{transform:scale(1.3)}.line-badges{display:flex;flex-wrap:wrap;gap:6px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:16px;font-size:.78rem;font-weight:600;background:var(--badge-bg);color:var(--text)}.badge.metro{color:#fff}.badge.small{padding:2px 8px;font-size:.75rem}.stop-details{margin-top:12px;padding-top:12px;border-top:1px solid var(--card-border);display:flex;flex-direction:column;gap:10px}.line-detail{display:flex;flex-direction:column;gap:4px}.line-detail-header{display:flex;align-items:center;gap:8px}.direction{font-size:.8rem;color:var(--text-muted);flex:1}.wait-message{font-size:.9rem;font-weight:500;padding-left:4px;color:#4ade80}.wait-message.scheduled{color:#60a5fa;font-weight:400}.wait-message.no-data{color:var(--text-muted);font-style:italic;font-weight:400;font-size:.82rem}.no-info{color:var(--text-muted);font-size:.85rem;font-style:italic}
