blog-write

Write new blog articles from scratch optimized for Google rankings and AI citations. Generates full articles with template selection, answer-first formatting, TL;DR box, information gain markers, citation capsules, sourced statistics, Pixabay/Unsplash images, built-in SVG chart generation, FAQ schema, internal linking zones, and proper heading hierarchy. Supports MDX, markdown, and HTML output. Use when user says "write blog", "new blog post", "create article", "write about", "draft blog", "generate blog post".

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "blog-write" with this command: npx skills add agricidaniel/claude-blog/agricidaniel-claude-blog-blog-write

Blog Writer -- New Article Generation

Writes complete blog articles from a topic, brief, or outline. Every article follows the 6 pillars of dual optimization (Google rankings + AI citations).

Key references:

  • references/content-templates.md — Template selection guide and usage
  • references/quality-scoring.md — 5-category scoring (Content 30, SEO 25, E-E-A-T 15, Technical 15, AI Citation 15)
  • references/eeat-signals.md — Experience, expertise, authority, trust markers
  • references/internal-linking.md — Linking strategy and anchor text rules
  • references/visual-media.md — Image sourcing and chart styling

Workflow

Phase 1: Topic Understanding

  1. Clarify the topic — If the user provides just a topic, ask:
    • Target audience (who is this for?)
    • Primary keyword / search intent
    • Desired word count (default: 2,000-2,500 words)
    • Platform/format (MDX, markdown, HTML — auto-detect if in a project)
  2. If a brief exists — Load it and skip to Phase 1.5

Phase 1.5: Template Selection

Select the appropriate content template from the 12 templates in templates/.

  1. Auto-detect content type from the topic and search intent:

    SignalTemplate
    "How to...", process, stepshow-to-guide
    "Best X", "Top N", list formatlisticle
    Client result, before/after, metricscase-study
    "X vs Y", comparison, alternativescomparison
    Broad topic, comprehensive guidepillar-page
    "Is X worth it", product evaluationproduct-review
    Opinion, prediction, industry takethought-leadership
    Expert quotes, multi-source collectionroundup
    Code walkthrough, tool demo, technicaltutorial
    Breaking news, algorithm update, eventnews-analysis
    Survey results, experiment, original datadata-research
    Q&A, knowledge base, "What is X"faq-knowledge
  2. Load the matching template — Read from templates/<type>.md

  3. Adapt the outline — Use the template's section structure, heading patterns, and word count guidance to shape Phase 3's outline

  4. Fallback — If no template clearly fits, use the generic outline structure in Phase 3 below. Inform the user which template was selected (or that none matched).

See references/content-templates.md for detailed selection criteria and intent mapping.

Phase 2: Research

Spawn a blog-researcher agent (or do inline research with WebSearch):

  1. Find 8-12 current statistics (2025-2026 data preferred)
    • Search: [topic] study 2025 2026 data statistics
    • Prioritize tier 1-3 sources (see references/quality-scoring.md)
    • Record: statistic, source name, URL, date, methodology
  2. Find a cover image (wide, high-quality, topic-relevant):
    • Search: site:pixabay.com [topic] wide banner (preferred)
    • Alternative: site:unsplash.com [topic] wide
    • Fallback: site:pexels.com [topic] wide banner
    • Target dimensions: 1200x630 (OG-compatible) or 1920x1080
    • Or generate a custom SVG cover via blog-chart (text-on-gradient with key stat)
    • Or generate a custom AI image via blog-image sub-skill (if nanobanana-mcp configured)
    • See references/visual-media.md for cover image sizing details
  3. Find 3-5 inline images from open-source platforms:
    • Pixabay (preferred): Search site:pixabay.com [topic keywords]
      • Extract image URL from page
      • Direct URLs: https://cdn.pixabay.com/photo/YYYY/MM/DD/HH/MM/filename.jpg
      • Verify with curl -sI "<url>" | head -1 returns HTTP 200
    • Unsplash (alternative): Search site:unsplash.com [topic keywords]
      • Build URL: https://images.unsplash.com/photo-<id>?w=1200&h=630&fit=crop&q=80
    • Pexels (fallback): Search site:pexels.com [topic keywords]
  4. Plan 2-4 data visualizations from researched statistics
    • Select diverse chart types (see references/visual-media.md)
    • Map data points to chart formats
  5. AI image generation (optional, if nanobanana-mcp configured):
    • If stock photo results are insufficient (< 3 good matches) or topic is too niche
    • Generate custom hero image and/or inline illustrations via blog-image sub-skill
    • Stock photos remain default — AI generation supplements, never replaces

