:root{--bg-cream:#ece0be;--bg-cream-2:#dfd0a4;--paper-shadow:#c7b68b;--shroom-red:#b86855;--shroom-red-deep:#8e4a40;--shroom-cap:#f4ecd4;--ink:#3a3226;--ink-50:#6e6253;--ink-30:#a29684;--leaf:#779c5c;--sky:#93b5c9;--sun:#d9a458;--r-sm:12px;--r-md:20px;--r-lg:28px;--r-pill:999px;--font-display:"Fraunces", "Noto Serif SC", ui-serif, serif;--font-body:"Outfit", "Noto Sans SC", system-ui, -apple-system, sans-serif;--font-hand:"Caveat", "Ma Shan Zheng", cursive;--shadow-card:0 6px 0 var(--paper-shadow), 0 10px 24px #2c241814;--shadow-btn:0 5px 0 var(--shroom-red-deep), 0 8px 16px #e2555540;--shadow-btn-leaf:0 5px 0 #3d8c3d, 0 8px 16px #5bae5b40}*{box-sizing:border-box}html,body{background:var(--bg-cream);height:100%;color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;overscroll-behavior:none;touch-action:manipulation;margin:0;padding:0;font-size:17px}#root{flex-direction:column;min-height:100%;display:flex}button{cursor:pointer;font-family:inherit}.app{background:var(--bg-cream);flex-direction:column;min-height:100vh;display:flex;position:relative;overflow:hidden}.app:before{content:"";pointer-events:none;z-index:100;opacity:.04;mix-blend-mode:multiply;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='3' seed='8'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='220' height='220' filter='url(%23n)' opacity='1'/></svg>");position:fixed;inset:0}.topbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--paper-shadow);z-index:10;background:#faefd9d9;grid-template-columns:40px 1fr auto;align-items:center;gap:12px;padding:14px 16px;display:grid;position:sticky;top:0}.topbar-back{width:40px;height:40px;color:var(--ink);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:background .15s,transform .1s;display:inline-flex}.topbar-back:hover{background:#c04b2d14}.topbar-back:active{background:#c04b2d2e;transform:scale(.9)}.topbar-back-spacer{width:40px}.brand{font-family:var(--font-display);color:var(--ink);align-items:center;gap:8px;font-size:20px;font-weight:600;display:flex}.brand .icon{width:28px;height:28px}.progress-mini{gap:6px;display:flex}.progress-mini .dot{background:var(--paper-shadow);border-radius:50%;width:10px;height:10px;transition:all .3s}.progress-mini .dot.active{background:var(--shroom-red);transform:scale(1.4)}.progress-mini .dot.done{background:var(--leaf)}.scene{flex-direction:column;flex:1;width:100%;max-width:720px;margin:0 auto;padding:32px 24px 40px;display:flex;position:relative}.scene-eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--ink-50);align-items:center;gap:8px;margin-bottom:12px;font-size:13px;display:flex}.scene-eyebrow:before{content:"";background:var(--shroom-red);border-radius:2px;width:32px;height:2px}.scene h1{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 16px;font-size:clamp(36px,7vw,52px);font-weight:600;line-height:1.1}.scene h1 em{color:var(--shroom-red);font-style:italic}.scene-ride h1 em{color:var(--current-line,var(--shroom-red))}.scene-ride .scene-eyebrow:before{background:var(--current-line,var(--shroom-red))}.scene .lead{color:var(--ink-50);max-width:520px;margin:0 0 32px;font-size:18px;line-height:1.6}.stage{border-radius:var(--r-lg);min-height:280px;box-shadow:inset 0 2px 0 #ffffff80, 0 4px 0 var(--paper-shadow), 0 8px 20px #2c241814;background:linear-gradient(#f4e4bd 0%,#faefd9 100%);flex:1;justify-content:center;align-items:center;margin-bottom:32px;padding:20px 24px;display:flex;position:relative;overflow:hidden}.stage.text-only{font-family:var(--font-hand);color:var(--ink-30);border:2px dashed var(--paper-shadow);background:var(--bg-cream-2);box-shadow:none;font-size:32px}.illu{width:100%;height:auto;max-height:280px;display:block}@keyframes coin-drop{0%{opacity:0;transform:translateY(-120px)}60%{opacity:1;transform:translateY(100px)}80%{transform:translate(-4px,100px)}to{opacity:0;transform:translateY(100px)}}@keyframes ticket-out{0%{transform:translateY(0)}to{transform:translateY(14px)}}@keyframes train-arrive{0%{transform:translate(280px)}85%{transform:translate(-30px)}to{transform:translate(-20px)}}.big-btn{font-family:var(--font-display);letter-spacing:-.01em;background:var(--shroom-red);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-btn);-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:12px;width:100%;max-width:480px;min-height:64px;padding:20px 32px;font-size:22px;font-weight:600;transition:transform .1s,box-shadow .1s;display:inline-flex}.big-btn:active{box-shadow:0 2px 0 var(--shroom-red-deep), 0 4px 8px #e2555533;transform:translateY(3px)}.big-btn .arrow{transition:transform .2s;display:inline-block}.big-btn:active .arrow{transform:translate(6px)}.big-btn.leaf{background:var(--leaf);box-shadow:var(--shadow-btn-leaf)}.big-btn.leaf:active{box-shadow:0 2px #3d8c3d,0 4px 8px #5bae5b33}.big-btn.ghost{color:var(--ink);border:2px solid var(--ink);box-shadow:0 5px 0 var(--ink);background:0 0}.big-btn.ghost:active{box-shadow:0 2px 0 var(--ink)}.btn-row{flex-direction:column;align-items:center;gap:12px;display:flex}.floor-panel{border-radius:var(--r-md);box-shadow:var(--shadow-card);background:#fff;margin-bottom:16px;padding:16px 18px}.floor-panel-label{font-family:var(--font-mono);letter-spacing:.18em;color:var(--ink-50);text-transform:uppercase;margin-bottom:10px;font-size:11px}.floor-row{gap:10px;display:flex}.floor-btn{background:var(--bg-cream-2);border-radius:var(--r-md);font-family:var(--font-display);color:var(--ink-50);cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;flex:1;padding:18px 16px;font-size:18px;font-weight:700;transition:all .15s;position:relative}.floor-btn:disabled{cursor:not-allowed;opacity:.5}.floor-btn.target{color:var(--shroom-red);border-color:var(--shroom-red);box-shadow:0 4px 0 var(--shroom-red);background:#fff}.floor-btn.target:before{content:"👆";font-size:22px;animation:1.2s ease-in-out infinite pulse-finger;position:absolute;top:-8px;right:-4px}.floor-btn.target.pressed{background:var(--shroom-red);color:#fff;box-shadow:0 0 0 var(--shroom-red);transform:translateY(4px)}.floor-btn.target.pressed:before{display:none}@keyframes pulse-finger{0%,to{transform:translate(0)rotate(-10deg)}50%{transform:translateY(4px)rotate(-10deg)}}.lift-car.phase-closing{transform:translateY(0)}.lift-car.phase-descending{animation:3.6s linear forwards lift-down-anim}@keyframes lift-down-anim{0%{transform:translateY(0)}to{transform:translateY(50px)}}.lift-btn-blink{animation:1s ease-in-out infinite btn-blink}@keyframes btn-blink{0%,to{opacity:1;filter:drop-shadow(0 0 #e25555)}50%{opacity:.6;filter:drop-shadow(0 0 4px #e25555)}}.lift-btn-pressed{filter:drop-shadow(0 0 6px #f4b942)}.lift-btn-active{animation:.8s ease-in-out infinite btn-active}@keyframes btn-active{0%,to{filter:drop-shadow(0 0 #f4b942)}50%{filter:drop-shadow(0 0 6px #f4b942)}}.lift-int-doors .door-l,.lift-int-doors .door-r{transform-origin:50%;transform-box:fill-box;transition:transform .7s cubic-bezier(.4,0,.3,1)}.lift-int-doors.phase-closing .door-l{animation:1s ease-in-out both door-close-l}.lift-int-doors.phase-closing .door-r{animation:1s ease-in-out both door-close-r}@keyframes door-close-l{0%{transform:translate(-30px)}to{transform:translate(0)}}@keyframes door-close-r{0%{transform:translate(30px)}to{transform:translate(0)}}.lift-int-doors.open .door-l{transform:translate(-32px)}.lift-int-doors.open .door-r{transform:translate(32px)}.platform-peek{animation:.6s ease-out .2s both peek-in}@keyframes peek-in{0%{opacity:0}to{opacity:1}}.ding-flash{animation:.8s ease-out both ding}@keyframes ding{0%{opacity:0;transform:translateY(8px)scale(.8)}20%{opacity:1;transform:translateY(0)scale(1.3)}to{opacity:0;transform:translateY(-12px)scale(1)}}.lift-cabin-descending{animation:4s linear forwards cabin-descend}@keyframes cabin-descend{0%{transform:translateY(0)}to{transform:translateY(100px)}}.lift-counterweight{animation:4s linear forwards counterweight-rise}@keyframes counterweight-rise{0%{transform:translateY(0)}to{transform:translateY(-20px)}}.motor-spin{transform-origin:10px 10px;transform-box:fill-box;animation:.4s linear infinite motor-spin}@keyframes motor-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lift-floor-display.rolling{animation:.4s ease-in-out floor-roll}@keyframes floor-roll{0%,to{opacity:1;transform:translateY(0)}50%{opacity:.3;transform:translateY(2px)}}.stage-transfer{padding:12px}.transfer-illu .transfer-walker{transform-origin:50%;animation:2.6s cubic-bezier(.4,0,.6,1) infinite alternate corridor-walk}@keyframes corridor-walk{0%{transform:translate(0)}to{transform:translate(140px)}}.scene-avatar{padding-bottom:32px}.avatar-current{border-radius:var(--r-md);box-shadow:var(--shadow-card);background:#fff;align-items:center;gap:14px;margin-bottom:20px;padding:20px 22px;display:flex}.avatar-current .avatar-emoji{font-size:56px;line-height:1}.avatar-current .avatar-name{font-family:var(--font-display);border:none;border-bottom:2px dashed var(--paper-shadow);color:var(--ink);background:0 0;outline:none;flex:1;padding:6px 0;font-size:22px}.avatar-current .avatar-name:focus{border-bottom-color:var(--shroom-red)}.avatar-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.avatar-cell{border-radius:var(--r-md);box-shadow:var(--shadow-card);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:3px solid #0000;flex-direction:column;align-items:center;gap:4px;padding:14px 6px 10px;transition:transform .12s,border-color .18s;display:flex}.avatar-cell:active{transform:translateY(2px)}.avatar-cell.picked{border-color:var(--shroom-red);background:#fff8f0}.avatar-cell .ae{font-size:34px;line-height:1}.avatar-cell .al{font-family:var(--font-body);color:var(--ink-50);letter-spacing:.04em;font-size:11px}.player-strip{border-radius:var(--r-md);box-shadow:var(--shadow-card);background:#fff;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;display:flex}.player-strip .player-emoji{font-size:28px;line-height:1}.player-strip .player-text{font-family:var(--font-body);color:var(--ink-50);flex:1;font-size:14px}.player-strip .player-text strong{font-family:var(--font-display);color:var(--ink);margin-right:4px;font-size:16px;font-weight:600}.player-strip .player-change{font-family:var(--font-mono);color:var(--shroom-red);cursor:pointer;-webkit-tap-highlight-color:transparent;letter-spacing:.04em;background:#c04b2d14;border:none;border-radius:999px;padding:5px 11px;font-size:11px}.festival-banner{background:var(--festival-color,var(--shroom-red));color:#fff;font-family:var(--font-display);letter-spacing:.04em;z-index:9;justify-content:center;align-items:center;gap:8px;padding:8px 14px;font-size:14px;font-weight:600;display:flex;position:relative}.festival-banner .festival-emoji{font-size:18px}.festival-banner .festival-name{text-shadow:0 1px #00000026}.time-flavor{background:var(--bg-cream-2);color:var(--ink-50);font-family:var(--font-mono);letter-spacing:.04em;border-bottom:1px solid var(--paper-shadow);align-items:center;gap:8px;padding:6px 16px;font-size:11px;display:flex}.station-egg{border-radius:var(--r-md);border:2px solid var(--shroom-red);z-index:5;background:#fff;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;animation:1.6s cubic-bezier(.2,1.6,.4,1) both egg-pop;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 6px 18px #2c241840}.station-egg .station-egg-emoji{font-size:38px;line-height:1}.station-egg .station-egg-label{font-family:var(--font-display);color:var(--shroom-red);font-size:13px;font-weight:600}@keyframes egg-pop{0%{opacity:0;transform:scale(0)rotate(15deg)}15%{opacity:1;transform:scale(1.2)rotate(-3deg)}30%{opacity:1;transform:scale(1)rotate(0)}80%{opacity:1;transform:scale(1)rotate(0)}to{opacity:0;transform:scale(.4)rotate(20deg)}}.special-tag{font-family:var(--font-body);color:var(--ink);text-align:center;background:#ffffffeb;border-radius:999px;padding:8px 14px;font-size:12px;animation:.55s cubic-bezier(.2,1.4,.4,1) .4s both special-slide-up;position:absolute;bottom:12px;left:12px;right:12px;box-shadow:0 2px 8px #2c24181f}@keyframes special-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.elevator-choose{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.elevator-card{border-radius:var(--r-md);box-shadow:var(--shadow-card);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:center;background:#fff;border:3px solid #0000;flex-direction:column;align-items:center;gap:8px;padding:28px 20px;transition:transform .15s,border-color .2s;display:flex}.elevator-card:active{border-color:var(--shroom-red);background:#fff8f0;transform:translateY(3px)}.elevator-icon{width:80px;height:80px}.elevator-card .elevator-name{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;font-size:22px;font-weight:700}.elevator-card .elevator-hint{font-family:var(--font-body);color:var(--ink-50);font-size:13px;line-height:1.4}.stage-elevator{padding:0;overflow:hidden}@keyframes step-down{0%{opacity:0;transform:translate(-12px,-16px)}10%{opacity:1}90%{opacity:1}to{opacity:0;transform:translate(0)}}.escalator-steps line{transform-origin:50%;transform-box:fill-box;animation:2.6s linear infinite step-down}.escalator-steps line:first-child{animation-delay:0s}.escalator-steps line:nth-child(2){animation-delay:.37s}.escalator-steps line:nth-child(3){animation-delay:.74s}.escalator-steps line:nth-child(4){animation-delay:1.11s}.escalator-steps line:nth-child(5){animation-delay:1.48s}.escalator-steps line:nth-child(6){animation-delay:1.85s}.escalator-steps line:nth-child(7){animation-delay:2.22s}.escalator-steps.done line{animation-play-state:paused}@keyframes rider-down{0%{transform:translate(-78px,-64px)}to{transform:translate(0)}}.escalator-rider{transform-origin:50%;transform-box:fill-box;animation:4.2s linear forwards rider-down}.escalator-rider.done{transform:translate(0)}@keyframes lift-down{0%{transform:translateY(0)}20%{transform:translateY(0)}85%{transform:translateY(50px)}to{transform:translateY(50px)}}.lift-car{animation:4.6s ease-in-out forwards lift-down}.lift-doors .door-l,.lift-doors .door-r{transition:transform .45s ease-out}.lift-doors.open .door-l{transform:translate(-28px)}.lift-doors.open .door-r{transform:translate(28px)}.city-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px;display:grid}.city-card{border-radius:var(--r-md);box-shadow:var(--shadow-card);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;background:#fff;border:2.5px solid #0000;flex-direction:column;align-items:flex-start;gap:4px;padding:16px 16px 14px;transition:transform .15s,border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.city-card:before{content:"";background:var(--city-theme,var(--shroom-red));height:4px;position:absolute;top:0;left:0;right:0}.city-card:active{transform:translateY(2px)}.city-card.current{border-color:var(--city-theme,var(--shroom-red));background:#fff8f0}.city-card .city-emoji{margin-bottom:4px;font-size:32px;line-height:1}.city-card .city-name{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;font-size:22px;font-weight:700}.city-card .city-tagline{font-family:var(--font-body);color:var(--city-theme,var(--ink-50));margin-bottom:4px;font-size:12px;font-weight:500;line-height:1.35}.city-card .city-en{font-family:var(--font-body);letter-spacing:.06em;color:var(--ink-30);margin-bottom:4px;font-size:11px}.city-card .city-meta{font-family:var(--font-mono);color:var(--ink-50);gap:6px;font-size:11px;display:flex}.city-card .city-visited{font-family:var(--font-mono);letter-spacing:.05em;color:var(--leaf);background:#5bae5b1f;border-radius:999px;margin-top:6px;padding:2px 8px;font-size:10px}.city-eyebrow{align-items:center;gap:12px;margin-bottom:14px;display:flex}.city-eyebrow:before{content:none}.city-back{font-family:var(--font-body);color:var(--shroom-red);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#c04b2d14;border:none;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:inline-flex}.city-back:active{background:#c04b2d2e}.trip-strip{border-radius:var(--r-md);box-shadow:var(--shadow-card);font-family:var(--font-body);background:#fff;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;padding:12px 14px;font-size:14px;display:flex}.trip-strip .strip-label{font-family:var(--font-mono);letter-spacing:.15em;background:var(--shroom-red);color:#fff;border-radius:3px;padding:2px 6px;font-size:10px}.trip-strip .strip-name{font-family:var(--font-display);color:var(--ink);font-size:17px;font-weight:600}.trip-strip .strip-arrow{color:var(--ink-30);margin:0 4px;font-size:18px}.trip-strip .strip-reset{color:var(--ink-50);background:var(--bg-cream-2);border-radius:var(--r-sm);border:none;margin-left:auto;padding:6px 10px;font-size:12px}.line-tabs{scrollbar-width:none;gap:6px;margin:0 -4px 12px;padding:4px 0 12px;display:flex;overflow-x:auto}.line-tabs::-webkit-scrollbar{display:none}.line-tab{border-radius:var(--r-pill);background:var(--bg-cream-2);color:var(--ink-50);font-family:var(--font-display);white-space:nowrap;cursor:pointer;-webkit-tap-highlight-color:transparent;border:2px solid #0000;align-items:center;gap:6px;padding:8px 14px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.line-tab .dot{background:var(--line-color,#999);border-radius:50%;width:10px;height:10px}.line-tab small{font-family:var(--font-mono);color:var(--ink-30);font-size:11px;font-weight:400}.line-tab.active{color:var(--ink);border-color:var(--line-color,var(--ink));box-shadow:0 2px 0 var(--paper-shadow);background:#fff}.line-tab.active small{color:var(--ink-50)}.station-list{border-radius:var(--r-md);box-shadow:var(--shadow-card);background:#fff;flex:1;min-height:280px;max-height:50vh;margin-bottom:16px;padding:8px 0;overflow-y:auto}.station-row{cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:12px;padding:12px 16px;display:flex}.station-row:hover:not(.disabled),.station-row:active:not(.disabled){background:var(--bg-cream-2)}.station-row.disabled{opacity:.4;cursor:not-allowed}.station-row .row-rail{flex-direction:column;align-items:center;width:16px;height:100%;min-height:28px;display:flex;position:relative}.station-row .row-dot{z-index:1;border:2px solid #fff;border-radius:50%;width:12px;height:12px;margin-top:4px;box-shadow:0 0 0 1.5px}.station-row .row-line{width:3px;position:absolute;top:16px;bottom:-12px;left:50%;transform:translate(-50%)}.station-row .row-name{font-family:var(--font-display);color:var(--ink);flex-wrap:wrap;flex:1;align-items:center;gap:10px;font-size:17px;font-weight:500;display:flex}.station-row .row-interchange{gap:3px;display:inline-flex}.interchange-chip{width:22px;height:22px;font-family:var(--font-display);color:#fff;text-shadow:0 1px #0000002e;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.station-row .row-tag{font-family:var(--font-mono);letter-spacing:.15em;color:var(--ink-30);font-size:10px}.visited-strip{background:var(--bg-cream-2);border-radius:var(--r-pill);font-family:var(--font-body);color:var(--ink-50);align-self:flex-start;align-items:baseline;gap:8px;margin-top:auto;padding:10px 16px;font-size:13px;display:inline-flex}.visited-strip .visited-count{font-family:var(--font-display);color:var(--shroom-red);font-size:22px;font-weight:700}.visited-strip .visited-of{font-family:var(--font-mono);font-size:12px}.scene.home{padding-bottom:24px}.station-grid{grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:32px;display:grid}.station-card{border-radius:var(--r-md);text-align:left;box-shadow:var(--shadow-card);cursor:pointer;font-family:var(--font-body);-webkit-tap-highlight-color:transparent;background:#fff;border:3px solid #0000;padding:24px 20px;transition:transform .15s,border-color .2s}.station-card:active{transform:translateY(2px)}.station-card.selected{border-color:var(--shroom-red);background:#fff8f0}.station-card .emoji{margin-bottom:8px;font-size:36px;line-height:1;display:block}.station-card .name{font-family:var(--font-display);color:var(--ink);font-size:22px;font-weight:600}.station-card .ch{color:var(--ink-50);letter-spacing:.05em;margin-top:2px;font-size:13px;display:block}.route-mini{scrollbar-width:none;margin:0 -8px 16px;padding:6px 8px;overflow-x:auto}.route-mini::-webkit-scrollbar{display:none}.route-mini-strip{border-radius:var(--r-pill);box-shadow:var(--shadow-card);white-space:nowrap;background:#fff;align-items:center;gap:0;min-width:100%;padding:8px 12px;display:inline-flex}.route-mini-stop{font-family:var(--font-body);color:var(--ink-30);align-items:center;gap:4px;font-size:12px;display:inline-flex;position:relative}.route-mini-stop:not(:last-child):after{content:"";background:var(--paper-shadow);width:14px;height:2px;margin:0 4px;display:inline-block}.route-mini-stop .route-mini-dot{background:var(--paper-shadow);border-radius:50%;flex-shrink:0;width:8px;height:8px}.route-mini-stop.done{color:var(--leaf)}.route-mini-stop.done .route-mini-dot{background:var(--c)}.route-mini-stop.active{color:var(--ink);font-weight:700}.route-mini-stop.active .route-mini-dot{background:var(--c);width:12px;height:12px;box-shadow:0 0 0 3px #0000000f}.route-mini-xfer{color:var(--shroom-red);margin-left:2px}.passport{border-radius:var(--r-lg);box-shadow:var(--shadow-card);background:#fff;margin-bottom:32px;padding:32px 28px}.passport h3{font-family:var(--font-hand);color:var(--city-theme,var(--shroom-red));margin:0;font-size:32px;display:inline-block;transform:rotate(-2deg)}.passport-head{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:6px;display:flex}.passport-count{font-family:var(--font-display);color:var(--city-theme,var(--shroom-red));letter-spacing:-.02em;font-size:28px;font-weight:700}.passport-count small{font-family:var(--font-mono);color:var(--ink-50);font-size:11px;font-weight:400}.passport-progress{background:var(--paper-shadow);border-radius:999px;height:6px;margin-top:16px;overflow:hidden}.passport-progress-fill{border-radius:999px;height:100%;transition:width .6s ease-out}.visited-more{font-family:var(--font-mono);letter-spacing:.04em;font-size:11px;font-weight:600;background:var(--paper-shadow)!important;color:var(--ink-50)!important}.story-card{border-radius:var(--r-md);box-shadow:var(--shadow-card);border-left:4px solid var(--city-theme,var(--shroom-red));background:linear-gradient(135deg,#fff,#fff8f0);gap:14px;margin-bottom:14px;padding:16px 18px;display:flex}.story-card .story-icon{flex-shrink:0;font-size:26px;line-height:1}.story-card .story-station{font-family:var(--font-display);color:var(--ink);margin-bottom:4px;font-size:17px;font-weight:700}.story-card .story-body{font-family:var(--font-body);color:var(--ink-50);font-size:14px;line-height:1.55}.quest-card{border-radius:var(--r-md);box-shadow:var(--shadow-card);border-left:4px solid var(--mustard);background:#fff;margin-bottom:14px;padding:14px 18px}.quest-card.done{border-left-color:var(--leaf);background:#f0f8f0}.quest-card .quest-label{font-family:var(--font-mono);letter-spacing:.18em;color:var(--ink-50);margin-bottom:6px;font-size:11px}.quest-card .quest-row{align-items:center;gap:8px;display:flex}.quest-card .quest-icon{background:var(--mustard);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:18px;font-weight:700;display:inline-flex}.quest-card.done .quest-icon{background:var(--leaf)}.quest-card .quest-text{font-family:var(--font-display);color:var(--ink);font-size:16px;font-weight:600}.quest-card .quest-bonus{font-family:var(--font-mono);color:var(--leaf);letter-spacing:.05em;margin-top:6px;font-size:11px}.title-card{background:linear-gradient(135deg, var(--theme,#c04b2d)15, #fff);border-radius:var(--r-md);box-shadow:var(--shadow-card);justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:14px 18px;display:flex}.title-card .title-left{align-items:center;gap:12px;display:flex}.title-card .title-emoji{font-size:36px;line-height:1}.title-card .title-name{font-family:var(--font-display);color:var(--ink);font-size:20px;font-weight:700}.title-card .title-progress{font-family:var(--font-body);color:var(--ink-50);font-size:12px}.title-card .title-next{text-align:right}.title-card .title-next-label{font-family:var(--font-mono);color:var(--ink-30);letter-spacing:.1em;font-size:10px}.title-card .title-next-name{font-family:var(--font-display);color:var(--ink);font-size:14px;font-weight:600}.title-card .title-next-rem{font-family:var(--font-body);color:var(--shroom-red);margin-top:2px;font-size:11px}.map-section{border-radius:var(--r-md);box-shadow:var(--shadow-card);background:#fff;margin-bottom:14px;padding:12px 14px 6px}.map-section .map-label{font-family:var(--font-display);color:var(--ink);justify-content:space-between;align-items:baseline;margin-bottom:6px;font-size:14px;font-weight:600;display:flex}.map-section .map-count{font-family:var(--font-mono);color:var(--shroom-red);letter-spacing:.04em;font-size:12px}.china-map{width:100%;height:auto;display:block}.china-map.compact{max-height:180px}.share-card-wrap{border-radius:var(--r-md);box-shadow:var(--shadow-card);background:#fff;margin:12px 0 18px;padding:8px}.share-card-label{text-align:center;font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-50);margin:4px 0 8px;font-size:10px}.share-card-svg{border-radius:var(--r-sm);width:100%;height:auto;display:block}.done-hero{justify-content:center;align-items:center;min-height:180px;margin:8px 0 24px;display:flex;position:relative}.done-stamp{border:4px solid var(--stamp-color,var(--shroom-red));opacity:0;background:#fff;border-radius:50%;flex-direction:column;align-items:center;gap:4px;padding:22px 28px 18px;transition:transform .55s cubic-bezier(.2,1.6,.4,1),opacity .4s;display:flex;transform:rotate(-6deg)scale(.5);box-shadow:0 8px 20px #2c24181f}.done-hero.boom .done-stamp{opacity:1;transform:rotate(-6deg)scale(1)}.done-stamp-emoji{font-size:48px;line-height:1}.done-stamp-cn{font-family:var(--font-hand);color:var(--stamp-color,var(--shroom-red));margin-top:2px;font-size:20px}.done-stamp-name{font-family:var(--font-display);color:var(--ink);letter-spacing:-.01em;font-size:22px;font-weight:700}.done-fireworks{pointer-events:none;position:absolute;inset:0}.firework{opacity:0;font-size:22px;position:absolute}.done-hero.boom .firework{animation:1.4s ease-out forwards firework-pop}.firework.f1{color:#e25555;top:10%;left:18%;animation-delay:.15s!important}.firework.f2{color:#f4b942;top:30%;right:14%;animation-delay:.3s!important}.firework.f3{color:#5bae5b;bottom:18%;left:22%;animation-delay:.45s!important}.firework.f4{color:#7bc4e8;bottom:30%;right:18%;animation-delay:.2s!important}.firework.f5{color:#c99fcd;top:8%;right:30%;animation-delay:.4s!important}.firework.f6{color:#ff850d;bottom:8%;left:45%;animation-delay:.55s!important}@keyframes firework-pop{0%{opacity:0;transform:scale(0)rotate(0)}40%{opacity:1;transform:scale(1.4)rotate(120deg)}80%{opacity:1;transform:scale(.9)rotate(220deg)}to{opacity:0;transform:scale(.4)rotate(360deg)}}.badge-first{background:var(--mustard);color:var(--ink);font-family:var(--font-mono);letter-spacing:.1em;vertical-align:middle;border-radius:999px;margin-left:12px;padding:3px 10px;font-size:11px;display:inline-block}.visited-list{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.visited-pill{background:var(--bg-cream-2);border-radius:var(--r-pill);font-family:var(--font-body);align-items:center;gap:6px;padding:6px 12px 6px 8px;font-size:14px;display:inline-flex}.visited-pill-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.visited-pill-name{font-family:var(--font-display);color:var(--ink);font-weight:500}.visited-empty{color:var(--ink-50);text-align:center;padding:16px;font-style:italic}.passport .stamps{grid-template-columns:repeat(5,1fr);gap:10px;margin-top:20px;display:grid}.passport .stamp{aspect-ratio:1;background:var(--bg-cream-2);border:2px dashed var(--ink-30);color:var(--ink-30);border-radius:50%;justify-content:center;align-items:center;font-size:28px;display:flex}.passport .stamp.collected{background:var(--shroom-red);color:#fff;border:2px solid var(--shroom-red-deep);animation:.45s cubic-bezier(.2,1.5,.4,1) both stamp-in;transform:rotate(-8deg)}@keyframes stamp-in{0%{opacity:0;transform:rotate(40deg)scale(2.5)}60%{opacity:1;transform:rotate(-8deg)scale(1.05)}to{transform:rotate(-8deg)scale(1)}}.foot{text-align:center;color:var(--ink-30);padding:16px 20px 24px;font-size:12px}.foot a{color:var(--ink-50);border-bottom:1px dashed var(--ink-30);text-decoration:none}@media (width<=600px){.scene{padding:24px 20px 32px}.scene h1{font-size:clamp(32px,8vw,40px)}.scene .lead{font-size:16px}.station-grid{gap:10px}.station-card{padding:18px 16px}.big-btn{padding:18px 24px;font-size:20px}.passport .stamps{gap:6px}}.eye-care-banner{color:#f4ecd4;letter-spacing:.08em;-webkit-user-select:none;user-select:none;background:linear-gradient(#9dae82 0%,#7b9263 100%);border-bottom:1px solid #3a32262e;justify-content:center;align-items:center;gap:8px;padding:6px 14px;font-size:12px;display:flex}.eye-care-icon{font-size:14px;line-height:1}.eye-care-text{letter-spacing:.06em;font-weight:500}.build-tag{letter-spacing:.04em;opacity:.85;background:#f4ecd433;border-radius:999px;margin-left:12px;padding:1px 8px;font-family:ui-monospace,monospace;font-size:10px}@media (width<=400px){.build-tag{display:none}}@media (width<=600px){.eye-care-banner{padding:5px 12px;font-size:11px}}.big-back-btn{background:var(--paper,#faefd9);border:2px solid var(--ink-90,#2c2418);width:max-content;max-width:calc(100% - 40px);font:inherit;color:var(--ink-90,#2c2418);cursor:pointer;box-shadow:0 3px 0 var(--ink-90,#2c2418);border-radius:999px;align-items:center;gap:10px;margin:14px auto 4px;padding:12px 22px;font-size:16px;font-weight:600;transition:background .15s,transform .1s,box-shadow .15s;display:flex}.big-back-btn:hover{background:color-mix(in srgb, var(--paper) 80%, var(--ink-90) 8%);box-shadow:0 4px 0 var(--ink-90,#2c2418);transform:translateY(-1px)}.big-back-btn:active{box-shadow:0 1px 0 var(--ink-90,#2c2418);transform:translateY(2px)}.big-back-arrow{font-size:22px;line-height:1}.big-back-text{letter-spacing:.02em}@media (width<=600px){.big-back-btn{width:auto;margin:10px 20px 4px;padding:14px 18px;font-size:15px}.big-back-arrow{font-size:20px}}.scene.hub{padding-top:30px}.hub-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:28px 0 24px;display:grid}.hub-card{border:2px solid var(--ink-15);background:var(--paper);cursor:pointer;font:inherit;text-align:left;--card-theme:#c04b2d;border-radius:18px;flex-direction:column;align-items:flex-start;gap:8px;padding:26px 22px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;position:relative}.hub-card:before{content:"";background:linear-gradient(135deg, color-mix(in srgb, var(--card-theme) 12%, transparent), transparent 60%);pointer-events:none;border-radius:18px;position:absolute;inset:0}.hub-card:hover{border-color:var(--card-theme);box-shadow:0 12px 28px -10px color-mix(in srgb, var(--card-theme) 35%, transparent);transform:translateY(-4px)}.hub-card:active{transform:translateY(-1px)}.hub-card .hub-card-emoji{font-size:44px;line-height:1}.hub-card .hub-card-name{font-family:var(--font-display,"Newsreader", serif);color:var(--ink-90);letter-spacing:-.01em;font-size:24px;font-weight:600}.hub-card .hub-card-tag{color:var(--ink-50);font-size:13px;line-height:1.55}.hub-card .hub-card-cta{color:var(--card-theme);letter-spacing:.02em;margin-top:6px;font-size:13px;font-weight:600}.hub-card .hub-card-badge{color:var(--ink-50);background:var(--paper-80,#f4e4bd);letter-spacing:.04em;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600;position:absolute;top:12px;right:12px}.hub-card-soon{opacity:.55;cursor:not-allowed}.hub-card-soon:hover{box-shadow:none;border-color:var(--ink-15);transform:none}.hub-privacy{text-align:center;color:var(--ink-50);letter-spacing:.06em;opacity:.7;margin-top:30px;padding:12px 16px;font-size:12px}.hub-privacy p{margin:0}.hub-section{margin-top:30px}.hub-section-head{margin-bottom:14px}.hub-section-title{font-family:var(--font-display,"Fraunces", serif);color:var(--ink,#3a3226);letter-spacing:-.01em;margin:0 0 4px;font-size:22px;font-weight:600}.hub-section-desc{color:var(--ink-50);letter-spacing:.02em;margin:0;font-size:13px}.hub-card-badge.new{background:var(--leaf,#779c5c);color:#f4ecd4;font-weight:700}.hub-extras{text-align:center;margin-top:28px}.hub-extra-link{border:1.5px dashed var(--ink-30);color:var(--ink-50);font:inherit;cursor:pointer;background:0 0;border-radius:999px;padding:10px 24px;font-size:14px;transition:all .15s}.hub-extra-link:hover{background:color-mix(in srgb, var(--paper-shadow) 50%, transparent);color:var(--ink,#3a3226)}.scene-lookdo{padding-top:14px}.lookdo-levels{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:24px;display:grid}.lookdo-level-card{background:var(--paper,#ece0be);border:2px solid var(--paper-shadow,#c7b68b);cursor:pointer;font:inherit;text-align:left;border-radius:14px;flex-direction:column;align-items:flex-start;gap:6px;padding:20px 18px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.lookdo-level-card:hover{border-color:var(--shroom-red,#b86855);transform:translateY(-2px);box-shadow:0 6px 18px #3a32261a}.lookdo-level-card .lvl-code{font-family:var(--font-display,"Fraunces", serif);color:var(--shroom-red,#b86855);font-size:36px;font-weight:700;line-height:1}.lookdo-level-card .lvl-name{color:var(--ink,#3a3226);font-size:18px;font-weight:600}.lookdo-level-card .lvl-desc{color:var(--ink-50);font-size:13px;line-height:1.5}.lookdo-prompt{justify-content:center;align-items:center;min-height:60px;margin:30px 0 20px;display:flex}.lookdo-status{font-family:var(--font-display,"Fraunces", serif);color:var(--ink,#3a3226);text-align:center;letter-spacing:-.01em;margin:0;font-size:22px;font-weight:500}.lookdo-status strong{color:var(--shroom-red,#b86855);font-weight:700}.lookdo-status.correct{color:var(--leaf,#779c5c)}.lookdo-status.wrong{color:var(--ink-50)}.lookdo-buttons{grid-template-columns:repeat(2,1fr);gap:18px;margin:20px 0 12px;display:grid}.lookdo-color-btn{aspect-ratio:2;font-family:var(--font-display,"Fraunces", serif);cursor:pointer;letter-spacing:.04em;text-shadow:0 2px 4px #0000002e;border:3px solid #0003;border-radius:16px;font-size:28px;font-weight:700;transition:transform .12s,box-shadow .12s,opacity .12s;box-shadow:0 6px #0000002e,0 10px 22px #0000001f}.lookdo-color-btn:active:not(:disabled){transform:translateY(5px);box-shadow:0 1px #0000002e,0 4px 10px #0000001a}.lookdo-color-btn:disabled{opacity:.65;cursor:not-allowed}.scene-log{padding-top:14px}.log-overview{grid-template-columns:repeat(3,1fr);gap:12px;margin:24px 0;display:grid}.log-stat{background:var(--paper,#ece0be);border:1px solid var(--paper-shadow,#c7b68b);text-align:center;border-radius:12px;padding:18px 12px}.log-stat-num{font-family:var(--font-display,"Fraunces", serif);color:var(--ink,#3a3226);font-size:38px;font-weight:700;line-height:1}.log-stat-label{color:var(--ink-50);letter-spacing:.08em;margin-top:6px;font-size:12px}.log-level-grid,.log-day-list{flex-direction:column;gap:8px;margin-top:8px;display:flex}.log-level-row,.log-day{background:var(--paper,#ece0be);border:1px solid var(--paper-shadow,#c7b68b);border-radius:10px;justify-content:space-between;padding:12px 16px;font-size:14px;display:flex}.log-level-name{color:var(--ink,#3a3226)}.log-level-stats{color:var(--ink,#3a3226);font-weight:500}.log-day-date{color:var(--ink-50)}.log-day-data{color:var(--ink,#3a3226)}.log-day.empty{opacity:.45}.log-tip{background:color-mix(in srgb, var(--paper) 70%, var(--ink-90) 6%);border-left:3px solid var(--leaf,#779c5c);color:var(--ink-50);border-radius:4px;margin-top:28px;padding:16px 18px;font-size:14px;line-height:1.6}.log-tip p{margin:0}.log-tip strong{color:var(--ink,#3a3226)}@media (width<=600px){.lookdo-color-btn{font-size:22px}.log-overview{gap:8px}.log-stat-num{font-size:30px}.log-stat{padding:14px 8px}}.hub-footer-note{background:color-mix(in srgb, var(--paper) 75%, var(--ink-90) 6%);border-left:3px solid var(--ink-30);border-radius:4px;margin-top:20px;padding:14px 16px}.hub-footer-note p{color:var(--ink-50);margin:0;font-size:13px;font-style:italic;line-height:1.6}.brand-emoji{margin-right:4px;font-size:24px;line-height:1}.scene-lift{padding-top:14px}.lift-shell-wrap{flex-direction:column;align-items:center;gap:16px;margin:16px 0 20px;display:flex}.lift-display{background:linear-gradient(#1a2a1a 0%,#0d1a0d 100%);border:3px solid #3a3226;border-radius:10px;justify-content:center;align-items:center;gap:12px;min-width:160px;padding:12px 20px;display:flex;box-shadow:inset 0 2px 8px #00000080,0 4px 10px #00000026}.lift-display-screen{background:#050d05;border:1px solid #2a1f0e;border-radius:4px;justify-content:center;align-items:center;min-width:100px;height:60px;display:flex}.lift-floor-num{color:#0f6;letter-spacing:4px;text-shadow:0 0 8px #00ff66b3,0 0 14px #0f66;font-family:Courier New,monospace;font-size:52px;font-weight:700;line-height:1}.lift-arrows{flex-direction:column;gap:6px;display:flex}.lift-arrow{color:#2a3a2a;font-size:22px;line-height:1;transition:color .2s,text-shadow .2s}.lift-arrow.active{color:#0f6;text-shadow:0 0 8px #0f6c;animation:.8s ease-in-out infinite liftArrowBlink}@keyframes liftArrowBlink{0%,to{opacity:1}50%{opacity:.4}}.lift-svg{filter:drop-shadow(0 12px 22px #0000002e);width:clamp(220px,70vw,320px);height:auto}.lift-doors .lift-door{transform-origin:50%;transition:transform 1.1s cubic-bezier(.65,0,.35,1)}.lift-doors.closed .lift-door-left,.lift-doors.closed .lift-door-right{transform:translate(0)}.lift-doors.open .lift-door-left{transform:translate(-98px)}.lift-doors.open .lift-door-right{transform:translate(98px)}.lift-doors.open .lift-door-seam{opacity:0}.lift-doors.closed .lift-door-seam{opacity:1}.lift-panel{background:linear-gradient(#dfd0a4 0%,#c8b68a 100%);border:2px solid #3a3226;border-radius:14px;max-width:420px;margin:16px auto 0;padding:16px 18px;box-shadow:0 4px #8a7559,0 8px 20px #0000001f}.lift-panel-title{text-align:center;font-family:var(--font-display,"Fraunces", serif);color:var(--ink,#3a3226);letter-spacing:.18em;opacity:.6;margin-bottom:12px;font-size:13px}.lift-panel-grid{flex-direction:column;gap:8px;display:flex}.lift-panel-row{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.lift-floor-btn{aspect-ratio:1;width:100%;color:var(--ink,#3a3226);font-family:var(--font-display,"Fraunces", serif);cursor:pointer;background:#ece0be;border:2px solid #6e6253;border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:600;transition:all .15s;display:flex;box-shadow:0 2px #8a7559}.lift-floor-btn:hover:not(:disabled){background:var(--shroom-red,#b86855);color:#f4ecd4;transform:translateY(-1px);box-shadow:0 3px #8e4a40}.lift-floor-btn:active:not(:disabled){transform:translateY(2px);box-shadow:0 0 #8a7559}.lift-floor-btn.current{background:var(--leaf,#779c5c);color:#f4ecd4;cursor:not-allowed;border-color:#5c7f44;box-shadow:0 2px #5c7f44,inset 0 0 10px #0000002e}.lift-floor-btn:disabled:not(.current){opacity:.4;cursor:not-allowed}.lift-panel-hint{text-align:center;color:var(--ink-50);margin-top:10px;font-size:12px;font-style:italic}.lift-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:8px;display:flex}@media (width<=600px){.lift-svg{width:240px}.lift-floor-num{font-size:42px}.lift-display{min-width:140px;padding:10px 16px}.lift-floor-btn{font-size:16px}.lift-panel{padding:12px 14px}}.scene-traffic{--phase-color:#d9322e;padding-top:20px}.traffic-toggle{background:var(--ink-90,#2c2418);border-radius:999px;gap:6px;margin:0 auto 20px;padding:4px;display:inline-flex}.mode-pill{color:var(--paper-80,#f4e4bd);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:8px 18px;font-size:14px;font-weight:500;transition:background .18s,color .18s}.mode-pill.active{background:var(--paper,#faefd9);color:var(--ink-90,#2c2418)}.traffic-stage{justify-content:center;align-items:center;gap:28px;margin:24px 0 28px;padding:20px 0;display:flex}.traffic-illu{filter:drop-shadow(0 12px 22px #0000002e);width:160px;height:auto}.traffic-illu .lamp.on circle:first-child,.signal-svg .lamp.on circle:first-child{transform-origin:50%;animation:1.4s ease-in-out infinite lampPulse}.traffic-stand-row{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:18px;margin:20px 0 16px;padding:16px 8px;display:flex}.signal-stand{flex-direction:column;align-items:center;gap:6px;display:flex}.signal-svg{filter:drop-shadow(0 6px 14px #0000002e);width:64px;height:auto}.signal-label{flex-direction:column;align-items:center;gap:2px;display:flex}.signal-symbol{color:var(--ink-90,#2c2418);font-size:22px;font-weight:700;line-height:1}.signal-name{letter-spacing:.08em;color:var(--ink-50);font-size:12px}.traffic-countdown.big{margin:8px auto 12px}.phase-strip{justify-content:center;gap:8px;margin:10px 0 16px;display:flex}.phase-dot{border:1.5px solid var(--ink-30);background:var(--paper);width:28px;height:28px;color:var(--ink-50);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;transition:all .18s;display:flex}.phase-dot.done{background:var(--ink-30);color:var(--paper);border-color:var(--ink-30)}.phase-dot.active{background:var(--phase-color,#2ba84a);color:#fff;border-color:var(--phase-color,#2ba84a);box-shadow:0 0 0 4px color-mix(in srgb, var(--phase-color) 25%, transparent);transform:scale(1.15)}@keyframes lampPulse{0%,to{opacity:1;filter:drop-shadow(0 0 4px var(--phase-color))}50%{opacity:.88;filter:drop-shadow(0 0 12px var(--phase-color))}}.traffic-countdown{font-family:var(--font-display,"Newsreader", serif);flex-direction:column;justify-content:center;align-items:center;line-height:1;display:flex}.countdown-num{letter-spacing:-.04em;font-size:clamp(80px,18vw,120px);font-weight:600;animation:1s ease-in-out countTick}.countdown-unit{color:var(--ink-50);letter-spacing:.1em;margin-top:6px;font-size:20px}@keyframes countTick{0%{opacity:.8;transform:scale(1.08)}20%{opacity:1;transform:scale(1)}to{opacity:1;transform:scale(1)}}.traffic-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:4px;display:flex}.traffic-tip{background:color-mix(in srgb, var(--paper) 75%, var(--ink-90) 6%);border-left:3px solid var(--phase-color);border-radius:4px;margin-top:24px;padding:14px 18px}.traffic-tip p{color:var(--ink-50);margin:0;font-size:13px;font-style:italic;line-height:1.55}@media (width<=600px){.traffic-stage{gap:16px}.traffic-illu{width:130px}.countdown-num{font-size:clamp(72px,22vw,100px)}.hub-card{padding:22px 18px}.hub-card .hub-card-emoji{font-size:38px}.hub-card .hub-card-name{font-size:22px}.traffic-stand-row{gap:10px}.signal-svg{width:50px}.signal-symbol{font-size:18px}.phase-dot{width:24px;height:24px;font-size:11px}}
