認証済み AgentReady.md 証明書
発行日時 sig: 14ad8bf8747640e8 検証 →

分析済みURL

https://www.rivalr.app/

別のURLを分析

AI-Readyスコア

71 / C

普通

/ 100

トークン削減量

HTMLトークン 1936
Markdownトークン 1
削減率 100%

スコア内訳

セマンティックHTML 35/100
コンテンツ効率 93/100
AI発見可能性 61/100
構造化データ 85/100
アクセシビリティ 85/100

新興プロトコル

3件中0件検出

AIエージェントが探すwell-knownエンドポイント。検出されればエージェントが自動的にあなたのサービスを発見・接続できます。

  • OAuth Discovery RFC 8414
    /.well-known/oauth-authorization-server
  • MCP Server Card Anthropic
    /.well-known/mcp.json
  • A2A Agent Card Google
    /.well-known/agent.json

ページに<article>または<main>要素がありません。これらのセマンティックコンテナはAIエージェントがメインコンテンツ領域を特定し、ナビゲーション、サイドバー、フッターを無視するのに役立ちます。

実装方法

ページのメインコンテンツの周りに<main>要素を追加し、ブログ投稿や製品説明などの独立したコンテンツブロックには<article>を使用してください。

見出し構造に問題があります(レベルの飛ばしや複数のh1タグ)。クリーンな階層はAIエージェントがコンテンツ構成を理解するのに役立ちます。

実装方法

ページごとに正確に1つの<h1>を持ち、見出しが順番に従うようにしてください:h1 > h2 > h3。レベルを飛ばさないでください(例:h1から直接h3)。

サイトマップが見つかりません。サイトマップはAIエージェントがサイトのすべてのページを発見するのに役立ちます。

実装方法

すべての公開ページをリストした/sitemap.xmlを作成してください。ほとんどのCMSプラットフォームで自動生成できます。

ページが<div>要素に大きく依存しています。<section>、<nav>、<header>、<footer>、<aside>などのセマンティック要素はAIエージェントに意味のある構造を提供します。

実装方法

汎用的な<div>コンテナを適切なセマンティック要素に置き換えてください。テーマ別グループには<section>、ナビゲーションには<nav>、ページ/セクションのヘッダーとフッターには<header>/<footer>を使用してください。

サイトがMarkdown for Agentsに対応していません。このCloudflare標準により、AIエージェントがmarkdown形式でコンテンツをリクエストでき、トークン使用量を約80%削減できます。

実装方法

以下の1つ以上を実装してください:(1) Accept: text/markdownにmarkdownコンテンツで応答。(2) .md URL(例:/page.md)を提供。(3) <link rel="alternate" type="text/markdown">タグを追加。(4) markdown検出用のLink HTTPヘッダーを追加。

{\n res.setHeader('Vary', 'Accept');\n res.setHeader('Link', '; rel=\"alternate\"; type=\"text/markdown\"');\n if ((req.headers.accept || '').includes('text/markdown')) {\n res.type('text/markdown; charset=utf-8');\n return res.send(renderMarkdown('page'));\n }\n res.render('page');\n});"},{"id":"fastify","label":"Fastify","language":"javascript","filename":"server.js","code":"// Mechanisms 1 + 4: content negotiation + Link header\nfastify.get('/page', async (req, reply) => {\n reply.header('Vary', 'Accept');\n reply.header('Link', '; rel=\"alternate\"; type=\"text/markdown\"');\n if ((req.headers.accept || '').includes('text/markdown')) {\n return reply.type('text/markdown; charset=utf-8').send(renderMarkdown('page'));\n }\n return reply.view('/page.ejs');\n});"},{"id":"nextjs","label":"Next.js","language":"typescript","filename":"app/page/route.ts","code":"// Next.js App Router — Route Handler returning Markdown\nimport { NextRequest } from 'next/server';\nimport { renderMarkdown } from '@/lib/md';\nexport async function GET(req: NextRequest) {\n const accept = req.headers.get('accept') || '';\n if (accept.includes('text/markdown')) {\n return new Response(await renderMarkdown('page'), {\n headers: {\n 'Content-Type': 'text/markdown; charset=utf-8',\n 'Vary': 'Accept',\n },\n });\n }\n // Fall through to the page component\n return new Response(null, { status: 404 });\n}"},{"id":"wordpress","label":"WordPress","language":"php","filename":"functions.php","code":"post_content));\n exit;\n});"},{"id":"static","label":"Hugo / Jekyll / Astro","language":"txt","filename":"static/page.md","code":"# Mechanism 2: serve .md alongside .html\n# Hugo: place page.md in /static/ — built unchanged\n# Jekyll: drop page.md in /assets/ — copied as-is\n# Astro: src/pages/page.md.ts that exports a GET returning markdown\n\n# Then advertise with mechanism 3 in :\n# "}] }'>

正規URLが見つかりません。これはAIエージェントがページの優先バージョンを特定し、重複コンテンツを回避するのに役立ちます。

実装方法

ページの正規URLを指す<link rel="canonical" href="...">タグを追加してください。

