:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:"Inter", system-ui, sans-serif;--heading:"Inter", system-ui, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{background:linear-gradient(#f8f9fb 0%,#eef1f5 100%);margin:0}#root{text-align:center;flex-direction:column;width:100%;min-height:100vh;margin:0;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1px;margin:24px 0;font-size:48px;font-weight:700}h2{margin-bottom:8px;font-size:20px;font-weight:600}p{margin:0}button{font-weight:600}input{font-weight:500}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,sans-serif}body{color:#000;background:radial-gradient(circle at top,#ba0c2f0f,#0000 22%),linear-gradient(#f8fafc 0%,#eef2f7 100%);font-family:Aptos,Segoe UI Variable,Segoe UI,sans-serif}.auth-container{background:linear-gradient(135deg,#ba0c2f 0%,#8b0a23 100%);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:420px;animation:.4s ease-out slideUp;overflow:hidden;box-shadow:0 10px 30px #0000001f,0 2px 6px #00000014}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{color:#fff;text-align:left;background:#ba0c2f;padding:18px 20px;font-size:22px;font-weight:700}.auth-content{flex-direction:column;gap:18px;padding:28px 24px;display:flex}.auth-content h2{color:#111;font-size:22px;font-weight:700}.auth-subtitle{color:#6b7280;font-size:14px}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#000;font-size:14px;font-weight:600}.form-group input{color:#111;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;padding:12px 14px;font-size:15px;font-weight:500;transition:all .2s}.form-group input::placeholder{color:#9ca3af}.form-group input:focus{border-color:#ba0c2f;outline:none;box-shadow:0 0 0 3px #ba0c2f1f}.form-group input:disabled{color:#9ca3af;background:#f3f4f6}.error-message{color:#ba0c2f;background:#fee;border-left:4px solid #ba0c2f;border-radius:6px;padding:12px 14px;font-size:14px;animation:.3s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.success-message{color:#22863a;background:#efe;border-left:4px solid #22863a;border-radius:6px;padding:12px 14px;font-size:14px}.auth-button{cursor:pointer;border:none;border-radius:8px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:all .2s}.auth-button.primary{color:#fff;background:#ba0c2f;border-radius:10px;font-size:15px;font-weight:600;transition:all .2s}.auth-button.primary:hover:not(:disabled){background:#950a25;transform:translateY(-1px);box-shadow:0 6px 16px #ba0c2f4d}.auth-button.primary:disabled{opacity:.6;cursor:not-allowed}.auth-button.secondary{color:#333;background:0 0;border:1.5px solid #e5e7eb;border-radius:10px}.auth-button.secondary:hover{background:#f8f9fb}.auth-button.secondary:hover:not(:disabled){color:#950a25;background:#fef;border-color:#950a25}.auth-button.secondary:disabled{opacity:.6;cursor:not-allowed}.auth-divider{text-align:center;color:#999;margin:8px 0;font-size:14px}.auth-footer{text-align:center;color:#999;margin:8px 0 0;font-size:12px;line-height:1.4}.container{flex-direction:column;gap:20px;max-width:1380px;margin:0 auto 56px;padding:22px 18px 0;display:flex}header{color:#fff;background:#ba0c2f;border-radius:10px;justify-content:space-between;align-items:center;padding:16px 18px;font-size:22px;font-weight:700;display:flex;box-shadow:0 4px 12px #0000001a}h2{margin-top:8px;font-size:18px}.container h2{color:#111827;font-weight:800}input{border:1.5px solid #ddd;border-radius:8px;width:100%;padding:12px 14px;font-size:15px}input:focus{border-color:#ba0c2f;outline:none}button{color:#fff;background:#ba0c2f;border:none;border-radius:14px;width:100%;padding:13px 16px;font-size:15px;font-weight:600;transition:transform .18s,box-shadow .18s,background .18s;box-shadow:0 10px 20px #ba0c2f29}button:hover:not(:disabled){background:#950a25;transform:translateY(-1px);box-shadow:0 14px 24px #950a2533}button:disabled{opacity:.6;cursor:not-allowed}button.secondary{color:#ba0c2f;box-shadow:none;background:#fff;border:1.5px solid #d0d7e2}button.secondary:hover:not(:disabled){background:#fff5f7;border-color:#fda4af}button.small{border-radius:999px;width:auto;min-height:38px;padding:8px 14px;font-size:13px}header button.secondary.small{color:#fff;background:#fff3;border:1px solid #ffffff80;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;display:flex}header button.secondary.small:hover:not(:disabled){background:#ffffff4d;border-color:#fffc}.msg{color:#ba0c2f;text-align:center;min-height:18px;font-size:14px;font-weight:600}hr{border:none;border-top:1px solid #ddd}.card{background:#fff;border-left:5px solid #ba0c2f;border-radius:18px;justify-content:space-between;align-items:center;padding:16px 18px;transition:all .2s;display:flex;box-shadow:0 14px 30px #0f172a12}.card:hover{transform:translateY(-2px)}.card--interactive{cursor:pointer}.card--interactive:hover{box-shadow:0 10px 24px #0000001a}.card-title{color:#111827;text-align:left;font-weight:700;line-height:1.35}.route-card{align-items:flex-start;gap:18px;width:100%;padding:14px 16px}.route-card__body{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.route-card__eyebrow{letter-spacing:.06em;text-transform:uppercase;color:#64748b;text-align:left;font-size:11px;font-weight:800}.route-card__actions{flex-shrink:0;align-self:center}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:12px;width:90%;max-width:380px;padding:24px;animation:.3s ease-out slideUp;box-shadow:0 20px 60px #0000004d}.modal h3{color:#000;margin:0 0 8px;font-size:20px}.modal p{color:#666;margin:0 0 24px;font-size:15px;line-height:1.5}.modal-actions{flex-direction:row-reverse;gap:12px;display:flex}.modal-actions button{flex:1}@media (width<=480px){.auth-container{padding:12px}.auth-card{border-radius:16px}.auth-content{gap:14px;padding:24px 16px}.auth-content h2{color:#111;font-size:22px;font-weight:700}.auth-subtitle{color:#6b7280;font-size:14px}.auth-header{padding:20px 16px;font-size:24px}.modal{width:85%;padding:20px}.modal h3{font-size:18px}}.navbar{z-index:100;color:#fff;background:#ba0c2f;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;display:flex;position:sticky;top:0;box-shadow:0 10px 24px #5c06182e}.nav-left h2{color:#fff;white-space:nowrap;font-size:18px;font-weight:700}.nav-brand{color:#fff;letter-spacing:.01em;white-space:nowrap;cursor:pointer;background:0 0;border:none;border-radius:0;width:auto;padding:0;font-size:19px;font-weight:750}.nav-brand:hover:not(:disabled){opacity:.88;background:0 0}.nav-center{flex:1;max-width:500px}.nav-center input{color:#fff;background:#ffffff26;border:none;border-radius:8px;width:100%;padding:10px 14px;font-size:14px}.nav-center input::placeholder{color:#ffffffb3}.nav-right{align-items:center;gap:10px;display:flex}.nav-right button{color:#fff;cursor:pointer;width:auto;min-width:68px;box-shadow:none;background:#ffffff1f;border:none;border-radius:14px;padding:10px 16px;font-size:13px;font-weight:700;transition:background .18s,color .18s,transform .18s}.nav-right button:hover{background:#fff3;transform:translateY(0)}.nav-right button.active{color:#ba0c2f;background:#fff}.nav-right button:last-child{background:#75091fb3}.auth-loading{color:#666;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;font-size:15px;display:flex}.spinner{border:3px solid #e5e7eb;border-top-color:#ba0c2f;border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.homepage{flex-direction:column;min-height:100vh;display:flex}.hero{color:#fff;background:linear-gradient(135deg,#ba0c2f 0%,#8b0a23 50%,#5c0618 100%);flex-wrap:wrap;justify-content:center;align-items:center;gap:64px;min-height:80vh;padding:80px 24px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(circle,#ffffff0f 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-50%;right:-30%}.hero-content{z-index:1;max-width:520px}.hero-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:100px;margin-bottom:24px;padding:8px 18px;font-size:14px;font-weight:600;display:inline-block}.hero h1{letter-spacing:-1.5px;color:#fff;margin-bottom:20px;font-size:52px;font-weight:800;line-height:1.1}.hero-accent{background:linear-gradient(135deg,gold,#fa0);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-description{opacity:.9;color:#ffffffd9;margin-bottom:32px;font-size:18px;line-height:1.6}.hero-actions{flex-wrap:wrap;gap:14px;display:flex}.hero-btn{cursor:pointer;border-radius:12px;padding:14px 32px;font-size:16px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-block}.hero-btn.primary{color:#ba0c2f;background:#fff;box-shadow:0 4px 14px #00000026}.hero-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.hero-btn.secondary{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1f;border:1.5px solid #ffffff4d}.hero-btn.secondary:hover{background:#fff3;border-color:#ffffff80}.hero-visual{z-index:1;animation:4s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.hero-card{background:#fff;border-radius:16px;width:300px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.hero-card-header{background:#f5f5f5;gap:6px;padding:12px 16px;display:flex}.hero-card-dot{border-radius:50%;width:10px;height:10px}.hero-card-dot.red{background:#ff5f57}.hero-card-dot.yellow{background:#ffbd2e}.hero-card-dot.green{background:#28ca42}.hero-card-body{padding:20px}.hero-route{align-items:center;gap:12px;display:flex}.hero-route-icon{font-size:22px}.hero-route-label{color:#999;text-transform:uppercase;letter-spacing:.5px;text-align:left;font-size:12px;font-weight:600}.hero-route-value{color:#111;text-align:left;font-size:15px;font-weight:600}.hero-route-divider{align-items:center;gap:8px;padding:8px 0 8px 10px;display:flex}.hero-route-line{background:#e5e7eb;flex:1;height:1px}.hero-route-arrow{color:#ba0c2f;font-size:16px;font-weight:700}.hero-card-btn{color:#fff;text-align:center;background:#ba0c2f;border-radius:10px;margin-top:16px;padding:12px;font-size:14px;font-weight:700}.features{text-align:center;background:#fff;padding:80px 24px}.features-title{color:#111;margin-bottom:8px;font-size:32px;font-weight:800}.features-subtitle{color:#6b7280;margin-bottom:48px;font-size:16px}.features-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;max-width:960px;margin:0 auto;display:grid}.feature-card{text-align:center;background:#fafafa;border:1px solid #f0f0f0;border-radius:16px;padding:32px 24px;transition:all .3s}.feature-card:hover{border-color:#e0e0e0;transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.feature-icon{margin-bottom:16px;font-size:36px}.feature-card h3{color:#111;margin-bottom:10px;font-size:18px;font-weight:700}.feature-card p{color:#6b7280;font-size:14px;line-height:1.6}.homepage-footer{text-align:center;color:#ffffff80;background:#111;margin-top:auto;padding:32px 24px;font-size:13px}@media (width<=768px){.hero{min-height:auto;padding:60px 20px}.hero h1{font-size:36px}.hero-description{font-size:16px}.hero-visual{display:none}.features{padding:48px 20px}.features-title{font-size:26px}}.sub-nav-bar{color:#9f1239;cursor:pointer;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background-color:#ffffffeb;border-bottom:1px solid #e2e8f0;align-items:center;gap:8px;width:100%;padding:14px 20px;font-size:15px;font-weight:700;display:flex}.sub-nav-icon{background:#fff1f2;border:1px solid #fecdd3;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;line-height:1;display:inline-flex}.map-container{background:linear-gradient(135deg,#e8ecf1 0%,#d9e0e8 100%);border-bottom:3px solid #ba0c2f;width:100%;height:460px;position:relative;box-shadow:0 18px 36px #0f172a1f}.map-helper{z-index:2;color:#475569;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;border:1px solid #e2e8f0f2;border-radius:999px;max-width:360px;padding:9px 12px;font-size:11px;font-weight:700;line-height:1.35;position:absolute;bottom:16px;left:16px;box-shadow:0 8px 18px #0f172a14}.gm-style .gm-ui-hover-effect[title=Close]{display:none!important}.map-loading,.map-error{color:#666;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.map-error{color:#ba0c2f;background:#fef2f2}.map-info-window{min-width:270px;max-width:340px;padding:6px 4px}.map-info-window__header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.map-info-window h4{color:#111;margin:0 0 8px;font-size:16px;font-weight:800;line-height:1.35}.map-info-close{color:#0000;width:32px;min-width:32px;height:32px;box-shadow:none;background:#fff1f2;border:1px solid #fecdd3;border-radius:999px;padding:0;font-size:20px;line-height:1;position:relative}.map-info-close:before{content:"×";color:#9f1239;justify-content:center;align-items:center;font-size:22px;line-height:1;display:flex;position:absolute;inset:0}.map-info-close:hover:not(:disabled){background:#ffe4e6;border-color:#fda4af}.map-info-routes{flex-wrap:wrap;gap:4px;display:flex}.map-info-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.map-info-action{color:#fff;background:#ba0c2f;border-radius:10px;width:auto;padding:8px 12px;font-size:12px;font-weight:700}.map-info-action--secondary{color:#ba0c2f;background:#fff;border:1px solid #fecdd3}.user-location-marker{width:20px;height:20px;position:relative}.user-loc-dot{z-index:2;background:#4285f4;border:3px solid #fff;border-radius:50%;width:14px;height:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #4285f480}.user-loc-pulse{z-index:1;background:#4285f433;border-radius:50%;width:40px;height:40px;animation:2s ease-out infinite pulse-ring;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pulse-ring{0%{opacity:1;transform:translate(-50%,-50%)scale(.5)}70%{opacity:.4}to{opacity:0;transform:translate(-50%,-50%)scale(1.3)}}.live-bus-marker{background:var(--bus-color,#ba0c2f);color:#fff;letter-spacing:.02em;border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;min-width:34px;min-height:34px;padding:0 10px;font-size:11px;font-weight:700;display:inline-flex;box-shadow:0 8px 24px #0003}.route-badge{color:#fff;white-space:nowrap;background:#ba0c2f;border:1px solid #0000;border-radius:100px;padding:5px 11px;font-size:12px;font-weight:700;display:inline-block;box-shadow:inset 0 -1px #ffffff2e}.route-badge--small{padding:4px 9px;font-size:11px}.route-badge--tiny{letter-spacing:.01em;padding:3px 8px;font-size:10px}.route-badge--outlined{align-self:flex-start}.stop-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:16px;transition:all .2s;box-shadow:0 12px 28px #0f172a0f}.stop-card:hover{border-color:#e0e0e0;transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.stop-card{min-height:156px}.stop-card--compact{padding:14px 16px}.stop-card-info{flex-direction:column;gap:8px;display:flex}.stop-card-name{color:#111;text-align:left;align-items:center;gap:8px;font-size:15px;font-weight:600;line-height:1.45;display:flex}.stop-card-icon{flex-shrink:0;width:16px;height:16px;font-size:0;line-height:1;position:relative}.stop-card-icon:before{content:"📍";font-size:16px;line-height:1;position:absolute;inset:0}.stop-card-distance{color:#6b7280;padding-left:24px;font-size:13px}.stop-card-routes{flex-wrap:wrap;gap:6px;padding-left:24px;display:flex}.stop-list{flex-direction:column;gap:14px;display:flex}.stops-columns{gap:24px;width:100%;display:grid}.stops-section{min-width:0}.stops-section__header{text-align:left;margin-bottom:16px}.stops-section__header h3{color:#0f172a;margin:0;font-size:1.15rem;font-weight:800}.stops-section__header p{color:#64748b;margin:6px 0 0;font-size:.95rem;line-height:1.45}.autocomplete-wrapper{width:100%;position:relative}.autocomplete-wrapper input{color:#111;background:#fff;border-color:#cbd5e1;border-radius:14px;box-shadow:inset 0 1px 2px #0f172a08}.autocomplete-wrapper input::placeholder{color:#6b7280}.autocomplete-dropdown{z-index:50;background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:16px;max-height:280px;margin:8px 0 0;padding:6px;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 18px 38px #0f172a24}.autocomplete-section+.autocomplete-section{border-top:1px solid #e2e8f0;margin-top:10px;padding-top:10px}.autocomplete-section__label{text-transform:uppercase;letter-spacing:.06em;color:#64748b;padding:0 8px 8px;font-size:11px;font-weight:800}.autocomplete-section__list{flex-direction:column;gap:4px;list-style:none;display:flex}.autocomplete-item{cursor:pointer;border-radius:12px;align-items:flex-start;gap:10px;padding:12px;transition:background .15s,transform .15s;display:flex}.autocomplete-item:hover,.autocomplete-item--active{background:#f8fafc}.autocomplete-item--active{background:#fff1f2}.autocomplete-item-icon{background:linear-gradient(#fb7185 0%,#be123c 100%);border-radius:999px;flex-shrink:0;width:10px;height:10px;margin-top:6px;box-shadow:0 0 0 4px #fb718529}.autocomplete-item-content{flex-direction:column;gap:2px;min-width:0;display:flex}.autocomplete-item-name{color:#111;text-align:left;font-size:14px;font-weight:600}.autocomplete-item-routes{flex-wrap:wrap;gap:6px;display:flex}.autocomplete-empty{text-align:center;color:#64748b;padding:16px 14px;font-size:13px;font-weight:600}.route-inputs{flex-direction:column;gap:14px;display:flex}.planner-shell{grid-template-columns:1fr;gap:24px;display:grid}.planner-panel,.support-panel,.results-panel{flex-direction:column;gap:24px;display:flex}.planner-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffe0;border:1px solid #ffffffb3;border-radius:24px;padding:20px;box-shadow:0 20px 45px #0f172a14}.planner-card__header{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.planner-card__header h2{letter-spacing:-.04em;text-wrap:balance;margin-top:0;font-size:clamp(2rem,2.5vw,2.6rem);line-height:.98}.ghost-button{color:#be123c;width:auto;min-width:92px;box-shadow:none;background:#fff;border:1px solid #fecdd3;border-radius:12px;align-self:flex-start;padding:10px 14px;font-size:14px}.selection-summary{grid-template-columns:1fr;gap:10px;margin-bottom:16px;display:grid}.selection-chip{color:#475569;box-shadow:none;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:18px;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px;transition:border-color .18s,box-shadow .18s,background .18s;display:flex}.selection-chip.is-filled{color:#0f172a;background:#fff;border-style:solid}.selection-chip.is-origin{border-color:#22c55e59;box-shadow:inset 0 0 0 1px #22c55e29}.selection-chip.is-destination{border-color:#ef444459;box-shadow:inset 0 0 0 1px #ef444429}.selection-chip__label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-size:12px;font-weight:800}.selection-chip__top{justify-content:space-between;align-items:center;gap:8px;width:100%;display:flex}.selection-chip__clear{color:#0000;width:28px;min-width:28px;height:28px;box-shadow:none;background:#fff;border:1px solid #fecdd3;border-radius:999px;padding:0;font-size:19px;font-weight:500;line-height:1;position:relative}.selection-chip__clear:before{content:"×";color:#9f1239;justify-content:center;align-items:center;font-size:20px;line-height:1;display:flex;position:absolute;inset:0}.selection-chip__clear:hover:not(:disabled){background:#fff1f2;border-color:#fda4af}.route-input-group{flex-direction:column;gap:6px;display:flex}.action-row{gap:10px;margin-top:10px;display:flex}.action-row>*{flex:1;min-height:50px}.input-label{color:#333;text-align:left;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.input-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.input-dot--origin{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.input-dot--dest{background:#ef4444;box-shadow:0 0 0 3px #ef444433}.view-hint{color:#6b7280;margin-bottom:4px;font-size:14px}.results-section{background:#ffffffa3;border:1px solid #e2e8f0cc;border-radius:24px;flex-direction:column;gap:12px;padding:16px;display:flex;box-shadow:0 18px 36px #0f172a0d}.results-panel .results-section h3,.planner-panel h3{text-transform:uppercase;letter-spacing:.06em;font-size:14px}.results-panel .results-section h3{margin-left:4px}.results-section h3,.live-status-card h3{color:#0f172a;font-size:1rem;font-weight:800;line-height:1.25}.trip-card{background:#fff;border:1px solid #ececec;border-radius:20px;flex-direction:column;gap:10px;padding:18px 18px 16px;display:flex;box-shadow:0 18px 34px #0f172a12}.trip-card--transit{border-left:5px solid #ba0c2f}.trip-card--walking{border-left:5px solid #0f766e}.trip-card-header{color:#111;justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.trip-card-header__title{flex-direction:column;gap:4px;min-width:0;display:flex}.trip-card-kicker{text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-size:11px;font-weight:800}.trip-card-line{flex-direction:column;align-items:flex-start;gap:8px;display:flex}.route-badge--hero{padding:10px 14px;font-size:15px;font-weight:800}.trip-card-total{color:#0f766e;flex-shrink:0;font-size:1.2rem;font-weight:800;line-height:1}.trip-card-header strong,.trip-card-header span{font-size:.98rem}.trip-card p{color:#6b7280;font-size:14px}.trip-step-detail-block{flex-direction:column;gap:4px;display:flex}.trip-step-detail-block p{color:#4b5563}.trip-step-list{flex-direction:column;gap:12px;display:flex}.trip-step{align-items:flex-start;gap:10px;display:flex}.trip-step-content{flex-direction:column;gap:6px;display:flex}.trip-step-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px;margin-top:3px}.trip-step-dot.is-transit{background:#ba0c2f}.trip-step-dot.is-walk{background:#0f766e}.trip-step-title{color:#111;font-size:15px;font-weight:700}.live-status-card{background:radial-gradient(circle at 100% 0,#0f766e14,#0000 24%),linear-gradient(145deg,#fff 0%,#f8fafc 100%);border:1px solid #e2e8f0;border-radius:24px;padding:20px;box-shadow:0 18px 38px #0f172a12}.live-status-card p{color:#4b5563;font-size:13px}.live-status-card__main{flex-direction:column;gap:16px;display:flex}.stop-board-list{grid-template-columns:1fr;gap:12px;display:grid}.stop-board-card{background:#ffffffd1;border:1px solid #dbe4ea;border-radius:20px;flex-direction:column;gap:10px;min-height:164px;padding:16px;display:flex;box-shadow:inset 0 1px #fff6}.stop-board-card--departure{border-color:#10b98147;box-shadow:inset 0 0 0 1px #10b9811a}.stop-board-card--arrival{border-color:#3b82f647;box-shadow:inset 0 0 0 1px #3b82f61a}.stop-board-card__top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.stop-board-card__content{flex-direction:column;gap:4px;min-width:0;display:flex}.stop-board-card__eyebrow{text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:4px;font-size:11px;font-weight:800;display:block}.stop-board-card h4{color:#0f172a;font-size:1.02rem;line-height:1.28}.stop-board-card__detail{color:#64748b;font-size:.95rem;line-height:1.45}.stop-board-card__eta{text-align:right;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;display:flex}.stop-board-card__eta strong{color:#0f766e;font-size:1.55rem;line-height:1}.stop-board-card__eta span{color:#475569;font-size:.84rem;font-weight:600}.stop-board-card--departure .stop-board-card__eta strong{color:#0f9f6e}.stop-board-card--arrival .stop-board-card__eta strong{color:#2563eb}.stop-board-card__footer{justify-content:flex-start;align-items:center;display:flex}.service-banner{background:#ffffffdb;border:1px solid #dbe4ea;border-radius:16px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.service-banner strong{font-size:14px;font-weight:800;line-height:1.35}.service-banner span{font-size:13px;line-height:1.5}.service-banner--warning{background:#fffbeb;border-color:#fcd34d}.service-banner--warning strong{color:#92400e}.service-banner--warning span{color:#a16207}.service-banner--active{background:#f0fdfa;border-color:#99f6e4}.service-banner--active strong,.service-banner--active span{color:#0f766e}.live-status-card__header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.live-status-card__header h3{margin-bottom:2px}.live-status-time{color:#0f766e;white-space:normal;text-align:right;font-size:11px;font-weight:700;line-height:1.4}.live-route-picker{flex-direction:column;gap:8px;display:flex}.live-route-picker__label,.live-metric__label{letter-spacing:.04em;text-transform:uppercase;color:#64748b;font-size:11px;font-weight:700}.live-route-select{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:12px;width:100%;padding:12px 14px;font-size:14px;font-weight:600}.live-status-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.live-metric{background:#ffffffc7;border:1px solid #e2e8f0;border-radius:18px;flex-direction:column;gap:6px;min-height:124px;padding:14px;display:flex}.live-metric strong{color:#0f766e;font-size:1.45rem;line-height:1.1}.live-metric small{color:#64748b;font-size:.88rem;line-height:1.35}.arrival-pill-row{flex-wrap:wrap;gap:8px;display:flex}.arrival-pill{color:#fff;background:#0f766e;border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:6px 10px;font-size:13px;font-weight:700;display:inline-flex}.arrival-pill--empty{color:#475569;background:#e2e8f0}.schedule-list{flex-direction:column;gap:10px;display:flex}.schedule-item{background:#ffffffc7;border:1px solid #dbe4ea;border-radius:20px;flex-direction:column;gap:12px;padding:16px;display:flex}.schedule-item__top{justify-content:space-between;align-items:center;gap:12px;display:flex}.schedule-line-badge{color:#fff;background:#ba0c2f;border-radius:999px;justify-content:center;align-items:center;padding:7px 12px;font-size:12px;font-weight:800;display:inline-flex}.schedule-duration{color:#0f172a;font-size:13px;font-weight:700}.schedule-item__times{grid-template-columns:1fr;gap:12px;display:grid}.schedule-label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:4px;font-size:11px;font-weight:800;display:block}.schedule-item__times strong{color:#0f172a;margin-bottom:4px;font-size:18px;display:block}.schedule-item__times p,.schedule-meta{color:#475569;font-size:13px;line-height:1.5}.schedule-empty{background:#ffffffb8;border:1px dashed #cbd5e1;border-radius:18px;padding:18px}.schedule-empty p{color:#0f172a;margin-bottom:6px;font-weight:700}.schedule-empty span{color:#64748b;font-size:13px}.live-status-error{color:#be123c;background:#fff1f2;border:1px solid #fecdd3;border-radius:12px;padding:10px 12px}.live-status-note{color:#475569;line-height:1.5}.nearby-section,.nearby-section--embedded{border-top:none;margin-top:0;padding-top:0}.nearby-section h3{color:#111;text-align:left;margin-bottom:12px;font-size:16px;font-weight:700}.empty-state{text-align:center;color:#9ca3af;padding:32px 0;font-size:15px}.saved-empty{text-align:center;color:#64748b;background:#ffffffc2;border:1px dashed #cbd5e1;border-radius:20px;padding:20px}.saved-routes-list{flex-direction:column;gap:14px;width:100%;max-width:760px;margin:0 auto;display:flex}@media (width<=768px){.map-container{height:340px}.navbar{gap:10px;padding:12px 14px}.nav-right{gap:8px}.nav-right button{min-width:0;padding:8px 12px}.action-row,.live-status-card__header,.trip-card-header,.schedule-item__top,.stop-board-card__top,.route-card{flex-direction:column;align-items:stretch}.live-status-metrics{grid-template-columns:1fr}.planner-card__header h2{font-size:2.35rem}.map-info-actions{flex-direction:column}.live-status-time{white-space:normal}.map-helper{text-align:center;bottom:12px;left:12px;right:12px}.route-card__actions .small{width:100%}.stop-board-card__eta{text-align:left;align-items:flex-start}.trip-card-total{font-size:1rem}.stop-card{min-height:auto}}@media (width>=760px){.container{padding:28px 24px 0}.selection-summary,.schedule-item__times{grid-template-columns:repeat(2,minmax(0,1fr))}.stops-columns--split{grid-template-columns:minmax(280px,.95fr) minmax(0,1.45fr);align-items:start}.nearby-section--embedded .stop-list{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}}@media (width>=1024px){.map-container{height:560px}.planner-shell{grid-template-columns:minmax(330px,420px) minmax(320px,390px) minmax(0,1fr);justify-content:stretch;align-items:start}.planner-panel,.support-panel{align-self:start;position:sticky;top:96px}.planner-card__header{flex-direction:row;justify-content:space-between;align-items:flex-start}.results-panel{gap:18px;padding-top:6px}.results-panel .results-section:first-child{min-height:100%}}
