: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}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}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}}.nsb-wrap{position:relative;width:100%}.nsb-btn{width:100%;height:46px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:14px;background:#fff;font-size:15px;font-weight:600;text-align:left}.nsb-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #02061714;list-style:none;margin:0;padding:4px 0}.nsb-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:14px}.nsb-item:hover{background:#f1f5f9}.nsb-name{flex:1;font-weight:700}.nsb-dist{font-size:12px;color:#64748b}.rsi-wrap{position:relative;width:100%}.rsi-input{width:100%;height:46px;padding:10px 12px;border-radius:14px;border:1px solid #e5e7eb;background:#fff;font-size:15px;box-sizing:border-box}.rsi-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;max-height:320px;overflow:auto;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 28px #0206171f;padding:6px;z-index:1000}.rsi-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;cursor:pointer}.rsi-item.is-active{background:#f8fafc}.rsi-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid currentColor;background:#0000000a;color:currentColor}.rsi-dot{width:8px;height:8px;border-radius:999px;display:inline-block}.rsi-name{font-weight:700}.rsi-chip{width:100%;height:46px;border-radius:14px;border:1.5px solid;background:#fff;font-size:15px;font-weight:800;display:inline-flex;align-items:center;gap:8px;justify-content:flex-start;padding:0 12px}.rsi-chip-dot{width:8px;height:8px;border-radius:999px;display:inline-block}html,body,#root{width:100%;height:100%;margin:0;padding:0}*,*:before,*:after{box-sizing:border-box}:root{--z-dropdown: 1000;--z-search: 300;--z-result: 100;--z-swap: 350}#root,.app-root{min-height:100svh;min-height:-webkit-fill-available;display:flex;flex-direction:column}.bg-gradient{position:fixed;inset:0;background:radial-gradient(900px 480px at 80% -10%,rgba(99,102,241,.08),transparent 55%),radial-gradient(800px 480px at -10% 10%,rgba(14,165,233,.08),transparent 50%);pointer-events:none}.container{flex:1;width:100%;padding:16px 12px 24px;box-sizing:border-box}.header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.brand-row{display:flex;align-items:center;gap:10px}.brand-mark{width:28px;height:28px;border-radius:10px;background:linear-gradient(135deg,#4f46e5,#3b82f6 40%,#06b6d4);box-shadow:0 6px 14px #4f46e538}.title{margin:0;font-size:18px;font-weight:800}@media (min-width: 1024px){.header{justify-content:center}.brand-row{justify-content:center;flex:1}.title{font-size:24px;text-align:center}}.panel,.panel-search{position:relative;z-index:var(--z-result);background:#fff;border:1px solid #e8ecf2;border-radius:16px;box-shadow:0 8px 18px #0206170f;padding:12px;margin-top:10px;width:100%}@media (min-width: 1024px){.panel,.panel-search{width:min(860px,92vw);margin-left:auto;margin-right:auto;padding:20px}}@media (min-width: 1440px){.panel,.panel-search{width:min(980px,88vw);padding:24px}}.route-top-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.route-top-row .nsb-btn{flex:1;min-width:0;height:44px;border-radius:12px;font-size:14px;background:#f9fafb;border:1px solid #e5e7eb}.reset-btn{width:40px;height:40px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-size:18px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.reset-btn:hover{background:#f3f4f6}.route-form-row{display:flex;align-items:stretch;gap:10px}.swap-col{display:flex;flex-direction:column}.swap-btn{width:44px;min-height:100%;border-radius:12px;border:1px solid #e5e7eb;background:#fff;font-size:20px;font-weight:800;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px #00000014;z-index:var(--z-swap);transition:background .15s}.swap-btn:hover{background:#f3f4f6}.route-inputs{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.input{height:52px;padding:0 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;font-size:15px;width:100%;max-width:100%;min-width:0}.mt-6{margin-top:6px}.mt-14{margin-top:14px}.step-title{font-weight:800;margin-bottom:6px}.arrival-grid{display:grid;gap:10px}.arrival-empty{padding:12px;border:1px dashed #e5e7eb;border-radius:10px;color:#6b7280}.ssi-panel,.nsb-panel{var(--z-dropdown);position:absolute}.coffee-link{text-decoration:none;font-weight:600;color:#374151;transition:color .2s}.coffee-link:hover{color:#111827}@media (min-width: 1024px){.panel-search{width:min(860px,92vw);margin:0 auto;padding:18px}.title{font-size:24px}.route-top-row .nsb-btn{height:48px;font-size:15px}.reset-btn{width:44px;height:44px;font-size:20px}.swap-btn{width:52px;font-size:24px}.route-inputs{gap:10px}.input{height:60px;font-size:17px;padding:0 16px}}@media (min-width: 1440px){.panel-search{width:min(980px,88vw);padding:22px}.title{font-size:28px}.swap-btn{width:56px;font-size:26px}.input{height:64px;font-size:18px}}@media (hover: hover){button:hover{box-shadow:0 8px 18px #4f46e524}}.app-root{min-height:100dvh;display:flex;flex-direction:column}.container{flex:1;width:100%;padding:16px 12px 24px;box-sizing:border-box;overflow-x:hidden}.panel{position:relative;background:#fff;border:1px solid #e8ecf2;border-radius:16px;box-shadow:0 8px 18px #0206170f;padding:12px;margin-top:10px;z-index:var(--z-result);overflow:visible}.panel-search{z-index:var(--z-search)}.ssi-panel,.nsb-panel{position:fixed;z-index:var(--z-dropdown)}.ssi-panel,.nsb-panel{position:fixed;z-index:1000}.footer{position:relative;margin-top:40px;margin-bottom:0;padding:16px 12px;text-align:center;font-size:13px;color:#64748b;z-index:10}.footer .muted-small{margin:4px 0}@media (min-width: 1024px){.panel.panel-search{width:min(860px,92vw);padding:18px;margin:0 auto}}@media (min-width: 1440px){.panel.panel-search{width:min(980px,88vw);padding:22px}}.footer{margin-bottom:0!important}input,textarea,select{-webkit-text-fill-color:#0f172a;color:#0f172a}html,body{color:#0f172a;background:#f8fafc}input,textarea,select{color:#0f172a!important;background-color:#fff!important;-webkit-text-fill-color:#0f172a!important;caret-color:#0f172a!important;appearance:none}input::placeholder,textarea::placeholder{color:#9ca3af!important;opacity:1!important}input:-webkit-autofill,textarea:-webkit-autofill,select:-webkit-autofill{-webkit-text-fill-color:#0f172a!important;box-shadow:0 0 0 1000px #fff inset!important;transition:background-color 9999s ease-out 0s!important}#root,.app-root{min-height:100svh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;flex-direction:column}.container{flex:1}.footer{position:relative;margin:0;padding-bottom:max(16px,env(safe-area-inset-bottom))}:root{color-scheme:light}input,textarea,select{color:#0f172a;-webkit-text-fill-color:#0f172a}