多くの要素にインラインスタイル属性があります。これらはAIエージェントがコンテンツを抽出する際のノイズになります。

実装方法

すべてのインラインスタイルをスタイルシートのCSSクラスに移動してください。多くの固有スタイルが必要な場合はTailwindなどのユーティリティCSSフレームワークを使用してください。

Markdownトークン: 1

  
Rivalr — Find Players & Join Activity Groups Near You

このファイルをサーバーの/index.mdとしてアップロードし、AIエージェントがページのクリーンなバージョンにアクセスできるようにしましょう。Accept: text/markdownコンテンツネゴシエーションを設定して自動的に配信することもできます。

推奨内容

llms.txtをダウンロード
# rivalr.app

> Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.

## Main
- [Rivalr — Find Players & Join Activity Groups Near You](https://www.rivalr.app/): Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one…

完全なllms.txtにはドメイン全体の分析が必要です(近日公開)

このファイルをドメインのルートにhttps://www.rivalr.app/llms.txtとしてアップロードしてください。ChatGPT、Claude、PerplexityなどのAIエージェントはこのファイルを確認してサイト構造を理解します。

このサイトにはすでにllms.txtファイルがあります。

無効な形式 — #見出しで始まり、意味のあるコンテンツが必要です
<!doctype html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <link rel="icon" type="image/svg+xml" href="/favicon.svg" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta name="description" content="Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed." />

    <!-- Open Graph -->
    <meta property="og:type" content="website" />
    <meta property="og:url" content="https://www.rivalr.app/" />
    <meta property="og:title" content="Rivalr — Find Players &amp; Join Activity Groups" />
    <meta property="og:description" content="Connect with people for football, basketball, padel, concerts, dinners, hikes and more. Post open spots or join an existing group — no group chat needed." />
    <meta property="og:image" content="https://www.rivalr.app/og-image.png" />
    <meta property="og:image:width" content="1200" />
    <meta property="og:image:height" content="630" />
    <meta property="og:image:alt" content="Rivalr — Find Players &amp; Join Activity Groups" />
    <meta property="og:site_name" content="Rivalr" />

    <!-- Twitter Card -->
    <meta name="twitter:card" content="summary_large_image" />
    <meta name="twitter:title" content="Rivalr — Find Players &amp; Join Activity Groups" />
    <meta name="twitter:description" content="Connect with people for football, basketball, padel, concerts, dinners, hikes and more. Post open spots or join an existing group — no group chat needed." />
    <meta name="twitter:image" content="https://www.rivalr.app/og-image.png" />

    <title>Rivalr — Find Players &amp; Join Activity Groups Near You</title>

    <!-- Schema.org JSON-LD -->
    <script type="application/ld+json">
    {
      "@context": "https://schema.org",
      "@graph": [
        {
          "@type": "Organization",
          "@id": "https://www.rivalr.app/#organization",
          "name": "Rivalr",
          "url": "https://www.rivalr.app/",
          "logo": {
            "@type": "ImageObject",
            "url": "https://www.rivalr.app/og-image.png",
            "width": 1200,
            "height": 630
          },
          "description": "Rivalr connects people for shared activities — football, basketball, padel, concerts, dinners, hikes and more."
        },
        {
          "@type": "WebSite",
          "@id": "https://www.rivalr.app/#website",
          "url": "https://www.rivalr.app/",
          "name": "Rivalr",
          "publisher": { "@id": "https://www.rivalr.app/#organization" }
        },
        {
          "@type": "SoftwareApplication",
          "@id": "https://www.rivalr.app/#app",
          "name": "Rivalr",
          "operatingSystem": ["iOS", "Android"],
          "applicationCategory": "SocialNetworkingApplication",
          "description": "Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.",
          "offers": {
            "@type": "Offer",
            "price": "0",
            "priceCurrency": "EUR"
          },
          "url": "https://www.rivalr.app/"
        }
      ]
    }
    </script>

    <link rel="preconnect" href="https://fonts.googleapis.com" />
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
    <link href="https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=DM+Serif+Display:ital@0;1&display=swap" rel="stylesheet" />
    <script type="module" crossorigin src="/assets/index-DekaQV6t.js"></script>
    <link rel="stylesheet" crossorigin href="/assets/index-Bv57ANoo.css">
  </head>
  <body style="background:#0B0F19;color:#F1F5F9">
    <div id="root"></div>
    <noscript>
      <h1>Find Players &amp; Join Activity Groups Near You</h1>
      <p>Rivalr connects you with people for football, basketball, padel, tennis, concerts, dinners, hiking and more. Post open spots or join an existing group — no group chat needed.</p>
      <nav aria-label="Activity pages">
        <a href="/activities/football/athens/">Football in Athens</a>
        <a href="/activities/basketball/athens/">Basketball in Athens</a>
        <a href="/activities/padel/athens/">Padel in Athens</a>
        <a href="/activities/tennis/athens/">Tennis in Athens</a>
        <a href="/activities/concert/athens/">Concerts in Athens</a>
        <a href="/activities/hiking/athens/">Hiking in Athens</a>
        <a href="/activities/dinner/athens/">Dinner in Athens</a>
        <a href="/activities/football/thessaloniki/">Football in Thessaloniki</a>
        <a href="/activities/basketball/thessaloniki/">Basketball in Thessaloniki</a>
        <a href="/activities/padel/thessaloniki/">Padel in Thessaloniki</a>
      </nav>
    </noscript>
    <!-- WebMCP: expose Rivalr tools to AI agents via the browser -->
    <script>
      (function () {
        if (!navigator.modelContext || typeof navigator.modelContext.registerTool !== 'function') return;
        const ac = new AbortController();
        const BASE = 'https://api.rivalr.app';

        navigator.modelContext.registerTool({
          name: 'rivalr_list_postings',
          description: 'List open match postings and pickup game slots on Rivalr, optionally filtered by activity type, city, or date.',
          inputSchema: {
            type: 'object',
            properties: {
              activity: { type: 'string', description: 'Activity type, e.g. football, basketball, padel, tennis, concert, dinner, hiking' },
              city: { type: 'string', description: 'City name, e.g. athens, thessaloniki' },
              date: { type: 'string', format: 'date', description: 'ISO 8601 date to filter by' }
            }
          },
          execute: async ({ activity, city, date } = {}) => {
            const params = new URLSearchParams();
            if (activity) params.set('activity', activity);
            if (city) params.set('city', city);
            if (date) params.set('date', date);
            const res = await fetch(`${BASE}/postings?${params}`);
            return res.json();
          },
          signal: ac.signal
        });

        navigator.modelContext.registerTool({
          name: 'rivalr_get_posting',
          description: 'Get full details about a specific Rivalr match posting including spots left, date, venue, and participants.',
          inputSchema: {
            type: 'object',
            required: ['id'],
            properties: {
              id: { type: 'string', description: 'Match posting ID' }
            }
          },
          execute: async ({ id }) => {
            const res = await fetch(`${BASE}/postings/${encodeURIComponent(id)}`);
            return res.json();
          },
          signal: ac.signal
        });

        navigator.modelContext.registerTool({
          name: 'rivalr_list_venues',
          description: 'List sports venues on Rivalr with location, supported activities, and availability.',
          inputSchema: {
            type: 'object',
            properties: {
              city: { type: 'string', description: 'City name to filter venues' },
              activity: { type: 'string', description: 'Activity type supported by the venue' }
            }
          },
          execute: async ({ city, activity } = {}) => {
            const params = new URLSearchParams();
            if (city) params.set('city', city);
            if (activity) params.set('activity', activity);
            const res = await fetch(`${BASE}/venues?${params}`);
            return res.json();
          },
          signal: ac.signal
        });

        window.addEventListener('unload', () => ac.abort(), { once: true });
      })();
    </script>
  </body>
</html>

セマンティックHTML

articleまたはmain要素を使用 (0/100)

Missing <article> and <main> elements

適切な見出し階層 (0/100)

No headings found

セマンティックHTML要素を使用 (0/100)

0 semantic elements, 1 divs (ratio: 0%)

意味のある画像alt属性 (100/100)

No images found

低いdivネスト深度 (100/100)

Avg div depth: 0.0, max: 0

コンテンツ効率

良好なトークン削減率 (100/100)

100% token reduction (HTML→Markdown)

良好なコンテンツ対ノイズ比 (100/100)

Content ratio: 43.1% (3395 content chars / 7876 HTML bytes)

最小限のインラインスタイル (50/100)

1/30 elements with inline styles (3.3%)

適切なページ重量 (100/100)

HTML size: 8KB

AI発見可能性

llms.txtファイルあり (50/100)

llms.txt exists but appears empty or invalid

robots.txtファイルあり (100/100)

robots.txt exists

robots.txtがAIボットを許可 (100/100)

All major AI bots allowed

sitemap.xmlあり (0/100)

No sitemap found

Markdown for Agentsサポート (40/100) Application
&#10003; Accept: text/markdown &#10007; .md URL &#10007; <link> tag &#10007; Link header YAML frontmatter (enriched)
Content-Signalあり(robots.txtまたはHTTPヘッダー) (80/100)
&#10003; robots.txt &#10007; HTTP header &#10003; Policy

構造化データ

Schema.org / JSON-LDあり (100/100)

JSON-LD found: Organization, WebSite, SoftwareApplication

Open Graphタグあり (100/100)

All OG tags present

メタディスクリプションあり (100/100)

Meta description: 149 chars

正規URLあり (0/100)

No canonical URL

lang属性あり (100/100)

lang="en"

アクセシビリティ

JavaScript不要でコンテンツ利用可能 (100/100)

Content available without JavaScript

適切なページサイズ (100/100)

Page size: 8KB

HTML内でコンテンツが早い位置に配置 (50/100)

Main content starts at 49% of HTML

{
  "url": "https://www.rivalr.app/",
  "timestamp": 1778798510409,
  "fetch": {
    "mode": "simple",
    "timeMs": 775,
    "htmlSizeBytes": 7876,
    "supportsMarkdown": true,
    "markdownAgents": {
      "contentNegotiation": true,
      "mdUrl": {
        "found": false,
        "url": null
      },
      "linkTag": {
        "found": false,
        "url": null
      },
      "linkHeader": {
        "found": false,
        "url": null
      },
      "responseHeaders": {
        "contentSignal": "ai-train=yes, search=yes, ai-input=yes",
        "xMarkdownTokens": "486",
        "vary": "Accept"
      },
      "frontmatter": {
        "present": true,
        "fields": [
          "title",
          "description",
          "image"
        ],
        "level": "enriched"
      },
      "level": "application"
    },
    "statusCode": 200
  },
  "extraction": {
    "title": "Rivalr — Find Players & Join Activity Groups Near You",
    "excerpt": "Find Players & Join Activity Groups Near You\n      Rivalr connects you with people for football, basketball, padel, tennis, concerts, dinners, hiking and more. Post open spots or join an existing grou",
    "byline": null,
    "siteName": null,
    "lang": "en",
    "contentLength": 3395,
    "metadata": {
      "description": "Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.",
      "ogTitle": "Rivalr — Find Players & Join Activity Groups",
      "ogDescription": "Connect with people for football, basketball, padel, concerts, dinners, hikes and more. Post open spots or join an existing group — no group chat needed.",
      "ogImage": "https://www.rivalr.app/og-image.png",
      "ogType": "website",
      "canonical": null,
      "lang": "en",
      "schemas": [
        {
          "@type": "Organization",
          "@id": "https://www.rivalr.app/#organization",
          "name": "Rivalr",
          "url": "https://www.rivalr.app/",
          "logo": {
            "@type": "ImageObject",
            "url": "https://www.rivalr.app/og-image.png",
            "width": 1200,
            "height": 630
          },
          "description": "Rivalr connects people for shared activities — football, basketball, padel, concerts, dinners, hikes and more."
        },
        {
          "@type": "WebSite",
          "@id": "https://www.rivalr.app/#website",
          "url": "https://www.rivalr.app/",
          "name": "Rivalr",
          "publisher": {
            "@id": "https://www.rivalr.app/#organization"
          }
        },
        {
          "@type": "SoftwareApplication",
          "@id": "https://www.rivalr.app/#app",
          "name": "Rivalr",
          "operatingSystem": [
            "iOS",
            "Android"
          ],
          "applicationCategory": "SocialNetworkingApplication",
          "description": "Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.",
          "offers": {
            "@type": "Offer",
            "price": "0",
            "priceCurrency": "EUR"
          },
          "url": "https://www.rivalr.app/"
        }
      ],
      "robotsMeta": null,
      "author": null,
      "generator": null,
      "markdownAlternateHref": null
    }
  },
  "markdown": "\n",
  "fullPageMarkdown": "Rivalr — Find Players & Join Activity Groups Near You\n",
  "markdownStats": {
    "images": 0,
    "links": 10,
    "tables": 0,
    "codeBlocks": 0,
    "headings": 1
  },
  "tokens": {
    "htmlTokens": 1936,
    "markdownTokens": 1,
    "reduction": 1935,
    "reductionPercent": 100
  },
  "score": {
    "score": 71,
    "grade": "C",
    "dimensions": {
      "semanticHtml": {
        "score": 35,
        "weight": 20,
        "grade": "F",
        "checks": {
          "uses_article_or_main": {
            "score": 0,
            "weight": 20,
            "details": "Missing <article> and <main> elements"
          },
          "proper_heading_hierarchy": {
            "score": 0,
            "weight": 25,
            "details": "No headings found"
          },
          "semantic_elements": {
            "score": 0,
            "weight": 20,
            "details": "0 semantic elements, 1 divs (ratio: 0%)"
          },
          "meaningful_alt_texts": {
            "score": 100,
            "weight": 15,
            "details": "No images found"
          },
          "low_div_nesting": {
            "score": 100,
            "weight": 20,
            "details": "Avg div depth: 0.0, max: 0"
          }
        }
      },
      "contentEfficiency": {
        "score": 93,
        "weight": 25,
        "grade": "A",
        "checks": {
          "token_reduction_ratio": {
            "score": 100,
            "weight": 40,
            "details": "100% token reduction (HTML→Markdown)"
          },
          "content_to_noise_ratio": {
            "score": 100,
            "weight": 30,
            "details": "Content ratio: 43.1% (3395 content chars / 7876 HTML bytes)"
          },
          "minimal_inline_styles": {
            "score": 50,
            "weight": 15,
            "details": "1/30 elements with inline styles (3.3%)"
          },
          "reasonable_page_weight": {
            "score": 100,
            "weight": 15,
            "details": "HTML size: 8KB"
          }
        }
      },
      "aiDiscoverability": {
        "score": 61,
        "weight": 25,
        "grade": "C",
        "checks": {
          "has_llms_txt": {
            "score": 50,
            "weight": 20,
            "details": "llms.txt exists but appears empty or invalid"
          },
          "has_robots_txt": {
            "score": 100,
            "weight": 10,
            "details": "robots.txt exists"
          },
          "robots_allows_ai_bots": {
            "score": 100,
            "weight": 15,
            "details": "All major AI bots allowed"
          },
          "has_sitemap": {
            "score": 0,
            "weight": 10,
            "details": "No sitemap found"
          },
          "supports_markdown_negotiation": {
            "score": 40,
            "weight": 25,
            "details": "Application level — Content negotiation"
          },
          "has_content_signals": {
            "score": 80,
            "weight": 20,
            "details": "robots.txt: ai-train=no, search=yes, ai-input=no | Policy included"
          }
        }
      },
      "structuredData": {
        "score": 85,
        "weight": 15,
        "grade": "B",
        "checks": {
          "has_schema_org": {
            "score": 100,
            "weight": 30,
            "details": "JSON-LD found: Organization, WebSite, SoftwareApplication"
          },
          "has_open_graph": {
            "score": 100,
            "weight": 25,
            "details": "All OG tags present"
          },
          "has_meta_description": {
            "score": 100,
            "weight": 20,
            "details": "Meta description: 149 chars"
          },
          "has_canonical_url": {
            "score": 0,
            "weight": 15,
            "details": "No canonical URL"
          },
          "has_lang_attribute": {
            "score": 100,
            "weight": 10,
            "details": "lang=\"en\""
          }
        }
      },
      "accessibility": {
        "score": 85,
        "weight": 15,
        "grade": "B",
        "checks": {
          "content_without_js": {
            "score": 100,
            "weight": 40,
            "details": "Content available without JavaScript"
          },
          "reasonable_page_size": {
            "score": 100,
            "weight": 30,
            "details": "Page size: 8KB"
          },
          "fast_content_position": {
            "score": 50,
            "weight": 30,
            "details": "Main content starts at 49% of HTML"
          }
        }
      }
    }
  },
  "recommendations": [
    {
      "id": "add_article_main",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.add_article_main.title",
      "descriptionKey": "rec.add_article_main.description",
      "howToKey": "rec.add_article_main.howto",
      "effort": "quick-win",
      "estimatedImpact": 8,
      "checkScore": 0,
      "checkDetails": "Missing <article> and <main> elements"
    },
    {
      "id": "fix_heading_hierarchy",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.fix_heading_hierarchy.title",
      "descriptionKey": "rec.fix_heading_hierarchy.description",
      "howToKey": "rec.fix_heading_hierarchy.howto",
      "effort": "quick-win",
      "estimatedImpact": 6,
      "checkScore": 0,
      "checkDetails": "No headings found"
    },
    {
      "id": "add_sitemap",
      "priority": "critical",
      "category": "aiDiscoverability",
      "titleKey": "rec.add_sitemap.title",
      "descriptionKey": "rec.add_sitemap.description",
      "howToKey": "rec.add_sitemap.howto",
      "effort": "quick-win",
      "estimatedImpact": 5,
      "checkScore": 0,
      "checkDetails": "No sitemap found"
    },
    {
      "id": "add_semantic_elements",
      "priority": "critical",
      "category": "semanticHtml",
      "titleKey": "rec.add_semantic_elements.title",
      "descriptionKey": "rec.add_semantic_elements.description",
      "howToKey": "rec.add_semantic_elements.howto",
      "effort": "moderate",
      "estimatedImpact": 5,
      "checkScore": 0,
      "checkDetails": "0 semantic elements, 1 divs (ratio: 0%)"
    },
    {
      "id": "add_markdown_negotiation",
      "priority": "high",
      "category": "aiDiscoverability",
      "titleKey": "rec.add_markdown_negotiation.title",
      "descriptionKey": "rec.add_markdown_negotiation.description",
      "howToKey": "rec.add_markdown_negotiation.howto",
      "effort": "significant",
      "estimatedImpact": 6,
      "checkScore": 40,
      "checkDetails": "Application level — Content negotiation"
    },
    {
      "id": "add_canonical_url",
      "priority": "high",
      "category": "structuredData",
      "titleKey": "rec.add_canonical_url.title",
      "descriptionKey": "rec.add_canonical_url.description",
      "howToKey": "rec.add_canonical_url.howto",
      "effort": "quick-win",
      "estimatedImpact": 3,
      "checkScore": 0,
      "checkDetails": "No canonical URL"
    },
    {
      "id": "remove_inline_styles",
      "priority": "medium",
      "category": "contentEfficiency",
      "titleKey": "rec.remove_inline_styles.title",
      "descriptionKey": "rec.remove_inline_styles.description",
      "howToKey": "rec.remove_inline_styles.howto",
      "effort": "moderate",
      "estimatedImpact": 3,
      "checkScore": 50,
      "checkDetails": "1/30 elements with inline styles (3.3%)"
    }
  ],
  "llmsTxtPreview": "# rivalr.app\n\n> Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.\n\n## Main\n- [Rivalr — Find Players & Join Activity Groups Near You](https://www.rivalr.app/): Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one…\n\n",
  "llmsTxtExisting": "<!doctype html>\n<html lang=\"en\">\n  <head>\n    <meta charset=\"UTF-8\" />\n    <link rel=\"icon\" type=\"image/svg+xml\" href=\"/favicon.svg\" />\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n    <meta name=\"description\" content=\"Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.\" />\n\n    <!-- Open Graph -->\n    <meta property=\"og:type\" content=\"website\" />\n    <meta property=\"og:url\" content=\"https://www.rivalr.app/\" />\n    <meta property=\"og:title\" content=\"Rivalr — Find Players &amp; Join Activity Groups\" />\n    <meta property=\"og:description\" content=\"Connect with people for football, basketball, padel, concerts, dinners, hikes and more. Post open spots or join an existing group — no group chat needed.\" />\n    <meta property=\"og:image\" content=\"https://www.rivalr.app/og-image.png\" />\n    <meta property=\"og:image:width\" content=\"1200\" />\n    <meta property=\"og:image:height\" content=\"630\" />\n    <meta property=\"og:image:alt\" content=\"Rivalr — Find Players &amp; Join Activity Groups\" />\n    <meta property=\"og:site_name\" content=\"Rivalr\" />\n\n    <!-- Twitter Card -->\n    <meta name=\"twitter:card\" content=\"summary_large_image\" />\n    <meta name=\"twitter:title\" content=\"Rivalr — Find Players &amp; Join Activity Groups\" />\n    <meta name=\"twitter:description\" content=\"Connect with people for football, basketball, padel, concerts, dinners, hikes and more. Post open spots or join an existing group — no group chat needed.\" />\n    <meta name=\"twitter:image\" content=\"https://www.rivalr.app/og-image.png\" />\n\n    <title>Rivalr — Find Players &amp; Join Activity Groups Near You</title>\n\n    <!-- Schema.org JSON-LD -->\n    <script type=\"application/ld+json\">\n    {\n      \"@context\": \"https://schema.org\",\n      \"@graph\": [\n        {\n          \"@type\": \"Organization\",\n          \"@id\": \"https://www.rivalr.app/#organization\",\n          \"name\": \"Rivalr\",\n          \"url\": \"https://www.rivalr.app/\",\n          \"logo\": {\n            \"@type\": \"ImageObject\",\n            \"url\": \"https://www.rivalr.app/og-image.png\",\n            \"width\": 1200,\n            \"height\": 630\n          },\n          \"description\": \"Rivalr connects people for shared activities — football, basketball, padel, concerts, dinners, hikes and more.\"\n        },\n        {\n          \"@type\": \"WebSite\",\n          \"@id\": \"https://www.rivalr.app/#website\",\n          \"url\": \"https://www.rivalr.app/\",\n          \"name\": \"Rivalr\",\n          \"publisher\": { \"@id\": \"https://www.rivalr.app/#organization\" }\n        },\n        {\n          \"@type\": \"SoftwareApplication\",\n          \"@id\": \"https://www.rivalr.app/#app\",\n          \"name\": \"Rivalr\",\n          \"operatingSystem\": [\"iOS\", \"Android\"],\n          \"applicationCategory\": \"SocialNetworkingApplication\",\n          \"description\": \"Find players for football, basketball, padel and tennis. Join concerts, dinners and hikes. Post open spots or claim one — free, no group chat needed.\",\n          \"offers\": {\n            \"@type\": \"Offer\",\n            \"price\": \"0\",\n            \"priceCurrency\": \"EUR\"\n          },\n          \"url\": \"https://www.rivalr.app/\"\n        }\n      ]\n    }\n    </script>\n\n    <link rel=\"preconnect\" href=\"https://fonts.googleapis.com\" />\n    <link rel=\"preconnect\" href=\"https://fonts.gstatic.com\" crossorigin />\n    <link href=\"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=DM+Serif+Display:ital@0;1&display=swap\" rel=\"stylesheet\" />\n    <script type=\"module\" crossorigin src=\"/assets/index-DekaQV6t.js\"></script>\n    <link rel=\"stylesheet\" crossorigin href=\"/assets/index-Bv57ANoo.css\">\n  </head>\n  <body style=\"background:#0B0F19;color:#F1F5F9\">\n    <div id=\"root\"></div>\n    <noscript>\n      <h1>Find Players &amp; Join Activity Groups Near You</h1>\n      <p>Rivalr connects you with people for football, basketball, padel, tennis, concerts, dinners, hiking and more. Post open spots or join an existing group — no group chat needed.</p>\n      <nav aria-label=\"Activity pages\">\n        <a href=\"/activities/football/athens/\">Football in Athens</a>\n        <a href=\"/activities/basketball/athens/\">Basketball in Athens</a>\n        <a href=\"/activities/padel/athens/\">Padel in Athens</a>\n        <a href=\"/activities/tennis/athens/\">Tennis in Athens</a>\n        <a href=\"/activities/concert/athens/\">Concerts in Athens</a>\n        <a href=\"/activities/hiking/athens/\">Hiking in Athens</a>\n        <a href=\"/activities/dinner/athens/\">Dinner in Athens</a>\n        <a href=\"/activities/football/thessaloniki/\">Football in Thessaloniki</a>\n        <a href=\"/activities/basketball/thessaloniki/\">Basketball in Thessaloniki</a>\n        <a href=\"/activities/padel/thessaloniki/\">Padel in Thessaloniki</a>\n      </nav>\n    </noscript>\n    <!-- WebMCP: expose Rivalr tools to AI agents via the browser -->\n    <script>\n      (function () {\n        if (!navigator.modelContext || typeof navigator.modelContext.registerTool !== 'function') return;\n        const ac = new AbortController();\n        const BASE = 'https://api.rivalr.app';\n\n        navigator.modelContext.registerTool({\n          name: 'rivalr_list_postings',\n          description: 'List open match postings and pickup game slots on Rivalr, optionally filtered by activity type, city, or date.',\n          inputSchema: {\n            type: 'object',\n            properties: {\n              activity: { type: 'string', description: 'Activity type, e.g. football, basketball, padel, tennis, concert, dinner, hiking' },\n              city: { type: 'string', description: 'City name, e.g. athens, thessaloniki' },\n              date: { type: 'string', format: 'date', description: 'ISO 8601 date to filter by' }\n            }\n          },\n          execute: async ({ activity, city, date } = {}) => {\n            const params = new URLSearchParams();\n            if (activity) params.set('activity', activity);\n            if (city) params.set('city', city);\n            if (date) params.set('date', date);\n            const res = await fetch(`${BASE}/postings?${params}`);\n            return res.json();\n          },\n          signal: ac.signal\n        });\n\n        navigator.modelContext.registerTool({\n          name: 'rivalr_get_posting',\n          description: 'Get full details about a specific Rivalr match posting including spots left, date, venue, and participants.',\n          inputSchema: {\n            type: 'object',\n            required: ['id'],\n            properties: {\n              id: { type: 'string', description: 'Match posting ID' }\n            }\n          },\n          execute: async ({ id }) => {\n            const res = await fetch(`${BASE}/postings/${encodeURIComponent(id)}`);\n            return res.json();\n          },\n          signal: ac.signal\n        });\n\n        navigator.modelContext.registerTool({\n          name: 'rivalr_list_venues',\n          description: 'List sports venues on Rivalr with location, supported activities, and availability.',\n          inputSchema: {\n            type: 'object',\n            properties: {\n              city: { type: 'string', description: 'City name to filter venues' },\n              activity: { type: 'string', description: 'Activity type supported by the venue' }\n            }\n          },\n          execute: async ({ city, activity } = {}) => {\n            const params = new URLSearchParams();\n            if (city) params.set('city', city);\n            if (activity) params.set('activity', activity);\n            const res = await fetch(`${BASE}/venues?${params}`);\n            return res.json();\n          },\n          signal: ac.signal\n        });\n\n        window.addEventListener('unload', () => ac.abort(), { once: true });\n      })();\n    </script>\n  </body>\n</html>",
  "emergingProtocols": {
    "oauthDiscovery": {
      "exists": false,
      "url": "https://www.rivalr.app/.well-known/oauth-authorization-server"
    },
    "mcpServerCard": {
      "exists": false,
      "url": "https://www.rivalr.app/.well-known/mcp.json"
    },
    "a2aAgentCard": {
      "exists": false,
      "url": "https://www.rivalr.app/.well-known/agent.json"
    },
    "count": 0
  },
  "snippets": [
    {
      "id": "fix_heading_hierarchy",
      "title": "Fix heading hierarchy",
      "description": "Your page has no <h1>. Every page needs exactly one <h1> as the main heading. Add it inside your <main> or <article>.",
      "language": "html",
      "code": "<h1>Rivalr — Find Players & Join Activity Groups Near You</h1>",
      "filename": "<main> or <article>"
    },
    {
      "id": "add_canonical_url",
      "title": "Add canonical URL",
      "description": "The canonical URL tells AI agents which version of the page is the \"official\" one, avoiding duplicate content issues.",
      "language": "html",
      "code": "<link rel=\"canonical\" href=\"https://www.rivalr.app/\">",
      "filename": "<head>"
    },
    {
      "id": "add_sitemap",
      "title": "Create /sitemap.xml",
      "description": "A sitemap helps AI agents discover all your pages. Most CMS platforms generate one automatically.",
      "language": "xml",
      "code": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<urlset xmlns=\"http://www.sitemaps.org/schemas/sitemap/0.9\">\n  <url>\n    <loc>https://www.rivalr.app/</loc>\n    <lastmod>2026-05-14</lastmod>\n  </url>\n</urlset>",
      "filename": "/sitemap.xml"
    },
    {
      "id": "add_article_main",
      "title": "Wrap content in <main> and <article>",
      "description": "Semantic HTML landmarks help AI agents identify the main content of your page.",
      "language": "html",
      "code": "<main>\n  <article>\n    <h1>Your Page Title</h1>\n    <p>Your content here...</p>\n  </article>\n</main>",
      "filename": "<body>"
    },
    {
      "id": "add_markdown_negotiation",
      "title": "Support Markdown for Agents",
      "description": "Let AI agents request a clean Markdown version of any page via content negotiation, .md alternate URLs, link tags or Link headers.",
      "language": "html",
      "code": "<!-- Mechanism 3: link tag advertising the .md alternate -->\n<link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">",
      "filename": "<head>",
      "stacks": [
        {
          "id": "html",
          "label": "HTML <head>",
          "language": "html",
          "filename": "<head>",
          "code": "<!-- Mechanism 3: link tag advertising the .md alternate -->\n<link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">"
        },
        {
          "id": "express",
          "label": "Express",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Mechanisms 1 + 4: content negotiation + Link header\napp.get('/page', (req, res) => {\n  res.setHeader('Vary', 'Accept');\n  res.setHeader('Link', '</page.md>; rel=\"alternate\"; type=\"text/markdown\"');\n  if ((req.headers.accept || '').includes('text/markdown')) {\n    res.type('text/markdown; charset=utf-8');\n    return res.send(renderMarkdown('page'));\n  }\n  res.render('page');\n});"
        },
        {
          "id": "fastify",
          "label": "Fastify",
          "language": "javascript",
          "filename": "server.js",
          "code": "// Mechanisms 1 + 4: content negotiation + Link header\nfastify.get('/page', async (req, reply) => {\n  reply.header('Vary', 'Accept');\n  reply.header('Link', '</page.md>; rel=\"alternate\"; type=\"text/markdown\"');\n  if ((req.headers.accept || '').includes('text/markdown')) {\n    return reply.type('text/markdown; charset=utf-8').send(renderMarkdown('page'));\n  }\n  return reply.view('/page.ejs');\n});"
        },
        {
          "id": "nextjs",
          "label": "Next.js",
          "language": "typescript",
          "filename": "app/page/route.ts",
          "code": "// Next.js App Router — Route Handler returning Markdown\nimport { NextRequest } from 'next/server';\nimport { renderMarkdown } from '@/lib/md';\nexport async function GET(req: NextRequest) {\n  const accept = req.headers.get('accept') || '';\n  if (accept.includes('text/markdown')) {\n    return new Response(await renderMarkdown('page'), {\n      headers: {\n        'Content-Type': 'text/markdown; charset=utf-8',\n        'Vary': 'Accept',\n      },\n    });\n  }\n  // Fall through to the page component\n  return new Response(null, { status: 404 });\n}"
        },
        {
          "id": "wordpress",
          "label": "WordPress",
          "language": "php",
          "filename": "functions.php",
          "code": "<?php\n// Mechanism 1: respond to Accept: text/markdown on the same URL\nadd_action('template_redirect', function () {\n    if (!is_singular()) return;\n    $accept = $_SERVER['HTTP_ACCEPT'] ?? '';\n    if (strpos($accept, 'text/markdown') === false) return;\n    header('Content-Type: text/markdown; charset=utf-8');\n    header('Vary: Accept');\n    $post = get_queried_object();\n    echo \"# \" . get_the_title($post) . \"\\n\\n\";\n    echo wp_strip_all_tags(apply_filters('the_content', $post->post_content));\n    exit;\n});"
        },
        {
          "id": "static",
          "label": "Hugo / Jekyll / Astro",
          "language": "txt",
          "filename": "static/page.md",
          "code": "# Mechanism 2: serve .md alongside .html\n# Hugo: place page.md in /static/ — built unchanged\n# Jekyll: drop page.md in /assets/ — copied as-is\n# Astro: src/pages/page.md.ts that exports a GET returning markdown\n\n# Then advertise with mechanism 3 in <head>:\n#   <link rel=\"alternate\" type=\"text/markdown\" href=\"/page.md\">"
        }
      ]
    }
  ]
}

APIを使用してプログラムで取得できます(近日公開)

このJSONは内部使用向けです — MarkdownやllMs.txtファイルとは異なり、サイトにアップロードするものではありません。スコアの経時変化を追跡するための基準値として保存するか、開発チームと共有するか、CI/CDパイプラインに統合してください。

結果を共有

Twitter LinkedIn

バッジを埋め込む

このバッジをサイトに追加してください。AI対応スコアが変わると自動的に更新されます。

AgentReady.md score for www.rivalr.app
Script 推奨
<script src="https://agentready.md/badge.js" data-id="869e97d4-81ec-4e34-948b-49149a42d94e" data-domain="www.rivalr.app"></script>
Markdown
[![AgentReady.md score for www.rivalr.app](https://agentready.md/badge/www.rivalr.app.svg)](https://agentready.md/ja/r/869e97d4-81ec-4e34-948b-49149a42d94e)

近日公開: ドメイン全体分析

ドメイン全体をクロールし、llms.txtを生成し、AI対応スコアを経時的にモニタリング。ウェイトリストに登録して通知を受け取りましょう。

リストに登録されました!サービス開始時にお知らせします。