Blog Writing
v2.2.1Step-by-step SEO blog writing workflow for teams who want full control over every phase. Covers keyword strategy, competitive research, content structure, in...
Like a lobster shell, security has layers — review code before you run it.
License
SKILL.md
SEO Blog Writing — Complete Workflow
When to Use
- Writing any blog article (comparison, how-to, listicle, guide, thought piece)
- Creating long-form SEO content (2000+ words)
- Producing content for filomail.com/blog or any website
Execution Model (IMPORTANT)
This skill requires running shell commands (Phase 5 link verification, Phase 6 QA runner). It must be executed in a context with full exec permissions.
Always spawn the writing subagent with security: "full":
sessions_spawn(
task: "[full article brief]",
runtime: "subagent",
security: "full" ← REQUIRED — without this, exec approval gates block Phase 5 & 6
)
If running in main session directly (fallback only), exec permissions are already sufficient — proceed normally.
Never spawn without security: "full" — the subagent will silently skip QA and deliver an unverified draft.
Failure Recovery Guardrails (Mandatory)
- Section-by-section writes — Write each H2 section to disk incrementally. Never hold more than one section only in context.
- Inline AI-tell check — After each H2 section, run the 4-point check (see Phase 3) before moving on. Fix inline, don't batch.
- QA loop cap — Max 3 QA rounds. Each round fixes only concrete FAIL items from the latest report. Never regenerate passing sections.
- Timeout recovery — If interrupted mid-article, write partial output to disk immediately, note the resume section, and continue from there. Do not restart from zero.
Pre-Flight
- Read
filomail/product/for current product facts - Read
filomail/brand/for voice and red lines - Check
filomail/blog/plan/internal-links-map.mdfor internal linking targets - Check
filomail/blog/plan/content-plan.mdfor where this article fits in the topic cluster
Phase 1: Research (Before Writing)
Keyword Research
- Primary keyword — The exact phrase we want to rank for (e.g., "best AI email apps 2026")
- Secondary keywords — Related phrases to include naturally (3-5)
- Long-tail variants — Question-form queries for FAQ section
Competitive Analysis
For the primary keyword, search Google and analyze top 5 results:
- Word count of each
- H2/H3 structure
- What they cover that we should cover
- What they miss that we can fill (content gap)
- External links they use (authority sources)
Run the QA runner to analyze SERP gaps during research:
python3 skills/seo-geo-qa/scripts/seo_qa_runner.py path/to/draft.md --keyword "best email apps for mac"
Use the lower-level analyzer only when debugging SERP gaps in isolation:
python3 skills/seo-geo-qa/scripts/serp_gap_analyzer.py "best email apps for mac" path/to/draft.md
python3 skills/seo-geo-qa/scripts/serp_gap_analyzer.py "best email apps for mac" path/to/draft.md --urls https://competitor1.com https://competitor2.com
Search Intent Classification
| Intent Type | Signal | Article Approach |
|---|---|---|
| Informational | "what is", "how to" | Definitive guide, answer-first |
| Comparison | "best", "vs", "alternatives" | Structured comparison, table-heavy |
| Commercial | "review", "pricing" | Detailed evaluation, honest pros/cons |
| Navigational | brand name | Product-focused, feature deep-dive |
Output: Research Brief
Save to filomail/blog/plan/ before writing:
## Research Brief: [Title]
- Primary keyword:
- Secondary keywords:
- Search intent:
- Target word count:
- Top 5 competitor URLs + word counts
- Content gaps to exploit
- Internal links to include
- External authority sources identified
Phase 2: Outline
Standard Article Structure
# H1 — Contains primary keyword, under 60 chars
Opening hook (150-200 words)
- Define the problem/question
- Why this matters now
- What this article covers
## Quick Comparison Table (for comparison articles)
## Detailed Reviews / Sections (bulk of article)
### H3 subsections as needed
## How We Tested / Methodology
## How to Choose / Decision Framework
## FAQ (4-6 questions, schema-markup ready)
## Further Reading (internal + external links)
Heading Rules
- One H1 per article, contains primary keyword
- H2s match search queries where possible
- H3s for subsections within H2s
- Never skip levels (H1 → H3 is wrong)
- Headings describe content, not for styling
Phase 3: Write
Opening (First 100 Words — Critical)
- Primary keyword appears in first 100 words
- Direct answer or clear hook (no throat-clearing)
- Set expectation for what reader will learn
Body Writing Standards
Word Count by Type:
| Type | Minimum | Target |
|---|---|---|
| Comparison / Listicle | 2,500 | 3,000-3,500 |
| How-to Guide | 1,500 | 2,000-2,500 |
| Thought Piece | 1,000 | 1,500-2,000 |
| Product Comparison (vs) | 2,000 | 2,500-3,000 |
Keyword Density:
- Primary keyword: 1-2% (natural, never stuffed)
- Secondary keywords: 0.5-1% each
- Check: keyword should feel invisible to the reader
Paragraph Structure:
- Max 3-4 sentences per paragraph
- One idea per paragraph
- Short sentences mixed with longer ones
- Use bullet points and numbered lists for scanability
Readability Target:
- Flesch Reading Ease: 60-70 (standard/conversational)
- Grade level: 8-10 (accessible but not dumbed down)
- Sentence length: average 15-20 words, max 35
Internal Linking Strategy
| Word Count | Internal Links Min | Target |
|---|---|---|
| < 1500 | 2 | 3-5 |
| 1500-2500 | 3 | 5-8 |
| 2500-3500 | 5 | 8-12 |
| 3500+ | 7 | 10-15 |
- Link with descriptive anchor text (not "click here")
- Link to related blog posts in the same topic cluster
- Link to product/feature pages where natural
- Follow hub-spoke pattern (see internal-links-map)
- Consult
filomail/blog/plan/internal-links-map.md
External Linking Standards (Proportional)
| Content Type | External Links Min | Rationale |
|---|---|---|
| Comparison / Best-of (8+ products) | 16-24 | Each product: official site + 1 authority source |
| Comparison / Best-of (5-7 products) | 12-18 | Same ratio |
| Alternatives page | 10-15 | Each alternative + authority sources |
| How-to guide | 5-10 | Claims need sources, fewer entities |
| Thought piece | 3-8 | Fewer claims, more perspective |
The principle: Every entity mentioned gets a link. Every factual claim gets a source. Don't link for the sake of linking.
- Prefer: official sites > media reviews > research papers
- Avoid: personal blogs, paywalled content, temporary pages
- Never link to competitors' comparison articles (link to their product page)
- All links must be verified (Phase 5)
Authority Signals (GEO/AEO Optimization)
These boost visibility in AI search engines (ChatGPT, Perplexity, Google AI Overviews):
| Signal | Impact | How |
|---|---|---|
| Statistics with sources | +37% | "According to [Source], X% of users..." |
| Quotations (expert quotes) | +30% | "As [Name], [Title] at [Company], notes..." |
| Authoritative tone | +25% | Write with demonstrated expertise, not hedge language |
| Authoritative citations | +40% | Link to research, not just claims |
| Clear definitions | +20% | Definition in first paragraph of each section |
| FAQ with schema | +30-40% | Natural Q&A format at bottom |
| "Last updated" date | +freshness | Include at bottom of article |
Evidence sandwich pattern — Structure every major claim as: Claim → Evidence → Interpretation
"Most users prefer [X] [claim]. A 2024 study of 1,000 professionals found Y [evidence]. This means Z for your specific workflow [interpretation]."
Stats without interpretation are noise. Interpretation without evidence is opinion. The sandwich does both and is the format AI systems are most likely to excerpt.
Content Extractability (for AI Citation)
AI systems extract passages, not pages. Each key point should work standalone:
- Lead every section with a direct answer (don't bury it)
- Keep key answer passages to 40-60 words
- Tables beat prose for comparison content
- Numbered lists beat paragraphs for process content
- Self-contained answer blocks that work without surrounding context
Platform-Specific GEO
Different AI systems cite differently. Write each major section to satisfy all four:
| Platform | What it prefers | Format to use |
|---|---|---|
| Google AI Overviews | Direct answers, tables, lists | Lead with 40-60 word direct answer. "X is [definition]. Key points: [numbered list]." |
| Perplexity | Evidence with methodology, attributed data | "Research shows [finding] (N=size, method, year)." Front-load sample size and date. |
| ChatGPT | Multiple angles, acknowledged limitations | "While X is generally true, Y also matters because..." Cover edge cases. |
| Claude | Logical cause-and-effect chains | "Because X happens, Y results, leading to Z." Structure reasoning, not just conclusions. |
In practice: One well-structured section satisfies all four. Lead with direct answer (Google), follow with sourced evidence (Perplexity), add nuance (ChatGPT), ensure logical flow throughout (Claude).
Comparison Article Specifics
For "Best X" / "X Alternatives" / "X vs Y" articles:
- Always include a comparison table at the top
- Each entry needs: Name, Price, Key Feature, Platforms, Best For
- Be honest about competitors — acknowledge strengths
- Be honest about our weaknesses — builds trust, ranks better
- Position Filo first but earn it with real arguments
- Include anchor IDs for each product section
Inline AI-Tell Check (Run After Each H2 — Not Batched)
After writing each H2 section, check these 4 things before moving to the next section. Fix inline. Do not save the check for Phase 4.
□ Banned words: delve, seamlessly, robust, leverage, revolutionize, holistic, tapestry,
navigate (metaphor), harness, paradigm, synergy, game-changer, elevate
□ Long sentences: any sentence > 35 words? Split it.
□ Throat-clearing opener: section starts with "It's important to..." / "When it comes to..."?
Cut it — start with the point.
□ Em-dash density: > 1 em-dash per 200 words? Rewrite as commas, semicolons, or split sentences.
If any box is checked: rewrite only the flagged sentence(s). Then move on. This takes under 30 seconds per section and catches problems at the source rather than in a painful batch rewrite at the end.
Phase 4: Optimize
SEO Checklist (Before Review)
- H1 contains primary keyword, under 60 chars
- Meta description drafted: 150-160 chars, includes keyword
- Primary keyword in first 100 words
- Primary keyword in at least one H2
- URL slug is keyword-rich and clean
- At least one table or list (featured snippet opportunity)
- FAQ section present (schema markup ready)
- "Last updated: [Month Year]" at bottom
- Internal links ≥ 3
- External links ≥ 10
- All images have alt text (when applicable)
AI Writing Pattern Avoidance
CRITICAL: Content must not read like AI wrote it.
Common AI patterns to eliminate:
| Pattern | Example | Fix |
|---|---|---|
| Em-dash overuse | "The tool — which is powerful — works well" | Use commas or periods instead. Max 3 em-dashes per article. |
| "Delve into" | "Let's delve into the features" | "Here's what it does" / "Let's look at" |
| "Landscape" | "In today's email landscape" | Cut it. Be specific. |
| "Leverage" | "Leverage AI to improve" | "Use AI to improve" |
| "Tapestry/Mosaic" | "A rich tapestry of features" | Just describe the features. |
| "Revolutionize" | "Revolutionizing how you email" | "Changes how you email" |
| "Game-changer" | "This is a game-changer" | Say what it actually changes. |
| "Seamlessly" | "Seamlessly integrates" | "Integrates" or "works with" |
| "Robust" | "A robust set of features" | "A full set of features" or just list them. |
| "Elevate" | "Elevate your inbox experience" | "Improve" or describe the specific improvement. |
| "Navigate" (metaphor) | "Navigate your inbox challenges" | "Deal with" / "Handle" / "Manage" |
| "Harness" | "Harness the power of AI" | "Use AI to..." |
| "Paradigm" | "A paradigm shift" | Describe the actual change. |
| "Synergy" | "Create synergy between..." | "Works well with" or describe specifically. |
| "Holistic" | "A holistic approach" | "A complete approach" or be specific. |
| "At the end of the day" | Filler | Cut it. |
| "Without further ado" | "Without further ado, here's..." | Just start. |
| Triple-adjective stacking | "Powerful, intuitive, and elegant" | Pick one. Prove it. |
| Rhetorical questions | "But what if there was a better way?" | State the better way. |
| "In conclusion" / "In summary" | "In conclusion, Filo is the best" | Just make your point. |
Self-check: Read the article out loud. If any sentence sounds like a press release, rewrite it.
Phase 5: Link Verification (MANDATORY)
Never deliver content without verifying every link.
Process
- Extract all URLs from the article
- Test each with
web_fetchorcurl -sI - Check for: 404, 403, redirects to wrong content, paywalls
- For non-obvious external sources, run a source-quality spot check (AITDK/Ahrefs/search evidence)
Source Quality Spot Check
For external sources that are not obviously authoritative, check whether they are worth citing:
- AITDK traffic page:
https://aitdk.com/traffic/<domain>for traffic / keyword / domain-age hints when accessible - Ahrefs Backlink Checker: use as a quick proxy for domain strength / backlink profile
- Search evidence:
site:domain.com, branded query, and recent indexed pages if third-party tools are blocked
Do not require perfect metrics. The goal is to catch weak, stale, spammy, or irrelevant sources before they land in the article.
When Links Fail
- Search for alternative source supporting the same claim
- Prioritize: Official sites > Research > Major publications
- Update surrounding text if needed
- Document changes:
**Original:** https://broken-link.com (404)
**Replacement:** https://working-link.com
**Reason:** Original returned 404
**Verified:** ✅ Same data confirmed
Quote & Attribution Verification (CRITICAL — learned the hard way)
- If citing a review → verify the quote exists AND the article's overall tone matches your framing
- Tone match test: Read the first 3 paragraphs of the source article. Is it positive, negative, or neutral?
- Source is positive → quote freely
- Source is negative → either don't quote, or frame honestly: "Even [Source]'s critical review acknowledged..."
- Source is neutral → quote with accurate framing
- Don't pull positive fragments from negative reviews — readers click through and lose trust
- Statistics must match their cited source exactly (number, date, methodology)
- "According to [Source]" → verify Source actually says that
Phase 6: Automated QA (MANDATORY — runs before human review)
After completing Phase 5, ALWAYS run the QA runner before spawning a review agent or delivering the draft. Do not skip this. Do not ask whether to run it.
python3 skills/seo-geo-qa/scripts/seo_qa_runner.py path/to/article.md --keyword "primary keyword"
What happens automatically
- All links verified (liveness + source quality tiering)
- Dead links, weak sources, moved links flagged
- FAQ count, external link count, SERP gap checked
- Markdown + JSON report saved to
qa-reports/{slug}/next to the article - Verdict: PASS or FAIL
If FAIL
- Fix critical issues (dead links, too many TIER-D sources)
- Re-run until PASS
- Max 3 rounds
If PASS
- Proceed to Phase 7 (human review)
- Include the QA report link in the review handoff
Phase 7: Review (Auto-Spawn)
Always spawn a review agent after Phase 6 passes. The review agent checks:
Review must check:
- QA runner verdict is PASS (with report link)
- SEO checklist complete
- Brand voice compliance
- Factual accuracy (pricing, features)
- AI writing patterns eliminated
- Readability standards met
File Conventions
Where to Save
- Research briefs:
blog/plan/brief-{slug}.md - Article drafts:
blog/seo/{slug}.md(SEO) orblog/{slug}.md(general) - Article images: handled separately in your CMS or website repo
Slug Format
- Lowercase, hyphen-separated
- Match target URL path:
/blog/{slug}
Title Year Rules (2026-03-24 决策)
| 文章类型 | 标题带年份? | 原因 |
|---|---|---|
| 比较类 (best X, X alternatives) | ✅ 是 | 年份是搜索关键词的一部分("best email app 2026") |
| 教育型 / How-to | ❌ 否 | 搜索意图是常青的,年份反而限制文章寿命 |
| 场景痛点 | ❌ 否 | 同上 |
| 功能发布 | ❌ 否 | 功能不按年份搜索 |
| 思想 / 署名文章 | ❌ 否 | 同上 |
- 教育类文章的 freshness 信号放在文末 "Last updated: [Month Year]"
- 比较类文章的年份每年 Q1 集中更新(标题 + 内容 + slug)
- 参考:Anthropic claude.com/blog 零篇使用年份标题,全靠内容 freshness 信号
Related Skills
content-production— Mandatory produce → review → revise workflowcontent-qa— QA checklist and review agentseo-audit— Technical SEO checks for the whole siteseo-geo— GEO optimization for AI search enginescompetitor-alternatives— Comparison page structureschema-markup— JSON-LD implementationcopy-editing— Multi-pass editing framework
Files
1 totalComments
Loading comments…
