Accessibility
· 20 checks — Landmarks, headings, alt text, forms, and link quality rolled into one auditable list.DMobile Keyboard & AutofillAction2/2 eligible field(s) missing autocomplete or inputmodeFIX
FFavicon & BrandingAction2 icon(s) detectedFIX
DWeb ManifestActionNot foundFIX
No web manifest found.
DPrint StylesheetActionNo print stylesFIX
BLandmark Structure5 landmarksREVIEW
A page should have only one <main> landmark.
Multiple <main> elements violate the spec — there must be exactly one per page.
Learn more ▾ ▴
HTML5 spec: 'authors must not include more than one main element' visible to AT at the same time. Multiple <main>s confuse AT and break the 'jump to main content' shortcut. Refactor to a single <main> with nested <section>/<article>.
Source: HTML5 spec
The skip-link anchor (e.g., `href="#main"`) points at an ID that has no corresponding element on the page. Activating the link does nothing -- a silent WCAG 2.4.1 failure that the visual link presence hides. Add `id="main"` (or whichever matches the href) to the target landmark.
Skip link points at an ID that doesn't exist on the page. The link looks fine visually but does nothing when activated -- silent WCAG 2.4.1 failure.
Learn more ▾ ▴
Find the target landmark (typically <main> or the first <h1>) and add `id="..."` matching the skip link's href fragment. Test by tabbing to the skip link and pressing Enter -- focus should jump to the target.
Source: WCAG 2.1 SC 2.4.1
BTap Target Adequacy3 tap target(s) too small or too close togetherREVIEW
C404 Error PageActionHTTP 404, custom pageREVIEW
BDark Mode SupportDark mode detectedREVIEW
Detection limited to meta tags and inline styles.
A+Heading Hierarchy14 headingsPASS
- H1 The React Framework for the Web
- H2 What's in Next.js?
- H2 Built on a foundation of fast, production-grade tooling
- H2 Get started in seconds
- H2 The framework of choice when it matters
- H2 Customer Testimonials
- H3 “With Next.js, we now consistently average 0.09 or lower for Cumulative Layout Shift, placing our site in the top tier for user experience and Core Web Vitals.”
- H3 “Our UI for Frame.io responds to user input within 100ms and all animations run at a consistent 60fps with Next.js.”
- H3 “Next.js has been a game-changer for our agency work and team collaboration. Its powerful features have allowed us to build high-performance websites quickly and efficiently like never before.”
- H4 Resources
- H4 More
- H4 About Vercel
- H4 Legal
- H4 Subscribe to our newsletter
A+Alt Text QualityAll 45 images OKPASS
A+Form AccessibilityAll 1 controls labeledPASS
| Control | Type | Label | Method |
|---|---|---|---|
| Enter your email | aria-label |
ALink & Button Quality97 links, 10 buttons — all OKPASS
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| https://vercel.com/home?utm_source=next-… | Go to Vercel homepage | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/home?utm_source=next-… | Go to Vercel homepage | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/templates/next.js?utm… | Templates | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/contact/sales/nextjs?… | Enterprise | new tab | Add '(opens in new tab)' to text |
| https://react.dev | ReactThe library for web and n… | new tab | Add '(opens in new tab)' to text |
| https://nextjs.org/docs/app/api-referenc… | TurbopackAn incremental bundle… | new tab | Add '(opens in new tab)' to text |
| https://swc.rs | Speedy Web CompilerAn extensib… | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/templates/next.js?utm… | Deploy a Template on Vercel | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/home?utm_source=next-… | Vercel logo | new tab | Add '(opens in new tab)' to text |
| https://github.com/vercel/next.js | GitHub | new tab | Add '(opens in new tab)' to text |
| https://x.com/nextjs | X | new tab | Add '(opens in new tab)' to text |
| https://bsky.app/profile/nextjs.org | Bluesky | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/analytics?utm_source=… | Analytics | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/products/previews?utm… | Previews | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/templates/next.js/nex… | Next.js Commerce | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/contact/sales?utm_sou… | Contact Sales | new tab | Add '(opens in new tab)' to text |
| https://community.vercel.com | Community | new tab | Add '(opens in new tab)' to text |
| https://github.com/vercel/next.js | GitHub | new tab | Add '(opens in new tab)' to text |
| https://github.com/vercel/next.js/releas… | Releases | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/solutions/nextjs?utm_… | Next.js + Vercel | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/oss?utm_source=next-s… | Open Source Software | new tab | Add '(opens in new tab)' to text |
| https://github.com/vercel | GitHub | new tab | Add '(opens in new tab)' to text |
| https://bsky.app/profile/vercel.com | Bluesky | new tab | Add '(opens in new tab)' to text |
| https://x.com/vercel | X | new tab | Add '(opens in new tab)' to text |
| https://vercel.com/legal/privacy-policy | Privacy Policy | new tab | Add '(opens in new tab)' to text |
| https://github.com/vercel/next.js | GitHub | new tab | Add '(opens in new tab)' to text |
| https://x.com/nextjs | new tab | Add '(opens in new tab)' to text | |
| https://bsky.app/profile/nextjs.org | Bluesky | new tab | Add '(opens in new tab)' to text |
Add '(opens in new tab)' to link text or aria-label.
https://vercel.com/home?utm_source=next-site&utm_medium=banner&utm_campaign=h…; https://vercel.com/home?utm_source=next-site&utm_medium=banner&utm_campaign=h…; https://vercel.com/templates/next.js?utm_source=next-site&utm_medium=navbar&u…; https://vercel.com/contact/sales/nextjs?utm_source=next-site&utm_medium=navba…; https://react.dev; https://nextjs.org/docs/app/api-reference/turbopack; https://swc.rs; https://vercel.com/templates/next.js?utm_source=next-site&utm_medium=deploy-t…; https://vercel.com/home?utm_source=next-site&utm_medium=footer&utm_campaign=n…; https://github.com/vercel/next.js (+18 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
A+Form Input Types1 form control(s) checked, no type mismatchesPASS
A+Document LanguageLang attribute set to "en"PASS
A+Tabindex Anti-Patterns8 explicit tabindex attribute(s) checked, no anti-patternsPASS
A+Iframe AccessibilityNo iframes on this pagePASS
A+Mobile-Readable Font SizesAll 122 visible text node(s) render at >= 12 CSS pixelsPASS
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 The React Framework | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h1 for the Web | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 What's in Next.js? | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Built on a foundatio… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 production-grade too… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Get started in secon… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 The framework of cho… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 when it matters | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Customer Testimonial… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 With Next.js, we now… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Our UI for Frame.io … | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Next.js has been a g… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| title Next.js by Vercel - … | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Skip to content | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| button Search documentation… | 19.60:1 | 4.5:1 | #000000 | #F7F7F7 | Pass |
| button Search... | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| kbd ⌘K | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Showcase | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Docs | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Blog | 21.00:1 | 4.5: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.
A+Lighthouse Accessibility AuditsScore 96/100 — 2 failing, 24 passedPASS
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.
Best practices
Touch targets with sufficient size and spacing help users who may have difficulty targeting small controls to activate the targets. Learn more about touch targets.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
Switch to light theme footer.footer-module__rV1DKq__footer > div.flex > div.theme-switcher-module__R4aA1q__root > button.theme-switcher-module__R4aA1q__switch |
Switch to system theme footer.footer-module__rV1DKq__footer > div.flex > div.theme-switcher-module__R4aA1q__root > button.theme-switcher-module__R4aA1q__switch |
Switch to dark theme footer.footer-module__rV1DKq__footer > div.flex > div.theme-switcher-module__R4aA1q__root > button.theme-switcher-module__R4aA1q__switch |
These items highlight common accessibility best practices.
Visible text labels that do not match the accessible name can result in a confusing experience for screen reader users. Learn more about accessible names.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
▲ ~ npx create-next-app@latest div.intro-module__l-DIkW__intro > div.flex > div.flex > button.intro-module__l-DIkW__copy |
Built-in Optimizations
Automatic Image, Font, and Script Optimizations for impr… div.flex > div.features-module__KQTBcq__grid > div > a.features-module__KQTBcq__card |
Dynamic HTML Streaming
Instantly stream UI from the server, integrated with the… div.flex > div.features-module__KQTBcq__grid > div > a.features-module__KQTBcq__card |
React Server Components
Add components without sending additional client-side J… div.flex > div.features-module__KQTBcq__grid > div > a.features-module__KQTBcq__card |
Next.js 16
The power of full-stack to the frontend. Read the release notes. div.flex > div.features-module__KQTBcq__grid > div > a.features-module__KQTBcq__card |