:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.map-container{--track-axis: 30px;--row-height: 50px}.direction-toggle{background:#fff;padding:15px;border-radius:12px;margin-bottom:20px;box-shadow:0 4px 6px #0000000d}.toggle-row{display:flex;gap:10px;margin-top:10px}.toggle-row button{flex:1;padding:10px;border:1px solid #ddd;background:#f9f9f9;border-radius:8px;font-weight:600;color:#666;cursor:pointer;transition:all .2s ease}.toggle-row button.active{background:var(--line-color);color:#fff;border-color:var(--line-color)}.thermometer{position:relative;margin-top:20px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;overflow:hidden;padding:0}.red-line-layout{padding-bottom:10px}.trunk-container{position:relative}.branches-container{display:flex;justify-content:space-between;position:relative;width:100%}.track-svg-layer{position:absolute;inset:0;z-index:0;pointer-events:none}.branch-column{flex:1;position:relative}.map-stop-row{position:relative;display:flex;align-items:center;min-height:var(--row-height);z-index:1}.map-marker-area{width:calc(var(--track-axis) * 2);display:flex;justify-content:center;align-items:center;position:relative;flex-shrink:0}.map-stop-name{font-size:.95rem;color:#333;font-weight:500;flex:1;padding-left:0;padding-right:10px}.trunk-container .map-marker-area{position:absolute;left:40%;transform:translate(-50%);width:40px}.trunk-container .map-stop-name{padding-left:calc(40% + 20px)}.ashmont-col .map-marker-area{position:absolute;left:40%;transform:translate(-50%);width:40px}.ashmont-col .map-stop-name{padding-left:calc(40% + 20px)}.braintree-col .map-marker-area{position:absolute;left:20%;transform:translate(-50%);width:40px}.braintree-col .map-stop-name{padding-left:calc(20% + 20px)}.red-line-layout .map-stop-row{display:flex;align-items:center}.stop-dot{width:12px;height:12px;background:#fff;border:3px solid var(--line-color, #999);border-radius:50%;z-index:1;box-sizing:border-box}.train-marker{position:absolute;left:50%;margin-left:-14px;background:#fff;border:2px solid var(--line-color);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 2px 4px #0003;z-index:2;transition:top .3s ease}.train-marker.moving{border-style:dashed}:root{--bg-app: #f4f4f9;--bg-card: #ffffff;--text-primary: #333333;--text-secondary: #666666;--text-muted: #888888;--border-light: #dddddd;--brand-blue: #003da5;--brand-gold: #ffb700;--spacing-md: 15px;--spacing-lg: 20px;--radius-card: 12px}html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}html,body{margin:0;padding:0;width:100vw;max-width:100%;overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:var(--bg-app);color:var(--text-primary)}.app-container{width:auto;max-width:600px;margin:0 auto;padding:15px 15px 90px;overflow:hidden}header h1{text-align:center;font-size:1.5rem;margin-top:10px;margin-bottom:20px}.selector-group,.destination-card,.favorites-container{background:var(--bg-card);padding:15px;border-radius:var(--radius-card);box-shadow:0 4px 6px #0000001a;margin-bottom:20px;width:auto;min-width:0}.destination-card{border-left:6px solid var(--line-color, #003da5)}label{display:block;font-weight:600;margin-bottom:8px;font-size:.85rem;text-transform:uppercase;color:var(--text-secondary)}select{width:100%;padding:12px;font-size:16px;border:1px solid var(--border-light);border-radius:8px;background-color:#fff;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;appearance:none}.predictions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.destinations-list{display:flex;flex-direction:column;gap:15px;width:auto}.destination-card h3{margin:0 0 10px;font-size:1.1rem;color:#444;border-bottom:1px solid #eee;padding-bottom:8px}.train-row-container{display:flex;gap:10px;width:100%;overflow-x:auto;padding-bottom:5px;-webkit-overflow-scrolling:touch}.train-pill{background-color:color-mix(in srgb,var(--line-color, #003da5),white 90%);border:1px solid var(--line-color, #003da5);color:var(--line-color, #003da5);padding:10px 16px;min-width:100px;border-radius:8px;font-weight:700;font-size:1.2rem;white-space:nowrap;display:flex;justify-content:center;align-items:center;flex-shrink:0}.new-badge{margin-left:6px;font-size:.9em;filter:drop-shadow(0 0 2px rgba(255,215,0,.5))}.no-data,.no-selection-msg{text-align:center;color:#999;font-style:italic;margin-top:20px}.favorites-label{font-size:.75rem;font-weight:700;color:var(--text-muted);margin-bottom:8px;margin-left:5px}.favorites-list{display:flex;gap:10px;overflow-x:auto;padding-bottom:5px;width:100%}.fav-chip{background:#fff;border:1px solid var(--border-light);padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;color:#333;display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0}.fav-route-dot{width:10px;height:10px;border-radius:50%;background-color:var(--chip-color, #333)}.star-btn{background:none;border:none;font-size:1.5rem;color:var(--brand-gold);cursor:pointer;padding:0 0 0 10px;line-height:1}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;background:#fff;border-top:1px solid var(--border-light);display:flex;justify-content:space-around;padding:10px 0;box-shadow:0 -2px 10px #0000000d;z-index:1000}.nav-item{background:none;border:none;display:flex;flex-direction:column;align-items:center;color:#999;cursor:pointer}.nav-item.active{color:var(--line-color, #003da5)}.nav-icon{font-size:1.5rem;margin-bottom:2px}.nav-label{font-size:.75rem;font-weight:600}
