:root{--bg0: #070708;--bg1: #0c0c0e;--glow-a: rgba(255, 255, 255, .05);--glow-b: rgba(255, 255, 255, .04);--glow-c: rgba(255, 255, 255, .06);--glass-bg: rgba(16, 16, 20, .7);--glass-bg-strong: rgba(13, 13, 17, .86);--line: rgba(255, 255, 255, .075);--line-strong: rgba(255, 255, 255, .16);--rim: inset 0 1px 0 rgba(255, 255, 255, .06);--fill-1: rgba(255, 255, 255, .045);--fill-2: rgba(255, 255, 255, .09);--text: #f0f0f3;--text-2: #9b9ba4;--text-3: #5d5d66;--danger: #ff6b6b;--r-xl: 26px;--r-lg: 20px;--r-md: 14px;--r-sm: 10px;--shadow-float: 0 24px 70px rgba(0, 0, 0, .5), 0 4px 14px rgba(0, 0, 0, .28);--shadow-soft: 0 10px 30px rgba(0, 0, 0, .35), 0 2px 8px rgba(0, 0, 0, .22);--shadow-sheet: 0 40px 140px rgba(0, 0, 0, .62), 0 8px 28px rgba(0, 0, 0, .35);--t: .15s;--ease: cubic-bezier(.3, .7, .3, 1);--spring: cubic-bezier(.3, 1.36, .36, 1);--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: ui-monospace, "SF Mono", SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;--stage-inset: 18px}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{background:var(--bg0);color:var(--text);font:13px/1.45 var(--font-ui);-webkit-font-smoothing:antialiased;overflow:hidden}::selection{background:#ffffff38}:focus{outline:none}:focus-visible{outline:2px solid rgba(255,255,255,.65);outline-offset:2px;border-radius:6px}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}svg{display:block;flex-shrink:0}.glass{background:linear-gradient(#ffffff0d,#ffffff04 40%,#fff0 75%),var(--glass-bg);-webkit-backdrop-filter:blur(24px) saturate(1.5);backdrop-filter:blur(24px) saturate(1.5);border:1px solid var(--line);box-shadow:var(--shadow-float),var(--rim)}.glass-strong{background:linear-gradient(#ffffff0d,#ffffff03 45%,#fff0 80%),var(--glass-bg-strong);-webkit-backdrop-filter:blur(28px) saturate(1.5);backdrop-filter:blur(28px) saturate(1.5);border:1px solid var(--line);box-shadow:var(--shadow-float),var(--rim)}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.glass{background:#121216f0}.glass-strong{background:#0e0e12f7}}#app{position:relative;overflow:hidden}.ambient{position:fixed;inset:0;z-index:0;background:var(--bg0)}.ambient:before{content:"";position:absolute;inset:-10%;background:radial-gradient(46% 42% at 16% 8%,var(--glow-a),transparent 70%),radial-gradient(52% 48% at 86% 26%,var(--glow-b),transparent 70%),radial-gradient(60% 54% at 50% 104%,var(--glow-c),transparent 72%);transition:opacity .6s ease}.ambient:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 95% at 50% 42%,transparent 58%,rgba(0,0,0,.45) 100%)}.stage{position:fixed;inset:0;z-index:1;display:grid;place-items:center}canvas#view{display:block;border-radius:var(--r-lg);background:#000;box-shadow:0 0 0 1px #ffffff12,0 30px 110px #0000008c,0 6px 24px #00000059,0 0 140px var(--glow-b);transition:border-radius .26s var(--ease)}.chrome{position:fixed;inset:0;z-index:20;pointer-events:none;transition:opacity .28s ease}.chrome>*{pointer-events:auto}@keyframes chrome-in{0%{opacity:0;translate:0 14px}}.island,.dock,.corner{animation:chrome-in .64s var(--spring) backwards}.dock{animation-delay:70ms}.corner{animation-delay:.13s}.island{position:absolute;top:18px;display:flex;align-items:center}.island-brand{left:18px;height:44px;gap:9px;padding:0 15px 0 13px;border-radius:16px;user-select:none;border-color:transparent;box-shadow:var(--shadow-soft)}.island-brand svg{width:18px;height:18px;filter:drop-shadow(0 0 7px rgba(140,120,255,.4))}.island-brand h1{font:600 13.5px var(--font-ui);letter-spacing:.02em}.island-utils{right:18px;gap:8px}.glass-btn{width:44px;height:44px;display:grid;place-items:center;border-radius:15px;color:var(--text-2);background:linear-gradient(#ffffff0d,#fff0 70%),var(--glass-bg);-webkit-backdrop-filter:blur(20px) saturate(1.5);backdrop-filter:blur(20px) saturate(1.5);border:1px solid var(--line);box-shadow:var(--shadow-soft),var(--rim);transition:color var(--t),background var(--t),transform .32s var(--spring),box-shadow var(--t)}.glass-btn:hover{color:var(--text);background:linear-gradient(#ffffff12,#ffffff03 70%),var(--glass-bg);transform:translateY(-2px);box-shadow:var(--shadow-float),var(--rim)}.glass-btn:active{transform:scale(.95)}.glass-btn svg{width:16px;height:16px}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.glass-btn{background:#121216f0}}.dock{position:absolute;left:50%;bottom:18px;transform:translate(-50%);display:flex;align-items:center;gap:9px;height:56px;padding:0 11px;border-radius:var(--r-xl);max-width:calc(100vw - 24px)}.dock-group{display:flex;align-items:center;gap:7px}.dock-sep{width:1px;height:22px;background:var(--line);flex-shrink:0}.dock-btn{height:38px;min-width:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;border-radius:13px;color:var(--text-2);background:var(--fill-1);border:1px solid rgba(255,255,255,.04);font:500 11.5px var(--font-ui);white-space:nowrap;transition:color var(--t),background var(--t),transform var(--t)}.dock-btn:hover{color:var(--text);background:var(--fill-2)}.dock-btn:active{transform:scale(.96)}.dock-btn svg{width:14px;height:14px}.dock-btn svg:last-child:not(:first-child){width:11px;height:11px;opacity:.55}.dock-play{width:38px;padding:0}.dock-btn-label{font:500 11.5px var(--font-mono);letter-spacing:.02em}.btn{height:32px;display:inline-flex;align-items:center;gap:7px;padding:0 13px;border-radius:12px;font:500 12px var(--font-ui);letter-spacing:.01em;border:1px solid transparent;transition:background var(--t),border-color var(--t),transform var(--t),opacity var(--t),box-shadow var(--t);white-space:nowrap}.btn:active{transform:scale(.97)}.btn svg{width:14px;height:14px}.btn-primary{background:#fff;color:#0a0a0c;box-shadow:0 6px 22px #ffffff21,0 2px 8px #0000004d}.btn-primary:hover{background:#ececf0;box-shadow:0 8px 28px #ffffff2e,0 2px 8px #0000004d}.btn-primary.dock-main{height:38px;padding:0 17px;border-radius:13px;font-weight:600}.btn-ghost{background:var(--fill-1);border-color:var(--line);color:var(--text)}.btn-ghost:hover{background:var(--fill-2);border-color:var(--line-strong)}.btn[disabled]{opacity:.38;cursor:not-allowed;transform:none}.icon-btn{width:28px;height:28px;display:grid;place-items:center;border-radius:9px;color:var(--text-2);transition:color var(--t),background var(--t)}.icon-btn:hover{color:var(--text);background:var(--fill-2)}.icon-btn svg{width:15px;height:15px}.icon-btn.small{width:24px;height:24px}.icon-btn.small svg{width:13px;height:13px}.scrub{position:relative;width:104px;height:38px;cursor:pointer;flex-shrink:0}.scrub:before{content:"";position:absolute;left:0;right:0;top:50%;height:3px;margin-top:-1.5px;border-radius:2px;background:#ffffff21}.scrub-fill{position:absolute;left:0;top:50%;height:3px;margin-top:-1.5px;width:0;border-radius:2px;background:#ffffffb3;pointer-events:none}.scrub-fill:after{content:"";position:absolute;right:-4px;top:50%;width:9px;height:9px;margin-top:-4.5px;border-radius:50%;background:#fff;box-shadow:0 1px 6px #0000008c;transition:transform var(--t)}.scrub:hover .scrub-fill,.scrub.scrubbing .scrub-fill{background:#fffffff2}.scrub:hover .scrub-fill:after,.scrub.scrubbing .scrub-fill:after{transform:scale(1.3)}.corner{position:absolute;bottom:18px;display:flex;align-items:center;gap:8px}.corner-l{left:18px}.corner-r{right:18px}.chip{height:40px;display:inline-flex;align-items:center;gap:8px;padding:0 14px;border-radius:14px;color:var(--text-2);font:500 11.5px var(--font-ui);white-space:nowrap;transition:color var(--t),transform .32s var(--spring),border-color var(--t)}.chip svg{width:14px;height:14px}button.chip:hover{color:var(--text);transform:translateY(-2px)}button.chip:active{transform:scale(.96)}.chip.on{color:var(--text);border-color:#ffffff47}.chip b{font-weight:600;color:var(--text)}.chip .dim{color:var(--text-3)}.chip-quiet{color:var(--text-2);font:10.5px var(--font-mono);cursor:default}a.chip{text-decoration:none}.chip-link{color:var(--text-2);font:500 11px var(--font-mono);letter-spacing:.04em}.chip-link:hover{color:var(--text);transform:translateY(-2px)}.meta-label{font:10.5px var(--font-mono);letter-spacing:.02em;font-variant-numeric:tabular-nums}.fpanel{position:fixed;top:80px;display:flex;flex-direction:column;max-height:min(76vh,820px);max-width:calc(100vw - 20px);border-radius:var(--r-lg);opacity:0;visibility:hidden;transform:translateY(16px) scale(.97);transition:opacity .26s ease,transform .48s var(--spring),visibility 0s linear .26s}.fpanel.open{opacity:1;visibility:visible;transform:none;transition:opacity .22s ease,transform .48s var(--spring)}.fpanel-styles{left:18px}.fpanel-inspector{right:18px}.fpanel-library{left:50%;margin-left:-168px}.fpanel.placed{right:auto;margin:0}.fpanel.dragged{transition:opacity .22s ease}.fpanel-head{display:flex;align-items:center;gap:6px;padding:11px 12px 9px 17px;cursor:grab;user-select:none;flex-shrink:0}.fpanel.dragged .fpanel-head{cursor:grabbing}.fpanel-title{flex:1;min-width:0;font:600 12.5px var(--font-ui);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fpanel-actions{display:flex;align-items:center;gap:3px}.fpanel-body{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:2px 14px 16px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.14) transparent}.fpanel-body::-webkit-scrollbar{width:8px}.fpanel-body::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px;border:2px solid transparent;background-clip:content-box}.section{padding:12px 0 16px;border-bottom:1px solid var(--line)}.section:last-child{border-bottom:none;padding-bottom:6px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}.section-title{font:600 10px var(--font-mono);text-transform:uppercase;letter-spacing:.16em;color:#bdbdc8;text-shadow:0 1px 2px rgba(0,0,0,.45);user-select:none}.section-head .icon-btn{color:var(--text-3);margin:-4px 0}.section-head .icon-btn:hover{color:var(--text)}.fam-chips{display:flex;flex-wrap:wrap;gap:4px;padding-top:4px;margin-bottom:12px}.fam-chip{font:10px var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:#c9c9d3;padding:4px 9px;border-radius:8px;background:#07070b6b;border:1px solid rgba(255,255,255,.05);text-shadow:0 1px 2px rgba(0,0,0,.55);transition:color var(--t),background var(--t),border-color var(--t)}.fam-chip:hover{color:#fff;background:#07070b99;border-color:var(--line)}.fam-chip.active{background:#ffffff29;border-color:#ffffff73;color:#fff;text-shadow:none}.style-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.style-tile{display:flex;flex-direction:column;align-items:center;border-radius:var(--r-md);border:1px solid var(--line);color:#c2c2cc;text-shadow:0 1px 2px rgba(0,0,0,.5);background:#ffffff05;transition:color var(--t),border-color var(--t),transform .32s var(--spring),box-shadow var(--t)}.style-tile.preview{padding:0 0 7px;gap:6px;overflow:hidden}.style-tile:hover{color:var(--text);border-color:var(--line-strong);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.style-tile:active{transform:scale(.97)}.style-tile.active{color:#fff;border-color:#ffffff8c;box-shadow:0 0 0 1px #ffffff73,var(--shadow-soft)}.style-thumb{display:block;width:100%;aspect-ratio:288 / 178;object-fit:cover;background:#000}.style-name{font:8.5px var(--font-mono);text-transform:uppercase;letter-spacing:.09em}.toggle-row{display:flex;align-items:center;gap:8px;margin-top:13px;color:var(--text-2);font-size:11.5px;cursor:pointer;user-select:none;width:fit-content}.toggle-row:hover{color:var(--text)}.toggle-row input{appearance:none;width:14px;height:14px;border:1px solid var(--line-strong);border-radius:5px;cursor:pointer;display:grid;place-items:center;transition:background var(--t),border-color var(--t)}.toggle-row input:checked{background:#fff;border-color:#fff}.toggle-row input:checked:after{content:"";width:7px;height:4px;border-left:1.6px solid #0b0b0d;border-bottom:1.6px solid #0b0b0d;transform:rotate(-45deg) translate(.5px,-.5px)}.palette-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:14px}.palette-chip{height:26px;border-radius:9px;overflow:hidden;display:flex;border:1px solid rgba(255,255,255,.1);transition:transform .3s var(--spring),outline-color var(--t);outline:1px solid transparent;outline-offset:2px}.palette-chip span{flex:1}.palette-chip:hover{transform:translateY(-2px)}.palette-chip.active{outline-color:#ffffffd9}.swatch-row{display:flex;align-items:flex-start;gap:9px;margin-bottom:4px}.swatch-cell{display:flex;flex-direction:column;align-items:center;gap:5px}.swatch{position:relative;width:35px;height:35px;border-radius:12px;border:1px solid rgba(255,255,255,.14);box-shadow:inset 0 1px #ffffff1f,0 3px 10px #0000004d;cursor:pointer;transition:transform .3s var(--spring)}.swatch:hover{transform:translateY(-2px)}.swatch input[type=color]{position:absolute;inset:0;opacity:0;cursor:pointer;border:none;padding:0}.swatch-label{font:9px var(--font-mono);color:var(--text-2);letter-spacing:.1em;text-shadow:0 1px 2px rgba(0,0,0,.45)}.swatch-div{width:1px;align-self:stretch;height:35px;background:var(--line);margin:0 2px}.ctl{margin-top:11px}.ctl-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:0}.ctl-label{font-size:12px;color:#cdcdd3;user-select:none}.ctl-value{font:11px var(--font-mono);color:var(--text-2);font-variant-numeric:tabular-nums}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:24px;background:transparent;cursor:pointer;--fill: 50%}input[type=range]::-webkit-slider-runnable-track{height:3px;border-radius:2px;background:linear-gradient(90deg,rgba(255,255,255,.78) var(--fill),rgba(255,255,255,.11) var(--fill))}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;border-radius:50%;background:#fff;margin-top:-5px;box-shadow:0 1px 6px #0000008c,0 0 0 3px #ffffff0f;transition:transform var(--t),box-shadow var(--t)}input[type=range]:hover::-webkit-slider-thumb{transform:scale(1.18);box-shadow:0 2px 9px #0009,0 0 0 4px #ffffff17}input[type=range]::-moz-range-track{height:3px;border-radius:2px;background:#ffffff1c}input[type=range]::-moz-range-progress{height:3px;border-radius:2px;background:#ffffffc7}input[type=range]::-moz-range-thumb{width:13px;height:13px;border:none;border-radius:50%;background:#fff;box-shadow:0 1px 6px #0000008c}.field-row{display:flex;gap:8px}.text-input{flex:1;min-width:0;height:32px;background:#ffffff0b;border:1px solid var(--line);border-radius:11px;font:12px var(--font-mono);color:var(--text);padding:0 11px;transition:border-color var(--t),background var(--t)}.text-input::placeholder{color:var(--text-3)}.text-input:focus{border-color:var(--line-strong);background:#ffffff0f}.text-input.invalid{border-color:#ff6b6b99;animation:shake .28s var(--ease)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-2px)}}.share-row{display:flex;gap:8px;margin-bottom:9px}.share-row .btn{flex:1;justify-content:center}.popover{position:fixed;z-index:44;padding:7px;border-radius:18px;opacity:0;visibility:hidden;transform:translateY(10px) scale(.96);transform-origin:bottom center;transition:opacity .2s ease,transform .4s var(--spring),visibility 0s linear .2s}.popover.open{opacity:1;visibility:visible;transform:none;transition:opacity .16s ease,transform .4s var(--spring)}.pop-aspect{display:flex;flex-direction:column;gap:2px;min-width:124px}.pop-opt{display:flex;justify-content:center;padding:9px 14px;border-radius:12px;font:11.5px var(--font-mono);letter-spacing:.03em;color:var(--text-2);transition:background var(--t),color var(--t)}.pop-opt:hover{background:var(--fill-1);color:var(--text)}.pop-opt.active{background:var(--fill-2);color:#fff}.pop-export{display:flex;flex-direction:column;gap:5px;min-width:244px;padding:8px}.export-row{height:38px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;border-radius:12px;color:var(--text);font:500 12px var(--font-ui);transition:background var(--t),opacity var(--t)}.export-row:hover:not([disabled]){background:var(--fill-2)}.export-row[disabled]{opacity:.38;cursor:not-allowed}.export-row .ex-label{display:inline-flex;align-items:center;gap:10px}.export-row svg{width:14px;height:14px;color:var(--text-2)}.export-row .fmt{font:9.5px var(--font-mono);letter-spacing:.12em;color:var(--text-3)}.toasts{position:fixed;left:50%;transform:translate(-50%);bottom:90px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:70;pointer-events:none}.toast{background:linear-gradient(#ffffff0d,#fff0 70%),var(--glass-bg-strong);-webkit-backdrop-filter:blur(20px) saturate(1.5);backdrop-filter:blur(20px) saturate(1.5);border:1px solid var(--line-strong);border-radius:999px;padding:10px 17px;font:11.5px var(--font-mono);color:var(--text);box-shadow:var(--shadow-float),var(--rim);animation:toast-in .42s var(--spring);max-width:min(440px,calc(100vw - 32px));text-align:center}.toast.error{border-color:#ff6b6b73;color:#ffc2c2}.toast.leaving{animation:toast-out .22s var(--ease) forwards}@keyframes toast-in{0%{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:none}}@keyframes toast-out{to{opacity:0;transform:translateY(8px) scale(.97)}}.modal-backdrop{position:fixed;inset:0;background:#0404078c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:50;display:grid;place-items:center;padding:24px;animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}}.modal{background:linear-gradient(#ffffff0d,#ffffff03 40%,#fff0 75%),#111115e0;-webkit-backdrop-filter:blur(30px) saturate(1.5);backdrop-filter:blur(30px) saturate(1.5);border:1px solid var(--line-strong);border-radius:var(--r-xl);padding:22px 26px 24px;width:100%;max-width:620px;max-height:min(78vh,720px);overflow-y:auto;box-shadow:var(--shadow-sheet),var(--rim);animation:sheet-in .48s var(--spring);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}@keyframes sheet-in{0%{opacity:0;transform:translateY(18px) scale(.965)}}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-title{font:600 11px var(--font-mono);text-transform:uppercase;letter-spacing:.18em;color:var(--text)}.docs{color:var(--text-2);font-size:12.5px;line-height:1.65}.docs h3{font:600 10px var(--font-mono);text-transform:uppercase;letter-spacing:.14em;color:var(--text);margin:20px 0 8px}.docs h3:first-child{margin-top:0}.docs p+p{margin-top:7px}.docs table{width:100%;border-collapse:collapse;margin-top:4px}.docs td{padding:4.5px 0;border-bottom:1px solid var(--line);vertical-align:middle}.docs td:first-child{width:130px}.docs-footer{margin-top:22px;padding-top:14px;border-top:1px solid var(--line);font:11px var(--font-mono);letter-spacing:.04em;color:var(--text-2)}.docs-footer a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--line-strong);transition:border-color var(--t)}.docs-footer a:hover{border-bottom-color:#fff}kbd{font:10.5px var(--font-mono);background:#ffffff12;border:1px solid var(--line-strong);border-bottom-width:2px;border-radius:5px;padding:1px 6px;margin-right:3px;white-space:nowrap}code{font:11px var(--font-mono);background:#ffffff0f;border-radius:5px;padding:1px 5px}.progress-label{font:11.5px var(--font-mono);color:var(--text-2);margin-bottom:12px;display:flex;justify-content:space-between;gap:12px}.progress-track{height:3px;background:#ffffff14;border-radius:2px;overflow:hidden;margin-bottom:18px}.progress-fill{height:100%;width:0;background:#fff;border-radius:2px;transition:width .12s linear}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.library-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:4px}.lib-item{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);cursor:pointer;aspect-ratio:8 / 5;background:#000;transition:border-color var(--t),transform .32s var(--spring),box-shadow var(--t);padding:0}.lib-item img{width:100%;height:100%;object-fit:cover;display:block}.lib-item:hover{border-color:#ffffff59;transform:translateY(-2px);box-shadow:var(--shadow-soft)}.lib-item .lib-name{position:absolute;left:0;right:0;bottom:0;padding:10px 8px 5px;font:9px var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:#ffffffd9;background:linear-gradient(transparent,#000000a6);text-align:left;pointer-events:none}.lib-del{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:7px;display:grid;place-items:center;background:#08080aa6;color:var(--text-2);opacity:0;transition:opacity var(--t),color var(--t)}.lib-item:hover .lib-del{opacity:1}.lib-del:hover{color:var(--danger)}.lib-del svg{width:12px;height:12px}.lib-empty{font:11px var(--font-mono);color:var(--text-3);padding:36px 24px;text-align:center;line-height:1.8;grid-column:1 / -1;white-space:pre-line}.drop-overlay{position:fixed;inset:0;z-index:80;display:none;place-items:center;background:#05050799;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.drop-overlay:before{content:"";position:absolute;inset:16px;border:1.5px dashed rgba(255,255,255,.35);border-radius:var(--r-xl)}body.dragging .drop-overlay{display:grid}.drop-overlay span{font:12px var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text)}.fallback{position:absolute;inset:0;display:grid;place-items:center;text-align:center}.fallback-inner{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:420px;padding:24px}.fallback-inner svg{width:42px;height:42px;color:var(--text-3)}.fallback-inner h2{font:600 13px var(--font-mono);letter-spacing:.2em;text-transform:uppercase}.fallback-inner p{color:var(--text-2);font-size:12.5px;line-height:1.7}body.focus-mode .chrome{opacity:0;visibility:hidden;transition:opacity .28s ease,visibility 0s linear .28s}body.focus-mode .stage{--stage-inset: 0px}body.focus-mode canvas#view{border-radius:0;box-shadow:none}body.exporting .chrome{opacity:.45}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:960px){.chip-quiet{display:none}}@media(max-width:820px){.dock-main .btn-label{display:none}.btn-primary.dock-main{padding:0 12px}.dock{gap:7px;padding:0 9px}.scrub{width:72px}}@media(max-width:680px){.dock-export .dock-btn-label,.chip .chip-label{display:none}.chip{padding:0 13px}}@media(max-width:640px){.chip-link{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.layer-list{display:flex;flex-direction:column;gap:10px}.layer-card{border:1px solid var(--line);border-radius:14px;padding:11px 12px 12px;background:#ffffff06}.layer-base{background:#ffffff03}.layer-head{display:flex;align-items:center;gap:4px}.layer-title{flex:1;min-width:0;font:600 11px var(--font-mono);letter-spacing:.04em;color:#d6d6dd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px rgba(0,0,0,.45);user-select:none}.layer-head .icon-btn{color:var(--text-3);flex:none}.layer-head .icon-btn:hover:not(:disabled){color:var(--text)}.layer-head .icon-btn:disabled{opacity:.32;cursor:default}.layer-hint{margin-top:4px;font-size:11.5px;line-height:1.45;color:var(--text-3)}.layer-select{width:100%;margin-top:9px;padding:6px 9px;font:12px var(--font-ui);color:var(--text);background:#0c0c10b8;border:1px solid var(--line);border-radius:9px;outline:none;cursor:pointer}.layer-select:focus-visible{border-color:#fff6}.layer-row{display:flex;align-items:center;gap:6px;margin-top:8px}.layer-row .layer-select{margin-top:0;flex:1}.layer-row .icon-btn{flex:none;color:var(--text-3)}.layer-row .icon-btn:hover{color:var(--text)}.layer-details{margin-top:9px;border-top:1px solid var(--line);padding-top:3px}.layer-details summary{list-style:none;cursor:pointer;font:600 10px var(--font-mono);text-transform:uppercase;letter-spacing:.14em;color:var(--text-3);padding:6px 0 2px;user-select:none}.layer-details summary::-webkit-details-marker{display:none}.layer-details summary:hover{color:var(--text-2)}.layer-details[open] summary{color:#cdcdd3}.layer-ctl-tail{display:inline-flex;align-items:center;gap:2px}.layer-reset{opacity:0;pointer-events:none;color:var(--text-3)}.layer-ctl.overridden .layer-reset{opacity:1;pointer-events:auto}.layer-ctl.overridden .ctl-label{color:#fff}.checkup{display:flex;flex-direction:column;gap:9px}.checkup-row{display:flex;gap:11px;align-items:flex-start;padding:9px 12px;border:1px solid var(--line);border-radius:11px;background:#ffffff05}.checkup-mark{font:600 13px var(--font-mono);line-height:1.35;flex:none}.checkup-row.pass .checkup-mark{color:#7ee2a8}.checkup-row.warn .checkup-mark{color:#ffd479}.checkup-row.fail .checkup-mark{color:#ff8a8a}.checkup-row.fail{border-color:#ff787859;background:#ff5a5a0f}.checkup-label{font:600 12px var(--font-ui);color:var(--text)}.checkup-detail{margin-top:2px;font:11.5px var(--font-mono);line-height:1.5;color:var(--text-2);word-break:break-word;white-space:pre-wrap}.checkup-verdict{margin:4px 2px 0;font-size:12.5px;line-height:1.5;color:var(--text-2)}.fam-chip.fam-studio{border-style:dashed}.fam-chip.fam-studio.active{border-style:solid}.style-tile{position:relative}.style-tile .lib-del{opacity:0}.style-tile:hover .lib-del,.style-tile:focus-within .lib-del{opacity:1}.ai-sheet{display:flex;flex-direction:column;gap:8px}.ai-lede{margin:0 0 6px;font-size:12.5px;line-height:1.55;color:var(--text-2)}.ai-label{font:600 10px var(--font-mono);text-transform:uppercase;letter-spacing:.14em;color:var(--text-3);margin-top:6px;user-select:none}.ai-key,.ai-brief{width:100%;padding:8px 11px;font:12.5px var(--font-mono);color:var(--text);background:#0c0c10b8;border:1px solid var(--line);border-radius:10px;outline:none}.ai-brief{font-family:var(--font-ui);line-height:1.5;resize:vertical;min-height:84px}.ai-key:focus-visible,.ai-brief:focus-visible{border-color:#fff6}.ai-hint{margin:2px 1px 0;font-size:11px;line-height:1.5;color:var(--text-3)}.ai-generate{align-self:flex-start;margin-top:8px;display:inline-flex;align-items:center;gap:7px}.ai-status{min-height:18px;font:11.5px var(--font-mono);line-height:1.6;color:var(--text-2);white-space:pre-wrap}.ai-result{border-top:1px solid var(--line);padding-top:10px;display:flex;flex-direction:column;gap:6px}.ai-result:empty{display:none}.ai-result-name{font:600 14px var(--font-ui);color:var(--text)}.ai-result-notes{margin:0;font-size:12px;line-height:1.5;color:var(--text-2)}.ai-result-actions{display:flex;gap:8px;margin-top:4px}.studio-actions{display:inline-flex;gap:2px}.motion-drawer{position:fixed;left:50%;bottom:86px;transform:translate(-50%,16px);width:min(860px,calc(100vw - 24px));max-height:min(46vh,420px);display:flex;flex-direction:column;border-radius:18px;padding:12px 14px 14px;opacity:0;pointer-events:none;transition:opacity var(--t),transform var(--t);z-index:30}.motion-drawer.open{opacity:1;pointer-events:auto;transform:translate(-50%)}.motion-head{display:flex;align-items:center;gap:8px;margin-bottom:9px}.motion-title{flex:1;font:600 11px var(--font-mono);text-transform:uppercase;letter-spacing:.16em;color:#cdcdd3;user-select:none}.motion-add,.motion-ease{margin-top:0;width:auto}.motion-ease:disabled{opacity:.45}.motion-ruler{position:relative;height:14px;border-radius:7px;background:#ffffff12;cursor:pointer;overflow:hidden;flex:none}.motion-ruler-fill{position:absolute;inset:0 auto 0 0;width:0%;background:linear-gradient(90deg,#ffffff29,#ffffff57);border-radius:7px}.motion-lanes{margin-top:10px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0}.motion-empty{margin-top:10px;padding:14px 6px 4px;font-size:12px;line-height:1.55;color:var(--text-3);text-align:center;white-space:pre-line}.lane{border:1px solid var(--line);border-radius:12px;padding:8px 10px 10px;background:#ffffff05;flex:none}.lane-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.lane-name{flex:1;font:600 11px var(--font-ui);color:#d6d6dd;user-select:none}.lane-head .icon-btn{color:var(--text-3)}.lane-head .icon-btn:hover{color:var(--text)}.lane-svg{display:block;width:100%;height:64px;border-radius:8px;background:linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px) 0 0 / 25% 100%,#00000047;touch-action:none}.lane-curve{fill:none;stroke:#ffffff8c;stroke-width:2;vector-effect:non-scaling-stroke}.lane-playhead{stroke:#ffffff59;stroke-width:1;vector-effect:non-scaling-stroke}.lane-key{fill:#fff;stroke:#0000008c;stroke-width:1.5;vector-effect:non-scaling-stroke;cursor:grab}.lane-key.smooth{fill:#9ed1ff}.lane-key.hold{fill:#ffd479}.lane-key.selected{stroke:#fff;stroke-width:2.5}.ctl-tail{display:inline-flex;align-items:center;gap:6px}.ctl-track-badge{display:none;font-size:9px;line-height:1;color:#9ed1ff;padding:2px 3px;border-radius:4px}.ctl.tracked .ctl-track-badge{display:inline-block}.ctl-track-badge:hover{color:#fff;background:#9ed1ff2e}.ctl.tracked input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(90deg,rgba(158,209,255,.75) var(--fill),rgba(158,209,255,.16) var(--fill))}@media(max-width:680px){.motion-drawer{bottom:78px}}.lib-tabs{display:flex;gap:6px;margin-bottom:10px}.material-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}.mat-tile{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#ffffff05;aspect-ratio:8 / 5;cursor:pointer;transition:border-color var(--t),transform var(--t)}.mat-tile:hover{border-color:#ffffff57;transform:translateY(-1px)}.mat-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.mat-name{position:absolute;left:7px;bottom:7px;padding:3px 8px;border-radius:7px;background:#08080ab8;font:600 10px var(--font-mono);letter-spacing:.06em;color:#e8e8ee;text-shadow:0 1px 2px rgba(0,0,0,.5)}.packs-sheet{display:flex;flex-direction:column;gap:12px}.packs-actions{display:flex;gap:8px}.packs-list{display:flex;flex-direction:column;gap:8px}.pack-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#ffffff05}.pack-name{font:600 13px var(--font-ui);color:var(--text)}.pack-meta{margin-top:2px;font:11px var(--font-mono);color:var(--text-3)}.pack-row .icon-btn{color:var(--text-3)}.pack-row .icon-btn:hover{color:var(--text)}.node-overlay{position:fixed;inset:16px;z-index:60;border-radius:22px;display:flex;flex-direction:column;padding:14px 16px 16px}.node-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.node-name{width:220px;font-family:var(--font-ui)}.node-status{flex:1;font:11.5px var(--font-mono);color:#ffd479;text-align:right}.node-palette{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;flex:none}.node-surface{position:relative;flex:1;min-height:0;border:1px solid var(--line);border-radius:16px;background:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px) 0 0 / 100% 28px,linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px) 0 0 / 28px 100%,#00000052;overflow:auto}.node-wires{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.node-wire{fill:none;stroke:#ffffff73;stroke-width:2}.node-wire.pending{stroke-dasharray:5 4;stroke:#9ed1ffcc}.node-cards{position:absolute;inset:0}.node-card{position:absolute;width:172px;border:1px solid var(--line);border-radius:13px;background:#101015eb;box-shadow:0 10px 28px #0000006b;padding:8px 10px 10px}.node-card.group-space{border-top:2px solid rgba(158,209,255,.55)}.node-card.group-field{border-top:2px solid rgba(170,255,196,.5)}.node-card.group-mix{border-top:2px solid rgba(255,212,121,.5)}.node-card.group-out{border-top:2px solid rgba(255,153,196,.55)}.node-card-head{display:flex;align-items:center;justify-content:space-between;cursor:grab;margin-bottom:6px}.node-card-head:active{cursor:grabbing}.node-title{font:600 11px var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:#d6d6dd;user-select:none}.node-card-head .icon-btn{color:var(--text-3);margin:-3px -4px}.node-port-row{display:flex;align-items:center;gap:7px;margin:3px 0}.node-port-row.out{justify-content:flex-end}.node-port{width:13px;height:13px;border-radius:50%;border:2px solid rgba(255,255,255,.65);background:#0a0a0ee6;cursor:crosshair;flex:none;padding:0}.node-port.type-v2{border-color:#9ed1ffd9}.node-port.type-f1{border-color:#aaffc4cc}.node-port:hover{background:#ffffff59}.node-port-label{font:10.5px var(--font-ui);color:var(--text-2);user-select:none}.node-preview{display:block;width:100%;border-radius:8px;margin:5px 0 2px;background:#0006}.node-ctl{margin-top:5px}.node-ctl .ctl-label{font-size:10.5px}
