*{box-sizing:border-box;margin:0;padding:0}html,body{max-width:100vw;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:inherit;text-decoration:none}:root{--bg-base:#faf9f7;--bg-surface:#fff;--bg-elevated:#f5f3f0;--bg-hover:#f0ede8;--bg-active:#e8e4dd;--bg-muted:#f8f6f3;--accent-primary:#c75d3a;--accent-hover:#b54e2c;--accent-light:#fef4f0;--accent-muted:#c75d3a1a;--accent-subtle:#c75d3a0d;--text-primary:#1a1816;--text-secondary:#5c5650;--text-muted:#8a847c;--text-ghost:#b5aea5;--border-ghost:#0000000a;--border-subtle:#00000014;--border-medium:#0000001f;--border-accent:#c75d3a40;--color-success:#16a34a;--color-success-bg:#16a34a1a;--color-warning:#d97706;--color-warning-bg:#d977061a;--color-error:#9a6700;--color-error-bg:#d977061f;--color-info:#2563eb;--color-info-bg:#2563eb1a;--font-display:"Clash Display",sans-serif;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--ease-out-expo:cubic-bezier(.16,1,.3,1)}@media (prefers-color-scheme:dark){:root{--bg-base:#0a0a0a99;--bg-surface:#141414a6;--bg-elevated:#1e1e1eb3;--bg-hover:#2d2d2dcc;--bg-active:#373737d9;--bg-muted:#0f0f0f80;--accent-primary:#d9f158;--accent-hover:#e5f585;--accent-light:#fef4f0;--accent-muted:#d9f1581a;--accent-subtle:#d9f1580d;--text-primary:#ededed;--text-secondary:#a1a1a1;--text-muted:#777;--text-ghost:#444;--border-ghost:#ffffff0a;--border-subtle:#ffffff14;--border-medium:#ffffff1f;--border-accent:#d9f15840}}body{height:100dvh;color:var(--text-primary);background:#fcfcfc;margin:0;overflow:hidden}@media (prefers-color-scheme:dark){body{background:#080808}}::selection{background:var(--accent-muted);color:var(--text-primary)}.ui-shell{flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.ui-shell:before{content:"";pointer-events:none;z-index:0;filter:blur(80px);opacity:.7;background:radial-gradient(circle at 15% 0,#c8dcff59 0%,#0000 40%),radial-gradient(circle at 85% 10%,#ffdcc840 0%,#0000 40%),radial-gradient(circle at 50% 100%,#f0f0ff66 0%,#0000 50%);position:fixed;inset:0}@media (prefers-color-scheme:dark){.ui-shell:before{opacity:.6;background:radial-gradient(circle at 20% 0,#283c6440 0%,#0000 50%),radial-gradient(circle at 80% 0,#50281e2e 0%,#0000 50%)}}.ui-shell>*{z-index:1;position:relative}.ui-topbar{-webkit-backdrop-filter:blur(16px);z-index:100;background:#fcfcfcbf;border-bottom:1px solid #0000000d;flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 28px;display:flex}@media (prefers-color-scheme:dark){.ui-topbar{background:#080808bf;border-bottom-color:#ffffff0d}}.ui-topbar-left{align-items:center;gap:16px;display:flex}.ui-logo{cursor:pointer;align-items:baseline;gap:0;display:flex;position:relative}.ui-logo:after{content:"";background:linear-gradient(90deg,var(--accent-primary),var(--accent-hover));border-radius:1px;width:0;height:2px;transition:width .3s;position:absolute;bottom:-4px;left:0}.ui-logo:hover:after{width:100%}.logo-f{font-family:var(--font-instrument),serif;color:var(--text-primary);font-size:28px;font-weight:400;line-height:1;transition:color .3s}.logo-m{font-family:var(--font-liu),cursive;color:var(--text-primary);font-size:30px;font-weight:400;line-height:1;transition:color .3s}.logo-text{font-family:var(--font-body);color:var(--text-primary);letter-spacing:-.01em;opacity:1;max-width:100px;font-size:16px;font-weight:500;transition:max-width 1.2s cubic-bezier(.4,0,.2,1),opacity .8s,color .3s;display:inline-block;overflow:hidden}.logo-v3{color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,var(--accent-primary),#ffa37e);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-left:6px;font-family:inherit;font-size:.55em;font-weight:800;line-height:1;display:inline-block;transform:translateY(-4px)}.ui-logo:hover .logo-f,.ui-logo:hover .logo-m,.ui-logo:not(.collapsed):hover .logo-text{color:var(--accent-hover)}.ui-logo.collapsed .logo-text{opacity:0;max-width:0}.ui-topbar-status{color:var(--text-muted);align-items:center;gap:8px;font-size:12px;font-weight:400;display:flex}.status-dot{background:var(--border-medium);border-radius:50%;width:6px;height:6px;transition:background .3s}.status-dot.active{background:var(--color-success);box-shadow:0 0 8px #16a34a66}.ui-topbar-right{align-items:center;gap:8px;display:flex}.btn-icon{border:1px solid var(--border-subtle);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-icon:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-medium)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.btn-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;width:14px;height:14px;animation:.75s linear infinite spin;display:inline-block}.new-chat-btn{border:1px solid var(--border-subtle);height:36px;color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:6px;padding:0 16px;transition:all .15s;display:flex}.new-chat-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-medium)}.new-chat-btn:disabled{opacity:.4;cursor:not-allowed}.auth-btn{border:1px solid var(--border-subtle);background:var(--bg-surface);height:36px;color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-body);cursor:pointer;border-radius:10px;padding:0 14px;transition:all .15s}.auth-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-medium)}.auth-btn:disabled{opacity:.4;cursor:not-allowed}.ui-content-body{flex:1;min-height:0;display:flex;overflow:hidden}.ui-content-body.resizing{cursor:ew-resize;-webkit-user-select:none;user-select:none}.resize-handle{cursor:ew-resize;z-index:10;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:8px;transition:background .15s;display:flex}.resize-handle:hover,.resize-handle:active{background:var(--bg-hover)}.resize-bar{background:var(--border-medium);border-radius:2px;width:4px;height:48px;transition:background .15s}.resize-handle:hover .resize-bar,.resize-handle:active .resize-bar{background:var(--accent-primary)}.right-pane-tabs{border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);flex-shrink:0;display:flex}.right-pane-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;justify-content:center;align-items:center;gap:5px;padding:10px 0;font-size:12px;font-weight:500;transition:color .12s,border-color .12s;display:flex}.right-pane-tab svg{flex-shrink:0}.right-pane-tab:hover{color:var(--text-primary)}.right-pane-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.tab-badge{background:var(--accent-muted);color:var(--accent-primary);border-radius:99px;padding:1px 6px;font-size:10px;font-weight:600;line-height:1.4}.ui-chat-pane{-webkit-backdrop-filter:blur(24px);background:#ffffff80;border-left:none;flex-direction:column;flex-shrink:0;min-width:0;height:100%;min-height:0;display:flex;position:relative;overflow:hidden}@media (prefers-color-scheme:dark){.ui-chat-pane{background:#0f0f0f80}}.assets-panel{border-bottom:1px solid var(--border-ghost);background:var(--bg-base);flex-shrink:0;padding:10px 16px 12px;transition:background .15s,box-shadow .15s}.assets-panel.drop-active{background:var(--accent-subtle);box-shadow:inset 0 0 0 1px var(--border-accent)}.assets-panel-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.assets-panel-header h3{color:var(--text-primary);margin:0;font-size:13px;font-weight:600}.assets-panel-header p{color:var(--text-muted);margin:2px 0 0;font-size:11px}.asset-library-upload{border:1px solid var(--border-subtle);background:var(--bg-surface);height:28px;color:var(--text-secondary);font-size:12px;font-weight:500;font-family:var(--font-body);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:0 10px;transition:all .15s;display:inline-flex}.asset-library-upload:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-medium)}.asset-library-upload:disabled{opacity:.4;cursor:not-allowed}.asset-tabs{align-items:center;gap:6px;margin-top:10px;display:flex}.asset-tab-btn{border:1px solid var(--border-subtle);color:var(--text-muted);font-size:11px;font-weight:500;font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:999px;padding:5px 10px;transition:all .15s}.asset-tab-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.asset-tab-btn.active{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-medium)}.asset-tab-content{max-height:176px;margin-top:10px;overflow-y:auto}.asset-tab-content::-webkit-scrollbar{width:5px}.asset-tab-content::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.asset-list{flex-direction:column;gap:8px;display:flex}.asset-item{border:1px solid var(--border-subtle);background:var(--bg-surface);border-radius:10px;grid-template-columns:36px 1fr auto;align-items:center;gap:10px;padding:8px;display:grid}.asset-thumb{border:1px solid var(--border-subtle);background:var(--bg-surface);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.asset-thumb img{object-fit:cover;width:100%;height:100%;display:block}.asset-thumb.is-video{background:linear-gradient(135deg,#2e2b28,#1c1a18)}.asset-meta{min-width:0}.asset-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:12px;line-height:1.3;overflow:hidden}.asset-kind{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin:2px 0 0;font-size:10px;line-height:1.2}.asset-actions{align-items:center;gap:6px;display:flex}.asset-action-btn{border:1px solid var(--border-subtle);height:24px;color:var(--text-secondary);font-size:10px;font-weight:500;font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:7px;padding:0 8px;transition:all .15s}.asset-action-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-medium)}.asset-action-btn:disabled{opacity:.4;cursor:not-allowed}.asset-action-btn.is-danger:hover:not(:disabled){color:#a63b2d;background:#cc463514;border-color:#cc463559}.asset-empty{border:1px dashed var(--border-subtle);background:var(--bg-surface);color:var(--text-muted);border-radius:10px;margin:0;padding:12px 10px;font-size:12px;line-height:1.4}.ui-chat{scroll-behavior:smooth;flex-direction:column;flex:1 1 0;gap:8px;min-height:0;padding:24px 24px 16px;display:flex;overflow:hidden auto}.ui-chat::-webkit-scrollbar{width:6px}.ui-chat::-webkit-scrollbar-track{background:0 0}.ui-chat::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.ui-chat::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.empty-state{text-align:center;max-width:480px;margin:auto;padding:40px 20px;animation:.6s fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.empty-state-icon{border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-muted)0%,var(--accent-subtle)100%);border:1px solid var(--border-subtle);width:56px;height:56px;color:var(--accent-primary);justify-content:center;align-items:center;margin:0 auto 24px;display:flex}.empty-state h2{font-family:var(--font-display);letter-spacing:-.035em;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary)0%,var(--text-secondary)50%,var(--text-primary)100%);-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:32px;font-weight:500;line-height:1.1;animation:8s ease-in-out infinite shimmer}@keyframes shimmer{0%,to{background-position:0%}50%{background-position:100%}}.empty-state p{color:var(--text-muted);max-width:360px;margin:0 auto;font-size:15px;line-height:1.6}.msg{align-items:flex-start;gap:0;max-width:100%;animation:.4s cubic-bezier(.34,1.56,.64,1) messageAppear;display:flex}@keyframes messageAppear{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.msg.user{justify-content:flex-end}.msg-avatar{display:none}.msg-body{border-radius:var(--radius-xl);max-width:min(560px,85%);padding:12px 18px;font-size:15px;line-height:1.6}.msg.user .msg-body{color:var(--text-secondary);border:1px solid var(--border-subtle);box-shadow:none;background:#5f646b0f;border-radius:10px;max-width:min(520px,80%);padding:7px 11px;font-size:13px;line-height:1.5}.msg.assistant .msg-body{color:var(--text-secondary);box-shadow:none;background:0 0;border:0;border-radius:0;max-width:min(620px,92%);padding:2px 0 10px;font-size:13px;line-height:1.58}.msg.tool .msg-body{border-left:2px solid var(--border-medium);background:0 0;border-radius:0;max-width:100%;margin-left:4px;padding:8px 12px}.msg.tool-scene .msg-body{background:#6366f10a;border-left-color:#6366f1}.msg.tool-scene .msg-title{color:#6366f1}.msg.tool-animate .msg-body{background:#f59e0b0a;border-left-color:#f59e0b}.msg.tool-animate .msg-title{color:#b45309}.msg.tool-transition .msg-body{background:#10b9810a;border-left-color:#10b981}.msg.tool-transition .msg-title{color:#059669}.msg.tool-comp .msg-body{background:#ec48990a;border-left-color:#ec4899}.msg.tool-comp .msg-title{color:#db2777}.msg.system .msg-body{color:var(--text-muted);text-align:left;background:0 0;align-items:center;gap:8px;max-width:100%;padding:2px 0 8px;font-size:13px;display:inline-flex}.msg.system{--step-dot:#767b8294;--step-line:#767b826b;min-height:20px;padding-left:26px;position:relative}.msg-step-rail{pointer-events:none;width:12px;height:14px;position:absolute;top:2px;left:8px}.msg-step-rail:before{content:"";background:var(--step-dot);transform-origin:50%;width:4px;height:4px;position:absolute;top:3px;left:4px;transform:rotate(45deg)}.msg-step-icon{border:1px solid var(--border-subtle);background:var(--bg-surface);color:#5f646be0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:inline-flex}.msg.system.step-continue .msg-step-rail:after{content:"";background-image:repeating-linear-gradient(to bottom,var(--step-line)0 3px,transparent 3px 7px);clip-path:polygon(50% 0,100% 8%,100% 92%,50% 100%,0 92%,0 8%);transform-origin:top;width:2px;height:30px;animation:stepLineGrow .26s var(--ease-out-expo)both;position:absolute;top:10px;left:5px}@keyframes stepLineGrow{0%{opacity:.35;transform:scaleY(0)}to{opacity:1;transform:scaleY(1)}}.msg.error .msg-body{color:#7f5b13;background:#9a670012;border:1px dashed #9a67003d;border-radius:8px;max-width:420px;padding:6px 10px;font-size:13px}.msg.error .msg-title{display:none}.msg.thinking .msg-body{background:0 0;border-radius:0;max-width:100%;padding:2px 0 8px}.thinking-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;align-items:center;gap:5px;padding:2px 0;font-family:inherit;font-size:12px;transition:color .15s;display:inline-flex}.thinking-toggle:hover{color:var(--text-secondary)}.thinking-toggle-icon{width:10px;font-size:10px}.thinking-content{max-height:300px;font-size:11px;font-family:var(--font-mono);color:var(--text-muted);background:var(--bg-muted);white-space:pre-wrap;word-break:break-word;border-radius:6px;margin:6px 0 0;padding:8px 10px;line-height:1.5;overflow-y:auto}.msg-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600;font-family:var(--font-mono);margin:0 0 2px}.msg-text{font-size:inherit;white-space:pre-wrap;word-break:break-word;margin:0;line-height:1.55}.msg-markdown{font-size:inherit;color:inherit;line-height:1.55}.msg-markdown>*{margin:0 0 6px}.msg-markdown>:last-child{margin-bottom:0}.msg-markdown ul,.msg-markdown ol{margin:0 0 6px 16px;padding:0}.msg-markdown li{margin:2px 0}.msg-markdown strong{color:var(--text-primary);font-weight:600}.msg-markdown a{color:var(--text-secondary);text-underline-offset:2px;text-decoration:underline}.msg-markdown code{font-family:var(--font-mono);background:var(--bg-muted);border:1px solid var(--border-subtle);border-radius:4px;padding:1px 4px;font-size:12px}.msg-markdown pre{border:1px solid var(--border-subtle);background:var(--bg-muted);border-radius:8px;max-height:220px;margin:0 0 6px;padding:8px 10px;overflow:auto}.msg-markdown pre code{background:0 0;border:0;padding:0}.msg-details{margin-top:6px}.msg-details summary{cursor:pointer;color:var(--text-muted);-webkit-user-select:none;user-select:none;font-size:12px;font-weight:500;font-family:var(--font-mono);transition:color .15s}.msg-details summary:hover{color:var(--text-secondary)}.msg-details pre{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-muted);max-height:180px;color:var(--text-secondary);font-size:11px;line-height:1.4;font-family:var(--font-mono);margin:6px 0 0;padding:10px;overflow:auto}.msg-details pre::-webkit-scrollbar{width:4px;height:4px}.msg-details pre::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}.limit-banner{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffa03214;border:1px solid #ffa03259;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 16px;animation:.25s ease-out limitSlideIn;display:flex;position:absolute;bottom:90px;left:20px;right:20px}@keyframes limitSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.limit-banner-content{flex:1;align-items:flex-start;gap:10px;min-width:0;display:flex}.limit-banner-icon{flex-shrink:0;font-size:16px;line-height:1.4}.limit-banner-text{color:var(--text-primary,#e4e4e7);margin:0;font-size:13px;line-height:1.45}.limit-banner-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.limit-banner-btn{color:var(--text-primary,#e4e4e7);cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff1f;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:500;transition:background .15s}.limit-banner-btn:hover{background:#ffffff24}.limit-banner-dismiss{width:24px;height:24px;color:var(--text-secondary,#a1a1aa);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.limit-banner-dismiss:hover{background:#ffffff14}.limit-banner-link{color:#000;text-underline-offset:2px;font-weight:600;text-decoration:underline}.limit-banner-link:hover{opacity:.85}.history-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#0003;animation:.2s fadeIn;position:fixed;inset:0}.history-sidebar{background:var(--bg-surface);border-left:1px solid var(--border-subtle);z-index:95;width:320px;animation:slideInRight .25s var(--ease-out-expo);-webkit-backdrop-filter:blur(24px);flex-direction:column;display:flex;position:fixed;top:60px;bottom:0;right:0;box-shadow:-4px 0 24px #00000014}@media (prefers-color-scheme:dark){.history-sidebar{background:#121212f2;border-left-color:#ffffff0f;box-shadow:-4px 0 32px #0006}.history-empty,.history-empty p{color:var(--text-secondary)}.history-item-title{color:var(--text-primary)}.history-item-time{color:var(--text-muted)}.history-item-badge{color:var(--text-secondary);background:#ffffff14}.history-item:hover:not(:disabled){background:#ffffff0f}.history-item.active{background:#d9f15814}.history-sidebar-header{border-bottom-color:#ffffff0f}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInCard{0%{opacity:0;transform:translateY(-8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.history-sidebar-header{border-bottom:1px solid var(--border-ghost);justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.history-sidebar-title{color:var(--text-primary);align-items:center;gap:10px;display:flex}.history-sidebar-title h3{font-size:15px;font-weight:600;font-family:var(--font-display);letter-spacing:-.01em;margin:0}.history-sidebar-title svg{color:var(--text-muted)}.history-sidebar-actions{align-items:center;gap:4px;display:flex}.history-sidebar-body{flex:1;padding:12px;overflow-y:auto}.history-sidebar-body::-webkit-scrollbar{width:3px}.history-sidebar-body::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}.history-list{flex-direction:column;gap:4px;display:flex}.history-item{text-align:left;border-radius:var(--radius-md);cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;gap:8px;width:100%;padding:12px 14px;transition:all .18s;display:flex;position:relative}.history-item:before{content:"";background:0 0;border-radius:0 3px 3px 0;width:3px;transition:background .18s;position:absolute;top:8px;bottom:8px;left:0}.history-item:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-ghost)}.history-item.active{background:var(--accent-subtle);border-color:var(--border-accent)}.history-item.active:before{background:var(--accent-primary)}.history-item:disabled{opacity:.5;cursor:not-allowed}.history-item.loading{opacity:.6}.history-item-content{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.history-item-title{color:var(--text-primary);text-overflow:ellipsis;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;flex:1;min-width:0;font-size:13px;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.history-item-time{color:var(--text-ghost);white-space:nowrap;flex-shrink:0;margin-top:2px;font-size:11px}.history-item-footer{justify-content:space-between;align-items:center;display:flex}.history-item-badge{color:var(--text-muted);background:var(--bg-elevated);letter-spacing:.02em;border-radius:99px;padding:2px 8px;font-size:10px;font-weight:500}.history-item.active .history-item-badge{background:var(--accent-muted);color:var(--accent-primary)}.history-item-loading{align-items:center;display:flex}.history-empty{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 20px;display:flex}.history-empty p{margin:0;font-size:14px;font-weight:500}.history-empty-sub{color:var(--text-ghost);line-height:1.5;font-size:12px!important}.auth-gate-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.auth-gate-modal{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);text-align:center;width:380px;max-width:calc(100vw - 32px);animation:slideInCard .3s var(--ease-out-expo);padding:32px 28px 24px;position:relative;box-shadow:0 16px 64px #0000002e,0 4px 16px #00000014}.auth-gate-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;top:12px;right:12px}.auth-gate-close:hover{background:var(--bg-hover);color:var(--text-primary)}.auth-gate-icon{background:var(--accent-light);width:56px;height:56px;color:var(--accent-primary);border-radius:16px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.auth-gate-title{font-size:18px;font-weight:600;font-family:var(--font-display);color:var(--text-primary);margin:0 0 8px}.auth-gate-text{color:var(--text-secondary);margin:0 0 20px;font-size:13px;line-height:1.5}.auth-gate-signin{border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--bg-surface);width:100%;height:44px;color:var(--text-primary);font-size:14px;font-weight:500;font-family:var(--font-body);cursor:pointer;justify-content:center;align-items:center;gap:10px;transition:all .15s;display:flex}.auth-gate-signin:hover{background:var(--bg-hover);border-color:var(--border-medium);box-shadow:0 2px 8px #0000000f}.auth-gate-footer{color:var(--text-muted);margin:14px 0 0;font-size:12px}.auth-gate-link{color:var(--accent-primary);font-weight:600;text-decoration:none}.auth-gate-link:hover{text-decoration:underline}.ui-composer{background:linear-gradient(to top,var(--bg-base)80%,transparent);flex-shrink:0;padding:8px 20px 20px;transition:all .4s cubic-bezier(.16,1,.3,1)}.ui-composer.centered{pointer-events:none;z-index:50;background:0 0;justify-content:center;align-items:center;padding-bottom:120px;display:flex;position:absolute;inset:0}.ui-composer.centered .ui-composer-inner{pointer-events:auto;border-color:#00000014;width:100%;max-width:640px;box-shadow:0 8px 30px #0000000f}@media (prefers-color-scheme:dark){.ui-composer.centered .ui-composer-inner{border-color:#ffffff14;box-shadow:0 8px 30px #0006}}.ui-composer-inner{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-2xl);padding:16px 20px;transition:all .2s;box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008}.ui-composer-inner.drop-active{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-muted),0 10px 24px #00000014}.ui-composer-inner:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-muted),0 8px 24px #00000014}.ui-composer-top{width:100%}.ui-composer textarea{resize:none;width:100%;min-height:24px;max-height:160px;color:var(--text-primary);font-family:var(--font-body);background:0 0;border:0;outline:none;padding:4px 0;font-size:15px;line-height:1.5}.ui-composer textarea::placeholder{color:var(--text-ghost)}.ui-composer-bottom{justify-content:space-between;align-items:center;gap:10px;margin-top:8px;display:flex}.composer-actions{flex:1;align-items:center;gap:8px;min-width:0;padding-bottom:2px;display:flex;overflow-x:auto}.composer-actions::-webkit-scrollbar{height:4px}.composer-actions::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:999px}.asset-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.asset-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-medium);color:var(--text-primary)}.asset-btn:disabled{opacity:.4;cursor:not-allowed}.uploaded-asset{border:1px solid var(--border-subtle);background:var(--bg-surface);border-radius:8px;flex-shrink:0;width:30px;height:30px;position:relative;overflow:hidden}.uploaded-asset img{object-fit:cover;width:100%;height:100%;display:block}.uploaded-asset.is-video{background:linear-gradient(135deg,#2e2b28,#1c1a18)}.uploaded-asset-placeholder{color:#f2eee8;justify-content:center;align-items:center;width:100%;height:100%;font-size:12px;line-height:1;display:flex}.remove-asset{border:1px solid var(--border-subtle);background:var(--bg-surface);width:16px;height:16px;color:var(--text-muted);cursor:pointer;opacity:0;border-radius:999px;justify-content:center;align-items:center;font-size:11px;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:-6px;right:-6px}.uploaded-asset:hover .remove-asset{opacity:1}.send-btn{color:#fff;background:var(--accent-primary);border-radius:var(--radius-sm);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.send-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 8px #c75d3a4d}.send-btn:disabled{opacity:.3;cursor:not-allowed}.cancel-btn{background:var(--bg-hover);color:var(--text-secondary)}.cancel-btn:hover:not(:disabled){color:#fff;background:#ff5e5e;box-shadow:0 2px 8px #ff5e5e4d}.studio-start-screen{flex:1;justify-content:center;align-items:center;min-height:0;padding:24px;animation:.5s fadeUp;display:flex}.studio-start-inner{text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:680px;display:flex}.studio-start-headline{font-family:var(--font-display);letter-spacing:-.025em;color:var(--text-primary);margin-bottom:10px;font-size:clamp(26px,3.5vw,40px);font-weight:500;line-height:1.1}.studio-start-sub{color:var(--text-muted);margin-bottom:32px;font-size:16px;line-height:1.5}.studio-start-composer{width:100%}.studio-start-composer .ui-composer-inner{border-radius:var(--radius-2xl);padding:16px 20px 12px}.ui-preview{-webkit-backdrop-filter:blur(24px);background:#fff6;flex-direction:column;flex-shrink:0;min-width:0;height:100%;min-height:0;display:flex;position:relative;overflow:hidden}@media (prefers-color-scheme:dark){.ui-preview{background:#0f0f0f66}}.ui-preview-content{flex:1;justify-content:center;align-items:center;min-height:0;padding:24px;display:flex;overflow:hidden}.ui-preview-content>div{border-radius:var(--radius-xl);justify-content:center;align-items:center;width:fit-content;max-width:100%;height:100%;max-height:100%;display:flex;overflow:hidden}.preview-actions{border-top:1px solid var(--border-ghost);background:var(--bg-surface);justify-content:center;padding:12px 16px;display:flex}.export-btn{border:1px solid var(--border-subtle);min-width:152px;height:36px;color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:0 14px;transition:all .15s;display:inline-flex}.export-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-medium)}.export-btn:disabled{opacity:.45;cursor:not-allowed}.timeline{border-top:1px solid var(--border-ghost);background:var(--bg-surface);font-size:11px;font-family:var(--font-mono);color:var(--text-muted);max-height:80px;margin:0;padding:12px 16px;line-height:1.4;overflow:auto}.timeline::-webkit-scrollbar{width:4px}.timeline::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}.loading-orbit{border:1px solid var(--border-subtle);background:var(--bg-surface);border-radius:999px;justify-content:center;align-self:flex-start;align-items:center;width:36px;height:36px;animation:.3s messageAppear;display:inline-flex}.loading-orbit-svg{transform-origin:50%;width:28px;height:28px;animation:2.2s linear infinite loadingOrbitSpin}.loading-orbit-ring{fill:none;stroke:#5f646b2e;stroke-width:1.4px}.loading-orbit-curve{fill:none;stroke:#303438d1;stroke-width:1.7px;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:38;stroke-dashoffset:38px;animation:loadingCurveDraw 1.2s var(--ease-out-expo)infinite}@keyframes loadingOrbitSpin{to{transform:rotate(360deg)}}@keyframes loadingCurveDraw{0%{stroke-dashoffset:38px;opacity:.35}45%{stroke-dashoffset:12px;opacity:1}70%{stroke-dashoffset:0;opacity:.9}to{stroke-dashoffset:-38px;opacity:.3}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:1024px){.ui-content-body{flex-direction:column;overflow:hidden}.ui-preview{flex:1;width:100%!important}.ui-chat-pane{border-top:1px solid var(--border-ghost);flex:1;width:100%!important}.resize-handle{display:none}}@media (max-width:640px){.ui-topbar{height:50px;padding:0 16px}.ui-topbar-status{display:none}.ui-chat{padding:16px 16px 130px}.assets-panel{padding:10px 12px}.assets-panel-header p{display:none}.asset-item{grid-template-columns:32px 1fr;gap:8px}.asset-thumb{width:32px;height:32px}.asset-actions{flex-wrap:wrap;grid-column:1/-1;margin-top:4px}.ui-composer{padding:12px 12px 16px}.ui-composer-inner{border-radius:var(--radius-xl);padding:12px 16px}.msg-body{max-width:min(560px,90%);padding:10px 14px}.empty-state h2{font-size:24px}.empty-state p{font-size:14px}}.panel-toggle{background:var(--bg-base);border-bottom:1px solid var(--border-ghost);flex-shrink:0;align-items:center;gap:2px;padding:10px 16px;display:flex}.panel-toggle-btn{border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.panel-toggle-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.panel-toggle-btn.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:0 1px 3px #0000000f,0 0 0 1px var(--border-subtle)}.ui-edit-scroll{flex:1;overflow:hidden auto}.ui-edit-scroll::-webkit-scrollbar{width:6px}.ui-edit-scroll::-webkit-scrollbar-track{background:0 0}.ui-edit-scroll::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.ep-root{padding:8px 0}.ep-empty{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;height:100%;padding:60px 24px;display:flex}.ep-empty-icon{margin-bottom:12px;font-size:32px}.ep-empty p{margin:0;font-size:14px;line-height:1.5}.ep-empty-hint{color:var(--text-ghost);margin-top:6px!important;font-size:12px!important}.ep-section-header{width:100%;color:var(--text-secondary);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:10px 16px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.ep-section-header:hover{background:var(--bg-hover);color:var(--text-primary)}.ep-section-icon{color:var(--text-muted);display:flex}.ep-chevron{color:var(--text-ghost);transition:transform .2s;display:flex}.ep-section-body{padding:4px 16px 12px}.ep-field{margin-bottom:10px}.ep-field:last-child{margin-bottom:0}.ep-label{color:var(--text-muted);letter-spacing:.2px;margin-bottom:4px;font-size:11px;font-weight:500;display:block}.ep-control{width:100%}.ep-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.ep-input{border:1px solid var(--border-subtle);background:var(--bg-surface);width:100%;height:32px;color:var(--text-primary);font-family:var(--font-mono);border-radius:6px;outline:none;padding:0 10px;font-size:12px;transition:all .15s}.ep-input:hover{border-color:var(--border-medium)}.ep-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-muted)}.ep-textarea{border:1px solid var(--border-subtle);background:var(--bg-surface);width:100%;min-height:48px;color:var(--text-primary);font-family:var(--font-body);resize:vertical;border-radius:6px;outline:none;padding:8px 10px;font-size:13px;line-height:1.4;transition:all .15s}.ep-textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-muted)}.ep-select{border:1px solid var(--border-subtle);background:var(--bg-surface);width:100%;height:32px;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a847c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:6px;outline:none;padding:0 28px 0 10px;font-size:12px;transition:all .15s}.ep-select:hover{border-color:var(--border-medium)}.ep-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-muted)}.ep-select-sm{height:28px;font-size:11px}.ep-color-row{align-items:center;gap:6px;display:flex}.ep-color-swatch::-webkit-color-swatch-wrapper{padding:0}.ep-color-swatch::-webkit-color-swatch{border:none;border-radius:4px}.ep-color-row .ep-input{flex:1}.ep-list-item{width:100%;color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:8px;padding:7px 10px;font-size:13px;transition:all .15s;display:flex}.ep-list-item:hover{background:var(--bg-hover);color:var(--text-primary)}.ep-list-item.active{background:var(--accent-light);border-color:var(--border-accent);color:var(--text-primary)}.ep-list-icon{color:var(--text-muted);flex-shrink:0;display:flex}.ep-list-meta{color:var(--text-ghost);font-size:11px;font-family:var(--font-mono);flex-shrink:0}.ep-anim-card{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-muted);margin-bottom:8px;padding:10px}.ep-anim-card:last-child{margin-bottom:0}.ep-anim-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.ep-anim-header .ep-select{flex:1}.ep-root{background:var(--bg-surface);height:100%;color:var(--text-primary);flex-direction:column;font-size:12px;display:flex;overflow-y:auto}.ep-empty{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex}.ep-empty-icon{font-size:28px}.ep-empty-hint{color:var(--text-muted);font-size:11px}.ep-section{border-bottom:1px solid var(--border-subtle)}.ep-section-header{cursor:pointer;width:100%;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:0 0;border:none;justify-content:space-between;align-items:center;gap:6px;padding:8px 12px;font-size:11px;font-weight:600;display:flex}.ep-section-header:hover{background:var(--bg-hover)}.ep-section-left{align-items:center;gap:6px;display:flex}.ep-section-icon{opacity:.6}.ep-chevron{opacity:.5;transition:transform .15s}.ep-chevron.open{transform:rotate(0)}.ep-chevron:not(.open){transform:rotate(-90deg)}.ep-section-body{flex-direction:column;gap:8px;padding:8px 12px 12px;display:flex}.ep-field{flex-direction:column;flex:1;gap:3px;display:flex}.ep-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:500}.ep-control{display:flex}.ep-row{gap:8px;display:flex}.ep-input{border:1px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);border-radius:6px;outline:none;padding:5px 8px;font-size:12px;transition:border-color .12s}.ep-input:focus{border-color:var(--accent-primary)}.ep-textarea{border:1px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);resize:vertical;border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:12px;transition:border-color .12s}.ep-textarea:focus{border-color:var(--accent-primary)}.ep-select{border:1px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);cursor:pointer;border-radius:6px;outline:none;padding:5px 8px;font-size:12px}.ep-select-sm{font-size:11px}.ep-color-row{align-items:center;gap:6px;width:100%;display:flex}.ep-color-swatch{border:1px solid var(--border-default);cursor:pointer;background:0 0;border-radius:5px;flex-shrink:0;width:28px;height:28px;padding:1px}.ep-list{flex-direction:column;gap:2px;display:flex}.ep-list-item{cursor:pointer;text-align:left;width:100%;color:var(--text-primary);background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;transition:background .1s;display:flex}.ep-list-item:hover{background:var(--bg-hover)}.ep-list-item.active{background:var(--accent-muted);color:var(--accent-primary)}.ep-list-icon{opacity:.5;flex-shrink:0}.ep-list-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ep-list-meta{color:var(--text-muted);flex-shrink:0;font-size:10px}.ep-anim-card{border:1px solid var(--border-subtle);background:var(--bg-muted);border-radius:8px;flex-direction:column;gap:6px;padding:8px;display:flex}.ep-anim-header{align-items:center;gap:6px;display:flex}.ep-anim-badge{background:var(--accent-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex}.canvas-overlay{pointer-events:auto;-webkit-user-select:none;user-select:none}.canvas-element-handle{box-sizing:border-box;border:1.5px solid #0000;border-radius:2px;transition:border-color .12s,box-shadow .12s}.canvas-element-handle:hover{border-color:#6366f180;box-shadow:0 0 0 1px #6366f126}.canvas-element-handle.selected{border-color:#6366f1;box-shadow:0 0 0 1px #6366f14d,0 0 12px #6366f11a}.canvas-element-handle.selected:before,.canvas-element-handle.selected:after{content:"";background:#6366f1;border:1.5px solid #fff;border-radius:1px;width:6px;height:6px;position:absolute}.canvas-element-handle.selected:before{box-shadow:calc(100% + 0px)0 0 0 #6366f1;top:-3px;left:-3px}.canvas-element-handle.selected:after{box-shadow:calc(100% + 0px)0 0 0 #6366f1;bottom:-3px;left:-3px}.assets-tab-body{flex-direction:column;flex:1;transition:box-shadow .2s;display:flex;overflow:hidden}.assets-tab-body.drop-active{box-shadow:inset 0 0 0 2px var(--accent-primary)}.assets-tab-toolbar{border-bottom:1px solid var(--border-ghost);align-items:center;gap:12px;padding:14px 16px;display:flex}.assets-upload-btn{color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.assets-upload-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-medium)}.assets-upload-btn:disabled{opacity:.4;cursor:not-allowed}.assets-drop-hint{color:var(--text-ghost);font-size:11px}.assets-tab-content{flex:1;padding:12px;overflow-y:auto}.assets-tab-content::-webkit-scrollbar{width:3px}.assets-tab-content::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}.asset-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;display:grid}.asset-card{border-radius:var(--radius-md);border:1px solid var(--border-ghost);background:var(--bg-surface);flex-direction:column;transition:all .18s;display:flex;overflow:hidden}.asset-card:hover{border-color:var(--border-medium);box-shadow:0 2px 8px #0000000f}.asset-card-thumb{aspect-ratio:1;background:var(--bg-elevated);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.asset-card-thumb.is-video{background:linear-gradient(135deg,#1a1a1a,#0a0a0a)}.asset-card-thumb img{object-fit:cover;width:100%;height:100%;display:block}.asset-card-overlay{opacity:0;background:#00000080;justify-content:center;align-items:center;gap:6px;transition:opacity .18s;display:flex;position:absolute;inset:0}.asset-card:hover .asset-card-overlay{opacity:1}.asset-overlay-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff3;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.asset-overlay-btn:hover:not(:disabled){background:#ffffff4d;transform:scale(1.05)}.asset-overlay-btn.danger:hover:not(:disabled){background:#dc3c3c99;border-color:#dc3c3c66}.asset-overlay-btn:disabled{opacity:.3;cursor:not-allowed}.asset-card-meta{flex-direction:column;gap:2px;padding:8px 10px;display:flex}.asset-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.asset-card-kind{color:var(--text-ghost);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.assets-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 24px;display:flex}.assets-empty-state p{color:var(--text-secondary);margin:0;font-size:14px;font-weight:500}.assets-empty-state span{color:var(--text-ghost);font-size:12px;line-height:1.5}
