*{margin:0;padding:0;box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}:root{--bg: #f5efe6;--surface-strong: rgba(255, 255, 255, .8);--border: rgba(58, 52, 43, .18);--border-strong: rgba(58, 52, 43, .32);--text: #2a241c;--text-soft: rgba(42, 36, 28, .78);--text-muted: rgba(42, 36, 28, .6);--accent: #d28e5c;--accent-strong: #b86f3d;--accent-soft: rgba(210, 142, 92, .18);--shadow-card: 0 16px 50px rgba(74, 60, 42, .18)}html,body{width:100%;height:100%;overflow:hidden;touch-action:none;-webkit-touch-callout:none;-webkit-text-size-adjust:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);height:100vh;height:100dvh;height:var(--app-height, 100dvh)}#app{position:fixed;inset:0;width:100%;height:100%;height:100dvh;height:var(--app-height, 100dvh);overflow:hidden;background:var(--bg);z-index:1}.seo-content{position:relative;z-index:0;font-size:14px;line-height:1.6;color:var(--text);padding:24px;-webkit-user-select:text;user-select:text}.seo-content h1,.seo-content h2,.seo-content h3{margin:12px 0 8px;font-weight:600}.seo-content h1{font-size:22px}.seo-content h2{font-size:18px}.seo-content h3{font-size:15px}.seo-content p,.seo-content ul,.seo-content ol{margin:6px 0;padding-left:1.2em}#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;image-rendering:-webkit-optimize-contrast;image-rendering:high-quality}#hud{position:absolute;inset:0;pointer-events:none;z-index:10}#hud>*{pointer-events:auto}#overlay{position:absolute;inset:0;z-index:20;pointer-events:none}#overlay.active{pointer-events:auto}#account-gate{position:fixed;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;background:#f5efe6c7;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .32s ease;padding:16px}#account-gate.show{opacity:1;pointer-events:auto}.gate-card{width:100%;max-width:440px;background:#fffffff2;border:1px solid rgba(58,52,43,.12);border-radius:18px;padding:36px 28px;text-align:center;box-shadow:0 12px 48px #3a342b1f;animation:gate-card-in .45s ease-out .1s both}@keyframes gate-card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.gate-title{font-size:22px;font-weight:500;letter-spacing:4px;color:var(--text);margin-bottom:6px}.gate-subtitle{font-size:11px;letter-spacing:3px;color:var(--text-muted);margin-bottom:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gate-tip{font-size:13px;line-height:1.7;color:var(--text-soft);margin-bottom:24px;letter-spacing:1px}.gate-tip strong{color:var(--text);font-weight:500}.gate-input{width:100%;box-sizing:border-box;padding:12px 14px;font-size:15px;letter-spacing:2px;text-align:center;border:1.5px solid rgba(58,52,43,.16);border-radius:10px;background:#ffffffb3;color:var(--text);margin-bottom:20px;font-family:inherit;transition:border-color .2s ease,background .2s ease}.gate-input:focus{outline:none;border-color:var(--accent);background:#fff}.gate-btn-group{display:flex;gap:12px;justify-content:center}.gate-btn{flex:1;max-width:180px;white-space:nowrap}@media (max-width: 480px){.gate-card{padding:28px 20px}.gate-title{font-size:19px;letter-spacing:3px}}.hud-top{position:absolute;top:calc(24px + env(safe-area-inset-top));left:50%;transform:translate(-50%);display:flex;gap:28px;align-items:center;padding:10px 22px;background:#ffffff8c;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:999px;font-size:14px;font-variant-numeric:tabular-nums;letter-spacing:.5px;color:var(--hud-fg, var(--text));border:1px solid var(--border);box-shadow:0 6px 20px #4a3c2a14;max-width:calc(100vw - 32px)}.hud-top .item{display:flex;align-items:center;gap:6px}.hud-top .item.level .value{font-variant-numeric:tabular-nums;font-weight:600}.hud-top .icon{font-size:16px;opacity:.9}.hud-top .value{font-weight:600}.hud-top .timer.warn{color:#d97706}.hud-top .timer.critical{color:#dc2626;animation:pulse .6s ease-in-out infinite alternate}@keyframes pulse{0%{opacity:.7;transform:scale(1)}to{opacity:1;transform:scale(1.06)}}.hud-corner{position:absolute;top:calc(24px + env(safe-area-inset-top));right:calc(24px + env(safe-area-inset-right));display:flex;gap:8px}.hud-btn{width:38px;height:38px;border-radius:50%;background:#ffffff8c;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);color:var(--hud-fg, var(--text));font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s;box-shadow:0 6px 20px #4a3c2a14}.hud-btn:hover{transform:scale(1.06);background:#fffc}.hud-btn:active{transform:scale(.94)}.minimap{position:absolute;bottom:calc(24px + env(safe-area-inset-bottom));right:calc(24px + env(safe-area-inset-right));width:140px;height:140px;background:#ffffff80;border:1px solid var(--border);border-radius:12px;overflow:hidden;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 6px 20px #4a3c2a14}.has-touch-pad .minimap{right:auto;left:calc(24px + env(safe-area-inset-left))}.hud-dark-theme .hud-top,.hud-dark-theme .hud-btn,.hud-dark-theme .minimap{background:#0d11178c;border-color:#ffffff1a;box-shadow:0 6px 20px #00000059}.hud-dark-theme .hud-btn:hover{background:#0d1117bf}.hud-dark-theme .toast{background:#0d1117b3;border-color:#ffffff1f;color:var(--hud-fg, #f5efe6)}.hud-dark-theme .touch-pad{background-color:#0d111780;border-color:#ffffff24}.hud-dark-theme .touch-pad.pressed{background-color:#0d1117b8}.hud-dark-theme .touch-arrow{color:#f5efe6cc}.scene{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5efe6d9,#ece4d3f2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .4s ease}.scene.has-scene-header{padding-top:88px}.scene.show{opacity:1}.scene-card{background:var(--surface-strong);border:1px solid var(--border);border-radius:16px;padding:56px 64px 48px;min-width:420px;text-align:center;box-shadow:var(--shadow-card);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);position:relative}.menu-icon-stack{position:fixed;top:max(14px,env(safe-area-inset-top));right:max(14px,env(safe-area-inset-right));display:flex;flex-direction:column;gap:8px;pointer-events:none;z-index:5}.menu-icon-stack>*{pointer-events:auto}.menu-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;outline:none;color:var(--text-soft);font-family:inherit;cursor:pointer;transition:color .15s,transform .1s,background .15s;-webkit-tap-highlight-color:transparent;border-radius:8px;line-height:0}.menu-icon-btn:focus{outline:none}.menu-icon-btn:focus-visible{color:var(--text);background:#3a342b0f}.menu-icon-btn:hover{color:var(--text);background:#3a342b0f;transform:translateY(-1px)}.menu-icon-btn:active{transform:scale(.92)}.menu-icon-btn svg{display:block}.scene-title{font-size:36px;font-weight:400;letter-spacing:8px;margin-bottom:10px;color:var(--text);padding:0 28px}.scene-subtitle{font-size:13px;color:var(--text-muted);letter-spacing:4px;margin-bottom:40px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-header{position:absolute;top:max(28px,env(safe-area-inset-top));left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;width:max-content;max-width:calc(100% - 32px);pointer-events:none;animation:scene-header-enter .55s ease-out .12s both}.scene-header.empty{display:none}.scene-header-greeting{font-size:14px;letter-spacing:3px;color:var(--accent-strong, var(--text));font-weight:500;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes scene-header-enter{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.btn-group{display:flex;flex-direction:column;gap:14px;align-items:stretch}.btn{padding:12px 28px;background:#3a342b0a;border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;letter-spacing:2px;cursor:pointer;transition:all .18s;font-family:inherit}.btn:hover{background:#3a342b14;border-color:var(--border-strong);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.primary{background:var(--accent-soft);border-color:#e8a87c80;color:var(--accent-strong);font-weight:500}.btn.primary:hover{background:#e8a87c47}.scene-card-wide{min-width:520px;max-width:min(640px,92vw);max-height:calc(100dvh - 60px);display:flex;flex-direction:column;overflow:hidden;padding:36px 36px 24px}.scene-card-wide .scene-title,.scene-card-wide .scene-subtitle,.scene-card-wide .chapter-nav,.scene-card-wide .btn-group{flex:0 0 auto}.scene-card-wide .chapter-section,.scene-card-wide .chapter-header{text-align:left}.scene-card-wide .scene-title{margin-bottom:4px}.scene-card-wide .scene-subtitle{margin-bottom:18px}.chapter-nav{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;padding:4px 2px 10px;margin-bottom:4px;border-bottom:1px solid var(--border)}.chapter-nav-item{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:#3a342b0a;border:1px solid var(--border);border-radius:999px;color:var(--text);cursor:pointer;font-family:inherit;font-size:12px;line-height:1.2;transition:all .15s ease}.chapter-nav-item:hover:not(.locked){background:#3a342b14;transform:translateY(-1px)}.chapter-nav-item.locked{opacity:.4;cursor:not-allowed}.chapter-nav-item.active{background:var(--chapter-bg, var(--accent-soft));border-color:var(--chapter-color, rgba(232, 168, 124, .5));box-shadow:0 0 0 1px var(--chapter-color, transparent) inset}.chapter-nav-item .ci{font-size:12px;font-weight:600;color:var(--chapter-color, var(--accent-strong))}.chapter-nav-item .cn{font-size:11px;letter-spacing:1px;color:var(--text-soft)}.chapter-list{flex:1 1 auto;min-height:0;overflow-y:auto;padding:8px 4px 4px;margin-bottom:16px;scrollbar-width:thin}.chapter-list::-webkit-scrollbar{width:6px}.chapter-list::-webkit-scrollbar-thumb{background:#3a342b2e;border-radius:3px}.chapter-section{margin-bottom:22px;padding:14px 12px 10px;border-radius:14px;background:color-mix(in srgb,var(--chapter-bg, transparent) 40%,transparent);border:1px solid color-mix(in srgb,var(--chapter-wall, var(--border)) 25%,transparent);transition:background .3s ease}.chapter-section.locked{filter:grayscale(.55) brightness(.96)}.chapter-section.locked .level-grid{opacity:.55}.chapter-header{margin-bottom:12px;padding:0 4px 0 12px;border-left:3px solid var(--chapter-color, var(--accent))}.chapter-title-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:4px}.chapter-title-row .ci{font-size:13px;letter-spacing:2px;color:var(--chapter-color, var(--accent-strong));font-weight:500}.chapter-title-row .cn{font-size:18px;font-weight:500;color:var(--text);letter-spacing:2px}.chapter-title-row .cs{font-size:10px;letter-spacing:3px;color:var(--text-muted)}.chapter-meta{font-size:11px;letter-spacing:1px;color:var(--text-soft)}.level-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:8px}.level-tile{height:78px;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:transform .15s,box-shadow .2s;background:var(--tile-bg, var(--card));color:var(--tile-fg, var(--text));border:1px solid color-mix(in srgb,var(--tile-border, var(--border)) 45%,transparent);box-shadow:inset 0 -2px color-mix(in srgb,var(--tile-bg-accent, transparent) 60%,transparent)}.level-tile:hover:not(.locked){transform:translateY(-3px);border-color:var(--tile-border, var(--accent));box-shadow:inset 0 -2px color-mix(in srgb,var(--tile-bg-accent, transparent) 80%,transparent),0 6px 16px color-mix(in srgb,var(--tile-border, transparent) 25%,transparent)}.level-tile.locked{opacity:.3;cursor:not-allowed}.level-tile .num{font-size:17px;font-weight:400;font-variant-numeric:tabular-nums;color:var(--tile-fg, var(--text))}.level-tile .name{font-size:9px;letter-spacing:1px;opacity:.72;color:var(--tile-fg, var(--text-soft))}.level-tile .stars{font-size:10px;letter-spacing:2px;margin-top:2px;color:var(--tile-exit, #d97706)}.result-stats{display:flex;flex-direction:column;gap:10px;margin:20px 0 28px;font-size:14px;color:var(--text)}.result-stats .row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--border)}.result-stats .row .v{font-weight:600;font-variant-numeric:tabular-nums}.stars-row{font-size:32px;letter-spacing:8px;margin:16px 0 24px;height:36px;color:var(--border-strong)}.star{display:inline-block;opacity:.25;transform:scale(.6);transition:all .4s cubic-bezier(.34,1.56,.64,1)}.star.lit{opacity:1;transform:scale(1);color:#f5b528;text-shadow:0 0 16px rgba(245,181,40,.5)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:14px 0;font-size:13px;letter-spacing:1px}.settings-row label{flex:0 0 80px;text-align:left;color:var(--text-soft)}.settings-row input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:#3a342b1f;border-radius:2px;outline:none}.settings-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #e8a87c73}.settings-row .val{flex:0 0 40px;text-align:right;font-variant-numeric:tabular-nums;color:var(--text)}.scene-card-sync{padding:48px 56px 36px;text-align:left;max-height:calc(100dvh - 60px);overflow-y:auto}.scene-card-sync .scene-title,.scene-card-sync .scene-subtitle{text-align:center}.sync-section{margin-top:22px;padding:16px 18px 18px;background:#3a342b06;border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;gap:12px}.sync-section-head{display:flex;flex-direction:column;gap:2px}.sync-section-title{font-size:14px;font-weight:600;letter-spacing:2px;color:var(--text)}.sync-section-sub{font-size:11px;color:var(--text-muted);letter-spacing:.5px;line-height:1.4}.sync-section-body{display:flex;flex-direction:column;gap:10px}.sync-panel{display:flex;flex-direction:column;gap:12px}.sync-actions{display:flex;flex-direction:column;gap:8px}.sync-actions .btn{width:100%;font-size:13px;padding:10px 12px;letter-spacing:1.5px}.sync-actions .sync-secondary{font-size:12px;padding:8px 10px;background:transparent;color:var(--text-soft)}.sync-code-row{display:flex;align-items:center;gap:10px;background:var(--accent-soft);padding:12px 14px;border-radius:10px;border:1px solid rgba(232,168,124,.35)}.sync-code-info{flex:1 1 auto;min-width:0}.sync-code-label{font-size:11px;color:var(--text-soft);letter-spacing:1px;margin-bottom:2px}.sync-code-value{font-size:22px;font-weight:700;letter-spacing:3px;color:var(--accent-strong);font-family:SF Mono,Monaco,Menlo,Consolas,Roboto Mono,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sync-copy-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;padding:8px 12px;background:#ffffffb3;border:1px solid var(--border);border-radius:8px;color:var(--accent-strong);font-family:inherit;font-size:12px;letter-spacing:1px;cursor:pointer;transition:background .15s,transform .1s,color .15s,border-color .15s;white-space:nowrap}.sync-copy-btn:hover{background:#fffffff2;border-color:var(--border-strong)}.sync-copy-btn:active{transform:scale(.96)}.sync-copy-btn .sync-copy-icon{font-size:14px;line-height:1}.sync-copy-btn.copied{color:var(--ok, #2a9d8f);background:#2a9d8f14;border-color:#2a9d8f59}.btn.sync-danger{width:100%;background:#c040400f;border-color:#c0404052;color:#b94545;letter-spacing:2px;font-size:13px;padding:10px 12px}.btn.sync-danger:hover{background:#c040401f;border-color:#c0404080}.btn.sync-danger:active{transform:translateY(0) scale(.98)}.btn.sync-danger:disabled{opacity:.55;cursor:not-allowed}.btn.sync-back{width:100%;margin-top:22px}.qr-modal{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#1c160e80;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:50;padding:24px;opacity:0;transition:opacity .28s ease}.qr-modal.show{opacity:1}.qr-modal .scene-card{transform:scale(.92);transition:transform .32s cubic-bezier(.2,.9,.3,1.2)}.qr-modal.show .scene-card{transform:scale(1)}.scene-card-qr{display:flex;flex-direction:column;align-items:center;min-width:320px;position:relative}.qr-close-icon{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:50%;color:var(--text-soft);font-size:16px;font-family:inherit;line-height:1;cursor:pointer;transition:background .15s,color .15s,border-color .15s,transform .1s;-webkit-tap-highlight-color:transparent}.qr-close-icon:hover{background:#3a342b14;color:var(--text);border-color:var(--border)}.qr-close-icon:active{transform:scale(.92)}.scene-card-qr .scene-title,.scene-card-qr .scene-subtitle,.scene-card-qr .qr-tip{width:100%}.scene-card-confirm{display:flex;flex-direction:column;align-items:stretch;min-width:300px;max-width:min(420px,92vw);padding:28px 28px 24px}.scene-card-confirm .confirm-title{font-size:18px;font-weight:600;letter-spacing:2px;color:var(--text);text-align:center;margin-bottom:14px}.scene-card-confirm .confirm-message{font-size:13px;line-height:1.7;color:var(--text-soft);text-align:center;margin-bottom:22px;padding:0 4px}.scene-card-confirm .confirm-btn-group{display:flex;flex-direction:row;gap:10px;width:100%}.scene-card-confirm .confirm-btn-group .btn{flex:1;white-space:nowrap}.btn.confirm-danger{background:#e639461f;border-color:#e6394666;color:#b8413c;font-weight:600}.btn.confirm-danger:hover{background:#e6394633;border-color:#e6394699}.btn.confirm-danger:active{transform:scale(.97)}.scene-card-input{display:flex;flex-direction:column;align-items:center;min-width:320px;padding:36px 32px 28px}.scene-card-input .scene-title,.scene-card-input .scene-subtitle,.scene-card-input .input-tip{width:100%}.scene-card-input .input-tip{font-size:13px;color:var(--text-soft);letter-spacing:1px;margin:14px 0 12px;text-align:center}.scene-card-input .code-input{width:100%;box-sizing:border-box;padding:12px 16px;font-family:SF Mono,Monaco,Menlo,Consolas,Roboto Mono,monospace;font-size:18px;letter-spacing:2px;text-align:center;color:var(--text);background:#3a342b0a;border:1px solid var(--border);border-radius:10px;outline:none;transition:border-color .15s,background .15s;-webkit-user-select:text;user-select:text}.scene-card-input .code-input::placeholder{color:var(--text-muted);letter-spacing:1px;font-weight:400}.scene-card-input .code-input:focus{border-color:var(--accent);background:#fff9}.scene-card-input .btn-group{display:flex;flex-direction:row;gap:10px;width:100%;margin-top:18px}.scene-card-input .btn-group .btn{flex:1}.scene-card-qr .qr-wrap{margin:18px 0 6px;padding:10px;background:#fff;border-radius:12px;border:1px solid var(--border);box-shadow:0 4px 14px #4a3c2a14;display:block;line-height:0}.scene-card-qr .qr-wrap svg{display:block}.scene-card-qr .qr-tip{font-size:12px;color:var(--text-soft);text-align:center;line-height:1.7;margin-top:12px;padding:0 8px}.scene-card-qr .qr-tip-warn{display:inline-block;margin-top:4px;color:var(--accent-strong);font-weight:600}.scene-card-qr .qr-tip-security{width:100%;margin-top:12px;text-align:center}.scene-card-qr .qr-tip-secure{display:inline-block;padding:8px 14px;font-size:12px;font-weight:600;line-height:1.5;letter-spacing:.5px;color:#b8413c;background:#e6394614;border:1px solid rgba(230,57,70,.35);border-radius:8px;max-width:100%;box-sizing:border-box;animation:qr-secure-pulse 2.4s ease-in-out infinite}@keyframes qr-secure-pulse{0%,to{box-shadow:0 0 #e6394600}50%{box-shadow:0 0 0 4px #e639461f}}@media (prefers-reduced-motion: reduce){.scene-card-qr .qr-tip-secure{animation:none}}.scene-card-share{width:380px;max-width:calc(100vw - 48px)}.scene-card-share .share-tip-wechat{display:inline-block;padding:8px 14px;font-size:12.5px;line-height:1.5;letter-spacing:.5px;color:#2a8064;background:#2a9d8f1a;border:1px solid rgba(42,157,143,.35);border-radius:8px;font-weight:500}.scene-card-share .share-tip-wechat strong{color:#1a6b50;font-size:16px;margin:0 2px;letter-spacing:0}.scene.scene-review{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;align-items:flex-start;justify-content:flex-end;padding:16px 16px 0 0;pointer-events:none}.scene.scene-review .review-card{pointer-events:auto;padding:10px 16px;min-width:0;background:#ffffffeb;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);box-shadow:0 6px 20px #4a3c2a24;max-width:280px;text-align:left}.scene.scene-review .review-card .scene-title{font-size:14px!important;letter-spacing:3px;margin:0 0 2px;text-align:center}.scene.scene-review .review-card .scene-subtitle{font-size:11px;letter-spacing:1px;margin:0 0 6px!important;text-align:center;white-space:normal;overflow:visible;text-overflow:clip}.scene.scene-review .review-card .btn-group{margin-top:4px}.scene.scene-review .review-card .btn{padding:6px 14px;min-width:0;width:100%;font-size:12px}.review-legend{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap;margin:0 0 8px;font-size:11px;color:var(--text-soft)}.review-legend .legend-item{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.review-legend .legend-dot{display:inline-block;width:16px;height:3px;border-radius:2px}.review-legend .legend-dot-best{background:var(--accent);box-shadow:0 0 6px var(--accent-soft)}.review-legend .legend-dot-player{background:#506eaae6}.a2hs-banner{position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fffffff5;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;box-shadow:0 8px 28px #4a3c2a38;border:1px solid var(--border);z-index:9999;transform:translateY(120%);opacity:0;transition:transform .32s ease,opacity .32s ease;pointer-events:auto}.a2hs-banner.a2hs-show{transform:translateY(0);opacity:1}.a2hs-banner.a2hs-hide{transform:translateY(120%);opacity:0}.a2hs-banner .a2hs-text{flex:1;min-width:0}.a2hs-banner .a2hs-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}.a2hs-banner .a2hs-tip{font-size:12px;color:var(--text-soft);line-height:1.4}.a2hs-banner .a2hs-icon{display:inline-block;padding:0 4px;color:var(--accent);font-weight:700}.a2hs-banner .a2hs-close{flex-shrink:0;width:28px;height:28px;border:none;background:transparent;font-size:22px;line-height:1;color:var(--text-muted);cursor:pointer;padding:0;border-radius:50%}.a2hs-banner .a2hs-close:active{background:#00000014}.toast{position:absolute;top:80px;left:50%;transform:translate(-50%) translateY(-10px);padding:8px 18px;background:#ffffffd9;border:1px solid var(--border);backdrop-filter:blur(10px);border-radius:999px;font-size:13px;letter-spacing:1px;color:var(--text);box-shadow:0 6px 20px #4a3c2a1f;opacity:0;transition:all .4s ease;pointer-events:none;z-index:30}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.global-toast{position:fixed;top:calc(24px + env(safe-area-inset-top));left:50%;transform:translate(-50%) translateY(-12px);max-width:min(86vw,380px);padding:10px 18px;background:#fffffff0;border:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:12px;font-size:14px;letter-spacing:.5px;line-height:1.45;text-align:center;color:var(--text);box-shadow:0 10px 30px #4a3c2a2e;opacity:0;transition:opacity .3s ease,transform .3s ease;pointer-events:none;z-index:10000}.global-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.global-toast-success{border-color:#4c915a59;color:#2c5e3a}.global-toast-error{border-color:#c4604c66;color:#8a3a2b;background:#fff7f4f5}.best-path-btn{position:absolute;top:calc(120px + env(safe-area-inset-top));left:50%;transform:translate(-50%) translateY(-6px);display:inline-flex;align-items:center;gap:8px;padding:8px 18px 8px 14px;background:#ffffffd9;border:1px solid var(--border);border-radius:999px;color:var(--text);font-family:inherit;font-size:13px;letter-spacing:1px;cursor:pointer;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .3s ease,transform .3s ease,background .15s ease;box-shadow:0 6px 20px #4a3c2a2e;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:31}.best-path-btn.show{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%) translateY(0)}.best-path-btn:hover{background:#fffffff2;transform:translate(-50%) translateY(-1px)}.best-path-btn .x{font-size:14px;width:18px;height:18px;line-height:18px;text-align:center;border-radius:50%;background:var(--accent-soft);color:var(--accent-strong)}.hud-dark-theme .best-path-btn{background:#0d1117b3;border-color:#ffffff24;color:var(--hud-fg, #f5efe6)}.hud-dark-theme .best-path-btn:hover{background:#0d1117d9}.hud-dark-theme .best-path-btn .x{background:#ffffff1f;color:var(--hud-fg, #f5efe6)}@media (max-width: 600px){.best-path-btn{top:calc(96px + env(safe-area-inset-top));font-size:12px;padding:7px 14px 7px 10px}}.touch-pad{position:absolute;right:calc(20px + env(safe-area-inset-right));bottom:calc(20px + env(safe-area-inset-bottom));width:180px;height:180px;border-radius:50%;background:#ffffff8c;border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 6px 24px #4a3c2a1f;z-index:12;opacity:.85;transition:opacity .15s ease,background .15s ease;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;background-image:linear-gradient(45deg,transparent 49.6%,rgba(74,60,42,.08) 49.6% 50.4%,transparent 50.4%),linear-gradient(-45deg,transparent 49.6%,rgba(74,60,42,.08) 49.6% 50.4%,transparent 50.4%)}.touch-pad.pressed{opacity:1;background-color:#ffffffc7}.touch-arrow{position:absolute;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--hud-fg, var(--text));opacity:.55;pointer-events:none;transition:opacity .12s ease,transform .1s ease,color .12s ease;font-family:inherit;line-height:1}.touch-arrow-up{top:8px;left:50%;transform:translate(-50%)}.touch-arrow-down{bottom:8px;left:50%;transform:translate(-50%)}.touch-arrow-left{left:8px;top:50%;transform:translateY(-50%)}.touch-arrow-right{right:8px;top:50%;transform:translateY(-50%)}.touch-arrow.active{opacity:1;color:var(--accent-strong, var(--text))}.touch-arrow-up.active{transform:translate(-50%) translateY(-2px) scale(1.15)}.touch-arrow-down.active{transform:translate(-50%) translateY(2px) scale(1.15)}.touch-arrow-left.active{transform:translateY(-50%) translate(-2px) scale(1.15)}.touch-arrow-right.active{transform:translateY(-50%) translate(2px) scale(1.15)}.touch-pad-center{position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;background:#4a3c2a40;transform:translate(-50%,-50%);pointer-events:none;transition:background .15s ease}.touch-pad.pressed .touch-pad-center{background:#4a3c2a73}@media (max-width: 600px){.scene-card{padding:44px 36px 36px;min-width:0;width:min(86vw,380px);max-height:calc(100dvh - 40px);overflow-y:auto}.scene-title{font-size:26px;letter-spacing:4px;padding:0 24px}.scene-subtitle{margin-bottom:28px}.scene.has-scene-header{padding-top:64px}.scene-header{top:max(16px,env(safe-area-inset-top));gap:4px;max-width:calc(100% - 24px)}.scene-header-greeting{font-size:12px;letter-spacing:2px}.scene-card-wide{min-width:0;width:94%;max-width:94%;padding:28px 18px 16px}.chapter-nav-item{padding:4px 8px;font-size:11px}.chapter-nav-item .ci{font-size:11px}.chapter-nav-item .cn{font-size:10px}.chapter-title-row .cn{font-size:16px;letter-spacing:1px}.chapter-title-row .cs{display:none}.level-grid{grid-template-columns:repeat(5,1fr);gap:8px}.level-tile{height:64px;border-radius:10px}.level-tile .num{font-size:14px}.level-tile .name{font-size:8px;letter-spacing:0}.level-tile .stars{font-size:8px;letter-spacing:1px}.minimap{width:96px;height:96px;bottom:calc(14px + env(safe-area-inset-bottom));right:calc(14px + env(safe-area-inset-right));opacity:.78}.has-touch-pad .minimap{right:auto;left:calc(14px + env(safe-area-inset-left))}.hud-top{top:calc(10px + env(safe-area-inset-top));gap:14px;padding:7px 14px;font-size:12px}.hud-top .icon{font-size:13px}.hud-corner{top:calc(10px + env(safe-area-inset-top));right:calc(10px + env(safe-area-inset-right));gap:6px}.hud-btn{width:34px;height:34px;font-size:14px}.toast{top:64px;font-size:12px;padding:7px 14px;max-width:80vw;text-align:center}.stars-row{font-size:26px;letter-spacing:6px;margin:12px 0 18px}.result-stats{font-size:13px;margin:14px 0 22px}.btn{padding:11px 20px;font-size:13px}.settings-row input[type=range]::-webkit-slider-thumb{width:18px;height:18px}.touch-pad{width:168px;height:168px;right:calc(14px + env(safe-area-inset-right));bottom:calc(14px + env(safe-area-inset-bottom))}.touch-arrow{width:40px;height:40px;font-size:22px}.scene.scene-review{align-items:flex-start;justify-content:center;padding:12px 12px 0}.scene.scene-review .review-card{max-width:calc(100% - 24px);width:auto}.scene-card-sync{padding:36px 22px 26px}.sync-section{padding:14px 14px 16px;margin-top:16px}.sync-code-row{padding:10px 12px;gap:8px}.sync-code-value{font-size:18px;letter-spacing:2px}.sync-copy-btn{padding:7px 10px;font-size:11px}.sync-copy-btn .sync-copy-text{display:none}.btn.sync-back{margin-top:18px}}@media (max-width: 380px){.scene-title{font-size:22px;letter-spacing:3px}.level-tile{height:56px}.level-tile .num{font-size:12px}.level-grid{gap:6px}.chapter-nav-item{padding:3px 6px;font-size:10px}.chapter-nav-item .ci{font-size:10px}.chapter-nav-item .cn{font-size:9px}.minimap{width:80px;height:80px;opacity:.7}.touch-pad{width:152px;height:152px}.touch-arrow{width:36px;height:36px;font-size:20px}}@media (max-height: 500px) and (orientation: landscape){.scene-card{padding:24px 36px;max-height:92dvh;overflow-y:auto}.scene-title{font-size:22px;margin-bottom:4px}.scene-subtitle{margin-bottom:16px}.scene.has-scene-header{padding-top:36px}.scene-header{top:max(8px,env(safe-area-inset-top));gap:2px}.scene-header-greeting{font-size:11px;letter-spacing:1.5px}.hud-top{top:calc(8px + env(safe-area-inset-top));padding:6px 14px;font-size:12px}.minimap{width:90px;height:90px}.touch-pad{width:156px;height:156px}.touch-arrow{width:38px;height:38px;font-size:20px}}.settings-nick-row{flex-wrap:wrap}.settings-nick-row>label{flex:0 0 auto}.settings-nick-input{flex:1 1 220px;min-width:200px;padding:8px 14px;font-family:inherit;font-size:13px;background:#3a342b0a;border:1px solid var(--border);border-radius:8px;color:var(--text);outline:none;transition:border-color .15s,background .15s;-webkit-user-select:text;user-select:text}.settings-nick-input::placeholder{color:var(--text-muted);letter-spacing:.5px}.settings-nick-input:focus{border-color:var(--accent);background:#fff9}.settings-nick-save{flex:0 0 auto;padding:8px 16px;font-size:12px;letter-spacing:1px}.settings-nick-save:disabled{opacity:.4;cursor:not-allowed;transform:none}
