Accessibility
· 13 checks — Landmarks, headings, alt text, forms, and link quality rolled into one auditable list.DHeading HierarchyAction17 headings, 2 skip(s)FIX
- H3 Features
- H5 Calling skipped
- H5 Messaging
- H5 Groups
- H5 Channels
- H5 Meta AI
- H5 Status
- H5 Security
- H3 (empty)
- H4 WhatsApp Invite
- H4 Don't have the app?
- H4 Download it now
- H2 Looks like you don't have WhatsApp installed!
- H4 What we do skipped
- H4 Who we are
- H4 Use WhatsApp
- H4 Need help?
Every page should have one H1 that describes the page content.
No H1 means screen-reader users can't identify the page's primary topic, and Google's content-extraction degrades.
Learn more ▾ ▴
The H1 is the document title for assistive tech and a strong signal to search engines about page topic. Pages without one force screen readers to fall back to the <title> attribute or page chrome. Add a single H1 that names the page's primary subject.
Source: WCAG 2.4.6 / Google Search Central
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
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
Empty headings appear in the document outline but provide no information.
Empty <hN> tags break the document outline — screen-reader users navigating by heading hit dead silence.
Source: WCAG 2.4.6
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.
FFavicon & BrandingAction2 icon(s) detectedFIX
FWeb ManifestActionInvalid JSONFIX
Manifest contains invalid JSON.
DDark Mode SupportActionNo dark mode signalsFIX
Detection limited to meta tags and inline styles.
DPrint StylesheetActionNo print stylesFIX
CLandmark StructureAction4 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
Multiple navigations need aria-label to distinguish them for screen readers.
Some <nav> elements lack aria-label — screen-reader users hear 'navigation' multiple times with no way to distinguish them.
Learn more ▾ ▴
When a page has multiple <nav> regions (primary, footer, breadcrumb), each needs aria-label or aria-labelledby. AT users navigate by landmark; identical 'navigation' announcements force them to enter each one to discover purpose.
Source: WAI-ARIA Authoring Practices
CLink & Button QualityAction2 issue(s) across 78 links and 4 buttonsREVIEW
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| https://x.com/whatsapp | x link | new tab | Add '(opens in new tab)' to text |
| https://www.youtube.com/channel/UCAuerig… | youtube link | new tab | Add '(opens in new tab)' to text |
| https://www.instagram.com/whatsapp/?hl=e… | Instagram link | new tab | Add '(opens in new tab)' to text |
| https://www.facebook.com/profile.php?id=… | facebook link | new tab | Add '(opens in new tab)' to text |
| https://www.whatsapp.com/legal/ | WhatsApp legal policies | new tab | Add '(opens in new tab)' to text |
| https://web.whatsapp.com/accept?code=&ut… | Continue to WhatsApp Web | new tab | Add '(opens in new tab)' to text |
| https://web.whatsapp.com/accept?code=&ut… | Continue to WhatsApp Web | new tab | Add '(opens in new tab)' to text |
| https://x.com/whatsapp | new tab | Add '(opens in new tab)' to text | |
| https://www.youtube.com/channel/UCAuerig… | Youtube | new tab | Add '(opens in new tab)' to text |
| https://www.instagram.com/whatsapp/?hl=e… | new tab | Add '(opens in new tab)' to text | |
| https://www.facebook.com/profile.php?id=… | new tab | Add '(opens in new tab)' to text | |
| https://www.metacareers.com/jobs?divisio… | Careers | new tab | Add '(opens in new tab)' to text |
| https://www.facebook.com/brand/resources… | Visit WhatsApp's brand center | new tab | Add '(opens in new tab)' to text |
| https://x.com/whatsapp | new tab | Add '(opens in new tab)' to text | |
| https://www.youtube.com/channel/UCAuerig… | Youtube | new tab | Add '(opens in new tab)' to text |
| https://www.instagram.com/whatsapp/?hl=e… | new tab | Add '(opens in new tab)' to text | |
| https://www.facebook.com/profile.php?id=… | new tab | Add '(opens in new tab)' to text | |
| https://x.com/whatsapp | new tab | Add '(opens in new tab)' to text | |
| https://www.youtube.com/channel/UCAuerig… | Youtube | new tab | Add '(opens in new tab)' to text |
| https://www.instagram.com/whatsapp/?hl=e… | new tab | Add '(opens in new tab)' to text | |
| https://www.facebook.com/profile.php?id=… | new tab | Add '(opens in new tab)' to text | |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
Add '(opens in new tab)' to link text or aria-label.
https://x.com/whatsapp; https://www.youtube.com/channel/UCAuerig2N-RZWJT8x75V9yw; https://www.instagram.com/whatsapp/?hl=en; https://www.facebook.com/profile.php?id=100064758844406; https://www.whatsapp.com/legal/; https://web.whatsapp.com/accept?code=&utm_campaign=wa_chat_v2; https://web.whatsapp.com/accept?code=&utm_campaign=wa_chat_v2; https://x.com/whatsapp; https://www.youtube.com/channel/UCAuerig2N-RZWJT8x75V9yw; https://www.instagram.com/whatsapp/?hl=en (+11 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
Icon-only buttons need an aria-label so screen readers can announce them.
button#u_0_2_da; button#u_0_4_8C
Buttons with no accessible text (icon-only, no aria-label) can't be activated by voice control or understood by screen readers.
Source: WCAG 2.1 SC 4.1.2
CColor Contrast (Screenshot)Action20 text elements analyzed, 5 fail WCAG AAREVIEW
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 |
|---|---|---|---|---|---|
| h2 Looks like you don't… | 1.20:1 | 3.0:1 | #000000 | #111B21 | Fail |
| h3 Features | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| title WhatsApp Invite | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Skip to content | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Home | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Apps | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Calling | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Messaging | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Groups | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Status | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Channels | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Meta AI | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Security | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Privacy | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Help Center | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Blog | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span For Business | 1.20:1 | 4.5:1 | #000000 | #111B21 | Fail |
| span Download | 1.20:1 | 4.5:1 | #000000 | #111B21 | Fail |
| span Terms & Privacy Poli… | 1.20:1 | 4.5:1 | #000000 | #111B21 | Fail |
| div 2026 © WhatsApp LLC | 1.20:1 | 4.5:1 | #000000 | #111B21 | Fail |
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.
BLighthouse Accessibility AuditsScore 81/100 — 6 failing, 22 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.
Names and labels
When a button doesn't have an accessible name, screen readers announce it as "button", making it unusable for users who rely on screen readers. Learn how to make buttons more accessible.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
div._afvx > div._afvy > div._af8g > button#u_0_2_VP div._afvx > div._afvy > div._af8g > button#u_0_2_VP |
Informative elements should aim for short, descriptive alternate text. Decorative elements can be ignored with an empty alt attribute. Learn more about the `alt` attribute.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
div#main_block > a#action-icon > span._advp > img._9vx6 div#main_block > a#action-icon > span._advp > img._9vx6 |
These are opportunities to improve the semantics of the controls in your application. This may enhance the experience for users of assistive technology, like a screen reader.
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 |
|---|
Join Chat div#main_block > div > a#action-button > span._advp |
Download div > h4._9vd5 > a._9vcv > span._advp |
These are opportunities to improve the legibility of your content.
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 |
|---|
Sitemap span._aeom > div._9tar > span > a._asnw |
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#facebook html#facebook |
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 |
|---|
Join Chat div._9vd6 > div#main_block > div > a#action-button |
Download div#main_block > div > h4._9vd5 > a._9vcv |
Download footer._9t2i > div._9tar > span._ae_s > a._aeo8 |
About us div._9t2j > div._9tar > div._9vd6 > a._asnw |
Contact Us div._9t2j > div._9tar > div._9vd6 > a#contact_us_link_footer |
Apps div._9t2j > div._9tar > div._9vd6 > a._asnw |
Terms & Privacy Policy div._9t2m > span._aeom > div._9tar > a._9vcv |
A+Alt Text QualityAll 4 images OKPASS
A+Form AccessibilityAll 4 controls labeledPASS
| Control | Type | Label | Method |
|---|---|---|---|
| #u_0_6_L6 | select | Select your preferred language | aria-label |
| #u_0_7_Ke | select | Select your preferred language | aria-label |
| #u_0_a_dW | select | Select your preferred language | aria-label |
| #u_0_b_BY | select | Select your preferred language | aria-label |