skills/marketing/hormozi-ad-factory/SKILL.md
Generates 150-750+ ad variations using Alex Hormozi's combinatorial Hook x Meat x CTA framework. Triggers on requests to create ads, ad copy, ad scripts, marketing creatives, video ad scripts, ad hooks, CTAs, ad testing, ad scaling, or ad factories. Also triggers on mentions of Hormozi's ad method or combinatorial ad creation. Does not trigger for general copywriting, email marketing, landing pages, or non-advertising content.
npx skillsauth add pedronauck/skills hormozi-ad-factoryInstall 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.
A systematic framework for generating 150-750+ unique ad variations from a single product or offer, based on Alex Hormozi's combinatorial ad creation method.
Ads consist of three modular parts: Hook, Meat, and CTA. Instead of writing one ad at a time, generate each component independently, then combine them:
This approach creates massive variety for testing, which is what wins at scale.
Execute the following four steps in order. Before starting, gather context from the user.
Before generating any ad components, ask the user these questions (skip any the user has already answered):
If the user provides minimal context, infer reasonable defaults and state the assumptions clearly before proceeding.
Hooks are the first 1-3 seconds (video) or first line (text) of the ad. They stop the scroll and earn attention. Use these five sourcing methods to create variety:
Distribute the 50 hooks across awareness levels to cover different audience segments:
| Level | Description | Hook Style | |-------|-------------|------------| | Unaware | Does not know they have a problem | Pattern interrupt, curiosity, shock | | Problem-Aware | Knows the problem, not the solution | Call out the pain, frustration, desire | | Solution-Aware | Knows solutions exist, has not chosen one | Compare approaches, reveal flaws in alternatives | | Product-Aware | Knows the product, has not bought | Overcome objections, social proof, urgency | | Most Aware | Knows the product well, needs a push | Deals, bonuses, scarcity, direct offer |
Default to a balanced spread (~10 hooks per level) unless the user specifies a focus.
For hook formula templates and examples, read references/hook-formulas.md.
The meat is the body of the ad — it educates the audience on the offer, the product, the solution, or the problem. Generate one meat per format:
Each meat must be self-contained and work with any hook and any CTA.
For detailed meat structures and length guidelines, read references/meat-formats.md.
The CTA tells the viewer exactly what to do next. A strong CTA includes up to five elements:
Not every CTA needs all five, but the best ones cover most of them.
For CTA templates and examples, read references/cta-templates.md.
After generating all components, combine them into a matrix. Present the output as:
For the full output format template, read assets/output-template.md.
Adapt the format of each component based on the target platform:
| Platform | Hook | Meat | CTA | |----------|------|------|-----| | Video ads (TikTok, YouTube, Reels) | Opening line/scene (1-3s) | Script section with visual directions (15-45s) | Closing sequence with on-screen text | | Text/copy ads (Facebook, LinkedIn) | Headline or opening line | Body copy paragraphs (3-8 sentences) | Closing paragraph with link | | Carousel ads (Instagram, LinkedIn) | Slide 1 | Slides 2-8 | Last slide | | Short-form (Twitter/X, Stories) | Single punchy line | 1-3 sentences max | Inline CTA |
User: "Generate ads for my project management tool aimed at remote teams."
Process:
User: "Crie anuncios para meu curso de culinaria online para iniciantes."
Process:
User: "I need some ad ideas for my coaching business."
Process:
tools
Plans real-user QA deliverables: personas, journey maps, exploratory charters, persona/journey/tour/CFR test cases, regression suites, Figma validation checks, automation intent, and user-impact bug reports. Writes artifacts under <qa-output-path>/qa/ for qa-execution to consume. Use when planning QA before execution, documenting journey-driven test strategy, marking flows that need E2E follow-up, or filing structured bug reports. Do not use for live execution, AI implementation audits, CI gate ownership, or technical integration/security/performance suites; use qa-execution or agent-output-audit instead.
development
Executes real-user QA sessions through public interfaces using personas, journeys, exploratory charters, test tours, edge-case probes, CFR checks, and browser evidence. Reads qa-report artifacts from <qa-output-path>/qa/ when present, captures issues/screenshots/reports under the same output tree, and classifies bugs by user impact. Use when validating a release candidate, migration, refactor, or user-facing change against production-like behavior. Do not use for AI implementation audits, task-status reconciliation, CI gate runs, integration/security/performance templates, or flaky-test triage; use agent-output-audit for those.
development
Transform outside-of-diff review files into properly formatted issue files for a given PR. Use when converting review files from ai-docs/reviews-pr-<PR>/outside/ into issue format in ai-docs/reviews-pr-<PR>/issues/. Automatically determines starting issue number and preserves all metadata (file path, date, status) from original review files. Don't use for inline-diff review files, non-PR review artifacts, or creating GitHub issues directly.
development
Enforce root-cause fixes over workarounds, hacks, and symptom patches in all software engineering tasks. Use when debugging issues, fixing bugs, resolving test failures, planning solutions, making architectural decisions, or reviewing code changes. Activates gate functions that detect and reject common workaround patterns such as type assertions, lint suppressions, error swallowing, timing hacks, and monkey patches. Don't use for trivial formatting changes or documentation-only edits.