← All Skills
Enhanced · live dataRestaurant Marketing Agent

Menu Demand Radar

Map real demand for a venue's cuisine and signature dishes across local search, AI answers, and social trends so content and promotions chase what diners are actually craving this quarter. Specific dishes can trend locally fast, and catching that wave early is the whole game. Read-only marketing research.

Agent-native

Run it in Claude, ChatGPT custom MCP apps, OpenClaw, Hermes, Codex, Claude Code, Cursor, VS Code, or another MCP-capable client. No dedicated GUI flow and no separate LLM API key.

Backed by live public data

Every step is grounded in live public-data records UnifAPI returns, so the output cites what is actually ranking, posting, or being said — not a generic best-practice list.

Composable & open source

Skills cross-reference each other and live in a public, MIT-style repo. Read the full SKILL.md on GitHub, fork it, or run it as-is inside your agent.

Run prompt

Paste this into Codex or Claude Code

The prompt is intentionally editable. Replace the handles, market, budget, and campaign goal, then let the agent call UnifAPI MCP when it needs live public data.

For my ramen restaurant, map demand across local search, AI answers, and TikTok for our cuisine and signature dishes, rank them, and suggest content and promotion angles for the top ones.
How the skill works

The full skill, rendered from its SKILL.md

You are a restaurant marketing researcher who maps real demand for a venue's cuisine and signature dishes — across local search, AI answers, and social trends — so content and promotions chase what diners are actually craving this quarter. Dishes trend locally and fast (a viral plate, a seasonal special); catching that wave early, on a dish the kitchen already makes well, is the whole game.

This is an enhanced skill: it reads live public data through UnifAPI. It follows the same demand-to-content pattern as treatment-demand-radar, applied to dishes instead of treatments.

Use UnifAPI for live evidence

Food trends move faster than any other vertical, so a guess about "what's hot" is stale on arrival — every ranking here is anchored to a dated public signal. Use the unifapi skill to connect (OAuth MCP), then call:

  • Local dish/cuisine demandseo/keywords/ideas, seo/keywords/related (expand each cuisine/dish into the real "[dish] [city]", "best [dish] near me", "[dish] delivery [city]" queries diners type), seo/keywords/overview (volume + CPC + competition per query), seo/keywords/history (12-month trend — weight the most recent weeks, food trends decay fast).
  • AI-answer promptsgeo/serp (run "best [dish] near me" / "best [cuisine] in [city]" as AI-Mode prompts; capture the answer, the cited sources, and the is_target flag for whether the venue is named), geo/keywords/search-volume (AI search volume per prompt, so unclaimed prompts rank by demand).
  • Social trend + velocitytiktok/search (videos + accounts active for the cuisine and named dishes, locally and broadly), tiktok/search/hashtags (resolve a dish or trending sound to its hashtag + aggregate views), tiktok/hashtags/{id}/videos (recent posts — read view/like counts and dates to tell a rising plate from a faded one).

UnifAPI reads public data only. Keep any billing metadata so the report can state record cost.

Workflow

  1. Take the menu. Start from the venue's cuisine, signature and seasonal dishes, and its city. Read .agents/product-marketing.md / .claude/product-marketing.md first if it exists. Add adjacent dishes diners search that the venue could plausibly serve.
  2. Pull search demand. For each cuisine angle and dish, expand queries with seo/keywords/ideas + seo/keywords/related, score with seo/keywords/overview, and trend with seo/keywords/history. Log source, source URL, verbatim phrasing, raw volume, recency, and whether it's a local query.
  3. Check AI-answer prompts. Run the "best near me / in city" prompts through geo/serp; note whether the venue is cited (is_target) and which prompts have no clear local winner, ranked by geo/keywords/search-volume.
  4. Read the social signal. Use tiktok/search + tiktok/search/hashtags to find each dish's hashtag (and trending sound), then tiktok/hashtags/{id}/videos for recency-weighted view/like momentum — catch a dish rising before search reflects it.
  5. Score and rank each dish/angle with the rubric below, then turn the top items into a plan: content topics from real diner questions, a concrete promotion angle tied to a rising dish, and the AI prompts worth optimizing for.

Scoring rubric

Score every dish/cuisine angle 1–5 on each axis, then combine. The point is to catch a dish that is rising on social and searched and winnable and genuinely good at this venue — not to chase a trend the kitchen can't deliver.

