design-review
This skill runs a structured design review of what has been built, measured against the design brief and the chosen aesthetic philosophy.
CRITICAL — Visual Screenshot Capture
You MUST capture screenshots of the running application as part of every design review. Code review alone is insufficient — you need to see what the user sees. Follow the screenshot capture protocol in Step 3 below. This is not optional.
Example prompts
- "Review what I just built"
- "Run a design critique on the landing page"
- "Check this against the brief"
- "Here's a screenshot. How does it look?" [paste screenshot]
- "QA pass before I ship this"
Process
-
Read the brief. Look for the active feature's brief at
.design/<feature-slug>/DESIGN_BRIEF.md. If multiple feature folders exist under.design/, ask the user which feature to review. If no.design/folder exists, fall back toDESIGN_BRIEF.mdin the project root. If neither exists, ask the user what the intended design direction was. -
Explore the built code. Examine every component, page, and style file that was created or modified. Scan specifically for:
- All new or modified components and their relationship to pre-existing components
- Token/variable usage: are components using shared tokens or hardcoding values?
- Duplicate components that should be consolidated
- File naming and organization: do new files follow the project's conventions?
- Understand what was actually built, not what was planned.
-
Capture screenshots of the running application.
This step is mandatory. Do not skip it. Do not rely only on user-provided screenshots.
Screenshot Tool Priority
Try each option in order. Use the first one that is available:
- Playwright MCP (preferred). Check if the
plugin-playwright-playwrightMCP server is available. If it is, use it — it gives you precise control over viewport sizing, full-page captures, and file naming. - Cursor IDE Browser (second choice). If Playwright MCP is not available, use the
cursor-ide-browserMCP server'sbrowser_take_screenshottool instead. It has the same core capabilities. - Ask the user (last resort). If neither MCP server nor in-app browser is available, you MUST ask the user to provide screenshots manually. Be specific about what you need:
- "I don't have access to a browser tool. To complete the visual review I need screenshots of the running application. Please provide:"
- A full-page screenshot at desktop width (1280px)
- A full-page screenshot at tablet width (768px)
- A full-page screenshot at mobile width (375px)
- Dark mode variants (if applicable)
- Any specific component or interactive state you want reviewed
- Ask the user to paste/attach the images directly in chat, or to save them into the
screenshots/folder themselves. - Do not skip the visual review. Wait for the user to provide screenshots before proceeding with the checklist.
Screenshot Save Location
All screenshots MUST be saved to a
screenshots/subfolder inside the feature's.design/directory — the same folder whereDESIGN_BRIEF.mdand other design flow files live.Path pattern:
.design/<feature-slug>/screenshots/If the brief lives at
.design/onboarding-flow/DESIGN_BRIEF.md, screenshots go to.design/onboarding-flow/screenshots/. Create the folder if it does not exist.If no
.design/folder exists (legacy project or standalone review), fall back to ascreenshots/folder in the project root.Use descriptive filenames that encode what was captured:
.design/ └── onboarding-flow/ ├── DESIGN_BRIEF.md ├── DESIGN_REVIEW.md └── screenshots/ ├── review-homepage-desktop-1280.png ├── review-homepage-tablet-768.png ├── review-homepage-mobile-375.png ├── review-homepage-dark-mode-desktop-1280.png └── review-card-component-hover.pngScreenshot Capture Protocol
a. Navigate to the application. Ask the user for the URL if not obvious from the project (e.g.,
http://localhost:3000). Usebrowser_navigateto open it.b. Capture responsive breakpoints. At minimum, capture these three viewports for every key page/view:
Breakpoint Width × Height Filename suffix Mobile 375 × 812 -mobile-375Tablet 768 × 1024 -tablet-768Desktop 1280 × 800 -desktop-1280Use
browser_resizeto set the viewport before each screenshot. Usebrowser_take_screenshotwithfullPage: trueto capture the entire scrollable page, and save with thefilenameparameter pointing to thescreenshots/folder.Playwright MCP example sequence (assuming feature slug is
onboarding-flow):1. browser_navigate → { url: "http://localhost:3000" } 2. browser_resize → { width: 1280, height: 800 } 3. browser_take_screenshot → { type: "png", filename: ".design/onboarding-flow/screenshots/review-homepage-desktop-1280.png", fullPage: true } 4. browser_resize → { width: 768, height: 1024 } 5. browser_take_screenshot → { type: "png", filename: ".design/onboarding-flow/screenshots/review-homepage-tablet-768.png", fullPage: true } 6. browser_resize → { width: 375, height: 812 } 7. browser_take_screenshot → { type: "png", filename: ".design/onboarding-flow/screenshots/review-homepage-mobile-375.png", fullPage: true }c. Capture interactive states (when relevant).
- Hover states on buttons, cards, links
- Focus states on form fields
- Open states on dropdowns, modals, menus
- Error/success states on forms
- Loading and empty states
d. Capture dark mode (if the project supports it). Toggle dark mode and repeat the responsive breakpoint captures with
-dark-modein the filename.e. Capture specific components. If the review focuses on a particular component, use the
elementandrefparameters to screenshot just that element.Analyze Every Screenshot
After capturing, visually analyze each screenshot against the design brief. For each screenshot:
- Compare against the brief's aesthetic direction
- Check visual hierarchy: is the most important element the most prominent?
- Check spacing consistency: do margins and padding look even and intentional?
- Check color: does the palette match the brief's direction?
- Check typography: are font sizes, weights, and spacing visually correct?
- Check responsive adaptation: does the layout properly reorganize (not just shrink)?
- Note rendering issues that code review alone would miss (font loading failures, broken images, layout overflow, z-index problems, incorrect border-radius, color mismatches)
Reference specific screenshots by filename in the review output so findings are traceable.
- Playwright MCP (preferred). Check if the
-
Run the review checklist below. For each category, note what passes and what needs refinement. Be specific. Reference exact components, files, line numbers, and screenshot filenames.
-
Produce a prioritized refinement list. Group issues by severity:
- Must fix: Broken functionality, accessibility failures, major deviations from the brief.
- Should fix: Inconsistencies, missing states, responsive issues.
- Could improve: Polish, animation refinement, typography fine-tuning.
-
Save the review as
DESIGN_REVIEW.mdinside the feature's.design/<feature-slug>/folder (next toDESIGN_BRIEF.md). If no.design/folder exists, save to the project root. Include a "Screenshots Captured" section listing all screenshots taken with their paths. Present the review directly as well if the user prefers.
Review Checklist
Visual Hierarchy
- Is the most important content the most visually prominent on each page/view?
- Does the type scale create clear levels of importance (heading, subheading, body, caption)?
- Do interactive elements (buttons, links, inputs) have enough visual weight to be found without hunting?
- Is there a clear reading order? Can you trace where the eye goes first, second, third?
Consistency
- Are spacing values consistent? Check padding and margins against the established scale (4px/8px base or whatever the project uses).
- Are colors used consistently? Check that the same semantic meaning always maps to the same color (primary actions, errors, success states, disabled states).
- Are border radii, shadow values, and font sizes reused from a shared set, or are there one-off values?
- Do similar components look and behave similarly? (e.g., all cards, all form fields, all buttons within a category.)
Aesthetic Fidelity
- Does the implementation match the named philosophy from the brief?
- Would someone looking at this immediately recognize the intended aesthetic direction?
- Are there elements that break the aesthetic (a generic component in an otherwise distinctive interface, a conflicting font, an out-of-place color)?
- Does the level of detail match the philosophy? (Minimalist designs should not have unnecessary decoration. Maximalist designs should not have empty, unfinished areas.)
Component Quality
- Do existing components from the codebase appear correctly, or were they reimplemented?
- Are new components following the same API patterns (props, naming, file organization) as existing ones?
- Are there duplicate components that should be consolidated?
States and Interactions
- Do interactive elements have all necessary states: default, hover, focus, active, disabled?
- Do form fields have states for: empty, filled, error, success, disabled?
- Are loading states handled? Empty states?
- Do transitions and animations match the philosophy's motion guidelines?
- Is there visual feedback for every user action?
Responsive Behavior
- Does the layout work at mobile (375px), tablet (768px), and desktop (1280px+)?
- Do components adapt appropriately? (Not just shrink, but reorganize when needed.)
- Is touch target size adequate on mobile (minimum 44x44px)?
- Does text remain readable at all breakpoints? No text too small, no lines too wide (max 65-75 characters).
Accessibility
- Color contrast: Do text/background combinations meet WCAG AA (4.5:1 for body text, 3:1 for large text)?
- Keyboard navigation: Can every interactive element be reached and activated with keyboard alone?
- Focus indicators: Are focus rings visible and styled consistently?
- Semantic HTML: Are headings in order? Are landmarks used (main, nav, header, footer)? Are form labels associated?
- Screen reader: Do images have alt text? Do icons have labels? Are decorative elements hidden from assistive technology?
- Motion: Is there a reduced-motion media query for users who need it?
Typography
- Is the font actually loading? (Check for FOIT/FOUT flash.)
- Are line lengths comfortable for reading (45-75 characters on body text)?
- Is line height appropriate (1.4-1.6 for body, tighter for headings)?
- Is the type scale intentional, or are there arbitrary sizes?
Dark Mode
- If the project has dark mode tokens, are they applied correctly?
- Are all color values using CSS variables (not hardcoded hex values that won't switch)?
- Does the dark palette feel intentional for the chosen philosophy, or is it a simple inversion?
- Are shadows adjusted for dark mode (darker, more transparent)?
- Do accent colors maintain sufficient contrast against dark backgrounds?
- Is there a working toggle mechanism or
prefers-color-schemesupport?
Mobile-First
- Was the layout built mobile-first (using
min-widthmedia queries, notmax-width)? - Does the mobile layout work at 375px without horizontal scrolling?
- Is navigation adapted for mobile (not just a desktop nav that overflows)?
- Are touch targets at least 44x44px?
- Is body text at least 16px on mobile?
Output Format
# Design Review: [Feature/Page Name]
Reviewed against: DESIGN_BRIEF.md
Philosophy: [named philosophy]
Date: [date]
## Screenshots Captured
| Screenshot | Breakpoint | Description |
| -------------------------------------------- | ------------------ | --------------- |
| `screenshots/review-[page]-desktop-1280.png` | Desktop (1280×800) | [what it shows] |
| `screenshots/review-[page]-tablet-768.png` | Tablet (768×1024) | [what it shows] |
| `screenshots/review-[page]-mobile-375.png` | Mobile (375×812) | [what it shows] |
> All screenshots are in `.design/<feature-slug>/screenshots/`.
## Summary
[2-3 sentences on overall quality and the biggest finding.]
## Must Fix
1. **[Issue]**: [Specific description with file/component reference]. See [`screenshots/[relevant-screenshot].png`]. _Fix: [concrete suggestion]._
## Should Fix
1. **[Issue]**: [Description]. See [`screenshots/[relevant-screenshot].png`]. _Fix: [suggestion]._
## Could Improve
1. **[Issue]**: [Description]. _Suggestion: [idea]._
## What Works Well
[Note the strongest aspects of the implementation. This is not padding. Designers need to know what to keep doing.]