jpskill.com
🎨 デザイン コミュニティ

blog-cluster

検索エンジンのデータに基づきキーワードをグループ化し、ハブ&スポーク型のブログ記事構造を自動で設計、記事間の内部リンクも最適化することで、ブログ戦略の実行を支援するSkill。

📜 元の英語説明(参考)

Semantic topic cluster planning and automated execution engine for claude-blog. Performs SERP-based keyword research, groups keywords by search intent and SERP overlap, builds a hub-and-spoke cluster architecture, generates an interactive SVG cluster map, and executes the full cluster by orchestrating blog-write calls with shared cluster context and automatic internal-link injection. Fills the strategy-to-execution gap: blog-strategy plans the blueprint, blog-cluster builds the house. Use when user says "blog cluster", "topic cluster", "content cluster", "cluster plan", "cluster execute", "pillar content", "hub and spoke", "content ecosystem", "cluster map".

🇯🇵 日本人クリエイター向け解説

一言でいうと

検索エンジンのデータに基づきキーワードをグループ化し、ハブ&スポーク型のブログ記事構造を自動で設計、記事間の内部リンクも最適化することで、ブログ戦略の実行を支援するSkill。

※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o blog-cluster.zip https://jpskill.com/download/10517.zip && unzip -o blog-cluster.zip && rm blog-cluster.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/10517.zip -OutFile "$d\blog-cluster.zip"; Expand-Archive "$d\blog-cluster.zip" -DestinationPath $d -Force; ri "$d\blog-cluster.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して blog-cluster.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → blog-cluster フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-18
取得日時
2026-05-18
同梱ファイル
1

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

ブログクラスター (セマンティックトピッククラスターエンジン)

単一のシードキーワードから、相互にリンクされたコンテンツエコシステム全体を計画し、実行します。3つのレイヤーがあります:セマンティッククラスタリング(頭脳)、クラスターアーキテクチャ(構造)、および実行エンジン(機械)。

Lutfiya Miller による semantic-cluster-engine の提出物から改変 (AI Marketing Hub Pro Challenge 受賞、2026年3月、95/100 模範的)。 オリジナルのリポジトリ: https://github.com/Drfiya/semantic-cluster-engine このポートは、Plan + Execute アーキテクチャとクラスターコンテキストの革新性を維持し、ブランド固有(ScienceExperts.ai)のスタイリングと画像プロンプトを削除し、claude-blog の既存のサブスキルを経由するようにルーティングします。

コマンド

コマンド 実行内容
/blog cluster インタラクティブ。計画するか実行するかを尋ねます。
/blog cluster plan <seed-keyword> SERP ベースのセマンティック分析。クラスター計画とマップを出力します。
/blog cluster plan --from strategy [path] 既存の blog-strategy クラスター構築計画をインポートし、SERP データに対して検証します。
/blog cluster execute [path-to-plan] クラスターコンテキストと自動相互リンクを使用した、連続的な blog-write 呼び出し。

主要な参考文献(オンデマンドでロード)

  • references/semantic-clustering.md (SERP オーバーラップ分析、インテント分類、キーワードユニバースの拡張)
  • references/cluster-architecture.md (ハブアンドスポークの仕様、スキーマ戦略、リンク密度ルール)
  • references/execution-workflow.md (実行順序、コンテキスト注入、スコアカード、エラー処理)

既存の claude-blog スキルへの相互参照

スキル このスキルが呼び出すタイミング
/blog strategy 上流の計画。plan --from strategy はそのクラスター構築計画テーブルを使用します。
/blog write 投稿ごとの実行。各スポークとピラーは、先頭にクラスターコンテキストブロックが付加された blog-write によって生成されます。
/blog chart インライン SVG チャートのために blog-write によって内部的に呼び出されます。このスキルからの直接呼び出しはありません。
/blog image 投稿ごとのオプションのヒーロー画像生成(nanobanana-mcp が構成されていない場合は、グレースフルフォールバック)。
/blog seo-check 実行後、投稿ごとのオンページ検証に推奨されます。
/blog cannibalization 実行後、クラスター全体でキーワードの重複がないことを確認するために推奨されます。
/blog schema 実行後、BreadcrumbListItemList、および Article スキーマを追加するために推奨されます。

