:root{--route-bg:#e8f5ef;--route-ink:#10221c;--route-red:#d71920;--route-sky:#6cabdd;--route-muted:#60756d;--route-line:rgba(16,34,28,.15);--route-dark:#10221c}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:linear-gradient(180deg,#e8f5ef,#f7fbf9);color:var(--route-ink);font-family:"Segoe UI",Arial,sans-serif;line-height:1.7}
a{color:#b51d24;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.route-map{width:min(1180px,calc(100% - 32px));margin:0 auto}
.route-stationtop{padding:17px 0;border-bottom:1px solid var(--route-line);background:rgba(232,245,239,.94);position:sticky;top:0;z-index:20}
.route-stationline{display:grid;grid-template-columns:250px 1fr;gap:20px;align-items:center}
.route-logo{display:flex;gap:12px;align-items:center;color:var(--route-ink);font-weight:900}
.route-dot{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(180deg,var(--route-red) 0 50%,var(--route-sky) 50%);color:#fff}
.route-logo small{display:block;color:var(--route-muted);font-size:12px}
.route-nav{display:flex;justify-content:flex-end;gap:9px;flex-wrap:wrap}
.route-nav a{color:var(--route-ink);background:#fff;border:1px solid var(--route-line);padding:8px 12px;border-radius:999px}
.route-hero{padding:42px 0}
.route-hero-grid{display:grid;grid-template-columns:1fr 420px;gap:30px}
.route-board{background:#fff;border:1px solid var(--route-line);border-radius:34px;padding:36px;box-shadow:0 22px 60px rgba(16,34,28,.11)}
.route-tag{display:inline-flex;padding:8px 12px;border-radius:999px;background:#fff0f0;color:var(--route-red);font-size:12px;font-weight:900;text-transform:uppercase}
h1,h2,h3{line-height:1.12;margin:0 0 16px}
h1{font-size:clamp(40px,6vw,76px)}
.route-lead{font-size:20px;color:#41584f;margin:0 0 16px}
.route-photo{border-radius:34px;overflow:hidden;background:#111}
.route-photo img{width:100%;min-height:430px;object-fit:cover}
.route-cap{padding:11px 13px;background:#10221c;color:#e9fff4;font-size:13px}
.route-subway{padding:30px 0;background:#10221c;color:#fff}
.route-grid{display:grid;grid-template-columns:1fr 80px 1fr 80px 1fr;gap:14px;align-items:center}
.route-station{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:20px}
.route-transfer{text-align:center;font-size:34px;color:#ffd166;font-weight:900}
.route-red{color:#ff7b80}
.route-blue{color:#9ed2ff}
.route-section{padding:50px 0}
.route-layout{display:grid;grid-template-columns:300px 1fr;gap:32px}
.route-side{position:sticky;top:90px;background:#fff;border:1px solid var(--route-line);border-radius:28px;padding:24px}
.route-side img{border-radius:20px}
.route-copy p{font-size:18px;color:#354c43}
.route-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:24px 0}
.route-card{background:#fff;border:1px solid var(--route-line);border-radius:22px;padding:22px}
.route-card span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--route-sky);color:#fff;font-weight:900}
.route-final{padding:24px;border-left:8px solid var(--route-red);background:#fff0f0;border-radius:22px;font-size:20px}
.route-footer{padding:24px 0;border-top:1px solid var(--route-line);color:var(--route-muted)}
@media(max-width:900px){.route-stationline,.route-hero-grid,.route-grid,.route-layout,.route-cards{grid-template-columns:1fr}.route-nav{justify-content:flex-start}.route-transfer{text-align:left}.route-side{position:static}.route-photo img{min-height:280px}}
