/* panels.css — all panel interiors */

.panel {
  background: var(--bg-panel);
  border: 0.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 12px;
  overflow: hidden;
}

.panel-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 8px;
}
.panel-hint {
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-dim);
  font-size: 10px;
}
.panel-hint em { font-style: italic; color: var(--accent); }

/* ── Code panel ── */
.code-scroll {
  flex: 1;
  overflow-y: auto;
  background: var(--bg);
  border-radius: var(--radius);
  border: 0.5px solid var(--border);
  min-height: 0;
}
.code-pre {
  font-family: var(--font-mono);
  font-size: 11.5px;
  line-height: 1.9;
  padding: 10px 0;
  white-space: pre;
  /* allow spans to stretch full width */
  display: block;
}
.code-line {
  display: block;
  min-width: 100%;
  width: max-content;
  padding: 0 14px;
  border-left: 2px solid transparent;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
  color: #6a7390;
  box-sizing: border-box;
}
.code-line--active {
  background: #1a2744;
  border-left-color: var(--accent);
  color: var(--text);
}
.code-line--active .code-kw  { color: #c9d8ff; }
.code-line--active .code-cmt { color: #7a9aaa; }

.code-line--changed {
  background: var(--amber-lo);
  border-left-color: var(--amber);
  color: #f5c86a;
}
.code-line--result {
  background: var(--green-lo);
  border-left-color: var(--green);
  color: var(--green);
}

.code-kw   { color: #c792ea; }
.code-fn   { color: #82aaff; }
.code-cmt  { color: #546e7a; font-style: italic; }
.code-num  { color: #f78c6c; }
.code-bool-t { color: var(--green); }
.code-bool-f { color: var(--red); }

.status-bar {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-muted);
  min-height: 18px;
  padding: 0 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── State arrays panel ── */
.arrays-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
.array-block { display: flex; flex-direction: column; }

.chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 2px;
}
.chip {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 3px 9px;
  border-radius: 16px;
  background: var(--bg-raised);
  border: 0.5px solid var(--border-hi);
  color: var(--text-muted);
  transition: all 0.25s;
}
.chip--active   { background: var(--accent-lo); border-color: var(--accent); color: var(--accent); font-weight: 700; }
.chip--result   { background: var(--green-lo);  border-color: var(--green);  color: var(--green);  font-weight: 700; }
.chip--included { background: var(--purple-lo); border-color: var(--purple); color: var(--purple); }

.kv-list { display: flex; flex-direction: column; gap: 3px; margin-top: 2px; }
.kv-row {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 3px 7px;
  border-radius: 4px;
  border-left: 2px solid transparent;
  transition: background 0.25s;
  color: var(--text-muted);
}
.kv-row .key  { color: var(--text-dim); }
.kv-row .val  { font-weight: 700; color: var(--text); }
.kv-row--active  { background: var(--accent-lo); border-left-color: var(--accent); }
.kv-row--active .val { color: var(--accent); }
.kv-row--changed { background: var(--amber-lo);  border-left-color: var(--amber); }
.kv-row--changed .val { color: var(--amber); }

/* ── Editor panel ── */
.editor-body { display: flex; flex-direction: column; gap: 8px; }
.editor-field { display: flex; flex-direction: column; gap: 4px; }
.field-label {
  font-size: 10px; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-muted);
}
.field-hint { font-weight: 400; letter-spacing: 0; text-transform: none; color: var(--text-dim); font-size: 10px; }
.text-input {
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--bg);
  border: 0.5px solid var(--border-hi);
  border-radius: var(--radius);
  padding: 7px 10px;
  color: var(--text);
  outline: none;
  transition: border-color 0.2s;
  width: 100%;
}
.text-input--short { width: 100px; }
.text-input:focus  { border-color: var(--accent); }
.editor-actions { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; }
.field-group    { display: flex; flex-direction: column; gap: 4px; }
.field-error    { font-size: 11px; color: var(--red); font-family: var(--font-mono); min-height: 16px; }
