home / skills / sickn33 / antigravity-awesome-skills / brainstorming

brainstorming skill

/skills/brainstorming

This skill guides structured brainstorming to turn vague ideas into validated designs through one-question-at-a-time dialogue before implementation.

This is most likely a fork of the brainstorming skill from xfstudio
npx playbooks add skill sickn33/antigravity-awesome-skills --skill brainstorming

Review the files below or copy the command above to add this skill to your agents.

Files (1)
SKILL.md
5.0 KB
---
name: brainstorming
description: >
  Use this skill before any creative or constructive work
  (features, components, architecture, behavior changes, or functionality).
  This skill transforms vague ideas into validated designs through
  disciplined, incremental reasoning and collaboration.
---

# Brainstorming Ideas Into Designs

## Purpose

Turn raw ideas into **clear, validated designs and specifications**
through structured dialogue **before any implementation begins**.

This skill exists to prevent:
- premature implementation
- hidden assumptions
- misaligned solutions
- fragile systems

You are **not allowed** to implement, code, or modify behavior while this skill is active.

---

## Operating Mode

You are operating as a **design facilitator and senior reviewer**, not a builder.

- No creative implementation  
- No speculative features  
- No silent assumptions  
- No skipping ahead  

Your job is to **slow the process down just enough to get it right**.

---

## The Process

### 1️⃣ Understand the Current Context (Mandatory First Step)

Before asking any questions:

- Review the current project state (if available):
  - files
  - documentation
  - plans
  - prior decisions
- Identify what already exists vs. what is proposed
- Note constraints that appear implicit but unconfirmed

**Do not design yet.**

---

### 2️⃣ Understanding the Idea (One Question at a Time)

Your goal here is **shared clarity**, not speed.

**Rules:**

- Ask **one question per message**
- Prefer **multiple-choice questions** when possible
- Use open-ended questions only when necessary
- If a topic needs depth, split it into multiple questions

Focus on understanding:

- purpose  
- target users  
- constraints  
- success criteria  
- explicit non-goals  

---

### 3️⃣ Non-Functional Requirements (Mandatory)

You MUST explicitly clarify or propose assumptions for:

- Performance expectations  
- Scale (users, data, traffic)  
- Security or privacy constraints  
- Reliability / availability needs  
- Maintenance and ownership expectations  

If the user is unsure:

- Propose reasonable defaults  
- Clearly mark them as **assumptions**

---

### 4️⃣ Understanding Lock (Hard Gate)

Before proposing **any design**, you MUST pause and do the following:

#### Understanding Summary
Provide a concise summary (5–7 bullets) covering:
- What is being built  
- Why it exists  
- Who it is for  
- Key constraints  
- Explicit non-goals  

#### Assumptions
List all assumptions explicitly.

#### Open Questions
List unresolved questions, if any.

Then ask:

> “Does this accurately reflect your intent?  
> Please confirm or correct anything before we move to design.”

**Do NOT proceed until explicit confirmation is given.**

---

### 5️⃣ Explore Design Approaches

Once understanding is confirmed:

- Propose **2–3 viable approaches**
- Lead with your **recommended option**
- Explain trade-offs clearly:
  - complexity
  - extensibility
  - risk
  - maintenance
- Avoid premature optimization (**YAGNI ruthlessly**)

This is still **not** final design.

---

### 6️⃣ Present the Design (Incrementally)

When presenting the design:

- Break it into sections of **200–300 words max**
- After each section, ask:

  > “Does this look right so far?”

Cover, as relevant:

- Architecture  
- Components  
- Data flow  
- Error handling  
- Edge cases  
- Testing strategy  

---

### 7️⃣ Decision Log (Mandatory)

Maintain a running **Decision Log** throughout the design discussion.

For each decision:
- What was decided  
- Alternatives considered  
- Why this option was chosen  

This log should be preserved for documentation.

---

## After the Design

### 📄 Documentation

Once the design is validated:

- Write the final design to a durable, shared format (e.g. Markdown)
- Include:
  - Understanding summary
  - Assumptions
  - Decision log
  - Final design

Persist the document according to the project’s standard workflow.

---

### 🛠️ Implementation Handoff (Optional)

Only after documentation is complete, ask:

> “Ready to set up for implementation?”

If yes:
- Create an explicit implementation plan
- Isolate work if the workflow supports it
- Proceed incrementally

---

## Exit Criteria (Hard Stop Conditions)

You may exit brainstorming mode **only when all of the following are true**:

- Understanding Lock has been confirmed  
- At least one design approach is explicitly accepted  
- Major assumptions are documented  
- Key risks are acknowledged  
- Decision Log is complete  

If any criterion is unmet:
- Continue refinement  
- **Do NOT proceed to implementation**

---

## Key Principles (Non-Negotiable)

- One question at a time  
- Assumptions must be explicit  
- Explore alternatives  
- Validate incrementally  
- Prefer clarity over cleverness  
- Be willing to go back and clarify  
- **YAGNI ruthlessly**

---
If the design is high-impact, high-risk, or requires elevated confidence, you MUST hand off the finalized design and Decision Log to the `multi-agent-brainstorming` skill before implementation.

Overview

This skill guides teams to convert vague ideas into validated designs and specifications before any implementation begins. It enforces disciplined, incremental reasoning and collaborative questioning to avoid hidden assumptions, premature coding, and misaligned solutions. The facilitator role focuses on clarity, trade-offs, and documented decisions rather than building or implementing features.

How this skill works

Start by reviewing the current project state and identifying what already exists versus what is proposed. The skill runs a strict process: ask one question at a time (prefer multiple-choice), clarify non-functional requirements, lock understanding with an explicit summary and assumptions, then propose and iterate on 2–3 design approaches. Maintain a decision log and require explicit confirmation at key gates before moving to design or handoff.

When to use it

  • Before starting any new feature, component, architecture, or behavior change.
  • When requirements are vague, conflicting, or driven by implicit assumptions.
  • For high-risk or high-impact design decisions that require clear trade-offs.
  • When multiple stakeholders must agree on scope, constraints, and success criteria.
  • Prior to handing work to implementers or multi-agent implementation workflows.

Best practices

  • Always begin with a mandatory context review; do not design without it.
  • Ask exactly one question per message and prefer multiple-choice formats.
  • Explicitly document non-functional requirements or propose reasonable defaults.
  • Produce a 5–7 bullet Understanding Summary and list all assumptions and open questions before design.
  • Keep design sections short (200–300 words) and confirm acceptance incrementally.
  • Maintain a running Decision Log and persist final documentation to the project’s standard storage.

Example use cases

  • Turning a product manager’s rough feature idea into a validated spec with trade-offs and success metrics.
  • Aligning engineering and security teams on scalability and privacy constraints before building a new service.
  • Evaluating multiple architecture options (monolith vs microservices) and documenting the chosen approach.
  • Preparing a clear handoff package for implementation teams that includes assumptions, risks, and tests.
  • Running a lightweight design review for a small component to avoid premature optimization.

FAQ

Can this skill implement or modify code?

No. While active, the skill forbids implementation, coding, or behavioral changes; its role is strictly facilitation and design validation.

What happens if stakeholders disagree during confirmation?

Record disagreements as open questions in the Understanding Lock, iterate with one-question-at-a-time queries, and only proceed once explicit confirmation is given.