:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--secondary-color: #6b7280;--success-color: #059669;--warning-color: #d97706;--error-color: #dc2626;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-radius: 8px;--header-height: 64px;--sidebar-width: 260px}.app-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:24px;margin-top:var(--header-height)}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.app-footer{display:flex;justify-content:center;align-items:center;padding:16px 24px;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.app-footer .footer-link{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--text-muted);font-size:.875rem;transition:color .2s}.app-footer .footer-link:hover{color:var(--text-primary)}.app-footer .footer-logo{height:20px;width:auto}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;padding:0 24px;z-index:100}.header-left{display:flex;align-items:center}.logo-link{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary)}.logo{height:36px;width:auto}.logo-text{font-size:1.25rem;font-weight:600}.header-center{flex:1;display:flex;justify-content:center;padding:0 24px}.header-right{display:flex;align-items:center;gap:16px}.nav-links{display:flex;gap:8px}.nav-link{padding:8px 16px;border-radius:var(--border-radius);text-decoration:none;color:var(--text-secondary);transition:all .2s}.nav-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.lang-toggle{padding:6px 12px;border-radius:var(--border-radius);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.lang-toggle:hover{border-color:var(--primary-color)}.user-menu{position:relative}.user-button{display:flex;align-items:center;gap:8px;padding:4px 8px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;border-radius:var(--border-radius)}.user-button:hover{background:var(--bg-tertiary)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:600}.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:8px;min-width:150px}.user-dropdown button{width:100%;padding:8px 12px;background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;border-radius:4px}.user-dropdown button:hover{background:var(--bg-tertiary)}.search-bar-container{position:relative;width:100%;max-width:500px}.search-form{display:flex;align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.search-input{flex:1;padding:10px 16px;background:transparent;border:none;color:var(--text-primary);font-size:.9375rem}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none}.search-button,.image-search-button{padding:10px 12px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:color .2s}.search-button:hover,.image-search-button:hover{color:var(--text-primary)}.image-upload-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:8px}.upload-image-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;border-radius:4px;white-space:nowrap}.upload-image-btn:hover{background:var(--bg-tertiary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.login-container{width:100%;max-width:400px;padding:32px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px}.login-header{text-align:center;margin-bottom:32px}.login-logo{height:60px;margin-bottom:16px}.login-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{padding:12px;background:#ef44441a;border:1px solid var(--error-color);border-radius:var(--border-radius);color:var(--error-color);font-size:.875rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.875rem;color:var(--text-secondary)}.form-group input,.form-group select{padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color)}.login-button{padding:14px;background:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.login-button:hover:not(:disabled){background:var(--primary-hover)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center}.lang-switch{padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);cursor:pointer}.lang-switch:hover{border-color:var(--primary-color);color:var(--text-primary)}.page-title{font-size:1.5rem;font-weight:600;margin-bottom:24px;color:var(--text-primary)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.header-actions{display:flex;gap:12px}.primary-button{padding:10px 20px;background:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .2s}.primary-button:hover:not(:disabled){background:var(--primary-hover)}.primary-button:disabled{opacity:.6;cursor:not-allowed}.secondary-button{padding:10px 20px;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);font-size:.9375rem;cursor:pointer;transition:all .2s}.secondary-button:hover{border-color:var(--primary-color)}.delete-button{padding:6px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.delete-button:hover{color:var(--error-color);background:#ef44441a}.delete-button:disabled,.reimport-button:disabled{opacity:.4;cursor:not-allowed}.catalog-actions{display:flex;gap:4px;align-items:center}.reimport-button{padding:6px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.reimport-button:hover{color:var(--primary-color);background:#3b82f61a}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all .2s ease}.stat-card.clickable{cursor:pointer;text-decoration:none}.stat-card.clickable:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.stat-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:12px}.stat-icon.catalogs-icon{background:#3b82f61a;color:#3b82f6}.stat-icon.items-icon{background:#10b9811a;color:#10b981}.stat-icon.suppliers-icon{background:#f59e0b1a;color:#f59e0b}.stat-icon.processing-icon{background:#8b5cf61a;color:#8b5cf6}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.dashboard-section h2{font-size:1.125rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.quick-action-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);text-decoration:none;color:var(--text-primary);transition:all .2s}.quick-action-card:hover{border-color:var(--primary-color);transform:translateY(-2px)}.search-page-content{display:flex;gap:24px}.sidebar,.search-filters{width:var(--sidebar-width);flex-shrink:0;position:sticky;top:calc(var(--header-height) + 24px);max-height:calc(100vh - var(--header-height) - 48px);overflow-y:auto;align-self:flex-start}.browse-content,.search-main{flex:1;min-width:0}.sidebar-section{margin-bottom:24px}.sidebar-title,.filter-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.sidebar-list,.filter-list{list-style:none;padding:0;margin:0}.sidebar-item,.filter-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;text-align:left;transition:all .2s}.sidebar-item:hover,.filter-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-item.active,.filter-item.active{background:var(--primary-color);color:#fff}.category-count,.supplier-count,.filter-count{font-size:.75rem;padding:2px 6px;background:var(--bg-tertiary);border-radius:10px}.clear-filters-btn{width:100%;padding:10px;margin-top:16px;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);cursor:pointer}.clear-filters-btn:hover{border-color:var(--primary-color);color:var(--text-primary)}.item-grid,.search-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.item-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:0 1px 3px #00000014;cursor:pointer;transition:all .2s;overflow:hidden;display:flex;flex-direction:column}.item-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.item-card-image{width:100%;height:150px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden}.item-card-image img{max-width:100%;max-height:100%;object-fit:contain}.item-card-content{padding:16px;flex:1;display:flex;flex-direction:column}.item-card-header{margin-bottom:8px}.item-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.item-catalog-number{font-size:.75rem;color:var(--text-muted);font-family:monospace}.item-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.item-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.item-category,.item-manufacturer{font-size:.75rem;padding:4px 8px;background:var(--bg-tertiary);border-radius:4px;color:var(--text-secondary)}.item-card-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:.75rem;color:var(--text-muted);margin-top:auto}.item-images-count{background:var(--primary-color);color:#fff;padding:2px 6px;border-radius:4px;font-size:.7rem}.item-product-line-badge{background:var(--bg-tertiary);color:var(--primary-color);border:1px solid var(--primary-color);padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.item-product-line-badge.clickable{cursor:pointer;transition:background .15s,color .15s}.item-product-line-badge.clickable:hover{background:var(--primary-color);color:#fff}.catalog-upload{margin-bottom:24px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius)}.upload-form{display:flex;flex-direction:column;gap:20px}.dropzone{padding:48px;border:2px dashed var(--border-color);border-radius:var(--border-radius);text-align:center;cursor:pointer;transition:all .2s}.dropzone:hover,.dropzone.active{border-color:var(--primary-color);background:#3b82f60d}.dropzone.has-file{border-style:solid;border-color:var(--success-color)}.dropzone-content{color:var(--text-secondary)}.dropzone-content svg{margin-bottom:16px}.file-info{color:var(--text-primary)}.file-info svg{color:var(--success-color);margin-bottom:12px}.file-name{font-weight:500;margin-bottom:4px}.file-size{font-size:.875rem;color:var(--text-secondary)}.upload-actions{display:flex;justify-content:flex-end;gap:12px}.upload-error{padding:12px;background:#ef44441a;border:1px solid var(--error-color);border-radius:var(--border-radius);color:var(--error-color)}.dropzone.uploading{pointer-events:none;border-color:var(--primary-color)}.upload-progress{width:100%;padding:20px}.upload-progress-bar{width:100%;height:12px;background:var(--bg-tertiary);border-radius:6px;overflow:hidden;margin-bottom:12px}.upload-progress-fill{height:100%;background:var(--primary-color);transition:width .3s}.upload-progress-text{text-align:center;color:var(--text-secondary);margin:0}.bulk-upload-info{text-align:center;margin-bottom:12px}.bulk-upload-info h3{margin:0 0 8px;font-size:1.125rem;color:var(--text-primary)}.bulk-upload-info p{margin:0;color:var(--text-secondary);font-size:.9375rem}.upload-success{padding:16px;background:#0596691a;border:1px solid var(--success-color);border-radius:var(--border-radius);color:var(--success-color);text-align:center}.upload-success p{margin:0}.upload-success .pdf-list{margin-top:8px;font-size:.875rem}.preview-summary{display:flex;gap:24px;justify-content:center;padding:12px;background:var(--bg-secondary);border-radius:var(--border-radius);margin-bottom:16px}.summary-item{font-size:.9375rem}.summary-item.skipped{color:var(--warning-color)}.preview-list{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--border-radius);margin-bottom:16px}.preview-table{width:100%;border-collapse:collapse}.preview-table th{position:sticky;top:0;background:var(--bg-secondary);padding:12px;text-align:left;font-weight:500;font-size:.875rem;border-bottom:1px solid var(--border-color)}.preview-table td{padding:10px 12px;border-bottom:1px solid var(--border-color);vertical-align:middle}.preview-row:last-child td{border-bottom:none}.filename-cell{min-width:200px}.filename-cell .filename{display:block;font-weight:500;margin-bottom:2px}.filename-cell .filesize{font-size:.75rem;color:var(--text-secondary)}.supplier-cell{min-width:250px}.supplier-input{width:100%;padding:6px 10px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.875rem;margin-bottom:6px}.supplier-input:focus{outline:none;border-color:var(--primary-color)}.supplier-select{width:100%;padding:4px 8px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:.8125rem;background:var(--bg-primary);color:var(--text-secondary)}.status-cell{width:100px;text-align:center}.badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.badge-new{background:#3b82f626;color:var(--primary-color)}.badge-existing{background:#05966926;color:var(--success-color)}.duplicates-section{margin-bottom:16px;padding:12px;background:#f59e0b1a;border:1px solid var(--warning-color);border-radius:var(--border-radius)}.duplicates-section h4{margin:0 0 8px;font-size:.875rem;color:var(--warning-color)}.duplicates-list{margin:0;padding:0;list-style:none}.duplicates-list li{display:flex;gap:8px;padding:4px 0;font-size:.875rem}.dup-filename{font-weight:500}.dup-note{color:var(--text-secondary)}.status-queued{background-color:#6b728026;color:#6b7280}.supplier-select-row{display:flex;gap:8px}.supplier-select-row select{flex:1}.new-supplier-form{margin-top:12px;padding:16px;background:var(--bg-tertiary);border-radius:var(--border-radius);display:flex;flex-direction:column;gap:12px}.new-supplier-form input{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.9375rem;background:var(--bg-secondary);color:var(--text-primary)}.new-supplier-form input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.new-supplier-actions{display:flex;justify-content:flex-end;gap:8px}.primary-button.small,.secondary-button.small{padding:6px 12px;font-size:.875rem}.catalog-progress{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:24px;margin-bottom:24px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.progress-header h3{margin:0;font-size:1.125rem;color:var(--text-primary)}.phase-indicator{margin-bottom:12px;padding:8px 12px;background:#dbeafe;border-radius:6px}.phase-indicator .phase-label{color:var(--primary-color);font-size:.875rem;font-weight:500}.progress-header-actions{display:flex;align-items:center;gap:8px}.cancel-button,.restart-button{padding:6px;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.cancel-button{background:#fee2e2;color:var(--error-color)}.cancel-button:hover:not(:disabled){background:#fecaca}.restart-button{background:#dbeafe;color:var(--primary-color)}.restart-button:hover:not(:disabled){background:#bfdbfe}.cancel-button:disabled,.restart-button:disabled{opacity:.5;cursor:not-allowed}.download-button,.export-button{padding:6px;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.download-button{background:#e0e7ff;color:#4f46e5}.download-button:hover:not(:disabled){background:#c7d2fe}.export-button{background:#d1fae5;color:#059669}.export-button:hover:not(:disabled){background:#a7f3d0}.download-button:disabled,.export-button:disabled{opacity:.5;cursor:not-allowed}.status-badge.status-cancelled{background:#fef3c7;color:#d97706}.progress-stats{display:flex;gap:32px;margin-bottom:16px}.progress-stats .stat{display:flex;flex-direction:column}.progress-stats .stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.progress-stats .stat-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.progress-bar-large{position:relative;height:24px;background:var(--bg-tertiary);border-radius:12px;overflow:hidden;margin-bottom:16px}.progress-bar-large .progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--primary-color),#60a5fa);transition:width .5s ease-out}.progress-bar-large .progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.875rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.current-item{display:flex;align-items:center;gap:8px;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius);margin-bottom:16px}.current-item-label{font-size:.875rem;color:var(--text-muted)}.current-item-name{font-weight:500;color:var(--text-primary)}.current-item.computing-similar{background:#8b5cf61a}.current-item.computing-similar .current-item-label{color:#8b5cf6}.progress-error{padding:12px;background:#ef44441a;border:1px solid var(--error-color);border-radius:var(--border-radius);color:var(--error-color);margin-bottom:16px}.progress-complete{display:flex;align-items:center;gap:12px;padding:16px;background:#10b9811a;border:1px solid var(--success-color);border-radius:var(--border-radius);color:var(--success-color)}.extracted-items{margin-top:20px}.extracted-items h4{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;margin:0 0 12px}.items-scroll-container{max-height:300px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--border-radius)}.extracted-item{display:flex;align-items:center;gap:16px;padding:12px 16px;border-bottom:1px solid var(--border-color)}.extracted-item:last-child{border-bottom:none}.extracted-item-page{font-size:.75rem;font-weight:600;color:var(--text-muted);background:var(--bg-tertiary);padding:4px 8px;border-radius:4px;white-space:nowrap}.extracted-item-info{flex:1;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.extracted-item-name{font-weight:500;color:var(--text-primary)}.extracted-item-number{font-size:.75rem;font-family:monospace;color:var(--text-muted)}.extracted-item-category{font-size:.75rem;color:var(--text-secondary);padding:2px 6px;background:var(--bg-tertiary);border-radius:4px}.processing-catalogs{margin-bottom:32px}.processing-catalogs h2,.completed-catalogs h2{font-size:1.125rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.catalogs-table,.suppliers-table{width:100%;border-collapse:collapse;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.catalogs-table th,.catalogs-table td,.suppliers-table th,.suppliers-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.catalogs-table th,.suppliers-table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary)}.catalogs-table td,.suppliers-table td{color:var(--text-primary)}.catalog-name{display:flex;align-items:center;gap:8px}.catalog-name svg{color:var(--text-secondary)}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500}.status-pending{background:#f59e0b1a;color:#f59e0b}.status-processing{background:#3b82f61a;color:#3b82f6}.status-computing_similar{background:#8b5cf61a;color:#8b5cf6}.status-completed{background:#10b9811a;color:#10b981}.status-failed{background:#ef44441a;color:#ef4444}.progress-bar{position:relative;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;min-width:100px}.progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--primary-color);transition:width .3s}.progress-text{position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.625rem;font-weight:600}.modal-overlay,.pdf-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal-content{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;max-width:900px;max-height:90vh;width:100%;overflow-y:auto}.item-detail-modal{padding:24px}.modal-close{position:absolute;top:16px;right:16px;padding:8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.item-detail-header{margin-bottom:24px;padding-right:48px}.item-detail-header h2{font-size:1.5rem;margin:0 0 8px}.item-detail-header .catalog-number{font-family:monospace;color:var(--text-muted)}.item-detail-body{display:flex;flex-direction:column;gap:24px}.item-gallery{display:flex;flex-direction:column;gap:12px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.gallery-main{display:flex;justify-content:center;align-items:center;background:var(--bg-tertiary);border-radius:var(--border-radius);overflow:hidden;min-height:200px;max-height:350px}.gallery-main-image{max-width:100%;max-height:350px;object-fit:contain}.gallery-thumbnails{display:flex;gap:8px;overflow-x:auto;padding:4px 0}.gallery-thumbnail{flex-shrink:0;width:64px;height:64px;padding:0;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);cursor:pointer;overflow:hidden;transition:border-color .2s}.gallery-thumbnail:hover{border-color:var(--text-muted)}.gallery-thumbnail.active{border-color:var(--primary-color)}.gallery-thumbnail img{width:100%;height:100%;object-fit:cover}.item-detail-content{display:grid;grid-template-columns:1fr 280px;gap:24px}.detail-section{margin-bottom:20px}.detail-section h3{font-size:.875rem;font-weight:600;color:var(--text-muted);margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em}.specifications-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.spec-item{display:flex;flex-direction:column}.spec-item dt{font-size:.75rem;color:var(--text-muted)}.spec-item dd{margin:0;color:var(--text-primary)}.detail-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.meta-item{display:flex;flex-direction:column}.meta-label{font-size:.75rem;color:var(--text-muted)}.meta-value{color:var(--text-primary)}.view-pdf-button{display:flex;align-items:center;gap:8px;padding:12px 20px;background:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;font-size:.9375rem;cursor:pointer;transition:background .2s}.view-pdf-button:hover{background:var(--primary-hover)}.similar-items h3{font-size:.875rem;font-weight:600;color:var(--text-muted);margin:0 0 16px;text-transform:uppercase;letter-spacing:.05em}.similar-items-list{list-style:none;padding:0;margin:0}.similar-item{display:flex;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius);margin-bottom:8px}.similar-item.clickable{cursor:pointer;transition:all .2s}.similar-item.clickable:hover{background:var(--bg-secondary);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.similar-item-image{width:60px;height:60px;flex-shrink:0;border-radius:4px;overflow:hidden;background:var(--bg-secondary)}.similar-item-image img{width:100%;height:100%;object-fit:cover}.similar-item-info{flex:1;min-width:0}.similar-item-name{font-weight:500;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.similar-item-number{font-size:.75rem;font-family:monospace;color:var(--text-muted);margin-bottom:4px}.similar-item-supplier{font-size:.75rem;color:var(--text-secondary)}.similar-items-loading{padding:20px;text-align:center;color:var(--text-muted);font-size:.875rem}.pdf-viewer-fullscreen{background:var(--bg-card);border-radius:12px;width:95vw;height:95vh;max-width:1400px;display:flex;flex-direction:column}.pdf-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.pdf-viewer-header h3{margin:0;color:var(--text-primary)}.pdf-page-jumper{display:flex;align-items:center;gap:8px}.pdf-page-jumper label{color:var(--text-secondary);font-size:.875rem}.pdf-page-jumper select{padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.875rem}.pdf-page-jumper .page-total{color:var(--text-muted);font-size:.875rem}.close-button{padding:8px;background:var(--bg-tertiary);border:none;border-radius:4px;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center}.close-button:hover{background:var(--border-color)}.pdf-viewer-scroll{flex:1;overflow-y:auto;padding:24px;background:var(--bg-tertiary)}.pdf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--text-secondary)}.pdf-pages-container{display:flex;flex-direction:column;align-items:center;gap:24px}.pdf-page-wrapper{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden;transition:box-shadow .3s}.pdf-page-wrapper.target-page{box-shadow:0 0 0 4px var(--primary-color),0 4px 12px #00000026}.pdf-page-number{padding:8px 16px;background:var(--bg-card);border-bottom:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted);text-align:center}.pdf-page-loading{display:flex;align-items:center;justify-content:center;min-height:400px;min-width:300px}.pdf-page-error{display:flex;align-items:center;justify-content:center;min-height:200px;min-width:300px;color:var(--error-color);padding:24px}.pdf-page-image-container{position:relative;display:flex;justify-content:center}.pdf-page-image{max-width:100%;display:block}.pdf-highlight-box{position:absolute;border:3px solid var(--primary-color);background:#4f46e526;border-radius:4px;pointer-events:none;animation:highlight-pulse 2s ease-in-out infinite}@keyframes highlight-pulse{0%,to{box-shadow:0 0 #4f46e566}50%{box-shadow:0 0 0 8px #4f46e500}}.pdf-highlight-shared{position:absolute;border:3px dashed #2563eb;background:#2563eb1a;border-radius:4px;pointer-events:none}.product-line-items{margin-bottom:24px}.product-line-items h3{font-size:.875rem;font-weight:600;color:var(--primary-color);margin:0 0 4px}.product-line-count{font-size:.75rem;color:var(--text-muted);margin-bottom:12px}.product-line-shared-image{width:100%;max-height:120px;border-radius:var(--border-radius);overflow:hidden;background:var(--bg-tertiary);margin-bottom:12px}.product-line-shared-image img{width:100%;height:100%;object-fit:contain}.product-line-list{list-style:none;padding:0;margin:0}.product-line-item{display:flex;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius);margin-bottom:8px}.product-line-item.clickable{cursor:pointer;transition:all .2s}.product-line-item.clickable:hover{background:var(--bg-secondary);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.product-line-item-image{width:60px;height:60px;flex-shrink:0;border-radius:4px;overflow:hidden;background:var(--bg-secondary)}.product-line-item-image img{width:100%;height:100%;object-fit:cover}.product-line-item-info{flex:1;min-width:0}.product-line-item-name{font-weight:500;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-line-item-number{font-size:.75rem;font-family:monospace;color:var(--text-muted)}.product-line-description{font-size:.8rem;color:var(--text-secondary);margin-bottom:8px;font-style:italic}.product-line-modal{max-width:700px;max-height:80vh;overflow-y:auto}.product-line-modal-header{margin-bottom:16px}.product-line-modal-header h2{margin:0 0 4px;font-size:1.25rem}.product-line-modal-description{color:var(--text-secondary);font-size:.9rem;margin:4px 0 8px;font-style:italic}.product-line-modal-count{font-size:.8rem;color:var(--text-muted)}.product-line-modal-shared-image{width:100%;max-height:200px;border-radius:var(--border-radius);overflow:hidden;background:var(--bg-tertiary);margin-bottom:16px;display:flex;align-items:center;justify-content:center}.product-line-modal-shared-image img{max-width:100%;max-height:200px;object-fit:contain}.product-line-modal-items{display:flex;flex-direction:column;gap:8px}.product-line-modal-item{display:flex;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius);cursor:pointer;transition:all .2s}.product-line-modal-item:hover{background:var(--bg-secondary);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.product-line-modal-item-image{width:70px;height:70px;flex-shrink:0;border-radius:4px;overflow:hidden;background:var(--bg-secondary)}.product-line-modal-item-image img{width:100%;height:100%;object-fit:cover}.product-line-modal-item-info{flex:1;min-width:0}.product-line-modal-item-name{font-weight:500;color:var(--text-primary);margin-bottom:4px}.product-line-modal-item-number{font-size:.8rem;font-family:monospace;color:var(--text-muted);margin-bottom:4px}.product-line-modal-item-desc{font-size:.8rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.browse-page{position:relative}.browse-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.browse-page-header .page-title{margin:0}.browse-stats{color:var(--text-secondary)}.browse-page-content{display:grid;grid-template-columns:280px 1fr;gap:24px}.browse-filters{display:flex;flex-direction:column;gap:16px}.browse-main{min-height:400px}@media (max-width: 900px){.browse-page-content{grid-template-columns:1fr}.browse-filters{flex-direction:row;flex-wrap:wrap}}.search-page{position:relative}.search-page-header{margin-bottom:24px}.header-top-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.image-search-trigger{display:flex;align-items:center}.image-search-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500}.image-search-btn:hover{border-color:var(--primary-color);background:var(--bg-secondary)}.image-search-btn svg{color:var(--primary-color)}.active-image-search{display:flex;align-items:center;gap:16px;margin-top:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color)}.image-search-preview{position:relative;flex-shrink:0}.image-search-preview img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid var(--primary-color)}.clear-image-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;padding:0;background:var(--error-color);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.clear-image-btn:hover{transform:scale(1.1)}.image-search-status{flex:1}.search-progress{display:flex;align-items:center;gap:10px}.progress-dot{width:10px;height:10px;background:var(--primary-color);border-radius:50%;animation:pulse 1s ease-in-out infinite}.progress-text{color:var(--text-secondary);font-size:.875rem;font-style:italic}.progress-count{padding:2px 8px;background:var(--primary-color);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600}.results-found{font-size:.9375rem;color:var(--text-primary);font-weight:500}.text-search-status{display:flex;align-items:center;gap:16px;margin-top:12px;flex-wrap:wrap}.search-query-display{font-size:.9375rem;color:var(--text-secondary)}.search-query-display strong{color:var(--text-primary)}.page-drop-zone{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:-1}.image-drop-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#2563ebf2;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drop-overlay-content{text-align:center;color:#fff}.drop-overlay-content svg{margin-bottom:24px;opacity:.9}.drop-overlay-content h2{font-size:1.75rem;font-weight:600;margin:0 0 8px}.drop-overlay-content p{font-size:1rem;opacity:.9;margin:0}.metrics-panel{background:#1a1a2e;border:1px solid #333;border-radius:8px;padding:12px;margin-bottom:16px;font-family:monospace;font-size:12px;max-height:250px;overflow-y:auto}.metrics-header{color:#888;margin-bottom:8px;font-weight:700;display:flex;justify-content:space-between}.metrics-streaming{color:#fbbf24}.metrics-initializing{color:#888;padding:4px 0}.metrics-log{display:flex;flex-direction:column;gap:2px}.metric-line{padding:3px 0;border-bottom:1px solid #333;color:#fbbf24}.metric-line:last-child{border-bottom:none}.metric-line.complete,.metric-line .success{color:#4ade80}.metric-line .analyzing{color:#60a5fa}.metric-line .error{color:#ef4444}.unified-search-box{display:flex;align-items:flex-start;gap:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:12px;margin-top:16px;transition:border-color .2s,box-shadow .2s}.unified-search-box:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.unified-search-box.searching{border-color:var(--warning-color)}.unified-search-box.has-image{align-items:stretch}.search-image-thumb{position:relative;flex-shrink:0;width:80px;height:80px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary)}.search-image-thumb img{width:100%;height:100%;object-fit:cover}.search-image-thumb .remove-image-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#000000b3;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.search-image-thumb:hover .remove-image-btn{opacity:1}.search-input-wrapper{flex:1;position:relative;min-height:40px}.search-textarea{width:100%;min-height:40px;padding:8px 12px;border:none;background:transparent;color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:none;outline:none;line-height:1.5}.search-textarea::placeholder{color:var(--text-muted)}.unified-search-box.has-image .search-textarea{min-height:64px}.search-status-bar{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:.875rem;color:var(--text-secondary)}.search-status-bar .status-dot{width:8px;height:8px;border-radius:50%;background:var(--warning-color);animation:pulse 1s ease-in-out infinite}.search-status-bar .status-progress{margin-left:auto;padding:2px 10px;background:var(--warning-color);color:#fff;border-radius:10px;font-size:.75rem;font-weight:600}.search-submit-btn{flex-shrink:0;width:48px;height:48px;border-radius:8px;border:none;background:var(--primary-color);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.search-submit-btn:hover:not(:disabled){background:var(--primary-hover);transform:scale(1.02)}.search-submit-btn:disabled{opacity:.5;cursor:not-allowed}.search-submit-btn svg{width:22px;height:22px}.upload-image-btn{flex-shrink:0;width:48px;height:48px;border-radius:8px;border:2px dashed var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.upload-image-btn svg{width:28px;height:28px}.upload-image-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background:#2563eb1a}.search-results-info{margin-top:12px;font-size:.875rem;color:var(--text-secondary)}.browse-header{margin-bottom:16px}.total-count{color:var(--text-secondary);font-size:.875rem}.empty-state{text-align:center;padding:64px 24px;color:var(--text-secondary)}.empty-state svg{margin-bottom:16px;color:var(--text-muted)}.empty-state h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 8px}.empty-state p{margin:0;font-size:.9375rem}.searching-state{text-align:center;padding:64px 24px;color:var(--text-secondary)}.searching-state h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 8px}.searching-state p{margin:0;font-size:.9375rem}.searching-animation{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.searching-animation span{width:12px;height:12px;border-radius:50%;background:var(--primary-color);animation:searchBounce 1.4s ease-in-out infinite}.searching-animation span:nth-child(1){animation-delay:0s}.searching-animation span:nth-child(2){animation-delay:.2s}.searching-animation span:nth-child(3){animation-delay:.4s}@keyframes searchBounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.image-search{margin-bottom:24px}.image-dropzone{padding:32px;border:2px dashed var(--border-color);border-radius:var(--border-radius);text-align:center;cursor:pointer;transition:all .2s}.image-dropzone:hover,.image-dropzone.active{border-color:var(--primary-color)}.image-dropzone.has-preview{border-style:solid;padding:16px}.image-preview{position:relative;display:inline-block}.image-preview img{max-width:200px;max-height:200px;object-fit:contain;border-radius:4px}.clear-preview{position:absolute;top:-8px;right:-8px;width:24px;height:24px;padding:0;background:var(--error-color);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.search-results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.search-results-header h2{font-size:1.125rem;margin:0;color:var(--text-primary)}.search-query{color:var(--text-secondary);font-weight:400}.results-info{display:flex;align-items:center;gap:16px}.results-count{color:var(--text-muted);font-size:.875rem}.streaming-indicator{display:flex;align-items:center;gap:8px;color:var(--primary-color);font-size:.875rem;font-weight:500}.streaming-dot{width:8px;height:8px;background:var(--primary-color);border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.search-results-grid.streaming .item-card{transition:transform .3s ease,opacity .3s ease}.search-results-grid .item-card.item-new{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.search-results-empty{text-align:center;padding:48px;color:var(--text-secondary)}.supplier-form-container{margin-bottom:24px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius)}.supplier-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.supplier-name-cell{display:flex;align-items:center;gap:8px}.website-link{color:var(--text-secondary)}.website-link:hover{color:var(--primary-color)}.no-data{text-align:center;color:var(--text-muted);padding:24px}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px}.loading-spinner{display:flex;align-items:center;justify-content:center}.spinner{border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.spinner-small .spinner{width:20px;height:20px}.spinner-medium .spinner{width:36px;height:36px}.spinner-large .spinner{width:48px;height:48px}.loading-text{margin-top:16px;color:var(--text-secondary)}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color)}.pagination-info{color:var(--text-secondary);font-size:.875rem}.pagination-controls{display:flex;gap:4px}.pagination-btn{min-width:36px;height:36px;padding:0 8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){border-color:var(--primary-color)}.pagination-btn.active{background:var(--primary-color);border-color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-ellipsis{display:flex;align-items:center;padding:0 8px;color:var(--text-muted)}.error-message{padding:16px;background:#ef44441a;border:1px solid var(--error-color);border-radius:var(--border-radius);color:var(--error-color);margin-bottom:16px}.no-results{text-align:center;padding:48px;color:var(--text-secondary)}.hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 768px){.header-center,.nav-links{display:none}.search-page-content{flex-direction:column}.sidebar,.search-filters{width:100%;margin-bottom:24px;position:static;max-height:none;overflow-y:visible}.item-detail-content{grid-template-columns:1fr}.gallery-main,.gallery-main-image{max-height:250px}.supplier-form,.stats-grid{grid-template-columns:1fr}}.indexing-page{max-width:1200px;margin:0 auto}.indexing-page .page-header{margin-bottom:24px}.indexing-page .page-subtitle{color:var(--text-secondary);margin-top:8px}.indexing-content{display:flex;flex-direction:column;gap:24px}.control-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:24px}.control-card h2{margin-bottom:8px;font-size:1.25rem}.control-card>p{color:var(--text-secondary);margin-bottom:20px}.control-card .btn{margin-bottom:20px}.status-info{border-top:1px solid var(--border-color);padding-top:16px}.status-info p{margin:8px 0;font-size:.875rem}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.status-idle{background:var(--bg-tertiary);color:var(--text-secondary)}.status-badge.status-running{background:#dbeafe;color:var(--primary-color)}.status-badge.status-completed{background:#d1fae5;color:var(--success-color)}.status-badge.status-failed{background:#fee2e2;color:var(--error-color)}.error-text{color:var(--error-color)}.status-cell{display:flex;align-items:center;gap:6px}.error-hint{color:var(--error-color);cursor:help;display:flex;align-items:center}.error-hint svg{opacity:.8}.warning-hint{color:#d97706;font-size:.7rem;opacity:.8}.indexing-progress{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:24px}.indexing-progress h2{margin-bottom:16px;font-size:1.25rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.phase-label{font-weight:500;color:var(--text-primary)}.progress-percent{font-weight:600;color:var(--primary-color)}.progress-bar-container{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:20px}.progress-bar{height:100%;background:var(--primary-color);border-radius:4px;transition:width .3s ease}.progress-stats{display:flex;gap:32px;margin-bottom:20px}.stat{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase}.events-log{border-top:1px solid var(--border-color);padding-top:16px}.events-log h3{font-size:.875rem;margin-bottom:12px;color:var(--text-secondary)}.events-list{max-height:200px;overflow-y:auto}.event{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--bg-tertiary);font-size:.875rem}.event:last-child{border-bottom:none}.event-time{color:var(--text-muted);flex-shrink:0;font-family:monospace}.event-message{color:var(--text-primary)}.event.event-error .event-message{color:var(--error-color)}.event.event-completed .event-message{color:var(--success-color)}.category-tree{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:24px}.tree-header{margin-bottom:16px}.tree-header h2{margin-bottom:8px;font-size:1.25rem}.tree-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:.875rem;color:var(--text-secondary);margin-bottom:12px}.tree-controls{display:flex;gap:8px}.tree-content{border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.category-node{border-bottom:1px solid var(--border-color)}.category-node:last-child{border-bottom:none}.category-header{display:flex;align-items:center;gap:8px;padding:12px 16px;cursor:pointer;background:var(--bg-tertiary);transition:background .15s}.category-header:hover{background:var(--bg-primary)}.expand-icon{width:16px;color:var(--text-secondary);font-size:.75rem}.category-name{font-weight:500;color:var(--text-primary)}.category-count{color:var(--text-muted);font-size:.875rem}.category-details{padding:16px 16px 16px 40px;background:var(--bg-secondary)}.category-summary{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin-bottom:16px}.subcategories{display:flex;flex-direction:column;gap:12px}.subcategory-node{padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius)}.subcategory-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.subcategory-name{font-weight:500;font-size:.875rem}.subcategory-count{color:var(--text-muted);font-size:.75rem}.subcategory-summary{color:var(--text-secondary);font-size:.8125rem;line-height:1.4;margin:0}.search-mode-indicator{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;margin-bottom:16px;background:#dbeafe;color:var(--primary-color);border-radius:20px;font-size:.75rem;font-weight:500}.load-more-container{display:flex;justify-content:center;padding:24px}.load-more-btn{min-width:150px}.no-more-results{color:var(--text-muted);font-size:.875rem}.btn-small{padding:6px 12px;font-size:.75rem}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-primary)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.category-tree-list{position:relative}.category-tree-item{margin-bottom:2px}.category-row{display:flex;align-items:stretch}.expand-btn{width:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.625rem;flex-shrink:0;padding:0}.expand-btn:hover{color:var(--text-primary)}.sidebar-item.category-item{flex:1;padding-left:4px}.sidebar-item.category-item.has-selection:not(.active){background:#2563eb0d}.subcategory-list{list-style:none;padding:0 0 0 24px;border-left:1px solid var(--border-color);margin:0 0 0 11px}.subcategory-list li{margin:2px 0}.sidebar-item.subcategory-item{font-size:.8125rem;padding:6px 8px}.sidebar-item.subcategory-item .category-count{font-size:.6875rem}.category-tooltip{position:absolute;left:calc(100% + 8px);top:0;width:280px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:12px;box-shadow:0 4px 12px #0000001a;z-index:100;pointer-events:none}.tooltip-title{font-weight:600;font-size:.875rem;margin-bottom:8px;color:var(--text-primary)}.tooltip-description{font-size:.8125rem;line-height:1.5;color:var(--text-secondary)}.sidebar-section,.category-filter-tree{position:relative}.category-filter-tree .category-row{display:flex;align-items:stretch}.category-filter-tree .expand-btn{width:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.625rem;flex-shrink:0;padding:0}.category-filter-tree .expand-btn:hover{color:var(--text-primary)}.category-filter-tree .filter-item.category-item{flex:1}.category-filter-tree .filter-item.category-item.has-selection:not(.active){background:#2563eb0d}.category-filter-tree .subcategory-list{list-style:none;padding:0 0 0 20px;border-left:1px solid var(--border-color);margin:0 0 0 9px}.category-filter-tree .subcategory-list li{margin:2px 0}.category-filter-tree .filter-item.subcategory-item{font-size:.8125rem;padding:4px 8px}.category-filter-tree .category-tooltip{position:absolute;left:calc(100% + 8px);top:0;width:250px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:12px;box-shadow:0 4px 12px #0000001a;z-index:100;pointer-events:none}.category-filter-tree .tooltip-title{font-weight:600;font-size:.875rem;margin-bottom:8px;color:var(--text-primary)}.category-filter-tree .tooltip-description{font-size:.8125rem;line-height:1.5;color:var(--text-secondary)}.catalog-filter-dropdown{margin-bottom:16px}.catalog-filter-dropdown .filter-label{display:block;font-size:.75rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.catalog-dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s}.catalog-dropdown-trigger:hover{border-color:var(--primary-color)}.catalog-dropdown-trigger.open{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.catalog-dropdown-trigger .dropdown-text{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.catalog-dropdown-trigger .dropdown-arrow{flex-shrink:0;margin-left:8px;transition:transform .2s}.catalog-dropdown-trigger.open .dropdown-arrow{transform:rotate(180deg)}.catalog-dropdown-menu{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:0 8px 24px #00000026;max-height:320px;overflow-y:auto}.catalog-dropdown-menu .dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text-primary);font-size:.875rem;text-align:left;cursor:pointer;transition:background .15s}.catalog-dropdown-menu .dropdown-item:hover{background:var(--bg-tertiary)}.catalog-dropdown-menu .dropdown-item.selected{background:#2563eb14}.catalog-dropdown-menu .dropdown-item .checkbox{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);border-radius:4px;flex-shrink:0;transition:all .15s}.catalog-dropdown-menu .dropdown-item.selected .checkbox{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.catalog-dropdown-menu .dropdown-item .catalog-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.catalog-dropdown-menu .dropdown-item .catalog-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary);padding:2px 6px;border-radius:10px;flex-shrink:0}.catalog-dropdown-menu .dropdown-divider{height:1px;background:var(--border-color);margin:4px 0}.queued-catalogs-section{margin-bottom:32px}.queued-catalogs-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.queued-catalogs-section h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.indexing-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-color)}.indexing-section .section-header{margin-bottom:24px}.indexing-section .section-header h2{margin:0 0 8px;font-size:1.5rem}.indexing-section .section-description{color:var(--text-secondary);margin:0}.indexing-section .indexing-control{margin-bottom:24px}.indexing-section .control-card h3{margin-bottom:8px;font-size:1.125rem}.indexing-section .control-card>p{color:var(--text-secondary);margin-bottom:20px}.embeddings-section{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-color)}.embeddings-section .section-header{margin-bottom:24px}.embeddings-section .section-header h2{margin:0 0 8px;font-size:1.5rem}.embeddings-section .section-description{color:var(--text-secondary);margin:0}.embeddings-section .embeddings-control{margin-bottom:24px}.embeddings-section .control-card h3{margin-bottom:8px;font-size:1.125rem}.embeddings-section .status-info{margin:16px 0;padding:12px;background:var(--bg-tertiary);border-radius:var(--border-radius)}.embeddings-section .status-info p{margin:4px 0}.embeddings-section .muted{color:var(--text-muted);font-style:italic}.embeddings-section .progress-info{margin:16px 0}.embeddings-section .progress-bar-container{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:8px}.embeddings-section .progress-bar{height:100%;background:var(--primary-color);border-radius:4px;transition:width .3s ease}.embeddings-section .progress-info p{color:var(--text-secondary);font-size:.875rem;margin:0}.search-mode-toggle{display:flex;background:var(--bg-tertiary);border-radius:16px;padding:3px;flex-shrink:0}.search-mode-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:none;border-radius:13px;background:transparent;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .2s;font-weight:500}.search-mode-btn.active{background:var(--primary-color);color:#fff}.search-mode-btn:hover:not(.active){background:var(--bg-secondary)}.search-mode-btn svg{width:14px;height:14px}.metric-line .deep-analysis{color:#a855f7}.projects-page{max-width:1200px;margin:0 auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:24px}.project-form-container{background:var(--bg-card);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:24px;margin-bottom:24px}.project-form{display:flex;flex-direction:column;gap:16px}.project-form textarea{resize:vertical;min-height:60px}.project-card{background:var(--bg-card);border-radius:var(--border-radius);border:1px solid var(--border-color);padding:20px;cursor:pointer;transition:all .2s}.project-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #0000001a}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.project-card-title{font-size:1.125rem;font-weight:600;margin:0;color:var(--text-primary)}.project-card-delete{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--text-muted);border-radius:4px;transition:all .2s;opacity:0}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{color:var(--error-color);background:var(--bg-tertiary)}.project-card-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-stats{display:flex;gap:16px;margin-bottom:12px}.project-card-stat{display:flex;align-items:center;gap:6px;font-size:.875rem;color:var(--text-muted)}.project-card-stat svg{color:var(--text-muted)}.project-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border-color)}.project-card-date{font-size:.75rem;color:var(--text-muted)}.project-card-status{font-size:.75rem;padding:2px 8px;border-radius:12px;font-weight:500}.project-card-status.status-active{background:#0596691a;color:var(--success-color)}.project-card-status.status-archived{background:var(--bg-tertiary);color:var(--text-muted)}.project-detail-page{display:flex;flex-direction:column;height:calc(100vh - var(--header-height) - 48px);max-width:1400px;margin:0 auto}.project-detail-header{display:flex;align-items:center;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color);margin-bottom:16px}.back-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s}.back-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.project-title-section{flex:1}.project-title{font-size:1.5rem;cursor:pointer;padding:4px 8px;margin:0 0 0 -8px;border-radius:var(--border-radius);transition:background .2s}.project-title:hover{background:var(--bg-tertiary)}.project-title-input{font-size:1.5rem;font-weight:600;border:2px solid var(--primary-color);border-radius:var(--border-radius);padding:4px 8px;outline:none;width:100%;max-width:400px}.files-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:8px 12px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;gap:6px;transition:all .2s}.files-toggle:hover,.files-toggle.active{border-color:var(--primary-color);color:var(--primary-color)}.files-count{background:var(--primary-color);color:#fff;font-size:.75rem;padding:2px 6px;border-radius:10px;font-weight:500}.project-detail-content{display:flex;flex:1;gap:20px;min-height:0}.chat-container{flex:1;display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--border-radius);border:1px solid var(--border-color);min-height:0}.chat-container.with-sidebar{flex:1}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-muted);padding:40px}.chat-empty-icon{margin-bottom:16px;color:var(--border-color)}.chat-empty-state h3{font-size:1.125rem;color:var(--text-secondary);margin:0 0 8px}.chat-empty-state p{margin:0;max-width:300px}.chat-message{display:flex;gap:12px;max-width:85%}.chat-message.user{align-self:flex-end;flex-direction:row-reverse}.chat-message.assistant{align-self:flex-start}.chat-message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-message.user .chat-message-avatar{background:var(--primary-color);color:#fff}.chat-message.assistant .chat-message-avatar{background:var(--bg-tertiary);color:var(--text-secondary)}.chat-message-body{display:flex;flex-direction:column;gap:8px}.chat-message-content{padding:12px 16px;border-radius:16px;line-height:1.5}.chat-message.user .chat-message-content{background:var(--primary-color);color:#fff;border-bottom-right-radius:4px}.chat-message.assistant .chat-message-content{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:4px}.chat-message-content code{background:#0000001a;padding:1px 4px;border-radius:3px;font-size:.875em}.chat-heading{margin:16px 0 8px;font-weight:600;color:var(--text-primary)}.chat-message-content h2.chat-heading{font-size:1.25rem}.chat-message-content h3.chat-heading{font-size:1.1rem}.chat-message-content h4.chat-heading{font-size:1rem}.chat-message-content .chat-heading:first-child{margin-top:0}.chat-bullet{padding-left:8px;margin:4px 0}.chat-message-time{font-size:.75rem;color:var(--text-muted);padding:0 4px}.chat-message.user .chat-message-time{text-align:right}.chat-message.streaming .chat-message-content{min-height:44px}.thinking-indicator{display:inline-flex;gap:4px;align-items:center}.thinking-dot{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:thinking 1.4s infinite ease-in-out both}.thinking-dot:nth-child(1){animation-delay:-.32s}.thinking-dot:nth-child(2){animation-delay:-.16s}@keyframes thinking{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-current-action{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--border-radius);font-size:.875rem;color:var(--text-secondary);margin-bottom:8px}.action-spinner{width:14px;height:14px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.chat-message-products{margin-top:8px}.chat-products-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.chat-products-count{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.chat-products-toggle{background:none;border:none;font-size:.875rem;color:var(--primary-color);cursor:pointer;padding:0}.chat-products-toggle:hover{text-decoration:underline}.chat-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.chat-product-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;cursor:pointer;transition:all .2s}.chat-product-card:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0000001a}.chat-product-image{width:100%;height:100px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.chat-product-image img{width:100%;height:100%;object-fit:contain}.chat-product-placeholder{color:var(--text-muted)}.chat-product-info{padding:10px}.chat-product-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.chat-product-catalog{font-size:.75rem;color:var(--text-muted);font-family:monospace}.chat-product-category{font-size:.75rem;color:var(--text-secondary)}.chat-inline-product{display:inline-block;vertical-align:top;margin:8px 8px 8px 0;max-width:200px}.chat-inline-product .chat-product-card{width:180px}.chat-inline-product .chat-product-image{height:80px}.chat-product-loading,.chat-product-error{opacity:.7}.chat-product-error .chat-product-placeholder{color:var(--error-color)}.loading-spinner-small{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.chat-message-actions{display:flex;gap:4px;margin-top:8px;opacity:0;transition:opacity .2s}.chat-message:hover .chat-message-actions{opacity:1}.chat-action-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;transition:all .2s}.chat-action-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.chat-raw-content{background:var(--bg-tertiary);padding:12px;border-radius:var(--border-radius);font-family:monospace;font-size:.8rem;white-space:pre-wrap;word-break:break-all;overflow-x:auto;max-height:400px;overflow-y:auto;margin-top:4px}.chat-message-categories{margin-top:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:12px}.chat-categories-header{font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.chat-categories-list{display:flex;flex-wrap:wrap;gap:8px}.chat-category-item{display:flex;align-items:center;gap:6px;background:var(--bg-tertiary);padding:4px 10px;border-radius:16px;font-size:.875rem}.chat-category-name{color:var(--text-primary)}.chat-category-count{color:var(--text-muted);font-size:.75rem}.chat-category-more{color:var(--text-muted);font-size:.875rem;padding:4px}.chat-input-container{border-top:1px solid var(--border-color);padding:16px}.chat-input-form{display:flex;gap:12px;align-items:flex-end}.chat-textarea{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:20px;resize:none;font-size:.9375rem;line-height:1.4;min-height:44px;max-height:200px;outline:none;transition:border-color .2s}.chat-textarea:focus{border-color:var(--primary-color)}.chat-textarea:disabled{background:var(--bg-tertiary);color:var(--text-muted)}.chat-send-button{width:44px;height:44px;border-radius:50%;background:var(--primary-color);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.chat-send-button:hover:not(:disabled){background:var(--primary-hover)}.chat-send-button:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.chat-send-button .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-input-hint{font-size:.75rem;color:var(--text-muted);margin-top:8px;text-align:center}.chat-attach-button{width:44px;height:44px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.chat-attach-button:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color)}.chat-attach-button:disabled{opacity:.5;cursor:not-allowed}.chat-attached-files{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.chat-attached-file{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--border-radius);font-size:.875rem;color:var(--text-primary)}.attached-file-icon{display:flex;color:var(--primary-color)}.attached-file-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attached-file-remove{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:all .2s}.attached-file-remove:hover{background:var(--error-color);color:#fff}.chat-message-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.chat-attachment{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#0000000d;border-radius:6px;font-size:.8125rem;color:var(--text-secondary);border:none;cursor:default}.chat-attachment.clickable{cursor:pointer;transition:all .2s}.chat-attachment.clickable:hover{background:#0000001a}.chat-attachment:disabled{opacity:.7;cursor:not-allowed}.chat-message.user .chat-attachment{background:#fff3;color:inherit}.chat-message.user .chat-attachment.clickable:hover{background:#ffffff4d}.chat-attachment-icon{display:flex;opacity:.8}.chat-attachment-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-attachment-download{display:flex;opacity:.6;margin-left:4px}.chat-attachment.clickable:hover .chat-attachment-download{opacity:1}.project-files-sidebar{width:280px;background:var(--bg-card);border-radius:var(--border-radius);border:1px solid var(--border-color);display:flex;flex-direction:column;min-height:0}.project-files-header{padding:16px;border-bottom:1px solid var(--border-color)}.project-files-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.project-files-upload{margin:16px;padding:20px;border:2px dashed var(--border-color);border-radius:var(--border-radius);text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-secondary)}.project-files-upload:hover{border-color:var(--primary-color);background:var(--bg-tertiary)}.project-files-upload svg{color:var(--text-muted)}.project-files-upload span{font-size:.875rem}.upload-hint{font-size:.75rem!important;color:var(--text-muted)!important}.project-files-list{flex:1;overflow-y:auto;padding:0 16px 16px}.no-files{text-align:center;color:var(--text-muted);font-size:.875rem;padding:20px}.project-file-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--border-radius);transition:background .2s}.project-file-item:hover{background:var(--bg-tertiary)}.file-icon{color:var(--text-muted);flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.file-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.project-file-item:hover .file-actions{opacity:1}.file-download,.file-delete{background:transparent;border:none;padding:6px;border-radius:4px;cursor:pointer;color:var(--text-muted);text-decoration:none;display:flex;align-items:center;justify-content:center;transition:all .2s}.file-download:hover{color:var(--primary-color);background:var(--bg-secondary)}.file-delete:hover{color:var(--error-color);background:var(--bg-secondary)}.file-download:disabled{opacity:.6;cursor:not-allowed}.download-spinner{width:14px;height:14px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state-icon{color:var(--border-color);margin-bottom:20px}.empty-state h3{font-size:1.25rem;color:var(--text-secondary);margin:0 0 8px}.empty-state p{color:var(--text-muted);margin:0 0 20px;max-width:300px}.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:20px}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr}.project-detail-content{flex-direction:column}.project-files-sidebar{width:100%;max-height:300px}.chat-message{max-width:95%}.chat-products-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.users-page{max-width:900px}.user-form-container{margin-bottom:24px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius)}.user-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.user-form .form-group:last-of-type{grid-column:1 / -1}.form-error{grid-column:1 / -1;padding:12px;background:#ef44441a;border:1px solid var(--error-color);border-radius:var(--border-radius);color:var(--error-color);font-size:.875rem}.users-table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.users-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.users-table td{vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.user-name-cell{display:flex;align-items:center;gap:12px}.user-name-cell .user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.role-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.role-badge.role-admin{background:#2563eb1a;color:var(--primary-color)}.role-badge.role-user{background:var(--bg-tertiary);color:var(--text-secondary)}@media (max-width: 768px){.user-form{grid-template-columns:1fr}.user-form .form-group:last-of-type{grid-column:auto}}.section-loading{display:flex;align-items:center;gap:10px;padding:16px;color:var(--text-muted);font-size:.875rem}.section-loading .loading-indicator{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.category-tree-loading{margin-top:16px;padding:24px;background:var(--bg-tertiary);border-radius:var(--border-radius)}.extraction-config{margin-bottom:24px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius)}.extraction-config .config-loading{padding:24px;text-align:center;color:var(--text-secondary)}.extraction-config .config-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px 16px;margin-bottom:20px}.extraction-config .config-header h3{margin:0;font-size:18px;white-space:nowrap}.extraction-config .config-catalog-info{display:flex;gap:12px;color:var(--text-secondary);font-size:14px;word-break:break-all}.extraction-config .filename-link{color:var(--primary-color);text-decoration:none;cursor:pointer}.extraction-config .filename-link:hover{text-decoration:underline}.extraction-config .config-form{display:flex;flex-direction:column;gap:20px}.extraction-config .form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:14px}.extraction-config .form-group select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:14px}.extraction-config .form-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.extraction-config .form-group-header label{margin-bottom:0}.extraction-config .modified-badge{margin-left:8px;padding:2px 8px;font-size:11px;font-weight:600;color:var(--warning-color, #f59e0b);background:#f59e0b1a;border-radius:10px}.extraction-config .template-controls{display:flex;gap:8px;align-items:center}.extraction-config .template-select{width:auto;min-width:180px}.extraction-config .icon-button{background:none;border:1px solid var(--border-color);border-radius:var(--border-radius);padding:4px 8px;cursor:pointer;font-size:14px;color:var(--text-secondary)}.extraction-config .icon-button.danger:hover{color:var(--error-color);border-color:var(--error-color)}.extraction-config .prompt-textarea{width:100%;min-height:200px;padding:12px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-family:SF Mono,Fira Code,monospace;font-size:13px;line-height:1.5;resize:vertical;box-sizing:border-box}.extraction-config .prompt-actions{display:flex;gap:8px;align-items:center;margin-top:8px}.extraction-config .save-template-form{display:flex;gap:8px;align-items:center}.extraction-config .save-template-form input{padding:6px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:14px}.extraction-config .config-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color)}.enrichment-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.enrichment-dialog{background:var(--bg-secondary);border-radius:12px;width:90vw;max-width:960px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.enrichment-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.enrichment-header h2{margin:0;font-size:18px}.enrichment-header .close-button{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);padding:0 4px;line-height:1}.enrichment-content{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:16px}.enrichment-controls{display:flex;flex-direction:column;gap:12px}.threshold-control{display:flex;align-items:center;gap:12px}.threshold-control label{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500}.threshold-control input[type=range]{width:200px}.threshold-value{font-weight:600;min-width:40px;text-align:center;background:var(--bg-tertiary);padding:2px 8px;border-radius:4px;font-size:13px}.preview-summary{font-size:14px;color:var(--text-secondary)}.selection-controls{display:flex;align-items:center;gap:12px}.selection-controls .text-button{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:13px;padding:4px 8px;border-radius:4px}.selection-controls .text-button:hover{background:var(--bg-tertiary)}.selection-count{font-size:13px;color:var(--text-muted)}.bbraun-skip-note{color:var(--text-muted);font-size:12px}.item-preview-list{flex:1;overflow-y:auto;max-height:450px;border:1px solid var(--border-color);border-radius:var(--border-radius)}.enrich-item-row{display:flex;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border-color);transition:background .1s}.enrich-item-row:last-child{border-bottom:none}.enrich-item-row:hover{background:var(--bg-tertiary)}.enrich-item-row.selected{background:#2563eb0a}.enrich-item-checkbox{padding-top:2px;flex-shrink:0}.enrich-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.enrich-item-title-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.enrich-item-name{font-weight:500;font-size:14px;color:var(--primary-color);cursor:pointer;line-height:1.3}.enrich-item-name:hover{text-decoration:underline}.enrich-item-catnum{font-size:12px;color:var(--text-muted);background:var(--bg-tertiary);padding:1px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0}.enrich-item-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.enrich-item-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:2px}.enrich-item-page{font-size:11px;color:var(--text-muted);white-space:nowrap}.info-score-bar{position:relative;width:80px;height:18px;background:var(--bg-tertiary);border-radius:9px;overflow:hidden}.info-score-fill{position:absolute;top:0;left:0;height:100%;border-radius:9px;transition:width .3s}.info-score-text{position:absolute;top:0;left:0;right:0;text-align:center;font-size:11px;line-height:18px;font-weight:600;color:var(--text-primary)}.missing-fields{display:flex;flex-wrap:wrap;gap:4px}.missing-field-tag{font-size:11px;padding:1px 6px;border-radius:3px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.enrichment-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border-color)}.enrichment-loading,.enrichment-empty{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}.configure-section{display:flex;flex-direction:column;gap:16px}.configure-summary{font-size:14px;color:var(--text-secondary);font-weight:500;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--border-radius)}.configure-section .form-group{display:flex;flex-direction:column;gap:6px}.configure-section label{font-size:14px;font-weight:500}.configure-section label .hint{font-weight:400;color:var(--text-muted);font-size:12px}.configure-section select,.configure-section textarea{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-family:inherit}.configure-section textarea{font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace;font-size:12px;line-height:1.5;resize:vertical}.enrichment-progress{display:flex;flex-direction:column;gap:16px}.enrichment-progress h3{margin:0;font-size:16px}.enrichment-progress .progress-bar-container{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.enrichment-progress .progress-bar{height:100%;background:var(--primary-color);border-radius:4px;transition:width .5s ease}.progress-stats{display:flex;justify-content:space-between;font-size:13px;color:var(--text-secondary)}.enrichment-log{max-height:250px;overflow-y:auto;font-size:12px;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace;background:var(--bg-tertiary);border-radius:var(--border-radius);padding:12px;display:flex;flex-direction:column;gap:4px}.log-entry{color:var(--text-secondary)}.log-entry.log-page_enriching{color:var(--primary-color)}.log-entry.log-item_updated{color:var(--success-color)}.log-entry.log-enrichment_started{color:var(--text-primary);font-weight:500}.enrichment-done{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 20px}.enrichment-result{text-align:center}.enrichment-result h3{margin:0 0 8px;font-size:18px}.enrichment-result.success h3{color:var(--success-color)}.enrichment-result.error h3{color:var(--error-color)}.enrichment-result p{color:var(--text-secondary);margin:0}.enrich-button{padding:6px;background:none;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .15s}.enrich-button:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.dialog-content{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;max-width:700px;max-height:90vh;width:100%;overflow-y:auto;padding:24px}.dialog-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dialog-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.dialog-header .close-button{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);padding:0 4px;line-height:1}.dialog-header .close-button:hover{color:var(--text-primary)}.dialog-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.extraction-config-dialog{max-width:800px}.extraction-config-dialog .config-form{display:flex;flex-direction:column;gap:16px}.extraction-config-dialog .form-group{display:flex;flex-direction:column;gap:6px}.extraction-config-dialog .form-group label{font-weight:600;font-size:.9rem;color:var(--text-primary)}.extraction-config-dialog .form-group select,.extraction-config-dialog .form-group .pages-input{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.extraction-config-dialog .form-hint{font-size:.8rem;color:var(--text-secondary)}.extraction-config-dialog .checkbox-label{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer}.extraction-config-dialog .checkbox-label input[type=checkbox]{width:16px;height:16px}.extraction-config-dialog .form-group-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.extraction-config-dialog .template-controls{display:flex;gap:6px;align-items:center}.extraction-config-dialog .template-select{padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem}.extraction-config-dialog .modified-badge{display:inline-block;margin-left:8px;padding:1px 6px;font-size:.75rem;font-weight:400;background:var(--primary-color);color:#fff;border-radius:4px}.extraction-config-dialog .prompt-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-family:monospace;font-size:.85rem;resize:vertical;min-height:120px;box-sizing:border-box}.extraction-config-dialog .prompt-actions{display:flex;gap:8px;align-items:center}.extraction-config-dialog .save-template-form{display:flex;gap:6px;align-items:center}.extraction-config-dialog .save-template-form input{padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem}.extraction-config-dialog .icon-button.danger{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;padding:4px}.extraction-config-dialog .icon-button.danger:hover{color:#e53e3e}.queued-catalogs-list{display:flex;flex-direction:column;gap:8px}.queued-catalog-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px}.queued-catalog-info{display:flex;align-items:center;gap:16px}.queued-catalog-name{font-weight:600;color:var(--text-primary)}.queued-catalog-supplier{color:var(--text-secondary);font-size:.9rem}.queued-catalog-size{color:var(--text-secondary);font-size:.85rem}.extraction-results-dialog{max-width:1000px;max-height:85vh;display:flex;flex-direction:column}.extraction-results-summary{color:var(--text-secondary);font-size:.9rem;margin-bottom:16px}.extraction-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;overflow-y:auto;max-height:60vh;padding:4px}.pairing-page{padding:24px;max-width:1200px;margin:0 auto}.pairing-page h2{margin-bottom:16px}.pairing-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.pairing-card{border:1px solid var(--border-color);border-radius:10px;padding:20px;background:var(--bg-primary);transition:box-shadow .15s,border-color .15s}.pairing-card-ready{cursor:pointer}.pairing-card-ready:hover{border-color:var(--primary-color);box-shadow:0 4px 16px #4f46e51f}.pairing-card-disabled{opacity:.6}.pairing-card-names{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:600;margin-bottom:10px}.pairing-card-arrow{color:var(--text-muted);font-weight:400;font-size:1.2rem}.pairing-card-meta{display:flex;align-items:center;gap:12px;font-size:.85rem;color:var(--text-muted)}.pairing-card-pairs{color:var(--primary-color);font-weight:600}.pairing-card-runs{color:var(--text-muted)}.pairing-job-viewer{display:flex;flex-direction:column;height:calc(100vh - 120px);padding:0 12px}.pairing-job-header{display:flex;align-items:center;gap:16px;padding:12px 0;flex-shrink:0}.pairing-job-header h2{margin:0;font-size:1.1rem}.pairing-arrow{color:var(--text-muted);font-weight:400}.pairing-viewer{display:flex;flex-direction:column;flex:1;min-height:0}.pairing-viewer-stats{display:flex;gap:16px;padding:8px 0;font-size:.85rem;flex-shrink:0}.pairing-stat-approved{color:#22c55e;font-weight:600}.pairing-stat-pending{color:#f59e0b;font-weight:600}.pairing-stat-rejected{color:#ef4444;font-weight:600}.pairing-viewer-panels{display:flex;gap:8px;flex:1;min-height:0}.pairing-panel{flex:1;display:flex;flex-direction:column;min-width:0;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.pairing-panel-header{padding:6px 10px;background:var(--bg-secondary);font-weight:600;font-size:.85rem;border-bottom:1px solid var(--border-color);flex-shrink:0;display:flex;align-items:center;gap:8px}.pairing-panel-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.pairing-panel-scroll{flex:1;overflow-y:auto;padding:8px}.pairing-page-wrapper{margin-bottom:12px}.pairing-page-number{font-size:.75rem;color:var(--text-muted);padding:4px 0}.pairing-page-loading,.pairing-page-error{height:400px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:4px;color:var(--text-muted)}.pairing-viewer-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px}.pairing-box{position:absolute;border:2px solid;border-radius:3px;cursor:pointer;transition:background .15s,box-shadow .15s;z-index:2}.pairing-box:hover{background:#4f46e51f;box-shadow:0 0 0 2px #4f46e54d}.pairing-box-approved{border-color:#22c55e;background:#22c55e0f}.pairing-box-pending{border-color:#f59e0b;background:#f59e0b0f}.pairing-box-rejected{border-color:#f97316;background:#f973160f}.pairing-box-unmatched{border-color:#9ca3af;background:#9ca3af0f;border-style:dashed}.pairing-box-no-match{border-color:#ef4444;background:#ef44440f;border-style:dashed}.pairing-box-selected{animation:pairing-pulse 1.5s ease-in-out infinite;z-index:3}@keyframes pairing-pulse{0%,to{box-shadow:0 0 #4f46e580}50%{box-shadow:0 0 0 6px #4f46e526}}.pairing-tooltip{position:fixed;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:6px 10px;box-shadow:0 4px 12px #00000026;z-index:1000;pointer-events:none;max-width:280px}.pairing-tooltip-name{font-weight:600;font-size:.8rem}.pairing-tooltip-num{font-size:.75rem;color:var(--text-muted)}.repair-page-btn{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:.7rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.repair-page-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.repair-page-btn:disabled{opacity:.6;cursor:not-allowed}.repair-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pairing-action-bar{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:2px solid var(--border-color);box-shadow:0 -4px 20px #0000001f;padding:10px 20px;z-index:100;display:flex;align-items:center;gap:16px}.pairing-action-items{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.pairing-action-item{display:flex;flex-direction:column;gap:2px;padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .15s;min-width:0;flex:1;text-align:left}.pairing-action-item:hover{border-color:var(--primary-color);background:#2563eb0d}.pairing-action-label{font-size:.65rem;text-transform:uppercase;color:var(--text-muted);font-weight:600;letter-spacing:.5px}.pairing-action-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pairing-action-catnum{font-size:.7rem;color:var(--text-secondary)}.pairing-action-score{display:flex;flex-direction:column;align-items:center;gap:1px;padding:4px 8px;flex-shrink:0}.pairing-action-score-value{font-size:1.3rem;font-weight:700;color:var(--primary-color);line-height:1}.pairing-action-score-label{font-size:.6rem;text-transform:uppercase;color:var(--text-muted)}.pairing-action-sub-score{font-size:.65rem;color:var(--text-secondary)}.pairing-action-buttons{display:flex;align-items:center;gap:8px;flex-shrink:0}.pairing-action-status{font-size:.7rem;font-weight:600;text-transform:uppercase;padding:3px 8px;border-radius:4px}.pairing-action-status-pending{color:#f59e0b;background:#f59e0b1a}.pairing-action-status-approved{color:#22c55e;background:#22c55e1a}.pairing-action-status-rejected{color:#ef4444;background:#ef44441a}.pairing-btn-approve{background:#22c55e;color:#fff;border:none;padding:6px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:.85rem}.pairing-btn-approve:hover{background:#16a34a}.pairing-btn-reject{background:#ef4444;color:#fff;border:none;padding:6px 16px;border-radius:6px;font-weight:600;cursor:pointer;font-size:.85rem}.pairing-btn-reject:hover{background:#dc2626}.pairing-btn-dismiss{padding:6px 12px;font-size:.85rem}.pairing-action-error{position:absolute;top:-28px;right:20px;background:#fef2f2;color:#dc2626;font-size:.75rem;padding:4px 10px;border-radius:4px;border:1px solid #fecaca}.pairing-page-jump{display:flex;align-items:center;gap:4px;flex-shrink:0}.pairing-page-jump-input{width:52px;padding:2px 6px;font-size:.75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);text-align:center}.pairing-page-jump-input::-webkit-inner-spin-button,.pairing-page-jump-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.pairing-page-jump-input[type=number]{-moz-appearance:textfield}.pairing-page-jump-btn{padding:2px 8px;font-size:.7rem;font-weight:600;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.pairing-page-jump-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pairing-sidebar{width:180px;flex-shrink:0;display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background:var(--bg-primary)}.pairing-sidebar-header{padding:6px 10px;background:var(--bg-secondary);font-weight:600;font-size:.8rem;border-bottom:1px solid var(--border-color);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.pairing-sidebar-count{font-size:.7rem;color:var(--text-muted);font-weight:400;background:var(--bg-tertiary);padding:1px 6px;border-radius:8px}.pairing-sidebar-list{flex:1;overflow-y:auto;padding:4px}.pairing-sidebar-item{display:flex;align-items:flex-start;gap:6px;padding:5px 6px;border-radius:4px;cursor:pointer;transition:background .12s;font-size:.75rem}.pairing-sidebar-item:hover{background:var(--bg-secondary)}.pairing-sidebar-item-selected{background:#4f46e51a;outline:1px solid rgba(79,70,229,.3)}.pairing-sidebar-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}.pairing-sidebar-dot-approved{background:#22c55e}.pairing-sidebar-dot-pending{background:#f59e0b}.pairing-sidebar-dot-rejected{background:#f97316}.pairing-sidebar-dot-no-match{background:#ef4444}.pairing-sidebar-dot-unsearched{background:#9ca3af}.pairing-sidebar-item-text{min-width:0;flex:1}.pairing-sidebar-item-name{color:var(--text-primary);font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.pairing-sidebar-item-catnum{color:var(--text-muted);font-size:.65rem;margin-top:1px}.pairing-sidebar-empty{padding:16px 8px;text-align:center;color:var(--text-muted);font-size:.75rem}*{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1e293b;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{height:100%}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;height:auto}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::selection{background:#2563eb33;color:#1e293b}
