*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--text-primary: #1a1a1a;--text-secondary: #666666;--accent: #3b82f6;--accent-hover: #2563eb;--border: #e0e0e0;--shadow: rgba(0,0,0,.1);--danger: #ef4444}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:40%;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:0 16px;height:60px;min-height:60px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.menu-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px}.sidebar-title{font-size:18px;font-weight:600}.doc-list{flex:1;overflow-y:auto;padding:8px}.doc-item{padding:12px;border-radius:8px;cursor:pointer;margin-bottom:4px;transition:background .2s}.doc-item:hover{background:var(--bg-tertiary)}.doc-item.active{background:var(--accent);color:#fff}.doc-title{font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-meta{font-size:12px;color:var(--text-secondary)}.doc-item.active .doc-meta{color:#fffc}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:0 16px;height:60px;min-height:60px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.chat-header h2{font-size:16px}.user-info{display:flex;align-items:center;gap:8px;font-size:14px}.role-badge{font-size:11px;padding:2px 8px;border-radius:12px;background:var(--accent);color:#fff}.role-badge.admin{background:#8b5cf6}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.message{max-width:80%;padding:12px 16px;border-radius:16px;line-height:1.5}.message.user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.message.assistant{background:var(--bg-secondary);align-self:flex-start;border-bottom-left-radius:4px}.message .docs-hint{margin-top:8px;font-size:13px;opacity:.9}.chat-input-area{padding:16px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}.doc-preview-area{height:300px;border-top:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-secondary)}.doc-preview-header{padding:8px 16px;background:var(--bg-tertiary);display:flex;justify-content:space-between;align-items:center;font-weight:500;font-size:14px}.doc-preview-grid{flex:1;overflow-y:auto;padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.doc-thumbnail{background:#fff;border-radius:8px;border:1px solid var(--border);padding:12px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:8px}.doc-thumbnail:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000001a}.doc-thumbnail-icon{font-size:32px;text-align:center;padding:8px}.doc-thumbnail-info{flex:1;display:flex;flex-direction:column;gap:4px}.doc-thumbnail-title{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-thumbnail-preview{font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-height:1.4}.doc-thumbnail-similarity{font-size:11px;font-weight:600}.doc-preview-pagination{padding:8px 16px;background:var(--bg-tertiary);display:flex;justify-content:center;align-items:center;gap:16px;border-top:1px solid var(--border)}.pagination-btn{padding:6px 12px;background:#fff;border:1px solid var(--border);border-radius:4px;cursor:pointer;font-size:14px}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn:not(:disabled):hover{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination-info{font-size:13px;color:var(--text-secondary)}.doc-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.doc-viewer{background:var(--bg-primary);width:90%;height:90%;border-radius:12px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.doc-viewer-toolbar{padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:16px}.doc-viewer-title{font-weight:600;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-viewer-meta{font-size:13px;color:var(--text-secondary);margin-left:8px;font-weight:400}.doc-viewer-actions{display:flex;align-items:center;gap:8px}.toolbar-btn{padding:6px 12px;background:#fff;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:4px}.toolbar-btn:hover{background:var(--bg-tertiary)}.toolbar-btn.close{background:var(--danger);color:#fff;border-color:var(--danger)}.toolbar-btn.close:hover{background:#dc2626}.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 4px}.zoom-level{font-size:13px;color:var(--text-secondary);min-width:40px;text-align:center}.doc-viewer-content{flex:1;overflow:auto;padding:24px;background:#fafafa}.doc-viewer-loading,.doc-viewer-error{display:flex;align-items:center;justify-content:center;height:100%;font-size:16px;color:var(--text-secondary)}.doc-viewer-error{color:var(--danger)}.doc-viewer-text{background:#fff;padding:32px;min-height:100%;box-shadow:0 1px 3px #0000001a;line-height:1.6;color:var(--text-primary);font-size:14px}.chat-input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:24px;font-size:14px;outline:none}.chat-input:focus{border-color:var(--accent)}.send-btn{padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:24px;cursor:pointer;font-weight:500}.send-btn:hover{background:var(--accent-hover)}.action-bar{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px;background:var(--bg-secondary)}.action-btn{padding:8px 16px;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:6px}.action-btn:hover{background:var(--bg-tertiary)}.login-container{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-secondary)}.login-box{background:var(--bg-primary);padding:32px;border-radius:16px;box-shadow:0 4px 24px var(--shadow);width:100%;max-width:360px}.login-box h1{margin-bottom:24px;text-align:center}.login-box input{width:100%;padding:12px 16px;margin-bottom:12px;border:1px solid var(--border);border-radius:8px;font-size:14px}.login-box button{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer}.login-box button:hover{background:var(--accent-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-primary);padding:24px;border-radius:16px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.modal h3{margin-bottom:16px}.modal-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.btn-secondary{padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;cursor:pointer}.btn-danger{padding:8px 16px;background:var(--danger);color:#fff;border:none;border-radius:8px;cursor:pointer}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;bottom:0;width:80%;z-index:50;transform:translate(-100%);transition:transform .3s}.sidebar.open{transform:translate(0)}.main{width:100%}}
