:root{--bg: #0d1117;--panel: #161b22;--panel-soft: #1f2630;--text: #f3f6fb;--muted: #a9b4c2;--border: #2d3642;--accent: #5ac8a8;--warning: #ffb84d;--danger: #ff6b6b;--info: #63a4ff;--shadow: 0 18px 40px rgba(0, 0, 0, .22);--radius-lg: 20px;--radius-md: 14px;--radius-sm: 10px}*{box-sizing:border-box}html{font-size:16px}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(180deg,#090d12,#0f1720);color:var(--text)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:wait;opacity:.7}button:focus-visible,a:focus-visible{outline:3px solid #ffffff;outline-offset:2px}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin-top:0}.app-shell{min-height:100vh;padding:2rem}.top-nav{display:flex;gap:.75rem;margin-bottom:1.625rem}.nav-link,.line-tab,.station-pill{border:1px solid var(--border);background:#161b22e6;box-shadow:var(--shadow)}.nav-link{padding:.6rem .95rem;border-radius:999px;color:var(--muted)}.nav-link.active,.line-tab.active{color:var(--text);border-color:#63a4ff66;background:#63a4ff1f}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.topbar h1{margin-bottom:.35rem;font-size:clamp(1.9rem,3vw,2.7rem)}.subtitle,.muted,.card-helper{color:var(--muted)}.primary-button,.text-button{border:0;border-radius:999px;transition:transform .2s ease,opacity .2s ease}.primary-button{padding:.9rem 1.25rem;background:var(--accent);color:#08211b;font-weight:700;box-shadow:var(--shadow)}.primary-button:hover,.text-button:hover{transform:translateY(-1px)}.text-button{padding:.45rem .8rem;background:transparent;color:var(--info)}.main-content{display:flex;flex-direction:column;gap:1.25rem;max-width:1440px;margin:0 auto}.alert-banner,.panel,.info-card{background:#161b22e6;border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.alert-banner{border-radius:var(--radius-lg);padding:1rem 1.2rem}.alert-banner.warning{border-left:5px solid var(--warning)}.alert-banner.info{border-left:5px solid var(--info)}.alert-banner.critical,.error-message{border-left:5px solid var(--danger)}.card-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.info-card{border-radius:var(--radius-lg);padding:1.1rem}.card-label{color:var(--muted);font-size:.92rem}.info-card h2{margin:.4rem 0;font-size:1.8rem;line-height:1.1}.card-value-compact{font-size:1.2rem!important;font-weight:600;line-height:1.35;word-break:break-word}.dashboard-grid,.detail-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:1rem}.left-column,.right-column{display:flex;flex-direction:column;gap:1rem}.panel{border-radius:var(--radius-lg);padding:1.1rem}.panel-heading{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.9rem}.panel-heading h2{margin-bottom:0;font-size:1.2rem}.line-list,.demand-list,.connected-route-list{display:grid;gap:.8rem}.line-card,.station-item,.demand-row,.connected-route-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.95rem;background:var(--panel-soft);border:1px solid var(--border);border-radius:var(--radius-md)}.line-badge{width:14px;height:48px;border-radius:999px;flex-shrink:0}.line-dot{display:inline-flex;width:12px;height:12px;border-radius:999px;margin-right:.5rem}.line-yellow{background:#f2c230}.line-green{background:#00c97d}.line-purple{background:#8f0024}.line-orange{background:#ff9350}.status-chip{display:inline-flex;align-items:center;justify-content:center;min-width:84px;padding:.45rem .75rem;border-radius:999px;font-size:.85rem;font-weight:700;border:1px solid transparent}.status-chip.normal,.status-chip.low{background:#5ac8a81f;color:#7df0cd;border-color:#5ac8a84d}.status-chip.delayed,.status-chip.medium{background:#ffb84d24;color:#ffd089;border-color:#ffb84d4d}.status-chip.high,.status-chip.planned,.status-chip.disrupted{background:#ff6b6b24;color:#ffadad;border-color:#ff6b6b40}.station-list{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}.station-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;color:var(--muted);text-align:right}.arrival-label{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .55rem;border-radius:999px;border:1px solid rgba(99,164,255,.35);background:#63a4ff1f;color:#b7d3ff;font-size:.78rem}.line-selector{display:flex;flex-wrap:wrap;gap:.75rem}.line-tab{display:inline-flex;align-items:center;padding:.7rem 1rem;border-radius:999px;color:var(--muted)}.vertical-line-grid{display:grid;gap:1.25rem;align-items:start;justify-content:center}.two-column-line-grid{position:relative;grid-template-columns:repeat(2,minmax(320px,560px))}.two-column-line-grid:before{content:"";position:absolute;top:1rem;bottom:1rem;left:50%;width:1px;background:linear-gradient(to bottom,transparent,rgba(169,180,194,.2),transparent);transform:translate(-50%);pointer-events:none}.single-column-line-grid{grid-template-columns:minmax(320px,620px)}.vertical-line-column{--rail-width: 10px;--node-column-width: 3rem;--rail-center: calc(var(--node-column-width) / 2);position:relative;border:1px solid var(--border);border-radius:var(--radius-lg);background:#10161eeb;padding:1.1rem 1.05rem 1rem;min-width:0}.vertical-line-rail{position:absolute;left:calc(1rem + var(--rail-center) - (var(--rail-width) / 2));width:var(--rail-width);border-radius:999px;top:2.1rem;bottom:2.1rem}.vertical-line-rail.show-top{top:.85rem}.vertical-line-rail.show-bottom{bottom:.85rem}.vertical-line-stations{display:grid;gap:.45rem}.vertical-line-stop{position:relative;display:grid;grid-template-columns:var(--node-column-width) 1fr;gap:.9rem;align-items:center;min-height:2.95rem;border-radius:var(--radius-md);padding:.12rem 0}.vertical-line-stop.is-disabled{opacity:.72}.vertical-line-node-wrap{display:flex;justify-content:center;align-items:center;z-index:1}.vertical-line-node{width:18px;height:18px;border-radius:999px;background:#fff;border:3px solid currentColor;box-shadow:0 0 0 1px #0000002e;color:inherit}.vertical-line-node.line-yellow{color:#f2c230}.vertical-line-node.line-green{color:#00c97d}.vertical-line-node.line-purple{color:#8f0024}.vertical-line-node.line-orange{color:#ff9350}.vertical-line-node.interchange{box-shadow:0 0 0 2px #fff,0 0 0 3px #0000002e}.vertical-line-node.terminal{width:40px;height:40px;background:currentColor;border:4px solid #ffffff;box-shadow:0 0 0 1px #0000002e}.vertical-line-node.terminal.interchange{box-shadow:0 0 0 1px #0000002e}.vertical-line-copy{display:flex;flex-direction:column;gap:.14rem}.vertical-line-name{font-size:1.08rem;font-weight:700;line-height:1.15;color:var(--text)}.vertical-line-name.terminal{font-size:1.34rem;font-weight:800}.vertical-line-meta{color:var(--muted);font-size:.8rem;line-height:1.15}.vertical-line-column.line-one-return-column .vertical-line-rail{top:1.55rem;bottom:1.5rem}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.8rem .7rem;text-align:left;border-bottom:1px solid var(--border)}th{color:var(--muted);font-size:.92rem;font-weight:600}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 1024px){.card-grid,.dashboard-grid,.detail-grid,.two-column-line-grid,.analytics-grid,.analytics-summary-grid{grid-template-columns:1fr}.two-column-line-grid:before{display:none}}@media (max-width: 768px){.app-shell{padding:1rem}.topbar,.panel-heading,.station-item,.demand-row,.line-card,.connected-route-item{flex-direction:column;align-items:flex-start}.card-grid,.dashboard-grid,.detail-grid,.two-column-line-grid,.single-column-line-grid,.analytics-grid,.analytics-summary-grid{grid-template-columns:1fr}.analytics-delay-row{flex-direction:column;align-items:flex-start}.station-meta{align-items:flex-start;text-align:left}.primary-button{width:100%}}.analytics-panel{display:grid;gap:1rem}.analytics-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:1rem}.analytics-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem}.analytics-card,.analytics-delay-panel{border:1px solid var(--border);background:var(--panel-soft);border-radius:var(--radius-md);padding:1rem}.analytics-card h3,.analytics-delay-panel h3{margin:.35rem 0 .4rem;font-size:1.35rem}.analytics-delay-list{display:grid;gap:.75rem}.analytics-delay-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 0;border-bottom:1px solid var(--border)}.analytics-delay-row:last-child{border-bottom:0;padding-bottom:0}
