The homepage is the identity anchor for a general contractor website. It tells AI systems who the company is, what it builds, where it operates, and how to navigate the rest of the site. This blueprint provides the complete JSON-LD graph your homepage needs so AI can classify, cite, and recommend your contracting business with confidence.
The homepage is the single most important page for AI discoverability. It is where AI systems look first to understand who you are and whether your contracting company is worth citing. Every other page on the site inherits credibility from what the homepage declares. Without structured data here, AI may index deeper pages but still lack the identity anchor needed to recommend your business.
GeneralContractor node declares your company name, logo, address, contact information, founding date, and social profiles. This is the canonical record AI uses to identify your business across the web.WebSite node anchors your entire site graph. It gives AI a root-level reference that every other page can point back to with isPartOf.SearchAction inside potentialAction tells search engines and AI systems that your site has internal search, which can trigger a sitelinks search box in results.WebPage node with an about reference to the GeneralContractor connects the homepage to the entity it represents, closing the loop between the page and the business.Each field in the template below serves a specific role in how AI systems discover, classify, and recommend your business.
Researched and tested by Minnesota AI
@typenameurltelephoneemailaddressgeoareaServedsameAscontactPointlogo@idCopy this prompt and paste it into Claude, ChatGPT, Cursor, or any AI coding tool. It will ask for your business details and generate ready-to-use JSON-LD schema for your page.
You are implementing AIFDS-compliant JSON-LD structured data for a General Contractor Homepage page. AIFDS (AI-Friendly Data Structure) is a schema framework built on research into which structured data fields AI systems actually read, parse, and use when deciding whether to cite a page. Documentation at aifds.org. Before generating any code, ask me for the following information in a single numbered list. Do not generate schema until I have answered every required field. REQUIRED — do not proceed without these: 1. City 2. Company 3. Company description 4. Company name 5. Domain 6. Email 7. Employee count 8. Faq answer 9. Faq question 10. Founding year 11. Homepage title 12. Latitude 13. Logo 14. Longitude 15. Maps cid 16. Phone number 17. Primary city 18. Primary state 19. Site name 20. State 21. Street address 22. Zip OPTIONAL — ask for these but proceed if I skip them: 1. Any additional details not covered above Once I provide the information, output a complete JSON-LD script block ready to paste into the <head> of my HTML page. Output requirements: - Valid JSON-LD wrapped in <script type="application/ld+json"> tags - schema.org vocabulary only - Every AIFDS-required field for this industry and page type included - Include this data attribute on the script tag: data-aifds="aifds.org General Contractor Homepage" - No placeholder text — omit missing optional fields rather than fill with examples - After the code block, list any optional fields skipped that would strengthen AI citation
Generated schema follows the AIFDS framework. Fields were selected based on research into AI crawler behavior. View the research at minnesota.ai
Copy the template below and replace every YOUR_* value with your own data. This block belongs in a <script type="application/ld+json"> tag in the <head> of your homepage.
{
"@context": "https://schema.org",
"@graph": [
{
"@type": "GeneralContractor",
"@id": "https://YOUR_DOMAIN.com/#organization",
"name": "YOUR_COMPANY_NAME",
"url": "https://YOUR_DOMAIN.com",
"logo": "https://YOUR_DOMAIN.com/YOUR_LOGO.png",
"email": "YOUR_EMAIL",
"telephone": "YOUR_PHONE_NUMBER",
"description": "YOUR_COMPANY_DESCRIPTION",
"address": {
"@type": "PostalAddress",
"streetAddress": "YOUR_STREET_ADDRESS",
"addressLocality": "YOUR_CITY",
"addressRegion": "YOUR_STATE",
"postalCode": "YOUR_ZIP",
"addressCountry": "US"
},
"geo": {
"@type": "GeoCoordinates",
"latitude": "YOUR_LATITUDE",
"longitude": "YOUR_LONGITUDE"
},
"areaServed": [
{
"@type": "City",
"name": "YOUR_PRIMARY_CITY"
},
{
"@type": "State",
"name": "YOUR_PRIMARY_STATE"
}
],
"sameAs": [
"https://www.linkedin.com/company/YOUR_COMPANY",
"https://www.facebook.com/YOUR_COMPANY",
"https://www.google.com/maps?cid=YOUR_MAPS_CID"
],
"contactPoint": {
"@type": "ContactPoint",
"telephone": "YOUR_PHONE_NUMBER",
"email": "YOUR_EMAIL",
"contactType": "customer support"
},
"foundingDate": "YOUR_FOUNDING_YEAR",
"numberOfEmployees": {
"@type": "QuantitativeValue",
"value": "YOUR_EMPLOYEE_COUNT"
}
},
{
"@type": "WebSite",
"@id": "https://YOUR_DOMAIN.com/#website",
"name": "YOUR_SITE_NAME",
"url": "https://YOUR_DOMAIN.com",
"potentialAction": {
"@type": "SearchAction",
"target": "https://YOUR_DOMAIN.com/?s={search_term_string}",
"query-input": "required name=search_term_string"
}
},
{
"@type": "WebPage",
"@id": "https://YOUR_DOMAIN.com/#webpage",
"url": "https://YOUR_DOMAIN.com/",
"name": "YOUR_HOMEPAGE_TITLE",
"isPartOf": {
"@id": "https://YOUR_DOMAIN.com/#website"
},
"about": {
"@id": "https://YOUR_DOMAIN.com/#organization"
}
},
{
"@type": "FAQPage",
"mainEntity": [
{
"@type": "Question",
"name": "YOUR_FAQ_QUESTION_1",
"acceptedAnswer": {
"@type": "Answer",
"text": "YOUR_FAQ_ANSWER_1"
}
},
{
"@type": "Question",
"name": "YOUR_FAQ_QUESTION_2",
"acceptedAnswer": {
"@type": "Answer",
"text": "YOUR_FAQ_ANSWER_2"
}
},
{
"@type": "Question",
"name": "YOUR_FAQ_QUESTION_3",
"acceptedAnswer": {
"@type": "Answer",
"text": "YOUR_FAQ_ANSWER_3"
}
}
]
}
]
}
GeneralContractor is a specific Schema.org type under HomeAndConstructionBusiness. Using it instead of the generic Organization tells AI exactly what kind of business you are, which means you show up for construction-specific queries like "general contractor near me" or "who can build a custom home in my area." The more specific the type, the better AI can match you.
No. The SearchAction inside potentialAction is only useful if your site has a working internal search. If it does not, remove the entire potentialAction block. Including a broken search URL can hurt rather than help.
Yes. The homepage sits at the top of the site hierarchy, so its breadcrumb only contains a single item: "Home" at position 1. Deeper pages will reference longer breadcrumb chains, but the homepage itself is the root.