:root{--bg-primary: rgba(0, 0, 0, .3);--bg-overlay: rgba(0, 0, 0, .6);--popup-bg: rgba(0, 0, 0, .6);--accent-primary: rgb(238, 238, 238);--bg-svg: rgba(0, 0, 0, .1);--border-svg: rgba(255, 255, 255, .3);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .9);--text-tertiary: rgba(255, 255, 255, .7);--text-quaternary: rgba(255, 255, 255, .5);--border-primary: rgba(255, 255, 255, .2)}#root{width:100%;height:100%}html{font-size:16px}body{background:#000;height:100vh;margin:0;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:1rem}.scene-overlay{position:absolute;inset:0;width:100%;height:100%;background:#0d0d0d;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999}.scene-spinner{width:2.875rem;height:2.875rem;border-radius:50%;border:.25rem solid rgba(255,255,255,.12);border-top-color:#fff;animation:spin .8s linear infinite;margin-bottom:1.25rem}.scene-title{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:.375rem}.scene-subtitle{font-size:.875rem;color:#ffffff8c}.download-tutorial{display:flex;flex-direction:row;align-items:stretch;justify-content:center;width:100%;max-width:560px;margin:0 auto;padding-inline:1rem;box-sizing:border-box}.download-tutorial__column{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;text-align:center;padding-inline:1.25rem;position:relative}.download-tutorial__column:not(:last-child):after{content:"";position:absolute;right:0;top:0;bottom:0;width:1px;background:#ffffff14}.download-tutorial__column-visual{display:flex;align-items:flex-start;justify-content:center;width:7rem;min-width:7rem;height:4.5rem;flex-shrink:0;margin:0 auto 1.5rem}.download-tutorial__column-text{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1}.download-tutorial__column-title{font-size:.8125rem;font-weight:700;letter-spacing:.12em;color:#fffffffa;line-height:1.2;text-transform:uppercase}.download-tutorial__column-desc{font-size:.75rem;font-weight:500;letter-spacing:.03em;color:#ffffffeb;line-height:1.4;max-width:11em;text-shadow:0 1px 3px rgba(0,0,0,.5)}.download-tutorial__keys{display:flex;flex-direction:column;align-items:center;gap:.5rem}.download-tutorial__keys-row{display:flex;gap:.25rem;justify-content:center}.download-tutorial__key{width:2rem;height:2rem;border:1px solid rgba(255,255,255,.65);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#fffffffa;background:transparent}.download-tutorial__key--wide{min-width:2.75rem;font-size:.5625rem;letter-spacing:.02em}.download-tutorial__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.download-tutorial__joystick-icon{position:relative;width:72px;height:72px}.download-tutorial__joystick-base{position:absolute;inset:0;border:1px solid rgba(255,255,255,.65);border-radius:50%;background:transparent}.download-tutorial__joystick-stick{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border:1px solid rgba(255,255,255,.65);border-radius:50%;background:transparent}.download-tutorial__touch-icon{width:72px;height:72px;color:#ffffffb3}.download-tutorial__touch-icon svg{width:36px;height:36px}.download-tutorial__mouse-icon{position:relative;width:48px;height:72px}.download-tutorial__mouse-body{position:absolute;width:40px;height:68px;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid rgba(255,255,255,.65);border-radius:20px;background:transparent}.download-tutorial__mouse-wheel{position:absolute;left:50%;top:14px;transform:translate(-50%);width:2px;height:10px;background:#ffffffa6;border-radius:1px}.download-tutorial__mouse-buttons{position:absolute;left:4px;right:4px;top:6px;height:12px;border-bottom:1px solid rgba(255,255,255,.55)}.download-tutorial--orbit-only{max-width:300px}.download-tutorial--orbit-only .download-tutorial__column:after{display:none}.download-tutorial--orbit-only .download-tutorial__column{flex:0 1 auto;padding-inline:0}.download-tutorial--orbit-only .download-tutorial__column-visual{height:4.5rem}.download-tutorial--orbit-only .download-tutorial__column-desc{max-width:14em}@media(orientation:landscape)and (max-height:500px){.download-tutorial{max-width:100%;padding-inline:clamp(.5rem,2vw,1rem)}.download-tutorial__column{flex-direction:row;gap:clamp(.5rem,2vw,1rem);text-align:left;align-items:center;padding-inline:clamp(.5rem,2vw,1.25rem);padding-block:clamp(.25rem,1vh,.5rem)}.download-tutorial__column-visual{flex-shrink:0;width:clamp(3rem,12vh,5rem);min-width:clamp(3rem,12vh,5rem);height:clamp(2.5rem,10vh,4rem);margin:0;align-items:center;justify-content:flex-start}.download-tutorial__column-text{align-items:flex-start;flex:1;min-width:0;gap:clamp(.2rem,.8vh,.4rem)}.download-tutorial__column-desc{max-width:none}.download-tutorial--orbit-only{max-width:100%}.download-tutorial--orbit-only .download-tutorial__column-visual{height:clamp(2.5rem,10vh,4rem)}.download-tutorial__column-title{font-size:clamp(.625rem,1.8vh,.8125rem)}.download-tutorial__column-desc{font-size:clamp(.5625rem,1.5vh,.75rem);text-shadow:0 1px 3px rgba(0,0,0,.5)}.download-tutorial__joystick-icon,.download-tutorial__touch-icon{width:clamp(36px,11vh,52px);height:clamp(36px,11vh,52px)}.download-tutorial__joystick-stick{width:clamp(6px,2vh,10px);height:clamp(6px,2vh,10px)}.download-tutorial__touch-icon svg{width:clamp(28px,9vh,44px);height:clamp(28px,9vh,44px)}.download-tutorial__mouse-icon{width:clamp(28px,8vh,40px);height:clamp(36px,12vh,56px)}.download-tutorial__mouse-body{width:clamp(24px,7vh,32px);height:clamp(32px,10vh,52px)}.download-tutorial__key{width:clamp(1.25rem,4vh,1.75rem);height:clamp(1.25rem,4vh,1.75rem);font-size:clamp(.5rem,1.4vh,.6875rem)}.download-tutorial__key--wide{min-width:clamp(1.75rem,5vh,2.25rem);font-size:clamp(.4rem,1.2vh,.5rem)}}@media(max-width:540px){.download-tutorial{flex-direction:column;gap:1.25rem;max-width:100%;padding-inline:1rem}.download-tutorial__column:after{display:none}.download-tutorial__column{flex-direction:row;gap:1.5rem;text-align:left;width:100%;max-width:320px;margin:0 auto;align-items:center;padding:0}.download-tutorial__column:not(:last-child){padding-bottom:1.25rem;border-bottom:1px solid rgba(255,255,255,.08)}.download-tutorial--orbit-only{max-width:100%}.download-tutorial__column-visual{flex-shrink:0;width:5.5rem;min-width:5.5rem;height:3.5rem;margin:0;align-items:center;justify-content:center}.download-tutorial__column-text{align-items:flex-start;flex:1;min-width:0;gap:.375rem}.download-tutorial__column-desc{max-width:none}.download-tutorial--orbit-only .download-tutorial__column-visual{height:3.5rem}.download-tutorial__column-title{font-size:.75rem}.download-tutorial__column-desc{font-size:.6875rem;text-shadow:0 1px 3px rgba(0,0,0,.5)}.download-tutorial__joystick-icon,.download-tutorial__touch-icon{width:52px;height:52px}.download-tutorial__joystick-stick{width:10px;height:10px}.download-tutorial__touch-icon svg{width:44px;height:44px}.download-tutorial__mouse-icon{width:36px;height:56px}.download-tutorial__mouse-body{width:32px;height:52px}.download-tutorial__key{width:1.75rem;height:1.75rem;font-size:.6875rem}.download-tutorial__key--wide{min-width:2.25rem;font-size:.5rem}}.download-screen{position:absolute;inset:0;overflow:hidden;color:#fff}.download-bg{position:relative;width:100%;height:100%;overflow:hidden;background:#000}.download-bg:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 50%,transparent 35%,rgba(0,0,0,.3) 55%,rgba(0,0,0,.6) 100%);pointer-events:none}.download-bg video{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s ease-out}.download-bg video.download-bg-video--visible{opacity:1}.download-fade{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(to bottom,#0000,#0009 40%,#000000e6);pointer-events:none}.download-title{position:absolute;top:2.5rem;left:50%;transform:translate(-50%);width:100%;max-width:90vw;margin:0;font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;color:#fff;text-align:center;padding:0 1rem;box-sizing:border-box}.download-title--long{font-size:clamp(1.25rem,3.5vw,1.75rem)}.download-title--very-long{font-size:clamp(1rem,3vw,1.5rem)}.download-content{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:0;padding-top:clamp(2rem,5vw,3rem);padding-bottom:clamp(3rem,6vw,4rem);padding-inline:max(2rem,env(safe-area-inset-left),env(safe-area-inset-right));box-sizing:border-box}.download-instructions-wrap{width:100%;max-width:560px;margin-bottom:clamp(2rem,4vw,2.75rem);display:flex;flex-direction:column;align-items:center}.download-instructions-wrap--spacer{visibility:hidden;min-height:100px}.download-instructions-wrap--orbit-only.download-instructions-wrap--spacer{min-height:72px}.download-instructions-wrap--orbit-only:not(.download-instructions-wrap--spacer){margin-bottom:clamp(1.5rem,3.5vw,2.25rem)}.download-instructions-placeholder{width:100%;max-width:560px;height:56px}.download-instructions-heading{margin:0 0 2rem;font-size:clamp(.75rem,2vw,.875rem);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;text-align:center}.download-controls-row{width:100%;display:flex;justify-content:center}.download-info,.download-progress-wrap{width:100%}.download-progress-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:.5rem;min-height:1.5em}.download-subtitle{font-size:.875rem;opacity:.85;color:#ffffffe6}.download-pct{font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:#fffffffa;line-height:1}.download-progress-track{width:100%;height:6px;border-radius:3px;background:#fff3;overflow:hidden}.download-progress-fill{height:100%;background:linear-gradient(90deg,#2f6d9b,#64c8f5 28%,#e57224 58%,#d95686);transition:width .25s ease-out;border-radius:3px}.download-progress-fill--indeterminate{width:40%!important;animation:download-progress-indeterminate 1.5s ease-in-out infinite}@keyframes download-progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(350%)}}@media(max-width:640px){.download-content{padding-top:clamp(1.5rem,4vw,2rem);padding-bottom:clamp(2.5rem,5vw,3rem);padding-inline:max(1.25rem,env(safe-area-inset-left),env(safe-area-inset-right))}.download-pct{font-size:clamp(1.25rem,5vw,1.75rem)}.download-controls-row{margin-bottom:clamp(1.75rem,4vw,2.25rem)}.download-title{top:1.5rem;font-size:clamp(1.25rem,5vw,1.75rem)}.download-title--long{font-size:clamp(1.125rem,4vw,1.5rem)}.download-title--very-long{font-size:clamp(1rem,3.5vw,1.25rem)}}.canvas-instructions-overlay{pointer-events:none;-webkit-user-select:none;user-select:none;animation:canvas-instructions-fade-in .6s cubic-bezier(.25,.46,.45,.94) forwards}.canvas-instructions-overlay .download-content{animation:canvas-instructions-content-in .6s cubic-bezier(.25,.46,.45,.94) forwards}.canvas-instructions-overlay .download-instructions-heading,.canvas-instructions-overlay .download-tutorial__column-title,.canvas-instructions-overlay .download-tutorial__column-desc{text-shadow:2px 2px 4px rgba(0,0,0,.45)}.canvas-instructions-overlay .download-tutorial__joystick-icon,.canvas-instructions-overlay .download-tutorial__touch-icon,.canvas-instructions-overlay .download-tutorial__mouse-icon,.canvas-instructions-overlay .download-tutorial__key{filter:drop-shadow(2px 2px 4px rgba(0,0,0,.45))}.canvas-instructions-overlay.canvas-instructions-overlay--exiting{animation:canvas-instructions-fade-out .4s cubic-bezier(.25,.46,.45,.94) forwards}.canvas-instructions-overlay.canvas-instructions-overlay--exiting .download-content{animation:canvas-instructions-content-out .4s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes canvas-instructions-fade-in{0%{opacity:0}to{opacity:1}}@keyframes canvas-instructions-fade-out{0%{opacity:1}to{opacity:0}}@keyframes canvas-instructions-content-in{0%{transform:translateY(8px)}to{transform:translateY(0)}}@keyframes canvas-instructions-content-out{0%{transform:translateY(0)}to{transform:translateY(8px)}}.error-screen{position:absolute;inset:0;background:#0d0d0d;display:flex;align-items:center;justify-content:center;color:#fff}.error-box{text-align:center;padding:2rem 2.5rem;border-radius:1rem}.error-title{font-size:1.375rem;font-weight:600;margin-bottom:.5rem}.error-message{font-size:.9375rem;opacity:.75;margin-bottom:1.5rem;max-width:23.75rem}.help-popup__overlay{position:fixed;inset:0;background:var(--bg-overlay);z-index:10000;animation:fadeIn .2s ease-out;pointer-events:auto}.help-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10001;background:var(--popup-bg);border-radius:12px;padding:24px;max-width:800px;width:80%;max-height:80vh;overflow-y:auto;animation:popupSlideIn .3s ease-out;pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.help-popup__close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:var(--text-quaternary);cursor:pointer;padding:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;z-index:10002;pointer-events:auto}.help-popup__close:hover{color:var(--text-primary);background-color:var(--hover-bg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popupSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.help-popup--touch{inset:0;transform:translateY(100%);max-width:100%;width:100%;max-height:100vh;height:100vh;border-radius:0;padding:60px 0 20px;box-sizing:border-box;display:flex;flex-direction:column;animation:slideUpMobile .3s ease-out forwards}.help-popup--touch .help-popup__content{padding:0 20px;flex:1;overflow-y:auto;display:flex;flex-direction:column}@media(max-width:624px){.help-popup{inset:0;transform:translateY(100%);max-width:100%;width:100%;max-height:100vh;height:100vh;border-radius:0;padding:60px 0 20px;box-sizing:border-box;display:flex;flex-direction:column;animation:slideUpMobile .3s ease-out forwards}.help-popup__content{padding:0 20px;flex:1;overflow-y:auto;display:flex;flex-direction:column}}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.help-content{display:flex;flex-direction:column}.help-content__section:not(:last-child){margin-bottom:24px}.help-content__title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px;line-height:1.3}.help-content__description{font-size:13px;font-weight:400;color:var(--text-tertiary);line-height:1.6;margin:0}.help-content__modes{display:grid;grid-template-columns:1fr 1fr;gap:24px}.help-content__mode-panel{display:flex;flex-direction:column}.help-content__mode-svg{width:100%;margin-bottom:20px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);min-height:180px;display:flex;align-items:center;justify-content:center}.help-content__mode-svg svg{width:100%;height:auto;display:block;max-width:100%;min-height:180px}.help-content__mode-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.help-content__mode-icon{color:var(--text-primary);flex-shrink:0}.help-content__mode-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4}.help-content__mode-description{font-size:13px;font-weight:400;color:var(--text-tertiary);line-height:1.6;margin:0 0 16px}.help-content__controls{margin-top:auto;padding-top:4px}.help-content__control-group{display:flex;flex-direction:column;gap:12px}.help-content__control-item{display:flex;align-items:center;gap:10px;font-size:13px;line-height:1.5}.help-content__control-icon{color:var(--text-quaternary);flex-shrink:0}.help-content__control-key{font-weight:600;color:var(--text-primary);min-width:60px}.help-content__control-label{font-weight:400;color:var(--text-tertiary)}.help-popup--touch .help-content__modes{grid-template-columns:1fr;gap:32px}.help-popup--touch .help-content__mode-svg{order:3;margin:20px 0 0}.help-popup--touch .help-content__mode-header{order:1}.help-popup--touch .help-content__mode-description{order:2;margin-bottom:0}.help-popup--touch .help-content__controls{order:4;margin-top:20px}@media(max-width:624px){.help-content__modes{grid-template-columns:1fr;gap:32px}.help-content__mode-svg{order:3;margin:20px 0 0}.help-content__mode-header{order:1}.help-content__mode-description{order:2;margin-bottom:0}.help-content__controls{order:4;margin-top:20px}}.tooltip-target{display:inline-flex}.tooltip{position:fixed;z-index:1000;background:var(--bg-primary);color:var(--text-primary);border:none;font-size:.75rem;line-height:1.4;font-weight:500;padding:.5rem .75rem;border-radius:.5rem;white-space:nowrap;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .12s ease-out,transform .12s ease-out}.tooltip--visible{opacity:1;transform:translateY(0)}@media(pointer:coarse){.tooltip{display:none}}.animation-controls{position:fixed;bottom:0;left:0;width:100%;z-index:100;display:flex;justify-content:center;pointer-events:none}.controls-row{pointer-events:auto;display:flex;flex-direction:column;align-items:stretch;width:100%;gap:2px;padding:0 1.25rem 1.25rem;opacity:1;transform:translateY(0);transition:opacity .35s ease,transform .35s ease}.slider-wrapper{width:100%;display:flex}.controls-actions{width:100%;display:flex;justify-content:space-between;align-items:center}.view-toggle-group{display:flex;align-items:center;gap:4px;margin-left:auto;background:var(--bg-primary);border-radius:999px;padding:4px;height:3.5rem;box-sizing:border-box}.icon-button{display:inline-flex;align-items:center;justify-content:center;background:transparent;border-radius:50%;width:2.75rem;height:2.75rem;font-size:1rem;color:var(--accent-primary);cursor:pointer;border:none}.icon-button svg{width:1.5rem;height:1.5rem;filter:drop-shadow(0 0 1px rgba(0,0,0,1));color:var(--accent-primary)}.icon-button:hover{background:#ffffff1a}.view-toggle-button{display:inline-flex;align-items:center;justify-content:center;background:none;border-radius:999px;padding:0;height:auto;box-sizing:border-box;gap:4px;cursor:default;border:none}.view-toggle-option{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;width:2.75rem;height:2.75rem;font-size:1rem;cursor:pointer}.view-toggle-option svg{width:1.5rem;height:1.5rem;filter:drop-shadow(0 0 1px rgba(0,0,0,1));color:var(--accent-primary)}.view-toggle-option:hover{background:#ffffff1a}.view-toggle-option.active{background:#ffffff26}.view-toggle-option.active svg{stroke-width:3}.animation-controls.is-hidden .controls-row{opacity:0;pointer-events:none;transform:translateY(.75rem)}.play-pause-button{background:var(--bg-primary);border:none;border-radius:50%;padding:0;width:3.5rem;height:3.5rem;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer}.play-pause-button svg{flex-shrink:0;width:1.5rem;height:1.5rem;color:var(--accent-primary);filter:drop-shadow(0 0 1px rgba(0,0,0,1));fill:var(--accent-primary)}.progress-slider{width:100%;-webkit-appearance:none;appearance:none;height:2.5rem;background:transparent;border-radius:999px;outline:none;cursor:pointer;padding:0;margin:0}.progress-slider::-moz-range-track{width:100%;height:4px;background:linear-gradient(to right,var(--accent-primary) 0%,var(--accent-primary) var(--progress, 0%),rgb(40,40,40,.6) var(--progress, 0%),rgb(40,40,40,.6) 100%);border-radius:999px;border:none}.progress-slider::-webkit-slider-runnable-track{width:100%;height:.25rem;background:linear-gradient(to right,var(--accent-primary) 0%,var(--accent-primary) var(--progress, 0%),rgb(40,40,40,.6) var(--progress, 0%),rgb(40,40,40,.6) 100%);border-radius:999px;border:none}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:none;cursor:pointer}.progress-slider::-webkit-slider-thumb{position:relative;z-index:1;margin-top:-5px}@media(max-width:600px),(max-height:600px)and (orientation:landscape){.controls-row{padding:0 10px 10px;gap:2px}.progress-slider{height:1.25rem}.play-pause-button{font-size:.875rem;height:3rem;width:3rem}.icon-button{font-size:.875rem;width:2.5rem;height:2.5rem}.view-toggle-group{gap:3px;padding:3px;height:3rem}.view-toggle-button{gap:3px}.view-toggle-option{width:2.5rem;height:2.5rem;font-size:.875rem}}.react-joystick{position:relative;border-radius:50%;background:#f1f1f1;box-shadow:0 0 5px #d5dadb inset;border:1px solid #fff;text-align:initial}.react-joystick.react-joystick-disabled{opacity:.5;cursor:not-allowed}.react-joystick .arrows-wrapper{position:absolute;width:100%;height:100%;top:0;left:0}.react-joystick .arrows-wrapper .controller-arrow{display:inline-flex;position:absolute}.react-joystick .arrows-wrapper .arrow-up{display:inline-flex;position:absolute;top:0;left:50%;transform:translate(-50%,50%)}.react-joystick .arrows-wrapper .arrow-down{display:inline-flex;position:absolute;bottom:0;left:50%;transform:translate(-50%,-50%)}.react-joystick .arrows-wrapper .arrow-left{display:inline-flex;position:absolute;left:0;top:50%;transform:translate(50%,-50%)}.react-joystick .arrows-wrapper .arrow-right{display:inline-flex;position:absolute;right:0;top:50%;transform:translate(-50%,-50%)}.react-joystick .react-joystick-controller{background:linear-gradient(to bottom,#fff,#eaf4fe);border-radius:50%;box-shadow:0 0 16px #d5dadb;border:1px solid #d9dde4;box-sizing:border-box}.react-joystick .controller-wrapper{display:inline-flex}.react-joystick-ghost-area{position:relative}.react-joystick-ghost-area .react-joystick-wrapper{position:absolute;width:0;height:0}.react-joystick-ghost-area .react-joystick-wrapper .react-joystick{transform:translate(-50%,-50%)}.react-joystick-ghost-area .react-joystick-wrapper .react-joystick.ghost{visibility:hidden}.react-joystick-ghost-area .react-joystick-wrapper .react-joystick.ghost-active{visibility:visible}.mobile-joystick-wrapper{position:absolute;bottom:80px;left:50%;transform:translate(-50%);z-index:1000;pointer-events:auto;touch-action:none;display:flex;align-items:center;gap:16px;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.mobile-joystick{background:var(--bg-primary);border:none;box-shadow:none}.mobile-joystick-controller{background:var(--accent-primary)!important;box-shadow:none!important;border:none!important}.mobile-joystick path{fill:var(--accent-primary)!important}.strafe-button{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;border:none;background:var(--bg-primary);color:var(--accent-primary);cursor:pointer;flex-shrink:0;padding:0;touch-action:none}@media(orientation:portrait){.mobile-joystick-container{left:50%;transform:translate(-50%)}}@media(orientation:landscape){.mobile-joystick-wrapper{bottom:80px;left:12px;transform:none}}.video-player{position:absolute;top:0;left:0;width:100%;height:100%;background:#000;display:flex;justify-content:center;align-items:center;overflow:hidden;opacity:1;pointer-events:auto;transition:opacity .5s ease-in-out}.video-player--hidden{opacity:0;pointer-events:none}.video-player__video{position:absolute;width:100%;object-fit:contain;z-index:10;pointer-events:auto}.video-player__buffering{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:20;pointer-events:none}.video-player__spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.logo-container{position:relative;top:-16px;right:-16px;z-index:10;flex-shrink:0;pointer-events:auto}.logo{height:5rem;width:auto;cursor:pointer}.logo:hover{opacity:.8}@media(max-width:480px){.logo-container{top:-10px;right:-10px}.logo{height:3.5rem}}.top-bar{position:fixed;top:0;left:0;right:0;z-index:99;display:flex;justify-content:space-between;padding:1.25rem;pointer-events:none;gap:1rem}.top-bar__name{font-size:1.25rem;font-weight:500;color:#fffffff2;line-height:1.2;text-shadow:2px 2px 4px rgba(0,0,0,.45);flex-shrink:1;word-wrap:break-word;overflow-wrap:break-word}@media(max-width:480px){.top-bar{padding:.5rem;gap:.5rem}.top-bar__name{font-size:1rem}}.video-fallback{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:8px;background:var(--popup-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border-primary);border-radius:8px;padding:10px 14px;font-size:13px;white-space:nowrap;animation:videoFallbackIn .25s ease-out}@keyframes videoFallbackIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.video-fallback__icon{color:var(--accent-primary, #f59e0b);flex-shrink:0}.video-fallback__message{color:var(--text-primary)}.video-fallback__close{background:transparent;border:none;color:var(--text-quaternary);font-size:18px;line-height:1;cursor:pointer;padding:0 0 0 4px;display:flex;align-items:center;transition:color .15s ease}.video-fallback__close:hover{color:var(--text-primary)}.viewer{width:100%;height:100%}.viewer-overlay{position:absolute;inset:0;width:100%;height:100%;z-index:2;opacity:1;transition:opacity 1s ease}.viewer-overlay--faded{opacity:0}.viewer-instructions-overlay{position:absolute;inset:0;z-index:999;pointer-events:none}
