*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{height:100vh;overflow:hidden;width:100vw}.control-panel{background:#111;border-right:1px solid #1a1a1a;min-width:300px;overflow-y:auto;padding:24px;scrollbar-color:#333 #111;scrollbar-width:thin;transition:width .3s ease,padding .3s ease;width:320px}.control-panel::-webkit-scrollbar{width:8px}.control-panel::-webkit-scrollbar-track{background:#111}.control-panel::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.control-panel::-webkit-scrollbar-thumb:hover{background:#444}.panel-section{margin-bottom:32px}.panel-section h2{color:#fff;font-size:28px;font-weight:600;letter-spacing:-.5px;margin-bottom:8px}.panel-section h3{border-bottom:1px solid #1a1a1a;color:#888;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:16px;padding-bottom:12px;text-transform:uppercase}.subtitle{color:#666;font-size:13px;font-weight:400;margin-bottom:24px}.file-upload-button{align-items:center;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:12px 20px;position:relative;text-align:center;transition:all .2s ease;width:100%}.file-upload-text{transition:opacity .3s ease,width .3s ease}.file-upload-icon{display:none;flex-shrink:0;transition:opacity .3s ease}.file-upload-button:hover{background:#222;border-color:#333;transform:translateY(-1px)}.control-group{margin-bottom:20px}.control-group label{margin-bottom:10px}.control-group input[type=range]{margin:10px 0}.control-group input[type=color]{border-radius:8px;height:44px;padding:4px;width:100%}.control-group input[type=number]{border-radius:8px;font-size:14px;padding:10px 12px}.control-group input[type=checkbox]{margin-right:10px}.control-group:has(input[type=checkbox]) label{align-items:center;display:flex;flex-direction:row;margin-bottom:0}.control-group small{color:#666;display:block;font-size:11px;line-height:1.4;margin-top:6px}.controls-list{list-style:none;padding:0}.controls-list li{color:#999;font-size:13px;line-height:1.6;margin-bottom:12px}.controls-list strong{color:#ccc;font-weight:600}.file-list-container{margin-top:16px;overflow-x:hidden}.file-list{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-x:hidden;overflow-y:auto;scrollbar-color:#333 #111;scrollbar-width:thin}.file-list::-webkit-scrollbar{width:6px}.file-list::-webkit-scrollbar-track{background:#111}.file-list::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.file-list::-webkit-scrollbar-thumb:hover{background:#444}.file-list-item{align-items:center;background:#0000;border:none;border-radius:0;box-sizing:border-box;cursor:pointer;display:flex;font-size:13px;gap:10px;min-height:44px;padding:10px 0;transition:all .2s ease;width:100%}.file-list-item.active,.file-list-item:hover{background:#0000;border:none;box-shadow:none}.file-list-item.active .file-list-name{font-weight:600}.file-list-icon{align-items:center;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.file-list-icon svg{stroke-width:2;color:#ccc}.file-list-item.active .file-list-icon svg{color:#fff}.file-list-thumbnail{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;flex-shrink:0;height:32px;object-fit:cover;width:32px}.file-list-name{color:#ccc;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-list-item.active .file-list-name{color:#fff;font-weight:500}@media (max-width:1199px){.control-panel{min-width:80px;overflow-x:clip;overflow-y:auto;padding:16px 8px;width:80px}.file-upload-button,.panel-section{overflow:visible;position:relative}.file-upload-button{justify-content:center;padding:12px}.file-upload-text{display:none}.file-upload-icon{display:block}.file-list-container{margin-top:12px}.file-list{max-height:300px;overflow-y:auto}.file-list-item{justify-content:center;min-height:48px;overflow:visible;padding:8px 0;position:relative}.file-list-name{display:none}.file-list-icon,.file-list-thumbnail{height:40px;width:40px}.file-list-thumbnail{border-radius:6px}.panel-section-controls{display:none}.file-list-item:after{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;box-shadow:0 4px 12px #0000004d;color:#fff;content:attr(title);font-size:12px;left:calc(100% + 12px);padding:8px 12px;white-space:nowrap;z-index:1000}.file-list-item:after,.file-list-item:before{opacity:0;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:opacity .2s ease}.file-list-item:before{border-bottom:6px solid #0000;border-right:6px solid #1a1a1a;border-top:6px solid #0000;content:"";height:0;left:calc(100% + 4px);width:0;z-index:1001}.file-list-item:hover:after,.file-list-item:hover:before{opacity:1}.file-upload-button:after{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;box-shadow:0 4px 12px #0000004d;color:#fff;content:attr(title);font-size:12px;left:calc(100% + 12px);padding:8px 12px;white-space:nowrap;z-index:1000}.file-upload-button:after,.file-upload-button:before{opacity:0;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:opacity .2s ease}.file-upload-button:before{border-bottom:6px solid #0000;border-right:6px solid #1a1a1a;border-top:6px solid #0000;content:"";height:0;left:calc(100% + 4px);width:0;z-index:1001}.file-upload-button:hover:after,.file-upload-button:hover:before{opacity:1}}.export-panel{background:#111;border-left:1px solid #1a1a1a;min-width:300px;overflow-y:auto;padding:16px;scrollbar-color:#333 #111;scrollbar-width:thin;width:320px}.export-panel::-webkit-scrollbar{width:8px}.export-panel::-webkit-scrollbar-track{background:#111}.export-panel::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.export-panel::-webkit-scrollbar-thumb:hover{background:#444}.export-panel .panel-section{margin-bottom:20px}.export-panel .panel-section:last-child{margin-bottom:0}.export-panel .panel-section h2{color:#fff;font-size:28px;font-weight:600;letter-spacing:-.5px;margin-bottom:8px}.export-panel .panel-section h3{border-bottom:1px solid #1a1a1a;color:#888;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;margin-top:0;padding-bottom:8px;text-transform:uppercase}.export-panel .subtitle{color:#666;font-size:13px;font-weight:400;margin-bottom:24px}.export-button{background:#fff;border:none;border-radius:6px;color:#0a0a0a;cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.5px;padding:10px 16px;text-transform:uppercase;transition:all .2s ease;width:100%}.export-button:hover:not(:disabled){background:#f0f0f0;box-shadow:0 4px 12px #ffffff1a;transform:translateY(-1px)}.export-button:disabled{color:#444;cursor:not-allowed}.export-button:disabled,.save-button{background:#1a1a1a;border:1px solid #2a2a2a}.save-button{border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.5px;margin-top:10px;padding:10px 16px;text-transform:uppercase;transition:all .2s ease;width:100%}.save-button:hover{background:#222;border-color:#333;transform:translateY(-1px)}.svg-preview-container{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;margin-top:0;padding:12px}.svg-preview-container h3{color:#ccc;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;margin-top:0;text-transform:uppercase}.svg-metadata{align-items:center;color:#666;display:flex;font-size:10px;font-weight:400;gap:6px;letter-spacing:.3px;margin-top:8px}.svg-metadata span{opacity:.7}.svg-preview{background:#0000;border-radius:4px;max-height:300px;overflow:auto;padding:8px;scrollbar-color:#333 #1a1a1a;scrollbar-width:thin}.svg-preview::-webkit-scrollbar{height:8px;width:8px}.svg-preview::-webkit-scrollbar-track{background:#1a1a1a}.svg-preview::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.svg-preview svg{display:block;height:auto;max-width:100%}.hint{color:#666;font-size:11px;font-style:italic;line-height:1.4;margin-top:8px}.control-group{margin-bottom:12px}.control-group:last-child{margin-bottom:0}.control-group label{color:#ccc;display:block;font-size:13px;font-weight:500;margin-bottom:6px}.control-row{align-items:center;display:flex;gap:12px;margin-bottom:4px}.control-label{color:#888;flex-shrink:0;font-size:11px;font-weight:400;min-width:80px}.control-group input[type=range]{-webkit-appearance:none;appearance:none;background:#1a1a1a;border-radius:3px;height:6px;margin:6px 0;outline:none;width:100%}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;border-radius:50%;cursor:pointer;height:16px;-webkit-transition:all .2s;transition:all .2s;width:16px}.control-group input[type=range]::-webkit-slider-thumb:hover{background:#f0f0f0;transform:scale(1.1)}.control-group input[type=range]::-moz-range-thumb{background:#fff;border:none;border-radius:50%;cursor:pointer;height:16px;-moz-transition:all .2s;transition:all .2s;width:16px}.control-group input[type=range]::-moz-range-thumb:hover{background:#f0f0f0;transform:scale(1.1)}.control-group input[type=color]{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;cursor:pointer;flex-shrink:0;height:36px;padding:2px;width:50px}.control-row input[type=color]{width:50px}.control-group input[type=number]{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;color:#fff;font-size:13px;padding:8px 10px;transition:all .2s;width:100%}.control-group input[type=number]:focus{background:#222;border-color:#444;outline:none}.control-group select{-webkit-appearance:none;appearance:none;background:#1a1a1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23fff' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid #2a2a2a;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:8px 32px 8px 10px;transition:all .2s;width:100%}.control-row select{flex:1 1}.control-group select:focus{background-color:#222;border-color:#444;outline:none}.control-group select:hover{border-color:#333}.export-select{margin-top:6px}.control-group input[type=checkbox]{accent-color:#fff;cursor:pointer;flex-shrink:0;height:18px;width:18px}.control-row input[type=checkbox]{margin:0}.value-display{color:#fff;display:inline-block;font-size:13px;font-weight:500;margin-left:10px}.export-tabs{border-bottom:1px solid #1a1a1a;display:flex;gap:8px;margin-bottom:20px;padding-bottom:0}.export-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:-1px;padding:10px 16px;text-transform:uppercase;transition:all .2s ease}.export-tab:hover{color:#999}.export-tab.active{border-bottom-color:#fff;color:#fff}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.section-header h3{flex:1 1;margin-bottom:0}.add-button{align-items:center;background:#0000;border:1px solid #2a2a2a;border-radius:4px;color:#ccc;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:20px}.add-button:hover{background:#1a1a1a;border-color:#444;color:#fff}.effect-item{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;margin-top:8px;padding:8px}.effect-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.effect-item-label{color:#ccc;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.remove-button{align-items:center;background:#0000;border:1px solid #2a2a2a;border-radius:3px;color:#666;cursor:pointer;display:flex;font-size:14px;height:18px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:18px}.remove-button:hover{background:#222;border-color:#444;color:#fff}.dithering-settings{border-top:none;margin-top:0;padding-top:0}.color-palette-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));margin-top:8px}.color-palette-item{align-items:center;display:flex;justify-content:center}.color-palette-picker{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;cursor:pointer;height:40px;padding:2px;transition:all .2s;width:100%}.color-palette-picker:hover{border-color:#444;transform:scale(1.05)}.effect-add-item{align-items:center;cursor:pointer;display:flex;justify-content:space-between;margin-top:8px;padding:10px 0;transition:all .2s ease}.effect-add-item:hover{opacity:.8}.effect-add-label{color:#ccc;font-size:13px;font-weight:400}.effect-add-icon{color:#999;flex-shrink:0;font-size:16px;line-height:1}.export-settings-content{margin-top:0}.draggable-input-wrapper{margin-bottom:12px}.draggable-input-row{align-items:center;display:flex;gap:12px;margin-bottom:4px}.draggable-input-label{color:#888;flex-shrink:0;font-size:11px;font-weight:400;min-width:80px}.draggable-input-container{align-items:center;display:flex;flex:1 1;position:relative}.draggable-input{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;color:#fff;cursor:ew-resize;font-family:inherit;font-size:13px;padding:6px 8px;transition:all .2s;width:100%}.draggable-input::placeholder{color:#666;opacity:1}.draggable-input:hover:not(:focus){border-color:#333}.draggable-input:focus{background:#222;border-color:#444;cursor:text;outline:none}.draggable-input.dragging{cursor:ew-resize;-webkit-user-select:none;user-select:none}.input-unit{color:#666;font-size:12px;margin-left:4px;pointer-events:none;position:absolute;right:8px}.switch{align-items:center;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;cursor:pointer;display:inline-flex;height:24px;outline:none;padding:0;position:relative;transition:all .2s ease;width:44px}.switch:hover{border-color:#333}.switch:focus-visible{outline:2px solid #fff;outline-offset:2px}.switch-checked{background:#fff;border-color:#fff}.switch-thumb{background:#666;border-radius:50%;display:block;height:20px;transform:translateX(2px);transition:all .2s ease;width:20px}.switch-checked .switch-thumb{background:#0a0a0a;transform:translateX(20px)}.app{display:flex;height:100vh;width:100vw}.app,.canvas-container{background:#0a0a0a;overflow:hidden}.canvas-container{flex:1 1;min-width:0;position:relative}.canvas-container canvas{display:block;height:100%;width:100%}.view-mode-toggle{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#111111e6;border:1px solid #2a2a2a;border-radius:8px;display:flex;gap:8px;padding:4px;position:absolute;right:16px;top:16px;z-index:100}.toggle-button{align-items:center;background:#0000;border:none;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;letter-spacing:.5px;padding:8px 12px;text-transform:uppercase;transition:all .2s ease}.toggle-button:hover:not(:disabled){background:#ffffff0d;color:#999}.toggle-button.active{background:#ffffff1a;color:#fff}.toggle-button:disabled{cursor:not-allowed;opacity:.4}.toggle-button svg{height:16px;width:16px}.svg-preview-view{background:#0a0a0a;overflow:hidden}.svg-preview-content,.svg-preview-view{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.svg-preview-content{cursor:grab}.svg-preview-content:active{cursor:grabbing}.svg-preview-inner{align-items:center;display:flex;height:-webkit-fit-content;height:fit-content;justify-content:center;margin:auto;min-height:0;min-width:0;position:relative;width:-webkit-fit-content;width:fit-content}.svg-preview-inner svg{background:#0000}.svg-preview-inner img,.svg-preview-inner svg{display:block;height:auto;max-height:none;max-width:none;width:auto}.svg-preview-empty{color:#666;font-size:14px;height:100%;width:100%}.drag-overlay,.svg-preview-empty{align-items:center;display:flex;justify-content:center}.drag-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0a0ab3;bottom:0;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:9999}.drag-overlay-content{background:#111111e6;border:2px dashed #444;border-radius:12px;padding:32px;text-align:center}.upload-icon{color:#888;height:48px;margin:0 auto 16px;width:48px}.drag-overlay-content h2{color:#ccc;font-size:18px;font-weight:500;letter-spacing:0;margin:0 0 8px}.drag-overlay-content p{color:#666;font-size:14px;font-weight:400;margin:0}.loading-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0a0acc;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1000}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff1a;border-radius:50%;border-top-color:#888;height:48px;margin-bottom:16px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay p{color:#888;font-size:14px;font-weight:400;margin:0}.sidebar-toggle{align-items:center;background:#0000;border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;height:48px;justify-content:center;position:fixed;top:50%;transform:translateY(-50%);transition:all .2s ease;width:48px;z-index:1000}.sidebar-toggle:hover{color:#ccc}.sidebar-toggle-left{left:16px}.sidebar-toggle-right{right:16px}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0a0ab3;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:2000}.sidebar-overlay.active{display:block}.sidebar-content{background:#111;bottom:0;box-shadow:2px 0 20px #00000080;max-width:85vw;overflow-y:auto;position:fixed;top:0;transition:width .3s ease;width:320px;z-index:2001}.sidebar-content-left{border-right:1px solid #1a1a1a;left:0}.sidebar-content-right{border-left:1px solid #1a1a1a;right:0}@media (max-width:1199px){.sidebar-overlay,.sidebar-toggle{display:none!important}.sidebar-content{width:80px}}
/*# sourceMappingURL=main.d7f8f97e.css.map*/