Accessibility
· 13 checks — Landmarks, headings, alt text, forms, and link quality rolled into one auditable list.F404 Error PageActionSoft 404 detectedFIX
The server returned HTTP 200 for a non-existent path. Search engines will index this page as real content. Configure your server to return HTTP 404 for missing pages.
FWeb ManifestActionInvalid JSONFIX
Manifest contains invalid JSON.
DPrint StylesheetActionNo print stylesFIX
BLandmark Structure4 landmarksREVIEW
Screen reader users cannot quickly navigate to the primary content. Wrap your main content in <main>.
Without a <main> landmark, screen-reader users can't skip past the navigation to the page content — every page starts with re-reading the menu.
Learn more ▾ ▴
The <main> element marks the page's primary content area. Assistive tech offers a 'jump to main' shortcut — but only if <main> exists. Without it, every page navigation forces re-reading the header. Wrap your primary content in a single <main>.
Source: WAI-ARIA / WCAG 2.4.1
CLink & Button QualityAction26 issue(s) across 161 links and 11 buttonsREVIEW
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| https://community.vercel.com/ | CommunityJoin the conversation | new tab | Add '(opens in new tab)' to text |
| /templates/ai | (empty) | empty | Add link text or aria-label |
| /templates/starter | (empty) | empty | Add link text or aria-label |
| /templates/ecommerce | (empty) | empty | Add link text or aria-label |
| /templates/saas | (empty) | empty | Add link text or aria-label |
| /templates/blog | (empty) | empty | Add link text or aria-label |
| /templates/portfolio | (empty) | empty | Add link text or aria-label |
| /templates/cms | (empty) | empty | Add link text or aria-label |
| /templates/backend | (empty) | empty | Add link text or aria-label |
| /templates/edge-functions | (empty) | empty | Add link text or aria-label |
| /templates/edge-middleware | (empty) | empty | Add link text or aria-label |
| /templates/edge-config | (empty) | empty | Add link text or aria-label |
| /templates/cron | (empty) | empty | Add link text or aria-label |
| /templates/multi-tenant-apps | (empty) | empty | Add link text or aria-label |
| /templates/realtime-apps | (empty) | empty | Add link text or aria-label |
| /templates/documentation | (empty) | empty | Add link text or aria-label |
| /templates/virtual-event | (empty) | empty | Add link text or aria-label |
| /templates/monorepos | (empty) | empty | Add link text or aria-label |
| /templates/web3 | (empty) | empty | Add link text or aria-label |
| /templates/vercel-firewall | (empty) | empty | Add link text or aria-label |
| /templates/microfrontends | (empty) | empty | Add link text or aria-label |
| /templates/authentication | (empty) | empty | Add link text or aria-label |
| /templates/marketing-sites | (empty) | empty | Add link text or aria-label |
| /templates/cdn | (empty) | empty | Add link text or aria-label |
| /templates/admin-dashboard | (empty) | empty | Add link text or aria-label |
| /templates/security | (empty) | empty | Add link text or aria-label |
| https://v0.app | v0 | new tab | Add '(opens in new tab)' to text |
| https://community.vercel.com | Community | new tab | Add '(opens in new tab)' to text |
| https://ai-sdk.dev | AI SDK | new tab | Add '(opens in new tab)' to text |
| https://useworkflow.dev | Workflow SDKNew | new tab | Add '(opens in new tab)' to text |
| https://flags-sdk.dev | Flags SDK | new tab | Add '(opens in new tab)' to text |
| https://chat-sdk.dev | Chat SDK | new tab | Add '(opens in new tab)' to text |
| https://streamdown.ai | Streamdown AINew | new tab | Add '(opens in new tab)' to text |
| https://github.com/vercel | GitHub | new tab | Add '(opens in new tab)' to text |
| https://linkedin.com/company/vercel | new tab | Add '(opens in new tab)' to text | |
| https://x.com/vercel | X | new tab | Add '(opens in new tab)' to text |
| https://youtube.com/@VercelHQ | YouTube | new tab | Add '(opens in new tab)' to text |
| /home | (empty) | empty | Add link text or aria-label |
| https://vercel-status.com | Loading status… | new tab | Add '(opens in new tab)' to text |
Links without text are announced as raw URLs by screen readers.
/templates/ai; /templates/starter; /templates/ecommerce; /templates/saas; /templates/blog; /templates/portfolio; /templates/cms; /templates/backend; /templates/edge-functions; /templates/edge-middleware (+16 more)
Links with no accessible text (empty <a></a>, image-only no alt, icon-only no aria-label) are unidentifiable to screen readers.
Source: WCAG 2.1 SC 2.4.4
Add '(opens in new tab)' to link text or aria-label.
https://community.vercel.com/; https://v0.app; https://community.vercel.com; https://ai-sdk.dev; https://useworkflow.dev; https://flags-sdk.dev; https://chat-sdk.dev; https://streamdown.ai; https://github.com/vercel; https://linkedin.com/company/vercel (+3 more)
Links with target="_blank" without rel="noopener" leak the originating page's window context — security and UX issue.
Learn more ▾ ▴
Without rel="noopener", the new tab can navigate the original tab via window.opener (tab-nabbing attack). Modern browsers default to noopener for target=_blank but only since recent versions. Always set rel="noopener noreferrer" explicitly.
Source: MDN target / OWASP
BFavicon & Branding10 icon(s) detectedREVIEW
BLighthouse Accessibility AuditsScore 84/100 — 5 failing, 21 passedREVIEW
Accessibility
These checks highlight opportunities to improve the accessibility of your web app. Automatic detection can only detect a subset of issues and does not guarantee the accessibility of your web app, so manual testing is also encouraged.
Contrast
Low-contrast text is difficult or impossible for many users to read. Learn how to provide sufficient color contrast.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
Get started with Next.js and React in seconds. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
An image gallery built on Next.js and Cloudinary. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Simple, powerful and flexible markdown-powered docs site. Built with Next.js. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Deploy Hono backends using the Bun runtime. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
This template creates a voice chat using Hume AI's Empathic Voice Interface. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Starter kit for high-performance commerce with Shopify. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
An inbound lead qualification and research agent built with Next.js, AI SDK, Wo… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Examples of many Next.js App Router features. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Easily create a portfolio with Next.js and Markdown. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
An Incremental Static Regeneration Blog Example Using Next.js and WordPress div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Enterprise-grade Next.js boilerplate built with Tailwind CSS, Radix UI, TypeScr… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A statically generated blog example using Next.js and Markdown. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A blog template with Next.js 13 App Router, Contentlayer, Tailwind CSS and dark… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Use a Large Language Model to summarize customer feedback. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A Nuxt.js 3 app, bootstrapped with create-nuxt-app. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
An AI chatbot template to build your own chatbot powered by Nuxt MDC and Vercel… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
AI answer engine with Generative UI. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A personal website built with Next.js and Sanity featuring visual editing, live… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A clean Next.js + Sanity starter with visual editing, drag-and-drop page builde… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A Next.js starter chatbot using Vercel's AI SDK and implements the Retrieval-Au… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
Real-time collaborative product starter kit built with Next.js and Liveblocks div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A link-in-bio SaaS built with Nuxt.js, where the data lives in the URL – no dat… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
The all-in-one subscription starter kit for high-performance SaaS applications,… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
QrGPT is an AI tool for you to generate beautiful QR codes using AI with one cl… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A SvelteKit app including nested routes, layouts, and page endpoints. div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
A Next.js App Router template configured with cookie-based auth using Supabase,… div.mt-20 > a.link-module__Q1NRQq__link > div.flex > div.text-label-14 |
These are opportunities to improve the legibility of your content.
Navigation
Properly ordered headings that do not skip levels convey the semantic structure of the page, making it easier to navigate and understand when using assistive technologies. Learn more about heading order.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
Next.js Boilerplate a.link-module__Q1NRQq__link > div.flex > div.flex > h3.text-heading-16 |
These are opportunities to improve keyboard navigation in your application.
Tables and lists
Screen readers have a specific way of announcing lists. Ensuring proper list structure aids screen reader output. Learn more about proper list structure.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
Vercel logo nav > div.grid > div > ul.list-none |
These are opportunities to improve the experience of reading tabular or list data using assistive technology, like a screen reader.
Best practices
Disabling zooming is problematic for users with low vision who rely on screen magnification to properly see the contents of a web page. Learn more about the viewport meta tag.
Informational: a Permissions-Policy directive showing feature -> allowed origins.
Source: MDN Permissions-Policy
| Failing Elements |
|---|
head > meta head > meta |
One main landmark helps screen reader users navigate a web page. Learn more about landmarks.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
html.geist_mono_98cac566-module__bcNCwW__className html.geist_mono_98cac566-module__bcNCwW__className |
These items highlight common accessibility best practices.
AHeading Hierarchy59 headings, 1 skip(s)PASS
- H5 AI Cloud
- H5 Core Platform
- H5 Security
- H5 Company
- H5 Learn
- H5 Open Source
- H5 Use Cases
- H5 Tools
- H5 Users
- H1 Find your Template
- H4 Filter Templates skipped
- H4 Use Case
- H4 Framework
- H4 CSS
- H4 Database
- H4 CMS
- H4 Authentication
- H4 Experimentation
- H3 Next.js Boilerplate
- H3 Image Gallery Starter
- H3 Chatbot
- H3 Nextra: Docs Starter Kit
- H3 Express on Bun
- H3 Hono on Bun
- H3 Hume AI - Empathic Voice Interface Starter
- H3 Next.js Commerce
- H3 Lead Agent
- H3 Next.js App Router Playground
- H3 Platforms Starter Kit
- H3 Portfolio Starter Kit
- H3 Slack Agent Template
- H3 ISR Blog with Next.js and WordPress
- H3 Next.js Enterprise Boilerplate
- H3 Blog Starter Kit
- H3 Next.js Contentlayer Blog Starter
- H3 Customer Reviews AI Summary
- H3 Nuxt.js 3 Boilerplate
- H3 Nuxt AI Chatbot
- H3 Morphic: AI-powered answer engine
- H3 Sanity + Next.js Personal Website
- H3 Sanity + Next.js Clean App
- H3 Pinecone - Vercel AI SDK Starter
- H3 Liveblocks Starter Kit
- H3 Onelink
- H3 Stripe Subscription Starter
- H3 qrGPT – AI QR Code Generator
- H3 SvelteKit Boilerplate
- H3 Supabase Starter
- H2 Get Started
- H2 Build
- H2 Scale
- H2 Secure
- H2 Resources
- H2 Learn
- H2 Frameworks
- H2 SDKs
- H2 Use Cases
- H2 Company
- H2 Community
Skipping heading levels breaks the document outline. Screen readers may interpret missing levels as structural errors.
Skipping heading levels breaks the document outline — screen-reader users lose track of section nesting.
Learn more ▾ ▴
Screen reader users navigate by jumping between headings (H1 → H2 → H3). Skipping (H1 → H3) breaks the sense of hierarchy. Use sequential levels even if you don't like the default styling — restyle with CSS instead. WCAG 1.3.1 (Info and Relationships) treats this as an A failure.
Source: WCAG 2.1 SC 1.3.1 / W3C WAI
A+Alt Text QualityAll 32 images OKPASS
A+Form AccessibilityAll 29 controls labeledPASS
| Control | Type | Label | Method |
|---|---|---|---|
| #input-_R_1bfiram_ | search | Search | aria-label |
| #checkbox-_R_ccvfiram_ | checkbox | | none |
| #checkbox-_R_kcvfiram_ | checkbox | | none |
| #checkbox-_R_scvfiram_ | checkbox | | none |
| #checkbox-_R_14cvfiram_ | checkbox | | none |
| #checkbox-_R_1ccvfiram_ | checkbox | | none |
| #checkbox-_R_1kcvfiram_ | checkbox | | none |
| #checkbox-_R_1scvfiram_ | checkbox | | none |
| #checkbox-_R_24cvfiram_ | checkbox | | none |
| #checkbox-_R_2ccvfiram_ | checkbox | | none |
| #checkbox-_R_2kcvfiram_ | checkbox | | none |
| #checkbox-_R_2scvfiram_ | checkbox | | none |
| #checkbox-_R_34cvfiram_ | checkbox | | none |
| #checkbox-_R_3ccvfiram_ | checkbox | | none |
| #checkbox-_R_3kcvfiram_ | checkbox | | none |
| #checkbox-_R_3scvfiram_ | checkbox | | none |
| #checkbox-_R_44cvfiram_ | checkbox | | none |
| #checkbox-_R_4ccvfiram_ | checkbox | | none |
| #checkbox-_R_4kcvfiram_ | checkbox | | none |
| #checkbox-_R_4scvfiram_ | checkbox | | none |
| #checkbox-_R_54cvfiram_ | checkbox | | none |
| #checkbox-_R_5ccvfiram_ | checkbox | | none |
| #checkbox-_R_5kcvfiram_ | checkbox | | none |
| #checkbox-_R_5scvfiram_ | checkbox | | none |
| #checkbox-_R_64cvfiram_ | checkbox | | none |
| #checkbox-_R_6ccvfiram_ | checkbox | | none |
| #theme-switch-system-_R_aniram_ | radio | system | aria-label |
| #theme-switch-light-_R_aniram_ | radio | light | aria-label |
| #theme-switch-dark-_R_aniram_ | radio | dark | aria-label |
A+Dark Mode SupportFull dark mode supportPASS
Detection limited to meta tags and inline styles.
A+Color Contrast (Screenshot)20 text elements analyzed, 0 fail WCAG AAPASS
Analyzes text contrast against the actual rendered page, including background images, gradients, and overlays that CSS-based tools cannot detect.
Show all checked elements (20)
| Element | Ratio | Required | FG | BG | Result |
|---|---|---|---|---|---|
| h1 Find your Template | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Get Started | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Build | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Scale | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Secure | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Resources | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Learn | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Frameworks | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 SDKs | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Use Cases | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Company | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Community | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Next.js Boilerplate | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Image Gallery Starte… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Chatbot | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Nextra: Docs Starter… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Express on Bun | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Hono on Bun | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Hume AI - Empathic V… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Next.js Commerce | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
Methodology: The top 20 text elements by font size were checked. Background color was sampled from the desktop screenshot using a 5-point pattern. WCAG 2.1 AA requires 4.5:1 for normal text and 3:1 for large text.