:root{color-scheme:light;--bg: #f5f6fc;--bg-alt: #edf1fb;--ink: #1b1e2d;--muted: #636f7e;--accent-purple: #9ec78a;--accent-green: #9fd68a;--accent: #b3dca0;--accent-strong: #9ccb87;--accent-mix-soft: linear-gradient(135deg, rgba(158, 199, 138, .16), rgba(159, 214, 138, .16));--accent-mix-soft-strong: linear-gradient(135deg, rgba(158, 199, 138, .24), rgba(159, 214, 138, .24));--accent-gradient: linear-gradient(135deg, var(--accent-purple), var(--accent-green));--teal: #2f9188;--teal-dark: #2f5f7b;--card: #ffffff;--shadow: 0 18px 40px rgba(24, 19, 54, .14);--radius: 20px;--mono: "JetBrains Mono", "SFMono-Regular", Menlo, monospace;--display: "Noto Serif KR", serif;--sans: "Pretendard Variable", "SUIT", "Apple SD Gothic Neo", sans-serif;--scrollbar-size: 8px;--scrollbar-thumb: rgba(151, 204, 127, .34);--scrollbar-thumb-strong: rgba(151, 204, 127, .48);--scrollbar-track: transparent;--select-arrow: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%23b3dca0' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");--app-bg-solid: #f5f6fc;--app-bg: radial-gradient(920px 500px at 8% -14%, rgba(186, 228, 176, .25), transparent 62%), radial-gradient(760px 420px at 108% -2%, rgba(216, 237, 186, .18), transparent 56%), radial-gradient(700px 430px at 20% 104%, rgba(204, 236, 198, .24), transparent 64%), conic-gradient(from 212deg at 72% 12%, rgba(163, 208, 144, .11), rgba(143, 208, 201, .08), rgba(164, 214, 147, .14), rgba(163, 208, 144, .11)), linear-gradient(180deg, rgba(242, 249, 238, .93) 0%, rgba(242, 248, 240, .93) 46%, rgba(246, 251, 244, .93) 100%), repeating-linear-gradient(135deg, rgba(255, 255, 255, .2) 0 2px, rgba(255, 255, 255, 0) 2px 10px), var(--bg);--chrome-top: #e9ecff}*{box-sizing:border-box}button,input,select,textarea{font-family:var(--sans);font-size:inherit;line-height:inherit}.is-hidden{display:none!important}html{scrollbar-gutter:stable;position:relative;background:var(--app-bg);background-attachment:scroll;background-repeat:no-repeat;background-color:var(--app-bg-solid);overscroll-behavior:none;min-height:100%;padding-bottom:0}html:before{content:none}html.theme-night{background:transparent;background-color:var(--app-bg-solid);--chrome-top: #05070f;--app-bg-solid: #141b3f;--scrollbar-thumb: rgba(246, 226, 138, .35);--scrollbar-thumb-strong: rgba(246, 226, 138, .55)}html:after{content:"";position:fixed;top:0;left:0;right:0;height:1px;background:var(--chrome-top);z-index:3;pointer-events:none}body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--app-bg);background-attachment:scroll;background-repeat:no-repeat;background-color:var(--app-bg-solid);min-height:100dvh;padding-bottom:0;overscroll-behavior:none}body:before{content:none}@media (max-width: 1024px){body:before{content:none}}body.theme-night{color:#eef1ff;--muted: rgba(238, 241, 255, .92);--ink: #eef1ff;--select-arrow: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'><path d='M1 1l6 6 6-6' fill='none' stroke='%23ffffff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");--app-bg: var(--night-sky, linear-gradient(180deg, #05070f 0%, #0b1026 55%, #141b3f 100%));--chrome-top: #05070f;animation:none;background:var(--app-bg);background-attachment:scroll;background-repeat:no-repeat;background-color:var(--app-bg-solid)}@keyframes nightSkyTwinkle{0%{filter:brightness(1)}50%{filter:brightness(1.03)}to{filter:brightness(1)}}body.theme-night .hero-card,body.theme-night .next-card,body.theme-night .notice-card,body.theme-night .route-card,body.theme-night .time-table{background:var(--card-glow-1, radial-gradient(420px 200px at -10% -20%, rgba(246, 226, 138, .08), transparent 64%)),var(--card-glow-2, radial-gradient(340px 220px at 115% 10%, rgba(96, 169, 255, .1), transparent 62%)),var(--card-glow-3, radial-gradient(300px 220px at 20% 120%, rgba(125, 214, 255, .08), transparent 64%)),linear-gradient(135deg,#ffffff0f,#ffffff04),#121838c7;color:#eef1ff;box-shadow:0 18px 40px #080a1a73}body.theme-night nav.primary-nav a{color:#eef1ff;background:#ffffff0d}body.theme-night .favorite-tab{background:#ffffff1f;color:#f6e28a}body.theme-night .favorite-tab.is-active{background:#f6e28a4d;color:#f6e28a;box-shadow:0 12px 24px #0608188c}body.theme-night .favorite-dock__handle,body.theme-night .favorite-dock__panel{background:#080a18f0;color:#eef1ff;box-shadow:0 18px 40px #0608188c;border-color:#f6e28a2e}body.theme-night .favorite-dock__item{background:#ffffff14}body.theme-night .favorite-dock__empty{background:#ffffff14;color:#eef1ffcc}body.theme-night .favorite-dock__times span{background:#f6e28a33;color:#f6e28a}body.theme-night .theme-toggle,body.theme-night .locale-toggle{background:#ffffff1f;color:#f6e28a;box-shadow:0 10px 24px #0508168c}body.theme-night .theme-toggle .icon-sun{display:none}body.theme-night .theme-toggle .icon-moon{display:inline-block}body.theme-night .stop-pill,body.theme-night .destination-pill,body.theme-night .campus-pill,body.theme-night .favorite-chip{background-color:#ffffff14;color:#eef1ff;border-color:#ffffff26}body.theme-night .stop-pills,body.theme-night .stop-pill,body.theme-night .destination-pill,body.theme-night .campus-pill,body.theme-night .favorite-chip{background-image:none!important}body.theme-night select{background-color:#ffffff14;background-image:var(--select-arrow);background-repeat:no-repeat;background-position:right 14px center;background-size:14px 9px;color-scheme:dark}body.theme-night select option{background:#0c1330;color:#eef1ff}body.theme-night .action-button{background:#f6e28a;color:#1c2346}body.theme-night .action-button.is-disabled,body.theme-night .action-button:disabled,body.theme-night .action-button[data-disabled=true],body.theme-night .action-button[aria-disabled=true]{background:#ffffff0f;color:#eef1ff8c;filter:saturate(.25);border:1px dashed rgba(246,226,138,.3)}body.theme-night .action-button--ghost{background:#ffffff1f;color:#f6e28a}body.theme-night .swap-button{background:#f6e28a33;color:#f6e28a}body.theme-night .campus-pill.is-disabled{background:#ffffff1f;color:#eef1ff80}body.theme-night .campus-pill.is-active{background:#f6e28a;color:#1c2346;border-color:#f6e28ae6;box-shadow:0 8px 16px #0a0c1c59}body.theme-night .next-badge{background:#f6e28a33;color:#f6e28a}body.theme-night .next-chip{background:#ffffff1a;color:#eef1ff;box-shadow:0 6px 14px #080a1a59}body.theme-night .next-chip .last-tag{background:#f6e28a33;color:#f6e28a}body.theme-night .hero-badge,body.theme-night .weekday-pill{background:#f6e28a2e;color:#f6e28a}body.theme-night .weekday-pill--day{background:#f6e28a38;color:#f6e28a}body.theme-night .section-title{color:#eef1ff}body.theme-night .route-note{background:#3b79d140;color:#d8e1ff}body.theme-night .time-row{background:#ffffff14}body.theme-night .muted,body.theme-night .next-note,body.theme-night .notice-card p,body.theme-night .notice-date,body.theme-night .footer,body.theme-night .pill-sub{color:#eef1ffd1}body.theme-night .next-empty{background:#ffffff14;color:#eef1ffcc;border-color:#f6e28a33}body.theme-night [data-date],body.theme-night [data-weekday],body.theme-night [data-route-subtitle],body.theme-night .campus-label{color:#f8fafffa;text-shadow:0 0 6px rgba(255,255,255,.35),0 0 14px rgba(86,140,255,.25)}body.theme-night .weekday-pill--day[data-weekday]{color:#f6e28a;text-shadow:none}body.theme-night .notice-empty{color:#eef1ffd1;background:#ffffff14}.page{display:flex;flex-direction:column;min-height:100dvh}header.navbar{padding:24px clamp(20px,5vw,60px);display:flex;align-items:center;justify-content:space-between;gap:20px}header.navbar.is-wrapped{flex-direction:column;align-items:flex-start}header.navbar.is-wrapped nav.primary-nav{width:100%;flex-wrap:wrap;gap:8px;margin-left:0}header.navbar.is-wrapped nav.primary-nav a{flex:1 1 0;text-align:center}header.navbar.is-wrapped .nav-links{width:100%;order:1;flex-wrap:nowrap;gap:4px}header.navbar.is-wrapped .nav-actions{width:100%;order:2;justify-content:flex-end;gap:4px;margin-top:0}header.navbar.is-wrapped .favorite-tab{flex:1 1 auto}header.navbar.is-wrapped .theme-toggle{flex:0 0 38px;width:38px;height:38px}header.navbar.is-wrapped .locale-toggle{flex:0 0 auto}.brand{display:flex;align-items:center;gap:14px;font-weight:600;letter-spacing:.02em;flex-shrink:0}.brand strong{white-space:nowrap}.brand img{width:42px;height:42px}.muted{color:var(--muted);font-size:.9rem;display:flex;gap:6px;flex-wrap:nowrap;white-space:nowrap;flex-shrink:0}[data-clock],[data-clock-card]{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.muted [data-clock]{display:inline-block;min-width:8ch;text-align:right}nav.primary-nav{display:flex;gap:16px;font-size:.95rem;align-items:center;flex-wrap:nowrap;min-width:0;flex:0 0 auto;margin-left:auto;justify-content:flex-end}nav.primary-nav a{color:var(--ink);text-decoration:none;padding:8px 14px;border-radius:999px;background:#fff9;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;white-space:nowrap;word-break:keep-all}nav.primary-nav a:hover{transform:translateY(-1px);box-shadow:0 8px 18px #18133629}.nav-links{display:flex;gap:16px;align-items:center;flex:0 0 auto;flex-wrap:nowrap;min-width:0}.nav-actions{display:flex;gap:16px;align-items:center;flex:0 0 auto;flex-wrap:nowrap}.favorite-tab{border:none;background:#b3dca029;color:#24385a;padding:8px 14px;border-radius:999px;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;white-space:nowrap;word-break:keep-all}.favorite-tab.is-active{background:var(--accent);color:#fff;box-shadow:0 12px 24px #18133633}.favorite-tab:hover{transform:translateY(-1px);box-shadow:0 8px 18px #18133629}body:not(.theme-night) nav.primary-nav a,body:not(.theme-night) .favorite-tab,body:not(.theme-night) .theme-toggle,body:not(.theme-night) .locale-toggle,body:not(.theme-night) .day-toggle button,body:not(.theme-night) .action-button--ghost,body:not(.theme-night) .search-chip,body:not(.theme-night) .dropdown__recent-chip,body:not(.theme-night) .notice-ticker,body:not(.theme-night) .weekday-pill,body:not(.theme-night) .weekday-pill--day{background:#8aca7229;color:#274236;border-color:#7eb76557}body:not(.theme-night) .favorite-tab.is-active,body:not(.theme-night) .day-toggle button.is-active,body:not(.theme-night) .action-button,body:not(.theme-night) .stop-pill.is-active,body:not(.theme-night) .destination-pill.is-active,body:not(.theme-night) .campus-pill.is-active,body:not(.theme-night) .hero-badge.is-weekday,body:not(.theme-night) .hero-badge.is-daily,body:not(.theme-night) .next-chip.next-chip--more{background:var(--accent);color:#1f2f1d;border-color:transparent}.favorite-dock{position:fixed;top:64px;right:clamp(20px,5vw,60px);left:auto;z-index:5;display:flex;flex-direction:column;gap:10px}.favorite-dock__handle{display:none}.favorite-dock__panel{display:none;background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);min-width:min(420px,80vw);border:1px solid rgba(179,220,160,.15);color:#24385a}.favorite-dock__empty{padding:16px;border-radius:12px;background:#1813360a;color:#24385a;font-weight:600;text-align:center;min-height:84px;display:flex;align-items:center;justify-content:center;font-size:.95rem;border:1px dashed rgba(179,220,160,.35)}.favorite-dock.is-open .favorite-dock__panel{display:block}.favorite-dock__item{display:grid;gap:8px;padding:10px 12px;border-radius:12px;background:#1813360a;margin-bottom:10px}.favorite-dock__item[data-jump-route]{cursor:pointer}.favorite-dock__item:last-child{margin-bottom:0}.favorite-dock__title{display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:600}.favorite-dock__times{display:flex;gap:8px;flex-wrap:wrap;min-height:26px;align-items:center}.favorite-dock__times span{background:#b3dca01f;padding:4px 10px;border-radius:999px;font-weight:600;display:inline-flex;align-items:center;gap:6px;height:26px}.favorite-dock__times .last-tag{font-style:normal;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:999px;background:#b3dca029;color:#2f4f86}body.theme-night .favorite-dock__times .last-tag{background:#f6e28a33;color:#f6e28a}.favorite-dock__times span.favorite-dock__empty-text{color:var(--muted);font-weight:600;padding:0!important;background:transparent!important;box-shadow:none!important;border-radius:0!important;height:26px;line-height:26px}.favorite-dock__times span.favorite-dock__more{color:#2f4b83;font-weight:700;padding:4px 10px!important;border-radius:999px!important;background:linear-gradient(135deg,#b3dca047,#b3dca02e);border:1px solid rgba(179,220,160,.45);box-shadow:inset 0 0 0 1px #ffffff59,0 4px 10px #1813361a}body.theme-night .favorite-dock__times span.favorite-dock__empty-text{color:#eef1ffc7}body.theme-night .favorite-dock__times span.favorite-dock__more{color:#f6e28a;background:linear-gradient(135deg,#f6e28a47,#f6e28a2e)!important;border-color:#f6e28a80;box-shadow:inset 0 0 0 1px #f6e28a38,0 4px 10px #00000047}body:not(.theme-night) .favorite-dock__times span.favorite-dock__more{background:var(--accent)!important;color:#1f2f1d!important;border:1px solid transparent!important;box-shadow:inset 0 0 0 1px #ffffff59,0 6px 14px #1813361a!important}.favorite-dock__row{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.favorite-dock__actions{display:inline-flex;align-items:center;gap:6px}.favorite-dock__move{border:none;background:transparent;color:transparent;padding:0;border-radius:10px;font-size:0;font-weight:700;cursor:pointer;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center}.favorite-dock__move:disabled{opacity:.35;cursor:default}.favorite-dock__move:before{content:"";width:14px;height:10px;background-image:var(--select-arrow);background-repeat:no-repeat;background-position:center;background-size:contain;display:block;opacity:.9}.favorite-dock__move:not(:disabled):before{opacity:1;background-image:none;background-color:var(--ink);-webkit-mask-image:var(--select-arrow);mask-image:var(--select-arrow);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain}.favorite-dock__move[data-move-favorite=up]:before{transform:rotate(180deg)}.favorite-dock__remove{border:none;background:#b3dca01f;color:#24385a;padding:4px 10px;border-radius:999px;font-size:.72rem;cursor:pointer;white-space:nowrap}body.theme-night .favorite-dock__remove{background:#ffffff1f;color:#f6e28a}body.theme-night .favorite-dock__move{background:transparent;color:transparent}body.theme-night .favorite-dock__move:not(:disabled):before{background-color:#f6e28a;-webkit-mask-image:var(--select-arrow);mask-image:var(--select-arrow);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain}.theme-toggle{border:none;background:#b3dca029;color:#24385a;width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.locale-toggle{border:none;background:#b3dca029;color:#24385a;height:38px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-weight:700;letter-spacing:.02em;transition:transform .2s ease,box-shadow .2s ease}.locale-toggle:hover,.theme-toggle:hover{transform:translateY(-1px);box-shadow:0 8px 18px #18133629}.theme-toggle svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.theme-toggle .icon-sun{display:inline-block}.theme-toggle .icon-moon{display:none}main{flex:1;padding:0 clamp(20px,5vw,60px) 60px}.route-layout{max-width:100%}.route-side,.route-main{min-width:0}.route-info-card select,.next-card,.hero-card,.route-note,.time-table{max-width:100%}.hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin-bottom:32px}.hero-card{background:var(--card);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}.route-info-card{overflow:visible;position:relative;z-index:3}.route-info-card .selector{position:relative;z-index:2}.route-layout,.route-side{overflow:visible}.route-info-card .dropdown__list{z-index:30}.hero>.hero-card:first-child h1{font-family:var(--sans)}body:not(.theme-night) .hero-card,body:not(.theme-night) .next-card,body:not(.theme-night) .notice-card,body:not(.theme-night) .route-card{background-image:linear-gradient(135deg,#ffffffbf,#fff0 58%),linear-gradient(0deg,#b3dca014,#b3dca000)}.hero-card h1{font-family:var(--display);font-size:clamp(1.8rem,3vw,2.6rem);margin:0 0 12px}.hero-card p{margin:0;color:var(--muted)}.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#b3dca01f;color:var(--teal-dark);padding:6px 12px;border-radius:999px;font-size:.85rem;margin-top:16px}.weekday-pill{font-size:.85rem;padding:4px 10px;border-radius:999px;background:#b3dca01f;color:var(--teal-dark);white-space:nowrap}.weekday-pill--day{background:#b3dca029;color:#2f4f86}.section-title{display:flex;align-items:center;justify-content:space-between;margin:30px 0 16px;font-weight:600;font-size:1.1rem}.hero-card>.section-title:first-child{margin-top:0}.section-title.section-title--right{justify-content:flex-end;text-align:right}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}#nextDepartures{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.notice-ticker{border-radius:14px;padding:12px 16px;background:#b3dca01f;border:1px solid rgba(179,220,160,.2);color:#24385a;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:1;transform:translateY(0);transition:opacity .24s ease,transform .24s ease}.notice-ticker.is-switching{opacity:.72;transform:translateY(-1px)}.notice-ticker.is-link{cursor:pointer}.route-page main>section:first-child{margin-bottom:22px}body.theme-night .notice-ticker{background:#f6e28a1f;border-color:#f6e28a47;color:#f6e28a}#notice.notice-flash{animation:noticeFlashPulse 1.1s ease}@keyframes noticeFlashPulse{0%{box-shadow:0 0 #b3dca085;border-radius:18px}70%{box-shadow:0 0 0 14px #b3dca000;border-radius:18px}to{box-shadow:0 0 #b3dca000;border-radius:18px}}.next-card{background:linear-gradient(140deg,#e9ecff,#fff);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid rgba(179,220,160,.12)}.next-card[data-jump-route]{cursor:pointer}.next-card--wide{padding:26px}.next-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.next-header h3{margin:0}.next-header p{margin:4px 0 0;color:var(--muted)}.next-badge{font-size:.8rem;padding:6px 12px;border-radius:999px;background:#b3dca033;color:#2f4f86}.next-list{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 14px}.next-chip{background:#fff;border-radius:999px;padding:8px 14px;box-shadow:0 6px 14px #1813361f;font-weight:600;display:inline-flex;align-items:center;gap:6px}.next-chip .last-tag{font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:999px;background:#b3dca029;color:#2f4f86}.next-chip.next-chip--more{padding:8px 14px;background:linear-gradient(135deg,#b3dca047,#b3dca02e);border:1px solid rgba(179,220,160,.45);box-shadow:inset 0 0 0 1px #ffffff59,0 6px 14px #1813361a;color:#2f4b83}body.theme-night .next-chip.next-chip--more{background:linear-gradient(135deg,#f6e28a47,#f6e28a2e);border-color:#f6e28a80;color:#f6e28a;box-shadow:inset 0 0 0 1px #f6e28a38,0 6px 14px #0000004d}.time-row.last-run{border:1px solid rgba(179,220,160,.3);background:#b3dca014}body.theme-night .time-row.last-run{border-color:#f6e28a59;background:#f6e28a1f}.next-note{margin:18px 0 0;color:var(--muted);font-size:.85rem}.next-empty{padding:20px;border-radius:var(--radius);background:#ffffffb3;color:var(--muted);border:1px dashed rgba(179,220,160,.25);text-align:center}.next-empty-inline{font-size:.9rem;color:var(--muted);padding:4px 0}body.theme-night .next-empty-inline{color:#eef1ffc7}.notice-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.notice-card h3{margin:0;font-size:1.1rem}.notice-card p{margin:8px 0 0;color:var(--muted)}.notice-head{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.notice-head h3{min-width:0}.notice-tag{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:.75rem;background:#b3dca033;color:#2b4a3c;border:1px solid rgba(179,220,160,.42)}body.theme-night .notice-tag{background:#f6e28a33;color:#f6e28a;border:1px solid rgba(246,226,138,.35)}.notice-date{display:block;margin-top:12px;font-size:.8rem;color:var(--muted)}.notice-empty{padding:20px;background:#fff9;border-radius:var(--radius);color:var(--muted)}.route-card{background:var(--card);border-radius:var(--radius);padding:18px 20px;text-decoration:none;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.route-card:hover{transform:translateY(-2px);box-shadow:0 20px 45px #18133629;background-color:#b3dca014}body.theme-night .route-card:hover{background-color:#ffffff1f}.route-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.route-tags span{background:#1b181514;padding:4px 8px;border-radius:999px;font-size:.72rem}.selector{display:grid;gap:12px}.selector-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.selector-row label{flex:0 0 64px;max-width:64px;min-width:64px}.selector-row select,.selector-row .dropdown{flex:1 1 auto;min-width:0}.selector-row--search label{min-width:72px}.route-search{margin:12px 0 10px}.search-input{width:100%;border:none;background:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 6px 14px #1813361f;font-family:var(--sans);font-size:.95rem;color:var(--ink)}.search-input::placeholder{color:#2e2e5899}body.theme-night .search-input{background:#ffffff24;color:#eef1ff;border:1px solid rgba(246,226,138,.35);box-shadow:0 10px 22px #06081873,0 0 0 2px #f6e28a1a}body.theme-night .search-input::placeholder{color:#eef1ff99}.section-title--with-search{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.route-search-inline{display:inline-flex;align-items:center;gap:10px;flex-wrap:nowrap}.route-search-inline .route-search-recent{margin:0;gap:6px;flex-direction:row;align-items:center}.route-search-inline .search-recent__label{margin-right:6px;white-space:nowrap}.route-search-inline .search-recent__items{flex-wrap:nowrap;overflow-x:auto;max-width:min(520px,48vw);padding-bottom:0;scrollbar-gutter:auto}.route-search-inline .search-chip{flex:0 0 auto}.search-input--inline{max-width:min(440px,100%);flex:0 0 240px;margin-left:auto}.search-input-wrap{position:relative;display:flex;align-items:center;flex:0 0 240px;max-width:min(440px,100%)}.search-input-wrap .search-input--inline{flex:1 1 auto;margin-left:0;padding-right:36px}.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;border:none;background:#b3dca029;color:#24385a;font-size:18px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;transition:box-shadow .2s ease}.search-clear--dropdown{width:24px;height:24px;font-size:16px}body.theme-night .search-clear{background:#ffffff24;color:#f6e28a}.search-clear.is-visible{display:inline-flex}.search-clear:hover{box-shadow:0 10px 18px #18133624}input.search-input[type=search]::-webkit-search-cancel-button,input.search-input[type=search]::-webkit-search-decoration{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:none}.dropdown__search-input::-webkit-search-cancel-button,.dropdown__search-input::-webkit-search-decoration{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:none}.route-search-recent{margin:6px 0 12px;display:flex;flex-direction:column;gap:8px}.route-search-recent--left{align-items:flex-start}.search-recent__label{font-size:.8rem;color:var(--muted);font-weight:600}.search-recent__empty{font-size:.8rem;color:var(--muted);padding:2px 0}.search-recent__items{display:flex;gap:8px;flex-wrap:wrap}.search-recent__items,.route-search-inline .search-recent__items{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}.search-recent__items::-webkit-scrollbar,.route-search-inline .search-recent__items::-webkit-scrollbar{height:var(--scrollbar-size)}.search-recent__items::-webkit-scrollbar-track,.route-search-inline .search-recent__items::-webkit-scrollbar-track{background:var(--scrollbar-track)}.search-recent__items::-webkit-scrollbar-thumb,.route-search-inline .search-recent__items::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px}.search-chip{border:none;background:#b3dca01f;color:#24385a;padding:4px 10px;border-radius:999px;font-size:.78rem;cursor:pointer}body.theme-night .search-chip{background:#ffffff1f;color:#f6e28a}.search-highlight{background:#b3dca033;color:inherit;padding:0 2px;border-radius:4px}body.theme-night .search-highlight{background:#f6e28a40}.dropdown__search{position:sticky;top:0;z-index:2;background:var(--card);padding:6px 6px 8px;margin-bottom:6px;position:relative}.dropdown__search-input{width:100%;border:none;background:#b3dca014;padding:8px 36px 8px 10px;border-radius:10px;font-family:var(--sans);font-size:.9rem;color:var(--ink)}.dropdown__search .search-clear{right:12px}.dropdown__search-input::placeholder{color:#2e2e5899}body.theme-night .dropdown__search{background:#0e1226f2}body.theme-night .dropdown__search-input{background:#ffffff1a;color:#eef1ff}body.theme-night .dropdown__search-input::placeholder{color:#eef1ff99}.dropdown__recent{padding:0 6px 6px;display:flex;flex-direction:column;gap:6px}.dropdown__recent-label{font-size:.75rem;color:var(--muted);font-weight:600}.dropdown__recent-items{display:flex;gap:6px;flex-wrap:wrap}.dropdown__recent-chip{border:none;background:#b3dca01f;color:#24385a;padding:4px 8px;border-radius:999px;font-size:.75rem;cursor:pointer}body.theme-night .dropdown__recent-chip{background:#ffffff1f;color:#f6e28a}.route-info-card .selector-row .dropdown,.route-info-card .selector-row select{max-width:clamp(240px,45vw,360px)}.day-toggle{margin-top:12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.day-toggle__segment{display:inline-flex;align-items:center;gap:6px;padding:4px;border-radius:999px;background:#b3dca033;border:1px solid rgba(179,220,160,.42)}.day-toggle button{border:none;background:transparent;color:#355538;padding:7px 14px;border-radius:999px;cursor:pointer;font-size:.88rem;font-weight:700;min-height:34px;transition:background-color .18s ease,color .18s ease,box-shadow .18s ease}.day-toggle__auto{background:#b3dca029;border:1px solid rgba(179,220,160,.46)}.day-toggle button.is-active{background:var(--accent);color:#1f2f1d;box-shadow:0 6px 14px #18133624}body.theme-night .day-toggle__segment{background:#ffffff14;border-color:#ffffff29}body.theme-night .day-toggle button{background:transparent;color:#eef1ff}body.theme-night .day-toggle__auto{background:#ffffff1f;border-color:#fff3}body.theme-night .day-toggle button.is-active{background:#f6e28ae6;color:#1c2346;box-shadow:0 10px 22px #080a1a73}.selector label{font-weight:700}.campus-selector{margin-top:16px;display:none;display:grid;grid-template-columns:44px 1fr;column-gap:12px;row-gap:10px;align-items:center}.campus-label-column{display:grid;grid-template-rows:auto auto;row-gap:12px;justify-items:start;align-items:center}.campus-label{font-weight:700;min-width:44px;line-height:1.1;height:36px;display:flex;align-items:center}.campus-pills-column{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;column-gap:10px;row-gap:10px}.campus-pills-row{display:flex;flex-wrap:wrap;gap:8px;grid-column:1}.campus-pills-row[data-campus-role=from]{grid-row:1}.campus-pills-row[data-campus-role=to]{grid-row:2}.campus-pills-column .swap-button{grid-column:2;grid-row:1 / span 2;align-self:center}.campus-pills{display:flex;flex-wrap:wrap;gap:8px}.campus-pill{border:1px solid rgba(179,220,160,.3);background:#fff;padding:8px 14px;border-radius:999px;font-size:.85rem;cursor:pointer;white-space:nowrap}.campus-pill.is-active{background:#b3dca02e;border-color:#b3dca099;font-weight:600}.campus-pill.is-disabled{opacity:.45;cursor:not-allowed;background:#1813360f}.swap-button{border:none;background:#3b79d129;color:#1b2b61;width:36px;height:36px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.swap-button svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.toggle-row{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;color:var(--muted)}select{border:none;background:#fff;padding:10px 42px 10px 14px;border-radius:12px;box-shadow:0 6px 14px #1813361f;font-family:var(--sans);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:var(--select-arrow);background-repeat:no-repeat;background-position:right 14px center;background-size:12px 8px}select.native-select{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;margin:0;padding:0;border:0}.dropdown{position:relative;min-width:200px;flex:1 1 auto}.dropdown__button{width:100%;border:none;background:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 6px 14px #1813361f;font-family:var(--sans);text-align:left;cursor:pointer;display:inline-flex;align-items:center;justify-content:space-between;gap:10px}.dropdown__label{flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown__chevron{width:14px;height:9px;background-image:var(--select-arrow);background-repeat:no-repeat;background-position:center;background-size:14px 9px;transition:transform .2s ease}.dropdown.is-open .dropdown__chevron{transform:rotate(180deg)}.dropdown__list{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--card);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:none;max-height:280px;overflow:auto;z-index:20;contain:layout paint;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb-strong) var(--scrollbar-track)}.dropdown.is-open .dropdown__list{display:block}.dropdown__list::-webkit-scrollbar{width:var(--scrollbar-size)}.dropdown__list::-webkit-scrollbar-track{background:var(--scrollbar-track)}.dropdown__list::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px;border:2px solid transparent;background-clip:padding-box}body.theme-night .dropdown__list{scrollbar-color:var(--scrollbar-thumb-strong) var(--scrollbar-track)}body.theme-night .dropdown__list::-webkit-scrollbar-thumb{background:#f6e28a66}.dropdown__option{width:100%;border:none;background:transparent;text-align:left;padding:8px 10px;border-radius:10px;cursor:pointer;font-family:var(--sans)}.dropdown__option[aria-selected=true]{background:#b3dca029;font-weight:600}.dropdown__empty{padding:8px 10px;color:var(--muted);font-size:.85rem}body.theme-night .dropdown__button{background:#ffffff14;color:#eef1ff;box-shadow:0 8px 18px #080a1a59}body.theme-night .dropdown__list{background:#0e1226f2;box-shadow:0 18px 40px #0608188c}body.theme-night .dropdown__option{color:#eef1ff}body.theme-night .dropdown__option[aria-selected=true]{background:#f6e28a38;color:#f6e28a}select.route-select--static{background-image:none!important;pointer-events:none;opacity:.85}.action-row{display:flex;align-items:center;justify-content:flex-start;gap:16px;margin-top:16px;flex-wrap:wrap}.favorite-help-row{display:inline-flex;align-items:center;gap:12px;position:relative}.action-button{border:1px solid transparent;background:var(--accent);color:#fff;padding:8px 14px;border-radius:999px;font-weight:600;cursor:pointer;position:relative;font-size:.86rem;min-height:34px}.action-button--ghost{background:#b3dca024;color:#24385a}.action-button.is-disabled,.action-button:disabled,.action-button[data-disabled=true],.action-button[aria-disabled=true]{opacity:.6;background:#b3dca00f;color:#2b2b6080;cursor:not-allowed;box-shadow:none;filter:saturate(.25);border:1px dashed rgba(179,220,160,.35)}.action-button.is-disabled:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.favorite-help{display:none;position:absolute;font-size:.78rem;color:#24385a;background:#f2f3ff;padding:6px 10px;border-radius:10px;line-height:1.3;width:max-content;max-width:70vw;margin-top:0;top:calc(100% + 8px);left:0;z-index:2;border:2px solid rgba(179,220,160,.22)}.favorite-help:before{content:"";position:absolute;left:15px;top:-7px;transform:none;border-width:0 7px 7px 7px;border-style:solid;border-color:transparent transparent rgba(179,220,160,.22) transparent}.favorite-help:after{content:"";position:absolute;left:16px;top:-6px;transform:none;border-width:0 6px 6px 6px;border-style:solid;border-color:transparent transparent #f2f3ff transparent}.favorite-help.is-flipped{left:auto;right:0}.favorite-help.is-flipped:before{left:auto;right:16px}.favorite-help.is-flipped:after{left:auto;right:16px}.favorite-help.is-visible{display:inline-flex;align-items:center}body.theme-night .favorite-help{color:#eef1ff;background:#0f142f;box-shadow:0 10px 24px #06081859;border-color:#f6e28a52}body.theme-night .favorite-help:before{border-color:transparent transparent rgba(246,226,138,.28) transparent}body.theme-night .favorite-help:after{border-color:transparent transparent #0f142f transparent}.stop-pills{display:flex;gap:10px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:12px;background-image:none;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track);scrollbar-gutter:stable}.stop-pills.is-collapsed{max-height:52px;overflow-x:auto;overflow-y:hidden}.pill-toggle{border:none;background:transparent;color:#24385a;padding:2px 6px;border-radius:999px;font-size:0;cursor:pointer;line-height:1;width:24px;height:24px;background-image:var(--select-arrow);background-repeat:no-repeat;background-position:center;background-size:12px 8px}body.theme-night .pill-toggle{background:transparent;color:#eef1ff}.stop-pills.is-collapsed+.pill-toggle{transform:rotate(0)}.pill-toggle.is-open{transform:rotate(180deg)}.stop-pills::-webkit-scrollbar{height:var(--scrollbar-size)}.stop-pills::-webkit-scrollbar-track{background:var(--scrollbar-track)}.stop-pills::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px}body.theme-night .stop-pills{scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}body.theme-night .stop-pills::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}.stop-pill{border:1px solid rgba(179,220,160,.3);background:#fff;padding:8px 14px;border-radius:999px;font-size:.85rem;cursor:pointer;font-family:var(--sans);white-space:nowrap;display:flex;flex-direction:column;gap:2px;line-height:1.2;justify-content:center;background-image:none}.stop-pill.is-active{background:#b3dca02e;border-color:#b3dca099;font-weight:600}body.theme-night .stop-pill.is-active{background:#f6e28ac7;border-color:#f6e28ae6;color:#1c2346}body.theme-night .stop-pill.is-active,body.theme-night .stop-pill.is-active *{color:#1c2346}.destination-pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.destination-pill{border:1px solid rgba(179,220,160,.3);background:#fff;padding:10px 16px;border-radius:999px;font-size:.9rem;cursor:pointer;line-height:1.2}.destination-pill.is-active{background:#b3dca02e;border-color:#b3dca099;font-weight:600}.pill-title{font-weight:600;line-height:1.2}.pill-sub{font-size:.72rem;color:var(--muted);line-height:1.2}.favorite-chip{border:none;background:#fff;border-radius:999px;padding:10px 16px;box-shadow:0 8px 18px #1813361f;display:flex;flex-direction:column;gap:4px;cursor:pointer}.favorite-chip strong{font-size:.95rem}.favorite-times{display:flex;gap:6px;flex-wrap:wrap;font-size:.75rem;color:var(--muted)}.favorite-times span{background:#b3dca01f;padding:2px 8px;border-radius:999px}.footer{padding:32px clamp(20px,5vw,60px) calc(32px + env(safe-area-inset-bottom));font-size:.85rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px;align-items:center}.footer-update{opacity:.92;white-space:nowrap}.route-layout{display:grid;gap:20px;grid-template-columns:minmax(0,1fr) 200px;align-items:start}.route-layout.is-no-timetable{grid-template-columns:minmax(0,1fr)}.route-layout.is-no-timetable .route-main{display:none}.route-side{display:flex;flex-direction:column;gap:20px}.route-side .hero-card,.route-main .time-table{width:100%}.info-card{padding:20px}.info-card .section-title{margin-top:0}#nextPanel.info-card{padding:22px}#routeNote.info-card{background:#3b79d11f;color:var(--teal-dark);white-space:pre-line;line-height:1.6}body.theme-night #routeNote.info-card{background:#3b79d133;color:#d8e1ff}.route-title-row{display:flex;align-items:center;justify-content:flex-start;gap:12px;flex-wrap:nowrap}.route-info-card h1{margin:0;font-family:var(--sans);flex:1 1 auto;min-width:0}.route-info-card p{margin:8px 0 0;color:var(--muted)}.share-note{margin:6px 0 0;font-size:.82rem;color:var(--muted)}body.theme-night .share-note{color:#eef1ffbf}.route-info-card .hero-badge{margin-top:0;white-space:nowrap;align-self:center}.hero-badge.is-weekday{background:#b3dca02e;color:#2f4f86}.hero-badge.is-daily{background:#3b79d133;color:#2b3a8d}body.theme-night .hero-badge.is-weekday{background:#f6e28a38;color:#f6e28a}body.theme-night .hero-badge.is-daily{background:#82c6ff38;color:#bfe1ff}.route-main{width:200px}.route-main .section-title{margin-top:0}.time-table{background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);display:grid;gap:12px;grid-auto-rows:minmax(44px,auto)}.time-empty{padding:18px;border-radius:14px;text-align:center;color:var(--muted);background:#fff9}body.theme-night .time-empty{background:#ffffff14;color:#eef1ffcc}.time-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#1813360a;border-radius:12px;font-weight:600}.time-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.route-note{padding:16px 20px;background:#3b79d11f;border-radius:var(--radius);color:var(--teal-dark);white-space:pre-line;line-height:1.6}@media (max-width: 900px){.route-layout{grid-template-columns:1fr}.route-main{width:100%}.route-main .section-title--right{justify-content:flex-start;text-align:left;padding-right:6px}}@media (max-width: 640px){header.navbar{padding:16px 16px 10px}nav.primary-nav{gap:8px}header.navbar{flex-direction:column;align-items:flex-start}nav.primary-nav{width:100%;flex-wrap:wrap}main{padding:0 20px 40px}.route-side,.route-main,.hero-card,.route-info-card,.route-note{width:100%}.route-title-row{flex-wrap:nowrap;align-items:center}.hero-card{padding:18px}.route-search-inline{flex-direction:column;align-items:stretch;width:100%}.route-search-inline .route-search-recent{width:100%}.route-search-inline .search-recent__items{max-width:100%}.search-input--inline{width:100%;flex:none;margin-left:0}.search-input-wrap{width:100%;flex:none}.hero-card,.next-card,.notice-card,.route-card,.route-side .hero-card,.route-side .info-card,.route-main .time-table{width:100%;margin:0}.route-main .section-title--right{padding-right:18px}.selector,.selector select{width:100%}.stop-pills{flex-wrap:wrap;overflow-x:visible;padding-bottom:0}.favorite-dock{position:fixed;top:72px;left:12px;right:12px;padding:0;z-index:12}.favorite-dock__panel{max-width:100%}.next-list{overflow-x:auto;padding-bottom:6px;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}.next-list::-webkit-scrollbar{height:var(--scrollbar-size)}.next-list::-webkit-scrollbar-track{background:var(--scrollbar-track)}.next-list::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:999px}body.theme-night .next-list{scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}body.theme-night .next-list::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb)}.hero-card h1{font-size:1.6rem}.section-title{padding:0}.next-card{padding:18px}nav.primary-nav a{flex:1 1 auto;text-align:center}nav.primary-nav a,.favorite-tab,.locale-toggle,.theme-toggle{margin-top:0}.nav-links{width:100%;order:1;flex-wrap:nowrap;gap:4px}.nav-links a{flex:1 1 0;min-width:0;text-align:center}.nav-actions{width:100%;order:2;justify-content:flex-end;gap:4px;margin-top:0}.favorite-dock{position:fixed;top:140px;left:12px;right:12px;padding:0;z-index:12}.favorite-dock__handle{display:none}.favorite-tab{flex:1 1 auto}.locale-toggle{flex:0 0 auto}.theme-toggle{flex:0 0 38px;width:38px;height:38px}}@media (max-width: 480px){.favorite-dock__times{gap:6px;min-height:22px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.favorite-dock__times::-webkit-scrollbar{display:none}.favorite-dock__times span{font-size:.8rem;padding:3px 8px;height:22px;gap:4px;flex-shrink:0}.favorite-dock__times .last-tag{font-size:.62rem;padding:2px 5px}.favorite-dock__times span.favorite-dock__empty-text{font-size:.8rem}.favorite-dock__times span.favorite-dock__more{font-size:.8rem;padding:3px 8px!important}}
