collabdocchat 2.4.8 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,8 @@
1
+ :root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #8b5cf6;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-dark: #0f172a;--bg-card: #1e293b;--bg-hover: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border: #334155;--shadow: rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);color:var(--text-primary);min-height:100vh}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:var(--bg-card);border-radius:20px;padding:40px;width:100%;max-width:450px;box-shadow:0 20px 60px var(--shadow);animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:30px}.logo{font-size:32px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:10px}.tagline{color:var(--text-secondary);font-size:14px}.auth-switch{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.switch-text{color:var(--text-secondary);font-size:14px;margin:0}.link-btn{background:none;border:none;color:var(--primary);text-decoration:none;cursor:pointer;font-size:14px;font-weight:600;padding:0;margin-left:5px;transition:all .3s}.link-btn:hover{color:var(--primary-dark);text-decoration:underline}.register-note{text-align:center;padding:15px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:8px;margin-bottom:10px}.register-note p{color:var(--text-secondary);font-size:13px;margin:0}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form.hidden,.hidden{display:none}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{padding:12px 16px;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.btn-primary{padding:14px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #6366f166}.error-message{color:var(--danger);font-size:14px;min-height:20px}.dashboard{display:flex;height:100vh;width:100%;background:var(--bg-dark)}.sidebar{width:280px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px;height:100vh;overflow-y:auto;overflow-x:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.sidebar-header h2{font-size:20px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.badge-admin{background:var(--primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-user{background:var(--success);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.user-info{display:flex;align-items:center;gap:12px;padding:15px;background:var(--bg-dark);border-radius:12px;margin-bottom:30px}.avatar{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}.username{font-weight:600;font-size:15px}.user-role{font-size:13px;color:var(--text-secondary)}.nav-menu{flex:1;display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:none;border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .3s;font-size:15px;text-align:left}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--primary);color:#fff}.nav-item .icon{font-size:20px}.btn-logout{padding:12px;background:var(--danger);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.btn-logout:hover{background:#dc2626}.main-content{flex:1;overflow-y:auto;padding:30px;width:100%;max-width:100%;height:100vh;max-height:100vh}.view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.view-header h2{font-size:28px;font-weight:700}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.group-card{background:var(--bg-card);border-radius:15px;padding:25px;transition:all .3s;border:2px solid transparent}.group-card:hover{border-color:var(--primary);transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow)}.group-card h3{font-size:20px;margin-bottom:10px}.group-card p{color:var(--text-secondary);font-size:14px;margin-bottom:15px}.group-stats{display:flex;gap:15px;margin-bottom:15px;font-size:13px;color:var(--text-secondary)}.btn-select{width:100%;padding:10px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.btn-select:hover{background:var(--primary-dark)}.tasks-list{display:flex;flex-direction:column;gap:15px}.task-card{background:var(--bg-card);border-radius:15px;padding:20px;border-left:4px solid var(--primary)}.task-card.status-completed{border-left-color:var(--success);opacity:.7}.task-card.status-terminated{border-left-color:var(--danger);opacity:.7}.task-card h3{font-size:18px;margin-bottom:10px}.task-card p{color:var(--text-secondary);font-size:14px;margin-bottom:15px}.task-meta{display:flex;gap:15px;flex-wrap:wrap;font-size:13px;color:var(--text-secondary)}.status-badge{padding:4px 12px;border-radius:20px;background:var(--primary);color:#fff;font-weight:600}.task-actions{margin-top:15px;display:flex;gap:10px}.btn-sm{padding:8px 16px;font-size:13px;border-radius:8px;border:none;cursor:pointer;font-weight:600;transition:all .3s}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff;border:none;cursor:pointer;transition:all .3s}.btn-danger:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 5px 15px #ef444466}.btn-danger:active{transform:translateY(0);box-shadow:0 2px 8px #ef44444d}.documents-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.document-card{background:var(--bg-card);border-radius:15px;padding:20px;transition:all .3s}.document-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px var(--shadow)}.document-card h3{font-size:18px;margin-bottom:15px}.doc-meta{display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--text-secondary);margin-bottom:15px}.btn-edit{width:100%;padding:10px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s}.editor-container{background:var(--bg-card);border-radius:15px;padding:20px;height:calc(100vh - 200px);display:flex;flex-direction:column}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid var(--border)}.online-users{display:flex;gap:10px;flex-wrap:wrap}.user-badge{padding:6px 12px;background:var(--bg-dark);border-radius:20px;font-size:13px}.user-badge.typing{background:var(--primary);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}#editor{flex:1;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;padding:20px;color:var(--text-primary);font-family:Consolas,monospace;font-size:15px;line-height:1.6;resize:none}#editor:focus{outline:none;border-color:var(--primary)}.editor-footer{margin-top:15px;padding-top:15px;border-top:1px solid var(--border);font-size:13px;color:var(--text-secondary)}.chat-container{background:var(--bg-card);border-radius:15px;height:calc(100vh - 200px);display:flex;flex-direction:column}.messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px}.message{display:flex;flex-direction:column;gap:5px;max-width:70%}.message.own{align-self:flex-end}.message-header{display:flex;gap:10px;font-size:12px;color:var(--text-secondary)}.message-content{background:var(--bg-dark);padding:12px 16px;border-radius:12px;word-wrap:break-word}.message.own .message-content{background:var(--primary)}.notification{align-self:center;background:var(--bg-hover);padding:8px 16px;border-radius:20px;font-size:13px;color:var(--text-secondary)}.chat-input{display:flex;gap:10px;padding:20px;border-top:1px solid var(--border)}.chat-input input{flex:1;padding:12px 16px;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px}.chat-input input:focus{outline:none;border-color:var(--primary)}.call-panel{background:var(--bg-card);border-radius:15px;padding:30px}.call-controls{display:flex;align-items:center;gap:15px;margin-bottom:30px}.call-controls label{font-weight:600}.call-controls input{width:80px;padding:10px;background:var(--bg-dark);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:16px}.btn-large{padding:14px 30px;font-size:18px}.call-result{min-height:200px}.called-members{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px;margin-top:20px}.member-card{background:var(--bg-dark);border-radius:12px;padding:20px;text-align:center;animation:bounceIn .5s ease}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.member-card .avatar{margin:0 auto 10px}.member-name{font-weight:600}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal.hidden{display:none}.modal-content{background:var(--bg-card);border-radius:15px;padding:30px;width:90%;max-width:500px}.modal-content h3{margin-bottom:20px;font-size:24px}.modal-content form{display:flex;flex-direction:column;gap:15px}.btn-secondary{padding:12px;background:var(--bg-hover);border:none;border-radius:8px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s}.btn-back{padding:10px 20px;background:var(--bg-hover);border:none;border-radius:8px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s}.btn-back:hover{background:var(--border)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}.doc-status{padding:8px 16px;background:var(--bg-card);border-radius:20px;font-size:14px}.doc-link{color:var(--primary);text-decoration:none;font-size:14px;margin-top:10px;display:inline-block}.doc-link:hover{text-decoration:underline}.audit-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-card);border-radius:12px;padding:20px;text-align:center;box-shadow:0 4px 20px var(--shadow)}.stat-card h3{font-size:14px;color:var(--text-secondary);margin-bottom:10px;font-weight:500}.stat-number{font-size:32px;font-weight:700;color:var(--primary)}.audit-table{background:var(--bg-card);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px var(--shadow)}.audit-header{display:grid;grid-template-columns:150px 120px 120px 1fr 2fr;gap:20px;padding:15px 20px;background:var(--bg-hover);font-weight:600;font-size:14px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.audit-row{display:grid;grid-template-columns:150px 120px 120px 1fr 2fr;gap:20px;padding:15px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .3s}.audit-row:hover{background:var(--bg-hover)}.audit-row:last-child{border-bottom:none}.audit-time{font-size:12px;color:var(--text-secondary)}.audit-user{display:flex;align-items:center;gap:8px}.audit-user .avatar{width:24px;height:24px;font-size:10px}.audit-user span{font-size:13px}.audit-action .action-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.action-badge.action-document_create{background:#10b98133;color:var(--success)}.action-badge.action-document_update{background:#3b82f633;color:#3b82f6}.action-badge.action-document_delete{background:#ef444433;color:var(--danger)}.action-badge.action-content_edit{background:#f59e0b33;color:var(--warning)}.action-badge.action-title_edit{background:#8b5cf633;color:var(--secondary)}.action-badge.action-document_permission_change{background:#6b728033;color:#6b7280}.audit-resource{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-description{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pagination{display:flex;align-items:center;justify-content:center;gap:15px;margin-top:20px}.pagination button{padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .3s}.pagination button:hover:not(:disabled){background:var(--bg-hover)}.pagination button:disabled{opacity:.5;cursor:not-allowed}#pageInfo{color:var(--text-secondary);font-size:14px}.form-select,.form-input{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px}.form-select option{background:var(--bg-card);color:var(--text-primary)}.error-state{text-align:center;padding:40px;color:var(--danger);background:#ef44441a;border-radius:8px;margin:20px 0}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border)}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.audit-detail{padding:20px;background:var(--bg-dark);border-radius:8px}.audit-detail p{margin-bottom:10px;line-height:1.6}@media (max-width: 768px){.audit-header,.audit-row{grid-template-columns:1fr;gap:10px}.audit-header>div,.audit-row>div{display:flex;justify-content:space-between;align-items:center}.audit-header>div:before,.audit-row>div:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:12px}.view-header{flex-direction:column;gap:15px}.view-header>div{flex-wrap:wrap;gap:10px}}.files-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;padding:20px}.file-card{background:var(--bg-card);border-radius:12px;padding:20px;display:flex;gap:15px;align-items:flex-start;transition:transform .2s,box-shadow .2s}.file-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.file-icon{font-size:40px;flex-shrink:0}.file-info{flex:1;min-width:0}.file-info h4{margin:0 0 8px;color:var(--text-primary);font-size:16px;word-break:break-word}.file-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary);margin-bottom:8px}.file-description{color:var(--text-secondary);font-size:13px;margin:8px 0 0;line-height:1.4}.file-actions{display:flex;gap:8px;flex-shrink:0}.file-actions a{text-decoration:none}.btn-emoji{background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;padding:12px 16px;font-size:20px;cursor:pointer;transition:all .2s}.btn-emoji:hover{background:var(--bg-hover);border-color:var(--primary)}.btn-emoji:disabled{opacity:.5;cursor:not-allowed}emoji-picker{position:absolute;bottom:70px;left:20px;z-index:1000;border-radius:12px;box-shadow:0 4px 20px #0003}emoji-picker.hidden{display:none}.search-container{padding:20px}.search-box{display:flex;gap:10px;margin-bottom:20px}.search-box input{flex:1;padding:12px 16px;background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:15px}.search-box input:focus{outline:none;border-color:var(--primary)}.search-filters{display:flex;gap:20px;margin-bottom:20px;padding:15px;background:var(--bg-card);border-radius:10px}.search-filters label{display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--text-primary);font-size:14px}.search-filters input[type=checkbox]{width:18px;height:18px;cursor:pointer}.search-results{display:flex;flex-direction:column;gap:15px}.search-result-item{background:var(--bg-card);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s}.search-result-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.result-type{font-size:12px;color:var(--text-secondary);background:var(--bg-dark);padding:4px 8px;border-radius:6px}.result-time{font-size:12px;color:var(--text-secondary)}.search-result-item h4{margin:0 0 8px;color:var(--text-primary);font-size:16px}.search-result-item p{margin:0 0 10px;color:var(--text-secondary);font-size:14px;line-height:1.5}.search-result-item mark{background:var(--primary);color:#fff;padding:2px 4px;border-radius:3px}.result-group,.result-status{display:inline-block;font-size:12px;color:var(--text-secondary);background:var(--bg-dark);padding:4px 8px;border-radius:6px;margin-right:8px}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.ql-container{font-size:15px;color:var(--text-primary);background:var(--bg-dark);border:2px solid var(--border);border-radius:10px;min-height:400px}.ql-toolbar{background:var(--bg-card);border:2px solid var(--border);border-bottom:none;border-radius:10px 10px 0 0}.ql-toolbar .ql-stroke{stroke:var(--text-primary)}.ql-toolbar .ql-fill{fill:var(--text-primary)}.ql-toolbar button:hover,.ql-toolbar button.ql-active{color:var(--primary)}.ql-toolbar button:hover .ql-stroke,.ql-toolbar button.ql-active .ql-stroke{stroke:var(--primary)}.ql-toolbar button:hover .ql-fill,.ql-toolbar button.ql-active .ql-fill{fill:var(--primary)}#editor.readonly .ql-toolbar{display:none}#editor.readonly .ql-container{border-top:2px solid var(--border);border-radius:10px}.chat-input{position:relative}.chat-input .btn-emoji{flex-shrink:0}@media (max-width: 768px){.files-list{grid-template-columns:1fr}emoji-picker{left:10px;right:10px;width:auto}.search-filters{flex-direction:column;gap:10px}}/*!
2
+ * Quill Editor v1.3.7
3
+ * https://quilljs.com/
4
+ * Copyright (c) 2014, Jason Chen
5
+ * Copyright (c) 2013, salesforce.com
6
+ */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor>*{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor ul,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"�?}.ql-editor ul[data-checked=true],.ql-editor ul[data-checked=false]{pointer-events:none}.ql-editor ul[data-checked=true]>li *,.ql-editor ul[data-checked=false]>li *{pointer-events:all}.ql-editor ul[data-checked=true]>li:before,.ql-editor ul[data-checked=false]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"�?}.ql-editor ul[data-checked=false]>li:before{content:"�?}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;counter-increment:list-0}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:"";display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer: coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{white-space:pre-wrap;margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label:before,.ql-snow .ql-picker.ql-header .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label:before,.ql-snow .ql-picker.ql-font .ql-picker-item:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label:before,.ql-snow .ql-picker.ql-size .ql-picker-item:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:#0003 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0px}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0px;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}
7
+ .knowledge-filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}}:is() .knowledge-filters input,:is() .knowledge-filters select{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-primary);min-width:180px}:is() .knowledge-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}:is() .knowledge-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px}:is() .kb-header{display:flex;justify-content:space-between;align-items:center;gap:8px}:is() .kb-header h3{font-size:17px;margin:0;flex:1;color:var(--text-primary)}:is() .kb-status{padding:6px 10px;border-radius:10px;font-size:12px;text-transform:uppercase;background:var(--bg-hover);color:var(--text-secondary)}:is() .kb-status.published{background:#10b98133;color:var(--success)}:is() .kb-status.draft{background:#f59e0b33;color:var(--warning)}:is() .kb-status.archived{background:#64748b33;color:#cbd5e1}:is() .kb-meta,:is() .kb-tags,:is() .kb-actions{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text-secondary)}:is() .kb-tags .tag{background:var(--bg-hover);padding:4px 8px;border-radius:8px;color:var(--text-primary);font-size:12px}:is() .kb-actions{margin-top:4px}:is() .export-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}:is() .export-section{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 6px 18px var(--shadow)}:is() .export-section h3{margin:0;font-size:16px;color:var(--text-primary)}:is() .export-section p{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.5}:is() .export-actions{display:flex;flex-wrap:wrap;gap:10px}:is() .settings-view{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.02) 100%);border:1px solid var(--border);border-radius:20px;padding:28px;animation:fadeInUp .6s ease}:is() .settings-tabs{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--border)}:is() .settings-tabs .tab-btn{padding:12px 24px;border:2px solid var(--border);border-radius:12px;background:var(--bg-dark);color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-weight:600;font-size:14px;position:relative;overflow:hidden}:is() .settings-tabs .tab-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}:is() .settings-tabs .tab-btn:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #6366f133}:is() .settings-tabs .tab-btn:hover:before{left:100%}:is() .settings-tabs .tab-btn.active{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-color:var(--primary);color:#fff;box-shadow:0 6px 20px #6366f166;transform:translateY(-2px)}:is() .settings-content{background:var(--bg-dark);border:1px solid var(--border);border-radius:16px;padding:24px;min-height:400px}:is() .tab-content{display:none;animation:fadeIn .4s ease}:is() .tab-content.active{display:block}:is() .setting-item{display:flex;align-items:flex-start;gap:12px;padding:16px;border-bottom:1px solid var(--border);transition:all .3s ease;border-radius:8px}:is() .setting-item:hover{background:#6366f10d;transform:translate(5px)}:is() .setting-item:last-child{border-bottom:none}:is() .setting-item label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;font-size:15px}:is() .setting-item input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}:is() .setting-description{margin:8px 0 0 32px;color:var(--text-secondary);font-size:13px;line-height:1.6}:is() .ai-settings,:is() .notification-settings{display:flex;flex-direction:column;gap:16px}:is() .ai-settings h3,:is() .notification-settings h3{margin:0 0 20px;font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .help-center{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.02) 100%);border:1px solid var(--border);border-radius:20px;padding:28px;animation:fadeInUp .6s ease}:is() .help-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}:is() .help-section{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.03) 100%);border:1px solid var(--border);border-radius:16px;padding:24px;transition:all .3s ease;position:relative;overflow:hidden}:is() .help-section:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);transition:all .5s ease}:is() .help-section:hover{transform:translateY(-8px);box-shadow:0 12px 32px #6366f133;border-color:var(--primary)}:is() .help-section:hover:before{top:0;right:0}:is() .help-section h3{margin:0 0 16px;font-size:18px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px;position:relative;z-index:1}:is() .help-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--text-secondary);position:relative;z-index:1}:is() .help-section ul li{padding:8px 12px;border-radius:8px;transition:all .3s ease;cursor:pointer}:is() .help-section ul li:hover{background:#6366f11a;color:var(--text-primary);transform:translate(5px)}:is() .help-section a{color:var(--primary);text-decoration:none;font-weight:600;transition:all .3s ease}:is() .help-section a:hover{color:var(--secondary);text-decoration:underline}:is() .help-footer{margin-top:30px;padding:24px;background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.05) 100%);border-radius:16px;border:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}:is() .help-footer p{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}:is() .help-footer button{padding:12px 28px;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border:none;border-radius:12px;color:#fff;font-weight:700;font-size:15px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6366f14d}:is() .help-footer button:hover{transform:translateY(-3px);box-shadow:0 8px 24px #6366f180}:is() .task-detail-view{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.03) 100%);border:1px solid var(--border);border-radius:20px;padding:28px;box-shadow:0 16px 48px var(--shadow);color:var(--text-primary);animation:modalSlideIn .4s ease}:is() .task-detail-header{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid var(--border)}:is() .task-detail-header h2{margin:0;font-size:26px;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .task-detail-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:24px;padding:20px;background:var(--bg-dark);border-radius:12px;border:1px solid var(--border)}:is() .task-detail-info .info-row{display:flex;gap:10px;font-size:14px;align-items:center}:is() .task-detail-info .info-label{color:var(--text-secondary);font-weight:600;min-width:80px}:is() .task-detail-info .info-value{color:var(--text-primary);font-weight:500}:is() .task-completion-stats{margin-bottom:24px}:is() .task-completion-stats h3{margin:0 0 16px;font-size:18px;font-weight:700;color:var(--text-primary)}:is() .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}:is() .stat-card{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;transition:all .3s ease;position:relative;overflow:hidden}:is() .stat-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);transition:all .5s ease}:is() .stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px #6366f133;border-color:var(--primary)}:is() .stat-card:hover:before{top:0;right:0}:is() .stat-label{color:var(--text-secondary);font-size:13px;margin-bottom:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}:is() .stat-value{font-size:28px;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .progress-bar-container{margin-top:16px}:is() .progress-bar{width:100%;height:12px;background:var(--bg-hover);border-radius:10px;overflow:hidden;box-shadow:inset 0 2px 4px #0003}:is() .progress-fill{height:100%;background:linear-gradient(90deg,var(--primary) 0%,var(--secondary) 100%);border-radius:10px;transition:width .6s ease;box-shadow:0 0 10px #6366f180}:is() .poll-results-section{margin-bottom:24px}:is() .poll-results-section h3{margin:0 0 16px;font-size:18px;font-weight:700}:is() .poll-options-results{display:flex;flex-direction:column;gap:14px}:is() .poll-option-result{background:var(--bg-dark);border:1px solid var(--border);border-radius:12px;padding:16px;transition:all .3s ease}:is() .poll-option-result:hover{border-color:var(--primary);transform:translate(5px)}:is() .poll-option-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;font-size:15px}:is() .poll-option-text{color:var(--text-primary);font-weight:600}:is() .poll-option-count{color:var(--text-secondary);font-weight:700}:is() .task-members-list h3{margin:0 0 16px;font-size:18px;font-weight:700}:is() .members-table{border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 4px 12px var(--shadow)}:is() .members-table-header,:is() .members-table-row{display:grid;grid-template-columns:1fr 140px 180px;gap:16px;align-items:center;padding:14px 18px}:is() .members-table-header{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%);color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px}:is() .members-table-row{border-top:1px solid var(--border);background:var(--bg-card);transition:all .3s ease}:is() .members-table-row:hover{background:#6366f10d;transform:translate(5px)}:is() .member-info{display:flex;align-items:center;gap:12px}:is() .member-status{font-size:13px;font-weight:600}:is() .member-time{color:var(--text-secondary);font-size:13px}:is() .members-table-row.completed{background:linear-gradient(90deg,rgba(16,185,129,.1) 0%,transparent 100%);border-left:3px solid var(--success)}:is() .members-table-row.pending{background:linear-gradient(90deg,rgba(239,68,68,.08) 0%,transparent 100%);border-left:3px solid var(--danger)}:is() .backup-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px;animation:fadeInUp .6s ease}:is() .backup-stats .stat-card{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(99,102,241,.05) 100%);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 8px 24px var(--shadow);transition:all .3s ease;position:relative;overflow:hidden}:is() .backup-stats .stat-card:before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);border-radius:50%;transform:translate(30%,-30%)}:is() .backup-stats .stat-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px #6366f133;border-color:var(--primary)}:is() .backup-stats .stat-card h3{margin:0 0 12px;font-size:13px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}:is() .backup-stats .stat-number{font-size:32px;font-weight:800;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .backup-list{background:transparent;animation:fadeIn .8s ease}:is() .backups-table{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 8px 24px var(--shadow)}:is() .backup-header,:is() .backup-row{display:grid;grid-template-columns:200px 100px 120px 150px 1fr;gap:16px;align-items:center;padding:16px 20px}:is() .backup-header{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%);color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid var(--border)}:is() .backup-row{border-top:1px solid var(--border);font-size:14px;color:var(--text-primary);transition:all .3s ease}:is() .backup-row:hover{background:#6366f10d;transform:translate(5px)}:is() .backup-row:nth-child(2n){background:#ffffff05}:is() .backup-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}:is() .backup-type-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border);transition:all .3s ease}:is() .backup-type-badge:hover{transform:scale(1.05)}:is() .backup-type-badge.manual{background:linear-gradient(135deg,#6366f133,#6366f11a);border-color:#6366f180;color:#818cf8}:is() .backup-type-badge.scheduled{background:linear-gradient(135deg,#10b98133,#10b9811a);border-color:#10b98180;color:#34d399}:is() .backup-type-badge.auto{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);border-color:#f59e0b80;color:#fbbf24}@media (max-width: 900px){{@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes spin{to{transform:rotate(360deg)}}}:is() .backup-header{display:none}:is() .backup-row{grid-template-columns:1fr;gap:8px}:is() .backup-row>div{display:flex;justify-content:space-between;gap:10px}:is() .backup-row>div:nth-child(1):before{content:"备份时间";color:var(--text-secondary)}:is() .backup-row>div:nth-child(2):before{content:"类型";color:var(--text-secondary)}:is() .backup-row>div:nth-child(3):before{content:"大小";color:var(--text-secondary)}:is() .backup-row>div:nth-child(4):before{content:"状�?;color:var(--text-secondary)}
8
+ .backup-row>div:nth-child(5){justify-content:flex-end}}:is() .btn-primary,:is() .btn-secondary,:is() .btn-success,:is() .btn-danger,:is() .btn-warning{position:relative;overflow:hidden;transition:all .3s ease}:is() .btn-primary:before,:is() .btn-secondary:before,:is() .btn-success:before,:is() .btn-danger:before,:is() .btn-warning:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}:is() .btn-primary:hover:before,:is() .btn-secondary:hover:before,:is() .btn-success:hover:before,:is() .btn-danger:hover:before,:is() .btn-warning:hover:before{width:300px;height:300px}:is() .btn-success{background:linear-gradient(135deg,var(--success) 0%,#059669 100%);color:#fff}:is() .btn-success:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}:is() .btn-warning{background:linear-gradient(135deg,var(--warning) 0%,#d97706 100%);color:#fff}:is() .btn-warning:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}:is() .modal{animation:fadeIn .3s ease}:is() .modal-content{animation:scaleIn .4s ease;border-radius:20px;box-shadow:0 20px 60px #00000080}:is() .modal-header{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%);border-radius:20px 20px 0 0;padding:20px 24px}:is() .modal-header h3{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}:is() .close-btn,:is() .modal-close{transition:all .3s ease}:is() .close-btn:hover,:is() .modal-close:hover{transform:rotate(90deg);color:var(--danger)}:is() .status-badge{padding:6px 14px;border-radius:20px;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease;display:inline-flex;align-items:center;gap:6px}:is() .status-badge:hover{transform:scale(1.05)}:is() .status-badge.status-completed{background:linear-gradient(135deg,#10b98133,#10b9811a);color:var(--success);border:1px solid rgba(16,185,129,.3)}:is() .status-badge.status-pending{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--warning);border:1px solid rgba(245,158,11,.3)}:is() .status-badge.status-in_progress{background:linear-gradient(135deg,#3b82f633,#3b82f61a);color:#3b82f6;border:1px solid rgba(59,130,246,.3)}:is() .status-badge.status-terminated,:is() .status-badge.status-failed{background:linear-gradient(135deg,#ef444433,#ef44441a);color:var(--danger);border:1px solid rgba(239,68,68,.3)}:is() .empty-state{text-align:center;padding:80px 20px;color:var(--text-secondary);font-size:16px;background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.03) 100%);border-radius:16px;border:2px dashed var(--border);animation:fadeIn .6s ease}:is() .empty-state:before{content:"📭";display:block;font-size:64px;margin-bottom:20px;animation:bounce 2s infinite}:is() .view-header{animation:fadeInDown .6s ease}:is() .view-header h2{position:relative;display:inline-block}:is() .view-header h2:after{content:"";position:absolute;bottom:-5px;left:0;width:60px;height:4px;background:linear-gradient(90deg,var(--primary) 0%,var(--secondary) 100%);border-radius:2px}:is() .group-card,:is() .task-card,:is() .document-card,:is() .knowledge-card,:is() .workflow-card,:is() .file-card{animation:fadeInUp .5s ease;animation-fill-mode:both}:is() .group-card:nth-child(1){animation-delay:.1s}:is() .group-card:nth-child(2){animation-delay:.2s}:is() .group-card:nth-child(3){animation-delay:.3s}:is() .group-card:nth-child(4){animation-delay:.4s}:is() .group-card:nth-child(5){animation-delay:.5s}:is() .group-card:nth-child(6){animation-delay:.6s}:is() .form-group input:focus,:is() .form-group select:focus,:is() .form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}:is() .loading{position:relative;color:var(--text-secondary)}:is() .loading:after{content:"";display:inline-block;width:20px;height:20px;margin-left:10px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}:is() .help-sections{grid-template-columns:1fr}:is() .stats-grid{grid-template-columns:repeat(2,1fr)}:is() .task-detail-info,:is() .members-table-header,:is() .members-table-row{grid-template-columns:1fr}:is() .backup-stats{grid-template-columns:repeat(2,1fr)}@media (max-width: 600px){:is() .stats-grid,:is() .backup-stats{grid-template-columns:1fr}:is() .view-header{flex-direction:column;align-items:flex-start}:is() .view-header>div{width:100%}}:is() ::-webkit-scrollbar{width:10px;height:10px}:is() ::-webkit-scrollbar-track{background:var(--bg-dark);border-radius:5px}:is() ::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);border-radius:5px;transition:all .3s ease}:is() ::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%)}:is() [title]{position:relative;cursor:help}:is() button:focus-visible,:is() input:focus-visible,:is() select:focus-visible,:is() textarea:focus-visible{outline:2px solid var(--primary);outline-offset:2px}:is() *{transition-timing-function:cubic-bezier(.4,0,.2,1)}@media print{:is() .sidebar,:is() .nav-menu,:is() .btn-logout,:is() .modal,:is() button{display:none!important}:is() .main-content{margin:0;padding:0}:is() .view-header h2:after{display:none}}:is() img,:is() video,:is() canvas{max-width:100%;height:auto}:is() *{word-wrap:break-word;overflow-wrap:break-word}@media (max-width: 1024px){:is() .sidebar{width:240px}:is() .main-content{padding:20px}:is() .view-header{flex-direction:column;align-items:flex-start;gap:12px}:is() .view-header h2{font-size:24px}:is() .groups-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}:is() .documents-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}:is() .knowledge-list{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}:is() .backup-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}:is() .settings-cards-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}:is() .collab-tools-tabs-modern{gap:8px}:is() .collab-tab-btn{min-width:100px;padding:12px 16px;font-size:13px}:is() .modal-content{width:85%;max-width:700px;padding:24px}:is() .task-detail-info{grid-template-columns:1fr;gap:12px}:is() .stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}}@media (max-width: 768px){:is() .dashboard{flex-direction:column;height:auto;min-height:100vh}:is() .sidebar{width:100%;height:auto;max-height:none;border-right:none;border-bottom:2px solid var(--border);padding:12px;overflow-y:visible;position:sticky;top:0;z-index:100;background:var(--bg-card)}:is() .sidebar-header{margin-bottom:12px}:is() .sidebar-header h2{font-size:18px}:is() .user-info{padding:10px;margin-bottom:12px}:is() .avatar{width:36px;height:36px;font-size:16px}:is() .username{font-size:14px}:is() .user-role{font-size:12px}:is() .nav-menu{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;gap:8px;padding-bottom:8px;-webkit-overflow-scrolling:touch}:is() .nav-menu::-webkit-scrollbar{height:4px}:is() .nav-menu::-webkit-scrollbar-track{background:var(--bg-dark);border-radius:2px}:is() .nav-menu::-webkit-scrollbar-thumb{background:var(--primary);border-radius:2px}:is() .nav-item{flex-shrink:0;padding:10px 14px;font-size:13px;white-space:nowrap}:is() .nav-item .icon{font-size:16px}:is() .sidebar-footer{display:flex;flex-direction:row;gap:8px;margin-top:12px}:is() .sidebar-footer .nav-item{flex:1}:is() .btn-logout{padding:10px;font-size:13px;margin-top:8px}:is() .main-content{padding:16px;height:auto;max-height:none}:is() .view-header{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:20px}:is() .view-header h2{font-size:22px}:is() .view-header button{width:100%}:is() .groups-grid,:is() .documents-list,:is() .knowledge-list,:is() .files-list{grid-template-columns:1fr;gap:12px}:is() .group-card,:is() .document-card,:is() .knowledge-card,:is() .file-card{padding:16px}:is() .group-card h3,:is() .document-card h3,:is() .knowledge-card h3{font-size:16px}:is() .tasks-list{gap:12px}:is() .task-card{padding:16px}:is() .task-card h3{font-size:16px}:is() .task-meta,:is() .task-actions{flex-direction:column;gap:8px}:is() .task-actions button{width:100%}:is() .modal{padding:10px}:is() .modal-content{width:95%;max-width:none;padding:20px;max-height:90vh;overflow-y:auto}:is() .modal-header h3{font-size:20px}:is() .form-group{margin-bottom:16px}:is() .form-group label{font-size:13px}:is() .form-group input,:is() .form-group select,:is() .form-group textarea{padding:10px 12px;font-size:14px}:is() .btn-primary,:is() .btn-secondary,:is() .btn-danger,:is() .btn-success,:is() .btn-warning{padding:12px 16px;font-size:14px;width:100%}:is() .btn-sm{padding:8px 12px;font-size:12px}:is() .chat-container{height:calc(100vh - 200px);min-height:400px}:is() .messages{padding:12px;gap:12px}:is() .message{max-width:85%}:is() .message-content{padding:10px 12px;font-size:14px}:is() .chat-input{padding:12px;gap:8px}:is() .chat-input input{padding:10px 12px;font-size:14px}:is() .editor-container{height:calc(100vh - 250px);min-height:300px;padding:12px}:is() .editor-toolbar{flex-wrap:wrap;gap:8px}:is() #editor{padding:12px;font-size:14px}:is() .search-box{flex-direction:column;gap:8px}:is() .search-box input,:is() .search-box button{width:100%}:is() .search-filters{flex-direction:column;gap:12px}:is() .audit-stats{grid-template-columns:repeat(2,1fr);gap:12px}:is() .stat-number{font-size:24px}:is() .audit-header{display:none}:is() .audit-row{grid-template-columns:1fr;gap:8px;padding:12px}:is() .audit-row>div{display:flex;justify-content:space-between;align-items:center;gap:8px}:is() .audit-row>div:before{content:attr(data-label);font-weight:600;color:var(--text-secondary);font-size:12px}:is() .backup-stats{grid-template-columns:1fr;gap:12px}:is() .backup-header{display:none}:is() .backup-row{grid-template-columns:1fr;gap:8px;padding:12px}:is() .backup-row>div{display:flex;justify-content:space-between;align-items:center}:is() .backup-actions{justify-content:flex-start;flex-wrap:wrap}:is() .settings-cards-grid{grid-template-columns:1fr;gap:12px}:is() .setting-card{padding:20px}:is() .setting-icon{font-size:40px}:is() .settings-detail-modern{padding:16px}:is() .settings-header-modern{padding:24px 16px}:is() .settings-icon-large{font-size:48px}:is() .settings-header-modern h2{font-size:24px}:is() .setting-card-detail{flex-direction:column;text-align:center;padding:16px}:is() .setting-card-header{flex-direction:column;gap:12px}:is() .settings-actions{flex-direction:column}:is() .btn-primary-large,:is() .btn-secondary-large{width:100%;justify-content:center;padding:14px 24px;font-size:15px}:is() .language-selector-modern{grid-template-columns:1fr}:is() .language-card{padding:16px}:is() .data-stats-cards{grid-template-columns:1fr;gap:12px}:is() .features-grid{grid-template-columns:1fr}:is() .help-sections{grid-template-columns:1fr;gap:16px}:is() .help-footer{flex-direction:column;text-align:center}:is() .help-footer button{width:100%}:is() .task-detail-view{padding:20px}:is() .task-detail-header{flex-direction:column;align-items:flex-start;gap:12px}:is() .task-detail-header h2{font-size:20px}:is() .task-detail-info{grid-template-columns:1fr;gap:10px;padding:16px}:is() .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}:is() .stat-card{padding:16px}:is() .stat-value{font-size:24px}:is() .members-table-header,:is() .members-table-row{grid-template-columns:1fr;gap:8px;padding:12px}:is() .members-table-header{display:none}:is() .members-table-row>div{display:flex;justify-content:space-between;align-items:center}:is() .collab-tools-tabs-modern{flex-direction:column;gap:8px}:is() .collab-tab-btn{width:100%;flex-direction:row;justify-content:center;padding:12px 16px}:is() .tab-icon{font-size:20px}:is() .tab-text{font-size:13px}:is() .whiteboard-container{min-height:400px}:is() .whiteboard-toolbar{flex-wrap:wrap;gap:8px;padding:12px}:is() .tool-btn{font-size:12px;padding:8px 12px}:is() #whiteboard{margin:12px;max-height:400px}:is() #brushSize{width:100%}:is() .whiteboard-footer{flex-direction:column;gap:12px;padding:12px}:is() .poll-creator{padding:16px;max-height:calc(100vh - 200px)}:is() .poll-creator h3{font-size:20px}:is() .code-editor{min-height:400px}:is() .editor-toolbar{flex-wrap:wrap;padding:12px}:is() #codeEditor{padding:12px;font-size:13px}:is() .code-output{max-height:150px}:is() .mindmap-container{min-height:400px}:is() .mindmap-toolbar{flex-wrap:wrap;gap:8px;padding:12px}:is() .mindmap-toolbar button{font-size:12px;padding:8px 12px}:is() .mindmap-canvas{min-height:300px}:is() .mindmap-node{min-width:100px;padding:10px 12px;font-size:13px}:is() .mindmap-node.root{min-width:140px;padding:12px 16px;font-size:16px}:is() .mindmap-legend{font-size:11px;padding:10px}:is() .legend-color{width:16px;height:16px}:is() .login-container{padding:16px}:is() .login-card{padding:24px;max-width:100%}:is() .logo{font-size:28px}:is() .auth-form{gap:16px}:is() .call-panel{padding:20px}:is() .call-controls{flex-direction:column;align-items:stretch;gap:12px}:is() .call-controls input{width:100%}:is() .called-members{grid-template-columns:repeat(2,1fr);gap:12px}:is() .export-container{grid-template-columns:1fr;gap:14px}:is() .export-section{padding:14px}:is() .export-actions{flex-direction:column}:is() .export-actions button{width:100%}:is() .knowledge-filters{flex-direction:column;gap:10px}:is() .knowledge-filters input,:is() .knowledge-filters select{width:100%;min-width:auto}:is() .poll-options-results{gap:10px}:is() .poll-option-result{padding:12px}:is() .poll-option-header{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 480px){:is() .main-content{padding:12px}:is() .view-header h2{font-size:20px}:is() .modal-content{padding:16px}:is() .btn-primary,:is() .btn-secondary{padding:10px 12px;font-size:13px}:is() .audit-stats,:is() .stats-grid,:is() .called-members{grid-template-columns:1fr}:is() .setting-icon{font-size:36px}:is() .settings-icon-large{font-size:40px}:is() .task-detail-header h2{font-size:18px}:is() .stat-value{font-size:20px}}@media (max-width: 768px) and (orientation: landscape){:is() .sidebar{position:fixed;top:0;left:0;right:0;z-index:1000;max-height:60px;overflow:hidden}:is() .sidebar-header,:is() .user-info,:is() .sidebar-footer{display:none}:is() .nav-menu{margin:0;padding:8px}:is() .main-content{margin-top:60px}:is() .chat-container,:is() .editor-container{height:calc(100vh - 120px)}}@media (hover: none) and (pointer: coarse){:is() .nav-item,:is() .btn-primary,:is() .btn-secondary,:is() button{min-height:44px;min-width:44px}:is() .nav-item:hover,:is() .btn-primary:hover,:is() .group-card:hover,:is() .document-card:hover{transform:none}:is() *{-webkit-overflow-scrolling:touch}:is() *{touch-action:manipulation}}@media print{:is() .sidebar,:is() .nav-menu,:is() .btn-logout,:is() .view-header button,:is() .task-actions,:is() .modal,:is() .whiteboard-toolbar,:is() .editor-toolbar,:is() .mindmap-toolbar{display:none!important}:is() .main-content{padding:0;max-height:none;overflow:visible}:is() .dashboard{display:block}:is() *{background:#fff!important;color:#000!important}}@media (prefers-contrast: high){:is() :root{--border: #ffffff;--text-primary: #ffffff;--text-secondary: #cccccc}:is() .btn-primary,:is() .btn-secondary,:is() .nav-item{border-width:3px}}@media (prefers-reduced-motion: reduce){:is() *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}}
@@ -0,0 +1,16 @@
1
+ <!DOCTYPE html>
2
+ <html lang="zh-CN">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ <title>CollabDocChat - 协作文档聊天平台</title>
7
+ <link href="https://cdn.quilljs.com/1.3.6/quill.snow.css" rel="stylesheet">
8
+ <script src="https://cdn.quilljs.com/1.3.6/quill.js"></script>
9
+ <script type="module" crossorigin src="/assets/index-BXsUUS0E.js"></script>
10
+ <link rel="stylesheet" crossorigin href="/assets/index-D8ZqeoaM.css">
11
+ </head>
12
+ <body>
13
+ <div id="app"></div>
14
+ </body>
15
+ </html>
16
+
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "collabdocchat",
3
- "version": "2.4.8",
3
+ "version": "2.5.0",
4
4
  "description": "开源的实时协作文档聊天平台 - 集成任务管理、多人文档编辑、智能点名功能",
5
5
  "main": "./server/index.js",
6
6
  "type": "module",
@@ -12,6 +12,7 @@
12
12
  "server",
13
13
  "src",
14
14
  "scripts",
15
+ "dist",
15
16
  "README.md",
16
17
  "LICENSE",
17
18
  "package.json",
@@ -67,8 +68,8 @@
67
68
  "preview": "vite preview",
68
69
  "serve": "node server/index.js",
69
70
  "fix": "node scripts/fix-startup-issues.js",
70
- "prepack": "node scripts/pre-publish-check.js",
71
- "prepublishOnly": "node scripts/pre-publish-check.js"
71
+ "prepublishOnly": "npm run build && node scripts/pre-publish-check.js",
72
+ "prepack": "node scripts/pre-publish-check.js"
72
73
  },
73
74
  "dependencies": {
74
75
  "archiver": "^6.0.2",
@@ -24,6 +24,12 @@ function checkDevDependencies() {
24
24
  return existsSync(vitePath);
25
25
  }
26
26
 
27
+ // 检查是否有构建后的前端
28
+ function checkBuiltFrontend() {
29
+ const distPath = join(rootDir, 'dist', 'index.html');
30
+ return existsSync(distPath);
31
+ }
32
+
27
33
  // 安装 devDependencies
28
34
  function installDevDependencies() {
29
35
  return new Promise((resolve, reject) => {
@@ -189,8 +195,12 @@ async function main() {
189
195
 
190
196
  // 检查是否有开发依赖(全局安装时可能没有)
191
197
  const hasDevDeps = checkDevDependencies();
198
+ const hasBuiltFrontend = checkBuiltFrontend();
192
199
 
193
- if (!hasDevDeps) {
200
+ if (hasBuiltFrontend) {
201
+ console.log('✅ 检测到完整前端(已构建)');
202
+ console.log('💡 您将看到完整的图形界面\n');
203
+ } else if (!hasDevDeps) {
194
204
  console.log('⚠️ 检测到全局安装模式(无开发依赖)');
195
205
  console.log('💡 将只启动服务器,不启动客户端\n');
196
206
  console.log('📝 如需完整开发环境,请:');
@@ -213,8 +223,22 @@ async function main() {
213
223
 
214
224
  let client = null;
215
225
 
216
- // 只有在有开发依赖时才启动客户端
217
- if (hasDevDeps) {
226
+ // 如果有构建后的前端,直接打开浏览器
227
+ if (hasBuiltFrontend) {
228
+ console.log('\n✅ 服务器启动成功!');
229
+ console.log('\n💡 提示:');
230
+ console.log(` • 完整应用: http://localhost:${PORT}`);
231
+ console.log(' • 默认账号: admin / admin123');
232
+ console.log('\n🌐 正在打开浏览器...\n');
233
+
234
+ setTimeout(() => {
235
+ openBrowser(`http://localhost:${PORT}`);
236
+ }, 1000);
237
+
238
+ console.log('⚠️ 按 Ctrl+C 停止服务\n');
239
+ }
240
+ // 只有在有开发依赖且没有构建前端时才启动开发服务器
241
+ else if (hasDevDeps) {
218
242
  // 启动客户端
219
243
  client = startClient();
220
244
 
@@ -236,7 +260,7 @@ async function main() {
236
260
  }
237
261
  }, 3000);
238
262
  } else {
239
- // 全局安装模式,只有服务器
263
+ // 全局安装模式,只有服务器,自动打开浏览器
240
264
  console.log('\n✅ 服务器启动成功!');
241
265
  console.log('\n💡 提示:');
242
266
  console.log(` • API 服务器: http://localhost:${PORT}`);
@@ -244,7 +268,14 @@ async function main() {
244
268
  console.log('\n📝 注意:');
245
269
  console.log(' 全局安装模式仅提供 API 服务器');
246
270
  console.log(' 如需完整的前端界面,请在本地项目中运行');
247
- console.log('\n⚠️ 按 Ctrl+C 停止服务\n');
271
+ console.log('\n🌐 正在打开浏览器...\n');
272
+
273
+ // 延迟1秒后打开浏览器
274
+ setTimeout(() => {
275
+ openBrowser(`http://localhost:${PORT}`);
276
+ }, 1000);
277
+
278
+ console.log('⚠️ 按 Ctrl+C 停止服务\n');
248
279
  }
249
280
 
250
281
  // 处理退出信号
package/server/index.js CHANGED
@@ -4,6 +4,9 @@ import { WebSocketServer } from 'ws';
4
4
  import cors from 'cors';
5
5
  import dotenv from 'dotenv';
6
6
  import mongoose from 'mongoose';
7
+ import { fileURLToPath } from 'url';
8
+ import { dirname, join } from 'path';
9
+ import { existsSync } from 'fs';
7
10
  import authRoutes from './routes/auth.js';
8
11
  import taskRoutes from './routes/tasks.js';
9
12
  import documentRoutes from './routes/documents.js';
@@ -23,6 +26,9 @@ import { initDefaultAdmin } from './utils/initAdmin.js';
23
26
  import { errorHandler, notFoundHandler } from './middleware/errorHandler.js';
24
27
  import backupService from './utils/backup.js';
25
28
 
29
+ const __filename = fileURLToPath(import.meta.url);
30
+ const __dirname = dirname(__filename);
31
+
26
32
  dotenv.config();
27
33
 
28
34
  const app = express();
@@ -50,6 +56,21 @@ mongoose.connect(process.env.MONGODB_URI || 'mongodb://localhost:27017/collabdoc
50
56
  // 静态文件服务(用于文件下载)
51
57
  app.use('/uploads', express.static('uploads'));
52
58
 
59
+ // 静态页面服务
60
+ // 优先提供构建后的前端(如果存在)
61
+ const distPath = join(__dirname, '..', 'dist');
62
+ const publicPath = join(__dirname, 'public');
63
+
64
+ if (existsSync(distPath)) {
65
+ // 完整模式:提供构建后的前端
66
+ app.use(express.static(distPath));
67
+ console.log('✅ 前端模式:完整界面');
68
+ } else {
69
+ // API 模式:提供欢迎页面
70
+ app.use(express.static(publicPath));
71
+ console.log('✅ API 模式:欢迎页面');
72
+ }
73
+
53
74
  // API 路由
54
75
  app.use('/api/auth', authRoutes);
55
76
  app.use('/api/tasks', taskRoutes);
@@ -74,6 +95,26 @@ app.get('/health', (req, res) => {
74
95
  res.json({ status: 'ok', timestamp: new Date().toISOString() });
75
96
  });
76
97
 
98
+ // SPA 路由支持 - 所有非 API 路由都返回 index.html
99
+ app.get('*', (req, res, next) => {
100
+ // 如果是 API 路由,跳过
101
+ if (req.path.startsWith('/api/')) {
102
+ return next();
103
+ }
104
+
105
+ // 尝试提供构建后的 index.html
106
+ const distIndexPath = join(__dirname, '..', 'dist', 'index.html');
107
+ const publicIndexPath = join(__dirname, 'public', 'index.html');
108
+
109
+ if (existsSync(distIndexPath)) {
110
+ res.sendFile(distIndexPath);
111
+ } else if (existsSync(publicIndexPath)) {
112
+ res.sendFile(publicIndexPath);
113
+ } else {
114
+ next();
115
+ }
116
+ });
117
+
77
118
  // 404 处理
78
119
  app.use(notFoundHandler);
79
120
 
@@ -0,0 +1,246 @@
1
+ <!DOCTYPE html>
2
+ <html lang="zh-CN">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ <title>CollabDocChat - API 服务器</title>
7
+ <style>
8
+ * {
9
+ margin: 0;
10
+ padding: 0;
11
+ box-sizing: border-box;
12
+ }
13
+
14
+ body {
15
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
16
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
17
+ min-height: 100vh;
18
+ display: flex;
19
+ align-items: center;
20
+ justify-content: center;
21
+ padding: 20px;
22
+ }
23
+
24
+ .container {
25
+ background: white;
26
+ border-radius: 20px;
27
+ box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
28
+ max-width: 800px;
29
+ width: 100%;
30
+ padding: 40px;
31
+ }
32
+
33
+ .header {
34
+ text-align: center;
35
+ margin-bottom: 40px;
36
+ }
37
+
38
+ .logo {
39
+ font-size: 48px;
40
+ margin-bottom: 10px;
41
+ }
42
+
43
+ h1 {
44
+ color: #333;
45
+ font-size: 32px;
46
+ margin-bottom: 10px;
47
+ }
48
+
49
+ .subtitle {
50
+ color: #666;
51
+ font-size: 16px;
52
+ }
53
+
54
+ .status {
55
+ background: #f0fdf4;
56
+ border: 2px solid #86efac;
57
+ border-radius: 12px;
58
+ padding: 20px;
59
+ margin-bottom: 30px;
60
+ }
61
+
62
+ .status-title {
63
+ color: #16a34a;
64
+ font-weight: bold;
65
+ font-size: 18px;
66
+ margin-bottom: 10px;
67
+ }
68
+
69
+ .status-item {
70
+ color: #166534;
71
+ margin: 8px 0;
72
+ padding-left: 20px;
73
+ position: relative;
74
+ }
75
+
76
+ .status-item::before {
77
+ content: "✓";
78
+ position: absolute;
79
+ left: 0;
80
+ color: #16a34a;
81
+ font-weight: bold;
82
+ }
83
+
84
+ .info-box {
85
+ background: #f8fafc;
86
+ border-radius: 12px;
87
+ padding: 20px;
88
+ margin-bottom: 20px;
89
+ }
90
+
91
+ .info-title {
92
+ font-weight: bold;
93
+ color: #334155;
94
+ margin-bottom: 15px;
95
+ font-size: 18px;
96
+ }
97
+
98
+ .info-item {
99
+ display: flex;
100
+ justify-content: space-between;
101
+ padding: 10px 0;
102
+ border-bottom: 1px solid #e2e8f0;
103
+ }
104
+
105
+ .info-item:last-child {
106
+ border-bottom: none;
107
+ }
108
+
109
+ .info-label {
110
+ color: #64748b;
111
+ }
112
+
113
+ .info-value {
114
+ color: #0f172a;
115
+ font-weight: 500;
116
+ }
117
+
118
+ .api-link {
119
+ color: #667eea;
120
+ text-decoration: none;
121
+ font-weight: 500;
122
+ }
123
+
124
+ .api-link:hover {
125
+ text-decoration: underline;
126
+ }
127
+
128
+ .warning-box {
129
+ background: #fef3c7;
130
+ border: 2px solid #fbbf24;
131
+ border-radius: 12px;
132
+ padding: 20px;
133
+ margin-bottom: 20px;
134
+ }
135
+
136
+ .warning-title {
137
+ color: #92400e;
138
+ font-weight: bold;
139
+ margin-bottom: 10px;
140
+ }
141
+
142
+ .warning-text {
143
+ color: #78350f;
144
+ line-height: 1.6;
145
+ }
146
+
147
+ .action-box {
148
+ background: #eff6ff;
149
+ border-radius: 12px;
150
+ padding: 20px;
151
+ }
152
+
153
+ .action-title {
154
+ color: #1e40af;
155
+ font-weight: bold;
156
+ margin-bottom: 15px;
157
+ }
158
+
159
+ .action-steps {
160
+ color: #1e3a8a;
161
+ line-height: 1.8;
162
+ }
163
+
164
+ .action-steps li {
165
+ margin: 8px 0;
166
+ }
167
+
168
+ code {
169
+ background: #1e293b;
170
+ color: #e2e8f0;
171
+ padding: 2px 8px;
172
+ border-radius: 4px;
173
+ font-family: 'Courier New', monospace;
174
+ font-size: 14px;
175
+ }
176
+
177
+ .footer {
178
+ text-align: center;
179
+ margin-top: 30px;
180
+ color: #64748b;
181
+ font-size: 14px;
182
+ }
183
+ </style>
184
+ </head>
185
+ <body>
186
+ <div class="container">
187
+ <div class="header">
188
+ <div class="logo">🎉</div>
189
+ <h1>CollabDocChat</h1>
190
+ <p class="subtitle">开源的实时协作文档聊天平台</p>
191
+ </div>
192
+
193
+ <div class="status">
194
+ <div class="status-title">✅ API 服务器运行中</div>
195
+ <div class="status-item">MongoDB 已连接</div>
196
+ <div class="status-item">WebSocket 服务已启动</div>
197
+ <div class="status-item">所有 API 端点可用</div>
198
+ </div>
199
+
200
+ <div class="info-box">
201
+ <div class="info-title">📍 服务器信息</div>
202
+ <div class="info-item">
203
+ <span class="info-label">API 地址</span>
204
+ <span class="info-value"><a href="/api" class="api-link" target="_blank">http://localhost:3000/api</a></span>
205
+ </div>
206
+ <div class="info-item">
207
+ <span class="info-label">健康检查</span>
208
+ <span class="info-value"><a href="/health" class="api-link" target="_blank">http://localhost:3000/health</a></span>
209
+ </div>
210
+ <div class="info-item">
211
+ <span class="info-label">WebSocket</span>
212
+ <span class="info-value">ws://localhost:3000</span>
213
+ </div>
214
+ <div class="info-item">
215
+ <span class="info-label">默认账号</span>
216
+ <span class="info-value">admin / admin123</span>
217
+ </div>
218
+ </div>
219
+
220
+ <div class="warning-box">
221
+ <div class="warning-title">⚠️ 全局安装模式</div>
222
+ <p class="warning-text">
223
+ 当前运行在全局安装模式下,仅提供 API 服务器。
224
+ 如需完整的前端界面和开发环境,请按照下方步骤操作。
225
+ </p>
226
+ </div>
227
+
228
+ <div class="action-box">
229
+ <div class="action-title">🚀 获取完整功能</div>
230
+ <ol class="action-steps">
231
+ <li>克隆或下载项目到本地目录</li>
232
+ <li>运行 <code>npm install</code> 安装所有依赖</li>
233
+ <li>运行 <code>npm run dev</code> 启动完整应用</li>
234
+ <li>访问 <code>http://localhost:5173</code> 使用前端界面</li>
235
+ </ol>
236
+ </div>
237
+
238
+ <div class="footer">
239
+ <p>CollabDocChat v2.4.8 | MIT License</p>
240
+ <p><a href="https://github.com/shijinghao/collabdocchat" class="api-link" target="_blank">GitHub</a> |
241
+ <a href="https://www.npmjs.com/package/collabdocchat" class="api-link" target="_blank">NPM</a></p>
242
+ </div>
243
+ </div>
244
+ </body>
245
+ </html>
246
+