.chat-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px;flex-shrink:0}.sidebar-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:4px 0}.logo-text{font-weight:600;font-size:16px}.logo-mark{background:var(--accent);color:#fff;font-weight:700;font-size:12px;width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;letter-spacing:.3px;flex-shrink:0}.logo-mark.large{width:56px;height:56px;font-size:20px;border-radius:14px;margin-bottom:16px}.new-chat-btn{background:var(--surface-2);color:var(--text);border:1px solid var(--border);text-align:left;padding:10px 14px;font-size:13px;width:100%}.new-chat-btn:hover{background:var(--border)}.sidebar-footer{margin-top:auto}.settings-btn{background:none;color:var(--text-muted);font-size:13px;padding:8px 10px;width:100%;text-align:left}.settings-btn:hover{color:var(--text);background:var(--surface-2)}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;gap:8px}.empty-state h1{font-size:22px;font-weight:600;margin-bottom:4px}.empty-state p{color:var(--text-muted);font-size:14px;margin-bottom:24px}.suggestions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:640px}.suggestion-chip{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:13px;padding:10px 16px;border-radius:20px;text-align:left;transition:border-color .15s}.suggestion-chip:hover{border-color:var(--accent)}.messages{flex:1;overflow-y:auto;padding:24px 0;display:flex;flex-direction:column;gap:4px}.message{display:flex;gap:14px;padding:12px 24px;max-width:100%}.message.user{background:transparent}.message.assistant{background:var(--surface)}.message.error .message-content p{color:#f44}.message-avatar{font-size:11px;font-weight:700;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.message.user .message-avatar{background:var(--user-bubble);color:#90b8e0}.message.assistant .message-avatar{background:var(--accent);color:#fff}.message-content{flex:1;max-width:720px;font-size:15px;line-height:1.7}.message-content p{margin:0 0 8px}.message-content p:last-child{margin-bottom:0}.message-content ul,.message-content ol{padding-left:20px;margin:8px 0}.message-content code{background:var(--surface-2);padding:2px 6px;border-radius:4px;font-size:13px}.message-content pre{background:var(--surface-2);border-radius:8px;padding:14px;overflow-x:auto;margin:8px 0}.message-content pre code{background:none;padding:0}.typing-dots{display:flex;gap:4px;align-items:center;height:20px}.typing-dots span{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:bounce 1.2s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.input-area{padding:16px 24px 24px;display:flex;gap:10px;align-items:flex-end;border-top:1px solid var(--border);background:var(--bg)}.chat-input{flex:1;resize:none;max-height:160px;overflow-y:auto;line-height:1.6;font-size:15px;padding:12px 16px;border-radius:10px}.send-btn{width:40px;height:40px;border-radius:10px;background:var(--accent);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.send-btn:hover:not(:disabled){background:var(--accent-hover)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.setup-prompt{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;padding:24px}.setup-prompt h2{font-size:24px;font-weight:600}.setup-prompt p{color:var(--text-muted);font-size:15px;margin-bottom:8px}.setup-prompt .btn-primary{padding:12px 32px;font-size:15px;background:var(--accent);color:#fff;font-weight:600}.setup-prompt .btn-primary:hover{background:var(--accent-hover)}.setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.setup-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:480px}.setup-logo{display:flex;align-items:center;gap:12px;margin-bottom:8px}.logo-mark{background:var(--accent);color:#fff;font-weight:700;font-size:14px;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;letter-spacing:.5px}.setup-logo h1{font-size:20px;font-weight:600}.setup-subtitle{color:var(--text-muted);font-size:14px;margin-bottom:28px}.field{margin-bottom:20px}.field label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px}.hint{display:block;font-size:12px;color:var(--text-muted);margin-top:5px}.saved-badge{background:#1a3a1a;color:#4caf50;font-size:11px;padding:2px 7px;border-radius:4px;font-weight:400}.error-msg{color:#f44;font-size:13px;margin-bottom:16px}.btn-primary{width:100%;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:12px;border-radius:8px;margin-top:4px}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--surface: #1a1a1a;--surface-2: #242424;--border: #2e2e2e;--text: #f0f0f0;--text-muted: #888;--accent: #e8630a;--accent-hover: #d45500;--user-bubble: #1e3a5f;--ai-bubble: #1a1a1a;--radius: 12px;--font: "Inter", system-ui, sans-serif}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:var(--font);font-size:14px;border:none;border-radius:8px;padding:10px 18px;transition:background .15s}input,select,textarea{font-family:var(--font);font-size:14px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:10px 14px;width:100%;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