Phase 3: Outline Generation

Create a structured outline before writing. If a template was loaded in Phase 1.5, adapt this skeleton to match the template's section structure:

# [Title as Question — Include Primary Keyword]

## Introduction (100-150 words)
- Hook with surprising statistic
- Problem/opportunity statement
- What the reader will learn

> **TL;DR:** [40-60 word standalone summary — placeholder]

## H2: [Question Format] (300-400 words)
- Answer-first paragraph (40-60 words with stat + source)
- Supporting evidence
- [Image placement]
- Practical advice
- [CITATION CAPSULE placeholder]
- [INTERNAL-LINK: anchor text → target description]

## H2: [Question Format] (300-400 words)
- Answer-first paragraph
- [Chart: type + data description]
- Analysis and implications
- [CITATION CAPSULE placeholder]
- [INTERNAL-LINK: anchor text → target description]

## H2: [Statement for Variety] (300-400 words)
- Answer-first paragraph
- Real-world example or case study
- [Image placement]
- [CITATION CAPSULE placeholder]

## H2: [Question Format] (300-400 words)
- Answer-first paragraph
- [Chart: type + data description]
- Step-by-step guidance
- [CITATION CAPSULE placeholder]
- [INTERNAL-LINK: anchor text → target description]

## H2: [Question Format] (200-300 words)
- Answer-first paragraph
- Forward-looking analysis

## FAQ Section (3-5 questions, 40-60 words each answer)
- [INTERNAL-LINK: anchor text → detailed content]

## Conclusion (100-150 words)
- Key takeaways (bulleted)
- Call to action
- [INTERNAL-LINK: anchor text → next logical content]

Present the outline to the user for approval before writing.

Phase 4: Chart Generation (Built-In)

When the researcher identifies chart-worthy data (3+ comparable metrics, trend data, before/after comparisons):

  1. Select chart type using the diversity rule (no repeated types per post)
  2. Invoke blog-chart sub-skill with: chart type, title, data values, source, platform format
  3. Embed the returned SVG directly in the post within a <figure> wrapper
  4. Target 2-4 charts per 2,000-word post
  5. Distribute charts evenly — never cluster them

See references/visual-media.md for chart type selection and styling rules.

Phase 5: Content Writing

Write the full article following these rules:

5a. Frontmatter

---
title: "[Question-format title with primary keyword]"
description: "[Fact-dense, 150-160 chars, includes 1 statistic]"
coverImage: "[URL from Pixabay/Unsplash/Pexels or generated SVG path]"
coverImageAlt: "[Descriptive sentence about the cover image]"
ogImage: "[Same as coverImage, or custom OG image URL]"
date: "YYYY-MM-DD"
lastUpdated: "YYYY-MM-DD"
author: "[Author name]"
tags: ["keyword1", "keyword2", "keyword3"]
---

If the platform uses a different field name (e.g., image, hero, thumbnail), adapt to match the project's existing frontmatter convention.

5b. TL;DR Box

Immediately after the introduction (before the first H2 body section), add a TL;DR box:

> **TL;DR:** [40-60 word standalone summary that makes sense without reading the
> full article. Contains the key finding or recommendation plus 1 statistic with
> source attribution. Reader should get the core value from this alone.]

Requirements:

  • 40-60 words, no more
  • Must be self-contained — understandable without reading the article
  • Include 1 specific statistic with source name
  • State the key finding, recommendation, or answer
  • Place as a blockquote directly after the introduction paragraph

5c. Answer-First Formatting (Critical)

Every H2 section MUST open with a 40-60 word paragraph containing:

  • At least one specific statistic with source attribution
  • A direct answer to the heading's implicit question

