Accessibility
· 13 checks — Landmarks, headings, alt text, forms, and link quality rolled into one auditable list.DDark Mode SupportActionTheme color onlyFIX
Detection limited to meta tags and inline styles.
BForm Accessibility2 of 15 controls have issuesREVIEW
| Control | Type | Label | Method |
|---|---|---|---|
| #footer-newsletter | Enter email | aria-label | |
| input | submit | none | |
| query | search | Enter search term… | aria-label |
| input | submit | none | |
| query | search | Enter search term… | aria-label |
| input | submit | none | |
| #login-email | for/id | ||
| #login-password | password | Password | for/id |
| #rememberme | checkbox | Remember me? | for/id |
| #register-email | for/id | ||
| #prosyn-economics-newsletter | checkbox | PS Economics Newsletter | for/id |
| #prosyn-ai-tech-newsletter | checkbox | PS AI & Tech Newsletter | for/id |
| #promotion_emails | checkbox | Marketing Communications & Updates | for/id |
| #login-button | submit | (none) | none |
| #register-button | submit | (none) | none |
Form controls need a <label>, aria-label, or aria-labelledby for screen readers.
<input type="submit" id="login-button">; <input type="submit" name="reg-button" id="register-button">
Form controls without labels — assistive tech announces 'edit text' with no context; users can't complete forms.
Source: WCAG 2.1 SC 3.3.2
BLink & Button Quality1 issue(s) across 307 links and 37 buttonsREVIEW
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| /magazines/ps-quarterly-1q2026-winners-l… | Learn more | generic text | Replace with descriptive text |
Before: Learn more Suggested: Ps Quarterly 1q2026 Winners Losers | |||
| https://www.facebook.com/projectsyndicat… | new tab | Add '(opens in new tab)' to text | |
| https://twitter.com/prosyn | X | new tab | Add '(opens in new tab)' to text |
| https://www.linkedin.com/company/project… | new tab | Add '(opens in new tab)' to text | |
| https://www.youtube.com/user/ProjectSynd… | YouTube | new tab | Add '(opens in new tab)' to text |
| https://twitter.com/prosyn | X | new tab | Add '(opens in new tab)' to text |
| https://www.facebook.com/projectsyndicat… | new tab | Add '(opens in new tab)' to text | |
| https://www.youtube.com/user/ProjectSynd… | YouTube | new tab | Add '(opens in new tab)' to text |
| https://www.linkedin.com/company/project… | new tab | Add '(opens in new tab)' to text | |
Generic link text like 'click here' doesn't describe the destination.
/magazines/ps-quarterly-1q2026-winners-losers ("Learn more")
Generic anchor text ('click here', 'read more', 'learn more') tells screen readers and search engines nothing about the destination.
Learn more ▾ ▴
Out-of-context lists of links read by AT (one navigation pattern) become useless when every link says 'click here'. Use the destination's title or topic as anchor text. Doubles as SEO win — Google passes anchor-text relevance to the destination.
Source: WCAG 2.4.4 / Google Search Central
Add '(opens in new tab)' to link text or aria-label.
https://www.facebook.com/projectsyndicate; https://twitter.com/prosyn; https://www.linkedin.com/company/project-syndicate; https://www.youtube.com/user/ProjectSyndicate; https://twitter.com/prosyn; https://www.facebook.com/projectsyndicate; https://www.youtube.com/user/ProjectSyndicate; https://www.linkedin.com/company/project-syndicate
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
BWeb ManifestValid manifestREVIEW
CColor Contrast (Screenshot)Action20 text elements analyzed, 19 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 |
|---|---|---|---|---|---|
| h1 YOUR CHOICES REGARDI… | 6.92:1 | 3.0:1 | #000000 | #949493 | Pass |
| h1 PS - The World's Opi… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Decoupling and South… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Is a Perfect Financi… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Will AI Solve Rich C… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Does Private-Credit … | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Escaping the IMF Aus… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 American Jews’ Net… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Morocco’s New Mode… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 The Risky Geography … | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 The Origins and Fate… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Secure your copy of | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 – and save $25 | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Trump’s Self-Defea… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 The World After Trum… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 The Geopolitics of I… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 The Private Credit P… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Is a Perfect Financi… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Morocco’s New Mode… | 1.66:1 | 3.0:1 | #000000 | #333333 | Fail |
| h2 Does Private-Credit … | 1.66:1 | 3.0:1 | #000000 | #333333 | 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.
ARIA
ARIA dialog elements without accessible names may prevent screen readers users from discerning the purpose of these elements. Learn how to make ARIA dialog elements more accessible.
Informational: a Permissions-Policy directive showing feature -> allowed origins.
Source: MDN Permissions-Policy
| Failing Elements |
|---|
As the US and China surge ahead in AI, can Europe keep up? Don’t miss our next … body > dialog#message-dialog |
These are opportunities to improve the usage of ARIA in your application which may enhance the experience for users of assistive technology, like a screen reader.
Names and labels
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 |
|---|
dialog#message-dialog > div.dialog__content > figure > img dialog#message-dialog > div.dialog__content > figure > img |
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.
ALandmark Structure17 landmarksPASS
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
AHeading Hierarchy66 headingsPASS
- H1 YOUR CHOICES REGARDING COOKIES ON THIS SITE
- H1 PS - The World's Opinion Page duplicate H1
- H2 Decoupling and South Korea’s New Capitalism
- H3 Further reading
- H2 Is a Perfect Financial Storm Gathering?
- H3 Further reading
- H2 Will AI Solve Rich Countries’ Debt Woes?
- H3 Further reading
- H2 Does Private-Credit Smoke Mean Financial Fire?
- H3 Further reading
- H2 Escaping the IMF Austerity Trap
- H3 Further reading
- H2 American Jews’ Netanyahu Problem
- H3 Further reading
- H2 Morocco’s New Model Economy
- H3 Further reading
- H2 The Risky Geography of the Cloud
- H3 Further reading
- H2 The Origins and Fate of Digital Sovereignty
- H3 Further reading
- H2 Secure your copy of PS Quarterly: Winners & Losers – and save $25
- H2 Trump’s Self-Defeating Attacks on the Fed
- H2 The World After Trump
- H2 The Geopolitics of Infrastructure
- H2 The Private Credit Panic Is Overblown
- H3 PS Quarterly
- H2 Latest
- H2 Is a Perfect Financial Storm Gathering?
- H2 Morocco’s New Model Economy
- H2 Does Private-Credit Smoke Mean Financial Fire?
- H2 Will AI Solve Rich Countries’ Debt Woes?
- H2 Escaping the IMF Austerity Trap
- H2 Trending
- H2 Trump’s Next Coup Attempt
- H2 How Bad Will the Economy Be?
- H2 The Iran War’s Winners and Losers
- H2 The Decline and Fall of the Dollar Empire
- H2 Hedging Security in the Gulf Is Risky
- H2 OnPoint Subscriber Exclusive
- H2 The Origins and Fate of Digital Sovereignty
- H2 Hungary’s Counter-Counterrevolution
- H2 No Exit from Stalin
- H2 The Energy Transition Has Its Own Strait of Hormuz
- H2 Interdependence Bites Back
- H2 The Real Fallout From Trump’s Tariffs
- H2 Winners & Losers
- H2 Sustainability Now
- H2 The Geopolitics of Infrastructure
- H2 Fossil-Fuel Investments Are a Fiduciary Risk
- H2 African Clean-Energy Sovereignty Can’t Wait
- H2 Opinion that Moves
- H2 Economics & Finance
- H2 Politics & World Affairs
- H2 Human Development
- H2 Sustainability Now
- H2 Innovation & Technology
- H2 Culture & Society
- H2 The African Century
- H2 Press Released
- H2 The Ocean Imperative
- H3 Content
- H3 Subscriber Exclusive
- H3 Project Syndicate
- H3 Network
- H2 ✕ Log in/Register
- H2 (empty)
A page should have only one H1. Multiple H1s dilute the document outline.
Multiple H1s blur the page's primary topic — screen-reader users and Google both prefer one H1.
Learn more ▾ ▴
HTML5's outline algorithm technically allows multiple H1s within sectioning content, but no browser implements it. In practice: one H1 per page. Use H2-H6 for subsections.
Source: WCAG 2.4.6 / Google Search Central
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
AAlt Text QualityAll 27 images OKPASS
| Issue | Count |
|---|---|
| too long | 18 image(s) |