:root{--bg:#15181d;--panel:#1d2129;--text:#eef1f6;--muted:#98a2b3;--accent:#4aa3ff;--route-bg:#c8102e;--route-text:#fff;--live:#34d058}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.board{flex-direction:column;gap:1rem;height:100%;padding:clamp(.75rem,2vw,1.5rem);display:flex}.topbar{justify-content:space-between;align-items:center;display:flex}.brand{letter-spacing:-.02em;font-size:clamp(1.1rem,2.2vw,1.6rem);font-weight:800}.brand .accent{color:var(--accent)}.live{color:var(--live);font-weight:700}.sched{color:var(--muted);border:1px solid var(--muted);border-radius:999px;padding:.1em .7em;font-size:.85em;font-weight:600}.grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(min(100%,22rem),1fr));align-content:start;gap:1rem;display:grid}.card{background:var(--panel);border-radius:.9rem;flex-direction:column;gap:.55rem;padding:clamp(.7rem,1.5vw,1.1rem);display:flex}.card h2{margin:0 0 .2rem;font-size:clamp(1rem,1.8vw,1.35rem)}.row{grid-template-columns:auto 1fr auto;align-items:center;gap:.7rem;display:grid}.badge{background:var(--route-bg);color:var(--route-text);text-align:center;border-radius:.4rem;min-width:2.2em;padding:.15em .5em;font-weight:800}.badge[data-mode=rail],.badge[data-mode=metro]{--route-bg:#2d6cdf}.badge[data-mode=tram]{--route-bg:#1f9d55}.badge[data-mode=ferry],.badge[data-mode=gondola],.badge[data-mode=funicular],.badge[data-mode=cablecar]{--route-bg:#0e9bb0}.meta{flex-direction:column;min-width:0;display:flex}.dest{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.mode{color:var(--muted);letter-spacing:.04em;font-size:.72em}.times{font-variant-numeric:tabular-nums;gap:.6rem;display:flex}.time{white-space:nowrap;font-weight:700;position:relative}.time.cancelled{color:var(--muted);text-decoration:line-through}.time .dot{background:var(--live);border-radius:50%;width:5px;height:5px;margin-left:-2.5px;animation:1.8s ease-in-out infinite pulse;position:absolute;bottom:-.4em;left:50%}@keyframes pulse{0%,to{opacity:.35}50%{opacity:1}}.empty{color:var(--muted);margin:.2rem 0}.attrib{color:var(--muted);text-align:center;font-size:.72em}.topbar{gap:.6rem}.gear{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:.1rem .3rem;font-size:1.3rem}.gear:hover{color:var(--text)}.setup{color:var(--muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;display:flex}.muted{color:var(--muted)}.btn{background:var(--accent);color:#06121f;cursor:pointer;border:none;border-radius:.5rem;padding:.45em .9em;font-weight:700}.btn:disabled{opacity:.45;cursor:default}.btn.ghost{color:var(--text);border:1px solid var(--muted);background:0 0}.btn.small{padding:.25em .7em;font-size:.85em}.link{color:var(--accent);cursor:pointer;font:inherit;text-align:left;background:0 0;border:none;padding:0}.settings{flex-direction:column;gap:1rem;width:100%;max-width:48rem;height:100%;margin:0 auto;padding:clamp(.75rem,2vw,1.5rem);display:flex}.panel{background:var(--panel);border-radius:.9rem;flex-direction:column;gap:.7rem;padding:1rem;display:flex}.panel h3{margin:0;font-size:1.05rem}.chips{flex-wrap:wrap;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.chip{background:var(--bg);border-radius:999px;align-items:center;gap:.4rem;padding:.3em .4em .3em .8em;display:inline-flex}.chip .x{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:.9em}.searchbar{flex-wrap:wrap;gap:.5rem;display:flex}.searchbar input{background:var(--bg);color:var(--text);font:inherit;border:1px solid #2c333d;border-radius:.5rem;flex:16rem;padding:.5em .7em}.results,.nearby{flex-direction:column;gap:.4rem;margin:.3rem 0 0;padding:0;list-style:none;display:flex}.nearby-row{justify-content:space-between;align-items:center;gap:.7rem;display:flex}.feed-tag{background:var(--bg);color:var(--muted);letter-spacing:.03em;vertical-align:.05em;border-radius:.3rem;margin:0 .15rem;padding:.05em .4em;font-size:.72em;font-weight:700;display:inline-block}.surface-nav{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0c1073;border-radius:999px;gap:2px;padding:3px;display:flex;position:fixed;top:10px;right:10px}.surface-nav button{color:#cdd5df;font:inherit;cursor:pointer;background:0 0;border:0;border-radius:999px;padding:.3em .95em;font-size:.85rem}.surface-nav button.on{background:var(--accent,#ff5a5f);color:#fff}.map-canvas{position:fixed;inset:0}.surface-loading{height:100vh;color:var(--muted,#9aa4b2);place-items:center;display:grid}
