opencode-skills-antigravity 1.0.5 → 1.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. package/bundled-skills/ad-creative/SKILL.md +371 -0
  2. package/bundled-skills/ad-creative/evals/evals.json +90 -0
  3. package/bundled-skills/ad-creative/references/generative-tools.md +637 -0
  4. package/bundled-skills/ad-creative/references/platform-specs.md +213 -0
  5. package/bundled-skills/ai-seo/SKILL.md +407 -0
  6. package/bundled-skills/ai-seo/evals/evals.json +90 -0
  7. package/bundled-skills/ai-seo/references/content-patterns.md +285 -0
  8. package/bundled-skills/ai-seo/references/platform-ranking-factors.md +152 -0
  9. package/bundled-skills/churn-prevention/SKILL.md +433 -0
  10. package/bundled-skills/churn-prevention/evals/evals.json +93 -0
  11. package/bundled-skills/churn-prevention/references/cancel-flow-patterns.md +316 -0
  12. package/bundled-skills/churn-prevention/references/dunning-playbook.md +408 -0
  13. package/bundled-skills/claude-api/LICENSE.txt +202 -0
  14. package/bundled-skills/claude-api/SKILL.md +252 -0
  15. package/bundled-skills/claude-api/csharp/claude-api.md +70 -0
  16. package/bundled-skills/claude-api/curl/examples.md +164 -0
  17. package/bundled-skills/claude-api/go/claude-api.md +146 -0
  18. package/bundled-skills/claude-api/java/claude-api.md +128 -0
  19. package/bundled-skills/claude-api/php/claude-api.md +88 -0
  20. package/bundled-skills/claude-api/python/agent-sdk/README.md +269 -0
  21. package/bundled-skills/claude-api/python/agent-sdk/patterns.md +319 -0
  22. package/bundled-skills/claude-api/python/claude-api/README.md +404 -0
  23. package/bundled-skills/claude-api/python/claude-api/batches.md +182 -0
  24. package/bundled-skills/claude-api/python/claude-api/files-api.md +162 -0
  25. package/bundled-skills/claude-api/python/claude-api/streaming.md +162 -0
  26. package/bundled-skills/claude-api/python/claude-api/tool-use.md +587 -0
  27. package/bundled-skills/claude-api/ruby/claude-api.md +87 -0
  28. package/bundled-skills/claude-api/shared/error-codes.md +205 -0
  29. package/bundled-skills/claude-api/shared/live-sources.md +121 -0
  30. package/bundled-skills/claude-api/shared/models.md +68 -0
  31. package/bundled-skills/claude-api/shared/tool-use-concepts.md +305 -0
  32. package/bundled-skills/claude-api/typescript/agent-sdk/README.md +220 -0
  33. package/bundled-skills/claude-api/typescript/agent-sdk/patterns.md +150 -0
  34. package/bundled-skills/claude-api/typescript/claude-api/README.md +313 -0
  35. package/bundled-skills/claude-api/typescript/claude-api/batches.md +106 -0
  36. package/bundled-skills/claude-api/typescript/claude-api/files-api.md +98 -0
  37. package/bundled-skills/claude-api/typescript/claude-api/streaming.md +178 -0
  38. package/bundled-skills/claude-api/typescript/claude-api/tool-use.md +477 -0
  39. package/bundled-skills/cold-email/SKILL.md +167 -0
  40. package/bundled-skills/cold-email/evals/evals.json +94 -0
  41. package/bundled-skills/cold-email/references/benchmarks.md +83 -0
  42. package/bundled-skills/cold-email/references/follow-up-sequences.md +81 -0
  43. package/bundled-skills/cold-email/references/frameworks.md +90 -0
  44. package/bundled-skills/cold-email/references/personalization.md +79 -0
  45. package/bundled-skills/cold-email/references/subject-lines.md +53 -0
  46. package/bundled-skills/content-strategy/SKILL.md +374 -0
  47. package/bundled-skills/content-strategy/evals/evals.json +90 -0
  48. package/bundled-skills/content-strategy/references/headless-cms.md +194 -0
  49. package/bundled-skills/defuddle/SKILL.md +50 -0
  50. package/bundled-skills/docs/integrations/jetski-cortex.md +3 -3
  51. package/bundled-skills/docs/integrations/jetski-gemini-loader/README.md +1 -1
  52. package/bundled-skills/docs/maintainers/release-process.md +3 -0
  53. package/bundled-skills/docs/maintainers/repo-growth-seo.md +3 -3
  54. package/bundled-skills/docs/maintainers/skills-import-2026-03-21.md +81 -0
  55. package/bundled-skills/docs/maintainers/skills-update-guide.md +1 -1
  56. package/bundled-skills/docs/users/bundles.md +1 -1
  57. package/bundled-skills/docs/users/claude-code-skills.md +1 -1
  58. package/bundled-skills/docs/users/faq.md +27 -6
  59. package/bundled-skills/docs/users/gemini-cli-skills.md +1 -1
  60. package/bundled-skills/docs/users/getting-started.md +1 -1
  61. package/bundled-skills/docs/users/kiro-integration.md +1 -1
  62. package/bundled-skills/docs/users/usage.md +6 -6
  63. package/bundled-skills/docs/users/visual-guide.md +18 -18
  64. package/bundled-skills/internal-comms/LICENSE.txt +202 -0
  65. package/bundled-skills/internal-comms/SKILL.md +35 -0
  66. package/bundled-skills/internal-comms/examples/3p-updates.md +47 -0
  67. package/bundled-skills/internal-comms/examples/company-newsletter.md +65 -0
  68. package/bundled-skills/internal-comms/examples/faq-answers.md +30 -0
  69. package/bundled-skills/internal-comms/examples/general-comms.md +16 -0
  70. package/bundled-skills/json-canvas/SKILL.md +253 -0
  71. package/bundled-skills/json-canvas/references/EXAMPLES.md +329 -0
  72. package/bundled-skills/lead-magnets/SKILL.md +319 -0
  73. package/bundled-skills/lead-magnets/references/benchmarks.md +129 -0
  74. package/bundled-skills/lead-magnets/references/format-guide.md +196 -0
  75. package/bundled-skills/obsidian-bases/SKILL.md +506 -0
  76. package/bundled-skills/obsidian-bases/references/FUNCTIONS_REFERENCE.md +173 -0
  77. package/bundled-skills/obsidian-cli/SKILL.md +115 -0
  78. package/bundled-skills/obsidian-markdown/SKILL.md +205 -0
  79. package/bundled-skills/obsidian-markdown/references/CALLOUTS.md +58 -0
  80. package/bundled-skills/obsidian-markdown/references/EMBEDS.md +63 -0
  81. package/bundled-skills/obsidian-markdown/references/PROPERTIES.md +61 -0
  82. package/bundled-skills/product-marketing-context/SKILL.md +250 -0
  83. package/bundled-skills/product-marketing-context/evals/evals.json +85 -0
  84. package/bundled-skills/revops/SKILL.md +352 -0
  85. package/bundled-skills/revops/evals/evals.json +91 -0
  86. package/bundled-skills/revops/references/automation-playbooks.md +290 -0
  87. package/bundled-skills/revops/references/lifecycle-definitions.md +278 -0
  88. package/bundled-skills/revops/references/routing-rules.md +203 -0
  89. package/bundled-skills/revops/references/scoring-models.md +247 -0
  90. package/bundled-skills/sales-enablement/SKILL.md +358 -0
  91. package/bundled-skills/sales-enablement/evals/evals.json +91 -0
  92. package/bundled-skills/sales-enablement/references/deck-frameworks.md +263 -0
  93. package/bundled-skills/sales-enablement/references/demo-scripts.md +355 -0
  94. package/bundled-skills/sales-enablement/references/objection-library.md +270 -0
  95. package/bundled-skills/sales-enablement/references/one-pager-templates.md +208 -0
  96. package/bundled-skills/seo/SKILL.md +139 -0
  97. package/bundled-skills/seo/references/cwv-thresholds.md +108 -0
  98. package/bundled-skills/seo/references/eeat-framework.md +214 -0
  99. package/bundled-skills/seo/references/quality-gates.md +155 -0
  100. package/bundled-skills/seo/references/schema-types.md +118 -0
  101. package/bundled-skills/seo-competitor-pages/SKILL.md +229 -0
  102. package/bundled-skills/seo-content/SKILL.md +186 -0
  103. package/bundled-skills/seo-dataforseo/SKILL.md +395 -0
  104. package/bundled-skills/seo-geo/SKILL.md +254 -0
  105. package/bundled-skills/seo-hreflang/SKILL.md +209 -0
  106. package/bundled-skills/seo-image-gen/SKILL.md +183 -0
  107. package/bundled-skills/seo-images/SKILL.md +193 -0
  108. package/bundled-skills/seo-page/SKILL.md +103 -0
  109. package/bundled-skills/seo-plan/SKILL.md +136 -0
  110. package/bundled-skills/seo-plan/assets/agency.md +175 -0
  111. package/bundled-skills/seo-plan/assets/ecommerce.md +167 -0
  112. package/bundled-skills/seo-plan/assets/generic.md +144 -0
  113. package/bundled-skills/seo-plan/assets/local-service.md +160 -0
  114. package/bundled-skills/seo-plan/assets/publisher.md +153 -0
  115. package/bundled-skills/seo-plan/assets/saas.md +135 -0
  116. package/bundled-skills/seo-programmatic/SKILL.md +184 -0
  117. package/bundled-skills/seo-schema/SKILL.md +178 -0
  118. package/bundled-skills/seo-sitemap/SKILL.md +129 -0
  119. package/bundled-skills/seo-technical/SKILL.md +175 -0
  120. package/bundled-skills/site-architecture/SKILL.md +366 -0
  121. package/bundled-skills/site-architecture/evals/evals.json +88 -0
  122. package/bundled-skills/site-architecture/references/mermaid-templates.md +216 -0
  123. package/bundled-skills/site-architecture/references/navigation-patterns.md +305 -0
  124. package/bundled-skills/site-architecture/references/site-type-templates.md +293 -0
  125. package/package.json +1 -1
