:root{color:#1d2433;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f4f7f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button{font:inherit}.app-shell{width:min(100%,760px);margin:0 auto;padding:20px 16px 40px}.app-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 0 16px;display:flex}.eyebrow,.muted{color:#667085;margin:0;font-size:.9rem}h1,h2{letter-spacing:0;margin:0}h1{color:#0d392f;font-size:clamp(2rem,2rem + 1vw,3rem);line-height:1}.icon-button{color:#0d392f;cursor:pointer;background:#fff;border:1px solid #c7d7cc;border-radius:8px;place-items:center;width:48px;height:48px;display:inline-grid}.icon-button:disabled{cursor:wait;opacity:.7}.tabs{grid-template-columns:1fr 1fr;gap:8px;margin:12px 0 18px;display:grid}.tab{color:#26352f;cursor:pointer;background:#fff;border:1px solid #c7d7cc;border-radius:8px;min-height:48px}.tab[aria-selected=true]{color:#fff;background:#11785f;border-color:#11785f}.stop-picker{gap:8px;margin:0 0 18px;display:grid}.stop-picker span{color:#475467;font-size:.9rem;font-weight:700}.stop-picker select{color:#1d2433;width:100%;min-height:48px;font:inherit;background:#fff;border:1px solid #b8c9bf;border-radius:8px;padding:0 12px}.selected-stop-panel{background:#fbfffd;border:2px solid #11785f;border-radius:8px;margin:0 0 18px;padding:18px;box-shadow:0 12px 30px #11785f24}.selected-stop-heading{justify-content:space-between;align-items:flex-start;gap:14px;margin-top:4px;display:flex}.selected-stop-heading h2{color:#0a5d4b;font-size:1.65rem;line-height:1.08}.selected-stop-heading span{color:#8a968e;font-variant-numeric:tabular-nums;font-weight:800}.route-map{background:#fff;border:1px solid #d7e2da;border-radius:8px;margin:18px 0 0;padding:16px}.route-map-heading{gap:4px;margin-bottom:14px;display:grid}.route-map-heading h2{color:#0d392f;font-size:1.15rem}.route-map-heading p{color:#667085;margin:0;font-size:.9rem}.route-map-list{margin:0;padding:0;list-style:none;display:grid}.route-map-item{grid-template-columns:1fr;display:grid}.route-stop{color:#26352f;cursor:pointer;text-align:left;background:0 0;border:0;grid-template-columns:28px 1fr;align-items:center;gap:10px;min-height:42px;padding:0;display:grid}.route-dot{background:#fff;border:2px solid #11785f;border-radius:999px;justify-self:center;width:12px;height:12px}.route-stop-name{overflow-wrap:anywhere;min-width:0;font-weight:700}.route-stop-selected .route-dot{background:#11785f;border-color:#0a5d4b;width:20px;height:20px;box-shadow:0 0 0 5px #d9f5e8}.route-stop-selected .route-stop-name{color:#0a5d4b;font-size:1.15rem;font-weight:900}.route-link{border-left:2px solid #c7d7cc;gap:8px;min-height:32px;margin-left:13px;padding:4px 0 8px 24px;display:grid}.route-bus{color:#0d392f;background:#e9f7f1;border-radius:8px;align-items:center;gap:8px;width:fit-content;max-width:100%;padding:6px 9px;font-size:.88rem;font-weight:700;display:inline-flex}.route-bus-icon{color:#fff;text-transform:uppercase;background:#11785f;border-radius:7px;place-items:center;min-width:38px;min-height:24px;font-size:.72rem;font-weight:800;line-height:1;display:inline-grid}.messages,.status-panel,.state{background:#fff;border:1px solid #d7e2da;border-radius:8px;margin:12px 0;padding:16px}.messages{background:#fff9e8;border-color:#ecd493}.stop-list{gap:0;margin:0;padding:0;list-style:none;display:grid}.stop-card{grid-template-columns:28px 1fr;gap:10px;min-height:112px;display:grid}.stop-card-selected .stop-marker span{background:#11785f;border-color:#0a5d4b;width:22px;height:22px;margin-top:20px;box-shadow:0 0 0 6px #d9f5e8}.stop-card-selected .stop-content{background:#fbfffd;border-color:#11785f;box-shadow:0 10px 26px #11785f29}.stop-marker{justify-content:center;display:flex;position:relative}.stop-marker:before{content:"";background:#c7d7cc;width:2px;position:absolute;top:28px;bottom:-4px}.stop-card:last-child .stop-marker:before{display:none}.stop-marker span{z-index:1;background:#f4f7f3;border:3px solid #11785f;border-radius:999px;width:14px;height:14px;margin-top:24px}.stop-content{background:#fff;border:1px solid #d7e2da;border-radius:8px;margin-bottom:12px;padding:14px}.stop-heading{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.stop-title-button{color:#1d2433;cursor:pointer;text-align:left;background:0 0;border:0;min-width:0;padding:0;font-size:1.05rem;font-weight:800;line-height:1.25}.stop-card-selected .stop-title-button{color:#0a5d4b;font-size:1.35rem}.stop-heading h2{font-size:1.05rem;line-height:1.25}.stop-heading span{color:#8a968e;font-variant-numeric:tabular-nums}.waiting-times{gap:8px;margin-top:12px;display:grid}.waiting-pill{background:#e9f7f1;border-radius:8px;grid-template-columns:minmax(74px,auto) 1fr;align-items:center;gap:4px 10px;padding:10px 12px;display:grid}.waiting-pill strong{color:#0d392f;font-size:1.1rem}.waiting-pill span{overflow-wrap:anywhere;min-width:0}.waiting-pill small{color:#667085;grid-column:2}.empty-inline{color:#667085;margin:12px 0 0}.bus-inline{color:#0d392f;background:#f2faf6;border-left:3px solid #11785f;border-radius:6px;align-items:center;gap:8px;margin:12px 0 0;padding:9px 10px;font-size:.92rem;display:flex}.bus-icon,.bus-cluster span{color:#fff;text-transform:uppercase;background:#11785f;border-radius:7px;place-items:center;min-width:38px;min-height:24px;font-size:.72rem;font-weight:800;line-height:1;display:inline-grid}.bus-inline strong{font-variant-numeric:tabular-nums}.ellipsis-row{color:#667085;grid-template-columns:28px 1fr;align-items:center;gap:10px;min-height:64px;display:grid}.ellipsis-row>span{text-align:center;font-weight:800}.bus-cluster{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.bus-cluster span{text-transform:none;background:#0a5d4b;min-width:auto;min-height:28px;padding:0 9px;font-size:.75rem}.state{text-align:center}.state button{color:#fff;cursor:pointer;background:#11785f;border:0;border-radius:8px;min-height:42px;margin-top:10px;padding:0 16px}.state-error{background:#fff2ee;border-color:#f3b5a7}.loader{border:3px solid #c7d7cc;border-top-color:#11785f;border-radius:999px;width:28px;height:28px;margin:0 auto 10px;animation:.9s linear infinite spin}.bus-segments{gap:8px;margin:12px 0;padding:0;list-style:none;display:grid}.bus-segments li{background:#e9f7f1;border-radius:8px;padding:10px 12px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes spin{to{transform:rotate(360deg)}}@media (width>=680px){.app-shell{padding-top:34px}.waiting-times{grid-template-columns:repeat(2,minmax(0,1fr))}}
