@import "https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&family=Roboto+Mono:wght@400;500&display=swap";:root{--c-bg:#0d1117;--c-surface:#161b22;--c-surface-2:#21262d;--c-surface-3:#2d333b;--c-border:#ffffff14;--c-border-hi:#ffffff29;--c-accent:#f0883e;--c-accent-dim:#f0883e2e;--c-accent-glow:#f0883e59;--c-success:#3fb950;--c-success-dim:#3fb95026;--c-danger:#f85149;--c-danger-dim:#f8514926;--c-info:#58a6ff;--c-text:#e6edf3;--c-text-muted:#8b949e;--c-text-faint:#484f58;--c-speaker-respo:#c53d23;--c-speaker-respo-glow:#c53d2373;--c-speaker-antoine:#c99519;--c-speaker-antoine-glow:#c9951973;--font-ui:"Roboto", "Segoe UI", sans-serif;--font-mono:"Roboto Mono", monospace;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-pill:999px;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 12px #00000080, 0 2px 4px #0000004d;--shadow-lg:0 16px 48px #0009, 0 4px 12px #0006;--shadow-accent:0 0 24px var(--c-accent-glow);--glass-bg:#161b22e0;--glass-blur:blur(12px) saturate(1.4);--glass-border:1px solid var(--c-border);--t-fast:.12s ease;--t-base:.22s ease;--t-slow:.4s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--c-bg);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;width:100vw;height:100vh;overflow:hidden}#canvas{display:block}#progress-bar{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:var(--glass-border);z-index:250;align-items:center;gap:14px;padding:8px 24px;display:flex;position:fixed;top:0;left:0;right:0}#progress-bar span{color:var(--c-text-muted);text-transform:uppercase;letter-spacing:2px;margin-right:4px;font-size:10px;font-weight:700}.level-dot{background:var(--c-surface-2);border:1.5px solid var(--c-border);width:30px;height:30px;color:var(--c-text-faint);transition:all var(--t-base);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;position:relative}.level-dot:after{content:"";opacity:0;transition:opacity var(--t-base);border-radius:50%;position:absolute;inset:-3px}.level-dot:hover{border-color:var(--c-accent);color:var(--c-text);transform:scale(1.1)}.level-dot.active{background:var(--c-accent);border-color:var(--c-accent);color:#fff;box-shadow:0 0 12px var(--c-accent-glow)}.level-dot.done{background:var(--c-success-dim);border-color:var(--c-success);color:var(--c-success)}.level-dot--alt{border-style:dashed;border-color:var(--c-info);color:var(--c-info);width:34px;margin-left:16px;font-size:10px}.level-dot--alt:hover{border-color:var(--c-info);color:#fff;background:#58a6ff26}.level-dot--alt.active{background:var(--c-info);border-color:var(--c-info);color:#fff;box-shadow:0 0 12px #58a6ff66}#progress-bar .dot-connector{background:var(--c-border);flex:1;max-width:20px;height:1px}.screen{z-index:200;width:100%;height:100%;transition:opacity var(--t-slow);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}.screen.hidden{opacity:0;pointer-events:none}#intro-screen{background:radial-gradient(at 30% 20%,#f0883e14 0%,#0000 60%),radial-gradient(at 70% 80%,#58a6ff0f 0%,#0000 60%),linear-gradient(160deg,#0d1117 0% 100%)}.lang-selector{z-index:10;gap:6px;display:flex;position:absolute;top:16px;right:16px}.lang-btn{color:#fff;cursor:pointer;letter-spacing:.05em;background:#0000004d;border:1px solid #fff6;border-radius:4px;padding:4px 10px;font-size:12px;font-weight:700}.lang-btn.active{background:#ffffff40;border-color:#fff}.intro-badge{background:var(--c-accent-dim);border:1px solid var(--c-accent);color:var(--c-accent);border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:2.5px;align-items:center;gap:6px;margin-bottom:28px;padding:5px 14px;font-size:10px;font-weight:700;display:inline-flex}.intro-badge:before{content:"";background:var(--c-accent);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.intro-title{color:var(--c-text);text-align:center;letter-spacing:-1.5px;margin-bottom:16px;font-size:56px;font-weight:900;line-height:1.05}.intro-title span{color:var(--c-accent)}.intro-time{font-family:var(--font-mono);color:var(--c-text-muted);background:var(--c-surface-2);border:var(--glass-border);border-radius:var(--r-pill);margin-bottom:20px;padding:4px 12px;font-size:13px}.intro-subtitle{color:var(--c-text-muted);text-align:center;max-width:520px;margin-bottom:36px;font-size:17px;line-height:1.7}.btn{background:var(--c-accent);color:#fff;border-radius:var(--r-md);font-family:var(--font-ui);cursor:pointer;text-transform:uppercase;letter-spacing:1.2px;transition:all var(--t-base);box-shadow:var(--shadow-sm), inset 0 1px 0 #ffffff1f;border:none;padding:13px 32px;font-size:14px;font-weight:700;position:relative;overflow:hidden}.btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff14 0%,#0000 100%);position:absolute;inset:0}.btn:hover{box-shadow:var(--shadow-md), var(--shadow-accent);background:#f0975a;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.secondary{background:var(--c-surface-2);border:var(--glass-border);color:var(--c-text-muted);box-shadow:var(--shadow-sm)}.btn.secondary:hover{background:var(--c-surface-3);color:var(--c-text);box-shadow:var(--shadow-md)}.btn.green{background:var(--c-success);box-shadow:var(--shadow-sm), 0 0 16px #3fb9504d}.btn.green:hover{box-shadow:var(--shadow-md), 0 0 24px #3fb95066;background:#4fc760}#level-intro-screen{-webkit-backdrop-filter:blur(16px)saturate(1.2);background:#000000bf}.level-intro-card{background:var(--c-surface);border:var(--glass-border);border-top:2px solid var(--c-accent);border-radius:var(--r-xl);text-align:center;max-width:580px;box-shadow:var(--shadow-lg);animation:card-in var(--t-slow) ease both;padding:40px 48px}@keyframes card-in{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.level-num{font-family:var(--font-mono);color:var(--c-accent);text-transform:uppercase;letter-spacing:3px;margin-bottom:10px;font-size:10px;font-weight:700}.level-title{color:var(--c-text);letter-spacing:-.5px;margin-bottom:16px;font-size:30px;font-weight:800}.level-situation{color:var(--c-text-muted);white-space:pre-line;margin-bottom:32px;font-size:14px;line-height:1.75}#hud{z-index:100;position:fixed;top:50px;right:16px}.hud-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--r-lg);min-width:190px;box-shadow:var(--shadow-md);padding:12px 16px}.hud-title{font-family:var(--font-mono);color:var(--c-accent);text-transform:uppercase;letter-spacing:2px;border-bottom:1px solid var(--c-border);margin-bottom:10px;padding-bottom:8px;font-size:9px;font-weight:700}.epi-item{color:var(--c-text-faint);transition:color var(--t-base);align-items:center;gap:9px;padding:4px 0;font-size:12.5px;font-weight:500;display:flex}.epi-item.collected{color:var(--c-success)}.epi-item .check{background:var(--c-surface-3);border:1.5px solid var(--c-border);width:15px;height:15px;transition:all var(--t-base);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.epi-item.collected .check{background:var(--c-success-dim);border-color:var(--c-success);box-shadow:0 0 6px #3fb9504d}.epi-item.collected .check:after{content:"✓";color:var(--c-success);font-size:9px;font-weight:900;line-height:1}#timer-display{z-index:100;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:10px 16px;position:fixed;top:50px;left:16px}#timer-display .t-label{font-family:var(--font-mono);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:2px;font-size:9px;font-weight:700}#timer-display .t-value{font-family:var(--font-mono);color:var(--c-text);letter-spacing:2px;font-size:26px;font-weight:700}#instruction{top:56px;left:50%;bottom:unset;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);color:var(--c-text-muted);border-radius:var(--r-pill);z-index:100;white-space:nowrap;box-shadow:var(--shadow-sm);padding:9px 20px;font-size:12.5px;position:fixed;transform:translate(-50%)}#controls-hint{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);color:var(--c-text-muted);border-radius:var(--r-pill);z-index:100;white-space:nowrap;box-shadow:var(--shadow-sm);padding:9px 20px;font-size:12.5px;position:fixed;bottom:16px;left:50%;transform:translate(-50%)}kbd{background:var(--c-surface-3);color:var(--c-text);font-family:var(--font-mono);border:1px solid var(--c-border-hi);border-radius:4px;padding:2px 6px;font-size:10.5px;font-weight:700;box-shadow:0 1px #0006}#dialog-box{background:var(--c-surface);border-top:1px solid var(--c-border);border-top-left-radius:var(--r-xl);border-top-right-radius:var(--r-xl);z-index:300;transition:transform var(--t-base);padding:20px 32px 28px;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 32px #00000080}#dialog-box.hidden{transform:translateY(100%)}#dialog-box:before{content:"";background:var(--c-border-hi);border-radius:var(--r-pill);width:36px;height:3px;margin:0 auto 16px;display:block}#dialog-speaker{font-family:var(--font-mono);color:var(--c-accent);text-transform:uppercase;letter-spacing:2px;align-items:center;gap:8px;margin-bottom:8px;font-size:10px;font-weight:700;display:flex}#dialog-speaker:before{content:"";background:var(--c-accent);width:6px;height:6px;box-shadow:0 0 6px var(--c-accent-glow);border-radius:50%}#dialog-speaker.speaker-respo{color:var(--c-speaker-respo)}#dialog-speaker.speaker-respo:before{background:var(--c-speaker-respo);box-shadow:0 0 6px var(--c-speaker-respo-glow)}#dialog-speaker.speaker-antoine{color:var(--c-speaker-antoine)}#dialog-speaker.speaker-antoine:before{background:var(--c-speaker-antoine);box-shadow:0 0 6px var(--c-speaker-antoine-glow)}#dialog-text{color:var(--c-text);max-width:740px;margin-bottom:16px;font-size:15px;line-height:1.65}#dialog-options{flex-direction:column;gap:6px;max-width:740px;display:flex}.dialog-option{background:var(--c-surface-2);border:1px solid var(--c-border);color:var(--c-text-muted);border-radius:var(--r-md);cursor:pointer;text-align:left;transition:all var(--t-fast);font-size:13.5px;font-family:var(--font-ui);align-items:center;gap:10px;padding:10px 14px;display:flex}.dialog-option:before{content:"›";color:var(--c-text-faint);transition:color var(--t-fast), transform var(--t-fast);flex-shrink:0;font-size:16px;line-height:1}.dialog-option:hover{background:var(--c-surface-3);border-color:var(--c-accent);color:var(--c-text);transform:translate(2px)}.dialog-option:hover:before{color:var(--c-accent)}#action-hint{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--c-border-hi);color:var(--c-text);border-radius:var(--r-pill);z-index:150;pointer-events:none;transition:opacity var(--t-base);box-shadow:var(--shadow-sm);white-space:nowrap;text-align:center;padding:7px 18px;font-size:13px;font-weight:600;position:fixed;bottom:130px;left:50%;transform:translate(-50%)}#action-hint.hidden{opacity:0}#timer-tutorial{z-index:500;background:#000000b8;flex-direction:column;justify-content:flex-start;align-items:center;gap:18px;padding-top:90px;display:flex;position:fixed;inset:0}#timer-tutorial.hidden{display:none}#timer-tutorial-arrow{color:var(--c-accent);font-size:48px;animation:.6s infinite alternate arrow-bounce-left;position:absolute;top:100px;left:130px}@keyframes arrow-bounce-left{0%{opacity:1;transform:rotate(-45deg)translateY(0)}to{opacity:.6;transform:rotate(-45deg)translateY(-8px)}}#timer-tutorial-msg{background:var(--c-surface);border:1px solid var(--c-border-hi);border-radius:var(--r-xl);color:var(--c-text);text-align:center;max-width:380px;box-shadow:var(--shadow-lg);margin-top:60px;padding:20px 28px;font-size:15px;line-height:1.6}#timer-tutorial-btn{margin-top:8px}#tp-warning{background:var(--c-danger);color:#fff;border-radius:var(--r-lg);z-index:400;text-align:center;box-shadow:var(--shadow-lg), 0 0 32px #f8514980;padding:10px 22px;font-size:13px;font-weight:700;transition:opacity .3s;animation:.6s infinite alternate danger-pulse;position:fixed;top:12%;left:50%;transform:translate(-50%)}@keyframes danger-pulse{0%{box-shadow:var(--shadow-lg), 0 0 16px #f8514966}to{box-shadow:var(--shadow-lg), 0 0 40px #f85149b3}}#tp-warning.hidden{opacity:0;pointer-events:none}#tp-honk-bubble{color:#222;border:3px solid var(--c-danger);z-index:410;text-align:center;min-width:180px;box-shadow:var(--shadow-lg);background:#fff;border-radius:18px;flex-direction:column;align-items:center;gap:6px;padding:14px 20px;font-size:16px;font-weight:700;animation:.25s cubic-bezier(.34,1.56,.64,1) both honk-pop;display:flex;position:fixed;bottom:90px;left:50%;transform:translate(-50%)}#tp-honk-bubble:after{content:"";border:8px solid #0000;border-top-color:var(--c-danger);position:absolute;bottom:-16px;left:50%;transform:translate(-50%)}#tp-honk-bubble:before{content:"";z-index:1;border:7px solid #0000;border-top-color:#fff;position:absolute;bottom:-12px;left:50%;transform:translate(-50%)}#tp-honk-icon{font-size:28px;line-height:1;animation:.15s infinite alternate honk-shake}@keyframes honk-shake{0%{transform:rotate(-8deg)scale(1)}to{transform:rotate(8deg)scale(1.15)}}#tp-honk-text{color:var(--c-danger);font-size:15px}#tp-honk-bubble.hidden{display:none}@keyframes honk-pop{0%{opacity:0;transform:translate(-50%)scale(.5)}to{opacity:1;transform:translate(-50%)scale(1)}}#feedback-screen{-webkit-backdrop-filter:blur(20px)saturate(1.2);background:#000c}.video-card{background:var(--c-surface);border:var(--glass-border);border-radius:var(--r-xl);width:92vw;max-width:860px;box-shadow:var(--shadow-lg);flex-direction:column;align-items:center;gap:24px;padding:32px 36px;display:flex}.video-title{color:var(--c-text);text-align:center;font-size:1.25rem;font-weight:700}.video-wrapper{aspect-ratio:16/9;border-radius:var(--r-lg);background:#000;width:100%;position:relative;overflow:hidden}.video-wrapper iframe{border:none;width:100%;height:100%}.video-loader{color:#ffffffb3;z-index:2;background:#111;flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:.9rem;transition:opacity .4s;display:flex;position:absolute;inset:0}.video-loader.hidden{opacity:0;pointer-events:none}.video-spinner{border:4px solid #ffffff26;border-top-color:#fff;border-radius:50%;width:44px;height:44px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.feedback-card{background:var(--c-surface);border:var(--glass-border);border-radius:var(--r-xl);text-align:center;max-width:580px;box-shadow:var(--shadow-lg);animation:card-in var(--t-slow) ease both;padding:44px 52px}.feedback-icon{filter:drop-shadow(0 4px 12px #0006);margin-bottom:14px;font-size:48px;display:block}.feedback-title{color:var(--c-text);letter-spacing:-.3px;margin-bottom:14px;font-size:22px;font-weight:800}.feedback-text{color:var(--c-text-muted);white-space:pre-line;text-align:left;margin-bottom:28px;font-size:14px;line-height:1.75}#fb-stars{justify-content:center;gap:10px;margin-bottom:24px;display:flex}#fb-stars.hidden{display:none}.fb-star{color:var(--c-text-faint);transition:color var(--t-base), filter var(--t-base);font-size:40px;line-height:1}.fb-star.earned{color:#f5c518;filter:drop-shadow(0 2px 8px #f5c51899)}#production-gauge{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--r-lg);min-width:210px;box-shadow:var(--shadow-md);top:auto;left:8%;bottom:calc(var(--dialog-height,220px) + 12px);padding:10px 16px;position:fixed;transform:translate(-50%)}.gauge-label{font-family:var(--font-mono);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;font-size:9px;font-weight:700}.gauge-bar-bg{background:var(--c-surface-3);border-radius:var(--r-pill);height:8px;overflow:hidden}.gauge-bar{border-radius:var(--r-pill);background:var(--c-success);width:0%;height:100%;transition:width .5s,background .5s;box-shadow:0 0 6px}.gauge-value{font-family:var(--font-mono);color:var(--c-text);text-align:right;margin-top:5px;font-size:12px;font-weight:700}@keyframes gauge-bump{0%{color:var(--c-text);font-size:12px}30%{color:#ff6b35;font-size:16px}60%{color:#fa5;font-size:14px}to{color:var(--c-text);font-size:12px}}.gauge-value-bump{animation:.45s ease-out forwards gauge-bump}#production-delay-feedback{z-index:9800;pointer-events:none;font-family:var(--font-ui);color:#f94;text-align:center;box-shadow:0 0 32px #ff660080, var(--shadow-lg);letter-spacing:.02em;background:#140a05eb;border:2px solid #f60;border-radius:14px;padding:18px 36px;font-size:22px;font-weight:800;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}#production-delay-feedback.prod-delay-hidden{display:none}#production-delay-feedback.prod-delay-visible{animation:.35s cubic-bezier(.22,1,.36,1) both prod-delay-in,.4s ease-in 1.4s both prod-delay-out;display:block}@keyframes prod-delay-in{0%{opacity:0;transform:translate(-50%,-46%)scale(.85)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}@keyframes prod-delay-out{0%{opacity:1}to{opacity:0}}#phone-ui{background:var(--c-surface);border:var(--glass-border);border-top:2px solid var(--c-success);border-radius:var(--r-xl);z-index:400;width:90%;max-width:380px;box-shadow:var(--shadow-lg);animation:card-in var(--t-base) ease both;padding:24px 28px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}#phone-ui.hidden{display:none}.phone-title{color:var(--c-text);text-align:center;letter-spacing:.3px;margin-bottom:16px;font-size:13px;font-weight:700}#phone-contacts{flex-direction:column;gap:7px;margin-bottom:14px;display:flex}#btn-close-phone{width:100%}#burn-hud{z-index:100;background:var(--c-danger-dim);border:1px solid var(--c-danger);color:var(--c-danger);border-radius:var(--r-md);font-size:12px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1px;padding:7px 13px;position:fixed;top:50px;right:16px;box-shadow:0 0 12px #f8514940}#burn-hud.hidden{display:none}#error-hud{z-index:100;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);align-items:center;gap:8px;padding:6px 12px;display:flex;position:fixed;top:50px;left:16px}#error-hud.hidden{display:none}.error-label{font-size:10px;font-weight:700;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--c-text-muted)}.error-cross{color:var(--c-text-faint);transition:color var(--t-base), text-shadow var(--t-base);font-size:16px;font-weight:700}.error-cross.active{color:var(--c-danger);text-shadow:0 0 8px #f8514999}#phone-indicator{z-index:110;pointer-events:none;transition:opacity var(--t-base);position:fixed;bottom:80px;left:20px}#phone-indicator.hidden{display:none}#phone-indicator.phone-open .phone-ind-shell{border-color:var(--c-success);box-shadow:0 0 14px #3fb95073}#phone-indicator.phone-open .phone-ind-screen{background:#3fb9501f}#phone-indicator.phone-open .phone-ind-key{color:var(--c-success)}.phone-ind-shell{border:2px solid var(--c-border-hi);background:var(--c-surface-2);width:200px;height:350px;box-shadow:var(--shadow-sm);transition:border-color var(--t-base), box-shadow var(--t-base);border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:5px 0 6px;display:flex}.phone-ind-notch{background:var(--c-text-faint);border-radius:var(--r-pill);flex-shrink:0;width:12px;height:3px}.phone-ind-screen{background:var(--c-surface-3);width:calc(100% - 6px);transition:background var(--t-base);border-radius:3px;flex:1;justify-content:center;align-items:center;display:flex}.phone-ind-key{font-family:var(--font-mono);color:var(--c-text-muted);transition:color var(--t-base);font-size:11px;font-weight:700}.phone-ind-home{border:1.5px solid var(--c-text-faint);border-radius:50%;flex-shrink:0;width:10px;height:10px}#phone-ind-screen{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:2px;padding:4px 3px;overflow:hidden}.phone-screen-title{color:var(--c-text);text-align:center;border-bottom:1px solid var(--c-border);flex-shrink:0;padding:2px 2px 3px;font-size:7px;font-weight:700;line-height:1.2}.phone-screen-item{color:var(--c-text-muted);background:var(--c-surface-2);white-space:nowrap;text-overflow:ellipsis;border-radius:2px;flex-shrink:0;padding:1px 2px;font-size:6px;overflow:hidden}#choice-popup{background:var(--c-surface);border:var(--glass-border);border-top:2px solid var(--c-accent);border-radius:var(--r-xl);z-index:400;width:90%;max-width:480px;box-shadow:var(--shadow-lg);animation:card-in var(--t-base) ease both;padding:24px 28px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}#choice-popup.hidden{opacity:0;pointer-events:none}#choice-popup h3{color:var(--c-text);margin-bottom:16px;font-size:15px;font-weight:600;line-height:1.55}.choice-btn{background:var(--c-surface-2);border:1px solid var(--c-border);width:100%;color:var(--c-text-muted);border-radius:var(--r-md);cursor:pointer;text-align:left;transition:all var(--t-fast);font-size:13px;font-family:var(--font-ui);margin-bottom:7px;padding:10px 14px;display:block}.choice-btn:hover{background:var(--c-surface-3);border-color:var(--c-accent);color:var(--c-text)}.choice-btn.good{border-color:var(--c-success)}.choice-btn.good:hover{background:var(--c-success-dim)}#action-menu{background:var(--c-surface);border:var(--glass-border);border-top:2px solid var(--c-accent);border-radius:var(--r-xl);z-index:400;width:92%;max-width:500px;max-height:80vh;box-shadow:var(--shadow-lg);animation:card-in var(--t-base) ease both;padding:20px 24px;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}#action-menu.hidden{display:none}.action-menu-title{color:var(--c-accent);text-align:center;text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:700;font-family:var(--font-mono);margin-bottom:14px}#action-menu-options{flex-direction:column;gap:7px;display:flex}#pedestrian-indicator{z-index:100;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);pointer-events:none;min-width:150px;padding:10px 16px;position:fixed;top:50px;right:16px}#pedestrian-indicator .ped-label{font-family:var(--font-mono);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:4px;font-size:9px;font-weight:700}#pedestrian-indicator .ped-value{font-family:var(--font-mono);letter-spacing:2px;color:var(--c-success);transition:color var(--t-base);margin-bottom:6px;font-size:26px;font-weight:700;line-height:1}#pedestrian-indicator .ped-bar-bg{background:var(--c-surface-3);border-radius:var(--r-pill);height:4px;overflow:hidden}#pedestrian-indicator .ped-bar{border-radius:var(--r-pill);background:var(--c-success);height:100%;transition:width var(--t-base), background var(--t-base);width:0%}#speed-display{z-index:100;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);width:72px;height:72px;box-shadow:var(--shadow-md);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:1px;display:flex;position:fixed;bottom:20px;right:16px}#speed-value{font-family:var(--font-mono);color:var(--c-text);text-align:center;width:100%;font-size:22px;font-weight:700;line-height:1}#speed-display .speed-unit{font-family:var(--font-mono);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:1px;text-align:center;width:100%;font-size:9px}#error-toast{-webkit-backdrop-filter:var(--glass-blur);border:1.5px solid var(--c-danger);color:var(--c-text);border-radius:var(--r-pill);z-index:155;pointer-events:none;white-space:normal;text-align:center;background:#f8514926;max-width:480px;padding:10px 20px;font-size:13px;font-weight:600;line-height:1.5;animation:.2s cubic-bezier(.34,1.56,.64,1) both error-toast-in;position:fixed;bottom:180px;left:50%;transform:translate(-50%);box-shadow:0 0 18px #f851494d}#error-toast.hidden{display:none}@keyframes error-toast-in{0%{opacity:0;transform:translate(-50%)scale(.92)}to{opacity:1;transform:translate(-50%)scale(1)}}@media (width<=600px){#error-toast{max-width:90vw;font-size:12px;bottom:140px}}#level5-mobile-controls{z-index:120;flex-direction:row;gap:10px;display:none;position:fixed;bottom:20px;right:16px}.mb5-btn{background:var(--glass-bg);width:64px;height:64px;-webkit-backdrop-filter:var(--glass-blur);border:1.5px solid var(--c-border-hi);border-radius:var(--r-lg);color:var(--c-text);font-family:var(--font-mono);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--t-fast);box-shadow:var(--shadow-sm);touch-action:manipulation;flex-direction:column;justify-content:center;align-items:center;gap:2px;font-size:18px;font-weight:700;display:flex}.mb5-btn span{font-family:var(--font-ui);color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:9px;font-weight:600}.mb5-btn:active,.mb5-btn.mb-active{background:var(--c-accent);border-color:var(--c-accent);box-shadow:var(--shadow-accent)}.mb5-btn.mb-active span{color:#fffc}#parking-controls{z-index:100;flex-direction:column;align-items:center;gap:6px;display:flex;position:fixed;bottom:20px;left:16px;transform:none}.ctrl-row{gap:6px;display:flex}.ctrl-btn{background:var(--glass-bg);width:46px;height:46px;-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--r-md);color:var(--c-text);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--t-fast);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:18px;display:flex}.ctrl-btn:active,.ctrl-btn.pressed{background:var(--c-accent);border-color:var(--c-accent);box-shadow:var(--shadow-accent)}#final-screen{background:radial-gradient(at 20% 30%,#f0883e0f 0%,#0000 55%),radial-gradient(at 80% 70%,#3fb9500d 0%,#0000 55%),linear-gradient(160deg,#0d1117 0% 100%)}.final-card{background:var(--c-surface);border:var(--glass-border);border-radius:var(--r-xl);text-align:center;max-width:620px;max-height:90vh;box-shadow:var(--shadow-lg);animation:card-in var(--t-slow) ease both;padding:40px 48px;overflow-y:auto}.final-title{color:var(--c-text);letter-spacing:-1px;margin-bottom:8px;font-size:34px;font-weight:900}.final-subtitle{color:var(--c-text-muted);margin-bottom:28px;font-size:15px;line-height:1.6}.lessons{text-align:left;margin-bottom:28px}.lesson{border-bottom:1px solid var(--c-border);align-items:flex-start;gap:14px;padding:12px 0;display:flex}.lesson-num{background:var(--c-accent-dim);border:1px solid var(--c-accent);color:var(--c-accent);width:24px;height:24px;font-family:var(--font-mono);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:10px;font-weight:700;display:flex}.lesson-text{color:var(--c-text-muted);font-size:13.5px;line-height:1.6}.final-card::-webkit-scrollbar{width:4px}.final-card::-webkit-scrollbar-track{background:0 0}.final-card::-webkit-scrollbar-thumb{background:var(--c-border-hi);border-radius:2px}.final-scene-label{letter-spacing:.08em;color:var(--c-accent);text-transform:uppercase;margin-bottom:6px;font-size:13px;font-weight:700}.final-stars-grid{text-align:left;flex-direction:column;gap:6px;margin:20px 0;display:flex}.final-level-row{background:var(--c-surface-hi,#ffffff0a);border:1px solid var(--c-border);border-radius:var(--r-md,8px);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.final-level-name{color:var(--c-text-muted);flex:1;font-size:13px}.final-level-stars{white-space:nowrap}.final-level-stars .fs{color:var(--c-border-hi);font-size:18px}.final-level-stars .fs.earned{color:#f5a623}.final-score-bar{background:var(--c-surface-hi,#ffffff0a);border:1px solid var(--c-border);border-radius:var(--r-md,8px);justify-content:center;align-items:center;gap:0;margin:20px 0;display:flex;overflow:hidden}.final-score-item{text-align:center;flex:1;padding:14px 12px}.final-score-sep{background:var(--c-border);align-self:stretch;width:1px}.final-score-label{letter-spacing:.07em;color:var(--c-text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:700}.final-score-value{color:var(--c-text);font-size:22px;font-weight:900;font-family:var(--font-mono)}.final-comment{color:var(--c-text-muted);background:var(--c-surface-hi,#ffffff0a);border-left:3px solid var(--c-accent);border-radius:0 var(--r-md,8px) var(--r-md,8px) 0;text-align:left;margin-bottom:24px;padding:16px;font-size:14px;line-height:1.7}@media (width<=600px){#progress-bar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;padding:6px 10px;overflow-x:auto}#progress-bar span{display:none}.level-intro-card,.feedback-card{border-radius:var(--r-lg);max-width:96vw;padding:24px 20px}.level-title{font-size:22px}.level-situation{font-size:13px}.feedback-title{font-size:18px}.feedback-text{font-size:13px}.intro-title{font-size:36px}.intro-subtitle{max-width:90vw;font-size:14px}#action-menu{max-width:96vw;max-height:70vh;padding:14px}.dialog-option{padding:10px 12px;font-size:13px}#phone-ui{max-width:96vw;padding:18px 16px}#instruction{white-space:normal;text-align:center;max-width:80vw;padding:7px 12px;font-size:11px}#controls-hint{display:none}#action-hint{white-space:normal;text-align:center;max-width:90vw;font-size:12px;bottom:100px}.phone-ind-shell{width:44px;height:78px}.phone-ind-screen{border-radius:2px}.phone-ind-key{font-size:14px}#level5-mobile-controls{gap:8px;bottom:12px;right:10px}.mb5-btn{width:58px;height:58px;font-size:16px}#error-hud{top:46px}.final-card{max-width:96vw;padding:24px 16px}}.tutorial-screen{z-index:200;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.tut-backdrop,.tut-card{pointer-events:auto}.tutorial-screen.tut-leaving{pointer-events:none}.tutorial-screen.tut-leaving .tut-card{animation:tut-card-out var(--t-base) ease forwards}.tutorial-screen.tut-leaving .tut-backdrop{animation:tut-fade-out var(--t-base) ease forwards}.tut-backdrop{-webkit-backdrop-filter:blur(20px)saturate(1.3);animation:tut-fade-in var(--t-slow) ease both;background:radial-gradient(#0000008c,#000000d9);position:absolute;inset:0}@keyframes tut-fade-in{0%{opacity:0}to{opacity:1}}@keyframes tut-fade-out{0%{opacity:1}to{opacity:0}}.tut-card{background:var(--c-surface);border:var(--glass-border);border-top:2px solid var(--c-accent);border-radius:var(--r-xl);width:92%;max-width:720px;max-height:92vh;box-shadow:var(--shadow-lg), 0 0 60px #f0883e1a;padding:28px 36px 24px;animation:.45s cubic-bezier(.2,.8,.2,1) both tut-card-in;position:relative;overflow-y:auto}@keyframes tut-card-in{0%{opacity:0;filter:blur(4px);transform:translateY(24px)scale(.96)}to{opacity:1;filter:none;transform:none}}@keyframes tut-card-out{to{opacity:0;transform:translateY(12px)scale(.98)}}.tut-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px;display:flex}.tut-level-badge{font-family:var(--font-mono);letter-spacing:2px;color:var(--c-accent);text-transform:uppercase;border:1px solid var(--c-accent-dim);border-radius:var(--r-pill);background:var(--c-accent-dim);padding:4px 10px;font-size:11px;font-weight:700}.tut-skip{color:var(--c-text-muted);font-family:var(--font-ui);cursor:pointer;border-radius:var(--r-sm);transition:background var(--t-base), color var(--t-base);background:0 0;border:none;padding:6px 10px;font-size:13px}.tut-skip:hover{color:var(--c-text);background:#ffffff0f}.tut-progress{justify-content:center;gap:8px;margin:14px 0 22px;display:flex}.tut-dot{width:24px;height:3px;transition:background var(--t-base), width var(--t-base), box-shadow var(--t-base);background:#ffffff26;border-radius:2px}.tut-dot.active{background:var(--c-accent);width:36px;box-shadow:0 0 12px var(--c-accent-glow)}.tut-dot.done{background:#f0883e80}.tut-body{text-align:center;flex-direction:column;align-items:center;min-height:280px;display:flex}.tut-step{flex-direction:column;align-items:center;width:100%;display:flex}.tut-step-enter{animation:tut-step-slide var(--t-slow) ease both}@keyframes tut-step-slide{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.tut-hero{width:88px;height:88px;color:var(--c-accent);filter:drop-shadow(0 0 18px var(--c-accent-glow));margin:4px 0 18px}.tut-hero .tut-svg{width:100%;height:100%}.tut-title{color:var(--c-text);margin-bottom:8px;font-size:26px;font-weight:700;line-height:1.2}.tut-subtitle{color:var(--c-text-muted);max-width:540px;margin-bottom:18px;font-size:15px;line-height:1.5}.tut-body p.tut-body{color:var(--c-text-muted);margin-top:14px;font-size:14px}.tut-footer{justify-content:space-between;gap:12px;margin-top:18px;display:flex}.tut-footer .btn{min-width:130px}.tut-footer .btn.ghost{border:1px solid var(--c-border-hi);color:var(--c-text-muted);background:0 0}.tut-footer .btn.ghost:hover{color:var(--c-text);border-color:var(--c-text-muted);background:#ffffff0a}.tut-footer .btn.primary{background:var(--c-accent);color:#1a0e04;box-shadow:0 0 20px var(--c-accent-glow);font-weight:700}.tut-footer .btn.primary:hover{filter:brightness(1.08);box-shadow:0 0 28px var(--c-accent-glow)}.tut-footer .btn.tut-final{animation:1.6s ease-in-out infinite tut-final-pulse}@keyframes tut-final-pulse{0%,to{box-shadow:0 0 20px var(--c-accent-glow)}50%{box-shadow:0 0 36px var(--c-accent), 0 0 12px var(--c-accent)}}.tut-footer .btn:disabled,.tut-footer .btn.hidden-soft{opacity:0;pointer-events:none}.keycap{width:54px;height:54px;font-family:var(--font-mono);color:#eaeaea;transition:transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);-webkit-user-select:none;user-select:none;background:linear-gradient(#2a2a32,#1a1a20);border:1px solid #ffffff1f;border-radius:10px;justify-content:center;align-items:center;margin:4px;font-size:18px;font-weight:700;display:inline-flex;box-shadow:0 4px #0d0d12,0 8px 18px #00000080,inset 0 1px #ffffff0f}.keycap.wide{letter-spacing:1px;width:130px;font-size:13px}.keycap.pressed{border-color:var(--c-accent);box-shadow:0 1px 0 #0d0d12, 0 0 24px var(--c-accent), inset 0 1px 0 #ffffff29;animation:none;transform:translateY(2px)}.kb-cluster{flex-direction:column;align-items:center;gap:4px;display:flex}.kb-row{justify-content:center;gap:4px;display:flex}.ctrl-panel{flex-wrap:wrap;justify-content:center;gap:18px 24px;width:100%;margin:8px 0 4px;display:flex}.ctrl-group{flex-direction:column;align-items:center;gap:8px;min-width:90px;display:flex}.ctrl-label{color:var(--c-text-muted);text-align:center;max-width:160px;font-size:12px;line-height:1.35}.ctrl-icon{width:48px;height:48px;color:var(--c-text);justify-content:center;align-items:center;display:flex}.ctrl-icon .tut-svg{width:100%;height:100%}.ctrl-mobile .ctrl-icon{color:var(--c-info)}.hazard-grid{grid-template-columns:repeat(3,1fr);gap:14px;width:100%;margin-top:10px;display:grid}.hazard-card{border-radius:var(--r-md);text-align:center;transition:transform var(--t-base), border-color var(--t-base), background var(--t-base);background:#ffffff08;border:1px solid #ffffff14;padding:18px 14px}.hazard-card:hover{background:#ffffff0d;border-color:currentColor;transform:translateY(-3px)}.hazard-card .h-icon{filter:drop-shadow(0 0 12px);width:42px;height:42px;margin:0 auto 10px}.hazard-card .h-icon .tut-svg{width:100%;height:100%}.hazard-card .h-title{color:var(--c-text);margin-bottom:4px;font-size:15px;font-weight:700}.hazard-card .h-sub{color:var(--c-text-muted);font-size:12px;line-height:1.4}.hazard-warn{color:var(--c-accent)}.hazard-danger{color:var(--c-danger)}.hazard-safe{color:var(--c-success)}.hazard-info{color:var(--c-info)}.obj-grid{grid-template-columns:repeat(5,1fr);gap:10px;width:100%;margin-top:6px;display:grid}.obj-item{border-radius:var(--r-md);transition:border-color var(--t-base), background var(--t-base), transform var(--t-base);background:#ffffff08;border:1px solid #ffffff14;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;display:flex}.obj-item:hover{border-color:var(--c-accent);background:var(--c-accent-dim);transform:translateY(-2px)}.obj-icon{width:38px;height:38px;color:var(--c-accent)}.obj-icon .tut-svg{width:100%;height:100%}.obj-label{color:var(--c-text-muted);text-align:center;font-size:11px;line-height:1.2}@media (width<=720px){.tut-card{padding:22px 18px 18px}.tut-title{font-size:22px}.tut-subtitle{font-size:14px}.tut-hero{width:64px;height:64px}.keycap{width:46px;height:46px;font-size:15px}.keycap.wide{width:110px;font-size:12px}.hazard-grid{grid-template-columns:1fr;gap:10px}.obj-grid{grid-template-columns:repeat(3,1fr)}.tut-footer .btn{flex:1;min-width:0}}
