*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100vw;height:100vh;height:100dvh;overflow:hidden;background:#000;font-family:system-ui,sans-serif}canvas{display:block;touch-action:none;width:100%!important;height:100%!important}.crosshair{position:fixed;top:50%;left:50%;width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;background:#dcfffa80;pointer-events:none;z-index:5}.hint{position:fixed;top:16px;left:50%;transform:translate(-50%);color:#e6f0f580;font-size:13px;letter-spacing:.04em;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:5;text-align:center}.prompt{position:fixed;bottom:19%;left:50%;transform:translate(-50%);padding:8px 16px;background:#0a141699;border:1px solid rgba(220,255,250,.25);border-radius:999px;color:#eaf6f4;font-size:15px;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:6}.prompt b{background:#dcfffa26;padding:1px 7px;border-radius:5px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:20}.card{max-width:70%;padding:26px 34px;background:#101618e6;border:1px solid rgba(220,255,250,.2);border-radius:14px;color:#f2faf8;font-size:22px;line-height:1.45;letter-spacing:.04em;text-align:center}.overlay-hint{color:#e6f0f580;font-size:13px}.fade{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;pointer-events:none;transition:opacity .45s ease;z-index:15}.sound-btn{position:fixed;top:12px;right:12px;width:42px;height:42px;border:none;border-radius:10px;background:#0a141680;color:#fff;font-size:18px;cursor:pointer;z-index:10}.look-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8;touch-action:none}.joystick{position:fixed;left:26px;bottom:30px;width:120px;height:120px;border-radius:50%;background:#ffffff14;border:2px solid rgba(255,255,255,.18);z-index:9;touch-action:none}.knob{position:absolute;left:50%;top:50%;width:52px;height:52px;margin:-26px 0 0 -26px;border-radius:50%;background:#e6f5f566}.btn-action,.btn-jump{position:fixed;right:30px;width:76px;height:76px;border:2px solid rgba(255,255,255,.22);border-radius:50%;background:#ffffff1a;color:#fff;font-size:28px;z-index:9;touch-action:none}.btn-action{bottom:116px}.btn-jump{bottom:30px}.pause-btn{position:fixed;top:12px;left:12px;width:42px;height:42px;border:none;border-radius:10px;background:#0a141680;color:#fff;font-size:16px;z-index:10}.launch{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.6rem;background:#06080ad1;-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);color:#e8e4dc;z-index:100;overflow:hidden;animation:fadeIn .6s ease forwards;text-align:center;padding:1rem}.launch.paused{background:#04060899;animation:fadeIn .2s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.launch-grid{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background-image:linear-gradient(rgba(180,220,230,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(180,220,230,.06) 1px,transparent 1px);background-size:64px 64px;animation:gridDrift 22s linear infinite;pointer-events:none;-webkit-mask-image:radial-gradient(circle at 50% 45%,black,transparent 75%);mask-image:radial-gradient(circle at 50% 45%,black,transparent 75%)}@keyframes gridDrift{0%{background-position:0 0}to{background-position:64px 128px}}.launch-title{position:relative;font-size:clamp(2.6rem,9vw,5.5rem);font-weight:200;letter-spacing:.34em;text-transform:uppercase;text-shadow:0 4px 40px rgba(140,200,230,.25);margin-right:-.34em}.launch-title.pause{font-size:clamp(1.6rem,5vw,3rem);letter-spacing:.5em;margin-right:-.5em}.launch-sub{position:relative;font-size:.85rem;letter-spacing:.18em;opacity:.5;margin-top:-.6rem}.launch-btn{position:relative;min-width:220px;min-height:60px;padding:1rem 3rem;border:1px solid rgba(220,240,245,.35);border-radius:4px;background:transparent;color:inherit;font-size:1rem;letter-spacing:.28em;text-transform:uppercase;cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;animation:btnPulse 3s ease-in-out infinite}.launch-btn:hover,.launch-btn:focus-visible{border-color:#dcf0f5e6;background:#dcf0f514;outline:none;box-shadow:0 0 30px #8cc8e64d}@keyframes btnPulse{0%,to{box-shadow:0 0 #8cc8e600}50%{box-shadow:0 0 24px #8cc8e62e}}.launch-ctl{position:relative;max-width:90%;font-size:.75rem;letter-spacing:.08em;opacity:.4;line-height:1.7}
