:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;height:100vh;background-color:#f5f5f5;padding:.5rem;box-sizing:border-box;overflow:hidden}@media(min-width:769px){body{padding:1rem 2rem}}#root{max-width:1600px;margin:0 auto;padding:0;text-align:center;width:100%;height:100%;display:flex;flex-direction:column}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{background:#fff;padding:2.5rem;border-radius:16px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{font-size:2rem;font-weight:700;color:#007aff;margin-bottom:1rem}.login-header h2{font-size:1.75rem;color:#333;margin:0 0 .5rem;font-weight:600}.login-subtitle{color:#666;font-size:.95rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column}.login-input{padding:.875rem 1rem;border:1.5px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:all .2s;outline:none;width:100%;box-sizing:border-box}.login-input:focus{border-color:#007aff;box-shadow:0 0 0 3px #007aff1a}.login-submit-btn{background:#007aff;color:#fff;border:none;padding:.875rem;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.login-submit-btn:hover{background:#0051d5;transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.login-submit-btn:active{transform:translateY(0)}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:8px;font-size:.875rem;border:1px solid #fcc}.login-footer{margin-top:1.5rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-toggle-text{color:#666;font-size:.9rem}.login-toggle-btn{background:transparent;color:#007aff;border:none;cursor:pointer;font-size:.9rem;font-weight:600;padding:.25rem;transition:all .2s}.login-toggle-btn:hover{text-decoration:underline}.header{position:fixed;top:0;left:0;right:0;display:flex;justify-content:center;padding:1rem;background:#fff;border-bottom:1px solid #e0e0e0;z-index:100}.header-content{width:100%;max-width:1600px;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:0 2rem}.logo{font-size:1.2rem;font-weight:700;color:#007aff;white-space:nowrap}.header-right{display:flex;align-items:center;gap:1rem;overflow:hidden}.user-email{font-size:.9rem;color:#666;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:transparent;border:1px solid #ddd;padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;color:#666;transition:all .2s;white-space:nowrap;flex-shrink:0}.logout-btn:hover{background:#f5f5f5}.app-layout{display:flex;flex-direction:column;height:calc(100% - 95px);margin-top:95px;background:#fff;max-width:1000px;width:100%;margin-left:auto;margin-right:auto;box-shadow:0 0 20px #0000001a;border-radius:12px;overflow:hidden}.chat-container{display:flex;flex-direction:column;flex:1;padding:1rem;background:#fff;overflow:hidden;gap:1rem}@media(min-width:769px){.chat-container{padding:2rem 3rem}}.messages{flex:1;overflow-y:auto;margin-bottom:1rem;display:flex;flex-direction:column;gap:1rem;padding:.5rem 0}.message-wrapper{display:flex;align-items:flex-start;margin:.25rem 0}.message-wrapper.user{justify-content:flex-end}.message-wrapper.bot{justify-content:flex-start}.message{padding:.75rem 1rem;border-radius:18px;max-width:65%;word-wrap:break-word;line-height:1.4}@media(min-width:769px){.message{max-width:75%}}.message p{margin:0}.message.user{background:#007aff;color:#fff;border-bottom-right-radius:4px}.message.bot{background:#e9e9eb;color:#000;border-bottom-left-radius:4px}.input-container{display:flex;gap:.75rem;padding:.75rem;background:#fff;border-top:1px solid #e0e0e0;align-items:center}.input-container input{flex:1;padding:.75rem 1rem;border:1px solid #ddd;border-radius:24px;font-size:.95rem;outline:none;transition:border-color .2s}.input-container input:focus{border-color:#007aff}.send-btn{background:#000;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:24px;font-size:.95rem;cursor:pointer;font-weight:500;transition:background .2s;white-space:nowrap}.send-btn:hover{background:#333}.send-btn:active{transform:scale(.98)}.typing-indicator{display:flex;align-items:center;gap:4px;padding:1rem 1.25rem!important;min-width:60px}.typing-dot{width:8px;height:8px;border-radius:50%;background:#999;animation:typing-bounce 1.4s infinite ease-in-out}.typing-dot:nth-child(1){animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.typing-dot:nth-child(3){animation-delay:0s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}@media(max-width:768px){body{padding:.5rem;overflow:hidden}#root{max-width:100%;height:100%}.login-page{padding:1rem}.login-container{padding:2rem 1.5rem;max-width:100%}.login-logo,.login-header h2{font-size:1.5rem}.login-subtitle{font-size:.875rem}.header{padding:.75rem 1rem}.header-content{max-width:100%;padding:0 .5rem}.logo{font-size:1rem}.header-right{gap:.5rem}.user-email{font-size:.8rem}.logout-btn{padding:.4rem .8rem;font-size:.85rem}.app-layout{max-width:100%;box-shadow:none;border-radius:8px;height:calc(100% - 80px);margin-top:80px}.chat-container{padding:1rem}.message{max-width:85%}.input-container{padding:.75rem}}
