*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d1a;--bg2: #13131f;--bg3: #1a1a2e;--surface: #1e1e30;--surface2: #252538;--border: #2a2a40;--text: #e8e8f0;--text-muted: #8888a8;--accent: #f97316;--accent-green: #22c55e;--accent-blue: #3b82f6;--bubble-user: #1e3a5f;--bubble-ai: #1a1a2e;--radius: 14px;--radius-sm: 8px}html,body,#root{height:100%;width:100%;font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{background:var(--bg2);border-bottom:1px solid var(--border);padding:0;flex-shrink:0;z-index:10}.header-top{display:flex;align-items:center;justify-content:space-between;padding:12px 20px}.header-brand{display:flex;align-items:center;gap:12px}.header-logo{width:40px;height:40px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;color:#fff;letter-spacing:-1px;flex-shrink:0}.header-title{font-size:18px;font-weight:700;color:var(--text);display:flex;align-items:baseline;gap:6px}.header-title .group{color:var(--accent-green)}.header-subtitle{font-size:11px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-top:1px}.status-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:#22c55e1f;border:1px solid rgba(34,197,94,.25);font-size:13px;color:var(--accent-green);font-weight:500}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 6px var(--accent-green);animation:pulse 2s ease-in-out infinite}.status-badge.offline{color:#f87171;background:#f871711a;border-color:#f8717133}.status-badge.offline .status-dot{background:#f87171;box-shadow:0 0 6px #f87171;animation:none}.status-badge.checking{color:var(--text-muted);background:#8888a81a;border-color:#8888a833}.status-badge.checking .status-dot{background:var(--text-muted);animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.webhook-bar{display:flex;align-items:center;gap:8px;padding:8px 20px 12px;border-top:1px solid var(--border)}.webhook-label{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;flex-shrink:0}.webhook-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--accent-blue);font-size:13px;padding:6px 10px;font-family:Courier New,monospace;outline:none;transition:border-color .15s}.webhook-input:focus{border-color:var(--accent-blue)}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.welcome-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;text-align:center;gap:20px}.welcome-icon{width:72px;height:72px;border-radius:50%;background:#f9731626;border:2px solid rgba(249,115,22,.25);display:flex;align-items:center;justify-content:center;color:var(--accent)}.welcome-title{font-size:28px;font-weight:700;color:var(--text)}.welcome-subtitle{font-size:15px;color:var(--text-muted);line-height:1.6;max-width:380px}.quick-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:4px}.quick-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:14px;padding:8px 16px;border-radius:20px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.quick-btn:hover:not(:disabled){background:var(--surface2);border-color:var(--accent-blue)}.quick-btn:disabled{opacity:.5;cursor:not-allowed}.messages-wrapper{flex:1;overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:16px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.messages-wrapper::-webkit-scrollbar{width:4px}.messages-wrapper::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.message{display:flex;align-items:flex-end;gap:10px;max-width:780px}.message.user{align-self:flex-end;flex-direction:row-reverse;margin-left:auto}.message.assistant{align-self:flex-start}.avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.assistant-avatar{background:#f9731633;color:var(--accent);border:1px solid rgba(249,115,22,.3)}.user-avatar{background:var(--accent-blue);color:#fff}.bubble{padding:12px 16px;border-radius:var(--radius);max-width:680px;font-size:14px;line-height:1.6;word-break:break-word;position:relative}.user-bubble{background:var(--bubble-user);border-bottom-right-radius:4px}.assistant-bubble{background:var(--bubble-ai);border:1px solid var(--border);border-bottom-left-radius:4px}.error-bubble{border-color:#f8717166;background:#f8717114}.message-time{display:block;font-size:10px;color:var(--text-muted);margin-top:6px;text-align:right}.bubble p{margin-bottom:8px}.bubble p:last-of-type{margin-bottom:0}.bubble strong{color:var(--text);font-weight:600}.bubble em{font-style:italic}.bubble code{background:#ffffff14;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:12px}.bubble pre{background:#0000004d;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;overflow-x:auto;margin:8px 0}.bubble pre code{background:none;padding:0}.bubble ul,.bubble ol{padding-left:20px;margin:6px 0}.bubble li{margin-bottom:4px}.bubble h1,.bubble h2,.bubble h3{color:var(--text);font-weight:700;margin:10px 0 6px}.bubble h1{font-size:16px}.bubble h2{font-size:15px}.bubble h3{font-size:14px}.bubble a{color:var(--accent-blue);text-decoration:underline}.bubble hr{border:none;border-top:1px solid var(--border);margin:10px 0}.bubble blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-muted);margin:6px 0}.table-wrapper{overflow-x:auto;margin:10px 0;border-radius:var(--radius-sm);border:1px solid var(--border)}.table-wrapper table{width:100%;border-collapse:collapse;font-size:13px}.table-wrapper th{background:var(--surface);color:var(--text);font-weight:600;padding:8px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.table-wrapper td{padding:7px 12px;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text)}.table-wrapper tr:last-child td{border-bottom:none}.table-wrapper tr:hover td{background:#ffffff08}.typing-bubble{display:flex;align-items:center;gap:5px;padding:14px 18px;width:fit-content}.typing-bubble span{width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:bounce 1.2s ease-in-out infinite}.typing-bubble span:nth-child(2){animation-delay:.2s}.typing-bubble span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-6px);opacity:1}}.input-area{padding:12px 16px 16px;background:var(--bg2);border-top:1px solid var(--border);flex-shrink:0}.input-area-bottom-quick{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.input-area-bottom-quick .quick-btn{font-size:13px;padding:5px 12px}.chat-input-row{display:flex;align-items:flex-end;gap:8px}.chat-textarea{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:14px;padding:11px 14px;resize:none;outline:none;font-family:inherit;min-height:44px;max-height:140px;transition:border-color .15s;field-sizing:content;line-height:1.5}.chat-textarea:focus{border-color:var(--accent-blue)}.chat-textarea::placeholder{color:var(--text-muted)}.icon-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.icon-btn:hover:not(:disabled){background:var(--surface2);color:var(--text);border-color:var(--accent-blue)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.icon-btn.recording{background:#ef444426;border-color:#ef4444;color:#ef4444;animation:pulse 1s ease-in-out infinite}.send-btn{width:42px;height:42px;border-radius:50%;border:none;background:var(--accent-blue);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.send-btn:hover:not(:disabled){background:#2563eb;transform:scale(1.05)}.send-btn:disabled{background:var(--surface);color:var(--text-muted);transform:none;cursor:not-allowed}.input-hint{text-align:center;font-size:11px;color:var(--text-muted);margin-top:8px}
