.auth-screen{align-items:center;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.auth-bg-animated{animation:cityPan 180s linear infinite;background-position:0;background-repeat:repeat-x;background-size:auto;min-height:100vh;width:200%;will-change:transform;z-index:0}.auth-bg-animated,.auth-screen:after{height:100%;left:0;position:absolute;top:0}.auth-screen:after{background:#00000080;content:"";pointer-events:none;width:100%;z-index:1}@keyframes cityPan{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.auth-container{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;position:relative;width:100%;z-index:2}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-container h1{color:#333;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:#555;font-size:14px;font-weight:600}.form-group input{border:2px solid #e0e0e0;font-family:inherit;padding:12px 16px;transition:all .2s ease}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background-color:#f5f5f5;color:#999}.auth-error{background-color:#fee;border-left:4px solid #c33;color:#c33}.auth-error,.auth-success{animation:slideDown .3s ease-out;border-radius:8px;font-size:14px;padding:12px 16px}.auth-success{background-color:#efe;border-left:4px solid #3c3;color:#3c3}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:12px 24px;transition:all .2s ease}.auth-button:hover:not(:disabled){box-shadow:0 10px 20px #667eea4d;transform:translateY(-2px)}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{cursor:not-allowed;opacity:.6}.auth-footer{border-top:1px solid #e0e0e0;margin-top:30px;padding-top:20px;text-align:center}.auth-footer p{color:#666;font-size:14px;margin:0}.toggle-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:none;transition:color .2s ease}.toggle-button:hover{color:#764ba2;text-decoration:underline}@media (max-width:480px){.auth-container{margin:20px;padding:30px 20px}.auth-container h1{font-size:24px;margin-bottom:20px}.auth-form{gap:16px}.form-group input{font-size:16px;padding:10px 12px}}.splash-container{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.splash-background{background:radial-gradient(circle at 20% 50%,#ff6b6b1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#34d3991a 0,#0000 50%);height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.splash-content{align-items:center;display:flex;height:100%;justify-content:center;padding:20px;position:relative;width:100%;z-index:10}.login-card{animation:slideIn .6s ease-out;background:#141852f2;border:1px solid #6496ff4d;border-radius:16px;box-shadow:0 8px 32px #00000080,0 0 20px #34d39933,inset 0 1px 1px #ffffff1a;max-width:500px;padding:40px;width:100%}.login-header{margin-bottom:40px;text-align:center}.login-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#34d399,#10b981);-webkit-background-clip:text;background-clip:text;font-size:48px;font-weight:700;margin:0 0 10px}.login-header .subtitle{color:#94a3b8;font-size:16px;font-weight:300;margin:0}.login-form{gap:30px}.form-section,.login-form{display:flex;flex-direction:column}.form-section{gap:16px}.form-section h3{color:#cbd5e1;color:#34d399;font-size:14px;font-weight:600;letter-spacing:1px;margin:0;text-transform:uppercase}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{align-items:center;color:#cbd5e1;display:flex;font-size:13px;font-weight:500;gap:8px}.label-icon{font-size:18px}.form-group input{background:#1e293bcc;border:1px solid #6496ff4d;border-radius:8px;color:#e2e8f0;font-size:14px;outline:none;padding:12px 14px;transition:all .3s ease;width:100%}.form-group input:focus{background:#1e293b;border-color:#34d399;box-shadow:0 0 10px #34d3994d}.form-group input:disabled{cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:#64748b}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{margin:0;padding-right:40px}.toggle-password{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:4px 8px;position:absolute;right:12px;transition:color .2s ease}.toggle-password:hover:not(:disabled){color:#34d399}.toggle-password:disabled{cursor:not-allowed;opacity:.5}.looks-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-top:12px}.look-button{align-items:center;aspect-ratio:1;background:#1e293bcc;border:2px solid #6496ff33;border-radius:12px;cursor:pointer;display:flex;justify-content:center;overflow:hidden;padding:8px;transition:all .3s ease}.look-button img{height:100%;image-rendering:pixelated;object-fit:contain;width:100%}.look-button:hover:not(:disabled){background:#1e293b;border-color:#34d399;box-shadow:0 0 15px #34d39933;transform:scale(1.05)}.look-button.selected{background:#34d39933;border-color:#34d399;box-shadow:0 0 20px #34d39966}.look-button:disabled{cursor:not-allowed;opacity:.6}.error-message{align-items:center;animation:shake .4s ease-in-out;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#fca5a5;display:flex;font-size:13px;gap:10px;padding:12px 16px}.error-icon{flex-shrink:0;font-size:18px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.login-button{align-items:center;background:linear-gradient(135deg,#34d399,#10b981);border:none;border-radius:8px;color:#0f172a;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.5px;padding:14px;text-transform:uppercase;transition:all .3s ease}.login-button:hover:not(:disabled){box-shadow:0 10px 25px #34d3994d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.7}.spinner{border:2px solid #ffffff4d;border-top-color:#0f172a;display:inline-block;height:16px;width:16px}.login-footer{color:#94a3b8;font-size:13px;margin-top:20px;text-align:center}.login-footer a{color:#34d399;text-decoration:none;transition:color .2s ease}.login-footer a:hover{color:#10b981;text-decoration:underline}.success-message{align-items:center;animation:slideDown .3s ease-out;background-color:#10b981;border-left:4px solid #059669;border-radius:8px;color:#fff;display:flex;font-size:14px;gap:8px;padding:12px 16px}.error-icon,.success-icon{flex-shrink:0;font-size:16px}.toggle-mode-button{background:none;border:none;color:#34d399;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:none;transition:color .2s ease}.toggle-mode-button:hover:not(:disabled){color:#10b981;text-decoration:underline}.toggle-mode-button:disabled{cursor:not-allowed;opacity:.6}@media (max-width:600px){.login-card{padding:30px 20px}.login-header h1{font-size:36px}.looks-grid{grid-template-columns:repeat(2,1fr)}.form-group input,.toggle-password{font-size:16px}}.lobby-screen{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;height:100vh;overflow:hidden}.lobby-header{background:#0000004d;border-bottom:2px solid #fff3;padding:20px}.header-content{align-items:center;display:flex;gap:20px;justify-content:space-between}.header-content div{flex:1 1;text-align:center}.lobby-header h1{font-size:2.5em;font-weight:700;margin:0 0 10px;text-shadow:2px 2px 4px #00000080}.lobby-header p{font-size:1.1em;margin:0;opacity:.9}.logout-btn{background:linear-gradient(135deg,#f5576c,#f093fb);border:none;border-radius:8px;box-shadow:0 4px 15px #f5576c66;color:#fff;cursor:pointer;font-size:1em;font-weight:700;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.logout-btn:hover{box-shadow:0 6px 20px #f5576c99;transform:translateY(-2px)}.logout-btn:active{transform:translateY(0)}.lobby-content{display:flex;flex:1 1;gap:20px;overflow:hidden;padding:20px}.lobby-sidebar{background:#0000004d;border-radius:10px;display:flex;flex-direction:column;gap:15px;overflow-y:auto;padding:15px;width:350px}.create-room-btn{background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:8px;box-shadow:0 4px 15px #0003;color:#fff;cursor:pointer;font-size:1em;font-weight:700;padding:12px 20px;transition:all .3s ease}.create-room-btn:hover{box-shadow:0 6px 20px #0000004d;transform:translateY(-2px)}.search-box{display:flex;flex-direction:column;gap:8px}.search-input{background:#fffffff2;border:none;border-radius:8px;color:#333;font-size:1em;padding:10px 15px;transition:all .3s ease}.search-input:focus{background:#fff;box-shadow:0 0 10px #ffffff80;outline:none}.room-list{display:flex;flex:1 1;flex-direction:column;gap:10px;overflow:hidden}.room-list h2{font-size:1.3em;font-weight:700;margin:0}.rooms{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto;padding-right:5px}.room-item{align-items:center;background:#ffffff1a;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:12px 15px;transition:all .3s ease}.room-item:hover{background:#ffffff26;border-color:#ffffff4d}.room-item.selected{background:#ffffff40;border-color:#f093fb;box-shadow:0 0 10px #f093fb80}.room-name{font-size:1em;font-weight:700}.room-users{font-size:.85em;opacity:.8}.lobby-main{align-items:center;background:#0000004d;border-radius:10px;display:flex;flex:1 1;justify-content:center;overflow-y:auto;padding:20px}.no-selection{font-size:1.5em;opacity:.7;text-align:center}.room-detail{display:flex;flex-direction:column;gap:20px;width:100%}.room-preview{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;box-shadow:0 4px 15px #0000004d;display:flex;height:300px;justify-content:center;overflow:hidden;width:100%}.room-preview-placeholder{font-size:3em;opacity:.6;text-align:center}.room-info{display:flex;flex-direction:column;gap:15px}.room-info h2{font-size:2em;font-weight:700;margin:0}.info-section{display:flex;flex-direction:column;gap:5px}.info-section label{font-size:1.1em;font-weight:700;opacity:.8}.info-section p{background:#ffffff1a;border-radius:6px;font-size:1.05em;margin:0;padding:8px 12px}.room-actions{display:flex;gap:10px;margin-top:10px}.btn{border:none;border-radius:8px;box-shadow:0 4px 15px #0003;cursor:pointer;font-size:1.05em;font-weight:700;padding:12px 24px;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;flex:1 1}.btn-primary:hover{box-shadow:0 6px 20px #0000004d;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.lobby-main::-webkit-scrollbar,.lobby-sidebar::-webkit-scrollbar,.rooms::-webkit-scrollbar{width:8px}.lobby-main::-webkit-scrollbar-track,.lobby-sidebar::-webkit-scrollbar-track,.rooms::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.lobby-main::-webkit-scrollbar-thumb,.lobby-sidebar::-webkit-scrollbar-thumb,.rooms::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:10px}.lobby-main::-webkit-scrollbar-thumb:hover,.lobby-sidebar::-webkit-scrollbar-thumb:hover,.rooms::-webkit-scrollbar-thumb:hover{background:#ffffff80}.create-room-dialog-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.create-room-dialog{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #fff3;border-radius:15px;box-shadow:0 10px 50px #00000080;color:#fff;max-width:500px;padding:30px;width:90%}.dialog-header{align-items:center;border-bottom:2px solid #ffffff4d;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.dialog-header h2{font-size:1.5em;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5em;height:30px;justify-content:center;padding:0;transition:background .2s;width:30px}.close-btn:hover{background:#fff3}.dialog-content{margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{display:block;font-size:.95em;font-weight:700;margin-bottom:8px}.form-input,.form-textarea{background:#ffffff1a;border:2px solid #fff3;border-radius:8px;box-sizing:border-box;color:#fff;font-family:inherit;font-size:1em;padding:12px;transition:border-color .3s;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:#fff9}.form-input:focus,.form-textarea:focus{background:#ffffff26;border-color:#ffffff80;outline:none}.form-textarea{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;resize:vertical}.dialog-actions{display:flex;gap:10px;justify-content:flex-end}.dialog-actions .btn{border:none;border-radius:8px;cursor:pointer;font-size:.95em;font-weight:700;padding:10px 20px;transition:all .3s}.dialog-actions .btn-primary{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.dialog-actions .btn-primary:hover:not(:disabled){box-shadow:0 5px 15px #4caf5066;transform:translateY(-2px)}.dialog-actions .btn-secondary{background:linear-gradient(135deg,#f5576c,#f093fb);color:#fff}.dialog-actions .btn-secondary:hover:not(:disabled){box-shadow:0 5px 15px #f5576c66;transform:translateY(-2px)}.btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:1024px){.lobby-content{flex-direction:column}.lobby-sidebar{max-height:300px;width:100%}.room-preview{height:200px}}@media (max-width:768px){.lobby-header h1{font-size:1.8em}.lobby-content{gap:10px;padding:10px}.lobby-sidebar{padding:10px}.room-preview{height:150px}.room-info h2{font-size:1.5em}}.debug-panel{background:#141414f2;border:2px solid #0f0;border-radius:8px;bottom:20px;box-shadow:0 0 20px #00ff004d;font-family:Courier New,monospace;max-width:350px;padding:16px;position:fixed;right:20px;z-index:10000}.debug-panel-header{border-bottom:2px solid #0f0;margin-bottom:12px;padding-bottom:8px}.debug-panel-header h3{color:#0f0;font-size:14px;font-weight:700;margin:0}.debug-panel-content{color:#0f0}.position-controls{gap:12px}.control-group,.position-controls{display:flex;flex-direction:column}.control-group{gap:6px}.control-group label{color:#0f0;font-size:12px;font-weight:700}.control-group input[type=range]{-webkit-appearance:none;background:#1a1a1a;border-radius:3px;cursor:pointer;height:6px;outline:none;width:100%}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#0f0;border-radius:50%;box-shadow:0 0 8px #0f09;cursor:pointer;height:14px;width:14px}.control-group input[type=range]::-moz-range-thumb{background:#0f0;border:none;border-radius:50%;box-shadow:0 0 8px #0f09;cursor:pointer;height:14px;width:14px}.control-group input[type=number]{background:#1a1a1a;border:1px solid #0f0;border-radius:4px;color:#0f0;font-family:Courier New,monospace;font-size:12px;padding:6px;width:100%}.control-group input[type=number]:focus{box-shadow:0 0 8px #0f09;outline:none}.position-display{background:#1a1a1a;border:1px solid #0f0;border-radius:4px;margin:8px 0;padding:8px}.position-display p{color:#0f0;font-size:12px;margin:0;text-align:center}.spawn-button{background:#0f0;border:none;border-radius:4px;color:#000;cursor:pointer;font-family:Courier New,monospace;font-size:12px;font-weight:700;padding:10px;transition:all .2s;width:100%}.spawn-button:hover{background:#0c0;box-shadow:0 0 12px #0f09;transform:scale(1.02)}.spawn-button:active{transform:scale(.98)}.debug-info{border-top:1px solid #00ff004d;margin-top:10px;padding-top:8px}.debug-info p{color:#00ff00b3;font-size:11px;margin:0}.avatar-debug-toggle{background:#4caf50;border:none;border-radius:5px;bottom:20px;box-shadow:0 2px 5px #0000004d;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px 15px;position:fixed;right:20px;transition:all .3s;z-index:10000}.avatar-debug-toggle:hover{background:#45a049;transform:scale(1.05)}.avatar-debug-panel{background:#fff;border-radius:10px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;left:50%;max-height:90vh;max-width:1200px;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:95%;z-index:10001}.avatar-debug-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:15px 20px}.avatar-debug-header h3{font-size:18px;margin:0}.avatar-debug-header button{align-items:center;background:#fff3;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;width:30px}.avatar-debug-header button:hover{background:#ffffff4d}.avatar-debug-content{display:flex;flex:1 1;overflow:hidden}.avatar-debug-sidebar{background:#f5f5f5;border-right:1px solid #ddd;overflow-y:auto;padding:15px;width:200px}.avatar-debug-sidebar h4{color:#666;font-size:14px;margin:0 0 15px;text-transform:uppercase}.avatar-debug-types{display:flex;flex-direction:column;gap:5px}.avatar-debug-types button{align-items:center;background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;display:flex;font-size:13px;justify-content:space-between;padding:10px;position:relative;text-align:left;transition:all .2s}.avatar-debug-types button>div{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:3px}.part-name{color:#666;font-size:11px;font-weight:400}.avatar-debug-types button.active .part-name{color:#ffffffe6}.avatar-debug-types button:hover{background:#e8f4f8;border-color:#667eea}.avatar-debug-types button.active{background:#667eea;border-color:#667eea;color:#fff}.offset-indicator{font-size:11px;font-weight:400;opacity:.7}.avatar-debug-main{display:flex;flex:1 1;flex-direction:column;gap:20px;overflow-y:auto;padding:20px}.avatar-debug-preview-section{background:#f9f9f9;border:1px solid #ddd;border-radius:5px;padding:15px}.avatar-debug-preview-section h4{color:#666;font-size:14px;margin:0 0 15px;text-transform:uppercase}.preview-container{align-items:flex-start;display:flex;gap:15px;justify-content:center}.avatar-preview-canvas{background:#fff;border:2px solid #667eea;border-radius:5px;box-shadow:0 2px 5px #0000001a;height:600px;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;max-width:100%;width:400px}.preview-controls{display:flex;flex:1 1;flex-direction:column}.preview-controls label{color:#666;display:flex;flex-direction:column;font-size:12px}.preview-controls input{font-size:12px}.preview-controls button{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;padding:8px;transition:all .2s}.preview-controls button:hover{background:#5568d3}.avatar-debug-controls,.control-group{margin-bottom:20px}.control-group label{color:#333;display:block;font-size:14px;margin-bottom:8px}.control-row{flex-direction:column;gap:15px}.axis-control label{color:#666;font-size:12px}.part-desc{color:#999;display:block;font-size:11px;font-weight:400;margin-top:3px}.slider-container{align-items:center;display:flex;gap:5px}.adjust-btn{background:#667eea;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;min-width:35px;padding:5px 10px;transition:all .2s}.adjust-btn:hover{background:#5568d3;transform:scale(1.1)}.number-input{border:1px solid #ddd;border-radius:3px;padding:5px;text-align:center;width:70px!important}.slider-container input[type=range]{flex:1 1;margin-right:10px}.slider-container input[type=number]{border:1px solid #ddd;border-radius:3px;padding:5px}.control-actions{display:flex;gap:10px;margin-top:20px}.control-actions button{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:13px;padding:8px 15px;transition:all .2s}.control-actions button:hover{background:#5568d3}.control-actions button.danger{background:#f44336}.control-actions button.danger:hover{background:#da190b}.avatar-debug-info{background:#f9f9f9;border-radius:5px;margin-bottom:20px;padding:15px}.avatar-debug-info h4{color:#666;font-size:14px;margin:0 0 10px}.avatar-debug-info p{color:#333;font-size:13px;margin:5px 0}.avatar-debug-actions{display:flex;gap:10px}.avatar-debug-actions button,.avatar-debug-actions label{background:#4caf50;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:13px;padding:10px 15px;transition:all .2s}.avatar-debug-actions button:hover,.avatar-debug-actions label:hover{background:#45a049}.import-button{display:inline-block}.avatar-debug-footer{background:#f5f5f5;border-top:1px solid #ddd;padding:15px 20px}.avatar-debug-footer p{color:#666;font-size:12px;line-height:1.5;margin:0}.room-editor-minimized{position:fixed;right:10px;top:10px;z-index:1000}.editor-toggle-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.editor-toggle-btn:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.room-editor-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:12px;box-shadow:0 8px 32px #0003;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;max-height:90vh;overflow-y:auto;position:fixed;right:10px;top:10px;width:320px;z-index:1000}.editor-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:16px}.editor-header h3{font-size:18px;font-weight:600;margin:0}.editor-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:28px;justify-content:center;transition:all .2s ease;width:28px}.editor-close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.editor-section{border-bottom:1px solid #e0e0e0;padding:16px}.editor-section:last-child{border-bottom:none}.editor-section label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.editor-button-group{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr)}.editor-button-group button{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.editor-button-group button:hover{background:#f0f0ff;border-color:#667eea}.editor-button-group button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff}.editor-height-controls{align-items:center;display:flex;gap:12px;margin-bottom:12px}.editor-height-controls input[type=range]{-webkit-appearance:none;background:#e0e0e0;border-radius:3px;flex:1 1;height:6px;outline:none}.editor-height-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:18px;width:18px}.editor-height-controls input[type=range]::-moz-range-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:18px;width:18px}.editor-height-controls button{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#667eea;cursor:pointer;font-size:18px;font-weight:600;height:36px;transition:all .2s ease;width:36px}.editor-height-controls button:hover{background:#f0f0ff;border-color:#667eea}.editor-quick-heights{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr)}.editor-quick-heights button{background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:12px;font-weight:600;padding:8px;transition:all .2s ease}.editor-quick-heights button:hover{background:#f0f0ff;border-color:#667eea}.editor-quick-heights button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.editor-instructions{background:#f8f9fa;border-radius:8px;font-size:12px;padding:12px}.editor-instructions h4{color:#333;font-size:13px;margin:0 0 8px}.editor-instructions ul{color:#666;margin:0;padding-left:20px}.editor-instructions li{margin-bottom:4px}.editor-instructions kbd{background:#e0e0e0;border-radius:4px;box-shadow:0 1px 2px #0000001a;color:#333;font-family:monospace;font-size:11px;font-weight:600;padding:2px 6px}.editor-edit-mode-toggle{display:flex;flex-direction:column;gap:8px}.editor-edit-mode-toggle label{align-items:center;color:#333;cursor:pointer;display:flex;font-weight:600;gap:8px}.editor-edit-mode-toggle input[type=checkbox]{cursor:pointer;height:18px;width:18px}.editor-hint{color:#666;font-size:12px;font-style:italic}.editor-selected-tile{background:linear-gradient(135deg,#667eea15,#764ba215);border:2px solid #667eea;border-radius:8px;padding:12px}.editor-selected-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.editor-selected-header h4{color:#667eea;font-size:14px;margin:0}.editor-clear-btn{align-items:center;background:#fff3;border:1px solid #667eea;border-radius:50%;color:#667eea;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;transition:all .2s ease;width:24px}.editor-clear-btn:hover{background:#667eea;color:#fff}.editor-position-controls{display:flex;flex-direction:column;gap:12px}.editor-position-field{align-items:center;display:flex;gap:12px}.editor-position-field label{color:#333;font-size:13px;font-weight:600;min-width:60px}.editor-position-field input[type=number]{border:2px solid #e0e0e0;border-radius:6px;flex:1 1;font-size:14px;font-weight:500;padding:8px 12px;transition:all .2s ease}.editor-position-field input[type=number]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.editor-position-buttons{display:flex;gap:4px}.editor-position-buttons button{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#667eea;cursor:pointer;display:flex;font-size:16px;font-weight:600;height:32px;justify-content:center;transition:all .2s ease;width:32px}.editor-position-buttons button:hover{background:#f0f0ff;border-color:#667eea}.editor-wall-offsets{background:linear-gradient(135deg,#f8f9fa,#fff);border-top:2px solid #e0e0e0;margin-top:16px;padding-top:16px}.editor-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.editor-section-header h4{color:#333;font-size:14px;font-weight:600;margin:0}.editor-reset-btn{background-color:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.editor-reset-btn:hover{background-color:#5568d3;box-shadow:0 2px 4px #667eea4d;transform:translateY(-1px)}.editor-offset-group{background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:12px;padding:12px;transition:all .2s ease}.editor-offset-group:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.editor-offset-label{color:#333;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.editor-offset-controls{display:flex;flex-wrap:wrap;gap:8px}.editor-offset-field{align-items:center;display:flex;flex:1 1;gap:6px;min-width:100px}.editor-offset-field label{color:#666;font-size:12px;font-weight:500;min-width:20px}.editor-offset-field input[type=number]{background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#333;flex:1 1;font-size:13px;min-width:70px;padding:6px 10px;transition:all .2s ease}.editor-offset-field input[type=number]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.wall-editor-panel{background:#141414f2;border:2px solid #0f0;border-radius:8px;box-shadow:0 0 20px #00ff004d;color:#0f0;font-family:Courier New,monospace;padding:16px;position:fixed;right:20px;top:20px;width:400px;z-index:10000}.wall-editor-header{align-items:center;border-bottom:2px solid #0f0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.wall-editor-header h3{color:#0f0;font-size:16px;margin:0}.wall-editor-close{align-items:center;background:#f00c;border:1px solid red;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:30px;justify-content:center;transition:all .2s ease;width:30px}.wall-editor-close:hover{background:red;transform:scale(1.1)}.wall-editor-info{background:#00ff001a;border:1px solid #0f0;border-radius:6px;margin-bottom:16px;padding:12px}.info-row{display:flex;font-size:12px;justify-content:space-between;margin-bottom:6px}.info-row:last-child{margin-bottom:0}.info-label{color:#0f0;font-weight:700}.info-value{color:#fff;font-family:monospace}.wall-editor-controls{display:flex;flex-direction:column;gap:20px}.axis-control{display:flex;flex-direction:column;gap:8px}.axis-control label{color:#0f0;font-size:13px;font-weight:700;margin-bottom:4px}.control-row{align-items:center;display:flex;gap:6px}.control-row button{background:#0f03;border:1px solid #0f0;border-radius:4px;color:#0f0;cursor:pointer;font-size:12px;font-weight:700;min-width:45px;padding:6px 12px;transition:all .2s ease}.control-row button:hover{background:#0f06;transform:scale(1.05)}.control-row input[type=number]{background:#00000080;border:1px solid #0f0;border-radius:4px;color:#0f0;flex:1 1;font-family:Courier New,monospace;font-size:14px;padding:8px;text-align:center}.control-row input[type=number]:focus{border-color:#0ff;box-shadow:0 0 8px #0f09;outline:none}.axis-control input[type=range]{-webkit-appearance:none;background:#1a1a1a;border-radius:3px;cursor:pointer;height:6px;outline:none;width:100%}.axis-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#0f0;border-radius:50%;box-shadow:0 0 8px #0f09;cursor:pointer;height:14px;width:14px}.axis-control input[type=range]::-moz-range-thumb{background:#0f0;border:none;border-radius:50%;box-shadow:0 0 8px #0f09;cursor:pointer;height:14px;width:14px}.pixen-error,.pixen-loading,.pixen-room,.pixen-splash{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;width:100%}.pixen-loading{background:linear-gradient(135deg,#1a1a1a,#2d2d2d)}.pixen-error{background:#1a1a1a;gap:20px;text-align:center}.pixen-error h1{color:#ff6b6b;font-size:32px}.pixen-error p{color:#aaa;font-size:16px;max-width:600px}.pixen-error button{background:#4a90e2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:12px 30px}.pixen-error button:hover{background:#357abd}.loading-screen{align-items:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);display:flex;flex-direction:column;gap:20px;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:9999}.loading-screen p{color:#fff;font-size:18px;font-weight:500;margin:0}.pixen-splash{background:linear-gradient(135deg,#2d2d2d,#1a1a1a);gap:20px}.pixen-splash h1{color:#fff;font-size:48px;margin:0}.pixen-splash p{color:#ccc;cursor:pointer;font-size:18px;margin:0;opacity:.7;transition:opacity .3s}.pixen-splash p:hover{opacity:1}.pixen-room{background:#000;gap:0}.game-container{align-items:center;background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);display:flex;flex:1 1;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.game-container canvas{display:block;height:100%;image-rendering:pixelated;image-rendering:crisp-edges;width:100%}.engine-loading{align-items:center;display:flex;flex-direction:column;gap:20px;left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:100}.engine-loading p{color:#34d399;font-size:18px;font-weight:600}.ui-overlay{align-items:center;bottom:0;color:#fff;font-size:18px;justify-content:center;left:0;position:absolute;right:0;text-shadow:2px 2px 4px #000c;top:0}.toast-container,.ui-overlay{display:flex;pointer-events:none}.toast-container{flex-direction:column;gap:10px;position:fixed;right:20px;top:20px;z-index:9999}.toast{align-items:center;animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;font-size:14px;font-weight:500;gap:15px;justify-content:space-between;max-width:400px;min-width:300px;padding:16px 20px;pointer-events:auto}@keyframes slideIn{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}.toast-success{background-color:#22c55ef2;border-left:4px solid #22c55e;color:#fff}.toast-error{background-color:#ef4444f2;border-left:4px solid #ef4444;color:#fff}.toast-warning{background-color:#fbbf24f2;border-left:4px solid #fbbf24;color:#1f2937}.toast-info{background-color:#3b82f6f2;border-left:4px solid #3b82f6;color:#fff}.toast-message{flex:1 1;line-height:1.5}.toast-close{background:none;border:none;color:inherit;cursor:pointer;flex-shrink:0;font-size:18px;opacity:.7;padding:0;transition:opacity .2s}.toast-close:hover{opacity:1}@media (max-width:640px){.toast-container{left:10px;right:10px;top:10px}.toast{max-width:none;min-width:auto}}.loading-container{padding:2rem}.loading-container p{color:#666;font-size:.9rem;margin-top:1rem}.loading-small .spinner{border-width:2px;height:24px;width:24px}.loading-medium .spinner{border-width:3px;height:40px;width:40px}.loading-large .spinner{border-width:4px;height:60px;width:60px}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-top-color:#3498db}.error-container{min-height:100vh;padding:2rem}.error-container h1{color:#e74c3c;margin-bottom:1rem}.error-container p{color:#666;margin-bottom:2rem}.retry-button{background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .3s}.retry-button:hover{background-color:#2980b9}.retry-button:active{transform:scale(.98)}*{box-sizing:border-box;margin:0;padding:0}body,html{background-color:#000;color:#fff;font-family:Arial,sans-serif;overflow:hidden}#root,body,html{height:100%;width:100%}#app-root,.loading-container{display:flex;flex-direction:column;height:100%;width:100%}.loading-container{align-items:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);gap:20px;justify-content:center}.spinner{animation:spin .8s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{color:#ccc;font-size:18px}.error-container{align-items:center;background:#1a1a1a;display:flex;flex-direction:column;gap:20px;height:100%;justify-content:center;padding:20px;text-align:center;width:100%}.error-container h1{color:#ff6b6b;font-size:32px;margin-bottom:10px}.error-container p{color:#aaa;font-size:16px;margin-bottom:20px;max-width:600px}.error-container button{background:#4a90e2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:12px 30px;transition:background .3s}.error-container button:hover{background:#357abd}canvas{display:block}
/*# sourceMappingURL=main.5c2ce626.css.map*/