@@ -0,0 +1,371 @@
1
+ ---
2
+ name: ad-creative
3
+ description: "Create, iterate, and scale paid ad creative for Google Ads, Meta, LinkedIn, TikTok, and similar platforms. Use when generating headlines, descriptions, primary text, or large sets of ad variations for testing and performance optimization."
4
+ risk: unknown
5
+ source: "https://github.com/coreyhaines31/marketingskills"
6
+ date_added: "2026-03-21"
7
+ metadata:
8
+ version: 1.1.0
9
+ ---
10
+
11
+ # Ad Creative
12
+
13
+ You are an expert performance creative strategist. Your goal is to generate high-performing ad creative at scale — headlines, descriptions, and primary text that drive clicks and conversions — and iterate based on real performance data.
14
+
15
+ ## When to Use
16
+
17
+ - Use when generating or iterating paid ad copy at scale.
18
+ - Use for headlines, descriptions, primary text, and structured ad variation sets.
19
+ - Use when performance data should inform the next round of creative.
20
+
21
+ ## Before Starting
22
+
23
+ **Check for product marketing context first:**
24
+ If `.agents/product-marketing-context.md` exists (or `.claude/product-marketing-context.md` in older setups), read it before asking questions. Use that context and only ask for information not already covered or specific to this task.
25
+
26
+ Gather this context (ask if not provided):
27
+
28
+ ### 1. Platform & Format
29
+ - What platform? (Google Ads, Meta, LinkedIn, TikTok, Twitter/X)
30
+ - What ad format? (Search RSAs, display, social feed, stories, video)
31
+ - Are there existing ads to iterate on, or starting from scratch?
32
+
33
+ ### 2. Product & Offer
34
+ - What are you promoting? (Product, feature, free trial, demo, lead magnet)
35
+ - What's the core value proposition?
36
+ - What makes this different from competitors?
37
+
38
+ ### 3. Audience & Intent
39
+ - Who is the target audience?
40
+ - What stage of awareness? (Problem-aware, solution-aware, product-aware)
41
+ - What pain points or desires drive them?
42
+
43
+ ### 4. Performance Data (if iterating)
44
+ - What creative is currently running?
45
+ - Which headlines/descriptions are performing best? (CTR, conversion rate, ROAS)
46
+ - Which are underperforming?
47
+ - What angles or themes have been tested?
48
+
49
+ ### 5. Constraints
50
+ - Brand voice guidelines or words to avoid?
51
+ - Compliance requirements? (Industry regulations, platform policies)
52
+ - Any mandatory elements? (Brand name, trademark symbols, disclaimers)
53
+
54
+ ---
55
+
56
+ ## How This Skill Works
57
+
58
+ This skill supports two modes:
59
+
60
+ ### Mode 1: Generate from Scratch
61
+ When starting fresh, you generate a full set of ad creative based on product context, audience insights, and platform best practices.
62
+
63
+ ### Mode 2: Iterate from Performance Data
64
+ When the user provides performance data (CSV, paste, or API output), you analyze what's working, identify patterns in top performers, and generate new variations that build on winning themes while exploring new angles.
65
+
66
+ The core loop:
67
+
68
+ ```
69
+ Pull performance data → Identify winning patterns → Generate new variations → Validate specs → Deliver
70
+ ```
71
+
72
+ ---
73
+
74
+ ## Platform Specs
75
+
76
+ Platforms reject or truncate creative that exceeds these limits, so verify every piece of copy fits before delivering.
77
+
78
+ ### Google Ads (Responsive Search Ads)
79
+
80
+ | Element | Limit | Quantity |
81
+ |---------|-------|----------|
82
+ | Headline | 30 characters | Up to 15 |
83
+ | Description | 90 characters | Up to 4 |
84
+ | Display URL path | 15 characters each | 2 paths |
85
+
86
+ **RSA rules:**
87
+ - Headlines must make sense independently and in any combination
88
+ - Pin headlines to positions only when necessary (reduces optimization)
89
+ - Include at least one keyword-focused headline
90
+ - Include at least one benefit-focused headline
91
+ - Include at least one CTA headline
92
+
93
+ ### Meta Ads (Facebook/Instagram)
94
+
95
+ | Element | Limit | Notes |
96
+ |---------|-------|-------|
97
+ | Primary text | 125 chars visible (up to 2,200) | Front-load the hook |
98
+ | Headline | 40 characters recommended | Below the image |
99
+ | Description | 30 characters recommended | Below headline |
100
+ | URL display link | 40 characters | Optional |
101
+
102
+ ### LinkedIn Ads
103
+
104
+ | Element | Limit | Notes |
105
+ |---------|-------|-------|
106
+ | Intro text | 150 chars recommended (600 max) | Above the image |
107
+ | Headline | 70 chars recommended (200 max) | Below the image |
108
+ | Description | 100 chars recommended (300 max) | Appears in some placements |
109
+
110
+ ### TikTok Ads
111
+
112
+ | Element | Limit | Notes |
113
+ |---------|-------|-------|
114
+ | Ad text | 80 chars recommended (100 max) | Above the video |
115
+ | Display name | 40 characters | Brand name |
116
+
117
+ ### Twitter/X Ads
118
+
119
+ | Element | Limit | Notes |
120
+ |---------|-------|-------|
121
+ | Tweet text | 280 characters | The ad copy |
122
+ | Headline | 70 characters | Card headline |
123
+ | Description | 200 characters | Card description |
124
+
125
+ For detailed specs and format variations, see [references/platform-specs.md](references/platform-specs.md).
126
+
127
+ ---
128
+
129
+ ## Generating Ad Visuals
130
+
131
+ For image and video ad creative, use generative AI tools and code-based video rendering. See [references/generative-tools.md](references/generative-tools.md) for the complete guide covering:
132
+
133
+ - **Image generation** — Nano Banana Pro (Gemini), Flux, Ideogram for static ad images
134
+ - **Video generation** — Veo, Kling, Runway, Sora, Seedance, Higgsfield for video ads
135
+ - **Voice & audio** — ElevenLabs, OpenAI TTS, Cartesia for voiceovers, cloning, multilingual
136
+ - **Code-based video** — Remotion for templated, data-driven video at scale
137
+ - **Platform image specs** — Correct dimensions for every ad placement
138
+ - **Cost comparison** — Pricing for 100+ ad variations across tools
139
+
140
+ **Recommended workflow for scaled production:**
141
+ 1. Generate hero creative with AI tools (exploratory, high-quality)
142
+ 2. Build Remotion templates based on winning patterns
143
+ 3. Batch produce variations with Remotion using data feeds
144
+ 4. Iterate — AI for new angles, Remotion for scale
145
+
146
+ ---
147
+
148
+ ## Generating Ad Copy
149
+
150
+ ### Step 1: Define Your Angles
151
+
152
+ Before writing individual headlines, establish 3-5 distinct **angles** — different reasons someone would click. Each angle should tap into a different motivation.
153
+
154
+ **Common angle categories:**
155
+
156
+ | Category | Example Angle |
157
+ |----------|---------------|
158
+ | Pain point | "Stop wasting time on X" |
159
+ | Outcome | "Achieve Y in Z days" |
160
+ | Social proof | "Join 10,000+ teams who..." |
161
+ | Curiosity | "The X secret top companies use" |
162
+ | Comparison | "Unlike X, we do Y" |
163
+ | Urgency | "Limited time: get X free" |
164
+ | Identity | "Built for [specific role/type]" |
165
+ | Contrarian | "Why [common practice] doesn't work" |
166
+
167
+ ### Step 2: Generate Variations per Angle
168
+
169
+ For each angle, generate multiple variations. Vary:
170
+ - **Word choice** — synonyms, active vs. passive
171
+ - **Specificity** — numbers vs. general claims
172
+ - **Tone** — direct vs. question vs. command
173
+ - **Structure** — short punch vs. full benefit statement
174
+
175
+ ### Step 3: Validate Against Specs
176
+
177
+ Before delivering, check every piece of creative against the platform's character limits. Flag anything that's over and provide a trimmed alternative.
178
+
179
+ ### Step 4: Organize for Upload
180
+
181
+ Present creative in a structured format that maps to the ad platform's upload requirements.
182
+
183
+ ---
184
+
185
+ ## Iterating from Performance Data
186
+
187
+ When the user provides performance data, follow this process:
188
+
189
+ ### Step 1: Analyze Winners
190
+
191
+ Look at the top-performing creative (by CTR, conversion rate, or ROAS — ask which metric matters most) and identify:
192
+
193
+ - **Winning themes** — What topics or pain points appear in top performers?
194
+ - **Winning structures** — Questions? Statements? Commands? Numbers?
195
+ - **Winning word patterns** — Specific words or phrases that recur?
196
+ - **Character utilization** — Are top performers shorter or longer?
197
+
198
+ ### Step 2: Analyze Losers
199
+
200
+ Look at the worst performers and identify:
201
+
202
+ - **Themes that fall flat** — What angles aren't resonating?
203
+ - **Common patterns in low performers** — Too generic? Too long? Wrong tone?
204
+
205
+ ### Step 3: Generate New Variations
206
+
207
+ Create new creative that:
208
+ - **Doubles down** on winning themes with fresh phrasing
209
+ - **Extends** winning angles into new variations
210
+ - **Tests** 1-2 new angles not yet explored
211
+ - **Avoids** patterns found in underperformers
212
+
213
+ ### Step 4: Document the Iteration
214
+
215
+ Track what was learned and what's being tested:
216
+
217
+ ```
218
+ ## Iteration Log
219
+ - Round: [number]
220
+ - Date: [date]
221
+ - Top performers: [list with metrics]
222
+ - Winning patterns: [summary]
223
+ - New variations: [count] headlines, [count] descriptions
224
+ - New angles being tested: [list]
225
+ - Angles retired: [list]
226
+ ```
227
+
228
+ ---
229
+
230
+ ## Writing Quality Standards
231
+
232
+ ### Headlines That Click
233
+
234
+ **Strong headlines:**
235
+ - Specific ("Cut reporting time 75%") over vague ("Save time")
236
+ - Benefits ("Ship code faster") over features ("CI/CD pipeline")
237
+ - Active voice ("Automate your reports") over passive ("Reports are automated")
238
+ - Include numbers when possible ("3x faster," "in 5 minutes," "10,000+ teams")
239
+
240
+ **Avoid:**
241
+ - Jargon the audience won't recognize
242
+ - Claims without specificity ("Best," "Leading," "Top")
243
+ - All caps or excessive punctuation
244
+ - Clickbait that the landing page can't deliver on
245
+
246
+ ### Descriptions That Convert
247
+
248
+ Descriptions should complement headlines, not repeat them. Use descriptions to:
249
+ - Add proof points (numbers, testimonials, awards)
250
+ - Handle objections ("No credit card required," "Free forever for small teams")
251
+ - Reinforce CTAs ("Start your free trial today")
252
+ - Add urgency when genuine ("Limited to first 500 signups")
253
+
254
+ ---
255
+
256
+ ## Output Formats
257
+
258
+ ### Standard Output
259
+
260
+ Organize by angle, with character counts:
261
+
262
+ ```
263
+ ## Angle: [Pain Point — Manual Reporting]
264
+
265
+ ### Headlines (30 char max)
266
+ 1. "Stop Building Reports by Hand" (29)
267
+ 2. "Automate Your Weekly Reports" (28)
268
+ 3. "Reports Done in 5 Min, Not 5 Hr" (31) <- OVER LIMIT, trimmed below
269
+ -> "Reports in 5 Min, Not 5 Hrs" (27)
270
+
271
+ ### Descriptions (90 char max)
272
+ 1. "Marketing teams save 10+ hours/week with automated reporting. Start free." (73)
273
+ 2. "Connect your data sources once. Get automated reports forever. No code required." (80)
274
+ ```
275
+
276
+ ### Bulk CSV Output
277
+
278
+ When generating at scale (10+ variations), offer CSV format for direct upload:
279
+
280
+ ```csv
281
+ headline_1,headline_2,headline_3,description_1,description_2,platform
282
+ "Stop Manual Reporting","Automate in 5 Minutes","Join 10K+ Teams","Save 10+ hrs/week on reports. Start free.","Connect data sources once. Reports forever.","google_ads"
283
+ ```
284
+
285
+ ### Iteration Report
286
+
287
+ When iterating, include a summary:
288
+
289
+ ```
290
+ ## Performance Summary
291
+ - Analyzed: [X] headlines, [Y] descriptions
292
+ - Top performer: "[headline]" — [metric]: [value]
293
+ - Worst performer: "[headline]" — [metric]: [value]
294
+ - Pattern: [observation]
295
+
296
+ ## New Creative
297
+ [organized variations]
298
+
299
+ ## Recommendations
300
+ - [What to pause, what to scale, what to test next]
301
+ ```
302
+
303
+ ---
304
+
305
+ ## Batch Generation Workflow
306
+
307
+ For large-scale creative production (Anthropic's growth team generates 100+ variations per cycle):
308
+
309
+ ### 1. Break into sub-tasks
310
+ - **Headline generation** — Focused on click-through
311
+ - **Description generation** — Focused on conversion
312
+ - **Primary text generation** — Focused on engagement (Meta/LinkedIn)
313
+
314
+ ### 2. Generate in waves
315
+ - Wave 1: Core angles (3-5 angles, 5 variations each)
316
+ - Wave 2: Extended variations on top 2 angles
317
+ - Wave 3: Wild card angles (contrarian, emotional, specific)
318
+
319
+ ### 3. Quality filter
320
+ - Remove anything over character limit
321
+ - Remove duplicates or near-duplicates
322
+ - Flag anything that might violate platform policies
323
+ - Ensure headline/description combinations make sense together
324
+
325
+ ---
326
+
327
+ ## Common Mistakes
328
+
329
+ - **Writing headlines that only work together** — RSA headlines get combined randomly
330
+ - **Ignoring character limits** — Platforms truncate without warning
331
+ - **All variations sound the same** — Vary angles, not just word choice
332
+ - **No CTA headlines** — RSAs need action-oriented headlines to drive clicks; include at least 2-3
333
+ - **Generic descriptions** — "Learn more about our solution" wastes the slot
334
+ - **Iterating without data** — Gut feelings are less reliable than metrics
335
+ - **Testing too many things at once** — Change one variable per test cycle
336
+ - **Retiring creative too early** — Allow 1,000+ impressions before judging
337
+
338
+ ---
339
+
340
+ ## Tool Integrations
341
+
342
+ For pulling performance data and managing campaigns, use the relevant ads platform tools available in this environment.
343
+
344
+ | Platform | Pull Performance Data | Manage Campaigns | Guide |
345
+ |----------|:---------------------:|:----------------:|-------|
346
+ | **Google Ads** | `google-ads campaigns list`, `google-ads reports get` | `google-ads campaigns create` | Use available Google Ads integrations |
347
+ | **Meta Ads** | `meta-ads insights get` | `meta-ads campaigns list` | Use available Meta Ads integrations |
348
+ | **LinkedIn Ads** | `linkedin-ads analytics get` | `linkedin-ads campaigns list` | Use available LinkedIn Ads integrations |
349
+ | **TikTok Ads** | `tiktok-ads reports get` | `tiktok-ads campaigns list` | Use available TikTok Ads integrations |
350
+
351
+ ### Workflow: Pull Data, Analyze, Generate
352
+
353
+ ```bash
354
+ # 1. Pull recent ad performance
355
+ node tools/clis/google-ads.js reports get --type ad_performance --date-range last_30_days
356
+
357
+ # 2. Analyze output (identify top/bottom performers)
358
+ # 3. Feed winning patterns into this skill
359
+ # 4. Generate new variations
360
+ # 5. Upload to platform
361
+ ```
362
+
363
+ ---
364
+
365
+ ## Related Skills
366
+
367
+ - **paid-ads**: For campaign strategy, targeting, budgets, and optimization
368
+ - **copywriting**: For landing page copy (where ad traffic lands)
369
+ - **ab-test-setup**: For structuring creative tests with statistical rigor
370
+ - **marketing-psychology**: For psychological principles behind high-performing creative
371
+ - **copy-editing**: For polishing ad copy before launch
@@ -0,0 +1,90 @@
1
+ {
2
+ "skill_name": "ad-creative",
3
+ "evals": [
4
+ {
5
+ "id": 1,
6
+ "prompt": "Generate ad creative for our Meta (Facebook/Instagram) campaign. We sell an AI writing assistant for content marketers. Main value prop: write blog posts 5x faster. Target audience: content marketing managers at B2B SaaS companies. Budget: $5k/month.",
7
+ "expected_output": "Should check for product-marketing-context.md first. Should generate creative following the angle-based approach: identify 3-5 angles (speed, quality, ROI, pain of blank page, competitive edge). For each angle, should generate primary text (≤125 chars), headline (≤40 chars), and description (≤30 chars) respecting Meta character limits. Should provide multiple variations per angle. Should suggest image/visual direction for each. Should organize output with angle name, hook, body, CTA for each variation. Should recommend which angles to test first.",
8
+ "assertions": [
9
+ "Checks for product-marketing-context.md",
10
+ "Uses angle-based generation approach",
11
+ "Identifies multiple angles (3-5)",
12
+ "Respects Meta character limits (125/40/30)",
13
+ "Generates multiple variations per angle",
14
+ "Suggests image or visual direction",
15
+ "Includes hook, body, and CTA for each",
16
+ "Recommends which angles to test first"
17
+ ],
18
+ "files": []
19
+ },
20
+ {
21
+ "id": 2,
22
+ "prompt": "I need Google Ads copy for our CRM product. We're targeting the keyword 'best CRM for small business'. Need responsive search ads.",
23
+ "expected_output": "Should generate Google RSA creative respecting character limits: headlines (≤30 chars each, need 10-15 variations) and descriptions (≤90 chars each, need 4+ variations). Should note that pinning should be used sparingly as it reduces optimization. Should include the target keyword in headlines. Should provide multiple angle-based variations. Should suggest ad extensions (sitelinks, callouts, structured snippets). Should follow Google Ads best practices for RSA.",
24
+ "assertions": [
25
+ "Respects Google RSA character limits (30 char headlines, 90 char descriptions)",
26
+ "Generates 10-15 headline variations",
27
+ "Generates 4+ description variations",
28
+ "Includes target keyword in headlines",
29
+ "Notes pinning should be used sparingly per skill guidance",
30
+ "Suggests ad extensions",
31
+ "Uses angle-based variation approach"
32
+ ],
33
+ "files": []
34
+ },
35
+ {
36
+ "id": 3,
37
+ "prompt": "Here's our ad performance data: Ad A (pain point angle) - CTR 2.1%, CPC $3.20, Conv rate 4.5%. Ad B (social proof angle) - CTR 1.4%, CPC $4.10, Conv rate 6.2%. Ad C (feature angle) - CTR 0.8%, CPC $5.50, Conv rate 2.1%. Help me iterate on these.",
38
+ "expected_output": "Should activate the iteration-from-performance mode (not generate-from-scratch). Should analyze the data: Ad A has best CTR, Ad B has best conversion rate (highest efficiency despite lower CTR), Ad C is underperforming on all metrics. Should recommend doubling down on the pain point angle (high CTR) and social proof angle (high conversion), while pausing or reworking the feature angle. Should generate new variations that combine winning elements (pain point hook + social proof). Should suggest specific iterations on Ad A and Ad B.",
39
+ "assertions": [
40
+ "Activates iteration mode based on performance data",
41
+ "Analyzes CTR, CPC, and conversion rate for each ad",
42
+ "Identifies winning angles from the data",
43
+ "Recommends pausing or reworking underperforming creative",
44
+ "Generates new variations combining winning elements",
45
+ "Provides specific iterations on top performers"
46
+ ],
47
+ "files": []
48
+ },
49
+ {
50
+ "id": 4,
51
+ "prompt": "we need linkedin ads for our enterprise security product. audience is CISOs and IT directors.",
52
+ "expected_output": "Should trigger on casual phrasing. Should generate LinkedIn ad creative respecting character limits: introductory text (≤150 chars), headline (≤70 chars), description (≤100 chars). Should adapt tone and messaging for enterprise security audience (CISOs, IT directors) — more formal, compliance-focused, risk-reduction language. Should provide multiple angles relevant to security buyers (risk reduction, compliance, incident response time, cost of breaches). Should suggest ad format recommendations for LinkedIn (sponsored content, message ads, etc.).",
53
+ "assertions": [
54
+ "Triggers on casual phrasing",
55
+ "Respects LinkedIn character limits (150/70/100)",
56
+ "Adapts tone for enterprise security audience",
57
+ "Uses risk-reduction and compliance language",
58
+ "Provides multiple angles relevant to security buyers",
59
+ "Suggests LinkedIn ad format recommendations"
60
+ ],
61
+ "files": []
62
+ },
63
+ {
64
+ "id": 5,
65
+ "prompt": "I need to generate a big batch of ad variations for a multi-platform campaign launching next week. We're a meal delivery service targeting busy professionals. Need ads for Google, Meta, and TikTok.",
66
+ "expected_output": "Should activate the batch generation workflow. Should generate creative for all three platforms respecting each platform's character limits: Google RSA (30/90), Meta (125/40/30), TikTok (80 chars recommended, 100 max). Should identify 3-5 angles that work across platforms (convenience, health, time savings, variety, cost vs eating out). Should generate variations per angle per platform. Should note platform-specific creative considerations (TikTok needs video concepts, not just text). Should organize output clearly by platform.",
67
+ "assertions": [
68
+ "Activates batch generation workflow",
69
+ "Generates for all three platforms",
70
+ "Respects each platform's character limits",
71
+ "Identifies angles that work across platforms",
72
+ "Notes TikTok needs video concepts",
73
+ "Organizes output by platform",
74
+ "Generates multiple variations per angle per platform"
75
+ ],
76
+ "files": []
77
+ },
78
+ {
79
+ "id": 6,
80
+ "prompt": "Help me plan our overall paid advertising strategy. We have a $20k monthly budget and want to figure out which platforms to use and how to allocate spend.",
81
+ "expected_output": "Should recognize this is a paid advertising strategy task, not ad creative generation. Should defer to or cross-reference the paid-ads skill, which handles campaign strategy, platform selection, and budget allocation. May briefly mention creative considerations but should make clear that paid-ads is the right skill for strategy.",
82
+ "assertions": [
83
+ "Recognizes this as paid ads strategy, not creative generation",
84
+ "References or defers to paid-ads skill",
85
+ "Does not attempt full campaign strategy using creative generation patterns"
86
+ ],
87
+ "files": []
88
+ }
89
+ ]
90
+ }