@growthub/cli 0.3.37 → 0.3.39
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.
- package/README.md +26 -2
- package/assets/worker-kits/growthub-email-marketing-v1/brands/_template/brand-kit.md +172 -0
- package/assets/worker-kits/growthub-email-marketing-v1/brands/growthub/VERSION.md +32 -0
- package/assets/worker-kits/growthub-email-marketing-v1/brands/growthub/brand-kit.md +282 -0
- package/assets/worker-kits/growthub-email-marketing-v1/broadcasts/_template/broadcast-vault.md +188 -0
- package/assets/worker-kits/growthub-email-marketing-v1/broadcasts/growthub/broadcast-vault.md +324 -0
- package/assets/worker-kits/growthub-email-marketing-v1/bundles/growthub-email-marketing-v1.json +66 -0
- package/assets/worker-kits/growthub-email-marketing-v1/examples/campaign-brief-sample.md +110 -0
- package/assets/worker-kits/growthub-email-marketing-v1/examples/nurture-sequence-sample.md +265 -0
- package/assets/worker-kits/growthub-email-marketing-v1/examples/subject-line-matrix-sample.md +116 -0
- package/assets/worker-kits/growthub-email-marketing-v1/growthub-meta/README.md +108 -0
- package/assets/worker-kits/growthub-email-marketing-v1/growthub-meta/kit-standard.md +87 -0
- package/assets/worker-kits/growthub-email-marketing-v1/kit.json +101 -0
- package/assets/worker-kits/growthub-email-marketing-v1/output/growthub/showcase-proof-ai-ugc-v1-20260410/Growthub_Broadcast_ShowcaseProof_v1_20260410.md +139 -0
- package/assets/worker-kits/growthub-email-marketing-v1/output/growthub/showcase-proof-ai-ugc-v1-20260410/Growthub_CampaignBrief_ClientResults_v1_20260410.md +115 -0
- package/assets/worker-kits/growthub-email-marketing-v1/output/growthub/showcase-proof-ai-ugc-v1-20260410/Growthub_SubjectLineMatrix_v1_20260410.md +83 -0
- package/assets/worker-kits/growthub-email-marketing-v1/output-standards.md +174 -0
- package/assets/worker-kits/growthub-email-marketing-v1/runtime-assumptions.md +268 -0
- package/assets/worker-kits/growthub-email-marketing-v1/skills.md +490 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/broadcast-formats/INDEX.md +75 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/broadcast-formats/activation-booking.md +156 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/broadcast-formats/engagement-nudge.md +175 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/broadcast-formats/lead-magnet-traffic.md +149 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/broadcast-formats/showcase-proof.md +153 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/broadcast-formats/value-delivery.md +141 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/campaign-brief-template.md +115 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/cta-matrix.md +90 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-draft.md +145 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-formats/INDEX.md +59 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-formats/follow-up-sequence.md +111 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-formats/nurture-sequence.md +143 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-formats/outbound-cold-sequence.md +134 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-formats/promotional-broadcast.md +117 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-formats/re-engagement.md +108 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/INDEX.md +97 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/body/education-block.md +131 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/body/problem-agitate.md +107 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/body/story-bridge.md +112 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/body/value-reveal.md +107 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/cta/primary-cta.md +116 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/cta/reply-cta.md +131 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/cta/soft-cta.md +117 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/subject-lines/curiosity.md +112 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/subject-lines/personal.md +108 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/subject-lines/social-proof.md +109 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/email-modules/subject-lines/urgency.md +112 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/hooks-library/subject-line-patterns.csv +73 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/qa-checklist.md +106 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/sequence-planner.md +94 -0
- package/assets/worker-kits/growthub-email-marketing-v1/templates/subject-line-matrix.md +136 -0
- package/assets/worker-kits/growthub-email-marketing-v1/workers/email-marketing-strategist/CLAUDE.md +294 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/.env.example +9 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/QUICKSTART.md +85 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/brands/NEW-CLIENT.md +46 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/brands/_template/brand-kit.md +89 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/brands/growthub/brand-kit.md +96 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/bundles/growthub-open-higgsfield-studio-v1.json +57 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/docs/open-higgsfield-fork-integration.md +63 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/docs/provider-adapter-layer.md +67 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/examples/platform-ready-handoff-sample.md +24 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/examples/prompt-matrix-sample.md +6 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/examples/shot-plan-sample.md +7 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/examples/visual-campaign-brief-sample.md +22 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/growthub-meta/README.md +67 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/growthub-meta/kit-standard.md +47 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/kit.json +106 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/output/README.md +34 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/output-standards.md +133 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/runtime-assumptions.md +108 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/setup/check-deps.sh +37 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/setup/clone-fork.sh +27 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/setup/verify-env.mjs +72 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/skills.md +257 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/asset-tracking.md +5 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/frame-analysis.md +24 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/generation-batch-plan.md +7 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/model-selection-recommendation.md +23 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/platform-ready-execution-handoff.md +17 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/prompt-matrix.md +7 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/prompt-templates/cinema-generation.md +16 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/prompt-templates/image-generation.md +11 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/prompt-templates/lip-sync-generation.md +14 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/prompt-templates/video-generation.md +11 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/review-qa-checklist.md +26 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/shot-plan.md +11 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/studio-selection-brief.md +18 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/templates/visual-campaign-brief.md +24 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/validation-checklist.md +49 -0
- package/assets/worker-kits/growthub-open-higgsfield-studio-v1/workers/open-higgsfield-studio-operator/CLAUDE.md +264 -0
- package/package.json +1 -1
|
@@ -0,0 +1,490 @@
|
|
|
1
|
+
# Email Marketing Strategist — Master Skill Doc
|
|
2
|
+
|
|
3
|
+
**Source of truth for methodology. Read this file completely before beginning any task.**
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## QUICK REFERENCE TABLE
|
|
8
|
+
|
|
9
|
+
| Resource | Path |
|
|
10
|
+
|---|---|
|
|
11
|
+
| Agent operating law | `workers/email-marketing-strategist/CLAUDE.md` |
|
|
12
|
+
| Brand kit template | `brands/_template/brand-kit.md` |
|
|
13
|
+
| Growthub brand kit | `brands/growthub/brand-kit.md` |
|
|
14
|
+
| Email format library | `templates/email-formats/INDEX.md` |
|
|
15
|
+
| Broadcast format library | `templates/broadcast-formats/INDEX.md` |
|
|
16
|
+
| Broadcast vault template | `broadcasts/_template/broadcast-vault.md` |
|
|
17
|
+
| Growthub broadcast vault | `broadcasts/growthub/broadcast-vault.md` |
|
|
18
|
+
| Email module library | `templates/email-modules/INDEX.md` |
|
|
19
|
+
| Subject line patterns | `templates/hooks-library/subject-line-patterns.csv` |
|
|
20
|
+
| Campaign brief template | `templates/campaign-brief-template.md` |
|
|
21
|
+
| Sequence planner | `templates/sequence-planner.md` |
|
|
22
|
+
| Email draft template | `templates/email-draft.md` |
|
|
23
|
+
| Subject line matrix template | `templates/subject-line-matrix.md` |
|
|
24
|
+
| CTA matrix template | `templates/cta-matrix.md` |
|
|
25
|
+
| QA checklist | `templates/qa-checklist.md` |
|
|
26
|
+
| Output standards | `output-standards.md` |
|
|
27
|
+
| Platform integration | `runtime-assumptions.md` |
|
|
28
|
+
| Example: campaign brief | `examples/campaign-brief-sample.md` |
|
|
29
|
+
| Example: nurture sequence | `examples/nurture-sequence-sample.md` |
|
|
30
|
+
| Example: subject line matrix | `examples/subject-line-matrix-sample.md` |
|
|
31
|
+
| Output folder | `output/<client-slug>/<campaign-slug>/` |
|
|
32
|
+
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
## STEP 0 — BEFORE ANY TASK, ANSWER THESE QUESTIONS
|
|
36
|
+
|
|
37
|
+
Before writing a single word of copy, answer:
|
|
38
|
+
|
|
39
|
+
1. **Who is the client?** (slug, brand kit location)
|
|
40
|
+
2. **What campaign type?** (nurture / cold outbound / follow-up / re-engagement / promotional)
|
|
41
|
+
3. **Which content pillar?** (Growth System / Automation & AI / Client Results / Education & Strategy / Pipeline & Revenue)
|
|
42
|
+
4. **Who is the audience segment?** (new lead / warm prospect / past client / stalled pipeline / re-engage)
|
|
43
|
+
5. **What is the primary CTA?** (book call / start trial / claim offer / reply / read resource)
|
|
44
|
+
6. **Is platform handoff in scope?** (API / browser / export only)
|
|
45
|
+
|
|
46
|
+
If any of these are unknown after Step 3 of CLAUDE.md, ask before proceeding.
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
## STEP 1 — LOAD THE BRAND KIT
|
|
51
|
+
|
|
52
|
+
### 1a — If brand kit exists
|
|
53
|
+
|
|
54
|
+
```
|
|
55
|
+
Read: brands/<client-slug>/brand-kit.md
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
Extract into working context:
|
|
59
|
+
- `voice_and_tone` — exact adjectives, not summaries
|
|
60
|
+
- `approved_phrases` — verbatim, use these in copy
|
|
61
|
+
- `messaging_guardrails` — absolute no-go items
|
|
62
|
+
- `content_pillars` — definitions and angle mappings
|
|
63
|
+
- `cta_language` — exact CTA text from brand kit
|
|
64
|
+
- `compliance_notes` — required disclaimers and restrictions
|
|
65
|
+
|
|
66
|
+
### 1b — If brand kit does not exist
|
|
67
|
+
|
|
68
|
+
Copy `brands/_template/brand-kit.md` to `brands/<client-slug>/brand-kit.md`.
|
|
69
|
+
Ask the user to fill in the required fields before any copy is written.
|
|
70
|
+
Minimum required fields: `client_name`, `slug`, `voice_and_tone`, `content_pillars`, `approved_phrases`, `messaging_guardrails`, `primary_cta`.
|
|
71
|
+
|
|
72
|
+
---
|
|
73
|
+
|
|
74
|
+
## STEP 2 — CHECK THE FORMAT LIBRARY
|
|
75
|
+
|
|
76
|
+
```
|
|
77
|
+
Read: templates/email-formats/INDEX.md
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
Match the requested campaign type to a frozen format:
|
|
81
|
+
|
|
82
|
+
| Campaign type | Frozen format file |
|
|
83
|
+
|---|---|
|
|
84
|
+
| Lead nurture (5 emails) | `templates/email-formats/nurture-sequence.md` |
|
|
85
|
+
| Cold outbound (4 emails) | `templates/email-formats/outbound-cold-sequence.md` |
|
|
86
|
+
| Promotional broadcast (1 email) | `templates/email-formats/promotional-broadcast.md` |
|
|
87
|
+
| Re-engagement / win-back (3 emails) | `templates/email-formats/re-engagement.md` |
|
|
88
|
+
| Post-demo follow-up (3 emails) | `templates/email-formats/follow-up-sequence.md` |
|
|
89
|
+
|
|
90
|
+
**If a frozen format matches → use it exactly. Do not reinvent the arc structure.**
|
|
91
|
+
**If no format matches → build from `templates/sequence-planner.md` and freeze the new format after delivery.**
|
|
92
|
+
|
|
93
|
+
---
|
|
94
|
+
|
|
95
|
+
## STEP 2B — BROADCAST VAULT (for broadcast campaigns only)
|
|
96
|
+
|
|
97
|
+
> Skip this step for multi-email sequences. This step applies ONLY when the campaign type is a single-send broadcast.
|
|
98
|
+
|
|
99
|
+
### What is a broadcast?
|
|
100
|
+
|
|
101
|
+
A broadcast is a single-send email to a list segment — not a sequence. It is planned from the vault, not from a sequence brief. Use this step instead of the multi-email format workflow.
|
|
102
|
+
|
|
103
|
+
### Broadcast workflow
|
|
104
|
+
|
|
105
|
+
```
|
|
106
|
+
1. Load the vault
|
|
107
|
+
Read: broadcasts/<client-slug>/broadcast-vault.md
|
|
108
|
+
→ Load the full vault into working context
|
|
109
|
+
|
|
110
|
+
2. Identify the campaign goal
|
|
111
|
+
→ Deliver free value → format: value-delivery
|
|
112
|
+
→ Drive traffic to LM page → format: lead-magnet-traffic
|
|
113
|
+
→ Share proof / credibility → format: showcase-proof
|
|
114
|
+
→ Warm up / re-engage → format: engagement-nudge
|
|
115
|
+
→ Move warm leads to book → format: activation-booking
|
|
116
|
+
|
|
117
|
+
3. Check the broadcast format index
|
|
118
|
+
Read: templates/broadcast-formats/INDEX.md
|
|
119
|
+
→ Confirm format selection against the campaign goal
|
|
120
|
+
|
|
121
|
+
4. Select the vault asset
|
|
122
|
+
→ Match the campaign goal to the best asset from the vault
|
|
123
|
+
→ Check: asset status = active
|
|
124
|
+
→ Check cadence: same asset not sent to this segment in last 60 days
|
|
125
|
+
|
|
126
|
+
5. Load the format template
|
|
127
|
+
Read: templates/broadcast-formats/<format-id>.md
|
|
128
|
+
→ Fill all [PLACEHOLDER] slots from vault + brand kit
|
|
129
|
+
|
|
130
|
+
6. Generate subject line matrix
|
|
131
|
+
→ 3–5 options using subject line structures in the format file
|
|
132
|
+
→ Preview text paired with each subject line option
|
|
133
|
+
|
|
134
|
+
7. Platform handoff
|
|
135
|
+
→ Per runtime-assumptions.md
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
### Broadcast asset selection guide
|
|
139
|
+
|
|
140
|
+
| Campaign goal | Best vault asset types | Broadcast format |
|
|
141
|
+
|---|---|---|
|
|
142
|
+
| Deliver free value, build goodwill | Lead magnets (lm-*) | `value-delivery` |
|
|
143
|
+
| Drive traffic to a specific resource | Lead magnets with landing pages | `lead-magnet-traffic` |
|
|
144
|
+
| Build credibility, show results | Case studies (cs-*), showcases (sh-*) | `showcase-proof` |
|
|
145
|
+
| Warm up cold/cool leads | YouTube (yt-*), community (lm-04), educational LMs | `engagement-nudge` |
|
|
146
|
+
| Nudge warm leads toward booking | Testimonial (t-*), case studies, showcases | `activation-booking` |
|
|
147
|
+
|
|
148
|
+
### Broadcast cadence rules
|
|
149
|
+
|
|
150
|
+
Always check these before scheduling any broadcast send:
|
|
151
|
+
|
|
152
|
+
- Max 2 broadcasts per week
|
|
153
|
+
- Min 3 days between sends
|
|
154
|
+
- Preferred send days: Tuesday, Thursday
|
|
155
|
+
- Preferred send time: 9–11am recipient local time
|
|
156
|
+
- Do not re-send same vault asset to same segment within 60 days
|
|
157
|
+
- Never send the same lead magnet twice in one month to the same segment
|
|
158
|
+
|
|
159
|
+
---
|
|
160
|
+
|
|
161
|
+
## STEP 3 — CONFIRM BRIEF INPUTS
|
|
162
|
+
|
|
163
|
+
Before writing, collect all required fields:
|
|
164
|
+
|
|
165
|
+
**Campaign identity:**
|
|
166
|
+
- Campaign name
|
|
167
|
+
- Campaign type (from format library)
|
|
168
|
+
- Content pillar (anchor pillar)
|
|
169
|
+
- Secondary pillar (if blending)
|
|
170
|
+
- Audience segment + stage
|
|
171
|
+
- Entry trigger (what event starts this sequence)
|
|
172
|
+
- Goal (what the campaign is trying to get the reader to do)
|
|
173
|
+
|
|
174
|
+
**Copy direction:**
|
|
175
|
+
- Campaign angle (confirmed with user in CLAUDE.md Step 4)
|
|
176
|
+
- Emotional arc (Frustrated → Informed → Activated, or custom)
|
|
177
|
+
- Voice/tone notes (from brand kit, any campaign-specific additions)
|
|
178
|
+
- Compliance constraints (from brand kit + any campaign-specific)
|
|
179
|
+
|
|
180
|
+
**CTA spec:**
|
|
181
|
+
- Primary CTA (exact text + URL or action)
|
|
182
|
+
- Secondary CTA (optional — reply, resource, softer ask)
|
|
183
|
+
- Platform segment tag or trigger condition (if platform handoff in scope)
|
|
184
|
+
|
|
185
|
+
---
|
|
186
|
+
|
|
187
|
+
## STEP 4 — CONTENT PILLAR → CAMPAIGN ANGLE MAPPING
|
|
188
|
+
|
|
189
|
+
This is the core strategic layer. Every campaign is anchored to a pillar. The pillar determines the angle, the emotional arc, and the language patterns.
|
|
190
|
+
|
|
191
|
+
### Pillar 1 — Growth System
|
|
192
|
+
**Core idea:** Growthub is not a tool. It is the operating system for growth — infrastructure that makes scaling systematic, not chaotic.
|
|
193
|
+
|
|
194
|
+
**Campaign angles:**
|
|
195
|
+
- "Your growth is leaking — here's where"
|
|
196
|
+
- "Most businesses don't have a growth problem. They have a systems problem."
|
|
197
|
+
- "The difference between businesses that scale and those that stall isn't budget — it's infrastructure."
|
|
198
|
+
- "What happens when you remove the chaos from growth?"
|
|
199
|
+
|
|
200
|
+
**Emotional arc:** Chaotic → Systematic → In Control
|
|
201
|
+
**Voice:** Confident, diagnostic, operator-to-operator
|
|
202
|
+
**Language patterns:**
|
|
203
|
+
- "growth infrastructure", "systematic scaling", "without the chaos"
|
|
204
|
+
- "built-in accountability", "growth that compounds"
|
|
205
|
+
- "most agencies run on duct tape — this is the alternative"
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
### Pillar 2 — Automation & AI
|
|
210
|
+
**Core idea:** Speed from insight to action. The businesses winning right now are moving faster — not working harder. Automation removes the bottleneck between thinking and doing.
|
|
211
|
+
|
|
212
|
+
**Campaign angles:**
|
|
213
|
+
- "The bottleneck isn't your team. It's the time between ideas and execution."
|
|
214
|
+
- "What if your follow-up never dropped the ball again?"
|
|
215
|
+
- "Speed is the new competitive advantage in [niche]. Here's how to get it."
|
|
216
|
+
- "Most of your pipeline dies in the gap between 'not ready yet' and 'ready to buy.' Automation closes that gap."
|
|
217
|
+
|
|
218
|
+
**Emotional arc:** Overwhelmed → Informed → Empowered
|
|
219
|
+
**Voice:** Practical, specific, outcome-forward — not hype-driven
|
|
220
|
+
**Language patterns:**
|
|
221
|
+
- "speed to winning results", "automated follow-up that works while you sleep"
|
|
222
|
+
- "ideas → execution → learning", "test faster than competitors can react"
|
|
223
|
+
- "remove the bottleneck", "without adding headcount"
|
|
224
|
+
|
|
225
|
+
---
|
|
226
|
+
|
|
227
|
+
### Pillar 3 — Client Results
|
|
228
|
+
**Core idea:** Proof over promises. The most compelling thing we can show is what happened for someone like you. Results, specifics, stories — not features.
|
|
229
|
+
|
|
230
|
+
**Campaign angles:**
|
|
231
|
+
- "What [Name/Business type] did in [timeframe] with Growthub"
|
|
232
|
+
- "The agency that went from [X problem] to [Y outcome]"
|
|
233
|
+
- "Here's what scaling without chaos actually looks like"
|
|
234
|
+
- "Before Growthub: [pain]. After: [outcome]."
|
|
235
|
+
|
|
236
|
+
**Emotional arc:** Skeptical → Curious → Convinced
|
|
237
|
+
**Voice:** Story-forward, specific, peer-to-peer (not testimonial-polished)
|
|
238
|
+
**Language patterns:**
|
|
239
|
+
- exact metrics and outcomes (approved in brand kit only)
|
|
240
|
+
- "here's what actually happened", "not theory — this is a real result"
|
|
241
|
+
- "the same system is available to you"
|
|
242
|
+
|
|
243
|
+
---
|
|
244
|
+
|
|
245
|
+
### Pillar 4 — Education & Strategy
|
|
246
|
+
**Core idea:** We earn attention by making people smarter. Teach first. Position second. The most trusted brands give value before they ask for anything.
|
|
247
|
+
|
|
248
|
+
**Campaign angles:**
|
|
249
|
+
- "The [N]-step framework for [desired outcome]"
|
|
250
|
+
- "Why [common belief] is costing you [cost]"
|
|
251
|
+
- "The thing nobody tells you about [topic relevant to ICP]"
|
|
252
|
+
- "Here is exactly how we [do the thing your audience wants to do]"
|
|
253
|
+
|
|
254
|
+
**Emotional arc:** Curious → Informed → Action-ready
|
|
255
|
+
**Voice:** Generous, credible, direct — no condescension
|
|
256
|
+
**Language patterns:**
|
|
257
|
+
- "here's what we've found", "this is the framework we use"
|
|
258
|
+
- "most people miss this step", "the unlock is simpler than you think"
|
|
259
|
+
- "you can steal this", "take this and run with it"
|
|
260
|
+
|
|
261
|
+
---
|
|
262
|
+
|
|
263
|
+
### Pillar 5 — Pipeline & Revenue
|
|
264
|
+
**Core idea:** Email is a pipeline tool, not a broadcast tool. Every sequence should move someone from one stage to the next. The metric is pipeline movement, not open rates.
|
|
265
|
+
|
|
266
|
+
**Campaign angles:**
|
|
267
|
+
- "Your pipeline isn't dead. It's just quiet. Here's how to wake it up."
|
|
268
|
+
- "The follow-up sequence that converts stalled prospects without being pushy"
|
|
269
|
+
- "What to say when a prospect goes silent (and why most people say the wrong thing)"
|
|
270
|
+
- "There is more revenue in your existing list than in any new lead you'll generate this month."
|
|
271
|
+
|
|
272
|
+
**Emotional arc:** Stalled → Re-engaged → Moving
|
|
273
|
+
**Voice:** Direct, urgent-but-not-pushy, revenue-literate
|
|
274
|
+
**Language patterns:**
|
|
275
|
+
- "stalled pipeline", "move deals forward", "already in your list"
|
|
276
|
+
- "the money is in the follow-up", "pipeline health", "re-engage without burning bridges"
|
|
277
|
+
- "one email away from a yes", "revenue attribution"
|
|
278
|
+
|
|
279
|
+
---
|
|
280
|
+
|
|
281
|
+
## STEP 5 — COPYWRITING SYSTEM
|
|
282
|
+
|
|
283
|
+
### The 4-block email body framework
|
|
284
|
+
|
|
285
|
+
Every email body is built from these modular blocks. Select 2–4 per email. Mix and match — but follow the arc.
|
|
286
|
+
|
|
287
|
+
**Block 1 — PROBLEM/AGITATE**
|
|
288
|
+
Open with the tension. Name the pain or problem specifically. Make the reader feel it without dwelling too long.
|
|
289
|
+
- Module: `templates/email-modules/body/problem-agitate.md`
|
|
290
|
+
- Length: 2–4 sentences
|
|
291
|
+
- Rule: Specific always beats generic. "You're losing $3K/month in follow-up drop-off" beats "follow-up is hard."
|
|
292
|
+
|
|
293
|
+
**Block 2 — VALUE/REVEAL**
|
|
294
|
+
Introduce the idea, insight, or mechanism that resolves the tension. This is the "so here's the thing" moment.
|
|
295
|
+
- Module: `templates/email-modules/body/value-reveal.md`
|
|
296
|
+
- Length: 3–5 sentences
|
|
297
|
+
- Rule: One idea per block. Don't stack reveals.
|
|
298
|
+
|
|
299
|
+
**Block 3 — STORY/BRIDGE**
|
|
300
|
+
Bridge between the idea and the reader's reality. Use a client story, a scenario, or a "here's what this looks like in practice" example.
|
|
301
|
+
- Module: `templates/email-modules/body/story-bridge.md`
|
|
302
|
+
- Length: 3–6 sentences
|
|
303
|
+
- Rule: Approved proof points only. Never fabricate.
|
|
304
|
+
|
|
305
|
+
**Block 4 — EDUCATION**
|
|
306
|
+
Add depth, a framework, or a "here's how this works" explanation. Used in Education & Strategy pillar campaigns and longer nurture sequences.
|
|
307
|
+
- Module: `templates/email-modules/body/education-block.md`
|
|
308
|
+
- Length: 4–8 sentences or a short numbered list
|
|
309
|
+
- Rule: Teach one thing completely. Don't overview multiple topics.
|
|
310
|
+
|
|
311
|
+
---
|
|
312
|
+
|
|
313
|
+
### Subject line system
|
|
314
|
+
|
|
315
|
+
Subject lines are not decoration — they are the entire open rate. Every email gets a matrix of 5+ variants.
|
|
316
|
+
|
|
317
|
+
**The 4 subject line types:**
|
|
318
|
+
|
|
319
|
+
| Type | What it does | Use when |
|
|
320
|
+
|---|---|---|
|
|
321
|
+
| Curiosity | Opens a loop the reader must close | Education, nurture, pillar 4 |
|
|
322
|
+
| Social proof | Anchors credibility with a result | Client results, promo |
|
|
323
|
+
| Urgency | Creates a reason to act now | Promotional, pipeline-moving |
|
|
324
|
+
| Personal | Speaks directly to the individual | Cold outbound, re-engagement |
|
|
325
|
+
|
|
326
|
+
Load patterns from `templates/hooks-library/subject-line-patterns.csv`.
|
|
327
|
+
|
|
328
|
+
**3-pass subject line selection:**
|
|
329
|
+
1. Pass 1: Filter by campaign type (nurture / cold / promo / re-engage / follow-up)
|
|
330
|
+
2. Pass 2: Filter by pillar tone (diagnostic / proof-forward / education / urgency)
|
|
331
|
+
3. Pass 3: Select 5+ candidates, write variants using the Structure column as the frame
|
|
332
|
+
|
|
333
|
+
**Preview text rule:** Preview text is always written alongside the subject line. They are a pair, not an afterthought. Preview text should extend or complement the subject line — never repeat it.
|
|
334
|
+
|
|
335
|
+
---
|
|
336
|
+
|
|
337
|
+
### CTA system
|
|
338
|
+
|
|
339
|
+
Every email has one primary CTA. Secondary CTAs (reply, read, soft ask) are optional.
|
|
340
|
+
|
|
341
|
+
**CTA hierarchy:**
|
|
342
|
+
1. Primary CTA — one action, specific, above the fold if possible, and repeated in the PS
|
|
343
|
+
2. Soft CTA — a lower-commitment ask (reply to this, read this, watch this) for cold/nurture emails
|
|
344
|
+
3. Reply CTA — conversational ask ("reply with [X]") for sequences that want engagement signals
|
|
345
|
+
|
|
346
|
+
Load CTA patterns from `templates/email-modules/cta/`.
|
|
347
|
+
|
|
348
|
+
**CTA copy rules:**
|
|
349
|
+
- Verb-first: "Book your call", "Start your trial", "See how it works" — not "Click here" or "Learn more"
|
|
350
|
+
- Specific outcome: "Get your custom growth plan" beats "Book a call"
|
|
351
|
+
- One CTA per email (primary). Do not stack multiple CTAs.
|
|
352
|
+
- PS line always reinforces the primary CTA or adds a secondary angle.
|
|
353
|
+
|
|
354
|
+
---
|
|
355
|
+
|
|
356
|
+
### Voice and tone guardrails
|
|
357
|
+
|
|
358
|
+
These apply across all Growthub campaigns:
|
|
359
|
+
|
|
360
|
+
**Always:**
|
|
361
|
+
- Speak like a knowledgeable operator, not a marketer
|
|
362
|
+
- Use specific outcomes and concrete language
|
|
363
|
+
- Write in second person ("you", "your") not third
|
|
364
|
+
- Keep sentences short and scannable — max 2 lines before a break
|
|
365
|
+
- Use one idea per paragraph
|
|
366
|
+
- Lead with value, not features
|
|
367
|
+
|
|
368
|
+
**Never:**
|
|
369
|
+
- Hype ("revolutionary", "game-changing", "best-in-class")
|
|
370
|
+
- Vague promises ("grow your business", "scale to the moon")
|
|
371
|
+
- Passive voice in CTAs
|
|
372
|
+
- Stacked questions in the opening hook
|
|
373
|
+
- Jargon the ICP doesn't use
|
|
374
|
+
- Any phrase listed in `messaging_guardrails` in the brand kit
|
|
375
|
+
|
|
376
|
+
---
|
|
377
|
+
|
|
378
|
+
## STEP 6 — EMAIL PLATFORM INTEGRATION
|
|
379
|
+
|
|
380
|
+
Email platform handoff uses the adapter pattern defined in `runtime-assumptions.md`.
|
|
381
|
+
|
|
382
|
+
**Two integration modes:**
|
|
383
|
+
|
|
384
|
+
**Mode A — API (preferred for speed)**
|
|
385
|
+
- Platform API key from environment variable
|
|
386
|
+
- Operations: list templates, map copy to template slots, create/update campaign, trigger test send
|
|
387
|
+
- GHL is the reference adapter (see `runtime-assumptions.md → GHL Adapter`)
|
|
388
|
+
- New platforms: add a new adapter section in `runtime-assumptions.md`, no existing files change
|
|
389
|
+
|
|
390
|
+
**Mode B — Browser-assisted**
|
|
391
|
+
- Use Chrome browser tools to navigate platform UI
|
|
392
|
+
- Transfer copy manually into template slots
|
|
393
|
+
- Take screenshot of final email for review log
|
|
394
|
+
- Document workflow in `runtime-assumptions.md → Browser-Assisted Workflows`
|
|
395
|
+
|
|
396
|
+
**Mode C — Export only**
|
|
397
|
+
- Produce `<ClientSlug>_PlatformReady_v1_<YYYYMMDD>.md`
|
|
398
|
+
- Copy organized by template slot: subject, preview, body block 1-N, CTA, PS, footer
|
|
399
|
+
- Human or operator handles the upload
|
|
400
|
+
|
|
401
|
+
---
|
|
402
|
+
|
|
403
|
+
## DESIGN SYSTEM — email copy formatting conventions
|
|
404
|
+
|
|
405
|
+
### Structure inside a draft
|
|
406
|
+
|
|
407
|
+
```markdown
|
|
408
|
+
---
|
|
409
|
+
EMAIL: [N of N]
|
|
410
|
+
THEME: [theme name]
|
|
411
|
+
SEND DAY: [Day X of sequence]
|
|
412
|
+
PILLAR: [pillar name]
|
|
413
|
+
SEGMENT: [segment name]
|
|
414
|
+
---
|
|
415
|
+
|
|
416
|
+
**SUBJECT (primary):** [subject line]
|
|
417
|
+
**PREVIEW:** [preview text]
|
|
418
|
+
|
|
419
|
+
---
|
|
420
|
+
|
|
421
|
+
[Opening hook — 1–2 sentences]
|
|
422
|
+
|
|
423
|
+
[Body block 1]
|
|
424
|
+
|
|
425
|
+
[Body block 2]
|
|
426
|
+
|
|
427
|
+
[Body block 3 — optional]
|
|
428
|
+
|
|
429
|
+
[CTA]
|
|
430
|
+
|
|
431
|
+
---
|
|
432
|
+
|
|
433
|
+
**PS:** [PS line]
|
|
434
|
+
|
|
435
|
+
---
|
|
436
|
+
|
|
437
|
+
**PLAIN-TEXT FALLBACK:**
|
|
438
|
+
Subject: [subject line]
|
|
439
|
+
Preview: [preview text]
|
|
440
|
+
|
|
441
|
+
[full email in plain text, no formatting]
|
|
442
|
+
|
|
443
|
+
CTA: [URL or action, unformatted]
|
|
444
|
+
|
|
445
|
+
---
|
|
446
|
+
|
|
447
|
+
**PLATFORM SLOT MAP** (if platform handoff in scope):
|
|
448
|
+
- subject_line: [value]
|
|
449
|
+
- preview_text: [value]
|
|
450
|
+
- body_html: [block references]
|
|
451
|
+
- cta_text: [value]
|
|
452
|
+
- cta_url: [value]
|
|
453
|
+
- from_name: [value]
|
|
454
|
+
- from_email: [value]
|
|
455
|
+
```
|
|
456
|
+
|
|
457
|
+
---
|
|
458
|
+
|
|
459
|
+
## GUARDRAILS — apply to all campaigns
|
|
460
|
+
|
|
461
|
+
1. **Pillar first.** No campaign is written without a confirmed pillar. Pillar determines angle, tone, language patterns.
|
|
462
|
+
2. **Brand kit is the source of truth.** Voice, phrases, guardrails, CTA language — all from brand kit.
|
|
463
|
+
3. **One campaign type per sequence.** Never mix nurture and promotional logic in the same sequence.
|
|
464
|
+
4. **5+ subject line variants per email.** One subject line is not a matrix.
|
|
465
|
+
5. **Preview text is always paired.** Never deliver a subject line alone.
|
|
466
|
+
6. **Plain-text fallback is required.** Every email draft includes it.
|
|
467
|
+
7. **No fabricated proof.** Only use results and numbers approved in the brand kit.
|
|
468
|
+
8. **No hardcoded credentials.** Platform keys always from env vars.
|
|
469
|
+
9. **Sequence plan before drafts.** The arc must exist before individual emails are written.
|
|
470
|
+
10. **Platform push requires confirmation.** Never create or update a platform campaign without user approval.
|
|
471
|
+
|
|
472
|
+
---
|
|
473
|
+
|
|
474
|
+
## COMMON MISTAKES TABLE
|
|
475
|
+
|
|
476
|
+
| Mistake | Correct approach |
|
|
477
|
+
|---|---|
|
|
478
|
+
| Generic opening hook | Name the specific pain or problem from the pillar — not "Are you struggling with growth?" |
|
|
479
|
+
| Long paragraphs | Max 3 sentences per paragraph, white space is intentional |
|
|
480
|
+
| Feature-first body copy | Lead with what the reader gets/feels, not what the product does |
|
|
481
|
+
| Stacked CTAs | One primary CTA per email — period |
|
|
482
|
+
| "Learn more" as CTA text | Verb-first, outcome-specific: "See how [Brand] does it" |
|
|
483
|
+
| Subject line without preview text | Always write both together |
|
|
484
|
+
| Missing PS line | PS lines get high readership — always include one, reinforce the CTA or add a secondary angle |
|
|
485
|
+
| Not checking the subject line pattern library | Always run the 3-pass selection before writing new subject lines |
|
|
486
|
+
| Skipping the sequence plan | Even for a single email, build the context map first |
|
|
487
|
+
| Overwriting versioned files | Always `v2`, never overwrite |
|
|
488
|
+
| Not logging the deliverable | Append to brand kit after every completed output |
|
|
489
|
+
| "Guaranteed" without qualifier | Check compliance_notes first |
|
|
490
|
+
| Writing for opens, not pipeline movement | Every CTA should move the reader one stage closer to the goal |
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
# Broadcast Format Library — INDEX
|
|
2
|
+
|
|
3
|
+
> Broadcast formats are single-send email containers.
|
|
4
|
+
> They pair with vault assets from `broadcasts/<client>/broadcast-vault.md`.
|
|
5
|
+
> Check this index FIRST — match campaign goal to format, then load the format file.
|
|
6
|
+
>
|
|
7
|
+
> Broadcast formats ≠ sequence formats. Broadcasts are one-and-done sends to a list segment.
|
|
8
|
+
> For multi-email sequences, use `templates/email-formats/INDEX.md`.
|
|
9
|
+
|
|
10
|
+
---
|
|
11
|
+
|
|
12
|
+
## FORMAT LOOKUP TABLE
|
|
13
|
+
|
|
14
|
+
| # | Format ID | Campaign Goal | Vault Asset Types | File |
|
|
15
|
+
|---|---|---|---|---|
|
|
16
|
+
| 1 | `value-delivery` | Deliver a free resource directly — build goodwill | Lead magnets (lm-*) | `value-delivery.md` |
|
|
17
|
+
| 2 | `lead-magnet-traffic` | Drive traffic to a lead magnet landing page | Lead magnets with URLs | `lead-magnet-traffic.md` |
|
|
18
|
+
| 3 | `showcase-proof` | Share a case study, gallery, or proof asset — build credibility | Case studies, showcases | `showcase-proof.md` |
|
|
19
|
+
| 4 | `engagement-nudge` | Warm up cold/cool leads — nudge toward content consumption | YouTube, community, educational LMs | `engagement-nudge.md` |
|
|
20
|
+
| 5 | `activation-booking` | Move warm/nurtured leads toward booking a call | Testimonials, case studies + CTA | `activation-booking.md` |
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## FORMAT SELECTION GUIDE
|
|
25
|
+
|
|
26
|
+
**"I want to give subscribers something valuable with no ask"**
|
|
27
|
+
→ Use `value-delivery` — lead magnet straight to inbox, CTA to access
|
|
28
|
+
|
|
29
|
+
**"I have a resource with a landing page and want to drive traffic"**
|
|
30
|
+
→ Use `lead-magnet-traffic` — teaser copy + CTA to landing page
|
|
31
|
+
|
|
32
|
+
**"I want to show what we've done for clients and build credibility"**
|
|
33
|
+
→ Use `showcase-proof` — case study or gallery highlight, soft CTA
|
|
34
|
+
|
|
35
|
+
**"My list has gone quiet or needs warming — I want to re-engage with value"**
|
|
36
|
+
→ Use `engagement-nudge` — low-friction value: YouTube, community, educational content
|
|
37
|
+
|
|
38
|
+
**"I have warm leads who have gotten value but haven't booked yet"**
|
|
39
|
+
→ Use `activation-booking` — proof + urgency + direct booking CTA
|
|
40
|
+
|
|
41
|
+
---
|
|
42
|
+
|
|
43
|
+
## BROADCAST FORMAT RULES
|
|
44
|
+
|
|
45
|
+
- **One vault asset per broadcast.** Feature one thing clearly — not a roundup of 5 items.
|
|
46
|
+
- **Segment before sending.** Each format has a recommended segment. Don't send activation emails to cold leads.
|
|
47
|
+
- **Follow cadence rules.** Check `broadcasts/<client>/broadcast-vault.md` for cadence_rules before scheduling.
|
|
48
|
+
- **Match CTA to format intent.** Value-delivery CTAs = access. Traffic CTAs = click to page. Activation CTAs = book/apply.
|
|
49
|
+
- **No pitch in value-delivery sends.** If the email is delivering free value, the CTA should be to access the resource — not to buy anything.
|
|
50
|
+
- **Format arc is fixed.** Subject → hook → context → value bridge → CTA → PS. Don't reorder.
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
## HOW BROADCASTS CONNECT TO THE VAULT
|
|
55
|
+
|
|
56
|
+
```
|
|
57
|
+
broadcast-vault.md broadcast format file
|
|
58
|
+
────────────────── ────────────────────
|
|
59
|
+
vault asset (lm-01) → value-delivery.md
|
|
60
|
+
title [ASSET_TITLE]
|
|
61
|
+
description [ASSET_DESCRIPTION]
|
|
62
|
+
url [ASSET_URL]
|
|
63
|
+
cta_text [PRIMARY_CTA_TEXT]
|
|
64
|
+
audience → informs subject line angle
|
|
65
|
+
pillar → informs tone and language patterns
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
Agent workflow per broadcast:
|
|
69
|
+
1. Load `broadcast-vault.md` — read full vault into context
|
|
70
|
+
2. Identify campaign goal → look up format in this INDEX
|
|
71
|
+
3. Select vault asset(s) that match the goal
|
|
72
|
+
4. Load the format file
|
|
73
|
+
5. Fill all `[PLACEHOLDER]` slots from vault + brand kit
|
|
74
|
+
6. Generate subject line matrix (3–5 options)
|
|
75
|
+
7. Platform handoff per `runtime-assumptions.md`
|