*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f0e17;--bg-secondary: #1a1825;--bg-card: rgba(255, 255, 255, .04);--bg-card-hover: rgba(255, 255, 255, .07);--border: rgba(255, 255, 255, .08);--text-primary: #f8f7ff;--text-secondary: rgba(248, 247, 255, .6);--text-muted: rgba(248, 247, 255, .35);--accent: #a78bfa;--accent-glow: rgba(167, 139, 250, .35);--user-bubble: linear-gradient(135deg, #7c3aed 0%, #a78bfa 100%);--ai-bubble: rgba(255, 255, 255, .06);--radius: 16px;--radius-sm: 10px;--shadow: 0 8px 32px rgba(0, 0, 0, .3);font-family:Noto Sans SC,system-ui,-apple-system,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}html,body,#root{height:100%}body{background:var(--bg-primary);color:var(--text-primary);overflow:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}.app{display:flex;height:100vh;background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(124,58,237,.18) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 90%,rgba(236,72,153,.12) 0%,transparent 60%),var(--bg-primary)}.sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:#0f0e1799;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:24px 20px}.sidebar-header{display:flex;align-items:center;gap:12px;margin-bottom:32px}.logo{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#7c3aed,#ec4899);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 16px var(--accent-glow)}.logo-text h1{font-size:18px;font-weight:600;letter-spacing:.02em}.logo-text p{font-size:12px;color:var(--text-secondary);margin-top:2px}.sidebar-section{margin-bottom:24px}.sidebar-section h3{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:12px}.emotion-legend{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--bg-card);font-size:13px;color:var(--text-secondary);transition:background .2s}.legend-item:hover{background:var(--bg-card-hover)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border)}.status-badge{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}.status-dot.offline{background:#ef4444;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.btn-new-chat{width:100%;padding:12px 16px;border:1px dashed var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;margin-bottom:16px;font-family:inherit}.btn-new-chat:hover{border-color:var(--accent);color:var(--accent);background:#a78bfa14}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}.chat-header{padding:20px 32px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#0f0e1766;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chat-header-info h2{font-size:16px;font-weight:500}.chat-header-info p{font-size:13px;color:var(--text-secondary);margin-top:2px}.current-emotion{display:flex;align-items:center;gap:10px;padding:8px 16px;border-radius:24px;background:var(--bg-card);border:1px solid var(--border);font-size:13px;transition:all .3s}.current-emotion-emoji{font-size:20px}.messages-container{flex:1;overflow-y:auto;padding:24px 32px;display:flex;flex-direction:column;gap:20px}.welcome-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;animation:fadeIn .6s ease}.welcome-icon{font-size:56px;margin-bottom:20px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.welcome-screen h2{font-size:24px;font-weight:500;margin-bottom:8px}.welcome-screen p{color:var(--text-secondary);font-size:14px;max-width:400px;line-height:1.6}.suggestion-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;justify-content:center;max-width:520px}.chip{padding:10px 18px;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}.chip:hover{border-color:var(--accent);color:var(--text-primary);background:#a78bfa1a;transform:translateY(-1px)}.message{display:flex;gap:12px;max-width:75%;animation:slideUp .35s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.message.user{align-self:flex-end;flex-direction:row-reverse}.message-avatar{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.message.assistant .message-avatar{background:linear-gradient(135deg,#7c3aed33,#ec489933);border:1px solid var(--border)}.message.user .message-avatar{background:var(--user-bubble)}.message-body{display:flex;flex-direction:column;gap:6px}.message-bubble{padding:14px 18px;border-radius:var(--radius);font-size:14px;line-height:1.7;word-break:break-word}.message.assistant .message-bubble{background:var(--ai-bubble);border:1px solid var(--border);border-top-left-radius:4px}.message.user .message-bubble{background:var(--user-bubble);border-top-right-radius:4px;box-shadow:0 4px 16px var(--accent-glow)}.message-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);padding:0 4px}.message.user .message-meta{justify-content:flex-end}.emotion-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.typing-indicator{display:flex;gap:12px;align-self:flex-start;animation:slideUp .35s ease}.typing-dots{display:flex;align-items:center;gap:5px;padding:16px 20px;background:var(--ai-bubble);border:1px solid var(--border);border-radius:var(--radius);border-top-left-radius:4px}.typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:bounce 1.4s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.16s}.typing-dots span:nth-child(3){animation-delay:.32s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.input-area{padding:20px 32px 28px;border-top:1px solid var(--border);background:#0f0e1780;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.input-wrapper{display:flex;align-items:flex-end;gap:12px;padding:12px 12px 12px 20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-secondary);transition:border-color .2s,box-shadow .2s}.input-wrapper:focus-within{border-color:#a78bfa80;box-shadow:0 0 0 3px #a78bfa1f}.input-wrapper textarea{flex:1;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:14px;line-height:1.5;resize:none;max-height:120px;font-family:inherit}.input-wrapper textarea::placeholder{color:var(--text-muted)}.btn-send{width:42px;height:42px;border-radius:12px;border:none;background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.btn-send:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 16px var(--accent-glow)}.btn-send:disabled{opacity:.4;cursor:not-allowed}.input-hint{font-size:11px;color:var(--text-muted);margin-top:10px;text-align:center}.error-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);padding:12px 24px;border-radius:var(--radius-sm);background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:13px;animation:slideUp .3s ease;z-index:100;max-width:90%}@media(max-width:768px){.sidebar{display:none}.chat-header,.messages-container,.input-area{padding-left:16px;padding-right:16px}.message{max-width:90%}}
