*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#000;color:#fff;overflow:hidden;height:100vh;width:100vw}body{position:fixed;top:0;left:0}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;z-index:9999;font-family:Arial,sans-serif}.loading-content{text-align:center;max-width:400px;padding:2rem}.loading-title{font-size:2.5rem;font-weight:700;margin-bottom:2rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);background:linear-gradient(45deg,#fff,#e0e0e0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-bar{width:100%;height:8px;background:rgba(255,255,255,.2);border-radius:4px;overflow:hidden;margin-bottom:1rem}.loading-progress{height:100%;background:linear-gradient(90deg,#4ecdc4,#44a3a0,#4ecdc4);background-size:200% 100%;animation:loading-animation 2s linear infinite;border-radius:4px}@keyframes loading-animation{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-text{font-size:1.1rem;opacity:.9;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.9}50%{opacity:.6}}.debug-panel{position:fixed;top:20px;left:20px;background:rgba(0,0,0,.8);border:1px solid #333;border-radius:8px;padding:1rem;font-family:Courier New,monospace;font-size:.9rem;z-index:8888;color:#0f0;backdrop-filter:blur(10px)}.debug-panel h3{color:#4ecdc4;margin-bottom:.5rem;font-size:1rem}#debug-info{font-size:.8rem;line-height:1.4;max-height:300px;overflow-y:auto}#debug-toggle{background:#4ecdc4;color:#000;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;margin-top:.5rem;font-weight:700}#debug-toggle:hover{background:#44a3a0}.connection-status{position:fixed;top:20px;right:20px;background:rgba(0,0,0,.8);border:1px solid #333;border-radius:20px;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;z-index:8888;backdrop-filter:blur(10px);font-size:.9rem}.status-indicator{width:12px;height:12px;border-radius:50%;background:#e74c3c;animation:pulse-indicator 2s ease-in-out infinite}.status-indicator.connected{background:#27ae60}@keyframes pulse-indicator{0%,to{opacity:1}50%{opacity:.5}}.error-display{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(231,76,60,.95);border:2px solid #e74c3c;border-radius:12px;padding:2rem;z-index:9999;backdrop-filter:blur(10px);box-shadow:0 10px 30px rgba(0,0,0,.5)}.error-content{text-align:center}.error-content h3{color:#fff;margin-bottom:1rem;font-size:1.5rem}.error-content p{color:#fff;margin-bottom:1.5rem;line-height:1.4}.error-content button{background:#e74c3c;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:700;transition:background-color .3s ease}.error-content button:hover{background:#c0392b}#vr-entry-button,#ar-entry-button{z-index:8888;font-family:Arial,sans-serif}@media (max-width: 768px){.debug-panel{top:10px;left:10px;right:10px;font-size:.8rem}.connection-status{top:auto;bottom:80px;right:20px}.loading-title{font-size:2rem}#vr-entry-button,#ar-entry-button{bottom:15px!important;right:15px!important}}@media (prefers-contrast: high){.loading-screen{background:#000}.loading-title{color:#fff;text-shadow:none}.error-display{background:#000;border-color:#fff}}@media (prefers-reduced-motion: reduce){.loading-progress,.loading-text,.status-indicator{animation:none}}@media print{.loading-screen,.debug-panel,.connection-status,.error-display,#vr-entry-button,#ar-entry-button{display:none!important}}*:focus{outline:2px solid #4ecdc4;outline-offset:2px}button:focus,input:focus,textarea:focus{outline:2px solid #4ecdc4;outline-offset:2px}a-scene{position:absolute;top:0;left:0;width:100%;height:100%}.cursor{width:10px;height:10px;background:#4ecdc4;border-radius:50%;position:fixed;pointer-events:none;z-index:9999}.voice-indicator{animation:voice-pulse 1.5s ease-in-out infinite}@keyframes voice-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.gpu-accelerated{transform:translateZ(0);will-change:transform}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hidden{display:none!important}.visible{display:block!important}.loading{opacity:.6;pointer-events:none}.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid #4ecdc4;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.smooth-transition{transition:all .3s ease}@media (prefers-color-scheme: dark){body{background:#000;color:#fff}}@media (prefers-color-scheme: light){body{background:#f0f0f0;color:#333}.debug-panel,.connection-status,.error-display{background:rgba(255,255,255,.9);color:#333;border-color:#ddd}}
