design-md
google-labs-code/stitch-skills
Analyze Stitch projects and synthesize semantic design systems into DESIGN.md files
What is design-md?
This skill helps you create DESIGN.md files that serve as the source of truth for prompting Stitch to generate new screens aligned with existing design language. It analyzes Stitch project assets—screens, HTML, CSS, and design metadata—and synthesizes them into a structured design system document using descriptive, semantic language.
- Retrieve screen metadata and design assets from Stitch projects via MCP Server
- Extract color palettes, typography rules, and component styling from HTML/CSS and design themes
- Translate technical design values (Tailwind classes, border-radius, hex codes) into evocative natural language descriptions
- Map project identity, visual atmosphere, geometry, depth, and layout principles
- Generate clean, designer-friendly DESIGN.md files following a standardized structure
- Provide exact hex codes and functional roles for all design elements
How to install design-md
npx skills add https://github.com/google-labs-code/stitch-skills --skill design-md- Access to the Stitch MCP Server
- A Stitch project with at least one designed screen
- Access to the Stitch Effective Prompting Guide (https://stitch.withgoogle.com/docs/learn/prompting/)
How to use design-md
- 1.Identify your Stitch project ID by running list_projects with filter 'view=owned' via the Stitch MCP Server
- 2.Retrieve the target screen ID by calling list_screens with your project ID
- 3.Fetch complete screen metadata using get_screen with both project ID and screen ID
- 4.Download the HTML code from htmlCode.downloadUrl and optionally the screenshot for visual reference
- 5.Extract design tokens from the HTML/CSS, including Tailwind classes, custom CSS, and color values
- 6.Call get_project with the full project path to retrieve project-level design theme and metadata
- 7.Analyze the visual atmosphere, color palette, typography, components, and layout principles from the retrieved assets
- 8.Synthesize findings into a DESIGN.md file following the prescribed structure: Visual Theme, Color Palette, Typography, Component Stylings, and Layout Principles
Use cases
- Create a design system document for a Stitch furniture e-commerce project to ensure new screens match the existing aesthetic
- Document color palettes and component styles from a landing page design to guide AI-generated screen variations
- Synthesize typography and spacing rules from multiple screens into a single source-of-truth design guide
- Extract and describe the visual atmosphere and mood of a mobile app design for consistent future generation
- Build a semantic design system from an existing Stitch project to onboard new team members or AI tools
- Design Systems Leads and Design Managers
- Product Designers working with Stitch for UI generation
- AI/ML engineers integrating design consistency into code generation workflows
- Teams using Stitch to maintain design coherence across multiple screens
design-md FAQ
DESIGN.md serves as the source of truth for prompting Stitch to generate new screens that align perfectly with existing design language. Stitch interprets design through Visual Descriptions supported by specific color values.
Run list_tools to find the Stitch MCP prefix, then call [prefix]:list_projects with filter 'view=owned' to find your project. Extract the Project ID from the name field (e.g., projects/13534454087919359824). Use list_screens with your project ID to find the Screen ID.
For each color, provide a descriptive natural language name (e.g., 'Deep Muted Teal-Navy'), the exact hex code in parentheses (e.g., '#294056'), and its functional role (e.g., 'Used for primary actions').
Translate technical values into physical descriptions: rounded-full becomes 'Pill-shaped', rounded-lg becomes 'Subtly rounded corners', and rounded-none becomes 'Sharp, squared-off edges'.
Avoid using technical jargon without translation, omitting color codes, forgetting functional roles, being too vague in atmosphere descriptions, and ignoring subtle details like shadows or spacing patterns.
Full instructions (SKILL.md)
Source of truth, from google-labs-code/stitch-skills.
name: design-md description: Analyze Stitch projects and synthesize a semantic design system into DESIGN.md files allowed-tools:
- "stitch*:*"
- "Read"
- "Write"
- "web_fetch"
Stitch DESIGN.md Skill
You are an expert Design Systems Lead. Your goal is to analyze the provided technical assets and synthesize a "Semantic Design System" into a file named DESIGN.md.
Overview
This skill helps you create DESIGN.md files that serve as the "source of truth" for prompting Stitch to generate new screens that align perfectly with existing design language. Stitch interprets design through "Visual Descriptions" supported by specific color values.
Prerequisites
- Access to the Stitch MCP Server
- A Stitch project with at least one designed screen
- Access to the Stitch Effective Prompting Guide: https://stitch.withgoogle.com/docs/learn/prompting/
The Goal
The DESIGN.md file will serve as the "source of truth" for prompting Stitch to generate new screens that align perfectly with the existing design language. Stitch interprets design through "Visual Descriptions" supported by specific color values.
Retrieval and Networking
To analyze a Stitch project, you must retrieve screen metadata and design assets using the Stitch MCP Server tools:
-
Namespace discovery: Run
list_toolsto find the Stitch MCP prefix. Use this prefix (e.g.,mcp_stitch:) for all subsequent calls. -
Project lookup (if Project ID is not provided):
- Call
[prefix]:list_projectswithfilter: "view=owned"to retrieve all user projects - Identify the target project by title or URL pattern
- Extract the Project ID from the
namefield (e.g.,projects/13534454087919359824)
- Call
-
Screen lookup (if Screen ID is not provided):
- Call
[prefix]:list_screenswith theprojectId(just the numeric ID, not the full path) - Review screen titles to identify the target screen (e.g., "Home", "Landing Page")
- Extract the Screen ID from the screen's
namefield
- Call
-
Metadata fetch:
- Call
[prefix]:get_screenwith bothprojectIdandscreenId(both as numeric IDs only) - This returns the complete screen object including:
screenshot.downloadUrl- Visual reference of the designhtmlCode.downloadUrl- Full HTML/CSS source codewidth,height,deviceType- Screen dimensions and target platform- Project metadata including
designThemewith color and style information
- Call
-
Asset download:
- Use
web_fetchorread_url_contentto download the HTML code fromhtmlCode.downloadUrl - Optionally download the screenshot from
screenshot.downloadUrlfor visual reference - Parse the HTML to extract Tailwind classes, custom CSS, and component patterns
- Use
-
Project metadata extraction:
- Call
[prefix]:get_projectwith the projectname(full path:projects/{id}) to get:designThemeobject with color mode, fonts, roundness, custom colors- Project-level design guidelines and descriptions
- Device type preferences and layout principles
- Call
Analysis & Synthesis Instructions
1. Extract Project Identity (JSON)
- Locate the Project Title
- Locate the specific Project ID (e.g., from the
namefield in the JSON)
2. Define the Atmosphere (Image/HTML)
Evaluate the screenshot and HTML structure to capture the overall "vibe." Use evocative adjectives to describe the mood (e.g., "Airy," "Dense," "Minimalist," "Utilitarian").
3. Map the Color Palette (Tailwind Config/JSON)
Identify the key colors in the system. For each color, provide:
- A descriptive, natural language name that conveys its character (e.g., "Deep Muted Teal-Navy")
- The specific hex code in parentheses for precision (e.g., "#294056")
- Its specific functional role (e.g., "Used for primary actions")
4. Translate Geometry & Shape (CSS/Tailwind)
Convert technical border-radius and layout values into physical descriptions:
- Describe
rounded-fullas "Pill-shaped" - Describe
rounded-lgas "Subtly rounded corners" - Describe
rounded-noneas "Sharp, squared-off edges"
5. Describe Depth & Elevation
Explain how the UI handles layers. Describe the presence and quality of shadows (e.g., "Flat," "Whisper-soft diffused shadows," or "Heavy, high-contrast drop shadows").
Output Guidelines
- Language: Use descriptive design terminology and natural language exclusively
- Format: Generate a clean Markdown file following the structure below
- Precision: Include exact hex codes for colors while using descriptive names
- Context: Explain the "why" behind design decisions, not just the "what"
Output Format (DESIGN.md Structure)
# Design System: [Project Title]
**Project ID:** [Insert Project ID Here]
## 1. Visual Theme & Atmosphere
(Description of the mood, density, and aesthetic philosophy.)
## 2. Color Palette & Roles
(List colors by Descriptive Name + Hex Code + Functional Role.)
## 3. Typography Rules
(Description of font family, weight usage for headers vs. body, and letter-spacing character.)
## 4. Component Stylings
* **Buttons:** (Shape description, color assignment, behavior).
* **Cards/Containers:** (Corner roundness description, background color, shadow depth).
* **Inputs/Forms:** (Stroke style, background).
## 5. Layout Principles
(Description of whitespace strategy, margins, and grid alignment.)
Usage Example
To use this skill for the Furniture Collection project:
-
Retrieve project information:
Use the Stitch MCP Server to get the Furniture Collection project -
Get the Home page screen details:
Retrieve the Home page screen's code, image, and screen object information -
Reference best practices:
Review the Stitch Effective Prompting Guide at: https://stitch.withgoogle.com/docs/learn/prompting/ -
Analyze and synthesize:
- Extract all relevant design tokens from the screen
- Translate technical values into descriptive language
- Organize information according to the DESIGN.md structure
-
Generate the file:
- Create
DESIGN.mdin the project directory - Follow the prescribed format exactly
- Ensure all color codes are accurate
- Use evocative, designer-friendly language
- Create
Best Practices
- Be Descriptive: Avoid generic terms like "blue" or "rounded." Use "Ocean-deep Cerulean (#0077B6)" or "Gently curved edges"
- Be Functional: Always explain what each design element is used for
- Be Consistent: Use the same terminology throughout the document
- Be Visual: Help readers visualize the design through your descriptions
- Be Precise: Include exact values (hex codes, pixel values) in parentheses after natural language descriptions
Tips for Success
- Start with the big picture: Understand the overall aesthetic before diving into details
- Look for patterns: Identify consistent spacing, sizing, and styling patterns
- Think semantically: Name colors by their purpose, not just their appearance
- Consider hierarchy: Document how visual weight and importance are communicated
- Reference the guide: Use language and patterns from the Stitch Effective Prompting Guide
Common Pitfalls to Avoid
- ❌ Using technical jargon without translation (e.g., "rounded-xl" instead of "generously rounded corners")
- ❌ Omitting color codes or using only descriptive names
- ❌ Forgetting to explain functional roles of design elements
- ❌ Being too vague in atmosphere descriptions
- ❌ Ignoring subtle design details like shadows or spacing patterns
Related skills
More from google-labs-code/stitch-skills and the wider catalog.
react:components
Convert Stitch designs into modular React components with AST validation and Vite integration.
enhance-prompt
Transform vague UI ideas into polished, Stitch-optimized prompts with design system context.
stitch-loop
Autonomous website builder using Stitch with iterative baton-passing loop pattern
shadcn-ui
Expert guidance for integrating and building applications with shadcn/ui components.
remotion
Generate professional walkthrough videos from Stitch designs using Remotion with smooth transitions and overlays
stitch-design
Unified design system and high-fidelity UI generation for Stitch projects.