plugins/stitch-design/skills/extract-design-md/SKILL.md
Extract a comprehensive design system (DESIGN.md) directly from frontend source code — React, Vue, Svelte, Angular, plain HTML/CSS, or any web framework. Analyzes component files, stylesheets, Tailwind configs, theme definitions, and design tokens to produce a rich, Stitch-compatible design system document. Use this skill whenever the user wants to reverse-engineer a design system from an existing codebase, audit the visual language of a project, extract design tokens from source files, or understand the styling patterns in a frontend repo — even if they just say "what does this app look like?" or "pull out the design from this code."
npx skillsauth add google-labs-code/stitch-skills stitch::extract-design-mdInstall 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.
Analyze frontend source code to extract a comprehensive design system document (DESIGN.md) that captures the project's visual language — colors, typography, spacing, component patterns, and layout principles — directly from the source files, without needing to build or render the application.
The design-md skill works from rendered HTML. But often you have a codebase
and want to understand its design system before you can even run the app —
maybe dependencies are missing, the build is broken, or you just want a quick
audit. This skill reads the source files themselves: stylesheets, component
files, theme configs, and Tailwind setups. It's faster and works anywhere.
Start by understanding what you're working with. This determines which extraction patterns to use.
Scan the project root for telltale files:
| Signal File | Framework / Tool |
|:---|:---|
| package.json with react | React / Next.js |
| package.json with vue | Vue / Nuxt |
| package.json with svelte | Svelte / SvelteKit |
| package.json with @angular/core | Angular |
| tailwind.config.js/ts | Tailwind CSS |
| postcss.config.js | PostCSS pipeline |
| styled-components or @emotion in deps | CSS-in-JS |
| .css / .scss / .less files only | Plain CSS / SASS |
| theme.js / theme.ts / tokens.js | Design token files |
Read package.json first — it reveals the framework, CSS tooling, and any
design-token libraries (e.g., style-dictionary, @chakra-ui/react,
@mui/material, ant-design). This context tells you where to look for
styling information.
Identify the key directories and files you'll analyze:
src/
├── components/ ← Component-level styles
├── styles/ ← Global stylesheets
├── theme/ ← Theme definitions, tokens
├── assets/ ← Fonts, images
├── app.css ← Root styles
└── index.css ← Entry CSS
Also check for:
tailwind.config.js / tailwind.config.ts — Custom colors, fonts, spacingglobals.css / global.css — CSS custom properties (variables)theme.* or tokens.* fileschakra-theme.ts, vuetify.config.ts)Consult the appropriate reference for extraction patterns:
These references contain framework-specific patterns for locating colors, typography, spacing, and component styles. Read the one that matches before proceeding.
Work through each design dimension systematically. For each one, gather raw data from the source files, then synthesize it into descriptive language.
The goal isn't to dump every CSS property — it's to understand the intent behind the styling choices and describe them in human, editorial language that another designer (or Stitch) can use to recreate the same visual feel.
Read the broadest styling first to understand the overall mood:
body or root element background? Light
cream (#f-range) signals airy/clean; dark (#0-#2 range) signals moody/dramatic.Look for these signals in the source:
| Source Location | What It Tells You |
|:---|:---|
| Root background-color or Tailwind bg-* on layouts | Overall lightness/darkness |
| Spacing scale in Tailwind config or CSS vars | Whitespace philosophy |
| Number of components vs. wrapper padding | Density |
| Custom property naming (--warm-* vs --cool-*) | Color temperature intent |
| Comments in theme files | Design intent in the developer's own words |
Extract every unique color from the codebase and assign functional roles. Search across all layers:
Where to find colors:
| Layer | What to Search |
|:---|:---|
| CSS custom properties | --color-*, --primary, --bg-* |
| Tailwind config | theme.extend.colors |
| Theme/token files | Color objects, palettes |
| Component styles | background-color, color, border-color |
| Inline/scoped styles | bg-*, text-* classes in templates |
| CSS-in-JS theme objects | colors, palette keys |
How to organize: Group colors by function, not by hue:
For each color, create a descriptive name that evokes the color's character rather than its raw hex value:
#294056 → "Blue"#294056 → "Deep Muted Teal-Navy" — Primary CTA, active navigationDeduplication matters. Codebases often have near-duplicate colors (e.g.,
#333 and #2C2C2C). Consolidate them under one name that best represents
the intended color.
Extract the complete typographic system:
Font families:
font-family, Tailwind fontFamily, Google Fonts links, or
local @font-face declarations.Type scale (hierarchy):
font-size (in rem or px)font-weight (numeric value + descriptive name)letter-spacing (and why — elegance? compactness?)line-height (generous for readability? tight for display?)Spacing principles:
Analyze the 4-5 most important UI primitives:
Buttons:
Cards / Containers:
Navigation:
Inputs & Forms:
Domain-Specific Components:
Extract the structural system:
Grid & Structure:
max-width on containers)Whitespace Strategy:
Alignment & Visual Balance:
Responsive Behavior:
Synthesize the extraction into actionable prompts for Stitch:
Assemble everything into the standard DESIGN.md format. Place it at
.stitch/DESIGN.md in the project directory (create the .stitch/ directory
if it doesn't exist).
[!IMPORTANT] You MUST include the YAML frontmatter at the top of the file with
nameandcolorsmapping, exactly as shown in the example at examples/DESIGN.md. This structured data is required for other skills to parse the design system.Failure to include this YAML block with at least the core color tokens is a failure to use this skill correctly.
Use the format from the example at examples/DESIGN.md as your template. The file must start with the YAML block, followed by the markdown sections:
# Design System: [Project Name]
**Project ID:** [If known, otherwise omit]
## 1. Visual Theme & Atmosphere
[Rich 2-paragraph description of mood, philosophy, and key characteristics]
## 2. Color Palette & Roles
### Primary Foundation
### Accent & Interactive
### Typography & Text Hierarchy
### Functional States
## 3. Typography Rules
### Hierarchy & Weights
### Spacing Principles
## 4. Component Stylings
### Buttons
### Cards & [Domain-Specific Containers]
### Navigation
### Inputs & Forms
### [Domain-Specific Components]
## 5. Layout Principles
### Grid & Structure
### Whitespace Strategy
### Alignment & Visual Balance
### Responsive Behavior & Touch
## 6. Design System Notes for Stitch Generation
### Language to Use
### Color References
### Component Prompts
### Incremental Iteration
If the user wants to push the design system into Stitch:
manage-design-system skill for the MCP create/update callsIf the user just wants the document, you're done after Phase 3.
Before delivering the DESIGN.md, verify:
/* hero section — breathable */) and commit
messages. These are gold for understanding the why.style-dictionary,
@tokens-studio, or similar, these files are the most authoritative
source of design values.theme.ts that
defines a palette tells you the intended design system; scattered inline
styles in components tell you what actually shipped. Both matter, but
start from the theme.tailwind.config.js, that is the design system — extract from it first,
then spot-check components for overrides.--brand-primary, they're telling you this is a design token. Respect that.development
Convert Stitch HTML designs to React Native components with StyleSheet
development
Convert Stitch HTML designs to React Native components with StyleSheet
development
Semantic Design System Skill for Google Stitch. Generates agent-friendly DESIGN.md files that enforce premium, anti-generic UI standards — strict typography, calibrated color, asymmetric layouts, perpetual micro-motion, and hardware-accelerated performance.
development
Teaches agents to iteratively build websites using Stitch with an autonomous baton-passing loop pattern