:root{--bg-main: #ffffff;--bg-sidebar: #eff8f2;--bg-sidebar-hover: rgba(18, 122, 64, .1);--bg-sidebar-active: rgba(18, 122, 64, .17);--bg-menu: #ffffff;--bg-input: #ffffff;--text-primary: #1f242b;--text-secondary: #4a525b;--text-muted: #8b939c;--text-faint: #a7afb7;--accent: #16924a;--accent-soft: #e8f6ee;--danger: #e0564f;--border: #e4e8ec;--border-input: #e2e7ec;--menu-sep: #ececef;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--shadow-menu: 0 12px 40px rgba(20, 35, 55, .16), 0 1px 3px rgba(20, 35, 55, .08);--shadow-input: 0 1px 2px rgba(20, 35, 55, .05);--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);color:var(--text-primary);background:var(--bg-main);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:268px;flex-shrink:0;background:var(--bg-sidebar);display:flex;flex-direction:column;padding:10px 10px 8px;-webkit-user-select:none;user-select:none}.sidebar.collapsed{display:none}.win-controls{display:flex;align-items:center;gap:4px;height:38px;padding:0 2px 0 4px;-webkit-app-region:drag}.win-btn{width:30px;height:30px;display:grid;place-items:center;border-radius:var(--r-sm);color:var(--text-secondary);-webkit-app-region:no-drag}.win-btn:hover{background:var(--bg-sidebar-hover)}.nav{margin-top:6px}.nav-item{width:100%;display:flex;align-items:center;gap:11px;height:36px;padding:0 9px;border-radius:var(--r-sm);font-size:14.5px;color:var(--text-primary);text-align:left}.nav-item:hover{background:var(--bg-sidebar-hover)}.nav-item .ic{color:var(--text-secondary);flex-shrink:0;display:grid;place-items:center}.nav-item.brand .ic{color:var(--accent)}.section{margin-top:18px}.section-head{display:flex;align-items:center;gap:5px;padding:0 10px;height:26px;font-size:12px;font-weight:500;letter-spacing:.01em;color:var(--text-muted)}.section-head.button{width:100%;cursor:pointer;border-radius:var(--r-sm)}.section-head.button:hover{background:var(--bg-sidebar-hover)}.section-head .chev{transition:transform .15s ease}.section-head .chev.open{transform:rotate(90deg)}.filter-btn{margin-left:auto;display:grid;place-items:center;width:22px;height:22px;border-radius:6px;color:var(--text-muted)}.filter-btn:hover{background:var(--bg-sidebar-hover);color:var(--text-secondary)}.project-row{display:flex;align-items:center;gap:10px;height:34px;padding:0 9px;border-radius:var(--r-sm);font-size:14.5px;cursor:pointer}.project-row:hover{background:var(--bg-sidebar-hover)}.project-row.active{background:var(--bg-sidebar-active)}.project-row .ic{color:var(--text-secondary)}.chat-item{display:flex;align-items:center;gap:10px;height:33px;padding:0 10px 0 12px;margin-left:2px;border-radius:var(--r-sm);font-size:14px;color:var(--text-secondary);cursor:pointer}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:#aab4c8;transition:background .15s ease,box-shadow .15s ease}.status-dot.on{background:var(--accent);box-shadow:0 0 0 3px #16924a38}.chat-item:hover{background:var(--bg-sidebar-hover)}.chat-item.active{background:var(--bg-sidebar-active)}.chat-item .title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:7px}.chat-item .pin-dot{color:var(--text-faint);display:inline-flex}.chat-item .time{font-size:12.5px;color:var(--text-faint);flex-shrink:0}.chat-item .unread{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}.sidebar-spacer{flex:1;min-height:8px}.sidebar-bottom{padding-top:4px}.main{flex:1;display:flex;flex-direction:column;background:var(--bg-main);min-width:0;position:relative}.topbar{height:52px;display:flex;align-items:center;padding:0 16px;position:relative;-webkit-app-region:drag}.topbar-col{width:100%;max-width:880px;margin:0 auto;padding:0 32px;display:flex;align-items:center}.topbar-toggle{position:absolute;left:10px;top:50%;transform:translateY(-50%);-webkit-app-region:no-drag}.open-in{display:flex;align-items:center;gap:7px;height:34px;padding:0 10px 0 12px;border-radius:var(--r-sm);background:#fff;border:1px solid var(--border);font-size:14px;font-weight:500;box-shadow:var(--shadow-input);-webkit-app-region:no-drag}.open-in:hover{background:#fbfcfd}.open-in .send-ic{color:var(--accent)}.topbar .win-btn{-webkit-app-region:no-drag}.canvas{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 24px 96px}.hero-title{font-size:30px;font-weight:500;letter-spacing:-.01em;color:var(--text-primary);margin-bottom:26px;text-align:center}.composer-wrap{width:100%;max-width:720px}.composer{background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--r-lg);padding:14px 16px 10px;box-shadow:0 2px 10px #1423370d;transition:border-color .15s ease,box-shadow .15s ease}.composer:focus-within{border-color:#cdd7e2;box-shadow:0 4px 18px #14233714}.composer.dragover{border-color:var(--accent);box-shadow:0 0 0 3px #16924a29}.attachments{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.composer-quote{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding:8px 10px 8px 12px;border-radius:10px;background:#f1f3f5;border:1px solid var(--border)}.composer-quote .cq-icon{flex-shrink:0;color:var(--text-muted);font-size:14px}.composer-quote .cq-text{flex:1;min-width:0;font-size:13.5px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.composer-quote .cq-x{flex-shrink:0;width:22px;height:22px;display:grid;place-items:center;border-radius:50%;color:var(--text-muted);font-size:16px;line-height:1}.composer-quote .cq-x:hover{background:#141e2d1a;color:var(--text-secondary)}.attach{position:relative;height:56px;border-radius:10px;overflow:hidden;border:1px solid var(--border-input);background:#f4f5f7}.attach img{height:56px;width:56px;object-fit:cover;display:block}.attach-file{display:flex;align-items:center;height:56px;max-width:190px;padding:0 12px;font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attach-x{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:#141e2d99;color:#fff;font-size:14px;line-height:1;display:grid;place-items:center}.attach-x:hover{background:#141e2dd9}.composer textarea{width:100%;border:none;outline:none;resize:none;font-family:inherit;font-size:16px;line-height:1.5;color:var(--text-primary);background:transparent;min-height:26px;max-height:220px}.composer textarea::placeholder{color:var(--text-faint)}.composer-tools{display:flex;align-items:center;gap:8px;margin-top:8px}.tool-btn{display:grid;place-items:center;width:32px;height:32px;border-radius:var(--r-sm);color:var(--text-secondary)}.tool-btn:hover{background:var(--bg-sidebar-hover)}.chip{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 9px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;color:var(--text-secondary)}.chip:hover{background:var(--bg-sidebar-hover)}.chip.accent{color:var(--accent)}.chip .chev{color:var(--text-faint)}.chip.accent .chev{color:var(--accent)}.spacer{flex:1}.send-btn{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#c6ccd2;color:#fff;transition:background .15s ease}.send-btn.ready{background:var(--accent)}.send-btn:disabled{cursor:default}.stop-btn{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#1f242b;color:#fff;margin-right:2px}.stop-btn:hover{background:#2c333c}.context-chip{display:inline-flex;align-items:center;gap:7px;height:30px;margin-top:10px;margin-left:4px;padding:0 10px;border-radius:var(--r-sm);font-size:13.5px;color:var(--text-secondary)}.context-chip:hover{background:var(--bg-sidebar-hover)}.context-chip .ic{color:var(--text-muted)}.menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50}.menu{position:fixed;z-index:51;min-width:230px;background:var(--bg-menu);border-radius:var(--r-md);box-shadow:var(--shadow-menu);padding:6px;animation:menu-in .1s ease}@keyframes menu-in{0%{opacity:0;transform:translateY(-3px) scale(.99)}to{opacity:1;transform:none}}.menu-item{width:100%;display:flex;align-items:center;gap:11px;height:34px;padding:0 10px;border-radius:var(--r-sm);font-size:14px;color:var(--text-primary);text-align:left}.menu-item:hover{background:var(--bg-sidebar-hover)}.menu-item.danger,.menu-item.danger .ic{color:var(--danger)}.menu-item .ic{color:var(--text-secondary);flex-shrink:0}.menu-item .shortcut{margin-left:auto;color:var(--text-faint);font-size:13px}.menu-item .chev-r{margin-left:auto;color:var(--text-faint)}.menu-sep{height:1px;background:var(--menu-sep);margin:6px 8px}.menu.compact{padding:5px}.menu.compact .menu-item{height:29px;font-size:13px;padding:0 9px;gap:9px}.menu.compact .menu-sep{margin:5px 8px}.submenu-wrap{position:relative}.menu.submenu{position:absolute;left:100%;top:-5px;margin-left:2px;animation:none}.menu-account{padding:8px 10px 6px}.menu-account .email{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--text-secondary)}.menu-account .email .ic{color:var(--text-muted)}.menu-account .sub{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text-muted);margin-top:4px}.menu-account .sub .ic{color:var(--text-faint)}.dropdown{min-width:210px}.dropdown .menu-item .check{margin-left:auto;color:var(--accent)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:60;background:#1f242b;color:#fff;font-size:13.5px;padding:9px 16px;border-radius:10px;box-shadow:0 8px 28px #00000040;animation:menu-in .12s ease}.topbar-left{display:flex;align-items:center;gap:6px;margin-right:auto}.chat-header{display:flex;align-items:center;gap:4px}.chat-title{font-size:15px;font-weight:600;color:var(--text-primary)}.canvas.chat-mode{padding:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start}.chatview{flex:1;display:flex;flex-direction:column;min-height:0;width:100%;position:relative}.jump-down{position:absolute;left:50%;transform:translate(-50%);bottom:152px;z-index:40;width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:var(--bg-main);border:1px solid var(--border);color:var(--text-secondary);box-shadow:0 4px 14px #0f233724}.jump-down:hover{background:#fbfcfd;color:var(--text-primary)}.jump-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;display:grid;place-items:center}.quote-pop{position:fixed;z-index:60;transform:translate(-50%);display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:9px;background:#1f242b;color:#fff;font-size:13px;font-weight:500;box-shadow:0 8px 24px #0f233747;white-space:nowrap}.quote-pop:hover{background:#2c333c}.chat-scroll{flex:1;overflow-y:auto}.chat-col{max-width:880px;margin:0 auto;padding:8px 32px 24px}.queue-bar{flex-shrink:0;max-height:30vh;overflow-y:auto}.queue-bar .chat-col{padding-top:4px;padding-bottom:6px}.chat-composer{padding-bottom:18px}.chat-composer .composer-wrap{max-width:none}.msg-assistant{padding:16px 0 6px}.worked{display:inline-flex;align-items:center;gap:3px;color:var(--text-muted);font-size:14px;padding:4px 6px 4px 0;margin-bottom:4px;border-bottom:1px solid transparent}.worked:hover{color:var(--text-secondary)}.msg-text{font-size:15.5px;line-height:1.62;color:var(--text-primary);margin:11px 0}.msg-md{font-size:15.5px;line-height:1.62;color:var(--text-primary)}.msg-md>*:first-child{margin-top:4px}.msg-md>*:last-child{margin-bottom:0}.msg-md p{margin:10px 0}.msg-md h1,.msg-md h2,.msg-md h3,.msg-md h4{margin:18px 0 8px;line-height:1.3;font-weight:650}.msg-md h1{font-size:1.4em}.msg-md h2{font-size:1.25em}.msg-md h3{font-size:1.1em}.msg-md h4{font-size:1em}.msg-md strong{font-weight:650}.msg-md em{font-style:italic}.msg-md ul,.msg-md ol{margin:10px 0;padding-left:24px}.msg-md li{margin:4px 0}.msg-md li::marker{color:var(--text-muted)}.msg-md a{color:var(--accent);text-decoration:none}.msg-md a:hover{text-decoration:underline}.msg-md blockquote{margin:10px 0;padding:2px 14px;border-left:3px solid var(--border);color:var(--text-secondary)}.msg-md hr{border:none;border-top:1px solid var(--border);margin:18px 0}.msg-md pre{margin:12px 0;padding:14px 16px;background:#f4f5f7;border-radius:12px;overflow-x:auto}.msg-md pre code{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:13.5px;line-height:1.6;color:var(--text-primary);background:none;padding:0}.msg-md table{border-collapse:collapse;margin:12px 0;font-size:14px;display:block;overflow-x:auto}.msg-md th,.msg-md td{border:1px solid var(--border);padding:7px 12px;text-align:left}.msg-md th{background:#f4f5f7;font-weight:600}.inline-code{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:.86em;background:#eceef1;padding:2px 6px;border-radius:6px}.code-block{background:#f4f5f7;border-radius:12px;margin:14px 0;overflow:hidden}.code-head{display:flex;align-items:center;justify-content:space-between;padding:9px 10px 6px 14px}.code-head .lang{font-size:13px;color:var(--text-muted)}.code-actions{display:flex;gap:2px}.ic-btn{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;color:var(--text-muted)}.ic-btn:hover{background:#0f23370f;color:var(--text-secondary)}.code-body{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:14px;line-height:1.65;color:var(--text-primary);padding:2px 16px 16px;white-space:pre-wrap;word-break:break-word}.msg-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-size:15.5px;text-decoration:none;margin:12px 0}.msg-link:hover{text-decoration:underline}.msg-actions{display:flex;align-items:center;gap:2px;margin-top:12px}.msg-time{font-size:13px;color:var(--text-faint);margin-left:8px}.msg-user{display:flex;justify-content:flex-end;padding:12px 0}.msg-user .bubble{position:relative;background:#eceef1;color:var(--text-primary);font-size:15.5px;line-height:1.5;padding:11px 16px;border-radius:18px;max-width:100%;overflow-wrap:anywhere;white-space:pre-wrap}.msg-stack{display:flex;flex-direction:column;align-items:flex-end;gap:7px;max-width:78%;min-width:0}.msg-quote{max-width:100%;padding:6px 12px;border-left:3px solid var(--border);font-size:13.5px;line-height:1.45;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.msg-atts{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:7px}.msg-att-img{display:block;max-width:260px;max-height:320px;border-radius:16px;object-fit:cover;border:1px solid var(--border)}.msg-att-file{display:inline-flex;align-items:center;gap:8px;max-width:260px;padding:10px 14px;border-radius:14px;background:#f1f3f5;border:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.msg-att-file .att-file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-user.pending{align-items:center;gap:8px}.msg-user.pending .msg-stack{opacity:.55}.msg-user.queued{padding:5px 0}.msg-user.queued .bubble{font-size:13.5px;padding:8px 13px;border-radius:15px}.msg-user.queued .msg-stack{max-width:68%}.msg-user.queued .queue-x{width:22px;height:22px;font-size:15px}.queue-x{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:#141e2d14;color:var(--text-muted);display:grid;place-items:center;font-size:17px;line-height:1}.queue-x:hover{background:#141e2d29;color:var(--text-secondary)}.worked .chev{transition:transform .15s ease}.worked .chev.open{transform:rotate(90deg)}.worked-count{color:var(--text-faint);margin-left:4px}.worked-static{display:inline-flex;align-items:center;gap:4px;color:var(--text-muted);cursor:default}.process{margin:4px 0 12px;display:flex;flex-direction:column;gap:1px}.proc-item{display:flex;flex-direction:column}.process-row{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:4px 8px;border-radius:7px;font-size:13.5px;color:var(--text-muted);min-width:0}.process-row:hover{background:#0f23370d}.process-row .proc-name{flex:1;min-width:0;color:var(--text-muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.process-row .chev{flex-shrink:0;color:var(--text-faint);transition:transform .15s ease}.process-row .chev.open{transform:rotate(90deg)}.proc-detail-group{display:flex;flex-direction:column;gap:1px;margin:2px 0 6px 8px;padding-left:10px;border-left:2px solid var(--border)}.proc-sub{display:flex;align-items:center;gap:8px;padding:3px 4px;font-size:12.5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;min-width:0}.proc-sub-name{color:var(--text-secondary);font-weight:600;flex-shrink:0}.proc-sub-arg{flex:1;min-width:0;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.worked.working{display:inline-flex;align-items:center;gap:8px;color:var(--text-muted)}.dot-pulse{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.msg-tool{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);background:#f4f5f7;border-radius:8px;padding:6px 11px;margin:8px 0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.msg-tool .tool-name{color:var(--text-secondary);font-weight:600}.msg-tool .tool-arg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rename-input{width:100%;font-family:inherit;font-size:14px;color:var(--text-primary);background:#fff;border:1.5px solid var(--accent);border-radius:6px;padding:4px 8px;outline:none}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#fff;padding:24px}.login-card{width:100%;max-width:440px;display:flex;flex-direction:column;text-align:center}.login-title{font-size:40px;line-height:1.12;font-weight:700;letter-spacing:-.02em;color:#0d0d0d;margin-bottom:16px}.login-sub{font-size:17px;line-height:1.5;color:#6b7280;margin-bottom:28px}.login-input{height:58px;border:1px solid #d5d5d8;border-radius:16px;padding:0 20px;font-size:16px;font-family:inherit;color:#0d0d0d;background:#fff;outline:none;margin-bottom:10px;transition:border-color .15s ease}.login-input::placeholder{color:#9aa0a6}.login-input:focus{border-color:#0d0d0d}.login-error{font-size:14px;color:var(--danger);margin:4px 2px 8px;text-align:left}.login-btn{height:58px;border-radius:30px;background:#0d0d0d;color:#fff;font-size:16px;font-weight:600;margin-top:6px;transition:opacity .15s ease}.login-btn:hover{opacity:.88}.login-btn:disabled{opacity:.5;cursor:default}.palette-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#121e3038}.palette{position:fixed;z-index:71;top:12vh;left:50%;transform:translate(-50%);width:560px;max-width:calc(100vw - 32px);max-height:70vh;background:#fff;border-radius:16px;box-shadow:0 24px 70px #121e3047,0 2px 6px #121e301a;display:flex;flex-direction:column;overflow:hidden;animation:menu-in .12s ease}.palette-input{border:none;outline:none;font-family:inherit;font-size:17px;color:var(--text-primary);padding:18px 20px;background:transparent}.palette-input::placeholder{color:var(--text-faint)}.palette-list{overflow-y:auto;padding:4px 8px 10px}.palette-empty{padding:18px;text-align:center;color:var(--text-muted);font-size:14px}.palette-group{margin-top:6px}.palette-group-label{padding:8px 12px 5px;font-size:12.5px;font-weight:500;color:var(--text-muted)}.palette-item{width:100%;display:flex;align-items:center;gap:12px;height:40px;padding:0 12px;border-radius:10px;font-size:15px;color:var(--text-primary);text-align:left}.palette-item.active{background:#0f23370f}.pi-icon{display:grid;place-items:center;width:20px;color:var(--text-secondary);flex-shrink:0}.pi-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kbd{font-size:12.5px;color:var(--text-muted);background:#f0f1f4;padding:3px 9px;border-radius:8px;flex-shrink:0}.drop-overlay{position:absolute;top:8px;right:8px;bottom:8px;left:8px;z-index:80;pointer-events:none;display:grid;place-items:center;border-radius:16px;border:2px dashed rgba(22,146,74,.5);background:#16924a12}.drop-hint{padding:8px 16px;border-radius:10px;background:var(--bg-main);border:1px solid var(--accent-soft);color:var(--accent);font-size:14px;font-weight:600;box-shadow:0 4px 16px #0f23371a}