Pattern:

## How Does X Impact Y in 2026?

[Stat from source] ([Source Name](url), year). [Direct answer to the heading
question in 1-2 more sentences, explaining the implication and what this means
for the reader.]

5d. Information Gain Markers

Distribute at least 2-3 information gain markers throughout the article. These signal to search engines and AI systems that the content contains original value not available elsewhere.

Tag each with a comment or visible marker:

  • [ORIGINAL DATA] — Proprietary surveys, experiments, A/B test results, case study metrics the author collected first-hand
  • [PERSONAL EXPERIENCE] — First-hand observations, lessons learned from direct involvement, "when we tried X, Y happened" narratives
  • [UNIQUE INSIGHT] — Analysis others haven't made, contrarian perspectives backed by data, novel connections between existing research

Placement:

  • Weave into the body text naturally
  • Use as inline comments: <!-- [ORIGINAL DATA] --> before the relevant paragraph
  • Or as visible callouts if the format supports it:
    > **Our finding:** [original observation backed by specific data]
    
  • Minimum 2 per post, target 3 for comprehensive articles

These markers map directly to the "Originality/unique value markers" criterion in the Content Quality scoring category (see references/quality-scoring.md).

5e. Citation Capsules

For each major H2 section, generate a citation capsule — a 40-60 word self-contained passage designed so AI systems can extract and quote it directly.

Requirements per capsule:

  • 40-60 words, self-contained (makes sense in isolation)
  • Contains: one specific claim + one data point + source attribution
  • Written in a declarative, quotable style
  • Placed within the H2 section body (not as a separate block)

Example:

