:root{--bg:#f5f5f5;--fg:#1a1a1a;--muted:#666;--surface:#fff;--border:#e5e5e5;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root[data-theme=dark]{--bg:#1a1a1a;--fg:#e8e8e8;--muted:#a0a0a0;--surface:#242424;--border:#3a3a3a;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*,:before,:after{box-sizing:border-box}body{background:var(--bg);color:var(--fg);margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}.app{max-width:1280px;margin:0 auto;padding:2rem 1.5rem}.layout{grid-template-columns:1fr;gap:2rem;display:grid}@media (min-width:900px){.layout{grid-template-columns:400px minmax(0,1fr)}}.layout-controls{column-width:280px;column-fill:balance;column-gap:1rem}.layout-controls>*{break-inside:avoid;margin-bottom:1rem}.layout-controls>:last-child{margin-bottom:0}.preset-gallery{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.preset-tile{background:var(--surface);color:var(--fg);border:1px solid var(--border);font:inherit;cursor:pointer;text-align:left;border-radius:4px;flex-direction:column;align-items:stretch;gap:.25rem;padding:.35rem .4rem .4rem;transition:border-color .12s,background .12s;display:flex}.preset-tile:hover{border-color:var(--fg)}.preset-tile:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.preset-tile-gradient{border-radius:2px;width:100%;height:24px;display:block}.preset-tile-name{text-align:center;letter-spacing:.02em;font-size:.78rem;font-weight:500}.visualization{flex-direction:column;gap:.75rem;min-width:0;display:flex}.cube-area{flex-direction:column;gap:.5rem;display:flex}.cube-visualization{aspect-ratio:1;border:1px solid var(--border);background:#1a1a1a;border-radius:8px;width:100%;position:relative;overflow:hidden}.cube-toolbar{justify-content:space-between;align-items:center;gap:.375rem;display:flex}.cube-toolbar-group{align-items:center;gap:.375rem;display:inline-flex}.cube-icon-button{width:1.75rem;height:1.75rem;color:var(--fg);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background .12s,border-color .12s;display:inline-flex}.cube-icon-button:hover{background:var(--bg)}.cube-icon-button:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.cube-icon-button.is-active{background:var(--bg);border-color:var(--fg)}.cube-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:.75rem;padding:.75rem;font-size:.8125rem;display:flex}.cube-panel-row{flex-direction:column;gap:.5rem;display:flex}.cube-panel-row+.cube-panel-row{border-top:1px solid var(--border);padding-top:.75rem}.cube-panel-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:600}.cube-panel-label-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.cube-panel-button{font:inherit;color:var(--fg);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:.125rem .5rem;font-size:.75rem}.cube-panel-button:hover{background:var(--bg)}.cube-panel-button:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.cube-snap-grid{grid-template-columns:repeat(auto-fit,minmax(7rem,1fr));gap:.375rem;display:grid}.cube-snap-button{font:inherit;color:var(--fg);background:var(--surface);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:4px;align-items:center;gap:.5rem;padding:.375rem .5rem;font-size:.8125rem;transition:background .12s;display:inline-flex}.cube-snap-button:hover{background:var(--bg)}.cube-snap-button:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.cube-snap-swatch{border:1px solid var(--border);border-radius:50%;flex:none;width:.875rem;height:.875rem}.cube-visibility-grid{grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:.375rem 1rem;display:grid}.cube-segmented{border:1px solid var(--border);border-radius:6px;align-self:flex-start;display:inline-flex;overflow:hidden}.cube-segmented-option{cursor:pointer;background:var(--surface);align-items:center;padding:.25rem .625rem;display:inline-flex}.cube-segmented-option+.cube-segmented-option{border-left:1px solid var(--border)}.cube-segmented-option input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.cube-segmented-option.is-active{background:var(--bg);font-weight:600}.gamma-bar{border:1px solid var(--border);background:var(--surface);border-radius:4px;width:100%;height:20px;display:block}header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.header-titles{flex:1;min-width:0}header h1{margin:0 0 .25rem;font-size:2rem}header p{color:var(--muted);margin:0}.header-actions{flex-shrink:0;gap:.5rem;display:flex}.header-button,.header-icon-button{font:inherit;color:var(--fg);background:var(--surface);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;font-size:.875rem;transition:background .12s}.header-button{align-items:center;height:2rem;padding:0 .75rem;line-height:1;display:inline-flex}.header-icon-button{justify-content:center;align-items:center;width:2rem;height:2rem;padding:0;display:inline-flex}.header-button:hover,.header-icon-button:hover{background:var(--bg)}.header-button:focus-visible,.header-icon-button:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.controls{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;display:flex;overflow:hidden}.control-section+.control-section{border-top:1px solid var(--border)}.control-section-header{cursor:pointer;color:var(--fg);background:var(--bg);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.875rem 1.25rem;font-size:.95rem;font-weight:600;list-style:none;display:flex}.control-section-header::-webkit-details-marker{display:none}.control-section-header:hover{background:var(--border)}.control-section-chevron{color:var(--muted);font-size:1.25rem;line-height:1;transition:transform .15s}.control-section[open]>.control-section-header .control-section-chevron{transform:rotate(180deg)}.control-section-body{flex-direction:column;gap:1rem;padding:.5rem 1.25rem 1.25rem;display:flex}.slider label{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.25rem;display:flex}.slider-label{font-weight:500}.slider-value{color:var(--fg);text-align:right;background:var(--surface);border:1px solid var(--border);appearance:textfield;border-radius:4px;align-self:center;width:5rem;padding:.2rem .4rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.875rem}.slider-value::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.slider-value::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.slider-value:focus{outline:2px solid var(--fg);outline-offset:-1px}.slider input[type=range]{width:100%}.toggle{cursor:pointer;align-items:center;gap:.625rem;display:flex}.toggle input[type=checkbox]{margin:0}.saturation-block{flex-direction:column;gap:.5rem;display:flex}.saturation-block-label{font-weight:500}.saturation-field{width:100%}.saturation-field-row{justify-content:center;align-items:center;gap:.5rem;display:flex}.saturation-field-box{flex-direction:column;flex:none;align-items:stretch;gap:.35rem;display:flex}.saturation-field-label{color:var(--muted);text-align:center;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.saturation-field-track{border:1px solid var(--border);cursor:ns-resize;touch-action:none;border-radius:4px;width:88px;height:132px;position:relative;overflow:hidden}.saturation-field-track:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.saturation-field-canvas{pointer-events:none;width:100%;height:100%;display:block}.saturation-field-thumb{pointer-events:none;background:#fffffff2;height:2px;position:absolute;left:-2px;right:-2px;transform:translateY(50%);box-shadow:0 0 0 1px #000000a6,0 1px 3px #0006}.saturation-field-number{font:inherit;text-align:center;background:var(--surface);width:100%;color:var(--fg);border:1px solid var(--border);border-radius:4px;padding:.15rem .25rem;font-size:.8rem}.saturation-link-toggle{width:2rem;height:2rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:color .12s,border-color .12s;display:inline-flex}.saturation-link-toggle:hover{color:var(--fg);border-color:var(--fg)}.saturation-link-toggle:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.saturation-link-toggle[aria-pressed=true]{color:var(--fg)}.hue-control{flex-direction:column;gap:.5rem;display:flex}.hue-control-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.info-popover{flex:none;position:relative}.info-popover-trigger{border:1px solid var(--border);background:var(--surface);width:1.25rem;height:1.25rem;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;margin-top:.125rem;font-size:.75rem;font-weight:600;list-style:none;transition:color .12s,border-color .12s;display:inline-flex}.info-popover-trigger::-webkit-details-marker{display:none}.info-popover-trigger:hover,.info-popover[open] .info-popover-trigger{color:var(--fg);border-color:var(--fg)}.info-popover-content{z-index:20;background:var(--surface);border:1px solid var(--border);width:280px;max-width:calc(100vw - 2rem);color:var(--fg);border-radius:6px;padding:.75rem 1rem;font-size:.8125rem;line-height:1.5;position:absolute;top:calc(100% + .5rem);left:50%;transform:translate(-50%);box-shadow:0 6px 16px #0000001a}.info-popover-content p{margin:0}.info-popover-content p+p{margin-top:.5rem}.info-popover-content em{font-style:normal;font-weight:600}.hue-wheel{cursor:grab;touch-action:none;align-self:center;width:200px;height:200px}.hue-wheel:active{cursor:grabbing}.curve-control{flex-direction:column;gap:.5rem;display:flex}.curve-kind-selector{border:1px solid var(--border);border-radius:6px;align-self:flex-start;display:inline-flex;overflow:hidden}.curve-kind-option{cursor:pointer;color:var(--muted);background:var(--surface);border-right:1px solid var(--border);-webkit-user-select:none;user-select:none;align-items:center;padding:.25rem .625rem;font-size:.875rem;display:inline-flex}.curve-kind-option:last-child{border-right:none}.curve-kind-option.is-active{background:var(--fg);color:var(--bg)}.curve-kind-option input[type=radio]{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.bezier-editor{touch-action:none;align-self:center;width:100%;max-width:240px;height:240px}.range-slider{flex-direction:column;display:flex}.range-slider-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.25rem;display:flex}.range-slider-values{align-items:center;gap:.5rem;display:flex}.range-slider-track{height:28px;position:relative}.range-slider-track:before{content:"";background:var(--border);pointer-events:none;border-radius:2px;height:4px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.range-slider-fill{background:var(--muted);pointer-events:none;border-radius:2px;height:4px;position:absolute;top:50%;transform:translateY(-50%)}.range-slider-track input[type=range]{pointer-events:none;appearance:none;background:0 0;width:100%;margin:0;position:absolute;inset:0}.range-slider-track input[type=range]:focus{outline:none}.range-slider-track input[type=range]::-webkit-slider-runnable-track{background:0 0;border:none;height:4px}.range-slider-track input[type=range]::-moz-range-track{background:0 0;border:none;height:4px}.range-slider-track input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;cursor:pointer;border-radius:50%;width:16px;height:16px;margin-top:-6px}.range-slider-track input[type=range]::-moz-range-thumb{pointer-events:auto;cursor:pointer;border-radius:50%;width:16px;height:16px}.range-slider-track input.thumb-min::-webkit-slider-thumb{background:var(--thumb-color,#000);border:1px solid var(--fg);box-shadow:0 0 0 1px var(--surface)}.range-slider-track input.thumb-min::-moz-range-thumb{background:var(--thumb-color,#000);border:1px solid var(--fg);box-shadow:0 0 0 1px var(--surface)}.range-slider-track input.thumb-max::-webkit-slider-thumb{background:var(--thumb-color,#fff);border:1px solid var(--fg);box-shadow:0 0 0 1px var(--surface)}.range-slider-track input.thumb-max::-moz-range-thumb{background:var(--thumb-color,#fff);border:1px solid var(--fg);box-shadow:0 0 0 1px var(--surface)}.range-slider-track input[type=range]:focus-visible::-webkit-slider-thumb{outline:2px solid var(--fg);outline-offset:2px}.range-slider-track input[type=range]:focus-visible::-moz-range-thumb{outline:2px solid var(--fg);outline-offset:2px}.gradient-strip{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-shrink:0;width:100%;height:60px;display:block}.swatch-row{border:1px solid var(--border);border-radius:8px;grid-template-columns:repeat(9,1fr);gap:4px;display:grid;overflow:hidden}.swatch{aspect-ratio:1;justify-content:center;align-items:center;min-width:0;display:flex;overflow:hidden;container-type:inline-size}.swatch-hex{white-space:nowrap;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.75rem;font-weight:500}@container (width<=60px){.swatch-hex{display:none}}.about-dialog{border:1px solid var(--border);background:var(--surface);width:calc(100% - 2rem);max-width:560px;color:var(--fg);border-radius:8px;padding:0}.about-dialog::backdrop{background:#0006}.about-dialog-content{padding:1.5rem 1.75rem;position:relative}.about-dialog-content h2{margin:0 0 1rem;font-size:1.25rem}.about-dialog-content h3{margin:1.25rem 0 .5rem;font-size:1rem}.about-dialog-content p{margin:0 0 .75rem}.about-dialog-content blockquote{border-left:3px solid var(--border);background:var(--bg);border-radius:0 4px 4px 0;margin:0 0 .75rem;padding:.5rem .875rem;font-size:.9375rem}.about-dialog-content code{background:var(--bg);border-radius:3px;padding:.05rem .3rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.875rem}.about-dialog-content a{color:var(--fg);text-underline-offset:2px}.about-dialog-close{cursor:pointer;width:2rem;height:2rem;color:var(--muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;display:flex;position:absolute;top:.5rem;right:.5rem}.about-dialog-close:hover{background:var(--bg);color:var(--fg)}.about-dialog-close:focus-visible{outline:2px solid var(--fg);outline-offset:2px}.export-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:2rem;overflow:hidden}.export-panel-header{border-bottom:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:stretch;gap:.5rem;padding:.4rem .4rem .4rem .6rem;display:flex}.export-panel-tabs{flex-wrap:wrap;gap:.25rem;display:flex}.export-panel-tab{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:.3rem .6rem;font-size:.8125rem;transition:background .12s,color .12s}.export-panel-tab:hover{color:var(--fg)}.export-panel-tab.is-active{background:var(--surface);border-color:var(--border);color:var(--fg)}.export-panel-tab:focus-visible{outline:2px solid var(--fg);outline-offset:1px}.export-panel-output{white-space:pre;max-height:400px;margin:0;padding:1rem 1.25rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.8125rem;line-height:1.6;overflow-x:auto}
