*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--surface: #1a1a1a;--surface2: #252525;--surface3: #2d2d2d;--user-bg: #1d4ed8;--text: #e5e7eb;--text-muted: #6b7280;--text-dim: #4b5563;--border: #2a2a2a;--border2: #374151;--tool-bg: #111827;--tool-border: #1f2937;--error: #ef4444;--success: #10b981;--accent: #3b82f6;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace;--radius: 12px;--radius-sm: 8px}html,body,#root{height:100%;width:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100%;max-width:800px;margin:0 auto}.header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;gap:8px;padding-top:max(10px,env(safe-area-inset-top))}.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-dim);display:inline-block}.status-dot.connected{background:var(--success)}.status-dot.connecting{background:#f59e0b;animation:pulse 1s infinite}.status-dot.error{background:var(--error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.icon-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:color .15s,background .15s}.icon-btn:hover{color:var(--text);background:var(--surface2)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.dir-selector{position:relative;flex:1;min-width:0}.cwd-btn{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;width:100%;min-width:0;font-size:13px;transition:background .15s}.cwd-btn:hover{background:var(--surface3)}.cwd-btn:disabled{opacity:.5;cursor:not-allowed}.cwd-icon{flex-shrink:0}.cwd-path{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;color:var(--text-muted);font-family:var(--font-mono);font-size:12px}.cwd-chevron{flex-shrink:0;color:var(--text-dim);font-size:11px}.dir-picker{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);z-index:100;overflow:hidden;box-shadow:0 8px 24px #00000080}.dir-option{display:block;width:100%;padding:10px 12px;text-align:left;background:none;border:none;color:var(--text);font-family:var(--font-mono);font-size:12px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dir-option:hover{background:var(--surface3)}.dir-option.active{color:var(--accent)}.dir-custom{display:flex;gap:6px;padding:8px}.dir-custom input{flex:1;background:var(--surface3);border:1px solid var(--border2);color:var(--text);padding:6px 10px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:12px;outline:none}.dir-custom input:focus{border-color:var(--accent)}.dir-custom button{background:var(--accent);border:none;color:#fff;padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px}.dir-custom button:disabled{opacity:.5;cursor:not-allowed}.chat-window{flex:1;overflow-y:auto;padding:16px 12px;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--surface3) transparent}.chat-window::-webkit-scrollbar{width:4px}.chat-window::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-muted);padding:40px 0}.empty-icon{width:52px;height:52px;background:var(--user-bg);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:#fff;margin-bottom:8px}.empty-hint{font-size:13px;color:var(--text-dim)}.message{display:flex}.user-message{justify-content:flex-end}.user-bubble{background:var(--user-bg);color:#fff;padding:10px 14px;border-radius:var(--radius) var(--radius) 4px var(--radius);max-width:80%;word-break:break-word;white-space:pre-wrap}.assistant-message{justify-content:flex-start}.assistant-content{max-width:100%;width:100%;display:flex;flex-direction:column;gap:6px}.text-block{background:var(--surface);padding:10px 14px;border-radius:var(--radius);word-break:break-word;white-space:pre-wrap;max-width:88%}.streaming .text-block:after{content:"▋";animation:blink .8s infinite;color:var(--accent);font-size:.9em}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.system-message{text-align:center;font-size:12px;color:var(--text-dim);padding:4px 0}.system-message.error{color:var(--error)}.thinking-indicator{display:flex;gap:4px;padding:12px 16px;background:var(--surface);border-radius:var(--radius);width:fit-content}.thinking-indicator .dot{width:7px;height:7px;border-radius:50%;background:var(--text-dim);animation:bounce 1.2s infinite}.thinking-indicator .dot:nth-child(2){animation-delay:.2s}.thinking-indicator .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-4px);opacity:1}}.tool-card{background:var(--tool-bg);border:1px solid var(--tool-border);border-radius:var(--radius-sm);overflow:hidden;max-width:100%}.tool-card-error{border-color:#ef444466}.tool-header{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;color:var(--text);cursor:pointer;text-align:left;font-size:13px;transition:background .1s;min-width:0}.tool-header:hover{background:#ffffff0a}.tool-icon{flex-shrink:0;font-size:14px}.tool-label{font-weight:600;color:var(--text-muted);flex-shrink:0;font-size:12px}.tool-summary{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono);font-size:12px;color:var(--text-dim)}.tool-chevron{flex-shrink:0;font-size:10px;color:var(--text-dim)}.tool-spinner{width:12px;height:12px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.tool-body{border-top:1px solid var(--tool-border);padding:0}.tool-code{padding:10px 12px;font-family:var(--font-mono);font-size:12px;color:var(--text-muted);white-space:pre-wrap;word-break:break-all;background:#0000004d;overflow-x:auto}.tool-result{border-top:1px solid var(--tool-border)}.tool-result pre{padding:10px 12px;font-family:var(--font-mono);font-size:11px;color:var(--text-muted);white-space:pre-wrap;word-break:break-all;overflow-x:auto;max-height:200px;overflow-y:auto}.tool-result-error pre{color:#fca5a5}.input-bar{padding:10px 12px;padding-bottom:max(10px,env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);flex-shrink:0}.input-wrapper{display:flex;align-items:flex-end;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);padding:6px 6px 6px 12px;transition:border-color .15s}.input-wrapper:focus-within{border-color:var(--accent)}.input-textarea{flex:1;background:none;border:none;outline:none;resize:none;color:var(--text);font-size:15px;font-family:inherit;line-height:1.5;padding:4px 0;min-height:28px;max-height:160px;overflow-y:auto;scrollbar-width:thin}.input-textarea::placeholder{color:var(--text-dim)}.input-textarea:disabled{opacity:.5;cursor:not-allowed}.send-btn{width:36px;height:36px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,transform .1s}.send-btn:hover{background:#2563eb}.send-btn:active{transform:scale(.93)}.send-btn:disabled{background:var(--surface3);color:var(--text-dim);cursor:not-allowed}.abort-btn{background:var(--error);font-size:13px}.abort-btn:hover{background:#dc2626}.login-screen{height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:16px}.login-logo{width:64px;height:64px;background:var(--user-bg);border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff}.login-card h1{font-size:22px;font-weight:700}.login-card p{font-size:14px;color:var(--text-muted);text-align:center}.login-card input{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:12px 16px;border-radius:var(--radius-sm);font-size:15px;outline:none;text-align:center;font-family:var(--font-mono);letter-spacing:.1em}.login-card input:focus{border-color:var(--accent)}.login-card button{width:100%;background:var(--accent);border:none;color:#fff;padding:12px;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:background .15s}.login-card button:hover{background:#2563eb}
