When the user wants to optimize images for search engines and performance. Also use when the user mentions "image SEO," "alt text," "image captions," "figcaption," "image optimization," "WebP," "lazy loading," "LCP," "image sitemap," "responsive images," "srcset," "image format," or "hero image optimization." For CWV, use core-web-vitals.
Guides image optimization for Google Search (text results, Image Pack, Google Images, Discover), Core Web Vitals (LCP), and accessibility. Consolidates image-related best practices from components (hero, trust-badges) and pages (landing-page). References: Google Image SEO, Semrush Image SEO.
When invoking: On first use, if helpful, open with 1–2 sentences on what this skill covers and why it matters, then provide the main output. On subsequent use or when the user asks to skip, go directly to the main output.
Scope
- Discovery & indexing: HTML img elements, image sitemap
Format & performance: WebP, responsive images, lazy loading, LCP; full CWV optimization in core-web-vitals
Metadata: Alt text, file names, captions
Preferred image: primaryImageOfPage, og:image; thumbnail next to title/description in search results
Structured data: ImageObject, image in Article/Product/etc.
Initial Assessment
Check for project context first: If .claude/project-context.md or .cursor/project-context.md exists, read it for brand and page context.
Identify:
1. Context: Hero, content page, product, trust badge, social preview
Above vs below fold: LCP candidate (hero) vs lazy-loadable
Image count: Single hero vs gallery, programmatic pages
1. Discovery & Indexing
Use HTML Image Elements
Google finds images in the src attribute of <img> (including inside <picture>). CSS background images are not indexed.
Do
Don't
INLINECODE5
INLINECODE6
Image Sitemap
Submit an image sitemap to help Google discover images it might otherwise miss. Image sitemaps can include URLs from CDNs (other domains); verify CDN domain in Search Console for crawl error reporting.
Structure (from Google):
CODEBLOCK0
See xml-sitemap for sitemap index and submission. Image sitemap is an extension; can be standalone or combined with page sitemap.
2. Format & Performance
Supported Formats
Google supports: BMP, GIF, JPEG, PNG, WebP, SVG, AVIF. Match filename extension to format.
Modern browsers | Even smaller than WebP; check support |
| JPEG | Standard photos | Fallback; widely supported |
| PNG | Transparency, detail | Larger; use when needed |
| SVG | Icons, logos | Scalable; use <title> for inline SVG alt |
| GIF | Simple animation | First frame only for preview |
Responsive Images
Use <picture> or srcset for different screen sizes. Always provide fallback src—some crawlers don't understand srcset.
CODEBLOCK1
Picture element (format fallback, e.g. WebP → PNG):
CODEBLOCK2
Data URI (Inline Images)
Base64 data URIs (data:image/...;base64,...) reduce HTTP requests but increase HTML size. Use sparingly for small icons; avoid for large images. See web.dev.
Resize & Compress
- Max width: Generally ≤2,500px; match container max-width
Compression: WebP preferred; quality 75–85 for lossy; 72dpi for web
LCP: Hero/above-fold images are LCP candidates; optimize aggressively
Lazy Loading
Use loading="lazy"only for below-fold images. Above-fold images (hero) must load immediately—lazy loading them hurts LCP.
CODEBLOCK3
3. Alt Text
Alt text improves accessibility (screen readers, low bandwidth) and SEO (Google uses it with computer vision to understand images). It also serves as anchor text if the image is a link.
Best Practices
Do
Don't
Useful, information-rich description
Keyword stuffing
Context of page content
"image of" or "photo of" (redundant) |
| Max ~125 characters (some assistive tech truncates) | Empty alt on meaningful images |
| Descriptive for functional images | Alt on purely decorative images (use alt="") |
Examples (from Google):
- ❌ Missing: INLINECODE14
❌ Stuffing: INLINECODE15
✅ Better: INLINECODE16
✅ Best: INLINECODE17
Captions
Google extracts image context from captions and nearby text. Use <figcaption> or descriptive text near the image.
Images near answers with captions can capture thumbnail slots; see featured-snippet |
| Image Pack | Alt + caption + file name help Image Pack display; see serp-features |
Inline SVG
Use <title> inside SVG for accessibility:
CODEBLOCK4
4. File Names
Descriptive filenames give Google light clues about subject matter.
Do
Don't
INLINECODE20
INLINECODE21
Short, hyphen-separated
Generic: image1.jpg, pic.gif |
| Localize filenames for translated pages | Overly long filenames |
5. Preferred Image (SERP Thumbnail & Discover)
When users search for keywords, optimized images can appear as thumbnails next to the page title and description in search results—enhancing visibility and CTR. Google also uses these images for Google Discover. Search Engine Land
Google selects thumbnails automatically from multiple sources. Influence selection via:
Schema: primaryImageOfPage
CODEBLOCK5
Or attach image to main entity (e.g. BlogPosting, Article) via mainEntity or mainEntityOfPage.
Open Graph
CODEBLOCK6
Preferred image rules: Relevant, representative; avoid generic (e.g. logo) or text-heavy images; avoid extreme aspect ratios; high resolution. See open-graph, twitter-cards for social specs.
Google Discover (if targeting Discover): ≥1200px wide; ≥300KB; 16:9 aspect ratio preferred; important content visible in landscape crop.
6. Page Context
- Title & meta description: Google uses page title and meta for image result snippets. See title-tag, meta-description.
Placement: Put images near relevant text; page subject matter influences image indexing.
Same URL: Reference the same image with the same URL across pages for cache efficiency and crawl budget.
7. Structured Data
Add structured data for rich results in Google Images (badges, extra info). Image attribute is required for eligibility. See schema-markup for ImageObject, Article, Product, Recipe, etc.
8. Specs by Context
Context
Priority
Notes
Hero
LCP, alt, no lazy
See hero-generator; above-fold, fast load
Article / Blog hero
1200–1600px wide; proportional height; 1200×630 for og:image | Same image for Schema, Open Graph, Twitter Cards; under 200 KB; WebP preferred; descriptive alt; set width/height to prevent CLS; use srcset/sizes for responsive; articles with relevant images get ~94% more views |
| Trust badges | Alt text | See trust-badges-generator; e.g. "Norton Secured" |
| Landing page | All above | See landing-page-generator Pre-Delivery Checklist |
| OG / Twitter | 1200×630, 1200×675 | See open-graph, twitter-cards |
| Platforms | Per-platform | X, LinkedIn, Pinterest—see platform skills |
9. Opt-Out & SafeSearch
- Inline linking opt-out: Prevent full-sized image display in Google Images via HTTP referrer check (200 or 204). See Google docs.
SafeSearch: Label pages for explicit content if applicable.