:root{--bg: #ffffff;--fg: #000000;--accent: #1f30d0;--muted: #666666;--paper: #ffffff;--line: #000000;--border-w: 1.5px;--mono: "JetBrains Mono", "IBM Plex Mono", "Courier New", monospace;--c-red: #dc2020;--c-blue: #1f30d0;--c-orange: #f4731f;--c-yellow: #f4d11f;--c-cream: #f5ecdc}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--fg);font-family:var(--mono);font-size:13px;-webkit-font-smoothing:none;font-smooth:never}body{background-image:repeating-linear-gradient(0deg,transparent 0 23px,rgba(0,0,0,.04) 23px 24px),repeating-linear-gradient(90deg,transparent 0 23px,rgba(0,0,0,.04) 23px 24px)}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}.app{display:grid;grid-template-columns:170px 1fr 180px;grid-template-rows:56px 1fr 32px;grid-template-areas:"head head head" "left main right" "foot foot foot";height:100vh;width:100vw}.head{grid-area:head;border-bottom:var(--border-w) solid var(--line);display:flex;align-items:stretch;background:var(--c-red);color:var(--c-cream)}.head .brand{padding:0 18px;display:flex;align-items:center;gap:12px;background:var(--fg);color:var(--c-cream);border-right:var(--border-w) solid var(--line);font-family:Comic Sans MS,Comic Neue,Chalkboard SE,cursive;font-weight:700;letter-spacing:.04em}.head .brand .wordmark{display:flex;flex-direction:column;align-items:flex-start;line-height:.95}.head .brand .wordmark .line{display:block}.head .brand .wordmark .jox{font-size:13px;letter-spacing:.08em;color:var(--c-blue)}.head .brand .wordmark .phex{font-size:19px}.head .brand .wordmark .phex span:nth-child(odd){color:var(--c-yellow)}.head .brand .wordmark .phex span:nth-child(2n){color:var(--c-red)}.head .brand .glyph{display:inline-block;width:34px;height:34px;background-color:var(--c-cream);-webkit-mask:url(/logo.png) center / contain no-repeat;mask:url(/logo.png) center / contain no-repeat}.head .meta{display:flex;align-items:center;padding:0 16px;gap:18px;margin-left:auto;font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.85}.head .meta .dot{display:inline-block;width:8px;height:8px;background:#f5ecdc;margin-right:6px;vertical-align:middle}.left{grid-area:left;border-right:var(--border-w) solid var(--line);overflow-y:auto;background:var(--paper)}.right{grid-area:right;border-left:var(--border-w) solid var(--line);overflow-y:auto;background:var(--paper)}.main{grid-area:main;position:relative;overflow:hidden;background:repeating-conic-gradient(#e6e6e6 0 25%,#fff 0 50%) 50% 50% / 24px 24px}.main.drag-hover{outline:4px dashed var(--fg);outline-offset:-8px}.drop-overlay{position:absolute;inset:0;background:#ffffffd9;display:flex;align-items:center;justify-content:center;z-index:30;pointer-events:none}.drop-overlay-inner{text-align:center;padding:30px 50px;background:var(--bg);border:var(--border-w) solid var(--fg);font-family:var(--mono);font-weight:700;text-transform:uppercase}.foot{grid-area:foot;background:var(--c-red);color:var(--c-cream);border-top:var(--border-w) solid var(--line);display:flex;align-items:center;padding:0 12px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;gap:18px}.foot .spacer{flex:1}.panel-section{border-bottom:.5px solid var(--line)}.panel-section h2{margin:0;padding:8px 10px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;background:var(--c-blue);color:var(--c-cream);border-bottom:.5px solid var(--line);display:flex;align-items:center;gap:6px}.panel-section h2 .tag{background:var(--c-yellow);color:var(--fg);padding:1px 6px;font-size:9px;letter-spacing:.1em}.panel-section.cta-section h2{background:var(--c-yellow);color:var(--c-red)}.panel-section.cta-section h2 .tag{background:var(--c-red);color:var(--c-yellow)}.panel-body{padding:10px}.filter-group{border-bottom:.5px solid rgba(0,0,0,.18)}.group-header{display:flex;align-items:center;gap:6px;width:100%;padding:7px 10px;background:transparent;border:none;border-top:.5px solid rgba(0,0,0,.12);cursor:pointer;font-family:inherit;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);text-align:left}.group-header:hover{background:var(--fg);color:var(--bg)}.group-header .chev{display:inline-block;width:10px;text-align:center;font-size:9px}.group-header .grp-label{flex:1;font-weight:700}.group-header .grp-count{font-size:9px;opacity:.55;font-variant-numeric:tabular-nums}.filter-group.open .group-header{background:#0000000f}.filter-group.open .group-header:hover{background:var(--fg);color:var(--bg)}.group-toggle-all{margin-left:auto;background:transparent;border:.5px solid currentColor;color:inherit;cursor:pointer;font-family:inherit;font-size:9px;letter-spacing:.06em;padding:1px 6px;line-height:1}.group-toggle-all:hover{background:currentColor;color:var(--fg)}.filter-btn{display:block;width:100%;text-align:left;padding:6px 10px 6px 22px;background:transparent;border:none;border-top:.5px solid rgba(0,0,0,.12);cursor:pointer;letter-spacing:.04em;text-transform:uppercase;font-size:10.5px;position:relative}.filter-btn:before{position:absolute;left:10px;margin-right:0}.filter-btn:hover{background:var(--fg);color:var(--bg)}.filter-btn.active{background:var(--fg);color:var(--bg);font-weight:700}.filter-btn:before{content:"◼";margin-right:8px;opacity:.4}.filter-btn.active:before{opacity:1;content:"▶"}.control{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.control label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;display:flex;justify-content:space-between}.control label .val{background:var(--fg);color:var(--bg);padding:1px 6px;font-variant-numeric:tabular-nums}.control input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:22px;background:transparent;border:var(--border-w) solid var(--line);padding:0 2px}.control input[type=range]::-webkit-slider-runnable-track{height:14px;background:repeating-linear-gradient(90deg,var(--line) 0 2px,transparent 2px 6px)}.control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--fg);border:1px solid var(--line);margin-top:0;cursor:ew-resize}.control input[type=range]::-moz-range-track{height:14px;background:repeating-linear-gradient(90deg,var(--line) 0 2px,transparent 2px 6px)}.control input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--fg);border:1px solid var(--line);border-radius:0}.control select,.control input[type=text],.control input[type=number],.control input[type=password]{background:var(--paper);border:var(--border-w) solid var(--line);padding:6px 8px;border-radius:0;outline:none}.control select:focus,.control input:focus{background:#f0f0f0}.control .toggle{display:flex;border:var(--border-w) solid var(--line)}.control .toggle button{flex:1;padding:6px;background:var(--paper);border:none;border-right:.5px solid var(--line);cursor:pointer;text-transform:uppercase;letter-spacing:.1em;font-size:10px}.control .toggle button:last-child{border-right:none}.control .toggle button.on{background:var(--fg);color:var(--bg)}.btn{display:inline-block;background:var(--paper);border:var(--border-w) solid var(--line);padding:9px 14px;cursor:pointer;letter-spacing:.16em;text-transform:uppercase;font-size:11px;font-weight:700;box-shadow:4px 4px 0 var(--line);transition:transform .06s,box-shadow .06s}.btn:hover{background:var(--fg);color:var(--bg)}.btn:active{transform:translate(4px,4px);box-shadow:0 0 0 var(--line)}.btn.primary{background:var(--c-yellow);color:var(--c-red);border-color:var(--line)}.btn.primary:hover{background:var(--c-red);color:var(--c-yellow)}.btn.alt{background:var(--c-red);color:var(--c-yellow);border-color:var(--line)}.btn.alt:hover{background:var(--c-yellow);color:var(--c-red)}.btn.cta{background:var(--c-yellow);color:var(--c-red);border-color:var(--line)}.btn.cta:hover{background:var(--c-red);color:var(--c-yellow)}.btn.cta:hover .cta-letters span,.btn.cta:hover .cta-arrow,.ma-btn.cta:hover .cta-letters span,.ma-btn.cta:hover .cta-arrow{color:var(--c-yellow)}.cta-letters span:nth-child(odd){color:var(--c-blue)}.cta-letters span:nth-child(2n){color:var(--c-red)}.cta-arrow{color:var(--c-red)}.btn.full{width:100%;display:block}.btn:focus-visible,.filter-btn:focus-visible,.group-header:focus-visible,.chain-row:focus-visible,.recipe-load:focus-visible,.vc-btn:focus-visible,.ma-btn:focus-visible,.mobile-head-btn:focus-visible{outline:2px solid var(--c-blue);outline-offset:-2px}.btn-row{display:flex;gap:8px;margin-top:10px}.canvas-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:28px}.canvas-frame{position:relative;background:#fff;border:var(--border-w) solid var(--line);box-shadow:10px 10px 0 var(--line);max-width:100%;max-height:100%;overflow:hidden}.canvas-viewport{position:relative;overflow:hidden;cursor:grab;touch-action:none;user-select:none}.canvas-viewport.grabbing{cursor:grabbing}.canvas-viewport.painting,.canvas-viewport.painting.grabbing{cursor:crosshair}.canvas-viewport canvas{display:block;max-width:calc(100vw - 420px);max-height:calc(100vh - 180px);image-rendering:pixelated;image-rendering:crisp-edges;will-change:transform}.viewport-controls{position:absolute;left:12px;bottom:12px;display:flex;flex-direction:column;gap:4px;z-index:5;pointer-events:none}.viewport-controls>*{pointer-events:auto}.viewport-controls .vc-row{display:flex;gap:3px}.vc-btn{height:20px;padding:0 5px;font-family:var(--mono);font-size:9px;font-weight:700;background:var(--bg);color:var(--fg);border:1px solid var(--line);cursor:pointer;letter-spacing:.06em;line-height:1;box-shadow:1.5px 1.5px 0 var(--line);transition:transform .06s,box-shadow .06s;min-width:22px}.vc-btn:hover{background:var(--fg);color:var(--bg)}.vc-btn:active{transform:translate(1.5px,1.5px);box-shadow:0 0 0 var(--line)}.vc-zoom{min-width:42px;font-variant-numeric:tabular-nums}.vc-compare{width:100%;letter-spacing:.12em}.vc-compare.active{background:var(--fg);color:var(--bg)}.empty-state{text-align:center;padding:40px;border:var(--border-w) dashed var(--line);background:var(--paper);max-width:480px}.empty-state h3{margin:0 0 8px;letter-spacing:.2em;text-transform:uppercase}.empty-state p{margin:0 0 18px;color:var(--muted);line-height:1.5}.stripe{height:14px;background:repeating-linear-gradient(135deg,var(--bg) 0 8px,var(--line) 8px 16px);border-bottom:var(--border-w) solid var(--line)}.file-input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;margin:0;padding:0;border:0;overflow:hidden;clip:rect(0 0 0 0)}kbd{background:var(--paper);border:1px solid var(--line);padding:1px 5px;font-size:10px;box-shadow:2px 2px 0 var(--line)}.left::-webkit-scrollbar,.right::-webkit-scrollbar{width:10px}.left::-webkit-scrollbar-track,.right::-webkit-scrollbar-track{background:var(--paper);border-left:.5px solid var(--line)}.left::-webkit-scrollbar-thumb,.right::-webkit-scrollbar-thumb{background:var(--fg);border:1px solid var(--paper)}@keyframes blink{50%{opacity:0}}.pulse{animation:blink 1.2s steps(2,end) infinite}.chain{display:flex;flex-direction:column;gap:4px}.chain-row{display:flex;flex-direction:column;gap:4px;padding:6px 8px;border:1px solid var(--line);background:var(--paper);cursor:pointer;font-size:11px;letter-spacing:.06em;text-transform:uppercase;user-select:none}.chain-row .chain-line-1{display:flex;align-items:center;gap:6px}.chain-row.selected{background:var(--fg);color:var(--bg)}.chain-row.disabled{opacity:.45}.chain-row.disabled .chain-name{text-decoration:line-through}.chain-row .chain-idx{font-variant-numeric:tabular-nums;opacity:.6;font-size:10px}.chain-row .chain-name{flex:1;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chain-row .chain-actions{display:flex;gap:3px;justify-content:flex-end}.chain-row .chain-btn{width:22px;height:18px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid currentColor;color:inherit;font-size:10px;cursor:pointer;padding:0;line-height:1}.chain-row .chain-btn:hover{background:currentColor}.chain-row .chain-btn:hover{color:var(--paper)}.chain-row.selected .chain-btn:hover{color:var(--fg)}.chain-row .chain-btn:disabled{opacity:.25;cursor:not-allowed}.chain-row .chain-btn:disabled:hover{background:transparent;color:inherit}.chain-row .chain-btn.danger:hover{background:#c81e1e;color:#fff;border-color:#c81e1e}.recipes-save{display:flex;gap:4px;margin-bottom:6px}.recipes-save input{flex:1;min-width:0;padding:4px 6px;background:var(--paper);border:1px solid var(--line);font-size:10px;font-family:var(--mono);letter-spacing:.04em}.recipe-save-btn{padding:0 8px;background:var(--fg);color:var(--bg);border:1px solid var(--line);cursor:pointer;font-size:10px;font-weight:700;letter-spacing:.1em}.recipe-save-btn:disabled{background:var(--paper);color:var(--muted);cursor:not-allowed}.recipe-save-btn:not(:disabled):hover{background:var(--bg);color:var(--fg)}.recipe-list{display:flex;flex-direction:column;gap:3px}.recipe-row{display:flex;gap:3px}.recipe-load{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;padding:4px 7px;background:var(--paper);border:1px solid var(--line);cursor:pointer;font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;text-align:left}.recipe-load:hover{background:var(--fg);color:var(--bg)}.recipe-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.recipe-count{font-size:9px;opacity:.7;margin-left:6px;font-variant-numeric:tabular-nums}.recipe-del{width:22px;background:transparent;border:1px solid var(--line);cursor:pointer;font-size:10px}.recipe-del:hover{background:#c81e1e;color:#fff;border-color:#c81e1e}.brush-preview{margin-top:8px;border:1px solid var(--line);background:repeating-conic-gradient(#e6e6e6 0 25%,#fff 0 50%) 50% 50% / 12px 12px;padding:4px}.brush-preview img{display:block;width:100%;height:auto;max-height:110px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.brush-preview .brush-canvas{display:block;margin:0 auto;max-width:100%;max-height:110px;cursor:crosshair;touch-action:none;image-rendering:pixelated;image-rendering:crisp-edges}.brush-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-variant-numeric:tabular-nums}.brush-clear{background:transparent;border:1px solid var(--line);color:var(--fg);width:22px;height:18px;cursor:pointer;font-size:10px;padding:0;line-height:1}.brush-clear:hover{background:#c81e1e;color:#fff;border-color:#c81e1e}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg);border:var(--border-w) solid var(--line);box-shadow:8px 8px 0 var(--line);min-width:480px;max-width:90vw;display:flex;flex-direction:column}.modal-head{background:var(--fg);color:var(--bg);padding:8px 12px;display:flex;align-items:center;justify-content:space-between;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700}.modal-close{background:transparent;border:1px solid currentColor;color:inherit;width:22px;height:22px;cursor:pointer;font-size:11px;line-height:1}.modal-close:hover{background:currentColor;color:var(--fg)}.modal-body{padding:16px;background:#000;display:flex;align-items:center;justify-content:center}.modal-err{color:var(--bg);text-align:center;padding:30px;font-family:var(--mono);letter-spacing:.1em}.modal-foot{display:flex;gap:8px;padding:10px 12px;border-top:.5px solid var(--line);background:var(--bg)}.mobile-only{display:none}@media (max-width: 768px){.app{grid-template-columns:1fr;grid-template-rows:50px 1fr;grid-template-areas:"head" "main";height:100vh;height:100dvh}.foot,.viewport-controls{display:none}.head{padding-top:env(safe-area-inset-top,0);height:calc(50px + env(safe-area-inset-top,0))}.head .meta{display:none}.head .brand{padding:0 10px;border-right:none;gap:10px;flex:1}.head .brand .glyph{width:28px;height:28px}.head .brand .wordmark .jox{font-size:11px}.head .brand .wordmark .phex{font-size:16px}.mobile-head-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:36px;margin:0 10px 0 auto;background:transparent;border:1px solid var(--c-cream);color:var(--c-cream);cursor:pointer;font-size:16px;line-height:1;font-family:inherit}.mobile-head-btn:active{background:var(--c-cream);color:var(--c-red)}.left,.right{position:fixed;top:calc(50px + env(safe-area-inset-top,0));bottom:0;width:85vw;max-width:360px;z-index:60;background:var(--paper);transition:transform .22s ease;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border:none}.left{left:0;transform:translate(-101%);box-shadow:4px 0 24px #00000040}.right{right:0;transform:translate(101%);box-shadow:-4px 0 24px #00000040}.left.mobile-open,.right.mobile-open{transform:translate(0)}.right .params-section{display:none}.drawer-backdrop{position:fixed;inset:0;background:#00000073;z-index:55;animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.canvas-wrap{padding:12px}.canvas-frame{box-shadow:4px 4px 0 var(--line)}.canvas-viewport canvas{max-width:calc(100vw - 24px);max-height:calc(100dvh - 130px - env(safe-area-inset-top,0) - env(safe-area-inset-bottom,0))}body.has-mobile-tray.has-mobile-tray-collapsed .canvas-viewport canvas{max-height:calc(100dvh - 182px - env(safe-area-inset-top,0) - env(safe-area-inset-bottom,0))}body.has-mobile-tray:not(.has-mobile-tray-collapsed) .canvas-viewport canvas{max-height:calc(65dvh - 130px - env(safe-area-inset-top,0) - env(safe-area-inset-bottom,0))}.canvas-viewport{touch-action:none}.empty-state{max-width:90vw;padding:28px 20px}.empty-state h3{font-size:16px}.empty-state p{font-size:12px}.empty-mobile-cta{display:flex;gap:10px;margin-bottom:18px}.empty-mobile-cta .btn{flex:1;padding:14px 8px;font-size:12px;box-shadow:3px 3px 0 var(--line)}.mobile-params-tray{display:flex!important;flex-direction:column!important;position:fixed!important;left:0!important;right:0!important;bottom:calc(60px + env(safe-area-inset-bottom,0))!important;background:var(--paper);border-top:var(--border-w) solid var(--line);z-index:40;height:clamp(260px,35dvh,400px)!important;max-height:clamp(260px,35dvh,400px)!important;overflow:hidden!important;box-shadow:0 -4px 18px #0000002e}.mobile-params-tray.collapsed{height:auto!important;max-height:none!important}.mobile-params-head{flex:0 0 auto;display:flex;align-items:center;gap:8px;background:var(--c-blue);color:var(--c-cream);padding:10px;min-height:44px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;cursor:pointer;user-select:none;-webkit-tap-highlight-color:rgba(255,255,255,.1)}.mpt-chev{display:inline-block;width:14px;font-size:12px;text-align:center;line-height:1}.mpt-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mpt-close{background:transparent;color:inherit;border:1px solid currentColor;width:28px;height:28px;cursor:pointer;font-size:12px;line-height:1;margin-left:8px}.mobile-action-bar{display:flex;position:fixed;left:0;right:0;bottom:0;gap:6px;padding:6px 6px calc(6px + env(safe-area-inset-bottom,0));background:var(--bg);border-top:var(--border-w) solid var(--line);z-index:35}.ma-btn{flex:1;min-height:48px;background:var(--paper);color:var(--fg);border:var(--border-w) solid var(--line);font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;padding:0 6px;box-shadow:2px 2px 0 var(--line);transition:transform .06s,box-shadow .06s;-webkit-tap-highlight-color:transparent}.ma-btn.primary,.ma-btn.active{background:var(--fg);color:var(--bg)}.ma-btn.cta{background:var(--c-yellow);color:var(--c-red)}.ma-btn:active:not(:disabled){transform:translate(2px,2px);box-shadow:0 0 0 var(--line)}.ma-btn:disabled{opacity:.32;cursor:not-allowed;box-shadow:none;transform:none}.filter-btn{padding:13px 10px 13px 24px;font-size:12px;min-height:44px}.group-header{padding:12px 10px;font-size:11px;min-height:42px}.group-toggle-all{padding:4px 10px;font-size:10px}.panel-section h2{padding:11px 10px;font-size:11px}.panel-body{padding:12px}.control{margin-bottom:12px}.control input[type=range]{height:30px;padding:0 4px}.control input[type=range]::-webkit-slider-runnable-track{height:18px}.control input[type=range]::-moz-range-track{height:18px}.control input[type=range]::-webkit-slider-thumb{width:20px;height:20px}.control input[type=range]::-moz-range-thumb{width:20px;height:20px}.control .toggle button{padding:9px 6px;font-size:11px;min-height:36px}.mobile-params-body{flex:1 1 0!important;min-height:0!important;padding:10px 12px 12px;overflow-y:auto!important;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.control select,.control input[type=text],.control input[type=number],.control input[type=password],.recipes-save input{padding:11px 10px;font-size:16px}.recipe-save-btn{padding:0 14px;min-height:42px;font-size:11px}.recipe-load{padding:12px 10px;font-size:11px;min-height:42px}.recipe-del{width:42px;min-height:42px;font-size:12px}.chain-row{padding:10px;font-size:12px}.chain-row .chain-btn{width:36px;height:32px;font-size:12px}.btn{padding:13px 16px;font-size:12px}.modal{min-width:0;width:94vw;max-width:94vw;max-height:90dvh}.modal-body{padding:8px}.modal video{max-height:50dvh}.modal-foot{flex-wrap:wrap;padding:10px}.modal-foot .btn{flex:1;min-width:90px}body{background-image:none}}
