/* ========== QA DASHBOARD ========== */
.qa-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 24px;
}
.qa-title { font-size: 24px; font-weight: 800; letter-spacing: -0.5px; }
.qa-subtitle { font-size: 13px; color: var(--text-muted); margin-top: 4px; }
.qa-refresh-btn {
  background: var(--primary-dim); color: var(--primary);
  border: 1px solid var(--primary); border-radius: 10px;
  padding: 8px 20px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all 0.15s;
}
.qa-refresh-btn:hover { background: var(--primary); color: #000; }
.qa-body { display: flex; flex-direction: column; gap: 24px; }
.qa-loading {
  text-align: center; padding: 40px; color: var(--text-muted);
  font-size: 14px; display: flex; align-items: center; justify-content: center; gap: 12px;
}
.qa-section {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 16px; padding: 20px;
}
.qa-section-title {
  font-size: 14px; font-weight: 700; margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px;
}

/* Provider grid */
.qa-providers-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 10px;
}
.qa-provider-card {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border-radius: 10px;
  background: var(--surface2); border: 1px solid var(--border);
  transition: all 0.15s;
}
.qa-provider-card.healthy { border-left: 3px solid var(--success); }
.qa-provider-card.unhealthy { border-left: 3px solid var(--error); opacity: 0.7; }
.qa-provider-card.offline { border-left: 3px solid var(--text-dim); opacity: 0.5; }
.qa-provider-icon { font-size: 18px; min-width: 24px; text-align: center; }
.qa-provider-info { flex: 1; min-width: 0; }
.qa-provider-name { font-size: 13px; font-weight: 600; text-transform: capitalize; }
.qa-provider-model { font-size: 11px; color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.qa-provider-status { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; }
.qa-provider-card.healthy .qa-provider-status { color: var(--success); }
.qa-provider-card.unhealthy .qa-provider-status { color: var(--error); }

/* Services grid */
.qa-services-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
}
.qa-service-card {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; padding: 16px; border-radius: 12px;
  background: var(--surface2); border: 1px solid var(--border);
  text-align: center; transition: all 0.2s;
}
.qa-service-card.online { border-bottom: 2px solid var(--success); }
.qa-service-card.offline { border-bottom: 2px solid var(--error); }
.qa-service-icon { font-size: 24px; }
.qa-service-name { font-size: 13px; font-weight: 600; }
.qa-service-status { font-size: 11px; display: flex; align-items: center; gap: 6px; }

/* QA runs list */
.qa-runs-list { display: flex; flex-direction: column; gap: 4px; }
.qa-run-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 8px;
  background: var(--surface2); font-size: 13px;
}
.qa-run-item.success { border-left: 3px solid var(--success); }
.qa-run-item.error { border-left: 3px solid var(--error); }
.qa-run-item.running { border-left: 3px solid var(--warning); }
.qa-run-icon { font-size: 16px; }
.qa-run-id { font-weight: 600; min-width: 60px; }
.qa-run-date { flex: 1; color: var(--text-muted); }
.qa-run-duration { min-width: 60px; text-align: right; color: var(--text-dim); }
.qa-run-status { min-width: 60px; text-align: right; font-weight: 600; text-transform: uppercase; font-size: 11px; }
.qa-run-item.success .qa-run-status { color: var(--success); }
.qa-run-item.error .qa-run-status { color: var(--error); }

/* Quick tests */
.qa-quick-tests { display: flex; gap: 10px; flex-wrap: wrap; }
.qa-test-btn {
  padding: 10px 18px; border-radius: 10px;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--text); font-size: 13px; font-weight: 500;
  cursor: pointer; transition: all 0.15s;
}
.qa-test-btn:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-dim); }
.qa-test-result { margin-top: 12px; }
.qa-test-pass {
  padding: 12px 16px; border-radius: 10px;
  background: var(--success-dim); border: 1px solid var(--success);
  color: var(--success); font-size: 13px;
}
.qa-test-fail {
  padding: 12px 16px; border-radius: 10px;
  background: var(--error-dim); border: 1px solid var(--error);
  color: var(--error); font-size: 13px;
}
.qa-testing { color: var(--text-muted); font-size: 13px; display: flex; align-items: center; gap: 8px; }
.qa-empty {
  text-align: center; padding: 24px; color: var(--text-dim);
  font-size: 13px; font-style: italic;
}
.qa-footer {
  text-align: center; font-size: 11px; color: var(--text-dim);
  padding: 8px 0;
}

/* Mobile */
@media (max-width: 768px) {
  .qa-header { flex-direction: column; gap: 12px; align-items: flex-start; }
  .qa-providers-grid { grid-template-columns: 1fr; }
  .qa-services-grid { grid-template-columns: repeat(2, 1fr); }
  .qa-quick-tests { flex-direction: column; }
  .qa-run-date { display: none; }
}
