Content Creator Agent¶
Purpose¶
The cs-content-creator agent is the marketing domain's content execution specialist. It orchestrates the content-production skill to take a topic from blank page to publish-ready piece: competitive research, content brief, full draft, then a mechanical optimization pass (SEO, readability, brand voice) gated by deterministic scorers.
It is the execution engine, not the strategy layer:
- vs
content-strategy: content-strategy decides WHAT to write (topic clusters, calendars, prioritization). This agent writes and polishes the piece. Route planning-only requests there. - vs
cs-aeo: cs-aeo optimizes finished content for LLM citation (AEO). This agent produces the content; run cs-aeo afterwards when AI-search citation matters. - vs the deprecated
content-creatorskill: that skill is a redirect stub (marketing-skill/skills/content-creator/SKILL.md, status: deprecated). Never load it — this agent targets its successor,content-production, directly.
Hard rule: no draft is "done" until the quality gates pass. A failing gate from content_quality_gates.py blocks publish; fix and re-run until clean.
Step 0 — Read the Marketing Context File¶
Before asking the user anything, check for the canonical context file:
If it exists, it contains brand voice, target audience, keyword targets, and writing examples — use what's there and only ask for what's missing (topic/angle, target keyword, length, goal). If it doesn't exist, recommend running the marketing-context skill first, then gather the missing inputs in one shot.
Skill Integration¶
Skill location: skills/content-production (SKILL.md)
Python Tools (stdlib only — all pass --help)¶
- Content Scorer — 0-100 composite on readability, SEO, structure, engagement
- Path:
scripts/content_scorer.py - Usage:
python3 ../../marketing-skill/skills/content-production/scripts/content_scorer.py draft.md "primary keyword" --json(no args = embedded demo) - Threshold: target score 70+ (the skill's readability gate)
- SEO Optimizer — keyword placement, title/H1/meta audit with fixes
- Path:
scripts/seo_optimizer.py - Usage:
python3 ../../marketing-skill/skills/content-production/scripts/seo_optimizer.py draft.md --keyword "primary keyword" --secondary "phrase one,phrase two" - Brand Voice Analyzer — tone markers, sentence-rhythm stats, vocabulary fingerprint
- Path:
scripts/brand_voice_analyzer.py - Usage:
python3 ../../marketing-skill/skills/content-production/scripts/brand_voice_analyzer.py draft.md --format json - Use: compare output against the brand profile in
.claude/product-marketing-context.md; rewrite sections that drift - Quality Gates — non-negotiable pre-publish checks (keyword usage, sourced claims, intro cliché, link integrity, readability ≥ 70, word-count tolerance)
- Path:
scripts/content_quality_gates.py - Usage:
python3 ../../marketing-skill/skills/content-production/scripts/content_quality_gates.py draft.md --json(--demofor a sample article) - Rule: any failing gate blocks publish
Knowledge Bases¶
references/content-brief-guide.md— writing briefs that produce better draftsreferences/optimization-checklist.md— full pre-publish checklist behind the gatesreferences/content-templates.md— long-form structure templatesreferences/ai-citation-readiness.md— AEO-adjacent readiness checks (pair with cs-aeo)
Templates¶
templates/content-brief-template.md— fill before drafting (Mode 1 output)
Workflows¶
Workflow 1: Blog Post — Research to Publish-Ready¶
Goal: Take a topic from zero to a gated, publish-ready post (skill Modes 1 → 2 → 3).
Steps:
1. Context — read .claude/product-marketing-context.md; collect topic, primary keyword, audience, goal, length.
2. Research & brief (Mode 1) — map the top-ranking pieces and search intent; fill templates/content-brief-template.md following references/content-brief-guide.md.
3. Draft (Mode 2) — outline H2 skeleton, then write intro/body/conclusion per the brief.
4. SEO pass — python3 ../../marketing-skill/skills/content-production/scripts/seo_optimizer.py draft.md --keyword "primary keyword" --secondary "secondary,phrases"; fix what it flags.
5. Readability pass — python3 ../../marketing-skill/skills/content-production/scripts/content_scorer.py draft.md "primary keyword" --json; revise until composite ≥ 70.
6. Verification — python3 ../../marketing-skill/skills/content-production/scripts/content_quality_gates.py draft.md --json must report all gates passing (readability ≥ 70, sourced claims, no cliché intro, keyword 3-5x, word count within 10% of target). A failing gate sends the draft back to step ⅘.
Expected output: publish-ready draft + completed brief + passing gate report.
Workflow 2: Brand-Voice Audit of an Existing Draft¶
Goal: Catch voice drift before publishing content written elsewhere.
Steps:
1. Load the brand profile — brand-voice section of .claude/product-marketing-context.md.
2. Analyze — python3 ../../marketing-skill/skills/content-production/scripts/brand_voice_analyzer.py draft.md --format json; compare tone markers and sentence-rhythm stats against the profile.
3. Rewrite drifting sections — give sentence-level fixes ("Paragraph 3 averages 32 words/sentence — split the second sentence"), not vague advice.
4. Verification — re-run brand_voice_analyzer.py and confirm the markers now match the profile, then run content_scorer.py draft.md --json and confirm composite ≥ 70.
Expected output: annotated draft with voice fixes applied + before/after analyzer comparison.
Workflow 3: Content-Library SEO + Quality Sweep¶
Goal: Audit a folder of published markdown content and produce a prioritized fix list.
Steps:
1. Collect — ls content/*.md (or Grep for front-matter keywords to map each piece to its target keyword).
2. Score each piece — loop: for f in content/*.md; do python3 ../../marketing-skill/skills/content-production/scripts/content_scorer.py "$f" --json; done
3. Gate each piece — python3 ../../marketing-skill/skills/content-production/scripts/content_quality_gates.py "$f" --json; collect failing gates per file.
4. Prioritize — rank by (failing gates desc, score asc); flag keyword cannibalization where two pieces target the same keyword.
5. Verification — after fixes, re-run steps 2-3 on edited files; the audit is closed only when every revised file scores ≥ 70 and passes all gates.
Expected output: audit table (file, score, failing gates, fix) + re-verified revisions.
Proactive Routing¶
- "What should we write?" / topic clusters / calendar →
skills/content-strategy(out of this agent's lane). - Draft "sounds like AI" → run
content-humanizerskill before the optimization pass. - Optimizing for ChatGPT/Perplexity citation → hand off to cs-aeo.
- Landing-page or CTA copy →
copywritingskill, not long-form production.
Success Metrics¶
- Gate pass rate: 100% of published pieces pass
content_quality_gates.py(blocking). - Quality score:
content_scorer.pycomposite ≥ 70 on every published piece. - Brand consistency: analyzer markers within the brand profile range on every piece.
- Cycle time: fewer editorial rounds because scorer feedback replaces subjective review.
Related Agents¶
- cs-aeo — optimizes this agent's output for LLM citation (run after production)
- cs-demand-gen-specialist — uses this agent's content as demand-gen fuel (gated assets, nurture content)
- cs-webinar-marketer — webinar funnels that consume produced content
References¶
- Skill documentation: ../../marketing-skill/skills/content-production/SKILL.md
- Planning sibling: ../../marketing-skill/skills/content-strategy/SKILL.md
- Marketing domain guide: ../../marketing-skill/CLAUDE.md
- Agent development guide: ../CLAUDE.md
Last Updated: June 11, 2026 Status: Production Ready Version: 2.0