:root{--bg:#fafafa;--surface:#fff;--surface-2:#f3f4f6;--text:#111827;--text-muted:#6b7280;--border:#e5e7eb;--border-strong:#d1d5db;--accent:#f97316;--accent-strong:#ea580c;--accent-bg:#f973161f;--danger:#dc2626;--danger-strong:#b91c1c;--canvas-frame:#e5e7eb;--shadow-sm:0 1px 2px #0000000f, 0 1px 3px #00000014;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000f;--radius:10px;--radius-sm:6px;color:var(--text);background:var(--bg);font-synthesis:none;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif}@media (prefers-color-scheme:dark){:root{--bg:#0f1115;--surface:#181b22;--surface-2:#21242c;--text:#f3f4f6;--text-muted:#9ca3af;--border:#2d313b;--border-strong:#3a3f4b;--accent:#fb923c;--accent-strong:#f97316;--accent-bg:#fb923c26;--canvas-frame:#1f232b;--shadow-sm:0 1px 2px #0006, 0 1px 3px #00000080;--shadow-md:0 4px 12px #00000080, 0 2px 4px #0006}}*{box-sizing:border-box}html,body,#root{overscroll-behavior:none;height:100%;margin:0;padding:0}body{overflow:hidden}button{font:inherit;color:inherit;cursor:pointer}input,button{font:inherit}kbd{background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:.85em}.app{flex-direction:column;height:100dvh;display:flex}.toolbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.toolbar-row{align-items:center;gap:12px;padding:8px 14px;display:flex}.toolbar-top{border-bottom:1px solid var(--border);padding:6px 14px}.brand{color:var(--accent-strong);letter-spacing:-.01em;flex:1;align-items:center;gap:8px;font-weight:700;display:flex}.top-actions{gap:6px;display:flex}.toolbar-tools{flex-wrap:wrap;row-gap:10px}.toolbar-tools>*{align-items:center;gap:6px;display:flex}.action-group{border-left:1px solid var(--border);gap:4px;margin-left:4px;padding-left:12px;display:flex}.action-group:first-of-type{border-left:none;margin-left:0;padding-left:0}.save-group{margin-left:auto}.tool-btn,.icon-btn,.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:6px;min-width:40px;min-height:40px;padding:8px 10px;transition:background .15s,border-color .15s,transform 50ms;display:inline-flex}.tool-btn:hover,.icon-btn:hover,.btn:hover{background:var(--surface-2)}.tool-btn:active,.btn:active{transform:translateY(1px)}.tool-btn.active,.tool-btn[aria-pressed=true]{background:var(--accent-bg);border-color:var(--accent);color:var(--accent-strong)}.tool-btn:disabled,.btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn{min-width:36px;min-height:36px;padding:6px}.icon-btn.small{min-width:30px;min-height:30px;padding:4px}.btn{padding:8px 14px;font-weight:500}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:var(--danger-strong);border-color:var(--danger-strong)}.btn-sm{min-height:30px;padding:4px 10px;font-size:.9em}.mode-toggle,.shape-toggle{background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border);gap:2px;padding:2px;display:flex}.mode-toggle .tool-btn,.shape-toggle .tool-btn{border:1px solid #0000;min-width:36px;min-height:36px;padding:6px 8px}.color-picker{flex-wrap:wrap;gap:4px;max-width:320px;display:flex}.swatch{border:2px solid var(--border-strong);cursor:pointer;border-radius:50%;width:28px;height:28px;padding:0;transition:transform 80ms,box-shadow .15s;position:relative}.swatch:hover{transform:scale(1.1)}.swatch.active{border-color:var(--text);box-shadow:0 0 0 2px var(--bg), 0 0 0 4px var(--accent)}.swatch.custom{color:#fff;text-shadow:0 0 4px #000000b3;background:conic-gradient(#ef4444,#f97316,#eab308,#22c55e,#06b6d4,#6366f1,#a855f7,#ec4899,#ef4444);justify-content:center;align-items:center;font-size:16px;font-weight:700;line-height:1;display:inline-flex}.swatch.custom input{opacity:0;cursor:pointer;position:absolute;inset:0}.brush-controls{align-items:center;gap:8px;display:flex}.size-row{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;min-width:180px;height:40px;padding:4px 8px;display:flex}.size-preview{flex-shrink:0;min-width:4px;max-width:30px;min-height:4px;max-height:30px}.size-row input[type=range]{accent-color:var(--accent);cursor:pointer;flex:1}.size-num{font-variant-numeric:tabular-nums;color:var(--text-muted);text-align:right;min-width:24px;font-size:.9em}.pressure{margin-left:2px}.stage{background:var(--canvas-frame);flex:1;justify-content:center;align-items:center;padding:16px;display:flex;overflow:hidden}.canvas-frame{justify-content:center;align-items:center;width:100%;max-width:100%;height:100%;max-height:100%;display:flex}.canvas-stack{border-radius:var(--radius);box-shadow:var(--shadow-md);background:#fff;position:relative;overflow:hidden}.drawing-canvas,.onion-canvas{width:100%;height:100%;display:block;position:absolute;inset:0}.drawing-canvas{z-index:2;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;cursor:crosshair;background:0 0}.onion-canvas{z-index:1;pointer-events:none}.frame-deck{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:8px 14px;display:flex}.frame-deck-nav{align-items:center;gap:6px;display:flex}.frame-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);width:46px;height:46px;color:var(--text);justify-content:center;align-items:center;transition:background .12s,border-color .12s,color .12s,transform 50ms;display:inline-flex}.frame-btn:hover:not(:disabled){background:var(--accent-bg);border-color:var(--accent);color:var(--accent-strong)}.frame-btn:active:not(:disabled){transform:translateY(1px)}.frame-btn:disabled{opacity:.35;cursor:not-allowed}.play-btn{background:var(--accent-bg);border-color:var(--accent);color:var(--accent-strong)}.play-btn.playing{background:var(--accent);border-color:var(--accent);color:#fff}.frame-counter{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums;color:var(--text-muted);text-align:center;min-width:70px;margin-left:8px;padding:4px 12px;font-size:.95em}.frame-num{color:var(--text);font-weight:700}.frame-sep{margin:0 4px}.frame-deck-actions{gap:8px;display:flex}.filmstrip{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;padding:8px 10px;overflow:hidden}.filmstrip ul{scrollbar-width:thin;gap:6px;margin:0;padding:0;list-style:none;display:flex;overflow:auto hidden}.filmstrip-thumb{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:6px;flex-shrink:0;width:84px;height:52px;padding:0;transition:border-color .12s,transform 80ms;position:relative;overflow:hidden}.filmstrip-thumb:hover:not(:disabled):not(.active){border-color:var(--border-strong);transform:scale(1.03)}.filmstrip-thumb img{object-fit:contain;background:#fff;width:100%;height:100%;display:block}.filmstrip-thumb.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.filmstrip-thumb:disabled{cursor:not-allowed;opacity:.6}.filmstrip-num{color:#fff;font-variant-numeric:tabular-nums;background:#000000a6;border-radius:3px;padding:1px 5px;font-size:10px;line-height:1.3;position:absolute;bottom:2px;right:2px}.onion-controls{border-radius:var(--radius-sm);z-index:10;-webkit-backdrop-filter:blur(8px);background:#0000008c;align-items:center;gap:8px;padding:4px;display:flex;position:absolute;top:10px;right:10px}.onion-controls.disabled{opacity:.4}.onion-toggle{color:#fff;background:#ffffff1f;border:1px solid #0000;min-width:38px;min-height:38px;padding:6px}.onion-toggle:hover:not(:disabled){background:#ffffff38}.onion-toggle.active{background:var(--accent);border-color:var(--accent);color:#fff}.onion-opacity{width:110px;accent-color:var(--accent);margin-right:4px}.modal-backdrop{z-index:100;background:#0000008c;justify-content:center;align-items:center;padding:16px;animation:.15s ease-out fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:440px;box-shadow:var(--shadow-md);padding:20px 24px;animation:.18s ease-out pop-in}.modal-wide{max-width:720px;max-height:80vh;overflow:auto}.modal h2{align-items:center;gap:8px;margin:0 0 12px;font-size:1.25rem;display:flex}.modal h2 svg{color:var(--accent)}.modal p{color:var(--text-muted);margin:0 0 16px;line-height:1.5}.modal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-header h2{margin:0}.modal-actions{justify-content:flex-end;gap:10px;display:flex}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pop-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.help-hero{margin-bottom:18px;padding-top:4px;display:block;position:relative}.modal-close{position:absolute;top:0;right:0}.hero-title{letter-spacing:.04em;color:var(--accent-strong);justify-content:center;align-items:center;gap:14px;margin:0;padding:12px 48px 0;font-size:2.4rem;font-weight:800;line-height:1;display:flex}.hero-title svg{color:var(--accent);flex-shrink:0}@media (width<=480px){.hero-title{gap:10px;padding:8px 40px 0;font-size:1.7rem}}.help-body ul{padding-left:20px;line-height:1.6}.help-body li{margin-bottom:6px}.help-section-title{color:var(--accent-strong);margin:18px 0 8px;font-size:1rem;font-weight:700}.help-body details{border-top:1px solid var(--border);margin-top:14px;padding-top:12px}.help-body summary{cursor:pointer;font-weight:600}.shortcuts{margin-top:10px;padding-left:0;list-style:none}.shortcuts li{margin-bottom:6px}.hero-closer{border-top:1px solid var(--border);text-align:center;margin:18px 0 0;padding:16px 18px 14px;line-height:1.55}.hero-closer p{color:var(--accent-strong);margin:0;font-size:1.05rem;font-style:italic}.hero-closer strong{color:var(--accent);font-style:normal}.hero-closer-signoff{letter-spacing:.04em;font-style:italic;font-weight:600;color:var(--text-muted)!important;margin-top:10px!important}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin:0;padding:0;list-style:none;display:grid}.gallery-item{background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.thumb-btn{aspect-ratio:8/5;cursor:pointer;background:#fff;border:none;width:100%;padding:0;display:block;overflow:hidden}.thumb-btn img{object-fit:contain;background:#fff;width:100%;height:100%;display:block}.thumb-btn:hover img{transition:transform .15s;transform:scale(1.02)}.gallery-meta{justify-content:space-between;align-items:center;gap:6px;padding:6px 10px;display:flex}.gallery-title{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.85em;overflow:hidden}.confirm-inline{gap:4px;display:flex}.gallery-empty,.gallery-error{text-align:center;color:var(--text-muted);padding:30px 10px;line-height:1.5}.gallery-error{color:var(--danger)}.toast-stack{z-index:200;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{pointer-events:auto;background:var(--text);color:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-md);cursor:pointer;border:none;padding:10px 16px;font-size:.95em;animation:.2s ease-out toast-in}.toast-success{color:#fff;background:#16a34a}.toast-error{background:var(--danger);color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (width<=720px){.toolbar-row{padding:6px 10px}.brand span{display:none}.color-picker{flex-basis:100%;order:99;max-width:100%}.save-group{margin-left:0}.save-group .btn span{display:none}.stage{padding:8px}}@media (width<=480px){.toolbar-tools{gap:8px}.size-row{min-width:140px}}
