@import "https://fonts.googleapis.com/css2?family=Rajdhani:wght@500;600;700&family=JetBrains+Mono:wght@400;600&family=Noto+Sans:wght@400;500;600;700&display=swap";:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--canvas:#04091a;--surface-0:#070e1e;--surface-1:#0a1628;--surface-2:#0d1c33;--surface-3:#12233e;--accent:#e84d0e;--accent-dim:#e84d0e24;--gold:#cf8a14;--gold-dim:#cf8a1421;--ir-blue:#1b6db8;--ir-blue-glow:#1b6db838;--text-1:#ebf2ff;--text-2:#7a9dc0;--text-3:#3d5e7d;--success:#18bc67;--warn:#e8a020;--error:#e03535;--border:#ffffff0e;--border-hi:#ffffff21;--radius-sm:10px;--radius-md:18px;--radius-lg:26px;--radius-full:999px;--ease:cubic-bezier(.2,0,0,1);--t-fast:.16s;--t-norm:.28s;--t-slow:.5s;--stage-w:640px;--results-w:920px;--gutter:clamp(16px,4vw,52px);--header-h:68px;--av-hero:clamp(200px,38vw,290px);--av-compact:clamp(52px,8vw,68px)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{min-height:100%}body{background:var(--canvas);min-height:100dvh;color:var(--text-1);touch-action:manipulation;-webkit-font-smoothing:antialiased;margin:0;font-family:Noto Sans,system-ui,sans-serif;font-size:16px;line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,p{margin:0}button{font:inherit;cursor:pointer;border:0}svg{display:block}button:focus-visible,a:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:3px}button:disabled{cursor:not-allowed;opacity:.44}.skip-link{z-index:300;border-radius:var(--radius-full);background:var(--accent);color:#fff;transition:transform var(--t-fast) var(--ease);padding:10px 20px;font-weight:700;text-decoration:none;position:fixed;top:12px;left:12px;transform:translateY(-200%)}.skip-link:focus{transform:translateY(0)}.bg-grid{z-index:0;pointer-events:none;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff04 1px,#0000 1px);background-size:52px 52px;position:fixed;inset:0;-webkit-mask-image:radial-gradient(80% 60% at 50% 25%,#000 40%,#0000 100%);mask-image:radial-gradient(80% 60% at 50% 25%,#000 40%,#0000 100%)}.kiosk-header{z-index:40;height:var(--header-h);padding:0 var(--gutter);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#070e1eeb;align-items:center;gap:12px;display:flex;position:sticky;top:0}.brand-lockup{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.ir-emblem{background:var(--accent-dim);width:42px;height:42px;color:var(--accent);border:1px solid #e84d0e47;border-radius:50%;flex:none;place-items:center;display:grid}.ir-emblem svg{width:22px;height:22px}.brand-text strong{letter-spacing:.05em;color:var(--text-1);font-family:Rajdhani,sans-serif;font-size:clamp(17px,2.2vw,22px);font-weight:700;line-height:1;display:block}.brand-text small{letter-spacing:.12em;color:var(--text-3);text-transform:uppercase;margin-top:2px;font-size:11px;font-weight:600;display:block}.status-chip{border-radius:var(--radius-full);border:1px solid var(--border-hi);background:var(--surface-1);height:34px;color:var(--text-2);letter-spacing:.03em;white-space:nowrap;align-items:center;gap:8px;margin-left:auto;padding:0 14px;font-size:12px;font-weight:600;display:inline-flex}.status-dot{background:var(--text-3);width:8px;height:8px;transition:background var(--t-norm),box-shadow var(--t-norm);border-radius:50%;flex:none}.status-ready .status-dot{background:var(--success);box-shadow:0 0 8px var(--success)}.status-active .status-dot{background:var(--ir-blue);box-shadow:0 0 8px var(--ir-blue);animation:1.8s ease-in-out infinite dotPulse}.status-warning .status-dot{background:var(--warn)}.status-error .status-dot{background:var(--error)}.station-header-btn{border-radius:var(--radius-full);color:#ffe7dc;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;min-width:48px;height:38px;transition:transform var(--t-fast) var(--ease),border-color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);background:linear-gradient(135deg,#e84d0e33,#1b6db81a);border:1px solid #e84d0e61;place-items:center;padding:0 14px;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:800;display:inline-grid;box-shadow:inset 0 1px #ffffff0f,0 8px 22px #e84d0e1f}.station-header-btn:not(:disabled):hover{background:linear-gradient(135deg,#e84d0e47,#1b6db829);border-color:#e84d0e9e;transform:translateY(-1px);box-shadow:inset 0 1px #ffffff14,0 12px 30px #e84d0e2e}.admin-icon-btn{border:1px solid var(--border);width:38px;height:38px;color:var(--text-3);transition:color var(--t-fast),background var(--t-fast);background:0 0;border-radius:50%;flex:none;place-items:center;display:grid}.admin-icon-btn:hover{color:var(--text-1);background:var(--surface-2)}.admin-icon-btn svg{width:17px;height:17px}.kiosk-stage{z-index:1;min-height:calc(100dvh - var(--header-h));padding:clamp(28px,4dvh,56px) var(--gutter) clamp(36px,6dvh,80px);flex-direction:column;align-items:center;gap:clamp(20px,3dvh,36px);display:flex;position:relative}.agent-zone{width:100%;max-width:var(--stage-w);transition:gap var(--t-slow) var(--ease);flex-direction:column;align-items:center;gap:clamp(14px,2dvh,22px);display:flex}.agent-avatar-wrap{width:var(--av-hero);height:var(--av-hero);transition:width var(--t-slow) var(--ease),height var(--t-slow) var(--ease);flex:none;position:relative}.agent-zone.is-compact .agent-avatar-wrap{width:var(--av-compact);height:var(--av-compact)}.agent-avatar-img{object-fit:contain;object-position:center bottom;mix-blend-mode:screen;width:100%;height:100%;filter:drop-shadow(0 20px 44px var(--ir-blue-glow));transition:all var(--t-slow) var(--ease)}.avatar-ring{pointer-events:none;transition:border-color var(--t-norm),box-shadow var(--t-norm);border:2px solid #0000;border-radius:50%;position:absolute;inset:-8%}.ring-listening{border-color:var(--ir-blue);box-shadow:0 0 0 8px var(--ir-blue-glow),0 0 36px var(--ir-blue-glow);animation:1.6s ease-in-out infinite ringPulse}.ring-standby{border-color:#7cb2e3b8;animation:2.8s ease-in-out infinite ringPulse;box-shadow:0 0 0 7px #1b6db824,0 0 24px #1b6db833}.ring-speaking{border-color:var(--accent);box-shadow:0 0 0 8px var(--accent-dim),0 0 28px var(--accent-dim);animation:2.2s ease-in-out infinite ringPulse}.ring-connecting{border-color:var(--gold);animation:2s linear infinite ringRotate}.agent-meta{text-align:center;opacity:1;max-height:120px;transition:opacity var(--t-slow) var(--ease),max-height var(--t-slow) var(--ease);overflow:hidden}.agent-zone.is-compact .agent-meta{opacity:0;max-height:0}.agent-name{letter-spacing:.06em;color:var(--text-1);font-family:Rajdhani,sans-serif;font-size:clamp(42px,7vw,72px);font-weight:700;line-height:1}.agent-role{letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-top:5px;font-size:clamp(12px,1.5vw,15px);font-weight:600}.agent-status-text{min-height:26px;color:var(--text-2);text-align:center;opacity:1;max-height:60px;transition:opacity var(--t-slow) var(--ease),max-height var(--t-slow) var(--ease);font-size:clamp(15px,1.9vw,20px);font-weight:500;overflow:hidden}.agent-zone.is-compact .agent-status-text{opacity:0;max-height:0}.voice-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;display:flex}.voice-btn{border-radius:var(--radius-full);background:var(--accent);color:#fff;letter-spacing:.04em;height:clamp(52px,7dvh,66px);transition:transform var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),background var(--t-fast);align-items:center;gap:10px;padding:0 clamp(24px,3.5vw,38px);font-family:Rajdhani,sans-serif;font-size:clamp(16px,2vw,20px);font-weight:700;display:inline-flex;position:relative;box-shadow:0 8px 28px #e84d0e59}.voice-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 14px 38px #e84d0e7a}.voice-btn:not(:disabled):active{transform:translateY(1px);box-shadow:0 4px 16px #e84d0e40}.voice-btn.state-listening{background:var(--ir-blue);box-shadow:0 8px 28px #1b6db866}.voice-btn.state-standby{background:#164b78;box-shadow:0 8px 24px #1b6db847}.voice-btn.state-speaking{background:#0c7856;box-shadow:0 8px 28px #0c785666}.voice-btn.state-fallback{background:var(--warn);box-shadow:0 8px 28px #e8a02066}.voice-btn.state-error{background:var(--error);box-shadow:0 8px 28px #e0353559}.voice-btn-bg{border-radius:inherit;opacity:0;transition:opacity var(--t-fast);background:#ffffff1a;position:absolute;inset:0}.voice-btn:hover .voice-btn-bg{opacity:1}.voice-btn svg{flex:none;width:20px;height:20px}.voice-btn-label{white-space:nowrap}.new-enquiry-btn{border-radius:var(--radius-full);border:1px solid var(--border-hi);background:var(--surface-2);height:clamp(52px,7dvh,66px);color:var(--text-2);transition:background var(--t-fast),color var(--t-fast);padding:0 clamp(20px,2.8vw,30px);font-size:clamp(13px,1.6vw,16px);font-weight:600}.new-enquiry-btn:hover{background:var(--surface-3);color:var(--text-1)}.station-modal-backdrop{z-index:120;padding:var(--gutter);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);animation:modalFadeIn var(--t-fast) var(--ease) both;background:#020612b8;place-items:center;display:grid;position:fixed;inset:0}.station-modal{width:min(100%,660px);animation:modalLiftIn var(--t-norm) var(--ease) both;background:radial-gradient(circle at 10% 0,#e84d0e2e,#0000 34%),radial-gradient(circle at 90% 20%,#1b6db82e,#0000 30%),linear-gradient(135deg,#12233efa,#070e1efa);border:1px solid #ffffff21;border-radius:30px;gap:16px;padding:18px;display:grid;box-shadow:0 30px 90px #00000080,inset 0 1px #ffffff0f}.station-modal-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:2px 4px 0;display:flex}.station-modal-eyebrow{letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-size:11px;font-weight:800}.station-modal-header h2{letter-spacing:.04em;color:var(--text-1);margin-top:3px;font-family:Rajdhani,sans-serif;font-size:clamp(28px,4vw,38px);font-weight:700;line-height:1}.station-modal-close{border:1px solid var(--border-hi);width:38px;height:38px;color:var(--text-2);transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast) var(--ease);background:#0000002e;border-radius:50%;flex:none;place-items:center;display:grid}.station-modal-close:hover{color:#fff;background:#e84d0e2e;transform:rotate(4deg)}.station-modal .station-selector-card{width:100%;box-shadow:none}.station-selector-card{border-radius:var(--radius-lg);background:radial-gradient(circle at 12% 20%,#e84d0e29,#0000 32%),linear-gradient(135deg,#0d1c33e6,#070e1eeb);border:1px solid #ffffff1a;gap:14px;width:min(100%,620px);padding:14px;display:grid;box-shadow:0 18px 44px #00000038,inset 0 1px #ffffff0b}.station-current{border-radius:calc(var(--radius-md) + 2px);background:#00000038;border:1px solid #ffffff12;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.station-current-kicker,.station-current-source,.station-code-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);white-space:nowrap;font-size:11px;font-weight:700}.station-current-main{flex:1;align-items:baseline;gap:10px;min-width:0;display:flex}.station-current-code{color:#dbeafe;letter-spacing:.08em;font-family:JetBrains Mono,monospace;font-size:clamp(20px,3vw,28px);font-weight:700}.station-current-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-2);font-size:14px;font-weight:600;overflow:hidden}.station-current-source{color:#fde68a;text-align:right}.station-switcher{gap:8px;display:grid}.station-switch-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.station-code-input{border-radius:var(--radius-full);border:1px solid var(--border-hi);min-width:92px;height:42px;color:var(--text-1);letter-spacing:.12em;text-transform:uppercase;background:#00000047;flex:120px;padding:0 15px;font-family:JetBrains Mono,monospace;font-size:15px;font-weight:700}.station-code-input::placeholder{color:var(--text-3)}.station-action-btn{border-radius:var(--radius-full);letter-spacing:.04em;height:42px;transition:transform var(--t-fast) var(--ease),background var(--t-fast),color var(--t-fast),border-color var(--t-fast);padding:0 15px;font-size:13px;font-weight:800}.station-action-btn:not(:disabled):hover{transform:translateY(-1px)}.station-action-btn.primary{background:var(--accent);color:#fff;box-shadow:0 8px 22px #e84d0e40}.station-action-btn.secondary{color:#bfdbfe;background:#1b6db829;border:1px solid #93c5fd42}.station-helper{min-height:18px;color:var(--text-3);font-size:12px;font-weight:600}.results-zone{width:100%;max-width:var(--results-w);animation:resultsIn var(--t-slow) var(--ease) both}.train-list{gap:14px;display:grid}.results-header{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:2px;padding:0 2px;display:flex}.results-title{letter-spacing:.04em;color:var(--text-1);font-family:Rajdhani,sans-serif;font-size:clamp(24px,3.6vw,38px);font-weight:700;line-height:1.05}.results-sub{color:var(--text-2);margin-top:5px;font-size:clamp(13px,1.7vw,15px);font-weight:500}.results-pill{border-radius:var(--radius-full);color:#fde68a;letter-spacing:.04em;text-transform:uppercase;background:#cf8a1426;border:1px solid #cf8a1447;flex:none;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.results-pill.is-loading{color:#93c5fd;background:#1b6db829;border-color:#93c5fd47}.train-card{border-radius:var(--radius-lg);background:linear-gradient(135deg,#12233ee6,#070e1efa), var(--surface-1);transition:border-color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast);animation:cardIn .36s var(--ease) both;border:1px solid #ffffff1a;gap:12px;padding:clamp(15px,2.1dvh,22px) clamp(16px,2.6vw,26px);display:grid;box-shadow:0 18px 42px #0000003d,inset 0 1px #ffffff0a}.train-card:hover{border-color:var(--border-hi);transform:translateY(-1px);box-shadow:0 22px 52px #00000047,inset 0 1px #ffffff0d}.train-card-board{position:relative;overflow:hidden}.train-card-board:before{content:"";background:linear-gradient(180deg,var(--accent),var(--gold));width:4px;position:absolute;inset:0 auto 0 0}.train-card-board.is-late:before{background:linear-gradient(180deg,var(--warn),var(--accent))}.train-loader-card:before{background:linear-gradient(180deg,var(--ir-blue),var(--accent))}.train-card-main{grid-template-columns:minmax(0,1fr) minmax(128px,160px) minmax(104px,132px);align-items:stretch;gap:14px;display:grid}.train-identity{flex-direction:column;justify-content:center;min-width:0;display:flex}.train-card-top{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.train-badge{color:#ffd8c7;letter-spacing:.08em;background:#e84d0e2e;border:1px solid #e84d0e57;border-radius:8px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:clamp(13px,1.6vw,16px);font-weight:600;display:inline-block}.train-chip{border-radius:var(--radius-full);color:#9fd0ff;letter-spacing:.1em;text-transform:uppercase;background:#1b6db826;border:1px solid #1b6db852;padding:4px 10px;font-size:11px;font-weight:700}.train-name{color:var(--text-1);overflow-wrap:anywhere;margin-top:8px;font-size:clamp(18px,2.4vw,25px);font-weight:700;line-height:1.15}.train-service-line{color:var(--text-2);overflow-wrap:anywhere;margin-top:5px;font-size:13px;font-weight:600}.train-time-board,.platform-board{border-radius:var(--radius-md);background:#04091a9e;border:1px solid #ffffff17;flex-direction:column;justify-content:center;align-items:flex-start;min-height:96px;padding:13px 14px;display:flex}.train-time-board span,.platform-board span{letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);font-size:10px;font-weight:800}.train-time-board strong{color:#f8fafc;letter-spacing:.03em;margin-top:4px;font-family:Rajdhani,sans-serif;font-size:clamp(32px,4.7vw,44px);font-weight:700;line-height:.95}.train-time-board small{color:var(--text-2);letter-spacing:.03em;margin-top:8px;font-size:12px;font-weight:700}.platform-board{text-align:center;background:linear-gradient(#e84d0e29,#e84d0e0f);border-color:#e84d0e47;align-items:center}.platform-board strong{color:#fff;margin-top:2px;font-family:Rajdhani,sans-serif;font-size:clamp(34px,5vw,48px);font-weight:700;line-height:1}.platform-board.is-pending strong{color:var(--warn);font-size:clamp(24px,3.5vw,32px)}.train-route-strip{border-radius:var(--radius-md);background:#0d1c33c7;border:1px dashed #ffffff1c;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:12px;padding:10px 12px;display:grid}.station-end{flex-direction:column;gap:1px;min-width:0;display:flex}.station-end strong{color:#dbeafe;letter-spacing:.05em;overflow-wrap:anywhere;font-family:JetBrains Mono,monospace;font-size:clamp(15px,2vw,18px);font-weight:600}.station-end span{color:var(--text-3);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.station-end-right{text-align:right;align-items:flex-end}.route-arrow{color:var(--gold);font-size:22px;font-weight:700;line-height:1}.train-full-route-hint{color:var(--text-3);text-align:center;letter-spacing:.04em;opacity:.7;padding:2px 0 0;font-size:11px;font-weight:600}.train-detail-row{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.delay-badge{border-radius:var(--radius-full);color:#86efac;white-space:nowrap;background:#18bc6721;border:1px solid #18bc6747;flex:none;padding:5px 12px;font-size:12px;font-weight:800}.delay-badge.is-late{color:#fcd34d;background:#e8a02024;border-color:#e8a02052}.status-line{min-width:0;color:var(--text-2);text-align:right;overflow-wrap:anywhere;font-size:13px;font-weight:600}.train-enrichment-row{flex-wrap:wrap;gap:8px;min-width:0;display:flex}.train-enrichment-row span{border-radius:var(--radius-full);max-width:100%;color:var(--text-2);overflow-wrap:anywhere;background:#1b6db81f;border:1px solid #93c5fd2e;align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.train-enrichment-row strong{color:#bfdbfe;letter-spacing:.12em;text-transform:uppercase;font-size:10px}.train-card-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.train-live-status-btn{border-radius:var(--radius-full);color:#dbeafe;letter-spacing:.02em;min-height:44px;transition:transform var(--t-fast),border-color var(--t-fast),background var(--t-fast),color var(--t-fast);background:linear-gradient(135deg,#1b6db842,#0f766e33);border:1px solid #93c5fd47;padding:0 18px;font-size:13px;font-weight:800;box-shadow:0 10px 24px #0000002e,inset 0 1px #ffffff14}.train-live-status-btn:hover:not(:disabled){color:#fff;background:linear-gradient(135deg,#1b6db861,#0f766e42);border-color:#93c5fd80;transform:translateY(-1px)}.train-live-status-btn:disabled{opacity:.58;cursor:not-allowed}.train-last-updated{color:var(--text-3);letter-spacing:.04em;font-size:11px;font-weight:700}.train-route-map{border-radius:var(--radius-md);background:linear-gradient(135deg,#081426db,#0d1c33b8);border:1px solid #93c5fd24;gap:12px;padding:13px;display:grid}.route-map-head{align-items:flex-start;gap:10px;min-width:0;display:flex}.route-map-head>div{flex-direction:column;gap:2px;min-width:0;display:flex}.route-map-head strong{color:var(--text-1);overflow-wrap:anywhere;font-size:14px;font-weight:800}.route-map-head small{color:var(--text-3);overflow-wrap:anywhere;font-size:12px;font-weight:700}.route-map-progress{border-radius:var(--radius-full);background:#ffffff17;height:8px;position:relative;overflow:visible}.route-map-progress-fill{width:var(--route-progress,0%);border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--gold));position:absolute;inset:0 auto 0 0;box-shadow:0 0 18px #e84d0e3d}.route-map-progress-dot{top:50%;left:var(--route-progress,0%);border:4px solid var(--accent);background:#fff;border-radius:50%;width:16px;height:16px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 18px #e84d0e73}.route-stop-list{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#93c5fd38 transparent;gap:0;max-height:420px;margin:0;padding:0;list-style:none;display:grid;overflow-y:auto}.route-stop-list::-webkit-scrollbar{width:5px}.route-stop-list::-webkit-scrollbar-track{background:0 0}.route-stop-list::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#93c5fd38}.route-stop{grid-template-columns:auto minmax(0,1fr);align-items:stretch;gap:0;padding:0;display:grid;position:relative}.route-stop-track{flex-direction:column;flex-shrink:0;align-items:center;width:28px;padding-top:12px;display:flex}.route-stop.is-current .route-stop-track{padding-top:28px}.route-stop-marker{z-index:1;background:#94a3b88c;border-radius:50%;flex-shrink:0;width:14px;height:14px;box-shadow:0 0 0 4px #94a3b814}.route-stop-line{background:#94a3b838;flex:1;width:2px;margin-top:2px}.route-stop.is-passed .route-stop-marker{background:#60a5fa;box-shadow:0 0 0 4px #60a5fa1f}.route-stop.is-passed .route-stop-line{background:#60a5fa59}.route-stop.is-current .route-stop-marker{background:var(--accent);width:16px;height:16px;animation:1.6s ease-in-out infinite stationPulse;position:relative;box-shadow:0 0 0 5px #e84d0e29,0 0 20px #e84d0e80}.route-stop.is-current .route-stop-marker:after{content:"🚆";filter:drop-shadow(0 0 6px #e84d0e99);font-size:16px;line-height:1;position:absolute;top:-22px;left:50%;transform:translate(-50%)}.route-stop.is-current .route-stop-line{background:#e84d0e40}.route-stop.is-next .route-stop-marker{background:var(--gold);box-shadow:0 0 0 4px #e8a02024}.route-stop-body{border-radius:var(--radius-sm);background:#04091a73;border:1px solid #ffffff12;min-width:0;margin-bottom:4px;padding:8px 10px 12px}.route-stop.is-current .route-stop-body{background:#e84d0e1c;border-color:#e84d0e6b}.route-stop-header{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.route-stop-station{color:#dbeafe;letter-spacing:.05em;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.route-stop-name{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:12px;font-weight:700;overflow:hidden}.route-stop-delay{letter-spacing:.06em;text-transform:uppercase;border-radius:var(--radius-full);white-space:nowrap;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:800}.route-stop-delay.is-ontime{color:#34d399;background:#34d3991f;border:1px solid #34d39938}.route-stop-delay.is-late{color:#fb923c;background:#fb923c1f;border:1px solid #fb923c38}.route-stop-details{flex-wrap:wrap;align-items:center;gap:8px 14px;display:flex}.route-stop-time-pair{align-items:center;gap:4px;display:inline-flex}.route-stop-time-pair small{color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;width:24px;font-size:10px;font-weight:800}.route-stop-sched{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.route-stop-exp{color:var(--text-1);font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700}.route-stop-exp:before{content:"→ ";color:var(--text-3);font-size:10px}.route-stop-pf{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);border-radius:var(--radius-sm);background:#93c5fd14;border:1px solid #93c5fd1f;padding:2px 6px;font-size:10px;font-weight:800}.route-stop-dist{color:var(--text-3);letter-spacing:.04em;font-size:10px;font-weight:700}.route-stop-more{text-align:center;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;background:#ffffff08;border-style:dashed;font-size:11px;font-weight:800;display:block}.train-card-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.train-metric{border-radius:var(--radius-sm);background:var(--surface-2);padding:8px 10px}.train-metric-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);font-size:10px;font-weight:700;display:block}.train-metric-value{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-family:JetBrains Mono,monospace;font-size:clamp(12px,1.5vw,15px);font-weight:600;display:block;overflow:hidden}.train-loading-list{min-height:190px}.train-loader-card{background:linear-gradient(135deg,#0c1f3af5,#070e1efa);overflow:hidden}.loader-board-main{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:18px;min-height:118px;display:grid}.rail-loader{background:radial-gradient(circle,#1b6db842,#1b6db80d 62%,#0000 64%);border:1px solid #93c5fd3d;border-radius:50%;flex:none;place-items:center;width:86px;height:86px;display:grid;position:relative;box-shadow:0 0 32px #1b6db847,inset 0 0 22px #93c5fd14}.rail-loader:before,.rail-loader:after{content:"";border:2px solid #93c5fd;border-color:#93c5fd #e84d0ec7 #0000 #0000;border-radius:50%;animation:1.1s linear infinite loaderSpin;position:absolute;inset:12px}.rail-loader:after{border-top-color:var(--gold);border-right-color:#0000;animation-duration:1.6s;animation-direction:reverse;inset:25px}.rail-loader span{background:#93c5fd;border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite loaderDot;position:absolute;top:50%;left:50%;box-shadow:0 0 16px #93c5fd}.rail-loader span:nth-child(2){margin-left:-18px;animation-delay:.16s}.rail-loader span:nth-child(3){margin-left:18px;animation-delay:.32s}.loader-copy{min-width:0}.loader-copy .train-name{margin-top:10px}.loader-skeleton-grid{grid-template-columns:1.2fr .75fr .55fr;gap:10px;display:grid}.loader-skeleton-grid span{border-radius:var(--radius-sm);background:linear-gradient(90deg,#ffffff0d,#93c5fd29,#ffffff0d) 0 0/220% 100%;border:1px solid #ffffff0f;height:44px;animation:1.35s ease-in-out infinite loaderShimmer}.loader-skeleton-grid span:nth-child(2){animation-delay:.12s}.loader-skeleton-grid span:nth-child(3){animation-delay:.24s}.empty-state{color:var(--text-3);text-align:center;border-radius:var(--radius-lg);border:1px solid var(--border);background:#0a1628b8;align-content:center;place-items:center;gap:16px;padding:clamp(24px,5dvh,52px) 20px;font-size:clamp(14px,1.8vw,17px);font-weight:500;line-height:1.5;display:grid}.empty-state svg{width:56px;height:56px;color:var(--text-3)}.empty-title{letter-spacing:.04em;color:var(--text-1);margin-bottom:8px;font-family:Rajdhani,sans-serif;font-size:clamp(24px,3.5vw,34px);font-weight:700;line-height:1.1}.kiosk-toast{bottom:max(18px,env(safe-area-inset-bottom));z-index:80;border-radius:var(--radius-full);background:var(--surface-2);border:1px solid var(--border-hi);max-width:calc(100vw - 32px);color:var(--text-2);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:nowrap;animation:toastIn .22s var(--ease) both;padding:10px 22px;font-size:13px;font-weight:600;position:fixed;left:50%;transform:translate(-50%)}.admin-backdrop{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#04091ab3;justify-content:flex-end;display:flex;position:fixed;inset:0}.admin-drawer{background:var(--surface-1);border-left:1px solid var(--border-hi);scrollbar-width:thin;scrollbar-color:var(--border-hi) transparent;flex-direction:column;gap:24px;width:min(540px,100vw);height:100dvh;padding:28px 22px 64px;display:flex;overflow-y:auto}.admin-drawer-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.drawer-eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:4px;font-size:10px;font-weight:700}.admin-drawer-header h2{letter-spacing:.04em;color:var(--text-1);font-family:Rajdhani,sans-serif;font-size:clamp(26px,3.5vw,38px);font-weight:700;line-height:1}.drawer-close-btn{border:1px solid var(--border-hi);background:var(--surface-2);width:38px;height:38px;color:var(--text-2);transition:background var(--t-fast),color var(--t-fast);border-radius:50%;flex:none;place-items:center;font-size:17px;display:grid}.drawer-close-btn:hover{background:var(--surface-3);color:var(--text-1)}.admin-section{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:4px;display:flex}.admin-section-label{letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);font-size:10px;font-weight:700}.section-head-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.section-head-row .admin-section-label{margin:0}.admin-action-btn{border-radius:var(--radius-full);border:1px solid var(--border-hi);background:var(--surface-2);height:30px;color:var(--text-2);transition:background var(--t-fast),color var(--t-fast);padding:0 14px;font-size:12px;font-weight:600}.admin-action-btn:hover{background:var(--surface-3);color:var(--text-1)}.mode-row{flex-wrap:wrap;gap:8px;display:flex}.mode-pill{border-radius:var(--radius-full);border:1px solid var(--border-hi);background:var(--surface-2);height:38px;color:var(--text-2);transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);flex:1 0 auto;padding:0 16px;font-size:13px;font-weight:600}.mode-pill.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.mode-pill:not(.active):hover{background:var(--surface-3);color:var(--text-1)}.toggle-row{border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer;color:var(--text-2);align-items:center;gap:10px;padding:10px 12px;font-size:13px;font-weight:600;display:flex}.toggle-row.disabled{opacity:.44;cursor:not-allowed}.toggle-row input{width:16px;height:16px;accent-color:var(--accent)}.readout-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.readout-row{border-radius:var(--radius-sm);background:var(--surface-2);flex-direction:column;gap:2px;padding:8px 10px;display:flex}.readout-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-size:10px;font-weight:700}.readout-value{color:var(--text-1);word-break:break-word;font-size:13px;font-weight:600}.ledger-summary-row{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.ledger-metric{border-radius:var(--radius-sm);background:var(--surface-2);text-align:center;flex-direction:column;align-items:center;gap:2px;padding:9px 6px;display:flex}.ledger-metric span{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-size:9px;font-weight:700}.ledger-metric strong{color:var(--text-1);font-family:JetBrains Mono,monospace;font-size:14px;font-weight:600}.ledger-list{flex-direction:column;gap:5px;display:flex}.ledger-entry{border-radius:var(--radius-sm);background:var(--surface-2);justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;display:flex}.ledger-entry-name{color:var(--text-1);font-size:13px;font-weight:600}.ledger-entry-meta{color:var(--text-3);text-align:right;flex-shrink:0;font-size:11px;font-weight:500}.ledger-empty{color:var(--text-3);text-align:center;padding:10px;font-size:13px}.trace-grid{gap:14px;display:grid}.debug-column h4{letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:7px;font-size:11px;font-weight:700}.debug-row{border-radius:var(--radius-sm);background:#00000080;border:1px solid #ffffff0a;margin-bottom:4px;padding:7px 10px}.debug-row strong{color:#93c5fd;font-size:12px;font-weight:600;display:block}.debug-row span{color:var(--text-3);margin-top:1px;font-size:11px;display:block}.debug-row code{color:#86efac;overflow-wrap:anywhere;white-space:pre-wrap;max-height:56px;margin-top:3px;font-family:JetBrains Mono,monospace;font-size:11px;display:block;overflow:hidden}@keyframes dotPulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes stationPulse{0%,to{transform:scale(1);box-shadow:0 0 0 5px #e84d0e29,0 0 20px #e84d0e80}50%{transform:scale(1.2);box-shadow:0 0 0 10px #e84d0e14,0 0 32px #e84d0eb3}}@keyframes ringPulse{0%,to{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}@keyframes ringRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes resultsIn{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes cardIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalLiftIn{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes loaderSpin{to{transform:rotate(360deg)}}@keyframes loaderDot{0%,to{opacity:.45;transform:translate(-50%,-50%)scale(.85)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.15)}}@keyframes loaderShimmer{0%{background-position:130% 0}to{background-position:-130% 0}}@media (width>=720px){.readout-grid{grid-template-columns:repeat(3,1fr)}.trace-grid{grid-template-columns:1fr 1fr}}@media (width<=480px){:root{--av-hero:clamp(160px,44vw,210px);--av-compact:48px;--gutter:14px}.kiosk-header{gap:8px}.station-header-btn{min-width:42px;height:34px;padding:0 11px;font-size:12px}.station-modal-backdrop{align-items:end;padding:12px}.station-modal{border-radius:24px;max-height:calc(100dvh - 24px);padding:14px;overflow:auto}.station-modal-header h2{font-size:28px}.results-header{flex-direction:column;align-items:flex-start;gap:8px}.results-pill{align-self:flex-start}.train-card{border-radius:20px;padding:14px}.train-card-main{grid-template-columns:1fr;gap:10px}.loader-board-main{text-align:center;grid-template-columns:1fr;justify-items:center}.loader-skeleton-grid{grid-template-columns:1fr;gap:8px}.train-time-board,.platform-board{min-height:auto;padding:12px 13px}.platform-board{text-align:left;align-items:flex-start}.train-route-strip{grid-template-columns:1fr;gap:8px}.route-arrow{display:none}.station-end-right{text-align:left;align-items:flex-start}.train-detail-row{flex-direction:column;align-items:flex-start;gap:8px}.status-line{text-align:left}.train-card-actions{flex-direction:column;align-items:stretch}.train-live-status-btn{width:100%}.route-map-head{flex-direction:column}.route-stop{grid-template-columns:auto minmax(0,1fr);align-items:flex-start}.route-stop-time{text-align:left;grid-column:2;align-items:flex-start}.train-card-grid{grid-template-columns:1fr 1fr}.station-current{flex-direction:column;align-items:flex-start;gap:6px}.station-current-main{flex-direction:column;align-items:flex-start;gap:0}.station-current-source{text-align:left}.station-switch-row{flex-direction:column;align-items:stretch}.station-code-input,.station-action-btn{width:100%}.readout-grid{grid-template-columns:1fr 1fr}.ledger-summary-row{grid-template-columns:repeat(3,1fr)}.admin-drawer{padding:20px 14px 64px}.kiosk-toast{white-space:normal}.status-label{display:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:1ms!important;animation-duration:1ms!important}}
