skills/spec-brainstorm/SKILL.md
Conversational design workshop for new features. Interviews the human one question at a time, explores 2-3 approaches with trade-offs, then produces a focused spec. Combines requirements discovery with codebase research and architecture design. Use when the user says "create a spec", "design this feature", "let's brainstorm", "what should we build", or at the start of any feature/refactor/complex-bug workflow.
npx skillsauth add martinffx/claude-code-atelier spec-brainstormInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Conversational design workshop that produces a focused, reviewed spec.
One question at a time. Multiple approaches explored. Ruthless scope control. No implementation until design is approved.
docs/specs/YYYY-MM-DD-<topic>-design.md ← This skill's output
Requirements are inline — no separate requirements.json needed.
These principles apply to every spec, every time.
Every project goes through this process. No exceptions. The five-minute conversation often reveals assumptions that would cost hours in implementation. If it's truly trivial, the spec will be short — but it still gets written.
Break the system into units with one clear purpose each. Well-defined interfaces between them. Each unit independently understandable and independently testable. If you can't explain a unit's job in one sentence, it's doing too much.
Explore the current structure first. Follow existing patterns. Targeted improvements only. No unrelated refactoring. Understand why things are the way they are before proposing changes.
If the request describes multiple independent subsystems, flag it immediately. Decompose into sub-projects before diving into details. Each sub-project gets its own spec and its own plan. A spec that tries to cover three subsystems helps no one.
Remove unnecessary features from all designs. If a capability isn't needed for the first user story, it doesn't go in the spec. Every feature is a cost — to build, to test, to maintain, to understand later. Push back on scope creep during discovery.
Before diving in, understand where you are.
docs/specs/ for previous work. What domain model
exists? What patterns are established? What has been built before?This is silent — don't narrate it. Let the context inform where you focus.
Ask questions to understand what to build. Skip this step if requirements are already clear from context (existing specs, human provided details, etc.).
Ask one question at a time. Multiple choice preferred when possible — give 2-4 concrete options rather than open-ended prompts. Keep the conversation moving.
Good: "Should this be real-time or batch-processed? (a) Real-time via WebSocket, (b) Periodic polling every 30s, (c) On-demand when user requests it."
Bad: "How should the data synchronization work?"
Before asking any detail questions, assess scope. If the request describes multiple independent subsystems (e.g., "build a notification system with email, SMS, push, and an admin dashboard"):
Do not try to spec everything in one document.
During discovery, push back on scope:
If the human insists, include it — but flag the trade-off in the spec.
Adapt these to context. Not all are needed every time.
If you already know answers from orientation, confirm rather than ask.
Tell the human: "Based on my research, here's my understanding of what we're building. Does this look right?"
STOP. Wait for human confirmation.
Read the relevant codebase deeply. Not signatures — implementations, edge cases, error handling, data flows. Trace callers and callees. Read tests to understand expected behaviour.
Write findings directly into the spec as the foundation.
Tell the human: "I've written the research section of the spec. Ready for you to review before I continue with the design."
STOP. Wait for human review.
Before settling on a design, present 2-3 approaches with trade-offs.
For each approach, address:
Then make a recommendation and explain why.
Example:
Approach A: Single table with JSON columns
- Simple schema, fast to implement
- Querying inside JSON is limited, migration pain later
- Complexity: Low
Approach B: Normalized relational tables
- Clean queries, easy to evolve schema
- More joins, more migration files, more code
- Complexity: Medium
Recommendation: Approach B — the query flexibility matters more here than implementation speed.
Get explicit approval on the chosen approach before writing the full spec.
Tell the human: "Which approach should we go with? Or should I explore a different direction?"
STOP. Wait for human to choose an approach.
Once an approach is chosen, write the full spec document.
Use the Skill tool to invoke oracle-architect for component design, domain modeling, and layer boundaries.
# Feature Name
## Problem
- What problem are we solving
- Who has this problem
- How they solve it today
## Scope
- **In scope:** [specific capabilities]
- **Out of scope:** [explicitly deferred]
## User Stories
- US-1: As a [role], I want [action], so that [benefit]
- Given X, when Y, then Z
- Priority: must/should/could
## Constraints
- [Technical or business constraints]
## Context
- What exists today, how it works end-to-end
- Existing patterns and conventions
- Dependencies and integration points
- Gotchas, assumptions, technical debt
## Architecture
- Component structure (functional core / effectful edge)
- Domain model: entities, value objects, aggregates
- Where business logic lives, where IO lives
## API Design
- Endpoints, request/response contracts
- Error handling approach
- Event contracts (published/consumed)
## Data Model
- Schema design, access patterns
- Migrations needed
## Trade-offs
- Alternatives considered
- Why this approach wins
- Known limitations
## Open Questions
- Anything unresolved needing human input
Scale each section to complexity — a few sentences if straightforward, detailed if nuanced.
If human provides reference code — from open source, from elsewhere in codebase — use it as a concrete guide. Working from a reference produces dramatically better designs.
Before presenting the spec to the human, run this checklist silently:
Are there any TBD, TODO, FIXME, or incomplete sections? Every section should have real content or be removed.
Do sections contradict each other? If the Architecture section says "stateless" but the Data Model includes session state, resolve the conflict before presenting.
Is this focused enough for a single implementation plan? If the spec covers more than one independent subsystem, it should have been decomposed in Step 2. If it's still too broad, flag it now.
Could any requirement be interpreted two ways? If so, pick one interpretation, state it explicitly, and let the human correct you.
Fix any issues found. Then present.
Tell the human: "The spec is complete. Ready for your review."
STOP. Wait for human review.
Human may annotate the spec directly — adding corrections, rejections, domain knowledge, or "remove this section entirely."
When they say "I added notes":
This may repeat 1-6 times. Spec is not approved until human explicitly says so.
When the spec is approved, the next step is spec-plan.
"Spec is approved. Ready to write the implementation plan?"
If planning reveals design flaws, loop back to research. See spec-orchestrator for iteration patterns.
Do not start planning without explicit approval. Do not write code.
development
Security architecture and threat modeling knowledge. Auto-invokes when designing features that handle untrusted data, authentication, authorization, external integrations, file uploads, or sensitive data. Provides risk assessment frameworks, trust boundary analysis, and security design principles — not implementation code.
testing
Adversarial review of non-trivial decisions using fresh-context scrutiny. Use when correctness matters more than speed, when stakes are high (production, security-sensitive logic, irreversible operations), or before committing significant architectural or implementation choices.
development
Compact the current conversation into a handoff document for another agent to pick up.
testing
Socratic interrogation of plans against the project's domain model and documented decisions. Use when the user wants to stress-test a plan, clarify terminology, or validate assumptions against existing domain language. Updates CONTEXT.md and ADRs inline as decisions crystallise.