:root{--bg: #0d0d11;--surface: #141418;--raised: #1c1c22;--hover: #24242c;--active: #2a2a36;--border: rgba(255, 255, 255, .07);--border-md: rgba(255, 255, 255, .12);--border-hi: rgba(255, 255, 255, .2);--accent: #7c5af0;--accent-2: #6366f1;--accent-dim: rgba(124, 90, 240, .14);--accent-glow: rgba(124, 90, 240, .35);--accent-grad: linear-gradient(135deg, #7c5af0, #6366f1);--text: #f0effe;--text-muted: #8888a4;--text-faint: #44445a;--success: #22c55e;--success-dim: rgba(34, 197, 94, .14);--error: #f43f5e;--error-dim: rgba(244, 63, 94, .14);--warning: #f59e0b;--warning-dim: rgba(245, 158, 11, .14);--r-xs: 4px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--sidebar-w: 296px;--header-h: 52px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", Consolas, monospace;--ease: cubic-bezier(.25, .46, .45, .94)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{color-scheme:dark;font-size:14px}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;height:100dvh}#root{height:100dvh;display:flex;flex-direction:column}.accent-bar{height:1px;background:var(--accent-grad);flex-shrink:0}.app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.app-header{height:var(--header-h);display:flex;align-items:center;gap:12px;padding:0 16px;background:#0d0d11e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);flex-shrink:0;z-index:50}.app-body{display:flex;flex:1;min-height:0;overflow:hidden}.header-brand{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:130px}.brand-icon{color:var(--accent);flex-shrink:0}.brand-name{font-size:15px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.brand-sub{font-weight:400;color:var(--text-muted)}.header-center{flex:1;display:flex;justify-content:center}.workflow-select{background:var(--raised);border:1px solid var(--border-md);color:var(--text);font-family:var(--font);font-size:13px;font-weight:500;padding:6px 32px 6px 12px;border-radius:var(--r-md);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%238888a4' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color .15s;min-width:200px;max-width:320px}.workflow-select:hover{border-color:var(--border-hi)}.workflow-select:focus{outline:2px solid var(--accent);outline-offset:2px;border-color:transparent}.header-end{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:130px;justify-content:flex-end}.sdot-wrap{display:flex;align-items:center;gap:5px}.sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.sdot.ok{background:var(--success);box-shadow:0 0 6px var(--success)}.sdot.off{background:var(--text-faint)}.sdot-label{font-size:12px;color:var(--text-muted);font-weight:500}.job-pill{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:99px;border:1px solid var(--border-md);letter-spacing:.01em}.job-pill.job-queued{color:var(--warning);background:var(--warning-dim);border-color:#f59e0b40}.job-pill.job-running{color:#818cf8;background:var(--accent-dim);border-color:#7c5af04d}.job-pill.job-succeeded{color:var(--success);background:var(--success-dim);border-color:#22c55e40}.job-pill.job-failed{color:var(--error);background:var(--error-dim);border-color:#f43f5e40}.job-pulse{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 1.4s ease-in-out infinite}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.sb-section{padding:16px;border-bottom:1px solid var(--border)}.sb-section:last-child{border-bottom:none;flex:1}.sb-label{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:12px}.step-num{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(124,90,240,.3);color:var(--accent);font-size:10px;font-weight:700;flex-shrink:0}.upload-zone{position:relative;width:100%;aspect-ratio:4 / 3;max-height:200px;border:1.5px dashed var(--border-md);border-radius:var(--r-lg);background:var(--raised);cursor:pointer;overflow:hidden;transition:border-color .2s,background .2s;display:flex;align-items:center;justify-content:center}.upload-zone:hover,.upload-zone:focus-visible{border-color:var(--accent);background:var(--accent-dim);outline:none}.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-dim);box-shadow:inset 0 0 0 2px var(--accent)}.upload-zone.has-image{border-style:solid;border-color:var(--border-md)}.upload-preview{width:100%;height:100%;object-fit:contain;display:block;background:#0a0a0e}.upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a10bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text);font-size:12px;font-weight:600;opacity:0;transition:opacity .2s}.upload-zone:hover .upload-overlay{opacity:1}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;text-align:center}.upload-icon{color:var(--text-faint)}.upload-title{font-size:13px;font-weight:600;color:var(--text-muted)}.upload-hint{font-size:11px;color:var(--text-faint)}.filename-row{display:flex;align-items:center;gap:6px;margin-top:8px}.filename-text{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:230px}.file-input-hidden{display:none}.prompt-ta{width:100%;background:var(--raised);border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.5;padding:10px 12px;resize:vertical;transition:border-color .15s;min-height:72px}.prompt-ta:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.prompt-ta::placeholder{color:var(--text-faint)}.prompt-ta.neg{opacity:.8;margin-top:8px}.advanced-toggle{display:flex;align-items:center;gap:5px;margin-top:8px;background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;padding:2px 0;transition:color .15s}.advanced-toggle:hover{color:var(--text)}.advanced-panel{margin-top:8px}.params-stack{display:flex;flex-direction:column;gap:10px;margin-top:8px}.param-row{display:flex;flex-direction:column;gap:5px}.param-head{display:flex;align-items:center;justify-content:space-between}.param-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.param-val{font-size:11px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.param-slider{width:100%;height:4px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--border-md);border-radius:99px;cursor:pointer;outline:none}.param-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);cursor:grab;transition:transform .1s}.param-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}.param-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);cursor:grab}.seed-row{display:flex;gap:6px}.seed-input{flex:1;background:var(--raised);border:1px solid var(--border-md);border-radius:var(--r-sm);color:var(--text);font-family:var(--font-mono);font-size:12px;padding:6px 8px;min-width:0}.seed-input:focus{outline:none;border-color:var(--accent)}.dice-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--raised);border:1px solid var(--border-md);border-radius:var(--r-sm);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color .15s,border-color .15s,background .15s}.dice-btn:hover{color:var(--text);border-color:var(--border-hi);background:var(--hover)}.sb-actions{display:flex;flex-direction:column;gap:10px}.readiness-row{display:flex;gap:6px}.chip{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:99px;background:var(--raised);border:1px solid var(--border-md);color:var(--text-faint);transition:all .2s}.chip.ready{background:var(--success-dim);border-color:#22c55e40;color:var(--success)}.error-banner{display:flex;align-items:flex-start;gap:7px;background:var(--error-dim);border:1px solid rgba(244,63,94,.25);border-radius:var(--r-md);color:#fca5a5;font-size:12px;padding:9px 12px;line-height:1.4}.error-banner svg{flex-shrink:0;margin-top:1px;color:var(--error)}.btn-generate{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;background:var(--accent-grad);border:none;border-radius:var(--r-md);color:#fff;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 20px var(--accent-glow);position:relative;overflow:hidden}.btn-generate:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;transition:opacity .15s}.btn-generate:hover:not(:disabled):after{opacity:.07}.btn-generate:active:not(:disabled){transform:scale(.98)}.btn-generate:disabled{opacity:.38;cursor:not-allowed;box-shadow:none}.btn-download{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;background:var(--raised);border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text-muted);font-family:var(--font);font-size:13px;font-weight:500;text-decoration:none;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.btn-download:hover{color:var(--text);border-color:var(--border-hi);background:var(--hover)}.spinner{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.workspace{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg);position:relative}.workspace.processing .ws-panel{animation:ws-glow 1.8s ease-in-out infinite}.ws-tabs{display:flex;align-items:center;gap:2px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.tab-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:none;border:none;border-radius:var(--r-sm);color:var(--text-muted);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,background .15s;position:relative}.tab-btn:hover{color:var(--text);background:var(--hover)}.tab-btn.active{color:var(--text);background:var(--raised)}.tab-btn.active:after{content:"";position:absolute;bottom:-9px;left:10%;right:10%;height:2px;background:var(--accent-grad);border-radius:99px}.tab-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);flex-shrink:0}.ws-panel{flex:1;min-height:0;position:relative;overflow:hidden}.tab-view{display:none;position:absolute;top:0;right:0;bottom:0;left:0}.tab-view.active{display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:20px;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent}.tab-view.active::-webkit-scrollbar{width:4px}.tab-view.active::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.pad-card{width:100%;max-width:min(500px,100%);display:flex;flex-direction:column;gap:10px}.pad-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.pad-title-group{min-width:0}.pad-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}.pad-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px;line-height:1.4}.pad-toolbar-actions{display:flex;align-items:center;gap:3px;flex-shrink:0}.toolbar-divider{width:1px;height:16px;background:var(--border-md);margin:0 3px}.icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--raised);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.icon-btn:hover:not(:disabled){color:var(--text);border-color:var(--border-md);background:var(--hover)}.icon-btn:disabled{opacity:.3;cursor:not-allowed}.icon-btn.danger:hover:not(:disabled){color:var(--error);border-color:#f43f5e4d;background:var(--error-dim)}.icon-btn.active{color:var(--accent);border-color:#7c5af066;background:var(--accent-dim)}.pad-controls{display:flex;align-items:center;gap:16px;background:var(--raised);border:1px solid var(--border);border-radius:var(--r-md);padding:8px 12px}.ctrl-item{display:flex;align-items:center;gap:8px;flex-shrink:0}.ctrl-item.ctrl-brush{flex:1;flex-direction:column;align-items:stretch;gap:4px}.ctrl-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.ctrl-val{font-weight:700;color:var(--text);font-family:var(--font-mono);font-style:normal}.color-wrap{position:relative;width:26px;height:26px;flex-shrink:0}.color-swatch{width:26px;height:26px;border-radius:var(--r-xs);border:2px solid rgba(255,255,255,.15);cursor:pointer;flex-shrink:0}.color-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.brush-slider{width:100%;height:4px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--border-md);border-radius:99px;cursor:pointer;outline:none}.brush-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text);cursor:grab;box-shadow:0 1px 4px #0006;transition:transform .1s}.brush-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}.brush-slider::-moz-range-thumb{width:14px;height:14px;border:none;border-radius:50%;background:var(--text);box-shadow:0 1px 4px #0006;cursor:grab}.canvas-frame{position:relative;width:100%;background:#0a0a0e;border-radius:var(--r-lg);border:1px solid var(--border-md);overflow:hidden;background-size:contain;background-position:center;background-repeat:no-repeat;cursor:none}.canvas-frame[data-tool=pointer]{cursor:default}.drawing-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.canvas-empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;pointer-events:none}.brush-cursor{position:absolute;border:1.5px solid rgba(255,255,255,.7);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:10;mix-blend-mode:difference;transition:width .06s,height .06s}.brush-cursor.drawing{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.brush-cursor.eraser{border-color:#f59e0bcc;border-style:dashed}.brush-cursor.eraser.drawing{border-color:#f59e0b;box-shadow:0 0 8px #f59e0b66}.cursor-pointer-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:#ffffffe6;border:1.5px solid rgba(0,0,0,.4);pointer-events:none;transform:translate(-50%,-50%);z-index:10;box-shadow:0 0 4px #00000080}.cmp-slider{position:relative;width:100%;max-width:500px;max-height:70vh;overflow:hidden;border-radius:var(--r-lg);cursor:col-resize;-webkit-user-select:none;user-select:none;background:var(--raised);flex-shrink:0;border:1px solid var(--border-md)}.cmp-img{display:block;width:100%;height:100%;object-fit:contain;pointer-events:none}.cmp-after{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.cmp-handle{position:absolute;top:0;height:100%;transform:translate(-50%);z-index:10;cursor:col-resize;display:flex;flex-direction:column;align-items:center}.cmp-line{width:2px;height:100%;background:#ffffffe6;box-shadow:0 0 12px #00000080}.cmp-knob{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 16px #00000080;color:#333;transition:transform .12s}.cmp-handle.active .cmp-knob{transform:translateY(-50%) scale(1.1);box-shadow:0 4px 24px #0009}.cmp-badge{position:absolute;bottom:12px;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ffffffe6;font-size:10px;font-weight:700;padding:3px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.07em;pointer-events:none;border:1px solid rgba(255,255,255,.1)}.cmp-badge-l{left:12px}.cmp-badge-r{right:12px}.result-view{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:500px}.result-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;max-width:560px;flex-wrap:wrap}.slider-hint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-faint);font-style:italic}.btn-use-source{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--raised);border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text-muted);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;flex-shrink:0}.btn-use-source:hover{color:var(--text);border-color:var(--accent);background:var(--accent-dim)}.img-size-badge{font-size:10px;font-weight:600;font-family:var(--font-mono);color:var(--text-faint);background:var(--active);border-radius:var(--r-xs);padding:1px 5px;flex-shrink:0;white-space:nowrap}.result-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:60px 40px;color:var(--text-muted);width:100%}.result-empty-icon{color:var(--text-faint);margin-bottom:4px}.result-empty strong{font-size:16px;font-weight:600;color:var(--text-muted)}.result-empty p{font-size:13px;color:var(--text-faint);max-width:280px;line-height:1.6}.result-processing{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:60px 40px;text-align:center;width:100%}.proc-ring-outer{position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center}.proc-ring-outer:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:var(--accent-dim);animation:proc-pulse 1.8s ease-in-out infinite}.proc-ring{width:48px;height:48px;border-radius:50%;border:3px solid var(--raised);border-top-color:var(--accent);animation:spin .9s linear infinite;position:relative;z-index:1}.proc-text strong{font-size:16px;font-weight:600;display:block;margin-bottom:6px;color:var(--text)}.proc-text p{font-size:13px;color:var(--text-muted);max-width:260px;line-height:1.6}.toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:9px;padding:12px 18px;border-radius:var(--r-lg);font-size:13px;font-weight:500;box-shadow:0 8px 32px #00000080;z-index:200;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:toast-in .25s var(--ease) both;border:1px solid;max-width:320px}.toast-ok{background:#05140ceb;border-color:#22c55e4d;color:#86efac}.toast-ok svg{color:var(--success);flex-shrink:0}.toast-err{background:#140508eb;border-color:#f43f5e4d;color:#fca5a5}.toast-err svg{color:var(--error);flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes proc-pulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:.3}}@keyframes ws-glow{0%,to{box-shadow:inset 0 0 0 1px #7c5af033}50%{box-shadow:inset 0 0 0 1px #7c5af080,inset 0 0 48px #7c5af00f}}@keyframes toast-in{0%{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 900px){:root{--sidebar-w: 256px}.tab-btn{padding:5px 10px;font-size:12px;gap:5px}.tab-btn span{display:none}}@media (max-width: 680px){.app-body{flex-direction:column}.sidebar{width:100%;max-height:50dvh;border-right:none;border-bottom:1px solid var(--border)}.brand-sub,.sdot-label{display:none}.workflow-select{min-width:140px}}
