End-to-end cold email outreach orchestration. Handles goal alignment, lead ingestion from any source (CSV, paste, CRM export, database), sequence design, email generation, campaign setup in the user's chosen outreach tool, and launch. Tool-agnostic — supports Smartlead (full MCP automation), Instantly, Lemlist, Apollo, or manual CSV export.
npx gooseworks install --claude # Then in your agent: /gooseworks <prompt> --skill cold-email-outreach
The final mile of the outbound pipeline. Takes leads from wherever the user has them, builds email sequences, loads campaigns into the user's chosen outreach tool, and launches.
Tool-agnostic: Asks the user which outreach platform they use. Defaults to Smartlead if they have MCP tools configured. Falls back to CSV export for any other tool or manual workflow.
Use this skill when:
This skill does NOT assume a specific tool. It asks first, then adapts.
| Tool | Integration | How It Works |
|---|---|---|
| Smartlead (default) | MCP tools (mcp__smartlead__*) | Full automation: create campaign, add sequences, import leads, allocate mailboxes, configure schedule, launch |
| Instantly | CSV import | Generate CSV matching Instantly's import format, user uploads manually |
| Lemlist | CSV import | Generate CSV with Lemlist-compatible columns |
| Apollo | CSV import | Generate CSV matching Apollo sequence import format |
| Manual / Other | CSV + instructions | Export leads + emails as generic CSV, provide setup instructions |
Tool selection logic:
email, first_name, last_name, company, title, subject, body per touch) and ask user for their tool's import requirementsFor Smartlead (full automation):
SMARTLEAD_API_KEY=your_api_key_hereAll Smartlead API calls go to https://server.smartlead.ai/api/v1 with ?api_key=$SMARTLEAD_API_KEY appended. Rate limit: 10 requests per 2 seconds.
For CSV-based tools: No env vars needed.
Ask all questions at once. Organize by category. Skip any already answered.
Minimum required per lead: email address. Nice to have: first_name, last_name, company, title.
Accept leads from whatever source the user provides:
email (required) — also matches Email, email_addressfirst_name — also matches firstname, first, First Namelast_name — also matches lastname, last, Last Namecompany_name — also matches company, organization, CompanyShow a sample table (10-15 leads) with:
Tell user: total eligible leads, how many were invalid/removed.
Ask user to confirm or adjust before proceeding.
Present the sequence plan as a table before writing any copy:
| Touch | Day | Email Type | Framework | CTA |
|---|---|---|---|---|
| 1 | 1 | Cold intro | Signal-Proof-Ask | 15-min call |
| 2 | 5 | New angle / asset | PAS | Resource offer |
| 3 | 12 | Social proof | BAB | Open to chat? |
Get user approval on the structure before generating copy in Phase 3.
Write the email copy directly using these guidelines.
Every cold email follows this skeleton:
Hook (1 sentence) → Evidence (1-2 sentences) → Offer (1 sentence)Word count targets:
Tier 1 (Generic): Generate one template per touch with merge fields ({first_name}, {company}, {title}). Same template for all leads.
Tier 2 (Segment): Generate one template per segment per touch. Segments are defined by role, industry, or signal type. Swap pain points and proof points between segments.
Tier 3 (Deep): Generate unique email per lead per touch. Cap at 50 leads — recommend Tier 2 above that volume.
Full automation via MCP tools. Execute in this order:
Step 1: Find and allocate mailboxes
mcp__smartlead__get_email_accountsReturns all email accounts with id, from_email, from_name, daily_sent_count, is_smtp_success, is_imap_success.
To find free mailboxes (not already assigned to active campaigns):
mcp__smartlead__get_campaignsACTIVE or STARTED, fetch its email accounts: mcp__smartlead__get_campaign_email_accountsemail_account_id values currently assigned to active campaignsid is NOT in the active set AND is_smtp_success = true AND is_imap_success = truedaily_sent_count ascending (prefer least-used)If fewer free mailboxes than requested, tell the user and ask how to proceed.
Present available/selected accounts to user for confirmation.
Step 2: Create campaign
mcp__smartlead__create_campaign
name: {campaign_name}Save the returned campaign_id.
Step 3: Add sequence steps
mcp__smartlead__save_campaign_sequences
campaign_id: {campaign_id}
sequences: [
{ seq_number: 1, subject: "...", email_body: "...", seq_delay_details: { delay_in_days: 0 } },
{ seq_number: 2, subject: "...", email_body: "...", seq_delay_details: { delay_in_days: 4 } },
{ seq_number: 3, subject: "...", email_body: "...", seq_delay_details: { delay_in_days: 7 } }
]Merge variable mapping: Convert {first_name} → {{first_name}}, {company} → {{company}} (Smartlead uses double-brace syntax).
Note: Blank subject on emails 2+ makes them send as replies in the same thread.
Step 4: Import leads (batch 100)
mcp__smartlead__add_leads_to_campaign
campaign_id: {campaign_id}
lead_list: [{ email: "...", first_name: "...", last_name: "...", company_name: "...", ... }]Smartlead accepts max 100 leads per call. Chunk the list and call for each batch. Extra columns become custom_fields.
Step 5: Assign sending accounts
mcp__smartlead__add_email_accounts_to_campaign
campaign_id: {campaign_id}
email_account_ids: [...]Step 6: Set schedule
mcp__smartlead__update_campaign_schedule
campaign_id: {campaign_id}
schedule: {
timezone: "America/New_York",
days_of_the_week: [1, 2, 3, 4, 5],
start_hour: "08:00",
end_hour: "18:00",
min_time_btw_emails: 10,
max_new_leads_per_day: 20
}days_of_the_week: 0=Sunday, 1=Monday, ..., 6=Saturday.
Step 7: Configure settings
mcp__smartlead__update_campaign_settings
campaign_id: {campaign_id}
settings: {
track_settings: [],
stop_lead_settings: "REPLY_TO_AN_EMAIL",
send_as_plain_text: false,
follow_up_percentage: 100
}Allowed track_settings: DONT_TRACK_EMAIL_OPEN, DONT_TRACK_LINK_CLICK, DONT_TRACK_REPLY_TO_AN_EMAIL
Allowed stop_lead_settings: REPLY_TO_AN_EMAIL, CLICK_ON_A_LINK, OPEN_AN_EMAIL
Step 1: Generate CSV
Columns depend on personalization tier:
Tier 1 (same template for all):
email, first_name, last_name, company, title, custom_field_1 (signal/hook)Tier 2/3 (per-segment or per-lead emails):
email, first_name, last_name, company, title, touch_1_subject, touch_1_body, touch_2_subject, touch_2_body, touch_3_subject, touch_3_bodyStep 2: Save file
Save to the current working directory:
{campaign-name}-{YYYY-MM-DD}.csvStep 3: Provide tool-specific import instructions
Instantly:
Lemlist:
Apollo:
Other / Manual:
Present campaign summary:
Campaign: {name}
Leads: {count}
Sequence: {touches} touches over {days} days
Sending: {accounts} accounts × {daily_limit}/day = {daily_volume} emails/day
Estimated completion: {date}
Tool: {smartlead/instantly/etc.}Do NOT activate the campaign without explicit user confirmation. Present the summary, then ask: "Ready to launch? Type 'yes' to activate."
mcp__smartlead__update_campaign_status → set status to STARTAll endpoints use base URL https://server.smartlead.ai/api/v1 with ?api_key= query param.
| Endpoint | Method | Purpose |
|---|---|---|
/campaigns/create | POST | Create a new campaign |
/campaigns | GET | List all campaigns |
/campaigns/{id} | GET | Get campaign by ID |
/campaigns/{id}/schedule | POST | Set campaign schedule |
/campaigns/{id}/settings | POST | Update tracking/stop settings |
/campaigns/{id}/sequences | POST | Save email sequences |
/campaigns/{id}/leads | POST | Add leads (max 100 per call) |
/campaigns/{id}/email-accounts | GET | List mailboxes on a campaign |
/campaigns/{id}/email-accounts | POST | Assign mailboxes to campaign |
/campaigns/{id}/status | POST | Change campaign status (START/PAUSED/STOPPED) |
/campaigns/{id}/analytics | GET | Top-level campaign analytics |
/email-accounts/ | GET | List all email accounts (offset/limit) |
| Component | Cost |
|---|---|
| Smartlead campaign setup | Free (API included with Smartlead plan) |
| CSV export | Free |
| Email copy generation | Free (LLM reasoning) |
| Error | Fix |
|---|---|
SMARTLEAD_API_KEY not set | Ask user to add it to .env or export it |
| Smartlead rate limit (429) | Wait 2 seconds and retry |
| Lead upload fails | Check email format, retry batch |
| No free mailboxes | Show all accounts, ask user which to use |
| Campaign creation fails | Check API key validity |
Diagnose Meta Ads campaign performance using Meta's actual system mechanics — Breakdown Effect, Learning Phase, Auction Overlap, Pacing, and Creative Fatigue — and produce structured, testable recommendations that avoid judging segments by average CPA instead of marginal efficiency.
Pre-flight policy check for Meta ads. Takes ad copy plus advertiser context, resolves and fetches the relevant Meta transparency-center policy pages at runtime, and returns a Pass / Fix Required / Block verdict with cited findings and rewrites.
For paid lead-gen and participant-recruitment ads, replaces vanity CPA with true CAC per qualified lead by joining ad-platform data with downstream funnel events, surfaces tracking gaps, and classifies every creative into Scale / Keep / Investigate / Cut.