:root{--bg-app: #0a0e17;--bg-col: #0d1320;--bg-card: #121826;--bg-spine: #080b12;--bg-plan: #0b1019;--bg-pill: #121826;--tx-primary: #e8ecf4;--tx-secondary: #c3cad9;--tx-muted: #8a93a6;--tx-faint: #5b6577;--tx-fainter: #4a5468;--bd-structure: rgba(255, 255, 255, .07);--bd-card-left: rgba(255, 255, 255, .06);--bd-dashed: rgba(255, 255, 255, .18);--accent: #4da3ff;--c-vertrek: #38bdf8;--c-aankomst: #c084fc;--c-ontime: #34d399;--c-delay: #f5a524;--c-canceled: #f87171;--c-connection: #2dd4bf;--font-display: "Space Grotesk", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", monospace;color-scheme:dark}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg-app)}body{font-family:var(--font-display);color:var(--tx-primary);-webkit-font-smoothing:antialiased;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}button{font-family:inherit}.mono{font-family:var(--font-mono)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:10px;border:2px solid var(--bg-col)}::-webkit-scrollbar-thumb:hover{background:#ffffff38}@keyframes shimmer{0%{background-position:-300px 0}to{background-position:300px 0}}@keyframes blip{0%,to{opacity:1}50%{opacity:.35}}.app{height:100%;overflow:hidden;display:flex;flex-direction:column;background:var(--bg-app);color:var(--tx-primary)}.header{flex:none;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:15px 26px;border-bottom:1px solid var(--bd-structure);background:linear-gradient(180deg,#0e1422,#0a0e17)}.header__left{display:flex;align-items:center;gap:16px;min-width:0}.badge-logo{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;background:#101a2e;border:1px solid rgba(77,163,255,.35);color:var(--accent);font-weight:700;font-size:15px;flex:none}.route{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden}.route__arrow{color:var(--accent);font-size:13px}.route__mid{color:var(--tx-muted)}.date{font-family:var(--font-mono);font-size:11px;color:var(--tx-faint);margin-top:2px}.clock{display:flex;align-items:baseline;gap:2px;font-family:var(--font-mono);flex:none}.clock__hm{font-size:30px;font-weight:600;letter-spacing:-1px}.clock__s{font-size:15px;color:var(--tx-faint)}.header__right{display:flex;align-items:center;gap:14px;flex:none}.pill-group{display:flex;background:var(--bg-pill);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:3px}.seg{border:none;border-radius:8px;padding:6px 13px;font-size:12px;font-weight:600;cursor:pointer;background:transparent;color:var(--tx-muted);white-space:nowrap}.seg--active{background:var(--accent);color:#06122a}.icon-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;background:var(--bg-pill);border:1px solid rgba(255,255,255,.08);color:var(--tx-muted);cursor:pointer;font-size:15px}.icon-btn:hover{color:var(--tx-secondary)}.status{display:flex;align-items:center;gap:7px;background:transparent;border:none;cursor:pointer;color:var(--tx-muted);font-size:11px;font-family:var(--font-mono);padding:4px;white-space:nowrap}.status__dot{display:inline-block;width:7px;height:7px;border-radius:50%;animation:blip 2s infinite}.sheet-switch{position:relative}.sheet-switch select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-pill);border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--tx-secondary);font-family:var(--font-display);font-size:12px;font-weight:600;padding:7px 28px 7px 12px;cursor:pointer}.sheet-switch:after{content:"▾";position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--tx-muted);pointer-events:none;font-size:10px}.planbar{flex:none;padding:11px 26px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--bd-structure);background:var(--bg-plan);min-height:46px}.plan{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:13px;min-width:0}.plan__pill{display:inline-block;font-weight:700;font-size:10px;letter-spacing:.6px;text-transform:uppercase;padding:3px 9px;border-radius:6px;background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}.plan__line{font-family:var(--font-mono);color:var(--tx-secondary)}.plan__countdown{font-family:var(--font-mono);color:var(--accent)}.plan__hint{color:var(--tx-faint);font-size:13px}.legend{margin-left:auto;display:flex;align-items:center;gap:16px;font-size:11px;color:var(--tx-muted);white-space:nowrap}.legend__item{display:flex;align-items:center;gap:6px}.legend__dot{width:8px;height:8px;border-radius:50%}.board{flex:1;display:flex;min-height:0}.column{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg-col)}.column__head{position:sticky;top:0;z-index:2;padding:15px 20px;background:#0d1320f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--bd-structure);display:flex;align-items:baseline;justify-content:space-between;gap:12px}.column__title{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px}.column__count{font-family:var(--font-mono);font-size:11px;color:var(--tx-faint)}.column__body{flex:1;overflow-y:auto;padding:14px 16px 60px;display:flex;flex-direction:column;gap:9px}.empty{color:var(--tx-faint);font-size:13px;text-align:center;padding:40px 10px}.spine{width:48px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--bg-spine);border-left:1px solid var(--bd-structure);border-right:1px solid var(--bd-structure)}.spine__label{writing-mode:vertical-rl;transform:rotate(180deg);font-size:11px;letter-spacing:4px;color:var(--tx-fainter);text-transform:uppercase;font-weight:600;white-space:nowrap}.skeleton{height:74px;border-radius:14px;background:linear-gradient(90deg,#121826,#1a2236,#121826);background-size:600px 100%;animation:shimmer 1.4s infinite;flex:none}.card{position:relative;display:block;width:100%;text-align:left;border:1px solid var(--bd-structure);border-left:3px solid var(--bd-card-left);background:var(--bg-card);border-radius:14px;padding:13px 16px;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease;color:inherit;flex:none}.card:hover{transform:translateY(-1px);box-shadow:0 8px 20px -12px #000000b3}.card--past{opacity:.42}.card--target{border:1px solid var(--accent);border-left:3px solid var(--accent);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 14%,var(--bg-card)),var(--bg-card) 72%);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 33%,transparent),0 14px 34px -14px var(--accent)}.card--connection{border:1px solid color-mix(in srgb,var(--c-connection) 60%,transparent);border-left:3px solid var(--c-connection);background:linear-gradient(180deg,color-mix(in srgb,var(--c-connection) 9%,var(--bg-card)),var(--bg-card) 72%)}.card__meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.card__meta-left{display:flex;align-items:center;gap:8px;min-width:0}.type-badge{display:inline-block;font-weight:700;font-size:11px;letter-spacing:.5px;padding:2px 7px;border-radius:6px}.train-num{font-family:var(--font-mono);font-size:13px;color:var(--tx-secondary)}.delay-pill{display:inline-block;font-family:var(--font-mono);font-size:12px;font-weight:600;padding:3px 9px;border-radius:999px;white-space:nowrap}.delay-pill--delay{background:#f5a52429;color:var(--c-delay);border:1px solid rgba(245,165,36,.4)}.delay-pill--canceled{background:#f8717129;color:var(--c-canceled);border:1px solid rgba(248,113,113,.4)}.ontime{font-family:var(--font-mono);font-size:11px;color:var(--c-ontime)}.times{display:flex;align-items:flex-start;gap:12px}.leg-block{flex:none}.leg-block--arr{text-align:right}.mini-label{display:flex;align-items:center;gap:6px;font-size:9px;font-weight:700;letter-spacing:1px;margin-bottom:4px}.mini-label--dep{color:var(--c-vertrek)}.mini-label--arr{color:var(--c-aankomst);justify-content:flex-end}.mini-dot{width:8px;height:8px;border-radius:50%}.mini-dot--dep{background:var(--c-vertrek);box-shadow:0 0 0 3px #38bdf829}.mini-dot--arr{background:var(--c-aankomst);box-shadow:0 0 0 3px #c084fc29}.time-dep{font-family:var(--font-mono);font-size:25px;font-weight:600;letter-spacing:-.5px;line-height:1}.time-arr{font-family:var(--font-mono);font-size:21px;font-weight:600;letter-spacing:-.5px;line-height:1}.time-real{font-family:var(--font-mono);font-size:11px;color:var(--c-delay);margin-top:3px}.platform{font-size:11px;color:var(--tx-muted);margin-top:6px}.platform b{color:var(--tx-primary);font-weight:600;font-family:var(--font-mono)}.connector{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding-top:14px;min-width:24px}.connector__dur{font-family:var(--font-mono);font-size:10px;color:var(--tx-faint)}.connector__line{width:100%;display:flex;align-items:center;gap:3px}.connector__dot{width:5px;height:5px;border-radius:50%;flex:none}.connector__dot--dep{background:var(--c-vertrek)}.connector__dot--arr{background:var(--c-aankomst)}.connector__dash{flex:1;height:0;border-top:1.5px dashed var(--bd-dashed)}.connector__chev{color:var(--tx-faint);font-size:11px;flex:none;line-height:1}.tag{margin-top:10px;display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.3px}.tag--target{color:var(--accent)}.tag--connection{color:var(--c-connection)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#04070da8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal{width:100%;max-width:440px;max-height:86vh;overflow-y:auto;background:#0e1422;border:1px solid var(--bd-structure);border-radius:18px;padding:22px;box-shadow:0 30px 80px -20px #000c}.modal__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.modal__title{font-size:17px;font-weight:600}.field{margin-bottom:16px}.field>label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--tx-muted);margin-bottom:7px}.input{width:100%;background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--tx-primary);font-family:var(--font-display);font-size:14px;padding:10px 12px}.input:focus{outline:none;border-color:var(--accent)}.row{display:flex;align-items:center;gap:8px}.station-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.station-row__handle{color:var(--tx-faint);font-family:var(--font-mono);font-size:11px;width:18px;flex:none}.btn{border:1px solid rgba(255,255,255,.1);background:var(--bg-card);color:var(--tx-secondary);border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600;cursor:pointer}.btn:hover{border-color:#fff3}.btn--primary{background:var(--accent);border-color:var(--accent);color:#06122a}.btn--danger{color:var(--c-canceled);border-color:#f8717166}.btn--ghost{background:transparent;border-color:transparent;color:var(--tx-muted)}.btn-sm{padding:6px 9px;font-size:12px}.modal__actions{display:flex;gap:10px;margin-top:22px}.spacer{flex:1}.ac{position:relative;flex:1}.ac__menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#0e1422;border:1px solid rgba(255,255,255,.12);border-radius:10px;z-index:5;overflow:hidden;box-shadow:0 18px 40px -16px #000c}.ac__opt{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--tx-secondary);padding:9px 12px;font-size:13px;cursor:pointer}.ac__opt--active,.ac__opt:hover{background:#4da3ff24;color:var(--tx-primary)}.range{width:100%}.swatches{display:flex;gap:8px;flex-wrap:wrap}.swatch{width:28px;height:28px;border-radius:8px;border:2px solid transparent;cursor:pointer}.swatch--active{border-color:var(--tx-primary)}.hint{font-size:12px;color:var(--tx-faint);margin-top:6px}@media (max-width: 720px){.board{flex-direction:column;overflow-y:auto}.column{min-height:60vh}.spine{width:auto;height:40px;border-left:none;border-right:none;border-top:1px solid var(--bd-structure);border-bottom:1px solid var(--bd-structure)}.spine__label{writing-mode:horizontal-tb;transform:none;letter-spacing:4px}.header{flex-wrap:wrap;gap:12px;padding:12px 16px}.clock{order:3}.planbar{padding:10px 16px}.legend{display:none}}
