:root{--bg-0: #0a0a0b;--bg-1: #141416;--bg-2: #1c1c1f;--bg-3: #27272a;--border: #2e2e32;--text: #e4e4e7;--text-dim: #a1a1aa;--text-muted: #71717a;--accent: #6366f1;--accent-hover: #818cf8;--success: #22c55e;--error: #ef4444;--radius: 12px;--radius-sm: 8px;--transition: .15s ease}body{background:var(--bg-0);color:var(--text);overflow:hidden;height:100dvh}.app{display:flex;height:100dvh}.chat-panel{width:420px;min-width:320px;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-1)}.chat-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.chat-header h1{font-size:16px;font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.msg{padding:12px 16px;border-radius:var(--radius);max-width:90%;line-height:1.5;font-size:14px}.msg-user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.msg-assistant{background:var(--bg-2);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px}.msg-error{background:#ef44441a;border:1px solid var(--error);color:var(--error);align-self:center}.chat-input-area{padding:16px 20px;border-top:1px solid var(--border)}.chat-input-wrap{display:flex;gap:8px}.chat-input{flex:1;padding:12px 16px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color var(--transition);resize:none;min-height:44px;max-height:120px}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.send-btn{padding:12px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-weight:600;font-size:14px;cursor:pointer;transition:background var(--transition);white-space:nowrap}.send-btn:hover{background:var(--accent-hover)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.canvas-panel{flex:1;display:flex;flex-direction:column;background:var(--bg-0)}.canvas-toolbar{padding:10px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);background:var(--bg-1)}.toolbar-btn{padding:8px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);font-size:13px;font-family:inherit;cursor:pointer;transition:all var(--transition);font-weight:500}.toolbar-btn:hover{background:var(--bg-3);color:var(--text);border-color:var(--text-muted)}.toolbar-btn.active{border-color:var(--accent);color:var(--accent)}.toolbar-spacer{flex:1}.toolbar-version{font-size:12px;color:var(--text-muted);font-weight:500}.canvas-frame{flex:1;background:var(--bg-0);display:flex;align-items:center;justify-content:center}.canvas-frame iframe{width:100%;height:100%;border:none;background:#fff}.canvas-empty{text-align:center;color:var(--text-muted)}.canvas-empty p{font-size:14px;margin-top:8px}.canvas-empty .icon{font-size:48px;opacity:.3}.version-panel{width:260px;background:var(--bg-1);border-left:1px solid var(--border);display:flex;flex-direction:column}.version-header{padding:16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.version-list{flex:1;overflow-y:auto;padding:8px}.version-item{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);margin-bottom:4px}.version-item:hover{background:var(--bg-2)}.version-item.active{background:var(--bg-3);border:1px solid var(--accent)}.version-item .v-idx{font-size:12px;color:var(--accent);font-weight:600}.version-item .v-prompt{font-size:13px;color:var(--text-dim);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.version-item .v-time{font-size:11px;color:var(--text-muted);margin-top:4px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--bg-0)}.login-card{background:var(--bg-1);border:1px solid var(--border);border-radius:16px;padding:40px 32px;width:100%;max-width:380px;text-align:center}.login-card h1{font-size:24px;font-weight:700;margin-bottom:8px}.login-card p{font-size:14px;color:var(--text-muted);margin-bottom:24px}.login-input{width:100%;padding:12px 16px;margin-bottom:16px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;outline:none}.login-input:focus{border-color:var(--accent)}.login-btn{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer}.login-btn:hover{background:var(--accent-hover)}.login-error{color:var(--error);font-size:13px;margin-bottom:12px}.generating{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-sm);font-size:13px;color:var(--accent)}.generating .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:3px}