このスキルは、他のスキルに属するファイルを変更することはありません。Task ツールを介して、またはオーケストレーションされたサブスキルとしてそれらを呼び出します。

コマンドルーティング

  1. ユーザーのコマンドを解析して、サブコマンドを決定します。
  2. ユーザーが /blog cluster のみを入力した場合、「新しいクラスターを 計画 しますか、それとも既存の計画を 実行 しますか?」と尋ねます。
  3. ルート:
    • plan <keyword> を計画フェーズ(下記)へ
    • plan --from strategy [path] を戦略インポートフロー(下記)へ
    • execute [path]build、または run を実行フェーズ(下記)へ

計画フェーズ: /blog cluster plan <seed-keyword>

参照: references/semantic-clustering.md

ステップ 1. シードキーワードの拡張

WebSearch を使用して、シードを 30〜50 のフレーズのキーワードユニバースに拡張します。

  1. <seed> の直接検索により、関連検索と「他の人はこちらも質問」をキャプチャします。
  2. ロングテール拡張: <seed> guide<seed> tips<seed> tools<seed> examples<seed> vsbest <seed>how to <seed>
  3. 質問マイニング: what is <seed>how does <seed> workwhy <seed><seed> for beginners
  4. インテントバリアント: 商業修飾子 (best, top, review, comparison, pricing)、情報修飾子 (guide, tutorial, explained, examples)、およびトランザクション修飾子 (buy, download, tool, software, service) を追加します。
  5. 年の鮮度: <seed> 2026

ステップ 2. セマンティッククラスタリング

references/semantic-clustering.md の優先順位ルールを使用して、拡張されたキーワードをグループ化します。

  1. SERP Overlap Analysis が主要なシグナルです。5 つ以上の共有トップ 10 結果を持つ 2 つのキーワードは、同じインテントをターゲットにしており、1 つの投稿に属します。
  2. Intent Classification は、各キーワードを情報、商業、トランザクション、またはナビゲーションに割り当てます。
  3. Entity Mapping は、Google がトピックに関連付ける人物、製品、フレームワーク、および組織を識別します。
  4. Grouping は、インテントとトピックの近接性を共有するキーワードを組み合わせます。各グループは、ハブアンドスポークの 1 つのブランチになります。

ステップ 3. クラスターアーキテクチャの設計

参照: references/cluster-architecture.md

ハブアンドスポークを構築します。

  • ピラー (ハブ): 最も広いキーワードをターゲットにします。ワード数 2,500〜4,000。テンプレート pillar-page。すべてのスポークにリンクダウンします。
  • スポーク: それぞれがロングテールクラスターをターゲットにします。ワード数 1,200〜1,800。テンプレートはインテントによって自動選択されます。ピラーにリンクアップし、兄弟にリンクします。

クラスター形成ルール:

  • ピラーあたり 2〜5 個のクラスター。
  • クラスターあたり 2〜4 個のスポーク。
  • 合計: 1 つのピラーと 5〜15 個のスポーク。
  • すべてのスポークは、一意のプライマリキーワードをターゲットにします(キーワードの重複なし)。

ステップ 4. 内部リンクマトリックス

各スポーク S について:

  • S からピラーへ (常に; アンカーテキストはピラーのプライマリキーワードを使用します)。
  • ピラーから S へ (常に; アンカーテキストは S のプライマリキーワードを使用します)。
  • S から同じクラスター内の他のスポークへ (それぞれ 2〜3 個のリンク、コンテキストアンカー)。
  • S から隣接するクラスター内のスポークへ (0〜1 個のリンク、セマンティックに関連する場合のみ)。

すべてのスポークに少なくとも 3 つの受信リンクがあることを確認します。計画された相互リンクの合計数をカウントします。

