Payload CMS MCP Server
- public
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Google tag (gtag.js) -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-NNP8YC3GX8"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-NNP8YC3GX8');
</script>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>PAYLOAD CMS MCP SERVER | Matmax Worldwide</title>
<meta name="description" content="PAYLOAD CMS MCP SERVER - A powerful headless CMS built with Node.js, Express, MongoDB, and React.">
<meta name="keywords" content="Payload CMS 3.0, MCP, Model Context Protocol, AI agent, developer guidelines, structure validation, best practices, Cursor IDE, AI-assisted development">
<meta name="author" content="MATMAX WORLDWIDE">
<meta name="robots" content="index, follow">
<!-- Open Graph / Facebook -->
<meta property="og:type" content="website">
<meta property="og:url" content="https://www.payloadcmsmcp.info/">
<meta property="og:title" content="Payload CMS MCP Server - Validation & Query Service">
<meta property="og:description" content="Enhance your Payload CMS development with real-time validation, suggestions, and AI-assisted development.">
<meta property="og:image" content="https://www.payloadcmsmcp.info/og-image.jpg">
<!-- Twitter -->
<meta property="twitter:card" content="summary_large_image">
<meta property="twitter:url" content="https://www.payloadcmsmcp.info/">
<meta property="twitter:title" content="Payload CMS MCP Server - Validation & Query Service">
<meta property="twitter:description" content="Enhance your Payload CMS development with real-time validation, suggestions, and AI-assisted development.">
<meta property="twitter:image" content="https://www.payloadcmsmcp.info/og-image.jpg">
<!-- Canonical URL -->
<link rel="canonical" href="https://www.payloadcmsmcp.info/">
<link rel="icon" href="/logopayload.png" type="image/png">
<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=Inter:wght@300;400;500;600;700&display=swap" rel="stylesheet">
<!-- JSON-LD Structured Data -->
<script type="application/ld+json">
{
"@context": "https://schema.org",
"@type": "SoftwareApplication",
"name": "Payload CMS 3.0 MCP Server",
"applicationCategory": "DeveloperApplication",
"operatingSystem": "Any",
"offers": {
"@type": "Offer",
"price": "0",
"priceCurrency": "USD"
},
"description": "A specialized MCP server for Payload CMS 3.0, ensuring AI agents follow developer guidelines, respect structure, and adhere to best practices.",
"creator": {
"@type": "Organization",
"name": "MATMAX WORLDWIDE",
"url": "https://matmax.world",
"logo": "https://www.payloadcmsmcp.info/00Matmax-world-logo-_1_-svg.png"
},
"url": "https://www.payloadcmsmcp.info/",
"image": "https://www.payloadcmsmcp.info/00Matmax-world-logo-_1_-svg.png",
"sameAs": [
"https://github.com/Matmax-Worldwide/payloadcmsmcp",
"https://payload-cms-mcp-production.up.railway.app"
]
}
</script>
<style>
:root {
--primary: #5046e5;
--primary-light: #6a62ff;
--secondary: #2a2a2a;
--accent: #ff6b6b;
--light: #f5f5f7;
--dark: #121212;
--gray: #888;
--border-radius: 12px;
--box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1);
--transition: all 0.3s ease;
--primary-color: #6366f1;
--primary-hover: #4f46e5;
--secondary-color: #0ea5e9;
--text-color: #1e293b;
--light-text: #64748b;
--bg-color: #ffffff;
--light-bg: #f8fafc;
--border-color: #e2e8f0;
--radius: 8px;
--shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
}
html {
scroll-behavior: smooth;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Inter', sans-serif;
line-height: 1.6;
color: var(--secondary);
background-color: var(--light);
overflow-x: hidden;
}
.container {
width: 100%;
max-width: 1200px;
margin: 0 auto;
padding: 0 2rem;
}
header {
background-color: var(--dark);
color: white;
padding: 1.5rem 0;
position: sticky;
top: 0;
z-index: 100;
box-shadow: var(--box-shadow);
}
.header-content {
display: flex;
justify-content: space-between;
align-items: center;
position: relative;
}
.logo {
font-size: 1.5rem;
font-weight: 700;
color: white;
text-decoration: none;
display: flex;
align-items: center;
gap: 1rem;
z-index: 1001;
position: relative;
transition: all 0.3s ease;
}
.logo:hover .logo-icon {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
.logo-image {
width: 60px;
height: 60px;
border-radius: 10px;
box-shadow: 0 3px 10px rgba(0, 0, 0, 0.25);
transition: all 0.3s ease;
object-fit: contain;
background-color: white;
padding: 5px;
animation: subtle-pulse 3s ease-in-out infinite;
flex-shrink: 0;
display: block;
}
.logo-text {
display: inline-block;
white-space: nowrap;
overflow: visible;
text-overflow: unset;
max-width: none;
transition: all 0.3s ease;
line-height: 1.1;
}
.version-text {
display: inline-block;
margin-left: 3px;
}
@keyframes subtle-pulse {
0% { transform: scale(1); }
50% { transform: scale(1.05); }
100% { transform: scale(1); }
}
.logo:hover .logo-image {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
animation: none;
}
.logo-icon {
background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
width: 40px;
height: 40px;
border-radius: 10px;
display: flex;
align-items: center;
justify-content: center;
font-weight: bold;
box-shadow: 0 3px 10px rgba(0, 0, 0, 0.25);
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
letter-spacing: -0.5px;
position: relative;
overflow: hidden;
transition: all 0.3s ease;
}
.logo-icon::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
transition: 0.5s;
}
.logo:hover .logo-icon::before {
left: 100%;
}
nav ul {
display: flex;
list-style: none;
gap: 2rem;
}
nav a {
color: white;
text-decoration: none;
font-weight: 500;
transition: var(--transition);
position: relative;
}
nav a:hover {
color: var(--primary-light);
}
nav a::after {
content: '';
position: absolute;
bottom: -5px;
left: 0;
width: 0;
height: 2px;
background-color: var(--primary-light);
transition: var(--transition);
}
nav a:hover::after {
width: 100%;
}
.github-link {
display: flex;
align-items: center;
gap: 5px;
}
.nav-icon {
filter: invert(1);
transition: var(--transition);
}
.github-link:hover .nav-icon {
filter: invert(0.7) sepia(1) saturate(5) hue-rotate(175deg);
}
/* Hero Section */
.hero {
background: linear-gradient(135deg, #4f46e5 0%, #0ea5e9 100%);
color: white;
padding: 6rem 0;
text-align: center;
}
.hero-content {
max-width: 800px;
margin: 0 auto;
}
.hero h1 {
font-size: 3.5rem;
margin-bottom: 1.5rem;
font-weight: 700;
}
.hero p {
font-size: 1.5rem;
margin-bottom: 2.5rem;
opacity: 0.9;
line-height: 1.6;
}
.hero-buttons {
display: flex;
gap: 1rem;
justify-content: center;
}
.btn {
display: inline-block;
padding: 0.75rem 1.5rem;
border-radius: var(--radius);
font-weight: 600;
text-decoration: none;
transition: var(--transition);
cursor: pointer;
}
.btn-primary {
background-color: white;
color: var(--primary-color);
}
.btn-primary:hover {
background-color: #f8fafc;
transform: translateY(-2px);
}
.btn-secondary {
background-color: rgba(255, 255, 255, 0.15);
color: white;
backdrop-filter: blur(4px);
}
.btn-secondary:hover {
background-color: rgba(255, 255, 255, 0.25);
transform: translateY(-2px);
}
@media (max-width: 768px) {
.hero h1 {
font-size: 2.5rem;
}
.hero p {
font-size: 1.2rem;
}
.hero-buttons {
flex-direction: column;
align-items: center;
width: 100%;
max-width: 300px;
margin: 0 auto;
}
.btn {
width: 100%;
text-align: center;
margin-bottom: 0.5rem;
}
.logo-image {
width: 50px;
height: 50px;
padding: 4px;
margin-right: 2px;
}
}
.features {
padding: 5rem 0;
background-color: white;
}
.section-title {
text-align: center;
margin-bottom: 3rem;
}
.section-title h2 {
font-size: 2.5rem;
margin-bottom: 1rem;
color: var(--dark);
}
.section-title p {
color: var(--gray);
max-width: 700px;
margin: 0 auto;
}
.features-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 2rem;
}
.feature-card {
background-color: white;
border-radius: var(--border-radius);
padding: 2rem;
box-shadow: var(--box-shadow);
transition: var(--transition);
height: 100%;
display: flex;
flex-direction: column;
}
.feature-card:hover {
transform: translateY(-5px);
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}
.feature-icon {
width: 60px;
height: 60px;
background-color: var(--primary);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 1.5rem;
color: white;
font-size: 1.5rem;
}
.feature-card h3 {
font-size: 1.5rem;
margin-bottom: 1rem;
color: var(--dark);
}
.feature-card p {
margin-bottom: 0;
flex-grow: 1;
}
/* Tools Section Styles */
.tools-section {
padding: 5rem 0;
background-color: var(--light);
}
.tools-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 2rem;
}
.tool-card {
background-color: white;
border-radius: var(--radius);
padding: 2rem;
box-shadow: var(--shadow);
transition: var(--transition);
height: 100%;
display: flex;
flex-direction: column;
}
.tool-card:hover {
transform: translateY(-5px);
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}
.tool-card h3 {
font-size: 1.5rem;
margin-bottom: 1.5rem;
color: var(--primary-color);
border-bottom: 2px solid var(--border-color);
padding-bottom: 0.75rem;
}
.tool-list {
list-style: none;
padding: 0;
flex-grow: 1;
}
.tool-list li {
margin-bottom: 1rem;
padding-left: 1.5rem;
position: relative;
line-height: 1.5;
}
.tool-list li::before {
content: "→";
position: absolute;
left: 0;
color: var(--primary-color);
font-weight: bold;
}
.tool-name {
font-family: 'Courier New', monospace;
color: var(--primary-color);
font-weight: 600;
}
@media (max-width: 768px) {
.tools-grid {
grid-template-columns: 1fr;
}
}
.api-section {
padding: 5rem 0;
background-color: var(--light-bg);
}
.api-container {
display: flex;
flex-direction: column;
gap: 2rem;
}
.api-card {
background-color: white;
border-radius: var(--border-radius);
padding: 2rem;
box-shadow: var(--box-shadow);
}
.api-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 1.5rem;
padding-bottom: 1rem;
border-bottom: 1px solid #eee;
}
.api-name {
font-size: 1.25rem;
font-weight: 600;
color: var(--dark);
}
.api-method {
background-color: var(--primary);
color: white;
padding: 0.25rem 0.75rem;
border-radius: 20px;
font-size: 0.875rem;
font-weight: 600;
}
.api-description {
margin-bottom: 1.5rem;
color: var(--gray);
}
.api-url {
background-color: #f5f5f7;
padding: 1rem;
border-radius: 8px;
font-family: monospace;
overflow-x: auto;
margin-bottom: 1rem;
}
.about-section {
background-color: var(--light-bg);
padding: 5rem 0;
}
.about-content {
display: flex;
align-items: center;
gap: 4rem;
}
.about-image {
flex: 1;
border-radius: var(--border-radius);
overflow: hidden;
box-shadow: var(--box-shadow);
}
.about-image img {
width: 100%;
height: auto;
display: block;
max-width: 100%;
object-fit: contain;
}
.about-text {
flex: 1;
}
.about-text h2 {
font-size: 2.5rem;
margin-bottom: 1.5rem;
color: var(--dark);
}
.about-text p {
margin-bottom: 1.5rem;
color: var(--gray);
}
footer {
background-color: var(--dark);
color: white;
padding: 4rem 0 2rem;
}
.footer-content {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 3rem;
margin-bottom: 3rem;
}
.footer-column h3 {
font-size: 1.25rem;
margin-bottom: 1.5rem;
color: white;
}
.footer-column ul {
list-style: none;
}
.footer-column ul li {
margin-bottom: 0.75rem;
}
.footer-column a {
color: #ccc;
text-decoration: none;
transition: var(--transition);
}
.footer-column a:hover {
color: var(--primary-light);
}
.footer-bottom {
text-align: center;
padding-top: 2rem;
border-top: 1px solid #333;
color: #888;
}
.footer-bottom p {
margin-bottom: 1rem;
}
.social-links {
display: flex;
justify-content: center;
gap: 1.5rem;
margin-top: 1rem;
}
.social-links a {
color: #ccc;
font-size: 1.25rem;
transition: var(--transition);
display: flex;
align-items: center;
justify-content: center;
width: 40px;
height: 40px;
border-radius: 50%;
background-color: rgba(255, 255, 255, 0.1);
}
.social-links a:hover {
color: var(--primary-light);
background-color: rgba(255, 255, 255, 0.2);
transform: translateY(-3px);
}
.social-icon {
filter: invert(0.8);
transition: var(--transition);
}
.social-links a:hover .social-icon {
filter: invert(0.5) sepia(1) saturate(5) hue-rotate(175deg);
}
@media (max-width: 768px) {
.header-content {
flex-direction: row;
justify-content: space-between;
align-items: center;
padding: 0.5rem 0;
}
.logo {
font-size: 1.2rem;
gap: 0.5rem;
align-items: center;
max-width: 65%;
}
.logo-image {
width: 50px;
height: 50px;
padding: 4px;
margin-right: 2px;
}
.logo span {
font-size: 0.85rem;
}
.logo-text {
max-width: none;
line-height: 1.1;
font-size: 0.85rem;
}
.version-text {
margin-left: 1px;
font-size: 0.8rem;
}
nav ul {
gap: 1rem;
flex-wrap: wrap;
justify-content: center;
}
.hero h1 {
font-size: 2.5rem;
}
.about-content {
flex-direction: column;
gap: 2rem;
}
.btn-secondary {
margin-left: 0;
margin-top: 1rem;
}
}
/* Setup Section Styles */
.setup-section {
padding: 5rem 0;
background: linear-gradient(to bottom right, #f1f5f9, #e2e8f0);
}
.section-title {
text-align: center;
margin-bottom: 3rem;
}
.section-title h2 {
font-size: 2.5rem;
color: var(--text-color);
margin-bottom: 1rem;
}
.section-title p {
font-size: 1.2rem;
color: var(--light-text);
max-width: 700px;
margin: 0 auto;
}
.setup-steps {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 2rem;
}
.setup-step {
background-color: var(--bg-color);
border-radius: var(--radius);
padding: 2rem;
box-shadow: var(--shadow);
position: relative;
transition: var(--transition);
height: 100%;
display: flex;
flex-direction: column;
}
.setup-step:hover {
transform: translateY(-5px);
box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
}
.step-number {
position: absolute;
top: -15px;
left: -15px;
width: 40px;
height: 40px;
background-color: var(--primary-color);
color: white;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-weight: bold;
font-size: 1.2rem;
box-shadow: var(--shadow);
z-index: 1;
}
.setup-step h3 {
margin-top: 0.5rem;
margin-bottom: 1rem;
color: var(--primary-color);
font-size: 1.5rem;
}
.setup-step p {
margin-bottom: 1rem;
line-height: 1.6;
}
.setup-step p + .code-block {
margin-top: 0.5rem;
}
.setup-step p + p {
margin-top: 1.5rem;
}
.setup-step p, .setup-step li {
color: var(--text-color);
margin-bottom: 0.5rem;
line-height: 1.6;
}
.setup-step ul, .setup-step ol {
padding-left: 1.5rem;
margin-bottom: 1.5rem;
}
.setup-step li {
margin-bottom: 0.5rem;
}
.code-block {
background-color: #1e293b;
border-radius: var(--radius);
padding: 1rem;
margin: 1rem 0;
overflow-x: auto;
position: relative;
}
.code-block code {
display: block;
color: #e2e8f0;
font-family: 'Courier New', monospace;
line-height: 1.5;
white-space: pre;
margin: 0.25rem 0;
font-size: 0.9rem;
}
/* Responsive adjustments for Getting Started section */
@media (max-width: 1200px) {
.setup-steps {
grid-template-columns: repeat(2, 1fr);
}
}
@media (max-width: 900px) {
.setup-steps {
grid-template-columns: 1fr;
max-width: 600px;
margin: 0 auto;
}
.setup-step {
margin-bottom: 2rem;
padding: 1.75rem 1.5rem;
}
.step-number {
top: -12px;
left: -12px;
width: 35px;
height: 35px;
font-size: 1.1rem;
}
.setup-step h3 {
font-size: 1.4rem;
margin-bottom: 0.8rem;
}
.code-block {
padding: 0.8rem;
margin: 0.8rem 0;
}
.code-block code {
font-size: 0.85rem;
line-height: 1.4;
}
.setup-step ul, .setup-step ol {
padding-left: 1.2rem;
}
}
@media (max-width: 480px) {
.setup-step {
padding: 1.5rem 1.2rem;
margin-bottom: 1.5rem;
border-radius: 8px;
}
.step-number {
top: -10px;
left: -10px;
width: 30px;
height: 30px;
font-size: 1rem;
}
.setup-step h3 {
font-size: 1.3rem;
margin-bottom: 0.7rem;
padding-left: 0.5rem;
}
.setup-step p, .setup-step li {
font-size: 0.95rem;
}
.code-block {
padding: 0.7rem;
margin: 0.7rem 0;
border-radius: 6px;
}
.code-block code {
font-size: 0.8rem;
line-height: 1.3;
}
.setup-step ul, .setup-step ol {
padding-left: 1rem;
}
.setup-step li {
margin-bottom: 0.7rem;
}
.logo-image {
width: 45px;
height: 45px;
padding: 3px;
margin-right: 0;
}
}
.command-examples {
list-style: none;
padding: 0;
}
.command-examples li {
margin-bottom: 1rem;
padding: 0.75rem 1rem;
background-color: #f5f7fa;
border-radius: var(--radius);
color: var(--text-color);
font-family: 'Courier New', monospace;
border-left: 3px solid var(--primary-color);
transition: var(--transition);
}
.command-examples li:hover {
background-color: #eef2f7;
transform: translateX(5px);
}
@media (max-width: 480px) {
.command-examples li {
padding: 0.6rem 0.8rem;
font-size: 0.85rem;
margin-bottom: 0.8rem;
border-radius: 4px;
}
}
/* Mobile Navigation */
.mobile-nav-toggle {
display: none;
background: none;
border: none;
cursor: pointer;
padding: 0.5rem;
z-index: 1001;
position: absolute;
right: 0;
top: 50%;
transform: translateY(-50%);
width: 44px;
height: 44px;
border-radius: 50%;
transition: all 0.3s ease;
background-color: transparent;
box-shadow: none;
}
.mobile-nav-toggle:hover {
background-color: rgba(255, 255, 255, 0.1);
}
.mobile-nav-toggle:active {
transform: translateY(-50%) scale(0.95);
}
/* Classic hamburger icon */
.hamburger-icon {
width: 24px;
height: 18px;
position: relative;
margin: 0 auto;
transform: rotate(0deg);
transition: .5s ease-in-out;
}
.hamburger-icon span {
display: block;
position: absolute;
height: 2px;
width: 100%;
background: white;
border-radius: 4px;
opacity: 1;
left: 0;
transform: rotate(0deg);
transition: .25s ease-in-out;
}
.hamburger-icon span:nth-child(1) {
top: 0px;
width: 80%;
right: 0;
left: auto;
}
.hamburger-icon span:nth-child(2) {
top: 8px;
}
.hamburger-icon span:nth-child(3) {
top: 16px;
width: 80%;
right: 0;
left: auto;
}
.mobile-nav-toggle.active .hamburger-icon span:nth-child(1) {
top: 8px;
transform: rotate(135deg);
width: 100%;
left: 0;
}
.mobile-nav-toggle.active .hamburger-icon span:nth-child(2) {
opacity: 0;
left: -60px;
}
.mobile-nav-toggle.active .hamburger-icon span:nth-child(3) {
top: 8px;
transform: rotate(-135deg);
width: 100%;
left: 0;
}
@media (max-width: 768px) {
.mobile-nav-toggle {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.header-content {
padding: 0.5rem 0;
}
nav {
position: fixed;
top: 0;
right: -100%;
width: 80%;
max-width: 300px;
height: 100vh;
background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
padding: 5rem 2rem 2rem;
transition: right 0.4s cubic-bezier(0.77, 0, 0.175, 1);
z-index: 999;
box-shadow: -5px 0 25px rgba(0, 0, 0, 0.3);
overflow-y: auto;
border-left: none;
border-radius: 0 0 0 20px;
}
nav.active {
right: 0;
}
nav ul {
flex-direction: column;
gap: 1.5rem;
align-items: flex-start;
}
nav a {
display: block;
padding: 0.5rem 0;
font-size: 1.1rem;
width: 100%;
color: white;
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
padding-bottom: 0.8rem;
}
nav a:hover {
color: white;
opacity: 0.8;
}
nav a::after {
bottom: 0;
background-color: white;
}
.overlay {
display: none;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.5);
z-index: 998;
backdrop-filter: blur(2px);
transition: opacity 0.3s ease;
opacity: 0;
}
.overlay.active {
display: block;
opacity: 1;
}
}
/* Additional Responsive Breakpoints */
@media (max-width: 480px) {
.container {
padding: 0 1rem;
}
.logo {
font-size: 1rem;
gap: 0.4rem;
align-items: center;
}
.logo-icon {
width: 28px;
height: 28px;
font-size: 0.9rem;
}
.logo-image {
width: 45px;
height: 45px;
padding: 3px;
margin-right: 0;
}
.logo span {
font-size: 0.85rem;
}
.logo-text {
max-width: none;
line-height: 1.1;
font-size: 0.85rem;
}
.mobile-nav-toggle {
width: 36px;
height: 36px;
right: 0.5rem;
}
.mobile-nav-toggle span {
width: 22px;
height: 2px;
}
header {
padding: 0.8rem 0;
}
nav {
width: 85%;
padding: 4.5rem 1.5rem 1.5rem;
}
.hero h1 {
font-size: 2rem;
}
.hero p {
font-size: 1rem;
}
.section-title h2 {
font-size: 2rem;
}
.feature-card, .tool-card, .api-card {
padding: 1.5rem;
}
.footer-content {
grid-template-columns: 1fr;
gap: 2rem;
}
}
@media (min-width: 769px) and (max-width: 1024px) {
.features-grid, .tools-grid, .setup-steps {
grid-template-columns: repeat(2, 1fr);
}
.about-content {
gap: 2rem;
}
}
/* Improved Typography Responsiveness */
@media (max-width: 768px) {
body {
font-size: 15px;
}
.feature-card h3, .tool-card h3, .setup-step h3 {
font-size: 1.3rem;
}
.section-title p {
font-size: 1rem;
}
}
.no-scroll {
overflow: hidden;
}
@media (prefers-reduced-motion: reduce) {
* {
transition: none !important;
animation: none !important;
scroll-behavior: auto !important;
}
}
/* Responsive Images */
img {
max-width: 100%;
height: auto;
}
/* Improved Card Layout for Small Screens */
@media (max-width: 480px) {
.feature-card, .tool-card, .setup-step, .api-card {
padding: 1.5rem;
}
.feature-icon {
width: 50px;
height: 50px;
font-size: 1.25rem;
margin-bottom: 1rem;
}
.feature-card h3, .tool-card h3, .setup-step h3 {
font-size: 1.3rem;
margin-bottom: 0.75rem;
}
.tool-list li, .command-examples li {
font-size: 0.9rem;
}
}
/* Improved Responsive Layout */
@media (max-width: 768px) {
.hero {
padding: 4rem 0;
}
.features, .tools-section, .api-section, .about-section, .setup-section {
padding: 3rem 0;
}
.section-title {
margin-bottom: 2rem;
}
.about-image {
max-width: 300px;
margin: 0 auto;
}
.about-text {
text-align: center;
}
.about-text .btn {
margin: 0 auto;
display: block;
max-width: 200px;
}
/* Improved API cards */
.api-card {
padding: 1.5rem;
}
.api-header {
flex-direction: column;
align-items: flex-start;
gap: 0.5rem;
}
.code-block {
margin: 0.8rem 0;
padding: 0.8rem;
}
.code-block code {
font-size: 0.85rem;
}
}
@media (max-width: 480px) {
.hero {
padding: 3rem 0;
}
.features, .tools-section, .api-section, .about-section, .setup-section {
padding: 2.5rem 0;
}
.btn {
padding: 0.6rem 1.2rem;
font-size: 0.9rem;
}
.feature-icon {
width: 50px;
height: 50px;
font-size: 1.25rem;
margin-bottom: 1rem;
}
.feature-card h3, .tool-card h3, .setup-step h3 {
font-size: 1.3rem;
margin-bottom: 0.75rem;
}
.tool-list li, .command-examples li {
font-size: 0.9rem;
}
footer {
padding: 3rem 0 1.5rem;
}
/* Improved footer for mobile */
.footer-column h3 {
font-size: 1.2rem;
margin-bottom: 1rem;
}
.footer-column ul li {
margin-bottom: 0.6rem;
}
.footer-bottom {
padding-top: 1.5rem;
}
.social-links {
gap: 1.5rem;
}
}
/* Touch-friendly improvements */
@media (hover: none) {
.feature-card:hover, .tool-card:hover, .setup-step:hover {
transform: none;
}
.btn:hover {
transform: none;
}
.command-examples li:hover {
transform: none;
}
nav a {
padding: 0.7rem 0; /* Larger touch target */
}
.footer-column a {
padding: 0.3rem 0;
display: inline-block;
}
}
</style>
</head>
<body>
<header role="banner">
<div class="container header-content">
<a href="/" class="logo" aria-label="Payload CMS MCP Server Home">
<img src="/logopayload.png" alt="Payload CMS MCP Server" class="logo-image" width="60" height="60" loading="eager">
<span class="logo-text">
<strong>Payload CMS MCP Server</strong>
</span>
</a>
<button class="mobile-nav-toggle" aria-label="Toggle navigation menu" aria-expanded="false">
<div class="hamburger-icon">
<span></span>
<span></span>
<span></span>
</div>
</button>
<nav role="navigation" aria-label="Main Navigation">
<ul>
<li><a href="#features">Features</a></li>
<li><a href="#tools">Capabilities</a></li>
<li><a href="#api">Integration</a></li>
<li><a href="#setup">Setup</a></li>
<li><a href="/deployment.html">Deployment Options</a></li>
<li><a href="https://github.com/Matmax-Worldwide/payloadcmsmcp" target="_blank" rel="noopener noreferrer" class="github-link">
<img src="/images/github-icon.svg" alt="GitHub" width="18" height="18" class="nav-icon">
GitHub
</a></li>
</ul>
</nav>
<div class="overlay"></div>
</div>
</header>
<main>
<section class="hero" aria-labelledby="hero-heading">
<div class="container">
<div class="hero-content">
<h1 id="hero-heading">Payload CMS 3.0 MCP Server</h1>
<p>A specialized MCP server for Payload CMS 3.0 that validates code, generates templates, and scaffolds projects following best practices.</p>
<div class="hero-buttons">
<a href="#features" class="btn btn-primary">Explore Features</a>
<a href="#setup" class="btn btn-secondary">Get Started</a>
</div>
</div>
</div>
</section>
<section class="features" id="features" aria-labelledby="features-heading">
<div class="container">
<div class="section-title">
<h2 id="features-heading">Features</h2>
<p>Enhance your Payload CMS 3.0 development with AI that understands the framework's architecture and best practices.</p>
</div>
<div class="features-grid">
<article class="feature-card">
<div class="feature-icon" aria-hidden="true">📚</div>
<h3>Code Validation</h3>
<p>Validate Payload CMS code for collections, fields, globals, and config files with detailed feedback on syntax errors and best practices.</p>
</article>
<article class="feature-card">
<div class="feature-icon" aria-hidden="true">🔍</div>
<h3>Code Generation</h3>
<p>Generate code templates for collections, fields, globals, access control, hooks, endpoints, plugins, blocks, and migrations.</p>
</article>
<article class="feature-card">
<div class="feature-icon" aria-hidden="true">🚀</div>
<h3>Project Scaffolding</h3>
<p>Scaffold entire Payload CMS projects with validated options for consistency and adherence to best practices.</p>
</article>
</div>
</div>
</section>
<section class="tools-section" id="tools" aria-labelledby="tools-heading">
<div class="container">
<div class="section-title">
<h2 id="tools-heading">Payload CMS 3.0 Capabilities</h2>
<p>AI-powered tools to help you build robust Payload CMS 3.0 applications following best practices.</p>
</div>
<div class="tools-grid">
<article class="tool-card">
<h3>Validation Tools</h3>
<ul class="tool-list">
<li><span class="tool-name">validate</span> - Validate code for collections, fields, globals, and config</li>
<li><span class="tool-name">query</span> - Query validation rules and best practices</li>
<li><span class="tool-name">mcp_query</span> - Execute SQL-like queries for Payload CMS structures</li>
</ul>
</article>
<article class="tool-card">
<h3>Code Generation</h3>
<ul class="tool-list">
<li><span class="tool-name">generate_template</span> - Generate code templates for various components</li>
<li><span class="tool-name">generate_collection</span> - Create complete collection definitions</li>
<li><span class="tool-name">generate_field</span> - Generate field definitions with proper typing</li>
</ul>
</article>
<article class="tool-card">
<h3>Project Setup</h3>
<ul class="tool-list">
<li><span class="tool-name">scaffold_project</span> - Create entire Payload CMS project structures</li>
<li><span class="tool-name">validate_scaffold_options</span> - Ensure scaffold options follow best practices</li>
</ul>
</article>
</div>
</div>
</section>
<section class="api-section" id="api" aria-labelledby="api-heading">
<div class="container">
<div class="section-title">
<h2 id="api-heading">Payload CMS 3.0 AI Integration</h2>
<p>Connect to the MCP server to build Payload CMS 3.0 applications with AI that validates code, generates templates, and follows best practices.</p>
</div>
<div class="api-container">
<article class="api-card">
<div class="api-header">
<span class="api-name">Cursor IDE Integration</span>
</div>
<div class="api-description">
Use the MCP server with Cursor IDE to validate Payload CMS 3.0 code, generate templates, and scaffold projects with AI assistance.
</div>
<div class="code-block">
<code>// In Cursor Settings > MCP Servers</code>
<code>Name: "Payload CMS 3.0 MCP"</code>
<code>Transport Type: "Command"</code>
<code></code>
<code>// Option 1: After linking with Railway CLI</code>
<code>Command: railway run</code>
<code></code>
<code>// Option 2: Using API token and service ID</code>
<code>Command: railway run --service=YOUR_SERVICE_ID</code>
</div>
</article>
<article class="api-card">
<div class="api-header">
<span class="api-name">Example Commands</span>
</div>
<div class="api-description">
Once configured, you can use natural language to interact with the Payload CMS MCP Server.
</div>
<ul class="command-examples">
<li>"Validate this collection code for Payload CMS 3.0"</li>
<li>"Generate a template for a blog collection with title, content, and author fields"</li>
<li>"Query validation rules for access control in Payload CMS 3.0"</li>
<li>"Generate a field definition for an image field with validation"</li>
</ul>
</article>
</div>
</div>
</section>
<section class="about-section" id="about" aria-labelledby="about-heading">
<div class="container">
<div class="about-content">
<div class="about-image">
<img src="/00Matmax-world-logo-_1_-svg.png" alt="Matmax Worldwide" width="300" height="300" loading="lazy">
</div>
<div class="about-text">
<h2 id="about-heading">MATMAX WORLDWIDE</h2>
<p>Creating technology that helps humans be more human. We believe in tech for good—tools that enhance our lives while respecting our humanity.</p>
<p>Join us in building a future where technology serves wellness, connection, and purpose. Together, we can create digital experiences that bring out the best in us all.</p>
<a href="https://matmax.world" class="btn" target="_blank" rel="noopener noreferrer">Visit matmax.world</a>
</div>
</div>
</div>
</section>
<section class="setup-section" id="setup" aria-labelledby="setup-heading">
<div class="container">
<div class="section-title">
<h2 id="setup-heading">Getting Started</h2>
<p>Follow these steps to set up and start using the Payload CMS MCP Server.</p>
</div>
<div class="setup-steps">
<div class="setup-step">
<div class="step-number">1</div>
<h3>Prerequisites</h3>
<p>Before you begin, make sure you have:</p>
<ul>
<li>Node.js 18+ (required for Payload CMS 3.0)</li>
<li>npm or yarn package manager</li>
<li>An active Railway account (for Railway deployment)</li>
<li>A Railway API token (create one at <a href="https://railway.app/account/tokens" target="_blank" rel="noopener noreferrer">railway.app/account/tokens</a>)</li>
<li>Basic familiarity with Payload CMS 3.0 concepts</li>
</ul>
</div>
<div class="setup-step">
<div class="step-number">2</div>
<h3>Installation Options</h3>
<p><strong>Option 1:</strong> Install from npm (Recommended)</p>
<div class="code-block">
<code># Install specific version globally</code>
<code>npm install -g payload-cms-mcp@1.0.2</code>
<code></code>
<code># Or install latest version</code>
<code>npm install -g payload-cms-mcp</code>
<code></code>
<code># Run the server</code>
<code>payload-cms-mcp</code>
</div>
<p><strong>Option 2:</strong> Clone the repository</p>
<div class="code-block">
<code># Clone the repository</code>
<code>git clone https://github.com/Matmax-Worldwide/payloadcmsmcp.git</code>
<code>cd payloadcmsmcp</code>
<code></code>
<code># Install dependencies</code>
<code>npm install</code>
<code></code>
<code># Run the development server</code>
<code>npm run dev</code>
</div>
</div>
<div class="setup-step">
<div class="step-number">3</div>
<h3>Configure Cursor</h3>
<p>To use with Cursor IDE:</p>
<ol>
<li>Open Cursor Settings</li>
<li>Go to MCP Servers section</li>
<li>Add a new MCP server</li>
<li>Name it "Payload CMS 3.0 MCP"</li>
<li>Set Transport Type to "Command"</li>
<li>Set Command to one of the following options:</li>
<ul>
<li><strong>For Railway deployment:</strong> <code>railway run</code> (after linking with <code>railway link</code>)</li>
<li><strong>For local installation:</strong> <code>payload-cms-mcp</code> (if installed via npm)</li>
<li><strong>For local repository:</strong> <code>npm run dev</code> (in the repository directory)</li>
</ul>
<li>Save the configuration</li>
</ol>
</div>
<div class="setup-step">
<div class="step-number">4</div>
<h3>Using the MCP Server</h3>
<p>Once configured, you can use these tools in your AI prompts:</p>
<ul>
<li><strong>Code Validation:</strong> "Validate this Payload CMS collection code"</li>
<li><strong>Template Generation:</strong> "Generate a template for a media collection"</li>
<li><strong>Query Rules:</strong> "Query validation rules for access control"</li>
<li><strong>SQL-like Queries:</strong> "Execute a query to find field types for collections"</li>
</ul>
</div>
</div>
</div>
</section>
</main>
<footer role="contentinfo">
<div class="container">
<div class="footer-content">
<div class="footer-column">
<h3>Payload CMS 3.0 Resources</h3>
<ul>
<li><a href="https://github.com/Matmax-Worldwide/payloadcmsmcp" target="_blank" rel="noopener noreferrer">GitHub Repository</a></li>
<li><a href="https://payloadcms.com/docs" target="_blank" rel="noopener noreferrer">Payload CMS 3.0 Docs</a></li>
<li><a href="https://github.com/payloadcms/payload" target="_blank" rel="noopener noreferrer">Payload CMS GitHub</a></li>
<li><a href="https://discord.com/invite/payload" target="_blank" rel="noopener noreferrer">Payload CMS Discord</a></li>
</ul>
</div>
<div class="footer-column">
<h3>Quick Links</h3>
<ul>
<li><a href="#features">Features</a></li>
<li><a href="#tools">Payload CMS 3.0 Capabilities</a></li>
<li><a href="#setup">Getting Started</a></li>
<li><a href="#api">AI Integration</a></li>
</ul>
</div>
<div class="footer-column">
<h3>About Us</h3>
<p>Explore our vision for human-centered technology and join our community dedicated to wellness and meaningful innovation.</p>
<a href="https://matmax.world" class="btn" target="_blank" rel="noopener noreferrer" style="margin-top: 1rem;">Visit matmax.world</a>
</div>
</div>
<div class="footer-bottom">
<p>© 2025 MATMAX WORLDWIDE. Made with ❤️ for humanity.</p>
<div class="social-links">
<a href="https://github.com/Matmax-Worldwide" target="_blank" rel="noopener noreferrer" aria-label="GitHub">
<img src="/images/github-icon.svg" alt="GitHub" width="24" height="24" class="social-icon">
</a>
<a href="https://instagram.com/matmaxyoga" target="_blank" rel="noopener noreferrer" aria-label="Instagram">
<img src="/images/instagram-icon.svg" alt="Instagram" width="24" height="24" class="social-icon">
</a>
<a href="https://www.linkedin.com/company/the-wellness-brand" target="_blank" rel="noopener noreferrer" aria-label="LinkedIn">
<img src="/images/linkedin-icon.svg" alt="LinkedIn" width="24" height="24" class="social-icon">
</a>
</div>
</div>
</div>
</footer>
<!-- Structured data for Organization -->
<script type="application/ld+json">
{
"@context": "https://schema.org",
"@type": "Organization",
"name": "MATMAX WORLDWIDE",
"url": "https://matmax.world",
"logo": "https://www.payloadcmsmcp.info/00Matmax-world-logo-_1_-svg.png",
"sameAs": [
"https://github.com/Matmax-Worldwide",
"https://instagram.com/matmaxyoga",
"https://www.linkedin.com/company/the-wellness-brand"
],
"subOrganization": {
"@type": "Organization",
"name": "Payload CMS MCP Server",
"url": "https://www.payloadcmsmcp.info/",
"logo": "https://www.payloadcmsmcp.info/00Matmax-world-logo-_1_-svg.png"
}
}
</script>
<script>
// Smooth scrolling for navigation links
document.addEventListener('DOMContentLoaded', function() {
const navLinks = document.querySelectorAll('nav a[href^="#"]');
const footerLinks = document.querySelectorAll('.footer-column a[href^="#"]');
const heroButtons = document.querySelectorAll('.hero-buttons a[href^="#"]');
const allLinks = [...navLinks, ...footerLinks, ...heroButtons];
allLinks.forEach(link => {
link.addEventListener('click', function(e) {
e.preventDefault();
const targetId = this.getAttribute('href');
const targetElement = document.querySelector(targetId);
if (targetElement) {
const headerHeight = document.querySelector('header').offsetHeight;
const targetPosition = targetElement.getBoundingClientRect().top + window.pageYOffset - headerHeight;
window.scrollTo({
top: targetPosition,
behavior: 'smooth'
});
// Close mobile menu if open
if (document.querySelector('nav').classList.contains('active')) {
toggleMobileNav();
}
}
});
});
// Mobile Navigation Toggle
const mobileNavToggle = document.querySelector('.mobile-nav-toggle');
const nav = document.querySelector('nav');
const overlay = document.querySelector('.overlay');
const body = document.body;
function toggleMobileNav() {
mobileNavToggle.classList.toggle('active');
nav.classList.toggle('active');
overlay.classList.toggle('active');
body.classList.toggle('no-scroll');
// Update aria-expanded attribute
const isExpanded = mobileNavToggle.getAttribute('aria-expanded') === 'true';
mobileNavToggle.setAttribute('aria-expanded', !isExpanded);
// Add focus trap for accessibility
if (nav.classList.contains('active')) {
// Focus the first link in the menu
setTimeout(() => {
nav.querySelector('a').focus();
}, 100);
}
}
mobileNavToggle.addEventListener('click', toggleMobileNav);
overlay.addEventListener('click', toggleMobileNav);
// Close menu when pressing Escape key
document.addEventListener('keydown', function(e) {
if (e.key === 'Escape' && nav.classList.contains('active')) {
toggleMobileNav();
}
});
// Handle window resize
window.addEventListener('resize', function() {
if (window.innerWidth > 768 && nav.classList.contains('active')) {
toggleMobileNav();
}
});
// Prevent body scrolling when menu is open
function preventScroll(e) {
if (body.classList.contains('no-scroll')) {
e.preventDefault();
}
}
// Apply to touch devices
document.addEventListener('touchmove', preventScroll, { passive: false });
});
// Add no-scroll class to body
document.head.insertAdjacentHTML('beforeend', `
<style>
.no-scroll {
overflow: hidden;
position: fixed;
width: 100%;
height: 100%;
}
@media (prefers-reduced-motion: reduce) {
* {
transition: none !important;
animation: none !important;
scroll-behavior: auto !important;
}
}
</style>
`);
</script>
</body>
</html>