body{margin:0;font-family:"Monospace",monospace;background:#fff7f2;color:#1f1f1f}html{color-scheme:light}a{color:#d9481b;text-decoration:none}a:hover{color:#f05a28;text-decoration:underline dotted;text-underline-offset:3px}#streetcar-image{height:15rem;border-radius:.5rem;box-shadow:0 10px 30px #00000026}.zoomable-image{cursor:zoom-in;transition:transform .2s ease,box-shadow .2s ease}.zoomable-image:hover{transform:scale(1.04);box-shadow:0 14px 36px #0003}.wrapper{display:flex;flex-direction:column;align-items:center}.title{font-size:2rem;font-weight:700;font-style:italic;margin:1rem;text-align:center}.nav{display:flex;gap:1.5rem;justify-content:center;padding:1rem 0 .5rem;font-family:Inter,Arial,sans-serif}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin:.75rem 0 1.5rem}.status-grid.compact{margin:0 0 1rem}.status-card{background:#fff7f2;border-radius:.5rem;padding:.75rem;display:flex;flex-direction:column;gap:.35rem;text-align:left}.status-card span{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#7a3c22}.status-card strong{font-size:1.1rem;color:#1f1f1f}.information{text-align:center;margin:1rem;font-family:Inter}.loading{color:#f05a28;font-family:monospace}.loading-dots span{opacity:0;animation:loading-dots 1.4s infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.1s}.loading-dots span:nth-child(3){animation-delay:.2s}@keyframes loading-dots{0%,80%,to{opacity:0}20%{opacity:1}}.info{text-align:center;margin:1rem;font-family:Inter}.footer a{color:#f05a28}.footer{font-family:Arial,Helvetica,sans-serif;padding-bottom:2rem;text-align:center}.image-modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;animation:modalFadeIn .2s ease forwards}.image-modal-content{position:relative;max-width:min(90vw,900px);max-height:90vh;transform:scale(.96);opacity:0;animation:modalZoomIn .22s ease forwards}.image-modal-content img{width:100%;height:auto;border-radius:.75rem;box-shadow:0 20px 50px #0006}.image-modal-close{position:absolute;top:-12px;right:-12px;background:#f05a28;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:1.5rem;cursor:pointer;box-shadow:0 6px 16px #0000004d}.data-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));width:min(900px,95%);margin-bottom:2rem}.data-card{background:#fff;border-radius:.75rem;padding:1rem 1.25rem;box-shadow:0 8px 20px #00000014;border:1px solid rgba(240,90,40,.2)}.data-card h3{margin-top:0;color:#f05a28}.feed-card{position:relative;overflow:hidden}.feed-pulse:after{content:"";position:absolute;inset:0;background:#f05a281a;opacity:.7;animation:feed-pulse 1s ease-out;pointer-events:none}@keyframes feed-pulse{0%{opacity:.7}to{opacity:0}}.feed-gauges{display:grid;gap:1rem;margin:1rem 0 .5rem}.gauge-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#7a3c22;margin-bottom:.35rem}.gauge-bar{background:#fde8dc;border-radius:999px;overflow:hidden;display:flex;height:10px}.gauge-bar span{display:block;height:100%;background:#f05a28}.gauge-bar.single span{width:0}.gauge-secondary{background:#cbd5f5}.gauge-caption{font-size:.75rem;color:#6b7280;margin-top:.35rem}.feed-metric{display:flex;align-items:center;justify-content:space-between;gap:1rem}.metric-value{font-size:2rem;font-weight:700;color:#111827}.metric-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#7a3c22}.metric-chip{background:#fff7f2;color:#7a3c22;padding:.3rem .75rem;border-radius:999px;font-size:.75rem;white-space:nowrap}.feed-activity{margin:.85rem 0 .5rem}.panel-title{font-weight:700;margin-bottom:.3rem;color:#1f2937}.panel-search{width:100%;padding:.6rem .75rem;border-radius:.6rem;border:1px solid #e5e7eb;font-size:.9rem}.panel-search:focus{outline:2px solid rgba(240,90,40,.3);border-color:#f05a2880}.data-card pre{background:#fff7f2;padding:.75rem;border-radius:.5rem;overflow-x:auto;font-size:.85rem}.sample-list{display:grid;gap:.75rem;margin-top:.75rem}.sample-item{background:#fff7f2;border-radius:.5rem;padding:.75rem;display:grid;gap:.4rem}.sample-row{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem}.sample-key{font-weight:600;color:#7a3c22;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}.sample-value{font-family:monospace;color:#1f1f1f}.muted{color:#7a7a7a;font-style:italic}.feed-links{list-style:none;padding:0;margin:.5rem 0 1.5rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.leaderboard .leaderboard-position{will-change:transform}.leaderboard-item{will-change:transform,opacity}.leaderboard-enter{animation:leaderboard-enter .26s cubic-bezier(.2,.8,.2,1)}@keyframes leaderboard-enter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.leaderboard-position{display:flex;flex-direction:column;align-items:center;font-family:"Monospace",monospace}.content{width:100%;display:grid;grid-template-columns:2fr 1fr}.left-side{display:flex;justify-content:left;white-space:nowrap;overflow:hidden}.right-side{display:flex;justify-content:right;align-items:center;gap:.6rem;flex-wrap:nowrap}.position-route-number{color:#f05a28}.position-speed-ms{color:#9ca3af;font-size:.85rem;transition:opacity .18s ease;opacity:0}.position-speed{white-space:nowrap}.position-speed-ms{margin-left:.5rem;white-space:nowrap}.leaderboard-position:focus .position-speed-ms,.leaderboard-position:hover .position-speed-ms,.leaderboard-position:focus-within .position-speed-ms{opacity:1}.live-indicator{display:flex;align-items:center;gap:.5rem;width:min(900px,95%);margin:1rem 0 .75rem;padding:.5rem .75rem;background:#fff7f2;border:2px dashed #1f1f1f}.live-indicator.pulse .live-dot{animation:livePulse .7s ease}.live-dot{width:10px;height:10px;border-radius:50%;background:#10b981}.live-text{font-family:monospace;font-size:.85rem;color:#1f1f1f}@keyframes livePulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.flip-number{display:inline-block;transition:transform 60ms ease,opacity 60ms ease}.flip-number.flipping{transform:translateY(-2px) scale(1.05);opacity:.8}.tracking-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;width:min(900px,95%);margin:1rem 0;position:relative}.tracking-stats .status-card{border:2px dashed #1f1f1f;border-radius:0;perspective:1000px;padding:.5rem .75rem}.tracking-stats .status-card span{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:#7a3c22}.tracking-stats .status-card strong{display:block;font-size:3.25rem;font-weight:700;line-height:1.1;margin-top:.15rem}.fleet-status-container{width:min(900px,95%);margin:.5rem 0 1rem}.fleet-status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.fleet-status-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#7a3c22}.fleet-status-legend{display:flex;gap:1rem;font-size:.75rem;font-family:monospace;color:#1f1f1f}.legend-item{display:flex;align-items:center;gap:.35rem}.legend-dot{width:8px;height:8px;border-radius:50%}.legend-dot.moving{background:#10b981}.legend-dot.stopped{background:#ef4444}.fleet-status-bar{display:flex;height:12px;border:2px solid #1f1f1f;overflow:hidden;background:#fde8dc}.fleet-segment{transition:width .3s ease;min-width:0}.fleet-segment.moving{background:#10b981}.fleet-segment.stopped{background:#ef4444}.segment-count{font-family:monospace;font-size:.75rem;font-weight:600;white-space:nowrap;padding:0 .5rem}.route-type-filters{display:flex;flex-wrap:wrap;gap:.5rem;width:min(900px,95%);margin:0 0 1rem}.filter-btn{display:flex;align-items:center;gap:.35rem;padding:.5rem .85rem;font-family:monospace;font-size:.8rem;font-weight:600;background:#fff;border:2px solid #1f1f1f;cursor:pointer;transition:all .15s ease;color:#1f1f1f}.filter-btn:hover{background:#fde8dc}.filter-btn.active{background:#f05a28;color:#fff;border-color:#f05a28}.filter-btn.filter-local.active{background:#3b82f6;border-color:#3b82f6}.filter-btn.filter-express.active{background:#10b981;border-color:#10b981}.filter-btn.filter-school.active{background:#f59e0b;border-color:#f59e0b}.filter-count{font-size:.7rem;padding:.1rem .35rem;background:#00000026;border-radius:2px}.filter-btn.active .filter-count{background:#ffffff40}.bus-cluster{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:#7c3aed;border:3px solid #fff;box-shadow:0 2px 6px #00000059;cursor:pointer;transition:transform .15s ease}.bus-cluster:hover{transform:scale(1.15)}.cluster-count{font-size:.75rem;font-weight:700;font-family:monospace;color:#fff}.view-toggle{display:flex;width:min(900px,95%);margin:0 0 1rem;border:2px solid #1f1f1f;overflow:hidden}.toggle-btn{flex:1;padding:.6rem 1rem;font-family:monospace;font-size:.9rem;font-weight:600;background:#fff;border:none;cursor:pointer;transition:all .15s ease;color:#7a3c22}.toggle-btn:first-child{border-right:1px solid #1f1f1f}.toggle-btn:last-child{border-left:1px solid #1f1f1f}.toggle-btn:hover{background:#fde8dc}.toggle-btn.active{background:#f05a28;color:#fff}.live-map-container{width:min(900px,95%);height:450px;margin:0 0 1.5rem;border:2px solid #1f1f1f;border-radius:16px;overflow:hidden}.live-map{width:100%;height:100%;border-radius:14px}.rounded-map{border-radius:14px}.bus-marker{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:2px solid #fff;box-shadow:0 2px 4px #0000004d;cursor:pointer;transition:transform .15s ease;font-size:.65rem;font-weight:700;font-family:monospace;color:#fff}.bus-marker:hover{transform:scale(1.15)}.bus-marker.moving{background:#10b981}.bus-marker.stopped{background:#ef4444}.bus-marker.large{width:36px;height:36px;font-size:.75rem}.bus-marker-label{line-height:1}.bus-tooltip{font-family:monospace;font-size:.8rem}.landmark-marker{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;font-size:.55rem;font-weight:700;font-family:monospace;color:#fff;cursor:pointer;transition:transform .15s ease;box-shadow:0 1px 3px #0000004d}.landmark-marker:hover{transform:scale(1.1)}.landmark-marker.go{background:#00a651;border:2px solid #fff}.landmark-marker.city{background:#1e3a5f;border:2px solid #fff;width:28px;height:28px;font-size:.6rem}.landmark-marker.terminal{background:#7c3aed;border:2px solid #fff}.landmark-tooltip{font-family:monospace;font-size:.75rem}.stop-marker{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #f05a28;box-shadow:0 1px 3px #0003;cursor:pointer;transition:transform .15s ease}.stop-marker:hover{transform:scale(1.15)}.stop-number{font-size:.55rem;font-weight:700;font-family:monospace;color:#f05a28}.stop-tooltip{font-family:monospace;font-size:.75rem}.search-container{position:relative;width:min(900px,95%);margin:0 0 1rem;display:flex;gap:.5rem;align-items:center}.search-input{flex:1;padding:.85rem 2.5rem .85rem 1rem;font-size:1rem;font-family:monospace;border:2px dashed #1f1f1f;border-radius:0;background:#fff;color:#1f1f1f;transition:all .2s ease;box-sizing:border-box}.search-input:focus{outline:none;border-color:#1f1f1f;box-shadow:none}.search-input::placeholder{color:#9ca3af}.search-clear{width:2rem;height:2rem;border:none;background:#f05a28;color:#fff;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .15s ease}.search-clear:hover{background:#d04920;transform:scale(1.1)}.favorites-toggle{padding:.65rem .8rem;font-family:monospace;font-size:.9rem;font-weight:700;border:2px solid #1f1f1f;background:#fff;color:#f05a28;cursor:pointer;transition:all .15s ease}.favorites-toggle:hover{background:#fde8dc}.favorites-toggle.active{background:#f05a28;color:#fff;border-color:#f05a28}.bus-leaderboard{width:min(900px,95%);margin-bottom:2rem}.route-group{background:#fff;border-radius:0;margin-bottom:1rem;overflow:hidden;box-shadow:none;border:2px dashed #1f1f1f;transition:all .2s ease}.route-group:hover{box-shadow:none}.route-header{background:#fff7f2;color:#1f1f1f;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:background .2s ease}.route-header:hover{background:#fde8dc}.route-number{font-weight:700;font-size:1.1rem;font-family:monospace;background:transparent;padding:.25rem .6rem;border-radius:0;color:#f05a28;border:2px solid #1f1f1f}.route-name{flex:1;font-size:.95rem}.vehicle-count{font-size:.8rem;background:transparent;padding:.25rem .6rem;border-radius:0;border:2px solid #1f1f1f}.expand-indicator{font-size:1.2rem;font-weight:700;color:#f05a28;margin-left:auto;-webkit-user-select:none;user-select:none}.vehicle-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;padding:.75rem;margin-left:1rem}.vehicle-item{background:#fff7f2;border:2px dashed #1f1f1f;border-radius:0;padding:.65rem .75rem;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:space-between}.vehicle-item:hover{background:#fde8dc;border-color:#1f1f1f;transform:translateY(-2px);box-shadow:none}.vehicle-item.moving{border-left:3px solid #10b981}.vehicle-item.stopped{border-left:3px solid #ef4444}.vehicle-id{font-family:monospace;font-weight:600;color:#1f1f1f;font-size:.9rem}.vehicle-info{display:flex;align-items:center;gap:.5rem}.vehicle-speed{font-family:monospace;font-size:.85rem;color:#7a3c22;font-weight:500}.status-badge{font-size:.7rem;line-height:1;font-weight:700;font-family:monospace;text-transform:uppercase;letter-spacing:.05em}.status-badge.moving{color:#10b981}.status-badge.stopped{color:#ef4444}.no-results{text-align:center;padding:2rem;color:#7a3c22;font-style:italic;background:#fff7f2;border-radius:0;border:2px dashed #1f1f1f}.last-updated{width:min(900px,95%);text-align:center;color:#9ca3af;font-size:.85rem;margin:1rem 0 2rem;font-family:Inter,Arial,sans-serif}.bus-modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;animation:modalFadeIn .2s ease forwards}.bus-modal-content{position:relative;background:#fff;border-radius:16px;width:min(95vw,640px);max-height:90vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 20px 50px #0006;transform:scale(.96);opacity:0;animation:modalZoomIn .22s ease forwards;border:2px solid #1f1f1f}.bus-modal-actions{position:absolute;top:10px;right:10px;display:flex;gap:6px;z-index:12}.bus-modal-close{background:#161616;color:#fff;border:1px solid #000;width:32px;height:32px;border-radius:8px;font-size:1.05rem;cursor:pointer;transition:background .12s ease,transform .12s ease;display:flex;align-items:center;justify-content:center;line-height:1}.bus-modal-close:hover{background:#2b2b2b;transform:translateY(-1px)}.bus-favorite-btn{background:#fff;color:#f05a28;border:1px solid #1f1f1f;width:32px;height:32px;border-radius:8px;font-size:1.05rem;cursor:pointer;transition:background .12s ease,transform .12s ease;display:flex;align-items:center;justify-content:center;line-height:1}.bus-favorite-btn:hover{background:#fff7f2;transform:translateY(-1px)}.bus-favorite-btn.active{background:#f05a28;color:#fff;border-color:#f05a28}.bus-modal-header{background:#fff7f2;color:#1f1f1f;padding:1.5rem 1.25rem;border-radius:0}.bus-modal-title{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.route-badge{font-family:monospace;font-weight:700;font-size:1.2rem;background:transparent;padding:.35rem .75rem;border-radius:0;border:2px solid #1f1f1f;color:#f05a28}.route-name-modal{font-size:1rem}.status-indicator{display:inline-block;padding:.35rem .85rem;border-radius:0;font-size:.85rem;font-weight:600;background:transparent;text-transform:uppercase;letter-spacing:.05em;border:2px solid #1f1f1f}.status-indicator.moving{background:transparent;color:#10b981}.status-indicator.stopped{background:transparent;color:#ef4444}.bus-modal-body{padding:1.5rem 1.25rem}.route-info-section{margin-bottom:1.25rem;padding:1rem;background:#fff7f2;border-left:3px solid #f05a28}.route-type-badge{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .5rem;background:#f05a28;color:#fff;margin-bottom:.5rem}.route-termini{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.35rem}.termini-label,.availability-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#7a3c22}.termini-text,.availability-text{font-size:.85rem;color:#1f1f1f}.route-availability{display:flex;flex-direction:column;gap:.15rem}.modal-map-inline{width:90%;height:260px;border-radius:12px;overflow:hidden;border:2px solid #1f1f1f;position:relative;margin:.75rem auto 1.25rem}.map-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#fff7f2;font-family:monospace;color:#7a3c22}.detail-grid{display:grid;gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff7f2;border-radius:0;border-left:3px solid #f05a28}.detail-label{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:#7a3c22;font-weight:600}.detail-value{font-family:monospace;font-size:.95rem;color:#1f1f1f;font-weight:500}.bearing-compass{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:1rem}.compass-circle{position:relative;width:150px;height:150px;border-radius:50%;background:#fff7f2;border:3px solid #f05a28;box-shadow:none}.compass-needle{position:absolute;top:50%;left:50%;width:4px;height:55px;background:#f05a28;transform-origin:bottom center;margin-left:-2px;margin-top:-55px;border-radius:2px;transition:transform .5s ease}.compass-needle:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:10px solid #f05a28}.compass-label{position:absolute;font-size:.85rem;font-weight:700;color:#7a3c22}.compass-n{top:8px;left:50%;transform:translate(-50%)}.compass-e{right:8px;top:50%;transform:translateY(-50%)}.compass-s{bottom:8px;left:50%;transform:translate(-50%)}.compass-w{left:8px;top:50%;transform:translateY(-50%)}.bearing-text{font-size:1.5rem;font-weight:700;font-family:monospace;color:#f05a28}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalZoomIn{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.user-location-marker{position:relative;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.user-location-dot{width:12px;height:12px;background:#4285f4;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;z-index:2;position:absolute}.user-location-ring{width:20px;height:20px;background:#4285f44d;border-radius:50%;animation:userLocationPulse 2s ease-in-out infinite;z-index:1;position:absolute}.user-location-tooltip{font-family:monospace;font-size:.75rem}@keyframes userLocationPulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}to{transform:scale(1);opacity:1}}
