:root{color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%;background:#1b1d22;color:#e4e6eb;overflow:hidden}.app{position:relative;width:100%;height:100%}.app-layout{display:flex;width:100%;height:100%}.canvas-area{position:relative;flex:1 1 auto;min-width:0;height:100%}.canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0}.canvas-select-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5}.rect-select-box{position:fixed;border:1.5px solid #3a7bd5;background:#3a7bd514;pointer-events:none}.toolbar{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;padding:6px 8px;background:#1c1e24e0;border:1px solid #32353c;border-radius:8px;z-index:10;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.toolbar>button,.tb-menu>button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#2a2d34;color:#e4e6eb;border:1px solid #3a3e46;border-radius:6px;padding:5px 11px;cursor:pointer;font-size:13px;white-space:nowrap;display:flex;align-items:center;gap:5px}.toolbar>button:hover,.tb-menu>button:hover{background:#353941}.toolbar>button:disabled,.tb-menu>button:disabled{opacity:.5;cursor:default}.toolbar>button.active,.tb-menu>button.active{background:#3a7bd5;color:#fff;border-color:#3a7bd5}.tb-menu{position:relative}.tb-indicator{width:6px;height:6px;border-radius:50%;background:#60a5fa;flex-shrink:0}.tb-chevron{font-size:9px;opacity:.55;line-height:1;margin-left:1px}.tb-menu-panel{position:absolute;top:calc(100% + 6px);left:0;min-width:164px;background:#16181ef7;border:1px solid #32353c;border-radius:8px;padding:4px;z-index:200;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 28px #0000008c;display:flex;flex-direction:column}.tb-menu-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;color:#e4e6eb;border:none;border-radius:6px;padding:7px 12px;cursor:pointer;font-size:13px;text-align:left;width:100%;white-space:nowrap}.tb-menu-item:hover:not(:disabled){background:#2e3038}.tb-menu-item:disabled{opacity:.38;cursor:default}.tb-menu-item.active{color:#60a5fa}.tb-menu-item.danger{color:#ffb4b4}.tb-menu-item.danger:hover:not(:disabled){background:#3a2929}.tb-menu-sep{border:none;border-top:1px solid #2c2f38;margin:4px 0}.canvas-footer{position:absolute;bottom:10px;left:12px;max-width:min(480px,calc(100% - 24px));z-index:10;display:flex;flex-direction:column;gap:8px;pointer-events:none}.status{font-size:12px;opacity:.75}.selection-help{margin:0;padding-left:1.2em;font-size:11px;line-height:1.45;opacity:.7;color:#a8adb8;list-style:decimal}.selection-help li{margin:.1em 0}.selection-help kbd{display:inline-block;padding:.05em .35em;font-size:.95em;font-family:inherit;background:#00000040;border:1px solid #3a3e46;border-radius:4px}.loading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#8a8f98;padding:24px;text-align:center}.loading-error{color:#ffb4b4;background:#1b1d22}.import-error-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#3a2929;color:#ffb4b4;border:1px solid #7a3a3a;border-radius:6px;padding:10px 18px;font-size:13px;z-index:9999;pointer-events:none;white-space:pre-wrap;max-width:420px;text-align:center}.right-panel{position:absolute;top:16px;right:16px;z-index:10;width:240px;display:flex;flex-direction:column;gap:10px}.transform-controls,.scene-controls{background:#1c1e24eb;border:1px solid #32353c;border-radius:12px;padding:14px 18px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow:hidden}.panel-header{position:relative;display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0;min-height:28px}.panel-title{flex:1;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#8a8f98;text-align:center}.panel-collapse-icon{position:absolute;right:0;font-size:14px;color:#7a8090;transition:color .2s;line-height:1}.panel-header:hover .panel-collapse-icon{color:#c0c6d4}.panel-body{display:grid;grid-template-rows:1fr;opacity:1;transition:grid-template-rows .38s cubic-bezier(.4,0,.2,1),opacity .28s ease}.panel-body.collapsed{grid-template-rows:0fr;opacity:0}.panel-body-inner{overflow:hidden;display:flex;flex-direction:column;gap:12px;padding-top:14px}.light-toggle-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:46px;background:#1c1e24eb;border:1px solid #32353c;border-radius:12px;color:#6c7280;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .15s,border-color .15s,color .15s}.light-toggle-btn:hover{background:#353941;border-color:#4a5060;color:#a0a8b8}.light-toggle-btn.active{color:#6cb4ff;border-color:#3a7bd5}.transform-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#6c7280;text-align:center;margin-top:4px}.transform-axis{display:grid;grid-template-columns:28px 1fr 1fr;align-items:center;gap:8px}.transform-axis-label{font-size:14px;font-weight:700;color:#a0a8b8;text-align:center;letter-spacing:.05em}.transform-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#2a2d34;color:#e4e6eb;border:1px solid #3a3e46;border-radius:6px;height:44px;min-width:56px;padding:0 10px;cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,transform .05s;-webkit-user-select:none;user-select:none}.transform-btn:hover:not(:disabled){background:#353941;border-color:#4a7fd4}.transform-btn:active:not(:disabled){background:#1e2230;transform:scale(.96)}.transform-btn:disabled{opacity:.32;cursor:default}.transform-btn.active{background:#1e2a40;border-color:#3a7bd5;color:#6cb4ff}.transform-btn-wide{width:100%;height:48px;font-size:15px;font-weight:600;letter-spacing:.02em}.transform-knob-wrap{display:flex;justify-content:center;padding:4px 0 2px}.transform-knob{position:relative;width:116px;height:116px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#34383f,#1d1f24 75%);border:2px solid #3a3e46;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;transition:border-color .15s,box-shadow .15s}.transform-knob:hover:not(.disabled){border-color:#4a7fd4;box-shadow:0 0 0 4px #4a7fd41f}.transform-knob:active:not(.disabled){cursor:grabbing}.transform-knob.disabled{opacity:.32;cursor:default}.transform-knob-ticks{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.transform-knob-rotor{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.transform-knob-marker{position:absolute;top:10px;left:50%;width:5px;height:18px;background:#4a7fd4;border-radius:2px;transform:translate(-50%);box-shadow:0 0 6px #4a7fd499}.transform-knob-angle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:18px;font-weight:600;color:#e4e6eb;pointer-events:none;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums;letter-spacing:.02em}.transform-y-slider{display:flex;align-items:center;gap:8px;width:100%}.transform-y-slider input[type=range]{flex:1;height:4px;border-radius:2px;background:linear-gradient(to right,#3a3e46,#3a3e46);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.transform-y-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#4a7fd4;border:2px solid #2a3f60;cursor:pointer;box-shadow:0 0 4px #4a7fd466;transition:box-shadow .15s}.transform-y-slider input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 0 8px #4a7fd499}.transform-y-slider input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#4a7fd4;border:2px solid #2a3f60;cursor:pointer;box-shadow:0 0 4px #4a7fd466;transition:box-shadow .15s}.transform-y-slider input[type=range]::-moz-range-track{background:transparent;border:none}.transform-y-slider input[type=range]::-moz-range-progress{background:#4a7fd4;height:4px}.transform-y-slider input[type=range]:disabled{opacity:.32;cursor:default}.y-value{font-size:11px;font-weight:600;color:#a0a8b8;min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.port-tooltip{display:flex;flex-direction:column;gap:2px;background:#12141aeb;border:1px solid #3a3e46;border-radius:6px;padding:5px 8px;white-space:nowrap;pointer-events:none;font-size:11px;color:#e4e6eb;box-shadow:0 2px 8px #00000080;min-width:80px}.port-tooltip-label{font-weight:600;font-size:11px;color:#f0f2f5}.port-tooltip-role{font-size:10px;color:#8a8f98}.port-tooltip-status{font-size:10px;color:#60a5fa}.sidebar-handle{position:relative;z-index:20;flex:0 0 18px;width:18px;height:100%;background:#22252d;border:none;border-right:1px solid #32353c;color:#5a6170;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,color .15s;line-height:1}.sidebar-handle:hover{background:#2a2d34;color:#a0a8b8}.sidebar-handle--collapsed{border-right:1px solid #32353c}.sidebar{flex:0 0 260px;width:260px;height:100%;background:#1e2028;border-right:1px solid #2c2f38;display:flex;flex-direction:column;overflow:hidden;z-index:15}.sidebar-header{padding:14px 14px 8px;border-bottom:1px solid #2c2f38;flex:0 0 auto}.sidebar-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#6c7280}.sidebar-search{padding:8px 10px;flex:0 0 auto;border-bottom:1px solid #2c2f38}.sidebar-search-input{width:100%;background:#14161b;border:1px solid #32353c;border-radius:6px;color:#e4e6eb;font-size:12px;padding:5px 8px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.sidebar-search-input::placeholder{color:#4a5060}.sidebar-search-input:focus{border-color:#4a7fd4;box-shadow:0 0 0 2px #4a7fd426}.sidebar-scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#2c2f38 transparent}.sidebar-scroll::-webkit-scrollbar{width:6px}.sidebar-scroll::-webkit-scrollbar-track{background:transparent}.sidebar-scroll::-webkit-scrollbar-thumb{background:#2c2f38;border-radius:3px}.sidebar-empty{padding:20px 14px;font-size:12px;color:#4a5060}.sidebar-group{border-bottom:1px solid #22252d}.sidebar-group-header{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;width:100%;display:flex;align-items:center;gap:6px;padding:8px 10px;cursor:pointer;color:#8a8f98;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;text-align:left}.sidebar-group-header:hover{background:#ffffff08;color:#a0a8b8}.sidebar-group-arrow{font-size:10px;flex:0 0 auto;color:#5a6170}.sidebar-group-name{flex:1 1 auto}.sidebar-group-count{background:#2a2d34;border-radius:10px;padding:1px 6px;font-size:10px;color:#6c7280;letter-spacing:0;font-weight:500}.sidebar-group-body{padding:4px 8px 8px;display:flex;flex-direction:column;gap:6px}.part-card{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#22252d;border:1px solid #2c2f38;border-radius:8px;color:#e4e6eb;cursor:pointer;display:flex;align-items:center;gap:10px;padding:7px 10px;text-align:left;width:100%;transition:background .12s,border-color .12s}.part-card:hover{background:#2a2d38;border-color:#3a3e50}.part-card:active{background:#1e2230}.part-card:active:hover{cursor:grabbing}.part-card-thumb{width:44px;height:44px;flex:0 0 44px;border-radius:6px;overflow:hidden;background:#14161b;display:flex;align-items:center;justify-content:center}.part-card-info{display:flex;flex-direction:column;gap:2px;min-width:0}.part-card-label{font-size:12px;font-weight:500;color:#e4e6eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.part-card-kind{font-size:10px;color:#5a6170;text-transform:uppercase;letter-spacing:.05em}.part-card--in-use{background:#242736;border-color:#3d4460}.part-card--in-use:hover{background:#2a2f42;border-color:#4a5278}.part-card-badge{margin-left:auto;flex-shrink:0;font-size:11px;font-weight:600;color:#7b8ec8;background:#2a3050;border-radius:4px;padding:1px 5px;letter-spacing:.02em;line-height:1.5}.thumb-wrap{width:100%;height:100%}.thumb-wrap canvas{display:block;width:100%!important;height:100%!important}.toolbar-projects-wrap{position:relative}.toolbar-projects-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#2a2d34;color:#e4e6eb;border:1px solid #3a3e46;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:13px;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}.toolbar-projects-btn:hover{background:#353941}.project-panel{position:absolute;top:calc(100% + 8px);left:0;z-index:100;background:#1e2028;border:1px solid #32353c;border-radius:10px;box-shadow:0 8px 32px #00000080;width:300px;display:flex;flex-direction:column;gap:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden}.project-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;border-bottom:1px solid #2c2f38}.project-panel-title{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#6c7280}.project-panel-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;color:#6c7280;cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.project-panel-close:hover{color:#e4e6eb}.project-current{padding:10px 14px 6px}.project-current-name{font-size:14px;font-weight:600;color:#e4e6eb;cursor:pointer;border-bottom:1px dashed transparent;transition:border-color .15s}.project-current-name:hover{border-bottom-color:#4a7fd4}.project-name-input{width:100%;background:#14161b;border:1px solid #4a7fd4;border-radius:4px;color:#e4e6eb;font-size:14px;font-weight:600;padding:3px 6px;outline:none;box-shadow:0 0 0 2px #4a7fd426}.project-actions{display:flex;gap:6px;padding:6px 14px 10px}.project-actions button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#2a2d34;color:#e4e6eb;border:1px solid #3a3e46;border-radius:6px;padding:5px 10px;cursor:pointer;font-size:12px}.project-actions button:hover{background:#353941}.project-actions button:disabled{opacity:.4;cursor:default}.project-actions button.danger{border-color:#5e3030;color:#ffb4b4}.project-actions button.danger:hover{background:#3a2929}.project-divider{height:1px;background:#2c2f38}.project-list{max-height:240px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#2c2f38 transparent;padding:6px 0}.project-list::-webkit-scrollbar{width:6px}.project-list::-webkit-scrollbar-thumb{background:#2c2f38;border-radius:3px}.project-list-empty{padding:12px 14px;font-size:12px;color:#4a5060}.project-list-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;width:100%;text-align:left;padding:7px 14px;cursor:pointer;display:flex;flex-direction:column;gap:2px;transition:background .1s}.project-list-item:hover{background:#ffffff0a}.project-list-item.active{background:#4a7fd41f}.project-list-name{font-size:13px;color:#e4e6eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-list-meta{font-size:11px;color:#5a6170}.project-io{display:flex;gap:6px;padding:10px 14px}.project-io button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#2a2d34;color:#e4e6eb;border:1px solid #3a3e46;border-radius:6px;padding:5px 10px;cursor:pointer;font-size:12px;flex:1}.project-io button:hover{background:#353941}.project-io button:disabled{opacity:.4;cursor:default}.unsupported-device{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:100%;padding:24px;box-sizing:border-box}.unsupported-device__text{margin:0;max-width:28rem;text-align:center;line-height:1.55;font-size:15px;color:#c8ccd4}.ring-closure-prompt{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#23272f;border:1px solid #4a90e2;border-radius:8px;padding:12px 20px;display:flex;align-items:center;gap:12px;z-index:1000;box-shadow:0 4px 16px #00000080;color:#e8eaf0;font-size:14px}.ring-closure-prompt__actions{display:flex;gap:8px}.ring-closure-prompt__confirm{background:#4a90e2;color:#fff;border:none;border-radius:4px;padding:6px 14px;cursor:pointer}.ring-closure-prompt__cancel{background:transparent;color:#a0a8b8;border:1px solid #555;border-radius:4px;padding:6px 14px;cursor:pointer}
