/* Call tester page — uses toolbox.css for theming + topbar. */

.ct-main {
  max-width: 1080px;
  margin: 0 auto;
  padding: 32px 28px 80px;
}
.ct-header { margin-bottom: 24px; }
.ct-header h1 {
  font-size: 28px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}
.ct-header p { color: var(--text2); font-size: 13px; }

.card {
  background: var(--surf);
  border: 1px solid var(--br);
  border-radius: var(--rl);
  padding: 22px 24px;
  margin-bottom: 16px;
  box-shadow: var(--shadow);
}
.card-h { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.card-h h2 { font-size: 14px; font-weight: 700; color: var(--text); }
.cdot { width: 9px; height: 9px; border-radius: 50%; }
.cdot.blue   { background: var(--blue); }
.cdot.green  { background: var(--green); }
.cdot.teal   { background: var(--teal); }
.cdot.purple { background: var(--purple); }
.cdot.amber  { background: var(--amber); }
.cdot.red    { background: var(--red); }

.row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 12px;
}
label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 11px;
  color: var(--text2);
  letter-spacing: 0.4px;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
}
label.full { grid-column: 1 / -1; }

input[type="text"],
input[type="number"],
input[type="password"],
select,
textarea {
  background: var(--surf2);
  border: 1px solid var(--br);
  color: var(--text);
  padding: 9px 11px;
  border-radius: var(--r);
  font-size: 13px;
  font-family: 'DM Mono', monospace;
  width: 100%;
  outline: none;
  transition: border-color 0.15s;
}
input:focus, select:focus, textarea:focus { border-color: var(--blue); }
textarea { font-size: 12px; min-height: 80px; resize: vertical; }

.creds-block { padding-top: 8px; padding-bottom: 4px; border-top: 1px dashed var(--br); margin-top: 12px; }
.creds-block.hidden { display: none; }
.hint { font-size: 11px; color: var(--text3); margin-bottom: 10px; line-height: 1.5; }
.hint code { background: var(--surf2); padding: 1px 5px; border-radius: 3px; }

.oauth-refresh { margin-top: 12px; border: 1px dashed var(--br); border-radius: 6px; padding: 6px 12px 10px; }
.oauth-refresh > summary { cursor: pointer; padding: 6px 0; color: var(--text2); font-size: 12px; user-select: none; }
.oauth-refresh > summary::marker { color: var(--blue); }
.oauth-refresh[open] > summary { color: var(--blue); margin-bottom: 6px; }

.actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

button, .link-btn, .results-actions a {
  background: var(--surf2);
  border: 1px solid var(--br);
  color: var(--text);
  font-size: 12px;
  font-family: 'DM Mono', monospace;
  padding: 8px 14px;
  border-radius: var(--r);
  cursor: pointer;
  transition: all 0.12s;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
button:hover, .link-btn:hover, .results-actions a:hover {
  background: var(--surf3);
  color: var(--text);
  border-color: var(--br2);
}
button.primary, .results-actions a.primary {
  background: var(--blue);
  color: #001A2E;
  border-color: var(--blue);
  font-weight: 600;
}
button.primary:hover, .results-actions a.primary:hover { background: var(--blue2); border-color: var(--blue2); color: #001A2E; }
button.ghost { background: transparent; }
button:disabled { opacity: 0.4; cursor: not-allowed; }

.status { font-size: 12px; color: var(--text2); padding: 6px 10px; border-radius: var(--r); }
.status.ok    { color: var(--green); background: color-mix(in srgb, var(--green) 14%, transparent); }
.status.error { color: var(--red);   background: color-mix(in srgb, var(--red) 14%, transparent); }
.status.warn  { color: var(--amber); background: color-mix(in srgb, var(--amber) 14%, transparent); }

.hidden { display: none; }

/* Run progress counts */
.run-progress { margin-top: 14px; padding-top: 14px; border-top: 1px dashed var(--br); }
.run-counts {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
}
.count {
  background: var(--surf2);
  border: 1px solid var(--br);
  border-radius: var(--r);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.count b {
  font-size: 22px;
  font-weight: 700;
  font-family: 'Syne', sans-serif;
  color: var(--text);
}
.count i {
  font-style: normal;
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text3);
}
.count[data-k="answered"] b { color: var(--green); }
.count[data-k="no_ans"]   b { color: var(--amber); }
.count[data-k="busy"]     b { color: #F5C518; }
.count[data-k="rejected"] b { color: var(--red); }
.count[data-k="error"]    b { color: var(--purple); }

/* Results table */
.results-actions { display: flex; gap: 8px; margin-bottom: 14px; }
.results-actions.hidden { display: none; }

.table-wrap {
  overflow-x: auto;
  max-height: 420px;
  overflow-y: auto;
  border: 1px solid var(--br);
  border-radius: var(--r);
}
table#results { width: 100%; border-collapse: collapse; font-size: 12px; }
table#results th, table#results td {
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--br);
}
table#results th {
  background: var(--surf2);
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text3);
  font-family: 'DM Mono', monospace;
  position: sticky;
  top: 0;
  z-index: 1;
}
table#results td { font-family: 'DM Mono', monospace; }
table#results .empty td { text-align: center; color: var(--text3); padding: 24px; }

.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
}
.badge.answered { background: color-mix(in srgb, var(--green) 18%, transparent); color: var(--green); }
.badge.no-answer { background: color-mix(in srgb, var(--amber) 18%, transparent); color: var(--amber); }
.badge.busy { background: rgba(245, 197, 24, 0.18); color: #F5C518; }
.badge.rejected { background: color-mix(in srgb, var(--red) 18%, transparent); color: var(--red); }
.badge.error { background: color-mix(in srgb, var(--purple) 18%, transparent); color: var(--purple); }

@media (max-width: 720px) {
  .run-counts { grid-template-columns: repeat(3, 1fr); }
}
