:root{--bg-color: #000000;--text-color: rgba(255, 255, 255, .9);--accent-color: #4a9eff;--menu-bg: rgba(0, 0, 0, .5);--border-color: rgba(255, 255, 255, .1);--slider-bg: rgba(255, 255, 255, .1);--slider-thumb: #ffffff;--input-bg: rgba(255, 255, 255, .05);--button-bg: rgba(255, 255, 255, .05);--hover-bg: rgba(255, 255, 255, .15);--active-bg: rgba(74, 158, 255, .2);--toggle-bg: rgba(0, 116, 249, .5);--green: rgba(0, 255, 0, .25);--green-hover: rgba(0, 255, 0, .5);--yellow: rgba(255, 255, 0, .25);--yellow-hover: rgba(255, 255, 0, .5);--red: rgba(255, 0, 0, .25);--red-hover: rgba(255, 0, 0, .5);--warning: rgba(255, 150, 0, .33)}html,body{margin:0;padding:0;background:black;font-family:Inter,Segoe UI,sans-serif;color:var(--text-color)}canvas{position:fixed;top:0;left:0;z-index:-1}.panel-buttons{position:fixed;top:20px;right:20px;display:flex;flex-direction:row;gap:10px;z-index:1500;transition:all .3s cubic-bezier(.4,0,.2,1)}.panel-button{background:var(--menu-bg);border:1px solid var(--border-color);color:var(--text-color);padding:10px 14px;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:13px;font-weight:500;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;transform:translate(20px);animation:slideInButtonHorizontal .5s cubic-bezier(.4,0,.2,1) forwards}.panel-button:nth-child(5){animation-delay:.1s}.panel-button:nth-child(4){animation-delay:.2s}.panel-button:nth-child(3){animation-delay:.3s}.panel-button:nth-child(2){animation-delay:.4s}.panel-button:nth-child(1){animation-delay:.5s}@keyframes slideInButtonHorizontal{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.panel-button.hide{animation:slideOutButtonHorizontal .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideOutButtonHorizontal{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.panel-button:hover{background:var(--menu-bg);transform:translateY(-2px)}.panel-button.active{background:var(--menu-bg);border-color:var(--accent-color)}.panel-button.menu-button{display:flex;align-items:center;justify-content:center;background:var(--menu-bg);border:1px solid var(--border-color);margin-left:10px;animation-delay:0s!important}.panel-button.menu-button:hover{background:var(--menu-bg);border-color:var(--accent-color)}.menu-icon{font-size:16px;line-height:1}@media (max-width: 768px){.panel-buttons{top:auto;bottom:0;right:0;left:0;transform:none;flex-direction:row;justify-content:space-around;background:rgba(0,0,0,.8);padding:10px;border-top:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow-x:auto;overflow-y:hidden}.panel-button{animation:none;transform:translateY(100%);opacity:0;display:flex;align-items:center;justify-content:center;flex:1;margin:0 5px;padding:12px 8px;font-size:.9em;white-space:nowrap;background:transparent;border:none;color:#fff;-webkit-backdrop-filter:none;backdrop-filter:none}.panel-button:not(.hide){animation:slideInButtonVertical .3s cubic-bezier(.4,0,.2,1) forwards;transform:translateY(0);opacity:1}.panel-button.hide{animation:slideOutButtonVertical .3s cubic-bezier(.4,0,.2,1) forwards;transform:translateY(100%)}@keyframes slideInButtonVertical{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideOutButtonVertical{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}.panel-button:hover{transform:none;background:rgba(255,255,255,.1)}.panel-button.active{background:rgba(255,255,255,.2);border:none}.panel-button.menu-button{margin-left:0;background:transparent;border:none}.menu-icon{font-size:18px}}.control-panel-container{position:fixed;top:80px;right:60px;width:260px;z-index:2000}.control-panel{position:absolute;top:0;left:0;width:100%;background:var(--menu-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-color);padding:20px;border-radius:16px;border:1px solid var(--border-color);z-index:2000;max-height:calc(100vh - 140px);overflow-y:auto;opacity:0;pointer-events:none;transform:translate(100%);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1)}.control-panel::-webkit-scrollbar{width:8px}.control-panel::-webkit-scrollbar-track{background:transparent}.control-panel::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:4px;border:2px solid transparent;background-clip:content-box}.control-panel::-webkit-scrollbar-thumb:hover{background-color:var(--accent-color)}.control-panel.active{opacity:1;pointer-events:all;transform:translate(0)}.control-group{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.control-group:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.control-group h3{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--text-color);display:flex;align-items:center;letter-spacing:.5px}@media (max-width: 768px){.control-panel-container{position:static;top:auto;bottom:auto;left:auto;right:auto;width:auto;transform:none;z-index:2000;transition:none}.control-panel:not(#dynamicPanel){position:fixed;top:auto;bottom:75px;left:50%;transform:translate(-50%) translateY(0);width:90%;max-width:500px;overflow-y:auto}.control-panel.active{opacity:1;pointer-events:all;transform:translate(-50%) translateY(0)}.control-panel:not(.active){opacity:0;pointer-events:none}}#settingsPanel .control-group{margin-bottom:16px}#settingsPanel .performance-toggle{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 20px}#settingsPanel .performance-toggle:last-child{margin-bottom:0}#settingsPanel .toggle-switch{position:relative;display:inline-block;width:44px;height:24px}#settingsPanel .toggle-switch input{opacity:0;width:0;height:0}#settingsPanel .toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);transition:.4s;border-radius:24px}#settingsPanel .toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--text-color);transition:.4s;border-radius:50%}#settingsPanel input:checked+.toggle-slider{background-color:var(--accent-color)}#settingsPanel input:checked+.toggle-slider:before{transform:translate(20px)}@media (max-width: 768px){#settingsPanel .performance-toggle{padding:12px 15px}#settingsPanel .toggle-switch{width:52px;height:30px}#settingsPanel .toggle-slider:before{height:24px;width:24px;left:3px;bottom:3px}#settingsPanel input:checked+.toggle-slider:before{transform:translate(22px)}}.rendering-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--menu-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-color);padding:2rem;border-radius:10px;text-align:center;z-index:1000;max-width:90%;width:400px;opacity:0;animation:dialogFadeIn .3s ease-out forwards}@keyframes dialogFadeIn{0%{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}.rendering-dialog-content{display:flex;flex-direction:column;gap:1rem}.rendering-dialog h2{margin:0 0 1rem;color:var(--text-color)}.rendering-buttons{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.rendering-button{padding:.75rem 1.5rem;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:background-color .2s}.gpu-button{background:var(--green);color:var(--text-color)}.software-button{background:var(--yellow);color:var(--text-color)}.cpu-button{background:var(--red);color:var(--text-color)}.gpu-button:hover{background:var(--green-hover);color:var(--text-color)}.software-button:hover{background:var(--yellow-hover);color:var(--text-color)}.cpu-button:hover{background:var(--red-hover);color:var(--text-color)}.error-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-color);padding:2rem;border-radius:10px;text-align:center;z-index:1000;max-width:90%;width:400px;opacity:0;animation:errorDialogFadeIn .3s ease-out forwards}@keyframes errorDialogFadeIn{0%{opacity:0;transform:translate(-50%,-60%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.error-dialog-content{display:flex;flex-direction:column;gap:1rem}.error-dialog h2{margin:0 0 1rem;color:var(--text-color)}.error-dialog ul{text-align:left;margin:1rem 0;padding-left:1.5rem}.error-dialog li{margin:.5rem 0}.rendering-warning{position:fixed;top:20px;left:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-color);padding:1rem;border-radius:5px;text-align:center;z-index:2500;max-width:300px;opacity:0;animation:warningSlideIn .3s ease-out forwards}.green{background:var(--green)}.red{background:var(--red)}.yellow{background:var(--yellow)}@keyframes warningSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.rendering-dialog.hide,.error-dialog.hide,.rendering-warning.hide{animation:dialogFadeOut .3s ease-in forwards}@keyframes dialogFadeOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.95)}}.rendering-warning.hide{animation:warningFadeOut .3s ease-in forwards}@keyframes warningFadeOut{0%{opacity:1}to{opacity:0}}.slider-container{margin-bottom:.5rem}.slider-container:last-child{margin-bottom:0}.slider-container label{display:block;margin-bottom:4px;font-size:13px;color:var(--text-color);opacity:.9}.slider-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.slider-input-group{display:flex;align-items:center;gap:8px;margin-bottom:4px}.slider-input-group input[type=range]{flex:1;-webkit-appearance:none;height:6px;border-radius:3px;background:var(--slider-bg);outline:none;transition:all .2s ease}.slider-input-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--slider-thumb);cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #0003}.slider-input-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 3px 8px #0000004d}.slider-input-group input[type=number]{width:70px;padding:6px 8px;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-color);font-size:13px;transition:all .2s ease}.slider-input-group input[type=number]:focus{outline:none;border-color:var(--accent-color)}.value-display{font-size:12px;color:var(--text-color);opacity:.8;text-align:center;min-width:40px}.preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:8px}.preset-button{background:var(--button-bg);border:1px solid var(--border-color);color:var(--text-color);padding:6px 4px;border-radius:8px;cursor:pointer;min-height:35px;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:12px;font-weight:500}.preset-button:hover{background:var(--hover-bg);transform:translateY(0)}.preset-button.active{background:var(--active-bg);border-color:var(--accent-color)}.performance-toggle{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding:6px 10px;background:var(--input-bg);border-radius:8px;border:1px solid var(--border-color)}.performance-toggle label{font-size:13px;color:var(--text-color)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--slider-bg);transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--slider-thumb);transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:50%}input:checked+.toggle-slider{background-color:var(--toggle-bg)}input:checked+.toggle-slider:before{transform:translate(20px)}@media (max-width: 768px){.performance-toggle{padding:16px 15px}.toggle-switch{width:52px;height:30px}.toggle-slider:before{height:24px;width:24px;left:3px;bottom:3px}input:checked+.toggle-slider:before{transform:translate(22px)}}.custom-color-section{margin-top:12px;padding-top:8px;border-top:1px solid var(--border-color)}.custom-color-section h4{margin:0 0 6px;font-size:14px;font-weight:600;color:var(--text-color);opacity:.9}.color-picker-group{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.color-picker-group label{font-size:13px;color:var(--text-color);opacity:.8}.color-picker-group input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:40px;height:24px;padding:0;border:1px solid var(--border-color);border-radius:4px;background-color:transparent;cursor:pointer}.color-picker-group input[type=color]::-webkit-color-swatch{border-radius:3px;border:none}.color-picker-group input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-group input[type=color]::-moz-color-swatch{border-radius:3px;border:none}.color-picker-group input[type=color]::-moz-color-swatch-wrapper{padding:0}.shader-type-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:8px}.type-button{background:var(--input-bg);border:1px solid var(--border-color);color:var(--text-color);padding:6px 4px;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:12px;font-weight:500;text-align:center;min-height:35px}.type-button.large-button{padding:10px 8px}.type-button:hover{background:var(--hover-bg);transform:translateY(0)}.type-button.active{background:var(--active-bg);border-color:var(--accent-color)}.generate-random-button{background:var(--input-bg);border:1px solid var(--border-color);color:var(--text-color);padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:13px;font-weight:500;text-align:center;width:100%;min-height:40px;margin-bottom:12px}.generate-random-button:hover{background:var(--hover-bg);transform:translateY(0)}.reset-button{background:var(--red);border:1px solid var(--red-hover);color:var(--text-color);padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:13px;font-weight:500;text-align:center;width:100%;margin-top:8px;min-height:35px}.reset-button:hover{background:var(--red-hover)}.resolution-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}.resolution-button{background:var(--input-bg);border:1px solid var(--border-color);color:var(--text-color);padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:12px;font-weight:500;text-align:center;position:relative;min-height:35px}.resolution-button:hover{background:var(--hover-bg);transform:translateY(0)}.resolution-button.active{background:var(--active-bg);border-color:var(--accent-color)}.debug-menu{position:fixed;left:20px;top:20px;width:300px;height:auto;max-height:80vh;z-index:1000;background-color:var(--menu-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:12px;transform:translate(0);transition:transform .3s ease-in-out;overflow:hidden;display:flex;flex-direction:column}.debug-menu .panel-header{padding:15px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;border-top-left-radius:12px;border-top-right-radius:12px}.debug-menu .panel-header h3{margin:0;font-size:16px;color:var(--text-color);font-weight:500}.debug-menu .panel-content{padding:15px;border-bottom-left-radius:12px;border-bottom-right-radius:12px;overflow-y:auto;flex:1}.debug-menu .debug-item{margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;color:var(--text-color);font-size:14px}.debug-menu .debug-label{color:var(--text-color);font-weight:500}.debug-menu .debug-value{color:var(--text-color);font-family:monospace;background:var(--input-bg);padding:2px 6px;border-radius:4px;border:1px solid var(--border-color)}.debug-menu .debug-section-title{font-weight:500;margin:15px 0 8px;color:var(--text-color);font-size:14px;text-transform:uppercase;letter-spacing:.5px}.debug-menu .debug-uniforms-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px;max-height:300px;overflow-y:auto}.debug-menu .debug-uniform-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-color);background:var(--input-bg);padding:6px 8px;border-radius:4px;border:1px solid var(--border-color);margin-bottom:4px}.debug-menu .debug-uniform-label{color:var(--text-color);font-weight:500}.debug-menu .debug-uniform-value{color:var(--text-color);font-family:monospace;margin-left:8px;word-break:break-all;text-align:right;flex-grow:1;max-width:60%;overflow:hidden;text-overflow:ellipsis}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-track:horizontal{background:transparent}::-webkit-scrollbar-thumb{background:rgb(255,255,255,.75);border-radius:8px;border:4px solid rgba(255,255,255,0)}::-webkit-scrollbar-thumb:horizontal{background:rgb(255,255,255,.75);border-radius:8px;border:4px solid rgba(255,255,255,0)}::-webkit-scrollbar-thumb:hover,::-webkit-scrollbar-thumb:horizontal:hover{background:rgba(255,255,255,1)}.hidden-ui{display:none}.presentation-mode-hint{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background-color:#000000b3;color:#fff;padding:10px 20px;border-radius:5px;font-size:14px;opacity:.7;transition:opacity .3s,transform .3s;cursor:pointer;animation:fadeInOut 5s forwards}.presentation-mode-hint:hover{opacity:1;transform:translate(-50%)}@keyframes fadeInOut{0%{opacity:0}10%{opacity:.7}80%{opacity:.7}to{opacity:0;display:none}}.hardware-warning{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#000000e6;color:#fff;padding:20px 30px;border-radius:10px;font-size:16px;text-align:center;max-width:90%;z-index:1000;box-shadow:0 0 20px #00000080}.hardware-warning h2{color:#f55;margin-top:0;margin-bottom:15px}.hardware-warning p{margin-bottom:15px}.hardware-warning button{background-color:#555;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:10px;transition:background-color .3s}.hardware-warning button:hover{background-color:#777}:root{--critical-color: #ff2d2d;--high-color: #ff6b2d;--medium-color: #ffaa2d;--low-color: #ffcc2d;--glass-bg: rgba(30, 30, 30, .4);--glass-border: rgba(255, 255, 255, .12);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .2);--glass-blur: blur(10px)}.error-boundary{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(20,20,20,.85) 0%,rgba(10,10,10,.88) 100%);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);display:flex;align-items:center;justify-content:center;z-index:9999;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;color:var(--text-color, #ffffff);overflow:hidden}.error-boundary:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%23ffffff' fill-opacity='0.03' fill-rule='evenodd'/%3E%3C/svg%3E");opacity:.5;z-index:-1}.error-boundary-content{background:rgba(30,30,30,.5);border:1px solid var(--border-color, rgba(255, 255, 255, .15));border-radius:16px;box-shadow:0 10px 30px #0000004d;padding:2rem;max-width:1500px;width:90%;max-height:90vh;overflow-y:auto;animation:errorFadeIn .5s ease-out forwards;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.debug-mode .error-boundary-content{display:flex;flex-direction:column}@media (min-width: 992px){.debug-mode .error-boundary-content{flex-direction:row;align-items:stretch;gap:2rem;padding:2.5rem}.error-main-column{flex:1;max-width:50%;display:flex;flex-direction:column}.error-details-column{flex:1;border-left:1px solid var(--glass-border);padding-left:2rem;max-height:80vh;overflow-y:auto;position:relative}.error-details-column:before{content:"";position:absolute;top:0;bottom:0;left:0;width:1px;background:linear-gradient(to bottom,rgba(255,255,255,0),rgba(255,255,255,.15),rgba(255,255,255,.15),rgba(255,255,255,0))}.error-main-column .error-actions{margin-top:auto;padding-top:2rem}}@keyframes errorFadeIn{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.error-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .1));padding-bottom:1rem}.error-title-group{display:flex;flex-direction:column;gap:.5rem}.error-header h1{margin:0;font-size:1.8rem;color:var(--accent-color, #ff5252);font-weight:600}.error-type-badge{display:inline-block;padding:.4rem .8rem;border-radius:6px;font-size:.9rem;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 2px 4px #0003;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid rgba(255,255,255,.1)}.error-count{background:rgba(255,82,82,.2);color:var(--accent-color, #ff5252);padding:.4rem .8rem;border-radius:20px;font-size:.9rem;font-weight:500}.error-message{margin-bottom:2rem;font-size:1.1rem;line-height:1.6}.error-location{margin-top:1rem;padding:.8rem;background-color:#0003;border-radius:6px;font-size:.95rem}.error-details{background:rgba(0,0,0,.15);border-radius:12px;padding:1rem;margin-bottom:2rem;border:1px solid rgba(255,255,255,.08)}.error-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.error-details-controls{display:flex;gap:.5rem}.error-details-header h3{margin:0;font-size:1.2rem;font-weight:500}.toggle-details-btn{background:transparent;border:1px solid var(--border-color, rgba(255, 255, 255, .2));color:var(--text-color, #ffffff);padding:.4rem .8rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s}.toggle-details-btn:hover{background:rgba(255,255,255,.1)}.error-technical-details{animation:detailsFadeIn .3s ease-out forwards}@keyframes detailsFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.error-section{margin-bottom:1.5rem}.error-section h4{margin:0 0 .5rem;font-size:1rem;font-weight:500;color:var(--accent-color, #ff5252)}.error-message-text{background:rgba(0,0,0,.2);padding:1rem;border-radius:6px;margin:0;font-family:monospace;overflow-x:auto;white-space:pre-wrap;word-break:break-word;border:1px solid rgba(255,255,255,.05)}.error-detail-text{background:rgba(0,0,0,.2);padding:.8rem;border-radius:6px;margin:0;font-family:monospace;overflow-x:auto;white-space:pre-wrap;word-break:break-word;border:1px solid rgba(255,255,255,.05)}.error-stack{background:rgba(0,0,0,.2);padding:1rem;border-radius:6px;margin:0;font-family:monospace;font-size:.9rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;border:1px solid rgba(255,255,255,.05)}.error-actions{display:flex;flex-wrap:wrap;gap:1rem}.error-action-btn{padding:.8rem 1.2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;outline:none}.error-action-btn.primary{background:rgba(255,82,82,.8);color:#fff;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1)}.error-action-btn.primary:hover{background:rgba(255,112,112,.9);transform:translateY(-2px);box-shadow:0 5px 15px #ff52524d}.error-action-btn.secondary{background:rgba(255,255,255,.08);color:var(--text-color, #ffffff);border:1px solid var(--border-color, rgba(255, 255, 255, .15));-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.error-action-btn.secondary:hover{background:rgba(255,255,255,.15);transform:translateY(-2px);box-shadow:0 5px 15px #ffffff1a}.error-action-btn.tertiary{background:transparent;color:var(--text-color, #ffffff);text-decoration:underline;padding:.8rem 0}.error-action-btn.tertiary:hover{color:var(--accent-color, #ff5252)}.error-close-btn{position:absolute;top:1rem;right:1rem;width:2rem;height:2rem;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--border-color, rgba(255, 255, 255, .15));color:var(--text-color, #ffffff);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.error-close-btn:hover{background:rgba(255,255,255,.15);transform:scale(1.1);box-shadow:0 0 10px #fff3}.error-boundary.minimal-mode{background:linear-gradient(135deg,rgba(30,30,30,.7) 0%,rgba(20,20,20,.75) 100%)}.minimal-content{max-width:500px;text-align:center;padding:2.5rem 2rem;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);position:relative;overflow:hidden}.minimal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.2),rgba(255,255,255,0))}.minimal-content:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.1),rgba(255,255,255,0))}.minimal-header{border-bottom:none;justify-content:center;margin-bottom:2rem}.minimal-header h1{font-size:1.6rem;text-align:center}.minimal-actions{justify-content:center;margin-top:2rem;display:flex;gap:1rem}.minimal-mode .error-action-btn{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s ease;padding:.8rem 1.5rem}.minimal-mode .error-action-btn.primary{background:rgba(255,82,82,.6);border:1px solid rgba(255,255,255,.15)}.minimal-mode .error-action-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0003}.minimal-mode .error-action-btn.primary:hover{background:rgba(255,82,82,.8);box-shadow:0 8px 20px #ff525240}.debug-mode-trigger{position:absolute;bottom:10px;right:10px;width:20px;height:20px;border-radius:50%;background-color:transparent;cursor:pointer;opacity:.1}.debug-mode-trigger:hover{opacity:.2}@media (max-width: 768px){.error-boundary-content{padding:1.5rem}.error-header{flex-direction:column;align-items:flex-start;gap:.5rem}.error-header h1{font-size:1.5rem}.error-details-controls{flex-direction:column;gap:.5rem}.error-actions{flex-direction:column}.error-action-btn{width:100%}}.radio-group{margin-bottom:12px;max-width:100%}.radio-group-label{font-size:13px;color:var(--text-color);opacity:.9;margin-bottom:8px;font-weight:500}.radio-options{display:flex;gap:12px}.radio-stack{flex-direction:column}.radio-inline{flex-direction:row;flex-wrap:wrap;gap:16px}.radio-option{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;border-radius:6px;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;box-sizing:border-box;position:relative;overflow:hidden}.radio-option:hover{background-color:var(--hover-bg)}.radio-option.selected{background-color:var(--active-bg)}.radio-option input[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;border:2px solid var(--border-color);background-color:var(--input-bg);position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin:0;padding:0;box-sizing:border-box}.radio-option input[type=radio]:checked,.radio-option.selected input[type=radio]{border-color:var(--accent-color)}.radio-option input[type=radio]:checked:after,.radio-option.selected input[type=radio]:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;background-color:var(--accent-color)}.radio-option input[type=radio]:focus{outline:none;box-shadow:0 0 0 2px #4a9eff4d}.radio-option label{font-size:13px;color:var(--text-color);cursor:pointer;transition:all .2s ease;flex:1;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:2px}.radio-option:hover label{color:var(--accent-color)}.radio-option.selected label{color:var(--accent-color);font-weight:500}.resolution-section{margin-bottom:16px}.resolution-section .radio-group{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.resolution-section .radio-group:last-child{border-bottom:none}.resolution-section .radio-option{background-color:var(--input-bg);padding:8px 12px;border-radius:6px;border:1px solid var(--border-color);transition:all .2s ease;flex:1;min-width:100px;justify-content:center}.resolution-section .radio-option:hover{background-color:var(--hover-bg)}.resolution-section .radio-option.selected{background-color:var(--active-bg);border-color:var(--accent-color)}.resolution-section .radio-option input[type=radio]{margin-right:8px}.resolution-section .radio-option label{text-align:center;padding:2px 0}@media (max-width: 768px){.radio-option{padding:8px 12px}.radio-option input[type=radio]{width:20px;height:20px}.radio-option input[type=radio]:checked:after,.radio-option.selected input[type=radio]:after{width:10px;height:10px}.radio-option label{font-size:14px}.radio-inline{flex-direction:column;gap:10px}.resolution-section .radio-option{width:100%}}.language-panel{padding:1rem;display:flex;flex-direction:column;gap:1.5rem}.panel-title{margin:0 0 .5rem;font-size:1.2rem;font-weight:600;color:#fff}.language-selection{display:flex;flex-direction:column;gap:1rem}.language-description{margin:0;font-size:.9rem;color:#fffc}.language-info{margin-top:1rem;padding:1rem;background-color:#0003;border-radius:8px}.language-info h4{margin:0 0 .5rem;font-size:1rem;color:#fff}.language-info p{margin:0;font-size:.9rem;color:#fffc;line-height:1.4}.language-radio-group .radio-option{padding:10px 15px;border:1px solid rgba(255,255,255,.1);background-color:#0003;border-radius:8px;transition:all .2s ease}.language-radio-group .radio-option:hover{background-color:#0000004d;border-color:#fff3}.language-radio-group .radio-option.selected{background-color:#4a9eff26;border-color:#4a9eff80}.language-radio-group .radio-option label{font-size:1rem;font-weight:500}@media (max-width: 768px){.language-radio-group .radio-option{padding:12px 15px}.language-radio-group .radio-option label{font-size:1.1rem}}.panel-content-wrapper{position:relative;width:100%;min-height:100px;overflow:hidden;transition:height .3s cubic-bezier(.4,0,.2,1);will-change:height}.panel-content{position:absolute;top:0;left:0;width:100%;opacity:0;visibility:hidden;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1),visibility 0s .3s;will-change:transform,opacity,visibility;pointer-events:none}.panel-content.visible{position:relative;opacity:1;visibility:visible;transform:translate(0);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1),visibility 0s;pointer-events:auto;z-index:1}.panel-content.hidden{position:absolute;opacity:0;visibility:hidden;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1),visibility 0s .3s;pointer-events:none}.panel-content.next-in{animation:slideInFromRight .3s cubic-bezier(.4,0,.2,1) forwards}.panel-content.next-out{animation:slideOutToLeft .3s cubic-bezier(.4,0,.2,1) forwards}.panel-content.prev-in{animation:slideInFromLeft .3s cubic-bezier(.4,0,.2,1) forwards}.panel-content.prev-out{animation:slideOutToRight .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0;visibility:visible}to{transform:translate(0);opacity:1;visibility:visible}}@keyframes slideOutToLeft{0%{transform:translate(0);opacity:1;visibility:visible}to{transform:translate(-100%);opacity:0;visibility:visible}}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0;visibility:visible}to{transform:translate(0);opacity:1;visibility:visible}}@keyframes slideOutToRight{0%{transform:translate(0);opacity:1;visibility:visible}to{transform:translate(100%);opacity:0;visibility:visible}}#dynamicPanel{transition:height .3s cubic-bezier(.4,0,.2,1);will-change:height}.control-panel{height:auto!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}@media (max-width: 768px){#dynamicPanel{position:fixed!important;top:auto!important;bottom:75px!important;left:50%!important;transform:translate(-50%)!important;width:90%!important;max-width:500px!important;margin:0 auto!important;border-radius:16px!important;box-shadow:0 4px 20px #00000026!important;max-height:calc(100vh - 150px)!important;overflow-y:auto!important}#dynamicPanel:not(.active){transform:translate(-50%) translateY(100%)!important;opacity:0!important}#dynamicPanel.active{transform:translate(-50%) translateY(0)!important;opacity:1!important}.panel-content-wrapper{max-height:calc(100vh - 225px)}.panel-content{padding:15px!important;box-sizing:border-box!important}}.debug-menu-tabs{position:fixed;left:20px;top:20px;width:300px;z-index:1000;background-color:var(--menu-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000026;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.debug-tabs-header{display:flex;border-bottom:1px solid var(--border-color)}.debug-tab-button{flex:1;background:transparent;border:none;color:var(--text-color);padding:12px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.debug-tab-button:hover{background:rgba(255,255,255,.05)}.debug-tab-button.active{color:var(--accent-color)}.debug-tab-button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background-color:var(--accent-color);animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.debug-tabs-content{max-height:80vh;overflow-y:auto}.debug-tab-panel{padding:15px;animation:fadeIn .2s ease-out}.debug-item{margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;color:var(--text-color);font-size:14px}.debug-label{color:var(--text-color);font-weight:500}.debug-value{color:var(--text-color);font-family:monospace;background:var(--input-bg);padding:2px 6px;border-radius:4px;border:1px solid var(--border-color)}.debug-section-title{font-weight:500;margin:15px 0 8px;color:var(--text-color);font-size:14px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding-bottom:5px}.debug-uniforms-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px;max-height:70vh;overflow-y:auto}.debug-uniform-item{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text-color);background:var(--input-bg);padding:6px 8px;border-radius:4px;border:1px solid var(--border-color);margin-bottom:4px}.debug-uniform-label{color:var(--text-color);font-weight:500}.debug-uniform-value{color:var(--text-color);font-family:monospace;margin-left:8px;word-break:break-all;text-align:right;flex-grow:1;max-width:60%;overflow:hidden;text-overflow:ellipsis}.debug-message{padding:20px;text-align:center;color:var(--text-color);font-style:italic}.settings-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease-out}.settings-popup{background:var(--panel-bg);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 8px 32px #0000004d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);width:90%;max-width:1500px;height:80%;max-height:800px;display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .3s cubic-bezier(.16,1,.3,1)}.settings-popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color)}.settings-popup-header h2{margin:0;font-size:1.5rem;font-weight:500;color:var(--text-color)}.settings-popup-close{background:transparent;border:none;color:var(--text-color);font-size:24px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.settings-popup-close:hover{background:rgba(255,255,255,.1)}.settings-popup-content{display:flex;flex:1;overflow:hidden}.settings-popup-content-inner{margin:0 auto;max-width:600px}.settings-popup-sidebar{width:300px;border-right:1px solid var(--border-color);overflow-y:auto;background:rgba(0,0,0,.2)}.settings-popup-nav-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;transition:all .2s;color:var(--text-color);font-weight:500;border-left:3px solid transparent}.settings-popup-nav-item:hover{background:rgba(255,255,255,.05)}.settings-popup-nav-item.active{background:rgba(255,255,255,.1);border-left:3px solid var(--accent-color)}.settings-popup-nav-item.active .settings-popup-nav-label{color:var(--accent-color)}.settings-popup-nav-label{flex:1;cursor:pointer}.settings-popup-pin{cursor:pointer;opacity:.6;transition:all .2s;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}.settings-popup-pin svg{transition:all .2s}.settings-popup-pin:hover{opacity:1;background:rgba(255,255,255,.1)}.settings-popup-pin:hover svg{transform:scale(1.2)}.settings-popup-pin.pinned{opacity:1}.settings-popup-pin.pinned svg{color:var(--accent-color)}.settings-popup-main{flex:1;padding:20px;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.settings-popup{width:100%;height:100%;max-height:none;border-radius:0}.settings-popup-content{flex-direction:column}.settings-popup-sidebar{width:100%;height:auto;border-right:none;border-bottom:1px solid var(--border-color);display:flex;overflow-x:auto;overflow-y:hidden}.settings-popup-nav-item{padding:12px 16px;white-space:nowrap;border-left:none;border-bottom:3px solid transparent}.settings-popup-nav-item.active{border-left:none;border-bottom:3px solid var(--accent-color)}.settings-popup-pin{margin-left:8px}}
