Accessibility
· 13 checks — Landmarks, headings, alt text, forms, and link quality rolled into one auditable list.DLink & Button QualityAction16 issue(s) across 98 links and 37 buttonsFIX
| Element | Text | Issue | Suggested Fix |
|---|---|---|---|
| (empty) | empty | Add link text or aria-label | |
| https://creditcards.chase.com/a1/southwe… | Learn more | generic text | Replace with descriptive text |
Before: Learn more Suggested: Aep50kplus0326?Ref=Fullsite&Cell=62kc&Clk=Cb1578717&Cbid=Cb1578717 | |||
| https://www.southwest.com/route-map/?clk… | See everywhere we fly | new tab | Add '(opens in new tab)' to text |
| https://creditcards.chase.com/a1/southwe… | Learn more | generic text | Replace with descriptive text |
Before: Learn more Suggested: Aep50kplus0326?Ref=Fullsite&Cell=62kf&Clk=Cb1578971&Cbid=Cb1578971 | |||
| https://vacations.southwest.com/package/… | Explore this vacation package | new tab | Add '(opens in new tab)' to text |
| https://vacations.southwest.com/package/… | Explore this vacation package | new tab | Add '(opens in new tab)' to text |
| https://vacations.southwest.com/package/… | Explore this vacation package | new tab | Add '(opens in new tab)' to text |
| https://support.southwest.com/helpcenter… | Help Center | new tab | Add '(opens in new tab)' to text |
| https://www.facebook.com/Southwest?clk=G… | Facebook opens new window | new tab | Add '(opens in new tab)' to text |
| https://instagram.com/southwestair?clk=G… | Instagram opens new window | new tab | Add '(opens in new tab)' to text |
| https://www.youtube.com/user/NutsAboutSo… | Youtube opens new window | new tab | Add '(opens in new tab)' to text |
| https://www.linkedin.com/company/southwe… | LinkedIn Icon | new tab | Add '(opens in new tab)' to text |
| https://www.southwest.com/mobile-app/?cl… | Mobile Apps | new tab | Add '(opens in new tab)' to text |
| https://www.swamedia.com/?clk=GFOOTER-AB… | Press Room | new tab | Add '(opens in new tab)' to text |
| https://www.southwestairlinesinvestorrel… | Investor Relations | new tab | Add '(opens in new tab)' to text |
| https://careers.southwestair.com/?clk=GF… | Careers | new tab | Add '(opens in new tab)' to text |
| /swa-resources/pdfs/about-southwest/2309… | Code of Conduct | new tab | Add '(opens in new tab)' to text |
| /swa-resources/pdfs/corporate-commitment… | Contract of Carriage | new tab | Add '(opens in new tab)' to text |
| /swa-resources/pdfs/corporate-commitment… | Customer Service Plan | new tab | Add '(opens in new tab)' to text |
| https://www.southwesthotels.com/?utm_sou… | Hotels | new tab | Add '(opens in new tab)' to text |
| /corporate-travel/meetings-and-groups/?c… | Group Travel | new tab | Add '(opens in new tab)' to text |
| https://www.swathestore.com | Southwest® The Store | new tab | Add '(opens in new tab)' to text |
| https://www.southwestcruises.com/?utm_me… | Southwest Cruises | new tab | Add '(opens in new tab)' to text |
| https://app.nettracer.aero/lf-pax/southw… | Lost and Found | new tab | Add '(opens in new tab)' to text |
| https://www.southwest.com/about-southwes… | Terms and Conditions | new tab | Add '(opens in new tab)' to text |
| https://www.southwest.com/about-southwes… | View our privacy policy | new tab | Add '(opens in new tab)' to text |
| https://www.southwest.com/about-southwes… | View our trademarks | new tab | Add '(opens in new tab)' to text |
| https://www.southwest.com/dataprivacyreq… | Do Not Sell/Share My Personal … | new tab | Add '(opens in new tab)' to text |
| https://www.southwest.com/about-southwes… | More information about your pr… | new tab | Add '(opens in new tab)' to text |
| https://www.onetrust.com/products/cookie… | Powered by OneTrust Opens in a… | 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 |
| <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 |
Links without text are announced as raw URLs by screen readers.
a (#187 on page)
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
Generic link text like 'click here' doesn't describe the destination.
https://creditcards.chase.com/a1/southwest/AEP50KPlus0326?REF=FULLSITE&CELL=6… ("Learn more"); https://creditcards.chase.com/a1/southwest/AEP50KPlus0326?REF=FULLSITE&CELL=6… ("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.southwest.com/route-map/?clk=visrtmap; https://vacations.southwest.com/package/dl/results?productType=package&search…; https://vacations.southwest.com/package/dl/results?productType=package&search…; https://vacations.southwest.com/package/dl/results?productType=package&search…; https://support.southwest.com/helpcenter/s/?clk=GFOOTER-HC; https://www.facebook.com/Southwest?clk=GFOOTER-FACEBOOK; https://instagram.com/southwestair?clk=GFOOTER-INSTAGRAM; https://www.youtube.com/user/NutsAboutSouthwest?clk=GFOOTER-YOUTUBE; https://www.linkedin.com/company/southwest-airlines/?clk=GFOOTER-LINKEDIN; https://www.southwest.com/mobile-app/?clk=GFOOTER-APPS (+17 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.emphasis__x48LS (#167 on page); button.emphasis__x48LS (#178 on page); button.button__Yo1c8 (#385 on page); button.switcherooButton__38632 (#401 on page); button.button__Yo1c8 (#413 on page); button.button__Yo1c8 (#509 on page); button.button__Yo1c8 (#540 on page); button.button__Yo1c8 (#566 on page); button.button__Yo1c8 (#583 on page); button (#1617 on page) (+3 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
F404 Error PageActionHTTP 403, bare pageFIX
FFavicon & BrandingActionNo icons detectedFIX
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
BLandmark Structure5 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
CHeading HierarchyAction14 headings, 1 skip(s)REVIEW
- H2 Join Rapid Rewards®. Get rewarded rapidly.
- H2 Bundle and save with new Getaways by Southwest™
- H2 Special Offers
- H5 About Southwest skipped
- H5 Flying Southwest
- H5 Southwest Products
- H5 Help Center
- H2 Cookie Preferences
- H3 Manage Preferences
- H4 Strictly Necessary
- H4 Functional
- H4 Performance
- H4 Targeting
- H3 Cookie List
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
CColor Contrast (Screenshot)Action20 text elements analyzed, 11 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 Cookie Preferences | 11.76:1 | 3.0:1 | #000000 | #B4C2E2 | Pass |
| h3 Manage Preferences | 11.76:1 | 3.0:1 | #000000 | #B4C2E2 | Pass |
| h3 Cookie List | 11.76:1 | 3.0:1 | #000000 | #B4C2E2 | Pass |
| title Southwest Airlines |… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| div Southwest Airlines |… | 21.00:1 | 4.5:1 | #000000 | #FFFFFF | Pass |
| a Skip to content | 19.09:1 | 4.5:1 | #000000 | #F4F4F4 | Pass |
| div Log in | 19.09:1 | 4.5:1 | #000000 | #F4F4F4 | Pass |
| div first | 19.26:1 | 4.5:1 | #000000 | #F5F5F5 | Pass |
| div last | 19.26:1 | 4.5:1 | #000000 | #F5F5F5 | Pass |
| div Flight | Hotel | Car… | 1.78:1 | 4.5:1 | #000000 | #012999 | Fail |
| div Special Offers | 1.76:1 | 4.5:1 | #000000 | #002899 | Fail |
| div Rapid rewards | 1.76:1 | 4.5:1 | #000000 | #002899 | Fail |
| div first | 1.76:1 | 4.5:1 | #000000 | #002899 | Fail |
| div last | 1.76:1 | 4.5:1 | #000000 | #002899 | Fail |
| div first | 1.78:1 | 4.5:1 | #000000 | #002999 | Fail |
| div last | 1.80:1 | 4.5:1 | #000000 | #012A9A | Fail |
| p Earn 50,000 points +… | 1.80:1 | 4.5:1 | #000000 | #002A9A | Fail |
| a Learn more | 1.78:1 | 4.5:1 | #000000 | #00299A | Fail |
| div The current page is | 1.76:1 | 4.5:1 | #000000 | #002899 | Fail |
| div Flights | 1.73:1 | 4.5:1 | #000000 | #012697 | 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.
AAlt Text Quality2 of 29 images have issuesPASS
| Issue | Count |
|---|---|
| missing | 1 image(s) |
| filename | 1 image(s) |
Images without alt text are invisible to screen readers.
Each image without alt text is a WCAG 1.1.1 failure — invisible to screen-reader users, lost from Google Image Search.
Learn more ▾ ▴
WCAG 2.1 Level A requires text alternatives for non-decorative images. Empty alt='' is fine for decorative; meaningful images need descriptive text. Common fixes: CMS audit + bulk add, build-time linter (alt-text-required ESLint rule), CI gate on Lighthouse a11y score.
Source: WCAG 2.1 SC 1.1.1 / WebAIM Million Report
AForm Accessibility1 of 12 controls have issuesPASS
| Control | Type | Label | Method |
|---|---|---|---|
| #originationAirportCode | text | Depart* | for/id |
| #destinationAirportCode | text | Arrive* | for/id |
| #departureDate | text | Depart date in M M, D D format | aria-label |
| #returnDate | text | Return date in M M, D D format | aria-label |
| adultPassengersCount | text | Passenger Selector | aria-label |
| #promoCode | text | Promo code | aria-label |
| #vendor-search-handler | text | Cookie list search | aria-label |
| #chkbox-id | checkbox | checkbox label | for/id |
| #select-all-hosts-groups-handler | checkbox | checkbox label | for/id |
| #select-all-vendor-groups-handler | checkbox | checkbox label | for/id |
| #select-all-vendor-leg-handler | checkbox | checkbox label | for/id |
| #fileSelector | file | (none) | none |
Form controls need a <label>, aria-label, or aria-labelledby for screen readers.
<input type="file" name="file" id="fileSelector">
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
A+Lighthouse Accessibility AuditsScore 97/100 — 2 failing, 35 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 |
|---|
Super sale! Ready. Set. Jet. div.container__3p4xS > div.mainLayout__1jKOZ > div.textContent__3-wMK > div |
One-way as low as* div.textContent__3-wMK > div.offerDetails__2zw_j > div > div |
89 div.offerDetails__2zw_j > div > div.currency__1vXod > div.displayLarge__1cPop |
From New York (LaGuardia), NY div.textContent__3-wMK > div.offerDetails__2zw_j > div > div |
*Restrictions and exclusions apply. 21-day advance purchase required. Seats/day… div.mainLayout__1jKOZ > div > div.htmlValue__1ElrM > p |
These are opportunities to improve the legibility of your content.
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 |
|---|
Show fares in points form.form__3tmnN > div.fareOptionsContainer__2RRWu > span.showFareInPoints___f1CQ > div.checkbox__37tXt |
Search with low fare calendar form.form__3tmnN > div.fareOptionsContainer__2RRWu > span.lowFareCalendarCheckbox__3CyCf > div.checkbox__37tXt |
Explore package div > div.container__3Riyt > div.layout__3p5eH > a.navButton__3bxN4 |
Explore package div > div.container__3Riyt > div.layout__3p5eH > a.navButton__3bxN4 |
Explore package div > div.container__3Riyt > div.layout__3p5eH > a.navButton__3bxN4 |
See more featured deals div.layout__HiTxF > div#featuredPackagesCarousel > div.callToAction__B_uQT > a.button__uPCsA |
Privacy Policy div#onetrust-group-container > div#onetrust-policy > div#onetrust-policy-text > a.ot-cookie-policy-link |