loading…
Search for a command to run...
loading…
Expose a company's complete design system (colors, typography, logos, components, guidelines, CSS tokens) to AI tools via MCP. Auto-parses CSS / Markdown / PDF
Expose a company's complete design system (colors, typography, logos, components, guidelines, CSS tokens) to AI tools via MCP. Auto-parses CSS / Markdown / PDF / SVG / fonts; supports marketing vs product contexts with shared overrides; ships 12 tools, 16+ resources under brandkit://, and 4 prompts; stdio + SSE + Streamable HTTP transports. Install via NPM: npx -y brandkit-mcp serve.
Give every AI tool access to your company's complete brand atomic system via the Model Context Protocol.
npm version License: MIT Node 20+ TypeScript ejwhite7/brandkit-mcp MCP server
BrandKit MCP v2 is an open-source MCP server that exposes a company's complete brand atomic system -- verbal identity (positioning, audience, messaging, differentiation, concepts, voice) and visual identity (colors, typography, components, tokens, motion, assets) -- to Claude and other AI tools via the Model Context Protocol (MCP). It ships 18 tools and 14 resources. When an LLM helps build a website, app, or marketing asset, it has instant structured access to the exact brand language and visual rules it needs -- including a human-authored taste primer that carries the brand's instincts, not just its specs.
# 1. Install
npm install -g brandkit-mcp
# 2. Scaffold a new brand atomic system from the starter template
brandkit-mcp init
# 3. Edit the scaffolded files with your brand content
# 4. Wire into Claude Desktop (or any MCP-compatible client)
# Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
# {
# "mcpServers": {
# "brandkit": {
# "command": "brandkit-mcp",
# "args": ["serve"]
# }
# }
# }
A brand atomic system lives under a single <brand-root>/ directory (default: ./brand_atomic_system):
<brand-root>/
├── readme.md
├── magic_trick.md # human-authored taste primer
├── brandkit.config.yaml # version: 2
├── human/ # PDFs and human-only material (MCP ignores)
│ └── *.pdf
└── agent/
├── verbal/
│ ├── positioning.md
│ ├── audience.yaml
│ ├── messaging.md
│ ├── differentiation.md
│ ├── concepts.md
│ └── voice.md
└── visual/
├── colors_and_type.css
├── fonts/
├── assets/
├── components/
├── tokens/
├── motion/
│ ├── motion.json
│ └── motion.css
└── artifacts/
├── web/ # override layer
└── product/ # override layer
The human/ directory is intentionally ignored by the MCP server -- put PDFs, print specs, or any other human-only material there. Everything under agent/ is indexed and served.
BrandKit MCP exposes 18 tools to AI assistants:
| Tool | Description |
|---|---|
get_brand_overview |
High-level overview + taste primer |
get_magic_trick |
Verbatim magic_trick.md |
get_positioning |
Positioning document |
get_audience |
Audience YAML, parsed |
get_messaging |
Messaging document |
get_differentiation |
Differentiation document |
get_concepts |
Creative concepts/directions |
get_voice |
Voice document |
get_colors_and_type |
Colors + typography custom properties |
get_assets |
Logos + brand assets |
get_fonts |
Font faces |
get_components |
UI primitives |
get_tokens |
Token specimens |
get_motion |
Motion system (json + css) |
get_css |
colors_and_type.css + motion.css text |
search_brand |
Full-text search |
validate_usage |
Validate brand compliance |
get_context_diff |
Diff base vs web vs product |
Seven creative/verbal tools (get_brand_overview, get_positioning, get_audience, get_messaging, get_differentiation, get_concepts, get_voice) inject a _taste_primer field carrying magic_trick.md verbatim. get_magic_trick returns the primer directly without wrapping.
BrandKit MCP exposes 14 brand:// URIs as MCP resources:
| URI | Description |
|---|---|
brand://overview |
Brand overview |
brand://magic_trick |
Taste primer |
brand://verbal/positioning |
Positioning document |
brand://verbal/audience |
Audience YAML |
brand://verbal/messaging |
Messaging document |
brand://verbal/differentiation |
Differentiation document |
brand://verbal/concepts |
Creative concepts |
brand://verbal/voice |
Voice document |
brand://visual/colors_and_type |
Colors + typography CSS |
brand://visual/assets |
Asset index |
brand://visual/fonts |
Font face index |
brand://visual/components |
Component index |
brand://visual/tokens |
Token specimens |
brand://visual/motion |
Motion system |
The brandkit.config.yaml file at your project root controls BrandKit MCP:
version: 2
brand:
name: Acme Corp
description: Plumbing for builders.
root: ./brand_atomic_system
contexts: [base, web, product]
ignore:
- human/
version: 2 is required. A config file missing this field or declaring version: 1 causes the server to throw BrandkitV1ConfigError at startup.
BrandKit v2 supports three contexts:
| Context | Purpose |
|---|---|
base |
Shared foundation -- fonts, core colors, global tokens |
web |
Overrides for the public-facing website (agent/visual/artifacts/web/) |
product |
Overrides for the SaaS application (agent/visual/artifacts/product/) |
Verbal content (agent/verbal/) has no context overrides -- it applies globally. Visual content can be overridden per context via the artifacts/ layer.
2.0.0 is a breaking release. The directory layout, context vocabulary, and tool surface have all changed. No automated migration is included -- the path mapping is manual:
| v1 path | v2 path |
|---|---|
brand/shared/colors/*.css |
agent/visual/colors_and_type.css |
brand/shared/typography/*.css |
agent/visual/colors_and_type.css |
brand/shared/logos/* |
agent/visual/assets/ |
brand/shared/components/*.md |
agent/visual/components/*.md |
brand/shared/voice/brand-voice.md |
agent/verbal/voice.md |
brand/shared/guidelines/*.md |
agent/verbal/{positioning,messaging,differentiation,concepts}.md |
brand/marketing/* |
agent/visual/artifacts/web/* |
brand/product/* |
agent/visual/artifacts/product/* |
Your brandkit.config.yaml must also be updated to declare version: 2 and use the new brand.root field. v1 configs throw BrandkitV1ConfigError at startup -- the server will not start until the config is updated.
magic_trick.md is human-authored. The MCP reads it but no tool writes to it. If write tools are added in a future version, they must denylist this path. The taste primer is the brand's instincts -- it must stay human.
Token output formats. The get_tokens tool supports CSS custom properties, SCSS variables, Tailwind config, W3C Design Tokens, and flat JSON.
Transports. The server supports stdio (recommended for Claude Desktop), SSE (legacy HTTP), and Streamable HTTP (current MCP spec).
brandkit-mcp <command> [options]
Commands:
init [directory] Scaffold a brand atomic system from the starter template
validate [config] Validate configuration and scan for issues
serve Start the MCP server
preview Start the local preview server
docs Generate project documentation files
Global Options:
--version Show version number
--help Show help
Contributions are welcome.
git clone https://github.com/ejwhite7/brandkit-mcp
cd brandkit-mcp
npm install
npm run build
npm test
.js extensionsany types -- use proper interfacesMIT -- see LICENSE for details.
Built with the Model Context Protocol by Anthropic.
Выполни в терминале:
claude mcp add ejwhite7-brandkit-mcp -- npx Не уверен что выбрать?
Найди свой стек за 60 секунд
Автор?
Embed-бейдж для README
Похожее
Все в категории development