/* Noise Type Identifier — tool-specific overrides only.
   MIC tool: classifies the dominant noise TYPE from spectral SHAPE (calibration-
   independent) and suggests a likely SOURCE category (a heuristic, not a diagnosis).
   Global components live in design-system.css; only genuinely unique styles are here. */

/* Honest caveat note in the hero (styled like the .X-warn-note pattern) */
.nti-warn-note {
  max-width: 820px; margin: var(--space-md) auto 0;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-border); border-left: 4px solid var(--color-warning);
  border-radius: var(--radius-sm); background: rgba(255, 179, 0, 0.05);
  color: var(--color-text-dim); font-size: 0.9rem; line-height: 1.55; text-align: left;
}
.nti-warn-note strong { color: var(--color-text); }

/* Two-column tool layout: controls/verdict on the left, spectrum on the right */
.nti-layout { display: grid; grid-template-columns: 1fr 1.25fr; gap: var(--space-lg); align-items: start; }
@media (max-width: 860px) { .nti-layout { grid-template-columns: 1fr; } }

.nti-h3 { font-size: 1.0rem; margin: 0 0 var(--space-sm); }
.nti-h3--mt { margin-top: var(--space-lg); }

/* Controls */
.nti-field { margin-bottom: var(--space-md); }
.nti-select {
  width: 100%; margin-top: 6px; 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.95rem;
}
.nti-select:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.18); }
.nti-consent { margin-top: var(--space-sm); font-size: 0.78rem; color: var(--color-text-muted); line-height: 1.5; }

.nti-status {
  margin-top: var(--space-md); padding: 8px 12px; border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); background: rgba(0, 255, 65, 0.02);
  font-family: var(--font-mono); font-size: 0.85rem; color: var(--color-text-dim); line-height: 1.5;
}
.nti-status.is-live { border-color: rgba(0, 255, 65, 0.4); color: var(--color-primary); }
.nti-status.is-error { border-color: rgba(255, 23, 68, 0.45); color: var(--color-error); }

/* Verdict block */
.nti-verdict {
  margin-top: var(--space-md); padding: var(--space-md); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); background: rgba(0, 255, 65, 0.03);
}
.nti-verdict__type {
  font-family: var(--font-display, 'Orbitron', sans-serif); font-size: 1.6rem;
  color: var(--color-text-dim); line-height: 1.1;
}
.nti-verdict__type.is-on { color: var(--color-primary); }
.nti-verdict__conf { margin-top: 4px; font-family: var(--font-mono); font-size: 0.8rem; color: var(--color-text-muted); }
.nti-verdict__desc { margin-top: var(--space-sm); font-size: 0.88rem; color: var(--color-text-dim); line-height: 1.55; }

.nti-source { margin-top: var(--space-sm); padding-top: var(--space-sm); border-top: 1px solid var(--color-border); }
.nti-source__label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-muted); }
.nti-source__val { margin-top: 2px; font-family: var(--font-mono); font-size: 1.05rem; color: var(--color-secondary, #00e5ff); }
.nti-source__tip { margin-top: 6px; font-size: 0.85rem; color: var(--color-text-dim); line-height: 1.55; }

/* Spectrum canvas */
.nti-canvas {
  display: block; width: 100%; height: 300px; border-radius: var(--radius-sm);
  background: #050a07; border: 1px solid var(--color-border);
}
.nti-legend { display: flex; flex-wrap: wrap; gap: var(--space-md); margin-top: var(--space-sm); font-size: 0.76rem; color: var(--color-text-muted); }
.nti-legend span { display: inline-flex; align-items: center; gap: 6px; }
.nti-dot { width: 12px; height: 12px; border-radius: 2px; display: inline-block; }
.nti-dot--spec { background: #00ff41; } .nti-dot--peak { background: #00e5ff; } .nti-dot--mains { background: #ffb300; }

/* Metric cells */
.nti-cells { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-sm); margin-top: var(--space-md); }
@media (max-width: 720px) { .nti-cells { grid-template-columns: repeat(2, 1fr); } }
.nti-cell { padding: 8px 12px; border: 1px solid var(--color-border); border-radius: var(--radius-sm); background: rgba(0, 255, 65, 0.02); }
.nti-cell__label { display: block; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-muted); }
.nti-cell__val { display: block; margin-top: 2px; font-family: var(--font-mono); font-size: 1.05rem; color: var(--color-primary); }

/* Calibration row (shared fd-noise-cal offset) */
.nti-cal { margin-top: var(--space-md); padding: var(--space-md); border: 1px dashed var(--color-border); border-radius: var(--radius-sm); }
.nti-cal__row { display: flex; flex-wrap: wrap; gap: var(--space-sm); align-items: flex-end; }
.nti-cal__field { flex: 1 1 150px; min-width: 130px; }
.nti-num {
  width: 100%; margin-top: 6px; padding: 9px 11px; 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.92rem;
}
.nti-num:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.18); }
.nti-cal__out { margin-top: var(--space-sm); font-family: var(--font-mono); font-size: 0.84rem; color: var(--color-text-muted); line-height: 1.5; }
.nti-cal__out.is-active { color: var(--color-primary); }
.nti-cal__note { margin-top: 6px; font-size: 0.78rem; color: var(--color-text-muted); line-height: 1.5; }
