/* Noise Comparison Tool — tool-specific overrides only.
   Shared tokens/components live in design-system.css. Prefix: ncmp */

.ncmp-warn {
  max-width: 780px;
  margin: var(--space-md) auto 0;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-warning);
  border-left: 4px solid var(--color-warning);
  border-radius: var(--radius-sm);
  background: rgba(255, 179, 0, 0.07);
  color: #ffd479;
  font-size: 0.9rem;
  line-height: 1.55;
  text-align: left;
}
.ncmp-warn strong { color: #ffe6a8; }

/* Top controls row */
.ncmp-toprow {
  display: grid;
  grid-template-columns: 1.4fr 1fr auto;
  gap: var(--space-md);
  align-items: end;
}
@media (max-width: 720px) {
  .ncmp-toprow { grid-template-columns: 1fr; }
}
.ncmp-select,
.ncmp-num {
  width: 100%;
  padding: 10px 12px;
  background: var(--color-bg);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 0.9rem;
}
.ncmp-controls {
  display: flex;
  gap: var(--space-sm);
}
.ncmp-controls .btn { white-space: nowrap; }

/* Status lines */
.ncmp-status,
.ncmp-live {
  margin-top: var(--space-md);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--color-border);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  min-height: 1.2em;
}
.ncmp-live { margin-top: 8px; color: var(--color-secondary); }
.ncmp-status.is-live { border-color: var(--color-primary); color: var(--color-primary); }
.ncmp-status.is-error { border-color: var(--color-error); color: #ff8a9b; }

/* Capture buttons */
.ncmp-capbtns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
@media (max-width: 560px) {
  .ncmp-capbtns { grid-template-columns: 1fr; }
}
.ncmp-capbtn { width: 100%; }
.ncmp-capbtn--a {
  background: #00ff41;
  border-color: #00ff41;
}
.ncmp-capbtn--b {
  background: #00e5ff;
  border-color: #00e5ff;
  color: #04222a;
}

/* Key chips (A green / B cyan) */
.ncmp-key {
  display: inline-block;
  padding: 0 7px;
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 0.85em;
}
.ncmp-key--a { background: rgba(0, 255, 65, 0.15); color: #00ff41; border: 1px solid rgba(0, 255, 65, 0.5); }
.ncmp-key--b { background: rgba(0, 229, 255, 0.15); color: #00e5ff; border: 1px solid rgba(0, 229, 255, 0.5); }

/* Spectrum plot */
.ncmp-plot-wrap {
  margin-top: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  background: rgba(0, 0, 0, 0.25);
}
.ncmp-plot-title {
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
}
.ncmp-canvas {
  display: block;
  width: 100%;
  height: 260px;
  border-radius: var(--radius-sm);
  background: #020308;
}

/* Verdict banner */
.ncmp-verdict {
  margin-top: var(--space-lg);
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.02);
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--color-text);
}
.ncmp-verdict.is-better { border-left-color: var(--color-success); background: rgba(0, 230, 118, 0.06); }
.ncmp-verdict.is-worse { border-left-color: var(--color-error); background: rgba(255, 23, 68, 0.06); }
.ncmp-verdict.is-neutral { border-left-color: var(--color-secondary); background: rgba(0, 229, 255, 0.05); }

/* Comparison table */
.ncmp-table-wrap {
  margin-top: var(--space-lg);
  overflow-x: auto;
}
.ncmp-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 0.9rem;
}
.ncmp-table th,
.ncmp-table td {
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  text-align: left;
  white-space: nowrap;
}
.ncmp-table thead th {
  background: rgba(0, 255, 65, 0.04);
  color: var(--color-text-bright);
  font-weight: 600;
}
.ncmp-table tbody th {
  color: var(--color-text-muted);
  font-weight: 400;
}
.ncmp-table td { color: var(--color-text); }
.ncmp-delta { color: var(--color-secondary); font-weight: 600; }
.ncmp-na { color: var(--color-text-muted); }

/* Actions */
.ncmp-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

/* Calibration disclosure */
.ncmp-cal {
  margin-top: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.2);
}
.ncmp-cal__summary {
  cursor: pointer;
  padding: var(--space-md);
  font-family: var(--font-mono);
  font-size: 0.9rem;
  color: var(--color-secondary);
}
.ncmp-cal__summary:hover { color: var(--color-primary); }
.ncmp-cal__body { padding: 0 var(--space-md) var(--space-md); }
.ncmp-cal__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-sm);
}
@media (max-width: 640px) {
  .ncmp-cal__grid { grid-template-columns: 1fr; }
}
.ncmp-cal__actions {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-md);
  flex-wrap: wrap;
}
.ncmp-cal__state {
  margin-top: var(--space-md);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--color-border);
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--color-text-muted);
}
.ncmp-cal__state.is-on { border-color: var(--color-primary); color: var(--color-primary); }
