:root{--bg-color: #1e1e1e;--sidebar-bg: #2c2c2c;--toolbar-bg: #252525;--border-color: #383838;--text-color: #ffffff;--text-secondary: #b3b3b3;--accent-color: #0d99ff;--accent-hover: #0b84db;--input-bg: #3b3b3b;--danger-color: #ff4d4d;--success-color: #2ecc71;--font-family: "Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-color);color:var(--text-color);height:100vh;height:100dvh;display:flex;overflow:hidden;overscroll-behavior:none;-webkit-text-size-adjust:100%;touch-action:manipulation}#app{display:flex;width:100%;height:100%;position:relative}.sidebar{width:320px;min-width:240px;max-width:600px;background-color:var(--sidebar-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:24px;z-index:10;overflow-y:auto;height:100%;flex-shrink:0;transition:transform .25s ease;will-change:transform;-webkit-overflow-scrolling:touch}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:32px}.sidebar-header-actions{display:flex;align-items:center;gap:8px}.settings-menu-group{position:relative}.settings-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:20;min-width:200px;max-width:calc(100vw - 16px);padding:6px;background-color:var(--toolbar-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 6px 24px #0006;display:flex;flex-direction:column;gap:4px}html[dir=rtl] .settings-menu{right:auto;left:0}.settings-menu.hidden{display:none}.settings-menu-row{display:flex;flex-direction:column;gap:4px;padding:6px 8px}.settings-menu-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600}.lang-list{display:flex;flex-direction:column;max-height:240px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px;background-color:var(--input-bg);padding:2px}.lang-item{appearance:none;background:transparent;color:var(--text-color);border:1px solid transparent;border-radius:4px;padding:6px 8px;display:flex;align-items:center;gap:8px;cursor:pointer;font-family:inherit;font-size:13px;text-align:left;transition:background .15s,border-color .15s}[dir=rtl] .lang-item{text-align:right}.lang-item:hover{background-color:#ffffff0f}.lang-item:focus-visible{outline:none;border-color:var(--accent-color)}.lang-item[aria-selected=true]{background-color:#0d99ff29;color:var(--accent-color);font-weight:600}.lang-flag{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:20px}.lang-flag>svg{width:20px;height:auto;display:block;border-radius:2px}.lang-name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-menu-item{appearance:none;background:transparent;color:var(--text-color);border:1px solid transparent;border-radius:6px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;font-family:inherit;font-size:13px;text-align:left;transition:background .15s,border-color .15s}[dir=rtl] .settings-menu-item{text-align:right}.settings-menu-item:hover{background-color:#ffffff0f}.settings-menu-item:focus-visible{outline:none;background-color:#0d99ff1f;border-color:var(--accent-color)}.settings-menu-hint{font-size:11px;color:var(--text-secondary);font-family:monospace;border:1px solid var(--border-color);border-radius:4px;padding:0 6px;line-height:1.6}.settings-menu-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text-color);transition:background .15s,border-color .15s}[dir=rtl] .settings-menu-toggle{text-align:right}.settings-menu-toggle:hover{background-color:#ffffff0f}.settings-menu-toggle:focus-within{background-color:#0d99ff1f;border-color:var(--accent-color)}.settings-menu-toggle input[type=checkbox]{flex:0 0 auto;width:14px;height:14px;accent-color:var(--accent-color);cursor:pointer}.sidebar-header .logo{margin-bottom:0}.sidebar-close{display:none;background:transparent;border:1px solid var(--border-color);color:var(--text-color);width:36px;height:36px;border-radius:8px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s}.sidebar-close:hover{background-color:#ffffff0f}.sidebar-close>svg{width:14px;height:14px;display:block}.sidebar-backdrop{display:none;position:fixed;inset:0;background-color:#00000080;z-index:9;opacity:0;pointer-events:none;transition:opacity .2s ease}.menu-toggle{display:none!important}.toolbar-menu-group{display:none}.sidebar-resizer{width:4px;background-color:transparent;cursor:col-resize;z-index:20;transition:background-color .2s;flex-shrink:0}.sidebar-resizer:hover,.sidebar-resizer.active{background-color:var(--accent-color)}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#444;border-radius:10px}.sidebar::-webkit-scrollbar-thumb:hover{background:#555}.logo{font-weight:700;font-size:18px;margin-bottom:32px;display:flex;align-items:center;gap:8px}.logo-icon{width:24px;height:24px;display:inline-flex;flex-shrink:0}.logo-icon>svg{width:24px;height:24px;display:block}.section{margin-bottom:32px}.section-title{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:16px;font-weight:600}.control-group{display:flex;flex-direction:column;gap:12px}.control{display:flex;flex-direction:column;gap:6px}.control-row{flex-direction:row;align-items:center;gap:8px}.dim-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;column-gap:6px;row-gap:12px}.dim-controls>.control:nth-of-type(1){grid-column:1;grid-row:1}.dim-controls>.control:nth-of-type(2){grid-column:1;grid-row:2}.aspect-link{grid-column:2;grid-row:1 / 3;align-self:stretch;position:relative;width:32px;margin-left:2px;padding:0;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;transition:color .15s,background-color .15s,border-color .15s;--bracket-top: 40px;--bracket-bottom: 18px}.aspect-link:hover{color:var(--text-color);background-color:#ffffff0a}.aspect-link:focus-visible{outline:none;border-color:var(--accent-color);color:var(--text-color)}.aspect-link[aria-pressed=true]{color:var(--accent-color)}.aspect-bracket{position:absolute;left:-2px;width:11px;top:var(--bracket-top);bottom:var(--bracket-bottom);border:1px solid currentColor;border-left:none;border-top-right-radius:4px;border-bottom-right-radius:4px;opacity:.55;pointer-events:none;transition:opacity .15s}.aspect-link[aria-pressed=false] .aspect-bracket{opacity:.18;border-style:dashed}.aspect-icon{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;background-color:var(--sidebar-bg);padding:3px 4px}.aspect-icon>svg{width:16px;height:16px;display:block}.control-label-row{display:flex;justify-content:space-between;align-items:baseline}.control-value{font-size:13px;color:var(--text-color);font-variant-numeric:tabular-nums;font-weight:600}.control-note{font-size:11px;color:var(--text-secondary);min-height:14px}label{font-size:13px;color:var(--text-secondary)}input[type=number]{background-color:var(--input-bg);border:1px solid var(--border-color);color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;outline:none}input[type=range]{width:100%;padding:0;margin:0;background:transparent;outline:none}input[type=number]:focus{border-color:var(--accent-color)}input[type=text]{background-color:var(--input-bg);border:1px solid var(--border-color);color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;outline:none;width:100%}input[type=text]:focus{border-color:var(--accent-color)}.btn{background-color:var(--accent-color);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s,transform .1s;text-align:center}.btn:hover:not(:disabled){background-color:var(--accent-hover)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background-color:transparent;border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:#ffffff0d}.btn-small{padding:6px 12px;font-size:13px;width:100%}.btn-danger{background-color:var(--danger-color)}.btn-danger:hover:not(:disabled){background-color:#e04141}.btn:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.main-content{flex-grow:1;display:flex;flex-direction:column;position:relative;min-width:0}.top-bar{min-height:48px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;padding:0 12px;background-color:var(--toolbar-bg);gap:4px;flex-wrap:wrap;position:relative;z-index:5;flex-shrink:0;min-width:0;max-width:100%}.toolbar-group{display:flex;align-items:center;gap:2px;min-width:0}.toolbar-sep{width:1px;align-self:stretch;background-color:var(--border-color);margin:8px 4px}.toolbar-push{flex-grow:1}.tb-btn{background-color:transparent;color:var(--text-color);border:1px solid transparent;padding:6px 10px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;display:inline-flex;align-items:center;gap:6px;line-height:1;min-height:32px;font-family:inherit}.tb-btn:hover:not(:disabled){background-color:#ffffff0f}.tb-btn:disabled{opacity:.35;cursor:not-allowed}.tb-btn.active{background-color:#0d99ff33;border-color:var(--accent-color);color:var(--accent-color)}.tb-icon-btn{min-width:32px;justify-content:center;font-size:15px}.tb-icon{display:inline-flex;align-items:center;justify-content:center}.tb-label{font-size:13px}.tb-icon>svg{width:15px;height:15px;display:block}.tb-caret>svg{width:10px;height:10px;display:block}.tb-icon-btn>svg,.tb-btn.tb-tool>svg{width:18px;height:18px;display:block}input.zoom-label{width:58px;text-align:center;color:var(--text-secondary);font-variant-numeric:tabular-nums;font-family:inherit;font-size:13px;background-color:transparent;border:1px solid transparent;border-radius:4px;padding:4px 6px;outline:none;cursor:text;transition:background-color .15s,border-color .15s,color .15s;flex:0 0 auto}input.zoom-label:hover{border-color:var(--border-color);background-color:#ffffff0a;color:var(--text-color)}input.zoom-label:focus{border-color:var(--accent-color);background-color:#0d99ff1a;color:var(--text-color)}.tb-toggle{position:relative}.tb-toggle[aria-pressed=true]{background-color:#ffffff14;color:var(--text-color)}.tb-toggle[aria-pressed=true]:after{content:"";position:absolute;left:6px;right:6px;bottom:3px;height:2px;background-color:var(--accent-color);border-radius:1px}.tb-btn.btn-secondary{border-color:var(--border-color)}.export-modal-backdrop{position:fixed;inset:0;background-color:#0009;display:flex;align-items:stretch;justify-content:stretch;z-index:600;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease-out}.export-modal-backdrop.hidden{display:none}.export-modal{position:relative;background-color:var(--bg-color);border:1px solid var(--border-color);display:flex;flex-direction:column;width:calc(100vw - 32px);height:calc(100vh - 32px);height:calc(100dvh - 32px);margin:16px;border-radius:12px;box-shadow:0 20px 60px #00000080;overflow:hidden;animation:modalIn .2s ease-out}.export-modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-color);background-color:var(--toolbar-bg);flex-shrink:0}.export-modal-header h2{font-size:16px;font-weight:600;margin:0}.export-modal-close{background:transparent;border:1px solid var(--border-color);color:var(--text-color);width:32px;height:32px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.export-modal-close>svg{width:14px;height:14px;display:block}.export-modal-close:hover{background-color:#ffffff0f}.export-modal-body{flex:1 1 auto;display:grid;grid-template-columns:220px 1fr 320px;min-height:0}.export-format-list{border-right:1px solid var(--border-color);background-color:var(--toolbar-bg);padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.export-format-item{appearance:none;background:transparent;border:1px solid transparent;color:var(--text-color);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;cursor:pointer;text-align:left;font-family:inherit;transition:background .15s,border-color .15s}.export-format-item:hover{background-color:#ffffff0d}.export-format-item.active{background-color:#0d99ff29;border-color:var(--accent-color)}.export-format-label{font-size:13px;font-weight:600;line-height:1.2}.export-format-desc{font-size:11px;color:var(--text-secondary);line-height:1.3}.export-preview{display:flex;flex-direction:column;min-width:0;min-height:0}.export-preview-toolbar{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 8px;border-bottom:1px solid var(--border-color);background-color:var(--toolbar-bg);flex-shrink:0}.export-preview-scroller{flex:1 1 auto;min-width:0;min-height:0;overflow:auto;padding:16px;display:flex;align-items:safe center;justify-content:safe center;background-image:linear-gradient(45deg,#181818 25%,transparent 25%),linear-gradient(-45deg,#181818 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#181818 75%),linear-gradient(-45deg,transparent 75%,#181818 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;cursor:grab;touch-action:none}.export-preview-scroller.panning{cursor:grabbing}#exportPreviewCanvas{display:block;background-color:#fff;image-rendering:auto;box-shadow:0 4px 16px #0006;flex-shrink:0;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.export-preview-info{border-top:1px solid var(--border-color);padding:8px 16px;font-size:12px;color:var(--text-secondary);background-color:var(--toolbar-bg);font-variant-numeric:tabular-nums;flex-shrink:0}.export-config{border-left:1px solid var(--border-color);background-color:var(--sidebar-bg);padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.export-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-color);background-color:var(--toolbar-bg);flex-shrink:0}.export-modal-footer .btn{padding:8px 18px;font-size:13px}.export-field{display:flex;flex-direction:column;gap:6px}.export-field.hidden{display:none}.export-field-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600}.export-field-row{display:flex;gap:8px;align-items:center}.export-range{display:flex;align-items:center;gap:8px}.export-range>input[type=range]{flex:1 1 auto;min-width:0}.export-range>input[type=number].export-num{flex:0 0 auto;width:80px;padding:6px 8px;font-size:13px}.export-select{background-color:var(--input-bg);border:1px solid var(--border-color);color:var(--text-color);padding:8px 10px;border-radius:6px;font-size:13px;font-family:inherit;outline:none;cursor:pointer}.export-select:focus{border-color:var(--accent-color)}.export-text{background-color:var(--input-bg);border:1px solid var(--border-color);color:var(--text-color);padding:8px 10px;border-radius:6px;font-size:13px;font-family:inherit;outline:none;width:100%}.export-text:focus{border-color:var(--accent-color)}.export-color{-webkit-appearance:none;appearance:none;background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;padding:2px;width:44px;height:32px;cursor:pointer;flex-shrink:0}.export-color::-webkit-color-swatch-wrapper{padding:0}.export-color::-webkit-color-swatch{border:none;border-radius:4px}.export-color::-moz-color-swatch{border:none;border-radius:4px}.export-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-color);-webkit-user-select:none;user-select:none}.export-check input{width:14px;height:14px;accent-color:var(--accent-color);cursor:pointer}.export-segmented{display:flex;border:1px solid var(--border-color);border-radius:6px;overflow:hidden;background-color:var(--input-bg)}.export-segmented-btn{flex:1;padding:8px 10px;background:transparent;border:none;color:var(--text-color);font-family:inherit;font-size:13px;cursor:pointer;transition:background .15s,color .15s}.export-segmented-btn+.export-segmented-btn{border-left:1px solid var(--border-color)}.export-segmented-btn:hover{background-color:#ffffff0d}.export-segmented-btn.active{background-color:#0d99ff33;color:var(--accent-color);font-weight:600}.export-palette-picker{display:flex;flex-wrap:wrap;gap:4px;padding:6px;background-color:#00000026;border-radius:6px;max-height:140px;overflow-y:auto}.export-palette-swatch{width:22px;height:22px;border-radius:3px;border:2px solid transparent;padding:0;cursor:pointer;transition:transform .1s,border-color .1s}.export-palette-swatch:hover{transform:scale(1.1)}.export-palette-swatch.active{border-color:var(--accent-color);box-shadow:0 0 8px #0d99ff80}@media(max-width:1024px){.export-modal-body{grid-template-columns:180px 1fr 280px}}@media(max-width:760px){.export-modal{width:100vw;height:100vh;height:100dvh;margin:0;border-radius:0;border:none}.export-modal-body{grid-template-columns:1fr;grid-template-rows:auto minmax(220px,1fr) auto}.export-format-list{border-right:none;border-bottom:1px solid var(--border-color);flex-direction:row;overflow-x:auto}.export-format-item{flex:0 0 auto;min-width:140px}.export-config{border-left:none;border-top:1px solid var(--border-color);max-height:50vh}}.viewport{flex-grow:1;display:flex;align-items:safe center;justify-content:safe center;padding:40px;background-image:linear-gradient(45deg,#181818 25%,transparent 25%),linear-gradient(-45deg,#181818 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#181818 75%),linear-gradient(-45deg,transparent 75%,#181818 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;overflow:auto;position:relative;min-width:0;min-height:0}.canvas-sizer{position:relative;flex-shrink:0;box-shadow:0 10px 30px #00000080}.canvas-wrap{position:absolute;top:0;left:0;line-height:0;transform-origin:0 0;touch-action:none}canvas{display:block;background-color:#fff;image-rendering:pixelated;cursor:crosshair}.canvas-wrap.scheme-mode canvas{image-rendering:auto}.overlay-canvas{position:absolute;top:0;left:0;pointer-events:none;image-rendering:pixelated;background:transparent!important;box-shadow:none!important}.canvas-wrap.tool-eyedropper canvas{cursor:crosshair}.canvas-wrap.tool-brush canvas{cursor:crosshair}.canvas-wrap.tool-fill canvas{cursor:cell}.canvas-wrap.tool-line canvas{cursor:crosshair}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:56px 40px;border:2px dashed var(--border-color);border-radius:16px;cursor:pointer;transition:border-color .2s,background-color .2s,color .2s;color:var(--text-secondary);max-width:460px;text-align:center;background-color:#00000026}.empty-state:hover,.empty-state.highlight{border-color:var(--accent-color);background-color:#0d99ff14;color:var(--text-color)}.empty-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);opacity:.8}.empty-icon>svg{width:56px;height:56px;display:block}.empty-state-text{color:inherit;font-size:15px;font-weight:500}.empty-state-hint{color:var(--text-secondary);font-size:12px;opacity:.75}.coord-tooltip{position:fixed;pointer-events:none;background-color:#141414f2;border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;font-size:11px;font-family:Courier New,monospace;color:var(--text-color);z-index:100;white-space:nowrap;display:flex;align-items:center;gap:6px}.coord-tooltip .coord-swatch{width:10px;height:10px;border-radius:2px;border:1px solid rgba(255,255,255,.2)}.drop-indicator{position:absolute;inset:20px;border:3px dashed var(--accent-color);border-radius:12px;background-color:#0d99ff1a;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:var(--accent-color);pointer-events:none;z-index:50}.progress-overlay{position:absolute;inset:0;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.progress-box{background-color:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:12px;padding:24px 36px;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 10px 40px #0006;min-width:280px}.progress-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-label{font-size:13px;color:var(--text-color)}progress{width:100%;height:6px;appearance:none;border:none;background-color:var(--border-color);border-radius:3px;overflow:hidden}progress::-webkit-progress-bar{background-color:var(--border-color);border-radius:3px}progress::-webkit-progress-value{background-color:var(--accent-color);border-radius:3px;transition:width .1s linear}progress::-moz-progress-bar{background-color:var(--accent-color);border-radius:3px}.upload-zone{border:2px dashed var(--border-color);border-radius:12px;padding:32px 20px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;transition:border-color .2s}.upload-zone:hover,.upload-zone.highlight{border-color:var(--accent-color);background-color:#0d99ff0d}.upload-icon{font-size:32px}#imageInput{display:none}.hidden{display:none!important}.palette-container{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.color-swatch{width:36px;height:36px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:11px;font-weight:700;-webkit-user-select:none;user-select:none;position:relative;line-height:1;padding:0;font-family:inherit}.color-swatch:hover{transform:scale(1.1)}.color-swatch:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.color-swatch.active{border-color:var(--accent-color);transform:scale(1.1);box-shadow:0 0 10px #0d99ff80;animation:swatchPulse 1s ease-in-out infinite}@keyframes swatchPulse{0%,to{box-shadow:0 0 10px #0d99ff80}50%{box-shadow:0 0 18px #0d99ffe6}}.swatch-count{font-size:8px;font-weight:500;opacity:.8;margin-top:1px}.color-edit-panel{margin-top:12px;background-color:#ffffff08;padding:12px;border-radius:8px;border:1px solid var(--border-color);display:flex;flex-direction:column;gap:10px}.color-edit-title{font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px}.color-edit-title .preview-dot{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.15)}.color-edit-actions{display:flex;gap:8px}.color-edit-actions .btn{flex:1;padding:6px 8px;font-size:12px}.palette-picker-header{display:flex;justify-content:space-between;align-items:center;margin-top:6px;margin-bottom:4px}.palette-picker-title{font-size:11px;color:var(--text-secondary)}.palette-picker-change{background:none;border:none;color:var(--accent-color);font-size:10px;cursor:pointer;padding:0;font-family:inherit}.palette-picker-list{display:flex;flex-wrap:wrap;gap:4px;max-height:80px;overflow-y:auto}.palette-picker-list button{background-color:transparent;border:1px solid var(--border-color);color:var(--text-color);font-size:10px;padding:3px 8px;border-radius:4px;cursor:pointer;font-family:inherit}.palette-picker-list button:hover{background-color:#ffffff0d}.mini-palette-picker{display:flex;gap:4px;flex-wrap:wrap;padding:6px;max-height:100px;overflow-y:auto;background-color:#0000001a;border-radius:4px}.mini-swatch{width:18px;height:18px;border-radius:3px;cursor:pointer;border:1px solid rgba(255,255,255,.1);transition:transform .1s}.mini-swatch:hover{transform:scale(1.2);border-color:var(--accent-color);z-index:1}.deselect-btn{width:100%;margin-top:4px;font-size:11px;opacity:.7;padding:6px}.saved-palettes-list{display:flex;flex-direction:column;gap:12px}.palette-item{background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:10px;cursor:pointer;transition:border-color .2s,transform .1s;display:flex;flex-direction:column;gap:8px}.palette-item:hover{border-color:#555;transform:translateY(-2px)}.palette-item-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.palette-item-name{font-size:13px;font-weight:600;color:var(--text-color);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-item-actions{display:flex;gap:2px}.palette-item-action{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:inline-flex;align-items:center;justify-content:center;opacity:.5;transition:opacity .2s,color .2s;border-radius:4px}.palette-item-action>svg{width:14px;height:14px;display:block}.palette-item-action:hover{opacity:1;background-color:#ffffff0d}.palette-item-action.danger:hover{color:var(--danger-color)}.palette-preview{display:flex;gap:3px;flex-wrap:wrap}.preview-swatch{width:14px;height:14px;border-radius:2px}.empty-msg{font-size:12px;color:var(--text-secondary);font-style:italic;text-align:center;padding:12px}.toast-container{position:fixed;top:16px;right:16px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background-color:var(--sidebar-bg);border:1px solid var(--border-color);border-left:3px solid var(--accent-color);border-radius:6px;padding:10px 16px;font-size:13px;color:var(--text-color);box-shadow:0 4px 16px #0006;animation:toastIn .25s ease-out;pointer-events:auto;max-width:360px}.toast-success{border-left-color:var(--success-color)}.toast-error{border-left-color:var(--danger-color)}.toast-warning{border-left-color:#f39c12}.toast-hide{animation:toastOut .25s ease-in forwards}@keyframes toastIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(16px)}}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:12px;min-width:320px;max-width:520px;max-height:80vh;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;animation:modalIn .2s ease-out}@keyframes modalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border-color);font-size:15px;font-weight:600}.modal-body{padding:16px 20px;font-size:13px;color:var(--text-secondary);overflow-y:auto;display:flex;flex-direction:column;gap:12px}.modal-body p{color:var(--text-color);line-height:1.5}.modal-footer{padding:12px 20px;border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end}.modal-footer .btn{padding:8px 16px;font-size:13px}.kbd-grid{display:grid;grid-template-columns:fit-content(55%) 1fr;gap:6px 20px;font-size:13px;color:var(--text-color)}.kbd-grid dt{display:flex;gap:4px;flex-wrap:wrap}.kbd-grid .kbd-chunk{display:inline-flex;align-items:center;gap:4px}.kbd-grid .kbd-break{flex-basis:100%;height:0;width:0}.kbd{display:inline-block;background-color:var(--input-bg);border:1px solid var(--border-color);border-radius:4px;padding:4px 6px 1px;font-family:Courier New,monospace;font-size:11px;color:var(--text-color);line-height:1}.kbd-grid dd{color:var(--text-secondary);align-self:center}.kbd-section-title{grid-column:1 / -1;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600;margin-top:8px;padding-bottom:4px;border-bottom:1px solid var(--border-color)}html[dir=rtl] .sidebar{border-right:none;border-left:1px solid var(--border-color)}html[dir=rtl] .canvas-wrap,html[dir=rtl] .canvas-sizer,html[dir=rtl] #canvas,html[dir=rtl] .overlay-canvas{direction:ltr}.kbd-section-title:first-child{margin-top:0}@media(pointer:coarse){.tb-btn{min-height:40px;padding:8px 12px}.tb-icon-btn{min-width:40px}.color-swatch{width:40px;height:40px}.palette-item-action{padding:8px}.palette-item-action>svg{width:16px;height:16px}.btn-small{padding:10px 14px;font-size:14px}.lang-item{padding:8px 10px;font-size:14px}.mini-swatch{width:22px;height:22px}input[type=number],input[type=text]{padding:10px 12px;font-size:15px}.aspect-link{--bracket-top: 45px;--bracket-bottom: 23px}input.zoom-label{padding:6px;font-size:13px;width:52px}input[type=range]{height:28px}}@media(max-width:1024px){.sidebar{position:fixed;top:0;left:0;height:100%;width:320px;max-width:86vw;transform:translate(-100%);box-shadow:8px 0 24px #0006}.sidebar.open{transform:translate(0)}html[dir=rtl] .sidebar{left:auto;right:0;transform:translate(100%);box-shadow:-8px 0 24px #0006}html[dir=rtl] .sidebar.open{transform:translate(0)}.sidebar-resizer{display:none}.sidebar-close{display:inline-flex}.menu-toggle{display:inline-flex!important}.toolbar-menu-group{display:flex}.main-content{width:100%}.sidebar-backdrop{display:block}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.toolbar-push{display:none}}@media(max-width:640px){.top-bar{order:2;border-bottom:none;border-top:1px solid var(--border-color);padding:6px;gap:2px}.viewport{order:1}.toolbar-group{flex-wrap:wrap;row-gap:4px}.tb-btn .tb-label{display:none}.tb-btn{padding:6px 10px}.toolbar-sep{margin:6px 2px;opacity:.5}.viewport{padding:16px;background-size:14px 14px;background-position:0 0,0 7px,7px -7px,-7px 0px}.sidebar{padding:16px;width:300px;max-width:88vw}.section{margin-bottom:24px}.logo{font-size:16px}.empty-state{padding:40px 24px;gap:10px}.empty-icon>svg{width:44px;height:44px}.empty-state-text{font-size:14px}.modal{min-width:0;width:calc(100vw - 32px);max-width:420px}.modal-header{padding:14px 16px;font-size:14px}.modal-body{padding:14px 16px}.modal-footer{padding:12px 16px;flex-wrap:wrap}.modal-footer .btn{flex:1 1 auto;min-width:0}.toast-container{top:8px;right:8px;left:8px}.toast{max-width:none;font-size:13px}.coord-tooltip{font-size:10px;padding:3px 6px}}@media(max-width:360px){.sidebar{width:88vw;max-width:88vw}.top-bar{padding:4px}.tb-btn{padding:5px 8px}.viewport{padding:10px}}
