:root{--color-primary: #ee7f00;--color-primary-dark: #cc6d00;--color-black: #213452;--color-dark: #2d4263;--color-dark-hover: #3a5279;--color-white: #ffffff;--color-gray-light: #f5f5f5;--color-gray: #888;--color-border: #e0e0e0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--color-gray-light);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}#root{height:100vh;width:100vw;overflow:hidden}.app{display:flex;height:100vh}.sidebar{width:260px;background:var(--color-black);color:var(--color-white);padding:16px;display:flex;flex-direction:column;overflow:hidden}.sidebar-panels{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.sidebar-pool-panel{overflow-y:auto;min-height:0;flex-shrink:0}.sidebar-conv-panel{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.sidebar-drag-divider{flex-shrink:0;height:8px;cursor:ns-resize;display:flex;align-items:center;justify-content:center;margin:2px -16px;padding:0 16px;background:transparent;transition:background .15s}.sidebar-drag-divider:hover,.sidebar-drag-divider:active{background:#ffffff0d}.sidebar-drag-handle{width:32px;height:3px;border-radius:2px;background:var(--color-gray);opacity:.4;transition:opacity .15s}.sidebar-drag-divider:hover .sidebar-drag-handle,.sidebar-drag-divider:active .sidebar-drag-handle{opacity:.8}.sidebar h1{font-size:18px;margin:0;color:var(--color-primary)}.new-chat-btn{width:100%;background:var(--color-primary);color:var(--color-white);border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;margin-bottom:8px;transition:background .2s}.new-chat-btn:hover{background:var(--color-primary-dark)}.new-chat-btn:disabled{opacity:.6;cursor:not-allowed}.conversation-list{flex:1;overflow-y:auto;min-height:0}.no-conversations{color:var(--color-gray);font-size:14px;text-align:center;margin-top:20px}.conversation-item{padding:12px;border-radius:8px;cursor:pointer;margin-bottom:4px;transition:background .2s;position:relative}.conversation-item:hover{background:var(--color-dark)}.conversation-item.active{background:var(--color-dark);border-left:3px solid var(--color-primary)}.conversation-title{display:block;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-count{display:block;font-size:12px;color:var(--color-gray);margin-top:4px}.conversation-item .delete-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-gray);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;opacity:0;transition:opacity .2s,color .2s,background .2s}.conversation-item:hover .delete-btn{opacity:1}.conversation-item .delete-btn:hover{color:#f44;background:#ff44441a}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--color-white)}.error-banner{background:#ffe2e2;border-bottom:1px solid #ffb8b8;color:#b00020;padding:10px 16px;font-size:14px}.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666;padding:24px;text-align:center}.welcome h2{font-size:24px;margin-bottom:8px;color:var(--color-black)}.messages{flex:1;overflow-y:auto;padding:20px}.message{margin-bottom:24px;padding:16px 20px;border-radius:12px;max-width:900px;margin-left:auto;margin-right:auto}.message.user{background:#fff3e0;border-left:3px solid var(--color-primary)}.message.assistant{background:var(--color-gray-light)}.message.streaming{border-left:3px solid var(--color-primary)}.message-header{font-size:12px;font-weight:600;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:8px}.message.user .message-header{color:var(--color-primary)}.message-model{font-size:11px;font-weight:400;color:var(--color-gray);text-transform:none;letter-spacing:normal;background:var(--color-border);padding:1px 6px;border-radius:4px}.message-content{line-height:1.6}.message.user .message-content{white-space:pre-wrap}.streaming-cursor{display:inline-block;width:8px;height:16px;background:var(--color-primary);margin-left:2px;vertical-align:text-bottom;animation:blink .8s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.input-form{display:flex;flex-direction:column;gap:8px;padding:16px 24px 24px;border-top:1px solid var(--color-border);background:#fafafa}.input-controls{display:flex;align-items:center;gap:16px}.input-row{display:flex;align-items:flex-end;gap:12px}.message-input{flex:1;padding:14px;background:#fff;border:1px solid #d0d0d0;border-radius:8px;color:#333;font-size:15px;font-family:inherit;line-height:1.5;outline:none;resize:vertical;min-height:60px;max-height:300px}.message-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #ee7f0026}.message-input:disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5}.send-button{padding:14px 28px;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;align-self:flex-end}.send-button:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.send-button:disabled{opacity:.5;cursor:not-allowed;background:#ccc;border-color:#ccc}.model-selector{display:flex;align-items:center}.model-select{padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-white);font-size:13px;color:#333;cursor:pointer;outline:none;min-width:180px}.model-select:focus{border-color:var(--color-primary)}.model-select option:disabled{color:#bbb}.temperature-slider{display:flex;align-items:center;gap:8px}.temperature-label{font-size:13px;color:#666;white-space:nowrap;min-width:65px}.temperature-range{width:100px;height:4px;-webkit-appearance:none;appearance:none;background:var(--color-border);border-radius:2px;outline:none}.temperature-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-white);box-shadow:0 1px 3px #0003}.temperature-range::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-white);box-shadow:0 1px 3px #0003}.message.assistant .message-content h1,.message.assistant .message-content h2,.message.assistant .message-content h3,.message.assistant .message-content h4{margin-top:16px;margin-bottom:8px;color:var(--color-black)}.message.assistant .message-content h1{font-size:1.4em}.message.assistant .message-content h2{font-size:1.2em}.message.assistant .message-content h3{font-size:1.1em}.message.assistant .message-content p{margin-bottom:10px}.message.assistant .message-content p:last-child{margin-bottom:0}.message.assistant .message-content ul,.message.assistant .message-content ol{margin:8px 0;padding-left:24px}.message.assistant .message-content li{margin-bottom:4px}.message.assistant .message-content code{background:#e8e8e8;padding:2px 6px;border-radius:4px;font-size:.9em;font-family:SF Mono,Fira Code,Cascadia Code,monospace}.message.assistant .message-content pre{background:#1e1e2e;color:#cdd6f4;padding:16px;border-radius:8px;overflow-x:auto;margin:12px 0;font-size:.9em;line-height:1.5}.message.assistant .message-content pre code{background:none;padding:0;border-radius:0;color:inherit;font-size:inherit}.message.assistant .message-content blockquote{border-left:3px solid var(--color-primary);padding:8px 16px;margin:12px 0;background:#fff8f0;color:#555}.message.assistant .message-content table{border-collapse:collapse;width:100%;margin:12px 0}.message.assistant .message-content th,.message.assistant .message-content td{border:1px solid var(--color-border);padding:8px 12px;text-align:left}.message.assistant .message-content th{background:var(--color-gray-light);font-weight:600}.message.assistant .message-content hr{border:none;border-top:1px solid var(--color-border);margin:16px 0}.message.assistant .message-content a{color:var(--color-primary);text-decoration:none}.message.assistant .message-content a:hover{text-decoration:underline}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--color-gray-light)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--color-black)}.login-card{background:var(--color-white);border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 8px 32px #0000004d}.login-logo{text-align:center;color:var(--color-primary);font-size:28px;margin-bottom:24px}.login-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--color-border)}.login-tab{flex:1;padding:10px;background:none;border:none;font-size:14px;font-weight:600;color:var(--color-gray);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.login-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.login-error{background:#ffe2e2;color:#b00020;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:16px}.login-form{display:flex;flex-direction:column;gap:12px}.login-form input{padding:12px 14px;border:1px solid var(--color-border);border-radius:8px;font-size:15px;font-family:inherit;outline:none;transition:border-color .2s}.login-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #ee7f0026}.login-submit{padding:12px;background:var(--color-primary);color:var(--color-white);border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:4px}.login-submit:hover:not(:disabled){background:var(--color-primary-dark)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.sidebar-header{margin-bottom:4px}.user-info{display:flex;align-items:center;gap:8px;margin-top:8px}.user-name{font-size:13px;color:#ffffffb3}.admin-badge{font-size:11px;background:var(--color-primary);color:var(--color-white);padding:1px 6px;border-radius:4px;font-weight:600}.sidebar-footer{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.usage-widget{padding:12px;background:#ffffff0d;border-radius:8px;margin-bottom:10px}.usage-title{font-size:12px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.usage-row{display:flex;justify-content:space-between;font-size:13px;color:#ffffffb3;padding:2px 0}.usage-row span:last-child{font-weight:600;color:var(--color-white)}.logout-btn{width:100%;padding:10px;background:#ffffff14;color:#ffffffb3;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:13px;cursor:pointer;transition:background .2s,color .2s}.logout-btn:hover{background:#ffffff26;color:var(--color-white)}.assistant-selector{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.assistant-selector-label{font-size:11px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.assistant-grid{display:flex;flex-wrap:wrap;gap:6px}.assistant-card{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffd9;cursor:pointer;font-size:12px;transition:background .2s,border-color .2s}.assistant-card:hover{background:#ffffff26;border-color:var(--color-primary)}.assistant-icon{font-size:16px}.assistant-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.assistant-global-badge{font-size:9px;background:var(--color-primary);color:var(--color-white);padding:1px 4px;border-radius:3px;font-weight:600;margin-left:4px}.sidebar-actions{display:flex;gap:6px;margin-bottom:10px}.sidebar-action-btn{flex:1;padding:8px;background:#ffffff14;color:#ffffffb3;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:12px;cursor:pointer;transition:background .2s,color .2s}.sidebar-action-btn:hover{background:#ffffff26;color:var(--color-white)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-white);border-radius:12px;padding:24px;width:95%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-header h2{font-size:18px;margin:0;color:var(--color-black)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-gray);padding:0 4px;line-height:1}.modal-close:hover{color:var(--color-black)}.modal-error{background:#ffe2e2;color:#b00020;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:12px}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:13px;font-weight:600;color:#555;margin-bottom:4px}.form-hint{font-weight:400;color:var(--color-gray);font-size:12px}.form-input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #ee7f0026}.form-input-icon{width:60px;text-align:center;font-size:20px}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.form-checkbox{display:flex!important;align-items:center;gap:8px;cursor:pointer}.form-checkbox input{width:16px;height:16px;accent-color:var(--color-primary)}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.btn{padding:10px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:background .2s,opacity .2s}.btn-primary{background:var(--color-primary);color:var(--color-white)}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-gray-light);color:#555;border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border)}.btn-danger{background:#f44336;color:var(--color-white)}.btn-danger:hover{background:#d32f2f}.btn-small{padding:6px 10px;font-size:12px}.btn-full{width:100%;margin-bottom:16px}.manager-list{display:flex;flex-direction:column;gap:8px}.manager-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--color-gray-light);border-radius:8px;gap:12px}.manager-item-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.manager-item-icon{font-size:24px;flex-shrink:0}.manager-item-name{font-size:14px;font-weight:600;color:var(--color-black);display:flex;align-items:center;gap:6px}.manager-item-desc{font-size:12px;color:var(--color-gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.manager-item-actions{display:flex;gap:6px;flex-shrink:0}.manager-empty{text-align:center;color:var(--color-gray);font-size:14px;padding:24px}.template-category-badge{font-size:10px;background:var(--color-dark);color:var(--color-white);padding:1px 6px;border-radius:3px;font-weight:400}.template-picker{position:relative}.template-picker-btn{padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-white);font-size:13px;color:#555;cursor:pointer;transition:border-color .2s}.template-picker-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.template-picker-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:4px;background:var(--color-white);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 16px #0000001f;min-width:220px;max-height:250px;overflow-y:auto;z-index:100}.template-picker-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;border:none;background:none;cursor:pointer;text-align:left;font-size:13px;color:#333;transition:background .15s}.template-picker-item:hover{background:var(--color-gray-light)}.template-picker-name{font-weight:500}.template-picker-cat{font-size:11px;color:var(--color-gray)}.admin-dashboard{flex:1;display:flex;flex-direction:column;background:var(--color-white);overflow:hidden}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--color-border)}.admin-header h2{font-size:20px;color:var(--color-black);margin:0}.admin-tabs{display:flex;border-bottom:2px solid var(--color-border);padding:0 24px;gap:0}.admin-tab{padding:12px 20px;background:none;border:none;font-size:14px;font-weight:600;color:var(--color-gray);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.admin-tab:hover{color:var(--color-black)}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-content{flex:1;overflow-y:auto;padding:24px}.admin-loading{text-align:center;padding:40px;color:var(--color-gray);font-size:14px}.admin-error{background:#ffe2e2;color:#b00020;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:16px}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:left;padding:10px 12px;background:var(--color-gray-light);font-weight:600;color:var(--color-black);border-bottom:2px solid var(--color-border);font-size:13px;white-space:nowrap}.admin-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);color:#333}.admin-table tr:hover td{background:#fafafa}.admin-table code{font-size:12px;background:var(--color-gray-light);padding:2px 6px;border-radius:4px}.admin-table tr.user-inactive td{opacity:.5}.admin-empty-cell{text-align:center;color:var(--color-gray);padding:24px!important}.admin-metadata-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--color-gray)}.admin-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px}.admin-card{background:var(--color-gray-light);border-radius:10px;padding:20px;text-align:center}.admin-card-label{font-size:12px;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.admin-card-value{font-size:28px;font-weight:700;color:var(--color-black)}.admin-section-title{font-size:16px;color:var(--color-black);margin-bottom:12px}.token-filters{margin-bottom:24px}.token-filter-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.token-filter-group{display:flex;flex-direction:column;gap:4px}.token-filter-group label{font-size:12px;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.5px}.token-filter-group input[type=date]{padding:8px 12px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-white);color:var(--color-black);font-size:14px}.provider-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;background:var(--color-primary);color:#fff}.admin-card-sub{font-size:12px;color:var(--color-gray);margin-top:4px}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:#ccc;border-radius:22px;transition:background .2s}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:var(--color-white);border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.admin-model-form{background:var(--color-gray-light);padding:16px;border-radius:8px;margin-bottom:16px}.admin-model-form .form-row{margin-bottom:8px}.admin-filters{display:flex;gap:12px;margin-bottom:16px}.sidebar-admin-btn{width:100%;padding:10px 16px;background:#2d4263;color:#fff;border:1px solid #3a5279;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;margin-bottom:8px;transition:background .2s,border-color .2s}.sidebar-admin-btn:hover{background:#3a5279}.sidebar-admin-btn.active{background:var(--color-primary);border-color:var(--color-primary)}.provider-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.provider-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;overflow:hidden}.provider-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.provider-card-body{padding:16px;display:flex;flex-direction:column;gap:12px}.provider-key-row{display:flex;gap:8px}.provider-key-row .form-input{flex:1}.provider-actions{display:flex;gap:8px;flex-wrap:wrap}.badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge-success{background:#d4edda;color:#155724}.badge-info{background:#d1ecf1;color:#0c5460}.badge-warning{background:#fff3cd;color:#856404}.provider-test-result{padding:8px 12px;border-radius:6px;font-size:13px}.provider-test-result.success{background:#d4edda;color:#155724}.provider-test-result.error{background:#f8d7da;color:#721c24}.provider-hint{font-size:12px;color:var(--color-text-muted)}.file-upload{display:flex;align-items:flex-start;flex-direction:column;gap:4px}.upload-btn{width:42px;height:42px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-white);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s;flex-shrink:0}.upload-btn:hover:not(:disabled){border-color:var(--color-primary);background:#fff8f0}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.file-upload-progress{width:120px;display:flex;flex-direction:column;gap:2px}.file-upload-bar{height:4px;background:var(--color-primary);border-radius:2px;transition:width .2s ease;min-width:4px}.file-upload-bar--processing{width:100%!important;background:linear-gradient(90deg,var(--color-primary) 30%,transparent 50%,var(--color-primary) 70%);background-size:200% 100%;animation:upload-processing 1.4s linear infinite}.file-upload-label{font-size:10px;color:var(--color-gray);white-space:nowrap}.pool-doc-uploading{border:1px dashed var(--color-border)!important;opacity:.85}.pool-upload-progress{height:6px;background:var(--color-border);border-radius:3px;margin:4px 0 2px;overflow:hidden}.pool-upload-bar{height:100%;background:var(--color-primary);border-radius:3px;transition:width .2s ease;min-width:6px}.pool-upload-bar--processing{width:100%!important;background:linear-gradient(90deg,var(--color-primary) 30%,#ffb46a 50%,var(--color-primary) 70%);background-size:200% 100%;animation:upload-processing 1.4s linear infinite}.pool-upload-status{color:var(--color-primary)!important;font-style:italic}@keyframes upload-processing{0%{background-position:100% 0}to{background-position:-100% 0}}.document-list{display:flex;flex-wrap:wrap;gap:6px}.document-item{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:12px;background:#e8f4fd;color:#0c5460;border:1px solid #bee5eb}.document-item.doc-status-processing{background:#fff3cd;color:#856404;border-color:#ffeaa7}.document-item.doc-status-error{background:#f8d7da;color:#721c24;border-color:#f5c6cb}.doc-icon{font-size:13px}.doc-name{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-chunks{font-size:10px;background:#0000001a;padding:0 4px;border-radius:3px}.doc-processing{font-size:10px;animation:blink .8s infinite}.doc-error-icon{color:#dc3545;font-weight:700}.doc-delete{background:none;border:none;font-size:14px;cursor:pointer;color:inherit;opacity:.5;padding:0 2px;line-height:1}.doc-delete:hover{opacity:1;color:#dc3545}.rag-sources{display:flex;flex-direction:column;gap:6px;margin-top:10px;padding-top:8px;border-top:1px solid var(--color-border)}.rag-source-list{display:flex;flex-direction:column;gap:4px}.rag-source-item{display:flex;flex-direction:column}.rag-sources-label{font-size:11px;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.3px}.source-tag{display:inline-flex;align-items:center;padding:2px 8px;background:#e8f4fd;color:#0c5460;border-radius:4px;font-size:11px;border:1px solid #bee5eb;cursor:default;text-align:left;align-self:flex-start}.source-tag--citable{cursor:pointer;-webkit-user-select:none;user-select:none}.source-tag--citable:hover,.source-tag--open{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.source-tag-chevron{margin-left:4px;font-size:9px;opacity:.7}.source-excerpt{margin:4px 0 0 8px;padding:8px 12px;border-left:3px solid var(--color-primary);background:#00000008;font-size:12px;line-height:1.5;color:var(--color-text-secondary);font-style:italic;border-radius:0 4px 4px 0}.rag-image-sources{margin-top:10px;padding-top:8px;border-top:1px solid var(--color-border)}.rag-image-grid{margin-top:8px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.rag-image-item{margin:0;padding:8px;border:1px solid var(--color-border);border-radius:8px;background:#fafafa}.rag-image-item img{width:100%;height:auto;display:block;border-radius:4px;margin-bottom:6px}.rag-image-item figcaption{font-size:11px;color:var(--color-gray);line-height:1.4}.pool-list-section{margin-bottom:4px;padding-bottom:4px}.pool-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.pool-list-label{font-size:11px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.pool-list-actions{display:flex;gap:4px}.pool-action-btn{padding:2px 8px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#ffffffb3;font-size:11px;cursor:pointer;transition:background .2s}.pool-action-btn:hover{background:#ffffff26;color:var(--color-white)}.pool-items{display:flex;flex-direction:column;gap:4px}.pool-empty{font-size:12px;color:var(--color-gray);text-align:center;padding:8px}.pool-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .2s}.pool-item:hover{background:var(--color-dark)}.pool-item.active{background:var(--color-dark);border-left:3px solid var(--color-primary)}.pool-item-icon{font-size:18px;flex-shrink:0}.pool-item-info{display:flex;flex-direction:column;min-width:0}.pool-item-name{font-size:13px;color:var(--color-white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pool-item-role{font-size:11px;color:var(--color-gray)}.pool-join-form{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.pool-join-input{flex:1;padding:6px 8px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:var(--color-white);font-size:12px;min-width:120px}.pool-join-input::placeholder{color:#fff6}.pool-join-btn{padding:6px 10px;background:var(--color-primary);border:none;border-radius:4px;color:var(--color-white);font-size:12px;cursor:pointer}.pool-join-error{width:100%;font-size:11px;color:#ff6b6b;padding:2px 0}.pool-detail{flex:1;display:flex;flex-direction:column;background:var(--color-white);overflow:hidden}.pool-detail-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--color-border)}.pool-detail-title{display:flex;align-items:center;gap:12px}.pool-detail-icon{font-size:28px}.pool-detail-title h2{font-size:18px;margin:0;color:var(--color-black)}.pool-detail-desc{font-size:13px;color:var(--color-gray);margin:2px 0 0}.pool-detail-actions{display:flex;gap:8px}.pool-tabs{display:flex;border-bottom:2px solid var(--color-border);padding:0 24px}.pool-tab{padding:12px 20px;background:none;border:none;font-size:14px;font-weight:600;color:var(--color-gray);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.pool-tab:hover{color:var(--color-black)}.pool-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pool-content{flex:1;overflow-y:auto;padding:24px}.pool-documents-upload{display:flex;align-items:center;gap:12px;margin-bottom:20px}.pool-upload-hint{font-size:12px;color:var(--color-gray)}.pool-empty-state{text-align:center;color:var(--color-gray);font-size:14px;padding:40px 20px}.pool-document-list{display:flex;flex-direction:column;gap:8px}.pool-doc-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-gray-light);border-radius:8px;border:1px solid var(--color-border)}.pool-doc-item.doc-status-processing{border-color:#ffeaa7;background:#fffbf0}.pool-doc-item.doc-status-error{border-color:#f5c6cb;background:#fff5f5}.pool-doc-icon{font-size:20px;flex-shrink:0}.pool-doc-info{flex:1;min-width:0}.pool-doc-name{display:block;font-size:14px;font-weight:500;color:var(--color-black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pool-doc-summary{display:block;font-size:12px;color:var(--text-secondary);margin-top:3px;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.pool-doc-meta{display:block;font-size:12px;color:var(--color-gray);margin-top:2px}.pool-preview-summary{font-size:14px;line-height:1.6;color:var(--text-secondary);border-left:3px solid var(--accent);margin:0 0 16px;padding:8px 12px;background:var(--bg-secondary);border-radius:0 6px 6px 0;font-style:italic}.pool-doc-delete{background:none;border:none;font-size:18px;cursor:pointer;color:var(--color-gray);padding:4px 8px;border-radius:4px;transition:color .2s,background .2s}.pool-doc-delete:hover{color:#f44;background:#ff44441a}.pool-doc-actions{display:flex;align-items:center;gap:6px}.pool-doc-preview{padding:6px 10px}.pool-preview-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.pool-preview-modal{width:min(900px,100%);max-height:85vh;overflow:hidden;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column}.pool-text-modal{width:min(760px,100%);max-height:85vh;overflow:hidden;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column}.pool-preview-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--color-border)}.pool-preview-header h3{margin:0;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pool-preview-close{border:none;background:none;font-size:24px;color:var(--color-gray);cursor:pointer;line-height:1}.pool-preview-close:hover{color:var(--color-black)}.pool-preview-body{padding:16px;overflow:auto}.pool-preview-image{max-width:100%;border:1px solid var(--color-border);border-radius:8px;margin-bottom:12px}.pool-preview-text{white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.45;color:#223;background:#fafafa;border:1px solid #ececec;border-radius:8px;padding:12px}.pool-preview-hint,.pool-preview-empty{margin-top:10px;font-size:12px;color:var(--color-gray)}.pool-preview-error{color:#b00020}.pool-text-modal-body{display:flex;flex-direction:column;gap:10px}.pool-text-label{font-size:12px;font-weight:600;color:var(--color-gray)}.pool-text-input,.pool-text-editor{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;font-size:14px;color:var(--color-black);background:#fff}.pool-text-input:focus,.pool-text-editor:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #ee7f0026}.pool-text-editor{resize:vertical;min-height:220px;line-height:1.45;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.pool-text-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.pool-chat-create{display:flex;gap:8px;margin-bottom:20px}.pool-chat-section{margin-bottom:20px}.pool-chat-section-title{font-size:12px;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.pool-chat-item{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--color-gray-light);border-radius:8px;cursor:pointer;margin-bottom:6px;transition:background .2s;border:1px solid var(--color-border)}.pool-chat-item:hover{background:#eee}.pool-chat-icon{font-size:16px;flex-shrink:0}.pool-chat-info{flex:1;min-width:0}.pool-chat-name{display:block;font-size:14px;font-weight:500;color:var(--color-black)}.pool-chat-meta{display:block;font-size:12px;color:var(--color-gray)}.pool-chat-delete{background:none;border:none;font-size:18px;cursor:pointer;color:var(--color-gray);opacity:0;transition:opacity .2s,color .2s;padding:4px 8px}.pool-chat-item:hover .pool-chat-delete{opacity:1}.pool-chat-delete:hover{color:#f44}.pool-chat-area{display:flex;flex-direction:column;height:100%}.pool-chat-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--color-border);background:#fafafa}.pool-chat-title{flex:1;font-size:15px;font-weight:600;color:var(--color-black)}.pool-messages{flex:1;overflow-y:auto;padding:20px}.pool-chat-input{display:flex;align-items:flex-end;gap:12px;padding:16px 24px 24px;border-top:1px solid var(--color-border);background:#fafafa}.pool-members-error{background:#ffe2e2;color:#b00020;padding:10px 14px;border-radius:6px;font-size:14px;margin-bottom:12px}.pool-members-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px;align-items:flex-end}.pool-add-member{display:flex;gap:8px;align-items:center}.pool-role-select{width:100px}.pool-members-list{display:flex;flex-direction:column;gap:8px}.pool-member-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-gray-light);border-radius:8px}.pool-member-info{display:flex;align-items:center;gap:10px}.pool-member-name{font-size:14px;font-weight:500;color:var(--color-black)}.pool-member-you{font-size:12px;color:var(--color-gray);font-weight:400}.pool-member-role{font-size:11px;padding:2px 8px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.pool-member-role.role-owner{background:var(--color-primary);color:var(--color-white)}.pool-member-role.role-admin{background:#2196f3;color:var(--color-white)}.pool-member-role.role-editor{background:#4caf50;color:var(--color-white)}.pool-member-role.role-viewer{background:var(--color-border);color:#555}.pool-member-actions{display:flex;gap:8px;align-items:center}.pool-role-select-small{padding:4px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:12px}.pool-share-create{margin-bottom:20px}.pool-share-result{background:#e8f5e9;border:1px solid #c8e6c9;border-radius:8px;padding:16px;margin-bottom:20px}.pool-share-result label{display:block;font-size:12px;font-weight:600;color:#2e7d32;margin-bottom:6px}.pool-share-token-row{display:flex;gap:8px;align-items:center}.pool-share-token{flex:1;padding:8px 12px;background:var(--color-white);border:1px solid var(--color-border);border-radius:4px;font-size:13px;word-break:break-all}.pool-share-hint{font-size:12px;color:#555;margin-top:8px}.pool-share-existing{border-top:1px solid var(--color-border);padding-top:16px}.pool-share-existing h4{font-size:14px;color:var(--color-black);margin-bottom:10px}.pool-invite-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-gray-light);border-radius:6px;margin-bottom:6px}.pool-invite-info{display:flex;align-items:center;gap:8px}.pool-invite-token{font-size:12px;background:var(--color-white);padding:2px 6px;border-radius:3px;border:1px solid var(--color-border)}.pool-invite-uses{font-size:12px;color:var(--color-gray)}.icon-picker{display:flex;gap:6px;flex-wrap:wrap}.icon-option{width:36px;height:36px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-white);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s}.icon-option.selected{border-color:var(--color-primary);background:#fff8f0}.icon-option:hover{border-color:var(--color-primary)}.color-picker{display:flex;gap:6px;flex-wrap:wrap}.color-option{width:28px;height:28px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:border-color .2s,transform .2s}.color-option.selected{border-color:var(--color-black);transform:scale(1.15)}.color-option:hover{transform:scale(1.1)}@media(max-width:900px){.app{flex-direction:column}.sidebar{width:100%;max-height:40vh}.input-controls{flex-wrap:wrap;gap:8px}}
