/* Processing Speed — only test-specific overrides */
:root { --test-accent: #3fa8be; }
.t-intro-icon::before {
  content: 'rocket_launch';
}


/* ── STIMULUS BOX ── */
.ps-box {
  border-radius: 18px;
  min-height: 480px;
  background: var(--color-surface-container-low);
  border: 2.5px solid var(--color-outline-variant);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
  position: relative;
  overflow: hidden;
  margin-bottom: 24px;
  padding: 48px 24px;
  transition: background 0.1s, border-color 0.1s;
}

/* Target Area */
.ps-target-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.ps-target-label {
  font-family: 'Lexend', sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-muted);
}
.ps-target-icon {
  font-size: 48px !important;
  color: var(--test-accent);
  background: #fff;
  width: 100px;
  height: 100px;
  border-radius: 20px;
  border: 2.5px solid var(--test-accent);
  box-shadow: 0 10px 25px rgba(63, 168, 190, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 48;
}

/* Options Area */
.ps-options {
  display: flex;
  gap: 16px;
  justify-content: center;
  width: 100%;
}

.ps-btn {
  flex: none;
  width: 96px;
  height: 96px;
  background: #fff;
  border: 2px solid var(--color-outline-variant);
  border-bottom-width: 4px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.ps-btn span { font-size: 38px !important; color: var(--text); transition: color 0.1s; font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 48; }

.ps-btn:hover { border-color: var(--test-accent); background: var(--test-accent-soft); }
.ps-btn:active { transform: translateY(2px); border-bottom-width: 2px; }

/* Match states */
.ps-box[data-state="hit"] .ps-btn.correct { background: #2ecc71; border-color: #27ae60; color: #fff; transform: scale(1.05); }
.ps-box[data-state="hit"] .ps-btn.correct span { color: #fff; }

.ps-box[data-state="miss"] .ps-btn.wrong-tap { background: #e74c3c; border-color: #c0392b; }
.ps-box[data-state="miss"] .ps-btn.wrong-tap span { color: #fff; }
.ps-box[data-state="miss"] .ps-btn.correct { border-color: #2ecc71; background: #edfaf4; }
.ps-box[data-state="miss"] .ps-btn.correct span { color: #2ecc71; }

/* ── INTRO VISUAL MAPPING ── */
.ps-intro-visual {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  background: #f1f9fa;
  border: 2px dashed #bfe1e8;
  border-radius: 16px;
  padding: 20px;
  margin-bottom: 24px;
}

.ps-intro-rule {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.ps-intro-shape {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.ps-target-box {
  background: #fff;
  border: 2px solid var(--test-accent);
  color: var(--test-accent);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
}

.ps-option-box {
  background: #fff;
  border: 2px solid var(--color-outline-variant);
  color: var(--text);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 48px;
  height: 48px;
}

.ps-option-box.match {
  border-color: #2ecc71;
  color: #2ecc71;
  box-shadow: 0 0 0 4px rgba(35,193,107,0.15);
}

.ps-intro-text {
  font-family: 'Lexend', sans-serif;
  font-size: 13px;
  color: var(--text);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
}

.ps-intro-divider {
  color: var(--color-outline-variant);
  margin: -8px 0;
}

.rt-range-table { display: flex; flex-direction: column; gap: 8px; margin-top: 4px; }
.rt-range-row { display: grid; grid-template-columns: 10px 100px 1fr auto; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 8px; font-family: 'Lexend', sans-serif; font-size: 13px; }
.rt-range-dot { width: 10px; height: 10px; border-radius: 50%; }
.rt-range-label { font-weight: 700; color: var(--text); }
.rt-range-val { color: var(--text-muted); }
.rt-range-pct { font-weight: 700; text-align: right; }
.rt-range-row.elite  { background: #f0fdf4; } .rt-range-row.elite  .rt-range-dot { background: #2ecc71; } .rt-range-row.elite  .rt-range-pct { color: #2ecc71; }
.rt-range-row.fast   { background: #f0f9ff; } .rt-range-row.fast   .rt-range-dot { background: #0ea5e9; } .rt-range-row.fast   .rt-range-pct { color: #0ea5e9; }
.rt-range-row.avg    { background: #fafafa; } .rt-range-row.avg    .rt-range-dot { background: #f5a623; } .rt-range-row.avg    .rt-range-pct { color: #f5a623; }
.rt-range-row.slow   { background: #fef2f1; } .rt-range-row.slow   .rt-range-dot { background: #e74c3c; } .rt-range-row.slow   .rt-range-pct { color: #e74c3c; }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .ps-box { gap: 32px; padding: 32px 16px; min-height: 380px; }
  .ps-target-icon { width: 80px; height: 80px; font-size: 38px !important; border-radius: 16px; }
  .ps-options { gap: 14px; }
  .ps-btn { width: 78px; height: 78px; border-radius: 14px; border-bottom-width: 3px; }
  .ps-btn span { font-size: 32px !important; }
}

@media (max-width: 480px) {
  .ps-box { gap: 24px; padding: 24px 12px; min-height: 320px; }
  .ps-target-icon { width: 68px; height: 68px; font-size: 32px !important; border-radius: 12px; }
  .ps-options { gap: 10px; }
  .ps-btn { width: 64px; height: 64px; border-radius: 12px; border-bottom-width: 2.5px; }
  .ps-btn span { font-size: 26px !important; }
}

@media (max-width: 360px) {
  .ps-box { gap: 16px; padding: 16px 8px; min-height: 280px; }
  .ps-target-icon { width: 56px; height: 56px; font-size: 26px !important; border-radius: 10px; }
  .ps-options { gap: 6px; }
  .ps-btn { width: 52px; height: 52px; border-radius: 10px; border-bottom-width: 2px; }
  .ps-btn span { font-size: 22px !important; }
}

/* ── DARK MODE OVERRIDES ── */
html.dark .ps-target-icon,
html.dark .ps-btn,
html.dark .ps-target-box,
html.dark .ps-option-box {
  background: var(--color-surface-container-high) !important;
  border-color: var(--color-outline) !important;
  box-shadow: none !important;
}

html.dark .ps-target-icon {
  border-color: var(--test-accent) !important;
}

html.dark .ps-target-icon,
html.dark .ps-target-box {
  color: var(--test-accent) !important;
}

html.dark .ps-btn span,
html.dark .ps-option-box {
  color: var(--text) !important;
}

html.dark .ps-btn:hover {
  background: var(--test-accent-soft) !important;
  border-color: var(--test-accent) !important;
}

html.dark .ps-option-box.match {
  border-color: #2ecc71 !important;
  color: #2ecc71 !important;
  box-shadow: 0 0 0 4px rgba(35,193,107,0.2) !important;
}

html.dark .ps-box[data-state="hit"] .ps-btn.correct,
html.dark .ps-box[data-state="miss"] .ps-btn.correct {
  background: #2ecc71 !important;
  border-color: #27ae60 !important;
}
html.dark .ps-box[data-state="hit"] .ps-btn.correct span,
html.dark .ps-box[data-state="miss"] .ps-btn.correct span {
  color: #fff !important;
}

html.dark .ps-box[data-state="miss"] .ps-btn.wrong-tap {
  background: #e74c3c !important;
  border-color: #c0392b !important;
}
html.dark .ps-box[data-state="miss"] .ps-btn.wrong-tap span {
  color: #fff !important;
}
