Infrastructure
· 9 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.DCDN & DeliveryActionNo CDN detectedFIX
Consider using a CDN to improve global delivery speed and reduce origin load.
CIPv6 ReadinessActionNo IPv6 supportREVIEW
IPv6 support is increasingly important for global accessibility. About 40% of internet users have IPv6 connectivity.
No AAAA records — same impact as 'no IPv6 (AAAA) records'; IPv6-preferring clients pay extra latency falling back to IPv4.
Source: Google IPv6 stats
CCrawlabilityActionrobots.txt present, sitemap with 0 URLsREVIEW
Search engines may not be able to parse the sitemap. Fix XML validation errors.
An unparseable sitemap is silently ignored by Google — the URLs it advertises are never queued for crawl.
Learn more ▾ ▴
Google's sitemap parser is strict about XML validity. A single unescaped `&` or unclosed tag invalidates the whole file. Run your sitemap through a validator (Search Console's Sitemaps report flags it) and fix the offending entry. Most generators escape correctly; mistakes usually come from manually-written entries.
Source: sitemaps.org / Google Search Central
An empty sitemap provides no value. Add <url> entries for your pages.
An empty sitemap signals 'no content to index' to Google — actively harmful versus having no sitemap at all.
Learn more ▾ ▴
Google compares URLs in the sitemap against URLs it has crawled. An empty sitemap on a site with thousands of pages signals abandonment. Either populate it correctly (most CMSes auto-generate) or delete the file and let Google crawl normally.
Source: Google Search Central / sitemaps.org
Add a 'Sitemap:' directive to robots.txt so search engines can discover your sitemap.
robots.txt omits Sitemap: directive — crawlers must fetch /sitemap.xml by convention; reliable but missing the explicit hint.
Source: sitemaps.org
<!doctype html>
<html dir="ltr" lang="en-US" class="no-js">
<head>
<meta charset="utf-8" />
<title>"robots.txt" | Can I use... Support tables for HTML5, CSS3, etc</title>
<meta name="viewport" content="width=device-width">
<link rel="alternate" type="application/atom+xml" title="Can I Use updates" href="/feed">
<link href="//fonts.googleapis.com/css?family=Inconsolata&display=swap" rel="stylesheet">
<link rel="icon" href="/img/favicon-128.png" sizes="16x16 32x32 64x64 128x128" type="image/png"/>
<link rel="apple-touch-icon" href="/img/favicon-128.png">
<link rel="stylesheet" href="/css/main.css?1776478324" media="all">
<link rel="stylesheet" data-theme="light" href="/css/theme-light.css?1776478325" media="all">
<link rel="stylesheet" data-theme="dark" href="/css/theme-dark.css?1776478325" media="(prefers-color-scheme: dark)">
<meta name="Description" content=""Can I use" provides up-to-date browser support tables for support of front-end web technologies on desktop and mobile web browsers.">
<meta name="keywords" content="web browser compatibility support html css svg html5 css3 opera chrome firefox safari internet explorer">
<link rel="search" href="/opensearch.xml" type="application/opensearchdescription+xml" title="Can I use"/>
<link rel="preconnect" href="https://ipinfo.io">
<link rel="preconnect" href="https://www.google-analytics.com">
<base href="/" />
<script>
document.write('<style>.static-only {display:none}</style>');
</script>
<script async src="https://www.googletagmanager.com/gtag/js?id=G-8SCDSGDGKM"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-8SCDSGDGKM');
</script>
<script>
(function() {
if (!window.customElements) {
var s = document.createElement('script');
s.src = '/legacy-handler.js';
document.getElementsByTagName('head')[0].appendChild(s);
}
}());
</script>
<!--[if IE]><script src="/legacy-handler.js"></script><![endif]--><script defer src="js-data/data.js?1776729872"></script><script defer src="js/bundle.js?1776478326"></script></head>
<body class="is-home">
<div id="main" class="ciu-main-wrap">
<header class="ciu-page-header">
<nav role="navigation" id="tab-container">
<ul class="ciu-page-header__primary-nav">
<li class="site-nav-item js-site-nav"><a href="/" data-route="home">Home</a></li>
<li class="site-nav-item js-site-nav site-nav-item--news"><a href="/ciu/news" data-route="news">News</a></li>
</ul>
<ul class="ciu-page-header__secondary-nav">
<li class="site-nav-item js-site-nav site-nav-item--comparison"><a href="/ciu/comparison" data-route="comparison">Compare<span class="site-nav__extra-text"> browsers</span></a></li>
<li class="site-nav-item js-site-nav site-nav-item--last "><a href="/ciu/about" data-route="about">About</a></li>
</ul>
<a class="news js-news" data-newstime="1772668800" href="https://caniuse.com/loading-lazy-media"><span class="date">March 5, 2026 -</span> New feature: Lazy loading via attribute for video & audio</a> </nav>
<section class="ciu-search">
<div class="ciu-search__inner js-search">
<a href="/" class="ciu-search__label">Can I use</a>
<form action="/" class="ciu-search__form">
<label class="ciu-search__a11y-label" for="feat_search">Search</label>
<input type="text" class="ciu-search__input" id="feat_search" name="search" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false" autofocus value="robots.txt">
<input type="hidden" name="static" value="1">
</form>
?
<button class="options-toggle js-options-toggle">
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16" class="icon">
<path d="M16,8.87V7L15.74,7l-1.95-.64-.52-1.25,1-2.12L13,1.67l-.25.12-1.82.93L9.66,2.2,8.87,0H7.05L7,.26,6.33,2.21l-1.25.52L3,1.73,1.67,3l.12.25.93,1.82L2.2,6.34,0,7.13V8.95L.26,9l2,.64.52,1.25L1.73,13,3,14.33l.25-.12,1.82-.93,1.26.52L7.13,16H8.95L9,15.74l.64-2,1.26-.52,2.11,1L14.33,13l-.12-.25-.93-1.82.52-1.26ZM8,10.55A2.55,2.55,0,1,1,10.55,8,2.55,2.55,0,0,1,8,10.55Z"/>
</svg>
<span>
Settings
</span>
</button>
</div>
<div class="search-result-info js-search-result-info">0 results found. <p>Why not <a href="https://github.com/Fyrd/caniuse/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+thnthnth">suggest this feature be added?</a></p></div>
</section>
</header>
<main class="ciu-page-content js-content" data-static-id="search">
</main>
<aside class="bottom-ad">
<script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
<!-- Bottom leaderboard -->
<ins class="adsbygoogle"
style="display:inline-block;width:728px;height:90px"
data-ad-client="ca-pub-3347535679733957"
data-ad-slot="1205929339"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
</aside>
<footer class="ciu-footer">
<div class="footer__section footer__primary">
<h3 class="footer__heading">Can I use...</h3>
<p class="site-description">Browser support tables for modern web technologies</p>
<p>Created & maintained by <a class="external-link" href="https://front-end.social/@fyrd">@Fyrd</a>, design by <a class="external-link" href="https://mastodon.world/@lensco">@Lensco</a>.</p>
<p>Support data contributions by the GitHub <a class="external-link" href="https://github.com/Fyrd/caniuse/graphs/contributors">community</a>.
<p id="usage_note">
Usage share statistics by <a class="external-link" href="http://gs.statcounter.com/">StatCounter GlobalStats</a> for March, 2026 </p>
<p>Location detection provided by <a class="external-link" href="//ipinfo.io">ipinfo.io</a>.
</p>
<p>
Browser testing done via
<a class="external-link" href="https://www.browserstack.com?ref=caniuse-source&caniuse_source=brand-asset&utm_source=caniuse&utm_medium=partnered&utm_campaigncode=701OW000008y9C1YAI" target="_blank">
<img src="/img/browserstack.svg" alt="BrowserStack" width="140" height="28" loading="lazy">
</a>
</p>
</div>
<div class="footer__section footer__patreon">
<h3 class="footer__heading">Support via Patreon</h3>
<p>Become a caniuse Patron to support the site and disable ads for only $1/month!</p>
<div class="patreon-button">
<a href="https://www.patreon.com/join/caniuse">
<img src="/img/become_a_patron_button.png" width="163" height="38" alt="Become a Patron!" loading="lazy">
</a>
</div>
<p>
or <a class="external-link" href="http://www.patreon.com/oauth2/authorize?response_type=code&client_id=efdd32564c7459c2c0dcd644b984e6948070b23b72961a3b9fb32ab3ad797184&redirect_uri=https%3A%2F%2Fcaniuse.com">Log in</a>
</p>
</div>
<div class="footer__section footer__links">
<h3 class="footer__heading">Site links</h3>
<ol class="footer__list">
<li class="footer__list-item">
<a href="/">Home</a>
</li>
<li class="footer__list-item">
<a href="/ciu/index">Feature index</a>
</li>
<li class="footer__list-item">
<a href="/usage-table">Browser usage table</a>
</li>
<li class="footer__list-item">
<a href="/issue-list">Feature suggestion list</a>
</li>
<li class="footer__list-item">
<a href="https://github.com/fyrd/caniuse">Caniuse data on GitHub</a>
</li>
</ol>
</div>
<div class="footer__section footer__legend">
<section class="ciu-legend js-legend">
<h2 class="ciu-legend__header">Legend</h2>
<ul class="ciu-legend__list">
<li class="ciu-legend__item">
<span class="y ciu-legend__color">Green</span>
<span class="ciu-legend__symbol">✅</span>
= Supported
</li>
<li class="ciu-legend__item">
<span class="n ciu-legend__color">Red</span>
<span class="ciu-legend__symbol">❌</span>
= Not supported
</li>
<li class="ciu-legend__item">
<span class="a ciu-legend__color">Greenish yellow</span>
<span class="ciu-legend__symbol">◐</span>
= Partial support
</li>
<li class="ciu-legend__item">
<span class="u ciu-legend__color">Gray</span>
<span class="ciu-legend__symbol">﹖</span>
= Support unknown
</li>
</ul>
</section>
</div>
</footer>
</div><!-- /all -->
</body>
</html>
BTLS Certificate Expiry & Recommendations56 days until leaf cert expires — 3 issues to addressREVIEW
Certificate validity
Recommended actions
- Add includeSubDomains to the HSTS directive
- Enable DNSSEC on your domain for DNS spoofing protection
- Enable OCSP stapling on your TLS server to remove a CA roundtrip and protect user privacy
A+DNS Records1 A records, 117 ms lookupPASS
| A | 199.250.214.41 |
| AAAA | — |
| CNAME | — |
| NS | ns1.inmotionhosting.com, ns2.inmotionhosting.com |
| MX | 0 caniuse.com |
| TXT | SPF v=spf1 +a +mx +ip4:199.250.214.41 -all |
| CAA | Lookup not available with standard resolver |
Multiple A records provide failover if one server goes down.
Single A record means a single point of failure — if that IP goes down, your site is unreachable until DNS TTL expires.
Learn more ▾ ▴
Add multiple A records for round-robin failover, or use a managed DNS provider with health-checked failover (Route 53, Cloudflare, NS1). Short TTL (60-300s) lets clients recover faster on outages.
Source: SRE practice / DNS architecture
CAA record lookup requires a specialized DNS resolver. This check will be available in a future update.
Informational: CAA (Certification Authority Authorization) records weren't checked in this scan.
A+Redirect ChainNo redirects — direct accessPASS
https://caniuse.com
780 ms · HTTP/1.1 FINAL
| # | URL | Status | Time | Protocol | Server |
|---|---|---|---|---|---|
| 1 | https://caniuse.com | 200 | 780 ms | HTTP/1.1 | nginx/1.29.4 |
A+URL Variantswww/non-www, trailing slash, HTTP→HTTPSPASS
www / non-www
Preferred variant: non-www
HTTP → HTTPS
Consistent
A+Domain Intelligencecaniuse.com — via Tucows Domains Inc., 16 years, 2 months old, hosted on INMOTION - InMotion Hosting, Inc., USPASS
315 days
April 27, 2027
56 days
Issued by Let's Encrypt
16 years, 2 months
Registered April 27, 2010
Not enabled
Protects against DNS spoofing
INMOTION - InMotion Hosting, Inc., US
ASN AS22611
199.250.214.41
Tucows Domains Inc.
Expiry timeline
Recommended actions
- Enable DNSSEC to protect visitors from DNS spoofing
- Enable registrar lock (clientTransferProhibited) to block unauthorized domain transfers
DNSSEC protects against DNS spoofing attacks. While not required, enabling DNSSEC adds an additional layer of security. Contact your DNS provider to enable it.
Without DNSSEC, an attacker who can poison your DNS can hijack your domain — and SSL certs alone don't stop them.
Learn more ▾ ▴
DNSSEC adds cryptographic signatures to DNS records, preventing forged responses from poisoning resolver caches. Without it, an attacker who controls the network path can redirect your domain to a malicious server before any HTTPS handshake happens. Most modern registrars (Cloudflare, Google Domains, Route 53) enable it with one toggle.
Source: ICANN / RFC 4033
The domain can be transferred without an unlock step. Enable registrar lock (clientTransferProhibited) in your registrar's control panel to protect against unauthorized or accidental transfers.
Without registrar lock, an attacker who phishes your registrar credentials can transfer the domain in minutes — total brand hijack.
Learn more ▾ ▴
Registrar lock (clientTransferProhibited, clientUpdateProhibited, clientDeleteProhibited) requires extra verification before any transfer/update/delete. Every major registrar offers it free. Combined with 2FA on your registrar account, it's the strongest defense against domain hijacking.
Source: ICANN / domain-security best practice