.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:56px;background:#111118;border-bottom:1px solid #1e1e2a;flex-shrink:0;gap:8px;min-width:0}.app-header-left,.app-header-right{display:flex;align-items:center;gap:8px;min-width:0}.app-header-right{flex-shrink:0}.app-logo{font-size:1.25rem;font-weight:700;letter-spacing:.5px;color:#fff;white-space:nowrap}.app-logo span{color:#6c5ce7}.header-project-name{font-size:.8rem;color:#666;font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.header-badge{font-size:.75rem;padding:3px 8px;background:#6c5ce726;color:#a29bfe;border-radius:4px;white-space:nowrap}.panel-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:transparent;color:#888;border:none;cursor:pointer;font-size:1.1rem;transition:background .15s ease,color .15s ease;flex-shrink:0}.panel-toggle:hover{background:#1e1e2a;color:#ccc}.app-body{display:flex;flex:1;overflow:hidden}.panel-left{width:300px;min-width:260px;background:#111118;border-right:1px solid #1e1e2a;display:flex;flex-direction:column;overflow-y:auto}.panel-center{flex:1;display:flex;flex-direction:column;background:#0d0d14;overflow:hidden}.panel-right{width:300px;min-width:260px;background:#111118;border-left:1px solid #1e1e2a;display:flex;flex-direction:column;overflow-y:auto}.panel-section{padding:16px;border-bottom:1px solid #1e1e2a}.panel-section:last-child{border-bottom:none}.panel-section h3{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500;transition:all .15s ease;white-space:nowrap}.btn-primary{background:#6c5ce7;color:#fff}.btn-primary:hover{background:#7e70f0}.btn-primary:disabled{background:#3a3460;color:#777;cursor:not-allowed}.btn-secondary{background:#1e1e2a;color:#ccc}.btn-secondary:hover{background:#2a2a3a;color:#fff}.btn-secondary:disabled{background:#161620;color:#444;cursor:not-allowed}.btn-danger:disabled{background:#5a1f1a;color:#777;cursor:not-allowed}.btn-danger{background:#c0392b;color:#fff}.btn-danger:hover{background:#e74c3c}.btn-sm{padding:5px 10px;font-size:.8rem}.btn-block{width:100%}.btn-icon{width:32px;height:32px;padding:0;border-radius:6px;background:#1e1e2a;color:#ccc;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:#2a2a3a;color:#fff}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-online{background:#2ecc7126;color:#2ecc71}.badge-offline{background:#e74c3c26;color:#e74c3c}.badge-calibrating{background:#f1c40f26;color:#f1c40f}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.form-group{margin-bottom:12px}.form-label{display:block;font-size:.8rem;font-weight:500;color:#999;margin-bottom:4px}.form-input,.form-select{width:100%;padding:8px 12px;background:#1a1a24;border:1px solid #2a2a3a;border-radius:6px;color:#e2e2e8;font-size:.85rem}.form-input:focus,.form-select:focus{border-color:#6c5ce7}.slider-container{display:flex;align-items:center;gap:10px}.slider-container input[type=range]{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:#2a2a3a;border-radius:2px;outline:none}.slider-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#6c5ce7;cursor:pointer}.slider-value{font-size:.8rem;color:#888;min-width:36px;text-align:right}.progress-bar{width:100%;height:6px;background:#1e1e2a;border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#6c5ce7,#a29bfe);border-radius:3px;transition:width .3s ease}.progress-bar-fill.error{background:#e74c3c}.info-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.85rem}.info-row .label{color:#777}.info-row .value{color:#ddd;font-weight:500}.canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:16px;position:relative;overflow:hidden;min-width:0}.canvas-toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#111118;border-bottom:1px solid #1e1e2a;flex-shrink:0;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.canvas-toolbar::-webkit-scrollbar{display:none}.canvas-toolbar .separator{width:1px;height:20px;background:#2a2a3a;flex-shrink:0}.timeline-container{background:#111118;border-top:1px solid #1e1e2a;padding:12px 16px;flex-shrink:0}.upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0fd9;border:2px dashed #6c5ce7;border-radius:8px;gap:12px;z-index:10}.upload-overlay p{color:#aaa;font-size:.9rem}.controls-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.radio-group{display:flex;gap:2px;background:#1a1a24;border-radius:6px;overflow:hidden}.radio-group label{padding:6px 14px;font-size:.8rem;cursor:pointer;color:#888;transition:all .15s ease}.radio-group label:hover{color:#ccc}.radio-group input{display:none}.radio-option{padding:6px 14px;font-size:.8rem;cursor:pointer;color:#888;transition:all .15s ease}.radio-option.active{background:#6c5ce7;color:#fff}.render-stages{display:flex;align-items:center;gap:4px;margin:12px 0}.render-stage{flex:1;text-align:center;padding:6px 0;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#555;border-bottom:2px solid #222;transition:all .3s ease}.render-stage.active{color:#6c5ce7;border-color:#6c5ce7}.render-stage.complete{color:#2ecc71;border-color:#2ecc71}.render-stage.error{color:#e74c3c;border-color:#e74c3c}.toggle{position:relative;width:36px;height:20px;background:#2a2a3a;border-radius:10px;cursor:pointer;transition:background .2s ease}.toggle.active{background:#6c5ce7}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s ease}.toggle.active:after{transform:translate(16px)}.error-msg{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:6px;padding:10px 12px;color:#e74c3c;font-size:.85rem;margin-top:8px}.panel-backdrop{display:none}.panel-left,.panel-right{transition:width .25s ease,min-width .25s ease}.panel-left.panel-hidden,.panel-right.panel-hidden{width:0!important;min-width:0!important;overflow:hidden;border:none!important}@media (min-width: 768px) and (max-width: 1099px){.panel-left,.panel-right{width:240px;min-width:0}}@media (max-width: 767px){.panel-left{position:fixed;left:0;top:56px;bottom:0;z-index:200;width:280px!important;min-width:0!important;transform:translate(-100%);transition:transform .25s ease!important;border-right:1px solid #2a2a3a!important;overflow-y:auto;overflow-x:hidden}.panel-left:not(.panel-hidden){transform:translate(0)}.panel-left.panel-hidden{width:280px!important;overflow:hidden;border:none!important}.panel-right{position:fixed;right:0;top:56px;bottom:0;z-index:200;width:280px!important;min-width:0!important;transform:translate(100%);transition:transform .25s ease!important;border-left:1px solid #2a2a3a!important;overflow-y:auto;overflow-x:hidden}.panel-right:not(.panel-hidden){transform:translate(0)}.panel-right.panel-hidden{width:280px!important;overflow:hidden;border:none!important}.panel-center{width:100%;min-width:0}.panel-backdrop.panel-backdrop--open{display:block;position:fixed;right:0;bottom:0;left:0;top:56px;background:#0009;z-index:199;cursor:pointer}.header-project-name,.header-badge{display:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#0a0a0f;color:#e2e2e8;line-height:1.5;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,select{font-family:inherit;outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#111118}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555}
