*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden}body{min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{border-radius:8px;border:1px solid transparent;font-family:inherit;cursor:pointer;transition:all .3s ease}button:focus,button:focus-visible{outline:2px solid #667eea;outline-offset:2px}.landing-container{width:100%;min-height:100vh;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem;margin:0;overflow-x:hidden}.content{text-align:center;animation:fadeIn 1.5s ease-in}.main-title{font-size:4rem;font-weight:700;color:#fff;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3);animation:slideDown 1s ease-out}.subtitle{font-size:1.5rem;color:#f0f0f0;margin-bottom:2rem;animation:slideUp 1s ease-out}.decorative-line{width:200px;height:4px;background:linear-gradient(90deg,transparent,#ffffff,transparent);margin:0 auto 3rem;animation:expand 1.5s ease-out}.chat-button{padding:1rem 2.5rem;font-size:1.2rem;font-weight:600;color:#667eea;background:#fff;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .3s ease;animation:fadeIn 2s ease-in}.chat-button:hover{transform:translateY(-3px);box-shadow:0 6px 25px #0000004d;background:#f8f9fa}.welcome-text{color:#fff;font-size:1.1rem;margin-bottom:1rem}.secondary-button{padding:.875rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:#fff3;border:2px solid white;border-radius:50px;cursor:pointer;transition:all .3s ease;margin-top:1rem}.secondary-button:hover{background:#ffffff4d;transform:translateY(-2px)}.login-text{color:#fff;margin-top:1.5rem;font-size:1rem}.link-button{background:none;border:none;color:#fff;font-size:1rem;font-weight:700;text-decoration:underline;cursor:pointer;padding:0;margin-left:.25rem;transition:opacity .3s ease}.link-button:hover{opacity:.8}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes expand{0%{width:0}to{width:200px}}@media(max-width:768px){.landing-container{padding:1.5rem}.main-title{font-size:2.5rem}.subtitle{font-size:1.2rem}.chat-button{padding:.875rem 2rem;font-size:1.1rem}}@media(max-width:480px){.landing-container{padding:1rem}.main-title{font-size:2rem}.subtitle{font-size:1rem}.decorative-line{width:150px;margin-bottom:2rem}.chat-button{padding:.75rem 1.5rem;font-size:1rem}}.chatbot-container{display:flex;flex-direction:column;width:100%;height:100vh;min-height:100vh;margin:0;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden}.chatbot-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100;gap:1rem}.header-center{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem}.chatbot-header h2{margin:0;color:#667eea;font-size:1.5rem}.user-name{font-size:.85rem;color:#666;font-weight:500}.header-right{display:flex;align-items:center;gap:1rem}.back-button{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .3s ease;font-weight:500}.back-button:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.logout-button{background:#f43f5e;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .3s ease;font-weight:500}.logout-button:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #f43f5e66}.error-banner{background:#fee;color:#c33;padding:.875rem 1.5rem;text-align:center;font-size:.9rem;border-bottom:2px solid #fcc}.status-indicator{display:flex;align-items:center;gap:.5rem;color:#4ade80;font-size:.9rem;font-weight:500}.status-dot{width:10px;height:10px;background:#4ade80;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.messages-container{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#ffffff1a}.messages-container::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#ffffff80}.message{display:flex;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{justify-content:flex-end}.bot-message{justify-content:flex-start}.message-content{max-width:70%;padding:.875rem 1.25rem;border-radius:18px;word-wrap:break-word;box-shadow:0 2px 8px #0000001a;line-height:1.5}.user-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.bot-message .message-content{background:#fff;color:#333;border-bottom-left-radius:4px}.typing-indicator{display:flex;gap:5px;padding:1rem 1.25rem}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#667eea;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:.75rem;padding:1rem 1.5rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 -2px 10px #0000001a;position:sticky;bottom:0}.input-container textarea{flex:1;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;resize:none;font-family:inherit;transition:all .3s ease;min-height:48px;max-height:120px}.input-container textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input-container button{padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;white-space:nowrap}.input-container button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.input-container button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.chatbot-header{padding:.875rem 1rem;gap:.5rem}.chatbot-header h2{font-size:1.25rem}.user-name{font-size:.75rem}.back-button{padding:.5rem .75rem;font-size:.9rem}.logout-button{padding:.5rem .75rem;font-size:.85rem}.status-indicator{font-size:.8rem}.header-right{flex-direction:column;gap:.5rem}.messages-container{padding:1rem}.message-content{max-width:85%;padding:.75rem 1rem;font-size:.95rem}.input-container{padding:.75rem 1rem;gap:.5rem}.input-container textarea{font-size:.95rem;padding:.75rem}.input-container button{padding:.75rem 1.25rem;font-size:.95rem}}@media(max-width:480px){.chatbot-header{padding:.75rem}.chatbot-header h2{font-size:1.1rem}.back-button{padding:.4rem .6rem;font-size:.85rem}.status-indicator{font-size:.75rem}.status-dot{width:8px;height:8px}.messages-container{padding:.75rem}.message-content{max-width:90%;padding:.65rem .875rem;font-size:.9rem}.input-container{padding:.625rem .75rem}.input-container textarea{font-size:.9rem;padding:.65rem}.input-container button{padding:.65rem 1rem;font-size:.9rem}}.auth-container{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.auth-box{background:#fff;padding:3rem;border-radius:20px;box-shadow:0 10px 40px #0003;width:100%;max-width:450px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-title{font-size:2rem;font-weight:700;color:#667eea;margin-bottom:.5rem;text-align:center}.auth-subtitle{font-size:1rem;color:#666;margin-bottom:2rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:600;color:#333}.form-group input{padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .3s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.auth-button{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.auth-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:.875rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem;border:1px solid #fcc}.auth-footer{text-align:center;margin-top:1.5rem;color:#666;font-size:.9rem}.auth-footer a{color:#667eea;text-decoration:none;font-weight:600;transition:color .3s ease}.auth-footer a:hover{color:#5568d3;text-decoration:underline}@media(max-width:768px){.auth-container{padding:1.5rem}.auth-box{padding:2rem}.auth-title{font-size:1.75rem}.auth-subtitle{font-size:.9rem}.form-group input{padding:.75rem;font-size:.95rem}.auth-button{padding:.875rem 1.75rem;font-size:1rem}}@media(max-width:480px){.auth-container{padding:1rem}.auth-box{padding:1.5rem}.auth-title{font-size:1.5rem}.auth-form{gap:1.25rem}.form-group input{padding:.65rem;font-size:.9rem}.auth-button{padding:.75rem 1.5rem;font-size:.95rem}}
