:root{--bg: #1a1a1d;--panel: #25252a;--border: #34343a;--text: #e6e6ea;--muted: #8a8a93;--accent: #6cb4ff}*{box-sizing:border-box}html,body{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif}#app{display:grid;grid-template-rows:auto 1fr auto;height:100%}header{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;border-bottom:1px solid var(--border)}#status{font-size:.8rem;color:var(--muted)}#status[hidden]{display:none}main{display:grid;grid-template-columns:220px 1fr 260px;min-height:0}aside{background:var(--panel);border-right:1px solid var(--border);padding:.75rem;overflow:auto}aside:last-of-type{border-right:0;border-left:1px solid var(--border)}.drawer-toggle{display:none;background:transparent;border:1px solid var(--border);color:var(--text);width:36px;height:36px;border-radius:4px;font-size:1.2rem;line-height:1;cursor:pointer;padding:0}.drawer-toggle-right{margin-left:auto}#drawer-scrim{position:absolute;inset:0;background:#0006;z-index:80;display:none}#drawer-scrim:not([hidden]){display:block}@media (max-width: 900px){main{grid-template-columns:1fr}.drawer-toggle{display:inline-flex;align-items:center;justify-content:center}aside{position:fixed;top:0;bottom:0;width:78%;max-width:320px;z-index:100;border:0;padding:.75rem;transition:transform .18s ease-out;box-shadow:0 8px 28px #0006}#left-panel{left:0;transform:translate(-100%)}#right-panel{right:0;transform:translate(100%)}#left-panel.drawer-open,#right-panel.drawer-open{transform:translate(0)}.toolbar-btn{padding:.5rem .8rem;font-size:.86rem}.layer-row{padding:.5rem}.brush-btn,.btn-group-btn{padding:.55rem .5rem;font-size:.86rem}#stage{padding:.4rem}.perf-indicator{display:none}}@media (min-width: 901px) and (max-width: 1180px){main{grid-template-columns:180px 1fr 220px}aside{padding:.55rem}}#stage{display:flex;align-items:center;justify-content:center;padding:1rem;background:#0e0e10;overflow:hidden;position:relative}#stage.panning,#stage.panning #draw-canvas{cursor:grabbing!important}#stage.grab,#stage.grab #draw-canvas{cursor:grab}#draw-canvas{background:#000;width:640px;height:480px;touch-action:none;image-rendering:pixelated;position:relative;z-index:1}footer{border-top:1px solid var(--border);padding:.5rem 1rem;background:var(--panel)}.replay-indicator{position:fixed;top:.6rem;right:.6rem;z-index:9999;display:flex;align-items:center;gap:.55rem;padding:.4rem .7rem;background:#141418eb;border:1px solid var(--border);border-radius:999px;box-shadow:0 4px 16px #0006;font-size:.74rem;color:var(--text);pointer-events:none;user-select:none}.replay-indicator-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:replay-pulse .9s ease-in-out infinite alternate}.replay-indicator-text{font-variant-numeric:tabular-nums}.replay-indicator-pct{color:var(--muted)}@keyframes replay-pulse{0%{opacity:.35}to{opacity:1}}.perf-indicator{margin-top:1rem;padding:.45rem .7rem;background:#1414188c;border:1px solid var(--border);border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;color:var(--text);line-height:1.5;user-select:none;font-variant-numeric:tabular-nums}.perf-row{display:flex;justify-content:space-between;gap:.6rem}.perf-label{color:var(--muted)}.perf-val{color:var(--text)}.toolbar{display:flex;gap:.3rem;margin-left:1rem}.toolbar-btn{padding:.35rem .75rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.78rem;cursor:pointer}.toolbar-btn.active{background:var(--accent);color:#08151c;border-color:transparent}.selection-panel .sb-subtools .btn-group-btn[disabled]{opacity:.4;cursor:not-allowed}.sel-ops{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;margin-top:.4rem}.sel-op-btn{padding:.4rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.78rem;cursor:pointer}.sel-op-danger{background:#3a2a2a}.sel-info{margin-top:.6rem;padding:.4rem .5rem;background:#1f1f24;border-radius:4px;color:var(--muted);font-size:.72rem;font-variant-numeric:tabular-nums}.edit-hint{color:var(--muted);font-size:.78rem;line-height:1.5;padding:.4rem}.advanced-divider{margin:.6rem 0 .3rem;text-align:center;color:var(--muted);font-size:.7rem;letter-spacing:.06em}.panel h2{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 .4rem}.panel+.panel{margin-top:.8rem}.brush-list{list-style:none;margin:0 0 1rem;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.3rem}.brush-btn{width:100%;padding:.5rem .4rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.78rem;cursor:pointer;transition:background .08s}.brush-btn:hover{background:#3a3a42}.brush-btn.active{background:var(--accent);color:#08151c;border-color:transparent}.brush-btn.eraser{grid-column:span 2;background:#3a2a2a}.brush-btn.eraser.active{background:#ff7a5a;color:#2b0d05}.color-input{width:100%;height:32px;border:1px solid var(--border);border-radius:4px;background:none;cursor:pointer;margin-bottom:.6rem;padding:0}.slider{display:grid;grid-template-columns:70px 1fr 36px;align-items:center;gap:.4rem;font-size:.75rem;margin:.4rem 0}.slider-label{color:var(--muted)}.slider input[type=range]{width:100%;accent-color:var(--accent)}.slider-value{color:var(--text);font-variant-numeric:tabular-nums;text-align:right}.advanced-toggle{margin-top:.6rem;padding:.35rem .4rem;width:100%;text-align:left;background:#2a2a30;color:var(--text);border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:.75rem}.advanced-toggle:hover{background:#34343c}.advanced-body{margin-top:.4rem}.advanced-row{display:grid;grid-template-columns:70px 1fr;align-items:center;gap:.4rem;margin:.4rem 0;font-size:.75rem}.btn-group{display:flex;gap:.25rem}.btn-group-btn{flex:1;padding:.3rem .4rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.72rem;cursor:pointer}.btn-group-btn:hover{background:#3a3a42}.btn-group-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.layer-list{list-style:none;margin:0;padding:0}.layer-toolbar{display:flex;gap:.25rem;margin:0 0 .4rem}.layer-tool-btn{flex:1;padding:.3rem .2rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.8rem;cursor:pointer;line-height:1}.layer-tool-btn:hover{background:#353540;border-color:#50505a}.layer-tool-btn:active{background:#3d4350}.layer-row{display:flex;flex-direction:column;gap:.2rem;padding:.35rem .4rem;border:1px solid transparent;border-radius:4px;background:#2e2e35;cursor:pointer;user-select:none;margin-bottom:.3rem;font-size:.74rem}.layer-row-top{display:grid;grid-template-columns:14px 14px 1fr 18px 18px 18px;align-items:center;gap:.25rem}.layer-row-bot{display:grid;grid-template-columns:22px 22px 1fr 70px;align-items:center;gap:.3rem}.layer-target,.layer-mask-thumb{background:#1f1f24;color:var(--muted);border:1px solid var(--border);border-radius:3px;padding:0;cursor:pointer;text-align:center;line-height:1;font-size:.7rem;height:18px}.layer-mask-thumb{height:22px}.layer-target:hover,.layer-mask-thumb:hover{background:#353540}.layer-target.active-target,.layer-mask-thumb.active-target{background:var(--accent);color:#11141a;border-color:var(--accent)}.layer-mask-thumb.has-mask{color:var(--text)}.mask-edit-banner{background:var(--accent);color:#11141a;text-align:center;padding:.25rem .5rem;border-radius:4px;margin:0 0 .4rem;font-size:.78rem;font-weight:600;letter-spacing:.05em}.layer-row:hover{background:#353540}.layer-row.selected{background:#353e4a}.layer-row.active{border-color:var(--accent)}.layer-row.dragging{opacity:.4}.layer-row.drop-target{background:#3d4350}.layer-handle{cursor:grab;color:var(--muted);text-align:center;line-height:1}.layer-select-cb{margin:0;cursor:pointer;accent-color:var(--accent)}.layer-name{color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-name-input{background:#1f1f24;color:var(--text);border:1px solid var(--accent);border-radius:3px;font:inherit;padding:.1rem .25rem;width:100%;min-width:0}.layer-blend{background:#1f1f24;color:var(--text);border:1px solid var(--border);border-radius:3px;font-size:.68rem;padding:.1rem .15rem;min-width:0;width:100%}.layer-opacity{width:100%;accent-color:var(--accent);min-width:0}.layer-vis,.layer-lock,.layer-alock{background:none;border:none;color:var(--muted);width:18px;height:18px;padding:0;cursor:pointer;line-height:1;font-size:.85rem;border-radius:3px}.layer-vis:hover,.layer-lock:hover,.layer-alock:hover{background:#1f1f24;color:var(--text)}.layer-vis.on{color:var(--accent)}.layer-lock.on,.layer-alock.on{color:#ffb37b}.layer-menu{position:fixed;z-index:10000;min-width:9rem;background:#1f1f24;border:1px solid var(--border);border-radius:6px;padding:.25rem 0;box-shadow:0 8px 24px #0000008c;font-size:.78rem;color:var(--text);user-select:none}.layer-menu-item{padding:.4rem .8rem;cursor:pointer}.layer-menu-item:hover{background:#2e2e35}.layer-menu-item.disabled{color:var(--muted);cursor:not-allowed}.layer-menu-item.disabled:hover{background:transparent}.layer-menu-sep{height:1px;background:var(--border);margin:.25rem 0}.history-bar{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:.6rem}.history-btn{background:#2e2e35;color:var(--text);border:1px solid var(--border);padding:.3rem .8rem;border-radius:4px;font-size:.78rem;cursor:pointer}.history-btn:hover{background:#3a3a42}.history-slider{width:100%;accent-color:var(--accent)}.history-label{color:var(--muted);font-size:.78rem;font-variant-numeric:tabular-nums;min-width:6ch;text-align:right}.scale-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.3rem}.scale-btn{background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.4rem 0;font-size:.78rem;cursor:pointer}.scale-btn:hover{background:#3a3a42}.scale-btn.active{background:var(--accent);color:#08151c;border-color:transparent}.sketchbook-trigger{margin-left:auto;padding:.35rem .75rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.78rem;cursor:pointer;letter-spacing:.02em}.sketchbook-trigger:hover{background:var(--accent);color:#08151c;border-color:transparent}.sketchbook-modal{position:fixed;inset:0;background:#08080cb8;display:flex;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(4px)}.sketchbook-modal.hidden{display:none}.sketchbook-panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;width:min(960px,92vw);max-height:86vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #00000080;overflow:hidden}.sketchbook-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:#1e1e22}.sketchbook-header h2{margin:0;font-size:.85rem;font-weight:500;letter-spacing:.08em;color:var(--text);text-transform:uppercase}.sketchbook-actions{margin-left:auto;display:flex;gap:.4rem}.sb-btn{background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.35rem .8rem;font-size:.78rem;cursor:pointer}.sb-btn:hover{background:#3a3a42}.sb-btn-primary{background:var(--accent);color:#08151c;border-color:transparent}.sb-btn-primary:hover{background:#8dc6ff}.sb-btn-close{font-size:.78rem}.sketchbook-grid{padding:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.8rem;overflow:auto}.sketchbook-empty{grid-column:1 / -1;text-align:center;color:var(--muted);font-size:.85rem;padding:3rem 1rem}.sb-cell{background:#2a2a30;border:1px solid var(--border);border-radius:6px;padding:.5rem;cursor:pointer;display:flex;flex-direction:column;gap:.35rem;position:relative;transition:border-color .08s,transform .08s}.sb-cell:hover{border-color:#4a4a55}.sb-cell.active{border-color:var(--accent);box-shadow:0 0 0 2px #6cb4ff40}.sb-thumb{width:100%;aspect-ratio:4 / 3;background:#1a1a1d;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:1.5rem}.sb-thumb img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated}.sb-thumb-empty{background:repeating-linear-gradient(45deg,#1f1f24,#1f1f24 8px,#25252a 8px 16px)}.sb-name{background:transparent;border:1px solid transparent;color:var(--text);font-size:.78rem;padding:.2rem .3rem;border-radius:3px;font-family:inherit;width:100%;min-width:0}.sb-name:hover{border-color:var(--border)}.sb-name:focus{outline:none;border-color:var(--accent);background:#1a1a1d}.sb-stats{font-size:.7rem;color:var(--muted);padding:0 .3rem;font-variant-numeric:tabular-nums}.sb-del{position:absolute;top:.4rem;right:.4rem;width:24px;height:24px;background:#00000080;color:#ffb0a0;border:1px solid transparent;border-radius:4px;cursor:pointer;font-size:.78rem;line-height:0;opacity:0;transition:opacity .08s,background .08s}.sb-cell:hover .sb-del{opacity:1}.sb-del:hover{background:#ff5c4a;color:#1b0703}.color-panel-wheel-host{margin:.2rem 0 .4rem}.color-swatch-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.4rem;margin:.2rem 0 .6rem}.color-swatch-wrap{text-align:center}.color-swatch{width:100%;height:36px;border:1px solid var(--border);border-radius:5px;cursor:pointer;background:#444;padding:0}.color-swatch.active{box-shadow:0 0 0 2px var(--accent),inset 0 0 0 1px #fff3;border-color:transparent}.color-swatch-label{display:block;margin-top:.15rem;color:var(--muted);font-size:.7rem}.color-swap-btn{width:30px;height:30px;border-radius:999px;border:1px solid var(--border);background:#2e2e35;color:var(--text);cursor:pointer;font-size:.9rem}.color-swap-btn:hover{background:#3a3a42}.color-inputs{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.6rem}.color-input-row{display:flex;align-items:center;gap:.3rem;font-size:.72rem}.color-input-label{color:var(--muted);width:30px}.color-text{flex:1;background:#1f1f24;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.2rem .4rem;font-size:.74rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.color-num{width:50px;background:#1f1f24;color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.2rem .3rem;font-size:.72rem;font-variant-numeric:tabular-nums}.color-mixing-host{margin:.4rem 0 .6rem}.mixing-pad-label{color:var(--muted);font-size:.7rem;margin-bottom:.2rem}.color-recent-label{color:var(--muted);font-size:.7rem;margin:.3rem 0 .2rem}.color-recent{display:grid;grid-template-columns:repeat(8,1fr);gap:.18rem;margin-bottom:.6rem}.color-recent-cell{width:100%;aspect-ratio:1;border:1px solid var(--border);border-radius:3px;background:#1f1f24;cursor:pointer;padding:0}.color-recent-cell[disabled]{cursor:default;opacity:.4}.color-km-row{display:flex;align-items:center;gap:.4rem;margin-top:.4rem;font-size:.74rem}.color-km-row input[type=checkbox]{accent-color:var(--accent)}.color-km-row label{color:var(--text)}.color-km-hint{color:var(--muted);font-size:.68rem}.paint-color-preview{width:100%;height:28px;background:#888;border:1px solid var(--border);border-radius:4px;cursor:pointer;margin-bottom:.6rem;padding:0}.paint-color-preview:disabled{opacity:.4;cursor:not-allowed}.bg-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem;margin-bottom:.5rem}.bg-tab{background:var(--panel);border:1px solid var(--border);color:var(--fg);padding:.25rem 0;border-radius:4px;cursor:pointer;font-size:.78rem;transition:background .08s,border-color .08s,color .08s}.bg-tab:hover{border-color:var(--accent)}.bg-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.bg-body{display:flex;flex-direction:column;gap:.45rem}.bg-row{display:grid;grid-template-columns:3em 1fr auto;align-items:center;gap:.4rem;font-size:.78rem;color:var(--muted)}.bg-label{color:var(--muted)}.bg-readout{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.72rem;min-width:3em;text-align:right}.bg-color{width:36px;height:24px;border:1px solid var(--border);border-radius:3px;padding:0;cursor:pointer;background:transparent}.bg-hex{background:var(--panel);border:1px solid var(--border);color:var(--fg);padding:.15rem .3rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;width:6.5em;border-radius:3px}.bg-size{width:100%}.bg-preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:.4rem}.bg-preset-cell{aspect-ratio:1;background:linear-gradient(135deg,#2a2a2e,#1a1a1d);border:1px solid var(--border);border-radius:5px;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:border-color .08s,color .08s,background .08s}.bg-preset-cell:hover{border-color:var(--accent);color:var(--fg)}.bg-preset-cell.active{border-color:var(--accent);color:#fff;background:linear-gradient(135deg,#3a3a45,#232328);box-shadow:0 0 0 1px var(--accent)}.bg-preset-label{pointer-events:none}.bg-empty{color:var(--muted);font-size:.78rem;text-align:center;padding:.5rem 0}.adjust-panel .adjust-grid{display:grid;grid-template-columns:minmax(120px,1fr) minmax(120px,1fr);gap:.5rem;margin-top:.4rem}.adjust-op-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.adjust-op-btn{width:100%;text-align:left;padding:.35rem .5rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.78rem;cursor:pointer}.adjust-op-btn.disabled,.adjust-op-btn:disabled{opacity:.35;cursor:not-allowed}.adjust-op-btn.active{background:var(--accent);color:#08151c;border-color:transparent}.adjust-params{background:#1f1f24;border:1px solid var(--border);border-radius:4px;padding:.5rem;min-height:4rem}.adjust-op-hint{color:var(--muted);font-size:.72rem;line-height:1.4}.adjust-sub-panel-host{margin-top:.5rem}.adjust-sub-view{display:flex;flex-direction:column;gap:.4rem;margin-top:.6rem;padding:.55rem .55rem .5rem;background:#25252b;border:1px solid var(--accent);border-radius:6px;box-shadow:0 2px 8px #00000040}.adjust-sub-view[hidden]{display:none}.adjust-sub-title{font-size:.78rem;font-weight:600;margin:0 0 .2rem;color:var(--accent);letter-spacing:.04em}.adjust-sub-cta{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-top:.5rem;padding-top:.4rem;border-top:1px solid var(--border)}.adjust-sub-cancel,.adjust-sub-apply{padding:.45rem .6rem;border-radius:4px;border:1px solid var(--border);font-size:.8rem;cursor:pointer}.adjust-sub-cancel{background:#2e2e35;color:var(--text)}.adjust-sub-cancel:hover{background:#3a2a2a}.adjust-sub-apply{background:var(--accent);color:#08151c;border-color:transparent;font-weight:600}.adjust-sub-apply:hover{background:#84c4ff}.adjust-sub-panel-title{font-size:.78rem;font-weight:500;color:var(--text);margin-bottom:.2rem}.adjust-cb-group{margin-bottom:.4rem;padding-bottom:.2rem;border-bottom:1px dashed var(--border)}.adjust-cb-group:last-of-type{border-bottom:none}.adjust-cb-group-label{font-size:.7rem;color:var(--muted);margin:.2rem 0 .1rem}.adjust-sub-panel-reset{margin-top:.4rem;width:100%;padding:.3rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.72rem;cursor:pointer}.curves-tabs{display:flex;gap:.25rem;margin-bottom:.35rem}.curves-tab{flex:1;padding:.25rem .3rem;background:#2e2e35;color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:.72rem;cursor:pointer}.curves-tab.active{background:#25252b}.curves-canvas{display:block;width:100%;max-width:256px;border:1px solid var(--border);border-radius:4px;background:#1a1a1f;touch-action:none;cursor:crosshair}.adjust-confirm-bar{position:absolute;top:.6rem;left:50%;transform:translate(-50%);z-index:100;padding:.4rem .7rem;background:#141418eb;border:1px solid var(--border);border-radius:999px;display:flex;gap:.6rem;align-items:center;pointer-events:auto;color:var(--text);font-size:.78rem}.adjust-confirm-name{font-weight:500;padding-right:.4rem;border-right:1px solid var(--border)}.adjust-confirm-busy{color:var(--muted);font-size:.72rem}.adjust-confirm-apply,.adjust-confirm-cancel{padding:.3rem .65rem;border-radius:4px;border:1px solid var(--border);background:#2e2e35;color:var(--text);font-size:.78rem;cursor:pointer}.adjust-confirm-apply{background:var(--accent);color:#08151c;border-color:transparent}.adjust-confirm-apply:disabled{opacity:.4;cursor:not-allowed}.gradient-map-panel .gradient-strip-wrap{padding-bottom:.6rem}.gradient-strip{display:block;width:100%;max-width:256px;height:28px;border:1px solid var(--border);border-radius:4px;vertical-align:top;touch-action:none;cursor:crosshair}.gradient-hint{margin-top:.4rem;font-size:.68rem;color:var(--muted);line-height:1.4}.gradient-color-picker{position:absolute;width:0;height:0;opacity:0;pointer-events:none}
