*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;font-size:inherit;line-height:inherit}input[type=number]{-moz-appearance:textfield;appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}:root{color-scheme:dark}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e0e0e0;--text-primary: #000000;--text-secondary: #666666;--border-color: #cccccc}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2a2a2a;--bg-tertiary: #3a3a3a;--text-primary: #ffffff;--text-secondary: #cccccc;--border-color: #444444;--accent-color: #ff4081}[data-theme=midnight]{--bg-primary: #0d0d0d;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #e0e0e0;--text-secondary: #999999;--border-color: #333333;--accent-color: #7b68ee}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--border-radius);cursor:pointer;font-weight:600;font-size:var(--font-size-base);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.3;cursor:not-allowed}.btn-icon{width:var(--button-size);height:var(--button-size);padding:0;background:transparent;color:var(--text-secondary)}.btn-icon:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon:active:not(:disabled){transform:scale(.95)}.btn-icon-sm{width:var(--button-size-sm);height:var(--button-size-sm);padding:0;background:transparent;border-radius:var(--border-radius-sm);color:inherit;opacity:.7;transition:opacity var(--transition-slow)}.btn-icon-sm:hover:not(:disabled){opacity:1}.btn-primary{background:var(--accent-color);color:var(--text-primary)}.btn-primary:hover:not(:disabled){filter:brightness(1.1)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background:transparent;border:var(--border-width) solid var(--border-color);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-lg)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary)}.btn-ghost{background:transparent;border:none;color:var(--text-secondary);padding:var(--spacing-sm) var(--spacing-md);text-align:left}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-ghost.active{background:var(--accent-color);color:var(--text-primary);font-weight:600}.btn-action{width:100%;padding:var(--spacing-sm);background:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);color:var(--text-primary)}.btn-action:hover:not(:disabled){background:var(--bg-hover);transform:scale(1.02)}.btn-danger:hover:not(:disabled){background:var(--color-delete);border-color:var(--color-delete)}.btn-full{width:100%}.input,.input-text,.input-number,.input-select{padding:var(--spacing-xs);background:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.input:focus,.input-text:focus,.input-number:focus,.input-select:focus{outline:none;border-color:var(--accent-color);background:var(--bg-secondary)}.input::placeholder,.input-text::placeholder,.input-number::placeholder{color:var(--text-secondary);opacity:.6}.input-number{width:100%;max-width:300px}.input-text{width:100%}.input-with-unit{display:flex;align-items:center;gap:var(--spacing-md)}.input-with-unit input[type=range]{flex:1;max-width:300px}.range-value{min-width:50px;text-align:right;font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600}.input-select{padding:var(--spacing-xs);border-radius:var(--border-radius-sm);cursor:pointer}.input-color{border:var(--border-width-thick) solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast)}.input-color:hover{border-color:var(--accent-color)}.input-color-lg{width:var(--button-size-lg);height:var(--button-size-lg)}.input-checkbox{appearance:none;-webkit-appearance:none;width:18px;height:18px;cursor:pointer;border:var(--border-width-thick) solid var(--border-color);border-radius:var(--border-radius-sm);background-color:var(--bg-tertiary);position:relative;transition:all var(--transition-fast);flex-shrink:0}.input-checkbox:hover{border-color:var(--text-secondary);background-color:var(--bg-hover)}.input-checkbox:checked{background-color:var(--accent-color);border-color:var(--accent-color)}.input-checkbox:checked:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid var(--text-primary);border-width:0 2px 2px 0;transform:rotate(45deg)}.input-checkbox:disabled{opacity:.3;cursor:not-allowed}.input-range{-webkit-appearance:none;appearance:none;width:100%;height:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--spacing-sm);border:var(--border-width) solid var(--border-color);outline:none;cursor:pointer;accent-color:var(--accent-color)}.input-range-tall::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:var(--spacing-sm);height:calc(var(--button-size) - var(--spacing-sm));background:var(--accent-color);cursor:grab;border-radius:var(--border-radius);border:var(--border-width) solid rgba(0,0,0,.2)}.input-range-tall:active::-webkit-slider-thumb{cursor:grabbing;filter:brightness(1.1)}.input-range-tall::-moz-range-thumb{width:var(--spacing-sm);height:calc(var(--button-size) - var(--spacing-sm));background:var(--accent-color);cursor:grab;border-radius:var(--border-radius);border:var(--border-width) solid rgba(0,0,0,.2)}.input-range-tall:active::-moz-range-thumb{cursor:grabbing;filter:brightness(1.1)}.input-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent-color);cursor:pointer;border-radius:50%;border:1px solid rgba(0,0,0,.2);margin-top:-3px}.input-range:active::-webkit-slider-thumb{transform:scale(1.1);filter:brightness(1.1)}.input-range::-moz-range-thumb{width:14px;height:14px;background:var(--accent-color);cursor:pointer;border-radius:50%;border:1px solid rgba(0,0,0,.2)}.input-range:active::-moz-range-thumb{transform:scale(1.1);filter:brightness(1.1)}.input-label{display:block;margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500}.panel{background:var(--bg-secondary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow)}.modal{background:var(--bg-secondary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:column}.modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-slide-in{animation:slideIn var(--transition-normal) ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.card{background:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-sm)}.section{padding:var(--spacing-sm)}.section-bordered{padding-bottom:var(--spacing-sm);border-bottom:var(--border-width) solid var(--border-color)}.section-bordered:last-of-type{border-bottom:none;margin-bottom:none}.scrollable{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb-color) var(--scrollbar-track-color)}.scrollable::-webkit-scrollbar{width:var(--scrollbar-width);height:var(--scrollbar-width)}.scrollable::-webkit-scrollbar-track{background:var(--scrollbar-track-color)}.scrollable::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb-color);border-radius:var(--scrollbar-border-radius)}.scrollable::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover-color)}.scrollable-hidden{scrollbar-width:none;-ms-overflow-style:none}.scrollable-hidden::-webkit-scrollbar{display:none}h3{text-align:center}#root{width:100%;height:100vh}.splash-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.splash-content{text-align:center;width:90%;max-width:1100px;padding:var(--spacing-sm);background-color:var(--bg-secondary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.splash-content h1{font-size:2rem;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.splash-content>p{font-size:1rem;color:var(--text-secondary);margin-bottom:var(--spacing-md)}.project-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--spacing-sm);justify-content:center}.project-type-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-md);cursor:pointer;text-align:center;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background-color .2s ease}.project-type-card:hover{background-color:var(--bg-hover);border-color:var(--accent-color)}.project-type-card:hover .card-icon{color:var(--accent-color);border-color:var(--accent-color)}.card-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background-color:var(--bg-secondary);border-radius:var(--border-radius-lg);border:var(--border-width) solid var(--border-color);color:var(--text-secondary);flex-shrink:0;transition:all .2s ease}.card-content{flex:1}.project-type-card h2{font-size:1.25rem;margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);font-weight:600}.project-type-card p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.4}.confirmation-overlay{z-index:2000}.confirmation-dialog{padding:24px;max-width:400px;width:100%}.confirmation-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.confirmation-message{font-size:14px;color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.confirmation-buttons{display:flex;gap:12px;justify-content:flex-end}.confirmation-button{font-size:13px}.confirmation-button.confirm.btn-danger{background-color:var(--color-delete);color:#fff}.confirmation-button.confirm.btn-danger:hover{background-color:#d32f2f}.workspace-tabs-container{position:absolute;top:0;left:0;right:0;height:var(--workspace-tab-height);background-color:var(--bg-secondary);border-bottom:var(--border-width) solid var(--border-color);display:flex;align-items:stretch;overflow-x:auto;overflow-y:hidden;z-index:1000;pointer-events:auto}.workspace-tabs-container::-webkit-scrollbar{height:var(--scrollbar-size)}.workspace-tabs-container::-webkit-scrollbar-track{background:var(--scrollbar-bg)}.workspace-tabs-container::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:var(--border-radius-sm)}.workspace-tabs-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.workspace-tab{display:flex;align-items:center;gap:var(--tab-gap);padding:0 var(--tab-padding);min-width:var(--tab-min-width);max-width:var(--tab-max-width);background-color:var(--bg-tertiary);border-right:var(--border-width) solid var(--border-color);cursor:pointer;transition:background-color var(--transition-normal);-webkit-user-select:none;user-select:none;flex-shrink:0}.workspace-tab:hover{background-color:var(--bg-hover)}.workspace-tab.active{background-color:var(--bg-primary);border-bottom:var(--border-width-thick) solid var(--accent-color)}.workspace-tab-close{display:flex;align-items:center;justify-content:center;width:var(--icon-size);height:var(--icon-size);border-radius:var(--border-radius-sm);transition:background-color var(--transition-normal);flex-shrink:0}.workspace-tab-close:hover{background-color:var(--bg-secondary)}.workspace-tab-close svg{width:var(--icon-size);height:var(--icon-size);color:var(--text-secondary)}.workspace-tab-close:hover svg{color:var(--text-primary)}.workspace-tab-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:var(--text-primary)}.workspace-tab-name-input{flex:1;background:var(--bg-secondary);border:var(--border-width) solid var(--accent-color);border-radius:var(--border-radius-sm);padding:2px 4px;font-size:13px;color:var(--text-primary);outline:none;font-family:inherit}.workspace-tab-add{display:flex;align-items:center;justify-content:center;width:var(--workspace-tab-height);background-color:var(--bg-tertiary);cursor:pointer;transition:background-color var(--transition-normal);flex-shrink:0}.workspace-tab-add:hover{background-color:var(--bg-hover)}.workspace-tab-add svg{width:18px;height:18px;color:var(--text-secondary)}.workspace-tab-add:hover svg{color:var(--text-primary)}.workspace-tabs-spacer{flex:1;min-width:var(--spacing-md)}.workspace-settings-button{width:var(--workspace-tab-height);height:100%;background-color:var(--bg-tertiary);border-radius:0;flex-shrink:0;border-left:var(--border-width) solid var(--border-color);color:var(--text-secondary)}.workspace-settings-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.workspace-settings-button svg{width:18px;height:18px}.workspace-tab-add-container{position:relative;display:flex;align-items:center}.workspace-tab-add{display:flex;align-items:center;justify-content:center;width:var(--workspace-tab-height);height:100%;cursor:pointer;transition:background-color var(--transition-normal);color:var(--text-secondary);border-right:var(--border-width) solid var(--border-color)}.workspace-tab-add:hover{background-color:var(--bg-hover);color:var(--text-primary)}.workspace-add-menu{background-color:var(--bg-secondary);border:var(--border-width) solid var(--border-color);border-radius:0 0 var(--border-radius) var(--border-radius);box-shadow:var(--shadow-md);z-index:1001;min-width:160px;overflow:hidden}.workspace-add-menu-item{padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-primary);transition:background-color .2s}.workspace-add-menu-item:hover{background-color:var(--bg-hover)}.workspace-tab:hover{opacity:.5}.workspace-tab.dragging{opacity:.5;background-color:var(--bg-secondary)}.global-settings-modal{width:90%;max-width:900px;height:80vh;max-height:700px;overflow:hidden}.global-settings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-lg);border-bottom:var(--border-width) solid var(--border-color)}.global-settings-header h2{margin:0;font-size:var(--font-size-lg);color:var(--text-primary);font-weight:600}.close-button{font-size:32px;line-height:1}.global-settings-content{display:flex;flex:1;overflow:hidden}.settings-categories{width:200px;border-right:var(--border-width) solid var(--border-color);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);background:var(--bg-primary)}.category-button{font-size:var(--font-size-base)}.category-button.active:hover{background:var(--accent-color);filter:brightness(1.1)}.settings-panel{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.settings-section h4{margin:var(--spacing-sm);margin-top:0;font-size:var(--font-size-base);color:var(--text-primary);font-weight:600}.subsection-description{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-sm);color:var(--text-secondary)}.global-settings-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-lg);border-top:var(--border-width) solid var(--border-color);background:var(--bg-primary)}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section h3{margin:var(--spacing-sm);font-size:var(--font-size-lg);color:var(--text-primary);font-weight:600}.section-description{margin:0 0 var(--spacing-lg) 0;font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.5}.setting-group{margin-bottom:var(--spacing-sm)}.setting-group.checkbox-group{display:flex;align-items:center;gap:var(--spacing-sm)}.setting-description{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--text-secondary)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.custom-color-picker{width:var(--color-picker-width);padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.saturation-wrapper{width:100%;height:var(--color-picker-saturation-height);position:relative;border-radius:var(--border-radius);overflow:hidden}.hue-wrapper{width:100%;height:var(--color-picker-hue-height);position:relative;border-radius:var(--border-radius);overflow:hidden}.color-box{width:100%;height:50px;border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;position:relative;transition:border var(--transition-slow),transform var(--transition-fast);display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:0 var(--spacing-sm);gap:var(--spacing-sm);box-sizing:border-box}.color-box.locked{border:var(--border-width-thick) solid var(--accent-color)}.color-info{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:0;pointer-events:none}.color-info input{pointer-events:auto}.color-name{font-size:10px;font-weight:600;text-transform:capitalize;text-align:center;display:block;width:100%;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;line-height:1.2}.hex-input{border:none;background:transparent;font-family:monospace;font-size:12px;font-weight:700;text-align:center;padding:2px 4px;cursor:text;width:100%;text-transform:uppercase;color:inherit}.hex-input:focus{background-color:#fff3;border-radius:2px;outline:none}.color-control-btn{opacity:.6;transition:opacity .2s}.color-control-btn:hover{opacity:1;background-color:#fff3}.color-control-btn.locked{opacity:1}.color-box.compact{height:70px;padding:6px;flex-direction:column;justify-content:center;text-align:center}.color-box.compact .color-info{justify-content:center}.locked-indicator{position:absolute;top:4px;right:4px;width:16px;height:16px;background-color:#ffc107cc;border-radius:3px;display:flex;align-items:center;justify-content:center}.color-box.add-color{background-color:var(--bg-tertiary);border:2px dashed var(--border-color);color:var(--text-secondary);justify-content:center}.color-box.add-color:hover{border-color:var(--accent-color);color:var(--accent-color)}.texture-settings-input-top-margin{margin-top:var(--spacing-xs)}.attribution-panel{background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xs) var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-size-xs);font-family:monospace;-webkit-user-select:none;user-select:none;pointer-events:auto;box-shadow:var(--shadow-sm);opacity:.8;transition:opacity .2s}.attribution-panel:hover{opacity:1}.attribution-panel a{color:var(--text-primary);font-weight:700;text-decoration:underline;cursor:pointer}.attribution-panel a:hover{color:var(--accent-color)}.tool-layout{width:100%;height:100%;position:relative;background-color:var(--bg-primary);overflow:hidden}.tool-ui-container{position:absolute;inset:40px 0 0;margin:var(--spacing-sm);pointer-events:none;display:flex;gap:var(--spacing-sm)}.tool-ui-container>*{pointer-events:auto}.tool-center-container{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none;position:relative;min-width:0}.tool-center-container>*{pointer-events:auto}.tool-additional-info{position:absolute;bottom:0;right:0;pointer-events:none;display:flex;flex-direction:column-reverse;gap:var(--spacing-xs);align-items:flex-end;z-index:10}.tool-bottom-center{position:absolute;bottom:0;left:50%;transform:translate(-50%);pointer-events:none;z-index:10;display:flex;justify-content:center}.tool-bottom-center>*{pointer-events:auto}.tool-additional-info>*{pointer-events:auto}.tool-panel-left,.tool-panel-right{display:flex;flex-direction:column;height:100%;pointer-events:auto}.side-panel{height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative;background-color:var(--bg-secondary);border-right:var(--border-width) solid var(--border-color)}.side-panel-header{padding:var(--spacing-sm);border-bottom:var(--border-width) solid var(--border-color);text-align:center;flex-shrink:0}.side-panel-header h3{margin:0;font-size:var(--font-size-lg);color:var(--text-primary);font-weight:600}.side-panel-content{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.side-panel-content::-webkit-scrollbar{display:none}.resize-handle{position:absolute;top:0;bottom:0;width:var(--spacing-sm);cursor:ew-resize;z-index:10}.resize-handle.left{right:0}.resize-handle.right{left:0}.resize-handle:hover:after,.resize-handle:active:after{content:"";position:absolute;top:0;bottom:0;width:var(--border-width-thick);background-color:var(--accent-color)}.resize-handle.left:hover:after,.resize-handle.left:active:after{right:0}.resize-handle.right:hover:after,.resize-handle.right:active:after{left:0}.color-palette{display:flex;flex-direction:column;gap:var(--spacing-sm)}.color-box-container{display:flex;align-items:stretch;gap:6px}.drag-handle{width:var(--drag-handle-width);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:grab;opacity:.4;transition:opacity var(--transition-slow)}.drag-handle:hover{opacity:.8}.drag-handle:active{cursor:grabbing}.drag-lines{display:flex;align-items:center;justify-content:space-between;height:100%;width:100%}.drag-lines span{width:var(--border-width);height:100%;background-color:var(--text-primary);opacity:.5}.drag-handle:hover .drag-lines span{opacity:1}.color-box.dragging,.color-box-container.dragging{opacity:.5}.color-box.drag-over{border-color:var(--accent-color);border-width:var(--border-width-thick)}.color-box:hover{transform:scale(1.02)}.hex-input:disabled{cursor:not-allowed;opacity:.6}.color-box.add-color{background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-primary);padding:0}.toolbar-options{padding:var(--spacing-sm);margin-top:auto}.toolbar-options h3{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:14px}.color-palette.compact-mode{display:grid;gap:var(--spacing-sm)}.color-box.compact{height:70px;padding:6px;flex-direction:column;justify-content:space-between;cursor:grab;position:relative;font-size:12px}.color-box.compact:active{cursor:grabbing}.color-box.compact .color-info{flex:1;justify-content:center;gap:2px}.color-box.compact .locked-indicator{position:absolute;top:4px;right:4px;width:16px;height:16px;background-color:#ffc1074d;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:.9}.color-box.compact.add-color{height:70px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.context-menu{position:fixed;background-color:var(--bg-secondary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);box-shadow:0 4px 12px #0006;padding:4px;min-width:150px;z-index:10001}.context-menu button{width:100%;height:32px;font-size:13px;display:flex;align-items:center;gap:8px;text-align:left;justify-content:flex-start}.toolbar{height:100%;position:relative;min-width:var(--toolbar-min-width);max-width:var(--toolbar-max-width)}.toolbar-header{padding:var(--spacing-sm);border-bottom:var(--border-width) solid var(--border-color);text-align:center}.toolbar-header h3{margin:0;font-size:var(--font-size-lg);color:var(--text-primary);font-weight:600}.toolbar-resize-handle{position:absolute;top:0;right:0;width:var(--spacing-sm);height:100%;cursor:ew-resize;z-index:10}.toolbar-resize-handle:hover:after{content:"";position:absolute;top:0;right:-1px;transform:translate(-50%);width:var(--border-width-thick);height:100%;background-color:var(--accent-color)}.toolbar-resize-handle:active:after{opacity:1}.toolbar-section{flex:1;display:flex;flex-direction:column}.toolbar-section{display:flex;flex-direction:column}.toolbar-subsection{display:flex;flex-direction:column;padding:var(--spacing-sm);border-bottom:var(--border-width) solid var(--border-color);gap:var(--spacing-sm)}.toolbar-subsection:last-of-type{border-bottom:none}.toolbar-subsection h3{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600}.toolbar-subsection-header{display:flex;align-items:center;margin-bottom:var(--spacing-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.toolbar-subsection-header h3{margin:0;flex:1;font-size:var(--font-size-base)}.toolbar-subsection-header:hover h3,.toolbar-subsection-header:hover .toggle-icon{color:var(--text-primary)}.toggle-icon{color:var(--text-secondary);margin-right:4px;display:flex;align-items:center}.toolbar-setting-group label{display:flex;flex-direction:column;gap:var(--spacing-sm);color:var(--text-secondary);font-size:12px}.toolbar-setting-group.checkbox-group{gap:var(--spacing-sm)}.toolbar-setting-group.checkbox-group label{flex-direction:row;align-items:center;cursor:pointer}.toolbar-setting-group.inline{flex-direction:row;align-items:center;justify-content:space-between}.toolbar-setting-group.inline label{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;justify-content:space-between;flex-direction:row}.toolbar-setting-group.inline input{width:60px}.workspace-actions{padding:var(--spacing-sm);border-top:var(--border-width) solid var(--border-color);margin-top:auto}.workspace-actions h3{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:14px}.action-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.action-button{font-size:13px;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);flex-shrink:0;padding:var(--spacing-sm);border-radius:var(--border-radius);cursor:pointer;transition:all .2s;color:var(--text-primary);background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color)}.action-button.clear-button{color:#ff3b30}.action-button.clear-button:hover{background-color:#ff3b3033;border-color:#ff3b3080}.action-button:hover{background-color:var(--bg-hover)}.btn-full{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.canvas-container{position:fixed;left:calc(var(--toolbar-width) + var(--spacing-lg));right:calc(var(--toolbar-width) + var(--spacing-lg));top:var(--workspace-tab-height);bottom:0;display:flex;align-items:center;justify-content:center}.canvas-wrapper{max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.canvas{display:grid;border:var(--border-width) solid var(--border-color);image-rendering:-moz-crisp-edges;image-rendering:-webkit-crisp-edges;image-rendering:pixelated;image-rendering:crisp-edges}.canvas.pixel-canvas{display:block;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:-webkit-crisp-edges;image-rendering:crisp-edges}.gradient-controls{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column-reverse;gap:var(--spacing-sm);background-color:var(--overlay-bg);padding:var(--spacing-sm);border-radius:var(--border-radius-lg);z-index:100}.gradient-control-btn{background-color:var(--bg-tertiary);font-size:var(--icon-size-md)}.gradient-control-btn:hover{background-color:var(--overlay-lighter);transform:scale(1.1)}.gradient-control-btn.delete-btn:hover{background-color:var(--color-delete)}.gradient-control-btn.edit-btn:hover{background-color:var(--color-edit)}.gradient-control-btn.reverse-btn:hover{background-color:var(--color-reverse)}.gradient-control-btn.drag-btn{cursor:grab;font-weight:700;letter-spacing:-2px}.gradient-control-btn.drag-btn:active{cursor:grabbing}.pixel-canvas-container{position:relative}.pixel-canvas-overlay{pointer-events:none}.pixel-overlay-box{position:relative;pointer-events:auto;cursor:pointer}.pixel-overlay-box.dragging{opacity:.5;cursor:grabbing}.pixel-overlay-box.drag-over{box-shadow:0 0 0 3px var(--accent-color) inset}.pixel-overlay-box.add-box{display:flex;align-items:center;justify-content:center;background-color:#3333331a}.pixel-overlay-box.add-box:hover{background-color:#3333}.add-gradient{color:var(--text-secondary);pointer-events:none;opacity:.6;transition:opacity .2s}.add-box:hover .add-gradient{opacity:1}.cell-grid-overlay{transition:opacity .2s ease-in-out}.cell-grid-box{border:2px solid var(--accent-color);box-sizing:border-box;border-radius:5px;margin:2px}.zoom-control{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-sm)}.zoom-btn{background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);color:var(--text-primary)}.zoom-btn:hover{background-color:var(--bg-hover);border-color:var(--border-color)}.zoom-slider-container{position:relative;width:var(--zoom-slider-width);height:var(--button-size);display:flex;align-items:center;outline:none}.zoom-slider{width:100%;-webkit-appearance:none;appearance:none;background:transparent;outline:none;cursor:pointer;position:relative;z-index:2}.zoom-slider::-webkit-slider-track{width:100%;height:var(--spacing-sm);background:var(--bg-tertiary);border-radius:0;border:var(--border-width) solid var(--border-color)}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:var(--spacing-sm);height:calc(var(--button-size) - var(--spacing-sm));background:var(--accent-color);cursor:grab;border-radius:var(--border-radius);border:var(--border-width) solid rgba(0,0,0,.2);box-shadow:var(--shadow);margin-top:calc(-1 * var(--spacing-md))}.zoom-slider:active::-webkit-slider-thumb{cursor:grabbing;background:var(--accent-color);filter:brightness(1.1)}.zoom-slider::-moz-range-track{width:100%;height:var(--spacing-sm);background:var(--bg-tertiary);border-radius:0;border:var(--border-width) solid var(--border-color)}.zoom-slider::-moz-range-thumb{width:var(--spacing-sm);height:calc(var(--button-size) - var(--spacing-sm));background:var(--accent-color);cursor:grab;border-radius:var(--border-radius);border:var(--border-width) solid rgba(0,0,0,.2);box-shadow:var(--shadow)}.zoom-slider:active::-moz-range-thumb{cursor:grabbing;background:var(--accent-color);filter:brightness(1.1)}.zoom-notches{position:absolute;top:50%;left:0;right:0;height:var(--spacing-md);transform:translateY(-50%);pointer-events:none;z-index:1}.zoom-notch{position:absolute;width:var(--border-width-thick);height:var(--spacing-md);background-color:var(--border-color);transform:translate(-50%)}.zoom-label-bubble{position:absolute;bottom:100%;margin-bottom:var(--spacing-sm);transform:translate(-50%);background-color:var(--bg-secondary);border:var(--border-width) solid var(--accent-color);border-radius:var(--border-radius-lg);padding:var(--spacing-sm) var(--spacing-sm);font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;pointer-events:none;box-shadow:var(--shadow);z-index:3}.zoom-label-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:var(--spacing-sm) solid transparent;border-right:var(--spacing-sm) solid transparent;border-top:var(--spacing-sm) solid var(--accent-color)}.gradient-editor-modal{padding:var(--spacing-lg);max-width:100%;max-height:100%;overflow-y:auto;scrollbar-width:none}.gradient-editor-modal h3{margin:0 0 var(--spacing-lg) 0;color:var(--text-primary);font-size:20px;text-align:center}.gradient-editor-modal h4{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:14px}.gradient-preview-container{display:flex;justify-content:center;align-items:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--bg-primary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius)}.gradient-preview-canvas{display:block;border:var(--border-width-thick) solid var(--border-color);box-shadow:var(--shadow)}.gradient-controller{margin-bottom:var(--spacing-lg)}.gradient-slider-container{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--border-radius)}.gradient-slider{position:relative;height:20px;background:linear-gradient(to right,var(--overlay-light) 0%,var(--overlay-light) 100%);border:var(--border-width-thick) solid var(--border-color);border-radius:var(--border-radius);cursor:crosshair}.gradient-slider-track{position:absolute;inset:0;border-radius:var(--border-radius-sm);pointer-events:none}.color-stop{position:absolute;top:50%;transform:translate(-50%,-50%);width:var(--button-size-sm);height:var(--button-size-sm);border:var(--border-width-thicker) solid var(--text-primary);border-radius:var(--border-radius-round);cursor:grab;box-shadow:var(--shadow);transition:transform var(--transition-fast),border-color var(--transition-slow);z-index:10}.color-stop:hover{transform:translate(-50%,-50%) scale(1.15)}.color-stop:active{cursor:grabbing}.color-stop.selected{border-color:var(--accent-color);border-width:4px;transform:translate(-50%,-50%) scale(1.2);z-index:20}.color-stop-tooltip{position:absolute;bottom:32px;left:50%;transform:translate(-50%);background-color:#000000e6;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:700;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s}.color-stop:hover .color-stop-tooltip,.color-stop.selected .color-stop-tooltip{opacity:1}.color-stop-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid rgba(0,0,0,.9)}.delete-stop-btn{position:absolute;top:32px;left:50%;transform:translate(-50%);width:20px;height:20px;border:none;border-radius:50%;background-color:#ff3b30e6;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background-color .2s}.delete-stop-btn:hover{background-color:#ff3b30}.add-stop-btn{width:100%;height:var(--button-size-md);border:2px dashed var(--border-color);border-radius:var(--border-radius);background-color:transparent;color:var(--text-primary);cursor:pointer;font-weight:700;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all .2s}.add-stop-btn:hover{border-color:var(--accent-color);background-color:#34c7591a}.scale-control{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--border-radius)}.scale-control label{display:block;color:var(--text-primary);font-size:14px;margin-bottom:var(--spacing-sm)}.scale-control input[type=range]{width:100%;margin-top:var(--spacing-sm)}.scale-control input[type=range]::-webkit-slider-thumb{width:20px;height:20px;border-radius:50%;border:2px solid var(--text-primary)}.scale-control input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;border:2px solid var(--text-primary)}.palette-container{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--bg-primary);border-radius:var(--border-radius)}.palette-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-around}.palette-row{display:contents}.palette-color{width:48px;height:48px;border:3px solid transparent;border-radius:var(--border-radius);cursor:pointer;transition:all .15s;box-shadow:0 2px 4px #0003;flex-shrink:0}.palette-color:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.palette-color.active{border-color:var(--accent-color);transform:scale(1.15);box-shadow:var(--shadow)}.editor-buttons{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.editor-buttons button{flex:1;font-size:16px}.gradient-atlas-tool{width:100%;height:100%;position:relative}.gradient-atlas-center{justify-content:flex-end;align-items:center}.gradient-editor-wrapper{margin-bottom:auto;max-height:100%;overflow:hidden;display:flex;align-items:flex-start;z-index:100}.texture-settings-layout{display:flex;flex-direction:column;min-height:100%}.texture-settings-row{display:flex;gap:var(--spacing-sm)}.texture-settings-full-width{flex:1}.texture-settings-select{width:100%;height:var(--button-size)}.texture-settings-control-margin{margin-top:var(--spacing-sm)}.texture-settings-channel-row{display:flex;align-items:center;justify-content:space-between}.texture-settings-channel-label{text-transform:uppercase;width:30px;font-weight:600;font-size:var(--font-size-sm);color:var(--text-secondary)}.texture-settings-channel-select{flex:1}.texture-settings-pack-channels{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.texture-settings-separator{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:var(--border-width) solid var(--border-color)}.texture-settings-input-full{width:100%}.texture-settings-hidden-input{display:none}.texture-generator-tool{width:100%;height:100%;position:relative;background-color:var(--bg-primary);overflow:hidden}.texture-viewport-3d{width:100%;height:100%;position:relative;border-radius:var(--border-radius-lg);overflow:hidden;mask-image:linear-gradient(to right,transparent,black 40px,black calc(100% - 40px),transparent),linear-gradient(to bottom,transparent,black 40px,black calc(100% - 40px),transparent);mask-composite:intersect;-webkit-mask-image:linear-gradient(to right,transparent,black 40px,black calc(100% - 40px),transparent),linear-gradient(to bottom,transparent,black 40px,black calc(100% - 40px),transparent);-webkit-mask-composite:source-in}.texture-generator-tool .texture-generator-center{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:stretch;gap:var(--spacing-sm);min-width:0;position:relative}.texture-generator-tool .texture-generator-center>*{pointer-events:auto}.texture-generator-drop-target{width:100%;height:100%;position:relative}.texture-maps-container{padding:var(--spacing-sm);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-sm);flex:1;-ms-overflow-style:none;scrollbar-width:none}.texture-maps-container::-webkit-scrollbar{display:none}.camera-info-panel{background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-xs) var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-size-xs);font-family:monospace;-webkit-user-select:none;user-select:none;pointer-events:auto;box-shadow:var(--shadow);opacity:.8;transition:opacity .2s}.camera-info-panel:hover{opacity:1}.map-row{background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.map-header{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.map-header-row{display:flex;justify-content:center;align-items:center;position:relative;min-height:24px}.map-content{display:flex;flex-direction:column;gap:var(--spacing-sm)}.map-preview{width:100%;min-height:100px;background-color:var(--bg-secondary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;transition:border-color var(--transition-fast),background-color var(--transition-fast),min-height var(--transition-slow);position:relative}.map-preview.minimized{min-height:34px}.map-preview.droppable:not(.minimized){cursor:pointer}.map-preview.minimized img,.hidden-input{display:none}.btn-minimize-preview{position:absolute;top:var(--spacing-xs);margin:0 auto;width:var(--button-size-lg);height:var(--button-size-sm);background-color:var(--bg-tertiary);color:var(--text-secondary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-sm);transition:var(--transition-slow);padding:0;z-index:10;opacity:0}.btn-minimize-preview:hover{background-color:var(--bg-element);color:var(--text-primary)}.map-preview:hover .btn-minimize-preview,.map-preview.minimized .btn-minimize-preview{opacity:1}.map-preview.droppable:hover{border-color:var(--accent-color);background-color:var(--bg-hover)}.map-preview img{width:100%;height:auto;display:block}.map-placeholder{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center}.map-controls{flex:1;display:flex;flex-direction:column;justify-content:center;gap:var(--spacing-sm);min-width:0}.map-extra-controls{display:flex;flex-direction:column;gap:var(--spacing-sm)}.map-extra-controls .control-row{display:flex;align-items:center;gap:var(--spacing-sm)}.map-extra-controls .control-row label{font-size:var(--font-size-sm);color:var(--text-secondary);min-width:60px}.map-extra-controls .checkboxes{display:flex;gap:var(--spacing-md)}.map-extra-controls .checkboxes label{display:flex;align-items:center;gap:4px;cursor:pointer;min-width:auto}.map-slider-group{display:flex;align-items:center;gap:var(--spacing-sm);width:100%}.map-slider-group label{font-size:var(--font-size-sm);color:var(--text-secondary);width:60px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.map-slider-group input[type=range]{flex:1;min-width:0}.map-slider-controls{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.map-slider-value-input{width:45px;padding:2px 4px;font-size:var(--font-size-sm);text-align:right;color:var(--text-secondary)}.btn-reset{position:absolute;left:0;top:0;background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);color:var(--text-primary);padding:0;border-radius:var(--border-radius-sm);line-height:1;transition:background-color .2s,border-color .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.btn-reset:hover{background-color:var(--bg-hover);border-color:var(--border-color);color:var(--text-primary)}.btn-focus{position:absolute;right:0;top:0;background-color:var(--bg-tertiary);border:var(--border-width) solid var(--border-color);color:var(--text-secondary);padding:0;border-radius:var(--border-radius-sm);line-height:1;transition:all .2s;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.btn-focus:hover{background-color:var(--bg-hover);color:var(--text-primary)}.btn-focus.active{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.map-info{font-size:var(--font-size-xs);color:var(--text-secondary);text-align:center;margin-top:4px;font-family:monospace}.map-filters-group{margin-top:var(--spacing-sm);border-top:var(--border-width) solid var(--border-color);padding-top:var(--spacing-sm)}.map-filters-header{display:flex;align-items:center;cursor:pointer;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em;-webkit-user-select:none;user-select:none;opacity:.8;transition:opacity var(--transition-fast)}.map-filters-header:hover{opacity:1}.map-filters-header.open{margin-bottom:var(--spacing-sm)}.map-filters-label{margin-left:4px}.filter-item{background-color:var(--bg-primary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.filter-item.inactive{opacity:.6}.filter-select-override{width:100%}.filter-header{background-color:var(--bg-secondary);display:flex;align-items:center;padding:var(--spacing-xs);gap:var(--spacing-sm)}.filter-header-left{display:flex;align-items:center;flex:1;gap:6px;overflow:hidden}.filter-collapse-icon{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;opacity:.5}.filter-title{font-size:var(--font-size-sm);font-weight:500;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:grab}.filter-title:active{cursor:grabbing}.filter-item.dragging{opacity:.5;background:var(--overlay-bg);border-color:var(--text-secondary)}.filter-actions{display:flex;gap:2px}.btn-icon-small{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:2px;border-radius:2px;display:flex;align-items:center;justify-content:center;opacity:.7}.btn-icon-small:hover{background:var(--bg-hover);color:var(--text-primary);opacity:1}.btn-icon-small:disabled{opacity:.2;cursor:default}.btn-delete:hover{background:#ff323233;color:var(--color-delete)}.filter-content{background-color:var(--bg-primary);padding:var(--spacing-sm);border-top:var(--border-width) solid var(--border-color)}.filter-params{display:flex;flex-direction:column;gap:6px}.param-row{display:flex;flex-direction:column;gap:2px}.param-row label{font-size:var(--font-size-xs);color:var(--text-secondary);opacity:.8}.param-row-multi{display:flex;gap:8px}.param-col{flex:1;display:flex;flex-direction:column;gap:2px}.param-col label{font-size:10px;color:#fff9}.filter-params.checkboxes{flex-direction:row;gap:12px}.filter-params.checkboxes label{display:flex;align-items:center;gap:4px;font-size:11px;color:#fffc;cursor:pointer}.filter-stack{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;padding-bottom:var(--spacing-sm);border-bottom:var(--border-width) solid var(--border-color)}.filter-list{display:flex;flex-direction:column;gap:6px}.add-filter-dropdown select{width:100%;background-color:var(--bg-secondary);color:var(--text-primary)}.texture-tiler-tool{width:100%;height:100%;position:relative}.texture-tiler-center{flex:1;display:flex;justify-content:center;align-items:center;overflow:hidden;position:relative}.texture-tiler-viewport{width:100%;height:100%;overflow:hidden;display:flex;justify-content:center;align-items:center}.texture-tiler-preview{max-width:100%;max-height:100%;object-fit:contain;box-shadow:var(--shadow-lg)}.texture-tiler-placeholder{color:var(--text-secondary);font-style:italic}:root{--bg-primary: #1a1a1a;--bg-secondary: #2a2a2a;--bg-tertiary: #3a3a3a;--bg-hover: rgba(255, 255, 255, .1);--text-primary: #ffffff;--text-secondary: #cccccc;--border-color: #444444;--accent-color: #646cff;--color-delete: #ff3b30;--color-edit: #34c759;--color-reverse: #007aff;--overlay-bg: rgba(0, 0, 0, .5);--toolbar-width: 200px;--toolbar-min-width: 200px;--toolbar-max-width: 800px;--workspace-tab-height: 40px;--border-width: 1px;--border-width-thick: 2px;--border-width-thicker: 3px;--border-radius: 4px;--border-radius-sm: calc(var(--border-radius) / 2);--border-radius-lg: calc(var(--border-radius) * 2);--border-radius-round: 50%;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--font-size-xs: 10px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-lg: 16px;--button-size: 32px;--button-size-sm: 24px;--button-size-lg: 48px;--icon-size: 16px;--input-height: 16px;--input-width: 16px;--input-padding: 12px;--tab-min-width: 120px;--tab-max-width: 200px;--tab-padding: 12px;--tab-gap: 8px;--color-picker-width: 220px;--color-picker-saturation-height: 180px;--color-picker-hue-height: 14px;--zoom-slider-width: 240px;--drag-handle-width: 11px;--transition-fast: .1s ease;--transition-normal: .15s ease;--transition-slow: .2s ease;--shadow: 0 4px 12px rgba(0, 0, 0, .3)}.app{width:100vw;height:100vh;overflow:hidden;background-color:var(--bg-primary);color:var(--text-primary);position:relative}.empty-workspace-container{position:absolute;top:var(--workspace-tab-height);left:0;right:0;bottom:0;background-color:var(--bg-primary);z-index:0}::selection{background-color:var(--accent-color);color:var(--text-primary)}
