:root{--bg: #0d1117;--surface: #161b22;--surface-2: #1c2128;--surface-3: #22272e;--border: #30363d;--border-strong: #444c56;--text: #e6edf3;--text-dim: #8b949e;--text-bright: #f0f6fc;--accent: #ff6b35;--accent-hover: #ff8559;--accent-soft: rgba(255, 107, 53, .12);--danger: #f85149;--danger-soft: rgba(248, 81, 73, .12);--success: #3fb950;--radius: 10px;--radius-sm: 6px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color-scheme:dark;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text)}body{overscroll-behavior:none}button{font:inherit;font-weight:500;background:var(--surface-3);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 14px;cursor:pointer;transition:background .15s,border-color .15s,transform .05s;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px}button:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-strong)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.block{width:100%}button.icon{padding:6px 8px;background:transparent;border-color:transparent;color:var(--text-dim);min-height:32px;min-width:32px;border-radius:var(--radius-sm)}button.icon:hover:not(:disabled){background:var(--danger-soft);color:var(--danger)}input,select{font:inherit;background:var(--surface-3);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;width:100%;min-height:38px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}input::placeholder{color:var(--text-dim)}.app{display:grid;grid-template-rows:auto 1fr;height:100vh;height:100dvh}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border);z-index:10}.brand{display:flex;align-items:center;gap:10px;min-width:0}.brand h1{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;font-size:18px;background:var(--accent-soft);border-radius:var(--radius-sm);flex-shrink:0}.header-actions{display:flex;gap:8px;flex-shrink:0}.layout{display:grid;grid-template-columns:1fr 400px;overflow:hidden;min-height:0}.map-wrap{position:relative;min-height:0}.map-wrap .leaflet-container{height:100%;width:100%;background:#0d1117}.sidebar{display:flex;flex-direction:column;gap:14px;padding:16px;overflow-y:auto;background:var(--surface);border-left:1px solid var(--border);-webkit-overflow-scrolling:touch}.card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}.card h2{margin:0 0 12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);display:flex;align-items:center;justify-content:space-between;gap:6px}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;font-size:11px;font-weight:600;background:var(--surface-3);border:1px solid var(--border);color:var(--text);border-radius:999px;letter-spacing:0;text-transform:none}.stack{display:flex;flex-direction:column;gap:8px}.station-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.station-list li{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid transparent;transition:border-color .15s}.station-list li:hover{border-color:var(--border)}.station-list .name{flex:1;min-width:0}.station-list .name strong{display:block;font-size:14px;font-weight:500;color:var(--text-bright)}.station-list .name small{display:block;color:var(--text-dim);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.current-incident{display:flex;align-items:center;gap:10px;margin-top:10px;padding:10px 12px;background:var(--accent-soft);border:1px solid rgba(255,107,53,.3);border-radius:var(--radius-sm)}.current-incident .pin{font-size:18px}.current-incident .info{flex:1;min-width:0}.current-incident .info strong{display:block;font-size:13px;color:var(--text-bright)}.current-incident .info small{display:block;font-size:12px;color:var(--text-dim);word-break:break-word}.sort-controls{display:flex;gap:6px;margin-bottom:10px}.sort-controls select{flex:1}.results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px;counter-reset:result}.result{display:flex;align-items:center;gap:10px;padding:9px 10px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid transparent;transition:border-color .15s}.result:hover{border-color:var(--border)}.result .rank{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;font-weight:700;font-size:13px;background:var(--surface-3);color:var(--text-dim);border-radius:50%}.result .info{flex:1;min-width:0}.result .info strong{display:block;font-size:14px;font-weight:500;color:var(--text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result .info small{display:block;color:var(--text-dim);font-size:12px;margin-top:2px}.result.error{border-color:#f851494d}.result.error .rank{background:var(--danger-soft);color:var(--danger)}.result.error .info strong{color:var(--text-dim)}.error-banner{background:var(--danger-soft);border:1px solid rgba(248,81,73,.3);color:#ffb3aa;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;margin-top:8px}.hint{font-size:12px;color:var(--text-dim);margin-top:4px;line-height:1.5;display:flex;align-items:center;gap:6px}.spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .7s linear infinite;opacity:.7}@keyframes spin{to{transform:rotate(360deg)}}.autocomplete{position:relative}.autocomplete-spinner{position:absolute;right:12px;top:50%;width:14px;height:14px;margin-top:-7px;border:2px solid var(--text-dim);border-right-color:transparent;border-radius:50%;animation:spin .7s linear infinite;pointer-events:none}.suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1000;background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:4px;margin:0;list-style:none;max-height:280px;overflow-y:auto;box-shadow:var(--shadow-lg)}.suggestions li{display:flex;flex-direction:column;gap:1px;padding:8px 10px;border-radius:4px;cursor:pointer;font-size:13px;line-height:1.35}.suggestions li:hover,.suggestions li.active{background:var(--accent-soft)}.suggestion-label{color:var(--text-bright)}.suggestion-layer{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.leaflet-marker-icon.station-marker,.leaflet-marker-icon.incident-marker{background:transparent;border:none}.marker-pin{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 3px 8px #00000073;border:2.5px solid white}.marker-pin>.marker-rank,.marker-pin>.marker-emoji{transform:rotate(45deg);font-weight:700;font-size:13px;color:#fff;line-height:1}.marker-pin>.marker-emoji{font-size:16px}.marker-pin-incident{width:40px;height:40px;background:var(--accent);animation:pulse-incident 2s ease-out infinite}.marker-pin-incident>.marker-emoji{font-size:19px}@keyframes pulse-incident{0%,to{box-shadow:0 3px 8px #00000073,0 0 #ff6b3580}50%{box-shadow:0 3px 8px #00000073,0 0 0 10px #ff6b3500}}.leaflet-popup-content-wrapper{background:var(--surface-3);color:var(--text);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg)}.leaflet-popup-content{margin:10px 14px;font-size:13px;line-height:1.4}.leaflet-popup-tip{background:var(--surface-3)}.leaflet-container a.leaflet-popup-close-button{color:var(--text-dim)}.leaflet-control-attribution{background:#0d1117cc!important;color:var(--text-dim)!important}.leaflet-control-attribution a{color:var(--text)!important}@media(max-width:768px){.header{padding:10px 14px}.brand h1{font-size:15px}.brand-icon{width:28px;height:28px;font-size:16px}.header-actions button{padding:8px 10px;font-size:13px}.header-actions button .label-desktop{display:none}.layout{grid-template-columns:1fr;grid-template-rows:45vh 1fr}.sidebar{border-left:none;border-top:1px solid var(--border);padding:12px;gap:12px}.card{padding:12px}button{min-height:42px;padding:10px 14px}input,select{min-height:42px;font-size:16px}button.icon{min-height:36px;min-width:36px}.result{padding:10px}}@media(min-width:769px)and (max-width:1024px){.layout{grid-template-columns:1fr 340px}}.label-mobile{display:none}@media(max-width:768px){.label-mobile{display:inline}}
