:root{--bg: #0e1726;--bg-soft: #15213a;--card: #1a2742;--card-2: #213256;--border: #2c3f6b;--text: #eef2ff;--text-dim: #9aaad0;--accent: #3b82f6;--bus: #2e86de;--tram: #e74c3c;--rail: #8e44ad;--warn-bg: #5a3a0c;--warn-border: #b9770e;--warn-text: #ffe7b3;--danger: #e74c3c;--shadow: 0 4px 20px rgba(0, 0, 0, .35);--radius: 14px}@media (prefers-color-scheme: light){:root{--bg: #f4f6fb;--bg-soft: #ffffff;--card: #ffffff;--card-2: #f0f3fa;--border: #d8dff0;--text: #0e1726;--text-dim: #5b6685;--warn-bg: #fff5d9;--warn-border: #c98b13;--warn-text: #5a3d05;--shadow: 0 4px 16px rgba(15, 30, 60, .08)}}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}a{color:var(--accent)}.app{max-width:1100px;margin:0 auto;padding:2rem 1.25rem 4rem}.app__header h1{margin:0 0 .25rem;font-size:2rem;letter-spacing:-.01em}.app__subtitle{margin:0;color:var(--text-dim)}.app__footer{margin-top:3rem;color:var(--text-dim);font-size:.85rem;text-align:center}.banner{margin:1rem 0;padding:1rem 1.1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--card);font-size:.95rem;line-height:1.5}.banner code{background:#ffffff14;padding:.1rem .4rem;border-radius:6px;margin:0 .2rem;font-size:.9em}.banner--warn{background:var(--warn-bg);border-color:var(--warn-border);color:var(--warn-text)}.controls{margin:1.5rem 0 1rem;display:flex;flex-direction:column;gap:.5rem}.controls__count{margin:0;color:var(--text-dim);font-size:.85rem}.stop-search{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}.stop-search__label{display:block;margin-bottom:.5rem;font-weight:600}.stop-search__input{width:100%;padding:.75rem .9rem;font-size:1rem;border-radius:10px;border:1px solid var(--border);background:var(--bg-soft);color:var(--text)}.stop-search__input:focus{outline:2px solid var(--accent);outline-offset:1px}.stop-search__input:disabled{opacity:.6;cursor:not-allowed}.stop-search__hint{margin:.5rem 0 0;color:var(--text-dim);font-size:.85rem}.stop-search__error{margin:.5rem 0 0;color:var(--danger);font-size:.85rem}.stop-search__results{list-style:none;margin:.75rem 0 0;padding:0;display:flex;flex-direction:column;gap:.25rem;max-height:320px;overflow-y:auto}.stop-search__result{width:100%;display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;border-radius:8px;border:1px solid transparent;background:var(--card-2);color:var(--text);text-align:left;cursor:pointer;font-size:.95rem}.stop-search__result:hover,.stop-search__result:focus-visible{border-color:var(--accent);outline:none}.stop-search__result-name{flex:1;font-weight:500}.stop-search__result-code{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.85rem}.stop-search__result-desc{color:var(--text-dim);font-size:.8rem}.empty-state{margin-top:2rem;padding:2rem;border:2px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--text-dim)}.stop-grid{margin-top:1.5rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.stop-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.stop-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.9rem 1rem;border-bottom:1px solid var(--border)}.stop-card__title{display:flex;align-items:center;gap:.6rem;min-width:0}.stop-card__name{margin:0;font-size:1.05rem;line-height:1.25;word-break:break-word}.stop-card__meta{margin:.15rem 0 0;display:flex;gap:.6rem;color:var(--text-dim);font-size:.8rem}.stop-card__actions{display:flex;gap:.25rem;flex-shrink:0}.icon-btn{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--card-2);color:var(--text);cursor:pointer;font-size:.95rem;line-height:1}.icon-btn:hover:not(:disabled){border-color:var(--accent)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn--danger:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.stop-card__body{padding:.5rem .5rem .25rem;flex:1}.stop-card__error{margin:.5rem;padding:.6rem .8rem;border-radius:8px;background:#e74c3c1f;color:var(--danger);font-size:.9rem}.stop-card__empty{margin:.75rem;color:var(--text-dim);text-align:center;font-size:.9rem}.stop-card__footer{padding:.5rem 1rem .75rem;font-size:.75rem;color:var(--text-dim);display:flex;justify-content:flex-end}.stop-card__loading:before{content:"⟳";margin-right:.3rem;display:inline-block;animation:spin 1.2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.departures{list-style:none;margin:0;padding:0}.departure{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.55rem .75rem;border-radius:10px}.departure+.departure{border-top:1px solid var(--border);border-radius:0}.route-badge{min-width:44px;padding:.25rem .55rem;border-radius:8px;background:var(--bus);color:#fff;text-align:center;font-weight:700;font-size:.95rem;font-variant-numeric:tabular-nums}.route-badge.route-tram{background:var(--tram)}.route-badge.route-rail{background:var(--rail)}.departure__headsign{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.departure__times{display:flex;flex-direction:column;align-items:flex-end;gap:.05rem;font-variant-numeric:tabular-nums}.departure__rel{font-weight:700;font-size:1rem}.departure__clock{display:inline-flex;align-items:center;gap:.3rem;color:var(--text-dim);font-size:.8rem}.rt-dot{width:7px;height:7px;border-radius:50%;background:#2ecc71;display:inline-block;box-shadow:0 0 0 2px #2ecc7140}.mode-dot{width:12px;height:12px;border-radius:50%;background:var(--bus);flex-shrink:0}.mode-dot.mode-tram{background:var(--tram)}.mode-dot.mode-rail{background:var(--rail)}.stop-card--tram{border-top:3px solid var(--tram)}.stop-card--bus{border-top:3px solid var(--bus)}.stop-card--rail{border-top:3px solid var(--rail)}.privacy-banner{position:fixed;bottom:0;left:0;right:0;z-index:900;background:var(--card);border-top:1px solid var(--border);box-shadow:0 -4px 20px #00000040}.privacy-banner__content{max-width:1100px;margin:0 auto;padding:1rem 1.25rem;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1.5rem}.privacy-banner__title{margin:0;font-weight:600;font-size:.95rem}.privacy-banner__text{margin:0;flex:1;min-width:250px;font-size:.85rem;color:var(--text-dim);line-height:1.45}.privacy-banner__text code{background:var(--card-2);padding:.1em .35em;border-radius:4px;font-size:.8rem}.privacy-banner__btn{flex-shrink:0;padding:.5rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:opacity .15s}.privacy-banner__btn:hover{opacity:.85}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);max-width:600px;width:100%;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.modal__header h2{margin:0;font-size:1.5rem;font-weight:600}.modal__close{background:none;border:none;color:var(--text-dim);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;transition:color .15s}.modal__close:hover{color:var(--text)}.modal__content{flex:1;overflow-y:auto;padding:1.5rem}.modal__section{margin-bottom:1.5rem}.modal__section:last-child{margin-bottom:0}.modal__section h3{margin:0 0 .75rem;font-size:1.1rem;font-weight:600;color:var(--accent)}.modal__section p{margin:0 0 .75rem;color:var(--text-dim);line-height:1.6;font-size:.95rem}.modal__section p:last-child{margin-bottom:0}.modal__section code{background:var(--card);padding:.2em .4em;border-radius:4px;font-family:Courier New,monospace;font-size:.85em;color:var(--text)}.modal__link{display:inline-block;color:var(--accent);text-decoration:none;font-weight:500;transition:opacity .15s}.modal__link:hover{opacity:.8;text-decoration:underline}.modal__link-inline{color:var(--accent);text-decoration:none;font-weight:500;transition:opacity .15s;cursor:pointer}.modal__link-inline:hover{opacity:.8;text-decoration:underline}.modal__footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.modal__btn-close{padding:.75rem 2rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .15s}.modal__btn-close:hover{opacity:.85}.app__header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.app__about-btn{background:transparent;border:2px solid var(--border);border-radius:50%;width:44px;height:44px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:all .15s;flex-shrink:0;color:var(--text-dim)}.app__about-btn:hover{opacity:1;background:var(--card);border-color:var(--accent);color:var(--accent)}@media (max-width: 480px){.app{padding:1.25rem .75rem 3rem}.app__header h1{font-size:1.5rem}.app__header-content{flex-direction:column;align-items:stretch}.app__about-btn{align-self:flex-start}.stop-card__name{font-size:1rem}.route-badge{min-width:38px;font-size:.85rem}.privacy-banner__content{flex-direction:column;align-items:stretch}.privacy-banner__btn{width:100%;text-align:center}.modal{max-height:90vh}.modal__header{padding:1.25rem}.modal__header h2{font-size:1.25rem}.modal__content{padding:1.25rem}.modal__footer{padding:1rem 1.25rem}}
