@import "https://fonts.googleapis.com/css2?family=Google+Sans+Code:ital,wght@0,300..800;1,300..800&display=swap";:root{--color-bg:#12120f;--color-text:#eeeedf;--color-hover:#ffffff1a}*{box-sizing:border-box;margin:0;padding:0;font-family:Google Sans Code}html,body,#root{background-color:var(--color-bg);width:100%;height:100%;color:var(--color-text);user-select:none}#root{flex-direction:column;display:flex}::selection{background-color:var(--color-text);color:var(--color-bg)}header,footer{background-color:var(--color-bg);border-bottom:1px solid var(--color-text);width:100%;padding:.6rem}.app-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.app-header-title{letter-spacing:.08em;align-items:center;gap:.45rem;display:inline-flex;position:relative}.app-header-title>span{margin-left:3.2rem}.app-header-mark{width:auto;height:2.5rem;image-rendering:pixelated;flex-shrink:0;position:absolute;top:-.6rem;left:-.6rem}.app-header-links{align-items:center;gap:.75rem;display:flex}.header-link-btn{color:var(--color-text);letter-spacing:.08em;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #0000;align-items:center;gap:.35rem;padding:.2rem .35rem;display:inline-flex}.header-link-btn:hover{border-bottom-color:var(--color-text)}.header-modal-backdrop{z-index:999;background:#00000094;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.header-modal{border:1px solid var(--color-text);background:color-mix(in srgb, var(--color-bg) 92%, #000);gap:.8rem;width:min(36rem,100%);padding:1rem;display:grid}.header-modal-top{justify-content:space-between;align-items:center;gap:1rem;display:flex}.header-modal h2{letter-spacing:.1em;margin:0;font-size:1rem}.header-modal p{color:color-mix(in srgb, var(--color-text) 88%, transparent);font-size:.9rem;line-height:1.45}.header-modal a{color:var(--color-text)}.header-modal-support-block{user-select:text;gap:.45rem;display:grid}.header-modal-close{border:1px solid var(--color-text);color:var(--color-text);letter-spacing:.08em;cursor:pointer;background:0 0;padding:.3rem .55rem;font-size:.75rem}.header-modal-close:hover{background:var(--color-text);color:var(--color-bg)}.header-modal-setting{border-top:1px solid color-mix(in srgb, var(--color-text) 28%, transparent);justify-content:space-between;align-items:center;gap:.75rem;margin-top:.2rem;padding-top:.8rem;display:flex}.header-modal-setting-label{letter-spacing:.11em;color:color-mix(in srgb, var(--color-text) 92%, transparent);font-size:.78rem}.header-modal-toggle{border:1px solid var(--color-text);min-width:3.8rem;color:var(--color-text);letter-spacing:.08em;cursor:pointer;background:0 0;padding:.3rem .6rem;font-size:.75rem}.header-modal-toggle-group{align-items:center;gap:.35rem;display:flex}.header-modal-toggle[aria-pressed=true]{background:var(--color-text);color:var(--color-bg)}main{flex:1;width:100%;min-height:0;overflow:hidden}#root>main{min-height:0;display:flex}.resizable-shell{flex-shrink:0;width:20%;min-width:16rem;max-width:64rem;height:100%;min-height:0;position:relative}aside{border-right:1px solid var(--color-text);scrollbar-gutter:stable;width:100%;height:100%;min-height:0;padding:1rem;display:block;overflow:hidden auto}.resize-handle{cursor:col-resize;z-index:20;background-color:#0000;width:12px;transition:background-color .2s;position:absolute;top:0;bottom:0;right:-12px}.resize-handle:hover{background-color:var(--color-hover)}.resize-handle:hover:before,.resize-handle.dragging:before{opacity:1}#root:has(.resize-handle.dragging){cursor:col-resize}nav{border-right:1px solid var(--color-text);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;row-gap:.5rem;width:3.2rem;height:100%;padding-right:.3rem;display:flex;overflow-x:hidden}.nav-icon-btn{box-sizing:content-box;background:0 0;border:none;place-items:center;width:100%;padding:.8rem .5rem;transition:background-color .2s;display:grid}.nav-icon-btn:hover{background-color:var(--color-hover);cursor:pointer}.nav-icon-btn.selected{background-color:var(--color-text)}.nav-icon-img{width:24px;height:24px;image-rendering:pixelated}.nav-icon-btn.selected .nav-icon-img{filter:brightness(0)saturate()}.flex-v{flex-direction:column;width:100%;height:100%;min-height:0;display:flex}footer{border:none;border-top:1px solid var(--color-text)}#render{width:min-content;height:min-content;display:block;position:relative}.render-underlay{object-fit:fill;width:100%;height:100%;image-rendering:pixelated;pointer-events:none;position:absolute;inset:0}.render-canvas-layer{position:absolute;inset:0}.render-canvas-layer canvas,canvas{image-rendering:pixelated}h1,h2,h3{margin-bottom:1rem}.webgl2-blocker{text-align:center;align-content:center;justify-items:center;gap:.75rem;width:100%;height:100%;padding:2rem;display:grid}.webgl2-blocker h1{letter-spacing:.12em;font-size:clamp(1.25rem,2vw,2rem)}.webgl2-blocker p{max-width:42rem;color:color-mix(in srgb, var(--color-text) 85%, transparent)}.webgl2-blocker-continue-btn{border:1px solid var(--color-text);color:var(--color-text);letter-spacing:.08em;cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:.4rem;margin-top:.5rem;padding:.45rem .7rem;font-size:.74rem;display:inline-flex}.webgl2-blocker-continue-btn:hover{background:var(--color-text);color:var(--color-bg)}::-webkit-scrollbar{background-color:var(--color-bg);width:8px;height:8px}::-webkit-scrollbar-track{background-color:#0000}::-webkit-scrollbar-thumb{background-color:var(--color-text);opacity:.2}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text);cursor:grab}::-webkit-scrollbar-corner{background:var(--color-bg)}.palette-section{flex-direction:column;gap:.6rem;margin-bottom:1rem;display:flex}.palette-label{letter-spacing:.08em;color:color-mix(in srgb, var(--color-text) 72%, transparent);font-size:.8rem}.palette-option-group{flex-wrap:wrap;gap:.45rem;display:flex}.palette-option-btn{border:1px solid color-mix(in srgb, var(--color-text) 28%, transparent);background:color-mix(in srgb, var(--color-text) 3%, transparent);color:var(--color-text);letter-spacing:.04em;cursor:pointer;padding:.45rem .65rem;font-size:.76rem;line-height:1.1;transition:background-color .16s,color .16s,border-color .16s,transform .16s}.palette-option-btn:hover{background:color-mix(in srgb, var(--color-text) 10%, transparent);border-color:color-mix(in srgb, var(--color-text) 48%, transparent)}.palette-option-btn.active,.palette-option-btn[data-selected=true]{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.palette-option-btn:disabled{opacity:.45;cursor:not-allowed}.danger-btn{color:color-mix(in srgb, #ffb3b3 82%, var(--color-text));border-color:#b12d2d94}.danger-btn:hover:not(:disabled){background:#7d202026;border-color:#d64848b3}.dither-toggle-btn[data-dither-enabled=true][data-selected=true]{outline:1px solid color-mix(in srgb, #7ed321 70%, var(--color-text))}.size-controls-ratio{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.size-controls-ratio-value{letter-spacing:.06em;color:var(--color-text);opacity:.55;flex:1;font-size:.76rem}.size-controls-ratio-buttons{flex-wrap:nowrap}.slider-label-wrap{align-items:center;display:flex;position:relative}.slider-tooltip{background:var(--color-bg);border:1px solid color-mix(in srgb, var(--color-text) 35%, transparent);color:color-mix(in srgb, var(--color-text) 85%, transparent);letter-spacing:.02em;z-index:40;pointer-events:none;visibility:hidden;opacity:0;width:14rem;padding:.45rem .6rem;font-size:.72rem;line-height:1.45;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + .5rem);transform:translateY(-50%)}.slider-label-wrap:hover .slider-tooltip{visibility:visible;opacity:1}.palette-color-grid{grid-template-columns:repeat(auto-fill,minmax(7.25rem,1fr));gap:.45rem;display:grid}.palette-row-inline{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.palette-custom-head{grid-template-columns:1fr;gap:.45rem;display:grid}.palette-name-input{background:color-mix(in srgb, var(--color-text) 4%, transparent);border:1px solid color-mix(in srgb, var(--color-text) 28%, transparent);width:100%;min-width:0;color:var(--color-text);letter-spacing:.04em;padding:.35rem .45rem;font-size:.74rem}.palette-save-row{flex-wrap:nowrap;align-items:center}.palette-save-row .palette-name-input{flex:1;height:2rem}.palette-save-row .palette-option-btn{flex-shrink:0;align-items:center;height:2rem;display:inline-flex}.palette-color-grid--hidden{opacity:.58}.color-list-divider{letter-spacing:.08em;color:color-mix(in srgb, var(--color-text) 58%, transparent);margin:.5rem 0 .35rem;font-size:.72rem}.palette-color-chip{border:1px solid color-mix(in srgb, var(--color-bg) 48%, transparent);letter-spacing:.05em;text-transform:uppercase;align-content:start;min-height:2.15rem;padding:.4rem .5rem;font-size:.74rem;display:grid}.palette-custom-layout{grid-template-columns:minmax(0,1fr) 8.5rem;gap:.55rem;display:grid}.palette-floating-editor{border:1px solid color-mix(in srgb, var(--color-text) 24%, transparent);background:color-mix(in srgb, var(--color-bg) 92%, transparent);z-index:30;align-content:start;gap:.38rem;width:9.5rem;padding:.48rem;display:grid;position:absolute;top:1rem;left:calc(100% + .65rem)}.palette-custom-swatch{border:1px solid color-mix(in srgb, var(--color-bg) 52%, transparent);cursor:pointer;text-align:left;align-content:center;justify-items:start;min-height:2.25rem;padding:.35rem .42rem;display:grid;position:relative}.palette-custom-swatch--selected{border-color:var(--color-text);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-text) 65%, transparent)}.palette-custom-swatch--hidden{filter:saturate(.78)}.palette-custom-swatch-text{letter-spacing:.04em;text-transform:uppercase;font-size:.68rem}.palette-custom-swatch-hint{letter-spacing:.08em;opacity:.72;font-size:.54rem}.palette-custom-swatch-delete-wrap{opacity:0;transition:opacity .12s;position:absolute;top:.22rem;right:.22rem}.palette-custom-swatch:hover .palette-custom-swatch-delete-wrap,.palette-custom-swatch--selected .palette-custom-swatch-delete-wrap{opacity:1}.palette-custom-swatch-delete{background:color-mix(in srgb, var(--color-bg) 65%, transparent);width:1rem;height:1rem;color:color-mix(in srgb, #ffc8c8 80%, var(--color-text));cursor:pointer;border:1px solid #b53636a6;place-items:center;padding:0;line-height:0;transition:border-color .12s,background-color .12s;display:grid}.palette-custom-swatch-delete:hover{background:#7d20204d;border-color:#e14a4acc}.palette-custom-editor{border:1px solid color-mix(in srgb, var(--color-text) 20%, transparent);background:color-mix(in srgb, var(--color-text) 3%, transparent);align-content:start;gap:.38rem;padding:.42rem;display:grid}.palette-editor-preview{aspect-ratio:4/3;border:1px solid color-mix(in srgb, var(--color-bg) 56%, transparent);cursor:pointer;width:100%;display:block}.palette-editor-preview input{opacity:0;cursor:pointer;width:100%;height:100%}.palette-custom-toprow{grid-template-columns:1.35rem 1fr;align-items:center;gap:.35rem;display:grid}.palette-color-picker{border:1px solid color-mix(in srgb, var(--color-bg) 42%, transparent);background:0 0;width:1.35rem;height:1.35rem;padding:0}.palette-hex-input{background:color-mix(in srgb, var(--color-bg) 75%, transparent);border:1px solid color-mix(in srgb, var(--color-bg) 35%, transparent);width:100%;min-width:0;color:inherit;text-transform:uppercase;letter-spacing:.04em;padding:.18rem .3rem;font-size:.72rem}.palette-custom-actions{margin-top:.35rem}.palette-custom-actions .palette-option-btn{width:100%;padding:.3rem .45rem;font-size:.68rem}.palette-color-chip--hidden{filter:saturate(.85)}.palette-library-list{gap:.45rem;display:grid}.palette-library-group{gap:.35rem;display:grid}.palette-library-group-title{letter-spacing:.08em;color:color-mix(in srgb, var(--color-text) 70%, transparent);margin:0;font-size:.66rem}.palette-library-empty{border:1px dashed color-mix(in srgb, var(--color-text) 28%, transparent);color:color-mix(in srgb, var(--color-text) 62%, transparent);letter-spacing:.05em;margin:0;padding:.42rem .5rem;font-size:.68rem}.palette-library-card{position:relative}.palette-library-item{border:1px solid color-mix(in srgb, var(--color-text) 26%, transparent);background:color-mix(in srgb, var(--color-text) 4%, transparent);width:100%;color:var(--color-text);text-align:left;cursor:pointer;padding:.45rem 1.75rem .45rem .45rem}.palette-library-item:hover{border-color:color-mix(in srgb, var(--color-text) 52%, transparent)}.palette-library-delete{background:color-mix(in srgb, var(--color-bg) 65%, transparent);width:1rem;height:1rem;color:color-mix(in srgb, #ffc8c8 80%, var(--color-text));cursor:pointer;opacity:0;border:1px solid #b53636a6;place-items:center;padding:0;line-height:0;transition:opacity .12s,border-color .12s,background-color .12s;display:grid;position:absolute;top:.22rem;right:.22rem}.palette-library-card:hover .palette-library-delete{opacity:1}.palette-library-delete:hover{background:#7d20204d;border-color:#e14a4acc}.palette-library-head{letter-spacing:.04em;margin-bottom:.28rem;font-size:.72rem;display:flex}.palette-library-swatches-row{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:.42rem;display:grid}.palette-library-count{letter-spacing:.05em;color:color-mix(in srgb, var(--color-text) 76%, transparent);font-size:.68rem}.palette-library-swatches{grid-template-columns:repeat(20,minmax(0,1fr));gap:.15rem;display:grid}.palette-library-swatches>span{aspect-ratio:1;border:1px solid color-mix(in srgb, var(--color-bg) 60%, transparent);width:100%}.import-current-file{color:color-mix(in srgb, var(--color-text) 86%, transparent);overflow-wrap:anywhere;font-size:.78rem}.import-dropzone{border:1px dashed color-mix(in srgb, var(--color-text) 40%, transparent);background:color-mix(in srgb, var(--color-text) 3%, transparent);letter-spacing:.04em;text-align:center;padding:1rem .8rem;font-size:.78rem;transition:background-color .15s,border-color .15s}.import-dropzone.active{background:color-mix(in srgb, var(--color-text) 12%, transparent);border-color:color-mix(in srgb, var(--color-text) 75%, transparent)}.import-name-input{background:color-mix(in srgb, var(--color-text) 5%, transparent);border:1px solid color-mix(in srgb, var(--color-text) 30%, transparent);width:100%;color:var(--color-text);letter-spacing:.03em;outline:none;padding:.35rem .5rem;font-family:Google Sans Code;font-size:.78rem;transition:border-color .15s}.import-name-input:focus{border-color:color-mix(in srgb, var(--color-text) 70%, transparent)}.export-btn,.import-btn{align-items:center;gap:.4rem;display:flex}.import-export-status{color:color-mix(in srgb, var(--color-text) 72%, transparent);margin-top:.2rem;font-size:.76rem}.import-export-hint{color:color-mix(in srgb, var(--color-text) 58%, transparent);letter-spacing:.03em;margin-top:.25rem;font-size:.76rem}.import-export-ext{color:color-mix(in srgb, var(--color-text) 38%, transparent)}.app-footer{justify-content:space-between;align-items:center;gap:1rem;display:flex}.app-footer-status{letter-spacing:.08em;color:color-mix(in srgb, var(--color-text) 60%, transparent);white-space:nowrap;font-size:.76rem}.app-footer-status--busy{color:var(--color-text)}.footer-preview-btn{border:1px solid color-mix(in srgb, var(--color-text) 28%, transparent);background:color-mix(in srgb, var(--color-text) 3%, transparent);color:color-mix(in srgb, var(--color-text) 72%, transparent);letter-spacing:.06em;cursor:pointer;white-space:nowrap;user-select:none;padding:.2rem .55rem;font-size:.72rem;transition:background-color .1s,color .1s,border-color .1s}.footer-preview-btn:hover{border-color:color-mix(in srgb, var(--color-text) 48%, transparent);color:var(--color-text)}.footer-preview-btn--active{background:var(--color-text);border-color:var(--color-text);color:var(--color-bg)!important}.histogram-controls-row{justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.9rem;display:flex}.histogram-toggle-group{flex-wrap:nowrap}.histogram-floating-panel{border:1px solid color-mix(in srgb, var(--color-text) 24%, transparent);background:color-mix(in srgb, var(--color-bg) 92%, transparent);z-index:29;gap:.4rem;width:14rem;padding:.48rem;display:grid;position:absolute;top:1rem;left:calc(100% + .65rem)}.histogram-canvas{width:100%;height:64px;image-rendering:pixelated;display:block}.gallery-grid{contain:layout paint;grid-template-columns:repeat(auto-fill,minmax(4.25rem,4.25rem));justify-content:start;gap:.4rem;display:grid}.gallery-group{margin-top:.45rem}.gallery-group-title{letter-spacing:.08em;color:color-mix(in srgb, var(--color-text) 70%, transparent);margin:0 0 .32rem;font-size:.66rem}.gallery-empty{border:1px dashed color-mix(in srgb, var(--color-text) 28%, transparent);color:color-mix(in srgb, var(--color-text) 62%, transparent);letter-spacing:.05em;margin:0;padding:.42rem .5rem;font-size:.68rem}.gallery-thumb{border:1px solid color-mix(in srgb, var(--color-text) 22%, transparent);background:color-mix(in srgb, var(--color-text) 5%, transparent);cursor:pointer;width:100%;height:100%;padding:0;transition:border-color .12s;position:relative;overflow:hidden}.gallery-thumb-wrap{width:4.25rem;height:4.25rem;position:relative}.gallery-thumb:hover{border-color:color-mix(in srgb, var(--color-text) 55%, transparent)}.gallery-thumb img{object-fit:cover;width:100%;height:100%;image-rendering:pixelated;display:block}.gallery-thumb-label{background:color-mix(in srgb, var(--color-bg) 72%, transparent);color:color-mix(in srgb, var(--color-text) 85%, transparent);letter-spacing:.05em;text-align:center;opacity:0;white-space:nowrap;text-overflow:ellipsis;padding:.15rem .2rem;font-size:.6rem;transition:opacity .12s;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.gallery-thumb:hover .gallery-thumb-label,.gallery-thumb--active .gallery-thumb-label{opacity:1}.gallery-thumb--active{border-color:var(--color-text);border-width:2px}.gallery-thumb-delete{background:color-mix(in srgb, var(--color-bg) 65%, transparent);width:1rem;height:1rem;color:color-mix(in srgb, #ffc8c8 80%, var(--color-text));cursor:pointer;opacity:0;border:1px solid #b53636a6;place-items:center;padding:0;line-height:0;transition:opacity .12s,border-color .12s,background-color .12s;display:grid;position:absolute;top:.22rem;right:.22rem}.gallery-thumb-wrap:hover .gallery-thumb-delete,.gallery-thumb-wrap--active .gallery-thumb-delete{opacity:1}.gallery-thumb-delete:hover{background:#7d20204d;border-color:#e14a4acc}#root.is-resizing-aside .gallery-thumb,#root.is-resizing-aside .gallery-thumb-label,#root.is-resizing-aside .gallery-thumb-delete{transition:none!important}#root>main .zoomable-wrap{background-color:#101010;background-image:linear-gradient(45deg,#1d1d1d 25%,#0000 25%),linear-gradient(-45deg,#1d1d1d 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#1d1d1d 75%),linear-gradient(-45deg,#0000 75%,#1d1d1d 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px;flex-shrink:1;width:100%;height:100%;position:relative}.zoomable-outer{cursor:grab;width:100%;height:100%;position:absolute;overflow:auto}.zoomable-inner{transform-origin:0 0}.zoomable-inner>:first-child{pointer-events:none;transform-origin:0 0}
