Accessibility
· 24 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.
FWeb ManifestActionInvalid JSONFIX
Manifest contains invalid JSON.
DDark Mode SupportActionTheme color onlyFIX
Detection limited to meta tags and inline styles.
DPrint StylesheetActionNo print stylesFIX
BLink & Button Quality1 issue(s) across 71 links and 14 buttonsREVIEW
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| https://floya.brussels/ | Floya | img no alt | Add alt attribute to the image |
| https://floya.brussels/ | Floya | img no alt | Add alt attribute to the image |
| https://shops-metrostations.stib-mivb.be… | Open a shop in a station | new tab | Add '(opens in new tab)' to text |
| https://shops-metrostations.stib-mivb.be… | Open a shop in a station | new tab | Add '(opens in new tab)' to text |
| https://www.anysurfer.be/en/labels/anysu… | AnySurfer accessibility status… | new tab | Add '(opens in new tab)' to text |
| /bot-trap.html | (empty) | empty | Add link text or aria-label |
Links without text are announced as raw URLs by screen readers.
/bot-trap.html
Links with no accessible text (empty <a></a>, image-only no alt, icon-only no aria-label) are unidentifiable to screen readers.
Source: WCAG 2.1 SC 2.4.4
Add '(opens in new tab)' to link text or aria-label.
https://shops-metrostations.stib-mivb.be/; https://shops-metrostations.stib-mivb.be/; https://www.anysurfer.be/en/labels/anysurfer-label-for-websites/status/1148906
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 & Branding6 icon(s) detectedREVIEW
CLighthouse Accessibility AuditsActionScore 72/100 — 7 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.
ARIA
Some ARIA parent roles must contain specific child roles to perform their intended accessibility functions. Learn more about roles and required children elements.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
All
Metro
Tram
Bus div.col-12 > div#RTLinesAndTimetable > div.realtime-lines-nav > ul.nav-pills |
Some ARIA child roles must be contained by specific parent roles to properly perform their intended accessibility functions. Learn more about ARIA roles and required parent element.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
All div.realtime-lines-nav > ul.nav-pills > li.nav-item > button#react-aria5690077141-1-tab-a |
Metro div.realtime-lines-nav > ul.nav-pills > li.nav-item > button#react-aria5690077141-1-tab-METRO |
Tram div.realtime-lines-nav > ul.nav-pills > li.nav-item > button#react-aria5690077141-1-tab-TRAM |
Bus div.realtime-lines-nav > ul.nav-pills > li.nav-item > button#react-aria5690077141-1-tab-BUS |
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
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 |
|---|
Today div.form-line > div.input-group > div.dropdown > button#buttonFilterDropdownStartTimeDay |
Labels ensure that form controls are announced properly by assistive technologies, like screen readers. Learn more about form element labels.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
div.col-12 > div.form-line > div.input-group > input#StartTime div.col-12 > div.form-line > div.input-group > input#StartTime |
Link text (and alternate text for images, when used as links) that is discernible, unique, and focusable improves the navigation experience for screen reader users. Learn how to make links accessible.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
body > a body > a |
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 |
|---|
M5 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
12 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
17 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
19 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
28 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
29 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
38 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
39 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
42 div#swiper-wrapper-a5c1b6fb7a5105da5 > ul.swiper-slide > li > a.line-number |
These are opportunities to improve the legibility of your content.
Tables and lists
Screen readers require list items (`<li>`) to be contained within a parent `<ul>`, `<ol>` or `<menu>` to be announced properly. Learn more about proper list structure.
Performance issues directly impact user engagement and conversion rates.
| Failing Elements |
|---|
All div#RTLinesAndTimetable > div.realtime-lines-nav > ul.nav-pills > li.nav-item |
Metro div#RTLinesAndTimetable > div.realtime-lines-nav > ul.nav-pills > li.nav-item |
Tram div#RTLinesAndTimetable > div.realtime-lines-nav > ul.nav-pills > li.nav-item |
Bus div#RTLinesAndTimetable > div.realtime-lines-nav > ul.nav-pills > li.nav-item |
These are opportunities to improve the experience of reading tabular or list data using assistive technology, like a screen reader.
ALandmark Structure4 landmarksPASS
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
AHeading Hierarchy21 headingsPASS
- H1 Menu
- H1 nav.modal duplicate H1
- H1 Let's move Brussels duplicate H1
- H2 Real-time and timetables
- H3 Traffic information
- H2 Purchase your ticket online
- H3 Season tickets
- H3 Tickets
- H3 Pay contactless with your bank card
- H2 First time with STIB-MIVB? Discover how easy it is to travel with us!
- H2 In the spotlight
- H3 About STIB-MIVB
- H3 About STIB-MIVB
- H3 Discover Brussels
- H3 Discover Brussels
- H3 Our mobile apps
- H3 Our mobile apps
- H3 Professionals
- H3 Professionals
- H3 Follow us on social media
- H3 Newsletter
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
A+Heading Text QualityAll 21 heading(s) have substantive, well-formed textPASS
A+Alt Text QualityAll 13 images OKPASS
A+Form AccessibilityAll 1 controls labeledPASS
| Control | Type | Label | Method |
|---|---|---|---|
| #input-search-global | search | Rechercher dans tout le site | aria-label |
A+Form Input Types1 form control(s) checked, no type mismatchesPASS
A+Form Input Quality1 form control(s) checked, no input-semantic issuesPASS
A+Mobile Keyboard & AutofillNo autofill-eligible form controlsPASS
A+Document LanguageLang attribute set to "en"PASS
A+Tabindex Anti-Patterns4 explicit tabindex attribute(s) checked, no anti-patternsPASS
A+Iframe AccessibilityAll 2 iframe(s) have descriptive titlesPASS
A+Tap Target AdequacyAll tap targets meet WCAG 2.5.5/2.5.8 sizingPASS
A+Mobile-Readable Font SizesAll 54 visible text node(s) render at >= 12 CSS pixelsPASS
A+PWA DepthNo PWA depth issues detectedPASS
A+Mobile UX Depth1 mobile-depth signal(s) detectedPASS
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 Menu | 17.69:1 | 3.0:1 | #000000 | #D9EFFB | Pass |
| h1 nav.modal | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h1 Let's move Brussels | 13.73:1 | 3.0:1 | #00304D | #FFFFFF | Pass |
| h2 Purchase your ticket… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 First time with STIB… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h2 In the spotlight | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Traffic information | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Season tickets | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Tickets | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Pay contactless with… | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 About STIB-MIVB | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Discover Brussels | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Our mobile apps | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Professionals | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Follow us on social … | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| h3 Newsletter | 21.00:1 | 3.0:1 | #000000 | #FFFFFF | Pass |
| title Home - STIB - MIVB | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Buy | 13.67:1 | 4.5:1 | #000000 | #A1D8F6 | Pass |
| a Travel | 11.73:1 | 4.5:1 | #000000 | #81CBF0 | Pass |
| a Client support | 9.36:1 | 4.5:1 | #000000 | #50B8E8 | 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.