skills/capabilities/create-linkedin-content/SKILL.md
Draft voice-tuned LinkedIn post variants from a free-form brief. Reads a personal voice guide (generated via generate-voice-guide), produces 2–5 variants with distinct framings, applies LinkedIn-specific defaults (arrow bullets, "why this matters" beat, 150–500 words), and self-checks against the voice guide's banned phrases before returning.
npx skillsauth add athina-ai/goose-skills create-linkedin-contentInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Draft LinkedIn post variants that sound like a real human practitioner, not a LinkedIn thought-leader persona. Reads a voice guide the user has already generated (or prompts to create one), produces multiple framings of the same idea, and saves each variant as its own markdown file with frontmatter.
This is an agent-executed skill — the agent does the drafting and self-check inline. No Python script.
Mirrors create-x-content structurally; differences are marked ★.
/create-linkedin-content --brief "New open-source CLI that turns Figma files into React components. Called figma2react. Free, MIT licensed."
Or interactively:
/create-linkedin-content
| Flag | Required | Default |
|------|----------|---------|
| --brief | Yes (asked interactively if missing) | — |
| --variants | No | Skill decides based on brief richness (2–5) |
| --voice-guide | No | Resolved via chain below |
| --output | No | ./content/YYYY-MM-DD-<topic-slug>/ |
| --topic | No | Derived from brief |
Resolve in this order, stop at first hit:
--voice-guide <path> flag~/.goose-skills/config.json → voice_guides.linkedin~/.goose-skills/voice-guides/voice-linkedin.md (default path)/generate-voice-guide --platforms linkedin now to create one (recommended)Apply these unless the voice guide explicitly says otherwise:
→) for workflow steps — this is LinkedIn-native1️⃣ 2️⃣ 3️⃣ allowed sparingly for installation/quickstart type postsSame as create-x-content Phase 1 — load voice guide, extract banned phrases, hook patterns, format rules, dos/don'ts, examples.
Same 2–5 decision rubric. LinkedIn briefs often warrant fewer variants than X because LinkedIn posts are longer and the audience expects more narrative coherence — 3 strong framings usually beats 5.
Framings tuned for LinkedIn (subset of the X framings, plus a few LinkedIn-native ones):
| Framing | Structure | When to use |
|---------|-----------|-------------|
| builder-story ★ | "I built X. Here's why. Here's what I learned." | LinkedIn-native — builder stories outperform tactical posts here |
| product-launch ★ | Clear hook + 2-step quickstart + link | New tool/product announcements |
| problem-first | Open with the pain, then solution | Universal |
| ecosystem-map | Curated list of N related tools/companies | Landscape posts |
| contrarian-insight | "Your X might be worth more than Y" | Opinion pieces with a fresh take |
| workflow-tutorial | Arrow-bulleted step-by-step, with numbers | Tactical how-tos (denser than X version) |
Same 4 checks as create-x-content:
Plus LinkedIn-specific:
5. Arrow-bullet check — if the post uses lists, are they → style (or numbered emojis), matching the LinkedIn convention?
6. "Why this matters" check — does the post explain the stakes, or does it just state the facts? Add a "why this matters" beat if missing.
7. No corporate tone — does it sound like a press release? If yes, rewrite to sound like a human practitioner.
File naming (the linkedin- prefix distinguishes from X variants when they live in the same folder):
linkedin-<letter>-<framing-slug>.md
Examples: linkedin-a-builder-story.md, linkedin-b-product-launch.md.
Frontmatter:
---
id: <topic-slug>-li-<letter>
platform: linkedin
format: standard | long
topic: <slug>
framing: <framing-slug>
status: draft
---
Print output directory, file list, framing summary, suggested next step.
<output>/linkedin-<letter>-<framing>.md per variantBuilder story brief:
/create-linkedin-content --brief "Built a CRM for my AI agents using just markdown files and Claude Code. No Salesforce, no HubSpot. Works better than both."
→ 3 variants (builder-story, contrarian-insight, workflow-tutorial)
Launch brief:
/create-linkedin-content --brief "Launching goose-aeo — open-source CLI that measures your brand's visibility on AI search engines like ChatGPT, Perplexity, Gemini. npm install, three commands to run."
→ 3 variants (product-launch, problem-first, workflow-tutorial)
generate-voice-guide skill (for creating one when missing)content-media
Takes an existing screen recording or demo video and adds professional zoom/pan effects synchronized to the narration. Uses transcript-driven zoom targeting and Remotion for rendering. Optionally replaces audio with a soundtrack.
tools
Repurposes long-form video (podcasts, interviews, talks) into short-form vertical clips for Instagram Reels, TikTok, and YouTube Shorts. Handles transcription, moment selection, clip extraction, speaker-tracked reframing (16:9 to 9:16), and animated captions.
development
Creates talking head videos from any source material (docs, changelogs, blog posts, notes, transcripts). Produces multi-scene videos with avatar narration over screenshots/images using HeyGen v2 API. Supports Quick Shot and Full Producer modes.
tools
Generates Instagram-ready product reels from any e-commerce product page URL. Scrapes product images, classifies by type, generates AI-animated clips via Higgsfield API, creates text overlays with style presets, and composes a 15-20 second reel with music. Supports model-based and product-only reels.