:root{--bg:#050b0d;--bg-soft:#081417;--panel:#071114c7;--panel-strong:#081316f0;--text:#f5fbfc;--muted:#aab7ba;--faint:#607176;--line:#c2f4fa24;--line-soft:#c2f4fa12;--cyan:#56dce8;--amber:#f1b646;--violet:#9b86ff}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}.page-shell{background:linear-gradient(90deg,#56dce805 1px,#0000 1px) 0 0/92px 92px,linear-gradient(#56dce806 1px,#0000 1px) 0 0/92px 92px,radial-gradient(circle at 72% 30%,#56dce814,#0000 30%) 0 0/100% 100%,linear-gradient(#050b0d 0%,#071113 58%,#050b0d 100%) 0 0/100% 100%;min-height:100vh;position:relative;overflow:hidden}.page-shell:before{content:"";pointer-events:none;opacity:.72;background-image:linear-gradient(42deg,#0000 0 34%,#56dce829 34.1% 34.3%,#0000 34.4% 100%),linear-gradient(138deg,#0000 0 58%,#f1b6461f 58.1% 58.28%,#0000 58.38% 100%),linear-gradient(90deg,#0000 0 62%,#56dce81f 62.05% 62.2%,#0000 62.35% 100%);height:580px;position:absolute;inset:96px 0 auto;-webkit-mask-image:linear-gradient(#0000,#000 20% 76%,#0000);mask-image:linear-gradient(#0000,#000 20% 76%,#0000)}.site-header{z-index:3;border-bottom:1px solid var(--line-soft);grid-template-columns:1fr auto 1fr;align-items:center;width:min(1196px,100% - 120px);height:70px;margin:0 auto;display:grid;position:relative}.brand,.nav-links,.board-heading,.departure-row,.feature-row{align-items:center;display:flex}.brand{letter-spacing:0;gap:13px;width:max-content;font-size:17px;font-weight:760}.brand-mark{border-radius:8px;flex:0 0 32px;width:32px;height:32px;display:block}.nav-links{color:var(--muted);gap:42px;font-size:16px;font-weight:500}.nav-links a{transition:color .18s}.nav-links a:hover{color:var(--text)}.hero{z-index:2;width:min(1196px,100% - 120px);min-height:calc(100vh - 70px);margin:0 auto;padding:0 0 82px;position:relative}.hero-copy{z-index:1;width:min(620px,100%);padding-top:318px;position:relative}.hero h1{letter-spacing:0;margin:0;font-size:clamp(66px,12vw,156px);line-height:.88}.hero-copy p{color:#cfe0e4;max-width:600px;margin:24px 0 0;font-size:clamp(30px,2.85vw,38px);font-weight:760;line-height:1.08}.app-preview{z-index:2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#091316b8,#040a0ce0);border:1px solid #c2f4fa2b;border-radius:26px;width:580px;min-width:0;max-width:100%;min-height:620px;padding:0;position:absolute;top:166px;right:0;overflow:hidden;box-shadow:0 28px 90px #0000006b}.preview-map{border-radius:inherit;background:#081519;border:0;height:100%;position:absolute;inset:0;overflow:hidden}.map-chip{z-index:3;color:#dffaff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#071216c7;border:1px solid #c2f4fa2e;border-radius:999px;padding:10px 14px;font-size:14px;font-weight:760;position:absolute;top:28px;left:28px;box-shadow:0 12px 28px #00000042}.city-map{width:100%;height:100%;position:absolute;inset:0}.map-ground{fill:url(#mapGround)}.map-grid{fill:url(#mapGrid);opacity:.28}.map-grid-line{fill:none;stroke:#c2f4fa33;stroke-width:1px}.map-water{fill:#0b3440;opacity:.92}.map-park{fill:#183f34;opacity:.88}.map-park.small{fill:#14382e}.map-park.pocket{fill:#12342e;opacity:.74}.map-blocks rect{fill:#c2f4fa0e;stroke:#c2f4fa1a;stroke-width:1px;filter:url(#mapShadow)}.map-roads .road{fill:none;stroke-linecap:round;stroke-linejoin:round}.road-primary{stroke:#213b43;stroke-width:24px}.road-casing{stroke:#02080ad1;stroke-width:34px}.road-primary-soft{stroke:#1a333a;stroke-width:20px}.road-secondary{stroke:#2a4850d1;stroke-width:12px}.road-local{stroke:#c2f4fa1f;stroke-width:6px}.route-line{fill:none;stroke-width:6px;stroke-linecap:round;stroke-linejoin:round}.route-line-cyan{stroke:var(--cyan);filter:url(#routeGlow)}.route-line-amber{stroke:var(--amber);filter:drop-shadow(0 0 7px #f1b64640)}.route-line-violet{stroke:var(--violet);filter:drop-shadow(0 0 7px #9b86ff42)}.stop-halo{fill:#081519;stroke:#dffaffb8;stroke-width:4px}.stop-dot{fill:var(--cyan)}.stop-halo.amber{stroke:#f1b646bd}.stop-dot.amber{fill:var(--amber)}.route-badge rect{stroke:#ffffffc7;stroke-width:3px;filter:drop-shadow(0 9px 15px #00000052)}.route-badge text{fill:#06262d;text-anchor:middle;dominant-baseline:middle;font-size:15px;font-weight:800}.route-4 rect{fill:#56dce8}.route-13 rect{fill:#f1b646}.route-58 rect{fill:#9b86ff}.route-58 text{fill:#fff}.map-labels text{fill:#dffaff8a;letter-spacing:0;font-size:13px;font-weight:700}.departure-board{z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#040a0cd4;border:1px solid #c2f4fa21;border-radius:24px;min-width:0;padding:31px 18px 18px;position:absolute;bottom:20px;left:20px;right:20px;overflow:hidden}.drawer-handle{background:#c2f4fa45;border-radius:999px;width:44px;height:4px;position:absolute;top:14px;left:50%;transform:translate(-50%)}.board-heading{min-height:auto;color:var(--muted);border-bottom:0;justify-content:space-between;padding:0 0 13px;font-size:13px;font-weight:760}.board-heading strong{color:var(--cyan);font-size:14px}.departure-list{gap:8px;display:grid}.departure-row{background:#c2f4fa0b;border:1px solid #c2f4fa1a;border-radius:9px;gap:12px;min-height:52px;padding:8px 10px;position:relative}.departure-row:last-child{border-bottom:1px solid #c2f4fa1a}.line-badge{color:#050b0d;border-radius:8px;flex:0 0 42px;place-items:center;width:42px;height:32px;font-size:14px;font-weight:760;display:grid}.line-badge.cyan{background:var(--cyan)}.line-badge.amber{background:var(--amber)}.line-badge.violet{background:var(--violet);color:#050b0d}.timeline-node{display:none}.departure-row:not(:last-child) .timeline-node:after{content:"";background:#56dce857;width:1px;height:70px;position:absolute;top:11px;left:50%;transform:translate(-50%)}.departure-row:nth-child(2) .timeline-node{border-color:var(--amber)}.departure-row:nth-child(3) .timeline-node{border-color:var(--violet)}.departure-stop{flex:1;gap:3px;min-width:0;display:grid}.departure-stop strong{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:620;overflow:hidden}.departure-stop span{display:none}.departure-eta{min-width:70px;color:var(--text);text-align:right;font-size:18px;font-weight:760}.feature-strip{z-index:2;border-top:1px solid var(--line-soft);grid-template-columns:minmax(220px,.55fr) minmax(0,1.45fr);gap:56px;width:min(1240px,100% - 48px);margin:0 auto;padding:44px 0 92px;display:grid;position:relative}.feature-strip h2{color:var(--text);margin:0;font-size:clamp(24px,3vw,36px);font-weight:640;line-height:1.08}.feature-list{border-top:1px solid var(--line-soft);display:grid}.feature-row{border-bottom:1px solid var(--line-soft);grid-template-columns:56px minmax(170px,.42fr) minmax(0,1fr);gap:28px;min-height:104px;padding:26px 0;display:grid}.feature-index{color:var(--cyan);font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:14px}.feature-row h3{margin:0;font-size:22px;font-weight:640}.feature-row p{max-width:480px;color:var(--muted);margin:0;font-size:18px;line-height:1.42}@media (max-width:980px){.site-header{grid-template-columns:1fr auto}.nav-links{justify-self:end;gap:24px}.hero{grid-template-columns:minmax(0,1fr);min-height:auto;padding-top:72px;display:grid}.hero-copy{width:100%;padding-top:0}.app-preview{width:100%;min-height:560px;position:relative;top:auto;right:auto}.feature-strip{grid-template-columns:minmax(0,1fr);gap:30px}}@media (max-width:620px){.site-header,.hero,.feature-strip{width:min(100% - 28px,1240px)}.site-header{height:82px}.brand{gap:10px;font-size:18px}.brand-mark{width:32px;height:32px}.nav-links{display:none}.hero{padding:52px 0 62px}.hero h1{font-size:clamp(54px,16vw,76px)}.hero-copy p{max-width:330px;margin-top:24px;font-size:24px}.app-preview{border-radius:12px;min-height:520px;padding:0}.preview-map{height:100%}.map-chip{font-size:13px;top:10px;left:10px}.board-heading{min-height:48px;padding:0 12px;font-size:14px}.departure-row{grid-template-columns:42px minmax(0,1fr);gap:9px 12px;min-height:72px;padding:12px;display:grid}.line-badge{flex-basis:42px;width:42px;height:38px;font-size:18px}.timeline-node{display:none}.departure-stop strong{font-size:17px}.departure-stop span{font-size:13px}.departure-eta{min-width:0;color:var(--cyan);text-align:left;grid-column:2;font-size:16px}.feature-row{grid-template-columns:42px 1fr;gap:12px 18px}.feature-row p{grid-column:2;font-size:16px}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{transition-duration:.01ms!important}}
