Score verdict
Needs focused fixes
Level 3
Findable
Quotable
Understandable
Trustworthy
AI Readiness
Technical SEO
Security
Performance
Production Quality
Report brief
What stands out
modeta.cz scored 71/100 on this public readiness scan. 12 pages were sampled from 227 discovered URLs.
Top findings
- Needs workMeta Description QualityTechnical SEO
3 sampled page(s) have missing or multiple meta descriptions; 10 description quality warning(s) were detected.
/agents.md, /llms-full.txt, /llms.txt, www.modeta.cz (+8 more) - Needs workTitle QualityTechnical SEO
3 sampled page(s) have missing or multiple titles; 4 title quality warning(s) were detected.
/agents.md, /llms-full.txt, /llms.txt, /products/jednodilne-tvarujici-plavky-s-prusvitnymi-vsadkami-cerne (+3 more) - Needs workA2A Agent CardAI Readiness
A2A Agent Card is missing
- Needs workAgent SkillsAI Readiness
Agent Skills index is missing
- Needs workAPI CatalogAI Readiness
API catalog is missing
Category context
- AI Readiness: 45/100
- Technical SEO: 83/100
- Security: 57/100
- Performance: no signal
- Production Quality: 50/100
AI Readiness
A2A Agent Card
Publish an A2A Agent Card so other agents can discover your agent-to-agent capabilities and supported interfaces.
A2A Agent Card is missing
Publish /.well-known/agent-card.json describing your agent: `name`, `description`, `endpoints`, `version`, and a complete `supportedInterfaces` array with the protocols and message types you accept. Include a `capabilities` block so calling agents can negotiate, and keep the URL stable across deploys — agents cache discovery responses.
Agent Skills
Publish a discoverable agent-skills index so AI agents can find and load your structured skill bundles.
Agent Skills index is missing
Publish a skills discovery index at /.well-known/agent-skills/index.json (per the Agent Skills Discovery RFC v0.2.0) with a `$schema` field and a `skills` array. Each entry should have `name`, `type`, `description`, `url`, and a `sha256` digest of the SKILL.md so agents can verify integrity. Make sure each `url` resolves to a reachable SKILL.md.
API Catalog
Publish an API catalog at /.well-known/api-catalog so agents can discover your API documentation and schemas without crawling.
API catalog is missing
Create /.well-known/api-catalog returning `application/linkset+json` with a `linkset` array. Each entry should include an `anchor` URL for the API and link relations like `service-desc` (OpenAPI spec), `service-doc` (human docs), and `status` (health endpoint). See RFC 9727 Appendix A for examples and RFC 9264 for the linkset format.
MCP Server Card
Serve an MCP Server Card so agents can discover your Model Context Protocol surface and connect with the right capabilities.
MCP server card is missing
Serve an MCP Server Card at /.well-known/mcp/server-card.json with `serverInfo` (name, version), the transport endpoint URL, and the `capabilities` you support. Accept /.well-known/mcp.json as a fallback for clients on the legacy path. The schema is being standardized — track the active proposal at github.com/modelcontextprotocol/modelcontextprotocol/pull/2127.
OpenAPI Discovery
Publish a discoverable OpenAPI 3.x document so agents and developers can understand your public HTTP API without scraping docs.
OpenAPI document is missing
Publish a valid OpenAPI 3.x document at /openapi.json or /.well-known/openapi.json, and advertise it with a `Link: <...>; rel="service-desc"` header or from /.well-known/api-catalog. Include `openapi`, `info.title`, `info.version`, `servers`, and `paths`; give operations stable `operationId` and `summary` values so agents can choose the right endpoint safely.
OAuth Protected Resource
Publish OAuth Protected Resource metadata so agents know which auth servers issue valid tokens for your APIs.
OAuth protected resource metadata is missing
Publish /.well-known/oauth-protected-resource (per RFC 9728) with your `resource` identifier, `authorization_servers` (the list of OAuth/OIDC issuer URLs that can issue tokens for this resource), and `scopes_supported`. This tells agents which auth server to obtain access tokens from and which scopes to request.
WebMCP
Expose in-page tools to AI agents via the WebMCP browser API so agents can act on your site directly.
No WebMCP registration markers were detected
Implement the WebMCP API by calling `navigator.modelContext.provideContext()` with tool definitions exposing your site's key actions to AI agents. Each tool needs `name`, `description`, `inputSchema` (JSON Schema), and an `execute` callback. Register tools at the points an agent could meaningfully use them — after page hydration, on route changes, or when permission state changes.
Technical SEO
Meta Description Quality
Every indexable page has a single meta description (50-160 chars) that previews the page accurately for search and social.
3 sampled page(s) have missing or multiple meta descriptions; 10 description quality warning(s) were detected.
Add one `<meta name="description">` tag to each important indexable page — 50–180 characters of distinct, human-readable copy that previews the page accurately. Avoid copying the title, padding with keywords, or duplicating descriptions across pages; search engines either rewrite duplicates or skip them entirely.
Title Quality
Every indexable page has exactly one descriptive, unique title that summarizes the page in 50-60 characters.
3 sampled page(s) have missing or multiple titles; 4 title quality warning(s) were detected.
Add exactly one `<title>` tag to every indexable page, ideally 50–60 characters. Make each title descriptive and unique across the site so search engines can disambiguate them. For sectional pages, include the brand as a suffix (`Page Topic | Brand`) so social previews still attribute correctly.
Heading Structure
Each page has a clear heading hierarchy with one h1 and properly nested h2/h3 sections so structure conveys meaning to readers and crawlers.
5 H1 issue(s) and 9 skipped heading hierarchy warning(s) were detected.
Use exactly one `<h1>` per page that conveys the page's subject, then nest `<h2>` sections beneath it and `<h3>` for sub-sections — never skip levels (h1 → h3) or wrap headings in `<div>` for styling. Headings communicate document structure to assistive tech and crawlers; write them as outline entries, not as styled text.
Link headers
Expose Link response headers so agents can discover related resources (API catalog, skills, agent card) without parsing HTML.
No discovery-oriented Link headers were detected on the homepage response
Add Link response headers on your homepage and key API endpoints pointing agents to discovery documents. For example: `Link: </.well-known/api-catalog>; rel="api-catalog"` for your API catalog, or `Link: </docs/api>; rel="service-doc"` for documentation. See RFC 8288 for the format and the IANA Link Relations registry for valid `rel` values.
HTML Doctype
Every sampled HTML page starts with the HTML5 doctype so browsers and validators use standards mode.
3 sampled page(s) are missing an HTML5 doctype.
Add `<!doctype html>` as the first meaningful bytes before the `<html>` element on every public HTML document. This keeps browsers in standards mode and avoids parser differences that can affect crawlers, validators, and assistive technology.
Language Attribute
Every sampled page declares the primary content language on `<html lang>` so crawlers, translators, and assistive tech interpret it correctly.
3 sampled page(s) miss <html lang> and 0 use an invalid language value.
Set the primary page language on the root element, for example `<html lang="en">` or `<html lang="en-GB">`. Keep the value aligned with the visible page language and use hreflang links only for alternate localized URLs.
Internal Link Quality
Internal links use descriptive anchor text and form a reachable graph so crawlers, readers, and AI agents can navigate context.
76 link crawlability or anchor-text warning(s) were detected.
Use real `<a href="...">` elements for navigation — never `<div onclick>` or button-styled spans, which crawlers can't follow. Write descriptive anchor text that summarizes the destination (avoid "click here", "read more", or naked URLs). Keep important pages within ~3 clicks of the homepage so crawl depth doesn't starve them.
Content Freshness
Article-like and substantial pages expose reliable freshness signals so answer engines know whether the content is current.
6 content page(s) have no reliable date signal and 0 have a newest signal older than six months.
Add truthful freshness metadata only where it reflects a real content update: JSON-LD dateModified/datePublished, article modified-time meta tags, a visible updated or reviewed date, or sitemap lastmod. Do not stamp every page with build time unless the visible content actually changed.
Content Depth and Duplication
Each indexable page carries enough unique, substantive content to merit indexing on its own without overlapping siblings.
0 page(s) are under 100 words; 2 page(s) are between 100 and 300 words; 0 duplicate-content fingerprint group(s) were detected.
Audit indexable pages for substantive, unique content — at minimum a few hundred words of original copy that delivers on the title and description. Consolidate near-duplicate pages with canonical tags or merge them into a single richer page. Don't ship placeholder "Coming soon" pages to production indexable URLs.
External Citation Links
Content pages with factual claims link out to credible external primary sources so readers and answer engines can verify context.
4 content page(s) have fewer than two contextual external citation links.
For articles, guides, and research-like pages, cite official docs, standards, primary research, or authoritative sources where claims need support. Do not add arbitrary outbound links to transactional pages, and avoid vague anchors like "click here".
Image SEO and Accessibility
Images carry meaningful alt text and reasonable dimensions so the page is accessible, indexable, and renders without layout shift.
2 image metadata or crawlability warning(s) were detected.
Use `<img src="...">` (or a `srcset`) for crawlable images, never CSS `background-image` for content imagery. Write descriptive `alt` text on meaningful images and `alt=""` on purely decorative ones. Set explicit `width` and `height` attributes to reserve layout space, and avoid `loading="lazy"` on above-the-fold or LCP images so they aren't deferred.
Canonical Hygiene
Each indexable page declares one canonical URL pointing to itself or the definitive original, so search engines consolidate ranking signals.
0 canonical error(s) and 3 canonical warning(s) were detected in the sample.
Add exactly one `<link rel="canonical" href="...">` per indexable page in the document head, with an absolute URL pointing to the preferred version (after redirects, with the right protocol and trailing-slash policy). Self-canonical is fine for the original; cross-canonical only when consolidating duplicates. Never canonicalize to a noindexed or 404 page.
Social Preview / Open Graph
Pages expose complete Open Graph and Twitter Card metadata so they preview cleanly when shared on social, in chat, or by AI assistants.
0 blocking social preview issue(s) and 9 warning(s) were detected.
On shareable pages, add Open Graph and Twitter Card metadata in the head: `og:title`, `og:description`, `og:image` (1200×630 minimum), `og:url`, `og:type`, plus `twitter:card` set to `summary_large_image`. Make the OG content match the visible page so previews aren't misleading, and use a real image URL with stable dimensions so social platforms cache reliably.
Content Readability
Public page copy is readable enough for visitors, assistants, and crawlers to summarize without wading through oversized sentences.
6 sampled page(s) have unusually long sentence or word patterns.
Rewrite dense copy into shorter sentences and paragraphs with concrete nouns, direct verbs, and clear section breaks. Keep important explanatory pages easy to scan before adding more keywords or decorative copy.
FAQ Content
FAQPage schema is treated as a bonus only when it matches visible question-and-answer content.
Visible question headings were detected without matching FAQPage JSON-LD.
Keep FAQ sections visible and useful. Only add FAQPage JSON-LD when the same questions and answers are present in the page body; remove FAQ schema for hidden, fabricated, or irrelevant questions.
Page and Server Snapshot
Lightweight server and document metrics from the sampled homepage are captured every scan so drift in HTML size, server stack, or DOM complexity is observable across reports.
Captured lightweight server and document metrics from the sampled homepage.
Security
Content Signals
Declare AI-usage preferences via Content-Signal directives in robots.txt (ai-train, search, ai-input).
No Content Signals were detected
Add Content-Signal directives to your robots.txt declaring preferences for ai-train, search, and ai-input. Example: `Content-Signal: ai-train=no, search=yes, ai-input=no`. Pair with explicit User-agent blocks so each signal targets specific bots, and review quarterly as the spec evolves.
HTTP Observatory
HTTP Observatory grade F with score 0.
Tighten response headers and HTTP posture where Observatory reports gaps.
Web Bot Auth
Identify your own bot traffic with Web Bot Auth signed requests so receiving sites can verify and trust them.
Web Bot Auth HTTP Message Signatures directory is missing
Publish a JWKS at /.well-known/http-message-signatures-directory containing the public keys you use to sign outgoing bot requests, so receiving sites can verify those requests via HTTP Message Signatures (RFC 9421). Rotate keys on a regular cadence and keep the previous key in the JWKS until in-flight requests have aged out.
Cloudflare Challenge Signals
No Cloudflare Challenge Page marker was detected on the homepage response.
Domain Trust
Domain registration data is temporarily unavailable.
Performance
Cloudflare Cache Signals
Cloudflare reported cache status DYNAMIC.
PageSpeed Insights
PageSpeed Insights returned no Lighthouse result.
PageSpeed sometimes throttles or skips a URL. The miss is cached on our side for ~15 minutes, so refreshing this report often returns the same answer. A fresh scan is the surest fix.
- The URL might be unsupported (e.g. a single-page route Lighthouse can't reach).
- Google could be rate-limiting our project key — usually clears within a few minutes.
- The page returned a redirect chain or a non-200 that Lighthouse refused to score.
CrUX Field Data
Chrome doesn't have enough real-user traffic for this site to publish field metrics yet — this isn't a failure on your side.
The Chrome User Experience Report only covers public origins with enough opted-in Chrome traffic. Smaller or newly launched sites typically appear after they accumulate sufficient sample size. Lab performance (PageSpeed Insights) below stays a useful proxy in the meantime.
Production Quality
Discovery Link Headers
Homepage Link headers do not advertise agent-useful discovery artifacts
Expose Link headers for api-catalog, service-desc, agent-skills, or related discovery artifacts.
ACP
Publish Agentic Commerce Protocol discovery so agents can transact with your commerce surfaces without scraping.
No ACP discovery markers were detected
Serve /.well-known/acp.json at the origin root with `protocol.name` set to `"acp"`, the `protocol.version`, `api_base_url`, supported transports, and `capabilities.services`. Agents can then discover your ACP implementation without first creating a checkout session.
MPP
Publish Machine Payment Protocol metadata so agents can discover paid endpoints in your API.
No MPP discovery markers were detected
Publish an OpenAPI document at /openapi.json with `x-payment-info` extensions on payable operations. Each operation should declare `intent` (charge or session), `method` (tempo, stripe, lightning, card), `amount`, and `currency`. Use the MPP SDK (`mppx` for TypeScript, `pympp` for Python) with framework middleware for Hono, Express, Next.js, or Elysia to handle the payment flow.
x402
Support x402-style HTTP 402 payment flows so agents can pay for API access machine-to-machine.
No x402 discovery markers were detected
Add x402 payment middleware to your API routes so AI agents can pay for access via HTTP. Use `@x402/express`, `@x402/hono`, or `@x402/next` middleware with a facilitator URL and wallet address. Protected routes will return HTTP 402 with payment requirements that agents can fulfill automatically.
Scan Coverage
Scanned 12 representative pages out of 227.
Cloudflare Error Diagnostics
No Cloudflare-generated error diagnostics were detected on the homepage response.
Cloudflare Product Signals
No Cloudflare product beacons were detected in the homepage response.
Cloudflare Trace Endpoint
The Cloudflare trace endpoint was not available for this origin.
DNS Service Discovery
No recognizable third-party DNS service signals were detected.
HTML Validation
HTML validation is temporarily unavailable.