.login-container{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.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}.version-info{margin-top:24px;text-align:center;font-size:12px;color:#999;padding-top:16px;border-top:1px solid #eee}.chat-layout{display:flex;height:100vh;width:100%}.sidebar{width:280px;background:#f7f7f8;border-right:1px solid #e5e5e5;display:flex;flex-direction:column;transition:width .3s ease}.sidebar.collapsed{width:60px}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar.collapsed .new-chat-button{display:none}.sidebar.collapsed .sidebar-toggle{display:block}.sidebar-header{padding:16px;border-bottom:1px solid #e5e5e5;display:flex;gap:8px;align-items:center}.new-chat-button{flex:1;padding:12px 16px;background:#0069cc;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.new-chat-button:hover:not(:disabled){background:#0056b3}.new-chat-button:disabled{background:#ccc;cursor:not-allowed}.sidebar-toggle{padding:8px;background:none;border:1px solid #e5e5e5;border-radius:6px;cursor:pointer;font-size:16px;color:#666;transition:all .2s}.sidebar-toggle:hover{background:#f0f0f0;color:#333}.chat-list{flex:1;overflow-y:auto;padding:8px}.chat-item{display:flex;align-items:center;padding:12px;margin-bottom:4px;border-radius:8px;cursor:pointer;transition:background-color .2s;position:relative}.chat-item:hover{background:#e8e8e8}.chat-item.active{background:#e3f2fd;border-left:3px solid #0069cc}.chat-item-content{flex:1;min-width:0}.chat-title{font-size:14px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.chat-date{font-size:12px;color:#666}.chat-title-input{width:100%;padding:4px 8px;font-size:14px;font-weight:500;border:2px solid #0069cc;border-radius:4px;outline:none;background:#fff}.chat-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.chat-item:hover .chat-item-actions{opacity:1}.rename-chat-button,.delete-chat-button{background:none;border:none;color:#999;cursor:pointer;font-size:16px;padding:4px 6px;border-radius:4px;transition:all .2s}.rename-chat-button:hover{background:#0069cc;color:#fff}.delete-chat-button:hover{background:#f44;color:#fff}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#fff}.chat-header{padding:16px 24px;border-bottom:1px solid #e5e5e5;background:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.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:flex-end;gap:12px}.instructions-dropdown{position:relative;display:flex;flex-direction:column;align-items:flex-end}.instructions-button:hover{background:#4883d7;color:#fff}.instructions-dropdown-content{position:absolute;top:calc(100% + 8px);right:0;width:550px;max-width:90vw;max-height:80vh;overflow-y:auto;background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid #e6f0ff;box-shadow:0 8px 24px #08285026;border-radius:12px;padding:16px;z-index:1000;animation:dropdownFadeIn .2s ease-out}.panel-header{padding:16px;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;align-items:center}.panel-header h3{margin:0;font-size:16px;color:#333}.chip{background:#e3f2fd;color:#0069cc;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.panel-body{padding:16px}.panel-body h4{margin:0 0 8px;font-size:14px;color:#0069cc;font-weight:600}.instructions-tabs{display:flex;gap:8px;padding:12px 16px 0;border-bottom:1px solid #e5e5e5}.tab-button{flex:1;padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .2s}.tab-button:hover{color:#0069cc;background:#f8f9fa}.tab-button.active{color:#0069cc;border-bottom-color:#0069cc;font-weight:600}.muted{color:#666;font-size:14px;margin-bottom:16px}.instruction-list{list-style:none;padding:0;margin:0 0 16px}.instruction-list li{margin-bottom:8px;font-size:14px}.tag{background:#f0f0f0;padding:2px 6px;border-radius:4px;font-size:12px;margin-right:4px}.instruction-examples{display:flex;flex-direction:column;gap:8px}.example-button{padding:8px 12px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:6px;cursor:pointer;font-size:13px;text-align:left;transition:all .2s}.example-button:hover{background:#e9ecef;border-color:#0069cc}.example-button.small{padding:6px 10px;font-size:12px}.user-section{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.username{font-size:14px;font-weight:500;color:#0069cc;white-space:nowrap;line-height:1.2}.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:not(:disabled){background:#4883d7;color:#fff}.logout-button:disabled{background:#f0f0f0;color:#999;border-color:#ccc;cursor:not-allowed;opacity:.6}.chat-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.examples-section{padding:40px 24px;text-align:center}.examples-title{font-size:14px;color:#666;margin-bottom:20px;font-weight:500}.examples-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;max-width:1000px;margin:0 auto}.messages-container{flex:1;overflow-y:auto;padding:24px}.message{margin-bottom:24px;display:flex;flex-direction:column}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.message.system{align-items:center}.message-content-wrapper{position:relative;max-width:100%}.message-content{max-width:100%;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.5}.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.system .message-content{background:#fff3cd;color:#856404;border:1px solid #ffeaa7;font-style:italic;text-align:center;max-width:60%}.message.batch{opacity:.8;border-left:3px solid #4CAF50;padding-left:8px}.message.cancelled .message-content,.message.error .message-content{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.cancelled-label,.error-label{font-size:12px;font-style:italic}.loading{display:flex;align-items:center;gap:4px}.loading-dot{animation:loading 1.4s infinite ease-in-out}.loading-dot:nth-child(1){animation-delay:-.32s}.loading-dot:nth-child(2){animation-delay:-.16s}@keyframes loading{0%,80%,to{opacity:.3}40%{opacity:1}}.status-message{margin-left:10px;font-size:13px;color:#06c;font-weight:500;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.batch-status{margin-left:10px;font-size:12px;color:#666}.chat-error{padding:12px 24px;background:#f8d7da;color:#721c24;border-top:1px solid #f5c6cb;font-size:14px}.chat-input-form{padding:24px;border-top:1px solid #e5e5e5;background:#fff;display:flex;gap:12px;align-items:center}.chat-input{flex:1;padding:12px 16px;border:1px solid #e5e5e5;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#0069cc}.chat-input:disabled{background:#f8f9fa;color:#666}.send-button,.cancel-button{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.send-button{background:#0069cc;color:#fff}.send-button:hover:not(:disabled){background:#0056b3}.send-button:disabled{background:#ccc;cursor:not-allowed}.cancel-button{background:#dc3545;color:#fff}.cancel-button:hover{background:#c82333}.chat-footer{padding:16px 24px;border-top:1px solid #e5e5e5;background:#f8f9fa;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;font-size:12px;color:#666}.footer-left{display:flex;align-items:center;gap:8px;justify-self:start}.footer-right{display:flex;align-items:center;gap:8px;justify-self:center;grid-column:2}.version-text{color:#999;font-size:11px}.footer-logo{height:40px;width:auto;vertical-align:middle}.batch-upload-section{display:flex;align-items:center;gap:8px}.batch-upload-button,.instructions-button,.logout-button{padding:8px 16px;background:#fff;color:#0069cc;border:1px solid #4883d7;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s;height:36px;display:flex;align-items:center;justify-content:center;white-space:nowrap}.batch-upload-button:hover:not(:disabled){background:#4883d7;color:#fff}.batch-upload-button:disabled{background:#f0f0f0;color:#999;border-color:#ccc;cursor:not-allowed;opacity:.6}.batch-progress{font-size:12px;color:#666;font-weight:700}@media(max-width:768px){.sidebar{width:240px}.sidebar.collapsed{width:50px}.chat-header{padding:12px 16px}.messages-container,.chat-input-form{padding:16px}.message-content{max-width:90%}.instructions-dropdown-content{width:300px}}.metadata-info-icon{background:#e3f2fd;color:#0069cc;border:1px solid #0069cc;border-radius:50%;width:28px;height:28px;font-size:16px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;padding:0;position:absolute;top:12px;right:12px}.metadata-info-icon:hover{background:#0069cc;color:#fff;transform:scale(1.1)}.metadata-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.metadata-modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 24px #08285026;max-width:800px;width:90%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.metadata-modal-header{padding:20px 24px;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#4883d7,#0069cc)}.metadata-modal-header h3{margin:0;font-size:18px;font-weight:600;color:#fff}.metadata-modal-close{background:#fff3;color:#fff;border:none;border-radius:6px;width:32px;height:32px;font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.metadata-modal-close:hover{background:#ffffff4d;transform:scale(1.1)}.metadata-modal-body{padding:24px;overflow-y:auto;flex:1}.metadata-section{margin-bottom:20px}.metadata-section:last-child{margin-bottom:0}.metadata-section h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#0069cc}.metadata-value{padding:10px 14px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:6px;font-size:14px;color:#333;font-family:Courier New,monospace}.metadata-sql{padding:14px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:6px;font-size:13px;color:#333;font-family:Courier New,monospace;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;margin:0;max-height:300px;overflow-y:auto}.metadata-params{padding:14px;background:#f8f9fa;border:1px solid #e5e5e5;border-radius:6px;font-size:13px;color:#333;font-family:Courier New,monospace;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;margin:0;max-height:200px;overflow-y:auto}@media(max-width:768px){.metadata-modal-content{width:95%;max-height:90vh}.metadata-modal-header{padding:16px 20px}.metadata-modal-header h3{font-size:16px}.metadata-modal-body{padding:20px}.metadata-sql,.metadata-params{font-size:12px;max-height:200px}}*{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;width:100vw;display:flex;align-items:stretch;justify-content:center;padding:0}
