.login-container{width:100%;max-width:400px;padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 6px #0000001a}.login-logo{display:block;margin:0 auto 24px;max-width:200px;height:auto}.login-card h1{font-size:28px;margin-bottom:8px;color:#0069cc;text-align:center}.login-subtitle{color:#666;text-align:center;margin-bottom:32px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4883d7}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:16px;font-size:14px;border:1px solid #fcc}.login-button{width:100%;padding:12px;background:linear-gradient(135deg,#4883d7,#0069cc);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#5a93e7,#1079dc);transform:translateY(-1px);box-shadow:0 4px 8px #0069cc4d}.login-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.chat-container{width:100%;max-width:900px;height:90vh;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:20px 24px;border-bottom:2px solid #4883d7;display:flex;justify-content:space-between;align-items:center;background:#fff;color:#333}.chat-header-left{display:flex;align-items:center;gap:16px}.chat-logo{height:50px;width:auto}.chat-header-text h1{font-size:24px;margin-bottom:4px;color:#0069cc}.chat-subtitle{font-size:13px;color:#666}.header-actions{display:flex;align-items:center;gap:16px}.user-section{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.username{font-size:14px;font-weight:500;color:#0069cc}.logout-button{padding:8px 16px;background:#fff;color:#0069cc;border:1px solid #4883d7;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.logout-button:hover{background:#4883d7;color:#fff}.chat-content{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column}.examples-section{margin-bottom:20px}.examples-title{font-size:14px;color:#666;margin-bottom:12px;font-weight:500}.examples-grid{display:flex;flex-direction:column;gap:8px}.example-button{padding:12px 16px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;text-align:left;font-size:14px;color:#333;transition:all .2s}.example-button:hover{background:#e3f2fd;border-color:#4883d7}.messages-container{flex:1;display:flex;flex-direction:column;gap:16px}.message{display:flex;max-width:80%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message.cancelled .message-content{opacity:.7;background:#f8f9fa!important;border:1px dashed #dc3545;color:#666!important}.message.error .message-content{opacity:.7;background:#fff5f5!important;border:1px dashed #dc3545;color:#666!important}.cancelled-label,.error-label{color:#dc3545;font-style:italic;font-size:12px;margin-left:8px}.message-content{padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.5;word-wrap:break-word}.message.user .message-content{background:linear-gradient(135deg,#4883d7,#0069cc);color:#fff;border-bottom-right-radius:4px}.message.assistant .message-content{background:#f5f5f5;color:#333;border-bottom-left-radius:4px}.message.assistant .message-content table{border-collapse:collapse;width:100%;margin:8px 0;font-size:13px}.message.assistant .message-content th,.message.assistant .message-content td{border:1px solid #ddd;padding:8px 12px;text-align:left}.message.assistant .message-content th{background:linear-gradient(135deg,#4883d7,#0069cc);color:#fff;font-weight:600}.message.assistant .message-content tr:nth-child(2n){background-color:#f9f9f9}.message.assistant .message-content tr:hover{background-color:#e3f2fd}.message.assistant .message-content a{color:#0069cc;text-decoration:none;font-weight:500}.message.assistant .message-content a:hover{text-decoration:underline;color:#4883d7}.message.assistant .message-content p{margin:8px 0}.message.assistant .message-content p:first-child{margin-top:0}.message.assistant .message-content p:last-child{margin-bottom:0}.message-content.loading{display:flex;gap:4px;padding:12px 20px}.loading-dot{animation:loading 1.4s infinite;font-size:20px}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes loading{0%,60%,to{opacity:.3}30%{opacity:1}}.chat-error{padding:12px 20px;background:#fee;color:#c33;border-top:1px solid #fcc;font-size:14px}.chat-input-form{padding:20px;border-top:2px solid #4883d7;display:flex;gap:12px}.chat-input{flex:1;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s}.chat-input:focus{outline:none;border-color:#4883d7}.chat-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.send-button{padding:12px 24px;background:linear-gradient(135deg,#4883d7,#0069cc);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.send-button:hover:not(:disabled){background:linear-gradient(135deg,#5a93e7,#1079dc);transform:translateY(-1px);box-shadow:0 4px 8px #0069cc4d}.send-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.cancel-button{padding:12px 24px;background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-button:hover{background:linear-gradient(135deg,#e74c3c,#d62c1a);transform:translateY(-1px);box-shadow:0 4px 8px #dc35454d}.chat-footer{padding:16px 20px;border-top:1px solid #e0e0e0;background:#fafafa;display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px;color:#666}.footer-logo{height:40px;width:auto;vertical-align:middle}*{margin:0;padding:0;box-sizing:border-box}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:#f5f5f5}#root{min-height:100vh;display:flex;align-items:center;justify-content:center}
