Claude-code-marketing-skills google-ads-audit
Deep Google Ads account audit — keywords, quality scores, budget pacing, search terms
install
source · Clone the upstream repo
git clone https://github.com/cognyai/claude-code-marketing-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/cognyai/claude-code-marketing-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skill-pipeline/google-ads-audit" ~/.claude/skills/cognyai-claude-code-marketing-skills-google-ads-audit && rm -rf "$T"
manifest:
skill-pipeline/google-ads-audit/SKILL.mdsource content
Google Ads Audit
Comprehensive Google Ads account audit using live data via Cogny's MCP server.
Requires: Cogny Agent subscription ($9/mo) — Sign up
Prerequisites Check
Before starting, verify you have Google Ads MCP tools available. If
mcp__cogny__google_ads__tool_execute_gaql is not available:
This skill requires Cogny's Google Ads MCP server. 1. Sign up at https://cogny.com/agent 2. Connect your Google Ads account 3. Add your API key to .mcp.json 4. Restart Claude Code See the README for setup instructions.
Usage
/google-ads-audit — full account audit
/google-ads-audit keywords — keyword performance only
/google-ads-audit budget — budget pacing only
/google-ads-audit quality — quality scores only
/google-ads-audit search-terms — search term analysis only
Full Audit Steps
1. Account Discovery
google_ads__tool_list_accessible_accounts
Identify the account and confirm access.
2. Campaign Overview (last 30 days)
SELECT campaign.name, campaign.status, campaign.bidding_strategy_type, campaign_budget.amount_micros, metrics.cost_micros, metrics.conversions, metrics.clicks, metrics.impressions, metrics.conversions_value FROM campaign WHERE segments.date DURING LAST_30_DAYS ORDER BY metrics.cost_micros DESC
3. Keyword Performance
SELECT ad_group_criterion.keyword.text, ad_group_criterion.keyword.match_type, ad_group_criterion.quality_info.quality_score, campaign.name, metrics.cost_micros, metrics.conversions, metrics.clicks, metrics.impressions FROM keyword_view WHERE segments.date DURING LAST_30_DAYS AND metrics.cost_micros > 0 ORDER BY metrics.cost_micros DESC LIMIT 50
Flag: QS < 4, zero conversions with high spend, broad match bleeding
4. Search Term Analysis
SELECT search_term_view.search_term, search_term_view.status, campaign.name, metrics.cost_micros, metrics.conversions, metrics.clicks FROM search_term_view WHERE segments.date DURING LAST_30_DAYS AND metrics.cost_micros > 0 ORDER BY metrics.cost_micros DESC LIMIT 30
Flag: irrelevant terms, high-spend zero-conversion terms, missing negatives
5. Budget Pacing
SELECT campaign.name, campaign_budget.amount_micros, metrics.cost_micros, metrics.impressions FROM campaign WHERE segments.date DURING LAST_7_DAYS AND campaign.status = 'ENABLED'
Calculate: daily budget vs daily spend ratio per campaign
6. Quality Score Distribution
SELECT ad_group_criterion.quality_info.quality_score, ad_group_criterion.quality_info.creative_quality_score, ad_group_criterion.quality_info.search_predicted_ctr, ad_group_criterion.quality_info.post_click_quality_score, ad_group_criterion.keyword.text, campaign.name FROM keyword_view WHERE ad_group_criterion.quality_info.quality_score IS NOT NULL ORDER BY ad_group_criterion.quality_info.quality_score ASC
7. Report findings
Use
create_finding for each actionable issue found. Include specific data, estimated impact, and recommended action.
Present a summary table:
Google Ads Audit: [Account Name] Health Score: X/100 Campaign Performance (30d): Total Spend: [X] | Conversions: [X] | Avg CPA: [X] Issues Found: [N] - [Critical] ... - [High] ... - [Medium] ... Top 3 Actions: 1. [Highest impact with estimated savings] 2. ... 3. ...