*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.chat-container{display:flex;flex-direction:column;height:100vh;max-width:900px;margin:0 auto;background-color:#fff;box-shadow:0 0 20px #0000001a}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 4px #0000001a;z-index:100}.header-left{display:flex;flex-direction:column;gap:.25rem}.chat-header h1{font-size:1.5rem;font-weight:600;margin:0}.username-display{font-size:.875rem;opacity:.9;font-weight:400}.logout-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.logout-button:active{transform:translateY(0)}.logout-button svg{flex-shrink:0}.chat-content,.chat-kit-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden}.status-indicator{display:flex;align-items:center;gap:.5rem}.status-dot{width:10px;height:10px;border-radius:50%;background-color:#f44;animation:pulse 2s infinite}.status-dot.connected{background-color:#4f4}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:.9rem;font-weight:500}.error-banner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background-color:#fee;color:#c33;border-bottom:1px solid #fcc}.error-banner button{background:none;border:none;color:#c33;font-size:1.5rem;cursor:pointer;padding:0 .5rem;line-height:1}.error-banner button:hover{opacity:.7}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background-color:#f9f9f9}.empty-state{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#999;font-size:1.1rem;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{align-self:center}.error-message .message-content{background-color:#fee;color:#c33;border-radius:8px;border:1px solid #fcc}.message{display:flex;flex-direction:column;max-width:70%;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{align-self:flex-end}.user-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:18px 18px 4px}.assistant-message{align-self:flex-start}.assistant-message .message-content{background-color:#e9ecef;color:#333;border-radius:18px 18px 18px 4px}.message-content{padding:.75rem 1rem;word-wrap:break-word;line-height:1.5}.message-timestamp{font-size:.75rem;color:#999;margin-top:.25rem;padding:0 .5rem}.user-message .message-timestamp{text-align:right}.assistant-message .message-timestamp{text-align:left}.typing-indicator{display:inline-flex;gap:4px;padding:.75rem 1rem}.typing-indicator span{width:8px;height:8px;border-radius:50%;background-color:#999;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.input-container{display:flex;gap:.5rem;padding:1rem 1.5rem;background-color:#fff;border-top:1px solid #e0e0e0}.message-input{flex:1;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:24px;font-size:1rem;outline:none;transition:border-color .2s}.message-input:focus{border-color:#667eea}.message-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.send-button{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#f1f1f1}.messages-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.chat-container{height:100vh}.chat-header{padding:.75rem 1rem}.chat-header h1{font-size:1.2rem}.username-display{font-size:.75rem}.logout-button{padding:.4rem .75rem;font-size:.8rem}.logout-button span{display:none}.message{max-width:85%}.input-container{padding:.75rem 1rem}.send-button{padding:.75rem 1.5rem}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.login-box h1{margin:0 0 30px;color:#333;text-align:center;font-size:28px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .3s,transform .2s}.login-button:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-info{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0;font-size:12px;color:#666}.login-info p{margin:0 0 10px;font-weight:600}.login-info ul{margin:0;padding-left:20px}.login-info li{margin-bottom:8px;line-height:1.5}.login-info strong{color:#333}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}*{box-sizing:border-box}
