.connect-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:24px}.connect-content{text-align:center;max-width:360px;width:100%}.connect-icon{color:var(--accent);margin-bottom:24px}.connect-title{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.connect-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:24px;line-height:1.5}.server-input-group{margin-bottom:20px;text-align:left}.input-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.server-input{width:100%;padding:12px 14px;font-size:16px;font-family:var(--font-mono);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;transition:border-color .2s,background .2s;box-sizing:border-box;-webkit-appearance:none}.server-input:focus{border-color:var(--accent);background:var(--bg-input)}.server-input::placeholder{color:var(--text-muted);opacity:.6}.input-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:4px}.code-input-group{margin-bottom:24px;text-align:left}.session-code-input{width:100%;padding:14px 16px;text-align:center;font-size:22px;font-weight:700;letter-spacing:4px;font-family:var(--font-mono);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;transition:border-color .2s,background .2s;box-sizing:border-box;-webkit-appearance:none;text-transform:uppercase}.session-code-input:focus{border-color:var(--accent);background:var(--bg-input)}.session-code-input::placeholder{color:var(--text-muted);opacity:.4;letter-spacing:3px;font-weight:400}.session-code-input:disabled{opacity:.6}.connect-status{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--accent);font-size:14px;margin-bottom:16px}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.connect-error{color:var(--danger);font-size:14px;padding:10px 16px;background:#ef44441a;border-radius:var(--radius-sm);margin-bottom:16px}.connect-button{width:100%;padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .2s,transform .1s;margin-bottom:16px}.connect-button:hover:not(:disabled){opacity:.9}.connect-button:active:not(:disabled){transform:scale(.98)}.connect-button:disabled{opacity:.4;cursor:not-allowed}.connect-help{font-size:12px;color:var(--text-muted);line-height:1.6;margin-top:32px}.connect-divider{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:var(--text-muted);font-size:13px}.connect-divider:before,.connect-divider:after{content:"";flex:1;height:1px;background:var(--border)}.cloud-mode-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;font-size:15px;font-weight:600;color:var(--text-primary);background:transparent;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;margin-bottom:16px}.cloud-mode-button:hover:not(:disabled){border-color:var(--accent);background:var(--bg-secondary)}.cloud-mode-button:active:not(:disabled){transform:scale(.98)}.cloud-mode-button:disabled{opacity:.4;cursor:not-allowed}.cloud-login-screen{display:flex;align-items:center;justify-content:center;height:100%;padding:24px;position:relative}.cloud-login-content{text-align:center;max-width:360px;width:100%;position:relative}.cloud-back-btn{position:absolute;top:-48px;left:0;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:color .2s,background .2s;display:flex;align-items:center;gap:6px}.cloud-back-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.cloud-login-icon{color:var(--accent);margin-bottom:20px}.cloud-login-title{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.cloud-login-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:32px;line-height:1.5}.cloud-login-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.cloud-provider-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:14px 20px;font-size:15px;font-weight:600;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;background:var(--bg-secondary);color:var(--text-primary)}.cloud-provider-btn:hover:not(:disabled){border-color:var(--accent);background:var(--bg-tertiary)}.cloud-provider-btn:active:not(:disabled){transform:scale(.98)}.cloud-provider-btn:disabled{opacity:.5;cursor:not-allowed}.github-btn svg{flex-shrink:0}.google-btn svg{flex-shrink:0}.cloud-login-status{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--accent);font-size:14px;margin-bottom:16px}.cloud-login-error{color:var(--danger);font-size:14px;padding:10px 16px;background:#ef44441a;border-radius:var(--radius-sm);margin-bottom:16px;text-align:left}.cloud-login-help{font-size:12px;color:var(--text-muted);line-height:1.6;margin-top:16px}.chat-screen{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:10px}.status-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-indicator.connected{background:var(--success)}.status-indicator.disconnected{background:var(--danger)}.chat-header-title{font-size:15px;font-weight:600}.chat-header-subtitle{font-size:12px;color:var(--text-muted)}.chat-header-actions{display:flex;gap:4px}.header-btn{position:relative;background:none;border:none;color:var(--text-secondary);padding:8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s,color .2s}.header-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.approval-badge .badge{position:absolute;top:2px;right:2px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;color:var(--text-secondary);gap:8px}.chat-empty-icon{font-size:48px;margin-bottom:8px}.chat-empty-hint{font-size:13px;color:var(--text-muted);max-width:260px}.chat-bubble{max-width:85%}.chat-bubble.user{align-self:flex-end}.chat-bubble.assistant{align-self:flex-start}.bubble-content{padding:10px 14px;border-radius:var(--radius);font-size:14px;line-height:1.6;word-break:break-word;white-space:pre-wrap}.chat-bubble.user .bubble-content{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-bubble.assistant .bubble-content{background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px}.chat-bubble.action-bubble .bubble-content{background:#6366f114;border:1px solid rgba(99,102,241,.15);color:var(--text-secondary);font-size:13px;padding:8px 12px;border-radius:8px}.bubble-content.error{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.code-block{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin:8px 0;overflow-x:auto;font-family:var(--font-mono);font-size:13px;line-height:1.5}.code-lang{font-size:11px;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-family:var(--font-mono)}.inline-code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:13px}.thinking-indicator{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-secondary);border-radius:var(--radius);border-bottom-left-radius:4px;color:var(--text-secondary);font-size:13px}.thinking-dots{display:flex;gap:4px}.thinking-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.4s ease-in-out infinite}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}.streaming-cursor{display:inline-block;width:2px;height:16px;background:var(--accent);margin-left:2px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-input-container{padding:12px 16px;background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0}.chat-input-wrapper{display:flex;align-items:flex-end;gap:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:6px 6px 6px 14px}.chat-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:15px;resize:none;outline:none;font-family:inherit;line-height:1.5;max-height:120px;padding:6px 0}.chat-input::placeholder{color:var(--text-muted)}.send-btn{flex-shrink:0;width:36px;height:36px;border:none;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,opacity .2s}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn:not(:disabled):hover{background:var(--accent-hover)}.model-selector-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--accent);font-size:12px;padding:0;cursor:pointer;font-family:inherit}.model-selector-btn:active{opacity:.7}.model-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding-top:70px;animation:fadeIn .15s ease}.model-picker{background:var(--bg-secondary);border-radius:var(--radius-md, 12px);width:90%;max-width:340px;box-shadow:0 8px 32px #0000004d;overflow:hidden;animation:slideDown .2s ease}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.model-picker-title{padding:14px 16px 8px;font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.model-option{display:flex;align-items:center;width:100%;padding:12px 16px;border:none;background:none;cursor:pointer;text-align:left;color:var(--text-primary);font-family:inherit;transition:background .15s;position:relative}.model-option:hover{background:var(--bg-tertiary)}.model-option.selected{background:#6366f11a}.model-option-name{font-size:14px;font-weight:500;flex:1}.model-option-vendor{font-size:12px;color:var(--text-muted);margin-right:8px}.model-check{color:var(--accent);flex-shrink:0}.chat-bubble.approval-bubble{max-width:92%}.chat-bubble.approval-bubble .bubble-content{background:var(--bg-secondary);border:1px solid rgba(251,191,36,.3);border-left:3px solid #fbbf24;color:var(--text-primary);font-size:13px;padding:10px 14px;border-radius:8px}.inline-approval-actions{display:flex;gap:8px;margin-top:8px;padding:0 2px}.inline-approval-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0;border:none;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,transform .1s}.inline-approval-btn:active{transform:scale(.97)}.inline-approval-btn.approve{background:#22c55e;color:#fff}.inline-approval-btn.approve:hover{background:#16a34a}.inline-approval-btn.deny{background:var(--bg-tertiary);color:var(--text-secondary)}.inline-approval-btn.deny:hover{background:#ef444426;color:var(--danger)}.inline-approval-resolved{font-size:12px;color:var(--text-muted);padding:4px 0 0;font-style:italic}.dashboard{display:flex;flex-direction:column;height:100%;overflow:hidden}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.dashboard-header h2{font-size:18px;font-weight:600}.dashboard-path{font-size:12px;color:var(--text-muted);font-family:var(--font-mono);margin-top:2px}.dashboard-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.dashboard-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:20px}.stats-row{display:flex;gap:10px}.stat-card{flex:1;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center}.stat-value{font-size:28px;font-weight:700;font-family:var(--font-mono)}.stat-value.error{color:var(--danger)}.stat-value.warning{color:var(--warning)}.stat-label{font-size:12px;color:var(--text-muted);margin-top:4px}.dashboard-section h3{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.file-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.file-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:13px}.file-item.active{border:1px solid var(--accent);background:#3b82f61a}.file-name{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-icon{flex-shrink:0}.change-badge{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-weight:700;font-size:14px;font-family:var(--font-mono);flex-shrink:0}.change-badge[data-type=created]{background:#22c55e33;color:var(--success)}.change-badge[data-type=modified]{background:#3b82f633;color:var(--accent)}.change-badge[data-type=deleted]{background:#ef444433;color:var(--danger)}.terminal-output{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:10px;max-height:300px;overflow-y:auto;font-family:var(--font-mono);font-size:12px;line-height:1.5}.terminal-cmd{color:var(--success);font-weight:600;margin-top:8px}.terminal-cmd:first-child{margin-top:0}.terminal-text{color:var(--text-secondary);white-space:pre-wrap;word-break:break-all}.workspace-picker{height:100%;display:flex;flex-direction:column;background:var(--bg-primary)}.wsp-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}.wsp-back{background:none;border:none;color:var(--accent);font-size:15px;cursor:pointer;padding:4px 0}.wsp-title{font-size:18px;font-weight:700;color:var(--text-primary);flex:1}.wsp-user{font-size:12px;color:var(--text-secondary)}.wsp-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:var(--text-secondary)}.wsp-hint{font-size:13px;color:var(--text-muted);margin-top:8px}.wsp-section{padding:12px 20px}.wsp-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.wsp-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;margin-bottom:6px;background:var(--bg-secondary);border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:border-color .2s,background .2s}.wsp-item:hover:not(.offline){background:var(--bg-hover)}.wsp-item.active{border-color:var(--accent)}.wsp-item.offline{opacity:.5;cursor:default}.wsp-item-icon{flex-shrink:0}.wsp-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.wsp-dot.online{background:#22c55e;box-shadow:0 0 6px #22c55e66}.wsp-dot.offline{background:var(--text-muted)}.wsp-item-info{flex:1;min-width:0}.wsp-item-name{display:block;font-size:15px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wsp-item-file{display:block;font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.wsp-item-errors{display:inline-block;font-size:11px;color:var(--danger);margin-top:2px}.wsp-active-badge{font-size:11px;font-weight:600;color:var(--accent);padding:2px 8px;background:#6366f126;border-radius:10px;flex-shrink:0}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-input: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--border: #334155;--radius: 12px;--radius-sm: 8px;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation}#root{height:100%;width:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}@supports (padding: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-slide-up{animation:slideUp .3s ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}
