/* Tempo Ear Trainer — tool-specific overrides only. Uses design-system tokens. */

/* honest caveat note (matches the .X-warn-note pattern used across the site) */
.tet-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-secondary);
  border-radius: var(--radius-sm);
  background: rgba(0, 255, 65, 0.04);
  color: var(--color-text-muted);
  font-size: 0.9rem;
  line-height: 1.55;
  text-align: left;
}
.tet-warn-note strong { color: var(--color-text); }

.tet-mono { font-family: var(--font-mono); color: var(--color-secondary); }

.tet-h2 {
  font-family: var(--font-display);
  color: var(--color-primary);
  font-size: 1.15rem;
  margin: 0 0 var(--space-md);
}
.tet-h3 {
  font-family: var(--font-display);
  color: var(--color-text-bright);
  font-size: 1rem;
  margin: 0 0 var(--space-sm);
}

/* setup row */
.tet-setup {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
.tet-field { display: flex; flex-direction: column; }
.tet-select {
  margin-top: 6px;
  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.95rem;
}
.tet-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.18);
}
.tet-volval { color: var(--color-primary); font-family: var(--font-mono); }

/* range inputs */
.tet-range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  margin-top: 8px;
  border-radius: var(--radius-full);
  background: var(--color-border);
  outline: none;
}
.tet-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: var(--glow-sm);
  cursor: pointer;
}
.tet-range::-moz-range-thumb {
  width: 20px; height: 20px;
  border: none;
  border-radius: 50%;
  background: var(--color-primary);
  box-shadow: var(--glow-sm);
  cursor: pointer;
}
.tet-range:focus-visible { box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.25); }

/* transport */
.tet-controls {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
}
.tet-play { min-width: 200px; }

.tet-status {
  margin: var(--space-md) 0;
  padding: var(--space-sm) var(--space-md);
  border-left: 3px solid var(--color-secondary);
  background: rgba(0, 229, 255, 0.04);
  color: var(--color-text);
  font-size: 0.95rem;
  line-height: 1.5;
}
.tet-status strong { color: var(--color-primary); }

/* ---- estimate mode ---- */
.tet-estimate { margin-top: var(--space-md); }
.tet-bpm-read {
  text-align: center;
  font-family: var(--font-display);
  font-size: 2.6rem;
  color: var(--color-primary);
  text-shadow: var(--glow-sm);
  margin-bottom: var(--space-sm);
  line-height: 1.1;
}
.tet-scale {
  display: flex;
  justify-content: space-between;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--color-text-muted);
}

.tet-numrow {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-md);
  flex-wrap: wrap;
}
.tet-num {
  width: 110px;
  padding: 8px 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: 1rem;
}
.tet-num:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.18);
}

.tet-taprow {
  display: flex;
  gap: var(--space-md);
  align-items: center;
  margin-top: var(--space-md);
  flex-wrap: wrap;
}
.tet-tap { min-width: 160px; }
.tet-tapinfo {
  margin: var(--space-sm) 0 0;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.tet-submit { width: 100%; margin-top: var(--space-md); }

/* ---- compare mode ---- */
.tet-cmp-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin: var(--space-md) 0;
}
.tet-cmp-btn {
  padding: var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: 1.05rem;
  cursor: pointer;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.tet-cmp-btn:hover:not(:disabled) {
  transform: translateY(-2px);
  border-color: var(--color-border-glow);
  box-shadow: var(--glow-sm);
}
.tet-cmp-btn[aria-pressed="true"] {
  border-color: var(--color-primary);
  color: var(--color-primary);
  box-shadow: var(--glow-sm);
}
.tet-cmp-btn:focus-visible {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.25);
}
.tet-cmp-btn:disabled { opacity: 0.55; cursor: default; }

.tet-cmp-answers {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}
.tet-choice {
  padding: var(--space-sm) var(--space-xs);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 0.9rem;
  cursor: pointer;
  transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.tet-choice:hover:not(:disabled) {
  transform: translateY(-2px);
  border-color: var(--color-border-glow);
  box-shadow: var(--glow-sm);
}
.tet-choice:focus-visible {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(0, 255, 65, 0.25);
}
.tet-choice:disabled { cursor: default; }
.tet-choice--correct {
  border-color: var(--color-success);
  color: var(--color-success);
  box-shadow: 0 0 12px rgba(0, 230, 118, 0.35);
}
.tet-choice--wrong {
  border-color: var(--color-error);
  color: var(--color-error);
  box-shadow: 0 0 12px rgba(255, 23, 68, 0.3);
}

/* ---- reveal panel ---- */
.tet-reveal {
  margin: var(--space-md) 0;
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-alt);
  text-align: center;
}
.tet-reveal__name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  margin-bottom: var(--space-xs);
}
.tet-reveal__name--ok { color: var(--color-success); }
.tet-reveal__name--no { color: var(--color-warning); }
.tet-reveal__detail {
  font-family: var(--font-mono);
  color: var(--color-text-muted);
  font-size: 0.9rem;
  margin-bottom: var(--space-md);
  line-height: 1.5;
}
.tet-next { min-width: 200px; }

/* ---- scoreboard ---- */
.tet-scoreboard {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-sm);
  margin: var(--space-lg) 0 var(--space-md);
}
.tet-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  text-align: center;
}
.tet-stat__num {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--color-primary);
  line-height: 1.1;
}
.tet-stat__label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  margin-top: 2px;
}

.tet-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
}

.tet-saved {
  margin-top: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-sm);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

/* ---- reference tempos ---- */
.tet-refbox {
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--color-border);
}
.tet-reflist {
  list-style: none;
  margin: 0 0 var(--space-sm);
  padding: 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-sm);
}
.tet-ref {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-sm) var(--space-xs);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  text-align: center;
}
.tet-ref__bpm {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--color-primary);
}
.tet-ref__label {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 2px;
}

@media (max-width: 640px) {
  .tet-setup { grid-template-columns: 1fr; }
  .tet-scoreboard { grid-template-columns: repeat(2, 1fr); }
  .tet-reflist { grid-template-columns: repeat(2, 1fr); }
  .tet-cmp-answers { grid-template-columns: 1fr; }
  .tet-play, .tet-next, .tet-tap { min-width: 100%; }
}
