Design Lookup
Search the web for CSS components, SVG icons, animations, and design resources. Return usable code with attribution.
Tools
scripts/fetch_page.py — Playwright browser fetcher
Bypasses Cloudflare protection and renders SPAs. Use this for sites that block WebFetch (CodePen, UIVerse, etc.).
# Extract HTML/CSS/JS code from a CodePen pen (returns clean JSON) python3 scripts/fetch_page.py "https://codepen.io/user/pen/ID" --codepen-code # Fetch any protected page as text python3 scripts/fetch_page.py "https://uiverse.io/user/component-slug" # Extract specific elements with CSS selector python3 scripts/fetch_page.py "https://example.com" --selector ".code-block" # Increase timeout for slow pages python3 scripts/fetch_page.py "https://example.com" --wait 20
When to use: After WebSearch finds promising URLs on Cloudflare-protected sites (CodePen, UIVerse, etc.), use this script to fetch the actual code.
When NOT to use: For sites where WebFetch works fine (CSS-Tricks, GitHub raw, dev.to, MDN). WebFetch is faster.
Workflow
- •
Classify the request — Determine what the user needs:
- •CSS component (button, card, loader, toggle, etc.)
- •SVG icon (UI icon, brand logo, etc.)
- •CSS animation/effect (hover effect, transition, keyframe animation)
- •SVG graphic (illustration, wave, blob, background)
- •Design inspiration (visual reference, not code)
- •
Choose sources — Consult references/sources.md for the best sources and search patterns. Use the "Search Strategy by Request Type" table.
- •
Search broadly — Run 2-3 parallel WebSearch queries combining:
- •
site:{source} {query}for targeted source searches - •A general
{query} CSS/SVGsearch as fallback - •Vary terminology (e.g., "loader" vs "spinner" vs "loading animation")
- •
- •
Fetch code — Use the appropriate extraction method per source:
CodePen pens — Use
fetch_page.py --codepen-codeto extract clean HTML/CSS/JS as JSON.UIVerse components — Use
fetch_page.pyto get the page text (includes code with line numbers inline).SVG icons — Fetch raw SVGs directly from GitHub with WebFetch:
- •Lucide:
https://raw.githubusercontent.com/lucide-icons/lucide/main/icons/{name}.svg - •Heroicons:
https://raw.githubusercontent.com/tailwindlabs/heroicons/master/optimized/24/outline/{name}.svg(alsosolid/,20/solid/) - •Tabler:
https://raw.githubusercontent.com/tabler/tabler-icons/main/icons/outline/{name}.svg(alsofilled/) - •Feather:
https://raw.githubusercontent.com/feathericons/feather/main/icons/{name}.svg - •Simple Icons:
https://raw.githubusercontent.com/simple-icons/simple-icons/develop/icons/{name}.svg
Articles/tutorials — Fetch directly with WebFetch (CSS-Tricks, MDN, dev.to, blogs all work).
- •Lucide:
- •
Present results — Format output as:
## {Description of component}
Source: {URL}
{code block with HTML/CSS/SVG}
{One-line note on how to customize, if relevant}
Provide 2-4 options when possible so the user or design agent can choose.
Guidelines
- •Clean up extracted code — Remove unnecessary vendor prefixes, framework-specific wrappers, or unrelated styles. Present minimal, self-contained snippets.
- •Note licenses — If a source requires attribution (e.g., Flaticon free tier), mention it.
- •For SVG icons — Prefer inline SVG code over links to icon fonts. Include
viewBoxand strip unnecessary metadata. - •For generators (waves, blobs, gradients) — Suggest the generator URL so the user can tweak parameters, and provide a sample output.