Infrastructure
· 9 checks — DNS, redirects, IPv6, crawlability, URL variants, and domain intelligence rolled into one auditable list.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>
<!-- Made in Framer · framer.com ✨ -->
<!-- Published Apr 22, 2026, 3:00 PM UTC -->
<html lang="en" data-redirect-timezone="1">
<head>
<meta charset="utf-8">
<script>try{if(localStorage.get("__framer_force_showing_editorbar_since")){const n=document.createElement("link");n.rel = "modulepreload";n.href="https://framer.com/edit/alpha/init.mjs";document.head.appendChild(n)}}catch(e){}</script>
<!-- Start of headStart -->
<!-- Snippet: legacy-headStart -->
<script>(()=>{const n=["keydown","keyup","pointerdown","pointerup","mousedown","mouseup","click","mouseover","mouseout","mouseenter","mouseleave","pointerover","pointerenter","pointerleave","pointerout","scroll","touchstart","touchend","touchmove","touchcancel","dblclick","auxclick","contextmenu","change","copy","paste","cut","reset","dragend","dragstart","drop","input"];n.forEach(n=>document.addEventListener(n,e=>performance.measure(n,{start:performance.now()-1}),{passive:true,capture:true,__f:true}));setInterval(()=>performance.clearMeasures(...n),5000)})()</script>
<script>(()=>{var e;const t=new Set,n=new Set;let i=!1;function o(){i=!1;for(const e of n)e();n.clear()}function d(e){n.add(e),i||(i=!0,requestAnimationFrame(o))}function c(){for(const e of t)e();t.clear()}const a="scheduler"in window&&"postTask"in scheduler?e=>{scheduler.postTask(e,{priority:"background"})}:e=>setTimeout(e,1);let u=new Promise(e=>{window.addEventListener("load",()=>{e()})}).then(()=>{u=void 0});const s="scheduling"in navigator&&"function"==typeof(null===(e=navigator.scheduling)||void 0===e?void 0:e.isInputPending)?navigator.scheduling.isInputPending.bind(navigator.scheduling):()=>!1;function r(e,n=!1){if(document.hidden)return c(),void e();!async function(e,n){t.add(e),n&&"complete"!==document.readyState&&await u;const i=()=>{a(()=>{t.delete(e),e()})};d(()=>{s()?d(i):i()})}(e,n)}let l,f;function m(){l=void 0,null==f||f(),f=void 0}document.addEventListener("mousedown",function(e){0===e.button&&(l=async function(){return new Promise(e=>{const n=()=>{t.delete(e),e()};f=n,setTimeout(n,150),t.add(e)})}())},!0),document.addEventListener("click",m,!0),document.addEventListener("visibilitychange",()=>{document.hidden&&(c(),m())},!0),document.addEventListener("pagehide",()=>{m(),c()},!0);const p=document.addEventListener,v=["click","auxclick","mousedown","keyup","submit"];function h(e){if(e.__f)return;let t=e.push;Object.defineProperty(e,"push",{enumerable:!0,get:()=>t,set(e){var n;e!==t&&(t=e?(n=e,function(...e){return r(()=>{n.apply(this,e)},!0),!0}):void 0)}}),Object.defineProperty(e,"__f",{enumerable:!1,value:!0})}document.addEventListener=function(e,t,n){v.includes(e)?p.call(this,e,async function(e){"mousedown"===e.type&&0===e.button&&await l,r(()=>{"function"==typeof t?t.call(this,e):t.handleEvent(e)})},n):p.call(this,e,t,n)};const y=new MutationObserver(()=>{"complete"!==document.readyState||"dataLayer"in window?"dataLayer"in window&&(y.disconnect(),function(){let e=window.dataLayer;e&&(h(e),Object.defineProperty(window,"dataLayer",{enumerable:!0,get:()=>e,set(t){t!==e&&(e=t,e&&h(e))}}))}()):y.disconnect()});function w(e,t,n=!1){var i;const o=null!==(i=t[0])&&void 0!==i?i:this,d=null!=o&&"object"==typeof o;d&&!("__f"in o)?(e.apply(this,t),o.__f=!0):!d&&n&&e.apply(this,t)}function b(e,t){return function(...n){w.call(this,e,n),r(()=>{t.apply(this,n)})}}function g(e,t){var n;const i=null!==(n=e.__proto__[t])&&void 0!==n?n:e[t];let o=b(i,function(...e){w.call(this,i,e,!0)});Object.defineProperty(e,t,{enumerable:!0,get:()=>o,set(e){e!==o&&(o=e?b(i,e):void 0)}})}y.observe(document.documentElement,{childList:!0,subtree:!0}),g(history,"pushState"),g(history,"replaceState"),g(HTMLFormElement.prototype,"submit")})()</script>
<!-- SnippetEnd: legacy-headStart -->
<!-- Snippet: legacy-headStart-plugin-ced618 -->
<!-- Plugin: ced618 --> <script>
(function() {
window.__FcCheckoutConfigs = window.__FcCheckoutConfigs || {};
const previousSettings = {
checkout: { ...window.__FcCheckoutConfigs }
};
window.__FcCheckoutConfigs = {
...window.__FcCheckoutConfigs,
checkoutLocale: "en",
defaultCountry: "United States",
defaultCountryCode: "US",
defaultCurrency: "USD",
defaultCurrencySymbol: "$",
metaPixelId: "",
googleAnalyticsId: "",
filterByVendor: "",
filterByCollection: "",
filterByProductType: "",
filterByTags: "",
variantImageTitles: [],
variantImageSwatchTitles: [],
};
// Dispatch checkout settings update event to notify listeners
try {
const checkoutEvent = new CustomEvent('checkout__settings-updated', {
detail: {
previous: previousSettings.checkout,
current: window.__FcCheckoutConfigs
}
});
document.dispatchEvent(checkoutEvent);
} catch (e) {}
// Persist current defaults to storage when they differ to avoid stale markets/currencies
sessionStorage.setItem('checkoutLocale', 'en');
const existingCountry = localStorage.getItem('selectedCountry');
if (existingCountry !== 'United States') {
localStorage.setItem('selectedCountry', 'United States');
}
const existingCountryCode = localStorage.getItem('selectedCountryCode');
if (existingCountryCode !== 'US') {
localStorage.setItem('selectedCountryCode', 'US');
}
const existingCurrency = localStorage.getItem('selectedCurrency');
if (existingCurrency !== 'USD') {
localStorage.setItem('selectedCurrency', 'USD');
}
const existingCurrencySymbol = localStorage.getItem('selectedCurrencySymbol');
if (existingCurrencySymbol !== '$') {
localStorage.setItem('selectedCurrencySymbol', '$');
}
})();
</script>
<!-- SnippetEnd: legacy-headStart-plugin-ced618 -->
<!-- End of headStart -->
<meta name="viewport" content="width=device-width">
<meta name="generator" content="Framer 00f892b">
<title>Framer: Create a professional website, free. No code website builder loved by designers.</title>
<meta name="description" content="Build a free website with Framer—enjoy full design freedom, powerful CMS, built-in SEO, and real-time collaboration. Create professional, fully custom sites with the no-code builder loved by designers and high-performing teams.">
<meta name="framer-search-index" content="https://framerusercontent.com/sites/3BJ9zINIeWtEEVRMAcoTL8/searchIndex-IY1wO6qL6avU.json">
<meta name="framer-search-index-fallback" content="https://framerusercontent.com/sites/3BJ9zINIeWtEEVRMAcoTL8/searchIndex-M20bOp8ePbtV.json">
<meta name="framer-html-plugin" content="disable">
<link href="https://framerusercontent.com/images/Io89FonxEaWg4nxvQQllVLwPUUI.png" rel="icon" media="(prefers-color-scheme: light)">
<link href="https://framerusercontent.com/images/IWSWAkpF5evn8F9z67GntQanjk.png" rel="icon" media="(prefers-color-scheme: dark)">
<link rel="apple-touch-icon" href="https://framerusercontent.com/images/aXvo6HfUhqvR7oFjFL8b4AcyGfg.png">
<!-- Open Graph / Facebook -->
<meta property="og:type" content="website">
<meta property="og:title" content="Framer: Create a professional website, free. No code website builder loved by designers.">
<meta property="og:description" content="Build a free website with Framer—enjoy full design freedom, powerful CMS, built-in SEO, and real-time collaboration. Create professional, fully custom sites with the no-code builder loved by designers and high-performing teams.">
<meta property="og:image" content="https://framerusercontent.com/images/yyBL8MFizGZKUd27rQGHp30fyc.jpg">
<!-- Twitter -->
<meta name="twitter:card" content="summary_large_image">
<meta name="twitter:title" content="Framer: Create a professional website, free. No code website builder loved by designers.">
<meta name="twitter:description" content="Build a free website with Framer—enjoy full design freedom, powerful CMS, built-in SEO, and real-time collaboration. Create professional, fully custom sites with the no-code builder loved by designers and high-performing teams.">
<meta name="twitter:image" content="https://framerusercontent.com/images/yyBL8MFizGZKUd27rQGHp30fyc.jpg">
<style data-framer-font-css>/* latin-ext */
@font-face {
font-family: 'Instrument Serif';
font-style: italic;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/instrumentserif/v5/jizHRFtNs2ka5fXjeivQ4LroWlx-6zAjgn7MsNo.woff2) format('woff2');
unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
font-family: 'Instrument Serif';
font-style: italic;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/instrumentserif/v5/jizHRFtNs2ka5fXjeivQ4LroWlx-6zAjjH7M.woff2) format('woff2');
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
font-family: 'Instrument Serif';
font-style: normal;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/instrumentserif/v5/jizBRFtNs2ka5fXjeivQ4LroWlx-6zsTjmbI.woff2) format('woff2');
unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
font-family: 'Instrument Serif';
font-style: normal;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/instrumentserif/v5/jizBRFtNs2ka5fXjeivQ4
BTLS Certificate Expiry & Recommendations246 days until leaf cert expires — 3 issues to addressREVIEW
Certificate validity
Recommended actions
- Submit your domain to hstspreload.org to be added to the Chrome preload list
- 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
BCDN & DeliveryAWS CloudFront (FunctionGeneratedResponse from cloudfront)REVIEW
A+DNS Records4 A records, 90 ms lookupPASS
| A | 108.158.173.106, 108.158.173.26, 108.158.173.119, 108.158.173.25 |
| AAAA | 2600:9000:247e:a400:c:434b:9ec0:93a1, 2600:9000:247e:a000:c:434b:9ec0:93a1, 2600:9000:247e:c00:c:434b:9ec0:93a1, 2600:9000:247e:fa00:c:434b:9ec0:93a1, 2600:9000:247e:a200:c:434b:9ec0:93a1, 2600:9000:247e:9c00:c:434b:9ec0:93a1, 2600:9000:247e:0:c:434b:9ec0:93a1, 2600:9000:247e:8800:c:434b:9ec0:93a1 |
| CNAME | — |
| NS | ns-1243.awsdns-27.org, ns-1818.awsdns-35.co.uk, ns-336.awsdns-42.com, ns-792.awsdns-35.net |
| MX | — |
| TXT | SPF v=spf1 -all |
| CAA | Lookup not available with standard resolver |
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.
ARedirect Chain1 redirect(s), 37 ms totalPASS
https://framer.website
19 ms · HTTP/1.1
https://www.framer.com
18 ms · HTTP/1.1 FINAL
| # | URL | Status | Time | Protocol | Server |
|---|---|---|---|---|---|
| 1 | https://framer.website | 307 | 19 ms | HTTP/1.1 | CloudFront |
| 2 | https://www.framer.com | 200 | 18 ms | HTTP/1.1 | Framer/1151824 |
See the visual redirect chain in the HTTP Probe tab →
A+IPv6 ReadinessIPv6 reachable (2 ms)PASS
A+URL Variantswww/non-www, trailing slash, HTTP→HTTPSPASS
www / non-www
HTTP → HTTPS
Consistent
A+Domain Intelligenceframer.website — via CSC Corporate Domains, Inc., 4 years, 5 months oldPASS
157 days
November 19, 2026
246 days
Issued by Amazon
4 years, 5 months
Registered November 19, 2021
Not enabled
Protects against DNS spoofing
Unknown
2600:9000:247e:2000:c:434b:9ec0:93a1
CSC Corporate 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