*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0e0e12;--surface: #1a1a24;--surface-hover: #22222e;--border: #2a2a3a;--text: #e4e4ef;--text-muted: #8888a0;--accent: #6c5ce7;--accent-hover: #7f71ed;--accent-glow: rgba(108, 92, 231, .25);--danger: #ff6b6b;--success: #51cf66;--radius: 8px;--radius-lg: 12px;--font: "Inter", system-ui, -apple-system, sans-serif;--mono: "JetBrains Mono", "Fira Code", monospace}html{font-size:14px}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}header{text-align:center;padding:2rem 1rem 1rem}header h1{font-size:1.8rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--accent),#a29bfe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}main{display:grid;grid-template-columns:1fr 280px 1fr;gap:1.25rem;max-width:1400px;margin:0 auto;padding:1rem 1.25rem 3rem}@media (max-width: 1024px){main{grid-template-columns:1fr;max-width:640px}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem}.panel h2{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:1rem}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:2.5rem 1rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--accent);background:var(--accent-glow)}.drop-zone p{color:var(--text-muted)}.drop-zone-alt{font-size:.8rem;margin:.5rem 0}.canvas-wrap{position:relative;background:repeating-conic-gradient(#222,#222 25%,#1a1a1a 0%,#1a1a1a 50%) 50%/16px 16px;border-radius:var(--radius);overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:200px}.canvas-wrap canvas{max-width:100%;max-height:500px;display:block;image-rendering:auto}.seed-marker{position:absolute;width:var(--marker-size, 28px);height:var(--marker-size, 28px);border:2.5px solid #fff;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 0 2px #0009,0 0 12px var(--accent)}.seed-marker:after{content:"";position:absolute;top:50%;left:50%;width:4px;height:4px;background:#fff;border-radius:50%;transform:translate(-50%,-50%)}.hint{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:.75rem;color:var(--text-muted);pointer-events:none}.control-group{margin-bottom:1rem}.control-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:.3rem}.value-badge{font-family:var(--mono);font-size:.75rem;background:var(--bg);padding:.1em .4em;border-radius:4px;margin-left:.3rem}select,input[type=number],input[type=text]{width:100%;padding:.45rem .6rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:.85rem;outline:none;transition:border-color .15s}select:focus,input:focus{border-color:var(--accent)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:var(--bg);border-radius:3px;outline:none;margin-top:.3rem}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--surface)}input[type=color]{width:40px;height:32px;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);cursor:pointer}.hint-text{font-size:.7rem;color:var(--text-muted)}.color-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.color-row label{font-size:.8rem;color:var(--text-muted);margin-bottom:0;white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.2rem;border:none;border-radius:var(--radius);font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;width:100%;margin-top:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border);cursor:pointer}.btn-secondary:hover{background:var(--border)}.btn-sm{padding:.35rem .8rem;font-size:.78rem;margin-top:.6rem;width:100%}.status{margin-top:.75rem;padding:.5rem .75rem;border-radius:var(--radius);font-size:.8rem;font-family:var(--mono)}.status.running{background:#6c5ce71a;border:1px solid var(--accent);color:var(--accent)}.status.done{background:#51cf661a;border:1px solid var(--success);color:var(--success)}.status.error{background:#ff6b6b1a;border:1px solid var(--danger);color:var(--danger)}.status.warn{background:#ffc1071a;border:1px solid #ffc107;color:#ffc107;font-family:var(--font);font-size:.78rem;line-height:1.4}.frame-scrubber{margin-top:.75rem}.frame-scrubber label{font-size:.8rem;color:var(--text-muted)}.placeholder{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:.9rem}.export-buttons{margin-top:.75rem;display:flex;gap:.5rem}.export-buttons .btn{flex:1}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}