According to a 2026 Gartner study, 58% of enterprise buyers now consult AI
assistants before contacting a vendor ([Gartner](https://www.gartner.com), 2026).
This shift means B2B content must answer specific questions concisely enough
for AI systems to extract and cite in their responses.

Capsules map to the "AI Citation Readiness" scoring category (15 points) in references/quality-scoring.md.

5f. Internal Linking Zones

Mark internal linking opportunities throughout the article using placeholder notation. The user (or a follow-up pass) will resolve these to actual URLs.

Zone placement:

  • Introduction — Link to related pillar content or topic hub
  • Each H2 section — Link to supporting articles, deeper dives, related tools
  • FAQ section — Link answers to detailed content that expands on the answer
  • Conclusion — Link to the next logical piece of content the reader should consume

Format:

[INTERNAL-LINK: anchor text → target description]

Example:

For a deeper dive into keyword clustering, see our
[INTERNAL-LINK: complete guide to keyword clustering → pillar page on keyword research methodology].

Target 5-10 internal link zones per 2,000-word post. Use descriptive anchor text (never "click here" or "read more"). See references/internal-linking.md for anchor text rules and linking strategy.

5g. Paragraph Rules

  • Every paragraph: 40-80 words (never exceed 150)
  • Every sentence: max 15-20 words
  • Start each paragraph with the most important information
  • Target Flesch Reading Ease: 60-70

5h. Heading Rules

  • One H1 (title only)
  • H2s for main sections (60-70% as questions)
  • H3s for subsections only — never skip levels
  • Include primary keyword naturally in 2-3 headings

5i. Image Embedding

Standard markdown:

![Descriptive alt text — topic keywords naturally](https://cdn.pixabay.com/photo/...)

MDX with Next.js Image (if detected):

![Descriptive alt text — topic keywords naturally](https://cdn.pixabay.com/photo/...)
  • Place images after H2 headings, before body text
  • Space evenly throughout the post (not clustered)
  • Alt text should be a full descriptive sentence

5j. Chart Embedding

Standard markdown/HTML:

<figure>
  <svg viewBox="0 0 560 380" ...>...</svg>
  <figcaption>Source: [Source Name], [Year]</figcaption>
</figure>

MDX format:

<figure className="chart-container" style={{margin: '2.5rem 0', textAlign: 'center', padding: '1.5rem', borderRadius: '12px'}}>
  <svg viewBox="0 0 560 380" ...>...</svg>
</figure>

5k. Citation Format

Inline attribution (always):

Organic CTR declined 61% with AI Overviews ([Seer Interactive](https://www.seerinteractive.com/), 2025).

5l. FAQ Section

Add 3-5 FAQ items with 40-60 word answers. Each answer must contain a statistic.

For MDX with FAQSchema component:

<FAQSchema faqs={[
  { question: "Question?", answer: "40-60 word answer with statistic and source." },
]} />

For standard markdown:

## Frequently Asked Questions

### Question text here?

Answer with statistic and source attribution (40-60 words).

5m. Internal Linking

  • 5-10 internal links per 2,000-word post
  • Link to relevant existing content naturally
  • Use descriptive anchor text (not "click here")

Phase 6: Quality Check

Before delivering, verify:

Structure and Content

  1. Every H2 opens with a statistic + source
  2. No paragraph exceeds 150 words
  3. All statistics have named tier 1-3 sources
  4. 2-4 charts with type diversity
  5. 3-5 inline images with descriptive alt text
  6. Cover image present in frontmatter (coverImage + ogImage)
  7. FAQ section present with 3-5 items
  8. Heading hierarchy is clean (H1 -> H2 -> H3)
  9. Meta description is 150-160 chars with a stat

New Element Verification

  1. TL;DR box present after introduction (40-60 words, contains statistic + source)
  2. At least 2-3 information gain markers ([ORIGINAL DATA], [PERSONAL EXPERIENCE], or [UNIQUE INSIGHT])
  3. Citation capsules present in major H2 sections (40-60 words, self-contained, quotable)
  4. Internal linking zones marked in introduction, H2 sections, FAQ, and conclusion
  5. No AI-detectable phrases from banned list (see agents/blog-writer.md)

Burstiness and Naturalness Check

  1. Sentence length variance — Verify a mix of short (8-word) and long (25-word) sentences. Uniform sentence length signals AI authorship.
  2. Banned AI phrase scan — Check for and remove:
    • "in today's digital landscape", "it's important to note", "dive into"
    • "game-changer", "navigate the landscape", "revolutionize", "seamlessly"
    • "cutting-edge", "harness the power of", "leverage" (as verb)
    • "delve", "crucial", "elevate", "foster", "landscape" (overused)
    • "multifaceted", "robust", "tapestry", "embark"
    • Full list in agents/blog-writer.md
  3. Contractions — Verify natural use of contractions ("it's", "we've", "don't", "isn't"). Formal AI prose avoids contractions; natural writing uses them.
  4. Rhetorical questions — Verify at least one rhetorical question every 200-300 words to break up declarative patterns.

Phase 7: Delivery

Present the completed article with a summary:

## Blog Post Complete: [Title]

### Template Used
- [Template name] (or "generic outline — no template matched")

### Statistics
- [N] sourced statistics from tier 1-3 sources
- [N] unique sources cited

### Visual Elements
- Cover image: [source — Pixabay/Unsplash/Pexels or generated SVG]
- [N] inline images (Pixabay/Unsplash/Pexels)
- [N] SVG charts (types: bar, lollipop, donut, line)

### Dual-Optimization Elements
- TL;DR box: present (N words)
- Information gain markers: [N] ([types used])
- Citation capsules: [N] across H2 sections
- Internal linking zones: [N] marked

### Structure
- [N] H2 sections with answer-first formatting
- [N] FAQ items with schema
- Word count: ~[N] words
- Estimated reading time: [N] min

### Naturalness
- Sentence length variance: [pass/fail]
- AI phrase scan: [pass/fail]
- Contractions used: [yes/no]
- Rhetorical questions: [N] (target: 1 per 200-300 words)

### Next Steps
- Review and customize for your brand voice
- Resolve [INTERNAL-LINK] placeholders with actual URLs
- Add internal links to your existing content
- Run `/blog analyze <file>` to verify quality score

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

blog

No summary provided by upstream source.

Repository SourceNeeds Review
General

blog-seo-check

No summary provided by upstream source.

Repository SourceNeeds Review
General

blog-rewrite

No summary provided by upstream source.

Repository SourceNeeds Review
General

blog-brief

No summary provided by upstream source.

Repository SourceNeeds Review