:root{--bg-main: #111318;--bg-surface: #16191f;--bg-elevated: #1e2330;--bg-input: #242938;--text-primary: #e2e8f0;--text-secondary: #8892a4;--text-invert: #ffffff;--text-muted: #6b7280;--border-color: #2a3245;--scrollbar-thumb: #2d3a52;--primary: #3b82f6;--primary-hover: #2563eb;--primary-light: rgba(59,130,246,.1);--error-accent: #f87171;--header-bg: #13161d;--header-border: #1f2a3e}[data-theme=light]{--bg-main: #f4f6fa;--bg-surface: #ffffff;--bg-elevated: #eef1f7;--bg-input: #f8fafc;--text-primary: #0f172a;--text-secondary: #475569;--text-invert: #ffffff;--text-muted: #94a3b8;--border-color: #dde1eb;--scrollbar-thumb: #c8d0e0;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: rgba(37,99,235,.08);--error-accent: #ef4444;--header-bg: #ffffff;--header-border: #e2e8f0}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{background:var(--bg-main);color:var(--text-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}textarea.db-input{min-height:96px;resize:vertical}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px;padding:18px;overflow-y:auto}.admin-card{border:1px solid var(--border-color);border-radius:16px;background:var(--bg-surface);padding:16px}.admin-card-header{margin-bottom:14px}.admin-membership-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.admin-pill{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:999px;padding:6px 10px;font-size:12px}.admin-checkbox{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-primary)}.required-mark{color:#dc2626;font-weight:700}.app-container{width:100vw;height:100vh;display:flex;justify-content:center}.chat-container{width:100%;height:100%;background:var(--bg-surface);display:flex;flex-direction:column}.header{padding:0 18px;height:54px;border-bottom:1px solid var(--header-border, var(--border-color));display:flex;justify-content:space-between;align-items:center;background:var(--header-bg, var(--bg-surface));flex-shrink:0;gap:16px}.header h2{font-size:15px;font-weight:700;margin:0;white-space:nowrap;letter-spacing:-.2px;color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:6px;flex:1;justify-content:flex-end;min-width:0}.model-select{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color);padding:0 10px;border-radius:8px;font-size:13px;cursor:pointer;height:32px;transition:border-color .15s;outline:none}.model-select:hover,.model-select:focus{border-color:var(--primary)}.theme-btn{background:var(--bg-elevated);border:1px solid var(--border-color);cursor:pointer;color:var(--text-primary);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0;flex-shrink:0}.theme-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.fw-300{font-weight:400;color:var(--text-secondary)}.messages{flex:1;padding:24px 16px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;max-width:900px;width:100%;margin:0 auto;align-self:center;contain:layout style}@keyframes msg-appear{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.msg-appear{animation:msg-appear .3s ease forwards;will-change:opacity,transform}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:6px}.message{max-width:78%;padding:11px 16px;border-radius:14px;line-height:1.65;font-size:14px;word-break:break-word}.msg-para{margin:0 0 6px;line-height:1.65}.msg-para:last-child{margin-bottom:0}.msg-header{margin:0 0 6px;font-weight:700;font-size:14px;line-height:1.5}.msg-spacer{height:8px}.msg-list{margin:4px 0 8px;padding-left:0;list-style:none}.msg-list:last-child{margin-bottom:0}.msg-ul{list-style:disc;padding-left:20px}.msg-ul li{margin-bottom:7px;line-height:1.65}.msg-ul li:last-child{margin-bottom:0}.msg-ol{list-style:none;padding-left:0}.msg-ol-item{display:flex;align-items:flex-start;gap:6px;margin-bottom:7px;line-height:1.65}.msg-ol-item:last-child{margin-bottom:0}.msg-ol-num{flex-shrink:0;min-width:22px;font-weight:700;color:var(--accent, #6366f1)}.msg-ol-text{flex:1}.message strong{font-weight:700}.message em{font-style:italic}.message.user{background:var(--primary);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;box-shadow:0 2px 8px #2563eb40}.message.assistant{background:var(--bg-elevated);color:var(--text-primary);align-self:flex-start;border-bottom-left-radius:4px;border:1px solid var(--border-color)}.message.assistant.typing{opacity:.6;font-style:italic}.message-wrapper{display:flex;flex-direction:column;max-width:80%;position:relative;contain:layout style}.message-wrapper.user{align-self:flex-end;align-items:flex-end}.message-wrapper.assistant{align-self:flex-start;align-items:flex-start}.message-wrapper .message{max-width:100%}.source-model{font-size:10px;opacity:.55;color:var(--text-muted, #9ca3af)}.input-wrapper{padding:12px 16px 14px;border-top:1px solid var(--border-color);background:var(--bg-surface);flex-shrink:0}.composer{display:flex;align-items:flex-end;gap:8px;background:var(--bg-elevated);border:1.5px solid var(--border-color);border-radius:14px;padding:10px 12px;transition:all .2s ease;max-width:860px;margin:0 auto}.composer:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light, rgba(59,130,246,.12))}.composer.disabled{background-color:var(--bg-elevated);opacity:.6;cursor:not-allowed!important;border-color:var(--border-color)}.composer.disabled textarea{cursor:not-allowed;color:var(--text-secondary)}.composer.disabled .send-btn{background-color:var(--text-secondary)!important;cursor:not-allowed;opacity:.5}.composer textarea{flex:1;resize:none;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14.5px;line-height:1.5;min-height:24px;max-height:220px;overflow-y:auto;word-break:break-word;white-space:pre-wrap}.composer textarea::placeholder{color:var(--text-secondary)}.mode-bar{display:flex;align-items:center;gap:10px;padding:0 16px;min-height:48px;border-bottom:1px solid var(--border-color);background:var(--bg-surface);flex-shrink:0;flex-wrap:wrap}.mode-toggle{display:flex;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:8px;padding:3px;gap:2px}.mode-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.mode-btn:hover{color:var(--text-primary)}.mode-btn.active{background:var(--bg-surface);color:var(--primary);font-weight:600;box-shadow:0 1px 4px #00000026}.mode-btn.active.db{color:#22c55e}.mode-btn.active.db svg{stroke:#22c55e}.mode-project-btn{display:flex;align-items:center;gap:6px;padding:0 10px;height:32px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-primary);font-size:13px;cursor:pointer;min-width:140px;max-width:220px}.mode-project-btn:hover{border-color:var(--primary)}.mode-project-btn.db-required{border-color:#22c55e44}.mode-project-btn.db-required:hover{border-color:#22c55e}.project-btn-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.project-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.project-db-tag{font-size:10px;color:#22c55e;font-weight:600;background:#22c55e1f;border-radius:4px;padding:1px 5px;white-space:nowrap}.project-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:200;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 6px 20px #0000002e;min-width:200px;max-height:240px;overflow-y:auto}.project-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .1s}.project-dropdown-item:last-child{border-bottom:none}.project-dropdown-item:hover{background:var(--bg-elevated)}.project-dropdown-item.selected{background:var(--primary-light)}.mode-bar-hint{font-size:11px;color:var(--text-muted);font-style:italic}.db-mode-btn{display:flex;align-items:center;gap:5px;padding:0 10px;height:32px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .18s ease;flex-shrink:0}.db-mode-btn:hover:not(:disabled){border-color:#22c55e;color:#22c55e}.db-mode-btn.active{background:#22c55e1f;border-color:#22c55e;color:#22c55e;font-weight:600}.db-mode-btn.active svg{stroke:#22c55e}.send-btn{width:36px;height:36px;border-radius:10px;border:none;cursor:pointer;background:var(--primary);color:var(--text-invert);font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.send-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn.stop{background:#ef4444}.send-btn.stop:hover{background:#dc2626}select{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color);padding:4px 10px;border-radius:8px;font-size:13px;cursor:pointer;height:32px;outline:none;transition:border-color .15s}select:hover,select:focus{border-color:var(--primary)}select:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.error-modal{background:var(--bg-surface);color:var(--text-primary);width:90%;max-width:420px;border-radius:16px;padding:24px;box-shadow:0 20px 40px #0006;border:1px solid var(--error-accent)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-header h3{margin:0;font-size:18px;color:var(--error-accent)}.close-btn{background:transparent;border:none;cursor:pointer;color:var(--text-secondary);padding:10px;line-height:1}.close-btn:hover{color:var(--error-accent)}.modal-body p{margin:0;font-size:14px;line-height:1.5;color:var(--text-secondary)}.modal-footer{margin-top:24px;display:flex;justify-content:flex-end}.refresh-btn{padding:10px 20px;background:var(--primary);color:var(--text-invert);border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:background .2s ease}.refresh-btn:hover{background:var(--primary-hover)}.tab-switcher{display:flex;gap:2px;background:var(--bg-elevated);border-radius:8px;padding:3px}.tab-btn{background:transparent;border:none;cursor:pointer;font-size:13px;color:var(--text-secondary);padding:5px 14px;border-radius:6px;font-weight:500;transition:all .15s ease}.tab-btn.active{background:var(--primary);color:#fff;box-shadow:0 1px 4px #2563eb4d}.tab-btn:not(.active):hover{color:var(--text-primary);background:var(--bg-elevated)}.training-panel{flex:1;display:flex;flex-direction:column;gap:16px;padding:20px 16px;overflow-y:auto}.kb-stats-card{display:flex;justify-content:space-between;align-items:center;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:12px;padding:14px 18px}.kb-stats-info{display:flex;flex-direction:column;gap:2px}.kb-stats-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.kb-stats-value{font-size:16px;font-weight:600;color:var(--text-primary)}.refresh-stats-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);font-size:12px;padding:6px 14px;border-radius:8px;cursor:pointer;transition:all .15s ease}.refresh-stats-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.refresh-stats-btn:disabled{opacity:.4;cursor:not-allowed}.training-mode-tabs{display:flex;gap:8px;flex-wrap:wrap}.training-mode-btn{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary);font-size:13px;padding:8px 16px;border-radius:8px;cursor:pointer;transition:all .15s ease;font-weight:500}.training-mode-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.training-mode-btn:not(.active):hover{border-color:var(--primary);color:var(--text-primary)}.training-form{display:flex;flex-direction:column;gap:14px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:12px;padding:18px}.form-group{display:flex;flex-direction:column;gap:6px;flex:1}.form-row{display:flex;gap:12px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.form-hint{font-size:11px;color:var(--text-secondary);opacity:.8}.form-input{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);font-size:14px;padding:9px 12px;border-radius:8px;outline:none;transition:border-color .15s ease;width:100%;box-sizing:border-box}.form-input:focus{border-color:var(--primary)}.form-input:disabled{opacity:.5;cursor:not-allowed}.training-textarea{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);font-size:14px;padding:10px 12px;border-radius:8px;outline:none;resize:vertical;font-family:inherit;line-height:1.5;min-height:180px;width:100%;box-sizing:border-box;transition:border-color .15s ease}.training-textarea:focus{border-color:var(--primary)}.training-textarea:disabled{opacity:.5;cursor:not-allowed}.training-textarea::placeholder,.form-input::placeholder{color:var(--text-secondary);opacity:.7}.file-upload-area{display:flex;flex-direction:column;gap:6px}.file-input{background:var(--bg-input);border:1px dashed var(--border-color);color:var(--text-primary);font-size:13px;padding:10px 12px;border-radius:8px;cursor:pointer;width:100%;box-sizing:border-box;transition:border-color .15s ease}.file-input:hover{border-color:var(--primary)}.file-name{font-size:12px;color:var(--primary);font-weight:500;padding:0 4px}.train-btn{background:var(--primary);color:#fff;border:none;padding:11px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;align-self:flex-start}.train-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.train-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.training-result{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:10px;border:1px solid}.training-result.success{background:color-mix(in srgb,#22c55e 10%,var(--bg-elevated));border-color:#22c55e}.training-result.error{background:color-mix(in srgb,var(--error-accent) 10%,var(--bg-elevated));border-color:var(--error-accent)}.result-icon{font-size:18px;flex-shrink:0;margin-top:1px}.result-body{flex:1}.result-message{margin:0;font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4}.result-detail{margin:4px 0 0;font-size:12px;color:var(--text-secondary)}.result-close{background:transparent;border:none;cursor:pointer;color:var(--text-secondary);font-size:14px;padding:2px 4px;flex-shrink:0}.result-close:hover{color:var(--text-primary)}.training-panel::-webkit-scrollbar{width:6px}.training-panel::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:6px}.qa-pair{border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:12px;background:var(--input-bg);display:flex;flex-direction:column;gap:8px}.qa-pair-header{display:flex;align-items:center;justify-content:space-between}.qa-pair-num{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.remove-example-btn{background:none;border:none;cursor:pointer;color:#e53e3e;font-size:13px;padding:2px 6px;border-radius:4px;transition:background .15s}.remove-example-btn:hover:not(:disabled){background:#e53e3e1a}.remove-example-btn:disabled{opacity:.4;cursor:not-allowed}.qa-response{resize:vertical;min-height:60px}.add-example-btn{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .15s}.add-example-btn:hover:not(:disabled){opacity:.85}.add-example-btn:disabled{opacity:.5;cursor:not-allowed}.finetune-btn{background:linear-gradient(135deg,#6b46c1,#4299e1)}.finetune-btn:hover:not(:disabled){background:linear-gradient(135deg,#553c9a,#3182ce);opacity:1}@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}80%{transform:scale(2.4);opacity:0}to{transform:scale(2.4);opacity:0}}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;margin:auto;padding:48px 20px;text-align:center;flex:1}.chat-empty-icon{width:56px;height:56px;border-radius:14px;background:var(--bg-elevated);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.chat-empty-title{margin:0;font-size:17px;font-weight:600;color:var(--text-primary)}.chat-empty-sub{margin:0;font-size:13px;color:var(--text-secondary);max-width:320px;line-height:1.6}.message-wrapper{position:relative}.msg-actions{display:none;align-items:center;gap:4px;margin-top:4px}.message-wrapper:hover .msg-actions{display:flex}.message-wrapper.user .msg-actions{justify-content:flex-end}.message-wrapper.assistant .msg-actions{justify-content:flex-start;padding-left:2px}.msg-action-btn{background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary);width:26px;height:26px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}.msg-action-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.source-badge-row{display:flex;align-items:center;gap:6px;margin-top:5px;padding-left:2px}.source-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;letter-spacing:.2px;border:1px solid}.mode-db{background:#22c55e1f;color:#22c55e;border-color:#22c55e59}.mode-vector{background:#3b82f61f;color:#60a5fa;border-color:#3b82f64d}[data-theme=light] .mode-vector{color:#2563eb;background:#2563eb14;border-color:#2563eb40}.mode-finetune{background:#8b5cf61f;color:#a78bfa;border-color:#8b5cf64d}[data-theme=light] .mode-finetune{color:#7c3aed;background:#7c3aed14;border-color:#7c3aed40}.mode-general{background:#64748b1a;color:#94a3b8;border-color:#64748b40}[data-theme=light] .mode-general{color:#475569;background:#47556912;border-color:#47556933}.source-badge.source-vector_db{background:#22c55e1f;color:#22c55e;border-color:#22c55e4d}.source-badge.source-finetune{background:#8b5cf61f;color:#a78bfa;border-color:#8b5cf64d}.source-badge.source-general{background:#64748b1a;color:#94a3b8;border-color:#64748b33}[data-theme=light] .source-badge.source-vector_db{background:#d1fae5;color:#065f46;border-color:#a7f3d0}[data-theme=light] .source-badge.source-finetune{background:#ede9fe;color:#5b21b6;border-color:#ddd6fe}[data-theme=light] .source-badge.source-general{background:#f1f5f9;color:#64748b;border-color:#e2e8f0}.typing-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--text-secondary);animation:typing-bounce 1.3s infinite ease-in-out;margin:0 2px}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}.edit-banner{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--primary);background:var(--primary-light);border:1px solid rgba(59,130,246,.3);border-radius:8px;padding:6px 12px;margin-bottom:8px;max-width:860px;margin-left:auto;margin-right:auto}.edit-banner-cancel{background:none;border:none;cursor:pointer;color:var(--primary);margin-left:auto;font-size:13px;padding:0 2px;opacity:.7}.edit-banner-cancel:hover{opacity:1}.login-overlay{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-main)}.login-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;padding:40px 36px;width:100%;max-width:400px;box-shadow:0 8px 32px #0000002e}.login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.login-logo-text{font-size:32px;font-weight:800;color:var(--primary);letter-spacing:-1px}.login-logo-sub{font-size:12px;color:var(--text-secondary);font-weight:500;letter-spacing:.5px}.login-title{margin:0 0 4px;font-size:20px;font-weight:700;color:var(--text-primary);text-align:center}.login-subtitle{margin:0 0 24px;font-size:13px;color:var(--text-secondary);text-align:center}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.login-input{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);font-size:14px;padding:10px 12px;border-radius:8px;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s}.login-input:focus{border-color:var(--primary)}.login-pwd-wrap{position:relative}.login-pwd-wrap .login-input{padding-right:56px}.login-show-pwd{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--primary);font-size:12px;cursor:pointer;padding:2px 4px}.login-error{margin:0;font-size:13px;color:var(--error-accent);background:color-mix(in srgb,var(--error-accent) 10%,var(--bg-elevated));border:1px solid var(--error-accent);border-radius:8px;padding:8px 12px}.login-btn{background:var(--primary);color:#fff;border:none;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s;margin-top:4px}.login-btn:hover{background:var(--primary-hover)}.login-hint{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color);font-size:11px;color:var(--text-secondary);text-align:center;line-height:1.8}.login-hint p{margin:0}.user-badge{display:flex;align-items:center;gap:8px;font-size:12px}.role-tag{padding:3px 8px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.role-trainer,.role-project_admin,.role-platform_admin,.role-master_admin{background:color-mix(in srgb,#6b46c1 20%,var(--bg-elevated));color:#a78bfa;border:1px solid #6b46c160}.role-user{background:color-mix(in srgb,var(--primary) 15%,var(--bg-elevated));color:#60a5fa;border:1px solid var(--primary)60}.role-admin{background:color-mix(in srgb,#f59e0b 15%,var(--bg-elevated));color:#f59e0b;border:1px solid #f59e0b60}.user-email{color:var(--text-secondary);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:12px;padding:4px 10px;border-radius:6px;cursor:pointer;transition:all .15s}.logout-btn:hover{border-color:var(--error-accent);color:var(--error-accent)}.db-panel{flex:1;display:flex;flex-direction:column;gap:16px;padding:20px 16px;overflow-y:auto}.db-panel::-webkit-scrollbar{width:6px}.db-panel::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:6px}.db-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.db-title{margin:0 0 4px;font-size:16px;font-weight:700;color:var(--text-primary)}.db-subtitle{margin:0;font-size:12px;color:var(--text-secondary)}.db-add-btn{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.db-add-btn:hover{background:var(--primary-hover)}.db-form{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:12px;padding:18px;display:flex;flex-direction:column;gap:12px}.db-form-row{display:flex;gap:12px}.db-form-group{display:flex;flex-direction:column;gap:5px;flex:1}.db-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.db-input{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);font-size:13px;padding:8px 10px;border-radius:8px;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s;font-family:inherit}.db-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.db-input::placeholder{color:var(--text-muted, var(--text-secondary));opacity:.8}.db-save-msg{margin:0;font-size:13px;padding:8px 12px;border-radius:8px}.db-save-msg.success{background:color-mix(in srgb,#22c55e 12%,var(--bg-elevated));border:1px solid #22c55e;color:#22c55e}.db-save-msg.error{background:color-mix(in srgb,var(--error-accent) 12%,var(--bg-elevated));border:1px solid var(--error-accent);color:var(--error-accent)}.db-save-btn{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;align-self:flex-start;transition:background .15s}.db-save-btn:hover:not(:disabled){background:var(--primary-hover)}.db-save-btn:disabled{opacity:.4;cursor:not-allowed}.db-loading{color:var(--text-secondary);font-size:13px;padding:12px 0}.db-empty{background:var(--bg-elevated);border:1px dashed var(--border-color);border-radius:12px;padding:32px;text-align:center;color:var(--text-secondary);font-size:13px;line-height:1.8}.db-empty p{margin:0}.db-list{display:flex;flex-direction:column;gap:10px}.db-card{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.db-card-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.db-card-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.db-type-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:10px}.db-type-sql{background:color-mix(in srgb,#3b82f6 18%,var(--bg-elevated));color:#60a5fa;border:1px solid #3b82f6}.db-type-mongodb{background:color-mix(in srgb,#22c55e 18%,var(--bg-elevated));color:#4ade80;border:1px solid #22c55e}.db-type-qdrant{background:color-mix(in srgb,#a855f7 18%,var(--bg-elevated));color:#c084fc;border:1px solid #a855f7}.db-card-name{font-size:14px;font-weight:600;color:var(--text-primary)}.db-card-desc{font-size:12px;color:var(--text-secondary)}.db-card-actions{display:flex;gap:8px;flex-shrink:0}.db-test-btn{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);font-size:12px;padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .15s}.db-test-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.db-test-btn:disabled{opacity:.4;cursor:not-allowed}.db-delete-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:12px;padding:5px 12px;border-radius:6px;cursor:pointer;transition:all .15s}.db-delete-btn:hover{border-color:var(--error-accent);color:var(--error-accent)}.db-card-meta{display:flex;gap:8px;font-size:12px;color:var(--text-secondary);flex-wrap:wrap}.db-test-result{margin:0;font-size:12px;padding:6px 10px;border-radius:6px}.db-test-result.success{background:color-mix(in srgb,#22c55e 10%,var(--bg-elevated));color:#22c55e;border:1px solid #22c55e}.db-test-result.error{background:color-mix(in srgb,var(--error-accent) 10%,var(--bg-elevated));color:var(--error-accent);border:1px solid var(--error-accent)}.ft-options-section{background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:12px}.ft-options-title{margin:0 0 4px;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.cwgt-wrap{position:fixed;bottom:24px;z-index:2147483647;display:flex;flex-direction:column;align-items:flex-end;gap:12px}.cwgt-wrap--right{right:24px;align-items:flex-end}.cwgt-wrap--left{left:24px;align-items:flex-start}.cwgt-fab{width:54px;height:54px;border-radius:50%;background:var(--primary, #2563eb);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #2563eb80;transition:transform .18s,box-shadow .18s;flex-shrink:0}.cwgt-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #2563eba6}.cwgt-fab--open{background:#374151;box-shadow:0 4px 16px #0000004d}.cwgt-popup{width:420px;max-width:calc(100vw - 32px);height:590px;max-height:calc(100vh - 100px);background:var(--bg-surface, #1e2330);border:1px solid var(--border-color, #2a3245);border-radius:16px;box-shadow:0 12px 40px #00000047;display:flex;flex-direction:column;overflow:hidden;animation:cwgt-slide-up .22s ease}@keyframes cwgt-slide-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.cwgt-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-elevated, #242938);border-bottom:1px solid var(--border-color, #2a3245);flex-shrink:0}.cwgt-header-left{display:flex;align-items:center;gap:9px}.cwgt-dot{width:9px;height:9px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e99;flex-shrink:0}.cwgt-header-title{font-size:14px;font-weight:700;color:var(--text-primary, #e2e8f0)}.cwgt-header-sub{font-size:10px;color:var(--text-muted, #6b7280);margin-top:1px}.cwgt-header-btns{display:flex;gap:4px}.cwgt-hbtn{background:none;border:none;color:var(--text-muted, #6b7280);cursor:pointer;width:28px;height:28px;border-radius:6px;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.cwgt-hbtn:hover{background:var(--border-color, #2a3245);color:var(--text-primary, #e2e8f0)}.cwgt-messages{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:var(--border-color, #2a3245) transparent}.cwgt-messages::-webkit-scrollbar{width:4px}.cwgt-messages::-webkit-scrollbar-thumb{background:var(--border-color, #2a3245);border-radius:4px}.cwgt-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;margin:auto 0;padding:24px 16px;text-align:center}.cwgt-welcome-icon{width:50px;height:50px;border-radius:50%;background:#2563eb26;color:var(--primary, #3b82f6);display:flex;align-items:center;justify-content:center}.cwgt-welcome-text{font-size:13px;line-height:1.55;color:var(--text-secondary, #8892a4);margin:0}.cwgt-msg-row{display:flex;align-items:flex-end;gap:8px}.cwgt-msg-row--user{flex-direction:row-reverse}.cwgt-avatar{width:27px;height:27px;border-radius:50%;background:var(--primary, #3b82f6);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cwgt-bubble-col{max-width:82%;min-width:0}.cwgt-bubble{max-width:100%;padding:9px 12px;border-radius:12px;font-size:13px;line-height:1.55;word-break:break-word;white-space:normal}.cwgt-bubble--user{background:var(--primary, #3b82f6);color:#fff;border-bottom-right-radius:3px;white-space:pre-wrap}.cwgt-bubble--assistant{background:var(--bg-elevated, #242938);color:var(--text-primary, #e2e8f0);border:1px solid var(--border-color, #2a3245);border-bottom-left-radius:3px}.cwgt-mode-badge{display:inline-block;font-size:9px;font-weight:600;padding:2px 6px;border-radius:10px;margin-top:4px;letter-spacing:.3px}.cwgt-typing{display:inline-flex;gap:4px;align-items:center;padding:2px 0}.cwgt-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-secondary, #8892a4);animation:cwgt-dot-bounce 1.2s infinite ease-in-out}.cwgt-typing span:nth-child(2){animation-delay:.2s}.cwgt-typing span:nth-child(3){animation-delay:.4s}@keyframes cwgt-dot-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.cwgt-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border-color, #2a3245);background:var(--bg-surface, #1e2330);flex-shrink:0}.cwgt-input{flex:1;padding:9px 12px;background:var(--bg-elevated, #242938);border:1px solid var(--border-color, #2a3245);border-radius:10px;color:var(--text-primary, #e2e8f0);font-size:13px;outline:none;transition:border-color .15s}.cwgt-input:focus{border-color:var(--primary, #3b82f6)}.cwgt-input::placeholder{color:var(--text-muted, #6b7280)}.cwgt-input:disabled{opacity:.6}.cwgt-send-btn{width:36px;height:36px;border-radius:10px;background:var(--primary, #3b82f6);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.cwgt-send-btn:hover:not(:disabled){background:#2563eb}.cwgt-send-btn:disabled{opacity:.4;cursor:not-allowed}.cwgt-stop{background:#ef4444}.cwgt-stop:hover{background:#dc2626}.cwgt-footer{padding:5px 12px 8px;font-size:10px;text-align:center;color:var(--text-muted, #6b7280);flex-shrink:0}@media(max-width:480px){.cwgt-wrap--right{right:12px}.cwgt-wrap--left{left:12px}.cwgt-popup{width:calc(100vw - 24px);height:min(540px,calc(100vh - 110px))}}.cwgt-popup--light{background:#fff;border-color:#dde1eb;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: #dde1eb;--bg-elevated: #f1f5f9;--bg-surface: #ffffff;--primary: #2563eb}.cwgt-popup--light .cwgt-header{background:#f8fafc;border-bottom-color:#dde1eb}.cwgt-popup--light .cwgt-messages{background:#fff}.cwgt-popup--light .cwgt-input-row{background:#fff;border-top-color:#dde1eb}.cwgt-popup--light .cwgt-input{background:#f8fafc;border-color:#dde1eb;color:#0f172a}.cwgt-popup--light .cwgt-footer{background:#f8fafc;color:#94a3b8}.cwgt-popup--light .cwgt-bubble--assistant{background:#f1f5f9;color:#0f172a;border-color:#dde1eb}.cwgt-popup--light .cwgt-hbtn{color:#94a3b8}.cwgt-popup--light .cwgt-hbtn:hover{background:#dde1eb;color:#0f172a}.cwgt-popup--light .cwgt-welcome-text{color:#475569}.cwgt-popup--light .cwgt-header-title{color:#0f172a}.cwgt-bubble .msg-ol-num{color:#818cf8}.cwgt-popup--light .cwgt-header-sub{color:#94a3b8}.cwgt-popup--light .cwgt-typing span{background:#94a3b8}: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}}
