Accessibility
· 13 checks — Landmarks, headings, alt text, forms, and link quality rolled into one auditable list.DWeb ManifestActionNot foundFIX
No web manifest found.
DDark Mode SupportActionNo dark mode signalsFIX
Detection limited to meta tags and inline styles.
DPrint StylesheetActionNo print stylesFIX
CLink & Button QualityAction107 issue(s) across 491 links and 86 buttonsREVIEW
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| / | More | generic text | Replace with descriptive text |
Before: More Suggested: Home page | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| /register/ | here | generic text | Replace with descriptive text |
Before: here Suggested: Register | |||
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
| <button> | (empty) | empty | Add button text or aria-label |
Generic link text like 'click here' doesn't describe the destination.
/ ("More"); /register/ ("here"); /register/ ("here"); /register/ ("here"); /register/ ("here"); /register/ ("here"); /register/ ("here"); /register/ ("here"); /register/ ("here"); /register/ ("here") (+26 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
Icon-only buttons need an aria-label so screen readers can announce them.
button.popover__trigger (#1176 on page); button.popover__content__close (#1187 on page); button.popover__trigger (#1236 on page); button.popover__content__close (#1247 on page); button.popover__trigger (#1277 on page); button.popover__content__close (#1288 on page); button.popover__trigger (#1318 on page); button.popover__content__close (#1329 on page); button.popover__trigger (#1357 on page); button.popover__content__close (#1368 on page) (+61 more)
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
B404 Error PageHTTP 404, custom pageREVIEW
CFavicon & BrandingAction11 icon(s) detectedREVIEW
CColor Contrast (Screenshot)Action20 text elements analyzed, 2 fail WCAG AAREVIEW
Analyzes text contrast against the actual rendered page, including background images, gradients, and overlays that CSS-based tools cannot detect.
1 contrast failures on background images/gradients
These failures are invisible to CSS-based accessibility tools like Lighthouse. The text may be fine on a solid background, but fails when rendered over an image or gradient.
Show all checked elements (20)
| Element | Ratio | Required | FG | BG | Result |
|---|---|---|---|---|---|
| h1 Home | The National … | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Epaper Edition | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 weather (Ottawa) | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Canadian Tire | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 You've reached the 2… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 Looks like you've re… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| title Home | The National … | 16.71:1 | 4.5:1 | #000000 | #E0E5F6 | Pass |
| div Advertisement oop | 15.14:1 | 4.5:1 | #000000 | #ECDB96 | Pass |
| div Stories continue bel… | 13.99:1 | 4.5:1 | #000000 | #FFCD05 | Pass |
| div This advertisement h… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Skip to Content | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| strong Introducing Right? … | 9.83:1 | 3.0:1 | #000000 | #E89EA0 | Pass |
| span Sign up now >> | 3.79:1 | 4.5:1 | #000000 | #CF171D | Fail |
| strong Introducing Right? … | 7.00:1 | 3.0:1 | #000000 | #E27477 | Pass |
| span Sign up now >> | 19.95:1 | 4.5:1 | #000000 | #F9F9F9 | Pass |
| span Sections | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Search | 20.82:1 | 4.5:1 | #000000 | #FEFEFE | Pass |
| label Search nationalpost.… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| span Perform search | 17.43:1 | 4.5:1 | #000000 | #EBEAE5 | Pass |
| span Subscribe $6 for 6 m… | 2.90:1 | 4.5:1 | #000000 | #675344 | 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.
A+Landmark Structure33 landmarksPASS
AHeading Hierarchy72 headings, 1 skip(s)PASS
- H1 Home | The National Post Home Page | National Post
- H3 97% of Canadian doctors report having to counter harm caused by false online information skipped
- H3 Judge says 'colonization' a reason Indigenous man gets reduced sentence for choking a toddler
- H3 Canada's inflation rate hit 2.4% in March. Here's how it compares to the world's top economies
- H3 Gisèle Pelicot vs. a pack of rapists: 50 strangers and my former husband
- H2 Tasha Kheiriddin: Carney preparing to fail in Trump negotiations
- H3 Subscriber only. John Ivison: Avi Lewis’s NDP senses the right spots to attack Carney’s left
- H3 Adam Pankratz: Reconciliation law will be David Eby's downfall
- H3 Canadians overwhelmingly favour federal intervention over alleged news theft by AI
- H3 Postmedia nominated for four news awards by Canadian Association of Journalists
- H3 Group calls on Ottawa to ban flavoured vapes, despite mixed Quebec results
- H3 'I am Team Canada in my blood:' Erin O'Toole on why he believes in Carney's Canada-U.S. council more than Trudeau's
- H3 Danielle Smith: Nova Scotia could be a natural gas superpower, too
- H3 Jesse Kline: Carney gets a little help from his international banking friends
- H3 FIRST READING: Canada says it didn't endorse UN Iran appointment (except it did)
- H3 Colby Cosh: Paging Avi Lewis — Canada's communitarian grocer gets food inflation, too
- H3 Lisa Sygutek: Supportive federal policies have been game changers for community newspapers
- H3 J.D. Tuccille: Americans are primed for another tax revolt
- H3 Scott Stinson: Ontario MPPs blast Doug Ford over aborted plans for $28.9M private jet
- H3 Subscriber only. John Ivison: Carney’s feel-good video is weak medicine for our grave economic reality
- H2 Canada
- H3 B.C. real estate agent disciplined for sending Hitler image and 'anti-Semitic' message to Jewish-owned Toronto restaurant
- H3 Schizophrenic man behind Toronto army recruiting centre knife attack approved for Mecca pilgrimage
- H3 As feds look to criminalize deepfakes, advocates want a way to erase them from the internet
- H3 Ex-CBSA employee improperly passed on data to potential real estate clients
- H3 Alberta MLAs will again debate moving to permanent daylight time, Danielle Smith says
- H3 Tasha Kheiriddin: Carney preparing to fail in Trump negotiations
- H3 Erin O'Toole, Lisa Raitt, Ralph Goodale among the names on Carney's Canada-U.S. council
- H3 Canada changed citizenship rules and Americans are making the most of it
- H3 Jesse Kline: Carney gets a little help from his international banking friends
- H3 Who is going to Florida if Canada is boycotting U.S. travel? It's Canadians
- H2 Epaper Edition
- H2 World
- H3 Iran ceasefire ‘unlikely’ to be extended without a peace deal, Trump says
- H3 Dual Iran, U.S. blockades have traffic in Strait of Hormuz crippled once again
- H3 Canadian woman killed in shooting at popular Mexican tourist site
- H3 Who is going to Florida if Canada is boycotting U.S. travel? It's Canadians
- H3 Russia-aligned Radev wins in eighth Bulgarian election since 2021
- H2 NP Comment
- H3 Chris Selley: This can't be happening at Rideau Hall
- H3 Damien Kurek: The Liberal plan to silence the House of Commons
- H3 Trump’s plan for Cuba isn’t what you’ve been told: Full Comment podcast
- H3 Subscriber only. FIRST READING: Floor-crossings are technically allowed? Here's what else is technically allowed
- H3 Kelly McParland: Orbán's demise sends out a signal of hope
- H2 weather (Ottawa)
- H2 Canadian Tire
- H2 Longreads
- H3 Future of 24 Sussex Drive: While the government dithers, here are some ideas to fix it
- H3 Julie Payette’s disastrous reign as governor general: ‘Act of perpetual petulance’
- H3 Nelly Furtado is done with fame. So the Canadian pop icon has exited the stage
- H3 As the Blue Jays begin their 50th season, we find the men from the first opening day
- H3 What happens when you don't die on time?
- H2 Life
- H3 Toronto housing: “Reimagining what a neighbourhood can be”
- H3 Daily Horoscope - Tuesday, April 21, 2026
- H3 Daily Horoscope - Monday, April 20, 2026
- H3 Daily Horoscope - Sunday, April 19, 2026
- H3 Daily Horoscope - Saturday, April 18, 2026
- H2 Shopping
- H3 U.S. couple shocked after sunny cruise to Bermuda rerouted to chilly New Brunswick
- H3 These are the 3 best beauty products we tried this week
- H3 See how a $2,500 gym shed project created a fresh home fitness space
- H3 Canadian concert tours: Hottest tickets in 2026
- H3 Best standup comedy shows in Canada near you this week
- H2 Healthing
- H3 Serotonin tinnitus severity study opens the door for more precise treatment using SSRIs
- H3 What is food noise? Inside the cravings and intrusive thoughts that are impossible to ignore
- H3 MasterChef Canada's Marissa Leon-John cooking simple and fabulous food for people with diabetes
- H3 Behind the Scenes: The role of the hospital board of directors
- H3 Understanding how to apply for damages in long-term disability claims
- H2 You've reached the 20 article limit.
- H2 Looks like you've reached your saved article limit!
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 107 images OKPASS
| Issue | Count |
|---|---|
| too long | 2 image(s) |
A+Form AccessibilityAll 3 controls labeledPASS
| Control | Type | Label | Method |
|---|---|---|---|
| #id_search_text | input | Search nationalpost.com | for/id |
| #id_search_text_top | input | Search nationalpost.com | for/id |
| #emailNP_HeadlineNews | Email Address | aria-label |
ALighthouse Accessibility AuditsScore 92/100 — 3 failing, 28 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.
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 |
|---|
National Post in Taboola advertising section div.videoCube > a.item-label-href > span.video-label-box > span.branding |
National Post in Taboola advertising section div.videoCube > a.item-label-href > span.video-label-box > span.branding |
span.branding > div.logoDiv > a.trc_mobile_disclosure_link > span span.branding > div.logoDiv > a.trc_mobile_disclosure_link > span |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
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 |
|---|
97% of Canadian doctors report having to counter harm caused by false online in… div.article-card__content > div.article-card__details > a.article-card__link > h3.article-card__headline |
These are opportunities to improve keyboard navigation in your application.
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 |
|---|
BUSINESS ESSENTIALS section.carousel-widget > div.widget-title > div#BusinessEssentials4894490616705506819794126277443584 > a.widget-title__link |
Sponsored: learn about this recommendation (opens dialog) span.video-label-box > span.branding > div.logoDiv > a.trc_mobile_disclosure_link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
div.row > div.col-xs-12 > nav.footer__nav > a.footer__link div.row > div.col-xs-12 > nav.footer__nav > a.footer__link |
These items highlight common accessibility best practices.