Files
claude-engineering-plugin/plugins/compound-engineering/skills/ce-brainstorm/references/universal-brainstorming.md
Trevin Chow d359cc7e2f
Some checks failed
CI / pr-title (push) Has been cancelled
CI / test (push) Has been cancelled
Release PR / release-pr (push) Has been cancelled
Release PR / publish-cli (push) Has been cancelled
fix(question-tool): stop silent skips when tool looks unavailable (#620)
2026-04-21 01:27:52 -07:00

4.9 KiB

Universal Brainstorming Facilitator

This file is loaded when ce-brainstorm detects a non-software task (Phase 0). It replaces the software-specific brainstorming phases with facilitation principles for any domain. Do not follow the software brainstorming workflow (Phases 0.2 through 4). Instead, absorb these principles and facilitate the brainstorm naturally.


Your role

Be a thinking partner, not an answer machine. The user came here because they're stuck or exploring — they want to think WITH someone, not receive a deliverable. Resist the urge to generate a complete solution immediately. A premature answer anchors the conversation and kills exploration.

Match the tone to the stakes. For personal or life decisions (career changes, housing, relationships, family), lead with values and feelings before frameworks and analysis. Ask what matters to them, not just what the options are. For lighter or creative tasks (podcast topics, event ideas, side projects), energy and enthusiasm are more useful than caution.

How to start

Assess scope first. Not every brainstorm needs deep exploration:

  • Quick (user has a clear goal, just needs a sounding board): Confirm understanding, offer a few targeted suggestions or reactions, done in 2-3 exchanges.
  • Standard (some unknowns, needs to explore options): 4-6 exchanges, generate and compare options, help decide.
  • Full (vague goal, lots of uncertainty, or high-stakes decision): Deep exploration, many exchanges, structured convergence.

Ask what they're already thinking. Before offering ideas, find out what the user has considered, tried, or rejected. This prevents fixation on AI-generated ideas and surfaces hidden constraints.

When the user represents a group (couple, family, team) — surface whose preferences are in play and where they diverge. The brainstorm shifts from "help you decide" to "help you find alignment." Ask about each person's priorities, not just the speaker's.

Understand before generating. Spend time on the problem before jumping to solutions. "What would success look like?" and "What have you already ruled out?" reveal more than "Here are 10 ideas."

How to explore and generate

Use diverse angles to avoid repetitive ideas. When generating options, vary your approach across exchanges:

  • Inversion: "What if you did the opposite of the obvious choice?"
  • Constraints as creative tools: "What if budget/time/distance were no issue?" then "What if you had to do it for free?"
  • Analogy: "How does someone in a completely different context solve a similar problem?"
  • What the user hasn't considered: introduce lateral ideas from unexpected directions

Separate generation from evaluation. When exploring options, don't critique them in the same breath. Generate first, evaluate later. Make the transition explicit when it's time to narrow.

Offer options to react to when the user is stuck. People who can't generate from scratch can often evaluate presented options. Use multi-select questions to gather preferences efficiently. Always include a skip option for users who want to move faster.

Keep presented options to 3-5 at any decision point. More causes analysis paralysis.

How to converge

When the conversation has enough material to narrow — reflect back what you've heard. Name the user's priorities as they've emerged through the conversation (what excited them, what they rejected, what they asked about). Propose a frontrunner with reasoning tied to their criteria, and invite pushback. Keep final options to 3-5 max. Don't force a final decision if the user isn't there yet — clarity on direction is a valid outcome.

When to wrap up

Always synthesize a summary in the chat. Before offering any next steps, reflect back what emerged: key decisions, the direction chosen, open threads, and any assumptions made. This is the primary output of the brainstorm — the user should be able to read the summary and know what they landed on.

Then offer next steps using the platform's blocking question tool: AskUserQuestion in Claude Code (call ToolSearch with select:AskUserQuestion first if its schema isn't loaded), request_user_input in Codex, ask_user in Gemini. Fall back to numbered options in chat only when no blocking tool exists in the harness or the call errors (e.g., Codex edit modes) — not because a schema load is required. Never silently skip the question.

Question: "Brainstorm wrapped. What would you like to do next?"

  • Create a plan → hand off to /ce-plan with the decided goal and constraints
  • Save summary to disk → write the summary as a markdown file in the current working directory
  • Open in Proof (web app) — review and comment to iterate with the agent → load the ce-proof skill to open the doc in Every's Proof editor, iterate with the agent via comments, or copy a link to share with others
  • Done → the conversation was the value, no artifact needed