:root{--panel-w: 400px;--left-w: 190px}:root,[data-theme=dark]{--bg: #000000;--stage: #000000;--panel: #0b0b0b;--panel-2: #161616;--line: #262626;--line-soft: #1b1b1b;--text: #f4f4f4;--text-dim: #a0a0a0;--text-mute: #5f5f5f;--accent: #f4f4f4;--accent-soft: #ffffff;--on-accent: #000000;--toggle-off: #34343a;--input-bg: #000000;--board-shadow: 0 30px 80px -30px rgba(0, 0, 0, .9), inset 0 0 0 1px rgba(255, 255, 255, .06);--grid-line: rgba(255, 255, 255, .4)}[data-theme=light]{--bg: #f2f2f2;--stage: #ececec;--panel: #ffffff;--panel-2: #f4f4f4;--line: #e2e2e2;--line-soft: #ededed;--text: #0a0a0a;--text-dim: #565656;--text-mute: #9a9a9a;--accent: #0a0a0a;--accent-soft: #000000;--on-accent: #ffffff;--toggle-off: #cfcfcf;--input-bg: #f7f7f7;--board-shadow: 0 24px 60px -24px rgba(0, 0, 0, .28), inset 0 0 0 1px rgba(0, 0, 0, .07);--grid-line: rgba(255, 255, 255, .75)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}.app{--col-left: var(--left-w, 190px);--col-right: var(--panel-w, 400px);display:grid;grid-template-columns:var(--col-left) minmax(0,1fr) var(--col-right);height:100vh;transition:grid-template-columns .25s ease}.app.left-collapsed{--col-left: 0px}.app.panel-collapsed{--col-right: 0px}.left-reopen{position:absolute;top:22px;left:22px;width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--text-dim);font-size:16px;cursor:pointer;z-index:6;box-shadow:0 8px 24px -10px #0009}.left-reopen:hover{color:var(--text)}.left-panel{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100vh;overflow:hidden;width:var(--left-w, 190px);min-width:0}.left-scroll{overflow-y:auto;overflow-x:hidden;flex:1;padding-bottom:32px}.left-scroll::-webkit-scrollbar{width:10px}.left-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px;border:3px solid var(--panel)}.left-panel .preset-grid{grid-template-columns:repeat(2,1fr)}.logo-text{display:flex;flex-direction:column;line-height:1.15}.logo-text small{font-size:10px;font-weight:500;color:var(--text-mute);letter-spacing:0}.brand-right{justify-content:flex-end}.up-save-btn{width:calc(100% - 28px);margin:0 14px 8px;padding:8px;border:1px dashed var(--line);border-radius:8px;background:transparent;color:var(--text-dim);font-size:12px;font-weight:500;cursor:pointer}.up-save-btn:hover{color:var(--text);border-color:var(--text-mute)}.up-name-row{display:flex;gap:6px;padding:0 14px 8px}.up-input{flex:1;min-width:0;padding:7px 9px;border:1px solid var(--line);border-radius:8px;background:var(--input-bg);color:var(--text);font-size:12px}.up-input:focus{outline:none;border-color:var(--text-mute)}.up-confirm{width:30px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--text-dim);cursor:pointer}.up-confirm:hover{color:var(--text)}.up-empty{margin:0 14px 10px;font-size:11px;line-height:1.4;color:var(--text-mute)}.up-list{display:flex;flex-direction:column;gap:4px;padding:0 10px 6px}.up-item{position:relative;display:flex;align-items:center}.up-load{flex:1;min-width:0;display:flex;align-items:center;gap:9px;padding:5px 8px;border:none;border-radius:8px;background:transparent;color:var(--text);cursor:pointer;text-align:left}.up-load:hover{background:var(--hover, rgba(127, 127, 127, .1))}.up-swatch{width:30px;height:22px;border-radius:5px;flex:none;border:1px solid var(--line)}.up-name{flex:1;min-width:0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.up-actions{position:absolute;right:4px;top:0;bottom:0;display:flex;align-items:center;gap:1px;padding-left:16px;opacity:0;background:linear-gradient(90deg,transparent,var(--panel) 35%);pointer-events:none}.up-item:hover .up-actions{opacity:1;pointer-events:auto}.up-act{width:22px;height:24px;border:none;border-radius:6px;background:transparent;color:var(--text-mute);cursor:pointer;font-size:12px;flex:none}.up-act:hover{color:var(--text);background:var(--hover, rgba(127, 127, 127, .1))}.section-actions{display:flex;gap:6px}.palette-card{width:min(440px,100%);max-height:none}.palette-input{width:100%;box-sizing:border-box;margin-top:4px;padding:11px 12px;font-family:var(--mono, ui-monospace, monospace);font-size:12px;line-height:1.5;color:var(--text);background:var(--input-bg);border:1px solid var(--line);border-radius:10px;resize:vertical}.palette-input:focus{outline:none;border-color:var(--text-mute)}.palette-file-row{display:flex;align-items:center;gap:10px;margin-top:8px}.palette-file-hint{font-size:11px;color:var(--text-mute);font-family:var(--mono, ui-monospace, monospace)}.palette-preview{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.palette-chip{width:26px;height:26px;border-radius:6px;border:1px solid var(--line)}.palette-hint{margin:14px 0 0;font-size:12px;color:var(--text-mute)}.palette-apply{width:100%;margin-top:18px;padding:11px}.export-note{margin:9px 2px 0;font-size:10.5px;line-height:1.45;color:var(--text-mute)}.usage-lock{width:340px;max-width:100%;max-height:none;display:flex;flex-direction:column;align-items:center;text-align:center;padding:34px 28px 28px}.gate-dot{width:26px;height:26px;margin-bottom:16px}.gate-title{margin:0;font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.gate-sub{margin:6px 0 20px;font-size:13px;color:var(--text-mute)}.gate-input{width:100%;box-sizing:border-box;padding:11px 13px;font-family:inherit;font-size:14px;color:var(--text);background:var(--input-bg);border:1px solid var(--line);border-radius:9px;text-align:center}.gate-input:focus{outline:none;border-color:var(--text-mute)}.gate-input-err{border-color:#e0564f}.gate-err{margin-top:8px;font-size:12px;color:#e0564f}.gate-btn{width:100%;margin-top:16px;padding:11px}.usage-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.usage-card{width:min(880px,100%);max-height:88vh;overflow-y:auto;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:22px 24px 26px;box-shadow:0 24px 80px #0006}.usage-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.usage-head h2{margin:0;font-size:18px;font-weight:600;color:var(--text)}.usage-sub{margin:4px 0 0;font-size:12px;color:var(--text-mute)}.usage-head-actions{display:flex;gap:6px;flex:none}.usage-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px 28px}.usage-section-wide{grid-column:1 / -1}.usage-section h3{margin:0 0 10px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.usage-bars{display:flex;flex-direction:column;gap:7px}.usage-bar-row{display:grid;grid-template-columns:120px 1fr 32px;align-items:center;gap:10px}.usage-bar-label{font-size:12px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usage-bar-track{height:8px;border-radius:4px;background:var(--hover, rgba(127, 127, 127, .12));overflow:hidden}.usage-bar-fill{display:block;height:100%;border-radius:4px;background:var(--accent);min-width:3px}.usage-bar-count{font-size:12px;font-variant-numeric:tabular-nums;text-align:right;color:var(--text-dim)}.usage-empty{margin:0;font-size:12px;color:var(--text-mute)}.usage-empty-big{margin:30px 0;text-align:center;font-size:13px;line-height:1.5;color:var(--text-mute)}@media (max-width: 640px){.usage-grid{grid-template-columns:1fr}}.panel-reopen{position:absolute;top:22px;right:22px;width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--text-dim);font-size:16px;cursor:pointer;z-index:6;box-shadow:0 8px 24px -10px #0009}.panel-reopen:hover{color:var(--text)}.stage{position:relative;padding:28px;min-width:0;display:flex;background:var(--stage)}.board-area{flex:1;display:flex;align-items:center;justify-content:center;min-width:0;position:relative;overflow:hidden}.artboard{position:relative;touch-action:none;cursor:grab;will-change:transform}.artboard:active{cursor:grabbing}.artboard-clip{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;overflow:hidden;box-shadow:var(--board-shadow);background:#000}.mesh-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible}.grid-overlay path{fill:none;stroke:var(--grid-line);stroke-width:1;opacity:.6}.handles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.handle{position:absolute;width:20px;height:20px;border-radius:50%;transform:translate(-50%,-50%);border:2px solid rgba(255,255,255,.92);box-shadow:0 2px 8px #00000080,0 0 0 1px #00000040;cursor:grab;pointer-events:auto;padding:0;transition:transform .12s,box-shadow .12s}.handle:hover{transform:translate(-50%,-50%) scale(1.18)}.handle:active{cursor:grabbing}.handle.selected{box-shadow:0 0 0 3px var(--accent),0 2px 10px #0009;transform:translate(-50%,-50%) scale(1.22)}.grid-handle{width:13px;height:13px;border-width:2px}.handle-lines line{stroke:var(--accent);stroke-width:1.5;opacity:.9}.bez-handle{position:absolute;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);background:#fff;border:2px solid var(--accent);box-shadow:0 1px 5px #0006;cursor:grab;pointer-events:auto;padding:0;transition:transform .1s}.bez-handle:hover{transform:translate(-50%,-50%) scale(1.25)}.bez-handle:active{cursor:grabbing}.panel{background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;height:100vh;overflow:hidden;width:var(--panel-w, 400px);min-width:0}.brand{display:flex;align-items:center;justify-content:space-between;min-height:60px;box-sizing:border-box;padding:12px 14px 12px 18px;border-bottom:1px solid var(--line-soft)}.logo{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px;letter-spacing:-.01em;white-space:nowrap}.logo-text{white-space:nowrap}.logo-dot{width:16px;height:16px;border-radius:50%;background:conic-gradient(from 0deg,var(--text),var(--text-mute),var(--text),var(--text-mute),var(--text))}.brand-actions{display:flex;gap:2px;align-items:center}.icon-btn{width:30px;padding:6px 0;text-align:center}.hdr-btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;height:28px;min-width:28px;padding:0 6px;font-family:inherit;font-size:14px;font-weight:500;line-height:1;color:var(--text-mute);background:transparent;border:none;border-radius:7px;cursor:pointer;transition:background .12s,color .12s}.hdr-btn:hover:not(:disabled){color:var(--text);background:var(--hover, rgba(127, 127, 127, .1))}.hdr-btn:disabled{opacity:.3;cursor:default}.hdr-btn-text{padding:0 10px;font-size:12px;color:var(--text-dim)}.hdr-btn svg{display:block}.hdr-toggle{color:var(--text-dim)}.hdr-ico{font-size:13px}.hdr-sep{width:1px;height:18px;background:var(--line);margin:0 5px;flex:none}.menu-wrap{position:relative}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.menu{position:absolute;right:0;top:calc(100% + 6px);z-index:41;min-width:168px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:5px;box-shadow:0 18px 40px -14px #0009}.menu-item{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--text);font-family:inherit;font-size:13px;padding:8px 10px;border-radius:7px;cursor:pointer}.menu-item:hover{background:var(--panel-2)}.menu-sep{height:1px;background:var(--line-soft);margin:5px 4px}.theme-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 18px;border-bottom:1px solid var(--line-soft)}.theme-bar-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute);white-space:nowrap}.theme-seg{flex:1;max-width:210px}.panel-scroll{overflow-y:auto;overflow-x:hidden;padding:0 0 48px;flex:1;min-width:0}.panel-scroll::-webkit-scrollbar{width:10px}.panel-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px;border:3px solid var(--panel)}.section{padding:15px 18px;border-bottom:1px solid var(--line-soft)}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;min-height:20px}.section-head h3{margin:0;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-mute)}.ctrl{margin-bottom:13px;display:flex;flex-direction:column}.ctrl:last-child{margin-bottom:0}.ctrl-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.ctrl-label{font-size:13px;color:var(--text-dim)}.ctrl-val{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text)}.field-label{font-size:12px;color:var(--text-dim);margin-bottom:8px}.inline-toggle{flex-direction:row;align-items:center;justify-content:space-between}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:4px;background:linear-gradient(to right,var(--accent) var(--pct, 50%),var(--line) var(--pct, 50%));outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--on-accent);cursor:pointer;box-shadow:0 1px 4px #0006,0 0 0 2px var(--accent);transition:transform .1s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.segmented{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:3px;background:var(--panel-2);padding:3px;border-radius:8px;border:1px solid var(--line-soft)}.seg{border:none;background:transparent;color:var(--text-dim);font-size:11.5px;font-weight:500;padding:7px 4px;border-radius:6px;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .12s,color .12s}.seg:hover{color:var(--text)}.seg.active{background:var(--accent);color:var(--on-accent)}.toggle{width:38px;height:22px;border-radius:12px;background:var(--toggle-off);border:none;position:relative;cursor:pointer;transition:background .15s;padding:0}.toggle.on{background:var(--accent)}.knob{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s;box-shadow:0 1px 3px #00000059,0 0 0 1px #00000014}.toggle.on .knob{transform:translate(16px);background:var(--on-accent)}.ghost-btn,.add-btn,.primary-btn{font-family:inherit;font-size:12px;font-weight:500;border-radius:7px;cursor:pointer;transition:all .12s;border:1px solid var(--line)}.ghost-btn{background:var(--panel-2);color:var(--text-dim);padding:6px 10px}.ghost-btn:hover{color:var(--text);border-color:var(--text-mute)}.add-btn{background:transparent;color:var(--accent-soft);border-color:transparent;padding:2px 6px}.add-btn:hover{filter:brightness(1.2)}.add-btn:disabled{color:var(--text-mute);cursor:not-allowed}.add-select{background:transparent;color:var(--accent-soft);border:none;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;outline:none}.add-select option{background:var(--panel);color:var(--text)}.primary-btn{background:var(--accent);color:var(--on-accent);border-color:transparent;padding:8px 14px;flex:1}.primary-btn:hover{background:var(--accent-soft)}.preset-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.preset{background:none;border:none;padding:0;cursor:pointer;display:flex;flex-direction:column;gap:5px;align-items:center}.preset-swatch{width:100%;aspect-ratio:1;border-radius:9px;border:1px solid rgba(128,128,128,.18);transition:transform .12s,box-shadow .12s}.preset:hover .preset-swatch{transform:translateY(-2px);box-shadow:0 6px 16px -6px #0009}.preset-name{font-size:10px;color:var(--text-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.swatches{display:flex;flex-direction:column;gap:6px}.swatch-row{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:background .12s,border-color .12s}.swatch-row:hover{background:var(--panel-2)}.swatch-row.active{background:var(--panel-2);border-color:var(--line)}.swatch{width:26px;height:26px;border-radius:7px;border:1px solid rgba(128,128,128,.25);cursor:pointer;position:relative;overflow:hidden;flex-shrink:0}.swatch input[type=color]{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;width:150%;height:150%;border:none;padding:0;cursor:pointer;opacity:0}.hex-input{flex:1;background:var(--input-bg);border:1px solid var(--line-soft);border-radius:6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:12px;padding:6px 8px;width:0;outline:none}.hex-input:focus{border-color:var(--accent)}.del-btn{background:transparent;border:none;color:var(--text-mute);cursor:pointer;font-size:12px;padding:4px 6px;border-radius:6px;flex-shrink:0}.del-btn:hover{color:var(--text);background:var(--panel-2)}.del-btn:disabled{opacity:.3;cursor:not-allowed}.hint{font-size:11px;color:var(--text-mute);margin:10px 2px 0;line-height:1.5}.cp-anchor{position:relative;flex-shrink:0}.cp-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50}.cp-pop{position:absolute;top:calc(100% + 6px);left:0;z-index:51;width:236px}.cp{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:12px;box-shadow:0 18px 44px -14px #000000a6;display:flex;flex-direction:column;gap:10px}.cp-sv{position:relative;width:100%;height:130px;border-radius:8px;cursor:crosshair;touch-action:none}.cp-sv-thumb{position:absolute;width:14px;height:14px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #0006;transform:translate(-50%,-50%);pointer-events:none}.cp-hue{position:relative;width:100%;height:12px;border-radius:6px;cursor:pointer;touch-action:none;background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.cp-hue-thumb{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #0006;transform:translate(-50%,-50%);pointer-events:none}.cp-row{display:flex;align-items:center;gap:6px}.cp-preview{width:26px;height:26px;border-radius:6px;border:1px solid var(--line);flex-shrink:0}.cp-eye{width:28px;height:26px;border:1px solid var(--line);background:var(--input-bg);color:var(--text-dim);border-radius:6px;cursor:pointer;flex-shrink:0}.cp-eye:hover{color:var(--text)}.cp-ctrl{display:flex;flex-direction:column;gap:5px}.cp-ctrl-row{display:flex;justify-content:space-between;font-size:11px;color:var(--text-dim)}.cp-val{font-family:JetBrains Mono,monospace;color:var(--text)}.cp-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:10px;border-radius:6px;background:var(--track);border:1px solid var(--line-soft);outline:none}.cp-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid var(--accent);cursor:pointer;box-shadow:0 1px 4px #0006}.cp-swatches{display:flex;flex-wrap:wrap;gap:5px}.cp-swatches button{width:20px;height:20px;border-radius:5px;border:1px solid rgba(128,128,128,.3);cursor:pointer;padding:0}.line-actions{display:flex;gap:6px;margin-top:8px}.line-actions .ghost-btn{flex:1}.variant-previews{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:13px}.variant-card{background:var(--panel-2);border:1px solid var(--line-soft);border-radius:10px;padding:6px;cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:border-color .12s,transform .12s}.variant-card:hover{transform:translateY(-1px)}.variant-card.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.variant-thumb{width:100%;aspect-ratio:16 / 10;border-radius:6px;border:1px solid rgba(128,128,128,.18)}.variant-tag{font-size:11px;color:var(--text-dim);text-align:center}.vgrid{display:grid;gap:5px}.vgrid-cell{aspect-ratio:1;border-radius:6px;border:1px solid rgba(128,128,128,.2);cursor:pointer;padding:0;transition:transform .1s,box-shadow .1s}.vgrid-cell:hover{transform:scale(1.08)}.vgrid-cell:active{cursor:grabbing}.vgrid-cell.active{box-shadow:0 0 0 2px var(--accent)}.vgrid-cell.drop-target{box-shadow:0 0 0 2px var(--accent);transform:scale(1.12)}.vgrid-history{display:flex;gap:6px;margin-top:10px}.vgrid-history .ghost-btn{flex:1}.stepper-row{display:flex;gap:8px}.stepper{display:flex;align-items:center;gap:6px;background:var(--panel-2);border:1px solid var(--line-soft);border-radius:8px;padding:4px 8px;flex:1}.stepper-label{font-size:11px;color:var(--text-mute);margin-right:auto}.stepper button{width:22px;height:22px;border-radius:6px;border:none;background:var(--line);color:var(--text);cursor:pointer;font-size:14px;line-height:1}.stepper button:disabled{opacity:.35;cursor:not-allowed}.stepper-val{font-family:JetBrains Mono,monospace;font-size:13px;min-width:14px;text-align:center}.eff-list{display:flex;flex-direction:column;gap:6px}.eff{background:var(--panel-2);border:1px solid var(--line-soft);border-radius:8px;overflow:hidden}.eff-head{display:flex;align-items:center;gap:8px;padding:7px 8px}.eye{background:transparent;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0;width:16px}.eye:not(.on){color:var(--text-mute)}.eff-name{flex:1;text-align:left;background:transparent;border:none;color:var(--text);font-size:12.5px;font-family:inherit;cursor:pointer;padding:0}.eff-body{padding:4px 10px 12px;border-top:1px solid var(--line-soft)}.eff-body .ctrl:first-child{margin-top:10px}.export-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.etab{background:var(--panel-2);border:1px solid var(--line-soft);color:var(--text-dim);font-size:11px;font-family:JetBrains Mono,monospace;padding:5px 9px;border-radius:6px;cursor:pointer}.etab.active{background:var(--accent);color:var(--on-accent);border-color:transparent}.code-block{background:var(--input-bg);border:1px solid var(--line-soft);border-radius:8px;padding:12px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.6;color:var(--text-dim);max-height:170px;overflow:auto;margin:0 0 10px;white-space:pre}.export-actions{display:flex;gap:6px}.record-btn{width:100%;margin-top:8px}.view-toolbar{position:absolute;bottom:18px;right:18px;display:flex;align-items:center;gap:2px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:3px;box-shadow:0 8px 24px -10px #0009;z-index:5}.tool-bar{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:3px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:3px;box-shadow:0 8px 24px -10px #0009;z-index:5}.tool{border:none;background:transparent;color:var(--text-dim);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;padding:6px 11px;border-radius:7px}.tool:hover{color:var(--text)}.tool.active{background:var(--accent);color:var(--on-accent)}.tool-orient{display:flex;gap:2px;margin-left:3px;padding-left:5px;border-left:1px solid var(--line)}.tool-orient button{border:none;background:transparent;color:var(--text-dim);cursor:pointer;width:26px;height:26px;border-radius:6px;font-size:13px}.tool-orient button.active{background:var(--accent);color:var(--on-accent)}.tool-hint{font-size:11px;color:var(--text-mute);padding:0 8px 0 6px;white-space:nowrap}.artboard.adding-line{cursor:crosshair}.playback-bar{position:absolute;bottom:18px;left:50%;transform:translate(-50%);width:min(420px,60%);background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:8px 12px 10px;box-shadow:0 8px 24px -10px #0009;z-index:5}.playback-row{display:flex;align-items:center;gap:4px;margin-bottom:8px}.playback-row button{border:none;background:transparent;color:var(--text-dim);font-family:inherit;font-size:12px;cursor:pointer;width:28px;height:26px;border-radius:7px}.playback-row button:hover{background:var(--panel-2);color:var(--text)}.playback-row button.active{background:var(--accent);color:var(--on-accent)}.playback-time{margin-left:auto;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-mute)}.scrubber{width:100%}.view-toolbar button{border:none;background:transparent;color:var(--text-dim);font-family:inherit;font-size:14px;cursor:pointer;width:30px;height:28px;border-radius:7px;transition:background .12s,color .12s}.view-toolbar button:hover{background:var(--panel-2);color:var(--text)}.view-zoom{width:auto!important;min-width:52px;padding:0 8px;font-family:JetBrains Mono,monospace!important;font-size:12px!important}.view-toolbar button.active{background:var(--accent);color:var(--on-accent)}.view-sep{width:1px;align-self:stretch;background:var(--line);margin:2px}
