*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1e3a5f;--primary-light:#2563eb;--primary-dark:#1e293b;--accent:#f59e0b;--bg:#f1f5f9;--white:#fff;--gray-100:#f8fafc;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-500:#64748b;--gray-700:#334155;--gray-900:#0f172a;--red:#ef4444;--green:#22c55e;--shadow:0 1px 3px #0000001a;--shadow-lg:0 10px 25px #0000001a;--radius:12px}body{background:var(--bg);color:var(--gray-900);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{height:100vh}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100vh;display:flex}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary-light);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-container{background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);justify-content:center;align-items:center;height:100vh;display:flex}.login-card{background:var(--white);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:40px}.login-logo{text-align:center;margin-bottom:32px}.login-logo h1{color:var(--primary);font-size:28px;font-weight:700}.login-logo p{color:var(--gray-500);margin-top:4px}.login-card form{flex-direction:column;gap:12px;display:flex}.login-card input{border:1px solid var(--gray-200);border-radius:8px;outline:none;padding:12px 16px;font-size:15px;transition:border-color .2s}.login-card input:focus{border-color:var(--primary-light)}.login-card button[type=submit]{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:600;transition:background .2s}.login-card button[type=submit]:hover{background:var(--primary-light)}.login-card button:disabled{opacity:.6;cursor:not-allowed}.error-msg{color:var(--red);text-align:center;font-size:14px}.toggle-auth{text-align:center;color:var(--primary-light);cursor:pointer;margin-top:16px;font-size:14px}.chat-container{background:var(--white);max-width:900px;height:100vh;box-shadow:var(--shadow-lg);flex-direction:column;margin:0 auto;display:flex}.chat-header{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.header-left{align-items:center;gap:10px;display:flex}.header-left h2{font-size:18px;font-weight:600}.status-dot{background:var(--green);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-right{align-items:center;gap:12px;display:flex}.user-name{opacity:.9;font-size:14px}.btn-icon{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s;display:flex}.btn-icon:hover{background:#ffffff40}.btn-logout{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:6px;padding:6px 14px;font-size:13px}.btn-logout:hover{background:#ffffff40}.messages-area{background:var(--gray-100);flex-direction:column;flex:1;gap:12px;padding:24px;display:flex;overflow-y:auto}.welcome-msg{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.welcome-icon{margin-bottom:8px}.welcome-msg h3{color:var(--gray-900);font-size:22px}.welcome-msg p{color:var(--gray-500);max-width:400px}.suggestions{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:16px;display:flex}.suggestion-chip{background:var(--white);border:1px solid var(--gray-200);cursor:pointer;color:var(--gray-700);border-radius:20px;padding:8px 16px;font-size:13px;transition:all .2s}.suggestion-chip:hover{border-color:var(--primary-light);color:var(--primary-light);background:#eff6ff}.message{display:flex}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.bubble{border-radius:var(--radius);word-wrap:break-word;max-width:75%;padding:12px 16px;position:relative}.message.user .bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message.assistant .bubble{background:var(--white);color:var(--gray-900);border:1px solid var(--gray-200);border-bottom-left-radius:4px}.bubble p{white-space:pre-wrap;font-size:15px;line-height:1.5}.bubble .timestamp{opacity:.6;text-align:right;margin-top:6px;font-size:11px;display:block}.bubble.loading{gap:4px;padding:16px 20px;display:flex}.bubble.loading .dot{background:var(--gray-300);border-radius:50%;width:8px;height:8px;animation:1.2s infinite bounce}.bubble.loading .dot:nth-child(2){animation-delay:.2s}.bubble.loading .dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.btn-play{color:var(--primary-light);cursor:pointer;background:#2563eb1a;border:1px solid #2563eb33;border-radius:6px;align-items:center;gap:6px;margin-top:8px;padding:6px 12px;font-size:13px;display:inline-flex}.btn-play:hover{background:#2563eb33}.sources{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.source-tag{background:var(--gray-100);border:1px solid var(--gray-200);color:var(--gray-500);border-radius:4px;padding:2px 8px;font-size:11px}.input-area{border-top:1px solid var(--gray-200);background:var(--white);gap:8px;padding:16px 24px;display:flex}.input-area input{border:1px solid var(--gray-200);border-radius:24px;outline:none;flex:1;padding:12px 16px;font-size:15px;transition:border-color .2s}.input-area input:focus{border-color:var(--primary-light)}.btn-voice,.btn-send{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.btn-voice{background:var(--gray-100);color:var(--gray-700)}.btn-voice:hover{background:var(--gray-200)}.btn-voice.recording{background:var(--red);color:#fff;animation:1s infinite pulse-recording}@keyframes pulse-recording{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 10px #ef444400}}.btn-send{background:var(--primary);color:#fff}.btn-send:hover{background:var(--primary-light)}.btn-send:disabled,.btn-voice:disabled{opacity:.4;cursor:not-allowed}.messages-area::-webkit-scrollbar{width:6px}.messages-area::-webkit-scrollbar-track{background:0 0}.messages-area::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}@media (width<=768px){.chat-container{max-width:100%}.bubble{max-width:85%}.chat-header{padding:12px 16px}.messages-area{padding:16px}.input-area{padding:12px 16px}.welcome-msg{padding:40px 16px}.user-name{display:none}}
