.project-view{padding:24px}.project-view-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.project-view-header h2{margin:0;font-size:1.25rem}.project-view-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.project-cards{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:16px;transition:border-color .15s,box-shadow .15s}.project-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000f}.project-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.project-card-title h3{margin:0;font-size:1rem;font-weight:600;line-height:1.3}.project-card-number{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}.project-card-customer{color:var(--text-muted);margin-bottom:4px;font-size:.8rem}.project-card-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:4px 0 8px;font-size:.8rem;display:-webkit-box;overflow:hidden}.project-card-footer{color:var(--text-muted);border-top:1px solid var(--border);gap:12px;margin-top:8px;padding-top:8px;font-size:.75rem;display:flex}.project-card-meta{white-space:nowrap}.project-status-badge{white-space:nowrap;text-transform:uppercase;letter-spacing:.03em;border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.project-status-active{background:var(--success-bg,#dcfce7);color:var(--success-text,#166534)}.project-status-completed{background:var(--info-bg,#dbeafe);color:var(--info-text,#1e40af)}.project-status-archived{background:var(--neutral-bg,#f3f4f6);color:var(--neutral-text,#6b7280)}.project-status-on-hold{background:var(--warning-bg,#fef9c3);color:var(--warning-text,#854d0e)}.project-detail{padding:24px}.project-detail-header{margin-bottom:24px}.project-detail-nav{margin-bottom:8px}.project-detail-title-row{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.project-detail-title-row h2{margin:0 0 4px;font-size:1.25rem}.project-detail-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;display:flex}.project-detail-description{color:var(--text-secondary);max-width:600px;margin-top:8px;font-size:.85rem}.project-detail-actions{flex-shrink:0;gap:8px;display:flex}.project-products-section{margin-top:16px}.project-products-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-products-header h3{margin:0;font-size:1rem}.project-products-table{border-collapse:collapse;width:100%}.project-products-table th{text-align:left;text-transform:uppercase;color:var(--text-muted);border-bottom:2px solid var(--border);padding:8px 12px;font-size:.75rem;font-weight:600}.project-products-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:.85rem}.project-product-row{cursor:pointer;transition:background .1s}.project-product-row:hover{background:var(--hover)}.add-product-list{border:1px solid var(--border);border-radius:var(--radius);max-height:300px;margin-top:8px;overflow-y:auto}.add-product-item{cursor:pointer;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;transition:background .1s;display:flex}.add-product-item:hover{background:var(--hover)}.add-product-item+.add-product-item{border-top:1px solid var(--border)}.add-product-item-selected{background:var(--accent-bg,#eff6ff)}.product-check{color:var(--accent);flex-shrink:0;font-weight:600}.selected-products-chips{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.product-chip{background:var(--accent-bg,#eff6ff);border:1px solid var(--accent-border,#bfdbfe);white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:500;display:inline-flex}.product-chip-remove{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 2px;font-size:.7rem;line-height:1}.product-chip-remove:hover{color:var(--danger,#dc2626)}.project-detail-name-cell{font-weight:500}.product-detail-view{padding:24px}.product-detail-view-header{margin-bottom:24px}.product-detail-view-header h2{margin:0;font-size:1.25rem;font-weight:600}.product-detail-view-id{color:var(--text-muted);font-size:1rem;font-weight:400}.product-detail-view-customer{color:var(--text-secondary);margin-top:4px;font-size:.85rem}.product-detail-view-section{margin-bottom:32px}.product-detail-view-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.product-detail-view-section-header h3{margin:0;font-size:1rem;font-weight:600}.product-detail-view-empty{padding:16px 0;font-size:.85rem}.product-detail-view-table{border-collapse:collapse;width:100%}.product-detail-view-table th{text-align:left;text-transform:uppercase;color:var(--text-muted);border-bottom:2px solid var(--border);padding:8px 12px;font-size:.75rem;font-weight:600}.product-detail-view-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.product-detail-view-table th.sortable:hover{color:var(--text-primary)}.product-detail-view-table td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:.85rem}.product-detail-view-row.clickable{cursor:pointer;transition:background .1s}.product-detail-view-row.clickable:hover{background:var(--hover)}.product-detail-view-details-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:center;padding:14px 16px;transition:border-color .15s,box-shadow .15s;display:flex}.detail-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000000f}.detail-card-main{min-width:0}.detail-card-name{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.detail-card-id{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono);margin-top:2px}.detail-card-meta{color:var(--text-muted);white-space:nowrap;flex-shrink:0;margin-left:12px;font-size:.75rem}.product-id-number{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono)}
.complaint-status-badge{border-radius:var(--radius-sm);white-space:nowrap;border:1px solid #0000;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.complaint-status-badge[data-status=NEW]{color:var(--danger,#ef4444);border-color:var(--danger,#ef4444);background:#ef444414}.complaint-status-badge[data-status=IN_ANALYSIS]{color:#8b5cf6;background:#8b5cf614;border-color:#8b5cf6}.complaint-status-badge[data-status=CORRECTIVE_ACTION]{color:#3b82f6;background:#3b82f614;border-color:#3b82f6}.complaint-status-badge[data-status=CUSTOMER_RESPONSE]{color:#06b6d4;background:#06b6d414;border-color:#06b6d4}.complaint-status-badge[data-status=VERIFICATION]{color:var(--warning,#f59e0b);border-color:var(--warning,#f59e0b);background:#f59e0b14}.complaint-status-badge[data-status=CLOSED]{color:var(--success,#22c55e);border-color:var(--success,#22c55e);background:#22c55e14}.complaint-status-badge[data-status=REJECTED]{color:var(--text-muted);border-color:var(--border);background:var(--bg-secondary)}.complaint-priority{font-size:12px;font-weight:500}.complaint-priority[data-priority=CRITICAL]{color:var(--danger,#ef4444)}.complaint-priority[data-priority=HIGH]{color:var(--warning,#f59e0b)}.complaint-priority[data-priority=NORMAL]{color:var(--text-secondary)}.complaint-priority[data-priority=LOW]{color:var(--text-muted)}.complaint-type-pill{border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);padding:1px 7px;font-size:11px;font-weight:500;display:inline-block}.complaint-sla{color:var(--text-secondary);font-size:13px}.complaint-sla--overdue{color:var(--danger,#ef4444);font-weight:500}.complaint-sla--overdue:after{content:" ⚠"}.complaint-detail{padding:16px 24px 32px}.complaint-detail-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;padding-bottom:12px;display:flex}.complaint-detail-title{margin:0 0 4px;font-size:20px;font-weight:600}.complaint-detail-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:12px;font-size:13px;display:flex}.complaint-info-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px 24px;display:grid}.complaint-progress{flex-wrap:wrap;align-items:center;gap:4px;margin:8px 0 16px;display:flex}.complaint-progress-step{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.complaint-progress-step.active{color:var(--accent);font-weight:500}.complaint-progress-dot{background:var(--border);border-radius:50%;width:10px;height:10px}.complaint-progress-step.active .complaint-progress-dot{background:var(--accent)}.complaint-progress-separator{background:var(--border);width:18px;height:1px}.complaint-batch-result{border-radius:var(--radius-sm);padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.complaint-batch-result[data-result=OK]{color:var(--success,#22c55e);background:#22c55e1a}.complaint-batch-result[data-result=NOK]{color:var(--danger,#ef4444);background:#ef44441a}.complaint-batch-result[data-result=PARTIAL]{color:var(--warning,#f59e0b);background:#f59e0b1a}.complaint-attachment-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-secondary);align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:flex}.complaint-attachment-item+.complaint-attachment-item{margin-top:6px}.complaint-attachment-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}

