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.
DPrint StylesheetActionNo print stylesFIX
BLandmark Structure2 landmarksREVIEW
Add a skip link as the first focusable element so keyboard users can bypass repeated navigation.
Without a skip-nav link, keyboard users tab through every nav item before reaching content — every page, every visit.
Learn more ▾ ▴
WCAG 2.4.1 (Bypass Blocks) requires a mechanism to skip past repeated content. The standard implementation is a 'Skip to main content' link that's the first focusable element, visually hidden until focused. Three lines of HTML + four of CSS.
Source: WCAG 2.1 SC 2.4.1
BHeading HierarchyNo headingsREVIEW
No headings found
Headings create the document outline for screen reader navigation.
Headings (H1-H6) create the document outline for screen reader navigation.
A page with zero headings is unnavigable by assistive tech and reads as one undifferentiated wall of text.
Learn more ▾ ▴
Screen reader users navigate by jumping between H1-H6 elements. A page with no headings has no skip targets — users have to read every word linearly. Adding a heading hierarchy (one H1, then H2 sections, optional H3 subsections) makes the page skimmable for both AT and human readers.
Source: WCAG 1.3.1 / W3C WAI
BFavicon & Branding7 icon(s) detectedREVIEW
BDark Mode SupportDark mode detectedREVIEW
Detection limited to meta tags and inline styles.
CColor Contrast (Screenshot)Action20 text elements analyzed, 4 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 |
|---|---|---|---|---|---|
| title X. It’s what’s h… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Did someone say … … | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| div X and its partners u… | 1.00:1 | 4.5:1 | #FFFFFF | #FFFFFF | Fail |
| span Show more about your… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Accept all cookies | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Refuse non-essential… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Happening now | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Join today. | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Sign up with Google | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Sign up with Apple | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Create account | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| div By signing up, you a… | 6.12:1 | 4.5:1 | #536471 | #FFFFFF | Pass |
| span Terms of Service | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| div and | 6.12:1 | 4.5:1 | #536471 | #FFFFFF | Pass |
| span Privacy Policy | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| div , including | 6.12:1 | 4.5:1 | #536471 | #FFFFFF | Pass |
| span Cookie Use. | 20.82:1 | 4.5:1 | #000000 | #FEFEFE | Pass |
| span Already have an acco… | 1.13:1 | 4.5:1 | #000000 | #0F1419 | Fail |
| span Sign in | 1.13:1 | 4.5:1 | #000000 | #0F1419 | Fail |
| span Get the app | 1.13:1 | 4.5:1 | #000000 | #0F1419 | 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 89/100 — 2 failing, 18 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 |
|---|
Terms of Service div.css-175oi2r > div.css-146c3p1 > a.css-1jxf684 > span.css-1jxf684 |
Cookie Use. div.css-175oi2r > div.css-146c3p1 > a.css-1jxf684 > span.css-1jxf684 |
These are opportunities to improve the legibility of your content.
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 |
These items highlight common accessibility best practices.
A+Alt Text QualityNo imagesPASS
A+Form AccessibilityNo form controlsPASS
ALink & Button Quality24 links, 5 buttons — all OKPASS
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| https://x.com/tos | Terms of Service | new tab | Add '(opens in new tab)' to text |
| https://x.com/privacy | Privacy Policy | new tab | Add '(opens in new tab)' to text |
| https://help.x.com/rules-and-policies/tw… | Cookie Use. | new tab | Add '(opens in new tab)' to text |
| https://x.com/download | Get the app | new tab | Add '(opens in new tab)' to text |
| https://about.x.com | About | new tab | Add '(opens in new tab)' to text |
| https://help.x.com/using-x/download-the-… | Download the X app | new tab | Add '(opens in new tab)' to text |
| https://grok.com/download | Grok | new tab | Add '(opens in new tab)' to text |
| https://help.x.com | Help Center | new tab | Add '(opens in new tab)' to text |
| https://x.com/tos | Terms of Service | new tab | Add '(opens in new tab)' to text |
| https://x.com/privacy | Privacy Policy | new tab | Add '(opens in new tab)' to text |
| https://support.x.com/articles/20170514 | Cookie Policy | new tab | Add '(opens in new tab)' to text |
| https://help.x.com/resources/accessibili… | Accessibility | new tab | Add '(opens in new tab)' to text |
| https://business.x.com/en/help/troublesh… | Ads info | new tab | Add '(opens in new tab)' to text |
| https://blog.x.com | Blog | new tab | Add '(opens in new tab)' to text |
| https://careers.x.com | Careers | new tab | Add '(opens in new tab)' to text |
| https://about.x.com/press/brand-assets | Brand Resources | new tab | Add '(opens in new tab)' to text |
| https://ads.x.com/?ref=gl-tw-tw-twitter-… | Advertising | new tab | Add '(opens in new tab)' to text |
| https://marketing.x.com | Marketing | new tab | Add '(opens in new tab)' to text |
| https://business.x.com/?ref=web-twc-ao-g… | X for Business | new tab | Add '(opens in new tab)' to text |
| https://developer.x.com | Developers | new tab | Add '(opens in new tab)' to text |
| https://x.com/i/jf/stories/home | News | new tab | Add '(opens in new tab)' to text |
Add '(opens in new tab)' to link text or aria-label.
https://x.com/tos; https://x.com/privacy; https://help.x.com/rules-and-policies/twitter-cookies; https://x.com/download; https://about.x.com; https://help.x.com/using-x/download-the-x-app; https://grok.com/download; https://help.x.com; https://x.com/tos; https://x.com/privacy (+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