.json-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.json-btn {
  padding: 7px 16px;
  border: 1.5px solid var(--accent);
  border-radius: 6px;
  background: transparent;
  color: var(--accent);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.json-btn:hover { background: var(--accent); color: #fff; }

.json-btn-clear {
  border-color: var(--muted);
  color: var(--muted);
}
.json-btn-clear:hover { background: var(--muted); color: #fff; }

.json-status {
  font-size: 0.85rem;
  margin-left: auto;
}
.json-status.ok  { color: #22c55e; }
.json-status.err { color: #ef4444; }

.json-editors {
  display: flex;
  gap: 16px;
}
@media (max-width: 640px) {
  .json-editors { flex-direction: column; }
}

.json-editor-wrap { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.json-editor-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 6px;
}

.json-editor {
  flex: 1;
  min-height: 360px;
  resize: vertical;
  box-sizing: border-box;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 12px;
  font-size: 0.85rem;
  font-family: 'Cascadia Code', 'Fira Mono', 'Consolas', monospace;
  background: var(--bg);
  color: var(--text);
  outline: none;
  transition: border-color .15s;
  line-height: 1.5;
}
.json-editor:focus { border-color: var(--accent); }
.json-output { background: var(--input-bg, #f8f8f8); }
