Stitch-kit stitch-design-system
Extracts a Stitch design and generates production code artifacts — CSS custom properties with dark mode tokens, a Tailwind v4 @theme block, and a semantic design system document. Run this before framework conversion skills.
git clone https://github.com/gabelul/stitch-kit
T=$(mktemp -d) && git clone --depth=1 https://github.com/gabelul/stitch-kit "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/stitch-design-system" ~/.claude/skills/gabelul-stitch-kit-stitch-design-system && rm -rf "$T"
skills/stitch-design-system/SKILL.mdStitch → Design System Code Artifacts
You are a design systems engineer. You analyze Stitch designs and generate code artifacts — not just documentation. While the
design-md skill produces a human-readable markdown file, this skill produces files you actually import into your codebase: CSS custom properties with dark mode, Tailwind v4 configuration, and typography tokens.
Use this skill first, before
or stitch-nextjs-components
. The generated tokens become the foundation for all subsequent component generation.stitch-svelte-components
When to use this skill
Use this skill when:
- Starting a new project from a Stitch design
- The user mentions "design tokens", "CSS variables", "dark mode tokens", "Tailwind config"
- Running before framework conversion skills to ensure design consistency
- Updating an existing project's design system after a Stitch design update
What this skill generates
Three output files:
| File | Purpose |
|---|---|
| CSS custom properties — import this in your framework's global CSS |
| Tailwind v4 block — paste into your |
| Extended design document (richer than , includes dark mode + animation tokens) |
Step 1: Retrieve the Stitch design
- Namespace discovery — Run
to find the Stitch MCP prefix.list_tools - Fetch screen — Call
with[prefix]:get_screen
andprojectId
.screenId - Download HTML — Run:
bash scripts/fetch-stitch.sh "[htmlCode.downloadUrl]" "temp/source.html" - Visual reference — Check
to see the full design intent.screenshot.downloadUrl
If multiple screens exist, retrieve all of them. Run
[prefix]:list_screens and fetch each one to ensure the token set covers every pattern in the design.
Step 1.5: Read project DesignTheme (ground truth)
Before parsing HTML, get the authoritative design data from the Stitch API. This eliminates guesswork — the API knows the exact primary color, fonts, and full semantic color map.
- Call
withget_projectprojects/[projectId] - Check for
— if present, it's a full markdown design system document that Stitch auto-generated. Parse it for typography rules, color philosophy, component patterns, spacing guidelines, and do's/don'ts. This is the most valuable single field.designMd - Extract
— a 40+ token semantic color map. This gives you the ENTIRE color system pre-computed:namedColors- Primary:
,primary
,on_primary
,primary_container
,on_primary_container
,primary_fixedprimary_fixed_dim - Secondary:
,secondary
,on_secondary
,secondary_containeron_secondary_container - Tertiary: same pattern
- Surfaces:
,surface
,surface_dim
,surface_bright
,surface_container_lowest
,surface_container_low
,surface_container
,surface_container_high
,surface_container_highest
,surface_tintsurface_variant - Utility:
,background
,on_background
,on_surface
,on_surface_variant
,outlineoutline_variant - States:
,error
,on_error
,error_containeron_error_container - Inverse:
,inverse_surface
,inverse_on_surfaceinverse_primary
- Primary:
- Extract structural values:
| DesignTheme field | → CSS token | Mapping |
|---|---|---|
| | Hex seed — but prefer if available |
| | Takes precedence over customColor |
| | Exact hex override |
| | Exact hex override |
| | Base for surface hierarchy |
| (light) | Light mode page background |
| (dark) | Dark mode page background |
| / heading | Map enum → font-family stack (see table below) |
| | Map enum → font-family stack |
| | Map enum → font-family stack |
| baseline | ROUND_FOUR=4px, ROUND_EIGHT=8px, ROUND_TWELVE=12px, ROUND_FULL=9999px |
| spacing multiplier | 0=tight (base 2px), 1=compact (base 4px), 2=normal (base 4px), 3=spacious (base 8px) |
| informs palette approach | e.g., FIDELITY means stick to brand colors, VIBRANT means boost saturation |
Font enum → CSS font-family mapping:
| Stitch enum | CSS font-family |
|---|---|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
- Use these as the baseline. Then use HTML analysis (Step 2) only for values the API doesn't provide: motion/transition durations, exact spacing pixel values, shadow definitions, additional colors beyond the namedColors set.
If
is available, skip the color extraction in Step 2 entirely — the API's color map is authoritative and complete. Only supplement with motion, spacing pixel values, and shadows from HTML.namedColors
If
is available, use it as the foundation for the DESIGN.md output (Step 5). Don't rewrite it — augment it with CSS variable names, Tailwind mappings, and implementation notes.designMd
Step 2: Extract supplementary values from HTML
If Step 1.5 provided
namedColors and designMd, you only need HTML for:
Motion
- Transition durations used (or infer: 150ms for micro, 300ms for panels)
- Easing styles (linear, ease-out, spring-like)
Spacing pixel values
- Exact gap/padding values used in the design
- Shadow definitions
Additional colors (rare)
Only if the design uses colors not in
namedColors — check for gradients, overlays, or custom accent colors.
If Step 1.5 did NOT provide namedColors (older projects without designMd), fall back to full HTML extraction:
Colors (fallback)
Identify every distinct color from the Tailwind config in
<head> or infer from screenshot. For each, determine semantic role and usage frequency. Aim for 8-12 semantic tokens.
Typography (fallback)
- Font families (heading, body, mono — if present)
- Type scale sizes (the actual
orpx
values used in the design)rem - Font weights used
- Line heights
Spacing & geometry (fallback)
- Base spacing unit (usually 4px or 8px)
- Border radius values
- Shadow definitions
Step 3: Generate design-tokens.css
design-tokens.cssCreate
design-tokens.css with full light + dark mode token sets.
Naming convention:
— Color tokens--color-*
— Typography--font-*
— Spacing scale--spacing-*
— Border radius--radius-*
— Elevation--shadow-*
— Animation timing--motion-*
Template (when namedColors is available from API — preferred):
/* ============================================================= Design Tokens — extracted from Stitch project: [Project Name] Generated by stitch-design-system skill Source: DesignTheme API (namedColors) + HTML supplementary ============================================================= */ /* ---- Light mode (default) ---- */ :root { /* Colors: Direct mapping from Stitch namedColors API response */ --color-primary: [namedColors.primary]; --color-on-primary: [namedColors.on_primary]; --color-primary-container: [namedColors.primary_container]; --color-secondary: [namedColors.secondary]; --color-on-secondary: [namedColors.on_secondary]; --color-tertiary: [namedColors.tertiary]; --color-on-tertiary: [namedColors.on_tertiary]; --color-error: [namedColors.error]; --color-on-error: [namedColors.on_error]; --color-background: [namedColors.background]; --color-on-background: [namedColors.on_background]; --color-surface: [namedColors.surface]; --color-on-surface: [namedColors.on_surface]; --color-surface-variant: [namedColors.surface_variant]; --color-on-surface-variant: [namedColors.on_surface_variant]; --color-surface-container: [namedColors.surface_container]; --color-surface-container-low: [namedColors.surface_container_low]; --color-surface-container-high: [namedColors.surface_container_high]; --color-surface-container-highest: [namedColors.surface_container_highest]; --color-outline: [namedColors.outline]; --color-outline-variant: [namedColors.outline_variant]; --color-inverse-surface: [namedColors.inverse_surface]; --color-inverse-on-surface: [namedColors.inverse_on_surface]; --color-inverse-primary: [namedColors.inverse_primary]; --color-surface-tint: [namedColors.surface_tint]; /* Typography */ --font-sans: [font-family-stack]; /* Heading and UI font */ --font-body: [font-family-stack]; /* Body text font (may equal --font-sans) */ --font-mono: [monospace-stack]; /* Code, technical content */ /* Type scale */ --text-xs: 0.75rem; /* 12px */ --text-sm: 0.875rem; /* 14px */ --text-base: 1rem; /* 16px */ --text-lg: 1.125rem; /* 18px */ --text-xl: 1.25rem; /* 20px */ --text-2xl: 1.5rem; /* 24px */ --text-3xl: 1.875rem; /* 30px */ --text-4xl: 2.25rem; /* 36px */ /* Spacing scale (base 4px) */ --space-1: 0.25rem; /* 4px */ --space-2: 0.5rem; /* 8px */ --space-3: 0.75rem; /* 12px */ --space-4: 1rem; /* 16px */ --space-6: 1.5rem; /* 24px */ --space-8: 2rem; /* 32px */ --space-12: 3rem; /* 48px */ --space-16: 4rem; /* 64px */ /* Geometry */ --radius-sm: [value]; /* Small elements: badges, chips */ --radius-md: [value]; /* Buttons, inputs */ --radius-lg: [value]; /* Cards, panels */ --radius-xl: [value]; /* Modals, drawers */ --radius-full: 9999px; /* Pills, avatars */ /* Shadows */ --shadow-sm: [value]; /* Subtle card lift */ --shadow-md: [value]; /* Dropdown, tooltip */ --shadow-lg: [value]; /* Modal, sheet */ /* Motion tokens */ --motion-duration-fast: 150ms; /* Hover states, micro interactions */ --motion-duration-base: 250ms; /* Typical UI transitions */ --motion-duration-slow: 400ms; /* Page-level, large panel */ --motion-ease-default: cubic-bezier(0.4, 0, 0.2, 1); /* Material ease */ --motion-ease-out: cubic-bezier(0, 0, 0.2, 1); /* Entries */ --motion-ease-in: cubic-bezier(0.4, 0, 1, 1); /* Exits */ --motion-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1); /* Bouncy open */ } /* ---- Dark mode ---- */ /* Applied via .dark class (Next.js + next-themes) or [data-theme="dark"] (Svelte) */ .dark, [data-theme="dark"] { --color-background: [dark-hex]; --color-surface: [dark-hex]; --color-surface-elevated: [dark-hex]; --color-primary: [dark-hex]; /* Same hue, lighter for dark bg contrast */ --color-primary-hover: [dark-hex]; --color-primary-fg: [dark-hex]; --color-secondary: [dark-hex]; --color-secondary-fg: [dark-hex]; --color-text: [dark-hex]; --color-text-muted: [dark-hex]; --color-text-disabled: [dark-hex]; --color-border: [dark-hex]; --color-border-focus: [dark-hex]; --color-error: [dark-hex]; --color-success: [dark-hex]; --color-warning: [dark-hex]; /* Typography, spacing, geometry, motion tokens: unchanged in dark mode */ }
Step 4: Generate tailwind-theme.css
tailwind-theme.cssFor projects using Tailwind v4 (no
tailwind.config.js), generate a @theme block.
Important: Tailwind v4 uses
@theme in CSS, not a JS config file. Map tokens to Tailwind's namespace:
/* tailwind-theme.css — paste into your globals.css or import it */ @import "tailwindcss"; @theme { /* Wire Tailwind color utilities to your CSS variables */ --color-background: var(--color-background); --color-surface: var(--color-surface); --color-primary: var(--color-primary); --color-primary-hover: var(--color-primary-hover); --color-text: var(--color-text); --color-text-muted: var(--color-text-muted); --color-border: var(--color-border); /* Fonts */ --font-sans: var(--font-sans); --font-mono: var(--font-mono); /* Radius */ --radius-sm: var(--radius-sm); --radius-md: var(--radius-md); --radius-lg: var(--radius-lg); /* Animation duration utilities */ --animate-duration-fast: var(--motion-duration-fast); --animate-duration-base: var(--motion-duration-base); --animate-duration-slow: var(--motion-duration-slow); }
For Tailwind v3 projects (with
tailwind.config.js), instead generate a tailwind.config.js section using the extracted hex values directly.
Step 5: Generate DESIGN.md
DESIGN.mdProduce an extended design document. It has all sections from the standard
design-md skill plus:
# Design System: [Project Name] > Generated by stitch-design-system from Stitch project [ID] > Screens analyzed: [list] ## 1. Visual Theme & Atmosphere [Mood, density, aesthetic philosophy — 2-3 sentences] ## 2. Color Palette & Roles | Token | Light | Dark | Role | |-------|-------|------|------| | --color-primary | #... | #... | Main CTA, key actions | | --color-background | #... | #... | Page background | | ... | | | | ## 3. Typography - **Heading font**: [Family, weights used, where] - **Body font**: [Family, weights used, where] - **Type scale**: xs (12px) → sm (14px) → base (16px) → lg (18px) → ... → 4xl (36px) ## 4. Geometry & Elevation - **Border radius**: sm [Xpx] | md [Xpx] | lg [Xpx] | xl [Xpx] - **Shadows**: [describe the elevation system] ## 5. Motion System - **Micro** (hovers, toggles): [duration]ms [easing] - **Meso** (panels, drawers): [duration]ms [easing] - **Macro** (page transitions): [duration]ms [easing] - **Spring** (playful elements): cubicOut spring ## 6. Stitch Prompt Copy-Paste Block Use this block in every Stitch prompt for design consistency:
[Primary color: NAME (#HEX)] — used for buttons and key actions [Background: #HEX] — clean and [mood adjective] [Typography: FONT NAME] — [weight] weight for headings, regular for body [Aesthetic: 2-3 adjectives describing the visual style] [Border radius: SIZE — rounded/sharp/pill-shaped elements]
## 7. Dark Mode Notes [Specific notes on how the dark theme differs — any color roles that change significantly, any elements that need special treatment in dark mode]
Step 6: Output & integration
Write all three files to the project root (or wherever the user specifies):
design-tokens.csstailwind-theme.cssDESIGN.md
Then tell the user how to use them:
For Next.js:
// app/globals.css @import '../design-tokens.css'; @import '../tailwind-theme.css';
For SvelteKit:
<!-- src/app.css --> @import '$lib/design-tokens.css';
For the Stitch loop:
Copy Section 6 from
into every Stitch prompt to maintain design consistency across generated screens.DESIGN.md
Troubleshooting
| Issue | Fix |
|---|---|
| Can't determine dark mode hex values | Use the light-mode hue, desaturate slightly, and increase lightness by 30-40% |
| Font not loading | Add Google Fonts to |
| Tailwind v3 vs v4 confusion | Check — v4 uses and no config file |
| Tokens not applying | Ensure is imported BEFORE component CSS |
Integration with other skills
- Run this skill before
orstitch-nextjs-componentsstitch-svelte-components - The framework skills will import
instead of hardcoding valuesdesign-tokens.css - The
Section 6 feeds intoDESIGN.md
for multi-page consistencystitch-loop
References
— Full template with all token categoriesresources/tokens-template.css