:root{color:#17211c;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f5f4;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}.app-shell{color:#17211c;background:#f3f5f4;grid-template-columns:330px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:#fff;border-right:1px solid #cfd7d2;flex-direction:column;gap:14px;padding:14px;display:flex}.brand-row{border-bottom:1px solid #dfe5e1;align-items:center;gap:10px;padding-bottom:10px;display:flex}.brand-row svg{color:#0b7a53}.brand-row h1{margin:0;font-size:20px;line-height:1.1}.brand-row p,.results-header p,.origin-line,.warning-line,.leg-copy span,.details-meta,.empty-state span{color:#65726c;margin:0;font-size:12px}.control-group,.filter-panel{gap:8px;display:grid}label span{color:#53615a;margin-bottom:4px;font-size:12px;font-weight:700;display:block}.input-shell,.compact-input{background:#fbfcfb;border:1px solid #bfcac4;align-items:center;gap:7px;min-height:34px;padding:0 9px;display:flex}.icon-button{background:0 0;border:0;flex:none;place-items:center;width:24px;height:24px;padding:0;display:inline-grid}.input-shell svg,.compact-input svg{color:#607268;flex:none}input,select,button{font:inherit}input,select{color:#17211c;background:0 0;border:0;outline:0;width:100%;min-width:0;font-size:13px}.control-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}button{color:#17211c;cursor:pointer;background:#fff;border:1px solid #bfcac4}button:hover{border-color:#718079}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:1px;outline:2px solid #167a55}.segmented{min-height:32px;font-size:12px;font-weight:700}.segmented.active{color:#07573a;background:#e4f3ec;border-color:#0f7b54}.compact-input{min-height:32px}.hour-stepper{grid-column:1/-1;grid-template-columns:1fr 1fr;gap:6px;display:grid}.hour-stepper button{min-height:30px;font-size:12px;font-weight:800}.search-button{color:#fff;background:#0f7b54;border-color:#0f7b54;grid-column:1/-1;min-height:32px;font-size:12px;font-weight:800}.search-button:disabled{color:#748079;cursor:not-allowed;background:#dfe5e1;border-color:#c5cec9}.swap-button{justify-content:center;align-items:center;gap:7px;min-height:28px;font-size:12px;font-weight:800;display:inline-flex}.panel-title{grid-template-columns:auto 1fr auto;align-items:center;gap:7px;font-size:13px;font-weight:800;display:grid}.panel-title button{place-items:center;width:28px;height:28px;padding:0;display:inline-grid}.line-search{box-sizing:border-box;border:1px solid #bfcac4;height:32px;padding:0 9px}.filter-list{border:1px solid #d5ddd8;display:grid}.filter-row{border-bottom:1px solid #e5e9e6;grid-template-columns:70px 1fr;align-items:center;min-height:34px;padding:0 6px;font-size:12px;display:grid}.filter-row:last-child{border-bottom:0}.filter-row>span{font-weight:800}.filter-row div{grid-template-columns:1fr 1fr;gap:4px;display:grid}.mini-toggle{min-height:24px;padding:0 5px;font-size:11px}.mini-toggle.include.active{background:#dff3ea;border-color:#0d7d52}.mini-toggle.exclude.active{background:#fae3e3;border-color:#b12a2a}.results{flex-direction:column;min-width:0;display:flex}.results-header{background:#fff;border-bottom:1px solid #cfd7d2;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.eyeline{text-transform:uppercase;font-weight:800;color:#0c7350!important}.results-header h2{margin:1px 0 2px;font-size:19px;line-height:1.2}.options-button{align-items:center;gap:7px;min-height:32px;padding:0 10px;font-size:13px;font-weight:700;display:inline-flex}.options-panel{background:#fff;border-bottom:1px solid #dce3df;flex-wrap:wrap;align-items:center;gap:14px;padding:8px 16px;display:flex}.options-panel .api-key-field{min-width:260px}.options-panel .api-key-field input{border:1px solid #bfcac4;width:170px;height:28px;padding:0 7px}.options-panel label{color:#17211c;align-items:center;gap:7px;font-size:12px;font-weight:800;display:inline-flex}.options-panel label span{color:inherit;margin:0}.options-panel input[type=checkbox]{width:14px;height:14px}.options-panel select{border:1px solid #bfcac4;width:74px;height:28px;padding:0 6px;font-size:12px}.summary-strip{color:#435149;background:#eef5f1;border-bottom:1px solid #dce3df;flex-wrap:wrap;align-items:center;gap:12px;padding:7px 16px;font-size:12px;font-weight:700;display:flex}.summary-strip span+span{border-left:1px solid #c8d4ce;padding-left:12px}.connection-list{padding:8px;overflow:auto}.connection{background:#fff;border:1px solid #d2dbd6;border-left:4px solid #0000}.connection+.connection,.empty-state{margin-top:8px}.connection.expanded{border-left-color:#0a7b52}.connection-main{text-align:left;background:0 0;border:0;grid-template-columns:28px minmax(0,1fr) 24px;gap:8px;width:100%;padding:10px 10px 9px 8px;display:grid}.connection-icon{color:#1e4e3d;place-items:center;width:24px;height:24px;display:grid}.connection-icon svg:first-child{color:#a75d00}.connection-body{min-width:0}.connection-topline{grid-template-columns:minmax(0,1fr) auto;align-items:baseline;gap:10px;display:grid}.connection-topline strong{font-size:15px}.connection-topline span{color:#17211c;font-size:13px;font-weight:800}.route-chain{flex-wrap:wrap;align-items:center;gap:4px;margin-top:6px;display:flex}.route-token{color:#54635b;align-items:center;gap:4px;display:inline-flex}.line-badge{color:#fff;align-items:center;min-height:17px;padding:0 5px;font-size:11px;font-weight:900;line-height:1;display:inline-flex}.mode-s{background:#12964c}.mode-re{background:#e00025}.mode-rb{background:#58a915}.mode-bus{background:#a622a6}.mode-tram{background:#0076b6}.origin-line{margin-top:7px}.warning-line{color:#9b5c00;margin-top:3px}.chevron{place-self:center end;transition:transform .16s}.chevron.open{transform:rotate(180deg)}.connection-details{background:#fbfcfb;border-top:1px solid #e0e7e2;padding:8px 10px 10px 44px}.details-meta{flex-wrap:wrap;gap:8px;margin-bottom:7px;font-weight:700;display:flex}.details-meta span{background:#fff;border:1px solid #d5ddd8;padding:2px 6px}.leg-row{border-top:1px solid #e6ebe8;grid-template-columns:48px 46px minmax(0,1fr);align-items:start;gap:8px;padding:7px 0;display:grid}.leg-row:first-of-type{border-top:0}.leg-time{color:#18231e;gap:2px;font-size:12px;display:grid}.leg-time span{color:#66746d}.leg-mode{color:#53635b}.leg-copy{gap:2px;min-width:0;font-size:13px;display:grid}.empty-state{background:#fff;border:1px solid #d2dbd6;gap:3px;padding:14px;display:grid}@media (width<=860px){.app-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #cfd7d2;border-right:0}.filter-list{grid-template-columns:1fr 1fr}.filter-row:nth-child(odd){border-right:1px solid #e5e9e6}}@media (width<=560px){.sidebar{gap:10px;padding:10px}.brand-row{padding-bottom:8px}.results-header{flex-direction:column;align-items:stretch;gap:10px;padding:10px 14px}.options-button{justify-content:center}.options-panel{flex-direction:column;align-items:stretch;gap:8px;padding:8px 14px}.connection-topline{grid-template-columns:1fr;gap:2px}.connection-details{padding-left:10px}.leg-row{grid-template-columns:44px 42px minmax(0,1fr)}.filter-list{grid-template-columns:1fr;max-height:112px;overflow:auto}.filter-row:nth-child(odd){border-right:0}}
