.tooltip{position:fixed;z-index:9999;padding:4px 10px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;box-shadow:0 4px 16px #00000080;pointer-events:none;white-space:nowrap;font-size:12px;color:var(--text-primary, #ddd);transform:translateY(-50%)}.tooltip-top{transform:translate(-50%,-100%)}.tooltip-bottom{transform:translate(-50%)}.tooltip-left{transform:translate(-100%,-50%)}.tooltip-rich{white-space:normal;max-width:240px;padding:8px 12px}.tooltip-header{display:flex;align-items:center;gap:8px}.tooltip-label{font-weight:600}.tooltip-shortcut{font-size:10px;font-family:SF Mono,Fira Code,monospace;color:var(--text-muted, #888);background:var(--input-bg, #1a1a1a);padding:1px 5px;border-radius:3px;border:1px solid var(--panel-border, #333);flex-shrink:0}.tooltip-description{margin-top:4px;font-size:11px;line-height:1.4;color:var(--text-secondary, #aaa);font-weight:400}.toolbar-dock{grid-area:tools;display:flex;flex-direction:column;align-items:center;padding:8px 4px;gap:2px;background:var(--panel-bg, #252525);border-right:1px solid var(--panel-border, #333)}.toolbar-dock-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;padding:0;position:relative;transition:background .1s ease,color .1s ease,border-color .1s ease;-webkit-user-select:none;user-select:none}.toolbar-dock-btn:hover:not(.disabled){background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.toolbar-dock-btn.active{background:var(--hover-bg, #333);border-color:var(--accent, #4a9eff);color:var(--accent, #4a9eff)}.toolbar-dock-btn.disabled{color:var(--text-muted, #555);cursor:not-allowed;opacity:.5}.coming-soon-overlay{position:fixed;inset:0;z-index:10001;background:#00000080;display:flex;align-items:center;justify-content:center;animation:dialog-backdrop-in .15s ease}.coming-soon-card{background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #333);border-radius:12px;padding:28px 32px 24px;max-width:360px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px;animation:dialog-card-in .2s ease}.coming-soon-text{margin:0;font-size:14px;line-height:1.5;color:var(--text-primary, #ddd)}.coming-soon-btn{padding:8px 28px;font-size:13px;border-radius:6px;border:1px solid var(--accent-bg, #1976d2);background:var(--accent-bg, #1976d2);color:#fff;cursor:pointer;transition:filter .15s ease;font-family:inherit}.coming-soon-btn:hover{filter:brightness(1.1)}.toolbar-dock-btn.has-subtool:after{content:"";position:absolute;bottom:3px;right:3px;width:0;height:0;border-left:4px solid transparent;border-bottom:4px solid var(--text-muted, #666);pointer-events:none}.toolbar-dock-btn.has-subtool.active:after{border-bottom-color:var(--accent, #4a9eff)}.toolbar-separator{width:20px;height:1px;background:var(--panel-border, #444);margin:4px 0}.toolbar-color-spacer{flex:1;min-height:8px}.toolbar-color-swatch{width:28px;height:28px;border:2px solid var(--panel-border, #444);border-radius:4px;cursor:pointer;padding:0;transition:border-color .15s ease,box-shadow .15s ease;flex-shrink:0}.toolbar-color-swatch:hover{border-color:var(--text-secondary, #aaa);box-shadow:0 0 0 2px #ffffff1a}.toolbar-color-input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.toolbar-flyout{position:fixed;z-index:10000;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;padding:4px;display:flex;flex-direction:column;gap:2px;box-shadow:0 4px 12px #0006;min-width:150px}.toolbar-flyout-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;border:none;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;font-size:12px;white-space:nowrap;font-family:inherit;text-align:left}.toolbar-flyout-item:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.toolbar-flyout-item.selected{color:var(--accent, #4a9eff)}.toolbar-flyout-item .flyout-icon{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.toolbar-flyout-item .flyout-shortcut{margin-left:auto;color:var(--text-muted, #666);font-size:11px}@media(pointer:coarse){.toolbar-dock-btn{min-width:44px;min-height:44px}}@keyframes dialog-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes dialog-card-in{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.floating-action-bar{position:absolute;left:0;top:0;z-index:500;display:flex;align-items:center;gap:2px;padding:3px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;box-shadow:0 2px 8px #0006;pointer-events:auto;will-change:transform}.fab-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:4px;background:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:0}.fab-btn:hover{background:var(--hover-bg, #3a3a3a);color:var(--text-primary, #e0e0e0)}.fab-separator{width:1px;height:18px;background:var(--panel-border, #444);margin:0 2px}.fab-btn-active{background:var(--hover-bg, #3a3a3a);color:var(--accent-color, #5b9bd5)}.fab-flip-dropdown{position:fixed;z-index:1001;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;padding:4px 0;box-shadow:0 4px 12px #0006;min-width:140px}.fab-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;border:none;background:none;color:var(--text-primary, #e0e0e0);cursor:pointer;text-align:left;font-size:13px;font-family:inherit}.fab-dropdown-item:hover{background:var(--hover-bg, #3a3a3a)}.fab-collapse-btn{display:flex;align-items:center;justify-content:center;width:16px;height:28px;border:none;border-radius:4px;background:none;color:var(--text-secondary, #aaa);cursor:pointer;padding:0;font-size:10px}.fab-collapse-btn:hover{background:var(--hover-bg, #3a3a3a);color:var(--text-primary, #e0e0e0)}.viewport-action-bar{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:600;display:flex;align-items:center;gap:6px;padding:6px 8px 6px 12px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:8px;box-shadow:0 4px 16px #00000080;pointer-events:auto;user-select:none;-webkit-user-select:none;font-family:inherit;color:var(--text-primary, #e0e0e0)}.viewport-action-bar-label{font-size:12px;color:var(--text-secondary, #aaa);margin-right:4px;white-space:nowrap}.viewport-action-bar-btn{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:8px 14px;border:1px solid transparent;border-radius:6px;background:none;color:var(--text-primary, #e0e0e0);cursor:pointer;font-size:13px;font-family:inherit;font-weight:500;line-height:1;touch-action:manipulation}.viewport-action-bar-btn:hover:not(:disabled){background:var(--hover-bg, #3a3a3a)}.viewport-action-bar-btn:disabled{opacity:.45;cursor:not-allowed}.viewport-action-bar-btn-text{display:inline}.viewport-action-bar-cancel{color:var(--text-secondary, #aaa)}.viewport-action-bar-cancel:hover:not(:disabled){color:var(--text-primary, #e0e0e0)}.viewport-action-bar-accept{background:var(--accent, #5b9bd5);color:#fff;border-color:var(--accent, #5b9bd5)}.viewport-action-bar-accept:hover:not(:disabled){filter:brightness(1.1);background:var(--accent, #5b9bd5)}.viewport-action-bar-accept:disabled{background:var(--hover-bg, #3a3a3a);border-color:var(--panel-border, #444);color:var(--text-secondary, #aaa)}@media(max-width:480px){.viewport-action-bar{gap:4px;padding:6px}.viewport-action-bar-label{display:none}}.viewport-canvas-wrapper{width:100%;height:100%;position:relative;overflow:hidden;background:var(--canvas-bg, #1a1a1a)}.viewport-gpu-canvas{position:absolute;top:0;left:0;display:block;pointer-events:none}.viewport-overlay-canvas{position:absolute;top:0;left:0;display:block;touch-action:none;-webkit-user-select:none;user-select:none}.context-menu{position:fixed;z-index:1000;min-width:180px;background:var(--panel-bg, #2a2a2a);border:1px solid var(--panel-border, #444);border-radius:6px;padding:4px 0;box-shadow:0 4px 16px #0006;font-size:13px}.context-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 12px;border:none;background:none;color:var(--text-primary, #e0e0e0);cursor:pointer;text-align:left;font-size:inherit;font-family:inherit;gap:16px}.context-menu-item:hover:not(:disabled){background:var(--hover-bg, #3a3a3a)}.context-menu-item:disabled{color:var(--text-disabled, #666);cursor:default}.context-menu-shortcut{color:var(--text-secondary, #999);font-size:11px;white-space:nowrap}.context-menu-separator{height:1px;margin:4px 8px;background:var(--panel-border, #444)}.toast{position:fixed;top:64px;left:50%;transform:translate(-50%);z-index:9999;padding:8px 16px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;box-shadow:0 2px 12px #00000080;color:var(--text-primary, #e0e0e0);font-size:13px;font-weight:500;pointer-events:none;animation:toast-fade-in .15s ease-out;max-width:min(80vw,420px);text-align:center}@keyframes toast-fade-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.dialog-backdrop{position:fixed;inset:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;animation:dialog-backdrop-in .15s ease}.dialog-card{background:var(--panel-bg, #2a2a2a);border:1px solid var(--panel-border, #444);border-radius:8px;max-width:90vw;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;overflow:hidden;animation:dialog-card-in .2s ease}.dialog-card-spacious{border-radius:12px;background:var(--panel-bg, #252525);border-color:var(--panel-border, #333)}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-size:14px;font-weight:600;color:var(--text-primary, #ddd);border-bottom:1px solid var(--panel-border, #333)}.dialog-header-spacious{padding:24px 24px 16px;align-items:flex-start}.dialog-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary, #ddd)}.dialog-desc{margin:8px 0 0;font-size:13px;color:var(--text-secondary, #aaa);line-height:1.5}.dialog-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted, #888);cursor:pointer;font-size:18px;border-radius:4px;flex-shrink:0}.dialog-close:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.dialog-body{flex:1;overflow-y:auto}.dialog-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--panel-border, #333);justify-content:flex-end;align-items:center}.dialog-footer-spacious{padding:16px 24px}.shape-picker-kinds{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;justify-content:center}.shape-kind-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border:1px solid var(--panel-border, #444);border-radius:6px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;font-size:11px;transition:all .1s ease;min-width:60px}.shape-kind-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.shape-kind-btn.active{background:var(--hover-bg, #333);border-color:var(--accent, #4a9eff);color:var(--accent, #4a9eff)}.shape-picker-preview{display:flex;justify-content:center;padding:8px 16px}.shape-picker-preview canvas{background:var(--canvas-bg, #1a1a1a);border-radius:6px;border:1px solid var(--panel-border, #333)}.shape-picker-params{padding:8px 16px 12px;display:flex;flex-direction:column;gap:8px}.shape-param{display:flex;align-items:center;gap:8px}.shape-param label{font-size:12px;color:var(--text-secondary, #aaa);min-width:75px;flex-shrink:0}.shape-param input[type=range]{flex:1;height:4px;accent-color:var(--accent, #4a9eff)}.shape-param-value{font-size:12px;color:var(--text-primary, #ddd);min-width:32px;text-align:right;font-variant-numeric:tabular-nums}.shape-param-input{width:48px;padding:2px 4px;font-size:12px;color:var(--text-primary, #ddd);background:var(--canvas-bg, #1a1a1a);border:1px solid var(--panel-border, #444);border-radius:3px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;-moz-appearance:textfield}.shape-param-input::-webkit-inner-spin-button,.shape-param-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.shape-param-input:focus{outline:none;border-color:var(--accent, #4a9eff)}.shape-param-hint{font-size:11px;color:var(--text-muted, #666)}.shape-picker-cancel,.shape-picker-create{padding:6px 16px;border-radius:4px;border:1px solid var(--panel-border, #444);font-size:13px;cursor:pointer}.shape-picker-cancel{background:transparent;color:var(--text-secondary, #aaa)}.shape-picker-cancel:hover{background:var(--hover-bg, #333)}.shape-picker-create{background:var(--accent, #4a9eff);border-color:var(--accent, #4a9eff);color:#fff}.shape-picker-create:hover{filter:brightness(1.1)}.main-menu{position:relative;display:flex;align-items:center;z-index:1100}.main-menu-bar{display:flex;align-items:center;gap:0}.main-menu-trigger{padding:4px 10px;font-size:12px;font-weight:500;color:var(--text-secondary, #aaa);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.main-menu-trigger:hover,.main-menu-trigger-active{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.main-menu-dropdown{position:absolute;top:100%;margin-top:2px;min-width:240px;max-height:80vh;overflow-y:auto;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:8px;padding:4px 0;box-shadow:0 8px 32px #0006}.main-menu-item{display:flex;align-items:center;width:100%;padding:6px 12px;font-size:12px;color:var(--text-primary, #ddd);background:transparent;border:none;cursor:pointer;text-align:left;gap:0;transition:background .1s}.main-menu-item:hover:not(:disabled){background:var(--hover-bg, #333)}.main-menu-item-disabled{opacity:.4;cursor:default}.main-menu-check{width:16px;font-size:8px;color:var(--accent-bg, #4dabf7);flex-shrink:0}.main-menu-label{flex:1}.main-menu-shortcut{margin-left:24px;font-size:11px;color:var(--text-muted, #666);font-family:SF Mono,Fira Code,monospace;white-space:nowrap}.main-menu-separator{height:1px;margin:4px 8px;background:var(--panel-border, #333)}.main-menu-submenu-trigger{position:relative;cursor:pointer}.main-menu-submenu-trigger:hover{background:var(--hover-bg, #333)}.main-menu-submenu-portal{position:fixed;min-width:200px;max-height:80vh;overflow-y:auto;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:8px;padding:4px 0;box-shadow:0 8px 32px #0006;z-index:1200}.app-header{grid-area:header;display:flex;align-items:center;gap:12px;padding:0 16px;height:48px;background:var(--toolbar-bg, #252525);border-bottom:1px solid var(--panel-border, #333)}.header-button{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .15s ease}.header-button-primary{background:var(--accent-bg, #1976d2)}.header-button-secondary{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.header-button:hover:not(:disabled){filter:brightness(.9)}.header-button:active:not(:disabled){filter:brightness(.8)}.header-button:disabled{opacity:.6;cursor:wait}.header-button-active{background:var(--accent-bg, #1976d2)!important;color:#fff!important}.header-spacer{flex:1}.header-select{padding:5px 24px 5px 8px;font-size:12px;font-family:inherit;color:var(--text-primary, #ddd);background-color:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;cursor:pointer;outline:none;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.header-select:focus{border-color:var(--accent-bg, #1976d2)}.header-select option{color:var(--text-primary, #ddd);background-color:var(--panel-bg, #252525)}.header-zoom-group{display:flex;align-items:center;gap:2px}.header-zoom-btn{padding:4px 8px;font-size:11px;font-weight:500;color:var(--text-secondary, #aaa);background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:4px;cursor:pointer;transition:color .1s ease,background .1s ease}.header-zoom-btn:hover{color:var(--text-primary, #ddd);background:var(--panel-border, #444)}.header-zoom-pct{padding:0 6px;font-size:11px;font-family:SF Mono,Fira Code,monospace;color:var(--text-muted, #888);min-width:40px;text-align:right}.header-auth-indicator{display:flex;align-items:center;gap:6px;margin-left:8px}.header-auth-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent-bg, #1976d2);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;object-fit:cover}.header-tier-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:3px;background:#51cf6626;color:#51cf66;letter-spacing:.04em}.header-button-auth{background:transparent;color:var(--accent-bg, #4dabf7);border:1px solid var(--accent-bg, #4dabf7);font-size:12px;padding:4px 12px;margin-left:8px}.header-button-auth:hover{background:#4dabf71a;filter:none}.header-pathing-dropdown{position:absolute;top:100%;left:0;margin-top:4px;z-index:1001;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;padding:8px 12px;min-width:220px;display:flex;flex-direction:column;gap:8px}.header-pathing-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-primary, #ddd);cursor:pointer}.header-pathing-row input[type=checkbox]{accent-color:var(--accent-bg, #1976d2)}.header-pathing-row input[type=range]{flex:1;height:4px;accent-color:var(--accent-bg, #1976d2)}.header-pathing-row input[type=range]:disabled{opacity:.4}.header-pathing-label{min-width:64px;font-size:11px;color:var(--text-secondary, #aaa)}.header-pathing-value{min-width:42px;text-align:right;font-size:11px;font-family:SF Mono,Fira Code,monospace;color:var(--text-muted, #888)}@media(max-width:900px){.app-header{gap:6px;padding:0 8px}.header-button{padding:6px 10px;font-size:12px}}@media(max-width:700px){.header-zoom-group .header-zoom-btn:not(:first-child){display:none}.header-select{max-width:110px;overflow:hidden;text-overflow:ellipsis}}.align-row{display:flex;gap:4px;margin-bottom:6px}.align-row:last-child{margin-bottom:0}.align-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;padding:0;transition:background .1s ease,color .1s ease}.align-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.align-btn:active{background:var(--active-bg, #444)}.transform-grid{display:grid;grid-template-columns:16px minmax(0,1fr) 16px minmax(0,1fr);gap:4px;align-items:center}.transform-row{display:grid;grid-template-columns:16px minmax(0,1fr);gap:4px;align-items:center}.transform-label{font-size:11px;font-weight:600;color:var(--text-muted, #888);text-align:right;user-select:none}.transform-stepper{display:flex;align-items:center;gap:0}.transform-step-btn{width:18px;height:22px;display:flex;align-items:center;justify-content:center;border:1px solid var(--panel-border, #444);background:var(--input-bg, #1a1a1a);color:var(--text-muted, #888);cursor:pointer;font-size:11px;font-weight:600;padding:0;flex-shrink:0;user-select:none}.transform-step-btn:first-child{border-radius:3px 0 0 3px;border-right:none}.transform-step-btn:last-child{border-radius:0 3px 3px 0;border-left:none}.transform-step-btn:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.transform-step-btn:active{background:var(--accent, #4a9eff);color:#fff}.transform-input{flex:1;min-width:0;height:22px;padding:2px 4px;font-size:11px;font-family:SF Mono,Fira Code,monospace;color:var(--text-primary, #ddd);background:var(--input-bg, #1a1a1a);border:1px solid var(--panel-border, #444);border-radius:0;border-left:none;border-right:none;outline:none;box-sizing:border-box;-moz-appearance:textfield;text-align:center}.transform-input::-webkit-inner-spin-button,.transform-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.transform-input:focus{border-color:var(--accent, #4a9eff)}.transform-size-group{display:flex;align-items:center;gap:4px;margin-top:4px}.transform-size-inputs{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.transform-lock-btn{width:22px;height:48px;display:flex;align-items:center;justify-content:center;border:1px solid var(--panel-border, #444);border-radius:3px;background:transparent;color:var(--text-muted, #666);cursor:pointer;padding:0;flex-shrink:0;transition:color .1s ease,border-color .1s ease}.transform-lock-btn:hover{color:var(--text-primary, #ddd)}.transform-lock-btn.locked{color:var(--accent, #4a9eff);border-color:var(--accent, #4a9eff)}.transform-center-btn{display:flex;align-items:center;gap:6px;width:100%;height:26px;margin-top:4px;padding:0 8px;font-size:11px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #2a2a2a);color:var(--text-primary, #ccc);cursor:pointer;transition:background .1s}.transform-center-btn:hover{background:var(--hover-bg, #383838)}.transform-subsection-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #888);margin-top:8px;margin-bottom:4px}.transform-rotation-row{display:flex;align-items:center;gap:4px}.transform-quick-actions{display:flex;gap:4px;margin-top:2px}.transform-quick-btn{flex:1;display:flex;align-items:center;justify-content:center;height:26px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #2a2a2a);color:var(--text-primary, #ccc);cursor:pointer;transition:background .1s}.transform-quick-btn:hover{background:var(--hover-bg, #383838)}.transform-quick-btn:active{background:var(--accent, #4a9eff);color:#fff}.transform-unit-hint{font-size:10px;color:var(--text-muted, #666);text-align:right;margin-top:4px}@container (max-width: 240px){.transform-grid{grid-template-columns:16px minmax(0,1fr)}}.match-thread-body{display:flex;flex-direction:column;gap:12px;min-height:200px}.match-mode-group{display:flex;flex-direction:column;gap:8px}.match-mode-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;cursor:pointer;border:1px solid var(--panel-border, #333);background:var(--panel-bg, #1e1e1e);transition:border-color .15s}.match-mode-option:hover{border-color:var(--accent, #4ea1f3)}.match-mode-option.selected{border-color:var(--accent, #4ea1f3);background:#4ea1f314}.match-mode-label{font-weight:500;font-size:13px}.match-mode-desc{font-size:11px;color:var(--text-secondary, #999);margin-top:2px}.match-force-unique{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-left:24px;font-size:12px;color:var(--text-secondary, #999)}.match-force-unique input[type=checkbox]{accent-color:var(--accent, #4ea1f3)}.match-chart-section{display:flex;flex-direction:column;gap:8px}.match-chart-select{padding:6px 8px;border-radius:4px;border:1px solid var(--panel-border, #333);background:var(--input-bg, #2a2a2a);color:var(--text-primary, #eee);font-size:12px}.match-chart-empty{font-size:12px;color:var(--text-secondary, #999);padding:8px 0}.match-browse-btn{font-size:11px;color:var(--accent, #4ea1f3);background:none;border:none;cursor:pointer;text-decoration:underline;padding:4px 0;text-align:left}.match-browse-list{max-height:200px;overflow-y:auto;border:1px solid var(--panel-border, #333);border-radius:4px;padding:4px}.match-browse-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;font-size:11px;border-radius:3px;cursor:pointer}.match-browse-item:hover{background:#ffffff0d}.match-browse-item-name{flex:1}.match-browse-item-count{color:var(--text-secondary, #999);font-size:10px;margin-left:8px}.match-browse-add-btn{font-size:10px;padding:2px 8px;border-radius:3px;border:1px solid var(--accent, #4ea1f3);background:none;color:var(--accent, #4ea1f3);cursor:pointer}.match-browse-search{width:100%;padding:4px 8px;margin-bottom:4px;border:1px solid var(--panel-border, #333);border-radius:3px;background:var(--input-bg, #2a2a2a);color:var(--text-primary, #eee);font-size:11px}.match-manual-layout{display:flex;gap:12px;min-height:300px}.match-manual-palette{width:180px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex-shrink:0}.match-manual-palette-item{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:11px;border:1px solid transparent}.match-manual-palette-item:hover{background:#ffffff0d}.match-manual-palette-item.selected{border-color:var(--accent, #4ea1f3);background:#4ea1f314}.match-manual-palette-item.matched{opacity:.7}.match-manual-swatch{width:16px;height:16px;border-radius:3px;flex-shrink:0;border:1px solid rgba(255,255,255,.15)}.match-manual-check{color:#4caf50;font-size:12px;margin-left:auto}.match-manual-threads{flex:1;display:flex;flex-direction:column;gap:6px;overflow:hidden}.match-thread-search{padding:5px 8px;border:1px solid var(--panel-border, #333);border-radius:4px;background:var(--input-bg, #2a2a2a);color:var(--text-primary, #eee);font-size:11px}.match-thread-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(28px,1fr));gap:3px;overflow-y:auto;flex:1;padding:2px}.match-thread-cell{width:28px;height:28px;border-radius:3px;cursor:pointer;border:2px solid transparent;transition:border-color .1s}.match-thread-cell:hover{border-color:#fff}.match-thread-cell.picked{border-color:var(--accent, #4ea1f3);box-shadow:0 0 0 1px var(--accent, #4ea1f3)}.match-review-table{width:100%;border-collapse:collapse;font-size:12px}.match-review-table th{text-align:left;font-size:11px;color:var(--text-secondary, #999);padding:4px 8px;border-bottom:1px solid var(--panel-border, #333)}.match-review-row{cursor:pointer;transition:background .1s}.match-review-row:hover{background:#ffffff0a}.match-review-row td{padding:6px 8px;vertical-align:middle}.match-review-swatch{width:20px;height:20px;border-radius:3px;display:inline-block;vertical-align:middle;border:1px solid rgba(255,255,255,.15)}.match-review-arrow{color:var(--text-secondary, #999);font-size:14px;text-align:center}.match-review-thread-info{display:flex;align-items:center;gap:6px}.match-footer{display:flex;justify-content:flex-end;gap:8px}.match-btn{padding:6px 16px;border-radius:4px;font-size:12px;cursor:pointer;border:1px solid var(--panel-border, #333);background:var(--panel-bg, #1e1e1e);color:var(--text-primary, #eee)}.match-btn:hover{background:#ffffff14}.match-btn.primary{background:var(--accent, #4ea1f3);border-color:var(--accent, #4ea1f3);color:#fff}.match-btn.primary:hover{opacity:.9}.match-btn:disabled{opacity:.4;cursor:default}.palette-list{display:flex;flex-direction:column;gap:1px}.palette-row{display:flex;align-items:center;gap:8px;padding:5px 4px;border-radius:4px;cursor:pointer;min-height:28px}.palette-row:hover{background:var(--hover-bg, rgba(255,255,255,.04))}.palette-row.active{background:var(--accent-bg-muted, rgba(25, 118, 210, .15));outline:1px solid var(--accent-bg, #1976d2)}.palette-swatch{width:20px;height:20px;border-radius:3px;border:1px solid var(--panel-border, #444);flex-shrink:0}.palette-color-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border:1px solid var(--panel-border, #444);border-radius:3px;padding:0;cursor:pointer;background:none;flex-shrink:0}.palette-color-input::-webkit-color-swatch-wrapper{padding:0}.palette-color-input::-webkit-color-swatch{border:none;border-radius:2px}.palette-color-input::-moz-color-swatch{border:none;border-radius:2px}.palette-name{font-size:12px;color:var(--text-primary, #ddd);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:none}.palette-name-input{font-size:12px;color:var(--text-primary, #ddd);background:var(--input-bg, #1a1a1a);border:1px solid var(--accent-bg, #1976d2);border-radius:3px;padding:2px 4px;flex:1;outline:none}.palette-remove{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;border-radius:3px;font-size:14px;padding:0;flex-shrink:0;opacity:0;transition:opacity .1s}.palette-row:hover .palette-remove{opacity:1}.palette-remove:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.palette-add-form{display:flex;align-items:center;gap:6px;margin-top:8px}.palette-add-picker{width:28px;height:28px;padding:1px;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;cursor:pointer;flex-shrink:0}.palette-add-name{font-size:12px;color:var(--text-primary, #ddd);background:var(--input-bg, #1a1a1a);border:1px solid var(--panel-border, #444);border-radius:4px;padding:4px 6px;flex:1;min-width:0;outline:none}.palette-add-name:focus{border-color:var(--accent-bg, #1976d2)}.palette-add-confirm,.palette-add-cancel{font-size:11px;padding:4px 8px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #252525);color:var(--text-secondary, #aaa);cursor:pointer;white-space:nowrap}.palette-add-confirm:hover{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.palette-add-cancel:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.palette-actions{display:flex;gap:6px;margin-top:8px}.palette-action-btn{font-size:11px;padding:4px 10px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #252525);color:var(--text-secondary, #aaa);cursor:pointer}.palette-action-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.palette-load-menu{margin-top:6px;border:1px solid var(--panel-border, #444);border-radius:6px;overflow:hidden}.palette-load-item{display:flex;align-items:center;gap:6px;padding:6px 8px;cursor:pointer}.palette-load-item:hover{background:var(--hover-bg, rgba(255,255,255,.04))}.palette-load-item+.palette-load-item{border-top:1px solid var(--panel-border, #333)}.palette-load-swatches{display:flex;gap:2px;flex-shrink:0}.palette-load-mini-swatch{width:12px;height:12px;border-radius:2px;border:1px solid var(--panel-border, #444)}.palette-load-more{font-size:10px;color:var(--text-muted, #666);margin-left:2px}.palette-load-name{font-size:12px;color:var(--text-primary, #ddd);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-load-item .palette-remove{opacity:0}.palette-load-item:hover .palette-remove{opacity:1}.palette-dropdown{position:relative}.palette-dropdown-trigger{display:flex;align-items:center;gap:6px;padding:3px 8px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--input-bg, #1a1a1a);color:var(--text-primary, #ddd);cursor:pointer;font-size:12px;width:100%}.palette-dropdown-trigger:hover{border-color:var(--text-muted, #666)}.palette-dropdown-swatch{width:16px;height:16px;border-radius:2px;border:1px solid var(--panel-border, #444);flex-shrink:0}.palette-dropdown-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.palette-dropdown-chevron{flex-shrink:0;color:var(--text-muted, #666)}.palette-dropdown-popover{position:absolute;top:100%;left:0;right:0;margin-top:2px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:6px;box-shadow:0 4px 12px #0000004d;z-index:100;max-height:240px;overflow-y:auto;padding:4px}.palette-dropdown-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-primary, #ddd)}.palette-dropdown-item:hover{background:var(--hover-bg, rgba(255,255,255,.06))}.palette-dropdown-item.selected{background:var(--accent-bg-muted, rgba(25, 118, 210, .15))}.palette-dropdown-item-swatch{width:16px;height:16px;border-radius:2px;border:1px solid var(--panel-border, #444);flex-shrink:0}.palette-dropdown-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-dropdown-new{color:var(--text-muted, #888);font-size:11px;border-top:1px solid var(--panel-border, #333);margin-top:2px;padding-top:6px}.palette-dropdown-add-form{display:flex;align-items:center;gap:4px;padding:6px 4px;border-top:1px solid var(--panel-border, #333);margin-top:2px}.palette-dropdown-add-picker{width:24px;height:24px;padding:0;border:1px solid var(--panel-border, #444);border-radius:3px;background:transparent;cursor:pointer;flex-shrink:0}.palette-dropdown-add-name{font-size:11px;color:var(--text-primary, #ddd);background:var(--input-bg, #1a1a1a);border:1px solid var(--panel-border, #444);border-radius:3px;padding:3px 4px;flex:1;min-width:0;outline:none}.palette-dropdown-add-name:focus{border-color:var(--accent-bg, #1976d2)}.palette-dropdown-add-ok{font-size:10px;padding:3px 6px;border:1px solid var(--accent-bg, #1976d2);border-radius:3px;background:var(--accent-bg, #1976d2);color:#fff;cursor:pointer;white-space:nowrap}.angle-dial-container{display:flex;flex-direction:column;align-items:center;gap:4px}.angle-dial-svg{cursor:grab;flex-shrink:0;touch-action:none}.angle-dial-svg:active{cursor:grabbing}.angle-dial-input{width:48px}.save-status{font-size:11px;font-family:inherit;padding:0;white-space:nowrap;user-select:none;-webkit-user-select:none}.save-status-muted{color:var(--text-muted, #888)}.save-status-warn{color:var(--text-warn, #c89f3f)}.right-sidebar{background:var(--panel-bg, #252525);border-left:1px solid var(--panel-border, #333);display:flex;flex-direction:column;overflow:hidden;container-type:inline-size;height:100%}.inspector-header{padding:12px 16px;font-size:13px;font-weight:600;color:var(--text-secondary, #aaa);border-bottom:1px solid var(--panel-border, #333);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:space-between}.right-sidebar .sidebar-collapse-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;border-radius:3px;padding:0}.right-sidebar .sidebar-collapse-btn:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.inspector-empty{padding:20px 16px;color:var(--text-muted, #666);font-size:13px;text-align:center}.inspector-section{padding:8px 16px;border-bottom:1px solid var(--panel-border, #333)}details.inspector-section{padding:0}details.inspector-section>summary{padding:10px 16px;cursor:pointer;list-style:none;display:flex;align-items:center;gap:6px;user-select:none}details.inspector-section>summary::-webkit-details-marker{display:none}details.inspector-section>summary:before{content:"";display:inline-block;width:6px;height:6px;border-right:1.5px solid var(--text-muted, #888);border-bottom:1.5px solid var(--text-muted, #888);transform:rotate(-45deg);transition:transform .15s;flex-shrink:0}details.inspector-section[open]>summary:before{transform:rotate(45deg)}details.inspector-section>summary:hover{background:var(--hover-bg, rgba(255,255,255,.03))}details.inspector-section>:not(summary){padding:0 16px}details.inspector-section>:last-child{padding-bottom:12px}.inspector-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.inspector-section-title{font-size:11px;font-weight:600;color:var(--text-secondary, #aaa);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.inspector-section-header .inspector-section-title{margin-bottom:0}.inspector-info{font-size:13px;color:var(--text-primary, #ddd);line-height:1.5}.inspector-color-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.inspector-color-swatch{width:28px;height:28px;border-radius:4px;border:1px solid var(--panel-border, #444);flex-shrink:0}.inspector-color-label{display:flex;align-items:center;gap:8px;cursor:pointer}.inspector-color-input{width:28px;height:28px;padding:0;border:1px solid var(--panel-border, #444);border-radius:4px;cursor:pointer;background:none}.inspector-color-input::-webkit-color-swatch-wrapper{padding:2px}.inspector-color-input::-webkit-color-swatch{border:none;border-radius:2px}.inspector-color-hex{font-size:12px;font-family:SF Mono,Fira Code,monospace;color:var(--text-secondary, #aaa)}.inspector-color-name{font-size:12px;color:var(--text-muted, #888)}.inspector-subsection-divider{margin-top:8px}.inspector-color-name-inline{font-size:11px;color:var(--text-muted, #888);margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90px}.inspector-match-btns{display:flex;gap:4px}.inspector-match-btn{font-size:10px;padding:2px 8px;border:1px solid var(--panel-border, #444);border-radius:3px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;transition:background .1s ease,color .1s ease}.inspector-match-btn:hover:not(:disabled){background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.inspector-match-btn:disabled{opacity:.35;cursor:default}.chart-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.chart-tab{display:flex;align-items:center;gap:4px;padding:3px 8px;font-size:11px;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-muted, #888);cursor:pointer;transition:background .1s ease,color .1s ease}.chart-tab:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.chart-tab.active{background:var(--hover-bg, #333);color:var(--text-primary, #ddd);border-color:var(--text-secondary, #aaa)}.chart-tab-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.chart-tab-remove{border:none;background:none;color:inherit;cursor:pointer;padding:0 2px;font-size:13px;line-height:1;opacity:.5}.chart-tab-remove:hover{opacity:1}.chart-add-btn{display:block;width:100%;padding:4px 8px;margin-bottom:8px;font-size:11px;border:1px dashed var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-muted, #888);cursor:pointer;text-align:center;transition:background .1s ease,color .1s ease}.chart-add-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.chart-picker{margin-bottom:8px}.chart-picker-search{width:100%;padding:5px 8px;font-size:12px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--input-bg, #1a1a1a);color:var(--text-primary, #ddd);outline:none;margin-bottom:4px;box-sizing:border-box}.chart-picker-search:focus{border-color:var(--text-secondary, #aaa)}.chart-picker-list{max-height:180px;overflow-y:auto;border:1px solid var(--panel-border, #444);border-radius:4px}.chart-picker-empty{padding:8px;font-size:11px;color:var(--text-muted, #888);text-align:center}.chart-picker-item{display:flex;align-items:center;gap:6px;width:100%;padding:5px 8px;border:none;background:transparent;color:var(--text-primary, #ddd);cursor:pointer;font-size:11px;text-align:left;transition:background .1s ease}.chart-picker-item:hover{background:var(--hover-bg, #333)}.chart-picker-item+.chart-picker-item{border-top:1px solid var(--panel-border, #333)}.chart-picker-brand{font-weight:600;white-space:nowrap}.chart-picker-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary, #aaa)}.chart-picker-count{white-space:nowrap;color:var(--text-muted, #888);font-size:10px}.inspector-field{display:flex;align-items:center;gap:8px;margin-bottom:6px}.inspector-field label{font-size:12px;color:var(--text-secondary, #aaa);min-width:56px;flex-shrink:0}.inspector-field select{flex:1;min-width:0;padding:4px 24px 4px 6px;font-size:12px;border:1px solid var(--panel-border, #444);border-radius:4px;background-color:var(--input-bg, #1a1a1a);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;color:var(--text-primary, #ddd);outline:none;-webkit-appearance:none;appearance:none}.inspector-field select:focus{border-color:var(--text-secondary, #aaa)}.inspector-number-input{width:56px;min-width:40px;padding:4px 6px;font-size:12px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--input-bg, #1a1a1a);color:var(--text-primary, #ddd);outline:none;text-align:right}.inspector-number-input:focus{border-color:var(--text-secondary, #aaa)}.inspector-unit{font-size:11px;color:var(--text-muted, #888);min-width:24px}.inspector-field input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent, #4a9eff)}.inspector-subsection{margin-top:4px;margin-bottom:4px;border-left:2px solid var(--panel-border, #444);padding-left:10px}.inspector-subsection[open]{margin-bottom:8px}.inspector-subsection-title{font-size:11px;font-weight:600;color:var(--text-muted, #888);cursor:pointer;padding:3px 0;user-select:none;list-style:none}.inspector-subsection-title::-webkit-details-marker{display:none}.inspector-subsection-title:before{content:"▸ ";font-size:10px}.inspector-subsection[open]>.inspector-subsection-title:before{content:"▾ "}.inspector-subsection-title:hover{color:var(--text-secondary, #aaa)}.inspector-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.inspector-label{font-size:12px;color:var(--text-secondary, #aaa);min-width:52px;flex-shrink:0}.inspector-slider{flex:1;min-width:0;height:4px;accent-color:var(--accent, #4a9eff);cursor:pointer}.inspector-value{font-size:11px;color:var(--text-muted, #888);min-width:32px;text-align:right}.inspector-checkbox-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-primary, #ddd);cursor:pointer}.inspector-checkbox-label input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--accent, #4a9eff)}.inspector-btn{display:block;width:100%;padding:5px 8px;margin-top:8px;font-size:11px;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;text-align:center;transition:background .1s ease,color .1s ease}.inspector-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.inspector-btn-danger{border-color:#c62828;color:#ef5350}.inspector-btn-danger:hover{background:#c6282833;color:#ef5350}.inspector-btn-active{background:var(--accent-color, #1976d2);color:#fff;border-color:var(--accent-color, #1976d2)}.inspector-btn-active:hover{background:var(--accent-color, #1976d2);color:#fff}.layer-sidebar{grid-area:left;width:100%;background:var(--panel-bg, #252525);border-right:1px solid var(--panel-border, #333);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:12px 16px;font-size:13px;font-weight:600;color:var(--text-secondary, #aaa);border-bottom:1px solid var(--panel-border, #333);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:space-between}.sidebar-header-actions{display:flex;align-items:center;gap:2px}.sidebar-action-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted, #666);border-radius:3px;cursor:pointer;padding:0;transition:background .1s,color .1s}.sidebar-action-btn:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.sidebar-empty{padding:20px 16px;color:var(--text-muted, #666);font-size:13px;text-align:center}.sidebar-list{flex:1;overflow-y:auto;padding:8px 0}.layer-item{display:flex;flex-direction:column;gap:4px;padding:8px 16px;cursor:grab;transition:background .1s ease;border-left:3px solid transparent;user-select:none;-webkit-user-select:none;touch-action:pan-y}.layer-top-row{display:flex;align-items:center;gap:8px}.layer-bottom-row{display:flex;align-items:center;gap:4px;padding-left:2px}.layer-item:hover,.layer-item.hovered{background:var(--hover-bg, #333)}.layer-item.selected{background:var(--hover-bg, #333);border-left-color:var(--accent-bg, #1976d2)}.layer-item.hidden{opacity:.4}.layer-item.locked{opacity:.7}.layer-eye{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;border-radius:4px;border:none;background:transparent;color:var(--text-secondary, #aaa);padding:0;transition:color .1s ease,background .1s ease}.layer-eye:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.layer-eye.eye-hidden{color:var(--text-muted, #666)}.layer-eye.eye-hidden:hover{color:var(--text-secondary, #aaa)}.layer-lock{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;border-radius:4px;border:none;background:transparent;color:var(--text-muted, #666);padding:0;transition:color .1s ease,background .1s ease}.layer-lock:hover{background:var(--hover-bg, #333);color:var(--text-secondary, #aaa)}.layer-lock.lock-active{color:var(--text-secondary, #aaa)}.layer-lock.lock-active:hover{color:var(--text-primary, #ddd)}.layer-item.dragging{opacity:.3;cursor:grabbing}.layer-item.drag-over-top{box-shadow:0 -2px 0 0 var(--accent-bg, #1976d2)}.layer-item.drag-over-bottom{box-shadow:0 2px 0 0 var(--accent-bg, #1976d2)}body.layer-dragging,body.layer-dragging *{cursor:grabbing!important;touch-action:none}.layer-thumbnail{height:48px;border-radius:3px;flex-shrink:0;background:var(--canvas-bg, #1a1a1a)}.layer-info{flex:1;min-width:0}.layer-name{font-size:13px;color:var(--text-primary, #ddd);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}.layer-name-text{overflow:hidden;text-overflow:ellipsis;min-width:0}.layer-name-input{font:inherit;font-size:13px;color:var(--text-primary, #ddd);background:var(--input-bg, #1a1a1a);border:1px solid var(--accent-bg, #1976d2);border-radius:3px;padding:0 4px;outline:none;min-width:0;width:100%}.layer-shape-icon{display:inline-flex;align-items:center;color:var(--text-muted, #888);flex-shrink:0}.layer-details{font-size:11px;color:var(--text-muted, #888);margin-top:2px}.sidebar-collapse-btn{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;border-radius:3px;padding:0}.sidebar-collapse-btn:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.layer-category-header{padding:6px 16px 2px;font-size:10px;font-weight:600;color:var(--text-muted, #666);text-transform:uppercase;letter-spacing:.5px}.layer-arrows{display:flex;flex-direction:row;margin-left:auto;flex-shrink:0;gap:2px}.layer-arrow-btn{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;padding:0;border-radius:2px}.layer-arrow-btn:hover:not(:disabled){background:var(--hover-bg, #444);color:var(--text-primary, #ddd)}.layer-arrow-btn:disabled{opacity:.3;cursor:default}.folder-row{display:flex;align-items:center;gap:6px;padding:6px 16px;color:var(--text-primary, #ddd);font-size:13px;font-weight:500;cursor:pointer;user-select:none;-webkit-user-select:none;transition:background .1s ease}.folder-row:hover{background:var(--hover-bg, #333)}.folder-chevron{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted, #888);padding:0;cursor:pointer;transition:transform .12s ease}.folder-chevron.expanded{transform:rotate(90deg)}.folder-icon{color:var(--text-muted, #888);display:flex;align-items:center}.folder-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-name-input{flex:1;background:var(--input-bg, #1a1a1a);border:1px solid var(--accent-bg, #1976d2);color:var(--text-primary, #ddd);padding:2px 6px;font-size:13px;font-family:inherit;outline:none}.folder-row.dragging{opacity:.5}.folder-row.drag-over-top{border-top:2px solid var(--accent-bg, #1976d2)}.folder-row.drag-over-bottom{border-bottom:2px solid var(--accent-bg, #1976d2)}.folder-row.drag-over-into{background:#1976d22e;outline:1px dashed var(--accent-bg, #1976d2);outline-offset:-2px}.right-panel-tabs{display:flex;align-items:center;padding:0 2px;height:40px;border-bottom:1px solid var(--panel-border, #333);gap:0;flex-shrink:0;min-width:0}.right-panel-tab{flex:1 1 0;min-width:0;padding:0 6px;height:100%;font-size:11px;font-weight:600;font-family:inherit;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.4px;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .1s ease,border-color .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.right-panel-tab+.right-panel-tab{border-left:1px solid var(--panel-border, #333)}.right-panel-tab:hover{color:var(--text-secondary, #aaa)}.right-panel-tab.active{color:var(--text-primary, #ddd);border-bottom-color:var(--accent-bg, #1976d2)}.right-panel-tabs .sidebar-collapse-btn{margin-left:auto;flex-shrink:0;border-left:1px solid var(--panel-border, #333);padding-left:4px}.right-panel-content{flex:1;overflow-y:auto;min-height:0}@container (max-width: 220px){.right-panel-tabs{flex-direction:column;align-items:stretch;height:auto;padding:2px 0}.right-panel-tab{flex:0 0 auto;width:100%;height:32px;padding:0 12px;text-align:left;border-bottom:none;border-left:2px solid transparent}.right-panel-tab+.right-panel-tab{border-left:2px solid transparent;border-top:1px solid var(--panel-border, #333)}.right-panel-tab.active{border-bottom-color:transparent;border-left-color:var(--accent-bg, #1976d2)}.right-panel-tabs .sidebar-collapse-btn{margin-left:0;width:100%;height:28px;border-left:none;border-top:1px solid var(--panel-border, #333);padding:0 12px;text-align:left}}.layer-actions-bar{display:flex;justify-content:flex-start;padding:4px 8px;border-bottom:1px solid var(--panel-border, #333)}.right-panel-placeholder{display:flex;align-items:center;justify-content:center;padding:40px 16px;color:var(--text-muted, #666);font-size:13px;text-align:center}.resize-divider{width:5px;cursor:col-resize;background:transparent;position:relative;z-index:10;flex-shrink:0;touch-action:none}@media(pointer:coarse){.resize-divider:not(.collapsed){width:12px}}.resize-divider-left{grid-area:ldiv}.resize-divider-right{grid-area:rdiv}.resize-divider:after{content:"";position:absolute;top:0;bottom:0;width:1px;background:transparent;transition:background .1s}.resize-divider-left:after{right:2px}.resize-divider-right:after{left:2px}.resize-divider:hover:after{background:var(--accent-bg, #1976d2)}.resize-divider.collapsed{width:20px;cursor:pointer;background:var(--panel-border, #333)}.resize-divider.collapsed:hover{background:var(--hover-bg, rgba(255,255,255,.06))}.resize-divider-toggle{position:absolute;top:8px;width:24px;height:24px;padding:0;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #252525);color:var(--text-muted, #888);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:11;transition:background .1s,color .1s}.resize-divider-toggle:hover{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.resize-divider-toggle.toggle-side-right{right:100%;margin-right:-1px}.resize-divider-toggle.toggle-side-left{left:100%;margin-left:-1px}.command-palette-backdrop{position:fixed;inset:0;z-index:1000;background:#0006;backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding-top:20vh;animation:dialog-backdrop-in .15s ease}.command-palette{width:480px;max-height:400px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:8px;box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:dialog-card-in .2s ease}.command-palette-input{padding:12px 16px;font-size:14px;color:var(--text-primary, #ddd);background:transparent;border:none;border-bottom:1px solid var(--panel-border, #333);outline:none;font-family:inherit}.command-palette-input::placeholder{color:var(--text-muted, #666)}.command-palette-list{overflow-y:auto;flex:1;padding:4px 0}.command-palette-empty{padding:16px;text-align:center;color:var(--text-muted, #666);font-size:13px}.command-palette-item{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;cursor:pointer;font-size:13px;color:var(--text-primary, #ddd);transition:background .05s ease}.command-palette-item.selected{background:var(--hover-bg, #333)}.command-palette-item.disabled{color:var(--text-muted, #666);cursor:not-allowed}.command-palette-label{display:flex;align-items:center;gap:8px}.command-palette-category{font-size:11px;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.3px}.command-palette-shortcut{font-size:11px;font-family:SF Mono,Fira Code,monospace;color:var(--text-muted, #888);background:var(--input-bg, #1a1a1a);padding:2px 6px;border-radius:3px;border:1px solid var(--panel-border, #333)}.shortcut-sheet-backdrop{position:fixed;inset:0;z-index:1000;background:#00000080;backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;animation:dialog-backdrop-in .15s ease}.shortcut-sheet{width:720px;max-width:90vw;max-height:80vh;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:12px;box-shadow:0 16px 48px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:dialog-card-in .2s ease}.shortcut-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--panel-border, #333)}.shortcut-sheet-header h2{margin:0;font-size:16px;font-weight:600;color:var(--text-primary, #ddd)}.shortcut-sheet-close{padding:4px 10px;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-muted, #888);font-size:11px;font-family:monospace;cursor:pointer}.shortcut-sheet-close:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.shortcut-sheet-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:20px 24px;overflow-y:auto}.shortcut-sheet-category h3{margin:0 0 8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent, #4a9eff)}.shortcut-sheet-entries{display:flex;flex-direction:column;gap:4px}.shortcut-sheet-entry{display:flex;align-items:center;gap:12px;padding:3px 0}.shortcut-sheet-key{min-width:110px;font-size:11px;font-family:SF Mono,Fira Code,monospace;color:var(--text-primary, #ddd);background:var(--input-bg, #1a1a1a);padding:2px 8px;border-radius:3px;border:1px solid var(--panel-border, #333);text-align:center;white-space:nowrap}.shortcut-sheet-desc{font-size:12px;color:var(--text-secondary, #aaa)}.about-dialog-backdrop{position:fixed;inset:0;z-index:1000;background:#00000080;backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;animation:dialog-backdrop-in .15s ease}.about-dialog{width:360px;max-width:90vw;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:12px;box-shadow:0 16px 48px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:dialog-card-in .2s ease}.about-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--panel-border, #333)}.about-dialog-header h2{margin:0;font-size:16px;font-weight:600;color:var(--text-primary, #ddd)}.about-dialog-close{padding:4px 10px;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-muted, #888);font-size:11px;font-family:monospace;cursor:pointer}.about-dialog-close:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.about-dialog-body{padding:24px;text-align:center}.about-version{margin:0 0 8px;font-size:14px;font-weight:500;color:var(--text-primary, #ddd)}.about-description{margin:0 0 16px;font-size:12px;color:var(--text-secondary, #aaa)}.about-links{margin-bottom:16px}.about-link{background:none;border:none;padding:0;margin:0;font:inherit;font-size:12px;color:var(--accent, #4a9eff);text-decoration:underline;cursor:pointer}.about-link:hover{color:var(--accent-hover, #6bb3ff)}.about-copyright{margin:0;font-size:11px;color:var(--text-muted, #666)}.bug-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.bug-field{display:flex;flex-direction:column;gap:6px}.bug-label{font-size:13px;color:var(--text-primary, #ddd)}.bug-required{color:var(--accent-bg, #1976d2);margin-left:2px}.bug-textarea,.bug-input{padding:8px 10px;font-size:13px;font-family:inherit;background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;color:var(--text-primary, #ddd);outline:none;resize:vertical}.bug-textarea:focus,.bug-input:focus{border-color:var(--accent-bg, #1976d2)}.bug-checkbox-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-primary, #ddd);cursor:pointer}.bug-email-row{font-size:12px;color:var(--text-secondary, #aaa);padding-left:24px}.bug-email-readonly strong{color:var(--text-primary, #ddd)}.bug-disclosure{font-size:12px;color:var(--text-secondary, #aaa);border-top:1px solid var(--panel-border, #444);padding-top:10px}.bug-disclosure>summary{cursor:pointer;user-select:none;color:var(--text-primary, #ddd)}.bug-disclosure ul{margin:8px 0 0;padding-left:20px}.bug-disclosure li{margin-bottom:4px;line-height:1.4}.bug-discord{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--panel-border, #444)}.bug-discord-prompt{margin:0;font-size:12px;color:var(--text-secondary, #aaa);text-align:center}.bug-discord-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:500;color:#fff;background:#5865f2;border:1px solid #5865F2;border-radius:6px;text-decoration:none;cursor:pointer;transition:background .15s ease}.bug-discord-btn:hover{background:#4752c4;border-color:#4752c4}.bug-discord-icon{width:16px;height:16px;flex-shrink:0}.bug-error{margin:0;padding:10px 12px;font-size:12px;font-family:inherit;color:#f88;background:#ff3c3c14;border:1px solid rgba(255,60,60,.3);border-radius:6px;white-space:pre-wrap;word-break:break-word}.bug-btn{padding:8px 16px;font-size:13px;border-radius:6px;border:1px solid var(--panel-border, #444);cursor:pointer;transition:background .15s ease}.bug-btn-secondary{background:transparent;color:var(--text-secondary, #aaa)}.bug-btn-secondary:hover:not(:disabled){background:var(--hover-bg, #333)}.bug-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.bug-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.bug-btn:disabled{opacity:.4;cursor:not-allowed}.render-mode-wrapper{position:absolute;top:36px;right:0;z-index:10;display:flex;flex-direction:column;align-items:flex-end;gap:4px}.render-mode-toggle{display:flex;border-radius:6px;overflow:hidden;border:1px solid var(--panel-border, #444);background:var(--panel-bg, #252525);box-shadow:0 2px 8px #0000004d}.render-mode-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;border:none;background:transparent;color:var(--text-secondary, #888);cursor:pointer;padding:0;transition:background .15s,color .15s}.render-mode-btn:hover{background:var(--hover-bg, rgba(255, 255, 255, .08));color:var(--text-primary, #ccc)}.render-mode-btn.active{background:var(--accent-color, #4dabf7);color:#fff}.render-mode-btn.jump-btn.active{background:#50c8ff}.render-mode-btn.trim-btn.active{background:#ff5050}.render-mode-btn.realistic-btn.active{background:#a07850}.render-mode-btn.lighting-btn.active{background:#dcb43c}.render-mode-btn+.render-mode-btn{border-left:1px solid var(--panel-border, #444)}.lighting-wizard{position:absolute;top:44px;right:8px;z-index:10;width:260px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:8px;box-shadow:0 4px 16px #0006;overflow:hidden;font-size:12px;color:var(--text-primary, #ccc)}.lw-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-bottom:1px solid var(--panel-border, #444);background:var(--toolbar-bg, #2a2a2a)}.lw-title{font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #999)}.lw-close{background:none;border:none;color:var(--text-secondary, #999);font-size:18px;cursor:pointer;padding:0 2px;line-height:1}.lw-close:hover{color:var(--text-primary, #ccc)}.lw-section{padding:6px 10px;border-bottom:1px solid var(--panel-border, #333)}.lw-section-title{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #666);margin-bottom:4px}.lw-field{display:flex;align-items:center;gap:6px;margin-bottom:3px}.lw-label{min-width:52px;font-size:11px;color:var(--text-secondary, #999)}.lw-slider{flex:1;height:4px;accent-color:var(--accent, #4a9eff);cursor:pointer}.lw-value{min-width:32px;text-align:right;font-size:10px;font-variant-numeric:tabular-nums;color:var(--text-muted, #666)}.lw-color{width:28px;height:20px;padding:0;border:1px solid var(--panel-border, #444);border-radius:3px;cursor:pointer;background:none}.lw-presets{display:flex;flex-wrap:wrap;gap:4px;padding:8px 10px}.lw-preset-btn{flex:1;min-width:50px;padding:4px 8px;background:var(--hover-bg, rgba(255, 255, 255, .06));border:1px solid var(--panel-border, #444);border-radius:4px;color:var(--text-secondary, #999);font-size:11px;cursor:pointer;transition:background .15s,color .15s}.lw-preset-btn:hover{background:var(--accent-bg, rgba(74, 158, 255, .15));color:var(--text-primary, #ccc)}.lw-mode-switch{display:flex;border-radius:4px;overflow:hidden;border:1px solid var(--panel-border, #444)}.lw-mode-btn{padding:2px 10px;border:none;background:transparent;color:var(--text-secondary, #999);font-size:11px;cursor:pointer;transition:background .15s,color .15s}.lw-mode-btn+.lw-mode-btn{border-left:1px solid var(--panel-border, #444)}.lw-mode-btn:hover{background:var(--hover-bg, rgba(255, 255, 255, .08))}.lw-mode-btn.active{background:var(--accent-color, #4dabf7);color:#fff}.lw-reset{flex-basis:100%;background:transparent;color:var(--text-muted, #666);border-color:transparent}.lw-reset:hover{color:var(--text-secondary, #999);border-color:var(--panel-border, #444)}.setup-steps{display:flex;gap:8px}.setup-step-dot{font-size:12px;padding:4px 12px;border-radius:12px;color:var(--text-muted, #666);background:transparent;border:1px solid var(--panel-border, #333);transition:all .15s ease}.setup-step-dot.active{color:#fff;background:var(--accent-bg, #1976d2);border-color:var(--accent-bg, #1976d2)}.setup-step-dot.done{color:var(--text-secondary, #aaa);border-color:var(--text-muted, #666)}.setup-body{flex:1;overflow-y:auto;padding:20px 24px}.setup-screen{display:flex;flex-direction:column;gap:12px}.setup-description{margin:0;font-size:13px;color:var(--text-secondary, #aaa);line-height:1.5}.setup-label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:500;color:var(--text-secondary, #aaa)}.setup-select{padding:8px 28px 8px 10px;font-size:13px;font-family:inherit;color:var(--text-primary, #ddd);background-color:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;cursor:pointer;outline:none;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.setup-select:focus{border-color:var(--accent-bg, #1976d2)}.setup-select option{color:var(--text-primary, #ddd);background-color:var(--panel-bg, #252525)}.setup-select optgroup{color:var(--text-secondary, #aaa);font-weight:600}.setup-machine-info{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--hover-bg, #333);border-radius:6px;font-size:12px;color:var(--text-secondary, #aaa)}.setup-hoop-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--hover-bg, #333);border-radius:6px}.setup-hoop-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-primary, #ddd)}.setup-hoop-check input[type=checkbox]{accent-color:var(--accent-bg, #1976d2);width:16px;height:16px;cursor:pointer}.setup-hoop-name{font-weight:500}.setup-hoop-size{color:var(--text-secondary, #aaa);font-size:12px}.setup-hoop-part{color:var(--text-muted, #666);font-size:11px;font-family:SF Mono,Fira Code,monospace}.setup-hoop-active-btn{padding:3px 10px;font-size:11px;font-family:inherit;border:1px solid var(--panel-border, #444);border-radius:4px;background:transparent;color:var(--text-muted, #666);cursor:pointer;transition:all .1s ease}.setup-hoop-active-btn:hover{color:var(--text-secondary, #aaa);border-color:var(--text-muted, #666)}.setup-hoop-active-btn.is-active{color:#fff;background:var(--accent-bg, #1976d2);border-color:var(--accent-bg, #1976d2)}.setup-custom-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #666);padding-top:4px}.setup-hoop-actions{display:flex;align-items:center;gap:6px}.setup-hoop-remove-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;border-radius:4px;padding:0;transition:color .1s ease,background .1s ease}.setup-hoop-remove-btn:hover{color:#e53935;background:#e539351a}.setup-add-custom-btn{padding:8px 12px;font-size:12px;font-family:inherit;border:1px dashed var(--panel-border, #444);border-radius:6px;background:transparent;color:var(--text-muted, #666);cursor:pointer;text-align:center;transition:color .1s ease,border-color .1s ease}.setup-add-custom-btn:hover{color:var(--text-secondary, #aaa);border-color:var(--text-muted, #666)}.setup-custom-hoop-form{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--hover-bg, #333);border-radius:6px;border:1px solid var(--panel-border, #444)}.setup-input{padding:7px 10px;font-size:13px;font-family:inherit;color:var(--text-primary, #ddd);background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:4px;outline:none}.setup-input:focus{border-color:var(--accent-bg, #1976d2)}.setup-input::placeholder{color:var(--text-muted, #666)}.setup-input-sm{width:90px}.setup-select-sm{padding:6px 24px 6px 8px;font-size:12px}.setup-custom-hoop-dims{display:flex;align-items:center;gap:8px}.setup-dim-separator{color:var(--text-muted, #666);font-size:14px}.setup-custom-hoop-btns{display:flex;gap:8px}.setup-btn-sm{padding:5px 14px;font-size:12px}.setup-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.setup-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.setup-btn-primary:disabled{opacity:.5;cursor:not-allowed}.setup-search{padding:8px 12px;font-size:13px;font-family:inherit;color:var(--text-primary, #ddd);background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;outline:none}.setup-search:focus{border-color:var(--accent-bg, #1976d2)}.setup-search::placeholder{color:var(--text-muted, #666)}.setup-thread-list{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;border:1px solid var(--panel-border, #333);border-radius:6px;padding:4px}.setup-thread-group-label{padding:6px 10px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #666)}.setup-thread-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text-primary, #ddd);cursor:pointer;font-family:inherit;font-size:13px;text-align:left;transition:background .1s ease}.setup-thread-item:hover{background:var(--hover-bg, #333)}.setup-thread-item.is-selected{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.setup-thread-item.is-added{opacity:.5;cursor:default}.setup-thread-item.is-added:hover{background:transparent}.setup-thread-check{color:var(--accent-bg, #1976d2);font-size:14px;flex-shrink:0}.setup-selected-threads{border:1px solid var(--panel-border, #333);border-radius:6px;padding:8px;margin-bottom:4px;min-height:40px}.setup-selected-thread-item{display:flex;align-items:center;gap:8px;padding:5px 8px;font-size:13px;color:var(--text-primary, #ddd);border-radius:4px}.setup-selected-thread-item:hover{background:var(--hover-bg, #333)}.setup-selected-thread-remove{margin-left:auto;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;font-size:16px;padding:0 4px;border-radius:3px;flex-shrink:0}.setup-selected-thread-remove:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.setup-thread-brand{font-weight:500;min-width:0}.setup-thread-chart{flex:1;color:var(--text-secondary, #aaa);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setup-thread-item.is-selected .setup-thread-chart{color:#fffc}.setup-thread-count{flex-shrink:0;font-size:11px;color:var(--text-muted, #666)}.setup-thread-item.is-selected .setup-thread-count{color:#fff9}.setup-thread-empty{padding:20px;text-align:center;color:var(--text-muted, #666);font-size:13px}.setup-footer-right{display:flex;gap:8px}.setup-btn{padding:8px 18px;font-size:13px;font-family:inherit;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .1s ease}.setup-btn-skip{background:transparent;color:var(--text-muted, #666);border-color:transparent}.setup-btn-skip:hover{color:var(--text-secondary, #aaa)}.setup-btn-back{background:var(--hover-bg, #333);color:var(--text-secondary, #aaa);border-color:var(--panel-border, #444)}.setup-btn-back:hover{color:var(--text-primary, #ddd)}.setup-btn-next,.setup-btn-finish{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.setup-btn-next:hover,.setup-btn-finish:hover{filter:brightness(1.1)}.setup-btn-next:disabled{opacity:.5;cursor:not-allowed}.setup-machine-card{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;cursor:pointer;transition:border-color .1s ease}.setup-machine-card:hover{border-color:var(--text-muted, #666)}.setup-machine-card.is-active{border-color:var(--accent-bg, #1976d2)}.setup-machine-card-info{display:flex;flex-direction:column;gap:2px;min-width:0}.setup-machine-card-label{font-size:13px;font-weight:500;color:var(--text-primary, #ddd)}.setup-machine-card-meta{font-size:11px;color:var(--text-muted, #666)}.setup-machine-card-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.setup-machine-card-active-badge{padding:2px 8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:#fff;background:var(--accent-bg, #1976d2);border-radius:3px}.setup-empty-hint{padding:16px;text-align:center;color:var(--text-muted, #666);font-size:13px}.setup-unit-toggle{display:flex;align-items:center;gap:8px;margin-bottom:4px}.setup-unit-label{font-size:12px;color:var(--text-secondary, #aaa);font-weight:500}.setup-unit-toggle .setup-toggle-btn{flex:none;border:1px solid var(--panel-border, #444);border-radius:4px}.setup-add-machine-toggle{display:flex;gap:0;border:1px solid var(--panel-border, #444);border-radius:4px;overflow:hidden}.setup-toggle-btn{flex:1;padding:5px 12px;font-size:12px;font-family:inherit;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;transition:all .1s ease}.setup-toggle-btn.is-active{background:var(--accent-bg, #1976d2);color:#fff}.setup-format-grid{display:flex;flex-wrap:wrap;gap:6px 12px}.setup-format-check{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-primary, #ddd);cursor:pointer}.setup-format-check input[type=checkbox]{accent-color:var(--accent-bg, #1976d2);width:14px;height:14px;cursor:pointer}.setup-warning{font-size:12px;color:var(--text-secondary, #aaa);background:#ffaa0014;border:1px solid rgba(255,170,0,.25);border-radius:6px;padding:10px 12px;margin-bottom:12px;line-height:1.5}.setup-preset-list{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto}.setup-preset{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text-primary, #ddd);transition:background .1s}.setup-preset:hover{background:var(--hover-bg, #333)}.setup-preset-selected{background:var(--hover-bg, #333);outline:1px solid var(--accent-bg, #1976d2)}.setup-preset input[type=radio]{accent-color:var(--accent-bg, #1976d2);flex-shrink:0}.setup-preset-label{flex:1}.setup-preset-ppi{font-size:11px;color:var(--text-muted, #666);font-family:SF Mono,Fira Code,monospace;flex-shrink:0}.setup-preset-badge{font-size:10px;font-weight:600;color:var(--accent-bg, #1976d2);background:#1976d226;padding:2px 6px;border-radius:3px;flex-shrink:0}.setup-preset-detected{border-left:2px solid var(--accent-bg, #1976d2)}.setup-preset-list{padding:4px}.setup-preset-selected{outline-offset:-1px}.setup-preset-custom-top{margin-bottom:6px;border-bottom:1px solid var(--panel-border, #444);padding-bottom:10px}.setup-custom-input{width:64px;padding:4px 8px;font-size:12px;font-family:SF Mono,Fira Code,monospace;background:var(--panel-bg, #222);border:1px solid var(--panel-border, #444);border-radius:5px;color:var(--text-primary, #ddd);outline:none;text-align:right;-moz-appearance:textfield}.setup-custom-input::-webkit-inner-spin-button,.setup-custom-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.setup-custom-input:focus{border-color:var(--accent-bg, #1976d2)}.setup-info{font-size:12px;color:var(--text-secondary, #aaa);background:#1976d214;border:1px solid rgba(25,118,210,.25);border-radius:6px;padding:10px 12px;margin-bottom:12px;line-height:1.5}.tp-tabs{display:flex;gap:0;border-bottom:1px solid var(--panel-border, #333);margin-bottom:16px}.tp-tab{padding:8px 16px;font-size:13px;font-weight:500;color:var(--text-secondary, #aaa);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.tp-tab:hover{color:var(--text-primary, #ddd)}.tp-tab-active{color:var(--text-primary, #ddd);border-bottom-color:var(--accent-bg, #4dabf7)}.tp-body{min-height:240px;padding:0 8px}.tp-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #888);margin-bottom:10px;padding:0 2px}.tp-empty{padding:16px;text-align:center;color:var(--text-muted, #666);font-size:13px}.tp-palette-section{padding:4px 2px}.tp-palette-section+.tp-palette-section{margin-top:20px;padding-top:16px;border-top:1px solid var(--panel-border, #333)}.tp-chart-list{margin-bottom:12px}.tp-chart-item{display:flex;align-items:center;gap:8px;padding:6px 8px;font-size:13px;color:var(--text-primary, #ddd);border-radius:4px}.tp-chart-item:hover{background:var(--hover-bg, #333)}.tp-chart-brand{font-weight:500}.tp-chart-name{flex:1;color:var(--text-secondary, #aaa);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-chart-count{flex-shrink:0;font-size:11px;color:var(--text-muted, #666)}.tp-chart-remove{border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;font-size:16px;padding:0 4px;border-radius:3px;flex-shrink:0}.tp-chart-remove:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.tp-add-btn{font-size:12px;padding:6px 14px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #252525);color:var(--text-secondary, #aaa);cursor:pointer;margin-top:8px}.tp-add-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.tp-add-btn-sm{padding:5px 12px;font-size:11px;margin-top:0;min-width:64px}.tp-browse{margin-top:8px;border:1px solid var(--panel-border, #333);border-radius:6px;padding:8px}.tp-search{width:100%;padding:6px 10px;font-size:13px;color:var(--text-primary, #ddd);background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:4px;margin-bottom:8px;outline:none;box-sizing:border-box}.tp-search:focus{border-color:var(--accent-bg, #1976d2)}.tp-browse-list{max-height:200px;overflow-y:auto}.tp-browse-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border:none;border-radius:4px;background:transparent;color:var(--text-primary, #ddd);cursor:pointer;font-family:inherit;font-size:13px;text-align:left;width:100%}.tp-browse-item:hover:not(.tp-added){background:var(--hover-bg, #333)}.tp-browse-item.tp-added{opacity:.5;cursor:default}.tp-check{color:var(--accent-bg, #1976d2);font-size:14px;flex-shrink:0}.tp-group-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #888);padding:6px 8px 2px}.tp-close-browse{font-size:12px;padding:4px 12px;border:1px solid var(--panel-border, #444);border-radius:4px;background:var(--panel-bg, #252525);color:var(--text-secondary, #aaa);cursor:pointer;margin-top:8px}.tp-close-browse:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.tp-palette-list{margin-bottom:14px;display:flex;flex-direction:column;gap:4px}.tp-palette-item{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:6px;transition:background .12s ease}.tp-palette-item:hover{background:var(--hover-bg, #333)}.tp-palette-swatches{display:flex;gap:3px;flex-shrink:0}.tp-palette-swatch{width:16px;height:16px;border-radius:3px;border:1px solid var(--panel-border, #444)}.tp-palette-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.tp-palette-more{font-size:10px;color:var(--text-muted, #666);margin-left:2px;align-self:center}.tp-palette-name{flex:1;font-size:13px;color:var(--text-primary, #ddd);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-save-form{display:flex;align-items:center;gap:6px;margin-top:8px}.tp-save-form .tp-search{flex:1;margin-bottom:0}.calibrate-body{padding:24px;display:flex;flex-direction:column;gap:20px}.calibrate-line-container{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.calibrate-line{height:4px;background:var(--accent-bg, #1976d2);border-radius:2px;position:relative;max-width:100%}.calibrate-line:before,.calibrate-line:after{content:"";position:absolute;top:-6px;width:2px;height:16px;background:var(--accent-bg, #1976d2)}.calibrate-line:before{left:0}.calibrate-line:after{right:0}.calibrate-line-label{font-size:12px;color:var(--text-muted, #666)}.calibrate-input-row{display:flex;align-items:center;gap:12px}.calibrate-label{font-size:13px;color:var(--text-primary, #ddd);white-space:nowrap}.calibrate-input-group{display:flex;align-items:center;gap:6px}.calibrate-input{width:80px;padding:6px 10px;font-size:14px;font-family:SF Mono,Fira Code,monospace;background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;color:var(--text-primary, #ddd);outline:none}.calibrate-input:focus{border-color:var(--accent-bg, #1976d2)}.calibrate-unit{font-size:13px;color:var(--text-secondary, #aaa)}.calibrate-result{font-size:12px;color:var(--text-secondary, #aaa);padding:8px 12px;background:var(--hover-bg, #333);border-radius:6px}.calibrate-btn{padding:8px 16px;font-size:13px;border-radius:6px;border:1px solid var(--panel-border, #444);cursor:pointer;transition:background .15s ease}.calibrate-btn-secondary{background:transparent;color:var(--text-secondary, #aaa)}.calibrate-btn-secondary:hover{background:var(--hover-bg, #333)}.calibrate-btn-reset{background:transparent;color:var(--text-muted, #666);margin-right:auto}.calibrate-btn-reset:hover{color:var(--text-secondary, #aaa);background:var(--hover-bg, #333)}.calibrate-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.calibrate-btn-primary:hover{filter:brightness(1.1)}.calibrate-btn-primary:disabled{opacity:.4;cursor:not-allowed}.calibrate-preset-list{display:flex;flex-direction:column;gap:2px;max-height:360px;overflow-y:auto;padding:4px}.calibrate-preset{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--text-primary, #ddd);transition:background .1s}.calibrate-preset:hover{background:var(--hover-bg, #333)}.calibrate-preset-selected{background:var(--hover-bg, #333);outline:1.5px solid var(--accent-bg, #1976d2);outline-offset:-1px}.calibrate-preset input[type=radio]{accent-color:var(--accent-bg, #1976d2);flex-shrink:0}.calibrate-preset-label{flex:1}.calibrate-preset-ppi{font-size:11px;color:var(--text-muted, #666);font-family:SF Mono,Fira Code,monospace;flex-shrink:0}.calibrate-preset-badge{font-size:10px;font-weight:600;color:var(--accent-bg, #1976d2);background:#1976d226;padding:2px 6px;border-radius:3px;flex-shrink:0}.calibrate-preset-detected{border-left:2px solid var(--accent-bg, #1976d2)}.calibrate-preset-custom-top{margin-bottom:6px;border-bottom:1px solid var(--panel-border, #444);padding-bottom:10px}.calibrate-custom-input{width:64px;padding:4px 8px;font-size:12px;font-family:SF Mono,Fira Code,monospace;background:var(--panel-bg, #222);border:1px solid var(--panel-border, #444);border-radius:5px;color:var(--text-primary, #ddd);outline:none;text-align:right;-moz-appearance:textfield}.calibrate-custom-input::-webkit-inner-spin-button,.calibrate-custom-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.calibrate-custom-input:focus{border-color:var(--accent-bg, #1976d2)}.rotate-body{padding:24px;display:flex;flex-direction:column;gap:12px}.rotate-input-row{display:flex;align-items:center;gap:12px}.rotate-label{font-size:13px;color:var(--text-primary, #ddd);white-space:nowrap}.rotate-input-group{display:flex;align-items:center;gap:6px}.rotate-input{width:80px;padding:6px 10px;font-size:14px;font-family:SF Mono,Fira Code,monospace;background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;color:var(--text-primary, #ddd);outline:none}.rotate-input:focus{border-color:var(--accent-bg, #1976d2)}.rotate-unit{font-size:13px;color:var(--text-secondary, #aaa)}.rotate-hint{margin:0;font-size:12px;color:var(--text-muted, #666)}.rotate-btn{padding:8px 16px;font-size:13px;border-radius:6px;border:1px solid var(--panel-border, #444);cursor:pointer;transition:background .15s ease}.rotate-btn-secondary{background:transparent;color:var(--text-secondary, #aaa)}.rotate-btn-secondary:hover{background:var(--hover-bg, #333)}.rotate-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.rotate-btn-primary:hover{filter:brightness(1.1)}.rotate-btn-primary:disabled{opacity:.4;cursor:not-allowed}.recovery-banner{position:fixed;bottom:16px;left:50%;transform:translate(-50%);z-index:700;display:flex;align-items:center;gap:16px;padding:10px 14px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);color:var(--text-primary, #e0e0e0);font-size:13px;font-family:inherit;pointer-events:auto;max-width:calc(100vw - 32px)}.recovery-banner-text{display:flex;align-items:baseline;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recovery-banner-label{color:var(--text-primary, #e0e0e0)}.recovery-banner-age{color:var(--text-muted, #888);font-size:12px}.recovery-banner-actions{display:flex;gap:8px;flex-shrink:0}.recovery-banner-btn{padding:4px 12px;font-size:12px;font-family:inherit;border:1px solid var(--panel-border, #444);background:var(--toolbar-bg, #2c2c2c);color:var(--text-primary, #e0e0e0);cursor:pointer}.recovery-banner-btn:hover:not(:disabled){background:var(--hover-bg, #3a3a3a)}.recovery-banner-btn:disabled{opacity:.5;cursor:not-allowed}.recovery-banner-btn-primary{background:var(--accent, #5b9bd5);color:#fff;border-color:var(--accent, #5b9bd5)}.recovery-banner-btn-primary:hover:not(:disabled){background:var(--accent, #5b9bd5);border-color:var(--accent, #5b9bd5)}.new-project-body{padding:8px 0}.new-project-prompt{font-size:13px;color:var(--text-secondary, #aaa);margin:0 0 12px}.new-project-option{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--panel-border, #444);border-radius:6px;cursor:pointer;margin-bottom:6px}.new-project-option:hover{border-color:var(--text-muted, #666)}.new-project-option.selected{border-color:var(--accent-bg, #1976d2);background:var(--accent-bg-muted, rgba(25, 118, 210, .08))}.new-project-option input[type=radio]{accent-color:var(--accent-bg, #1976d2)}.new-project-option-label{font-size:13px;color:var(--text-primary, #ddd);flex:1}.new-project-option-swatches{display:flex;gap:3px;align-items:center}.new-project-mini-swatch{width:14px;height:14px;border-radius:2px;border:1px solid rgba(255,255,255,.12)}.new-project-more{font-size:10px;color:var(--text-muted, #666);margin-left:2px}.new-project-btn{padding:6px 16px;border-radius:5px;font-size:13px;cursor:pointer;border:1px solid var(--panel-border, #444)}.new-project-btn-secondary{background:var(--panel-bg, #252525);color:var(--text-secondary, #aaa)}.new-project-btn-secondary:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.new-project-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.new-project-btn-primary:hover{filter:brightness(1.1)}.svg-import-body{display:flex;flex-direction:column;gap:18px;padding:18px 20px 20px}.svg-import-section-label{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted, #888);margin-bottom:8px;user-select:none}.svg-import-size-row{display:grid;grid-template-columns:16px minmax(0,1fr) 32px 16px minmax(0,1fr);gap:6px;align-items:center}.svg-import-lock-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:4px;border:1px solid var(--panel-border, #444);background:var(--input-bg, #1a1a1a);color:var(--text-muted, #888);cursor:pointer;justify-self:center;transition:background .12s ease,color .12s ease,border-color .12s ease}.svg-import-lock-btn:hover{background:var(--hover-bg, #2a2a2a);color:var(--text-primary)}.svg-import-lock-btn.locked{background:var(--accent, #4a90e2);border-color:var(--accent, #4a90e2);color:#fff}.svg-import-original{font-size:11px;color:var(--text-secondary, #888);margin-top:6px;padding-left:2px;user-select:none}.svg-import-checkbox-row{display:flex;align-items:center;gap:10px;font-size:13px;cursor:pointer;user-select:none;padding:4px 2px}.svg-import-checkbox-row input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0;accent-color:var(--accent, #4a90e2)}.svg-import-divider{height:1px;background:var(--panel-border, #333);margin:0}.svg-import-filters{border:1px solid var(--panel-border, #333);border-radius:6px;padding:0 12px;background:var(--input-bg, #181818)}.svg-import-filters>summary{cursor:pointer;user-select:none;font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted, #888);padding:10px 0;list-style:none}.svg-import-filters>summary::-webkit-details-marker{display:none}.svg-import-filters>summary:before{content:"▶";display:inline-block;margin-right:8px;font-size:9px;transition:transform .12s ease;transform:translateY(-1px)}.svg-import-filters[open]>summary:before{transform:rotate(90deg) translate(-1px)}.svg-import-filter-rows{display:flex;flex-direction:column;gap:10px;padding:4px 0 12px}.svg-import-filter-row{display:grid;grid-template-columns:auto 80px auto;align-items:center;gap:8px;font-size:13px}.svg-import-filter-row label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}.svg-import-filter-row input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0;accent-color:var(--accent, #4a90e2)}.svg-import-filter-row input[type=number]{width:100%;padding:4px 6px;font-size:12px;background:var(--input-bg, #1a1a1a);border:1px solid var(--panel-border, #444);border-radius:4px;color:var(--text-primary, #ddd);outline:none;text-align:right}.svg-import-filter-row input[type=number]:focus{border-color:var(--text-secondary, #aaa)}.svg-import-filter-row input[type=number]:disabled{opacity:.4;cursor:not-allowed}.svg-import-filter-unit{font-size:12px;color:var(--text-muted, #888);user-select:none}.svg-import-filter-preview{font-size:11px;color:var(--text-secondary, #888);padding:4px 0 0;user-select:none;line-height:1.4}.svg-import-filter-preview.warn{color:var(--warn, #d6a55c)}.svg-import-filter-section-label{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted, #888);margin:8px 0 2px;padding-top:8px;border-top:1px solid var(--panel-border, #333);user-select:none}.svg-import-btn{font-size:13px;font-weight:500;padding:8px 18px;border-radius:6px;border:1px solid var(--panel-border, #444);background:var(--input-bg, #1a1a1a);color:var(--text-primary, #e8e8e8);cursor:pointer;min-width:96px;line-height:1.2;transition:background .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease,transform .04s ease;user-select:none}.svg-import-btn:hover:not(:disabled){background:var(--hover-bg, #2a2a2a);border-color:var(--panel-border-hover, #666)}.svg-import-btn:active:not(:disabled){transform:translateY(1px)}.svg-import-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--panel-bg, #111),0 0 0 4px var(--accent, #4a90e2)}.svg-import-btn-primary{background:var(--accent, #4a90e2);border-color:var(--accent, #4a90e2);color:#fff;font-weight:600}.svg-import-btn-primary:hover:not(:disabled){background:var(--accent-hover, #5aa0f2);border-color:var(--accent-hover, #5aa0f2);color:#fff}.svg-import-btn-primary:disabled{background:var(--panel-border, #333);border-color:var(--panel-border, #333);color:var(--text-muted, #666);cursor:not-allowed;opacity:.7}.save-dialog-body{padding:24px;display:flex;flex-direction:column;gap:16px}.save-dialog-field{display:flex;flex-direction:column;gap:6px}.save-dialog-label{font-size:13px;color:var(--text-secondary, #aaa)}.save-dialog-input{padding:8px 12px;font-size:14px;background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;color:var(--text-primary, #ddd);outline:none}.save-dialog-input:focus{border-color:var(--accent-bg, #1976d2)}.save-dialog-destinations{display:flex;flex-direction:column;gap:8px}.save-dialog-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-primary, #ddd)}.save-dialog-checkbox.disabled{color:var(--text-muted, #666);cursor:not-allowed}.save-dialog-checkbox input[type=checkbox]{accent-color:var(--accent-bg, #1976d2)}.save-dialog-radio{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-primary, #ddd)}.save-dialog-radio.disabled{color:var(--text-muted, #666);cursor:not-allowed}.save-dialog-radio input[type=radio]{accent-color:var(--accent-bg, #1976d2)}.save-dialog-hint-inline{font-size:11px;color:var(--text-muted, #666);margin-left:4px}.save-dialog-stitch-option{padding-top:4px;border-top:1px solid var(--panel-border, #333)}.save-dialog-hint{font-size:11px;color:var(--text-muted, #666);margin:-8px 0 0 24px}.save-dialog-footer{display:flex;gap:8px;justify-content:flex-end}.save-dialog-btn{padding:8px 16px;font-size:13px;border-radius:6px;border:1px solid var(--panel-border, #444);cursor:pointer;transition:background .15s ease}.save-dialog-btn-secondary{background:transparent;color:var(--text-secondary, #aaa)}.save-dialog-btn-secondary:hover{background:var(--hover-bg, #333)}.save-dialog-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.save-dialog-btn-primary:hover{filter:brightness(1.1)}.save-dialog-btn-primary:disabled{opacity:.4;cursor:not-allowed}.tab-bar{grid-area:tabbar;display:flex;align-items:flex-end;gap:0;padding:0 4px;height:36px;background:var(--toolbar-bg, #252525);border-bottom:1px solid var(--panel-border, #333);overflow-x:auto;overflow-y:hidden;user-select:none}.tab-bar::-webkit-scrollbar{height:0}.tab-item{display:flex;align-items:center;gap:6px;padding:0 12px;height:30px;font-size:12px;font-weight:500;color:var(--text-secondary, #aaa);background:transparent;border:none;border-top-left-radius:6px;border-top-right-radius:6px;cursor:pointer;white-space:nowrap;max-width:180px;transition:color .1s ease,background .1s ease;position:relative;flex-shrink:0}.tab-item:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.tab-item.active{color:var(--text-primary, #ddd);background:var(--panel-bg, #1e1e1e);border-bottom:2px solid var(--accent-bg, #1976d2)}.tab-label{overflow:hidden;text-overflow:ellipsis}.tab-dirty-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted, #888);flex-shrink:0}.tab-close{display:flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:14px;line-height:1;color:var(--text-muted, #888);background:transparent;border:none;border-radius:3px;cursor:pointer;padding:0;flex-shrink:0;opacity:0;transition:opacity .1s ease,color .1s ease,background .1s ease}.tab-item:hover .tab-close,.tab-item.active .tab-close{opacity:1}.tab-close:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #444)}.tab-add{display:flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:18px;line-height:1;color:var(--text-muted, #888);background:transparent;border:none;border-radius:4px;cursor:pointer;flex-shrink:0;margin-left:2px;transition:color .1s ease,background .1s ease}.tab-add:hover{color:var(--text-primary, #ddd);background:var(--hover-bg, #333)}.stitch-animator{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #333);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:100;user-select:none;max-width:calc(100% - 32px)}.stitch-animator-mode-toggle{display:flex;gap:0;border:1px solid var(--panel-border, #333);border-radius:4px;overflow:hidden;flex-shrink:0}.stitch-animator-mode-btn{padding:3px 8px;border:none;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;font-size:11px;white-space:nowrap}.stitch-animator-mode-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #eee)}.stitch-animator-mode-btn.active{background:var(--accent, #4a9eff);color:#fff}.stitch-animator-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--panel-border, #333);border-radius:4px;background:var(--toolbar-bg, #252525);color:var(--text-primary, #eee);cursor:pointer;padding:0;flex-shrink:0}.stitch-animator-btn:hover{background:var(--hover-bg, #333);border-color:var(--accent, #4a9eff)}.stitch-animator-btn.active{background:var(--accent, #4a9eff);color:#fff}.stitch-animator-btn:disabled{opacity:.4;cursor:not-allowed}.stitch-animator-btn.recording{background:#f443;border:1px solid #FF4444;animation:recording-pulse 1.5s ease-in-out infinite}.stitch-animator-recording-dot{width:8px;height:8px;border-radius:50%;background:#f44;flex-shrink:0;animation:recording-pulse 1.5s ease-in-out infinite}@keyframes recording-pulse{0%,to{opacity:1}50%{opacity:.3}}.stitch-animator-slider{flex:1;min-width:120px;height:4px;appearance:none;-webkit-appearance:none;background:var(--panel-border, #333);border-radius:2px;outline:none;cursor:pointer}.stitch-animator-slider:disabled{opacity:.5;cursor:not-allowed}.stitch-animator-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent, #4a9eff);cursor:grab}.stitch-animator-slider::-webkit-slider-thumb:active{cursor:grabbing}.stitch-animator-color-info{display:flex;align-items:center;gap:4px;flex-shrink:0}.stitch-animator-color-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.3);flex-shrink:0}.stitch-animator-color-name{font-size:11px;color:var(--text-primary, #eee);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stitch-animator-segment-num{font-size:10px;color:var(--text-secondary, #aaa);font-variant-numeric:tabular-nums;white-space:nowrap}.stitch-animator-speed{display:flex;align-items:center;gap:2px;flex-shrink:0}.stitch-animator-speed-btn{padding:2px 6px;border:1px solid var(--panel-border, #333);border-radius:3px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;font-size:11px}.stitch-animator-speed-btn:hover{background:var(--button-hover, #444)}.stitch-animator-speed-btn:disabled{opacity:.4;cursor:not-allowed}.stitch-animator-speed-btn.active{background:var(--accent, #4a9eff);color:#fff;border-color:var(--accent, #4a9eff)}.stitch-animator-speed-slider{width:70px;height:3px;appearance:none;-webkit-appearance:none;background:var(--panel-border, #333);border-radius:2px;outline:none;cursor:pointer;margin:0 2px}.stitch-animator-speed-slider:disabled{opacity:.4;cursor:not-allowed}.stitch-animator-speed-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent, #4a9eff);cursor:grab}.stitch-animator-speed-label{font-size:11px;color:var(--text-secondary, #aaa);font-variant-numeric:tabular-nums;min-width:32px;text-align:right;white-space:nowrap}.stitch-animator-count{color:var(--text-secondary, #aaa);font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0;min-width:80px;text-align:right}.stitch-animator-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--panel-border, #555);border-radius:4px;background:var(--panel-bg, #303030);color:var(--text-secondary, #aaa);cursor:pointer;padding:0;font-size:20px;flex-shrink:0}.stitch-animator-close:hover{background:var(--button-hover, #444);color:var(--text-primary, #eee)}.export-wizard-mode-toggle{display:flex;gap:0;margin:12px 16px 0;border:1px solid var(--panel-border, #444);border-radius:6px;overflow:hidden}.export-wizard-mode-btn{flex:1;padding:6px 12px;border:none;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;font-size:12px;font-weight:500}.export-wizard-mode-btn:hover{background:var(--hover-bg, #333)}.export-wizard-mode-btn.active{background:var(--accent, #4a9eff);color:#fff}.export-wizard-formats{padding:8px 16px 12px}.export-wizard-section-label{font-size:11px;font-weight:600;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.05em;margin:8px 0 6px}.export-wizard-format-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.export-wizard-format-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border:1px solid var(--panel-border, #444);border-radius:6px;background:transparent;color:var(--text-secondary, #aaa);cursor:pointer;font-size:11px;position:relative}.export-wizard-format-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.export-wizard-format-btn.active{background:var(--hover-bg, #333);border-color:var(--accent, #4a9eff);color:var(--accent, #4a9eff)}.export-wizard-format-btn.recommended{border-color:var(--accent, #4a9eff)}.export-wizard-format-btn.checkbox{flex-direction:row;gap:6px;padding:6px 8px;justify-content:flex-start}.export-wizard-format-ext{font-weight:700;font-size:13px}.export-wizard-format-label{font-size:10px;color:var(--text-muted, #888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.export-wizard-format-btn.active .export-wizard-format-label{color:var(--text-secondary, #aaa)}.export-wizard-format-badge{position:absolute;top:-4px;right:-4px;font-size:8px;font-weight:700;text-transform:uppercase;padding:1px 4px;border-radius:3px;background:var(--accent, #4a9eff);color:#fff;letter-spacing:.03em}.export-wizard-checkbox{width:16px;height:16px;border:1px solid var(--panel-border, #555);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;color:var(--accent, #4a9eff)}.export-wizard-format-btn.active .export-wizard-checkbox{background:var(--accent, #4a9eff);border-color:var(--accent, #4a9eff);color:#fff}.export-wizard-progress{margin-right:auto;font-size:12px;color:var(--text-secondary, #aaa)}.export-wizard-cancel,.export-wizard-export{padding:6px 16px;border-radius:4px;border:1px solid var(--panel-border, #444);font-size:13px;cursor:pointer}.export-wizard-cancel{background:transparent;color:var(--text-secondary, #aaa)}.export-wizard-cancel:hover{background:var(--hover-bg, #333)}.export-wizard-cancel:disabled,.export-wizard-export:disabled{opacity:.5;cursor:not-allowed}.export-wizard-export{background:var(--accent, #4a9eff);border-color:var(--accent, #4a9eff);color:#fff}.export-wizard-export:hover:not(:disabled){filter:brightness(1.1)}.auth-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-label{font-size:12px;font-weight:500;color:var(--text-secondary, #aaa);text-transform:uppercase;letter-spacing:.04em}.auth-input{padding:8px 12px;font-size:14px;background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:6px;color:var(--text-primary, #ddd);outline:none;transition:border-color .15s ease}.auth-input:focus{border-color:var(--accent-bg, #1976d2)}.auth-input::placeholder{color:var(--text-muted, #666)}.auth-input:disabled{opacity:.6}.auth-error-banner{padding:8px 12px;font-size:13px;color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.25);border-radius:6px;line-height:1.4}.auth-info-banner{padding:8px 12px;font-size:13px;color:#51cf66;background:#51cf661a;border:1px solid rgba(81,207,102,.25);border-radius:6px;line-height:1.4}.auth-btn{padding:10px 16px;font-size:14px;font-weight:500;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:background .15s ease,filter .15s ease}.auth-btn-google{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#333;border-color:#ddd}.auth-btn-google:hover{background:#f5f5f5;filter:none}.auth-btn-google:disabled{opacity:.5;cursor:not-allowed}.auth-btn-google svg{flex-shrink:0}.auth-divider{display:flex;align-items:center;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--panel-border, #444)}.auth-divider-text{font-size:12px;color:var(--text-muted, #666);text-transform:uppercase;letter-spacing:.04em}.auth-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.auth-btn-primary:hover{filter:brightness(1.1)}.auth-btn-primary:disabled{opacity:.5;cursor:not-allowed;filter:none}.auth-btn-skip{background:transparent;color:var(--text-muted, #666);border-color:var(--panel-border, #444);margin-top:4px;width:100%}.auth-btn-skip:hover{background:var(--hover-bg, #333);color:var(--text-secondary, #aaa)}.auth-footer-inner{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.auth-link{background:none;border:none;color:var(--accent-bg, #4dabf7);font-size:13px;cursor:pointer;padding:4px 0;transition:opacity .15s ease}.auth-link:hover{opacity:.8}.settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--panel-border, #333);margin-bottom:16px}.settings-tab{padding:8px 16px;font-size:13px;font-weight:500;color:var(--text-secondary, #aaa);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.settings-tab:hover{color:var(--text-primary, #ddd)}.settings-tab-active{color:var(--text-primary, #ddd);border-bottom-color:var(--accent-bg, #4dabf7)}.settings-body{min-height:200px}.settings-group{border:1px solid var(--panel-border, #333);border-radius:8px;padding:12px 16px;margin:0 8px 12px}.settings-group legend{font-size:12px;font-weight:600;color:var(--text-secondary, #aaa);padding:0 6px;text-transform:uppercase;letter-spacing:.04em}.settings-radio-group{display:flex;gap:16px;margin-top:8px}.settings-radio,.settings-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-primary, #ddd);cursor:pointer}.settings-radio input,.settings-checkbox input{accent-color:var(--accent-bg, #4dabf7)}.settings-hint{font-size:12px;color:var(--text-muted, #888);margin:4px 0}.settings-inline{display:flex;align-items:center;gap:8px;margin-top:8px}.settings-input{padding:4px 8px;font-size:13px;font-family:SF Mono,Fira Code,monospace;color:var(--text-primary, #ddd);background:var(--hover-bg, #333);border:1px solid var(--panel-border, #444);border-radius:4px;width:80px}.settings-btn{padding:4px 12px;font-size:12px;font-weight:500;color:#fff;background:var(--accent-bg, #1976d2);border:none;border-radius:4px;cursor:pointer}.settings-btn:hover{filter:brightness(.9)}.settings-about{text-align:center;padding:24px 0}.settings-about h3{font-size:18px;color:var(--text-primary, #ddd);margin:0 0 4px}.theme-category{margin-top:8px}.theme-category+.theme-category{margin-top:12px}.theme-category-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #888);margin-bottom:6px}.theme-swatch-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.theme-swatch{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px;border:2px solid transparent;border-radius:6px;background:transparent;cursor:pointer;transition:border-color .1s}.theme-swatch:hover{border-color:var(--panel-border, #444)}.theme-swatch-active{border-color:var(--accent-bg, #1976d2)}.theme-swatch-preview{width:40px;height:28px;border-radius:4px;border:1px solid;display:flex;align-items:flex-end;justify-content:flex-end;padding:3px;box-sizing:border-box}.theme-swatch-accent{width:12px;height:6px;border-radius:2px}.theme-swatch-name{font-size:10px;color:var(--text-secondary, #aaa);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:64px}.theme-editor-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.theme-editor{background:var(--panel-bg, #252525);border:1px solid var(--panel-border, #444);border-radius:12px;width:720px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 16px 64px #00000080}.theme-editor-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--panel-border, #444)}.theme-editor-header h2{margin:0;font-size:14px;font-weight:600;color:var(--text-primary, #ddd)}.theme-editor-close{background:none;border:none;color:var(--text-muted, #666);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.theme-editor-close:hover{color:var(--text-primary, #ddd)}.theme-editor-body{display:flex;flex:1;overflow:hidden}.theme-editor-sidebar{width:200px;border-right:1px solid var(--panel-border, #444);display:flex;flex-direction:column;flex-shrink:0}.theme-editor-list{flex:1;overflow-y:auto;padding:4px 0}.theme-editor-section-label{padding:6px 12px 2px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #666)}.theme-editor-list-item{display:flex;align-items:center;gap:4px;width:100%;padding:0 4px 0 8px;font-size:12px;color:var(--text-primary, #ddd);background:transparent}.theme-editor-list-item:hover{background:var(--hover-bg, #333)}.theme-editor-list-item.active{background:var(--accent-bg, #1976d2);color:#fff}.theme-editor-list-item.hidden-theme{opacity:.5}.theme-editor-vis-check{flex-shrink:0;width:14px;height:14px;cursor:pointer;accent-color:var(--accent-bg, #1976d2)}.theme-editor-vis-check:disabled{cursor:default;opacity:.3}.theme-editor-list-btn{display:flex;align-items:center;gap:6px;flex:1;padding:8px 4px;font-size:12px;color:inherit;background:transparent;border:none;cursor:pointer;text-align:left}.theme-editor-active-dot{font-size:8px;color:var(--accent-bg, #4dabf7)}.theme-editor-list-item.active .theme-editor-active-dot{color:#fff}.theme-editor-badge{margin-left:auto;font-size:10px;color:var(--text-muted, #666);opacity:.6}.theme-editor-new-btn{padding:8px 12px;margin:4px 8px 8px;font-size:12px;color:var(--accent-bg, #4dabf7);background:transparent;border:1px dashed var(--panel-border, #444);border-radius:6px;cursor:pointer}.theme-editor-new-btn:hover{background:var(--hover-bg, #333)}.theme-editor-colors{flex:1;overflow-y:auto;padding:12px 16px}.theme-editor-name-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.theme-editor-name-row label{font-size:12px;color:var(--text-secondary, #aaa);flex-shrink:0}.theme-editor-name-row input[type=text]{flex:1;padding:4px 8px;font-size:12px;background:var(--canvas-bg, #1a1a1a);color:var(--text-primary, #ddd);border:1px solid var(--panel-border, #444);border-radius:4px}.theme-editor-builtin-label{font-size:13px;font-weight:500;color:var(--text-primary, #ddd)}.theme-editor-dup-btn{margin-left:auto;padding:4px 12px;font-size:11px;color:var(--accent-bg, #4dabf7);background:transparent;border:1px solid var(--accent-bg, #4dabf7);border-radius:4px;cursor:pointer}.theme-editor-dup-btn:hover{background:var(--accent-bg, #1976d2);color:#fff}.theme-editor-actions{display:flex;gap:8px;margin-bottom:12px}.theme-editor-actions button{padding:4px 10px;font-size:11px;color:var(--text-secondary, #aaa);background:transparent;border:1px solid var(--panel-border, #444);border-radius:4px;cursor:pointer}.theme-editor-actions button:hover:not(:disabled){background:var(--hover-bg, #333);color:var(--text-primary, #ddd)}.theme-editor-delete-btn{color:#ef5350!important;border-color:#ef5350!important}.theme-editor-delete-btn:hover:not(:disabled){background:#ef535026!important}.theme-editor-delete-btn:disabled{opacity:.3;cursor:default}.theme-editor-groups{display:flex;flex-direction:column;gap:0}.theme-editor-group{border-bottom:1px solid var(--panel-border, #444)}.theme-editor-group:last-child{border-bottom:none}.theme-editor-group-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted, #666);cursor:pointer;padding:8px 0;list-style:none;user-select:none;transition:color .1s}.theme-editor-group-title::-webkit-details-marker{display:none}.theme-editor-group-title:before{content:"▸ ";font-size:10px}.theme-editor-group[open]>.theme-editor-group-title:before{content:"▾ "}.theme-editor-group-title:hover{color:var(--text-secondary, #aaa)}.theme-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding-top:4px;padding-bottom:8px}.theme-editor-color{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;cursor:pointer}.theme-editor-color:hover{background:var(--hover-bg, #333)}.theme-editor-color.readonly{opacity:.5;cursor:default}.theme-editor-color input[type=color]{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.theme-editor-swatch{width:20px;height:20px;border-radius:4px;border:1px solid var(--panel-border, #444);flex-shrink:0}.theme-editor-key{font-size:11px;color:var(--text-secondary, #aaa)}.cloud-open-body{padding:8px 24px 24px;min-height:120px}.cloud-open-status{font-size:13px;color:var(--text-muted, #666);text-align:center;padding:24px 0;margin:0}.cloud-open-error{font-size:12px;color:#e53935;margin:0 0 8px}.cloud-open-list{display:flex;flex-direction:column;gap:2px;max-height:320px;overflow-y:auto}.cloud-open-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:6px;cursor:pointer}.cloud-open-item:hover{background:var(--hover-bg, rgba(255,255,255,.04))}.cloud-open-item.loading{opacity:.6;cursor:wait}.cloud-open-item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.cloud-open-item-title{font-size:13px;color:var(--text-primary, #ddd);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cloud-open-item-date{font-size:11px;color:var(--text-muted, #666)}.cloud-open-item-loading{font-size:11px;color:var(--accent-bg, #1976d2);white-space:nowrap}.cloud-open-item-delete{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted, #666);cursor:pointer;border-radius:4px;font-size:16px;padding:0;opacity:0;transition:opacity .1s;flex-shrink:0}.cloud-open-item:hover .cloud-open-item-delete{opacity:1}.cloud-open-item-delete:hover{color:#e53935;background:var(--hover-bg, #333)}.design-limit-body{padding:24px;display:flex;flex-direction:column;gap:12px}.design-limit-text{font-size:14px;color:var(--text-primary, #ddd);line-height:1.5;margin:0}.design-limit-hint{font-size:12px;color:var(--text-muted, #888);line-height:1.5;margin:0}.design-limit-hint a{color:var(--accent-bg, #1976d2);text-decoration:none}.design-limit-hint a:hover{text-decoration:underline}.design-limit-footer{display:flex;gap:8px;justify-content:flex-end}.design-limit-btn{padding:8px 16px;font-size:13px;border-radius:6px;border:1px solid var(--panel-border, #444);cursor:pointer;transition:background .15s ease}.design-limit-btn-secondary{background:transparent;color:var(--text-secondary, #aaa)}.design-limit-btn-secondary:hover{background:var(--hover-bg, #333)}.design-limit-btn-primary{background:var(--accent-bg, #1976d2);color:#fff;border-color:var(--accent-bg, #1976d2)}.design-limit-btn-primary:hover{filter:brightness(1.1)}.app-container{display:grid;grid-template-columns:auto minmax(0,1fr) 5px auto;grid-template-rows:48px 36px 1fr;grid-template-areas:"header  header  header header" "tabbar  tabbar  tabbar right" "tools   canvas  rdiv   right";width:100%;height:100vh;height:100dvh;background:var(--canvas-bg, #1a1a1a)}.app-header{grid-area:header}.canvas-area{grid-area:canvas;position:relative;overflow:hidden;min-width:100px}.sidebar-wrapper{overflow:hidden;transition:width .2s ease;min-width:0}.sidebar-wrapper.right{grid-area:right}.sidebar-wrapper.collapsed{pointer-events:none}.sidebar-wrapper.resizing{transition:none}.import-overlay{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#00000073;pointer-events:none}.import-overlay-card{background:var(--panel-bg, #2a2a2a);border:1px solid var(--panel-border, #444);border-radius:8px;padding:20px 32px;min-width:240px;text-align:center;box-shadow:0 4px 24px #00000080}.import-overlay-message{color:var(--text-primary, #eee);font-size:14px;margin-bottom:12px}.import-overlay-bar{height:6px;background:var(--panel-border, #444);border-radius:3px;overflow:hidden}.import-overlay-bar-fill{height:100%;background:var(--accent, #5b9bd5);border-radius:3px;transition:width .15s ease-out}.import-overlay-count{color:var(--text-secondary, #999);font-size:12px;margin-top:8px}.empty-state{grid-column:1 / -1;grid-row:3;display:flex;align-items:center;justify-content:center;background-color:var(--canvas-bg, #1a1a1a);background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,var(--panel-border, #333) 10px,var(--panel-border, #333) 11px)}.empty-state-text{color:var(--text-muted, #666);font-size:14px;padding:16px 24px;background:var(--panel-bg, #252525);border-radius:8px;border:1px solid var(--panel-border, #333)}.drop-overlay{position:fixed;inset:0;z-index:9999;background:#4a9eff1f;border:3px dashed var(--accent-color, #4dabf7);display:flex;align-items:center;justify-content:center;pointer-events:none}.drop-overlay-text{font-size:24px;color:var(--accent-color, #4dabf7);font-weight:600;text-shadow:0 2px 8px rgba(0,0,0,.5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;-webkit-user-select:none;user-select:none}input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;color:var(--text-primary, #ddd);background:var(--canvas-bg, #1a1a1a);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scroll-track, #1a1a1a)}::-webkit-scrollbar-thumb{background:var(--scroll-thumb, #555);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scroll-thumb, #555);filter:brightness(1.2)}