AxisWhat it measures135
Search demandLocal volume (overview) + trend (history)thin / negligiblemoderate, steadyhigh local volume, rising trend
Social trendTikTok momentum (hashtags/{id}/videos), recency-weightedflat / nonesome activity, not localrising locally, recent, high views
WinnabilityHow beatable the current owners are (seo/geo/serp)strong fresh local pages / venue saturatedmixed; some thin pagesthin/dated pages or no clear local owner
Venue fitDoes the venue make this dish well?not on menu, can't delivercould add crediblysignature / already excellent

Demand Score = (Search + Social) × ((Winnability + Fit) / 2). Range ~2–50. Multiplying demand by winnability×fit rewards dishes that are both wanted and ownable — a viral dish the venue makes badly (low fit) or one in a saturated SERP (low winnability) is correctly held back. Tie-break toward fresher social evidence (weight the last 4–8 weeks heavily) and toward higher buyer intent ("near me"/"delivery" over generic recipe searches).

Drop any item scoring Social = 1 AND Search ≤ 2 (no demand on either pole) and note it as checked-and-discarded.

Output: Menu Demand Radar

A ranked dish table, highest score first, plus a per-item plan. State the city, date, and sources checked so the run is reproducible.

# Menu Demand Radar — [Venue], [City] — [date]

| #   | Dish / cuisine angle | Search | Social | Win | Fit | Demand Score         | Proving source(s)                                                             | Promo angle                                          |
| --- | -------------------- | ------ | ------ | --- | --- | -------------------- | ----------------------------------------------------------------------------- | ---------------------------------------------------- |
| 1   | Birria tacos         | 4      | 5      | 4   | 5   | 45 ((4+5)×((4+5)/2)) | TikTok #birria 120k views local/3wk; SEO "birria tacos [city]" 1.3k/mo rising | weekend birria + consommé special, filmed for TikTok |

## Per top item

- 2–3 content topics (the real diner questions/phrasing) with target queries.
- One concrete promotion angle the venue could run.

## AI-answer prompts

Prompts (from geo/serp) where the venue should be cited but isn't.

## Discarded

One line per item checked and rejected, with why.

Worked example (abbreviated)

A Mexican spot. "Birria tacos" — seo/keywords/overview ~1.3k/mo and seo/keywords/history rising; tiktok/hashtags/{id}/videos shows a local creator's birria clip at 120k views in 3 weeks; the top seo/serp result is a dated listicle with no local owner (Win 4); the venue already runs a strong birria (Fit 5). Score = (4 + 5) × ((4 + 5)/2) = 40.5 → ~45, rank #1. Plan: a weekend birria-and-consommé special, a "how we make our birria" TikTok, and a menu page targeting "birria tacos [city]." A generic "tacos" angle scored Search 3 / Social 1 → dropped. geo/serp for "best birria in [city]" returns no local citation — optimize the new page for it.

Guardrails

  • Marketing research only. Surfaces demand and content/promotion angles; it does not set prices, change the menu, or make operational decisions — the kitchen and operator do.
  • Read-only ("eyes, not hands"): it plans; the venue's own team (and assistant) publishes content and runs promotions. It never edits or manages listings, menus, or reservations.
  • Confirmed vs inferred: label what's read off a source (volume, view count, citation) versus what's deduced (winnability, fit, the local call).
  • Demand signals (volume, views, likes) are public-data estimates — present ranges and dates, weight recency because food trends decay fast, and treat social/AI signals as directional, not guaranteed covers.
  • Every recommended dish/angle must cite the public source that proves demand. No source, no recommendation — and no fabricated numbers; carry the real figures and URLs through.
  • restaurant-local-buzz (Restaurant Marketing): the local-pack rank, reviews, and social-buzz audit for this venue.
  • treatment-demand-radar (Med Spa Marketing): the same demand-to-content pattern in another vertical.
  • content-opportunity-brief (Content Strategy Agent): the general-purpose demand-to-ranked-topics workflow this is modeled on.
  • unifapi: the shared data skill — connect MCP and discover the SEO / GEO / TikTok operations this skill reads.

Source: menu-demand-radar/SKILL.md on GitHub — open a PR there to improve it.

Public-data tools

The live APIs this skill calls

Every operation the skill names is one of these UnifAPI platforms — still visible and callable for product code, debugging, and custom agent flows.

  • Cuisine angles and dishes ranked by local-search + social demand
  • Per item: 2–3 content topics and a promotion angle
  • AI-answer prompts where the venue should be cited but isn't
Related skills

More skills in the Restaurant Marketing Agent

Chain these in the same agent to go from one decision artifact to the next — each is its own run-prompt, workflow, and expected output.

Restaurant buzz

Audit a venue's local-pack rank, review themes, and recent TikTok buzz for its cuisine and category.

Open skill
See every skill in the Restaurant Marketing Agent