:root{--text:#334155;--muted:#64748b;--heading:#111827;--bg:#eef2f5;--surface:#fff;--surface-soft:#f8fafc;--border:#d8dee7;--focus:#2563eb;--shadow:0 18px 42px #0f172a24;--sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;font:15px/1.45 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0}button,input,select{font:inherit}button{cursor:pointer}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #2563eb4d}#root{min-height:100svh}.brand-row,.label-like,.control-group label{align-items:center;display:flex}.brand-row{border-bottom:1px solid var(--border);gap:12px;padding-bottom:12px}.brand-mark{color:#f8fafc;background:#111827;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}h1,h2,h3,p{margin:0}h1{color:var(--heading);letter-spacing:0;font-size:21px;font-weight:720;line-height:1.1}h2{color:var(--heading);letter-spacing:0;font-size:18px;font-weight:700;line-height:1.2}h3{color:var(--heading);letter-spacing:0;font-size:16px;font-weight:700;line-height:1.2}.brand-row p{color:var(--muted);font-size:13px}.control-group{flex-direction:column;gap:8px;display:flex}.control-group label,.label-like{color:var(--heading);gap:7px;font-size:13px;font-weight:700}input,select{border:1px solid var(--border);width:100%;min-height:38px;color:var(--heading);background:#fff;border-radius:7px;padding:8px 10px}.window-grid,.radius-buttons,.layer-grid{gap:8px;display:grid}.window-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.radius-buttons{grid-template-columns:repeat(4,minmax(0,1fr))}.layer-grid{grid-template-columns:1fr}.window-chip,.radius-button{border:1px solid var(--border);min-height:36px;color:var(--heading);background:var(--surface-soft);border-radius:7px;font-weight:700}.radius-button{white-space:nowrap;min-height:34px;padding:0 6px}.layer-toggle{border:1px solid var(--border);background:var(--surface-soft);border-radius:7px;grid-template-columns:18px minmax(0,1fr);align-items:center;min-height:34px;padding:8px 10px;color:var(--text)!important;gap:9px!important;font-weight:650!important;display:grid!important}.layer-toggle input{accent-color:#0f766e;width:18px;min-height:18px}.layer-toggle span{overflow-wrap:anywhere;min-width:0}.window-chip.active{color:#fff;border-color:var(--chip-color);background:var(--chip-color);box-shadow:inset 0 0 0 1px #ffffff29}.radius-button.active{color:#fff;background:#0f766e;border-color:#0f766e}.toggle-row{justify-content:flex-start;gap:9px;color:var(--text)!important;font-weight:600!important}.toggle-row input{accent-color:#0f766e;width:18px;min-height:18px}.api-shell{grid-template-columns:320px minmax(520px,1fr);gap:14px;min-height:100svh;padding:14px;display:grid}.api-shell.detail-open{grid-template-columns:320px minmax(420px,1fr) minmax(360px,480px)}.api-sidebar,.api-detail-panel{border:1px solid var(--border);background:var(--surface);min-width:0;max-height:calc(100svh - 28px);box-shadow:var(--shadow);border-radius:8px;flex-direction:column;gap:16px;padding:18px;display:flex;overflow:auto}.api-map-section{border:1px solid var(--border);min-width:0;min-height:calc(100svh - 28px);box-shadow:var(--shadow);background:#dbe7ef;border-radius:8px;position:relative;overflow:hidden}.api-detail-header{grid-template-columns:minmax(0,1fr) 34px;align-items:start;gap:12px;display:grid}.api-detail-title{overflow-wrap:anywhere;min-width:0;font-size:24px;font-weight:760;line-height:1.15}.api-detail-close{border:1px solid var(--border);width:34px;height:34px;color:var(--muted);background:#fff;border-radius:7px;place-items:center;display:grid}.api-detail-close:hover{color:var(--heading);background:var(--surface-soft)}.maplibre-map-shell{width:100%;height:100%;min-height:calc(100svh - 28px);position:relative}.maplibre-map{width:100%;height:100%;min-height:calc(100svh - 28px)}.map-zoom-level{z-index:1000;min-width:78px;color:var(--heading);pointer-events:none;background:#fffffff2;border:1px solid #0f172a29;border-radius:7px;padding:7px 9px;font-size:12px;font-weight:750;line-height:1;position:absolute;top:84px;left:12px;box-shadow:0 6px 18px #0f172a24}.api-legend{border:1px solid var(--border);max-width:calc(100% - 24px);color:var(--text);box-shadow:var(--shadow);background:#ffffffeb;border-radius:8px;flex-wrap:wrap;gap:8px;padding:9px 10px;font-size:12px;font-weight:650;display:flex;position:absolute;bottom:12px;left:12px}.map-update-status{z-index:1000;pointer-events:none;min-width:178px;color:var(--heading);text-align:center;opacity:0;background:#fffffff5;border:1px solid #0f172a29;border-radius:8px;padding:9px 12px;font-size:13px;font-weight:750;transition:opacity .16s,transform .16s;position:absolute;top:12px;left:50%;transform:translate(-50%)translateY(-6px);box-shadow:0 8px 22px #0f172a2e}.map-update-status.loading,.map-update-status.complete{opacity:1;transform:translate(-50%)translateY(0)}.map-update-status.loading{color:#1d4ed8;border-color:#2563eb47}.map-update-status.complete{color:#0f766e;border-color:#0f766e47}.api-legend span{align-items:center;gap:6px;display:inline-flex}.api-legend i{border-radius:999px}.legend-stop-regional{background:#075985;border:2px solid #fff;width:13px;height:13px}.legend-stop-urban{background:#0f766e;border:1.5px solid #fff;width:11px;height:11px}.legend-stop-bus{background:#64748b;border:1px solid #fff;width:8px;height:8px}.legend-route-bus{background:#b45309;width:16px;height:3px}.legend-school{background:#fff;border:2px solid #0f172a;width:13px;height:13px;border-radius:3px!important}.legend-school-gymnasium{background:#bfdbfe;border:2px solid #2563eb;width:13px;height:13px;border-radius:3px!important}.api-panel-section{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;padding-bottom:14px;display:flex}.api-panel-section p{color:var(--text);overflow-wrap:anywhere;font-size:13px}.api-detail-panel .api-panel-section h2,.api-disclosure summary{color:var(--heading);font-size:16px;font-weight:700}.api-disclosure summary{cursor:pointer;justify-content:center;align-items:center;list-style:none;display:flex}.api-disclosure summary::-webkit-details-marker{display:none}.api-disclosure summary:after{content:"";color:#64748b;background-color:#f8fafc;background-image:linear-gradient(45deg,#0000 45%,currentColor 45% 58%,#0000 58%),linear-gradient(135deg,#0000 45%,currentColor 45% 58%,#0000 58%);background-position:calc(50% - 4px) 8px,calc(50% + 4px) 8px;background-repeat:no-repeat;background-size:8px 8px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;border-radius:999px;flex:none;place-items:center;width:34px;height:20px;display:grid;box-shadow:inset 0 0 0 1px #94a3b859}.api-disclosure[open] summary:after{background-position:calc(50% - 4px) 6px,calc(50% + 4px) 6px;transform:rotate(180deg)}.api-disclosure-content{gap:8px;display:grid}.api-meta-disclosure{gap:12px;padding-top:2px}.api-meta-disclosure-content{gap:14px;display:grid}.api-meta-disclosure-content section{gap:7px;display:grid}.api-meta-disclosure-content h3{font-size:14px}.api-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.api-metric{border:1px solid var(--border);background:var(--surface-soft);border-radius:8px;min-width:0;padding:10px}.api-metric span,.api-metric strong{display:block}.api-metric span{color:var(--muted);font-size:12px}.api-metric strong{color:var(--heading);overflow-wrap:anywhere;margin-top:4px;font-size:17px}.api-itinerary-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.api-itinerary-block{gap:10px;padding-block:4px 10px;display:grid}.api-itinerary-block+.api-itinerary-block{border-top:1px solid var(--border);padding-top:12px}.api-itinerary-block h3{color:var(--heading);margin:0;font-size:14px}.api-realtime-controls{gap:7px;display:grid}.api-realtime-controls label{color:var(--muted);font-size:12px;font-weight:750}.api-realtime-time-row{grid-template-columns:minmax(86px,auto) minmax(112px,1fr) minmax(86px,auto);align-items:center;gap:8px;display:grid}.api-time-step-button{border:1px solid var(--border);min-height:38px;color:var(--heading);background:#fff;border-radius:7px;padding:8px 10px;font-size:12px;font-weight:750}.api-time-step-button:hover{background:var(--surface-soft)}.api-itinerary-alternatives{gap:18px;margin:0;padding:0;list-style:none;display:grid}.api-inline-status,.api-inline-error{border-radius:7px;margin:0;padding:8px;font-size:12px;font-weight:650}.api-inline-status{color:#0f766e;background:#ccfbf1}.api-loading-status{isolation:isolate;min-height:38px;position:relative;overflow:hidden}.api-loading-status:before{content:"";z-index:-1;background:linear-gradient(90deg,#0000 0%,#ffffffb8 42%,#0000 78%) 0 0/48% 100%,linear-gradient(90deg,#ccfbf1,#a7f3d0,#ccfbf1) 0 0/200% 100%;animation:1.15s ease-in-out infinite api-loading-sweep;position:absolute;inset:0}.api-loading-status span:after{content:"...";text-align:left;width:1.25em;animation:1.2s steps(4,end) infinite api-loading-dots;display:inline-block}.api-inline-error{color:#991b1b;background:#fee2e2}@keyframes api-loading-sweep{0%{background-position:-70% 0,0 0}to{background-position:170% 0,100% 0}}@keyframes api-loading-dots{0%{content:""}25%{content:"."}50%{content:".."}75%,to{content:"..."}}@media (prefers-reduced-motion:reduce){.api-loading-status:before,.api-loading-status span:after{animation:none}}.api-itinerary-summary span{border:1px solid var(--border);background:var(--surface-soft);overflow-wrap:anywhere;border-radius:7px;min-width:0;padding:8px;font-size:12px;font-weight:650}.api-driving-route{gap:8px;display:grid}.api-driving-route-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.api-driving-route-summary span{border:1px solid var(--border);background:var(--surface-soft);border-radius:7px;min-width:0;padding:9px}.api-driving-route-summary small,.api-driving-route-summary strong{display:block}.api-driving-route-summary small{color:var(--muted);font-size:12px;font-weight:650}.api-driving-route-summary strong{color:var(--heading);margin-top:3px;font-size:16px}.api-driving-route p{color:var(--muted);margin:0;font-size:12px}.api-leg-list{flex-direction:column;gap:8px;margin:7px 0 0;padding:0;list-style:none;display:flex}.api-leg-list li{color:var(--text);grid-template-columns:18px minmax(0,1fr);align-items:start;gap:8px;font-size:13px;display:grid}.api-leg-list strong{color:var(--heading);display:block}.api-leg-list small,.api-leg-list em{color:var(--muted);margin-top:2px;font-size:12px;font-style:normal;line-height:1.35;display:block}.api-leg-list em{color:#7c2d12}.api-leg-list li.cancelled{opacity:.72}.api-route-list{flex-wrap:wrap;gap:7px;display:flex}.api-route-list span{color:#fff;background:#0f766e;border-radius:7px;padding:6px 8px;font-size:12px;font-weight:700}.map-loading{min-height:calc(100svh - 28px);color:var(--muted);background:#dbe7ef;place-items:center;font-weight:700;display:grid}.residential-radius{filter:drop-shadow(0 0 2px #111827bf)}.map-base-toggle{z-index:1000;min-height:36px;color:var(--heading);background:#fffffff0;border:1px solid #1118272e;border-radius:7px;align-items:center;gap:7px;padding:8px 10px;font-size:13px;font-weight:750;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 8px 20px #0f172a24}.map-base-toggle:hover{background:#fff}.map-base-toggle.active{color:#fff;background:#0f766e;border-color:#0f766eb8}.map-popup{gap:4px;min-width:190px;max-width:280px;display:grid}.map-popup strong{color:var(--heading);overflow-wrap:anywhere}.map-popup span{color:var(--text);overflow-wrap:anywhere;line-height:1.35}.stop-hover-popup{gap:6px}.stop-hover-popup span{font-size:12px}@media (width<=1320px){.api-shell.detail-open{grid-template-rows:minmax(520px,1fr) auto;grid-template-columns:300px minmax(420px,1fr)}.api-shell.detail-open .api-detail-panel{grid-column:1/-1;max-height:520px}}@media (width<=820px){.api-shell,.api-shell.detail-open{flex-direction:column;min-height:auto;padding:8px;display:flex}.api-sidebar,.api-detail-panel{max-height:none}.api-map-section,.maplibre-map-shell,.maplibre-map{min-height:520px}.api-itinerary-summary,.api-realtime-time-row{grid-template-columns:1fr}.window-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
