/* Perfect Pitch Test — tool-specific overrides only.
   Shared tokens/components live in design-system.css. Prefix: ppt */

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

.ppt-h3 {
  font-family: var(--font-mono);
  color: var(--color-primary);
  margin-bottom: var(--space-md);
}

/* ---- setup ---- */
.ppt-setup {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}
.ppt-field { min-width: 0; }
.ppt-field .input-label { display: block; margin-bottom: 6px; }

.ppt-segmented {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.ppt-seg {
  flex: 1 1 0;
  min-width: 96px;
  padding: 10px 8px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text-dim);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  cursor: pointer;
  transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}
.ppt-seg:hover { color: var(--color-text); }
.ppt-seg--on {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(0, 255, 65, 0.08);
}

.ppt-select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-mono);
  font-size: 0.9rem;
}
.ppt-range { width: 100%; margin-top: 8px; accent-color: var(--color-primary); }
.ppt-volval { color: var(--color-secondary); font-family: var(--font-mono); }

/* ---- round ---- */
.ppt-round { margin-top: var(--space-lg); }

.ppt-roundbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  font-family: var(--font-mono);
  font-size: 0.9rem;
  color: var(--color-text-dim);
  margin-bottom: var(--space-md);
}
.ppt-running { color: var(--color-secondary); font-variant-numeric: tabular-nums; }

.ppt-stage {
  text-align: center;
  padding: var(--space-lg) var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: rgba(0, 255, 65, 0.03);
  transition: border-color 0.15s ease, background 0.15s ease;
}
.ppt-stage[data-state="played"] {
  border-color: var(--color-secondary);
  background: rgba(0, 229, 255, 0.06);
}
.ppt-stage[data-state="correct"] {
  border-color: var(--color-primary);
  background: rgba(0, 255, 65, 0.09);
}
.ppt-stage[data-state="wrong"] {
  border-color: #ff5c5c;
  background: rgba(255, 92, 92, 0.07);
}
.ppt-stage__icon { font-size: 2.4rem; line-height: 1; }
.ppt-stage__hint {
  margin-top: 8px;
  font-size: 0.92rem;
  color: var(--color-text-dim);
}

.ppt-playrow {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.ppt-playrow .btn { width: 100%; }

/* ---- choices ---- */
.ppt-choices {
  border: none;
  padding: 0;
  margin: var(--space-md) 0 0;
  min-width: 0;
}
.ppt-choices[disabled] { opacity: 0.5; }
.ppt-choices__legend {
  padding: 0;
  margin-bottom: var(--space-sm);
  font-family: var(--font-mono);
  font-size: 0.9rem;
  color: var(--color-text);
}

.ppt-notes {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
}
.ppt-note {
  padding: 12px 4px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-mono);
  font-size: 0.95rem;
  cursor: pointer;
  transition: border-color 0.12s ease, color 0.12s ease, background 0.12s ease;
}
.ppt-note:hover { border-color: var(--color-secondary); }
.ppt-note--on {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
  background: rgba(0, 229, 255, 0.1);
}
.ppt-note--correct {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(0, 255, 65, 0.14);
}
.ppt-note--miss {
  border-color: #ff5c5c;
  color: #ff8a8a;
  background: rgba(255, 92, 92, 0.12);
}

.ppt-octwrap { margin-top: var(--space-md); }
.ppt-octwrap .input-label { display: block; margin-bottom: 6px; }
.ppt-octrow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.ppt-octbtn {
  padding: 10px 4px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  cursor: pointer;
  transition: border-color 0.12s ease, color 0.12s ease, background 0.12s ease;
}
.ppt-octbtn:hover { border-color: var(--color-secondary); }
.ppt-octbtn--on {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
  background: rgba(0, 229, 255, 0.1);
}
.ppt-octbtn--correct {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(0, 255, 65, 0.14);
}
.ppt-octbtn--miss {
  border-color: #ff5c5c;
  color: #ff8a8a;
  background: rgba(255, 92, 92, 0.12);
}

.ppt-feedback {
  margin-top: var(--space-md);
  min-height: 1.4em;
  font-family: var(--font-mono);
  font-size: 0.95rem;
  text-align: center;
  color: var(--color-text-dim);
}
.ppt-feedback--right { color: var(--color-primary); }
.ppt-feedback--wrong { color: #ff8a8a; }

.ppt-nextrow {
  display: flex;
  gap: var(--space-sm);
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin-top: var(--space-md);
}
.ppt-nextrow .btn { flex: 1 1 auto; }

/* ---- results ---- */
.ppt-results { margin-top: var(--space-lg); }
.ppt-scorebox {
  text-align: center;
  padding: var(--space-lg) var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: rgba(0, 255, 65, 0.04);
}
.ppt-scorebox__pct {
  font-family: var(--font-mono);
  font-size: clamp(2.8rem, 11vw, 4rem);
  line-height: 1;
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.ppt-scorebox__frac {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 0.95rem;
  color: var(--color-secondary);
}
.ppt-scorebox__verdict {
  margin-top: var(--space-sm);
  font-size: 0.95rem;
  color: var(--color-text);
}
.ppt-scorebox__verdict--high { color: var(--color-primary); }
.ppt-scorebox__verdict--mid { color: var(--color-secondary); }
.ppt-scorebox__verdict--low { color: var(--color-text-dim); }

.ppt-context {
  margin-top: var(--space-md);
  display: grid;
  gap: var(--space-sm);
}
.ppt-context__row {
  padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: rgba(0, 229, 255, 0.04);
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--color-text);
}
.ppt-context__note {
  padding: 10px 12px;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 0.84rem;
  line-height: 1.5;
  color: var(--color-text-dim);
}

.ppt-best {
  margin-top: var(--space-md);
  padding: 8px 12px;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-text-dim);
}

.ppt-actions {
  display: flex;
  gap: var(--space-sm);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-md);
}

@media (min-width: 620px) {
  .ppt-setup { grid-template-columns: 1fr 1fr; }
  .ppt-setup .ppt-field:first-child { grid-column: 1 / -1; }
}
@media (max-width: 480px) {
  .ppt-notes { grid-template-columns: repeat(4, 1fr); }
  .ppt-playrow { grid-template-columns: 1fr; }
}
