html,body{margin:0;height:100%;overflow:hidden;background-color:#0a0a0a}#canvas{width:100%;height:100%;display:block}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0acc;display:none;align-items:center;justify-content:center;z-index:100}.loading-overlay.visible{display:flex}.spinner{width:40px;height:40px;border:4px solid #333;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}body.drop-zone-active:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;border:4px dashed #4a9eff;background:#4a9eff1a;pointer-events:none;z-index:50}.keyboard-hints{position:fixed;bottom:10px;right:10px;z-index:10;display:flex;gap:12px;font-family:system-ui,sans-serif;font-size:12px;color:#fff9}.keyboard-hints kbd{display:inline-block;padding:2px 6px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:3px;font-family:inherit;margin-right:4px}.lighting-panel{position:fixed;bottom:10px;left:10px;z-index:10;background:#000000b3;border:1px solid #444;border-radius:4px;width:180px;font-family:system-ui,sans-serif;font-size:12px;color:#fff}.lighting-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:8px;border-bottom:1px solid #444;cursor:pointer}.lighting-panel .panel-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:14px;line-height:1}.lighting-panel .panel-toggle:hover{background:#fff3}.lighting-panel .panel-content{padding:8px;display:flex;flex-direction:column;gap:8px}.lighting-panel .panel-content.collapsed{display:none}.lighting-panel label{display:flex;justify-content:space-between;color:#fffc}.lighting-panel input[type=range]{width:100%;height:4px;background:#333;border-radius:2px;outline:none;-webkit-appearance:none}.lighting-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer}.lighting-panel input[type=range]::-moz-range-thumb{width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;border:none}.lighting-panel #light-mode-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:12px;margin-top:4px}.lighting-panel #light-mode-btn:hover{background:#fff3}.display-panel{position:fixed;bottom:40px;right:10px;z-index:10;background:#000000b3;border:1px solid #444;border-radius:4px;width:180px;font-family:system-ui,sans-serif;font-size:12px;color:#fff}.display-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:8px;border-bottom:1px solid #444;cursor:pointer}.display-panel .panel-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:20px;height:20px;border-radius:3px;cursor:pointer;font-size:14px;line-height:1}.display-panel .panel-toggle:hover{background:#fff3}.display-panel .panel-content{padding:8px;display:flex;flex-direction:column;gap:8px}.display-panel .panel-content.collapsed{display:none}.display-panel label{display:flex;justify-content:space-between;color:#fffc}.display-panel input[type=range]{width:100%;height:4px;background:#333;border-radius:2px;outline:none;-webkit-appearance:none}.display-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer}.display-panel input[type=range]::-moz-range-thumb{width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;border:none}.display-panel #auto-rotate-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:12px}.display-panel #auto-rotate-btn:hover{background:#fff3}
