:root{--gray-950: #030712;--gray-900: #0b0f17;--gray-850: #111827;--gray-800: #1f2937;--gray-700: #374151;--gray-600: #4b5563;--gray-500: #6b7280;--gray-400: #9ca3af;--gray-300: #d1d5db;--gray-200: #e5e7eb;--gray-100: #f3f4f6;--blue-300: #93c5fd;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--ok: #34d399;--warn: #fbbf24;--fail: #f87171;--bg: var(--gray-950);--panel: var(--gray-900);--border: var(--gray-800);--text: var(--gray-100);--muted: var(--gray-500)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.fade-in{animation:fade-in .25s ease}.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));color:#fff;font-weight:800;font-size:15px;box-shadow:0 4px 14px #2563eb59}.logo-mark.sm{width:26px;height:26px;font-size:13px;border-radius:8px}.logo-mark.lg{width:48px;height:48px;font-size:22px;border-radius:14px}.logo-word{font-weight:700;letter-spacing:-.01em}.login{display:flex;height:100%;overflow:hidden}.login-brand-panel{display:none;flex-direction:column;justify-content:space-between;width:46%;padding:48px;background:radial-gradient(900px 500px at -10% -10%,rgba(37,99,235,.18),transparent 60%),var(--panel);border-right:1px solid var(--border)}@media (min-width: 900px){.login-brand-panel{display:flex}}.login-logo{display:flex;align-items:center;gap:12px}.login-quote{font-size:22px;line-height:1.5;color:var(--gray-300);max-width:30ch;margin:0 0 12px;font-weight:500}.login-pitch-sub{color:var(--gray-600);font-size:13px;margin:0}.login-tags{display:flex;gap:22px}.login-tag{display:flex;align-items:center;gap:8px;color:var(--gray-500);font-size:12px}.login-tag .dot{width:6px;height:6px;border-radius:999px;background:var(--blue-500)}.login-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-in .4s ease}.login-card{width:100%;max-width:360px}.login-logo-compact{margin-bottom:36px}@media (min-width: 900px){.login-logo-compact{display:none}}.login-card h1{font-size:26px;margin:0 0 6px;letter-spacing:-.02em}.login-sub{color:var(--gray-500);font-size:14px;margin:0 0 28px}.login-error{background:#f871711f;border:1px solid rgba(248,113,113,.4);color:#fecaca;font-size:13px;border-radius:10px;padding:10px 14px;margin-bottom:18px}.ms-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:13px;border:none;border-radius:12px;background:#fff;color:#111827;font-weight:600;transition:background .15s ease,transform .05s ease}.ms-button:hover:not(:disabled){background:var(--gray-200)}.ms-button:active:not(:disabled){transform:translateY(1px)}.ms-button:disabled{opacity:.6;cursor:default}.ms-logo{width:18px;height:18px}.login-fine{color:var(--gray-600);font-size:12px;text-align:center;margin-top:28px;line-height:1.5}.spinner{width:16px;height:16px;border:2px solid rgba(17,24,39,.25);border-bottom-color:#111827;border-radius:999px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.workspace{display:flex;height:100%}.sidebar{width:264px;flex-shrink:0;display:flex;flex-direction:column;background:var(--panel);border-right:1px solid var(--border);min-height:0}.sidebar-top{padding:16px 14px 10px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:4px 6px 14px}.new-chat{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--gray-850);color:var(--text);font-weight:500;font-size:14px;transition:background .15s ease,border-color .15s ease}.new-chat:hover{background:var(--gray-800);border-color:var(--gray-700)}.sidebar-list-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 6px;text-transform:uppercase;font-size:11px;letter-spacing:.07em;color:var(--gray-600)}.conversation-list{flex:1;overflow-y:auto;padding:2px 8px 8px;display:flex;flex-direction:column;gap:2px}.conversation-empty{padding:16px 12px;font-size:12px;color:var(--gray-600);text-align:center}.conversation-item{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:9px;color:var(--gray-400);cursor:pointer;transition:background .12s ease,color .12s ease}.conversation-item:hover{background:#1f293799;color:var(--gray-200)}.conversation-item.active{background:var(--gray-800);color:var(--gray-100)}.conversation-meta{flex:1;min-width:0;display:flex;flex-direction:column}.conversation-title{font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:11px;color:var(--gray-600);margin-top:1px}.conversation-delete{opacity:0}.conversation-item:hover .conversation-delete,.conversation-item.active .conversation-delete{opacity:1}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:none;background:transparent;color:var(--gray-500);transition:background .12s ease,color .12s ease}.icon-btn:hover{background:var(--gray-800);color:var(--gray-200)}.icon-btn.danger:hover{background:#7f1d1d66;color:var(--fail)}.sidebar-footer{display:flex;align-items:center;gap:8px;padding:12px 14px;border-top:1px solid var(--border)}.account-chip{flex:1;min-width:0;display:flex;align-items:center;gap:10px}.account-avatar{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;flex-shrink:0;border-radius:999px;background:var(--gray-800);color:var(--gray-200);font-size:12px;font-weight:700}.account-name{font-size:13px;color:var(--gray-300);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat{flex:1;min-width:0;display:flex;flex-direction:column;min-height:0}.transcript{flex:1;overflow-y:auto;min-height:0}.messages{max-width:760px;margin:0 auto;padding:28px 20px 12px;display:flex;flex-direction:column;gap:16px}.welcome{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;gap:6px;animation:fade-in .3s ease}.welcome h2{margin:14px 0 2px;font-size:24px;letter-spacing:-.02em}.welcome p{color:var(--gray-500);margin:0 0 8px;max-width:44ch}.msg{display:flex;animation:fade-in .2s ease}.msg.user{justify-content:flex-end}.user-bubble{max-width:76%;padding:11px 15px;border-radius:18px 18px 4px;background:var(--gray-800);color:var(--gray-100);line-height:1.55;white-space:pre-wrap;word-break:break-word}.msg.assistant{gap:12px;align-items:flex-start}.assistant-avatar{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));color:#fff;font-size:13px;font-weight:700;margin-top:2px}.assistant-body{min-width:0;flex:1;line-height:1.6;color:var(--gray-200);white-space:pre-wrap;word-break:break-word;padding-top:3px}.assistant-body.muted{color:var(--gray-500);font-style:italic}.cursor{display:inline-block;width:7px;height:1em;margin-left:2px;background:var(--blue-500);vertical-align:text-bottom;animation:blink 1s steps(2,start) infinite}@keyframes blink{to{visibility:hidden}}.tool{align-self:flex-start;display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--gray-500);background:var(--panel);border:1px solid var(--border);border-radius:9px;padding:6px 11px;margin-left:40px;max-width:calc(100% - 40px)}.tool-icon{opacity:.7}.tool-name{color:var(--gray-200);font-weight:600}.tool-effect{text-transform:uppercase;font-size:9.5px;letter-spacing:.06em;padding:1px 6px;border-radius:999px;border:1px solid var(--border)}.tool.write .tool-effect{color:var(--warn);border-color:#fbbf2466}.tool.read .tool-effect{color:var(--ok);border-color:#34d39966}.tool-args{color:var(--gray-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-result{align-self:flex-start;font-size:12.5px;margin-left:40px}.tool-result.ok{color:var(--ok)}.tool-result.fail{color:var(--fail)}.note{align-self:flex-start;font-size:13px;color:var(--gray-400);background:var(--panel);border:1px solid var(--border);border-radius:9px;padding:8px 13px;margin-left:40px;max-width:calc(100% - 40px)}.output-block{align-self:stretch;background:#05080f;border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin:0 0 0 40px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;color:var(--gray-200);white-space:pre-wrap;word-break:break-word;max-height:380px;overflow:auto}.error-card{align-self:stretch;background:#f8717114;border:1px solid rgba(248,113,113,.45);border-radius:12px;padding:12px 15px;display:flex;flex-direction:column;gap:6px}.error-head{display:flex;align-items:center;gap:8px}.error-icon{color:var(--fail)}.error-message{font-weight:600}.error-hint{font-size:13px;color:var(--gray-400)}.error-action{align-self:flex-start;margin-top:4px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);padding:6px 12px}.composer{padding:10px 20px 18px}.input-bar{max-width:760px;margin:0 auto;display:flex;align-items:flex-end;gap:8px;padding:10px 10px 10px 16px;background:var(--panel);border:1px solid var(--gray-700);border-radius:18px;transition:border-color .15s ease,box-shadow .15s ease}.input-bar:focus-within{border-color:var(--gray-500);box-shadow:0 0 0 3px #2563eb1f}.input-bar textarea{flex:1;resize:none;border:none;outline:none;background:transparent;color:var(--gray-100);font:inherit;line-height:1.5;max-height:180px;padding:6px 0}.input-bar textarea::placeholder{color:var(--gray-600)}.send-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:none;background:#fff;color:#111827;transition:background .15s ease,transform .05s ease,opacity .15s ease}.send-btn:hover:not(:disabled){background:var(--gray-200)}.send-btn:active:not(:disabled){transform:translateY(1px)}.send-btn:disabled{background:var(--gray-800);color:var(--gray-600);cursor:default}.send-btn.stop{background:var(--gray-200)}.stop-square{width:11px;height:11px;border-radius:3px;background:#111827}.composer-hint{max-width:760px;margin:8px auto 0;text-align:center;font-size:11.5px;color:var(--gray-600)}.transcript::-webkit-scrollbar,.conversation-list::-webkit-scrollbar,.output-block::-webkit-scrollbar{width:10px}.transcript::-webkit-scrollbar-thumb,.conversation-list::-webkit-scrollbar-thumb,.output-block::-webkit-scrollbar-thumb{background:var(--gray-800);border-radius:999px;border:3px solid transparent;background-clip:padding-box}.transcript::-webkit-scrollbar-thumb:hover,.conversation-list::-webkit-scrollbar-thumb:hover{background:var(--gray-700);background-clip:padding-box}