ステップ 5. 出力ファイルの生成

すべての計画および実行アーティファクトは、現在の作業ディレクトリの単一のサブディレクトリに格納されます。

<cwd>/
└── cluster-<seed-keyword-slug>/
    ├── cluster-plan.json
    ├── cluster-map.html
    ├── pillar-<slug>.md       (実行フェーズ)
    ├── <spoke-slug>.md        (実行フェーズ、スポークごとに 1 つ)
    └── cluster-scorecard.md   (実行フェーズ)

cluster-plan.json スキーマ

{
  "seed_keyword": "<seed>",
  "generated_at": "YYYY-MM-DDTHH:MM:SSZ",
  "pillar": {
    "id": "P",
    "title": "Title of the pillar",
    "prim
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

Blog Cluster (Semantic Topic Cluster Engine)

Plans and executes entire interlinked content ecosystems from a single seed keyword. Three layers: Semantic Clustering (the brain), Cluster Architecture (the structure), and Execution Engine (the machine).

Adapted from the semantic-cluster-engine submission by Lutfiya Miller (winner, AI Marketing Hub Pro Challenge, March 2026, 95/100 Exemplary). Original repository: https://github.com/Drfiya/semantic-cluster-engine This port keeps the Plan + Execute architecture and the cluster context innovation, removes brand-specific (ScienceExperts.ai) styling and image prompts, and routes through claude-blog's existing sub-skills.

Commands

Command What it does
/blog cluster Interactive. Asks whether to plan or execute.
/blog cluster plan <seed-keyword> SERP-based semantic analysis. Outputs cluster plan + map.
/blog cluster plan --from strategy [path] Imports existing blog-strategy cluster build plan and validates against SERP data.
/blog cluster execute [path-to-plan] Sequential blog-write calls with cluster context and auto-interlinks.

Key references (load on demand)

  • references/semantic-clustering.md (SERP overlap analysis, intent classification, keyword universe expansion)
  • references/cluster-architecture.md (hub-and-spoke specs, schema strategy, link-density rules)
  • references/execution-workflow.md (execution order, context injection, scorecard, failure handling)

Cross-references to existing claude-blog skills

Skill When this skill calls it
/blog strategy Upstream planning. plan --from strategy consumes its Cluster Build Plan tables.
/blog write Per-post execution. Each spoke and the pillar are produced by blog-write with a prepended cluster-context block.
/blog chart Invoked internally by blog-write for inline SVG charts. No direct call from this skill.
/blog image Optional hero image generation per post (graceful fallback if nanobanana-mcp is not configured).
/blog seo-check Recommended after execution for per-post on-page validation.
/blog cannibalization Recommended after execution to confirm zero keyword overlap across the cluster.
/blog schema Recommended after execution to add BreadcrumbList, ItemList, and Article schema.

This skill never modifies files belonging to other skills. It calls them via the Task tool or as orchestrated sub-skills.

Command Routing

  1. Parse the user's command to determine the sub-command.
  2. If the user typed only /blog cluster, ask: "Would you like to plan a new cluster or execute an existing plan?"
  3. Route:
    • plan <keyword> to the Plan Phase (below)
    • plan --from strategy [path] to the Strategy Import flow (below)
    • execute [path], build, or run to the Execute Phase (below)

Plan Phase: /blog cluster plan <seed-keyword>

Reference: references/semantic-clustering.md

Step 1. Seed keyword expansion

Use WebSearch to expand the seed into a keyword universe of 30 to 50 phrases:

  1. Direct search of <seed> to capture related searches and "People also ask".
  2. Long-tail expansion: <seed> guide, <seed> tips, <seed> tools, <seed> examples, <seed> vs, best <seed>, how to <seed>.
  3. Question mining: what is <seed>, how does <seed> work, why <seed>, <seed> for beginners.
  4. Intent variants: add commercial modifiers (best, top, review, comparison, pricing), informational modifiers (guide, tutorial, explained, examples), and transactional modifiers (buy, download, tool, software, service).
  5. Year freshness: <seed> 2026.

Step 2. Semantic clustering

Group the expanded keywords using the priority rules in references/semantic-clustering.md:

  1. SERP Overlap Analysis is the primary signal. Two keywords with 5 or more shared top-10 results target the same intent and belong in one post.
  2. Intent Classification assigns each keyword to informational, commercial, transactional, or navigational.
  3. Entity Mapping identifies the people, products, frameworks, and organizations Google associates with the topic.
  4. Grouping combines keywords that share intent and topical proximity. Each group becomes one branch of the hub and spoke.

Step 3. Cluster architecture design

Reference: references/cluster-architecture.md

Build the hub and spoke:

  • Pillar (hub): targets the broadest keyword. Word count 2,500 to 4,000. Template pillar-page. Links down to every spoke.
  • Spokes: each targets a long-tail cluster. Word count 1,200 to 1,800. Template auto-selected by intent. Links up to the pillar and across to siblings.

Cluster formation rules:

  • 2 to 5 clusters per pillar.
  • 2 to 4 spokes per cluster.
  • Total: 1 pillar plus 5 to 15 spokes.
  • Every spoke targets a unique primary keyword (zero cannibalization).

Step 4. Internal link matrix

For each spoke S:

  • S to Pillar (always; anchor text uses the pillar's primary keyword).
  • Pillar to S (always; anchor text uses S's primary keyword).
  • S to other spokes in the same cluster (2 to 3 links each, contextual anchors).
  • S to spokes in adjacent clusters (0 to 1 links, only when semantically relevant).

Verify every spoke has at least 3 incoming links. Count total planned interlinks.

Step 5. Generate output files

All plan and execute artifacts go into a single subdirectory of the current working directory:

<cwd>/
└── cluster-<seed-keyword-slug>/
    ├── cluster-plan.json
    ├── cluster-map.html
    ├── pillar-<slug>.md       (Execute Phase)
    ├── <spoke-slug>.md        (Execute Phase, one per spoke)
    └── cluster-scorecard.md   (Execute Phase)

cluster-plan.json schema

{
  "seed_keyword": "<seed>",
  "generated_at": "YYYY-MM-DDTHH:MM:SSZ",
  "pillar": {
    "id": "P",
    "title": "Title of the pillar",
    "primary_keyword": "broadest keyword",
    "secondary_keywords": ["..."],
    "search_volume_estimate": "high|medium|low",
    "template": "pillar-page",
    "word_count_target": 3000,
    "cluster": "pillar"
  },
  "clusters": [
    {
      "name": "Cluster A: Theme",
      "intent": "informational|commercial|transactional",
      "color": "#2563eb",
      "posts": [
        {
          "id": "A1",
          "title": "Post title",
          "primary_keyword": "long-tail keyword",
          "secondary_keywords": ["..."],
          "search_volume_estimate": "high|medium|low",
          "template": "how-to-guide",
          "word_count_target": 1500,
          "links_to": ["P", "A2"],
          "links_from": ["P", "A2"]
        }
      ]
    }
  ],
  "total_posts": 9,
  "total_interlinks": 23,
  "estimated_total_words": 18000
}

Note: volume estimates are relative indicators (high, medium, low) derived from SERP signals, not absolute search volumes. For precise data, the user should consult Ahrefs, SEMrush, or DataForSEO (claude-blog provides the seo-dataforseo companion sibling).

cluster-map.html (XSS-safe)

A static, self-contained HTML file with an embedded SVG visualization. Hard rules for the writer:

  • No inline <script> blocks. No onclick, onmouseover, or any on* event attributes anywhere in the document.
  • No external script <src> references.
  • Every text label drawn into the SVG (titles, keywords, cluster names) must be escaped: replace & with &amp;, < with &lt;, > with &gt;, " with &quot;, and ' with &#39; before insertion.
  • Hover effects use CSS :hover only. No JavaScript.
  • Use <title> child elements inside SVG nodes for accessible tooltips (browser native, no script).

The map shows: a central pillar node, color-coded cluster groups radiating outward, spoke nodes within each cluster, and link lines connecting related nodes.

Step 6. Present plan to user

Show a summary table of clusters and posts, total interlinks, estimated words, and the file paths. Ask for confirmation before proceeding to execution. Wait for explicit user approval. Do not auto-execute.


Strategy Import: /blog cluster plan --from strategy [path]

Bridges blog-strategy output into a cluster plan.

  1. Locate strategy output. Scan the current directory (or the user-specified path) for a file containing a Cluster Build Plan table with the columns # | Spoke Topic | Template | Target Keyword | Word Count | Internal Links (the format produced by /blog strategy).
  2. Parse the table. Extract the pillar row (marked P), the spoke rows, template assignments, target keywords, word counts, and link relationships.
  3. Validate and enrich. Run SERP overlap validation (Plan Phase Step 2) on each keyword. Add volume estimates and verify cluster groupings semantically.
  4. If SERP data contradicts the strategy table, flag the conflict; do not silently override the user's strategic intent.
  5. Generate cluster-plan.json and cluster-map.html using the same outputs as the standard Plan Phase.
  6. Present the converted plan with any SERP-based adjustments highlighted, and wait for user confirmation.

Execute Phase: /blog cluster execute [path-to-plan]

Reference: references/execution-workflow.md

Step 1. Load plan

Read cluster-plan.json from the user-specified path or the most recent cluster-*/cluster-plan.json in the working directory. Validate JSON structure. If no plan exists, return: "No cluster plan found. Run /blog cluster plan <seed-keyword> first."

Step 2. Determine execution order

  1. Pillar page first (so spokes can link to a known filename).
  2. Then spokes, ordered by (cluster priority, search_volume_estimate desc, post id alphabetical). Cluster priority is the sum of estimated volumes within the cluster (highest first).
  3. Alternating between clusters when more than 2 clusters exist diversifies the early content spread.

Step 3. For each post: build cluster context and call blog-write

Construct the cluster context block (full schema in references/execution-workflow.md) and prepend it to the topic prompt passed to the Task tool invoking blog-write. The context tells blog-write the cluster name, the post's role (pillar or spoke), the primary and secondary keywords, the chosen template, the word count target, the list of already-written posts (link to these), the list of upcoming posts (use [INTERNAL-LINK] placeholders), and the linking requirements for this post.

FLOW evidence triple propagation (required). The cluster context must include this directive for every spoke and the pillar: "Apply the FLOW evidence triple to every public statistic. Year anchor in prose ('In 2026,'), inline citation with publisher and title, URL with retrieval date in the source block. Drop unverifiable stats. Replace contradicted ones."

This cascade is required because cluster execution is a high-leverage operation (5 to 15 posts at once). Without explicit propagation, individual spokes could silently skip evidence discipline. See skills/blog/references/flow-alignment.md.

The context also instructs blog-write to run autonomously: skip topic clarification, skip outline approval, do not auto-detect template, do not pause.

Output format: standard markdown (.md) by default, matching blog-write's default. If the user explicitly requests HTML, set the platform target accordingly. Do not impose any brand-specific CSS or wordmark; that is the user's responsibility downstream.

Step 4. Per-post optional hero image

If nanobanana-mcp is configured, call /blog image generate via the Task tool to produce a 16:9 hero image for the post and place it in cluster-<slug>/images/<post-slug>-hero.png. Insert a standard markdown image reference in the post's frontmatter (coverImage:) and at the top of the body. If the MCP is unavailable or fails, log a warning and continue without images. Image generation is non-blocking.

Step 5. Backward link injection

After each post is written:

  1. Scan all previously written posts in the cluster directory for [INTERNAL-LINK: keyword -> filename.md] markers that reference the just-written post.
  2. Replace each match with a real markdown link: [keyword](filename.md).
  3. Add a cluster metadata block to the post's frontmatter on first pass (cluster:, cluster_role:, cluster_group:).

Step 6. Failure handling

If blog-write fails for a single post (timeout, error, or quality gate fail), log the failure and continue with remaining posts. Do not abort the cluster. The scorecard will mark the gap and recommend a retry with /blog write invoked manually for that post.

If the user cancels mid-execution, save progress and note completed posts. On the next /blog cluster execute, detect already-written files and resume from the next unwritten post.

Step 7. Generate cluster-scorecard.md

After all attempted posts complete, produce a markdown scorecard covering:

  • Per-post status (written, failed, skipped) with file path and word count.
  • Per-post quality score (call /blog analyze on each in parallel) and the cluster average.
  • Cluster cohesion score: a 0 to 100 composite of link reciprocity, intent diversity, template diversity, and keyword coverage (formula in references/execution-workflow.md).
  • Internal-link audit: outgoing and incoming counts per post, orphan flags, unresolved [INTERNAL-LINK] markers.
  • Cannibalization check: any two posts sharing primary keyword, or any pair with greater than 70% keyword overlap. Recommend running /blog cannibalization for a deeper pass.
  • Image generation summary: hero images generated vs. skipped.
  • Recommended next actions: schema generation (/blog schema), per-post SEO validation (/blog seo-check), repurposing (/blog repurpose).

Step 8. Final report

Return a concise summary to the user with totals, the scorecard path, and the next-action commands.


Output Artifacts (summary)

File Phase Format
cluster-plan.json Plan JSON
cluster-map.html Plan Static HTML + inline SVG, no JavaScript
pillar-<slug>.md Execute Markdown (or platform-detected format)
<spoke-slug>.md Execute Markdown (or platform-detected format)
images/<post-slug>-hero.png Execute (optional) PNG via blog-image
cluster-scorecard.md Execute Markdown

Quality Gates

Gate Check Action on fail
Cluster minimum At least 2 clusters with at least 2 posts each Warn during plan; suggest expansion
Cannibalization No two posts share primary keyword Block execution; require plan adjustment
Link completeness Every post has 3 or more incoming internal links Warn in scorecard
Word count Pillar at least 2,500 words; spokes at least 1,200 words Pass to blog-write as a hard constraint
Intent diversity At least 2 distinct intents across clusters Warn in scorecard
Template diversity At least 3 distinct templates across the cluster Warn in scorecard

Error Handling

Scenario Action
Seed keyword too broad (more than 50 keyword variants) Suggest narrowing the focus before clustering.
Seed keyword too narrow (fewer than 5 keyword variants) Offer a smaller cluster (pillar plus 2 to 3 spokes) or suggest broadening.
WebSearch unavailable Fall back to Claude's reasoning for keyword expansion and grouping. Note the reduced accuracy in the scorecard.
blog-write fails for one post Log, skip, continue. Mark the gap in the scorecard.
blog-write not installed Return: "blog-cluster requires claude-blog. Install it before running this skill."
cluster-plan.json malformed Validate JSON and report parse errors with line numbers.
User cancels execution Save progress; resume on next invocation with already-written posts auto-detected.
nanobanana-mcp not configured Skip hero image generation; warn once at start of execute, not per post.

Differentiation from related claude-blog skills

Skill Role What blog-cluster adds
blog-strategy Plans 3 to 5 content pillars and draws hub-and-spoke diagrams as a strategic exercise Performs SERP-based semantic clustering, then executes the plan into real, interlinked posts.
blog-calendar Schedules publication dates around topic clusters Does not build clusters or write posts; this skill does both.
blog-cannibalization Detects keyword overlap in existing content Diagnostic only. blog-cluster prevents cannibalization at the planning stage.
blog-write Writes one post at a time blog-cluster orchestrates many blog-write calls with shared cluster context and bidirectional linking.
blog-outline Generates a single SERP-informed outline blog-cluster generates an outline-equivalent across an entire cluster, then writes the posts.

blog-cluster is the general contractor: it analyzes the topic, draws the data-driven plan, and builds the entire structure from a single seed keyword.