: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}.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}.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}}.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)}@keyframes spin{to{transform:rotate(360deg)}}.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))}}*{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}
