*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#viewer-canvas{display:block;width:100%;height:100%;touch-action:none}#loading-screen{position:fixed;inset:0;z-index:100;background:#1a1a2e;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:1rem}.spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;opacity:.7}#password-gate{position:fixed;inset:0;z-index:200;display:none}.password-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center}.password-box{background:#1e1e2e;padding:2rem;border-radius:12px;text-align:center;color:#fff;max-width:360px;width:90%}.password-box h2{margin-bottom:.5rem;font-size:1.25rem}.password-box p{margin-bottom:1rem;opacity:.7;font-size:14px}.password-box input{width:100%;padding:12px;margin-bottom:1rem;border:1px solid #333;border-radius:8px;background:#2a2a3e;color:#fff;font-size:16px;outline:none}.password-box input:focus{border-color:#4a9eff}.password-box button{width:100%;padding:12px;background:#4a9eff;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;transition:background .2s}.password-box button:hover{background:#3a8eef}#pw-error{color:#ff6b6b;display:none;margin-top:.5rem;margin-bottom:0}#controls-hint{position:fixed;bottom:20px;left:50%;transform:translate(-50%);color:#ffffff80;font-size:14px;pointer-events:none;transition:opacity 1s ease;text-align:center;white-space:nowrap}#help-toggle{position:fixed;top:16px;left:16px;z-index:50;width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:#00000080;color:#fffc;font-size:14px;font-weight:600;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .2s,border-color .2s;display:none}#help-toggle:hover{background:#000000b3;border-color:#ffffff80}#help-toggle.active{background:#4a9eff4d;border-color:#4a9eff99}#help-panel{position:fixed;top:54px;left:16px;z-index:50;background:#000000a6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:16px 20px;color:#ffffffe6;font-size:13px;line-height:1.4;pointer-events:none;opacity:0;transform:translateY(-8px);transition:opacity .25s ease,transform .25s ease;max-width:260px}#help-panel.visible{opacity:1;transform:translateY(0);pointer-events:auto}.help-section{margin-bottom:12px}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff73;margin-bottom:6px}.help-row{display:flex;justify-content:space-between;align-items:center;padding:2px 0;gap:16px}.help-key{font-family:SF Mono,Menlo,Consolas,monospace;font-size:11px;color:#ffffffb3;background:#ffffff14;padding:2px 7px;border-radius:4px;border:1px solid rgba(255,255,255,.1);white-space:nowrap}.help-row>span:last-child{color:#ffffff8c;font-size:12px;text-align:right}.help-section-touch{display:none}.help-section-keyboard{display:block}@media(pointer:coarse){.help-section-touch{display:block}.help-section-keyboard{display:none}}@media(max-height:500px),(max-width:400px){#help-panel{top:40px;left:8px;max-width:200px;padding:8px 12px;font-size:11px;max-height:calc(100vh - 48px);max-height:calc(100dvh - 48px);overflow-y:auto;-webkit-overflow-scrolling:touch;border-radius:8px}#help-toggle{top:8px;left:8px;width:24px;height:24px;font-size:12px}.help-section{margin-bottom:6px}.help-section h3{font-size:9px;margin-bottom:2px}.help-row{padding:1px 0;gap:6px}.help-key{font-size:9px;padding:1px 4px}.help-row>span:last-child{font-size:9px}}#fullscreen-toggle{position:fixed;bottom:16px;right:16px;z-index:50;width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:#00000080;color:#fffc;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .2s,border-color .2s;display:none;padding:0;line-height:0}#fullscreen-toggle:hover{background:#000000b3;border-color:#ffffff80}#fullscreen-toggle svg{display:inline-block;vertical-align:middle}
